xref: /plugin/openlayersmap/ol/ol.js.map (revision cc295f62a6b98a71ec272f5cdffbe023a53befec)
1{"version":3,"file":"ol.js","sources":["../ol/CollectionEventType.js","../ol/ObjectEventType.js","../ol/obj.js","../ol/events.js","../ol/events/EventType.js","../ol/Disposable.js","../ol/array.js","../ol/functions.js","../ol/events/Event.js","../ol/events/Target.js","../ol/Observable.js","../ol/util.js","../ol/Object.js","../ol/Collection.js","../ol/TileState.js","../ol/easing.js","../ol/Tile.js","../ol/has.js","../ol/dom.js","../ol/DataTile.js","../ol/asserts.js","../ol/Feature.js","../ol/extent/Relationship.js","../ol/extent.js","../ol/math.js","../ol/sphere.js","../ol/console.js","../ol/string.js","../ol/coordinate.js","../ol/proj/Units.js","../ol/proj/Projection.js","../ol/proj/epsg3857.js","../ol/proj/epsg4326.js","../ol/proj/projections.js","../ol/proj/transforms.js","../ol/proj/utm.js","../ol/proj.js","../ol/transform.js","../ol/geom/flat/transform.js","../ol/geom/Geometry.js","../ol/geom/SimpleGeometry.js","../ol/geom/flat/area.js","../ol/geom/flat/closest.js","../ol/geom/flat/deflate.js","../ol/geom/flat/inflate.js","../ol/geom/flat/simplify.js","../ol/geom/LinearRing.js","../ol/geom/Point.js","../ol/geom/flat/contains.js","../ol/geom/flat/interiorpoint.js","../ol/geom/flat/segments.js","../ol/geom/flat/intersectsextent.js","../ol/geom/flat/reverse.js","../ol/geom/flat/orient.js","../ol/geom/Polygon.js","../ol/Geolocation.js","../ol/ImageState.js","../ol/Image.js","../ol/ImageCanvas.js","../ol/ImageTile.js","../ol/Kinetic.js","../ol/MapEvent.js","../ol/MapBrowserEvent.js","../ol/MapBrowserEventType.js","../ol/pointer/EventType.js","../ol/MapBrowserEventHandler.js","../ol/MapEventType.js","../ol/MapProperty.js","../ol/structs/PriorityQueue.js","../ol/TileQueue.js","../ol/ViewHint.js","../ol/ViewProperty.js","../ol/centerconstraint.js","../ol/resolutionconstraint.js","../ol/rotationconstraint.js","../ol/tilegrid/common.js","../ol/View.js","../ol/css.js","../ol/control/Control.js","../ol/control/Attribution.js","../ol/control/Rotate.js","../ol/control/Zoom.js","../ol/control/defaults.js","../ol/interaction/Property.js","../ol/interaction/Interaction.js","../ol/interaction/DoubleClickZoom.js","../ol/events/condition.js","../ol/interaction/Pointer.js","../ol/interaction/DragPan.js","../ol/interaction/DragRotate.js","../ol/render/Box.js","../ol/interaction/DragBox.js","../ol/interaction/DragZoom.js","../ol/events/Key.js","../ol/interaction/KeyboardPan.js","../ol/interaction/KeyboardZoom.js","../ol/interaction/MouseWheelZoom.js","../ol/interaction/PinchRotate.js","../ol/interaction/PinchZoom.js","../ol/interaction/defaults.js","../ol/layer/Property.js","../ol/layer/Base.js","../ol/layer/Group.js","../ol/render/EventType.js","../ol/layer/Layer.js","../../node_modules/quickselect/index.js","../../node_modules/rbush/index.js","../ol/color.js","../ol/size.js","../ol/expr/expression.js","../ol/expr/cpu.js","../ol/style/IconImageCache.js","../ol/style/IconImage.js","../ol/colorlike.js","../ol/render/canvas.js","../ol/style/Image.js","../ol/style/RegularShape.js","../ol/style/Circle.js","../ol/style/Fill.js","../ol/style/Icon.js","../ol/style/Stroke.js","../ol/style/Style.js","../ol/style/Text.js","../ol/render/canvas/style.js","../ol/layer/BaseVector.js","../ol/render/Event.js","../ol/renderer/Map.js","../ol/renderer/Composite.js","../ol/Map.js","../ol/Overlay.js","../ol/TileRange.js","../ol/VectorRenderTile.js","../ol/featureloader.js","../ol/net.js","../ol/loadingstrategy.js","../ol/geom/flat/lineoffset.js","../ol/render/VectorContext.js","../ol/render/canvas/Immediate.js","../ol/renderer/vector.js","../ol/render.js","../ol/reproj.js","../ol/resolution.js","../ol/structs/LRUCache.js","../ol/tilecoord.js","../ol/uri.js","../ol/reproj/Triangulation.js","../ol/reproj/common.js","../ol/reproj/Image.js","../ol/source/Source.js","../ol/source/common.js","../ol/source/Image.js","../ol/source/arcgisRest.js","../ol/tilegrid/TileGrid.js","../ol/tilegrid/WMTS.js","../ol/tilegrid.js","../ol/tileurlfunction.js","../ol/reproj/Tile.js","../ol/source/Tile.js","../ol/source/TileEventType.js","../ol/source/UrlTile.js","../ol/source/TileImage.js","../ol/source/BingMaps.js","../ol/source/XYZ.js","../ol/geom/flat/interpolate.js","../ol/geom/flat/length.js","../ol/geom/LineString.js","../ol/geom/MultiLineString.js","../ol/geom/MultiPoint.js","../ol/geom/flat/center.js","../ol/geom/MultiPolygon.js","../ol/render/Feature.js","../ol/structs/RBush.js","../ol/source/VectorEventType.js","../ol/source/Vector.js","../ol/vec/mat4.js","../ol/webgl/Canvas.js","../ol/reproj/glreproj.js","../ol/reproj/DataTile.js","../ol/source/DataTile.js","../ol/proj/proj4.js","../ol/source/static.js","../ol/source/ImageTile.js","../ol/source/wms.js","../ol/source/ogcTileUtil.js","../ol/source/OSM.js","../ol/render/canvas/ZIndexContext.js","../ol/renderer/Layer.js","../ol/renderer/canvas/Layer.js","../ol/renderer/canvas/ImageLayer.js","../ol/layer/BaseImage.js","../ol/layer/Image.js","../ol/renderer/canvas/TileLayer.js","../ol/layer/TileProperty.js","../ol/layer/BaseTile.js","../ol/layer/Tile.js","../ol/source/Raster.js","../ol/source/StadiaMaps.js","../ol/source/UTFGrid.js","../ol/xml.js","../ol/style/flat.js","../ol/render/canvas/Instruction.js","../ol/render/canvas/Builder.js","../ol/render/canvas/ImageBuilder.js","../ol/render/canvas/LineStringBuilder.js","../ol/render/canvas/PolygonBuilder.js","../ol/geom/flat/linechunk.js","../ol/geom/flat/straightchunk.js","../ol/render/canvas/TextBuilder.js","../ol/render/canvas/BuilderGroup.js","../ol/geom/flat/textpath.js","../ol/render/canvas/Executor.js","../ol/render/canvas/ExecutorGroup.js","../ol/render/canvas/hitdetect.js","../ol/renderer/canvas/VectorLayer.js","../ol/renderer/canvas/VectorImageLayer.js","../ol/geom/flat/geodesic.js","../ol/layer/Vector.js","../ol/layer/Graticule.js","../ol/webgl.js","../ol/webgl/Buffer.js","../ol/webgl/ContextEventType.js","../ol/webgl/PostProcessingPass.js","../ol/webgl/Helper.js","../ol/renderer/webgl/Layer.js","../ol/renderer/webgl/TileLayer.js","../ol/webgl/PaletteTexture.js","../ol/expr/gpu.js","../ol/render/webgl/compileUtil.js","../ol/render/webgl/float64Util.js","../ol/render/webgl/ShaderBuilder.js","../ol/render/webgl/MixedGeometryBatch.js","../ol/render/webgl/constants.js","../ol/render/webgl/renderinstructions.js","../ol/render/webgl/style.js","../ol/render/webgl/VectorStyleRenderer.js","../ol/worker/webgl.js","../ol/render/webgl/encodeUtil.js","../ol/webgl/RenderTarget.js","../ol/renderer/webgl/vectorUtil.js","../ol/renderer/webgl/VectorLayer.js","../ol/renderer/webgl/worldUtil.js","../ol/layer/Heatmap.js","../ol/interaction/DragAndDrop.js","../ol/geom/Circle.js","../ol/geom/GeometryCollection.js","../ol/interaction/tracing.js","../ol/interaction/Draw.js","../ol/interaction/Extent.js","../ol/interaction/Link.js","../ol/interaction/Modify.js","../ol/interaction/Select.js","../ol/events/SnapEvent.js","../ol/interaction/Snap.js","../ol/interaction/Translate.js","../ol/geom/flat/flip.js","../ol/format/Feature.js","../ol/format/XMLFeature.js","../ol/format/xsd.js","../ol/format/GPX.js","../ol/format/JSONFeature.js","../ol/format/GeoJSON.js","../ol/format/TextFeature.js","../ol/format/IGC.js","../ol/format/KML.js","../../node_modules/pbf/index.js","../ol/format/MVT.js","../ol/format/OSMXML.js","../ol/format/XML.js","../ol/format/xlink.js","../ol/format/OWS.js","../ol/format/Polyline.js","../ol/format/TopoJSON.js","../ol/format/GMLBase.js","../ol/format/GML2.js","../ol/format/GML3.js","../ol/format/GML32.js","../ol/format/filter/Filter.js","../ol/format/filter/LogicalNary.js","../ol/format/filter/And.js","../ol/format/filter/Bbox.js","../ol/format/WFS.js","../ol/format/WMTSCapabilities.js","../ol/control/FullScreen.js","../ol/control/MousePosition.js","../ol/control/OverviewMap.js","../ol/control/ScaleLine.js","../ol/control/ZoomSlider.js","../ol/dist/ol.js","../ol/control/ZoomToExtent.js","../ol/format/filter.js","../ol/format/WMSGetFeatureInfo.js","../ol/geom/flat/topology.js","../ol/interaction/DblClickDragZoom.js","../ol/interaction/DragRotateAndZoom.js","../ol/layer/VectorImage.js","../ol/source/Cluster.js","../ol/source/Google.js","../ol/source/ImageArcGISRest.js","../ol/source/ImageCanvas.js","../ol/source/ImageStatic.js","../ol/source/ImageWMS.js","../ol/source/TileArcGISRest.js","../ol/source/TileDebug.js","../ol/source/TileJSON.js","../ol/source/TileWMS.js","../ol/source/WMTS.js","../ol/source/mapserver.js","../ol/source.js"],"sourcesContent":["/**\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/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/obj\n */\n\n/**\n * Removes all properties from an object.\n * @param {Object<string, unknown>} object The object to clear.\n */\nexport function clear(object) {\n  for (const property in object) {\n    delete object[property];\n  }\n}\n\n/**\n * Determine if an object has any properties.\n * @param {Object} object The object to check.\n * @return {boolean} The object is empty.\n */\nexport function isEmpty(object) {\n  let property;\n  for (property in object) {\n    return false;\n  }\n  return !property;\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     * @param {Event|import('./events/Event.js').default} event The event\n     * @return {void|boolean} When the function returns `false`, event propagation will stop.\n     * @this {typeof target}\n     */\n    listener = function (event) {\n      target.removeEventListener(type, listener);\n      return originalListener.call(thisArg ?? this, event);\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/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/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/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<number>} 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<VALUE>} arr The array to modify.\n * @param {!Array<VALUE>|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<VALUE>} 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<any>|Uint8ClampedArray} arr1 The first array to compare.\n * @param {Array<any>|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 * @deprecated\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/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<any>|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<T>)} getter A function that returns a value or a promise for a value.\n * @return {Promise<T>} 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/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/Target\n */\nimport Disposable from '../Disposable.js';\nimport {VOID} from '../functions.js';\nimport {clear} from '../obj.js';\nimport Event from './Event.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<string, number>|null}\n     */\n    this.pendingRemovals_ = null;\n\n    /**\n     * @private\n     * @type {Object<string, number>|null}\n     */\n    this.dispatching_ = null;\n\n    /**\n     * @private\n     * @type {Object<string, Array<import(\"../events.js\").Listener>>|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<import(\"../events.js\").Listener>|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/Observable\n */\nimport {listen, listenOnce, unlistenByKey} from './events.js';\nimport EventType from './events/EventType.js';\nimport EventTarget from './events/Target.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.js\").default) => ?) => Return extends void ? void : Return[]} CombinedOnSignature\n */\n\n/**\n * @typedef {'change'|'error'} EventTypes\n */\n\n/***\n * @template Return\n * @typedef {OnSignature<EventTypes, import(\"./events/Event.js\").default, Return> & CombinedOnSignature<EventTypes, Return>} 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<import(\"./events.js\").EventsKey>} */ (\n        this.onInternal\n      );\n\n    this.once =\n      /** @type {ObservableOnSignature<import(\"./events.js\").EventsKey>} */ (\n        this.onceInternal\n      );\n\n    this.un = /** @type {ObservableOnSignature<void>} */ (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<string>} type Type.\n   * @param {function((Event|import(\"./events/Event.js\").default)): ?} listener Listener.\n   * @return {import(\"./events.js\").EventsKey|Array<import(\"./events.js\").EventsKey>} 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<string>} type Type.\n   * @param {function((Event|import(\"./events/Event.js\").default)): ?} listener Listener.\n   * @return {import(\"./events.js\").EventsKey|Array<import(\"./events.js\").EventsKey>} 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<string>} type Type.\n   * @param {function((Event|import(\"./events/Event.js\").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<string>} type The event type or array of event types.\n * @param {function((Event|import(\"./events/Event.js\").default)): ?} listener The listener function.\n * @return {import(\"./events.js\").EventsKey|Array<import(\"./events.js\").EventsKey>} 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<string>} type The event type or array of event types.\n * @param {function((Event|import(\"./events/Event.js\").default)): ?} listener The listener function.\n * @return {import(\"./events.js\").EventsKey|Array<import(\"./events.js\").EventsKey>} 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<string>} type The event type or array of event types.\n * @param {function((Event|import(\"./events/Event.js\").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<import(\"./events.js\").EventsKey>} 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/util\n */\n\n/**\n * @return {never} Any return.\n */\nexport function abstract() {\n  throw new Error('Unimplemented abstract method.');\n}\n\n/**\n * Counter for getUid.\n * @type {number}\n * @private\n */\nlet uidCounter_ = 0;\n\n/**\n * Gets a unique ID for an object. This mutates the object so that further calls\n * with the same object as a parameter returns the same value. Unique IDs are generated\n * as a strictly increasing sequence. Adapted from goog.getUid.\n *\n * @param {Object} obj The object to get the unique ID for.\n * @return {string} The unique ID for the object.\n * @api\n */\nexport function getUid(obj) {\n  return obj.ol_uid || (obj.ol_uid = String(++uidCounter_));\n}\n\n/**\n * OpenLayers version.\n * @type {string}\n */\nexport const VERSION = '10.9.0';\n","/**\n * @module ol/Object\n */\nimport ObjectEventType from './ObjectEventType.js';\nimport Observable from './Observable.js';\nimport Event from './events/Event.js';\nimport {isEmpty} from './obj.js';\nimport {getUid} from './util.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.js\").OnSignature<import(\"./Observable.js\").EventTypes, import(\"./events/Event.js\").default, Return> &\n *    import(\"./Observable.js\").OnSignature<import(\"./ObjectEventType.js\").Types, ObjectEvent, Return> &\n *    import(\"./Observable.js\").CombinedOnSignature<import(\"./Observable.js\").EventTypes|import(\"./ObjectEventType.js\").Types, Return>} 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 * @template {Object<string, *>} [Properties=Object<string, *>]\n * @api\n */\nclass BaseObject extends Observable {\n  /**\n   * @param {NoInfer<Properties>} [values] An object with key-value pairs.\n   */\n  constructor(values) {\n    super();\n\n    /***\n     * @type {ObjectOnSignature<import(\"./events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {ObjectOnSignature<import(\"./events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {ObjectOnSignature<void>}\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 {Partial<NoInfer<Properties>>|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<string>} 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 {NoInfer<Properties>} Object.\n   * @api\n   */\n  getProperties() {\n    return /** @type {NoInfer<Properties>} */ (\n      (this.values_ && Object.assign({}, this.values_)) || {}\n    );\n  }\n\n  /**\n   * Get an object of all property names and values.\n   * @return {Partial<NoInfer<Properties>>?} 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 {Partial<NoInfer<Properties>>} 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/Collection\n */\nimport CollectionEventType from './CollectionEventType.js';\nimport BaseObject from './Object.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.js\").OnSignature<import(\"./Observable.js\").EventTypes, import(\"./events/Event.js\").default, Return> &\n *   import(\"./Observable.js\").OnSignature<import(\"./ObjectEventType.js\").Types|'change:length', import(\"./Object.js\").ObjectEvent, Return> &\n *   import(\"./Observable.js\").OnSignature<'add'|'remove', CollectionEvent<T>, Return> &\n *   import(\"./Observable.js\").CombinedOnSignature<import(\"./Observable.js\").EventTypes|import(\"./ObjectEventType.js\").Types|\n *     'change:length'|'add'|'remove',Return>} 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<T>} [array] Array.\n   * @param {Options} [options] Collection options.\n   */\n  constructor(array, options) {\n    super();\n\n    /***\n     * @type {CollectionOnSignature<T, import(\"./events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {CollectionOnSignature<T, import(\"./events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {CollectionOnSignature<T, void>}\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<T>}\n     */\n    this.array_ = array ?? [];\n\n    if (this.unique_) {\n      for (let i = 1, 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<T>} arr Array.\n   * @return {Collection<T>} 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<T>): *} 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<T>} 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    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<T>} */ (\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<T>} */ (\n        new CollectionEvent(CollectionEventType.REMOVE, prev, index)\n      ),\n    );\n    this.dispatchEvent(\n      /** @type {CollectionEvent<T>} */ (\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    const array = this.array_;\n    for (let i = 0, ii = array.length; i < ii; ++i) {\n      if (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/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/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/Tile\n */\nimport TileState from './TileState.js';\nimport {easeIn} from './easing.js';\nimport EventType from './events/EventType.js';\nimport EventTarget from './events/Target.js';\nimport {abstract} from './util.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<string, number>}\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    // to remove the `change` listener on this tile in `ol/TileQueue#handleTileChange`\n    this.setState(TileState.EMPTY);\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.EMPTY) {\n      // no more state changes\n      return;\n    }\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  /**\n   * @override\n   */\n  disposeInternal() {\n    this.release();\n    super.disposeInternal();\n  }\n}\n\nexport default Tile;\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 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 {\n    // passive not supported\n  }\n  return passive;\n})();\n","import {WORKER_OFFSCREEN_CANVAS} from './has.js';\n\n/**\n * @module ol/dom\n */\n\n/**\n * @typedef {Object} ImageAttributes\n * @property {string|null} [crossOrigin] Cross origin.\n * @property {ReferrerPolicy} [referrerPolicy]  Referrer policy.\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<HTMLCanvasElement|OffscreenCanvas>} [canvasPool] Canvas pool to take existing canvas from.\n * @param {CanvasRenderingContext2DSettings} [settings] CanvasRenderingContext2DSettings\n * @return {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} 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 (class extends OffscreenCanvas {\n      style = {};\n    })(width ?? 300, height ?? 150);\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  return /** @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} */ (\n    canvas.getContext('2d', settings)\n  );\n}\n\n/**\n * @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D}\n */\nlet sharedCanvasContext;\n\n/**\n * @return {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} 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|OffscreenCanvasRenderingContext2D} 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<Node>} 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/**\n * Creates a minimal structure that mocks a DIV to be used by the composite and\n * layer renderer in a worker environment\n * @return {HTMLDivElement} mocked DIV\n */\nexport function createMockDiv() {\n  const mockedDiv = new Proxy(\n    {\n      /**\n       * @type {Array<HTMLElement>}\n       */\n      childNodes: [],\n      /**\n       * @param {HTMLElement} node html node.\n       * @return {HTMLElement} html node.\n       */\n      appendChild: function (node) {\n        this.childNodes.push(node);\n        return node;\n      },\n      /**\n       * dummy function, as this structure is not supposed to have a parent.\n       */\n      remove: function () {},\n      /**\n       * @param {HTMLElement} node html node.\n       * @return {HTMLElement} html node.\n       */\n      removeChild: function (node) {\n        const index = this.childNodes.indexOf(node);\n        if (index === -1) {\n          throw new Error('Node to remove was not found');\n        }\n        this.childNodes.splice(index, 1);\n        return node;\n      },\n      /**\n       * @param {HTMLElement} newNode new html node.\n       * @param {HTMLElement} referenceNode reference html node.\n       * @return {HTMLElement} new html node.\n       */\n      insertBefore: function (newNode, referenceNode) {\n        const index = this.childNodes.indexOf(referenceNode);\n        if (index === -1) {\n          throw new Error('Reference node not found');\n        }\n        this.childNodes.splice(index, 0, newNode);\n        return newNode;\n      },\n      style: {},\n    },\n    {\n      get(target, prop, receiver) {\n        if (prop === 'firstElementChild') {\n          return target.childNodes.length > 0 ? target.childNodes[0] : null;\n        }\n        return Reflect.get(target, prop, receiver);\n      },\n    },\n  );\n  return /** @type {HTMLDivElement} */ (/** @type {*} */ (mockedDiv));\n}\n\n/***\n * @param {*} obj The object to check.\n * @return {obj is (HTMLCanvasElement | OffscreenCanvas)} The object is a canvas.\n */\nexport function isCanvas(obj) {\n  return (\n    (typeof HTMLCanvasElement !== 'undefined' &&\n      obj instanceof HTMLCanvasElement) ||\n    (typeof OffscreenCanvas !== 'undefined' && obj instanceof OffscreenCanvas)\n  );\n}\n","/**\n * @module ol/DataTile\n */\nimport Tile from './Tile.js';\nimport TileState from './TileState.js';\nimport {createCanvasContext2D} from './dom.js';\n\n/**\n * @typedef {HTMLImageElement|HTMLCanvasElement|OffscreenCanvas|HTMLVideoElement|ImageBitmap} ImageLike\n */\n\n/**\n * @typedef {Uint8Array|Uint8ClampedArray|Float32Array|DataView} ArrayLike\n */\n\n/**\n * Data that can be used with a DataTile.\n * @typedef {ArrayLike|ImageLike} Data\n */\n\n/**\n * @param {Data} data Tile data.\n * @return {ImageLike|null} The image-like data.\n */\nexport function asImageLike(data) {\n  return data instanceof Image ||\n    data instanceof HTMLCanvasElement ||\n    data instanceof HTMLVideoElement ||\n    data instanceof ImageBitmap\n    ? data\n    : null;\n}\n\n/**\n * @param {Data} data Tile data.\n * @return {ArrayLike|null} The array-like data.\n */\nexport function asArrayLike(data) {\n  return data instanceof Uint8Array ||\n    data instanceof Uint8ClampedArray ||\n    data instanceof Float32Array ||\n    data instanceof DataView\n    ? data\n    : null;\n}\n\n/**\n * This is set as the cancellation reason when a tile is disposed.\n */\nexport const disposedError = new Error('disposed');\n\n/**\n * @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D|null}\n */\nlet sharedContext = null;\n\n/**\n * @param {ImageLike} image The image.\n * @return {Uint8ClampedArray} The data.\n */\nexport function toArray(image) {\n  if (!sharedContext) {\n    sharedContext = createCanvasContext2D(\n      image.width,\n      image.height,\n      undefined,\n      {willReadFrequently: true},\n    );\n  }\n  const canvas = sharedContext.canvas;\n  const width = image.width;\n  if (canvas.width !== width) {\n    canvas.width = width;\n  }\n  const height = image.height;\n  if (canvas.height !== height) {\n    canvas.height = height;\n  }\n  sharedContext.clearRect(0, 0, width, height);\n  sharedContext.drawImage(image, 0, 0);\n  return sharedContext.getImageData(0, 0, width, height).data;\n}\n\n/**\n * @type {import('./size.js').Size}\n */\nconst defaultSize = [256, 256];\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @property {function(): Promise<Data>} loader Data loader.  For loaders that generate images,\n * the promise should not resolve until the image is loaded.\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 * @property {import('./size.js').Size} [size=[256, 256]] Tile size.\n * @property {AbortController} [controller] An abort controller.\n * @api\n */\n\nclass DataTile extends Tile {\n  /**\n   * @param {Options} options Tile options.\n   */\n  constructor(options) {\n    const state = TileState.IDLE;\n\n    super(options.tileCoord, state, {\n      transition: options.transition,\n      interpolate: options.interpolate,\n    });\n\n    /**\n     * @type {function(): Promise<Data>}\n     * @private\n     */\n    this.loader_ = options.loader;\n\n    /**\n     * @type {Data}\n     * @private\n     */\n    this.data_ = null;\n\n    /**\n     * @type {Error}\n     * @private\n     */\n    this.error_ = null;\n\n    /**\n     * @type {import('./size.js').Size|null}\n     * @private\n     */\n    this.size_ = options.size || null;\n\n    /**\n     * @type {AbortController|null}\n     * @private\n     */\n    this.controller_ = options.controller || null;\n  }\n\n  /**\n   * Get the tile size.\n   * @return {import('./size.js').Size} Tile size.\n   */\n  getSize() {\n    if (this.size_) {\n      return this.size_;\n    }\n    const imageData = asImageLike(this.data_);\n    if (imageData) {\n      return [imageData.width, imageData.height];\n    }\n    return defaultSize;\n  }\n\n  /**\n   * Get the data for the tile.\n   * @return {Data} Tile data.\n   * @api\n   */\n  getData() {\n    return this.data_;\n  }\n\n  /**\n   * Get any loading error.\n   * @return {Error} Loading error.\n   * @api\n   */\n  getError() {\n    return this.error_;\n  }\n\n  /**\n   * Load the tile data.\n   * @api\n   * @override\n   */\n  load() {\n    if (this.state !== TileState.IDLE && this.state !== TileState.ERROR) {\n      return;\n    }\n    this.state = TileState.LOADING;\n    this.changed();\n\n    const self = this;\n    this.loader_()\n      .then(function (data) {\n        self.data_ = data;\n        self.state = TileState.LOADED;\n        self.changed();\n      })\n      .catch(function (error) {\n        self.error_ = error;\n        self.state = TileState.ERROR;\n        self.changed();\n      });\n  }\n\n  /**\n   * Clean up.\n   * @override\n   */\n  disposeInternal() {\n    if (this.controller_) {\n      this.controller_.abort(disposedError);\n      this.controller_ = null;\n    }\n    super.disposeInternal();\n  }\n}\n\nexport default DataTile;\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 * @module ol/Feature\n */\nimport BaseObject from './Object.js';\nimport {assert} from './asserts.js';\nimport {listen, unlistenByKey} from './events.js';\nimport EventType from './events/EventType.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.js\").OnSignature<import(\"./Observable.js\").EventTypes, import(\"./events/Event.js\").default, Return> &\n *   import(\"./Observable.js\").OnSignature<import(\"./ObjectEventType.js\").Types|'change:geometry', import(\"./Object.js\").ObjectEvent, Return> &\n *   import(\"./Observable.js\").CombinedOnSignature<import(\"./Observable.js\").EventTypes|import(\"./ObjectEventType.js\").Types\n *     |'change:geometry', Return>} FeatureOnSignature\n */\n\n/***\n * @template {import(\"./geom/Geometry.js\").default} [Geometry=import(\"./geom/Geometry.js\").default]\n * @template {Object<string, *>} [Properties=Object<string, *>]\n * @typedef {Properties & { 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 * @template {Object<string, *>} [Properties=Object<string, *>]\n * @extends {BaseObject<NoInfer<Properties>>}\n */\nclass Feature extends BaseObject {\n  /**\n   * @param {Geometry|ObjectWithGeometry<Geometry, NoInfer<Properties>>} [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<import(\"./events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {FeatureOnSignature<import(\"./events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {FeatureOnSignature<void>}\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 {?} */\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<Geometry>} The clone.\n   * @api\n   */\n  clone() {\n    const clone = /** @type {Feature<Geometry>} */ (new Feature());\n    const geometryName = this.geometryName_;\n    clone.setGeometryName(geometryName);\n\n    const properties = this.getPropertiesInternal();\n    if (properties) {\n      const geometry = this.getGeometry();\n      for (const key in properties) {\n        if (key === geometryName && geometry) {\n          clone.set(key, geometry.clone());\n        } else {\n          clone.set(key, properties[key], true);\n        }\n      }\n    }\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    if (name === this.geometryName_) {\n      return;\n    }\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>|!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<import(\"./style/Style.js\").default>}\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/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/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<number>} 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<import(\"./coordinate.js\").Coordinate>} 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<number>} xs Xs.\n * @param {Array<number>} 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<import(\"./coordinate.js\").Coordinate>} 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<number>} 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<Array<import(\"./coordinate.js\").Coordinate>>} 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<import(\"./coordinate.js\").Coordinate>} 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<number>} 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<Array<import(\"./coordinate.js\").Coordinate>>} 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<number>} 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<Extent>} 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/math\n */\n\n/**\n * Takes a number and clamps it to within the provided bounds.\n * @param {number} value The input number.\n * @param {number} min The minimum value to return.\n * @param {number} max The maximum value to return.\n * @return {number} The input number if it is within bounds, or the nearest\n *     number within the bounds.\n */\nexport function clamp(value, min, max) {\n  return Math.min(Math.max(value, min), max);\n}\n\n/**\n * Returns the square of the closest distance between the point (x, y) and the\n * line segment (x1, y1) to (x2, y2).\n * @param {number} x X.\n * @param {number} y Y.\n * @param {number} x1 X1.\n * @param {number} y1 Y1.\n * @param {number} x2 X2.\n * @param {number} y2 Y2.\n * @return {number} Squared distance.\n */\nexport function squaredSegmentDistance(x, y, x1, y1, x2, y2) {\n  const dx = x2 - x1;\n  const dy = y2 - y1;\n  if (dx !== 0 || dy !== 0) {\n    const t = ((x - x1) * dx + (y - y1) * dy) / (dx * dx + dy * dy);\n    if (t > 1) {\n      x1 = x2;\n      y1 = y2;\n    } else if (t > 0) {\n      x1 += dx * t;\n      y1 += dy * t;\n    }\n  }\n  return squaredDistance(x, y, x1, y1);\n}\n\n/**\n * Returns the square of the distance between the points (x1, y1) and (x2, y2).\n * @param {number} x1 X1.\n * @param {number} y1 Y1.\n * @param {number} x2 X2.\n * @param {number} y2 Y2.\n * @return {number} Squared distance.\n */\nexport function squaredDistance(x1, y1, x2, y2) {\n  const dx = x2 - x1;\n  const dy = y2 - y1;\n  return dx * dx + dy * dy;\n}\n\n/**\n * Solves system of linear equations using Gaussian elimination method.\n *\n * @param {Array<Array<number>>} mat Augmented matrix (n x n + 1 column)\n *                                     in row-major order.\n * @return {Array<number>|null} The resulting vector.\n */\nexport function solveLinearSystem(mat) {\n  const n = mat.length;\n\n  for (let i = 0; i < n; i++) {\n    // Find max in the i-th column (ignoring i - 1 first rows)\n    let maxRow = i;\n    let maxEl = Math.abs(mat[i][i]);\n    for (let r = i + 1; r < n; r++) {\n      const absValue = Math.abs(mat[r][i]);\n      if (absValue > maxEl) {\n        maxEl = absValue;\n        maxRow = r;\n      }\n    }\n\n    if (maxEl === 0) {\n      return null; // matrix is singular\n    }\n\n    // Swap max row with i-th (current) row\n    const tmp = mat[maxRow];\n    mat[maxRow] = mat[i];\n    mat[i] = tmp;\n\n    // Subtract the i-th row to make all the remaining rows 0 in the i-th column\n    for (let j = i + 1; j < n; j++) {\n      const coef = -mat[j][i] / mat[i][i];\n      for (let k = i; k < n + 1; k++) {\n        if (i == k) {\n          mat[j][k] = 0;\n        } else {\n          mat[j][k] += coef * mat[i][k];\n        }\n      }\n    }\n  }\n\n  // Solve Ax=b for upper triangular matrix A (mat)\n  const x = new Array(n);\n  for (let l = n - 1; l >= 0; l--) {\n    x[l] = mat[l][n] / mat[l][l];\n    for (let m = l - 1; m >= 0; m--) {\n      mat[m][n] -= mat[m][l] * x[l];\n    }\n  }\n  return x;\n}\n\n/**\n * Converts radians to to degrees.\n *\n * @param {number} angleInRadians Angle in radians.\n * @return {number} Angle in degrees.\n */\nexport function toDegrees(angleInRadians) {\n  return (angleInRadians * 180) / Math.PI;\n}\n\n/**\n * Converts degrees to radians.\n *\n * @param {number} angleInDegrees Angle in degrees.\n * @return {number} Angle in radians.\n */\nexport function toRadians(angleInDegrees) {\n  return (angleInDegrees * Math.PI) / 180;\n}\n\n/**\n * Returns the modulo of a / b, depending on the sign of b.\n *\n * @param {number} a Dividend.\n * @param {number} b Divisor.\n * @return {number} Modulo.\n */\nexport function modulo(a, b) {\n  const r = a % b;\n  return r * b < 0 ? r + b : r;\n}\n\n/**\n * Calculates the linearly interpolated value of x between a and b.\n *\n * @param {number} a Number\n * @param {number} b Number\n * @param {number} x Value to be interpolated.\n * @return {number} Interpolated value.\n */\nexport function lerp(a, b, x) {\n  return a + x * (b - a);\n}\n\n/**\n * Returns a number with a limited number of decimal digits.\n * @param {number} n The input number.\n * @param {number} decimals The maximum number of decimal digits.\n * @return {number} The input number with a limited number of decimal digits.\n */\nexport function toFixed(n, decimals) {\n  const factor = Math.pow(10, decimals);\n  return Math.round(n * factor) / factor;\n}\n\n/**\n * Rounds a number to the nearest integer value considering only the given number\n * of decimal digits (with rounding on the final digit).\n * @param {number} n The input number.\n * @param {number} decimals The maximum number of decimal digits.\n * @return {number} The nearest integer.\n */\nexport function round(n, decimals) {\n  return Math.round(toFixed(n, decimals));\n}\n\n/**\n * Rounds a number to the next smaller integer considering only the given number\n * of decimal digits (with rounding on the final digit).\n * @param {number} n The input number.\n * @param {number} decimals The maximum number of decimal digits.\n * @return {number} The next smaller integer.\n */\nexport function floor(n, decimals) {\n  return Math.floor(toFixed(n, decimals));\n}\n\n/**\n * Rounds a number to the next bigger integer considering only the given number\n * of decimal digits (with rounding on the final digit).\n * @param {number} n The input number.\n * @param {number} decimals The maximum number of decimal digits.\n * @return {number} The next bigger integer.\n */\nexport function ceil(n, decimals) {\n  return Math.ceil(toFixed(n, decimals));\n}\n\n/**\n * Wraps a number between some minimum and maximum values.\n * @param {number} n The number to wrap.\n * @param {number} min The minimum of the range (inclusive).\n * @param {number} max The maximum of the range (exclusive).\n * @return {number} The wrapped number.\n */\nexport function wrap(n, min, max) {\n  if (n >= min && n < max) {\n    return n;\n  }\n  const range = max - min;\n  return ((((n - min) % range) + range) % range) + min;\n}\n","/**\n * @module ol/sphere\n */\nimport {toDegrees, toRadians} from './math.js';\n\n/**\n * Object literal with options for the {@link getLength} or {@link getArea}\n * functions.\n * @typedef {Object} SphereMetricOptions\n * @property {import(\"./proj.js\").ProjectionLike} [projection='EPSG:3857']\n * Projection of the  geometry.  By default, the geometry is assumed to be in\n * Web Mercator.\n * @property {number} [radius=6371008.8] Sphere radius.  By default, the\n * [mean Earth radius](https://en.wikipedia.org/wiki/Earth_radius#Mean_radius)\n * for the WGS84 ellipsoid is used.\n */\n\n/**\n * The mean Earth radius (1/3 * (2a + b)) for the WGS84 ellipsoid.\n * https://en.wikipedia.org/wiki/Earth_radius#Mean_radius\n * @type {number}\n */\nexport const DEFAULT_RADIUS = 6371008.8;\n\n/**\n * Get the great circle distance (in meters) between two geographic coordinates.\n * @param {Array} c1 Starting coordinate.\n * @param {Array} c2 Ending coordinate.\n * @param {number} [radius] The sphere radius to use.  Defaults to the Earth's\n *     mean radius using the WGS84 ellipsoid.\n * @return {number} The great circle distance between the points (in meters).\n * @api\n */\nexport function getDistance(c1, c2, radius) {\n  radius = radius || DEFAULT_RADIUS;\n  const lat1 = toRadians(c1[1]);\n  const lat2 = toRadians(c2[1]);\n  const deltaLatBy2 = (lat2 - lat1) / 2;\n  const deltaLonBy2 = toRadians(c2[0] - c1[0]) / 2;\n  const a =\n    Math.sin(deltaLatBy2) * Math.sin(deltaLatBy2) +\n    Math.sin(deltaLonBy2) *\n      Math.sin(deltaLonBy2) *\n      Math.cos(lat1) *\n      Math.cos(lat2);\n  return 2 * radius * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));\n}\n\n/**\n * Get the cumulative great circle length of linestring coordinates (geographic).\n * @param {Array} coordinates Linestring coordinates.\n * @param {number} radius The sphere radius to use.\n * @return {number} The length (in meters).\n */\nfunction getLengthInternal(coordinates, radius) {\n  let length = 0;\n  for (let i = 0, ii = coordinates.length; i < ii - 1; ++i) {\n    length += getDistance(coordinates[i], coordinates[i + 1], radius);\n  }\n  return length;\n}\n\n/**\n * Get the spherical length of a geometry.  This length is the sum of the\n * great circle distances between coordinates.  For polygons, the length is\n * the sum of all rings.  For points, the length is zero.  For multi-part\n * geometries, the length is the sum of the length of each part.\n * @param {import(\"./geom/Geometry.js\").default} geometry A geometry.\n * @param {SphereMetricOptions} [options] Options for the\n * length calculation.  By default, geometries are assumed to be in 'EPSG:3857'.\n * You can change this by providing a `projection` option.\n * @return {number} The spherical length (in meters).\n * @api\n */\nexport function getLength(geometry, options) {\n  options = options || {};\n  const radius = options.radius || DEFAULT_RADIUS;\n  const projection = options.projection || 'EPSG:3857';\n  const type = geometry.getType();\n  if (type !== 'GeometryCollection') {\n    geometry = geometry.clone().transform(projection, 'EPSG:4326');\n  }\n  let length = 0;\n  let coordinates, coords, i, ii, j, jj;\n  switch (type) {\n    case 'Point':\n    case 'MultiPoint': {\n      break;\n    }\n    case 'LineString':\n    case 'LinearRing': {\n      coordinates = /** @type {import(\"./geom/SimpleGeometry.js\").default} */ (\n        geometry\n      ).getCoordinates();\n      length = getLengthInternal(coordinates, radius);\n      break;\n    }\n    case 'MultiLineString':\n    case 'Polygon': {\n      coordinates = /** @type {import(\"./geom/SimpleGeometry.js\").default} */ (\n        geometry\n      ).getCoordinates();\n      for (i = 0, ii = coordinates.length; i < ii; ++i) {\n        length += getLengthInternal(coordinates[i], radius);\n      }\n      break;\n    }\n    case 'MultiPolygon': {\n      coordinates = /** @type {import(\"./geom/SimpleGeometry.js\").default} */ (\n        geometry\n      ).getCoordinates();\n      for (i = 0, ii = coordinates.length; i < ii; ++i) {\n        coords = coordinates[i];\n        for (j = 0, jj = coords.length; j < jj; ++j) {\n          length += getLengthInternal(coords[j], radius);\n        }\n      }\n      break;\n    }\n    case 'GeometryCollection': {\n      const geometries =\n        /** @type {import(\"./geom/GeometryCollection.js\").default} */ (\n          geometry\n        ).getGeometries();\n      for (i = 0, ii = geometries.length; i < ii; ++i) {\n        length += getLength(geometries[i], options);\n      }\n      break;\n    }\n    default: {\n      throw new Error('Unsupported geometry type: ' + type);\n    }\n  }\n  return length;\n}\n\n/**\n * Returns the spherical area for a list of coordinates.\n *\n * [Reference](https://trs.jpl.nasa.gov/handle/2014/40409)\n * Robert. G. Chamberlain and William H. Duquette, \"Some Algorithms for\n * Polygons on a Sphere\", JPL Publication 07-03, Jet Propulsion\n * Laboratory, Pasadena, CA, June 2007\n *\n * @param {Array<import(\"./coordinate.js\").Coordinate>} coordinates List of coordinates of a linear\n * ring. If the ring is oriented clockwise, the area will be positive,\n * otherwise it will be negative.\n * @param {number} radius The sphere radius.\n * @return {number} Area (in square meters).\n */\nfunction getAreaInternal(coordinates, radius) {\n  let area = 0;\n  const len = coordinates.length;\n  let x1 = coordinates[len - 1][0];\n  let y1 = coordinates[len - 1][1];\n  for (let i = 0; i < len; i++) {\n    const x2 = coordinates[i][0];\n    const y2 = coordinates[i][1];\n    area +=\n      toRadians(x2 - x1) *\n      (2 + Math.sin(toRadians(y1)) + Math.sin(toRadians(y2)));\n    x1 = x2;\n    y1 = y2;\n  }\n  return (area * radius * radius) / 2.0;\n}\n\n/**\n * Get the spherical area of a geometry.  This is the area (in meters) assuming\n * that polygon edges are segments of great circles on a sphere.\n * @param {import(\"./geom/Geometry.js\").default} geometry A geometry.\n * @param {SphereMetricOptions} [options] Options for the area\n *     calculation.  By default, geometries are assumed to be in 'EPSG:3857'.\n *     You can change this by providing a `projection` option.\n * @return {number} The spherical area (in square meters).\n * @api\n */\nexport function getArea(geometry, options) {\n  options = options || {};\n  const radius = options.radius || DEFAULT_RADIUS;\n  const projection = options.projection || 'EPSG:3857';\n  const type = geometry.getType();\n  if (type !== 'GeometryCollection') {\n    geometry = geometry.clone().transform(projection, 'EPSG:4326');\n  }\n  let area = 0;\n  let coordinates, coords, i, ii, j, jj;\n  switch (type) {\n    case 'Point':\n    case 'MultiPoint':\n    case 'LineString':\n    case 'MultiLineString':\n    case 'LinearRing': {\n      break;\n    }\n    case 'Polygon': {\n      coordinates = /** @type {import(\"./geom/Polygon.js\").default} */ (\n        geometry\n      ).getCoordinates();\n      area = Math.abs(getAreaInternal(coordinates[0], radius));\n      for (i = 1, ii = coordinates.length; i < ii; ++i) {\n        area -= Math.abs(getAreaInternal(coordinates[i], radius));\n      }\n      break;\n    }\n    case 'MultiPolygon': {\n      coordinates = /** @type {import(\"./geom/SimpleGeometry.js\").default} */ (\n        geometry\n      ).getCoordinates();\n      for (i = 0, ii = coordinates.length; i < ii; ++i) {\n        coords = coordinates[i];\n        area += Math.abs(getAreaInternal(coords[0], radius));\n        for (j = 1, jj = coords.length; j < jj; ++j) {\n          area -= Math.abs(getAreaInternal(coords[j], radius));\n        }\n      }\n      break;\n    }\n    case 'GeometryCollection': {\n      const geometries =\n        /** @type {import(\"./geom/GeometryCollection.js\").default} */ (\n          geometry\n        ).getGeometries();\n      for (i = 0, ii = geometries.length; i < ii; ++i) {\n        area += getArea(geometries[i], options);\n      }\n      break;\n    }\n    default: {\n      throw new Error('Unsupported geometry type: ' + type);\n    }\n  }\n  return area;\n}\n\n/**\n * Returns the coordinate at the given distance and bearing from `c1`.\n *\n * @param {import(\"./coordinate.js\").Coordinate} c1 The origin point (`[lon, lat]` in degrees).\n * @param {number} distance The great-circle distance between the origin\n *     point and the target point.\n * @param {number} bearing The bearing (in radians).\n * @param {number} [radius] The sphere radius to use.  Defaults to the Earth's\n *     mean radius using the WGS84 ellipsoid.\n * @return {import(\"./coordinate.js\").Coordinate} The target point.\n */\nexport function offset(c1, distance, bearing, radius) {\n  radius = radius || DEFAULT_RADIUS;\n  const lat1 = toRadians(c1[1]);\n  const lon1 = toRadians(c1[0]);\n  const dByR = distance / radius;\n  const lat = Math.asin(\n    Math.sin(lat1) * Math.cos(dByR) +\n      Math.cos(lat1) * Math.sin(dByR) * Math.cos(bearing),\n  );\n  const lon =\n    lon1 +\n    Math.atan2(\n      Math.sin(bearing) * Math.sin(dByR) * Math.cos(lat1),\n      Math.cos(dByR) - Math.sin(lat1) * Math.sin(lat),\n    );\n  return [toDegrees(lon), toDegrees(lat)];\n}\n","/**\n * @module ol/console\n */\n\n/**\n * @typedef {'info'|'warn'|'error'|'none'} Level\n */\n\n/**\n * @type {Object<Level, number>}\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/string\n */\n\n/**\n * @param {number} number Number to be formatted\n * @param {number} width The desired width\n * @param {number} [precision] Precision of the output string (i.e. number of decimal places)\n * @return {string} Formatted string\n */\nexport function padNumber(number, width, precision) {\n  const numberString =\n    precision !== undefined ? number.toFixed(precision) : '' + number;\n  let decimal = numberString.indexOf('.');\n  decimal = decimal === -1 ? numberString.length : decimal;\n  return decimal > width\n    ? numberString\n    : new Array(1 + width - decimal).join('0') + numberString;\n}\n\n/**\n * Adapted from https://github.com/omichelsen/compare-versions/blob/master/index.js\n * @param {string|number} v1 First version\n * @param {string|number} v2 Second version\n * @return {number} Value\n */\nexport function compareVersions(v1, v2) {\n  const s1 = ('' + v1).split('.');\n  const s2 = ('' + v2).split('.');\n\n  for (let i = 0; i < Math.max(s1.length, s2.length); i++) {\n    const n1 = parseInt(s1[i] || '0', 10);\n    const n2 = parseInt(s2[i] || '0', 10);\n\n    if (n1 > n2) {\n      return 1;\n    }\n    if (n2 > n1) {\n      return -1;\n    }\n  }\n\n  return 0;\n}\n","/**\n * @module ol/coordinate\n */\nimport {getWidth} from './extent.js';\nimport {clamp, 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<number>} 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<Coordinate>} 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<Coordinate>} 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/**\n * Compute the angle between p0pA and p0pB\n * @param {Coordinate} p0 Point 0\n * @param {Coordinate} pA Point A\n * @param {Coordinate} pB Point B\n * @return {number} a value in [0, 2PI]\n */\nexport function angleBetween(p0, pA, pB) {\n  const lenA = Math.sqrt(\n    (pA[0] - p0[0]) * (pA[0] - p0[0]) + (pA[1] - p0[1]) * (pA[1] - p0[1]),\n  );\n  const tangentA = [(pA[0] - p0[0]) / lenA, (pA[1] - p0[1]) / lenA];\n  const orthoA = [-tangentA[1], tangentA[0]];\n  const lenB = Math.sqrt(\n    (pB[0] - p0[0]) * (pB[0] - p0[0]) + (pB[1] - p0[1]) * (pB[1] - p0[1]),\n  );\n  const tangentB = [(pB[0] - p0[0]) / lenB, (pB[1] - p0[1]) / lenB];\n\n  // this angle can be clockwise or anticlockwise; hence the computation afterwards\n  let angle =\n    lenA === 0 || lenB === 0\n      ? 0\n      : Math.acos(\n          clamp(tangentB[0] * tangentA[0] + tangentB[1] * tangentA[1], -1, 1),\n        );\n  angle = Math.max(angle, 0.00001); // avoid a zero angle otherwise this is detected as a line cap\n  const isClockwise = tangentB[0] * orthoA[0] + tangentB[1] * orthoA[1] > 0;\n  return !isClockwise ? Math.PI * 2 - angle : angle;\n}\n","/**\n * @module ol/proj/Units\n */\n\n/**\n * @typedef {'radians' | 'degrees' | 'ft' | 'm' | 'pixels' | 'tile-pixels' | 'us-ft'} Units\n * Projection units.\n */\n\n/**\n * See http://duff.ess.washington.edu/data/raster/drg/docs/geotiff.txt\n * @type {Object<number, Units>}\n */\nconst unitByCode = {\n  '9001': 'm',\n  '9002': 'ft',\n  '9003': 'us-ft',\n  '9101': 'radians',\n  '9102': 'degrees',\n};\n\n/**\n * @param {number} code Unit code.\n * @return {Units} Units.\n */\nexport function fromCode(code) {\n  return unitByCode[code];\n}\n\n/**\n * @typedef {Object} MetersPerUnitLookup\n * @property {number} radians Radians\n * @property {number} degrees Degrees\n * @property {number} ft  Feet\n * @property {number} m Meters\n * @property {number} us-ft US feet\n */\n\n/**\n * Meters per unit lookup table.\n * @const\n * @type {MetersPerUnitLookup}\n * @api\n */\nexport const METERS_PER_UNIT = {\n  // use the radius of the Normal sphere\n  'radians': 6370997 / (2 * Math.PI),\n  'degrees': (2 * Math.PI * 6370997) / 360,\n  'ft': 0.3048,\n  'm': 1,\n  'us-ft': 1200 / 3937,\n};\n","/**\n * @module ol/proj/Projection\n */\nimport {METERS_PER_UNIT} from './Units.js';\n\n/**\n * The function is called with a `number` view resolution and a\n * {@link module:ol/coordinate~Coordinate} as arguments, and returns the `number` resolution\n * in projection units at the passed coordinate.\n * @typedef {function(number, import(\"../coordinate.js\").Coordinate):number} GetPointResolution\n * @api\n */\n\n/**\n * @typedef {Object} Options\n * @property {string} code The SRS identifier code, e.g. `EPSG:4326`.\n * @property {import(\"./Units.js\").Units} [units] Units. Required unless a\n * proj4 projection is defined for `code`.\n * @property {import(\"../extent.js\").Extent} [extent] The validity extent for the SRS.\n * @property {string} [axisOrientation='enu'] The axis orientation as specified in Proj4.\n * @property {boolean} [global=false] Whether the projection is valid for the whole globe.\n * @property {number} [metersPerUnit] The meters per unit for the SRS.\n * If not provided, the `units` are used to get the meters per unit from the {@link METERS_PER_UNIT}\n * lookup table.\n * @property {import(\"../extent.js\").Extent} [worldExtent] The world extent for the SRS.\n * @property {GetPointResolution} [getPointResolution]\n * Function to determine resolution at a point. The function is called with a\n * `number` view resolution and a {@link module:ol/coordinate~Coordinate} as arguments, and returns\n * the `number` resolution in projection units at the passed coordinate. If this is `undefined`,\n * the default {@link module:ol/proj.getPointResolution} function will be used.\n */\n\n/**\n * @classdesc\n * In most cases, you should not need to create instances of this class.\n * Instead, where projection information is required, you can use a string\n * projection code or identifier (e.g. `EPSG:4326`) instead of a projection\n * instance.\n *\n * The library includes support for transforming coordinates between the following\n * projections:\n *\n *  WGS 84 / Geographic - Using codes `EPSG:4326`, `CRS:84`, `urn:ogc:def:crs:EPSG:6.6:4326`,\n *    `urn:ogc:def:crs:OGC:1.3:CRS84`, `urn:ogc:def:crs:OGC:2:84`, `http://www.opengis.net/gml/srs/epsg.xml#4326`,\n *    or `urn:x-ogc:def:crs:EPSG:4326`\n *  WGS 84 / Spherical Mercator - Using codes `EPSG:3857`, `EPSG:102100`, `EPSG:102113`, `EPSG:900913`,\n *    `urn:ogc:def:crs:EPSG:6.18:3:3857`, or `http://www.opengis.net/gml/srs/epsg.xml#3857`\n *  WGS 84 / UTM zones - Using codes `EPSG:32601` through `EPSG:32660` for northern zones\n *    and `EPSG:32701` through `EPSG:32760` for southern zones. Note that the built-in UTM transforms\n *    are lower accuracy (with errors on the order of 0.1 m) than those that you might get in a\n *    library like [proj4js](https://github.com/proj4js/proj4js).\n *\n * For additional projection support, or to use higher accuracy transforms than the built-in ones, you can use\n * the [proj4js](https://github.com/proj4js/proj4js) library. With `proj4js`, after adding any new projection\n * definitions, call the {@link module:ol/proj/proj4.register} function.\n *\n * You can use the {@link module:ol/proj.get} function to retrieve a projection instance\n * for one of the registered projections.\n *\n * @api\n */\nclass Projection {\n  /**\n   * @param {Options} options Projection options.\n   */\n  constructor(options) {\n    /**\n     * @private\n     * @type {string}\n     */\n    this.code_ = options.code;\n\n    /**\n     * Units of projected coordinates. When set to `TILE_PIXELS`, a\n     * `this.extent_` and `this.worldExtent_` must be configured properly for each\n     * tile.\n     * @private\n     * @type {import(\"./Units.js\").Units}\n     */\n    this.units_ = /** @type {import(\"./Units.js\").Units} */ (options.units);\n\n    /**\n     * Validity extent of the projection in projected coordinates. For projections\n     * with `TILE_PIXELS` units, this is the extent of the tile in\n     * tile pixel space.\n     * @private\n     * @type {import(\"../extent.js\").Extent}\n     */\n    this.extent_ = options.extent !== undefined ? options.extent : null;\n\n    /**\n     * Extent of the world in EPSG:4326. For projections with\n     * `TILE_PIXELS` units, this is the extent of the tile in\n     * projected coordinate space.\n     * @private\n     * @type {import(\"../extent.js\").Extent}\n     */\n    this.worldExtent_ =\n      options.worldExtent !== undefined ? options.worldExtent : null;\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.axisOrientation_ =\n      options.axisOrientation !== undefined ? options.axisOrientation : 'enu';\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.global_ = options.global !== undefined ? options.global : false;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.canWrapX_ = !!(this.global_ && this.extent_);\n\n    /**\n     * @private\n     * @type {GetPointResolution|undefined}\n     */\n    this.getPointResolutionFunc_ = options.getPointResolution;\n\n    /**\n     * @private\n     * @type {import(\"../tilegrid/TileGrid.js\").default}\n     */\n    this.defaultTileGrid_ = null;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.metersPerUnit_ = options.metersPerUnit;\n  }\n\n  /**\n   * @return {boolean} The projection is suitable for wrapping the x-axis\n   */\n  canWrapX() {\n    return this.canWrapX_;\n  }\n\n  /**\n   * Get the code for this projection, e.g. 'EPSG:4326'.\n   * @return {string} Code.\n   * @api\n   */\n  getCode() {\n    return this.code_;\n  }\n\n  /**\n   * Get the validity extent for this projection.\n   * @return {import(\"../extent.js\").Extent} Extent.\n   * @api\n   */\n  getExtent() {\n    return this.extent_;\n  }\n\n  /**\n   * Get the units of this projection.\n   * @return {import(\"./Units.js\").Units} Units.\n   * @api\n   */\n  getUnits() {\n    return this.units_;\n  }\n\n  /**\n   * Get the amount of meters per unit of this projection.  If the projection is\n   * not configured with `metersPerUnit` or a units identifier, the return is\n   * `undefined`.\n   * @return {number|undefined} Meters.\n   * @api\n   */\n  getMetersPerUnit() {\n    return this.metersPerUnit_ || METERS_PER_UNIT[this.units_];\n  }\n\n  /**\n   * Get the world extent for this projection.\n   * @return {import(\"../extent.js\").Extent} Extent.\n   * @api\n   */\n  getWorldExtent() {\n    return this.worldExtent_;\n  }\n\n  /**\n   * Get the axis orientation of this projection.\n   * Example values are:\n   * enu - the default easting, northing, elevation.\n   * neu - northing, easting, up - useful for \"lat/long\" geographic coordinates,\n   *     or south orientated transverse mercator.\n   * wnu - westing, northing, up - some planetary coordinate systems have\n   *     \"west positive\" coordinate systems\n   * @return {string} Axis orientation.\n   * @api\n   */\n  getAxisOrientation() {\n    return this.axisOrientation_;\n  }\n\n  /**\n   * Is this projection a global projection which spans the whole world?\n   * @return {boolean} Whether the projection is global.\n   * @api\n   */\n  isGlobal() {\n    return this.global_;\n  }\n\n  /**\n   * Set if the projection is a global projection which spans the whole world\n   * @param {boolean} global Whether the projection is global.\n   * @api\n   */\n  setGlobal(global) {\n    this.global_ = global;\n    this.canWrapX_ = !!(global && this.extent_);\n  }\n\n  /**\n   * @return {import(\"../tilegrid/TileGrid.js\").default} The default tile grid.\n   */\n  getDefaultTileGrid() {\n    return this.defaultTileGrid_;\n  }\n\n  /**\n   * @param {import(\"../tilegrid/TileGrid.js\").default} tileGrid The default tile grid.\n   */\n  setDefaultTileGrid(tileGrid) {\n    this.defaultTileGrid_ = tileGrid;\n  }\n\n  /**\n   * Set the validity extent for this projection.\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @api\n   */\n  setExtent(extent) {\n    this.extent_ = extent;\n    this.canWrapX_ = !!(this.global_ && extent);\n  }\n\n  /**\n   * Set the world extent for this projection.\n   * @param {import(\"../extent.js\").Extent} worldExtent World extent\n   *     [minlon, minlat, maxlon, maxlat].\n   * @api\n   */\n  setWorldExtent(worldExtent) {\n    this.worldExtent_ = worldExtent;\n  }\n\n  /**\n   * Set the getPointResolution function (see {@link module:ol/proj.getPointResolution}\n   * for this projection.\n   * @param {function(number, import(\"../coordinate.js\").Coordinate):number} func Function\n   * @api\n   */\n  setGetPointResolution(func) {\n    this.getPointResolutionFunc_ = func;\n  }\n\n  /**\n   * Get the custom point resolution function for this projection (if set).\n   * @return {GetPointResolution|undefined} The custom point\n   * resolution function (if set).\n   */\n  getPointResolutionFunc() {\n    return this.getPointResolutionFunc_;\n  }\n}\n\nexport default Projection;\n","/**\n * @module ol/proj/epsg3857\n */\nimport Projection from './Projection.js';\n\n/**\n * Radius of WGS84 sphere\n *\n * @const\n * @type {number}\n */\nexport const RADIUS = 6378137;\n\n/**\n * @const\n * @type {number}\n */\nexport const HALF_SIZE = Math.PI * RADIUS;\n\n/**\n * @const\n * @type {import(\"../extent.js\").Extent}\n */\nexport const EXTENT = [-HALF_SIZE, -HALF_SIZE, HALF_SIZE, HALF_SIZE];\n\n/**\n * @const\n * @type {import(\"../extent.js\").Extent}\n */\nexport const WORLD_EXTENT = [-180, -85, 180, 85];\n\n/**\n * Maximum safe value in y direction\n * @const\n * @type {number}\n */\nexport const MAX_SAFE_Y = RADIUS * Math.log(Math.tan(Math.PI / 2));\n\n/**\n * @classdesc\n * Projection object for web/spherical Mercator (EPSG:3857).\n */\nclass EPSG3857Projection extends Projection {\n  /**\n   * @param {string} code Code.\n   */\n  constructor(code) {\n    super({\n      code: code,\n      units: 'm',\n      extent: EXTENT,\n      global: true,\n      worldExtent: WORLD_EXTENT,\n      getPointResolution: function (resolution, point) {\n        return resolution / Math.cosh(point[1] / RADIUS);\n      },\n    });\n  }\n}\n\n/**\n * Projections equal to EPSG:3857.\n *\n * @const\n * @type {Array<import(\"./Projection.js\").default>}\n */\nexport const PROJECTIONS = [\n  new EPSG3857Projection('EPSG:3857'),\n  new EPSG3857Projection('EPSG:102100'),\n  new EPSG3857Projection('EPSG:102113'),\n  new EPSG3857Projection('EPSG:900913'),\n  new EPSG3857Projection('http://www.opengis.net/def/crs/EPSG/0/3857'),\n  new EPSG3857Projection('http://www.opengis.net/gml/srs/epsg.xml#3857'),\n];\n\n/**\n * Transformation from EPSG:4326 to EPSG:3857.\n *\n * @param {Array<number>} input Input array of coordinate values.\n * @param {Array<number>} [output] Output array of coordinate values.\n * @param {number} [dimension] Dimension (default is `2`).\n * @param {number} [stride] Stride (default is `dimension`).\n * @return {Array<number>} Output array of coordinate values.\n */\nexport function fromEPSG4326(input, output, dimension, stride) {\n  const length = input.length;\n  dimension = dimension > 1 ? dimension : 2;\n  stride = stride ?? dimension;\n  if (output === undefined) {\n    if (dimension > 2) {\n      // preserve values beyond second dimension\n      output = input.slice();\n    } else {\n      output = new Array(length);\n    }\n  }\n  for (let i = 0; i < length; i += stride) {\n    output[i] = (HALF_SIZE * input[i]) / 180;\n    let y = RADIUS * Math.log(Math.tan((Math.PI * (+input[i + 1] + 90)) / 360));\n    if (y > MAX_SAFE_Y) {\n      y = MAX_SAFE_Y;\n    } else if (y < -MAX_SAFE_Y) {\n      y = -MAX_SAFE_Y;\n    }\n    output[i + 1] = y;\n  }\n  return output;\n}\n\n/**\n * Transformation from EPSG:3857 to EPSG:4326.\n *\n * @param {Array<number>} input Input array of coordinate values.\n * @param {Array<number>} [output] Output array of coordinate values.\n * @param {number} [dimension] Dimension (default is `2`).\n * @param {number} [stride] Stride (default is `dimension`).\n * @return {Array<number>} Output array of coordinate values.\n */\nexport function toEPSG4326(input, output, dimension, stride) {\n  const length = input.length;\n  dimension = dimension > 1 ? dimension : 2;\n  stride = stride ?? dimension;\n  if (output === undefined) {\n    if (dimension > 2) {\n      // preserve values beyond second dimension\n      output = input.slice();\n    } else {\n      output = new Array(length);\n    }\n  }\n  for (let i = 0; i < length; i += stride) {\n    output[i] = (180 * input[i]) / HALF_SIZE;\n    output[i + 1] =\n      (360 * Math.atan(Math.exp(input[i + 1] / RADIUS))) / Math.PI - 90;\n  }\n  return output;\n}\n","/**\n * @module ol/proj/epsg4326\n */\nimport Projection from './Projection.js';\n\n/**\n * Semi-major radius of the WGS84 ellipsoid.\n *\n * @const\n * @type {number}\n */\nexport const RADIUS = 6378137;\n\n/**\n * Extent of the EPSG:4326 projection which is the whole world.\n *\n * @const\n * @type {import(\"../extent.js\").Extent}\n */\nexport const EXTENT = [-180, -90, 180, 90];\n\n/**\n * @const\n * @type {number}\n */\nexport const METERS_PER_UNIT = (Math.PI * RADIUS) / 180;\n\n/**\n * @classdesc\n * Projection object for WGS84 geographic coordinates (EPSG:4326).\n *\n * Note that OpenLayers does not strictly comply with the EPSG definition.\n * The EPSG registry defines 4326 as a CRS for Latitude,Longitude (y,x).\n * OpenLayers treats EPSG:4326 as a pseudo-projection, with x,y coordinates.\n */\nclass EPSG4326Projection extends Projection {\n  /**\n   * @param {string} code Code.\n   * @param {string} [axisOrientation] Axis orientation.\n   */\n  constructor(code, axisOrientation) {\n    super({\n      code: code,\n      units: 'degrees',\n      extent: EXTENT,\n      axisOrientation: axisOrientation,\n      global: true,\n      metersPerUnit: METERS_PER_UNIT,\n      worldExtent: EXTENT,\n    });\n  }\n}\n\n/**\n * Projections equal to EPSG:4326.\n *\n * @const\n * @type {Array<import(\"./Projection.js\").default>}\n */\nexport const PROJECTIONS = [\n  new EPSG4326Projection('CRS:84'),\n  new EPSG4326Projection('EPSG:4326', 'neu'),\n  new EPSG4326Projection('urn:ogc:def:crs:OGC:1.3:CRS84'),\n  new EPSG4326Projection('urn:ogc:def:crs:OGC:2:84'),\n  new EPSG4326Projection('http://www.opengis.net/def/crs/OGC/1.3/CRS84'),\n  new EPSG4326Projection('http://www.opengis.net/gml/srs/epsg.xml#4326', 'neu'),\n  new EPSG4326Projection('http://www.opengis.net/def/crs/EPSG/0/4326', 'neu'),\n];\n","/**\n * @module ol/proj/projections\n */\n\n/**\n * @type {Object<string, import(\"./Projection.js\").default>}\n */\nlet cache = {};\n\n/**\n * Clear the projections cache.\n */\nexport function clear() {\n  cache = {};\n}\n\n/**\n * Get a cached projection by code.\n * @param {string} code The code for the projection.\n * @return {import(\"./Projection.js\").default|null} The projection (if cached).\n */\nexport function get(code) {\n  return (\n    cache[code] ||\n    cache[code.replace(/urn:(x-)?ogc:def:crs:EPSG:(.*:)?(\\w+)$/, 'EPSG:$3')] ||\n    null\n  );\n}\n\n/**\n * Add a projection to the cache.\n * @param {string} code The projection code.\n * @param {import(\"./Projection.js\").default} projection The projection to cache.\n */\nexport function add(code, projection) {\n  cache[code] = projection;\n}\n","/**\n * @module ol/proj/transforms\n */\nimport {isEmpty} from '../obj.js';\n\n/**\n * @private\n * @type {!Object<string, Object<string, import(\"../proj.js\").TransformFunction>>}\n */\nlet transforms = {};\n\n/**\n * Clear the transform cache.\n */\nexport function clear() {\n  transforms = {};\n}\n\n/**\n * Registers a conversion function to convert coordinates from the source\n * projection to the destination projection.\n *\n * @param {import(\"./Projection.js\").default} source Source.\n * @param {import(\"./Projection.js\").default} destination Destination.\n * @param {import(\"../proj.js\").TransformFunction} transformFn Transform.\n */\nexport function add(source, destination, transformFn) {\n  const sourceCode = source.getCode();\n  const destinationCode = destination.getCode();\n  if (!(sourceCode in transforms)) {\n    transforms[sourceCode] = {};\n  }\n  transforms[sourceCode][destinationCode] = transformFn;\n}\n\n/**\n * Unregisters the conversion function to convert coordinates from the source\n * projection to the destination projection.  This method is used to clean up\n * cached transforms during testing.\n *\n * @param {import(\"./Projection.js\").default} source Source projection.\n * @param {import(\"./Projection.js\").default} destination Destination projection.\n * @return {import(\"../proj.js\").TransformFunction} transformFn The unregistered transform.\n */\nexport function remove(source, destination) {\n  const sourceCode = source.getCode();\n  const destinationCode = destination.getCode();\n  const transform = transforms[sourceCode][destinationCode];\n  delete transforms[sourceCode][destinationCode];\n  if (isEmpty(transforms[sourceCode])) {\n    delete transforms[sourceCode];\n  }\n  return transform;\n}\n\n/**\n * Get a transform given a source code and a destination code.\n * @param {string} sourceCode The code for the source projection.\n * @param {string} destinationCode The code for the destination projection.\n * @return {import(\"../proj.js\").TransformFunction|null} The transform function (if found).\n */\nexport function get(sourceCode, destinationCode) {\n  if (sourceCode in transforms && destinationCode in transforms[sourceCode]) {\n    return transforms[sourceCode][destinationCode];\n  }\n  return null;\n}\n","/**\n * @module ol/proj/utm\n */\n\n/**\n * Adapted from https://github.com/Turbo87/utm\n * Copyright (c) 2012-2017 Tobias Bieniek\n *\n * The functions here provide approximate transforms to and from UTM.\n * They are not appropriate for use beyond the validity extend of a UTM\n * zone, and the accuracy of the transform decreases toward the zone\n * edges.\n */\n\nimport {toDegrees, toRadians, wrap} from '../math.js';\nimport Projection from './Projection.js';\n\n/**\n * @typedef {Object} UTMZone\n * @property {number} number The zone number (1 - 60).\n * @property {boolean} north The northern hemisphere.\n */\n\nconst K0 = 0.9996;\n\nconst E = 0.00669438;\nconst E2 = E * E;\nconst E3 = E2 * E;\nconst E_P2 = E / (1 - E);\n\nconst SQRT_E = Math.sqrt(1 - E);\nconst _E = (1 - SQRT_E) / (1 + SQRT_E);\nconst _E2 = _E * _E;\nconst _E3 = _E2 * _E;\nconst _E4 = _E3 * _E;\nconst _E5 = _E4 * _E;\n\nconst M1 = 1 - E / 4 - (3 * E2) / 64 - (5 * E3) / 256;\nconst M2 = (3 * E) / 8 + (3 * E2) / 32 + (45 * E3) / 1024;\nconst M3 = (15 * E2) / 256 + (45 * E3) / 1024;\nconst M4 = (35 * E3) / 3072;\n\nconst P2 = (3 / 2) * _E - (27 / 32) * _E3 + (269 / 512) * _E5;\nconst P3 = (21 / 16) * _E2 - (55 / 32) * _E4;\nconst P4 = (151 / 96) * _E3 - (417 / 128) * _E5;\nconst P5 = (1097 / 512) * _E4;\n\nconst R = 6378137;\n\n/**\n * @param {number} easting Easting value of coordinate.\n * @param {number} northing Northing value of coordinate.\n * @param {UTMZone} zone The UTM zone.\n * @return {import(\"../coordinate.js\").Coordinate} The transformed coordinate.\n */\nfunction toLonLat(easting, northing, zone) {\n  const x = easting - 500000;\n  const y = zone.north ? northing : northing - 10000000;\n\n  const m = y / K0;\n  const mu = m / (R * M1);\n\n  const pRad =\n    mu +\n    P2 * Math.sin(2 * mu) +\n    P3 * Math.sin(4 * mu) +\n    P4 * Math.sin(6 * mu) +\n    P5 * Math.sin(8 * mu);\n\n  const pSin = Math.sin(pRad);\n  const pSin2 = pSin * pSin;\n\n  const pCos = Math.cos(pRad);\n\n  const pTan = pSin / pCos;\n  const pTan2 = pTan * pTan;\n  const pTan4 = pTan2 * pTan2;\n\n  const epSin = 1 - E * pSin2;\n  const epSinSqrt = Math.sqrt(1 - E * pSin2);\n\n  const n = R / epSinSqrt;\n  const r = (1 - E) / epSin;\n\n  const c = E_P2 * pCos ** 2;\n  const c2 = c * c;\n\n  const d = x / (n * K0);\n  const d2 = d * d;\n  const d3 = d2 * d;\n  const d4 = d3 * d;\n  const d5 = d4 * d;\n  const d6 = d5 * d;\n\n  const latitude =\n    pRad -\n    (pTan / r) *\n      (d2 / 2 - (d4 / 24) * (5 + 3 * pTan2 + 10 * c - 4 * c2 - 9 * E_P2)) +\n    (d6 / 720) * (61 + 90 * pTan2 + 298 * c + 45 * pTan4 - 252 * E_P2 - 3 * c2);\n\n  let longitude =\n    (d -\n      (d3 / 6) * (1 + 2 * pTan2 + c) +\n      (d5 / 120) * (5 - 2 * c + 28 * pTan2 - 3 * c2 + 8 * E_P2 + 24 * pTan4)) /\n    pCos;\n\n  longitude = wrap(\n    longitude + toRadians(zoneToCentralLongitude(zone.number)),\n    -Math.PI,\n    Math.PI,\n  );\n\n  return [toDegrees(longitude), toDegrees(latitude)];\n}\n\nconst MIN_LATITUDE = -80;\nconst MAX_LATITUDE = 84;\nconst MIN_LONGITUDE = -180;\nconst MAX_LONGITUDE = 180;\n\n/**\n * @param {number} longitude The longitude.\n * @param {number} latitude The latitude.\n * @param {UTMZone} zone The UTM zone.\n * @return {import('../coordinate.js').Coordinate} The UTM coordinate.\n */\nfunction fromLonLat(longitude, latitude, zone) {\n  longitude = wrap(longitude, MIN_LONGITUDE, MAX_LONGITUDE);\n\n  if (latitude < MIN_LATITUDE) {\n    latitude = MIN_LATITUDE;\n  } else if (latitude > MAX_LATITUDE) {\n    latitude = MAX_LATITUDE;\n  }\n\n  const latRad = toRadians(latitude);\n  const latSin = Math.sin(latRad);\n  const latCos = Math.cos(latRad);\n\n  const latTan = latSin / latCos;\n  const latTan2 = latTan * latTan;\n  const latTan4 = latTan2 * latTan2;\n\n  const lonRad = toRadians(longitude);\n  const centralLon = zoneToCentralLongitude(zone.number);\n  const centralLonRad = toRadians(centralLon);\n\n  const n = R / Math.sqrt(1 - E * latSin ** 2);\n  const c = E_P2 * latCos ** 2;\n\n  const a = latCos * wrap(lonRad - centralLonRad, -Math.PI, Math.PI);\n  const a2 = a * a;\n  const a3 = a2 * a;\n  const a4 = a3 * a;\n  const a5 = a4 * a;\n  const a6 = a5 * a;\n\n  const m =\n    R *\n    (M1 * latRad -\n      M2 * Math.sin(2 * latRad) +\n      M3 * Math.sin(4 * latRad) -\n      M4 * Math.sin(6 * latRad));\n\n  const easting =\n    K0 *\n      n *\n      (a +\n        (a3 / 6) * (1 - latTan2 + c) +\n        (a5 / 120) * (5 - 18 * latTan2 + latTan4 + 72 * c - 58 * E_P2)) +\n    500000;\n\n  let northing =\n    K0 *\n    (m +\n      n *\n        latTan *\n        (a2 / 2 +\n          (a4 / 24) * (5 - latTan2 + 9 * c + 4 * c ** 2) +\n          (a6 / 720) * (61 - 58 * latTan2 + latTan4 + 600 * c - 330 * E_P2)));\n\n  if (!zone.north) {\n    northing += 10000000;\n  }\n\n  return [easting, northing];\n}\n\n/**\n * @param {number} zone The zone number.\n * @return {number} The central longitude in degrees.\n */\nfunction zoneToCentralLongitude(zone) {\n  return (zone - 1) * 6 - 180 + 3;\n}\n\n/**\n * @type {Array<RegExp>}\n */\nconst epsgRegExes = [\n  /^EPSG:(\\d+)$/,\n  /^urn:ogc:def:crs:EPSG::(\\d+)$/,\n  /^http:\\/\\/www\\.opengis\\.net\\/def\\/crs\\/EPSG\\/0\\/(\\d+)$/,\n];\n\n/**\n * @param {string} code The projection code.\n * @return {UTMZone|null} The UTM zone info (or null if not UTM).\n */\nexport function zoneFromCode(code) {\n  let epsgId = 0;\n  for (const re of epsgRegExes) {\n    const match = code.match(re);\n    if (match) {\n      epsgId = parseInt(match[1]);\n      break;\n    }\n  }\n  if (!epsgId) {\n    return null;\n  }\n\n  let number = 0;\n  let north = false;\n  if (epsgId > 32700 && epsgId < 32761) {\n    number = epsgId - 32700;\n  } else if (epsgId > 32600 && epsgId < 32661) {\n    north = true;\n    number = epsgId - 32600;\n  }\n  if (!number) {\n    return null;\n  }\n\n  return {number, north};\n}\n\n/**\n * @param {function(number, number, UTMZone): import('../coordinate.js').Coordinate} transformer The transformer.\n * @param {UTMZone} zone The UTM zone.\n * @return {import('../proj.js').TransformFunction} The transform function.\n */\nfunction makeTransformFunction(transformer, zone) {\n  return function (input, output, dimension, stride) {\n    const length = input.length;\n    dimension = dimension > 1 ? dimension : 2;\n    stride = stride ?? dimension;\n    if (!output) {\n      if (dimension > 2) {\n        output = input.slice();\n      } else {\n        output = new Array(length);\n      }\n    }\n    for (let i = 0; i < length; i += stride) {\n      const x = input[i];\n      const y = input[i + 1];\n      const coord = transformer(x, y, zone);\n      output[i] = coord[0];\n      output[i + 1] = coord[1];\n    }\n    return output;\n  };\n}\n\n/**\n * @param {string} code The projection code.\n * @return {import('./Projection.js').default|null} A projection or null if unable to create one.\n */\nexport function makeProjection(code) {\n  const zone = zoneFromCode(code);\n  if (!zone) {\n    return null;\n  }\n  return new Projection({code, units: 'm'});\n}\n\n/**\n * @param {import('./Projection.js').default} projection The projection.\n * @return {import('../proj.js').Transforms|null} The transforms lookup or null if unable to handle projection.\n */\nexport function makeTransforms(projection) {\n  const zone = zoneFromCode(projection.getCode());\n  if (!zone) {\n    return null;\n  }\n\n  return {\n    forward: makeTransformFunction(fromLonLat, zone),\n    inverse: makeTransformFunction(toLonLat, zone),\n  };\n}\n","/**\n * @module ol/proj\n */\n\n/**\n * The ol/proj module stores:\n * a list of {@link module:ol/proj/Projection~Projection}\n * objects, one for each projection supported by the application\n * a list of transform functions needed to convert coordinates in one projection\n * into another.\n *\n * The static functions are the methods used to maintain these.\n * Each transform function can handle not only simple coordinate pairs, but also\n * large arrays of coordinates such as vector geometries.\n *\n * When loaded, the library adds projection objects for EPSG:4326 (WGS84\n * geographic coordinates) and EPSG:3857 (Web or Spherical Mercator, as used\n * for example by Bing Maps or OpenStreetMap), together with the relevant\n * transform functions.\n *\n * Additional transforms may be added by using the http://proj4js.org/\n * library (version 2.2 or later). You can use the full build supplied by\n * Proj4js, or create a custom build to support those projections you need; see\n * the Proj4js website for how to do this. You also need the Proj4js definitions\n * for the required projections. These definitions can be obtained from\n * https://spatialreference.org/, and are a JS function, so can be loaded in a\n * script tag (as in the examples) or pasted into your application.\n *\n * After all required projection definitions are added to proj4's registry (by\n * using `proj4.defs()`), simply call `register(proj4)` from the `ol/proj/proj4`\n * package. Existing transforms are not changed by this function. See\n * examples/wms-image-custom-proj for an example of this.\n *\n * Additional projection definitions can be registered with `proj4.defs()` any\n * time. Just make sure to call `register(proj4)` again; for example, with user-supplied data where you don't\n * know in advance what projections are needed, you can initially load minimal\n * support and then load whichever are requested.\n *\n * Note that Proj4js does not support projection extents. If you want to add\n * one for creating default tile grids, you can add it after the Projection\n * object has been created with `setExtent`, for example,\n * `get('EPSG:1234').setExtent(extent)`.\n *\n * In addition to Proj4js support, any transform functions can be added with\n * {@link module:ol/proj.addCoordinateTransforms}. To use this, you must first create\n * a {@link module:ol/proj/Projection~Projection} object for the new projection and add it with\n * {@link module:ol/proj.addProjection}. You can then add the forward and inverse\n * functions with {@link module:ol/proj.addCoordinateTransforms}. See\n * examples/wms-custom-proj for an example of this.\n *\n * Note that if no transforms are needed and you only need to define the\n * projection, just add a {@link module:ol/proj/Projection~Projection} with\n * {@link module:ol/proj.addProjection}. See examples/wms-no-proj for an example of\n * this.\n */\nimport {warn} from './console.js';\nimport {equals, getWorldsAway} from './coordinate.js';\nimport {applyTransform, getWidth} from './extent.js';\nimport {clamp, modulo} from './math.js';\nimport Projection from './proj/Projection.js';\nimport {METERS_PER_UNIT} from './proj/Units.js';\nimport {\n  PROJECTIONS as EPSG3857_PROJECTIONS,\n  fromEPSG4326,\n  toEPSG4326,\n} from './proj/epsg3857.js';\nimport {PROJECTIONS as EPSG4326_PROJECTIONS} from './proj/epsg4326.js';\nimport {\n  add as addProj,\n  clear as clearProj,\n  get as getProj,\n} from './proj/projections.js';\nimport {\n  add as addTransformFunc,\n  clear as clearTransformFuncs,\n  get as getTransformFunc,\n} from './proj/transforms.js';\nimport {\n  makeProjection as makeUTMProjection,\n  makeTransforms as makeUTMTransforms,\n} from './proj/utm.js';\nimport {getDistance} from './sphere.js';\n\n/**\n * A projection as {@link module:ol/proj/Projection~Projection}, SRS identifier\n * string or undefined.\n * @typedef {Projection|string|undefined} ProjectionLike\n * @api\n */\n\n/**\n * @typedef {Object} Transforms\n * @property {TransformFunction} forward The forward transform (from geographic).\n * @property {TransformFunction} inverse The inverse transform (to geographic).\n */\n\n/**\n * @type {Array<function(Projection): Transforms|null>}\n */\nconst transformFactories = [makeUTMTransforms];\n\n/**\n * @type {Array<function(string): Projection|null>}\n */\nconst projectionFactories = [makeUTMProjection];\n\n/**\n * A transform function accepts an array of input coordinate values, an optional\n * output array, and an optional dimension (default should be 2).  The function\n * transforms the input coordinate values, populates the output array, and\n * returns the output array.\n *\n * @callback TransformFunction\n * @param {Array<number>} input\n * @param {Array<number>} [output]\n * @param {number} [dimension]\n * @param {number} [stride]\n * @return {Array<number>}\n *\n * @api\n */\n\nexport {METERS_PER_UNIT};\n\nexport {Projection};\n\nlet showCoordinateWarning = true;\n\n/**\n * @param {boolean} [disable] Disable console info about `useGeographic()`\n */\nexport function disableCoordinateWarning(disable) {\n  const hide = disable === undefined ? true : disable;\n  showCoordinateWarning = !hide;\n}\n\n/**\n * @param {Array<number>} input Input coordinate array.\n * @param {Array<number>} [output] Output array of coordinate values.\n * @return {Array<number>} Output coordinate array (new array, same coordinate\n *     values).\n */\nexport function cloneTransform(input, output) {\n  if (output !== undefined) {\n    for (let i = 0, ii = input.length; i < ii; ++i) {\n      output[i] = input[i];\n    }\n    output = output;\n  } else {\n    output = input.slice();\n  }\n  return output;\n}\n\n/**\n * @param {Array<number>} input Input coordinate array.\n * @param {Array<number>} [output] Output array of coordinate values.\n * @return {Array<number>} Input coordinate array (same array as input).\n */\nexport function identityTransform(input, output) {\n  if (output !== undefined && input !== output) {\n    for (let i = 0, ii = input.length; i < ii; ++i) {\n      output[i] = input[i];\n    }\n    input = output;\n  }\n  return input;\n}\n\n/**\n * Add a Projection object to the list of supported projections that can be\n * looked up by their code.\n *\n * @param {Projection} projection Projection instance.\n * @api\n */\nexport function addProjection(projection) {\n  addProj(projection.getCode(), projection);\n  addTransformFunc(projection, projection, cloneTransform);\n}\n\n/**\n * @param {Array<Projection>} projections Projections.\n */\nexport function addProjections(projections) {\n  projections.forEach(addProjection);\n}\n\n/**\n * Fetches a Projection object for the code specified.\n *\n * @param {ProjectionLike} projectionLike Either a code string which is\n *     a combination of authority and identifier such as \"EPSG:4326\", or an\n *     existing projection object, or undefined.\n * @return {Projection|null} Projection object, or null if not in list.\n * @api\n */\nexport function get(projectionLike) {\n  if (!(typeof projectionLike === 'string')) {\n    return projectionLike;\n  }\n  const projection = getProj(projectionLike);\n  if (projection) {\n    return projection;\n  }\n  for (const makeProjection of projectionFactories) {\n    const projection = makeProjection(projectionLike);\n    if (projection) {\n      return projection;\n    }\n  }\n  return null;\n}\n\n/**\n * Get the resolution of the point in degrees or distance units.\n * For projections with degrees as the unit this will simply return the\n * provided resolution. For other projections the point resolution is\n * by default estimated by transforming the `point` pixel to EPSG:4326,\n * measuring its width and height on the normal sphere,\n * and taking the average of the width and height.\n * A custom function can be provided for a specific projection, either\n * by setting the `getPointResolution` option in the\n * {@link module:ol/proj/Projection~Projection} constructor or by using\n * {@link module:ol/proj/Projection~Projection#setGetPointResolution} to change an existing\n * projection object.\n * @param {ProjectionLike} projection The projection.\n * @param {number} resolution Nominal resolution in projection units.\n * @param {import(\"./coordinate.js\").Coordinate} point Point to find adjusted resolution at.\n * @param {import(\"./proj/Units.js\").Units} [units] Units to get the point resolution in.\n * Default is the projection's units.\n * @return {number} Point resolution.\n * @api\n */\nexport function getPointResolution(projection, resolution, point, units) {\n  projection = get(projection);\n  let pointResolution;\n  const getter = projection.getPointResolutionFunc();\n  if (getter) {\n    pointResolution = getter(resolution, point);\n    if (units && units !== projection.getUnits()) {\n      const metersPerUnit = projection.getMetersPerUnit();\n      if (metersPerUnit) {\n        pointResolution =\n          (pointResolution * metersPerUnit) / METERS_PER_UNIT[units];\n      }\n    }\n  } else {\n    const projUnits = projection.getUnits();\n    if ((projUnits == 'degrees' && !units) || units == 'degrees') {\n      pointResolution = resolution;\n    } else {\n      // Estimate point resolution by transforming the center pixel to EPSG:4326,\n      // measuring its width and height on the normal sphere, and taking the\n      // average of the width and height.\n      const toEPSG4326 = getTransformFromProjections(\n        projection,\n        get('EPSG:4326'),\n      );\n      if (!toEPSG4326 && projUnits !== 'degrees') {\n        // no transform is available\n        pointResolution = resolution * projection.getMetersPerUnit();\n      } else {\n        let vertices = [\n          point[0] - resolution / 2,\n          point[1],\n          point[0] + resolution / 2,\n          point[1],\n          point[0],\n          point[1] - resolution / 2,\n          point[0],\n          point[1] + resolution / 2,\n        ];\n        vertices = toEPSG4326(vertices, vertices, 2);\n        const width = getDistance(vertices.slice(0, 2), vertices.slice(2, 4));\n        const height = getDistance(vertices.slice(4, 6), vertices.slice(6, 8));\n        pointResolution = (width + height) / 2;\n      }\n      const metersPerUnit = units\n        ? METERS_PER_UNIT[units]\n        : projection.getMetersPerUnit();\n      if (metersPerUnit !== undefined) {\n        pointResolution /= metersPerUnit;\n      }\n    }\n  }\n  return pointResolution;\n}\n\n/**\n * Registers transformation functions that don't alter coordinates. Those allow\n * to transform between projections with equal meaning.\n *\n * @param {Array<Projection>} projections Projections.\n * @api\n */\nexport function addEquivalentProjections(projections) {\n  addProjections(projections);\n  projections.forEach(function (source) {\n    projections.forEach(function (destination) {\n      if (source !== destination) {\n        addTransformFunc(source, destination, cloneTransform);\n      }\n    });\n  });\n}\n\n/**\n * Registers transformation functions to convert coordinates in any projection\n * in projection1 to any projection in projection2.\n *\n * @param {Array<Projection>} projections1 Projections with equal\n *     meaning.\n * @param {Array<Projection>} projections2 Projections with equal\n *     meaning.\n * @param {TransformFunction} forwardTransform Transformation from any\n *   projection in projection1 to any projection in projection2.\n * @param {TransformFunction} inverseTransform Transform from any projection\n *   in projection2 to any projection in projection1..\n */\nexport function addEquivalentTransforms(\n  projections1,\n  projections2,\n  forwardTransform,\n  inverseTransform,\n) {\n  projections1.forEach(function (projection1) {\n    projections2.forEach(function (projection2) {\n      addTransformFunc(projection1, projection2, forwardTransform);\n      addTransformFunc(projection2, projection1, inverseTransform);\n    });\n  });\n}\n\n/**\n * Clear all cached projections and transforms.\n */\nexport function clearAllProjections() {\n  clearProj();\n  clearTransformFuncs();\n}\n\n/**\n * @param {Projection|string|undefined} projection Projection.\n * @param {string} defaultCode Default code.\n * @return {Projection} Projection.\n */\nexport function createProjection(projection, defaultCode) {\n  if (!projection) {\n    return get(defaultCode);\n  }\n  if (typeof projection === 'string') {\n    return get(projection);\n  }\n  return /** @type {Projection} */ (projection);\n}\n\n/**\n * Creates a {@link module:ol/proj~TransformFunction} from a simple 2D coordinate transform\n * function.\n * @param {function(import(\"./coordinate.js\").Coordinate): import(\"./coordinate.js\").Coordinate} coordTransform Coordinate\n *     transform.\n * @return {TransformFunction} Transform function.\n */\nexport function createTransformFromCoordinateTransform(coordTransform) {\n  return (\n    /**\n     * @param {Array<number>} input Input.\n     * @param {Array<number>} [output] Output.\n     * @param {number} [dimension] Dimensions that should be transformed.\n     * @param {number} [stride] Stride.\n     * @return {Array<number>} Output.\n     */\n    function (input, output, dimension, stride) {\n      const length = input.length;\n      dimension = dimension !== undefined ? dimension : 2;\n      stride = stride ?? dimension;\n      output = output !== undefined ? output : new Array(length);\n      for (let i = 0; i < length; i += stride) {\n        const point = coordTransform(input.slice(i, i + dimension));\n        const pointLength = point.length;\n        for (let j = 0, jj = stride; j < jj; ++j) {\n          output[i + j] = j >= pointLength ? input[i + j] : point[j];\n        }\n      }\n      return output;\n    }\n  );\n}\n\n/**\n * Registers coordinate transform functions to convert coordinates between the\n * source projection and the destination projection.\n * The forward and inverse functions convert coordinate pairs; this function\n * converts these into the functions used internally which also handle\n * extents and coordinate arrays.\n *\n * @param {ProjectionLike} source Source projection.\n * @param {ProjectionLike} destination Destination projection.\n * @param {function(import(\"./coordinate.js\").Coordinate): import(\"./coordinate.js\").Coordinate} forward The forward transform\n *     function (that is, from the source projection to the destination\n *     projection) that takes a {@link module:ol/coordinate~Coordinate} as argument and returns\n *     the transformed {@link module:ol/coordinate~Coordinate}.\n * @param {function(import(\"./coordinate.js\").Coordinate): import(\"./coordinate.js\").Coordinate} inverse The inverse transform\n *     function (that is, from the destination projection to the source\n *     projection) that takes a {@link module:ol/coordinate~Coordinate} as argument and returns\n *     the transformed {@link module:ol/coordinate~Coordinate}. If the transform function can only\n *     transform less dimensions than the input coordinate, it is supposeed to return a coordinate\n *     with only the length it can transform. The other dimensions will be taken unchanged from the\n *     source.\n * @api\n */\nexport function addCoordinateTransforms(source, destination, forward, inverse) {\n  const sourceProj = get(source);\n  const destProj = get(destination);\n  addTransformFunc(\n    sourceProj,\n    destProj,\n    createTransformFromCoordinateTransform(forward),\n  );\n  addTransformFunc(\n    destProj,\n    sourceProj,\n    createTransformFromCoordinateTransform(inverse),\n  );\n}\n\n/**\n * Transforms a coordinate from longitude/latitude to a different projection.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate as longitude and latitude, i.e.\n *     an array with longitude as 1st and latitude as 2nd element.\n * @param {ProjectionLike} [projection] Target projection. The\n *     default is Web Mercator, i.e. 'EPSG:3857'.\n * @return {import(\"./coordinate.js\").Coordinate} Coordinate projected to the target projection.\n * @api\n */\nexport function fromLonLat(coordinate, projection) {\n  disableCoordinateWarning();\n  return transform(\n    coordinate,\n    'EPSG:4326',\n    projection !== undefined ? projection : 'EPSG:3857',\n  );\n}\n\n/**\n * Transforms a coordinate to longitude/latitude.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Projected coordinate.\n * @param {ProjectionLike} [projection] Projection of the coordinate.\n *     The default is Web Mercator, i.e. 'EPSG:3857'.\n * @return {import(\"./coordinate.js\").Coordinate} Coordinate as longitude and latitude, i.e. an array\n *     with longitude as 1st and latitude as 2nd element.\n * @api\n */\nexport function toLonLat(coordinate, projection) {\n  const lonLat = transform(\n    coordinate,\n    projection !== undefined ? projection : 'EPSG:3857',\n    'EPSG:4326',\n  );\n  const lon = lonLat[0];\n  if (lon < -180 || lon > 180) {\n    lonLat[0] = modulo(lon + 180, 360) - 180;\n  }\n  return lonLat;\n}\n\n/**\n * Checks if two projections are the same, that is every coordinate in one\n * projection does represent the same geographic point as the same coordinate in\n * the other projection.\n *\n * @param {Projection} projection1 Projection 1.\n * @param {Projection} projection2 Projection 2.\n * @return {boolean} Equivalent.\n * @api\n */\nexport function equivalent(projection1, projection2) {\n  if (projection1 === projection2) {\n    return true;\n  }\n  const equalUnits = projection1.getUnits() === projection2.getUnits();\n  if (projection1.getCode() === projection2.getCode()) {\n    return equalUnits;\n  }\n  const transformFunc = getTransformFromProjections(projection1, projection2);\n  return transformFunc === cloneTransform && equalUnits;\n}\n\n/**\n * Searches in the list of transform functions for the function for converting\n * coordinates from the source projection to the destination projection.\n *\n * @param {Projection} source Source Projection object.\n * @param {Projection} destination Destination Projection\n *     object.\n * @return {TransformFunction|null} Transform function.\n */\nexport function getTransformFromProjections(source, destination) {\n  const sourceCode = source.getCode();\n  const destinationCode = destination.getCode();\n  let transformFunc = getTransformFunc(sourceCode, destinationCode);\n  if (transformFunc) {\n    return transformFunc;\n  }\n\n  /**\n   * @type {Transforms|null}\n   */\n  let sourceTransforms = null;\n\n  /**\n   * @type {Transforms|null}\n   */\n  let destinationTransforms = null;\n\n  // lazily add projections if we have supported transforms\n  for (const makeTransforms of transformFactories) {\n    if (!sourceTransforms) {\n      sourceTransforms = makeTransforms(source);\n    }\n    if (!destinationTransforms) {\n      destinationTransforms = makeTransforms(destination);\n    }\n  }\n\n  if (!sourceTransforms && !destinationTransforms) {\n    return null;\n  }\n\n  const intermediateCode = 'EPSG:4326';\n  if (!destinationTransforms) {\n    const toDestination = getTransformFunc(intermediateCode, destinationCode);\n    if (toDestination) {\n      transformFunc = composeTransformFuncs(\n        sourceTransforms.inverse,\n        toDestination,\n      );\n    }\n  } else if (!sourceTransforms) {\n    const fromSource = getTransformFunc(sourceCode, intermediateCode);\n    if (fromSource) {\n      transformFunc = composeTransformFuncs(\n        fromSource,\n        destinationTransforms.forward,\n      );\n    }\n  } else {\n    transformFunc = composeTransformFuncs(\n      sourceTransforms.inverse,\n      destinationTransforms.forward,\n    );\n  }\n\n  if (transformFunc) {\n    addProjection(source);\n    addProjection(destination);\n    addTransformFunc(source, destination, transformFunc);\n  }\n\n  return transformFunc;\n}\n\n/**\n * @param {TransformFunction} t1 The first transform function.\n * @param {TransformFunction} t2 The second transform function.\n * @return {TransformFunction} The composed transform function.\n */\nfunction composeTransformFuncs(t1, t2) {\n  return function (input, output, dimensions, stride) {\n    output = t1(input, output, dimensions, stride);\n    return t2(output, output, dimensions, stride);\n  };\n}\n\n/**\n * Given the projection-like objects, searches for a transformation\n * function to convert a coordinates array from the source projection to the\n * destination projection.\n *\n * @param {ProjectionLike} source Source.\n * @param {ProjectionLike} destination Destination.\n * @return {TransformFunction} Transform function.\n * @api\n */\nexport function getTransform(source, destination) {\n  const sourceProjection = get(source);\n  const destinationProjection = get(destination);\n  return getTransformFromProjections(sourceProjection, destinationProjection);\n}\n\n/**\n * Transforms a coordinate from source projection to destination projection.\n * This returns a new coordinate (and does not modify the original). If there\n * is no available transform between the two projection, the function will throw\n * an error.\n *\n * See {@link module:ol/proj.transformExtent} for extent transformation.\n * See the transform method of {@link module:ol/geom/Geometry~Geometry} and its\n * subclasses for geometry transforms.\n *\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {ProjectionLike} source Source projection-like.\n * @param {ProjectionLike} destination Destination projection-like.\n * @return {import(\"./coordinate.js\").Coordinate} Coordinate.\n * @api\n */\nexport function transform(coordinate, source, destination) {\n  const transformFunc = getTransform(source, destination);\n  if (!transformFunc) {\n    const sourceCode = get(source).getCode();\n    const destinationCode = get(destination).getCode();\n    throw new Error(\n      `No transform available between ${sourceCode} and ${destinationCode}`,\n    );\n  }\n  return transformFunc(coordinate, undefined, coordinate.length);\n}\n\n/**\n * Transforms an extent from source projection to destination projection.  This\n * returns a new extent (and does not modify the original).\n *\n * @param {import(\"./extent.js\").Extent} extent The extent to transform.\n * @param {ProjectionLike} source Source projection-like.\n * @param {ProjectionLike} destination Destination projection-like.\n * @param {number} [stops] Number of stops per side used for the transform.\n * By default only the corners are used.\n * @return {import(\"./extent.js\").Extent} The transformed extent.\n * @api\n */\nexport function transformExtent(extent, source, destination, stops) {\n  const transformFunc = getTransform(source, destination);\n  return applyTransform(extent, transformFunc, undefined, stops);\n}\n\n/**\n * Transforms the given point to the destination projection.\n *\n * @param {import(\"./coordinate.js\").Coordinate} point Point.\n * @param {Projection} sourceProjection Source projection.\n * @param {Projection} destinationProjection Destination projection.\n * @return {import(\"./coordinate.js\").Coordinate} Point.\n */\nexport function transformWithProjections(\n  point,\n  sourceProjection,\n  destinationProjection,\n) {\n  const transformFunc = getTransformFromProjections(\n    sourceProjection,\n    destinationProjection,\n  );\n  return transformFunc(point);\n}\n\n/**\n * @type {Projection|null}\n */\nlet userProjection = null;\n\n/**\n * Set the projection for coordinates supplied from and returned by API methods.\n * This includes all API methods except for those interacting with tile grids,\n * plus {@link import(\"./Map.js\").FrameState} and {@link import(\"./View.js\").State}.\n * @param {ProjectionLike} projection The user projection.\n * @api\n */\nexport function setUserProjection(projection) {\n  userProjection = get(projection);\n}\n\n/**\n * Clear the user projection if set.\n * @api\n */\nexport function clearUserProjection() {\n  userProjection = null;\n}\n\n/**\n * Get the projection for coordinates supplied from and returned by API methods.\n * @return {Projection|null} The user projection (or null if not set).\n * @api\n */\nexport function getUserProjection() {\n  return userProjection;\n}\n\n/**\n * Use geographic coordinates (WGS-84 datum) in API methods.\n * This includes all API methods except for those interacting with tile grids,\n * plus {@link import(\"./Map.js\").FrameState} and {@link import(\"./View.js\").State}.\n * @api\n */\nexport function useGeographic() {\n  setUserProjection('EPSG:4326');\n}\n\n/**\n * Return a coordinate transformed into the user projection.  If no user projection\n * is set, the original coordinate is returned.\n * @param {Array<number>} coordinate Input coordinate.\n * @param {ProjectionLike} sourceProjection The input coordinate projection.\n * @return {Array<number>} The input coordinate in the user projection.\n */\nexport function toUserCoordinate(coordinate, sourceProjection) {\n  if (!userProjection) {\n    return coordinate;\n  }\n  return transform(coordinate, sourceProjection, userProjection);\n}\n\n/**\n * Return a coordinate transformed from the user projection.  If no user projection\n * is set, the original coordinate is returned.\n * @param {Array<number>} coordinate Input coordinate.\n * @param {ProjectionLike} destProjection The destination projection.\n * @return {Array<number>} The input coordinate transformed.\n */\nexport function fromUserCoordinate(coordinate, destProjection) {\n  if (!userProjection) {\n    if (\n      showCoordinateWarning &&\n      !equals(coordinate, [0, 0]) &&\n      coordinate[0] >= -180 &&\n      coordinate[0] <= 180 &&\n      coordinate[1] >= -90 &&\n      coordinate[1] <= 90\n    ) {\n      showCoordinateWarning = false;\n      warn(\n        'Call useGeographic() from ol/proj once to work with [longitude, latitude] coordinates.',\n      );\n    }\n    return coordinate;\n  }\n  return transform(coordinate, userProjection, destProjection);\n}\n\n/**\n * Return an extent transformed into the user projection.  If no user projection\n * is set, the original extent is returned.\n * @param {import(\"./extent.js\").Extent} extent Input extent.\n * @param {ProjectionLike} sourceProjection The input extent projection.\n * @return {import(\"./extent.js\").Extent} The input extent in the user projection.\n */\nexport function toUserExtent(extent, sourceProjection) {\n  if (!userProjection) {\n    return extent;\n  }\n  return transformExtent(extent, sourceProjection, userProjection);\n}\n\n/**\n * Return an extent transformed from the user projection.  If no user projection\n * is set, the original extent is returned.\n * @param {import(\"./extent.js\").Extent} extent Input extent.\n * @param {ProjectionLike} destProjection The destination projection.\n * @return {import(\"./extent.js\").Extent} The input extent transformed.\n */\nexport function fromUserExtent(extent, destProjection) {\n  if (!userProjection) {\n    return extent;\n  }\n  return transformExtent(extent, userProjection, destProjection);\n}\n\n/**\n * Return the resolution in user projection units per pixel. If no user projection\n * is set, or source or user projection are missing units, the original resolution\n * is returned.\n * @param {number} resolution Resolution in input projection units per pixel.\n * @param {ProjectionLike} sourceProjection The input projection.\n * @return {number} Resolution in user projection units per pixel.\n */\nexport function toUserResolution(resolution, sourceProjection) {\n  if (!userProjection) {\n    return resolution;\n  }\n  const sourceMetersPerUnit = get(sourceProjection).getMetersPerUnit();\n  const userMetersPerUnit = userProjection.getMetersPerUnit();\n  return sourceMetersPerUnit && userMetersPerUnit\n    ? (resolution * sourceMetersPerUnit) / userMetersPerUnit\n    : resolution;\n}\n\n/**\n * Return the resolution in user projection units per pixel. If no user projection\n * is set, or source or user projection are missing units, the original resolution\n * is returned.\n * @param {number} resolution Resolution in user projection units per pixel.\n * @param {ProjectionLike} destProjection The destination projection.\n * @return {number} Resolution in destination projection units per pixel.\n */\nexport function fromUserResolution(resolution, destProjection) {\n  if (!userProjection) {\n    return resolution;\n  }\n  const destMetersPerUnit = get(destProjection).getMetersPerUnit();\n  const userMetersPerUnit = userProjection.getMetersPerUnit();\n  return destMetersPerUnit && userMetersPerUnit\n    ? (resolution * userMetersPerUnit) / destMetersPerUnit\n    : resolution;\n}\n\n/**\n * Creates a safe coordinate transform function from a coordinate transform function.\n * \"Safe\" means that it can handle wrapping of x-coordinates for global projections,\n * and that coordinates exceeding the source projection validity extent's range will be\n * clamped to the validity range.\n * @param {Projection} sourceProj Source projection.\n * @param {Projection} destProj Destination projection.\n * @param {function(import(\"./coordinate.js\").Coordinate): import(\"./coordinate.js\").Coordinate} transform Transform function (source to destination).\n * @return {function(import(\"./coordinate.js\").Coordinate): import(\"./coordinate.js\").Coordinate} Safe transform function (source to destination).\n */\nexport function createSafeCoordinateTransform(sourceProj, destProj, transform) {\n  return function (coord) {\n    let transformed, worldsAway;\n    if (sourceProj.canWrapX()) {\n      const sourceExtent = sourceProj.getExtent();\n      const sourceExtentWidth = getWidth(sourceExtent);\n      coord = coord.slice(0);\n      worldsAway = getWorldsAway(coord, sourceProj, sourceExtentWidth);\n      if (worldsAway) {\n        // Move x to the real world\n        coord[0] = coord[0] - worldsAway * sourceExtentWidth;\n      }\n      coord[0] = clamp(coord[0], sourceExtent[0], sourceExtent[2]);\n      coord[1] = clamp(coord[1], sourceExtent[1], sourceExtent[3]);\n      transformed = transform(coord);\n    } else {\n      transformed = transform(coord);\n    }\n    if (worldsAway && destProj.canWrapX()) {\n      // Move transformed coordinate back to the offset world\n      transformed[0] += worldsAway * getWidth(destProj.getExtent());\n    }\n    return transformed;\n  };\n}\n\n/**\n * Add transforms to and from EPSG:4326 and EPSG:3857.  This function is called\n * by when this module is executed and should only need to be called again after\n * `clearAllProjections()` is called (e.g. in tests).\n */\nexport function addCommon() {\n  // Add transformations that don't alter coordinates to convert within set of\n  // projections with equal meaning.\n  addEquivalentProjections(EPSG3857_PROJECTIONS);\n  addEquivalentProjections(EPSG4326_PROJECTIONS);\n  // Add transformations to convert EPSG:4326 like coordinates to EPSG:3857 like\n  // coordinates and back.\n  addEquivalentTransforms(\n    EPSG4326_PROJECTIONS,\n    EPSG3857_PROJECTIONS,\n    fromEPSG4326,\n    toEPSG4326,\n  );\n}\n\naddCommon();\n","/**\n * @module ol/transform\n */\nimport {assert} from './asserts.js';\n\n/**\n * An array representing an affine 2d transformation for use with\n * {@link module:ol/transform} functions. The array has 6 elements.\n * @typedef {!Array<number>} Transform\n * @api\n */\n\n/**\n * Collection of affine 2d transformation functions. The functions work on an\n * array of 6 elements. The element order is compatible with the [SVGMatrix\n * interface](https://developer.mozilla.org/en-US/docs/Web/API/SVGMatrix) and is\n * a subset (elements a to f) of a 3×3 matrix:\n * ```\n * [ a c e ]\n * [ b d f ]\n * [ 0 0 1 ]\n * ```\n */\n\n/**\n * @private\n * @type {Transform}\n */\nconst tmp_ = new Array(6);\n\n/**\n * Create an identity transform.\n * @return {!Transform} Identity transform.\n */\nexport function create() {\n  return [1, 0, 0, 1, 0, 0];\n}\n\n/**\n * Resets the given transform to an identity transform.\n * @param {!Transform} transform Transform.\n * @return {!Transform} Transform.\n */\nexport function reset(transform) {\n  return set(transform, 1, 0, 0, 1, 0, 0);\n}\n\n/**\n * Multiply the underlying matrices of two transforms and return the result in\n * the first transform.\n * @param {!Transform} transform1 Transform parameters of matrix 1.\n * @param {!Transform} transform2 Transform parameters of matrix 2.\n * @return {!Transform} transform1 multiplied with transform2.\n */\nexport function multiply(transform1, transform2) {\n  const a1 = transform1[0];\n  const b1 = transform1[1];\n  const c1 = transform1[2];\n  const d1 = transform1[3];\n  const e1 = transform1[4];\n  const f1 = transform1[5];\n  const a2 = transform2[0];\n  const b2 = transform2[1];\n  const c2 = transform2[2];\n  const d2 = transform2[3];\n  const e2 = transform2[4];\n  const f2 = transform2[5];\n\n  transform1[0] = a1 * a2 + c1 * b2;\n  transform1[1] = b1 * a2 + d1 * b2;\n  transform1[2] = a1 * c2 + c1 * d2;\n  transform1[3] = b1 * c2 + d1 * d2;\n  transform1[4] = a1 * e2 + c1 * f2 + e1;\n  transform1[5] = b1 * e2 + d1 * f2 + f1;\n\n  return transform1;\n}\n\n/**\n * Set the transform components a-f on a given transform.\n * @param {!Transform} transform Transform.\n * @param {number} a The a component of the transform.\n * @param {number} b The b component of the transform.\n * @param {number} c The c component of the transform.\n * @param {number} d The d component of the transform.\n * @param {number} e The e component of the transform.\n * @param {number} f The f component of the transform.\n * @return {!Transform} Matrix with transform applied.\n */\nexport function set(transform, a, b, c, d, e, f) {\n  transform[0] = a;\n  transform[1] = b;\n  transform[2] = c;\n  transform[3] = d;\n  transform[4] = e;\n  transform[5] = f;\n  return transform;\n}\n\n/**\n * Set transform on one matrix from another matrix.\n * @param {!Transform} transform1 Matrix to set transform to.\n * @param {!Transform} transform2 Matrix to set transform from.\n * @return {!Transform} transform1 with transform from transform2 applied.\n */\nexport function setFromArray(transform1, transform2) {\n  transform1[0] = transform2[0];\n  transform1[1] = transform2[1];\n  transform1[2] = transform2[2];\n  transform1[3] = transform2[3];\n  transform1[4] = transform2[4];\n  transform1[5] = transform2[5];\n  return transform1;\n}\n\n/**\n * Transforms the given coordinate with the given transform returning the\n * resulting, transformed coordinate. The coordinate will be modified in-place.\n *\n * @param {Transform} transform The transformation.\n * @param {import(\"./coordinate.js\").Coordinate|import(\"./pixel.js\").Pixel} coordinate The coordinate to transform.\n * @return {import(\"./coordinate.js\").Coordinate|import(\"./pixel.js\").Pixel} return coordinate so that operations can be\n *     chained together.\n */\nexport function apply(transform, coordinate) {\n  const x = coordinate[0];\n  const y = coordinate[1];\n  coordinate[0] = transform[0] * x + transform[2] * y + transform[4];\n  coordinate[1] = transform[1] * x + transform[3] * y + transform[5];\n  return coordinate;\n}\n\n/**\n * Applies rotation to the given transform.\n * @param {!Transform} transform Transform.\n * @param {number} angle Angle in radians.\n * @return {!Transform} The rotated transform.\n */\nexport function rotate(transform, angle) {\n  const cos = Math.cos(angle);\n  const sin = Math.sin(angle);\n  return multiply(transform, set(tmp_, cos, sin, -sin, cos, 0, 0));\n}\n\n/**\n * Applies scale to a given transform.\n * @param {!Transform} transform Transform.\n * @param {number} x Scale factor x.\n * @param {number} y Scale factor y.\n * @return {!Transform} The scaled transform.\n */\nexport function scale(transform, x, y) {\n  return multiply(transform, set(tmp_, x, 0, 0, y, 0, 0));\n}\n\n/**\n * Creates a scale transform.\n * @param {!Transform} target Transform to overwrite.\n * @param {number} x Scale factor x.\n * @param {number} y Scale factor y.\n * @return {!Transform} The scale transform.\n */\nexport function makeScale(target, x, y) {\n  return set(target, x, 0, 0, y, 0, 0);\n}\n\n/**\n * Applies translation to the given transform.\n * @param {!Transform} transform Transform.\n * @param {number} dx Translation x.\n * @param {number} dy Translation y.\n * @return {!Transform} The translated transform.\n */\nexport function translate(transform, dx, dy) {\n  return multiply(transform, set(tmp_, 1, 0, 0, 1, dx, dy));\n}\n\n/**\n * Creates a composite transform given an initial translation, scale, rotation, and\n * final translation (in that order only, not commutative).\n * @param {!Transform} transform The transform (will be modified in place).\n * @param {number} dx1 Initial translation x.\n * @param {number} dy1 Initial translation y.\n * @param {number} sx Scale factor x.\n * @param {number} sy Scale factor y.\n * @param {number} angle Rotation (in counter-clockwise radians).\n * @param {number} dx2 Final translation x.\n * @param {number} dy2 Final translation y.\n * @return {!Transform} The composite transform.\n */\nexport function compose(transform, dx1, dy1, sx, sy, angle, dx2, dy2) {\n  const sin = Math.sin(angle);\n  const cos = Math.cos(angle);\n  transform[0] = sx * cos;\n  transform[1] = sy * sin;\n  transform[2] = -sx * sin;\n  transform[3] = sy * cos;\n  transform[4] = dx2 * sx * cos - dy2 * sx * sin + dx1;\n  transform[5] = dx2 * sy * sin + dy2 * sy * cos + dy1;\n  return transform;\n}\n\n/**\n * Creates a composite transform given an initial translation, scale, rotation, and\n * final translation (in that order only, not commutative). The resulting transform\n * string can be applied as `transform` property of an HTMLElement's style.\n * @param {number} dx1 Initial translation x.\n * @param {number} dy1 Initial translation y.\n * @param {number} sx Scale factor x.\n * @param {number} sy Scale factor y.\n * @param {number} angle Rotation (in counter-clockwise radians).\n * @param {number} dx2 Final translation x.\n * @param {number} dy2 Final translation y.\n * @return {string} The composite css transform.\n * @api\n */\nexport function composeCssTransform(dx1, dy1, sx, sy, angle, dx2, dy2) {\n  return toString(compose(create(), dx1, dy1, sx, sy, angle, dx2, dy2));\n}\n\n/**\n * Invert the given transform.\n * @param {!Transform} source The source transform to invert.\n * @return {!Transform} The inverted (source) transform.\n */\nexport function invert(source) {\n  return makeInverse(source, source);\n}\n\n/**\n * Invert the given transform.\n * @param {!Transform} target Transform to be set as the inverse of\n *     the source transform.\n * @param {!Transform} source The source transform to invert.\n * @return {!Transform} The inverted (target) transform.\n */\nexport function makeInverse(target, source) {\n  const det = determinant(source);\n  assert(det !== 0, 'Transformation matrix cannot be inverted');\n\n  const a = source[0];\n  const b = source[1];\n  const c = source[2];\n  const d = source[3];\n  const e = source[4];\n  const f = source[5];\n\n  target[0] = d / det;\n  target[1] = -b / det;\n  target[2] = -c / det;\n  target[3] = a / det;\n  target[4] = (c * f - d * e) / det;\n  target[5] = -(a * f - b * e) / det;\n\n  return target;\n}\n\n/**\n * Returns the determinant of the given matrix.\n * @param {!Transform} mat Matrix.\n * @return {number} Determinant.\n */\nexport function determinant(mat) {\n  return mat[0] * mat[3] - mat[1] * mat[2];\n}\n\n/**\n * @type {Array}\n */\nconst matrixPrecision = [1e5, 1e5, 1e5, 1e5, 2, 2];\n\n/**\n * A matrix string version of the transform.  This can be used\n * for CSS transforms.\n * @param {!Transform} mat Matrix.\n * @return {string} The transform as a string.\n */\nexport function toString(mat) {\n  const transformString = 'matrix(' + mat.join(', ') + ')';\n  return transformString;\n}\n\n/**\n * Create a transform from a CSS transform matrix string.\n * @param {string} cssTransform The CSS string to parse.\n * @return {!Transform} The transform.\n */\nexport function fromString(cssTransform) {\n  const values = cssTransform.substring(7, cssTransform.length - 1).split(',');\n  return values.map(parseFloat);\n}\n\n/**\n * Compare two matrices for equality.\n * @param {!string} cssTransform1 A CSS transform matrix string.\n * @param {!string} cssTransform2 A CSS transform matrix string.\n * @return {boolean} The two matrices are equal.\n */\nexport function equivalent(cssTransform1, cssTransform2) {\n  const mat1 = fromString(cssTransform1);\n  const mat2 = fromString(cssTransform2);\n  for (let i = 0; i < 6; ++i) {\n    if (Math.round((mat1[i] - mat2[i]) * matrixPrecision[i]) !== 0) {\n      return false;\n    }\n  }\n  return true;\n}\n","/**\n * @module ol/geom/flat/transform\n */\n\n/**\n * @param {Array<number>} 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<number>} [dest] Destination.\n * @param {number} [destinationStride] Stride of destination coordinates; if unspecified, assumed to be 2.\n * @return {Array<number>} Transformed coordinates.\n */\nexport function transform2D(\n  flatCoordinates,\n  offset,\n  end,\n  stride,\n  transform,\n  dest,\n  destinationStride,\n) {\n  dest = dest ? dest : [];\n  destinationStride = destinationStride ? destinationStride : 2;\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    for (let k = 2; k < destinationStride; k++) {\n      dest[i++] = flatCoordinates[j + k];\n    }\n  }\n\n  if (dest && dest.length != i) {\n    dest.length = i;\n  }\n  return dest;\n}\n\n/**\n * @param {Array<number>} 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<number>} anchor Rotation anchor point.\n * @param {Array<number>} [dest] Destination.\n * @return {Array<number>} 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<number>} 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<number>} anchor Scale anchor point.\n * @param {Array<number>} [dest] Destination.\n * @return {Array<number>} 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<number>} 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<number>} [dest] Destination.\n * @return {Array<number>} 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/geom/Geometry\n */\nimport BaseObject from '../Object.js';\nimport {\n  createEmpty,\n  createOrUpdateEmpty,\n  getHeight,\n  returnOrUpdate,\n} from '../extent.js';\nimport {memoizeOne} from '../functions.js';\nimport {get as getProjection, getTransform} from '../proj.js';\nimport {\n  compose as composeTransform,\n  create as createTransform,\n} from '../transform.js';\nimport {abstract} from '../util.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/** @type {import('../coordinate.js').Coordinate} */\nconst tmpPoint = [NaN, NaN];\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    return this.closestPointXY(x, y, tmpPoint, Number.MIN_VALUE) === 0;\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            const transformed = transform2D(\n              inCoordinates,\n              0,\n              inCoordinates.length,\n              stride,\n              tmpTransform,\n              outCoordinates,\n            );\n            const projTransform = getTransform(sourceProj, destination);\n            if (projTransform) {\n              return projTransform(transformed, transformed, stride);\n            }\n            return transformed;\n          }\n        : getTransform(sourceProj, destination);\n    this.applyTransform(transformFn);\n    return this;\n  }\n}\n\nexport default Geometry;\n","/**\n * @module ol/geom/SimpleGeometry\n */\nimport {createOrUpdateFromFlatCoordinates, getCenter} from '../extent.js';\nimport {abstract} from '../util.js';\nimport Geometry from './Geometry.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<number>}\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<number>} 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<number>} 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<unknown>} */ (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(\n        this.flatCoordinates,\n        this.flatCoordinates,\n        this.layout.startsWith('XYZ') ? 3 : 2,\n        this.stride,\n      );\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<number>} [dest] Destination.\n * @return {Array<number>} 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<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} 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/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<number>} 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<number>} 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<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} 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<number>} 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<number>} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @param {Array<number>} [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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} 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<number>} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @param {Array<number>} [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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} 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<number>} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @param {Array<number>} [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/deflate\n */\n\n/**\n * @param {Array<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<import(\"../../coordinate.js\").Coordinate>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<import(\"../../coordinate.js\").Coordinate>>} coordinatess Coordinatess.\n * @param {number} stride Stride.\n * @param {Array<number>} [ends] Ends.\n * @return {Array<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<Array<import(\"../../coordinate.js\").Coordinate>>>} coordinatesss Coordinatesss.\n * @param {number} stride Stride.\n * @param {Array<Array<number>>} [endss] Endss.\n * @return {Array<Array<number>>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {Array<import(\"../../coordinate.js\").Coordinate>} [coordinates] Coordinates.\n * @return {Array<import(\"../../coordinate.js\").Coordinate>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {Array<Array<import(\"../../coordinate.js\").Coordinate>>} [coordinatess] Coordinatess.\n * @return {Array<Array<import(\"../../coordinate.js\").Coordinate>>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Endss.\n * @param {number} stride Stride.\n * @param {Array<Array<Array<import(\"../../coordinate.js\").Coordinate>>>} [coordinatesss]\n *     Coordinatesss.\n * @return {Array<Array<Array<import(\"../../coordinate.js\").Coordinate>>>} 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/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<number>} 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<number>} [simplifiedFlatCoordinates] Simplified flat\n *     coordinates.\n * @return {Array<number>} 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<number>} 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<number>} 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<number>} */\n  const markers = new Array(n);\n  markers[0] = 1;\n  markers[n - 1] = 1;\n  /** @type {Array<number>} */\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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {Array<number>} simplifiedFlatCoordinates Simplified flat\n *     coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @param {Array<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Endss.\n * @param {number} stride Stride.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {Array<number>} simplifiedFlatCoordinates Simplified flat\n *     coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @param {Array<Array<number>>} 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<number>} */\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<number>} 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<number>} 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<number>} 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<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {number} tolerance Tolerance.\n * @param {Array<number>} simplifiedFlatCoordinates Simplified flat\n *     coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @param {Array<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Endss.\n * @param {number} stride Stride.\n * @param {number} tolerance Tolerance.\n * @param {Array<number>} simplifiedFlatCoordinates Simplified flat\n *     coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @param {Array<Array<number>>} 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<number>} */\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/LinearRing\n */\nimport {closestSquaredDistanceXY} from '../extent.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {linearRing as linearRingArea} from './flat/area.js';\nimport {assignClosestPoint, maxSquaredDelta} from './flat/closest.js';\nimport {deflateCoordinates} from './flat/deflate.js';\nimport {inflateCoordinates} from './flat/inflate.js';\nimport {douglasPeucker} from './flat/simplify.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<import(\"../coordinate.js\").Coordinate>|Array<number>} 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<number>} */ (coordinates),\n      );\n    } else {\n      this.setCoordinates(\n        /** @type {Array<import(\"../coordinate.js\").Coordinate>} */ (\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<import(\"../coordinate.js\").Coordinate>} 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<number>} */\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<import(\"../coordinate.js\").Coordinate>} 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/Point\n */\nimport {containsXY, createOrUpdateFromCoordinate} from '../extent.js';\nimport {squaredDistance as squaredDx} from '../math.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {deflateCoordinate} from './flat/deflate.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/flat/contains\n */\nimport {forEachCorner} from '../../extent.js';\n\n/**\n * @param {Array<number>} 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<number>} 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://web.archive.org/web/20210504233957/http://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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} 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/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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} ends Ends.\n * @param {number} stride Stride.\n * @param {Array<number>} flatCenters Flat centers.\n * @param {number} flatCentersOffset Flat center offset.\n * @param {Array<number>} [dest] Destination.\n * @return {Array<number>} 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<number>} */\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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Endss.\n * @param {number} stride Stride.\n * @param {Array<number>} flatCenters Flat centers.\n * @return {Array<number>} 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<number>} */\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/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<number>} 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/**\n * Calculate the intersection point of two line segments.\n * Reference: https://stackoverflow.com/a/72474223/2389327\n * @param {Array<import(\"../../coordinate.js\").Coordinate>} segment1 The first line segment as an array of two points.\n * @param {Array<import(\"../../coordinate.js\").Coordinate>} segment2 The second line segment as an array of two points.\n * @return {import(\"../../coordinate.js\").Coordinate|undefined} The intersection point or `undefined` if no intersection.\n */\nexport function getIntersectionPoint(segment1, segment2) {\n  const [a, b] = segment1;\n  const [c, d] = segment2;\n  const t =\n    ((a[0] - c[0]) * (c[1] - d[1]) - (a[1] - c[1]) * (c[0] - d[0])) /\n    ((a[0] - b[0]) * (c[1] - d[1]) - (a[1] - b[1]) * (c[0] - d[0]));\n  const u =\n    ((a[0] - c[0]) * (a[1] - b[1]) - (a[1] - c[1]) * (a[0] - b[0])) /\n    ((a[0] - b[0]) * (c[1] - d[1]) - (a[1] - b[1]) * (c[0] - d[0]));\n\n  // Check if lines actually intersect\n  if (0 <= t && t <= 1 && 0 <= u && u <= 1) {\n    return [a[0] + t * (b[0] - a[0]), a[1] + t * (b[1] - a[1])];\n  }\n  return undefined;\n}\n","/**\n * @module ol/geom/flat/intersectsextent\n */\nimport {\n  createEmpty,\n  extendFlatCoordinates,\n  intersects,\n  intersectsSegment,\n} from '../../extent.js';\nimport {linearRingContainsExtent, linearRingContainsXY} from './contains.js';\nimport {forEach as forEachSegment} from './segments.js';\n\n/**\n * @param {Array<number>} 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 * @param {import('../../extent.js').Extent} [coordinatesExtent] Coordinates 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  coordinatesExtent,\n) {\n  coordinatesExtent =\n    coordinatesExtent ??\n    extendFlatCoordinates(createEmpty(), flatCoordinates, offset, end, stride);\n  if (!intersects(extent, coordinatesExtent)) {\n    return false;\n  }\n  if (\n    (coordinatesExtent[0] >= extent[0] && coordinatesExtent[2] <= extent[2]) ||\n    (coordinatesExtent[1] >= extent[1] && coordinatesExtent[3] <= extent[3])\n  ) {\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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} 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<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} 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/reverse\n */\n\n/**\n * @param {Array<number>} 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<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} 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<number>} flatCoordinates Flat coordinates\n * @param {Array<number>} ends Linear ring end indexes\n * @return {Array<Array<number>>} 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/Polygon\n */\nimport {extend} from '../array.js';\nimport {closestSquaredDistanceXY, getCenter, isEmpty} from '../extent.js';\nimport {modulo} from '../math.js';\nimport {offset as sphereOffset} from '../sphere.js';\nimport LinearRing from './LinearRing.js';\nimport Point from './Point.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {linearRings as linearRingsArea} from './flat/area.js';\nimport {arrayMaxSquaredDelta, assignClosestArrayPoint} from './flat/closest.js';\nimport {linearRingsContainsXY} from './flat/contains.js';\nimport {deflateCoordinatesArray} from './flat/deflate.js';\nimport {inflateCoordinatesArray} from './flat/inflate.js';\nimport {getInteriorPointOfArray} from './flat/interiorpoint.js';\nimport {intersectsLinearRingArray} from './flat/intersectsextent.js';\nimport {linearRingsAreOriented, orientLinearRings} from './flat/orient.js';\nimport {quantizeArray} from './flat/simplify.js';\n\n/**\n * @classdesc\n * Polygon geometry.\n *\n * @api\n */\nclass Polygon extends SimpleGeometry {\n  /**\n   * @param {!Array<Array<import(\"../coordinate.js\").Coordinate>>|!Array<number>} 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<number>} [ends] Ends (for internal use with flat coordinates).\n   */\n  constructor(coordinates, layout, ends) {\n    super();\n\n    /**\n     * @type {Array<number>}\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<number>|null}\n     */\n    this.orientedFlatCoordinates_ = null;\n\n    if (layout !== undefined && ends) {\n      this.setFlatCoordinates(\n        layout,\n        /** @type {Array<number>} */ (coordinates),\n      );\n      this.ends_ = ends;\n    } else {\n      this.setCoordinates(\n        /** @type {Array<Array<import(\"../coordinate.js\").Coordinate>>} */ (\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<Array<import(\"../coordinate.js\").Coordinate>>} 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<number>} Ends.\n   */\n  getEnds() {\n    return this.ends_;\n  }\n\n  /**\n   * @return {Array<number>} 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<LinearRing>} 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<number>} 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<number>} */ (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<number>} */\n    const simplifiedFlatCoordinates = [];\n    /** @type {Array<number>} */\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<Array<import(\"../coordinate.js\").Coordinate>>} 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<number>} */\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/Geolocation\n */\nimport BaseObject from './Object.js';\nimport BaseEvent from './events/Event.js';\nimport {circular as circularPolygon} from './geom/Polygon.js';\nimport {toRadians} from './math.js';\nimport {\n  get as getProjection,\n  getTransformFromProjections,\n  identityTransform,\n} from './proj.js';\n\n/**\n * @enum {string}\n */\nconst Property = {\n  ACCURACY: 'accuracy',\n  ACCURACY_GEOMETRY: 'accuracyGeometry',\n  ALTITUDE: 'altitude',\n  ALTITUDE_ACCURACY: 'altitudeAccuracy',\n  HEADING: 'heading',\n  POSITION: 'position',\n  PROJECTION: 'projection',\n  SPEED: 'speed',\n  TRACKING: 'tracking',\n  TRACKING_OPTIONS: 'trackingOptions',\n};\n\n/**\n * @enum string\n */\nconst GeolocationErrorType = {\n  /**\n   * Triggered when a `GeolocationPositionError` occurs.\n   * @event module:ol/Geolocation.GeolocationError#error\n   * @api\n   */\n  ERROR: 'error',\n};\n\n/**\n * @classdesc\n * Events emitted on [GeolocationPositionError](https://developer.mozilla.org/en-US/docs/Web/API/GeolocationPositionError).\n */\nexport class GeolocationError extends BaseEvent {\n  /**\n   * @param {GeolocationPositionError} error error object.\n   */\n  constructor(error) {\n    super(GeolocationErrorType.ERROR);\n\n    /**\n     * Code of the underlying `GeolocationPositionError`.\n     * @type {number}\n     * @api\n     */\n    this.code = error.code;\n\n    /**\n     * Message of the underlying `GeolocationPositionError`.\n     * @type {string}\n     * @api\n     */\n    this.message = error.message;\n  }\n}\n\n/**\n * @typedef {Object} Options\n * @property {boolean} [tracking=false] Start Tracking right after\n * instantiation.\n * @property {PositionOptions} [trackingOptions] Tracking options.\n * See https://www.w3.org/TR/geolocation-API/#position_options_interface.\n * @property {import(\"./proj.js\").ProjectionLike} [projection] The projection the position\n * is reported in.\n */\n\n/**\n * @typedef {import(\"./ObjectEventType.js\").Types|'change:accuracy'|'change:accuracyGeometry'|'change:altitude'|\n *    'change:altitudeAccuracy'|'change:heading'|'change:position'|'change:projection'|'change:speed'|'change:tracking'|\n *    'change:trackingOptions'} GeolocationObjectEventTypes\n */\n\n/***\n * @template Return\n * @typedef {import(\"./Observable.js\").OnSignature<GeolocationObjectEventTypes, import(\"./Object.js\").ObjectEvent, Return> &\n *   import(\"./Observable.js\").OnSignature<'error', GeolocationError, Return> &\n *   import(\"./Observable.js\").CombinedOnSignature<import(\"./Observable.js\").EventTypes|GeolocationObjectEventTypes, Return> &\n *   import(\"./Observable.js\").OnSignature<import(\"./Observable.js\").EventTypes, import(\"./events/Event.js\").default, Return>} GeolocationOnSignature\n */\n\n/**\n * @classdesc\n * Helper class for providing HTML5 Geolocation capabilities.\n * The [Geolocation API](https://www.w3.org/TR/geolocation-API/)\n * is used to locate a user's position.\n *\n * To get notified of position changes and errors, register listeners for the generic\n * `change` event and the `error` event on your instance of {@link module:ol/Geolocation~Geolocation}.\n *\n * Example:\n *\n *     const geolocation = new Geolocation({\n *       // take the projection to use from the map's view\n *       projection: view.getProjection()\n *     });\n *     // listen to changes in position\n *     geolocation.on('change', function(evt) {\n *       console.log(geolocation.getPosition());\n *     });\n *     // listen to error\n *     geolocation.on('error', function(evt) {\n *       window.console.log(evt.message);\n *     });\n *\n * @fires GeolocationError\n * @api\n */\nclass Geolocation extends BaseObject {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    super();\n\n    /***\n     * @type {GeolocationOnSignature<import(\"./events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {GeolocationOnSignature<import(\"./events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {GeolocationOnSignature<void>}\n     */\n    this.un;\n\n    options = options || {};\n\n    /**\n     * The unprojected (EPSG:4326) device position.\n     * @private\n     * @type {?import(\"./coordinate.js\").Coordinate}\n     */\n    this.position_ = null;\n\n    /**\n     * @private\n     * @type {import(\"./proj.js\").TransformFunction}\n     */\n    this.transform_ = identityTransform;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.watchId_ = undefined;\n\n    this.addChangeListener(Property.PROJECTION, this.handleProjectionChanged_);\n    this.addChangeListener(Property.TRACKING, this.handleTrackingChanged_);\n\n    if (options.projection !== undefined) {\n      this.setProjection(options.projection);\n    }\n    if (options.trackingOptions !== undefined) {\n      this.setTrackingOptions(options.trackingOptions);\n    }\n\n    this.setTracking(options.tracking !== undefined ? options.tracking : false);\n  }\n\n  /**\n   * Clean up.\n   * @override\n   */\n  disposeInternal() {\n    this.setTracking(false);\n    super.disposeInternal();\n  }\n\n  /**\n   * @private\n   */\n  handleProjectionChanged_() {\n    const projection = this.getProjection();\n    if (projection) {\n      this.transform_ = getTransformFromProjections(\n        getProjection('EPSG:4326'),\n        projection,\n      );\n      if (this.position_) {\n        this.set(Property.POSITION, this.transform_(this.position_));\n      }\n    }\n  }\n\n  /**\n   * @private\n   */\n  handleTrackingChanged_() {\n    if ('geolocation' in navigator) {\n      const tracking = this.getTracking();\n      if (tracking && this.watchId_ === undefined) {\n        this.watchId_ = navigator.geolocation.watchPosition(\n          this.positionChange_.bind(this),\n          this.positionError_.bind(this),\n          this.getTrackingOptions(),\n        );\n      } else if (!tracking && this.watchId_ !== undefined) {\n        navigator.geolocation.clearWatch(this.watchId_);\n        this.watchId_ = undefined;\n      }\n    }\n  }\n\n  /**\n   * @private\n   * @param {GeolocationPosition} position position event.\n   */\n  positionChange_(position) {\n    const coords = position.coords;\n    this.set(Property.ACCURACY, coords.accuracy);\n    this.set(\n      Property.ALTITUDE,\n      coords.altitude === null ? undefined : coords.altitude,\n    );\n    this.set(\n      Property.ALTITUDE_ACCURACY,\n      coords.altitudeAccuracy === null ? undefined : coords.altitudeAccuracy,\n    );\n    this.set(\n      Property.HEADING,\n      coords.heading === null ? undefined : toRadians(coords.heading),\n    );\n    if (!this.position_) {\n      this.position_ = [coords.longitude, coords.latitude];\n    } else {\n      this.position_[0] = coords.longitude;\n      this.position_[1] = coords.latitude;\n    }\n    const projectedPosition = this.transform_(this.position_);\n    this.set(Property.POSITION, projectedPosition.slice());\n    this.set(Property.SPEED, coords.speed === null ? undefined : coords.speed);\n    const geometry = circularPolygon(this.position_, coords.accuracy);\n    geometry.applyTransform(this.transform_);\n    this.set(Property.ACCURACY_GEOMETRY, geometry);\n    this.changed();\n  }\n\n  /**\n   * @private\n   * @param {GeolocationPositionError} error error object.\n   */\n  positionError_(error) {\n    this.dispatchEvent(new GeolocationError(error));\n  }\n\n  /**\n   * Get the accuracy of the position in meters.\n   * @return {number|undefined} The accuracy of the position measurement in\n   *     meters.\n   * @observable\n   * @api\n   */\n  getAccuracy() {\n    return /** @type {number|undefined} */ (this.get(Property.ACCURACY));\n  }\n\n  /**\n   * Get a geometry of the position accuracy.\n   * @return {?import(\"./geom/Polygon.js\").default} A geometry of the position accuracy.\n   * @observable\n   * @api\n   */\n  getAccuracyGeometry() {\n    return /** @type {?import(\"./geom/Polygon.js\").default} */ (\n      this.get(Property.ACCURACY_GEOMETRY) || null\n    );\n  }\n\n  /**\n   * Get the altitude associated with the position.\n   * @return {number|undefined} The altitude of the position in meters above mean\n   *     sea level.\n   * @observable\n   * @api\n   */\n  getAltitude() {\n    return /** @type {number|undefined} */ (this.get(Property.ALTITUDE));\n  }\n\n  /**\n   * Get the altitude accuracy of the position.\n   * @return {number|undefined} The accuracy of the altitude measurement in\n   *     meters.\n   * @observable\n   * @api\n   */\n  getAltitudeAccuracy() {\n    return /** @type {number|undefined} */ (\n      this.get(Property.ALTITUDE_ACCURACY)\n    );\n  }\n\n  /**\n   * Get the heading as radians clockwise from North.\n   * Note: depending on the browser, the heading is only defined if the `enableHighAccuracy`\n   * is set to `true` in the tracking options.\n   * @return {number|undefined} The heading of the device in radians from north.\n   * @observable\n   * @api\n   */\n  getHeading() {\n    return /** @type {number|undefined} */ (this.get(Property.HEADING));\n  }\n\n  /**\n   * Get the position of the device.\n   * @return {import(\"./coordinate.js\").Coordinate|undefined} The current position of the device reported\n   *     in the current projection.\n   * @observable\n   * @api\n   */\n  getPosition() {\n    return /** @type {import(\"./coordinate.js\").Coordinate|undefined} */ (\n      this.get(Property.POSITION)\n    );\n  }\n\n  /**\n   * Get the projection associated with the position.\n   * @return {import(\"./proj/Projection.js\").default|undefined} The projection the position is\n   *     reported in.\n   * @observable\n   * @api\n   */\n  getProjection() {\n    return /** @type {import(\"./proj/Projection.js\").default|undefined} */ (\n      this.get(Property.PROJECTION)\n    );\n  }\n\n  /**\n   * Get the speed in meters per second.\n   * @return {number|undefined} The instantaneous speed of the device in meters\n   *     per second.\n   * @observable\n   * @api\n   */\n  getSpeed() {\n    return /** @type {number|undefined} */ (this.get(Property.SPEED));\n  }\n\n  /**\n   * Determine if the device location is being tracked.\n   * @return {boolean} The device location is being tracked.\n   * @observable\n   * @api\n   */\n  getTracking() {\n    return /** @type {boolean} */ (this.get(Property.TRACKING));\n  }\n\n  /**\n   * Get the tracking options.\n   * See https://www.w3.org/TR/geolocation-API/#position-options.\n   * @return {PositionOptions|undefined} PositionOptions as defined by\n   *     the [HTML5 Geolocation spec\n   *     ](https://www.w3.org/TR/geolocation-API/#position_options_interface).\n   * @observable\n   * @api\n   */\n  getTrackingOptions() {\n    return /** @type {PositionOptions|undefined} */ (\n      this.get(Property.TRACKING_OPTIONS)\n    );\n  }\n\n  /**\n   * Set the projection to use for transforming the coordinates.\n   * @param {import(\"./proj.js\").ProjectionLike} projection The projection the position is\n   *     reported in.\n   * @observable\n   * @api\n   */\n  setProjection(projection) {\n    this.set(Property.PROJECTION, getProjection(projection));\n  }\n\n  /**\n   * Enable or disable tracking.\n   * @param {boolean} tracking Enable tracking.\n   * @observable\n   * @api\n   */\n  setTracking(tracking) {\n    this.set(Property.TRACKING, tracking);\n  }\n\n  /**\n   * Set the tracking options.\n   * See http://www.w3.org/TR/geolocation-API/#position-options.\n   * @param {PositionOptions} options PositionOptions as defined by the\n   *     [HTML5 Geolocation spec\n   *     ](http://www.w3.org/TR/geolocation-API/#position_options_interface).\n   * @observable\n   * @api\n   */\n  setTrackingOptions(options) {\n    this.set(Property.TRACKING_OPTIONS, options);\n  }\n}\n\nexport default Geolocation;\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/Image\n */\nimport ImageState from './ImageState.js';\nimport {listenOnce, unlistenByKey} from './events.js';\nimport EventType from './events/EventType.js';\nimport EventTarget from './events/Target.js';\nimport {toPromise} from './functions.js';\nimport {CREATE_IMAGE_BITMAP, IMAGE_DECODE} from './has.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<import(\"./DataTile.js\").ImageLike|ImageObject>} 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)=): Promise<import(\"./DataTile.js\").ImageLike|ImageObject>} ImageObjectPromiseLoader\n */\n\nclass ImageWrapper extends EventTarget {\n  /**\n   * @param {import(\"./extent.js\").Extent} extent Extent.\n   * @param {number|Array<number>|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|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<number>|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 {Loader|null}\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<number>} 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              (CREATE_IMAGE_BITMAP && 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<number>} 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<HTMLImageElement>} 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<HTMLImageElement>} 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<ImageBitmap|HTMLImageElement>} 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/ImageCanvas\n */\nimport ImageWrapper from './Image.js';\nimport ImageState from './ImageState.js';\n\n/**\n * A function that is called to trigger asynchronous canvas drawing.  It is\n * called with a \"done\" callback that should be called when drawing is done.\n * If any error occurs during drawing, the \"done\" callback should be called with\n * that error.\n *\n * @typedef {function(function(Error=): void): void} Loader\n */\n\nclass ImageCanvas extends ImageWrapper {\n  /**\n   * @param {import(\"./extent.js\").Extent} extent Extent.\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {HTMLCanvasElement|OffscreenCanvas} canvas Canvas.\n   * @param {Loader} [loader] Optional loader function to\n   *     support asynchronous canvas drawing.\n   */\n  constructor(extent, resolution, pixelRatio, canvas, loader) {\n    const state = loader !== undefined ? ImageState.IDLE : ImageState.LOADED;\n\n    super(extent, resolution, pixelRatio, state);\n\n    /**\n     * Optional canvas loader function.\n     * @type {?Loader}\n     * @private\n     */\n    this.loader_ = loader !== undefined ? loader : null;\n\n    /**\n     * @private\n     * @type {HTMLCanvasElement|OffscreenCanvas}\n     */\n    this.canvas_ = canvas;\n\n    /**\n     * @private\n     * @type {?Error}\n     */\n    this.error_ = null;\n  }\n\n  /**\n   * Get any error associated with asynchronous rendering.\n   * @return {?Error} Any error that occurred during rendering.\n   */\n  getError() {\n    return this.error_;\n  }\n\n  /**\n   * Handle async drawing complete.\n   * @param {Error} [err] Any error during drawing.\n   * @private\n   */\n  handleLoad_(err) {\n    if (err) {\n      this.error_ = err;\n      this.state = ImageState.ERROR;\n    } else {\n      this.state = ImageState.LOADED;\n    }\n    this.changed();\n  }\n\n  /**\n   * Load not yet loaded URI.\n   * @override\n   */\n  load() {\n    if (this.state == ImageState.IDLE) {\n      this.state = ImageState.LOADING;\n      this.changed();\n      this.loader_(this.handleLoad_.bind(this));\n    }\n  }\n\n  /**\n   * @return {HTMLCanvasElement|OffscreenCanvas} Canvas element.\n   * @override\n   */\n  getImage() {\n    return this.canvas_;\n  }\n}\n\nexport default ImageCanvas;\n","/**\n * @module ol/ImageTile\n */\nimport {listenImage} from './Image.js';\nimport Tile from './Tile.js';\nimport TileState from './TileState.js';\nimport {createCanvasContext2D} from './dom.js';\nimport {WORKER_OFFSCREEN_CANVAS} from './has.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 {import('./dom.js').ImageAttributes} imageAttributes Image attributes options.\n   * @param {import(\"./Tile.js\").LoadFunction} tileLoadFunction Tile load function.\n   * @param {import(\"./Tile.js\").Options} [options] Tile options.\n   */\n  constructor(\n    tileCoord,\n    state,\n    src,\n    imageAttributes,\n    tileLoadFunction,\n    options,\n  ) {\n    super(tileCoord, state, options);\n\n    /**\n     * @private\n     * @type {?string}\n     */\n    this.crossOrigin_ = imageAttributes?.crossOrigin;\n\n    /**\n     * @private\n     * @type {ReferrerPolicy}\n     */\n    this.referrerPolicy_ = imageAttributes?.referrerPolicy;\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|OffscreenCanvas}\n     */\n    this.image_;\n\n    if (WORKER_OFFSCREEN_CANVAS) {\n      this.image_ = new OffscreenCanvas(1, 1);\n    } else {\n      this.image_ = new Image();\n      if (this.crossOrigin_ !== null) {\n        this.image_.crossOrigin = this.crossOrigin_;\n      }\n      if (this.referrerPolicy_ !== undefined) {\n        this.image_.referrerPolicy = this.referrerPolicy_;\n      }\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, OffscreenCanvas, Image, or Video).\n   * @return {HTMLCanvasElement|OffscreenCanvas|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|OffscreenCanvas|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   * Get the cross origin of the ImageTile.\n   * @return {string} Cross origin.\n   */\n  getCrossOrigin() {\n    return this.crossOrigin_;\n  }\n\n  /**\n   * Get the referrer policy of the ImageTile.\n   * @return {ReferrerPolicy} Referrer policy.\n   */\n  getReferrerPolicy() {\n    return this.referrerPolicy_;\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    if (WORKER_OFFSCREEN_CANVAS) {\n      // OffscreenCanvas does not have naturalWidth and naturalHeight\n      this.state = TileState.LOADED;\n    } else {\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    }\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      if (this.referrerPolicy_ !== undefined) {\n        this.image_.referrerPolicy = this.referrerPolicy_;\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   * @override\n   */\n  disposeInternal() {\n    this.unlistenImage_();\n    this.image_ = null;\n    super.disposeInternal();\n  }\n}\n\n/**\n * Get a 1-pixel blank image.\n * @return {HTMLCanvasElement|OffscreenCanvas} 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/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<number>}\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/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 {PointerEvent|KeyboardEvent|WheelEvent} [EVENT=PointerEvent|KeyboardEvent|WheelEvent]\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<PointerEvent>} [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<PointerEvent>|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 MapBrowserEvent from './MapBrowserEvent.js';\nimport MapBrowserEventType from './MapBrowserEventType.js';\nimport {listen, unlistenByKey} from './events.js';\nimport EventType from './events/EventType.js';\nimport Target from './events/Target.js';\nimport {PASSIVE_EVENT_LISTENERS} from './has.js';\nimport PointerEventType from './pointer/EventType.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<typeof setTimeout>}\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<import(\"./events.js\").EventsKey>}\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<PointerEvent>}\n     * @private\n     */\n    this.activePointers_ = [];\n\n    /**\n     * @type {!Object<number, Event>}\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/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<T>}\n     * @private\n     */\n    this.elements_ = [];\n\n    /**\n     * @type {Array<number>}\n     * @private\n     */\n    this.priorities_ = [];\n\n    /**\n     * @type {!Object<string, boolean>}\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 TileState from './TileState.js';\nimport EventType from './events/EventType.js';\nimport PriorityQueue, {DROP} from './structs/PriorityQueue.js';\n\n/**\n * @typedef {function(import(\"./Tile.js\").default, string, import('./tilecoord.js').TileCoord, number): number} PriorityFunction\n */\n\n/**\n * @typedef {[import('./Tile.js').default, string, import('./tilecoord.js').TileCoord, number]} TileQueueElement\n */\n\n/**\n * @extends PriorityQueue<TileQueueElement>}\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      (element) => tilePriorityFunction.apply(null, element),\n      (element) => element[0].getKey(),\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<string,boolean>}\n     */\n    this.tilesLoadingKeys_ = {};\n  }\n\n  /**\n   * @param {TileQueueElement} 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      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/ViewHint\n */\n\n/**\n * @enum {number}\n */\nexport default {\n  ANIMATING: 0,\n  INTERACTING: 1,\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<number>=): (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<number>} [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 {linearFindNearest} from './array.js';\nimport {getHeight, getWidth} from './extent.js';\nimport {clamp} from './math.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<number>} 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/rotationconstraint\n */\nimport {toRadians} from './math.js';\n\n/**\n * @typedef {function((number|undefined), boolean=): (number|undefined)} Type\n */\n\n/**\n * @param {number|undefined} rotation Rotation.\n * @return {number|undefined} Rotation.\n */\nexport function disable(rotation) {\n  if (rotation !== undefined) {\n    return 0;\n  }\n  return undefined;\n}\n\n/**\n * @param {number|undefined} rotation Rotation.\n * @return {number|undefined} Rotation.\n */\nexport function none(rotation) {\n  if (rotation !== undefined) {\n    return rotation;\n  }\n  return undefined;\n}\n\n/**\n * @param {number} n N.\n * @return {Type} Rotation constraint.\n */\nexport function createSnapToN(n) {\n  const theta = (2 * Math.PI) / n;\n  return (\n    /**\n     * @param {number|undefined} rotation Rotation.\n     * @param {boolean} [isMoving] True if an interaction or animation is in progress.\n     * @return {number|undefined} Rotation.\n     */\n    function (rotation, isMoving) {\n      if (isMoving) {\n        return rotation;\n      }\n\n      if (rotation !== undefined) {\n        rotation = Math.floor(rotation / theta + 0.5) * theta;\n        return rotation;\n      }\n      return undefined;\n    }\n  );\n}\n\n/**\n * @param {number} [tolerance] Tolerance.\n * @return {Type} Rotation constraint.\n */\nexport function createSnapToZero(tolerance) {\n  const t = tolerance === undefined ? toRadians(5) : tolerance;\n  return (\n    /**\n     * @param {number|undefined} rotation Rotation.\n     * @param {boolean} [isMoving] True if an interaction or animation is in progress.\n     * @return {number|undefined} Rotation.\n     */\n    function (rotation, isMoving) {\n      if (isMoving || rotation === undefined) {\n        return rotation;\n      }\n\n      if (Math.abs(rotation) <= t) {\n        return 0;\n      }\n      return rotation;\n    }\n  );\n}\n","/**\n * @module ol/tilegrid/common\n */\n\n/**\n * Default maximum zoom for default tile grids.\n * @type {number}\n */\nexport const DEFAULT_MAX_ZOOM = 42;\n\n/**\n * Default tile size.\n * @type {number}\n */\nexport const DEFAULT_TILE_SIZE = 256;\n","/**\n * @module ol/View\n */\nimport BaseObject from './Object.js';\nimport ViewHint from './ViewHint.js';\nimport ViewProperty from './ViewProperty.js';\nimport {linearFindNearest} from './array.js';\nimport {assert} from './asserts.js';\nimport {none as centerNone, createExtent} from './centerconstraint.js';\nimport {\n  add as addCoordinate,\n  equals as coordinatesEqual,\n  equals,\n  rotate as rotateCoordinate,\n} from './coordinate.js';\nimport {easeOut, inAndOut} from './easing.js';\nimport {\n  getCenter,\n  getForViewAndSize,\n  getHeight,\n  getWidth,\n  isEmpty,\n} from './extent.js';\nimport {VOID} from './functions.js';\nimport {fromExtent as polygonFromExtent} from './geom/Polygon.js';\nimport {clamp, modulo} from './math.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 {\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 {DEFAULT_TILE_SIZE} from './tilegrid/common.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<number>} [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<number>} [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<number>} [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<import(\"./layer/Layer.js\").State>} [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.js\").Types|'change:center'|'change:resolution'|'change:rotation'} ViewObjectEventTypes\n */\n\n/***\n * @template Return\n * @typedef {import(\"./Observable.js\").OnSignature<import(\"./Observable.js\").EventTypes, import(\"./events/Event.js\").default, Return> &\n *   import(\"./Observable.js\").OnSignature<ViewObjectEventTypes, import(\"./Object.js\").ObjectEvent, Return> &\n *   import(\"./Observable.js\").CombinedOnSignature<import(\"./Observable.js\").EventTypes|ViewObjectEventTypes, Return>} 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 * @extends {BaseObject<ViewOptions>}\n */\nclass View extends BaseObject {\n  /**\n   * @param {ViewOptions} [options] View options.\n   */\n  constructor(options) {\n    super();\n\n    /***\n     * @type {ViewOnSignature<import(\"./events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {ViewOnSignature<import(\"./events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {ViewOnSignature<void>}\n     */\n    this.un;\n\n    options = Object.assign({}, options);\n\n    /**\n     * @private\n     * @type {Array<number>}\n     */\n    this.hints_ = [0, 0];\n\n    /**\n     * @private\n     * @type {Array<Array<Animation>>}\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<number>|undefined}\n     */\n    this.resolutions_ = options.resolutions;\n\n    /**\n     * @type {Array<number>|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<number>|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<number>} [hints] Destination array.\n   * @return {Array<number>} 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<number>|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_?.length) {\n      if (this.resolutions_.length === 1) {\n        return this.resolutions_[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.js\").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<number>|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] 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] 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/**\n * @typedef {function(ViewOptions):ViewOptions} ViewTransform\n */\n\n/**\n * Adds higher resolutions.\n * @param {number} num The number of higher resolution levels to use.\n * @return {ViewTransform} A view transform.\n */\nexport function withHigherResolutions(num) {\n  return function (options) {\n    if (!options.resolutions) {\n      return options;\n    }\n    const resolutions = [...options.resolutions];\n    const highest = resolutions[resolutions.length - 1];\n    for (let i = 0; i < num; ++i) {\n      resolutions.push(highest / Math.pow(2, i + 1));\n    }\n    return {\n      ...options,\n      resolutions,\n    };\n  };\n}\n\n/**\n * Adds lower resolutions.\n * @param {number} num The number of lower resolution levels to use.\n * @return {ViewTransform} A view transform.\n * @api\n */\nexport function withLowerResolutions(num) {\n  return function (options) {\n    if (!options.resolutions) {\n      return options;\n    }\n    const resolutions = [...options.resolutions];\n    const lowest = resolutions[0];\n    for (let i = 0; i < num; ++i) {\n      resolutions.unshift(lowest * Math.pow(2, i + 1));\n    }\n    return {\n      ...options,\n      resolutions,\n    };\n  };\n}\n\n/**\n * Applies a center based on the extent.\n * @return {ViewTransform} A view transform.\n * @api\n */\nexport function withExtentCenter() {\n  return function (options) {\n    if (!options.extent) {\n      return options;\n    }\n    const center = getCenter(options.extent);\n    const newOptions = {...options, center};\n    delete newOptions.extent;\n    return newOptions;\n  };\n}\n\n/**\n * Applies a zoom level.\n * @param {number} z The zoom level.\n * @return {ViewTransform} A view transform.\n * @api\n */\nexport function withZoom(z) {\n  return function (options) {\n    return {...options, zoom: z};\n  };\n}\n\n/**\n * Applies a series of transforms to a view that is resolved from a source.\n * @param {import(\"./source/Source.js\").default} source The source.\n * @param {...ViewTransform} transforms The transforms to apply.\n * @return {Promise<ViewOptions>} The view options.\n * @api\n */\nexport async function getView(source, ...transforms) {\n  let config = await source.getView();\n  for (const transform of transforms) {\n    config = transform(config);\n  }\n  return config;\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<string>} 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-z0-9]+?)\\\\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/** @type {Object<string|number, number>} */\nexport const fontWeights = {\n  normal: 400,\n  bold: 700,\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: '400',\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]] =\n        typeof value === 'string' ? value.trim() : value;\n    }\n  }\n  if (isNaN(Number(style.weight)) && style.weight in fontWeights) {\n    style.weight = fontWeights[style.weight];\n  }\n  style.families = style.family\n    .split(/,\\s?/)\n    .map((f) => f.trim().replace(/^['\"]|['\"]$/g, ''));\n  return style;\n};\n","/**\n * @module ol/control/Control\n */\nimport MapEventType from '../MapEventType.js';\nimport BaseObject from '../Object.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport {VOID} from '../functions.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<import(\"../events.js\").EventsKey>}\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      if (this.element) {\n        target.appendChild(this.element);\n      }\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 {equals} from '../array.js';\nimport {CLASS_COLLAPSED, CLASS_CONTROL, CLASS_UNSELECTABLE} from '../css.js';\nimport {removeChildren, replaceNode} from '../dom.js';\nimport EventType from '../events/EventType.js';\nimport {toPromise} from '../functions.js';\nimport Control from './Control.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 * @property {string|Array<string>|undefined} [attributions] Optional attribution(s) that will always be\n * displayed regardless of the layers rendered.\n * **Caution:** Attributions are rendered dynamically using `innerHTML`, which can lead to potential\n * [**XSS (Cross-Site Scripting)**](https://en.wikipedia.org/wiki/Cross-site_scripting) vulnerabilities.\n * Use this feature only for trusted content\n * or ensure that the content is properly sanitized before inserting it.\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    /**\n     * @private\n     * @type {string | Array<string> | undefined}\n     */\n    this.attributions_ = options.attributions;\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<string>}\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<string>} Attributions.\n   * @private\n   */\n  collectSourceAttributions_(frameState) {\n    const layers = this.getMap().getAllLayers();\n    const visibleAttributions = new Set(\n      layers.flatMap((layer) => layer.getAttributions(frameState)),\n    );\n    if (this.attributions_ !== undefined) {\n      Array.isArray(this.attributions_)\n        ? this.attributions_.forEach((item) => visibleAttributions.add(item))\n        : visibleAttributions.add(this.attributions_);\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 Array.from(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 {CLASS_CONTROL, CLASS_HIDDEN, CLASS_UNSELECTABLE} from '../css.js';\nimport {easeOut} from '../easing.js';\nimport EventType from '../events/EventType.js';\nimport Control from './Control.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 {CLASS_CONTROL, CLASS_UNSELECTABLE} from '../css.js';\nimport {easeOut} from '../easing.js';\nimport EventType from '../events/EventType.js';\nimport Control from './Control.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/control/defaults\n */\nimport Collection from '../Collection.js';\nimport Attribution from './Attribution.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<import(\"./Control.js\").default>} 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<import(\"./Control.js\").default>} */\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/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 {easeOut, linear} from '../easing.js';\nimport InteractionProperty from './Property.js';\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types|\n *     'change:active', import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"../ObjectEventType.js\").Types|\n *     'change:active', Return>} 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<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {InteractionOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {InteractionOnSignature<void>}\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 MapBrowserEventType from '../MapBrowserEventType.js';\nimport Interaction, {zoomByDelta} from './Interaction.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/events/condition\n */\nimport MapBrowserEventType from '../MapBrowserEventType.js';\nimport {FALSE, TRUE} from '../functions.js';\nimport {MAC, WEBKIT} from '../has.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 = mapBrowserEvent.originalEvent;\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 = mapBrowserEvent.originalEvent;\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. `<div id=\"map\" tabindex=\"1\">`.\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 rootNode = targetElement.getRootNode();\n  const activeElement = event.map.getOwnerDocument().activeElement;\n\n  return rootNode instanceof ShadowRoot\n    ? rootNode.host.contains(activeElement)\n    : 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  const targetElement = event.map.getTargetElement();\n  const rootNode = targetElement.getRootNode();\n  const tabIndexCandidate =\n    rootNode instanceof ShadowRoot ? rootNode.host : targetElement;\n\n  return tabIndexCandidate.hasAttribute('tabindex') ? focus(event) : 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 = mapBrowserEvent.originalEvent;\n  return (\n    'pointerId' in originalEvent &&\n    originalEvent.button == 0 &&\n    !(WEBKIT && MAC && originalEvent.ctrlKey)\n  );\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 = mapBrowserEvent.originalEvent;\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 = mapBrowserEvent.originalEvent;\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 = mapBrowserEvent.originalEvent;\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 = mapBrowserEvent.originalEvent;\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 = mapBrowserEvent.originalEvent;\n  // see https://www.w3.org/TR/pointerevents/#widl-PointerEvent-pointerType\n  return 'pointerId' in pointerEvent && 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 = mapBrowserEvent.originalEvent;\n  // see https://www.w3.org/TR/pointerevents/#widl-PointerEvent-pointerType\n  return 'pointerId' in pointerEvt && 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 = mapBrowserEvent.originalEvent;\n  // see https://www.w3.org/TR/pointerevents/#widl-PointerEvent-pointerType\n  return 'pointerId' in pointerEvt && 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 = mapBrowserEvent.originalEvent;\n  return (\n    'pointerId' in pointerEvent &&\n    pointerEvent.isPrimary &&\n    pointerEvent.button === 0\n  );\n};\n","/**\n * @module ol/interaction/Pointer\n */\nimport MapBrowserEventType from '../MapBrowserEventType.js';\nimport Interaction from './Interaction.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<PointerEvent>}\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<PointerEvent>} 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/interaction/DragPan\n */\nimport {\n  rotate as rotateCoordinate,\n  scale as scaleCoordinate,\n} from '../coordinate.js';\nimport {easeOut} from '../easing.js';\nimport {\n  all,\n  focusWithTabindex,\n  noModifierKeys,\n  primaryAction,\n} from '../events/condition.js';\nimport {FALSE} from '../functions.js';\nimport PointerInteraction, {\n  centroid as centroidFromPointers,\n} from './Pointer.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 {\n  altShiftKeysOnly,\n  mouseActionButton,\n  mouseOnly,\n} from '../events/condition.js';\nimport {FALSE} from '../functions.js';\nimport {disable} from '../rotationconstraint.js';\nimport PointerInteraction from './Pointer.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 {mouseActionButton} from '../events/condition.js';\nimport RenderBox from '../render/Box.js';\nimport PointerInteraction from './Pointer.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.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types|\n *     'change:active', import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<'boxcancel'|'boxdrag'|'boxend'|'boxstart', DragBoxEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"../ObjectEventType.js\").Types|\n *     'change:active'|'boxcancel'|'boxdrag'|'boxend', Return>} 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<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {DragBoxOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {DragBoxOnSignature<void>}\n     */\n    this.un;\n\n    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 ?? 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 ?? mouseActionButton;\n\n    /**\n     * @private\n     * @type {EndCondition}\n     */\n    this.boxEndCondition_ =\n      options.boxEndCondition ?? 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    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\n    this.box_.setMap(null);\n    this.startPixel_ = null;\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  /**\n   * @param {import(\"../Map.js\").default|null} map Map.\n   * @override\n   */\n  setMap(map) {\n    const oldMap = this.getMap();\n\n    if (oldMap) {\n      this.box_.setMap(null);\n\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.setMap(map);\n  }\n}\n\nexport default DragBox;\n","/**\n * @module ol/interaction/DragZoom\n */\nimport {easeOut} from '../easing.js';\nimport {shiftKeyOnly} from '../events/condition.js';\nimport DragBox from './DragBox.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 {rotate as rotateCoordinate} from '../coordinate.js';\nimport EventType from '../events/EventType.js';\nimport Key from '../events/Key.js';\nimport {noModifierKeys, targetNotEditable} from '../events/condition.js';\nimport Interaction, {pan} from './Interaction.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 {platformModifierKey, targetNotEditable} from '../events/condition.js';\nimport Interaction, {zoomByDelta} from './Interaction.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/interaction/MouseWheelZoom\n */\nimport {listen, unlistenByKey} from '../events.js';\nimport EventType from '../events/EventType.js';\nimport {all, always, focusWithTabindex} from '../events/condition.js';\nimport {clamp} from '../math.js';\nimport Interaction, {zoomByDelta} from './Interaction.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 * Mutliplier for the DOM_DELTA_LINE delta value.\n * @type {number}\n */\nconst DELTA_LINE_MULTIPLIER = 40;\n\n/**\n * Mutliplier for the DOM_DELTA_PAGE delta value.\n * @type {number}\n */\nconst DELTA_PAGE_MULTIPLIER = 300;\n\n/**\n * Mutliplier for the delta value when using pinch-to-zoom\n * @type {number}\n */\nconst DELTA_TRACKPAD_PINCH_TO_ZOOM_MULTIPLIER = 3; // 5 = google maps. 3 = apple maps, MapLibre.\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(\"../pixel.js\").Pixel}\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<typeof setTimeout>}\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<typeof setTimeout>}\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     * Tracks whether the Ctrl key is physically held down (as opposed to the\n     * browser synthesizing ctrlKey=true for pinch-to-zoom trackpad gestures).\n     * @private\n     * @type {boolean}\n     */\n    this.ctrlKeyPressed_ = false;\n\n    /**\n     * @private\n     * @type {Array<import('../events.js').EventsKey>}\n     */\n    this.ctrlKeyListenerKeys_ = [];\n  }\n\n  /**\n   * @param {import('../Map.js').default|null} map Map.\n   * @override\n   */\n  setMap(map) {\n    this.ctrlKeyListenerKeys_.forEach(unlistenByKey);\n    this.ctrlKeyListenerKeys_.length = 0;\n    this.ctrlKeyPressed_ = false;\n    super.setMap(map);\n    if (map) {\n      const doc = map.getOwnerDocument();\n      this.ctrlKeyListenerKeys_.push(\n        listen(doc, 'keydown', (/** @type {KeyboardEvent} */ e) => {\n          if (e.key === 'Control') {\n            this.ctrlKeyPressed_ = true;\n          }\n        }),\n        listen(doc, 'keyup', (/** @type {KeyboardEvent} */ e) => {\n          if (e.key === 'Control') {\n            this.ctrlKeyPressed_ = false;\n          }\n        }),\n      );\n    }\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    const direction = this.lastDelta_ ? (this.lastDelta_ > 0 ? 1 : -1) : 0;\n    view.endInteraction(\n      this.constrainResolution_ || view.getConstrainResolution()\n        ? 100\n        : undefined,\n      direction,\n      this.lastAnchor_ ? map.getCoordinateFromPixel(this.lastAnchor_) : null,\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    const isPinchToZoom = wheelEvent.ctrlKey && !this.ctrlKeyPressed_;\n    if (!wheelEvent.ctrlKey) {\n      this.ctrlKeyPressed_ = false;\n    }\n\n    if (this.useAnchor_) {\n      this.lastAnchor_ = mapBrowserEvent.pixel;\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 = wheelEvent.deltaY;\n\n    switch (wheelEvent.deltaMode) {\n      case WheelEvent.DOM_DELTA_LINE:\n        delta *= DELTA_LINE_MULTIPLIER;\n        break;\n      case WheelEvent.DOM_DELTA_PAGE:\n        delta *= DELTA_PAGE_MULTIPLIER;\n        break;\n      default:\n      // pass\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 (this.mode_ === 'trackpad') {\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      if (isPinchToZoom) {\n        delta = delta * DELTA_TRACKPAD_PINCH_TO_ZOOM_MULTIPLIER;\n      }\n      view.adjustZoom(\n        -delta / this.deltaPerZoom_,\n        this.lastAnchor_ ? map.getCoordinateFromPixel(this.lastAnchor_) : null,\n      );\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(\n      view,\n      delta,\n      this.lastAnchor_ ? map.getCoordinateFromPixel(this.lastAnchor_) : null,\n      this.duration_,\n    );\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 {FALSE} from '../functions.js';\nimport {disable} from '../rotationconstraint.js';\nimport PointerInteraction, {\n  centroid as centroidFromPointers,\n} from './Pointer.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 {FALSE} from '../functions.js';\nimport PointerInteraction, {\n  centroid as centroidFromPointers,\n} from './Pointer.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/interaction/defaults\n */\nimport Collection from '../Collection.js';\nimport Kinetic from '../Kinetic.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 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<import(\"./Interaction.js\").default>}\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<import(\"./Interaction.js\").default>} */\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/layer/Property\n */\n\n/**\n * @enum {string}\n */\nexport default {\n  OPACITY: 'opacity',\n  VISIBLE: 'visible',\n  EXTENT: 'extent',\n  Z_INDEX: 'zIndex',\n  MAX_RESOLUTION: 'maxResolution',\n  MIN_RESOLUTION: 'minResolution',\n  MAX_ZOOM: 'maxZoom',\n  MIN_ZOOM: 'minZoom',\n  SOURCE: 'source',\n  MAP: 'map',\n};\n","/**\n * @module ol/layer/Base\n */\nimport BaseObject from '../Object.js';\nimport {assert} from '../asserts.js';\nimport {clamp} from '../math.js';\nimport {abstract} from '../util.js';\nimport LayerProperty from './Property.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.js\").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.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<BaseLayerObjectEventTypes, import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|BaseLayerObjectEventTypes, Return>} BaseLayerOnSignature\n */\n\n/**\n * @template {Object<string, *>} [Properties=Object<string, *>]\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 {Properties} [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 * @template {Object<string, *>} [Properties=Object<string, *>]\n * @extends {BaseObject<NoInfer<Properties> & Object<string, *>>}\n */\nclass BaseLayer extends BaseObject {\n  /**\n   * @param {Options<NoInfer<Properties>>} options Layer options.\n   */\n  constructor(options) {\n    super();\n\n    /***\n     * @type {BaseLayerOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {BaseLayerOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {BaseLayerOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @type {BackgroundColor|false}\n     * @private\n     */\n    this.background_ = options.background;\n\n    /**\n     * @type {?}\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<import(\"./Layer.js\").default>} [array] Array of layers (to be\n   *     modified in place).\n   * @return {Array<import(\"./Layer.js\").default>} Array of layers.\n   */\n  getLayersArray(array) {\n    return abstract();\n  }\n\n  /**\n   * @abstract\n   * @param {Array<import(\"./Layer.js\").State>} [states] Optional list of layer\n   *     states (to be modified in place).\n   * @return {Array<import(\"./Layer.js\").State>} 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/layer/Group\n */\nimport Collection from '../Collection.js';\nimport CollectionEventType from '../CollectionEventType.js';\nimport ObjectEventType from '../ObjectEventType.js';\nimport {assert} from '../asserts.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport Event from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport {getIntersection} from '../extent.js';\nimport {clear} from '../obj.js';\nimport {getUid} from '../util.js';\nimport BaseLayer from './Base.js';\n\n/**\n * @enum {string}\n */\nconst GroupEventType = {\n  /**\n   * Triggered when a layer is added\n   * @event GroupEvent#addlayer\n   * @api\n   */\n  ADDLAYER: 'addlayer',\n  /**\n   * Triggered when a layer is removed\n   * @event GroupEvent#removelayer\n   * @api\n   */\n  REMOVELAYER: 'removelayer',\n};\n\n/**\n * @classdesc\n * A layer group triggers 'addlayer' and 'removelayer' events when layers are added to or removed from\n * the group or one of its child groups.  When a layer group is added to or removed from another layer group,\n * a single event will be triggered (instead of one per layer in the group added or removed).\n */\nexport class GroupEvent extends Event {\n  /**\n   * @param {GroupEventType} type The event type.\n   * @param {BaseLayer} layer The layer.\n   */\n  constructor(type, layer) {\n    super(type);\n\n    /**\n     * The added or removed layer.\n     * @type {BaseLayer}\n     * @api\n     */\n    this.layer = layer;\n  }\n}\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"./Base.js\").BaseLayerObjectEventTypes|\n *     'change:layers', import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<'addlayer'|'removelayer', GroupEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"./Base.js\").BaseLayerObjectEventTypes|'addlayer'|'removelayer'|'change:layers', Return>} GroupOnSignature\n */\n\n/**\n * @typedef {Object} Options\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} [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 {Array<import(\"./Base.js\").default>|Collection<import(\"./Base.js\").default>} [layers] Child layers.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n\n/**\n * @enum {string}\n * @private\n */\nconst Property = {\n  LAYERS: 'layers',\n};\n\n/**\n * @classdesc\n * A {@link module:ol/Collection~Collection} of layers that are handled together.\n *\n * A generic `change` event is triggered when the group/Collection changes.\n *\n * @fires GroupEvent\n * @api\n */\nclass LayerGroup extends BaseLayer {\n  /**\n   * @param {Options} [options] Layer options.\n   */\n  constructor(options) {\n    options = options || {};\n    const baseOptions = /** @type {Options} */ (Object.assign({}, options));\n    delete baseOptions.layers;\n\n    let layers = options.layers;\n\n    super(baseOptions);\n\n    /***\n     * @type {GroupOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {GroupOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {GroupOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @private\n     * @type {Array<import(\"../events.js\").EventsKey>}\n     */\n    this.layersListenerKeys_ = [];\n\n    /**\n     * @private\n     * @type {Object<string, Array<import(\"../events.js\").EventsKey>>}\n     */\n    this.listenerKeys_ = {};\n\n    this.addChangeListener(Property.LAYERS, this.handleLayersChanged_);\n\n    if (layers) {\n      if (Array.isArray(layers)) {\n        layers = new Collection(layers.slice(), {unique: true});\n      } else {\n        assert(\n          typeof (/** @type {?} */ (layers).getArray) === 'function',\n          'Expected `layers` to be an array or a `Collection`',\n        );\n      }\n    } else {\n      layers = new Collection(undefined, {unique: true});\n    }\n\n    this.setLayers(layers);\n  }\n\n  /**\n   * @private\n   */\n  handleLayerChange_() {\n    this.changed();\n  }\n\n  /**\n   * @private\n   */\n  handleLayersChanged_() {\n    this.layersListenerKeys_.forEach(unlistenByKey);\n    this.layersListenerKeys_.length = 0;\n\n    const layers = this.getLayers();\n    this.layersListenerKeys_.push(\n      listen(layers, CollectionEventType.ADD, this.handleLayersAdd_, this),\n      listen(\n        layers,\n        CollectionEventType.REMOVE,\n        this.handleLayersRemove_,\n        this,\n      ),\n    );\n\n    for (const id in this.listenerKeys_) {\n      this.listenerKeys_[id].forEach(unlistenByKey);\n    }\n    clear(this.listenerKeys_);\n\n    const layersArray = layers.getArray();\n    for (let i = 0, ii = layersArray.length; i < ii; i++) {\n      const layer = layersArray[i];\n      this.registerLayerListeners_(layer);\n      this.dispatchEvent(new GroupEvent(GroupEventType.ADDLAYER, layer));\n    }\n    this.changed();\n  }\n\n  /**\n   * @param {BaseLayer} layer The layer.\n   */\n  registerLayerListeners_(layer) {\n    const listenerKeys = [\n      listen(\n        layer,\n        ObjectEventType.PROPERTYCHANGE,\n        this.handleLayerChange_,\n        this,\n      ),\n      listen(layer, EventType.CHANGE, this.handleLayerChange_, this),\n    ];\n\n    if (layer instanceof LayerGroup) {\n      listenerKeys.push(\n        listen(layer, GroupEventType.ADDLAYER, this.handleLayerGroupAdd_, this),\n        listen(\n          layer,\n          GroupEventType.REMOVELAYER,\n          this.handleLayerGroupRemove_,\n          this,\n        ),\n      );\n    }\n\n    this.listenerKeys_[getUid(layer)] = listenerKeys;\n  }\n\n  /**\n   * @param {GroupEvent} event The layer group event.\n   */\n  handleLayerGroupAdd_(event) {\n    this.dispatchEvent(new GroupEvent(GroupEventType.ADDLAYER, event.layer));\n  }\n\n  /**\n   * @param {GroupEvent} event The layer group event.\n   */\n  handleLayerGroupRemove_(event) {\n    this.dispatchEvent(new GroupEvent(GroupEventType.REMOVELAYER, event.layer));\n  }\n\n  /**\n   * @param {import(\"../Collection.js\").CollectionEvent<import(\"./Base.js\").default>} collectionEvent CollectionEvent.\n   * @private\n   */\n  handleLayersAdd_(collectionEvent) {\n    const layer = collectionEvent.element;\n    this.registerLayerListeners_(layer);\n    this.dispatchEvent(new GroupEvent(GroupEventType.ADDLAYER, layer));\n    this.changed();\n  }\n\n  /**\n   * @param {import(\"../Collection.js\").CollectionEvent<import(\"./Base.js\").default>} collectionEvent CollectionEvent.\n   * @private\n   */\n  handleLayersRemove_(collectionEvent) {\n    const layer = collectionEvent.element;\n    const key = getUid(layer);\n    this.listenerKeys_[key].forEach(unlistenByKey);\n    delete this.listenerKeys_[key];\n    this.dispatchEvent(new GroupEvent(GroupEventType.REMOVELAYER, layer));\n    this.changed();\n  }\n\n  /**\n   * Returns the {@link module:ol/Collection~Collection collection} of {@link module:ol/layer/Layer~Layer layers}\n   * in this group.\n   * @return {!Collection<import(\"./Base.js\").default>} Collection of\n   *   {@link module:ol/layer/Base~BaseLayer layers} that are part of this group.\n   * @observable\n   * @api\n   */\n  getLayers() {\n    return /** @type {!Collection<import(\"./Base.js\").default>} */ (\n      this.get(Property.LAYERS)\n    );\n  }\n\n  /**\n   * Set the {@link module:ol/Collection~Collection collection} of {@link module:ol/layer/Layer~Layer layers}\n   * in this group.\n   * @param {!Collection<import(\"./Base.js\").default>} layers Collection of\n   *   {@link module:ol/layer/Base~BaseLayer layers} that are part of this group.\n   * @observable\n   * @api\n   */\n  setLayers(layers) {\n    const collection = this.getLayers();\n    if (collection) {\n      const currentLayers = collection.getArray();\n      for (let i = 0, ii = currentLayers.length; i < ii; ++i) {\n        this.dispatchEvent(\n          new GroupEvent(GroupEventType.REMOVELAYER, currentLayers[i]),\n        );\n      }\n    }\n\n    this.set(Property.LAYERS, layers);\n  }\n\n  /**\n   * @param {Array<import(\"./Layer.js\").default>} [array] Array of layers (to be modified in place).\n   * @return {Array<import(\"./Layer.js\").default>} Array of layers.\n   * @override\n   */\n  getLayersArray(array) {\n    array = array !== undefined ? array : [];\n    this.getLayers().forEach(function (layer) {\n      layer.getLayersArray(array);\n    });\n    return array;\n  }\n\n  /**\n   * Get the layer states list and use this groups z-index as the default\n   * for all layers in this and nested groups, if it is unset at this point.\n   * If dest is not provided and this group's z-index is undefined\n   * 0 is used a the default z-index.\n   * @param {Array<import(\"./Layer.js\").State>} [dest] Optional list\n   * of layer states (to be modified in place).\n   * @return {Array<import(\"./Layer.js\").State>} List of layer states.\n   * @override\n   */\n  getLayerStatesArray(dest) {\n    const states = dest !== undefined ? dest : [];\n    const pos = states.length;\n\n    this.getLayers().forEach(function (layer) {\n      layer.getLayerStatesArray(states);\n    });\n\n    const ownLayerState = this.getLayerState();\n    let defaultZIndex = ownLayerState.zIndex;\n    if (!dest && ownLayerState.zIndex === undefined) {\n      defaultZIndex = 0;\n    }\n    for (let i = pos, ii = states.length; i < ii; i++) {\n      const layerState = states[i];\n      layerState.opacity *= ownLayerState.opacity;\n      layerState.visible = layerState.visible && ownLayerState.visible;\n      layerState.maxResolution = Math.min(\n        layerState.maxResolution,\n        ownLayerState.maxResolution,\n      );\n      layerState.minResolution = Math.max(\n        layerState.minResolution,\n        ownLayerState.minResolution,\n      );\n      layerState.minZoom = Math.max(layerState.minZoom, ownLayerState.minZoom);\n      layerState.maxZoom = Math.min(layerState.maxZoom, ownLayerState.maxZoom);\n      if (ownLayerState.extent !== undefined) {\n        if (layerState.extent !== undefined) {\n          layerState.extent = getIntersection(\n            layerState.extent,\n            ownLayerState.extent,\n          );\n        } else {\n          layerState.extent = ownLayerState.extent;\n        }\n      }\n      if (layerState.zIndex === undefined) {\n        layerState.zIndex = defaultZIndex;\n      }\n    }\n\n    return states;\n  }\n\n  /**\n   * @return {import(\"../source/Source.js\").State} Source state.\n   * @override\n   */\n  getSourceState() {\n    return 'ready';\n  }\n}\n\nexport default LayerGroup;\n","/**\n * @module ol/render/EventType\n */\n\n/**\n * @enum {string}\n */\nexport default {\n  /**\n   * Triggered before a layer is rendered.\n   * @event module:ol/render/Event~RenderEvent#prerender\n   * @api\n   */\n  PRERENDER: 'prerender',\n\n  /**\n   * Triggered after a layer is rendered.\n   * @event module:ol/render/Event~RenderEvent#postrender\n   * @api\n   */\n  POSTRENDER: 'postrender',\n\n  /**\n   * Triggered before layers are composed.  When dispatched by the map, the event object will not have\n   * a `context` set.  When dispatched by a layer, the event object will have a `context` set.  Only\n   * WebGL layers currently dispatch this event.\n   * @event module:ol/render/Event~RenderEvent#precompose\n   * @api\n   */\n  PRECOMPOSE: 'precompose',\n\n  /**\n   * Triggered after layers are composed.  When dispatched by the map, the event object will not have\n   * a `context` set.  When dispatched by a layer, the event object will have a `context` set.  Only\n   * WebGL layers currently dispatch this event.\n   * @event module:ol/render/Event~RenderEvent#postcompose\n   * @api\n   */\n  POSTCOMPOSE: 'postcompose',\n\n  /**\n   * Triggered when rendering is complete, i.e. all sources and tiles have\n   * finished loading for the current viewport, and all tiles are faded in.\n   * The event object will not have a `context` set.\n   * @event module:ol/render/Event~RenderEvent#rendercomplete\n   * @api\n   */\n  RENDERCOMPLETE: 'rendercomplete',\n};\n\n/**\n * @typedef {'postrender'|'precompose'|'postcompose'|'rendercomplete'} MapRenderEventTypes\n */\n\n/**\n * @typedef {'postrender'|'prerender'} LayerRenderEventTypes\n */\n","/**\n * @module ol/layer/Layer\n */\nimport View from '../View.js';\nimport {assert} from '../asserts.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport EventType from '../events/EventType.js';\nimport {intersects} from '../extent.js';\nimport RenderEventType from '../render/EventType.js';\nimport BaseLayer from './Base.js';\nimport LayerProperty from './Property.js';\n\n/**\n * @typedef {function(import(\"../Map.js\").FrameState):HTMLElement} RenderFunction\n */\n\n/**\n * @typedef {'sourceready'|'change:source'} LayerEventType\n */\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"./Base.js\").BaseLayerObjectEventTypes|\n *     LayerEventType, import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../render/EventType.js\").LayerRenderEventTypes, import(\"../render/Event.js\").default, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"./Base.js\").BaseLayerObjectEventTypes|LayerEventType|\n *     import(\"../render/EventType.js\").LayerRenderEventTypes, Return>} LayerOnSignature\n */\n\n/**\n * @template {import(\"../source/Source.js\").default} [SourceType=import(\"../source/Source.js\").default]\n * @template {Object<string, *>} [Properties=Object<string, *>]\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} [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 {SourceType} [source] Source for this layer.  If not provided to the constructor,\n * the source can be set by calling {@link module:ol/layer/Layer~Layer#setSource layer.setSource(source)} after\n * construction.\n * @property {import(\"../Map.js\").default|null} [map] Map.\n * @property {RenderFunction} [render] Render function. Takes the frame state as input and is expected to return an\n * HTML element. Will overwrite the default rendering for the layer.\n * @property {Properties} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n\n/**\n * @typedef {Object} State\n * @property {import(\"./Layer.js\").default} layer Layer.\n * @property {number} opacity Opacity, the value is rounded to two digits to appear after the decimal point.\n * @property {boolean} visible Visible.\n * @property {boolean} managed Managed.\n * @property {import(\"../extent.js\").Extent} [extent] Extent.\n * @property {number} zIndex ZIndex.\n * @property {number} maxResolution Maximum resolution.\n * @property {number} minResolution Minimum resolution.\n * @property {number} minZoom Minimum zoom.\n * @property {number} maxZoom Maximum zoom.\n */\n\n/**\n * @classdesc\n * Base class from which all layer types are derived. This should only be instantiated\n * in the case where a custom layer is added to the map with a custom `render` function.\n * Such a function can be specified in the `options` object, and is expected to return an HTML element.\n *\n * A visual representation of raster or vector map data.\n * Layers group together those properties that pertain to how the data is to be\n * displayed, irrespective of the source of that data.\n *\n * Layers are usually added to a map with [map.addLayer()]{@link import(\"../Map.js\").default#addLayer}.\n * Components like {@link module:ol/interaction/Draw~Draw} use unmanaged layers\n * internally. These unmanaged layers are associated with the map using\n * [layer.setMap()]{@link module:ol/layer/Layer~Layer#setMap} instead.\n *\n * A generic `change` event is fired when the state of the source changes.\n * A `sourceready` event is fired when the layer's source is ready.\n *\n * @fires import(\"../render/Event.js\").RenderEvent#prerender\n * @fires import(\"../render/Event.js\").RenderEvent#postrender\n * @fires import(\"../events/Event.js\").BaseEvent#sourceready\n *\n * @template {import(\"../source/Source.js\").default} [SourceType=import(\"../source/Source.js\").default]\n * @template {import(\"../renderer/Layer.js\").default} [RendererType=import(\"../renderer/Layer.js\").default]\n * @template {Object<string, *>} [Properties=Object<string, *>]\n * @extends {BaseLayer<NoInfer<Properties>>}\n * @api\n */\nclass Layer extends BaseLayer {\n  /**\n   * @param {Options<SourceType, NoInfer<Properties>>} options Layer options.\n   */\n  constructor(options) {\n    const baseOptions = Object.assign({}, options);\n    delete baseOptions.source;\n\n    super(baseOptions);\n\n    /***\n     * @type {LayerOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {LayerOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {LayerOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @private\n     * @type {?import(\"../events.js\").EventsKey}\n     */\n    this.mapPrecomposeKey_ = null;\n\n    /**\n     * @private\n     * @type {?import(\"../events.js\").EventsKey}\n     */\n    this.mapRenderKey_ = null;\n\n    /**\n     * @private\n     * @type {?import(\"../events.js\").EventsKey}\n     */\n    this.sourceChangeKey_ = null;\n\n    /**\n     * @private\n     * @type {RendererType}\n     */\n    this.renderer_ = null;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.sourceReady_ = false;\n\n    /**\n     * @protected\n     * @type {boolean}\n     */\n    this.rendered = false;\n\n    // Overwrite default render method with a custom one\n    if (options.render) {\n      this.render = options.render;\n    }\n\n    if (options.map) {\n      this.setMap(options.map);\n    }\n\n    this.addChangeListener(\n      LayerProperty.SOURCE,\n      this.handleSourcePropertyChange_,\n    );\n\n    const source = options.source\n      ? /** @type {SourceType} */ (options.source)\n      : null;\n    this.setSource(source);\n  }\n\n  /**\n   * @param {Array<import(\"./Layer.js\").default>} [array] Array of layers (to be modified in place).\n   * @return {Array<import(\"./Layer.js\").default>} Array of layers.\n   * @override\n   */\n  getLayersArray(array) {\n    array = array ? array : [];\n    array.push(this);\n    return array;\n  }\n\n  /**\n   * @param {Array<import(\"./Layer.js\").State>} [states] Optional list of layer states (to be modified in place).\n   * @return {Array<import(\"./Layer.js\").State>} List of layer states.\n   * @override\n   */\n  getLayerStatesArray(states) {\n    states = states ? states : [];\n    states.push(this.getLayerState());\n    return states;\n  }\n\n  /**\n   * Get the layer source.\n   * @return {SourceType|null} The layer source (or `null` if not yet set).\n   * @observable\n   * @api\n   */\n  getSource() {\n    return /** @type {SourceType} */ (this.get(LayerProperty.SOURCE)) || null;\n  }\n\n  /**\n   * @return {SourceType|null} The source being rendered.\n   */\n  getRenderSource() {\n    return this.getSource();\n  }\n\n  /**\n   * @return {import(\"../source/Source.js\").State} Source state.\n   * @override\n   */\n  getSourceState() {\n    const source = this.getSource();\n    return !source ? 'undefined' : source.getState();\n  }\n\n  /**\n   * @private\n   */\n  handleSourceChange_() {\n    this.changed();\n    if (this.sourceReady_ || this.getSource().getState() !== 'ready') {\n      return;\n    }\n    this.sourceReady_ = true;\n    this.dispatchEvent('sourceready');\n  }\n\n  /**\n   * @private\n   */\n  handleSourcePropertyChange_() {\n    if (this.sourceChangeKey_) {\n      unlistenByKey(this.sourceChangeKey_);\n      this.sourceChangeKey_ = null;\n    }\n    this.sourceReady_ = false;\n    const source = this.getSource();\n    if (source) {\n      this.sourceChangeKey_ = listen(\n        source,\n        EventType.CHANGE,\n        this.handleSourceChange_,\n        this,\n      );\n      if (source.getState() === 'ready') {\n        this.sourceReady_ = true;\n        setTimeout(() => {\n          this.dispatchEvent('sourceready');\n        }, 0);\n      }\n    }\n    this.changed();\n  }\n\n  /**\n   * @param {import(\"../pixel.js\").Pixel} pixel Pixel.\n   * @return {Promise<Array<import(\"../Feature.js\").FeatureLike>>} Promise that resolves with\n   * an array of features.\n   */\n  getFeatures(pixel) {\n    if (!this.renderer_) {\n      return Promise.resolve([]);\n    }\n    return this.renderer_.getFeatures(pixel);\n  }\n\n  /**\n   * @param {import(\"../pixel.js\").Pixel} pixel Pixel.\n   * @return {Uint8ClampedArray|Uint8Array|Float32Array|DataView|null} Pixel data.\n   */\n  getData(pixel) {\n    if (!this.renderer_ || !this.rendered) {\n      return null;\n    }\n    return this.renderer_.getData(pixel);\n  }\n\n  /**\n   * The layer is visible on the map view, i.e. within its min/max resolution or zoom and\n   * extent, not set to `visible: false`, and not inside a layer group that is set\n   * to `visible: false`.\n   * @param {View|import(\"../View.js\").ViewStateLayerStateExtent} [view] View or {@link import(\"../Map.js\").FrameState}.\n   * Only required when the layer is not added to a map.\n   * @return {boolean} The layer is visible in the map view.\n   * @api\n   */\n  isVisible(view) {\n    let frameState;\n    const map = this.getMapInternal();\n    if (!view && map) {\n      view = map.getView();\n    }\n    if (view instanceof View) {\n      frameState = {\n        viewState: view.getState(),\n        extent: view.calculateExtent(),\n      };\n    } else {\n      frameState = view;\n    }\n    if (!frameState.layerStatesArray && map) {\n      frameState.layerStatesArray = map.getLayerGroup().getLayerStatesArray();\n    }\n    let layerState;\n    if (frameState.layerStatesArray) {\n      layerState = frameState.layerStatesArray.find(\n        (layerState) => layerState.layer === this,\n      );\n      if (!layerState) {\n        return false;\n      }\n    } else {\n      layerState = this.getLayerState();\n    }\n\n    const layerExtent = this.getExtent();\n\n    return (\n      inView(layerState, frameState.viewState) &&\n      (!layerExtent || intersects(layerExtent, frameState.extent))\n    );\n  }\n\n  /**\n   * Get the attributions of the source of this layer for the given view.\n   * @param {View|import(\"../View.js\").ViewStateLayerStateExtent} [view] View or {@link import(\"../Map.js\").FrameState}.\n   * Only required when the layer is not added to a map.\n   * @return {Array<string>} Attributions for this layer at the given view.\n   * @api\n   */\n  getAttributions(view) {\n    if (!this.isVisible(view)) {\n      return [];\n    }\n    const getAttributions = this.getSource()?.getAttributions();\n    if (!getAttributions) {\n      return [];\n    }\n    const frameState =\n      view instanceof View ? view.getViewStateAndExtent() : view;\n    let attributions = getAttributions(frameState);\n    if (!Array.isArray(attributions)) {\n      attributions = [attributions];\n    }\n    return attributions;\n  }\n\n  /**\n   * In charge to manage the rendering of the layer. One layer type is\n   * bounded with one layer renderer.\n   * @param {?import(\"../Map.js\").FrameState} frameState Frame state.\n   * @param {HTMLElement} target Target which the renderer may (but need not) use\n   * for rendering its content.\n   * @return {HTMLElement|null} The rendered element.\n   */\n  render(frameState, target) {\n    const layerRenderer = this.getRenderer();\n\n    if (layerRenderer.prepareFrame(frameState)) {\n      this.rendered = true;\n      return layerRenderer.renderFrame(frameState, target);\n    }\n    return null;\n  }\n\n  /**\n   * Called when a layer is not visible during a map render.\n   */\n  unrender() {\n    this.rendered = false;\n  }\n\n  /** @return {string} Declutter */\n  getDeclutter() {\n    return undefined;\n  }\n\n  /**\n   * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n   * @param {import(\"../layer/Layer.js\").State} layerState Layer state.\n   */\n  renderDeclutter(frameState, layerState) {}\n\n  /**\n   * When the renderer follows a layout -> render approach, do the final rendering here.\n   * @param {import('../Map.js').FrameState} frameState Frame state\n   */\n  renderDeferred(frameState) {\n    const layerRenderer = this.getRenderer();\n    if (!layerRenderer) {\n      return;\n    }\n    layerRenderer.renderDeferred(frameState);\n  }\n\n  /**\n   * For use inside the library only.\n   * @param {import(\"../Map.js\").default|null} map Map.\n   */\n  setMapInternal(map) {\n    if (!map) {\n      this.unrender();\n    }\n    this.set(LayerProperty.MAP, map);\n  }\n\n  /**\n   * For use inside the library only.\n   * @return {import(\"../Map.js\").default|null} Map.\n   */\n  getMapInternal() {\n    return this.get(LayerProperty.MAP);\n  }\n\n  /**\n   * Sets the layer to be rendered on top of other layers on a map. The map will\n   * not manage this layer in its layers collection. This\n   * is useful for temporary layers. To remove an unmanaged layer from the map,\n   * use `#setMap(null)`.\n   *\n   * To add the layer to a map and have it managed by the map, use\n   * {@link module:ol/Map~Map#addLayer} instead.\n   * @param {import(\"../Map.js\").default|null} map Map.\n   * @api\n   */\n  setMap(map) {\n    if (this.mapPrecomposeKey_) {\n      unlistenByKey(this.mapPrecomposeKey_);\n      this.mapPrecomposeKey_ = null;\n    }\n    if (!map) {\n      this.changed();\n    }\n    if (this.mapRenderKey_) {\n      unlistenByKey(this.mapRenderKey_);\n      this.mapRenderKey_ = null;\n    }\n    if (map) {\n      this.mapPrecomposeKey_ = listen(\n        map,\n        RenderEventType.PRECOMPOSE,\n        this.handlePrecompose_,\n        this,\n      );\n      this.mapRenderKey_ = listen(this, EventType.CHANGE, map.render, map);\n      this.changed();\n    }\n  }\n\n  /**\n   * @param {import(\"../events/Event.js\").default} renderEvent Render event\n   * @private\n   */\n  handlePrecompose_(renderEvent) {\n    const layerStatesArray =\n      /** @type {import(\"../render/Event.js\").default} */ (renderEvent)\n        .frameState.layerStatesArray;\n    const layerState = this.getLayerState(false);\n    assert(\n      !layerStatesArray.some(\n        (arrayLayerState) => arrayLayerState.layer === layerState.layer,\n      ),\n      'A layer can only be added to the map once. Use either `layer.setMap()` or `map.addLayer()`, not both.',\n    );\n    layerStatesArray.push(layerState);\n  }\n\n  /**\n   * Set the layer source.\n   * @param {SourceType|null} source The layer source.\n   * @observable\n   * @api\n   */\n  setSource(source) {\n    this.set(LayerProperty.SOURCE, source);\n  }\n\n  /**\n   * Get the renderer for this layer.\n   * @return {RendererType|null} The layer renderer.\n   */\n  getRenderer() {\n    if (!this.renderer_) {\n      this.renderer_ = this.createRenderer();\n    }\n    return this.renderer_;\n  }\n\n  /**\n   * @return {boolean} The layer has a renderer.\n   */\n  hasRenderer() {\n    return !!this.renderer_;\n  }\n\n  /**\n   * Create a renderer for this layer.\n   * @return {RendererType} A layer renderer.\n   * @protected\n   */\n  createRenderer() {\n    return null;\n  }\n\n  /**\n   * This will clear the renderer so that a new one can be created next time it is needed\n   */\n  clearRenderer() {\n    if (this.renderer_) {\n      this.renderer_.dispose();\n      delete this.renderer_;\n    }\n  }\n\n  /**\n   * Clean up.\n   * @override\n   */\n  disposeInternal() {\n    this.clearRenderer();\n    this.setSource(null);\n    super.disposeInternal();\n  }\n}\n\n/**\n * Return `true` if the layer is visible and if the provided view state\n * has resolution and zoom levels that are in range of the layer's min/max.\n * @param {State} layerState Layer state.\n * @param {import(\"../View.js\").State} viewState View state.\n * @return {boolean} The layer is visible at the given view state.\n */\nexport function inView(layerState, viewState) {\n  if (!layerState.visible) {\n    return false;\n  }\n  const resolution = viewState.resolution;\n  if (\n    resolution < layerState.minResolution ||\n    resolution >= layerState.maxResolution\n  ) {\n    return false;\n  }\n  const zoom = viewState.zoom;\n  return zoom > layerState.minZoom && zoom <= layerState.maxZoom;\n}\n\nexport default Layer;\n","\n/**\n * Rearranges items so that all items in the [left, k] are the smallest.\n * The k-th element will have the (k - left + 1)-th smallest value in [left, right].\n *\n * @template T\n * @param {T[]} arr the array to partially sort (in place)\n * @param {number} k middle index for partial sorting (as defined above)\n * @param {number} [left=0] left index of the range to sort\n * @param {number} [right=arr.length-1] right index\n * @param {(a: T, b: T) => number} [compare = (a, b) => a - b] compare function\n */\nexport default function quickselect(arr, k, left = 0, right = arr.length - 1, compare = defaultCompare) {\n\n    while (right > left) {\n        if (right - left > 600) {\n            const n = right - left + 1;\n            const m = k - left + 1;\n            const z = Math.log(n);\n            const s = 0.5 * Math.exp(2 * z / 3);\n            const sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);\n            const newLeft = Math.max(left, Math.floor(k - m * s / n + sd));\n            const newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));\n            quickselect(arr, k, newLeft, newRight, compare);\n        }\n\n        const t = arr[k];\n        let i = left;\n        /** @type {number} */\n        let j = right;\n\n        swap(arr, left, k);\n        if (compare(arr[right], t) > 0) swap(arr, left, right);\n\n        while (i < j) {\n            swap(arr, i, j);\n            i++;\n            j--;\n            while (compare(arr[i], t) < 0) i++;\n            while (compare(arr[j], t) > 0) j--;\n        }\n\n        if (compare(arr[left], t) === 0) swap(arr, left, j);\n        else {\n            j++;\n            swap(arr, j, right);\n        }\n\n        if (j <= k) left = j + 1;\n        if (k <= j) right = j - 1;\n    }\n}\n\n/**\n * @template T\n * @param {T[]} arr\n * @param {number} i\n * @param {number} j\n */\nfunction swap(arr, i, j) {\n    const tmp = arr[i];\n    arr[i] = arr[j];\n    arr[j] = tmp;\n}\n\n/**\n * @template T\n * @param {T} a\n * @param {T} b\n * @returns {number}\n */\nfunction defaultCompare(a, b) {\n    return a < b ? -1 : a > b ? 1 : 0;\n}\n","import quickselect from 'quickselect';\n\nexport default class RBush {\n    constructor(maxEntries = 9) {\n        // max entries in a node is 9 by default; min node fill is 40% for best performance\n        this._maxEntries = Math.max(4, maxEntries);\n        this._minEntries = Math.max(2, Math.ceil(this._maxEntries * 0.4));\n        this.clear();\n    }\n\n    all() {\n        return this._all(this.data, []);\n    }\n\n    search(bbox) {\n        let node = this.data;\n        const result = [];\n\n        if (!intersects(bbox, node)) return result;\n\n        const toBBox = this.toBBox;\n        const nodesToSearch = [];\n\n        while (node) {\n            for (let i = 0; i < node.children.length; i++) {\n                const child = node.children[i];\n                const childBBox = node.leaf ? toBBox(child) : child;\n\n                if (intersects(bbox, childBBox)) {\n                    if (node.leaf) result.push(child);\n                    else if (contains(bbox, childBBox)) this._all(child, result);\n                    else nodesToSearch.push(child);\n                }\n            }\n            node = nodesToSearch.pop();\n        }\n\n        return result;\n    }\n\n    collides(bbox) {\n        let node = this.data;\n\n        if (!intersects(bbox, node)) return false;\n\n        const nodesToSearch = [];\n        while (node) {\n            for (let i = 0; i < node.children.length; i++) {\n                const child = node.children[i];\n                const childBBox = node.leaf ? this.toBBox(child) : child;\n\n                if (intersects(bbox, childBBox)) {\n                    if (node.leaf || contains(bbox, childBBox)) return true;\n                    nodesToSearch.push(child);\n                }\n            }\n            node = nodesToSearch.pop();\n        }\n\n        return false;\n    }\n\n    load(data) {\n        if (!(data && data.length)) return this;\n\n        if (data.length < this._minEntries) {\n            for (let i = 0; i < data.length; i++) {\n                this.insert(data[i]);\n            }\n            return this;\n        }\n\n        // recursively build the tree with the given data from scratch using OMT algorithm\n        let node = this._build(data.slice(), 0, data.length - 1, 0);\n\n        if (!this.data.children.length) {\n            // save as is if tree is empty\n            this.data = node;\n\n        } else if (this.data.height === node.height) {\n            // split root if trees have the same height\n            this._splitRoot(this.data, node);\n\n        } else {\n            if (this.data.height < node.height) {\n                // swap trees if inserted one is bigger\n                const tmpNode = this.data;\n                this.data = node;\n                node = tmpNode;\n            }\n\n            // insert the small tree into the large tree at appropriate level\n            this._insert(node, this.data.height - node.height - 1, true);\n        }\n\n        return this;\n    }\n\n    insert(item) {\n        if (item) this._insert(item, this.data.height - 1);\n        return this;\n    }\n\n    clear() {\n        this.data = createNode([]);\n        return this;\n    }\n\n    remove(item, equalsFn) {\n        if (!item) return this;\n\n        let node = this.data;\n        const bbox = this.toBBox(item);\n        const path = [];\n        const indexes = [];\n        let i, parent, goingUp;\n\n        // depth-first iterative tree traversal\n        while (node || path.length) {\n\n            if (!node) { // go up\n                node = path.pop();\n                parent = path[path.length - 1];\n                i = indexes.pop();\n                goingUp = true;\n            }\n\n            if (node.leaf) { // check current node\n                const index = findItem(item, node.children, equalsFn);\n\n                if (index !== -1) {\n                    // item found, remove the item and condense tree upwards\n                    node.children.splice(index, 1);\n                    path.push(node);\n                    this._condense(path);\n                    return this;\n                }\n            }\n\n            if (!goingUp && !node.leaf && contains(node, bbox)) { // go down\n                path.push(node);\n                indexes.push(i);\n                i = 0;\n                parent = node;\n                node = node.children[0];\n\n            } else if (parent) { // go right\n                i++;\n                node = parent.children[i];\n                goingUp = false;\n\n            } else node = null; // nothing found\n        }\n\n        return this;\n    }\n\n    toBBox(item) { return item; }\n\n    compareMinX(a, b) { return a.minX - b.minX; }\n    compareMinY(a, b) { return a.minY - b.minY; }\n\n    toJSON() { return this.data; }\n\n    fromJSON(data) {\n        this.data = data;\n        return this;\n    }\n\n    _all(node, result) {\n        const nodesToSearch = [];\n        while (node) {\n            if (node.leaf) result.push(...node.children);\n            else nodesToSearch.push(...node.children);\n\n            node = nodesToSearch.pop();\n        }\n        return result;\n    }\n\n    _build(items, left, right, height) {\n\n        const N = right - left + 1;\n        let M = this._maxEntries;\n        let node;\n\n        if (N <= M) {\n            // reached leaf level; return leaf\n            node = createNode(items.slice(left, right + 1));\n            calcBBox(node, this.toBBox);\n            return node;\n        }\n\n        if (!height) {\n            // target height of the bulk-loaded tree\n            height = Math.ceil(Math.log(N) / Math.log(M));\n\n            // target number of root entries to maximize storage utilization\n            M = Math.ceil(N / Math.pow(M, height - 1));\n        }\n\n        node = createNode([]);\n        node.leaf = false;\n        node.height = height;\n\n        // split the items into M mostly square tiles\n\n        const N2 = Math.ceil(N / M);\n        const N1 = N2 * Math.ceil(Math.sqrt(M));\n\n        multiSelect(items, left, right, N1, this.compareMinX);\n\n        for (let i = left; i <= right; i += N1) {\n\n            const right2 = Math.min(i + N1 - 1, right);\n\n            multiSelect(items, i, right2, N2, this.compareMinY);\n\n            for (let j = i; j <= right2; j += N2) {\n\n                const right3 = Math.min(j + N2 - 1, right2);\n\n                // pack each entry recursively\n                node.children.push(this._build(items, j, right3, height - 1));\n            }\n        }\n\n        calcBBox(node, this.toBBox);\n\n        return node;\n    }\n\n    _chooseSubtree(bbox, node, level, path) {\n        while (true) {\n            path.push(node);\n\n            if (node.leaf || path.length - 1 === level) break;\n\n            let minArea = Infinity;\n            let minEnlargement = Infinity;\n            let targetNode;\n\n            for (let i = 0; i < node.children.length; i++) {\n                const child = node.children[i];\n                const area = bboxArea(child);\n                const enlargement = enlargedArea(bbox, child) - area;\n\n                // choose entry with the least area enlargement\n                if (enlargement < minEnlargement) {\n                    minEnlargement = enlargement;\n                    minArea = area < minArea ? area : minArea;\n                    targetNode = child;\n\n                } else if (enlargement === minEnlargement) {\n                    // otherwise choose one with the smallest area\n                    if (area < minArea) {\n                        minArea = area;\n                        targetNode = child;\n                    }\n                }\n            }\n\n            node = targetNode || node.children[0];\n        }\n\n        return node;\n    }\n\n    _insert(item, level, isNode) {\n        const bbox = isNode ? item : this.toBBox(item);\n        const insertPath = [];\n\n        // find the best node for accommodating the item, saving all nodes along the path too\n        const node = this._chooseSubtree(bbox, this.data, level, insertPath);\n\n        // put the item into the node\n        node.children.push(item);\n        extend(node, bbox);\n\n        // split on node overflow; propagate upwards if necessary\n        while (level >= 0) {\n            if (insertPath[level].children.length > this._maxEntries) {\n                this._split(insertPath, level);\n                level--;\n            } else break;\n        }\n\n        // adjust bboxes along the insertion path\n        this._adjustParentBBoxes(bbox, insertPath, level);\n    }\n\n    // split overflowed node into two\n    _split(insertPath, level) {\n        const node = insertPath[level];\n        const M = node.children.length;\n        const m = this._minEntries;\n\n        this._chooseSplitAxis(node, m, M);\n\n        const splitIndex = this._chooseSplitIndex(node, m, M);\n\n        const newNode = createNode(node.children.splice(splitIndex, node.children.length - splitIndex));\n        newNode.height = node.height;\n        newNode.leaf = node.leaf;\n\n        calcBBox(node, this.toBBox);\n        calcBBox(newNode, this.toBBox);\n\n        if (level) insertPath[level - 1].children.push(newNode);\n        else this._splitRoot(node, newNode);\n    }\n\n    _splitRoot(node, newNode) {\n        // split root node\n        this.data = createNode([node, newNode]);\n        this.data.height = node.height + 1;\n        this.data.leaf = false;\n        calcBBox(this.data, this.toBBox);\n    }\n\n    _chooseSplitIndex(node, m, M) {\n        let index;\n        let minOverlap = Infinity;\n        let minArea = Infinity;\n\n        for (let i = m; i <= M - m; i++) {\n            const bbox1 = distBBox(node, 0, i, this.toBBox);\n            const bbox2 = distBBox(node, i, M, this.toBBox);\n\n            const overlap = intersectionArea(bbox1, bbox2);\n            const area = bboxArea(bbox1) + bboxArea(bbox2);\n\n            // choose distribution with minimum overlap\n            if (overlap < minOverlap) {\n                minOverlap = overlap;\n                index = i;\n\n                minArea = area < minArea ? area : minArea;\n\n            } else if (overlap === minOverlap) {\n                // otherwise choose distribution with minimum area\n                if (area < minArea) {\n                    minArea = area;\n                    index = i;\n                }\n            }\n        }\n\n        return index || M - m;\n    }\n\n    // sorts node children by the best axis for split\n    _chooseSplitAxis(node, m, M) {\n        const compareMinX = node.leaf ? this.compareMinX : compareNodeMinX;\n        const compareMinY = node.leaf ? this.compareMinY : compareNodeMinY;\n        const xMargin = this._allDistMargin(node, m, M, compareMinX);\n        const yMargin = this._allDistMargin(node, m, M, compareMinY);\n\n        // if total distributions margin value is minimal for x, sort by minX,\n        // otherwise it's already sorted by minY\n        if (xMargin < yMargin) node.children.sort(compareMinX);\n    }\n\n    // total margin of all possible split distributions where each node is at least m full\n    _allDistMargin(node, m, M, compare) {\n        node.children.sort(compare);\n\n        const toBBox = this.toBBox;\n        const leftBBox = distBBox(node, 0, m, toBBox);\n        const rightBBox = distBBox(node, M - m, M, toBBox);\n        let margin = bboxMargin(leftBBox) + bboxMargin(rightBBox);\n\n        for (let i = m; i < M - m; i++) {\n            const child = node.children[i];\n            extend(leftBBox, node.leaf ? toBBox(child) : child);\n            margin += bboxMargin(leftBBox);\n        }\n\n        for (let i = M - m - 1; i >= m; i--) {\n            const child = node.children[i];\n            extend(rightBBox, node.leaf ? toBBox(child) : child);\n            margin += bboxMargin(rightBBox);\n        }\n\n        return margin;\n    }\n\n    _adjustParentBBoxes(bbox, path, level) {\n        // adjust bboxes along the given tree path\n        for (let i = level; i >= 0; i--) {\n            extend(path[i], bbox);\n        }\n    }\n\n    _condense(path) {\n        // go through the path, removing empty nodes and updating bboxes\n        for (let i = path.length - 1, siblings; i >= 0; i--) {\n            if (path[i].children.length === 0) {\n                if (i > 0) {\n                    siblings = path[i - 1].children;\n                    siblings.splice(siblings.indexOf(path[i]), 1);\n\n                } else this.clear();\n\n            } else calcBBox(path[i], this.toBBox);\n        }\n    }\n}\n\nfunction findItem(item, items, equalsFn) {\n    if (!equalsFn) return items.indexOf(item);\n\n    for (let i = 0; i < items.length; i++) {\n        if (equalsFn(item, items[i])) return i;\n    }\n    return -1;\n}\n\n// calculate node's bbox from bboxes of its children\nfunction calcBBox(node, toBBox) {\n    distBBox(node, 0, node.children.length, toBBox, node);\n}\n\n// min bounding rectangle of node children from k to p-1\nfunction distBBox(node, k, p, toBBox, destNode) {\n    if (!destNode) destNode = createNode(null);\n    destNode.minX = Infinity;\n    destNode.minY = Infinity;\n    destNode.maxX = -Infinity;\n    destNode.maxY = -Infinity;\n\n    for (let i = k; i < p; i++) {\n        const child = node.children[i];\n        extend(destNode, node.leaf ? toBBox(child) : child);\n    }\n\n    return destNode;\n}\n\nfunction extend(a, b) {\n    a.minX = Math.min(a.minX, b.minX);\n    a.minY = Math.min(a.minY, b.minY);\n    a.maxX = Math.max(a.maxX, b.maxX);\n    a.maxY = Math.max(a.maxY, b.maxY);\n    return a;\n}\n\nfunction compareNodeMinX(a, b) { return a.minX - b.minX; }\nfunction compareNodeMinY(a, b) { return a.minY - b.minY; }\n\nfunction bboxArea(a)   { return (a.maxX - a.minX) * (a.maxY - a.minY); }\nfunction bboxMargin(a) { return (a.maxX - a.minX) + (a.maxY - a.minY); }\n\nfunction enlargedArea(a, b) {\n    return (Math.max(b.maxX, a.maxX) - Math.min(b.minX, a.minX)) *\n           (Math.max(b.maxY, a.maxY) - Math.min(b.minY, a.minY));\n}\n\nfunction intersectionArea(a, b) {\n    const minX = Math.max(a.minX, b.minX);\n    const minY = Math.max(a.minY, b.minY);\n    const maxX = Math.min(a.maxX, b.maxX);\n    const maxY = Math.min(a.maxY, b.maxY);\n\n    return Math.max(0, maxX - minX) *\n           Math.max(0, maxY - minY);\n}\n\nfunction contains(a, b) {\n    return a.minX <= b.minX &&\n           a.minY <= b.minY &&\n           b.maxX <= a.maxX &&\n           b.maxY <= a.maxY;\n}\n\nfunction intersects(a, b) {\n    return b.minX <= a.maxX &&\n           b.minY <= a.maxY &&\n           b.maxX >= a.minX &&\n           b.maxY >= a.minY;\n}\n\nfunction createNode(children) {\n    return {\n        children,\n        height: 1,\n        leaf: true,\n        minX: Infinity,\n        minY: Infinity,\n        maxX: -Infinity,\n        maxY: -Infinity\n    };\n}\n\n// sort an array so that items come in groups of n unsorted items, with groups sorted between each other;\n// combines selection algorithm with binary divide & conquer approach\n\nfunction multiSelect(arr, left, right, n, compare) {\n    const stack = [left, right];\n\n    while (stack.length) {\n        right = stack.pop();\n        left = stack.pop();\n\n        if (right - left <= n) continue;\n\n        const mid = left + Math.ceil((right - left) / n / 2) * n;\n        quickselect(arr, mid, left, right, compare);\n\n        stack.push(left, mid, mid, right);\n    }\n}\n","/**\n * @module ol/color\n */\nimport {createCanvasContext2D} from './dom.js';\nimport {clamp, toFixed} 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<number>} Color\n * @api\n */\n\n/**\n * Color to indicate that no color should be rendered. This is meant to be used for per-reference\n * comparisons only.\n * @type {Color}\n */\nexport const NO_COLOR = [NaN, NaN, NaN, 0];\n\nlet colorParseContext;\n/**\n * @return {CanvasRenderingContext2D} The color parse context\n */\nfunction getColorParseContext() {\n  if (!colorParseContext) {\n    colorParseContext = createCanvasContext2D(1, 1, undefined, {\n      willReadFrequently: true,\n      desynchronized: true,\n    });\n  }\n  return colorParseContext;\n}\n\nconst rgbModernRegEx =\n  /^rgba?\\(\\s*(\\d+%?)\\s+(\\d+%?)\\s+(\\d+%?)(?:\\s*\\/\\s*(\\d+%|\\d*\\.\\d+|[01]))?\\s*\\)$/i;\nconst rgbLegacyAbsoluteRegEx =\n  /^rgba?\\(\\s*(\\d+)\\s*,\\s*(\\d+)\\s*,\\s*(\\d+)(?:\\s*,\\s*(\\d+%|\\d*\\.\\d+|[01]))?\\s*\\)$/i;\nconst rgbLegacyPercentageRegEx =\n  /^rgba?\\(\\s*(\\d+%)\\s*,\\s*(\\d+%)\\s*,\\s*(\\d+%)(?:\\s*,\\s*(\\d+%|\\d*\\.\\d+|[01]))?\\s*\\)$/i;\nconst hexRegEx = /^#([\\da-f]{3,4}|[\\da-f]{6}|[\\da-f]{8})$/i;\n\n/**\n * @param {string} s Color component as number or percentage.\n * @param {number} divider Divider for percentage.\n * @return {number} Color component.\n */\nfunction toColorComponent(s, divider) {\n  return s.endsWith('%')\n    ? Number(s.substring(0, s.length - 1)) / divider\n    : Number(s);\n}\n\n/**\n * @param {string} color Color string.\n */\nfunction throwInvalidColor(color) {\n  throw new Error('failed to parse \"' + color + '\" as color');\n}\n\n/**\n * @param {string} color Color string.\n * @return {Color} RGBa color array.\n */\nfunction parseRgba(color) {\n  // Fast lane for rgb(a) colors\n  if (color.toLowerCase().startsWith('rgb')) {\n    const rgb =\n      color.match(rgbLegacyAbsoluteRegEx) ||\n      color.match(rgbModernRegEx) ||\n      color.match(rgbLegacyPercentageRegEx);\n    if (rgb) {\n      const alpha = rgb[4];\n      const rgbDivider = 100 / 255;\n      return [\n        clamp((toColorComponent(rgb[1], rgbDivider) + 0.5) | 0, 0, 255),\n        clamp((toColorComponent(rgb[2], rgbDivider) + 0.5) | 0, 0, 255),\n        clamp((toColorComponent(rgb[3], rgbDivider) + 0.5) | 0, 0, 255),\n        alpha !== undefined ? clamp(toColorComponent(alpha, 100), 0, 1) : 1,\n      ];\n    }\n    throwInvalidColor(color);\n  }\n  // Fast lane for hex colors (also with alpha)\n  if (color.startsWith('#')) {\n    if (hexRegEx.test(color)) {\n      const hex = color.substring(1);\n      const step = hex.length <= 4 ? 1 : 2;\n      const colorFromHex = [0, 0, 0, 255];\n      for (let i = 0, ii = hex.length; i < ii; i += step) {\n        let colorComponent = parseInt(hex.substring(i, i + step), 16);\n        if (step === 1) {\n          colorComponent += colorComponent << 4;\n        }\n        colorFromHex[i / step] = colorComponent;\n      }\n      colorFromHex[3] = colorFromHex[3] / 255;\n      return colorFromHex;\n    }\n    throwInvalidColor(color);\n  }\n  // Use canvas color serialization to parse the color into hex or rgba\n  // See https://www.w3.org/TR/2021/SPSD-2dcontext-20210128/#serialization-of-a-color\n  const context = getColorParseContext();\n  context.fillStyle = '#abcdef';\n  let invalidCheckFillStyle = context.fillStyle;\n  context.fillStyle = color;\n  if (context.fillStyle === invalidCheckFillStyle) {\n    context.fillStyle = '#fedcba';\n    invalidCheckFillStyle = context.fillStyle;\n    context.fillStyle = color;\n    if (context.fillStyle === invalidCheckFillStyle) {\n      throwInvalidColor(color);\n    }\n  }\n  const colorString = context.fillStyle;\n  if (colorString.startsWith('#') || colorString.startsWith('rgba')) {\n    return parseRgba(colorString);\n  }\n  context.clearRect(0, 0, 1, 1);\n  context.fillRect(0, 0, 1, 1);\n  const colorFromImage = Array.from(context.getImageData(0, 0, 1, 1).data);\n  colorFromImage[3] = toFixed(colorFromImage[3] / 255, 3);\n  return colorFromImage;\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<string, Color>}\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// The functions b1, b2, a1, a2, rgbaToLcha and lchaToRgba below are adapted from\n// https://stackoverflow.com/a/67219995/2389327\n\n/**\n * @param {number} v Input value.\n * @return {number} Output value.\n */\nfunction b1(v) {\n  return v > 0.0031308 ? Math.pow(v, 1 / 2.4) * 269.025 - 14.025 : v * 3294.6;\n}\n\n/**\n * @param {number} v Input value.\n * @return {number} Output value.\n */\nfunction b2(v) {\n  return v > 0.2068965 ? Math.pow(v, 3) : (v - 4 / 29) * (108 / 841);\n}\n\n/**\n * @param {number} v Input value.\n * @return {number} Output value.\n */\nfunction a1(v) {\n  return v > 10.314724 ? Math.pow((v + 14.025) / 269.025, 2.4) : v / 3294.6;\n}\n\n/**\n * @param {number} v Input value.\n * @return {number} Output value.\n */\nfunction a2(v) {\n  return v > 0.0088564 ? Math.pow(v, 1 / 3) : v / (108 / 841) + 4 / 29;\n}\n\n/**\n * @param {Color} color RGBA color.\n * @return {Color} LCHuv color with alpha.\n */\nexport function rgbaToLcha(color) {\n  const r = a1(color[0]);\n  const g = a1(color[1]);\n  const b = a1(color[2]);\n  const y = a2(r * 0.222488403 + g * 0.716873169 + b * 0.06060791);\n  const l = 500 * (a2(r * 0.452247074 + g * 0.399439023 + b * 0.148375274) - y);\n  const q = 200 * (y - a2(r * 0.016863605 + g * 0.117638439 + b * 0.865350722));\n  const h = Math.atan2(q, l) * (180 / Math.PI);\n  return [\n    116 * y - 16,\n    Math.sqrt(l * l + q * q),\n    h < 0 ? h + 360 : h,\n    color[3],\n  ];\n}\n\n/**\n * @param {Color} color LCHuv color with alpha.\n * @return {Color} RGBA color.\n */\nexport function lchaToRgba(color) {\n  const l = (color[0] + 16) / 116;\n  const c = color[1];\n  const h = (color[2] * Math.PI) / 180;\n  const y = b2(l);\n  const x = b2(l + (c / 500) * Math.cos(h));\n  const z = b2(l - (c / 200) * Math.sin(h));\n  const r = b1(x * 3.021973625 - y * 1.617392459 - z * 0.404875592);\n  const g = b1(x * -0.943766287 + y * 1.916279586 + z * 0.027607165);\n  const b = b1(x * 0.069407491 - y * 0.22898585 + z * 1.159737864);\n  return [\n    clamp((r + 0.5) | 0, 0, 255),\n    clamp((g + 0.5) | 0, 0, 255),\n    clamp((b + 0.5) | 0, 0, 255),\n    color[3],\n  ];\n}\n\n/**\n * @param {string} s String.\n * @return {Color} Color.\n */\nexport function fromString(s) {\n  if (s === 'none') {\n    return NO_COLOR;\n  }\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    throwInvalidColor(s);\n  }\n  for (const c of color) {\n    if (isNaN(c)) {\n      throwInvalidColor(s);\n    }\n  }\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 * @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","/**\n * @module ol/size\n */\n\n/**\n * An array of numbers representing a size: `[width, height]`.\n * @typedef {Array<number>} Size\n * @api\n */\n\n/**\n * Returns a buffered size.\n * @param {Size} size Size.\n * @param {number} num The amount by which to buffer.\n * @param {Size} [dest] Optional reusable size array.\n * @return {Size} The buffered size.\n */\nexport function buffer(size, num, dest) {\n  if (dest === undefined) {\n    dest = [0, 0];\n  }\n  dest[0] = size[0] + 2 * num;\n  dest[1] = size[1] + 2 * num;\n  return dest;\n}\n\n/**\n * Determines if a size has a positive area.\n * @param {Size} size The size to test.\n * @return {boolean} The size has a positive area.\n */\nexport function hasArea(size) {\n  return size[0] > 0 && size[1] > 0;\n}\n\n/**\n * Returns a size scaled by a ratio. The result will be an array of integers.\n * @param {Size} size Size.\n * @param {number} ratio Ratio.\n * @param {Size} [dest] Optional reusable size array.\n * @return {Size} The scaled size.\n */\nexport function scale(size, ratio, dest) {\n  if (dest === undefined) {\n    dest = [0, 0];\n  }\n  dest[0] = (size[0] * ratio + 0.5) | 0;\n  dest[1] = (size[1] * ratio + 0.5) | 0;\n  return dest;\n}\n\n/**\n * Returns an `Size` array for the passed in number (meaning: square) or\n * `Size` array.\n * (meaning: non-square),\n * @param {number|Size} size Width and height.\n * @param {Size} [dest] Optional reusable size array.\n * @return {Size} Size.\n * @api\n */\nexport function toSize(size, dest) {\n  if (Array.isArray(size)) {\n    return size;\n  }\n  if (dest === undefined) {\n    dest = [size, size];\n  } else {\n    dest[0] = size;\n    dest[1] = size;\n  }\n  return dest;\n}\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 *   * `['line-metric']` returns the M component of the current point on a line (WebGL only); in case where the geometry layout of the line\n *      does not contain an M component (e.g. XY or XYZ), 0 is returned; 0 is also returned for geometries other than lines.\n *      Please note that the M component will be linearly interpolated between the two points composing a segment.\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 *   * `['has', attributeName, keyOrArrayIndex, ...]` returns `true` if feature properties include the (nested) key `attributeName`,\n *     `false` otherwise.\n *     Note that for WebGL layers, the hardcoded value `-9999999` is used to distinguish when a property is not defined.\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 *     This works as well for number arrays although it is not required. Mixing types (numbers and strings) will produce undefined results.\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<number>} 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<string>} variables Variables referenced with the 'var' operator.\n * @property {Set<string>} 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 * @property {boolean} mCoordinate The style uses the M coordinate of geometries\n * @property {boolean} mapState The style uses the map state (view state or time elapsed).\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    mCoordinate: false,\n    mapState: 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<string, string>}\n */\nexport const Ops = {\n  Get: 'get',\n  Var: 'var',\n  Concat: 'concat',\n  GeometryType: 'geometry-type',\n  LineMetric: 'line-metric',\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  Has: 'has',\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<string, Parser>}\n */\nconst parsers = {\n  [Ops.Get]: createCallExpressionParser(hasArgsCount(1, Infinity), withGetArgs),\n  [Ops.Var]: createCallExpressionParser(hasArgsCount(1, 1), withVarArgs),\n  [Ops.Has]: createCallExpressionParser(hasArgsCount(1, Infinity), withGetArgs),\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.LineMetric]: createCallExpressionParser(usesMCoordinate, withNoArgs),\n  [Ops.Resolution]: createCallExpressionParser(usesMapState, withNoArgs),\n  [Ops.Zoom]: createCallExpressionParser(usesMapState, withNoArgs),\n  [Ops.Time]: createCallExpressionParser(usesMapState, 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<EncodedExpression>, number, ParsingContext):Array<Expression>|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 usesMCoordinate(encoded, returnType, context) {\n  context.mCoordinate = true;\n}\n\n/**\n * @type {ArgValidator}\n */\nfunction usesMapState(encoded, returnType, context) {\n  context.mapState = 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<Expression>}\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<Expression>}\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\n  // check if we're using the 'literal' operator for the haystack\n  if (haystack[0] === 'literal') {\n    haystack = haystack[1];\n    if (!Array.isArray(haystack)) {\n      throw new Error(\n        `failed to parse \"in\" expression: the literal operator must be followed by an array`,\n      );\n    }\n  } else if (typeof haystack[0] === 'string') {\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\n  if (typeof haystack[0] === 'string') {\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<ArgValidator>} 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<Expression>}\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 {\n  fromString,\n  lchaToRgba,\n  rgbaToLcha,\n  toString,\n  withAlpha,\n} from '../color.js';\nimport {ColorType, LiteralExpression, Ops, parse} from './expression.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<number>|string)} ColorLikeEvaluator\n */\n\n/**\n * @typedef {function(EvaluationContext):Array<number>} NumberArrayEvaluator\n */\n\n/**\n * @typedef {function(EvaluationContext):Array<number>} CoordinateEvaluator\n */\n\n/**\n * @typedef {function(EvaluationContext):(Array<number>)} SizeEvaluator\n */\n\n/**\n * @typedef {function(EvaluationContext):(Array<number>|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    case Ops.Has: {\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    case Ops.Has: {\n      return (context) => {\n        const args = expression.args;\n        if (!(name in context.properties)) {\n          return false;\n        }\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          if (!value || !Object.hasOwn(value, key)) {\n            return false;\n          }\n          value = value[key];\n        }\n        return true;\n      };\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 - 1; 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 lchaToRgba(lcha);\n}\n","/**\n * @module ol/style/IconImageCache\n */\nimport ImageState from '../ImageState.js';\nimport {asArray} from '../color.js';\nimport {getSharedCanvasContext2D} from '../dom.js';\n\n/**\n * @classdesc\n * Singleton class. Available through {@link module:ol/style/IconImageCache.shared}.\n */\nclass IconImageCache {\n  constructor() {\n    /**\n     * @type {!Object<string, import(\"./IconImage.js\").default>}\n     * @private\n     */\n    this.cache_ = {};\n\n    /**\n     * @type {!Object<string, CanvasPattern>}\n     * @private\n     */\n    this.patternCache_ = {};\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.cacheSize_ = 0;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.maxCacheSize_ = 1024;\n  }\n\n  /**\n   * FIXME empty description for jsdoc\n   */\n  clear() {\n    this.cache_ = {};\n    this.patternCache_ = {};\n    this.cacheSize_ = 0;\n  }\n\n  /**\n   * @return {boolean} Can expire cache.\n   */\n  canExpireCache() {\n    return this.cacheSize_ > this.maxCacheSize_;\n  }\n\n  /**\n   * FIXME empty description for jsdoc\n   */\n  expire() {\n    if (this.canExpireCache()) {\n      let i = 0;\n      for (const key in this.cache_) {\n        const iconImage = this.cache_[key];\n        if ((i++ & 3) === 0 && !iconImage.hasListener()) {\n          delete this.cache_[key];\n          delete this.patternCache_[key];\n          --this.cacheSize_;\n        }\n      }\n    }\n  }\n\n  /**\n   * @param {string} src Src.\n   * @param {import(\"../color.js\").Color|string|null} color Color.\n   * @return {import(\"./IconImage.js\").default} Icon image.\n   */\n  get(src, color) {\n    const key = getCacheKey(src, color);\n\n    const icon = key in this.cache_ ? this.cache_[key] : null;\n    return icon;\n  }\n\n  /**\n   * @param {string} src Src.\n   * @param {import(\"../color.js\").Color|string|null} color Color.\n   * @return {CanvasPattern} Icon image.\n   */\n  getPattern(src, color) {\n    const key = getCacheKey(src, color);\n    return key in this.patternCache_ ? this.patternCache_[key] : null;\n  }\n\n  /**\n   * @param {string} src Src.\n   * @param {import(\"../color.js\").Color|string|null} color Color.\n   * @param {import(\"./IconImage.js\").default|null} iconImage Icon image.\n   * @param {boolean} [pattern] Also cache a `'repeat'` pattern with this `iconImage`.\n   */\n  set(src, color, iconImage, pattern) {\n    const key = getCacheKey(src, color);\n    const update = key in this.cache_;\n    this.cache_[key] = iconImage;\n    if (pattern) {\n      if (iconImage.getImageState() === ImageState.IDLE) {\n        iconImage.load();\n      }\n      if (iconImage.getImageState() === ImageState.LOADING) {\n        iconImage.ready().then(() => {\n          this.patternCache_[key] = getSharedCanvasContext2D().createPattern(\n            iconImage.getImage(1),\n            'repeat',\n          );\n        });\n      } else {\n        this.patternCache_[key] = getSharedCanvasContext2D().createPattern(\n          iconImage.getImage(1),\n          'repeat',\n        );\n      }\n    }\n    if (!update) {\n      ++this.cacheSize_;\n    }\n  }\n\n  /**\n   * Set the cache size of the icon cache. Default is `1024`. Change this value when\n   * your map uses more than 1024 different icon images and you are not caching icon\n   * styles on the application level.\n   * @param {number} maxCacheSize Cache max size.\n   * @api\n   */\n  setSize(maxCacheSize) {\n    this.maxCacheSize_ = maxCacheSize;\n    this.expire();\n  }\n}\n\n/**\n * @param {string} src Src.\n * @param {import(\"../color.js\").Color|string|null} color Color.\n * @return {string} Cache key.\n */\nexport function getCacheKey(src, color) {\n  const colorString = color ? asArray(color) : 'null';\n  return src + ':' + colorString;\n}\n\nexport default IconImageCache;\n\n/**\n * The {@link module:ol/style/IconImageCache~IconImageCache} for\n * {@link module:ol/style/Icon~Icon} images.\n * @api\n */\nexport const shared = new IconImageCache();\n","/**\n * @module ol/style/IconImage\n */\n\nimport {decodeFallback} from '../Image.js';\nimport ImageState from '../ImageState.js';\nimport {asString} from '../color.js';\nimport {createCanvasContext2D} from '../dom.js';\nimport EventType from '../events/EventType.js';\nimport EventTarget from '../events/Target.js';\nimport {shared as iconImageCache} from './IconImageCache.js';\n\n/**\n * @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D}\n */\nlet taintedTestContext = null;\n\nclass IconImage extends EventTarget {\n  /**\n   * @param {HTMLImageElement|HTMLCanvasElement|OffscreenCanvas|ImageBitmap|null} image Image.\n   * @param {string|undefined} src Src.\n   * @param {import('../dom.js').ImageAttributes} imageAttributes Image attributes options.\n   * @param {import(\"../ImageState.js\").default|undefined} imageState Image state.\n   * @param {import(\"../color.js\").Color|string|null} color Color.\n   */\n  constructor(image, src, imageAttributes, imageState, color) {\n    super();\n\n    /**\n     * @private\n     * @type {HTMLImageElement|OffscreenCanvas|HTMLCanvasElement|ImageBitmap}\n     */\n    this.hitDetectionImage_ = null;\n\n    /**\n     * @private\n     * @type {HTMLImageElement|HTMLCanvasElement|OffscreenCanvas|ImageBitmap|null}\n     */\n    this.image_ = image;\n\n    /**\n     * @private\n     * @type {string|null}\n     */\n    this.crossOrigin_ = imageAttributes?.crossOrigin;\n\n    /**\n     * @private\n     * @type {ReferrerPolicy}\n     */\n    this.referrerPolicy_ = imageAttributes?.referrerPolicy;\n\n    /**\n     * @private\n     * @type {Object<number, HTMLCanvasElement|OffscreenCanvas>}\n     */\n    this.canvas_ = {};\n\n    /**\n     * @private\n     * @type {import(\"../color.js\").Color|string|null}\n     */\n    this.color_ = color;\n\n    /**\n     * @private\n     * @type {import(\"../ImageState.js\").default}\n     */\n    this.imageState_ = imageState === undefined ? ImageState.IDLE : imageState;\n\n    /**\n     * @private\n     * @type {import(\"../size.js\").Size|null}\n     */\n    this.size_ =\n      image && image.width && image.height ? [image.width, image.height] : null;\n\n    /**\n     * @private\n     * @type {string|undefined}\n     */\n    this.src_ = src;\n\n    /**\n     * @private\n     */\n    this.tainted_;\n\n    /**\n     * @private\n     * @type {Promise<void>|null}\n     */\n    this.ready_ = null;\n  }\n\n  /**\n   * @private\n   */\n  initializeImage_() {\n    this.image_ = new Image();\n    if (this.crossOrigin_ !== null) {\n      this.image_.crossOrigin = this.crossOrigin_;\n    }\n    if (this.referrerPolicy_ !== undefined) {\n      this.image_.referrerPolicy = this.referrerPolicy_;\n    }\n  }\n\n  /**\n   * @private\n   * @return {boolean} The image canvas is tainted.\n   */\n  isTainted_() {\n    if (this.tainted_ === undefined && this.imageState_ === ImageState.LOADED) {\n      if (!taintedTestContext) {\n        taintedTestContext = createCanvasContext2D(1, 1, undefined, {\n          willReadFrequently: true,\n        });\n      }\n      taintedTestContext.drawImage(this.image_, 0, 0);\n      try {\n        taintedTestContext.getImageData(0, 0, 1, 1);\n        this.tainted_ = false;\n      } catch {\n        taintedTestContext = null;\n        this.tainted_ = true;\n      }\n    }\n    return this.tainted_ === true;\n  }\n\n  /**\n   * @private\n   */\n  dispatchChangeEvent_() {\n    this.dispatchEvent(EventType.CHANGE);\n  }\n\n  /**\n   * @private\n   */\n  handleImageError_() {\n    this.imageState_ = ImageState.ERROR;\n    this.dispatchChangeEvent_();\n  }\n\n  /**\n   * @private\n   */\n  handleImageLoad_() {\n    this.imageState_ = ImageState.LOADED;\n    this.size_ = [this.image_.width, this.image_.height];\n    this.dispatchChangeEvent_();\n  }\n\n  /**\n   * @param {number} pixelRatio Pixel ratio.\n   * @return {HTMLImageElement|HTMLCanvasElement|OffscreenCanvas|ImageBitmap} Image or Canvas element or image bitmap.\n   */\n  getImage(pixelRatio) {\n    if (!this.image_) {\n      this.initializeImage_();\n    }\n    this.replaceColor_(pixelRatio);\n    return this.canvas_[pixelRatio] ? this.canvas_[pixelRatio] : this.image_;\n  }\n\n  /**\n   * @param {HTMLImageElement|HTMLCanvasElement|OffscreenCanvas|ImageBitmap} image Image.\n   */\n  setImage(image) {\n    this.image_ = image;\n  }\n\n  /**\n   * @param {number} pixelRatio Pixel ratio.\n   * @return {number} Image or Canvas element.\n   */\n  getPixelRatio(pixelRatio) {\n    this.replaceColor_(pixelRatio);\n    return this.canvas_[pixelRatio] ? pixelRatio : 1;\n  }\n\n  /**\n   * @return {import(\"../ImageState.js\").default} Image state.\n   */\n  getImageState() {\n    return this.imageState_;\n  }\n\n  /**\n   * @return {HTMLImageElement|HTMLCanvasElement|OffscreenCanvas|ImageBitmap} Image element.\n   */\n  getHitDetectionImage() {\n    if (!this.image_) {\n      this.initializeImage_();\n    }\n    if (!this.hitDetectionImage_) {\n      if (this.isTainted_()) {\n        const width = this.size_[0];\n        const height = this.size_[1];\n        const context = createCanvasContext2D(width, height);\n        context.fillRect(0, 0, width, height);\n        this.hitDetectionImage_ = context.canvas;\n      } else {\n        this.hitDetectionImage_ = this.image_;\n      }\n    }\n    return this.hitDetectionImage_;\n  }\n\n  /**\n   * Get the size of the icon (in pixels).\n   * @return {import(\"../size.js\").Size} Image size.\n   */\n  getSize() {\n    return this.size_;\n  }\n\n  /**\n   * @return {string|undefined} Image src.\n   */\n  getSrc() {\n    return this.src_;\n  }\n\n  /**\n   * Load not yet loaded URI.\n   */\n  load() {\n    if (this.imageState_ !== ImageState.IDLE) {\n      return;\n    }\n    if (!this.image_) {\n      this.initializeImage_();\n    }\n\n    this.imageState_ = ImageState.LOADING;\n    try {\n      if (this.src_ !== undefined) {\n        /** @type {HTMLImageElement} */ (this.image_).src = this.src_;\n      }\n    } catch {\n      this.handleImageError_();\n    }\n    if (this.image_ instanceof HTMLImageElement) {\n      decodeFallback(this.image_, this.src_)\n        .then((image) => {\n          this.image_ = image;\n          this.handleImageLoad_();\n        })\n        .catch(this.handleImageError_.bind(this));\n    }\n  }\n\n  /**\n   * @param {number} pixelRatio Pixel ratio.\n   * @private\n   */\n  replaceColor_(pixelRatio) {\n    if (\n      !this.color_ ||\n      this.canvas_[pixelRatio] ||\n      this.imageState_ !== ImageState.LOADED\n    ) {\n      return;\n    }\n\n    const image = this.image_;\n    const ctx = createCanvasContext2D(\n      Math.ceil(image.width * pixelRatio),\n      Math.ceil(image.height * pixelRatio),\n    );\n    const canvas = ctx.canvas;\n\n    ctx.scale(pixelRatio, pixelRatio);\n    ctx.drawImage(image, 0, 0);\n\n    ctx.globalCompositeOperation = 'multiply';\n    ctx.fillStyle = asString(this.color_);\n    ctx.fillRect(0, 0, canvas.width / pixelRatio, canvas.height / pixelRatio);\n\n    ctx.globalCompositeOperation = 'destination-in';\n    ctx.drawImage(image, 0, 0);\n\n    this.canvas_[pixelRatio] = canvas;\n  }\n\n  /**\n   * @return {Promise<void>} Promise that resolves when the image is loaded.\n   */\n  ready() {\n    if (!this.ready_) {\n      this.ready_ = new Promise((resolve) => {\n        if (\n          this.imageState_ === ImageState.LOADED ||\n          this.imageState_ === ImageState.ERROR\n        ) {\n          resolve();\n        } else {\n          const onChange = () => {\n            if (\n              this.imageState_ === ImageState.LOADED ||\n              this.imageState_ === ImageState.ERROR\n            ) {\n              this.removeEventListener(EventType.CHANGE, onChange);\n              resolve();\n            }\n          };\n          this.addEventListener(EventType.CHANGE, onChange);\n        }\n      });\n    }\n    return this.ready_;\n  }\n}\n\n/**\n * @param {HTMLImageElement|HTMLCanvasElement|OffscreenCanvas|ImageBitmap|null} image Image.\n * @param {string|undefined} src Src.\n * @param {import('../dom.js').ImageAttributes} imageAttributes Image attributes options.\n * @param {import(\"../ImageState.js\").default|undefined} imageState Image state.\n * @param {import(\"../color.js\").Color|string|null} color Color.\n * @param {boolean} [pattern] Also cache a `repeat` pattern with the icon image.\n * @return {IconImage} Icon image.\n */\nexport function get(image, src, imageAttributes, imageState, color, pattern) {\n  let iconImage =\n    src === undefined ? undefined : iconImageCache.get(src, color);\n  if (!iconImage) {\n    iconImage = new IconImage(\n      image,\n      image && 'src' in image ? image.src || undefined : src,\n      imageAttributes,\n      imageState,\n      color,\n    );\n    iconImageCache.set(src, color, iconImage, pattern);\n  }\n  if (pattern && iconImage && !iconImageCache.getPattern(src, color)) {\n    iconImageCache.set(src, color, iconImage, pattern);\n  }\n  return iconImage;\n}\n\nexport default IconImage;\n","/**\n * @module ol/colorlike\n */\nimport ImageState from './ImageState.js';\nimport {toString} from './color.js';\nimport {createCanvasContext2D} from './dom.js';\nimport {get as getIconImage} from './style/IconImage.js';\nimport {shared as iconCache} from './style/IconImageCache.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, pattern.color);\n  }\n\n  const cacheKey = pattern.src + ':' + pattern.offset;\n\n  const canvasPattern = iconCache.getPattern(cacheKey, pattern.color);\n  if (canvasPattern) {\n    return canvasPattern;\n  }\n\n  const iconImage = iconCache.get(pattern.src, 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, pattern.color);\n}\n","/**\n * @module ol/render/canvas\n */\nimport BaseObject from '../Object.js';\nimport {fontWeights, getFontParameters} from '../css.js';\nimport {createCanvasContext2D} from '../dom.js';\nimport {WORKER_OFFSCREEN_CANVAS} from '../has.js';\nimport {clear} from '../obj.js';\n\n/**\n * @typedef {'Circle' | 'Image' | 'LineString' | 'Polygon' | 'Text' | 'Default'} BuilderType\n */\n\n/**\n * @typedef {Object} FillState\n * @property {import(\"../colorlike.js\").ColorLike} fillStyle FillStyle.\n */\n\n/**\n * @typedef Label\n * @property {number} width Width.\n * @property {number} height Height.\n * @property {Array<string|number>} contextInstructions ContextInstructions.\n */\n\n/**\n * @typedef {Object} FillStrokeState\n * @property {import(\"../colorlike.js\").ColorLike} [currentFillStyle] Current FillStyle.\n * @property {import(\"../colorlike.js\").ColorLike} [currentStrokeStyle] Current StrokeStyle.\n * @property {CanvasLineCap} [currentLineCap] Current LineCap.\n * @property {Array<number>} currentLineDash Current LineDash.\n * @property {number} [currentLineDashOffset] Current LineDashOffset.\n * @property {CanvasLineJoin} [currentLineJoin] Current LineJoin.\n * @property {number} [currentLineWidth] Current LineWidth.\n * @property {number} [currentMiterLimit] Current MiterLimit.\n * @property {number} [currentStrokeOffset] Current StrokeOffset.\n * @property {number} [lastStroke] Last stroke.\n * @property {import(\"../colorlike.js\").ColorLike} [fillStyle] FillStyle.\n * @property {import(\"../colorlike.js\").ColorLike} [strokeStyle] StrokeStyle.\n * @property {CanvasLineCap} [lineCap] LineCap.\n * @property {Array<number>} lineDash LineDash.\n * @property {number} [lineDashOffset] LineDashOffset.\n * @property {CanvasLineJoin} [lineJoin] LineJoin.\n * @property {number} [lineWidth] LineWidth.\n * @property {number} [miterLimit] MiterLimit.\n * @property {number} [strokeOffset] StrokeOffset.\n * @property {number} [fillPatternScale] Fill pattern scale.\n */\n\n/**\n * @typedef {Object} StrokeState\n * @property {CanvasLineCap} lineCap LineCap.\n * @property {Array<number>} lineDash LineDash.\n * @property {number} lineDashOffset LineDashOffset.\n * @property {CanvasLineJoin} lineJoin LineJoin.\n * @property {number} lineWidth LineWidth.\n * @property {number} miterLimit MiterLimit.\n * @property {number} [strokeOffset] StrokeOffset.\n * @property {import(\"../colorlike.js\").ColorLike} strokeStyle StrokeStyle.\n */\n\n/**\n * @typedef {Object} TextState\n * @property {string} font Font.\n * @property {CanvasTextAlign} [textAlign] TextAlign.\n * @property {number} [repeat] Repeat.\n * @property {import(\"../style/Text.js\").TextJustify} [justify] Justify.\n * @property {CanvasTextBaseline} textBaseline TextBaseline.\n * @property {import(\"../style/Text.js\").TextPlacement} [placement] Placement.\n * @property {number} [maxAngle] MaxAngle.\n * @property {boolean} [overflow] Overflow.\n * @property {import(\"../style/Fill.js\").default} [backgroundFill] BackgroundFill.\n * @property {import(\"../style/Stroke.js\").default} [backgroundStroke] BackgroundStroke.\n * @property {import(\"../size.js\").Size} [scale] Scale.\n * @property {Array<number>} [padding] Padding.\n */\n\n/**\n * @typedef {Object} SerializableInstructions\n * @property {Array<*>} instructions The rendering instructions.\n * @property {Array<*>} hitDetectionInstructions The rendering hit detection instructions.\n * @property {Array<number>} coordinates The array of all coordinates.\n * @property {!Object<string, TextState>} [textStates] The text states (decluttering).\n * @property {!Object<string, FillState>} [fillStates] The fill states (decluttering).\n * @property {!Object<string, StrokeState>} [strokeStates] The stroke states (decluttering).\n */\n\n/**\n * @typedef {Object<number, import(\"./canvas/Executor.js\").ReplayImageOrLabelArgs>} DeclutterImageWithText\n */\n\n/**\n * @const\n * @type {string}\n */\nexport const defaultFont = '10px sans-serif';\n\n/**\n * @const\n * @type {string}\n */\nexport const defaultFillStyle = '#000';\n\n/**\n * @const\n * @type {CanvasLineCap}\n */\nexport const defaultLineCap = 'round';\n\n/**\n * @const\n * @type {Array<number>}\n */\nexport const defaultLineDash = [];\n\n/**\n * @const\n * @type {number}\n */\nexport const defaultLineDashOffset = 0;\n\n/**\n * @const\n * @type {CanvasLineJoin}\n */\nexport const defaultLineJoin = 'round';\n\n/**\n * @const\n * @type {number}\n */\nexport const defaultMiterLimit = 10;\n\n/**\n * @const\n * @type {number}\n */\nexport const defaultStrokeOffset = 0;\n\n/**\n * @const\n * @type {import(\"../colorlike.js\").ColorLike}\n */\nexport const defaultStrokeStyle = '#000';\n\n/**\n * @const\n * @type {CanvasTextAlign}\n */\nexport const defaultTextAlign = 'center';\n\n/**\n * @const\n * @type {CanvasTextBaseline}\n */\nexport const defaultTextBaseline = 'middle';\n\n/**\n * @const\n * @type {Array<number>}\n */\nexport const defaultPadding = [0, 0, 0, 0];\n\n/**\n * @const\n * @type {number}\n */\nexport const defaultLineWidth = 1;\n\n/**\n * @type {BaseObject}\n */\nexport const checkedFonts = new BaseObject();\n\n/**\n * @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D}\n */\nlet measureContext = null;\n\n/**\n * @type {string}\n */\nlet measureFont;\n\n/**\n * @type {!Object<string, number>}\n */\nexport const textHeights = {};\n\nconst genericFontFamilies = new Set([\n  'serif',\n  'sans-serif',\n  'monospace',\n  'cursive',\n  'fantasy',\n  'system-ui',\n  'ui-serif',\n  'ui-sans-serif',\n  'ui-monospace',\n  'ui-rounded',\n  'emoji',\n  'math',\n  'fangsong',\n]);\n\n/**\n * @param {string} style Css font-style\n * @param {string} weight Css font-weight\n * @param {string} family Css font-family\n * @return {string} Font key.\n */\nfunction getFontKey(style, weight, family) {\n  return `${style} ${weight} 16px \"${family}\"`;\n}\n\n/**\n * Clears the label cache when a font becomes available.\n * @param {string} fontSpec CSS font spec.\n */\nexport const registerFont = (function () {\n  const retries = 100;\n  let timeout, fontFaceSet;\n\n  /**\n   * @param {string} fontSpec Css font spec\n   * @return {Promise<boolean>} Font with style and weight is available\n   */\n  async function isAvailable(fontSpec) {\n    await fontFaceSet.ready;\n    const fontFaces = await fontFaceSet.load(fontSpec);\n    if (fontFaces.length === 0) {\n      return false;\n    }\n    const font = getFontParameters(fontSpec);\n    const checkFamily = font.families[0].toLowerCase();\n    const checkWeight = font.weight;\n    return fontFaces.some(\n      /**\n       * @param {import('../css.js').FontParameters} f Font.\n       * @return {boolean} Font matches.\n       */\n      (f) => {\n        const family = f.family.replace(/^['\"]|['\"]$/g, '').toLowerCase();\n        const weight = fontWeights[f.weight] || f.weight;\n        return (\n          family === checkFamily &&\n          f.style === font.style &&\n          weight == checkWeight\n        );\n      },\n    );\n  }\n\n  async function check() {\n    await fontFaceSet.ready;\n    let done = true;\n    const checkedFontsProperties = checkedFonts.getProperties();\n    const fonts = Object.keys(checkedFontsProperties).filter(\n      (key) => checkedFontsProperties[key] < retries,\n    );\n    for (let i = fonts.length - 1; i >= 0; --i) {\n      const font = fonts[i];\n      let currentRetries = checkedFontsProperties[font];\n      if (currentRetries < retries) {\n        if (await isAvailable(font)) {\n          clear(textHeights);\n          checkedFonts.set(font, retries);\n        } else {\n          currentRetries += 10;\n          checkedFonts.set(font, currentRetries, true);\n          if (currentRetries < retries) {\n            done = false;\n          }\n        }\n      }\n    }\n    timeout = undefined;\n    if (!done) {\n      timeout = setTimeout(check, 100);\n    }\n  }\n\n  return async function (fontSpec) {\n    if (!fontFaceSet) {\n      fontFaceSet = WORKER_OFFSCREEN_CANVAS ? self.fonts : document.fonts;\n    }\n    const font = getFontParameters(fontSpec);\n    if (!font) {\n      return;\n    }\n    const families = font.families;\n    let needCheck = false;\n    for (const family of families) {\n      if (genericFontFamilies.has(family)) {\n        continue;\n      }\n      const key = getFontKey(font.style, font.weight, family);\n      if (checkedFonts.get(key) !== undefined) {\n        continue;\n      }\n      checkedFonts.set(key, 0, true);\n      needCheck = true;\n    }\n    if (needCheck) {\n      clearTimeout(timeout);\n      timeout = setTimeout(check, 100);\n    }\n  };\n})();\n\n/**\n * @param {string} font Font to use for measuring.\n * @return {import(\"../size.js\").Size} Measurement.\n */\nexport const measureTextHeight = (function () {\n  /**\n   * @type {HTMLDivElement}\n   */\n  let measureElement;\n  return function (fontSpec) {\n    let height = textHeights[fontSpec];\n    if (height == undefined) {\n      if (WORKER_OFFSCREEN_CANVAS) {\n        const font = getFontParameters(fontSpec);\n        const metrics = measureText(fontSpec, 'Žg');\n        const lineHeight = isNaN(Number(font.lineHeight))\n          ? 1.2\n          : Number(font.lineHeight);\n        height =\n          lineHeight *\n          (metrics.actualBoundingBoxAscent + metrics.actualBoundingBoxDescent);\n      } else {\n        if (!measureElement) {\n          measureElement = document.createElement('div');\n          measureElement.innerHTML = 'M';\n          measureElement.style.minHeight = '0';\n          measureElement.style.maxHeight = 'none';\n          measureElement.style.height = 'auto';\n          measureElement.style.padding = '0';\n          measureElement.style.border = 'none';\n          measureElement.style.position = 'absolute';\n          measureElement.style.display = 'block';\n          measureElement.style.left = '-99999px';\n        }\n        measureElement.style.font = fontSpec;\n        document.body.appendChild(measureElement);\n        height = measureElement.offsetHeight;\n        document.body.removeChild(measureElement);\n      }\n      textHeights[fontSpec] = height;\n    }\n    return height;\n  };\n})();\n\n/**\n * @param {string} font Font.\n * @param {string} text Text.\n * @return {TextMetrics} Text metrics.\n */\nfunction measureText(font, text) {\n  if (!measureContext) {\n    measureContext = createCanvasContext2D(1, 1);\n  }\n  if (font != measureFont) {\n    measureContext.font = font;\n    measureFont = measureContext.font;\n  }\n  return measureContext.measureText(text);\n}\n\n/**\n * @param {string} font Font.\n * @param {string} text Text.\n * @return {number} Width.\n */\nexport function measureTextWidth(font, text) {\n  return measureText(font, text).width;\n}\n\n/**\n * Measure text width using a cache.\n * @param {string} font The font.\n * @param {string} text The text to measure.\n * @param {Object<string, number>} cache A lookup of cached widths by text.\n * @return {number} The text width.\n */\nexport function measureAndCacheTextWidth(font, text, cache) {\n  if (text in cache) {\n    return cache[text];\n  }\n  const width = text\n    .split('\\n')\n    .reduce((prev, curr) => Math.max(prev, measureTextWidth(font, curr)), 0);\n  cache[text] = width;\n  return width;\n}\n\n/**\n * @param {TextState} baseStyle Base style.\n * @param {Array<string>} chunks Text chunks to measure.\n * @return {{width: number, height: number, widths: Array<number>, heights: Array<number>, lineWidths: Array<number>}}} Text metrics.\n */\nexport function getTextDimensions(baseStyle, chunks) {\n  const widths = [];\n  const heights = [];\n  const lineWidths = [];\n  let width = 0;\n  let lineWidth = 0;\n  let height = 0;\n  let lineHeight = 0;\n  for (let i = 0, ii = chunks.length; i <= ii; i += 2) {\n    const text = chunks[i];\n    if (text === '\\n' || i === ii) {\n      width = Math.max(width, lineWidth);\n      lineWidths.push(lineWidth);\n      lineWidth = 0;\n      height += lineHeight;\n      lineHeight = 0;\n      continue;\n    }\n    const font = chunks[i + 1] || baseStyle.font;\n    const currentWidth = measureTextWidth(font, text);\n    widths.push(currentWidth);\n    lineWidth += currentWidth;\n    const currentHeight = measureTextHeight(font);\n    heights.push(currentHeight);\n    lineHeight = Math.max(lineHeight, currentHeight);\n  }\n  return {width, height, widths, heights, lineWidths};\n}\n\n/**\n * @param {CanvasRenderingContext2D} context Context.\n * @param {number} rotation Rotation.\n * @param {number} offsetX X offset.\n * @param {number} offsetY Y offset.\n */\nexport function rotateAtOffset(context, rotation, offsetX, offsetY) {\n  if (rotation !== 0) {\n    context.translate(offsetX, offsetY);\n    context.rotate(rotation);\n    context.translate(-offsetX, -offsetY);\n  }\n}\n\n/**\n * @param {CanvasRenderingContext2D|import(\"../render/canvas/ZIndexContext.js\").ZIndexContextProxy} context Context.\n * @param {import(\"../transform.js\").Transform|null} transform Transform.\n * @param {number} opacity Opacity.\n * @param {Label|HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} labelOrImage Label.\n * @param {number} originX Origin X.\n * @param {number} originY Origin Y.\n * @param {number} w Width.\n * @param {number} h Height.\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../size.js\").Size} scale Scale.\n */\nexport function drawImageOrLabel(\n  context,\n  transform,\n  opacity,\n  labelOrImage,\n  originX,\n  originY,\n  w,\n  h,\n  x,\n  y,\n  scale,\n) {\n  context.save();\n\n  if (opacity !== 1) {\n    if (context.globalAlpha === undefined) {\n      context.globalAlpha = (context) => (context.globalAlpha *= opacity);\n    } else {\n      context.globalAlpha *= opacity;\n    }\n  }\n  if (transform) {\n    context.transform.apply(context, transform);\n  }\n\n  if (/** @type {*} */ (labelOrImage).contextInstructions) {\n    // label\n    context.translate(x, y);\n    context.scale(scale[0], scale[1]);\n    executeLabelInstructions(/** @type {Label} */ (labelOrImage), context);\n  } else if (scale[0] < 0 || scale[1] < 0) {\n    // flipped image\n    context.translate(x, y);\n    context.scale(scale[0], scale[1]);\n    context.drawImage(\n      /** @type {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} */ (\n        labelOrImage\n      ),\n      originX,\n      originY,\n      w,\n      h,\n      0,\n      0,\n      w,\n      h,\n    );\n  } else {\n    // if image not flipped translate and scale can be avoided\n    context.drawImage(\n      /** @type {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} */ (\n        labelOrImage\n      ),\n      originX,\n      originY,\n      w,\n      h,\n      x,\n      y,\n      w * scale[0],\n      h * scale[1],\n    );\n  }\n\n  context.restore();\n}\n\n/**\n * @param {Label} label Label.\n * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context Context.\n */\nfunction executeLabelInstructions(label, context) {\n  const contextInstructions = label.contextInstructions;\n  for (let i = 0, ii = contextInstructions.length; i < ii; i += 2) {\n    if (Array.isArray(contextInstructions[i + 1])) {\n      context[contextInstructions[i]].apply(\n        context,\n        contextInstructions[i + 1],\n      );\n    } else {\n      context[contextInstructions[i]] = contextInstructions[i + 1];\n    }\n  }\n}\n","/**\n * @module ol/style/Image\n */\nimport {toSize} from '../size.js';\nimport {abstract} from '../util.js';\n\n/**\n * @typedef {Object} Options\n * @property {number} opacity Opacity.\n * @property {boolean} rotateWithView If the image should get rotated with the view.\n * @property {number} rotation Rotation.\n * @property {number|import(\"../size.js\").Size} scale Scale.\n * @property {Array<number>} displacement Displacement.\n * @property {import('../style/Style.js').DeclutterMode} declutterMode Declutter mode: `declutter`, `obstacle`, `none`.\n */\n\n/**\n * @classdesc\n * A base class used for creating subclasses and not instantiated in\n * apps. Base class for {@link module:ol/style/Icon~Icon}, {@link module:ol/style/Circle~CircleStyle} and\n * {@link module:ol/style/RegularShape~RegularShape}.\n * @abstract\n * @api\n */\nclass ImageStyle {\n  /**\n   * @param {Options} options Options.\n   */\n  constructor(options) {\n    /**\n     * @private\n     * @type {number}\n     */\n    this.opacity_ = options.opacity;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.rotateWithView_ = options.rotateWithView;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.rotation_ = options.rotation;\n\n    /**\n     * @private\n     * @type {number|import(\"../size.js\").Size}\n     */\n    this.scale_ = options.scale;\n\n    /**\n     * @private\n     * @type {import(\"../size.js\").Size}\n     */\n    this.scaleArray_ = toSize(options.scale);\n\n    /**\n     * @private\n     * @type {Array<number>}\n     */\n    this.displacement_ = options.displacement;\n\n    /**\n     * @private\n     * @type {import('../style/Style.js').DeclutterMode}\n     */\n    this.declutterMode_ = options.declutterMode;\n  }\n\n  /**\n   * Clones the style.\n   * @return {ImageStyle} The cloned style.\n   * @api\n   */\n  clone() {\n    const scale = this.getScale();\n    return new ImageStyle({\n      opacity: this.getOpacity(),\n      scale: Array.isArray(scale) ? scale.slice() : scale,\n      rotation: this.getRotation(),\n      rotateWithView: this.getRotateWithView(),\n      displacement: this.getDisplacement().slice(),\n      declutterMode: this.getDeclutterMode(),\n    });\n  }\n\n  /**\n   * Get the symbolizer opacity.\n   * @return {number} Opacity.\n   * @api\n   */\n  getOpacity() {\n    return this.opacity_;\n  }\n\n  /**\n   * Determine whether the symbolizer rotates with the map.\n   * @return {boolean} Rotate with map.\n   * @api\n   */\n  getRotateWithView() {\n    return this.rotateWithView_;\n  }\n\n  /**\n   * Get the symoblizer rotation.\n   * @return {number} Rotation.\n   * @api\n   */\n  getRotation() {\n    return this.rotation_;\n  }\n\n  /**\n   * Get the symbolizer scale.\n   * @return {number|import(\"../size.js\").Size} Scale.\n   * @api\n   */\n  getScale() {\n    return this.scale_;\n  }\n\n  /**\n   * Get the symbolizer scale array.\n   * @return {import(\"../size.js\").Size} Scale array.\n   */\n  getScaleArray() {\n    return this.scaleArray_;\n  }\n\n  /**\n   * Get the displacement of the shape\n   * @return {Array<number>} Shape's center displacement\n   * @api\n   */\n  getDisplacement() {\n    return this.displacement_;\n  }\n\n  /**\n   * Get the declutter mode of the shape\n   * @return {import(\"./Style.js\").DeclutterMode} Shape's declutter mode\n   * @api\n   */\n  getDeclutterMode() {\n    return this.declutterMode_;\n  }\n\n  /**\n   * Get the anchor point in pixels. The anchor determines the center point for the\n   * symbolizer.\n   * @abstract\n   * @return {Array<number>} Anchor.\n   */\n  getAnchor() {\n    return abstract();\n  }\n\n  /**\n   * Get the image element for the symbolizer.\n   * @abstract\n   * @param {number} pixelRatio Pixel ratio.\n   * @return {import('../DataTile.js').ImageLike} Image element.\n   */\n  getImage(pixelRatio) {\n    return abstract();\n  }\n\n  /**\n   * @abstract\n   * @return {import('../DataTile.js').ImageLike} Image element.\n   */\n  getHitDetectionImage() {\n    return abstract();\n  }\n\n  /**\n   * Get the image pixel ratio.\n   * @param {number} pixelRatio Pixel ratio.\n   * @return {number} Pixel ratio.\n   */\n  getPixelRatio(pixelRatio) {\n    return 1;\n  }\n\n  /**\n   * @abstract\n   * @return {import(\"../ImageState.js\").default} Image state.\n   */\n  getImageState() {\n    return abstract();\n  }\n\n  /**\n   * @abstract\n   * @return {import(\"../size.js\").Size} Image size.\n   */\n  getImageSize() {\n    return abstract();\n  }\n\n  /**\n   * Get the origin of the symbolizer.\n   * @abstract\n   * @return {Array<number>} Origin.\n   */\n  getOrigin() {\n    return abstract();\n  }\n\n  /**\n   * Get the size of the symbolizer (in pixels).\n   * @abstract\n   * @return {import(\"../size.js\").Size} Size.\n   */\n  getSize() {\n    return abstract();\n  }\n\n  /**\n   * Set the displacement.\n   *\n   * @param {Array<number>} displacement Displacement.\n   * @api\n   */\n  setDisplacement(displacement) {\n    this.displacement_ = displacement;\n  }\n\n  /**\n   * Set the opacity.\n   *\n   * @param {number} opacity Opacity.\n   * @api\n   */\n  setOpacity(opacity) {\n    this.opacity_ = opacity;\n  }\n\n  /**\n   * Set whether to rotate the style with the view.\n   *\n   * @param {boolean} rotateWithView Rotate with map.\n   * @api\n   */\n  setRotateWithView(rotateWithView) {\n    this.rotateWithView_ = rotateWithView;\n  }\n\n  /**\n   * Set the rotation.\n   *\n   * @param {number} rotation Rotation.\n   * @api\n   */\n  setRotation(rotation) {\n    this.rotation_ = rotation;\n  }\n\n  /**\n   * Set the scale.\n   *\n   * @param {number|import(\"../size.js\").Size} scale Scale.\n   * @api\n   */\n  setScale(scale) {\n    this.scale_ = scale;\n    this.scaleArray_ = toSize(scale);\n  }\n\n  /**\n   * @abstract\n   * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\n   */\n  listenImageChange(listener) {\n    abstract();\n  }\n\n  /**\n   * Load not yet loaded URI.\n   * @abstract\n   */\n  load() {\n    abstract();\n  }\n\n  /**\n   * @abstract\n   * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\n   */\n  unlistenImageChange(listener) {\n    abstract();\n  }\n\n  /**\n   * @return {Promise<void>} `false` or Promise that resolves when the style is ready to use.\n   */\n  ready() {\n    return Promise.resolve();\n  }\n}\n\nexport default ImageStyle;\n","/**\n * @module ol/style/RegularShape\n */\n\nimport ImageState from '../ImageState.js';\nimport {asArray} from '../color.js';\nimport {asColorLike} from '../colorlike.js';\nimport {createCanvasContext2D} from '../dom.js';\nimport {\n  defaultFillStyle,\n  defaultLineCap,\n  defaultLineJoin,\n  defaultLineWidth,\n  defaultMiterLimit,\n  defaultStrokeStyle,\n} from '../render/canvas.js';\nimport IconImage from './IconImage.js';\nimport {shared as iconImageCache} from './IconImageCache.js';\nimport ImageStyle from './Image.js';\n\n/**\n * Specify radius for regular polygons, or both radius and radius2 for stars.\n * @typedef {Object} Options\n * @property {import(\"./Fill.js\").default} [fill] Fill style.\n * @property {number} points Number of points for stars and regular polygons. In case of a polygon, the number of points\n * is the number of sides.\n * @property {number} radius Radius of a regular polygon.\n * @property {number} [radius2] Second radius to make a star instead of a regular polygon.\n * @property {number} [angle=0] Shape's angle in radians. A value of 0 will have one of the shape's points facing up.\n * @property {Array<number>} [displacement=[0, 0]] Displacement of the shape in pixels.\n * Positive values will shift the shape right and up.\n * @property {import(\"./Stroke.js\").default} [stroke] Stroke style.\n * @property {number} [rotation=0] Rotation in radians (positive rotation clockwise).\n * @property {boolean} [rotateWithView=false] Whether to rotate the shape with the view.\n * @property {number|import(\"../size.js\").Size} [scale=1] Scale. Unless two dimensional scaling is required a better\n * result may be obtained with appropriate settings for `radius` and `radius2`.\n * @property {import('./Style.js').DeclutterMode} [declutterMode] Declutter mode.\n */\n\n/**\n * @typedef {Object} RenderOptions\n * @property {import(\"../colorlike.js\").ColorLike|undefined} strokeStyle StrokeStyle.\n * @property {number} strokeWidth StrokeWidth.\n * @property {number} size Size.\n * @property {CanvasLineCap} lineCap LineCap.\n * @property {Array<number>|null} lineDash LineDash.\n * @property {number} lineDashOffset LineDashOffset.\n * @property {CanvasLineJoin} lineJoin LineJoin.\n * @property {number} miterLimit MiterLimit.\n */\n\n/**\n * @classdesc\n * Set regular shape style for vector features. The resulting shape will be\n * a regular polygon when `radius` is provided, or a star when both `radius` and\n * `radius2` are provided.\n * @api\n */\nclass RegularShape extends ImageStyle {\n  /**\n   * @param {Options} options Options.\n   */\n  constructor(options) {\n    super({\n      opacity: 1,\n      rotateWithView:\n        options.rotateWithView !== undefined ? options.rotateWithView : false,\n      rotation: options.rotation !== undefined ? options.rotation : 0,\n      scale: options.scale !== undefined ? options.scale : 1,\n      displacement:\n        options.displacement !== undefined ? options.displacement : [0, 0],\n      declutterMode: options.declutterMode,\n    });\n\n    /**\n     * @private\n     * @type {HTMLCanvasElement|OffscreenCanvas|null}\n     */\n    this.hitDetectionCanvas_ = null;\n\n    /**\n     * @private\n     * @type {import(\"./Fill.js\").default|null}\n     */\n    this.fill_ = options.fill !== undefined ? options.fill : null;\n\n    /**\n     * @private\n     * @type {Array<number>}\n     */\n    this.origin_ = [0, 0];\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.points_ = options.points;\n\n    /**\n     * @protected\n     * @type {number}\n     */\n    this.radius = options.radius;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.radius2_ = options.radius2;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.angle_ = options.angle !== undefined ? options.angle : 0;\n\n    /**\n     * @private\n     * @type {import(\"./Stroke.js\").default|null}\n     */\n    this.stroke_ = options.stroke !== undefined ? options.stroke : null;\n\n    /**\n     * @private\n     * @type {import(\"../size.js\").Size}\n     */\n    this.size_;\n\n    /**\n     * @private\n     * @type {RenderOptions}\n     */\n    this.renderOptions_;\n\n    /**\n     * @private\n     */\n    this.imageState_ =\n      this.fill_ && this.fill_.loading()\n        ? ImageState.LOADING\n        : ImageState.LOADED;\n    if (this.imageState_ === ImageState.LOADING) {\n      this.ready().then(() => (this.imageState_ = ImageState.LOADED));\n    }\n    this.render();\n  }\n\n  /**\n   * Clones the style.\n   * @return {RegularShape} The cloned style.\n   * @api\n   * @override\n   */\n  clone() {\n    const scale = this.getScale();\n    const style = new RegularShape({\n      fill: this.getFill() ? this.getFill().clone() : undefined,\n      points: this.getPoints(),\n      radius: this.getRadius(),\n      radius2: this.getRadius2(),\n      angle: this.getAngle(),\n      stroke: this.getStroke() ? this.getStroke().clone() : undefined,\n      rotation: this.getRotation(),\n      rotateWithView: this.getRotateWithView(),\n      scale: Array.isArray(scale) ? scale.slice() : scale,\n      displacement: this.getDisplacement().slice(),\n      declutterMode: this.getDeclutterMode(),\n    });\n    style.setOpacity(this.getOpacity());\n    return style;\n  }\n\n  /**\n   * Get the anchor point in pixels. The anchor determines the center point for the\n   * symbolizer.\n   * @return {Array<number>} Anchor.\n   * @api\n   * @override\n   */\n  getAnchor() {\n    const size = this.size_;\n    const displacement = this.getDisplacement();\n    const scale = this.getScaleArray();\n    // anchor is scaled by renderer but displacement should not be scaled\n    // so divide by scale here\n    return [\n      size[0] / 2 - displacement[0] / scale[0],\n      size[1] / 2 + displacement[1] / scale[1],\n    ];\n  }\n\n  /**\n   * Get the angle used in generating the shape.\n   * @return {number} Shape's rotation in radians.\n   * @api\n   */\n  getAngle() {\n    return this.angle_;\n  }\n\n  /**\n   * Get the fill style for the shape.\n   * @return {import(\"./Fill.js\").default|null} Fill style.\n   * @api\n   */\n  getFill() {\n    return this.fill_;\n  }\n\n  /**\n   * Set the fill style.\n   * @param {import(\"./Fill.js\").default|null} fill Fill style.\n   * @api\n   */\n  setFill(fill) {\n    this.fill_ = fill;\n    this.render();\n  }\n\n  /**\n   * @return {HTMLCanvasElement|OffscreenCanvas} Image element.\n   * @override\n   */\n  getHitDetectionImage() {\n    if (!this.hitDetectionCanvas_) {\n      this.hitDetectionCanvas_ = this.createHitDetectionCanvas_(\n        this.renderOptions_,\n      );\n    }\n    return this.hitDetectionCanvas_;\n  }\n\n  /**\n   * Get the image icon.\n   * @param {number} pixelRatio Pixel ratio.\n   * @return {HTMLCanvasElement|OffscreenCanvas} Image or Canvas element.\n   * @api\n   * @override\n   */\n  getImage(pixelRatio) {\n    const fillKey = this.fill_?.getKey();\n    const cacheKey =\n      `${pixelRatio},${this.angle_},${this.radius},${this.radius2_},${this.points_},${fillKey}` +\n      Object.values(this.renderOptions_).join(',');\n    let image = /** @type {HTMLCanvasElement|OffscreenCanvas} */ (\n      iconImageCache.get(cacheKey, null)?.getImage(1)\n    );\n    if (!image) {\n      const renderOptions = this.renderOptions_;\n      const size = Math.ceil(renderOptions.size * pixelRatio);\n      const context = createCanvasContext2D(size, size);\n      this.draw_(renderOptions, context, pixelRatio);\n\n      image = context.canvas;\n      const iconImage = new IconImage(\n        image,\n        undefined,\n        null,\n        ImageState.LOADED,\n        null,\n      );\n      iconImageCache.set(cacheKey, null, iconImage);\n      // Update the image in place to an ImageBitmap for better performance and lower memory usage\n      createImageBitmap(image).then((imageBitmap) => {\n        iconImage.setImage(imageBitmap);\n      });\n    }\n    return image;\n  }\n\n  /**\n   * Get the image pixel ratio.\n   * @param {number} pixelRatio Pixel ratio.\n   * @return {number} Pixel ratio.\n   * @override\n   */\n  getPixelRatio(pixelRatio) {\n    return pixelRatio;\n  }\n\n  /**\n   * @return {import(\"../size.js\").Size} Image size.\n   * @override\n   */\n  getImageSize() {\n    return this.size_;\n  }\n\n  /**\n   * @return {import(\"../ImageState.js\").default} Image state.\n   * @override\n   */\n  getImageState() {\n    return this.imageState_;\n  }\n\n  /**\n   * Get the origin of the symbolizer.\n   * @return {Array<number>} Origin.\n   * @api\n   * @override\n   */\n  getOrigin() {\n    return this.origin_;\n  }\n\n  /**\n   * Get the number of points for generating the shape.\n   * @return {number} Number of points for stars and regular polygons.\n   * @api\n   */\n  getPoints() {\n    return this.points_;\n  }\n\n  /**\n   * Get the (primary) radius for the shape.\n   * @return {number} Radius.\n   * @api\n   */\n  getRadius() {\n    return this.radius;\n  }\n\n  /**\n   * Set the (primary) radius for the shape.\n   * @param {number} radius Radius.\n   * @api\n   */\n  setRadius(radius) {\n    if (this.radius === radius) {\n      return;\n    }\n    this.radius = radius;\n    this.render();\n  }\n\n  /**\n   * Get the secondary radius for the shape.\n   * @return {number|undefined} Radius2.\n   * @api\n   */\n  getRadius2() {\n    return this.radius2_;\n  }\n\n  /**\n   * Set the secondary radius for the shape.\n   * @param {number|undefined} radius2 Radius2.\n   * @api\n   */\n  setRadius2(radius2) {\n    if (this.radius2_ === radius2) {\n      return;\n    }\n    this.radius2_ = radius2;\n    this.render();\n  }\n\n  /**\n   * Get the size of the symbolizer (in pixels).\n   * @return {import(\"../size.js\").Size} Size.\n   * @api\n   * @override\n   */\n  getSize() {\n    return this.size_;\n  }\n\n  /**\n   * Get the stroke style for the shape.\n   * @return {import(\"./Stroke.js\").default|null} Stroke style.\n   * @api\n   */\n  getStroke() {\n    return this.stroke_;\n  }\n\n  /**\n   * Set the stroke style.\n   * @param {import(\"./Stroke.js\").default|null} stroke Stroke style.\n   * @api\n   */\n  setStroke(stroke) {\n    this.stroke_ = stroke;\n    this.render();\n  }\n\n  /**\n   * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\n   * @override\n   */\n  listenImageChange(listener) {}\n\n  /**\n   * Load not yet loaded URI.\n   * @override\n   */\n  load() {}\n\n  /**\n   * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\n   * @override\n   */\n  unlistenImageChange(listener) {}\n\n  /**\n   * Calculate additional canvas size needed for the miter.\n   * @param {string} lineJoin Line join\n   * @param {number} strokeWidth Stroke width\n   * @param {number} miterLimit Miter limit\n   * @return {number} Additional canvas size needed\n   * @private\n   */\n  calculateLineJoinSize_(lineJoin, strokeWidth, miterLimit) {\n    if (\n      strokeWidth === 0 ||\n      this.points_ === Infinity ||\n      (lineJoin !== 'bevel' && lineJoin !== 'miter')\n    ) {\n      return strokeWidth;\n    }\n    // m  | ^\n    // i  | |\\                  .\n    // t >|  #\\\n    // e  | |\\ \\              .\n    // r      \\s\\\n    //      |  \\t\\          .                 .\n    //          \\r\\                      .   .\n    //      |    \\o\\      .          .  . . .\n    //          e \\k\\            .  .    . .\n    //      |      \\e\\  .    .  .       . .\n    //       d      \\ \\  .  .          . .\n    //      | _ _a_ _\\#  .            . .\n    //   r1          / `             . .\n    //      |                       . .\n    //       b     /               . .\n    //      |                     . .\n    //           / r2            . .\n    //      |                        .   .\n    //         /                           .   .\n    //      |α                                   .   .\n    //       /                                         .   .\n    //      ° center\n    let r1 = this.radius;\n    let r2 = this.radius2_ === undefined ? r1 : this.radius2_;\n    if (r1 < r2) {\n      const tmp = r1;\n      r1 = r2;\n      r2 = tmp;\n    }\n    const points =\n      this.radius2_ === undefined ? this.points_ : this.points_ * 2;\n    const alpha = (2 * Math.PI) / points;\n    const a = r2 * Math.sin(alpha);\n    const b = Math.sqrt(r2 * r2 - a * a);\n    const d = r1 - b;\n    const e = Math.sqrt(a * a + d * d);\n    const miterRatio = e / a;\n    if (lineJoin === 'miter' && miterRatio <= miterLimit) {\n      return miterRatio * strokeWidth;\n    }\n    // Calculate the distance from center to the stroke corner where\n    // it was cut short because of the miter limit.\n    //              l\n    //        ----+---- <= distance from center to here is maxr\n    //       /####|k ##\\\n    //      /#####^#####\\\n    //     /#### /+\\# s #\\\n    //    /### h/+++\\# t #\\\n    //   /### t/+++++\\# r #\\\n    //  /### a/+++++++\\# o #\\\n    // /### p/++ fill +\\# k #\\\n    ///#### /+++++^+++++\\# e #\\\n    //#####/+++++/+\\+++++\\#####\\\n    const k = strokeWidth / 2 / miterRatio;\n    const l = (strokeWidth / 2) * (d / e);\n    const maxr = Math.sqrt((r1 + k) * (r1 + k) + l * l);\n    const bevelAdd = maxr - r1;\n    if (this.radius2_ === undefined || lineJoin === 'bevel') {\n      return bevelAdd * 2;\n    }\n    // If outer miter is over the miter limit the inner miter may reach through the\n    // center and be longer than the bevel, same calculation as above but swap r1 / r2.\n    const aa = r1 * Math.sin(alpha);\n    const bb = Math.sqrt(r1 * r1 - aa * aa);\n    const dd = r2 - bb;\n    const ee = Math.sqrt(aa * aa + dd * dd);\n    const innerMiterRatio = ee / aa;\n    if (innerMiterRatio <= miterLimit) {\n      const innerLength = (innerMiterRatio * strokeWidth) / 2 - r2 - r1;\n      return 2 * Math.max(bevelAdd, innerLength);\n    }\n    return bevelAdd * 2;\n  }\n\n  /**\n   * @return {RenderOptions}  The render options\n   * @protected\n   */\n  createRenderOptions() {\n    let lineCap = defaultLineCap;\n    let lineJoin = defaultLineJoin;\n    let miterLimit = 0;\n    let lineDash = null;\n    let lineDashOffset = 0;\n    let strokeStyle;\n    let strokeWidth = 0;\n\n    if (this.stroke_) {\n      strokeStyle = asColorLike(this.stroke_.getColor() ?? defaultStrokeStyle);\n      strokeWidth = this.stroke_.getWidth() ?? defaultLineWidth;\n      lineDash = this.stroke_.getLineDash();\n      lineDashOffset = this.stroke_.getLineDashOffset() ?? 0;\n      lineJoin = this.stroke_.getLineJoin() ?? defaultLineJoin;\n      lineCap = this.stroke_.getLineCap() ?? defaultLineCap;\n      miterLimit = this.stroke_.getMiterLimit() ?? defaultMiterLimit;\n    }\n\n    const add = this.calculateLineJoinSize_(lineJoin, strokeWidth, miterLimit);\n    const maxRadius = Math.max(this.radius, this.radius2_ || 0);\n    const size = Math.ceil(2 * maxRadius + add);\n\n    return {\n      strokeStyle: strokeStyle,\n      strokeWidth: strokeWidth,\n      size: size,\n      lineCap: lineCap,\n      lineDash: lineDash,\n      lineDashOffset: lineDashOffset,\n      lineJoin: lineJoin,\n      miterLimit: miterLimit,\n    };\n  }\n\n  /**\n   * @protected\n   */\n  render() {\n    this.renderOptions_ = this.createRenderOptions();\n    const size = this.renderOptions_.size;\n    this.hitDetectionCanvas_ = null;\n    this.size_ = [size, size];\n  }\n\n  /**\n   * @private\n   * @param {RenderOptions} renderOptions Render options.\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context The rendering context.\n   * @param {number} pixelRatio The pixel ratio.\n   */\n  draw_(renderOptions, context, pixelRatio) {\n    context.scale(pixelRatio, pixelRatio);\n    // set origin to canvas center\n    context.translate(renderOptions.size / 2, renderOptions.size / 2);\n\n    this.createPath_(context);\n\n    if (this.fill_) {\n      let color = this.fill_.getColor();\n      if (color === null) {\n        color = defaultFillStyle;\n      }\n      context.fillStyle = asColorLike(color);\n      context.fill();\n    }\n    if (renderOptions.strokeStyle) {\n      context.strokeStyle = renderOptions.strokeStyle;\n      context.lineWidth = renderOptions.strokeWidth;\n      if (renderOptions.lineDash) {\n        context.setLineDash(renderOptions.lineDash);\n        context.lineDashOffset = renderOptions.lineDashOffset;\n      }\n      context.lineCap = renderOptions.lineCap;\n      context.lineJoin = renderOptions.lineJoin;\n      context.miterLimit = renderOptions.miterLimit;\n      context.stroke();\n    }\n  }\n\n  /**\n   * @private\n   * @param {RenderOptions} renderOptions Render options.\n   * @return {HTMLCanvasElement|OffscreenCanvas} Canvas containing the icon\n   */\n  createHitDetectionCanvas_(renderOptions) {\n    let context;\n    if (this.fill_) {\n      let color = this.fill_.getColor();\n\n      // determine if fill is transparent (or pattern or gradient)\n      let opacity = 0;\n      if (typeof color === 'string') {\n        color = asArray(color);\n      }\n      if (color === null) {\n        opacity = 1;\n      } else if (Array.isArray(color)) {\n        opacity = color.length === 4 ? color[3] : 1;\n      }\n      if (opacity === 0) {\n        // if a transparent fill style is set, create an extra hit-detection image\n        // with a default fill style\n        context = createCanvasContext2D(renderOptions.size, renderOptions.size);\n        this.drawHitDetectionCanvas_(renderOptions, context);\n      }\n    }\n    return context ? context.canvas : this.getImage(1);\n  }\n\n  /**\n   * @private\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context The context to draw in.\n   */\n  createPath_(context) {\n    let points = this.points_;\n    const radius = this.radius;\n    if (points === Infinity) {\n      context.arc(0, 0, radius, 0, 2 * Math.PI);\n    } else {\n      const radius2 = this.radius2_ === undefined ? radius : this.radius2_;\n      if (this.radius2_ !== undefined) {\n        points *= 2;\n      }\n      const startAngle = this.angle_ - Math.PI / 2;\n      const step = (2 * Math.PI) / points;\n      for (let i = 0; i < points; i++) {\n        const angle0 = startAngle + i * step;\n        const radiusC = i % 2 === 0 ? radius : radius2;\n        context.lineTo(radiusC * Math.cos(angle0), radiusC * Math.sin(angle0));\n      }\n      context.closePath();\n    }\n  }\n\n  /**\n   * @private\n   * @param {RenderOptions} renderOptions Render options.\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context The context.\n   */\n  drawHitDetectionCanvas_(renderOptions, context) {\n    // set origin to canvas center\n    context.translate(renderOptions.size / 2, renderOptions.size / 2);\n\n    this.createPath_(context);\n\n    context.fillStyle = defaultFillStyle;\n    context.fill();\n    if (renderOptions.strokeStyle) {\n      context.strokeStyle = renderOptions.strokeStyle;\n      context.lineWidth = renderOptions.strokeWidth;\n      if (renderOptions.lineDash) {\n        context.setLineDash(renderOptions.lineDash);\n        context.lineDashOffset = renderOptions.lineDashOffset;\n      }\n      context.lineJoin = renderOptions.lineJoin;\n      context.miterLimit = renderOptions.miterLimit;\n      context.stroke();\n    }\n  }\n\n  /**\n   * @override\n   */\n  ready() {\n    return this.fill_ ? this.fill_.ready() : Promise.resolve();\n  }\n}\n\nexport default RegularShape;\n","/**\n * @module ol/style/Circle\n */\n\nimport RegularShape from './RegularShape.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Fill.js\").default} [fill] Fill style.\n * @property {number} radius Circle radius.\n * @property {import(\"./Stroke.js\").default} [stroke] Stroke style.\n * @property {Array<number>} [displacement=[0,0]] displacement\n * @property {number|import(\"../size.js\").Size} [scale=1] Scale. A two dimensional scale will produce an ellipse.\n * Unless two dimensional scaling is required a better result may be obtained with an appropriate setting for `radius`.\n * @property {number} [rotation=0] Rotation in radians\n * (positive rotation clockwise, meaningful only when used in conjunction with a two dimensional scale).\n * @property {boolean} [rotateWithView=false] Whether to rotate the shape with the view\n * (meaningful only when used in conjunction with a two dimensional scale).\n * @property {import('./Style.js').DeclutterMode} [declutterMode] Declutter mode\n */\n\n/**\n * @classdesc\n * Set circle style for vector features.\n * @api\n */\nclass CircleStyle extends RegularShape {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {radius: 5};\n\n    super({\n      points: Infinity,\n      fill: options.fill,\n      radius: options.radius,\n      stroke: options.stroke,\n      scale: options.scale !== undefined ? options.scale : 1,\n      rotation: options.rotation !== undefined ? options.rotation : 0,\n      rotateWithView:\n        options.rotateWithView !== undefined ? options.rotateWithView : false,\n      displacement:\n        options.displacement !== undefined ? options.displacement : [0, 0],\n      declutterMode: options.declutterMode,\n    });\n  }\n\n  /**\n   * Clones the style.\n   * @return {CircleStyle} The cloned style.\n   * @api\n   * @override\n   */\n  clone() {\n    const scale = this.getScale();\n    const style = new CircleStyle({\n      fill: this.getFill() ? this.getFill().clone() : undefined,\n      stroke: this.getStroke() ? this.getStroke().clone() : undefined,\n      radius: this.getRadius(),\n      scale: Array.isArray(scale) ? scale.slice() : scale,\n      rotation: this.getRotation(),\n      rotateWithView: this.getRotateWithView(),\n      displacement: this.getDisplacement().slice(),\n      declutterMode: this.getDeclutterMode(),\n    });\n    style.setOpacity(this.getOpacity());\n    return style;\n  }\n}\n\nexport default CircleStyle;\n","/**\n * @module ol/style/Fill\n */\n\nimport ImageState from '../ImageState.js';\nimport {asArray} from '../color.js';\nimport {getUid} from '../util.js';\nimport {get as getIconImage} from './IconImage.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike|import('../colorlike.js').PatternDescriptor|null} [color=null] A color,\n * gradient or pattern.\n * See {@link module:ol/color~Color} and {@link module:ol/colorlike~ColorLike} for possible formats. For polygon fills (not for {@link import(\"./RegularShape.js\").default} fills),\n * a pattern can also be provided as {@link module:ol/colorlike~PatternDescriptor}.\n * Default null; if null, the Canvas/renderer default black will be used.\n */\n\n/**\n * @classdesc\n * Set fill style for vector features.\n * @api\n */\nclass Fill {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options || {};\n\n    /**\n     * @private\n     * @type {import(\"./IconImage.js\").default|null}\n     */\n    this.patternImage_ = null;\n\n    /**\n     * @private\n     * @type {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike|import('../colorlike.js').PatternDescriptor|null}\n     */\n    this.color_ = null;\n    if (options.color !== undefined) {\n      this.setColor(options.color);\n    }\n  }\n\n  /**\n   * Clones the style. The color is not cloned if it is a {@link module:ol/colorlike~ColorLike}.\n   * @return {Fill} The cloned style.\n   * @api\n   */\n  clone() {\n    const color = this.getColor();\n    return new Fill({\n      color: Array.isArray(color) ? color.slice() : color || undefined,\n    });\n  }\n\n  /**\n   * Get the fill color.\n   * @return {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike|import('../colorlike.js').PatternDescriptor|null} Color.\n   * @api\n   */\n  getColor() {\n    return this.color_;\n  }\n\n  /**\n   * Set the color.\n   *\n   * @param {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike|import('../colorlike.js').PatternDescriptor|null} color Color.\n   * @api\n   */\n  setColor(color) {\n    if (color !== null && typeof color === 'object' && 'src' in color) {\n      const patternImage = getIconImage(\n        null,\n        color.src,\n        {crossOrigin: 'anonymous'},\n        undefined,\n        color.offset ? null : color.color ? color.color : null,\n        !(color.offset && color.size),\n      );\n      patternImage.ready().then(() => {\n        this.patternImage_ = null;\n      });\n      if (patternImage.getImageState() === ImageState.IDLE) {\n        patternImage.load();\n      }\n      if (patternImage.getImageState() === ImageState.LOADING) {\n        this.patternImage_ = patternImage;\n      }\n    }\n    this.color_ = color;\n  }\n\n  /**\n   * @return {string} Key of the fill for cache lookup.\n   */\n  getKey() {\n    const fill = this.getColor();\n    if (!fill) {\n      return '';\n    }\n    return fill instanceof CanvasPattern || fill instanceof CanvasGradient\n      ? getUid(fill)\n      : typeof fill === 'object' && 'src' in fill\n        ? fill.src + ':' + fill.offset\n        : asArray(fill).toString();\n  }\n\n  /**\n   * @return {boolean} The fill style is loading an image pattern.\n   */\n  loading() {\n    return !!this.patternImage_;\n  }\n\n  /**\n   * @return {Promise<void>} `false` or a promise that resolves when the style is ready to use.\n   */\n  ready() {\n    return this.patternImage_ ? this.patternImage_.ready() : Promise.resolve();\n  }\n}\n\nexport default Fill;\n","/**\n * @module ol/style/Icon\n */\nimport ImageState from '../ImageState.js';\nimport {assert} from '../asserts.js';\nimport {asArray} from '../color.js';\nimport EventType from '../events/EventType.js';\nimport {getUid} from '../util.js';\nimport {get as getIconImage} from './IconImage.js';\nimport ImageStyle from './Image.js';\n\n/**\n * @typedef {'fraction' | 'pixels'} IconAnchorUnits\n * Anchor unit can be either a fraction of the icon size or in pixels.\n */\n\n/**\n * @typedef {'bottom-left' | 'bottom-right' | 'top-left' | 'top-right'} IconOrigin\n * Icon origin. One of 'bottom-left', 'bottom-right', 'top-left', 'top-right'.\n */\n\n/**\n * @typedef {Object} Options\n * @property {Array<number>} [anchor=[0.5, 0.5]] Anchor. Default value is the icon center.\n * @property {IconOrigin} [anchorOrigin='top-left'] Origin of the anchor: `bottom-left`, `bottom-right`,\n * `top-left` or `top-right`.\n * @property {IconAnchorUnits} [anchorXUnits='fraction'] Units in which the anchor x value is\n * specified. A value of `'fraction'` indicates the x value is a fraction of the icon. A value of `'pixels'` indicates\n * the x value in pixels.\n * @property {IconAnchorUnits} [anchorYUnits='fraction'] Units in which the anchor y value is\n * specified. A value of `'fraction'` indicates the y value is a fraction of the icon. A value of `'pixels'` indicates\n * the y value in pixels.\n * @property {import(\"../color.js\").Color|string} [color] Color to tint the icon. If not specified,\n * the icon will be left as is.\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images. Note that you must provide a\n * `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for loaded images.\n * @property {HTMLImageElement|HTMLCanvasElement|OffscreenCanvas|ImageBitmap} [img] Image object for the icon.\n * @property {Array<number>} [displacement=[0, 0]] Displacement of the icon in pixels.\n * Positive values will shift the icon right and up.\n * @property {number} [opacity=1] Opacity of the icon.\n * @property {number} [width] The width of the icon in pixels. This can't be used together with `scale`.\n * @property {number} [height] The height of the icon in pixels. This can't be used together with `scale`.\n * @property {number|import(\"../size.js\").Size} [scale=1] Scale.\n * @property {boolean} [rotateWithView=false] Whether to rotate the icon with the view.\n * @property {number} [rotation=0] Rotation in radians (positive rotation clockwise).\n * @property {Array<number>} [offset=[0, 0]] Offset which, together with `size` and `offsetOrigin`, defines the\n * sub-rectangle to use from the original (sprite) image.\n * @property {IconOrigin} [offsetOrigin='top-left'] Origin of the offset: `bottom-left`, `bottom-right`,\n * `top-left` or `top-right`.\n * @property {import(\"../size.js\").Size} [size] Icon size in pixels. Used together with `offset` to define the\n * sub-rectangle to use from the original (sprite) image.\n * @property {string} [src] Image source URI.\n * @property {import(\"./Style.js\").DeclutterMode} [declutterMode] Declutter mode.\n */\n\n/**\n * @param {number} width The width.\n * @param {number} height The height.\n * @param {number|undefined} wantedWidth The wanted width.\n * @param {number|undefined} wantedHeight The wanted height.\n * @return {number|Array<number>} The scale.\n */\nfunction calculateScale(width, height, wantedWidth, wantedHeight) {\n  if (wantedWidth !== undefined && wantedHeight !== undefined) {\n    return [wantedWidth / width, wantedHeight / height];\n  }\n  if (wantedWidth !== undefined) {\n    return wantedWidth / width;\n  }\n  if (wantedHeight !== undefined) {\n    return wantedHeight / height;\n  }\n  return 1;\n}\n\n/**\n * @classdesc\n * Set icon style for vector features.\n * @api\n */\nclass Icon extends ImageStyle {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options || {};\n\n    /**\n     * @type {number}\n     */\n    const opacity = options.opacity !== undefined ? options.opacity : 1;\n\n    /**\n     * @type {number}\n     */\n    const rotation = options.rotation !== undefined ? options.rotation : 0;\n\n    /**\n     * @type {number|import(\"../size.js\").Size}\n     */\n    const scale = options.scale !== undefined ? options.scale : 1;\n\n    /**\n     * @type {boolean}\n     */\n    const rotateWithView =\n      options.rotateWithView !== undefined ? options.rotateWithView : false;\n\n    super({\n      opacity: opacity,\n      rotation: rotation,\n      scale: scale,\n      displacement:\n        options.displacement !== undefined ? options.displacement : [0, 0],\n      rotateWithView: rotateWithView,\n      declutterMode: options.declutterMode,\n    });\n\n    /**\n     * @private\n     * @type {Array<number>}\n     */\n    this.anchor_ = options.anchor !== undefined ? options.anchor : [0.5, 0.5];\n\n    /**\n     * @private\n     * @type {Array<number>}\n     */\n    this.normalizedAnchor_ = null;\n\n    /**\n     * @private\n     * @type {IconOrigin}\n     */\n    this.anchorOrigin_ =\n      options.anchorOrigin !== undefined ? options.anchorOrigin : 'top-left';\n\n    /**\n     * @private\n     * @type {IconAnchorUnits}\n     */\n    this.anchorXUnits_ =\n      options.anchorXUnits !== undefined ? options.anchorXUnits : 'fraction';\n\n    /**\n     * @private\n     * @type {IconAnchorUnits}\n     */\n    this.anchorYUnits_ =\n      options.anchorYUnits !== undefined ? options.anchorYUnits : 'fraction';\n\n    /**\n     * @private\n     * @type {?string}\n     */\n    this.crossOrigin_ =\n      options.crossOrigin !== undefined ? options.crossOrigin : null;\n\n    /**\n     * @private\n     * @type {ReferrerPolicy}\n     */\n    this.referrerPolicy_ = options.referrerPolicy;\n\n    const image = options.img !== undefined ? options.img : null;\n\n    let cacheKey = options.src;\n\n    assert(\n      !(cacheKey !== undefined && image),\n      '`image` and `src` cannot be provided at the same time',\n    );\n\n    if ((cacheKey === undefined || cacheKey.length === 0) && image) {\n      cacheKey = /** @type {HTMLImageElement} */ (image).src || getUid(image);\n    }\n    assert(\n      cacheKey !== undefined && cacheKey.length > 0,\n      'A defined and non-empty `src` or `image` must be provided',\n    );\n\n    assert(\n      !(\n        (options.width !== undefined || options.height !== undefined) &&\n        options.scale !== undefined\n      ),\n      '`width` or `height` cannot be provided together with `scale`',\n    );\n\n    let imageState;\n    if (options.src !== undefined) {\n      imageState = ImageState.IDLE;\n    } else if (image !== undefined) {\n      if ('complete' in image) {\n        if (image.complete) {\n          imageState = image.src ? ImageState.LOADED : ImageState.IDLE;\n        } else {\n          imageState = ImageState.LOADING;\n        }\n      } else {\n        imageState = ImageState.LOADED;\n      }\n    }\n\n    /**\n     * @private\n     * @type {import(\"../color.js\").Color}\n     */\n    this.color_ = options.color !== undefined ? asArray(options.color) : null;\n\n    /**\n     * @private\n     * @type {import(\"./IconImage.js\").default}\n     */\n    this.iconImage_ = getIconImage(\n      image,\n      /** @type {string} */ (cacheKey),\n      {\n        crossOrigin: this.crossOrigin_,\n        referrerPolicy: this.referrerPolicy_,\n      },\n      imageState,\n      this.color_,\n    );\n\n    /**\n     * @private\n     * @type {Array<number>}\n     */\n    this.offset_ = options.offset !== undefined ? options.offset : [0, 0];\n    /**\n     * @private\n     * @type {IconOrigin}\n     */\n    this.offsetOrigin_ =\n      options.offsetOrigin !== undefined ? options.offsetOrigin : 'top-left';\n\n    /**\n     * @private\n     * @type {Array<number>}\n     */\n    this.origin_ = null;\n\n    /**\n     * @private\n     * @type {import(\"../size.js\").Size}\n     */\n    this.size_ = options.size !== undefined ? options.size : null;\n\n    /**\n     * @private\n     */\n    this.initialOptions_;\n\n    /**\n     * Calculate the scale if width or height were given.\n     */\n    if (options.width !== undefined || options.height !== undefined) {\n      let width, height;\n      if (options.size) {\n        [width, height] = options.size;\n      } else {\n        const image = this.getImage(1);\n        if (image.width && image.height) {\n          width = image.width;\n          height = image.height;\n        } else if (image instanceof HTMLImageElement) {\n          this.initialOptions_ = options;\n          const onload = () => {\n            this.unlistenImageChange(onload);\n            if (!this.initialOptions_) {\n              return;\n            }\n            const imageSize = this.iconImage_.getSize();\n            this.setScale(\n              calculateScale(\n                imageSize[0],\n                imageSize[1],\n                options.width,\n                options.height,\n              ),\n            );\n          };\n          this.listenImageChange(onload);\n          return;\n        }\n      }\n      if (width !== undefined) {\n        this.setScale(\n          calculateScale(width, height, options.width, options.height),\n        );\n      }\n    }\n  }\n\n  /**\n   * Clones the style. The underlying Image/HTMLCanvasElement is not cloned.\n   * @return {Icon} The cloned style.\n   * @api\n   * @override\n   */\n  clone() {\n    let scale, width, height;\n    if (this.initialOptions_) {\n      width = this.initialOptions_.width;\n      height = this.initialOptions_.height;\n    } else {\n      scale = this.getScale();\n      scale = Array.isArray(scale) ? scale.slice() : scale;\n    }\n    return new Icon({\n      anchor: this.anchor_.slice(),\n      anchorOrigin: this.anchorOrigin_,\n      anchorXUnits: this.anchorXUnits_,\n      anchorYUnits: this.anchorYUnits_,\n      color:\n        this.color_ && this.color_.slice\n          ? this.color_.slice()\n          : this.color_ || undefined,\n      crossOrigin: this.crossOrigin_,\n      referrerPolicy: this.referrerPolicy_,\n      offset: this.offset_.slice(),\n      offsetOrigin: this.offsetOrigin_,\n      opacity: this.getOpacity(),\n      rotateWithView: this.getRotateWithView(),\n      rotation: this.getRotation(),\n      scale,\n      width,\n      height,\n      size: this.size_ !== null ? this.size_.slice() : undefined,\n      src: this.getSrc(),\n      displacement: this.getDisplacement().slice(),\n      declutterMode: this.getDeclutterMode(),\n    });\n  }\n\n  /**\n   * Get the anchor point in pixels. The anchor determines the center point for the\n   * symbolizer.\n   * @return {Array<number>} Anchor.\n   * @api\n   * @override\n   */\n  getAnchor() {\n    let anchor = this.normalizedAnchor_;\n    if (!anchor) {\n      anchor = this.anchor_;\n      const size = this.getSize();\n      if (\n        this.anchorXUnits_ == 'fraction' ||\n        this.anchorYUnits_ == 'fraction'\n      ) {\n        if (!size) {\n          return null;\n        }\n        anchor = this.anchor_.slice();\n        if (this.anchorXUnits_ == 'fraction') {\n          anchor[0] *= size[0];\n        }\n        if (this.anchorYUnits_ == 'fraction') {\n          anchor[1] *= size[1];\n        }\n      }\n\n      if (this.anchorOrigin_ != 'top-left') {\n        if (!size) {\n          return null;\n        }\n        if (anchor === this.anchor_) {\n          anchor = this.anchor_.slice();\n        }\n        if (\n          this.anchorOrigin_ == 'top-right' ||\n          this.anchorOrigin_ == 'bottom-right'\n        ) {\n          anchor[0] = -anchor[0] + size[0];\n        }\n        if (\n          this.anchorOrigin_ == 'bottom-left' ||\n          this.anchorOrigin_ == 'bottom-right'\n        ) {\n          anchor[1] = -anchor[1] + size[1];\n        }\n      }\n      this.normalizedAnchor_ = anchor;\n    }\n    const displacement = this.getDisplacement();\n    const scale = this.getScaleArray();\n    // anchor is scaled by renderer but displacement should not be scaled\n    // so divide by scale here\n    return [\n      anchor[0] - displacement[0] / scale[0],\n      anchor[1] + displacement[1] / scale[1],\n    ];\n  }\n\n  /**\n   * Set the anchor point. The anchor determines the center point for the\n   * symbolizer.\n   *\n   * @param {Array<number>} anchor Anchor.\n   * @api\n   */\n  setAnchor(anchor) {\n    this.anchor_ = anchor;\n    this.normalizedAnchor_ = null;\n  }\n\n  /**\n   * Get the icon color.\n   * @return {import(\"../color.js\").Color} Color.\n   * @api\n   */\n  getColor() {\n    return this.color_;\n  }\n\n  /**\n   * Set the icon color.\n   *\n   * Warning: Repeatedly setting the color on an icon style\n   * causes the icon image to be re-created each time. This can have a\n   * severe performance impact.\n   *\n   * @param {import(\"../color.js\").Color|string|null|undefined} color Color.\n   */\n  setColor(color) {\n    const nextColor = color ? asArray(color) : null;\n    if (\n      this.color_ === nextColor ||\n      (this.color_ &&\n        nextColor &&\n        this.color_.length === nextColor.length &&\n        this.color_.every((value, index) => value === nextColor[index]))\n    ) {\n      // Discard if the color hasn't changed.\n      return;\n    }\n\n    this.color_ = nextColor;\n    const src = this.getSrc();\n    const image = src !== undefined ? null : this.getHitDetectionImage();\n    const imageState =\n      src !== undefined ? ImageState.IDLE : this.iconImage_.getImageState();\n    this.iconImage_ = getIconImage(\n      image,\n      src,\n      {\n        crossOrigin: this.crossOrigin_,\n        referrerPolicy: this.referrerPolicy_,\n      },\n      imageState,\n      this.color_,\n    );\n  }\n\n  /**\n   * Get the image icon.\n   * @param {number} pixelRatio Pixel ratio.\n   * @return {HTMLImageElement|HTMLCanvasElement|OffscreenCanvas|ImageBitmap} Image or Canvas element. If the Icon\n   * style was configured with `src` or with a not let loaded `img`, an `ImageBitmap` will be returned.\n   * @api\n   * @override\n   */\n  getImage(pixelRatio) {\n    return this.iconImage_.getImage(pixelRatio);\n  }\n\n  /**\n   * Get the pixel ratio.\n   * @param {number} pixelRatio Pixel ratio.\n   * @return {number} The pixel ratio of the image.\n   * @api\n   * @override\n   */\n  getPixelRatio(pixelRatio) {\n    return this.iconImage_.getPixelRatio(pixelRatio);\n  }\n\n  /**\n   * @return {import(\"../size.js\").Size} Image size.\n   * @override\n   */\n  getImageSize() {\n    return this.iconImage_.getSize();\n  }\n\n  /**\n   * @return {import(\"../ImageState.js\").default} Image state.\n   * @override\n   */\n  getImageState() {\n    return this.iconImage_.getImageState();\n  }\n\n  /**\n   * @return {HTMLImageElement|HTMLCanvasElement|OffscreenCanvas|ImageBitmap} Image element.\n   * @override\n   */\n  getHitDetectionImage() {\n    return this.iconImage_.getHitDetectionImage();\n  }\n\n  /**\n   * Get the origin of the symbolizer.\n   * @return {Array<number>} Origin.\n   * @api\n   * @override\n   */\n  getOrigin() {\n    if (this.origin_) {\n      return this.origin_;\n    }\n    let offset = this.offset_;\n\n    if (this.offsetOrigin_ != 'top-left') {\n      const size = this.getSize();\n      const iconImageSize = this.iconImage_.getSize();\n      if (!size || !iconImageSize) {\n        return null;\n      }\n      offset = offset.slice();\n      if (\n        this.offsetOrigin_ == 'top-right' ||\n        this.offsetOrigin_ == 'bottom-right'\n      ) {\n        offset[0] = iconImageSize[0] - size[0] - offset[0];\n      }\n      if (\n        this.offsetOrigin_ == 'bottom-left' ||\n        this.offsetOrigin_ == 'bottom-right'\n      ) {\n        offset[1] = iconImageSize[1] - size[1] - offset[1];\n      }\n    }\n    this.origin_ = offset;\n    return this.origin_;\n  }\n\n  /**\n   * Get the image URL.\n   * @return {string|undefined} Image src.\n   * @api\n   */\n  getSrc() {\n    return this.iconImage_.getSrc();\n  }\n\n  /**\n   * Set the image URI\n   * @param {string} src Image source URI\n   * @api\n   */\n  setSrc(src) {\n    this.iconImage_ = getIconImage(\n      null,\n      src,\n      {\n        crossOrigin: this.crossOrigin_,\n        referrerPolicy: this.referrerPolicy_,\n      },\n      ImageState.IDLE,\n      this.color_,\n    );\n  }\n\n  /**\n   * Get the size of the icon (in pixels).\n   * @return {import(\"../size.js\").Size} Image size.\n   * @api\n   * @override\n   */\n  getSize() {\n    return !this.size_ ? this.iconImage_.getSize() : this.size_;\n  }\n\n  /**\n   * Get the width of the icon (in pixels). Will return undefined when the icon image is not yet loaded.\n   * @return {number} Icon width (in pixels).\n   * @api\n   */\n  getWidth() {\n    const scale = this.getScaleArray();\n    if (this.size_) {\n      return this.size_[0] * scale[0];\n    }\n    if (this.iconImage_.getImageState() == ImageState.LOADED) {\n      return this.iconImage_.getSize()[0] * scale[0];\n    }\n    return undefined;\n  }\n\n  /**\n   * Get the height of the icon (in pixels). Will return undefined when the icon image is not yet loaded.\n   * @return {number} Icon height (in pixels).\n   * @api\n   */\n  getHeight() {\n    const scale = this.getScaleArray();\n    if (this.size_) {\n      return this.size_[1] * scale[1];\n    }\n    if (this.iconImage_.getImageState() == ImageState.LOADED) {\n      return this.iconImage_.getSize()[1] * scale[1];\n    }\n    return undefined;\n  }\n\n  /**\n   * Set the scale.\n   *\n   * @param {number|import(\"../size.js\").Size} scale Scale.\n   * @api\n   * @override\n   */\n  setScale(scale) {\n    delete this.initialOptions_;\n    super.setScale(scale);\n  }\n\n  /**\n   * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\n   * @override\n   */\n  listenImageChange(listener) {\n    this.iconImage_.addEventListener(EventType.CHANGE, listener);\n  }\n\n  /**\n   * Load not yet loaded URI.\n   * When rendering a feature with an icon style, the vector renderer will\n   * automatically call this method. However, you might want to call this\n   * method yourself for preloading or other purposes.\n   * @api\n   * @override\n   */\n  load() {\n    this.iconImage_.load();\n  }\n\n  /**\n   * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\n   * @override\n   */\n  unlistenImageChange(listener) {\n    this.iconImage_.removeEventListener(EventType.CHANGE, listener);\n  }\n\n  /**\n   * @override\n   */\n  ready() {\n    return this.iconImage_.ready();\n  }\n}\n\nexport default Icon;\n","/**\n * @module ol/style/Stroke\n */\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike} [color] A color, gradient or pattern.\n * See {@link module:ol/color~Color} and {@link module:ol/colorlike~ColorLike} for possible formats.\n * Default null; if null, the Canvas/renderer default black will be used.\n * @property {CanvasLineCap} [lineCap='round'] Line cap style: `butt`, `round`, or `square`.\n * @property {CanvasLineJoin} [lineJoin='round'] Line join style: `bevel`, `round`, or `miter`.\n * @property {Array<number>} [lineDash] Line dash pattern. Default is `null` (no dash).\n * @property {number} [lineDashOffset=0] Line dash offset.\n * @property {number} [miterLimit=10] Miter limit.\n * @property {number} [offset] Line offset in pixels along the normal. A positive value offsets the line to the right,\n * relative to the direction of the line. Default is `undefined` (no offset).\n * @property {number} [width] Width.\n */\n\n/**\n * @classdesc\n * Set stroke style for vector features.\n * Note that the defaults given are the Canvas defaults, which will be used if\n * option is not defined. The `get` functions return whatever was entered in\n * the options; they will not return the default.\n * @api\n */\nclass Stroke {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options || {};\n\n    /**\n     * @private\n     * @type {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike}\n     */\n    this.color_ = options.color !== undefined ? options.color : null;\n\n    /**\n     * @private\n     * @type {CanvasLineCap|undefined}\n     */\n    this.lineCap_ = options.lineCap;\n\n    /**\n     * @private\n     * @type {Array<number>|null}\n     */\n    this.lineDash_ = options.lineDash !== undefined ? options.lineDash : null;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.lineDashOffset_ = options.lineDashOffset;\n\n    /**\n     * @private\n     * @type {CanvasLineJoin|undefined}\n     */\n    this.lineJoin_ = options.lineJoin;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.miterLimit_ = options.miterLimit;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.offset_ = options.offset;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.width_ = options.width;\n  }\n\n  /**\n   * Clones the style.\n   * @return {Stroke} The cloned style.\n   * @api\n   */\n  clone() {\n    const color = this.getColor();\n    return new Stroke({\n      color: Array.isArray(color) ? color.slice() : color || undefined,\n      lineCap: this.getLineCap(),\n      lineDash: this.getLineDash() ? this.getLineDash().slice() : undefined,\n      lineDashOffset: this.getLineDashOffset(),\n      lineJoin: this.getLineJoin(),\n      miterLimit: this.getMiterLimit(),\n      offset: this.getOffset(),\n      width: this.getWidth(),\n    });\n  }\n\n  /**\n   * Get the stroke color.\n   * @return {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike} Color.\n   * @api\n   */\n  getColor() {\n    return this.color_;\n  }\n\n  /**\n   * Get the line cap type for the stroke.\n   * @return {CanvasLineCap|undefined} Line cap.\n   * @api\n   */\n  getLineCap() {\n    return this.lineCap_;\n  }\n\n  /**\n   * Get the line dash style for the stroke.\n   * @return {Array<number>|null} Line dash.\n   * @api\n   */\n  getLineDash() {\n    return this.lineDash_;\n  }\n\n  /**\n   * Get the line dash offset for the stroke.\n   * @return {number|undefined} Line dash offset.\n   * @api\n   */\n  getLineDashOffset() {\n    return this.lineDashOffset_;\n  }\n\n  /**\n   * Get the line join type for the stroke.\n   * @return {CanvasLineJoin|undefined} Line join.\n   * @api\n   */\n  getLineJoin() {\n    return this.lineJoin_;\n  }\n\n  /**\n   * Get the miter limit for the stroke.\n   * @return {number|undefined} Miter limit.\n   * @api\n   */\n  getMiterLimit() {\n    return this.miterLimit_;\n  }\n\n  /**\n   * Get the line offset in pixels.\n   * @return {number|undefined} Offset.\n   * @api\n   */\n  getOffset() {\n    return this.offset_;\n  }\n\n  /**\n   * Get the stroke width.\n   * @return {number|undefined} Width.\n   * @api\n   */\n  getWidth() {\n    return this.width_;\n  }\n\n  /**\n   * Set the color.\n   *\n   * @param {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike} color Color.\n   * @api\n   */\n  setColor(color) {\n    this.color_ = color;\n  }\n\n  /**\n   * Set the line cap.\n   *\n   * @param {CanvasLineCap|undefined} lineCap Line cap.\n   * @api\n   */\n  setLineCap(lineCap) {\n    this.lineCap_ = lineCap;\n  }\n\n  /**\n   * Set the line dash.\n   *\n   * @param {Array<number>|null} lineDash Line dash.\n   * @api\n   */\n  setLineDash(lineDash) {\n    this.lineDash_ = lineDash;\n  }\n\n  /**\n   * Set the line dash offset.\n   *\n   * @param {number|undefined} lineDashOffset Line dash offset.\n   * @api\n   */\n  setLineDashOffset(lineDashOffset) {\n    this.lineDashOffset_ = lineDashOffset;\n  }\n\n  /**\n   * Set the line join.\n   *\n   * @param {CanvasLineJoin|undefined} lineJoin Line join.\n   * @api\n   */\n  setLineJoin(lineJoin) {\n    this.lineJoin_ = lineJoin;\n  }\n\n  /**\n   * Set the miter limit.\n   *\n   * @param {number|undefined} miterLimit Miter limit.\n   * @api\n   */\n  setMiterLimit(miterLimit) {\n    this.miterLimit_ = miterLimit;\n  }\n\n  /**\n   * Set the line offset in pixels.\n   *\n   * @param {number|undefined} offset Offset.\n   * @api\n   */\n  setOffset(offset) {\n    this.offset_ = offset;\n  }\n\n  /**\n   * Set the width.\n   *\n   * @param {number|undefined} width Width.\n   * @api\n   */\n  setWidth(width) {\n    this.width_ = width;\n  }\n}\n\nexport default Stroke;\n","/**\n * @module ol/style/Style\n */\n\nimport {assert} from '../asserts.js';\nimport CircleStyle from './Circle.js';\nimport Fill from './Fill.js';\nimport Stroke from './Stroke.js';\n\n/**\n * Defines how symbols and text are decluttered on layers ith `declutter` set to `true`\n * **declutter**: Overlapping symbols and text are decluttered.\n * **obstacle**: Symbols and text are rendered, but serve as obstacle for subsequent attempts\n *   to place a symbol or text at the same location.\n * **none**: No decluttering is done.\n *\n * @typedef {\"declutter\"|\"obstacle\"|\"none\"} DeclutterMode\n */\n\n/**\n * A function that takes a {@link module:ol/Feature~Feature} and a `{number}`\n * representing the view's resolution. The function should return a\n * {@link module:ol/style/Style~Style} or an array of them. This way e.g. a\n * vector layer can be styled. If the function returns `undefined`, the\n * feature will not be rendered.\n *\n * @typedef {function(import(\"../Feature.js\").FeatureLike, number):(Style|Array<Style>|void)} StyleFunction\n */\n\n/**\n * A {@link Style}, an array of {@link Style}, or a {@link StyleFunction}.\n * @typedef {Style|Array<Style>|StyleFunction} StyleLike\n */\n\n/**\n * A function that takes a {@link module:ol/Feature~Feature} as argument and returns an\n * {@link module:ol/geom/Geometry~Geometry} that will be rendered and styled for the feature.\n *\n * @typedef {function(import(\"../Feature.js\").FeatureLike):\n *     (import(\"../geom/Geometry.js\").default|import(\"../render/Feature.js\").default|undefined)} GeometryFunction\n */\n\n/**\n * Custom renderer function. Takes two arguments:\n *\n * 1. The pixel coordinates of the geometry in GeoJSON notation.\n * 2. The {@link module:ol/render~State} of the layer renderer.\n *\n * @typedef {function((import(\"../coordinate.js\").Coordinate|Array<import(\"../coordinate.js\").Coordinate>|Array<Array<import(\"../coordinate.js\").Coordinate>>|Array<Array<Array<import(\"../coordinate.js\").Coordinate>>>),import(\"../render.js\").State): void} RenderFunction\n */\n\n/**\n * @typedef {Object} Options\n * @property {string|import(\"../geom/Geometry.js\").default|GeometryFunction} [geometry] Feature property or geometry\n * or function returning a geometry to render for this style.\n * @property {import(\"./Fill.js\").default} [fill] Fill style.\n * @property {import(\"./Image.js\").default} [image] Image style.\n * @property {RenderFunction} [renderer] Custom renderer. When configured, `fill`, `stroke` and `image` will be\n * ignored, and the provided function will be called with each render frame for each geometry.\n * @property {RenderFunction} [hitDetectionRenderer] Custom renderer for hit detection. If provided will be used\n * in hit detection rendering.\n * @property {import(\"./Stroke.js\").default} [stroke] Stroke style.\n * @property {import(\"./Text.js\").default} [text] Text style.\n * @property {number} [zIndex] Z index.\n */\n\n/**\n * @classdesc\n * Container for vector feature rendering styles. Any changes made to the style\n * or its children through `set*()` methods will not take effect until the\n * feature or layer that uses the style is re-rendered.\n *\n * ## Feature styles\n *\n * If no style is defined, the following default style is used:\n * ```js\n *  import {Circle, Fill, Stroke, Style} from 'ol/style.js';\n *\n *  const fill = new Fill({\n *    color: 'rgba(255,255,255,0.4)',\n *  });\n *  const stroke = new Stroke({\n *    color: '#3399CC',\n *    width: 1.25,\n *  });\n *  const styles = [\n *    new Style({\n *      image: new Circle({\n *        fill: fill,\n *        stroke: stroke,\n *        radius: 5,\n *      }),\n *      fill: fill,\n *      stroke: stroke,\n *    }),\n *  ];\n * ```\n *\n * A separate editing style has the following defaults:\n * ```js\n *  import {Circle, Fill, Stroke, Style} from 'ol/style.js';\n *\n *  const styles = {};\n *  const white = [255, 255, 255, 1];\n *  const blue = [0, 153, 255, 1];\n *  const width = 3;\n *  styles['Polygon'] = [\n *    new Style({\n *      fill: new Fill({\n *        color: [255, 255, 255, 0.5],\n *      }),\n *    }),\n *  ];\n *  styles['MultiPolygon'] =\n *      styles['Polygon'];\n *  styles['LineString'] = [\n *    new Style({\n *      stroke: new Stroke({\n *        color: white,\n *        width: width + 2,\n *      }),\n *    }),\n *    new Style({\n *      stroke: new Stroke({\n *        color: blue,\n *        width: width,\n *      }),\n *    }),\n *  ];\n *  styles['MultiLineString'] = styles['LineString'];\n *\n *  styles['Circle'] = styles['Polygon'].concat(\n *    styles['LineString']\n *  );\n *\n *  styles['Point'] = [\n *    new Style({\n *      image: new Circle({\n *        radius: width * 2,\n *        fill: new Fill({\n *          color: blue,\n *        }),\n *        stroke: new Stroke({\n *          color: white,\n *          width: width / 2,\n *        }),\n *      }),\n *      zIndex: Infinity,\n *    }),\n *  ];\n *  styles['MultiPoint'] =\n *      styles['Point'];\n *  styles['GeometryCollection'] =\n *      styles['Polygon'].concat(\n *          styles['LineString'],\n *          styles['Point']\n *      );\n * ```\n *\n * @api\n */\nclass Style {\n  /**\n   * @param {Options} [options] Style options.\n   */\n  constructor(options) {\n    options = options || {};\n\n    /**\n     * @private\n     * @type {string|import(\"../geom/Geometry.js\").default|GeometryFunction|null}\n     */\n    this.geometry_ = null;\n\n    /**\n     * @private\n     * @type {!GeometryFunction}\n     */\n    this.geometryFunction_ = defaultGeometryFunction;\n\n    if (options.geometry !== undefined) {\n      this.setGeometry(options.geometry);\n    }\n\n    /**\n     * @private\n     * @type {import(\"./Fill.js\").default|null}\n     */\n    this.fill_ = options.fill !== undefined ? options.fill : null;\n\n    /**\n     * @private\n     * @type {import(\"./Image.js\").default|null}\n     */\n    this.image_ = options.image !== undefined ? options.image : null;\n\n    /**\n     * @private\n     * @type {RenderFunction|null}\n     */\n    this.renderer_ = options.renderer !== undefined ? options.renderer : null;\n\n    /**\n     * @private\n     * @type {RenderFunction|null}\n     */\n    this.hitDetectionRenderer_ =\n      options.hitDetectionRenderer !== undefined\n        ? options.hitDetectionRenderer\n        : null;\n\n    /**\n     * @private\n     * @type {import(\"./Stroke.js\").default|null}\n     */\n    this.stroke_ = options.stroke !== undefined ? options.stroke : null;\n\n    /**\n     * @private\n     * @type {import(\"./Text.js\").default|null}\n     */\n    this.text_ = options.text !== undefined ? options.text : null;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.zIndex_ = options.zIndex;\n  }\n\n  /**\n   * Clones the style.\n   * @return {Style} The cloned style.\n   * @api\n   */\n  clone() {\n    let geometry = this.getGeometry();\n    if (geometry && typeof geometry === 'object') {\n      geometry = /** @type {import(\"../geom/Geometry.js\").default} */ (\n        geometry\n      ).clone();\n    }\n    return new Style({\n      geometry: geometry ?? undefined,\n      fill: this.getFill() ? this.getFill().clone() : undefined,\n      image: this.getImage() ? this.getImage().clone() : undefined,\n      renderer: this.getRenderer() ?? undefined,\n      stroke: this.getStroke() ? this.getStroke().clone() : undefined,\n      text: this.getText() ? this.getText().clone() : undefined,\n      zIndex: this.getZIndex(),\n    });\n  }\n\n  /**\n   * Get the custom renderer function that was configured with\n   * {@link #setRenderer} or the `renderer` constructor option.\n   * @return {RenderFunction|null} Custom renderer function.\n   * @api\n   */\n  getRenderer() {\n    return this.renderer_;\n  }\n\n  /**\n   * Sets a custom renderer function for this style. When set, `fill`, `stroke`\n   * and `image` options of the style will be ignored.\n   * @param {RenderFunction|null} renderer Custom renderer function.\n   * @api\n   */\n  setRenderer(renderer) {\n    this.renderer_ = renderer;\n  }\n\n  /**\n   * Sets a custom renderer function for this style used\n   * in hit detection.\n   * @param {RenderFunction|null} renderer Custom renderer function.\n   * @api\n   */\n  setHitDetectionRenderer(renderer) {\n    this.hitDetectionRenderer_ = renderer;\n  }\n\n  /**\n   * Get the custom renderer function that was configured with\n   * {@link #setHitDetectionRenderer} or the `hitDetectionRenderer` constructor option.\n   * @return {RenderFunction|null} Custom renderer function.\n   * @api\n   */\n  getHitDetectionRenderer() {\n    return this.hitDetectionRenderer_;\n  }\n\n  /**\n   * Get the geometry to be rendered.\n   * @return {string|import(\"../geom/Geometry.js\").default|GeometryFunction|null}\n   * Feature property or geometry or function that returns the geometry that will\n   * be rendered with this style.\n   * @api\n   */\n  getGeometry() {\n    return this.geometry_;\n  }\n\n  /**\n   * Get the function used to generate a geometry for rendering.\n   * @return {!GeometryFunction} Function that is called with a feature\n   * and returns the geometry to render instead of the feature's geometry.\n   * @api\n   */\n  getGeometryFunction() {\n    return this.geometryFunction_;\n  }\n\n  /**\n   * Get the fill style.\n   * @return {import(\"./Fill.js\").default|null} Fill style.\n   * @api\n   */\n  getFill() {\n    return this.fill_;\n  }\n\n  /**\n   * Set the fill style.\n   * @param {import(\"./Fill.js\").default|null} fill Fill style.\n   * @api\n   */\n  setFill(fill) {\n    this.fill_ = fill;\n  }\n\n  /**\n   * Get the image style.\n   * @return {import(\"./Image.js\").default|null} Image style.\n   * @api\n   */\n  getImage() {\n    return this.image_;\n  }\n\n  /**\n   * Set the image style.\n   * @param {import(\"./Image.js\").default} image Image style.\n   * @api\n   */\n  setImage(image) {\n    this.image_ = image;\n  }\n\n  /**\n   * Get the stroke style.\n   * @return {import(\"./Stroke.js\").default|null} Stroke style.\n   * @api\n   */\n  getStroke() {\n    return this.stroke_;\n  }\n\n  /**\n   * Set the stroke style.\n   * @param {import(\"./Stroke.js\").default|null} stroke Stroke style.\n   * @api\n   */\n  setStroke(stroke) {\n    this.stroke_ = stroke;\n  }\n\n  /**\n   * Get the text style.\n   * @return {import(\"./Text.js\").default|null} Text style.\n   * @api\n   */\n  getText() {\n    return this.text_;\n  }\n\n  /**\n   * Set the text style.\n   * @param {import(\"./Text.js\").default} text Text style.\n   * @api\n   */\n  setText(text) {\n    this.text_ = text;\n  }\n\n  /**\n   * Get the z-index for the style.\n   * @return {number|undefined} ZIndex.\n   * @api\n   */\n  getZIndex() {\n    return this.zIndex_;\n  }\n\n  /**\n   * Set a geometry that is rendered instead of the feature's geometry.\n   *\n   * @param {string|import(\"../geom/Geometry.js\").default|GeometryFunction|null} geometry\n   *     Feature property or geometry or function returning a geometry to render\n   *     for this style.\n   * @api\n   */\n  setGeometry(geometry) {\n    if (typeof geometry === 'function') {\n      this.geometryFunction_ = geometry;\n    } else if (typeof geometry === 'string') {\n      this.geometryFunction_ = function (feature) {\n        return /** @type {import(\"../geom/Geometry.js\").default} */ (\n          feature.get(geometry)\n        );\n      };\n    } else if (!geometry) {\n      this.geometryFunction_ = defaultGeometryFunction;\n    } else if (geometry !== undefined) {\n      this.geometryFunction_ = function () {\n        return /** @type {import(\"../geom/Geometry.js\").default} */ (geometry);\n      };\n    }\n    this.geometry_ = geometry;\n  }\n\n  /**\n   * Set the z-index.\n   *\n   * @param {number|undefined} zIndex ZIndex.\n   * @api\n   */\n  setZIndex(zIndex) {\n    this.zIndex_ = zIndex;\n  }\n}\n\n/**\n * Convert the provided object into a style function.  Functions passed through\n * unchanged.  Arrays of Style or single style objects wrapped in a\n * new style function.\n * @param {StyleFunction|Array<Style>|Style} obj\n *     A style function, a single style, or an array of styles.\n * @return {StyleFunction} A style function.\n */\nexport function toFunction(obj) {\n  let styleFunction;\n\n  if (typeof obj === 'function') {\n    styleFunction = obj;\n  } else {\n    /**\n     * @type {Array<Style>}\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 `Style` or an array of `Style`',\n      );\n      const style = /** @type {Style} */ (obj);\n      styles = [style];\n    }\n    styleFunction = function () {\n      return styles;\n    };\n  }\n  return styleFunction;\n}\n\n/**\n * @type {Array<Style>|null}\n */\nlet defaultStyles = null;\n\n/**\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {number} resolution Resolution.\n * @return {Array<Style>} Style.\n */\nexport function createDefaultStyle(feature, resolution) {\n  // We don't use an immediately-invoked function\n  // and a closure so we don't get an error at script evaluation time in\n  // browsers that do not support Canvas. (import(\"./Circle.js\").CircleStyle does\n  // canvas.getContext('2d') at construction time, which will cause an.error\n  // in such browsers.)\n  if (!defaultStyles) {\n    const fill = new Fill({\n      color: 'rgba(255,255,255,0.4)',\n    });\n    const stroke = new Stroke({\n      color: '#3399CC',\n      width: 1.25,\n    });\n    defaultStyles = [\n      new Style({\n        image: new CircleStyle({\n          fill: fill,\n          stroke: stroke,\n          radius: 5,\n        }),\n        fill: fill,\n        stroke: stroke,\n      }),\n    ];\n  }\n  return defaultStyles;\n}\n\n/**\n * Default styles for editing features.\n * @return {Object<import(\"../geom/Geometry.js\").Type, Array<Style>>} Styles\n */\nexport function createEditingStyle() {\n  /** @type {Object<import(\"../geom/Geometry.js\").Type, Array<Style>>} */\n  const styles = {};\n  const white = [255, 255, 255, 1];\n  const blue = [0, 153, 255, 1];\n  const width = 3;\n  styles['Polygon'] = [\n    new Style({\n      fill: new Fill({\n        color: [255, 255, 255, 0.5],\n      }),\n    }),\n  ];\n  styles['MultiPolygon'] = styles['Polygon'];\n\n  styles['LineString'] = [\n    new Style({\n      stroke: new Stroke({\n        color: white,\n        width: width + 2,\n      }),\n    }),\n    new Style({\n      stroke: new Stroke({\n        color: blue,\n        width: width,\n      }),\n    }),\n  ];\n  styles['MultiLineString'] = styles['LineString'];\n\n  styles['Circle'] = styles['Polygon'].concat(styles['LineString']);\n\n  styles['Point'] = [\n    new Style({\n      image: new CircleStyle({\n        radius: width * 2,\n        fill: new Fill({\n          color: blue,\n        }),\n        stroke: new Stroke({\n          color: white,\n          width: width / 2,\n        }),\n      }),\n      zIndex: Infinity,\n    }),\n  ];\n  styles['MultiPoint'] = styles['Point'];\n\n  styles['GeometryCollection'] = styles['Polygon'].concat(\n    styles['LineString'],\n    styles['Point'],\n  );\n\n  return styles;\n}\n\n/**\n * Function that is called with a feature and returns its default geometry.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature to get the geometry for.\n * @return {import(\"../geom/Geometry.js\").default|import(\"../render/Feature.js\").default|undefined} Geometry to render.\n */\nfunction defaultGeometryFunction(feature) {\n  return feature.getGeometry();\n}\n\nexport default Style;\n","/**\n * @module ol/style/Text\n */\nimport {toSize} from '../size.js';\nimport Fill from './Fill.js';\n\n/**\n * @typedef {'point' | 'line'} TextPlacement\n * Default text placement is `'point'`. Note that\n * `'line'` requires the underlying geometry to be a {@link module:ol/geom/LineString~LineString},\n * {@link module:ol/geom/Polygon~Polygon}, {@link module:ol/geom/MultiLineString~MultiLineString} or\n * {@link module:ol/geom/MultiPolygon~MultiPolygon}.\n */\n\n/**\n * @typedef {'left' | 'center' | 'right'} TextJustify\n */\n\n/**\n * The default fill color to use if no fill was set at construction time; a\n * blackish `#333`.\n *\n * @const {string}\n */\nconst DEFAULT_FILL_COLOR = '#333';\n\n/**\n * @typedef {Object} Options\n * @property {string} [font] Font style as CSS `font` value, see:\n * https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/font. Default is `'10px sans-serif'`\n * @property {number} [maxAngle=Math.PI/4] When `placement` is set to `'line'`, allow a maximum angle between adjacent characters.\n * The expected value is in radians, and the default is 45° (`Math.PI / 4`).\n * @property {number} [offsetX=0] Horizontal text offset in pixels. A positive will shift the text right.\n * @property {number} [offsetY=0] Vertical text offset in pixels. A positive will shift the text down.\n * @property {boolean} [overflow=false] For polygon labels or when `placement` is set to `'line'`, allow text to exceed\n * the width of the polygon at the label position or the length of the path that it follows.\n * @property {TextPlacement} [placement='point'] Text placement.\n * @property {number} [repeat] Repeat interval. When set, the text will be repeated at this interval, which specifies\n * the distance between two text anchors in pixels. Only available when `placement` is set to `'line'`. Overrides 'textAlign'.\n * @property {number|import(\"../size.js\").Size} [scale] Scale.\n * @property {boolean} [rotateWithView=false] Whether to rotate the text with the view.\n * @property {boolean} [keepUpright=true] Whether the text can be rotated 180° to prevent being rendered upside down.\n * @property {number} [rotation=0] Rotation in radians (positive rotation clockwise).\n * @property {string|Array<string>} [text] Text content or rich text content. For plain text provide a string, which can\n * contain line breaks (`\\n`). For rich text provide an array of text/font tuples. A tuple consists of the text to\n * render and the font to use (or `''` to use the text style's font). A line break has to be a separate tuple (i.e. `'\\n', ''`).\n * **Example:** `['foo', 'bold 10px sans-serif', ' bar', 'italic 10px sans-serif', ' baz', '']` will yield \"**foo** *bar* baz\".\n * **Note:** Rich text is not supported for `placement: 'line'` or the immediate rendering API.\n * @property {CanvasTextAlign} [textAlign] Text alignment. Possible values: `'left'`, `'right'`, `'center'`, `'end'` or `'start'`.\n * Default is `'center'` for `placement: 'point'`. For `placement: 'line'`, the default is to let the renderer choose a\n * placement where `maxAngle` is not exceeded.\n * @property {TextJustify} [justify] Text justification within the text box.\n * If not set, text is justified towards the `textAlign` anchor.\n * Otherwise, use options `'left'`, `'center'`, or `'right'` to justify the text within the text box.\n * **Note:** `justify` is ignored for immediate rendering and also for `placement: 'line'`.\n * @property {CanvasTextBaseline} [textBaseline='middle'] Text base line. Possible values: `'bottom'`, `'top'`, `'middle'`, `'alphabetic'`,\n * `'hanging'`, `'ideographic'`.\n * @property {import(\"./Fill.js\").default|null} [fill] Fill style. If none is provided, we'll use a dark fill-style (#333). Specify `null` for no fill.\n * @property {import(\"./Stroke.js\").default} [stroke] Stroke style.\n * @property {import(\"./Fill.js\").default} [backgroundFill] Fill style for the text background when `placement` is\n * `'point'`. Default is no fill.\n * @property {import(\"./Stroke.js\").default} [backgroundStroke] Stroke style for the text background  when `placement`\n * is `'point'`. Default is no stroke.\n * @property {Array<number>} [padding=[0, 0, 0, 0]] Padding in pixels around the text for decluttering and background. The order of\n * values in the array is `[top, right, bottom, left]`.\n * @property {import('../style/Style.js').DeclutterMode} [declutterMode] Declutter mode: `declutter`, `obstacle`, `none`\n */\n\n/**\n * @classdesc\n * Set text style for vector features.\n * @api\n */\nclass Text {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options || {};\n\n    /**\n     * @private\n     * @type {string|undefined}\n     */\n    this.font_ = options.font;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.rotation_ = options.rotation;\n\n    /**\n     * @private\n     * @type {boolean|undefined}\n     */\n    this.rotateWithView_ = options.rotateWithView;\n\n    /**\n     * @private\n     * @type {boolean|undefined}\n     */\n    this.keepUpright_ = options.keepUpright;\n\n    /**\n     * @private\n     * @type {number|import(\"../size.js\").Size|undefined}\n     */\n    this.scale_ = options.scale;\n\n    /**\n     * @private\n     * @type {import(\"../size.js\").Size}\n     */\n    this.scaleArray_ = toSize(options.scale !== undefined ? options.scale : 1);\n\n    /**\n     * @private\n     * @type {string|Array<string>|undefined}\n     */\n    this.text_ = options.text;\n\n    /**\n     * @private\n     * @type {CanvasTextAlign|undefined}\n     */\n    this.textAlign_ = options.textAlign;\n\n    /**\n     * @private\n     * @type {TextJustify|undefined}\n     */\n    this.justify_ = options.justify;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.repeat_ = options.repeat;\n\n    /**\n     * @private\n     * @type {CanvasTextBaseline|undefined}\n     */\n    this.textBaseline_ = options.textBaseline;\n\n    /**\n     * @private\n     * @type {import(\"./Fill.js\").default|null}\n     */\n    this.fill_ =\n      options.fill !== undefined\n        ? options.fill\n        : new Fill({color: DEFAULT_FILL_COLOR});\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.maxAngle_ =\n      options.maxAngle !== undefined ? options.maxAngle : Math.PI / 4;\n\n    /**\n     * @private\n     * @type {TextPlacement}\n     */\n    this.placement_ =\n      options.placement !== undefined ? options.placement : 'point';\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.overflow_ = !!options.overflow;\n\n    /**\n     * @private\n     * @type {import(\"./Stroke.js\").default|null}\n     */\n    this.stroke_ = options.stroke !== undefined ? options.stroke : null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.offsetX_ = options.offsetX !== undefined ? options.offsetX : 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.offsetY_ = options.offsetY !== undefined ? options.offsetY : 0;\n\n    /**\n     * @private\n     * @type {import(\"./Fill.js\").default|null}\n     */\n    this.backgroundFill_ = options.backgroundFill\n      ? options.backgroundFill\n      : null;\n\n    /**\n     * @private\n     * @type {import(\"./Stroke.js\").default|null}\n     */\n    this.backgroundStroke_ = options.backgroundStroke\n      ? options.backgroundStroke\n      : null;\n\n    /**\n     * @private\n     * @type {Array<number>|null}\n     */\n    this.padding_ = options.padding === undefined ? null : options.padding;\n\n    /**\n     * @private\n     * @type {import('../style/Style.js').DeclutterMode}\n     */\n    this.declutterMode_ = options.declutterMode;\n  }\n\n  /**\n   * Clones the style.\n   * @return {Text} The cloned style.\n   * @api\n   */\n  clone() {\n    const scale = this.getScale();\n    return new Text({\n      font: this.getFont(),\n      placement: this.getPlacement(),\n      repeat: this.getRepeat(),\n      maxAngle: this.getMaxAngle(),\n      overflow: this.getOverflow(),\n      rotation: this.getRotation(),\n      rotateWithView: this.getRotateWithView(),\n      keepUpright: this.getKeepUpright(),\n      scale: Array.isArray(scale) ? scale.slice() : scale,\n      text: this.getText(),\n      textAlign: this.getTextAlign(),\n      justify: this.getJustify(),\n      textBaseline: this.getTextBaseline(),\n      fill:\n        this.getFill() instanceof Fill\n          ? this.getFill().clone()\n          : this.getFill(),\n      stroke: this.getStroke() ? this.getStroke().clone() : undefined,\n      offsetX: this.getOffsetX(),\n      offsetY: this.getOffsetY(),\n      backgroundFill: this.getBackgroundFill()\n        ? this.getBackgroundFill().clone()\n        : undefined,\n      backgroundStroke: this.getBackgroundStroke()\n        ? this.getBackgroundStroke().clone()\n        : undefined,\n      padding: this.getPadding() || undefined,\n      declutterMode: this.getDeclutterMode(),\n    });\n  }\n\n  /**\n   * Get the `overflow` configuration.\n   * @return {boolean} Let text overflow the length of the path they follow.\n   * @api\n   */\n  getOverflow() {\n    return this.overflow_;\n  }\n\n  /**\n   * Get the font name.\n   * @return {string|undefined} Font.\n   * @api\n   */\n  getFont() {\n    return this.font_;\n  }\n\n  /**\n   * Get the maximum angle between adjacent characters.\n   * @return {number} Angle in radians.\n   * @api\n   */\n  getMaxAngle() {\n    return this.maxAngle_;\n  }\n\n  /**\n   * Get the label placement.\n   * @return {TextPlacement} Text placement.\n   * @api\n   */\n  getPlacement() {\n    return this.placement_;\n  }\n\n  /**\n   * Get the repeat interval of the text.\n   * @return {number|undefined} Repeat interval in pixels.\n   * @api\n   */\n  getRepeat() {\n    return this.repeat_;\n  }\n\n  /**\n   * Get the x-offset for the text.\n   * @return {number} Horizontal text offset.\n   * @api\n   */\n  getOffsetX() {\n    return this.offsetX_;\n  }\n\n  /**\n   * Get the y-offset for the text.\n   * @return {number} Vertical text offset.\n   * @api\n   */\n  getOffsetY() {\n    return this.offsetY_;\n  }\n\n  /**\n   * Get the fill style for the text.\n   * @return {import(\"./Fill.js\").default|null} Fill style.\n   * @api\n   */\n  getFill() {\n    return this.fill_;\n  }\n\n  /**\n   * Determine whether the text rotates with the map.\n   * @return {boolean|undefined} Rotate with map.\n   * @api\n   */\n  getRotateWithView() {\n    return this.rotateWithView_;\n  }\n\n  /**\n   * Determine whether the text can be rendered upside down.\n   * @return {boolean|undefined} Keep text upright.\n   * @api\n   */\n  getKeepUpright() {\n    return this.keepUpright_;\n  }\n\n  /**\n   * Get the text rotation.\n   * @return {number|undefined} Rotation.\n   * @api\n   */\n  getRotation() {\n    return this.rotation_;\n  }\n\n  /**\n   * Get the text scale.\n   * @return {number|import(\"../size.js\").Size|undefined} Scale.\n   * @api\n   */\n  getScale() {\n    return this.scale_;\n  }\n\n  /**\n   * Get the symbolizer scale array.\n   * @return {import(\"../size.js\").Size} Scale array.\n   */\n  getScaleArray() {\n    return this.scaleArray_;\n  }\n\n  /**\n   * Get the stroke style for the text.\n   * @return {import(\"./Stroke.js\").default|null} Stroke style.\n   * @api\n   */\n  getStroke() {\n    return this.stroke_;\n  }\n\n  /**\n   * Get the text to be rendered.\n   * @return {string|Array<string>|undefined} Text.\n   * @api\n   */\n  getText() {\n    return this.text_;\n  }\n\n  /**\n   * Get the text alignment.\n   * @return {CanvasTextAlign|undefined} Text align.\n   * @api\n   */\n  getTextAlign() {\n    return this.textAlign_;\n  }\n\n  /**\n   * Get the justification.\n   * @return {TextJustify|undefined} Justification.\n   * @api\n   */\n  getJustify() {\n    return this.justify_;\n  }\n\n  /**\n   * Get the text baseline.\n   * @return {CanvasTextBaseline|undefined} Text baseline.\n   * @api\n   */\n  getTextBaseline() {\n    return this.textBaseline_;\n  }\n\n  /**\n   * Get the background fill style for the text.\n   * @return {import(\"./Fill.js\").default|null} Fill style.\n   * @api\n   */\n  getBackgroundFill() {\n    return this.backgroundFill_;\n  }\n\n  /**\n   * Get the background stroke style for the text.\n   * @return {import(\"./Stroke.js\").default|null} Stroke style.\n   * @api\n   */\n  getBackgroundStroke() {\n    return this.backgroundStroke_;\n  }\n\n  /**\n   * Get the padding for the text.\n   * @return {Array<number>|null} Padding.\n   * @api\n   */\n  getPadding() {\n    return this.padding_;\n  }\n\n  /**\n   * Get the declutter mode of the shape\n   * @return {import(\"./Style.js\").DeclutterMode} Shape's declutter mode\n   * @api\n   */\n  getDeclutterMode() {\n    return this.declutterMode_;\n  }\n\n  /**\n   * Set the `overflow` property.\n   *\n   * @param {boolean} overflow Let text overflow the path that it follows.\n   * @api\n   */\n  setOverflow(overflow) {\n    this.overflow_ = overflow;\n  }\n\n  /**\n   * Set the font.\n   *\n   * @param {string|undefined} font Font.\n   * @api\n   */\n  setFont(font) {\n    this.font_ = font;\n  }\n\n  /**\n   * Set the maximum angle between adjacent characters.\n   *\n   * @param {number} maxAngle Angle in radians.\n   * @api\n   */\n  setMaxAngle(maxAngle) {\n    this.maxAngle_ = maxAngle;\n  }\n\n  /**\n   * Set the x offset.\n   *\n   * @param {number} offsetX Horizontal text offset.\n   * @api\n   */\n  setOffsetX(offsetX) {\n    this.offsetX_ = offsetX;\n  }\n\n  /**\n   * Set the y offset.\n   *\n   * @param {number} offsetY Vertical text offset.\n   * @api\n   */\n  setOffsetY(offsetY) {\n    this.offsetY_ = offsetY;\n  }\n\n  /**\n   * Set the text placement.\n   *\n   * @param {TextPlacement} placement Placement.\n   * @api\n   */\n  setPlacement(placement) {\n    this.placement_ = placement;\n  }\n\n  /**\n   * Set the repeat interval of the text.\n   * @param {number|undefined} [repeat] Repeat interval in pixels.\n   * @api\n   */\n  setRepeat(repeat) {\n    this.repeat_ = repeat;\n  }\n\n  /**\n   * Set whether to rotate the text with the view.\n   *\n   * @param {boolean} rotateWithView Rotate with map.\n   * @api\n   */\n  setRotateWithView(rotateWithView) {\n    this.rotateWithView_ = rotateWithView;\n  }\n\n  /**\n   * Set whether the text can be rendered upside down.\n   *\n   * @param {boolean} keepUpright Keep text upright.\n   * @api\n   */\n  setKeepUpright(keepUpright) {\n    this.keepUpright_ = keepUpright;\n  }\n\n  /**\n   * Set the fill.\n   *\n   * @param {import(\"./Fill.js\").default|null} fill Fill style.\n   * @api\n   */\n  setFill(fill) {\n    this.fill_ = fill;\n  }\n\n  /**\n   * Set the rotation.\n   *\n   * @param {number|undefined} rotation Rotation.\n   * @api\n   */\n  setRotation(rotation) {\n    this.rotation_ = rotation;\n  }\n\n  /**\n   * Set the scale.\n   *\n   * @param {number|import(\"../size.js\").Size|undefined} scale Scale.\n   * @api\n   */\n  setScale(scale) {\n    this.scale_ = scale;\n    this.scaleArray_ = toSize(scale !== undefined ? scale : 1);\n  }\n\n  /**\n   * Set the stroke.\n   *\n   * @param {import(\"./Stroke.js\").default|null} stroke Stroke style.\n   * @api\n   */\n  setStroke(stroke) {\n    this.stroke_ = stroke;\n  }\n\n  /**\n   * Set the text.\n   *\n   * @param {string|Array<string>|undefined} text Text.\n   * @api\n   */\n  setText(text) {\n    this.text_ = text;\n  }\n\n  /**\n   * Set the text alignment.\n   *\n   * @param {CanvasTextAlign|undefined} textAlign Text align.\n   * @api\n   */\n  setTextAlign(textAlign) {\n    this.textAlign_ = textAlign;\n  }\n\n  /**\n   * Set the justification.\n   *\n   * @param {TextJustify|undefined} justify Justification.\n   * @api\n   */\n  setJustify(justify) {\n    this.justify_ = justify;\n  }\n\n  /**\n   * Set the text baseline.\n   *\n   * @param {CanvasTextBaseline|undefined} textBaseline Text baseline.\n   * @api\n   */\n  setTextBaseline(textBaseline) {\n    this.textBaseline_ = textBaseline;\n  }\n\n  /**\n   * Set the background fill.\n   *\n   * @param {import(\"./Fill.js\").default|null} fill Fill style.\n   * @api\n   */\n  setBackgroundFill(fill) {\n    this.backgroundFill_ = fill;\n  }\n\n  /**\n   * Set the background stroke.\n   *\n   * @param {import(\"./Stroke.js\").default|null} stroke Stroke style.\n   * @api\n   */\n  setBackgroundStroke(stroke) {\n    this.backgroundStroke_ = stroke;\n  }\n\n  /**\n   * Set the padding (`[top, right, bottom, left]`).\n   *\n   * @param {Array<number>|null} padding Padding.\n   * @api\n   */\n  setPadding(padding) {\n    this.padding_ = padding;\n  }\n}\n\nexport default Text;\n","/**\n * @module ol/render/canvas/style\n */\n\nimport {NO_COLOR} from '../../color.js';\nimport {buildExpression, newEvaluationContext} from '../../expr/cpu.js';\nimport {\n  BooleanType,\n  ColorType,\n  NumberArrayType,\n  NumberType,\n  StringType,\n  computeGeometryType,\n  newParsingContext,\n} from '../../expr/expression.js';\nimport {isEmpty} from '../../obj.js';\nimport {toSize} from '../../size.js';\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';\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<import('../../style/flat.js').Rule>} 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<import('../../style/flat.js').FlatStyle>} 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<StyleEvaluator>}\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<Style>}\n   */\n  const styles = new Array(length);\n\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    let nonNullCount = 0;\n    for (let i = 0; i < length; ++i) {\n      const style = evaluators[i](evaluationContext);\n      if (style) {\n        styles[nonNullCount] = style;\n        nonNullCount += 1;\n      }\n    }\n    styles.length = nonNullCount;\n    return styles;\n  };\n}\n\n/**\n * @typedef {function(EvaluationContext):Array<Style>} RuleSetEvaluator\n */\n\n/**\n * @typedef {Object} CompiledRule\n * @property {ExpressionEvaluator} filter The compiled filter evaluator.\n * @property {Array<StyleEvaluator>} styles The list of compiled style evaluators.\n */\n\n/**\n * @param {Array<import('../../style/flat.js').Rule>} rules The rules.\n * @param {ParsingContext} context The parsing context.\n * @return {RuleSetEvaluator} The evaluator function.\n */\nexport function buildRuleSet(rules, context) {\n  const length = rules.length;\n\n  /**\n   * @type {Array<CompiledRule>}\n   */\n  const compiledRules = new Array(length);\n\n  for (let i = 0; i < length; ++i) {\n    const rule = rules[i];\n    const filter =\n      'filter' in rule\n        ? buildExpression(rule.filter, BooleanType, context)\n        : always;\n\n    /**\n     * @type {Array<StyleEvaluator>}\n     */\n    let styles;\n    if (Array.isArray(rule.style)) {\n      const styleLength = rule.style.length;\n      styles = new Array(styleLength);\n      for (let j = 0; j < styleLength; ++j) {\n        styles[j] = buildStyle(rule.style[j], context);\n      }\n    } else {\n      styles = [buildStyle(rule.style, context)];\n    }\n\n    compiledRules[i] = {filter, styles};\n  }\n\n  return function (context) {\n    /**\n     * @type {Array<Style>}\n     */\n    const styles = [];\n\n    let someMatched = false;\n    for (let i = 0; i < length; ++i) {\n      const filterEvaluator = compiledRules[i].filter;\n      if (!filterEvaluator(context)) {\n        continue;\n      }\n      if (rules[i].else && someMatched) {\n        continue;\n      }\n      someMatched = true;\n      for (const styleEvaluator of compiledRules[i].styles) {\n        const style = styleEvaluator(context);\n        if (!style) {\n          continue;\n        }\n        styles.push(style);\n      }\n    }\n\n    return styles;\n  };\n}\n\n/**\n * @typedef {function(EvaluationContext):Style|null} StyleEvaluator\n */\n\n/**\n * @param {FlatStyle} flatStyle A flat style literal.\n * @param {ParsingContext} context The parsing context.\n * @return {StyleEvaluator} A function that evaluates to a style.  The style returned by\n * this function will be reused between invocations.\n */\nexport function buildStyle(flatStyle, context) {\n  const evaluateFill = buildFill(flatStyle, '', context);\n  const evaluateStroke = buildStroke(flatStyle, '', context);\n  const evaluateText = buildText(flatStyle, context);\n  const evaluateImage = buildImage(flatStyle, context);\n  const evaluateZIndex = numberEvaluator(flatStyle, 'z-index', context);\n\n  if (\n    !evaluateFill &&\n    !evaluateStroke &&\n    !evaluateText &&\n    !evaluateImage &&\n    !isEmpty(flatStyle)\n  ) {\n    // assume this is a user error\n    // would be nice to check the properties and suggest \"did you mean...\"\n    throw new Error(\n      'No fill, stroke, point, or text symbolizer properties in style: ' +\n        JSON.stringify(flatStyle),\n    );\n  }\n\n  const style = new Style();\n  return function (context) {\n    let empty = true;\n    if (evaluateFill) {\n      const fill = evaluateFill(context);\n      if (fill) {\n        empty = false;\n      }\n      style.setFill(fill);\n    }\n    if (evaluateStroke) {\n      const stroke = evaluateStroke(context);\n      if (stroke) {\n        empty = false;\n      }\n      style.setStroke(stroke);\n    }\n    if (evaluateText) {\n      const text = evaluateText(context);\n      if (text) {\n        empty = false;\n      }\n      style.setText(text);\n    }\n    if (evaluateImage) {\n      const image = evaluateImage(context);\n      if (image) {\n        empty = false;\n      }\n      style.setImage(image);\n    }\n    if (evaluateZIndex) {\n      style.setZIndex(evaluateZIndex(context));\n    }\n    if (empty) {\n      return null;\n    }\n    return style;\n  };\n}\n\n/**\n * @typedef {function(EvaluationContext):Fill|null} FillEvaluator\n */\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} prefix The property prefix.\n * @param {ParsingContext} context The parsing context.\n * @return {FillEvaluator?} A function that evaluates to a fill.\n */\nfunction buildFill(flatStyle, prefix, context) {\n  let evaluateColor;\n  if (prefix + 'fill-pattern-src' in flatStyle) {\n    evaluateColor = patternEvaluator(flatStyle, prefix + 'fill-', context);\n  } else {\n    if (flatStyle[prefix + 'fill-color'] === 'none') {\n      // avoids hit detection\n      return (context) => null;\n    }\n\n    evaluateColor = colorLikeEvaluator(\n      flatStyle,\n      prefix + 'fill-color',\n      context,\n    );\n  }\n  if (!evaluateColor) {\n    return null;\n  }\n\n  const fill = new Fill();\n  return function (context) {\n    const color = evaluateColor(context);\n    if (color === NO_COLOR) {\n      return null;\n    }\n    fill.setColor(color);\n    return fill;\n  };\n}\n\n/**\n * @typedef {function(EvaluationContext):Stroke|null} StrokeEvaluator\n */\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} prefix The property prefix.\n * @param {ParsingContext} context The parsing context.\n * @return {StrokeEvaluator?} A function the evaluates to a stroke.\n */\nfunction buildStroke(flatStyle, prefix, context) {\n  const evaluateWidth = numberEvaluator(\n    flatStyle,\n    prefix + 'stroke-width',\n    context,\n  );\n\n  const evaluateColor = colorLikeEvaluator(\n    flatStyle,\n    prefix + 'stroke-color',\n    context,\n  );\n\n  if (!evaluateWidth && !evaluateColor) {\n    return null;\n  }\n\n  const evaluateLineCap = stringEvaluator(\n    flatStyle,\n    prefix + 'stroke-line-cap',\n    context,\n  );\n\n  const evaluateLineJoin = stringEvaluator(\n    flatStyle,\n    prefix + 'stroke-line-join',\n    context,\n  );\n\n  const evaluateLineDash = numberArrayEvaluator(\n    flatStyle,\n    prefix + 'stroke-line-dash',\n    context,\n  );\n\n  const evaluateLineDashOffset = numberEvaluator(\n    flatStyle,\n    prefix + 'stroke-line-dash-offset',\n    context,\n  );\n\n  const evaluateMiterLimit = numberEvaluator(\n    flatStyle,\n    prefix + 'stroke-miter-limit',\n    context,\n  );\n\n  const evaluateOffset = numberEvaluator(\n    flatStyle,\n    prefix + 'stroke-offset',\n    context,\n  );\n\n  const stroke = new Stroke();\n  return function (context) {\n    if (evaluateColor) {\n      const color = evaluateColor(context);\n      if (color === NO_COLOR) {\n        return null;\n      }\n      stroke.setColor(color);\n    }\n\n    if (evaluateWidth) {\n      stroke.setWidth(evaluateWidth(context));\n    }\n\n    if (evaluateLineCap) {\n      const lineCap = evaluateLineCap(context);\n      if (lineCap !== 'butt' && lineCap !== 'round' && lineCap !== 'square') {\n        throw new Error('Expected butt, round, or square line cap');\n      }\n      stroke.setLineCap(lineCap);\n    }\n\n    if (evaluateLineJoin) {\n      const lineJoin = evaluateLineJoin(context);\n      if (\n        lineJoin !== 'bevel' &&\n        lineJoin !== 'round' &&\n        lineJoin !== 'miter'\n      ) {\n        throw new Error('Expected bevel, round, or miter line join');\n      }\n      stroke.setLineJoin(lineJoin);\n    }\n\n    if (evaluateLineDash) {\n      stroke.setLineDash(evaluateLineDash(context));\n    }\n\n    if (evaluateLineDashOffset) {\n      stroke.setLineDashOffset(evaluateLineDashOffset(context));\n    }\n\n    if (evaluateMiterLimit) {\n      stroke.setMiterLimit(evaluateMiterLimit(context));\n    }\n\n    if (evaluateOffset) {\n      stroke.setOffset(evaluateOffset(context));\n    }\n\n    return stroke;\n  };\n}\n\n/**\n * @typedef {function(EvaluationContext):Text} TextEvaluator\n */\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {ParsingContext} context The parsing context.\n * @return {TextEvaluator?} A function that evaluates to a text symbolizer.\n */\nfunction buildText(flatStyle, context) {\n  const prefix = 'text-';\n\n  // Currently, an Array<string> may be used for rich text support.  This doesn't\n  // work with our expression syntax where arrays of strings are interpreted as\n  // call expressions.  To support rich text, we could add a 'strings' operator\n  // where all the following arguments would be string values.\n  const evaluateValue = stringEvaluator(flatStyle, prefix + 'value', context);\n  if (!evaluateValue) {\n    return null;\n  }\n\n  const evaluateFill = buildFill(flatStyle, prefix, context);\n\n  const evaluateBackgroundFill = buildFill(\n    flatStyle,\n    prefix + 'background-',\n    context,\n  );\n\n  const evaluateStroke = buildStroke(flatStyle, prefix, context);\n\n  const evaluateBackgroundStroke = buildStroke(\n    flatStyle,\n    prefix + 'background-',\n    context,\n  );\n\n  const evaluateFont = stringEvaluator(flatStyle, prefix + 'font', context);\n\n  const evaluateMaxAngle = numberEvaluator(\n    flatStyle,\n    prefix + 'max-angle',\n    context,\n  );\n\n  const evaluateOffsetX = numberEvaluator(\n    flatStyle,\n    prefix + 'offset-x',\n    context,\n  );\n\n  const evaluateOffsetY = numberEvaluator(\n    flatStyle,\n    prefix + 'offset-y',\n    context,\n  );\n\n  const evaluateOverflow = booleanEvaluator(\n    flatStyle,\n    prefix + 'overflow',\n    context,\n  );\n\n  const evaluatePlacement = stringEvaluator(\n    flatStyle,\n    prefix + 'placement',\n    context,\n  );\n\n  const evaluateRepeat = numberEvaluator(flatStyle, prefix + 'repeat', context);\n\n  const evaluateScale = sizeLikeEvaluator(flatStyle, prefix + 'scale', context);\n\n  const evaluateRotateWithView = booleanEvaluator(\n    flatStyle,\n    prefix + 'rotate-with-view',\n    context,\n  );\n\n  const evaluateRotation = numberEvaluator(\n    flatStyle,\n    prefix + 'rotation',\n    context,\n  );\n\n  const evaluateAlign = stringEvaluator(flatStyle, prefix + 'align', context);\n\n  const evaluateJustify = stringEvaluator(\n    flatStyle,\n    prefix + 'justify',\n    context,\n  );\n\n  const evaluateBaseline = stringEvaluator(\n    flatStyle,\n    prefix + 'baseline',\n    context,\n  );\n\n  const evaluateKeepUpright = booleanEvaluator(\n    flatStyle,\n    prefix + 'keep-upright',\n    context,\n  );\n\n  const evaluatePadding = numberArrayEvaluator(\n    flatStyle,\n    prefix + 'padding',\n    context,\n  );\n\n  // The following properties are not currently settable\n  const declutterMode = optionalDeclutterMode(\n    flatStyle,\n    prefix + 'declutter-mode',\n  );\n\n  const text = new Text({declutterMode});\n\n  return function (context) {\n    text.setText(evaluateValue(context));\n\n    if (evaluateFill) {\n      text.setFill(evaluateFill(context));\n    }\n\n    if (evaluateBackgroundFill) {\n      text.setBackgroundFill(evaluateBackgroundFill(context));\n    }\n\n    if (evaluateStroke) {\n      text.setStroke(evaluateStroke(context));\n    }\n\n    if (evaluateBackgroundStroke) {\n      text.setBackgroundStroke(evaluateBackgroundStroke(context));\n    }\n\n    if (evaluateFont) {\n      text.setFont(evaluateFont(context));\n    }\n\n    if (evaluateMaxAngle) {\n      text.setMaxAngle(evaluateMaxAngle(context));\n    }\n\n    if (evaluateOffsetX) {\n      text.setOffsetX(evaluateOffsetX(context));\n    }\n\n    if (evaluateOffsetY) {\n      text.setOffsetY(evaluateOffsetY(context));\n    }\n\n    if (evaluateOverflow) {\n      text.setOverflow(evaluateOverflow(context));\n    }\n\n    if (evaluatePlacement) {\n      const placement = evaluatePlacement(context);\n      if (placement !== 'point' && placement !== 'line') {\n        throw new Error('Expected point or line for text-placement');\n      }\n      text.setPlacement(placement);\n    }\n\n    if (evaluateRepeat) {\n      text.setRepeat(evaluateRepeat(context));\n    }\n\n    if (evaluateScale) {\n      text.setScale(evaluateScale(context));\n    }\n\n    if (evaluateRotateWithView) {\n      text.setRotateWithView(evaluateRotateWithView(context));\n    }\n\n    if (evaluateRotation) {\n      text.setRotation(evaluateRotation(context));\n    }\n\n    if (evaluateAlign) {\n      const textAlign = evaluateAlign(context);\n      if (\n        textAlign !== 'left' &&\n        textAlign !== 'center' &&\n        textAlign !== 'right' &&\n        textAlign !== 'end' &&\n        textAlign !== 'start'\n      ) {\n        throw new Error(\n          'Expected left, right, center, start, or end for text-align',\n        );\n      }\n      text.setTextAlign(textAlign);\n    }\n\n    if (evaluateJustify) {\n      const justify = evaluateJustify(context);\n      if (justify !== 'left' && justify !== 'right' && justify !== 'center') {\n        throw new Error('Expected left, right, or center for text-justify');\n      }\n      text.setJustify(justify);\n    }\n\n    if (evaluateBaseline) {\n      const textBaseline = evaluateBaseline(context);\n      if (\n        textBaseline !== 'bottom' &&\n        textBaseline !== 'top' &&\n        textBaseline !== 'middle' &&\n        textBaseline !== 'alphabetic' &&\n        textBaseline !== 'hanging'\n      ) {\n        throw new Error(\n          'Expected bottom, top, middle, alphabetic, or hanging for text-baseline',\n        );\n      }\n      text.setTextBaseline(textBaseline);\n    }\n\n    if (evaluatePadding) {\n      text.setPadding(evaluatePadding(context));\n    }\n\n    if (evaluateKeepUpright) {\n      text.setKeepUpright(evaluateKeepUpright(context));\n    }\n\n    return text;\n  };\n}\n\n/**\n * @typedef {function(EvaluationContext):import(\"../../style/Image.js\").default} ImageEvaluator\n */\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {ParsingContext} context The parsing context.\n * @return {ImageEvaluator?} A function that evaluates to an image symbolizer.\n */\nfunction buildImage(flatStyle, context) {\n  if ('icon-src' in flatStyle) {\n    return buildIcon(flatStyle, context);\n  }\n\n  if ('shape-points' in flatStyle) {\n    return buildShape(flatStyle, context);\n  }\n\n  if ('circle-radius' in flatStyle) {\n    return buildCircle(flatStyle, context);\n  }\n\n  return null;\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {ParsingContext} context The parsing context.\n * @return {ImageEvaluator} A function that evaluates to an image symbolizer.\n */\nfunction buildIcon(flatStyle, context) {\n  const prefix = 'icon-';\n\n  // required property\n  const srcName = prefix + 'src';\n  const src = requireString(flatStyle[srcName], srcName);\n\n  // settable properties\n  const evaluateAnchor = coordinateEvaluator(\n    flatStyle,\n    prefix + 'anchor',\n    context,\n  );\n\n  const evaluateScale = sizeLikeEvaluator(flatStyle, prefix + 'scale', context);\n\n  const evaluateOpacity = numberEvaluator(\n    flatStyle,\n    prefix + 'opacity',\n    context,\n  );\n\n  const evaluateDisplacement = coordinateEvaluator(\n    flatStyle,\n    prefix + 'displacement',\n    context,\n  );\n\n  const evaluateRotation = numberEvaluator(\n    flatStyle,\n    prefix + 'rotation',\n    context,\n  );\n\n  const evaluateRotateWithView = booleanEvaluator(\n    flatStyle,\n    prefix + 'rotate-with-view',\n    context,\n  );\n\n  // the remaining symbolizer properties are not currently settable\n  const anchorOrigin = optionalIconOrigin(flatStyle, prefix + 'anchor-origin');\n  const anchorXUnits = optionalIconAnchorUnits(\n    flatStyle,\n    prefix + 'anchor-x-units',\n  );\n  const anchorYUnits = optionalIconAnchorUnits(\n    flatStyle,\n    prefix + 'anchor-y-units',\n  );\n  const colorValue = getExpressionValue(flatStyle, prefix + 'color');\n  let color;\n  let evaluateColor = null;\n  if (colorValue !== undefined) {\n    const isColorExpression =\n      Array.isArray(colorValue) &&\n      colorValue.length > 0 &&\n      typeof colorValue[0] === 'string';\n    if (isColorExpression) {\n      evaluateColor = colorLikeEvaluator(flatStyle, prefix + 'color', context);\n    } else {\n      color = requireColorLike(colorValue, prefix + 'color');\n    }\n  }\n  const crossOrigin = optionalString(flatStyle, prefix + 'cross-origin');\n  const offset = optionalNumberArray(flatStyle, prefix + 'offset');\n  const offsetOrigin = optionalIconOrigin(flatStyle, prefix + 'offset-origin');\n  const width = optionalNumber(flatStyle, prefix + 'width');\n  const height = optionalNumber(flatStyle, prefix + 'height');\n  const size = optionalSize(flatStyle, prefix + 'size');\n  const declutterMode = optionalDeclutterMode(\n    flatStyle,\n    prefix + 'declutter-mode',\n  );\n\n  const iconOptions = {\n    src,\n    anchorOrigin,\n    anchorXUnits,\n    anchorYUnits,\n    crossOrigin,\n    offset,\n    offsetOrigin,\n    height,\n    width,\n    size,\n    declutterMode,\n  };\n\n  let icon = null;\n\n  return function (context) {\n    if (!icon) {\n      // lazily create the icon to allow for expression evaluation\n      const initialColor = evaluateColor ? evaluateColor(context) : color;\n      icon = new Icon(\n        initialColor !== undefined\n          ? Object.assign({}, iconOptions, {color: initialColor})\n          : Object.assign({}, iconOptions),\n      );\n    } else if (evaluateColor) {\n      icon.setColor(evaluateColor(context));\n    }\n    if (evaluateOpacity) {\n      icon.setOpacity(evaluateOpacity(context));\n    }\n\n    if (evaluateDisplacement) {\n      icon.setDisplacement(evaluateDisplacement(context));\n    }\n\n    if (evaluateRotation) {\n      icon.setRotation(evaluateRotation(context));\n    }\n\n    if (evaluateRotateWithView) {\n      icon.setRotateWithView(evaluateRotateWithView(context));\n    }\n\n    if (evaluateScale) {\n      icon.setScale(evaluateScale(context));\n    }\n\n    if (evaluateAnchor) {\n      icon.setAnchor(evaluateAnchor(context));\n    }\n    return icon;\n  };\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {ParsingContext} context The parsing context.\n * @return {ImageEvaluator} A function that evaluates to an icon symbolizer.\n */\nfunction buildShape(flatStyle, context) {\n  const prefix = 'shape-';\n\n  // required property\n  const pointsName = prefix + 'points';\n  const radiusName = prefix + 'radius';\n  const points = requireNumber(flatStyle[pointsName], pointsName);\n  if (!(radiusName in flatStyle)) {\n    throw new Error(`Expected a number for ${radiusName}`);\n  }\n  const evaluateRadius = numberEvaluator(flatStyle, radiusName, context);\n  const initialRadius =\n    typeof flatStyle[radiusName] === 'number' ? flatStyle[radiusName] : 5;\n  const radius2Name = prefix + 'radius2';\n  const evaluateRadius2 = numberEvaluator(flatStyle, radius2Name, context);\n  const initialRadius2 =\n    typeof flatStyle[radius2Name] === 'number'\n      ? flatStyle[radius2Name]\n      : undefined;\n\n  // settable properties\n  const evaluateFill = buildFill(flatStyle, prefix, context);\n  const evaluateStroke = buildStroke(flatStyle, prefix, context);\n  const evaluateScale = sizeLikeEvaluator(flatStyle, prefix + 'scale', context);\n  const evaluateDisplacement = coordinateEvaluator(\n    flatStyle,\n    prefix + 'displacement',\n    context,\n  );\n  const evaluateRotation = numberEvaluator(\n    flatStyle,\n    prefix + 'rotation',\n    context,\n  );\n  const evaluateRotateWithView = booleanEvaluator(\n    flatStyle,\n    prefix + 'rotate-with-view',\n    context,\n  );\n\n  // the remaining properties are not currently settable\n  const angle = optionalNumber(flatStyle, prefix + 'angle');\n  const declutterMode = optionalDeclutterMode(\n    flatStyle,\n    prefix + 'declutter-mode',\n  );\n\n  const shape = new RegularShape({\n    points,\n    radius: initialRadius,\n    radius2: initialRadius2,\n    angle,\n    declutterMode,\n  });\n\n  return function (context) {\n    if (evaluateRadius) {\n      shape.setRadius(evaluateRadius(context));\n    }\n    if (evaluateRadius2) {\n      shape.setRadius2(evaluateRadius2(context));\n    }\n    if (evaluateFill) {\n      shape.setFill(evaluateFill(context));\n    }\n    if (evaluateStroke) {\n      shape.setStroke(evaluateStroke(context));\n    }\n    if (evaluateDisplacement) {\n      shape.setDisplacement(evaluateDisplacement(context));\n    }\n    if (evaluateRotation) {\n      shape.setRotation(evaluateRotation(context));\n    }\n    if (evaluateRotateWithView) {\n      shape.setRotateWithView(evaluateRotateWithView(context));\n    }\n    if (evaluateScale) {\n      shape.setScale(evaluateScale(context));\n    }\n\n    return shape;\n  };\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {ParsingContext} context The parsing context.\n * @return {ImageEvaluator} A function that evaluates to a circle symbolizer.\n */\nfunction buildCircle(flatStyle, context) {\n  const prefix = 'circle-';\n\n  // settable properties\n  const evaluateFill = buildFill(flatStyle, prefix, context);\n  const evaluateStroke = buildStroke(flatStyle, prefix, context);\n  const evaluateRadius = numberEvaluator(flatStyle, prefix + 'radius', context);\n  const evaluateScale = sizeLikeEvaluator(flatStyle, prefix + 'scale', context);\n  const evaluateDisplacement = coordinateEvaluator(\n    flatStyle,\n    prefix + 'displacement',\n    context,\n  );\n  const evaluateRotation = numberEvaluator(\n    flatStyle,\n    prefix + 'rotation',\n    context,\n  );\n  const evaluateRotateWithView = booleanEvaluator(\n    flatStyle,\n    prefix + 'rotate-with-view',\n    context,\n  );\n\n  // the remaining properties are not currently settable\n  const declutterMode = optionalDeclutterMode(\n    flatStyle,\n    prefix + 'declutter-mode',\n  );\n\n  const circle = new Circle({\n    radius: 5, // this is arbitrary, but required - the evaluated radius is used below\n    declutterMode,\n  });\n\n  return function (context) {\n    if (evaluateRadius) {\n      circle.setRadius(evaluateRadius(context));\n    }\n    if (evaluateFill) {\n      circle.setFill(evaluateFill(context));\n    }\n    if (evaluateStroke) {\n      circle.setStroke(evaluateStroke(context));\n    }\n    if (evaluateDisplacement) {\n      circle.setDisplacement(evaluateDisplacement(context));\n    }\n    if (evaluateRotation) {\n      circle.setRotation(evaluateRotation(context));\n    }\n    if (evaluateRotateWithView) {\n      circle.setRotateWithView(evaluateRotateWithView(context));\n    }\n    if (evaluateScale) {\n      circle.setScale(evaluateScale(context));\n    }\n\n    return circle;\n  };\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} name The property name.\n * @return {any|undefined} The encoded value, or undefined if not provided.\n */\nfunction getExpressionValue(flatStyle, name) {\n  if (!(name in flatStyle)) {\n    return undefined;\n  }\n  const value = flatStyle[name];\n  return value === undefined ? undefined : value;\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} name The property name.\n * @param {ParsingContext} context The parsing context.\n * @return {import('../../expr/cpu.js').NumberEvaluator|undefined} The expression evaluator or undefined.\n */\nfunction numberEvaluator(flatStyle, name, context) {\n  const encoded = getExpressionValue(flatStyle, name);\n  if (encoded === undefined) {\n    return undefined;\n  }\n  const evaluator = buildExpression(encoded, NumberType, context);\n  return function (context) {\n    return requireNumber(evaluator(context), name);\n  };\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} name The property name.\n * @param {ParsingContext} context The parsing context.\n * @return {import('../../expr/cpu.js').StringEvaluator?} The expression evaluator.\n */\nfunction stringEvaluator(flatStyle, name, context) {\n  const encoded = getExpressionValue(flatStyle, name);\n  if (encoded === undefined) {\n    return null;\n  }\n  const evaluator = buildExpression(encoded, StringType, context);\n  return function (context) {\n    return requireString(evaluator(context), name);\n  };\n}\n\nfunction patternEvaluator(flatStyle, prefix, context) {\n  const srcEvaluator = stringEvaluator(\n    flatStyle,\n    prefix + 'pattern-src',\n    context,\n  );\n  const offsetEvaluator = sizeEvaluator(\n    flatStyle,\n    prefix + 'pattern-offset',\n    context,\n  );\n  const patternSizeEvaluator = sizeEvaluator(\n    flatStyle,\n    prefix + 'pattern-size',\n    context,\n  );\n  const colorEvaluator = colorLikeEvaluator(\n    flatStyle,\n    prefix + 'color',\n    context,\n  );\n  return function (context) {\n    return {\n      src: srcEvaluator(context),\n      offset: offsetEvaluator && offsetEvaluator(context),\n      size: patternSizeEvaluator && patternSizeEvaluator(context),\n      color: colorEvaluator && colorEvaluator(context),\n    };\n  };\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} name The property name.\n * @param {ParsingContext} context The parsing context.\n * @return {import('../../expr/cpu.js').BooleanEvaluator?} The expression evaluator.\n */\nfunction booleanEvaluator(flatStyle, name, context) {\n  const encoded = getExpressionValue(flatStyle, name);\n  if (encoded === undefined) {\n    return null;\n  }\n  const evaluator = buildExpression(encoded, BooleanType, context);\n  return function (context) {\n    const value = evaluator(context);\n    if (typeof value !== 'boolean') {\n      throw new Error(`Expected a boolean for ${name}`);\n    }\n    return value;\n  };\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} name The property name.\n * @param {ParsingContext} context The parsing context.\n * @return {import('../../expr/cpu.js').ColorLikeEvaluator?} The expression evaluator.\n */\nfunction colorLikeEvaluator(flatStyle, name, context) {\n  const encoded = getExpressionValue(flatStyle, name);\n  if (encoded === undefined) {\n    return null;\n  }\n  const evaluator = buildExpression(encoded, ColorType, context);\n  return function (context) {\n    return requireColorLike(evaluator(context), name);\n  };\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} name The property name.\n * @param {ParsingContext} context The parsing context.\n * @return {import('../../expr/cpu.js').NumberArrayEvaluator?} The expression evaluator.\n */\nfunction numberArrayEvaluator(flatStyle, name, context) {\n  const encoded = getExpressionValue(flatStyle, name);\n  if (encoded === undefined) {\n    return null;\n  }\n  if (\n    Array.isArray(encoded) &&\n    (encoded.length === 0 || typeof encoded[0] !== 'string')\n  ) {\n    /** @type {Array<import('../../expr/cpu.js').NumberEvaluator>} */\n    const evaluators = encoded.map((value, index) => {\n      if (typeof value === 'number') {\n        return () => value;\n      }\n      const evaluator = buildExpression(value, NumberType, context);\n      return function (context) {\n        return requireNumber(evaluator(context), `${name}[${index}]`);\n      };\n    });\n    return function (context) {\n      const array = new Array(evaluators.length);\n      for (let i = 0; i < evaluators.length; ++i) {\n        array[i] = evaluators[i](context);\n      }\n      return array;\n    };\n  }\n  const evaluator = buildExpression(encoded, NumberArrayType, context);\n  return function (context) {\n    return requireNumberArray(evaluator(context), name);\n  };\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} name The property name.\n * @param {ParsingContext} context The parsing context.\n * @return {import('../../expr/cpu.js').CoordinateEvaluator?} The expression evaluator.\n */\nfunction coordinateEvaluator(flatStyle, name, context) {\n  const encoded = getExpressionValue(flatStyle, name);\n  if (encoded === undefined) {\n    return null;\n  }\n  const evaluator = buildExpression(encoded, NumberArrayType, context);\n  return function (context) {\n    const array = requireNumberArray(evaluator(context), name);\n    if (array.length !== 2) {\n      throw new Error(`Expected two numbers for ${name}`);\n    }\n    return array;\n  };\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} name The property name.\n * @param {ParsingContext} context The parsing context.\n * @return {import('../../expr/cpu.js').SizeEvaluator?} The expression evaluator.\n */\nfunction sizeEvaluator(flatStyle, name, context) {\n  const encoded = getExpressionValue(flatStyle, name);\n  if (encoded === undefined) {\n    return null;\n  }\n  const evaluator = buildExpression(encoded, NumberArrayType, context);\n  return function (context) {\n    return requireSize(evaluator(context), name);\n  };\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} name The property name.\n * @param {ParsingContext} context The parsing context.\n * @return {import('../../expr/cpu.js').SizeLikeEvaluator?} The expression evaluator.\n */\nfunction sizeLikeEvaluator(flatStyle, name, context) {\n  const encoded = getExpressionValue(flatStyle, name);\n  if (encoded === undefined) {\n    return null;\n  }\n  const evaluator = buildExpression(\n    encoded,\n    NumberArrayType | NumberType,\n    context,\n  );\n  return function (context) {\n    return requireSizeLike(evaluator(context), name);\n  };\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} property The symbolizer property.\n * @return {number|undefined} A number or undefined.\n */\nfunction optionalNumber(flatStyle, property) {\n  const value = flatStyle[property];\n  if (value === undefined) {\n    return undefined;\n  }\n  if (typeof value !== 'number') {\n    throw new Error(`Expected a number for ${property}`);\n  }\n  return value;\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} property The symbolizer property.\n * @return {import(\"../../size.js\").Size|undefined} A size or undefined.\n */\nfunction optionalSize(flatStyle, property) {\n  const encoded = flatStyle[property];\n  if (encoded === undefined) {\n    return undefined;\n  }\n  if (typeof encoded === 'number') {\n    return toSize(encoded);\n  }\n  if (!Array.isArray(encoded)) {\n    throw new Error(`Expected a number or size array for ${property}`);\n  }\n  if (\n    encoded.length !== 2 ||\n    typeof encoded[0] !== 'number' ||\n    typeof encoded[1] !== 'number'\n  ) {\n    throw new Error(`Expected a number or size array for ${property}`);\n  }\n  return encoded;\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} property The symbolizer property.\n * @return {string|undefined} A string or undefined.\n */\nfunction optionalString(flatStyle, property) {\n  const encoded = flatStyle[property];\n  if (encoded === undefined) {\n    return undefined;\n  }\n  if (typeof encoded !== 'string') {\n    throw new Error(`Expected a string for ${property}`);\n  }\n  return encoded;\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} property The symbolizer property.\n * @return {import(\"../../style/Icon.js\").IconOrigin|undefined} An icon origin or undefined.\n */\nfunction optionalIconOrigin(flatStyle, property) {\n  const encoded = flatStyle[property];\n  if (encoded === undefined) {\n    return undefined;\n  }\n  if (\n    encoded !== 'bottom-left' &&\n    encoded !== 'bottom-right' &&\n    encoded !== 'top-left' &&\n    encoded !== 'top-right'\n  ) {\n    throw new Error(\n      `Expected bottom-left, bottom-right, top-left, or top-right for ${property}`,\n    );\n  }\n  return encoded;\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} property The symbolizer property.\n * @return {import(\"../../style/Icon.js\").IconAnchorUnits|undefined} Icon anchor units or undefined.\n */\nfunction optionalIconAnchorUnits(flatStyle, property) {\n  const encoded = flatStyle[property];\n  if (encoded === undefined) {\n    return undefined;\n  }\n  if (encoded !== 'pixels' && encoded !== 'fraction') {\n    throw new Error(`Expected pixels or fraction for ${property}`);\n  }\n  return encoded;\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} property The symbolizer property.\n * @return {Array<number>|undefined} An array of numbers or undefined.\n */\nfunction optionalNumberArray(flatStyle, property) {\n  const encoded = flatStyle[property];\n  if (encoded === undefined) {\n    return undefined;\n  }\n  return requireNumberArray(encoded, property);\n}\n\n/**\n * @param {FlatStyle} flatStyle The flat style.\n * @param {string} property The symbolizer property.\n * @return {import('../../style/Style.js').DeclutterMode} Icon declutter mode.\n */\nfunction optionalDeclutterMode(flatStyle, property) {\n  const encoded = flatStyle[property];\n  if (encoded === undefined) {\n    return undefined;\n  }\n  if (typeof encoded !== 'string') {\n    throw new Error(`Expected a string for ${property}`);\n  }\n  if (encoded !== 'declutter' && encoded !== 'obstacle' && encoded !== 'none') {\n    throw new Error(`Expected declutter, obstacle, or none for ${property}`);\n  }\n  return encoded;\n}\n\n/**\n * @param {any} value The value.\n * @param {string} property The property.\n * @return {Array<number>} An array of numbers.\n */\nfunction requireNumberArray(value, property) {\n  if (!Array.isArray(value)) {\n    throw new Error(`Expected an array for ${property}`);\n  }\n  const length = value.length;\n  for (let i = 0; i < length; ++i) {\n    if (typeof value[i] !== 'number') {\n      throw new Error(`Expected an array of numbers for ${property}`);\n    }\n  }\n  return value;\n}\n\n/**\n * @param {any} value The value.\n * @param {string} property The property.\n * @return {string} A string.\n */\nfunction requireString(value, property) {\n  if (typeof value !== 'string') {\n    throw new Error(`Expected a string for ${property}`);\n  }\n  return value;\n}\n\n/**\n * @param {any} value The value.\n * @param {string} property The property.\n * @return {number} A number.\n */\nfunction requireNumber(value, property) {\n  if (typeof value !== 'number') {\n    throw new Error(`Expected a number for ${property}`);\n  }\n  return value;\n}\n\n/**\n * @param {any} value The value.\n * @param {string} property The property.\n * @return {Array<number>|string} A color.\n */\nfunction requireColorLike(value, property) {\n  if (typeof value === 'string') {\n    return value;\n  }\n  const array = requireNumberArray(value, property);\n  const length = array.length;\n  if (length < 3 || length > 4) {\n    throw new Error(`Expected a color with 3 or 4 values for ${property}`);\n  }\n  return array;\n}\n\n/**\n * @param {any} value The value.\n * @param {string} property The property.\n * @return {Array<number>} A number or an array of two numbers.\n */\nfunction requireSize(value, property) {\n  const size = requireNumberArray(value, property);\n  if (size.length !== 2) {\n    throw new Error(`Expected an array of two numbers for ${property}`);\n  }\n  return size;\n}\n\n/**\n * @param {any} value The value.\n * @param {string} property The property.\n * @return {number|Array<number>} A number or an array of two numbers.\n */\nfunction requireSizeLike(value, property) {\n  if (typeof value === 'number') {\n    return value;\n  }\n  return requireSize(value, property);\n}\n","/**\n * @module ol/layer/BaseVector\n */\nimport RBush from 'rbush';\nimport {\n  flatStylesToStyleFunction,\n  rulesToStyleFunction,\n} from '../render/canvas/style.js';\nimport Style, {\n  createDefaultStyle,\n  toFunction as toStyleFunction,\n} from '../style/Style.js';\nimport Layer from './Layer.js';\n\n/***\n * @template T\n * @typedef {T extends import(\"../source/Vector.js\").default<infer U extends import(\"../Feature.js\").FeatureLike> ? U : never} ExtractedFeatureType\n */\n\n/**\n * @template {import('../Feature.js').FeatureLike} FeatureType\n * @template {import(\"../source/Vector.js\").default<FeatureType>|import(\"../source/VectorTile.js\").default<FeatureType>} VectorSourceType<FeatureType>\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} [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 {import(\"../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 viewport extent used by the\n * renderer when getting features from the vector source for the rendering or hit-detection.\n * Recommended value: the size of the largest symbol, line width or label.\n * @property {VectorSourceType} [source] Source.\n * @property {import(\"../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()]{@link import(\"../Map.js\").default#addLayer}.\n * @property {boolean|string|number} [declutter=false] Declutter images and text. Any truthy value will enable\n * decluttering. Within a layer, a feature rendered before another has higher priority. All layers with the\n * same `declutter` value will be decluttered together. The priority is determined by the drawing order of the\n * layers with the same `declutter` value. Higher in the layer stack means higher priority. To declutter distinct\n * layers or groups of layers separately, use different truthy values for `declutter`.\n * @property {import(\"../style/Style.js\").StyleLike|import(\"../style/flat.js\").FlatStyleLike|null} [style] Layer style. When set to `null`, only\n * features that have their own style will be rendered. See {@link module:ol/style/Style~Style} for the default style\n * which will be used if this is not set.\n * @property {import(\"./Base.js\").BackgroundColor} [background] Background color for the layer. If not specified, no background\n * will be rendered.\n * @property {boolean} [updateWhileAnimating=false] When set to `true`, feature batches will\n * be recreated during animations. This means that no vectors will be shown clipped, but the\n * setting will have a performance impact for large amounts of vector data. When set to `false`,\n * batches will be recreated when no animation is active.\n * @property {boolean} [updateWhileInteracting=false] When set to `true`, feature batches will\n * be recreated during interactions. See also `updateWhileAnimating`.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n\n/**\n * @enum {string}\n * @private\n */\nconst Property = {\n  RENDER_ORDER: 'renderOrder',\n};\n\n/**\n * @classdesc\n * Vector data that is rendered client-side.\n * Note that any property set in the options is set as a {@link module:ol/Object~BaseObject}\n * property on the layer object; for example, setting `title: 'My Title'` in the\n * options means that `title` is observable, and has get/set accessors.\n *\n * @template {import('../Feature.js').FeatureLike} FeatureType\n * @template {import(\"../source/Vector.js\").default<FeatureType>|import(\"../source/VectorTile.js\").default<FeatureType>} VectorSourceType<FeatureType>\n * @extends {Layer<VectorSourceType, RendererType>}\n * @template {import(\"../renderer/canvas/VectorLayer.js\").default|import(\"../renderer/canvas/VectorTileLayer.js\").default|import(\"../renderer/canvas/VectorImageLayer.js\").default|import(\"../renderer/webgl/VectorLayer.js\").default|import(\"../renderer/webgl/PointsLayer.js\").default} RendererType\n * @api\n */\nclass BaseVectorLayer extends Layer {\n  /**\n   * @param {Options<FeatureType, VectorSourceType>} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    const baseOptions = Object.assign({}, options);\n\n    delete baseOptions.style;\n    delete baseOptions.renderBuffer;\n    delete baseOptions.updateWhileAnimating;\n    delete baseOptions.updateWhileInteracting;\n    super(baseOptions);\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.declutter_ = options.declutter ? String(options.declutter) : undefined;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.renderBuffer_ =\n      options.renderBuffer !== undefined ? options.renderBuffer : 100;\n\n    /**\n     * User provided style.\n     * @type {import(\"../style/Style.js\").StyleLike|import(\"../style/flat.js\").FlatStyleLike}\n     * @private\n     */\n    this.style_ = null;\n\n    /**\n     * Style function for use within the library.\n     * @type {import(\"../style/Style.js\").StyleFunction|undefined}\n     * @private\n     */\n    this.styleFunction_ = undefined;\n\n    this.setStyle(options.style);\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.updateWhileAnimating_ =\n      options.updateWhileAnimating !== undefined\n        ? options.updateWhileAnimating\n        : false;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.updateWhileInteracting_ =\n      options.updateWhileInteracting !== undefined\n        ? options.updateWhileInteracting\n        : false;\n  }\n\n  /**\n   * @return {string} Declutter group.\n   * @override\n   */\n  getDeclutter() {\n    return this.declutter_;\n  }\n\n  /**\n   * Get the topmost feature that intersects the given pixel on the viewport. Returns a promise\n   * that resolves with an array of features. The array will either contain the topmost feature\n   * when a hit was detected, or it will be empty.\n   *\n   * The hit detection algorithm used for this method is optimized for performance, but is less\n   * accurate than the one used in [map.getFeaturesAtPixel()]{@link import(\"../Map.js\").default#getFeaturesAtPixel}.\n   * Text is not considered, and icons are only represented by their bounding box instead of the exact\n   * image.\n   *\n   * @param {import(\"../pixel.js\").Pixel} pixel Pixel.\n   * @return {Promise<Array<import(\"../Feature.js\").FeatureLike>>} Promise that resolves with an array of features.\n   * @api\n   * @override\n   */\n  getFeatures(pixel) {\n    return super.getFeatures(pixel);\n  }\n\n  /**\n   * @return {number|undefined} Render buffer.\n   */\n  getRenderBuffer() {\n    return this.renderBuffer_;\n  }\n\n  /**\n   * @return {import(\"../render.js\").OrderFunction|null|undefined} Render order.\n   */\n  getRenderOrder() {\n    return /** @type {import(\"../render.js\").OrderFunction|null|undefined} */ (\n      this.get(Property.RENDER_ORDER)\n    );\n  }\n\n  /**\n   * Get the style for features.  This returns whatever was passed to the `style`\n   * option at construction or to the `setStyle` method.\n   * @return {import(\"../style/Style.js\").StyleLike|import(\"../style/flat.js\").FlatStyleLike|null|undefined} Layer style.\n   * @api\n   */\n  getStyle() {\n    return this.style_;\n  }\n\n  /**\n   * Get the style function.\n   * @return {import(\"../style/Style.js\").StyleFunction|undefined} Layer style function.\n   * @api\n   */\n  getStyleFunction() {\n    return this.styleFunction_;\n  }\n\n  /**\n   * @return {boolean} Whether the rendered layer should be updated while\n   *     animating.\n   */\n  getUpdateWhileAnimating() {\n    return this.updateWhileAnimating_;\n  }\n\n  /**\n   * @return {boolean} Whether the rendered layer should be updated while\n   *     interacting.\n   */\n  getUpdateWhileInteracting() {\n    return this.updateWhileInteracting_;\n  }\n\n  /**\n   * Render declutter items for this layer\n   * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n   * @param {import(\"../layer/Layer.js\").State} layerState Layer state.\n   * @override\n   */\n  renderDeclutter(frameState, layerState) {\n    const declutterGroup = this.getDeclutter();\n    if (declutterGroup in frameState.declutter === false) {\n      frameState.declutter[declutterGroup] = new RBush(9);\n    }\n    this.getRenderer().renderDeclutter(frameState, layerState);\n  }\n\n  /**\n   * @param {import(\"../render.js\").OrderFunction|null|undefined} renderOrder\n   *     Render order.\n   */\n  setRenderOrder(renderOrder) {\n    this.set(Property.RENDER_ORDER, renderOrder);\n  }\n\n  /**\n   * Set the style for features.  This can be a single style object, an array\n   * of styles, or a function that takes a feature and resolution and returns\n   * an array of styles. If set to `null`, the layer has no style (a `null` style),\n   * so only features that have their own styles will be rendered in the layer. Call\n   * `setStyle()` without arguments to reset to the default style. See\n   * [the ol/style/Style module]{@link module:ol/style/Style~Style} for information on the default style.\n   *\n   * If your layer has a static style, you can use [flat style]{@link module:ol/style/flat~FlatStyle} object\n   * literals instead of using the `Style` and symbolizer constructors (`Fill`, `Stroke`, etc.):\n   * ```js\n   * vectorLayer.setStyle({\n   *   \"fill-color\": \"yellow\",\n   *   \"stroke-color\": \"black\",\n   *   \"stroke-width\": 4\n   * })\n   * ```\n   *\n   * @param {import(\"../style/Style.js\").StyleLike|import(\"../style/flat.js\").FlatStyleLike|null} [style] Layer style.\n   * @api\n   */\n  setStyle(style) {\n    this.style_ = style === undefined ? createDefaultStyle : style;\n    const styleLike = toStyleLike(style);\n    this.styleFunction_ =\n      style === null ? undefined : toStyleFunction(styleLike);\n    this.changed();\n  }\n\n  /**\n   * @param {boolean|string|number} declutter Declutter images and text.\n   * @api\n   */\n  setDeclutter(declutter) {\n    this.declutter_ = declutter ? String(declutter) : undefined;\n    this.changed();\n  }\n}\n\n/**\n * Coerce the allowed style types into a shorter list of types.  Flat styles, arrays of flat\n * styles, and arrays of rules are converted into style functions.\n *\n * @param {import(\"../style/Style.js\").StyleLike|import(\"../style/flat.js\").FlatStyleLike|null} [style] Layer style.\n * @return {import(\"../style/Style.js\").StyleLike|null} The style.\n */\nfunction toStyleLike(style) {\n  if (style === undefined) {\n    return createDefaultStyle;\n  }\n  if (!style) {\n    return null;\n  }\n  if (typeof style === 'function') {\n    return style;\n  }\n  if (style instanceof Style) {\n    return style;\n  }\n  if (!Array.isArray(style)) {\n    return flatStylesToStyleFunction([style]);\n  }\n  if (style.length === 0) {\n    return [];\n  }\n\n  const length = style.length;\n  const first = style[0];\n\n  if (first instanceof Style) {\n    /**\n     * @type {Array<Style>}\n     */\n    const styles = new Array(length);\n    for (let i = 0; i < length; ++i) {\n      const candidate = style[i];\n      if (!(candidate instanceof Style)) {\n        throw new Error('Expected a list of style instances');\n      }\n      styles[i] = candidate;\n    }\n    return styles;\n  }\n\n  if ('style' in first) {\n    /**\n     * @type {Array<import(\"../style/flat.js\").Rule>}\n     */\n    const rules = new Array(length);\n    for (let i = 0; i < length; ++i) {\n      const candidate = style[i];\n      if (!('style' in candidate)) {\n        throw new Error('Expected a list of rules with a style property');\n      }\n      rules[i] = candidate;\n    }\n    return rulesToStyleFunction(rules);\n  }\n\n  const flatStyles =\n    /** @type {Array<import(\"../style/flat.js\").FlatStyle>} */ (style);\n  return flatStylesToStyleFunction(flatStyles);\n}\n\nexport default BaseVectorLayer;\n","/**\n * @module ol/render/Event\n */\n\nimport Event from '../events/Event.js';\n\nclass RenderEvent extends Event {\n  /**\n   * @param {import(\"./EventType.js\").default} type Type.\n   * @param {import(\"../transform.js\").Transform} [inversePixelTransform] Transform for\n   *     CSS pixels to rendered pixels.\n   * @param {import(\"../Map.js\").FrameState} [frameState] Frame state.\n   * @param {?(CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D|WebGLRenderingContext)} [context] Context.\n   */\n  constructor(type, inversePixelTransform, frameState, context) {\n    super(type);\n\n    /**\n     * Transform from CSS pixels (relative to the top-left corner of the map viewport)\n     * to rendered pixels on this event's `context`. Only available when a Canvas renderer is used, null otherwise.\n     * @type {import(\"../transform.js\").Transform|undefined}\n     * @api\n     */\n    this.inversePixelTransform = inversePixelTransform;\n\n    /**\n     * An object representing the current render frame state.\n     * @type {import(\"../Map.js\").FrameState|undefined}\n     * @api\n     */\n    this.frameState = frameState;\n\n    /**\n     * Canvas context. Not available when the event is dispatched by the map. For Canvas 2D layers,\n     * the context will be the 2D rendering context.  For WebGL layers, the context will be the WebGL\n     * context.\n     * @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D|WebGLRenderingContext|undefined}\n     * @api\n     */\n    this.context = context;\n  }\n}\n\nexport default RenderEvent;\n","/**\n * @module ol/renderer/Map\n */\nimport Disposable from '../Disposable.js';\nimport {wrapX} from '../coordinate.js';\nimport {getWidth} from '../extent.js';\nimport {TRUE} from '../functions.js';\nimport {inView} from '../layer/Layer.js';\nimport {shared as iconImageCache} from '../style/IconImageCache.js';\nimport {compose as composeTransform, makeInverse} from '../transform.js';\nimport {abstract} from '../util.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<T>} 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<T>} 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<HitMatch<T>>} */ ([]);\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 ObjectEventType from '../ObjectEventType.js';\nimport {CLASS_UNSELECTABLE} from '../css.js';\nimport {createMockDiv, isCanvas, replaceChildren} from '../dom.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport {WORKER_OFFSCREEN_CANVAS} from '../has.js';\nimport BaseVectorLayer from '../layer/BaseVector.js';\nimport {inView} from '../layer/Layer.js';\nimport RenderEvent from '../render/Event.js';\nimport RenderEventType from '../render/EventType.js';\nimport {checkedFonts} from '../render/canvas.js';\nimport {fromString} from '../transform.js';\nimport MapRenderer from './Map.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,\n      map,\n    );\n\n    /**\n     * @private\n     * @type {HTMLDivElement}\n     */\n    this.element_ = WORKER_OFFSCREEN_CANVAS\n      ? createMockDiv()\n      : 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    if (container) {\n      // maps in a worker do not have a viewport.\n      container.insertBefore(this.element_, container.firstChild || null);\n    }\n\n    /**\n     * @private\n     * @type {Array<HTMLElement>}\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    const map = this.getMap();\n    const mapCanvas = map.getTargetElement();\n    if (isCanvas(mapCanvas)) {\n      // Canvas composition when container is a canvas\n      const mapContext = mapCanvas.getContext('2d');\n      for (const container of this.children_) {\n        const canvas = container.firstElementChild || container;\n        const backgroundColor = container.style.backgroundColor;\n        if (backgroundColor && (!isCanvas(canvas) || canvas.width > 0)) {\n          mapContext.fillStyle = backgroundColor;\n          mapContext.fillRect(0, 0, mapCanvas.width, mapCanvas.height);\n        }\n        if (isCanvas(canvas) && canvas.width > 0) {\n          mapContext.save();\n          const opacity = container.style.opacity || canvas.style.opacity;\n          mapContext.globalAlpha = opacity === '' ? 1 : Number(opacity);\n          const transform = canvas.style.transform;\n          if (transform) {\n            // Get the transform parameters from the style's transform matrix\n            mapContext.transform(\n              .../** @type {[number, number, number, number, number, number]} */ (\n                fromString(transform)\n              ),\n            );\n          } else {\n            const w = parseFloat(canvas.style.width) / canvas.width;\n            const h = parseFloat(canvas.style.height) / canvas.height;\n            mapContext.transform(w, 0, 0, h, 0, 0);\n          }\n          mapContext.drawImage(canvas, 0, 0);\n          mapContext.restore();\n        }\n      }\n    }\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<import('../layer/Layer.js').State>} 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/Map\n */\nimport Collection from './Collection.js';\nimport CollectionEventType from './CollectionEventType.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 BaseObject from './Object.js';\nimport ObjectEventType from './ObjectEventType.js';\nimport TileQueue, {getTilePriority} from './TileQueue.js';\nimport View from './View.js';\nimport ViewHint from './ViewHint.js';\nimport {equals} from './array.js';\nimport {assert} from './asserts.js';\nimport {warn} from './console.js';\nimport {defaults as defaultControls} from './control/defaults.js';\nimport {isCanvas} from './dom.js';\nimport {listen, unlistenByKey} from './events.js';\nimport EventType from './events/EventType.js';\nimport {\n  clone,\n  createOrUpdateEmpty,\n  equals as equalsExtent,\n  getForViewAndSize,\n  isEmpty,\n} from './extent.js';\nimport {TRUE} from './functions.js';\nimport {\n  DEVICE_PIXEL_RATIO,\n  PASSIVE_EVENT_LISTENERS,\n  WORKER_OFFSCREEN_CANVAS,\n} from './has.js';\nimport {defaults as defaultInteractions} from './interaction/defaults.js';\nimport LayerGroup, {GroupEvent} from './layer/Group.js';\nimport Layer from './layer/Layer.js';\nimport PointerEventType from './pointer/EventType.js';\nimport {fromUserCoordinate, toUserCoordinate} from './proj.js';\nimport RenderEventType from './render/EventType.js';\nimport CompositeMapRenderer from './renderer/Composite.js';\nimport {hasArea} from './size.js';\nimport {\n  apply as applyTransform,\n  create as createTransform,\n} from './transform.js';\nimport {getUid} from './util.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<string, import(\"rbush\").default<import('./render/canvas/Executor.js').DeclutterEntry>>|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<import(\"./layer/Layer.js\").State>} layerStatesArray LayerStatesArray.\n * @property {number} layerIndex LayerIndex.\n * @property {import(\"./transform.js\").Transform} pixelToCoordinateTransform PixelToCoordinateTransform.\n * @property {Array<PostRenderFunction>} postRenderFunctions PostRenderFunctions.\n * @property {import(\"./size.js\").Size} size Size.\n * @property {TileQueue} tileQueue TileQueue.\n * @property {!Object<string, Object<string, boolean>>} usedTiles UsedTiles.\n * @property {Array<number>} viewHints ViewHints.\n * @property {!Object<string, Object<string, boolean>>} wantedTiles WantedTiles.\n * @property {string} mapId The id of the map.\n * @property {Object<string, boolean>} 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<import(\"./source/Source.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<import(\"./control/Control.js\").default>} [controls] Controls.\n * @property {Collection<import(\"./interaction/Interaction.js\").default>} [interactions] Interactions.\n * @property {HTMLElement|Document} keyboardEventTarget KeyboardEventTarget.\n * @property {Collection<import(\"./Overlay.js\").default>} overlays Overlays.\n * @property {Object<string, *>} values Values.\n */\n\n/**\n * @typedef {import(\"./ObjectEventType.js\").Types|'change:layergroup'|'change:size'|'change:target'|'change:view'} MapObjectEventTypes\n */\n\n/***\n * @template Return\n * @typedef {import(\"./Observable.js\").OnSignature<import(\"./Observable.js\").EventTypes, import(\"./events/Event.js\").default, Return> &\n *    import(\"./Observable.js\").OnSignature<MapObjectEventTypes, import(\"./Object.js\").ObjectEvent, Return> &\n *    import(\"./Observable.js\").OnSignature<import(\"./MapBrowserEventType.js\").Types, import(\"./MapBrowserEvent.js\").default, Return> &\n *    import(\"./Observable.js\").OnSignature<import(\"./MapEventType.js\").Types, import(\"./MapEvent.js\").default, Return> &\n *    import(\"./Observable.js\").OnSignature<import(\"./render/EventType.js\").MapRenderEventTypes, import(\"./render/Event.js\").default, Return> &\n *    import(\"./Observable.js\").CombinedOnSignature<import(\"./Observable.js\").EventTypes|MapObjectEventTypes|\n *      import(\"./MapBrowserEventType.js\").Types|import(\"./MapEventType.js\").Types|\n *      import(\"./render/EventType.js\").MapRenderEventTypes, Return>} MapEventHandler\n */\n\n/**\n * Object literal with config options for the map.\n * @typedef {Object} MapOptions\n * @property {Collection<import(\"./control/Control.js\").default>|Array<import(\"./control/Control.js\").default>} [controls]\n * Controls initially added to the map. If not specified,\n * {@link module:ol/control/defaults.defaults} is used. In a worker, no controls are added by default.\n * @property {number} [pixelRatio=window.devicePixelRatio] The ratio between\n * physical pixels and device-independent pixels (dips) on the device.\n * @property {Collection<import(\"./interaction/Interaction.js\").default>|Array<import(\"./interaction/Interaction.js\").default>} [interactions]\n * Interactions that are initially added to the map. If not specified,\n * {@link module:ol/interaction/defaults.defaults} is used. In a worker, no interactions are added by default.\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<import(\"./layer/Base.js\").default>|Collection<import(\"./layer/Base.js\").default>|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<import(\"./Overlay.js\").default>|Array<import(\"./Overlay.js\").default>} [overlays]\n * Overlays initially added to the map. By default, no overlays are added.\n * @property {HTMLElement|string|HTMLCanvasElement|OffscreenCanvas} [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 * For use in workers or when exporting a map, use an `OffscreenCanvas` or `HTMLCanvasElement` as target,\n * with a width and height in physical pixels, optionally multiplied by and a scale transform matching\n * the map's pixel ratio.\n * For accessibility (focus and keyboard events for map navigation), the `target` element must have a\n *  properly configured `tabindex` attribute. If the `target` element is inside a Shadow DOM, the\n *  `tabindex` atribute must be set on the custom element's host element.\n * **Note:** CSS `transform` support for the target element is limited to `scale`.\n * @property {View|Promise<import(\"./View.js\").ViewOptions>} [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<import(\"./events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {MapEventHandler<import(\"./events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {MapEventHandler<void>}\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<typeof setTimeout>}\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<import(\"./events.js\").EventsKey>}\n     */\n    this.layerGroupPropertyListenerKeys_ = null;\n\n    /**\n     * @private\n     * @type {!HTMLElement}\n     */\n    if (!WORKER_OFFSCREEN_CANVAS) {\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 =\n        'ol-overlaycontainer-stopevent';\n      this.viewport_.appendChild(this.overlayContainerStopEvent_);\n    }\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<import(\"./events.js\").EventsKey>}\n     */\n    this.targetChangeHandlerKeys_ = null;\n\n    /**\n     * @private\n     * @type {HTMLElement|null}\n     */\n    this.targetElement_ = null;\n\n    if (!WORKER_OFFSCREEN_CANVAS) {\n      /**\n       * @private\n       * @type {ResizeObserver}\n       */\n      this.resizeObserver_ = new ResizeObserver(() => this.updateSize());\n    }\n\n    /**\n     * @type {Collection<import(\"./control/Control.js\").default>}\n     * @protected\n     */\n    this.controls =\n      optionsInternal.controls ||\n      (WORKER_OFFSCREEN_CANVAS ? new Collection() : defaultControls());\n\n    /**\n     * @type {Collection<import(\"./interaction/Interaction.js\").default>}\n     * @protected\n     */\n    this.interactions =\n      optionsInternal.interactions ||\n      (WORKER_OFFSCREEN_CANVAS\n        ? new Collection()\n        : defaultInteractions({\n            onFocusOnly: true,\n          }));\n\n    /**\n     * @type {Collection<import(\"./Overlay.js\").default>}\n     * @private\n     */\n    this.overlays_ = optionsInternal.overlays;\n\n    /**\n     * A lookup of overlays by id.\n     * @private\n     * @type {Object<string, import(\"./Overlay.js\").default>}\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<PostRenderFunction>}\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<import(\"./control/Control.js\").default>} 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<import(\"./control/Control.js\").default>} 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<import(\"./interaction/Interaction.js\").default>} 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<import(\"./interaction/Interaction.js\").default>} 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<import(\"./Overlay.js\").default>} 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<import(\"./Overlay.js\").default>} 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   * For polygons without a fill, only the stroke will be used for hit detection.\n   * Polygons must have a fill style applied to ensure that pixels inside a polygon are detected.\n   * The fill can be transparent.\n   * @param {import(\"./pixel.js\").Pixel} pixel Pixel.\n   * @param {function(import(\"./Feature.js\").FeatureLike, import(\"./layer/Layer.js\").default<import(\"./source/Source.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   * For polygons without a fill, only the stroke will be used for hit detection.\n   * Polygons must have a fill style applied to ensure that pixels inside a polygon are detected.\n   * The fill can be transparent.\n   * @param {import(\"./pixel.js\").Pixel} pixel Pixel.\n   * @param {AtPixelOptions} [options] Optional options.\n   * @return {Array<import(\"./Feature.js\").FeatureLike>} 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<import(\"./layer/Layer.js\").default>} 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   * For polygons without a fill, only the stroke will be used for hit detection.\n   * Polygons must have a fill style applied to ensure that pixels inside a polygon are detected.\n   * The fill can be transparent.\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<import(\"./control/Control.js\").default>} 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<import(\"./Overlay.js\").default>} 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<import(\"./interaction/Interaction.js\").default>} 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<import(\"./layer/Base.js\").default>|Collection<import(\"./layer/Base.js\").default>} 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<import(\"./layer/Base.js\").default>} 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 pixel ratio of the rendered map.\n   * @return {number} Pixel ratio.\n   * @api\n   */\n  getPixelRatio() {\n    return this.pixelRatio_;\n  }\n\n  /**\n   * Set the pixel ratio of the rendered map.\n   * @param {number} pixelRatio Pixel ratio.\n   * @api\n   */\n  setPixelRatio(pixelRatio) {\n    if (this.pixelRatio_ === pixelRatio) {\n      return;\n    }\n    this.pixelRatio_ = pixelRatio;\n    this.render();\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 {PointerEvent|KeyboardEvent|WheelEvent} 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 = mapBrowserEvent.originalEvent;\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\n      const currentDoc =\n        rootNode instanceof ShadowRoot\n          ? rootNode.host === target\n            ? rootNode.host.ownerDocument\n            : rootNode\n          : rootNode === doc\n            ? doc.documentElement\n            : rootNode;\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        !currentDoc.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      const hints = frameState ? frameState.viewHints : undefined;\n      const animatingOrInteracting = hints\n        ? hints[ViewHint.ANIMATING] || hints[ViewHint.INTERACTING]\n        : false;\n      if (animatingOrInteracting) {\n        const lowOnFrameBudget = Date.now() - frameState.time > 8;\n        maxTotalLoading = lowOnFrameBudget ? 0 : 8;\n        maxNewLoads = lowOnFrameBudget ? 0 : 2;\n      }\n      if (tileQueue.getTilesLoading() < maxTotalLoading) {\n        if (animatingOrInteracting) {\n          tileQueue.reprioritize();\n        }\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    if (frameState) {\n      for (let i = 0, ii = postRenderFunctions.length; i < ii; ++i) {\n        postRenderFunctions[i](this, frameState);\n      }\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_ && !isCanvas(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      if (!isCanvas(targetElement)) {\n        targetElement.appendChild(this.viewport_);\n      }\n      if (!this.renderer_) {\n        this.renderer_ = new CompositeMapRenderer(this);\n      }\n\n      if (!isCanvas(targetElement)) {\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        let keyboardEventTarget;\n        if (!this.keyboardEventTarget_) {\n          // check if map target is in shadowDOM, if yes use host element as target\n          const targetRoot = targetElement.getRootNode();\n          const targetCandidate =\n            targetRoot instanceof ShadowRoot ? targetRoot.host : targetElement;\n          keyboardEventTarget = targetCandidate;\n        } else {\n          keyboardEventTarget = this.keyboardEventTarget_;\n        }\n\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        if (targetElement instanceof HTMLElement) {\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\n      this.updateSize();\n    }\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    if (!this.frameState_) {\n      return;\n    }\n    const layerStates = this.frameState_.layerStatesArray;\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   * For accessibility (focus and keyboard events for map navigation), the `target` element must have a\n   *  properly configured `tabindex` attribute. If the `target` element is inside a Shadow DOM, the\n   *  `tabindex` atribute must be set on the custom element's host element.\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<import(\"./View.js\").ViewOptions>|null} 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      let width, height;\n      if (isCanvas(targetElement)) {\n        const transform = targetElement.getContext('2d').getTransform();\n        // Use scale components of the transform to calculate the size in CSS pixels\n        width = targetElement.width / transform.a;\n        height = targetElement.height / transform.d;\n      } else {\n        const computedStyle = getComputedStyle(targetElement);\n        width =\n          targetElement.offsetWidth -\n          parseFloat(computedStyle['borderLeftWidth']) -\n          parseFloat(computedStyle['paddingLeft']) -\n          parseFloat(computedStyle['paddingRight']) -\n          parseFloat(computedStyle['borderRightWidth']);\n        height =\n          targetElement.offsetHeight -\n          parseFloat(computedStyle['borderTopWidth']) -\n          parseFloat(computedStyle['paddingTop']) -\n          parseFloat(computedStyle['paddingBottom']) -\n          parseFloat(computedStyle['borderBottomWidth']);\n      }\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.updateViewportSize_(size);\n      this.setSize(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<string, *>}\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<import(\"./layer/Base.js\").default>|Array<import(\"./layer/Base.js\").default>} */ (\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<import(\"./control/Control.js\").default>} */\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<import(\"./interaction/Interaction.js\").default>} */\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<import(\"./Overlay.js\").default>} */\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/Overlay\n */\nimport MapEventType from './MapEventType.js';\nimport BaseObject from './Object.js';\nimport {CLASS_SELECTABLE} from './css.js';\nimport {outerHeight, outerWidth, removeChildren} from './dom.js';\nimport {listen, unlistenByKey} from './events.js';\nimport {containsExtent} from './extent.js';\n\n/**\n * @typedef {'bottom-left' | 'bottom-center' | 'bottom-right' | 'center-left' | 'center-center' | 'center-right' | 'top-left' | 'top-center' | 'top-right'} Positioning\n * The overlay position: `'bottom-left'`, `'bottom-center'`,  `'bottom-right'`,\n * `'center-left'`, `'center-center'`, `'center-right'`, `'top-left'`,\n * `'top-center'`, or `'top-right'`.\n */\n\n/**\n * @typedef {Object} Options\n * @property {number|string} [id] Set the overlay id. The overlay id can be used\n * with the {@link module:ol/Map~Map#getOverlayById} method.\n * @property {HTMLElement} [element] The overlay element.\n * @property {Array<number>} [offset=[0, 0]] Offsets in pixels used when positioning\n * the overlay. The first element in the\n * array is the horizontal offset. A positive value shifts the overlay right.\n * The second element in the array is the vertical offset. A positive value\n * shifts the overlay down.\n * @property {import(\"./coordinate.js\").Coordinate} [position] The overlay position\n * in map projection.\n * @property {Positioning} [positioning='top-left'] Defines how\n * the overlay is actually positioned with respect to its `position` property.\n * Possible values are `'bottom-left'`, `'bottom-center'`, `'bottom-right'`,\n * `'center-left'`, `'center-center'`, `'center-right'`, `'top-left'`,\n * `'top-center'`, and `'top-right'`.\n * @property {boolean} [stopEvent=true] Whether event propagation to the map\n * viewport should be stopped. If `true` the overlay is placed in the same\n * container as that of the controls (CSS class name\n * `ol-overlaycontainer-stopevent`); if `false` it is placed in the container\n * with CSS class name specified by the `className` property.\n * @property {boolean} [insertFirst=true] Whether the overlay is inserted first\n * in the overlay container, or appended. If the overlay is placed in the same\n * container as that of the controls (see the `stopEvent` option) you will\n * probably set `insertFirst` to `true` so the overlay is displayed below the\n * controls.\n * @property {PanIntoViewOptions|boolean} [autoPan=false] Pan the map when calling\n * `setPosition`, so that the overlay is entirely visible in the current viewport.\n * @property {string} [className='ol-overlay-container ol-selectable'] CSS class\n * name.\n */\n\n/**\n * @typedef {Object} PanOptions\n * @property {number} [duration=1000] The duration of the animation in\n * milliseconds.\n * @property {function(number):number} [easing] The easing function to use. Can\n * be one from {@link module:ol/easing} or a custom function.\n * Default is {@link module:ol/easing.inAndOut}.\n */\n\n/**\n * @typedef {Object} PanIntoViewOptions\n * @property {PanOptions} [animation={}] The animation parameters for the pan\n * @property {number} [margin=20] The margin (in pixels) between the\n * overlay and the borders of the map when panning into view.\n */\n\n/**\n * @enum {string}\n * @protected\n */\nconst Property = {\n  ELEMENT: 'element',\n  MAP: 'map',\n  OFFSET: 'offset',\n  POSITION: 'position',\n  POSITIONING: 'positioning',\n};\n\n/**\n * @typedef {import(\"./ObjectEventType.js\").Types|'change:element'|'change:map'|'change:offset'|'change:position'|\n *   'change:positioning'} OverlayObjectEventTypes\n */\n\n/***\n * @template Return\n * @typedef {import(\"./Observable.js\").OnSignature<import(\"./Observable.js\").EventTypes, import(\"./events/Event.js\").default, Return> &\n *   import(\"./Observable.js\").OnSignature<OverlayObjectEventTypes, import(\"./Object.js\").ObjectEvent, Return> &\n *   import(\"./Observable.js\").CombinedOnSignature<import(\"./Observable.js\").EventTypes|OverlayObjectEventTypes, Return>} OverlayOnSignature\n */\n\n/**\n * @classdesc\n * An element to be displayed over the map and attached to a single map\n * location.  Like {@link module:ol/control/Control~Control}, Overlays are\n * visible widgets. Unlike Controls, they are not in a fixed position on the\n * screen, but are tied to a geographical coordinate, so panning the map will\n * move an Overlay but not a Control.\n *\n * Example:\n *\n *     import Overlay from 'ol/Overlay.js';\n *\n *     // ...\n *     const popup = new Overlay({\n *       element: document.getElementById('popup'),\n *     });\n *     popup.setPosition(coordinate);\n *     map.addOverlay(popup);\n *\n * @api\n */\nclass Overlay extends BaseObject {\n  /**\n   * @param {Options} options Overlay options.\n   */\n  constructor(options) {\n    super();\n\n    /***\n     * @type {OverlayOnSignature<import(\"./events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {OverlayOnSignature<import(\"./events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {OverlayOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @protected\n     * @type {Options}\n     */\n    this.options = options;\n\n    /**\n     * @protected\n     * @type {number|string|undefined}\n     */\n    this.id = options.id;\n\n    /**\n     * @protected\n     * @type {boolean}\n     */\n    this.insertFirst =\n      options.insertFirst !== undefined ? options.insertFirst : true;\n\n    /**\n     * @protected\n     * @type {boolean}\n     */\n    this.stopEvent = options.stopEvent !== undefined ? options.stopEvent : true;\n\n    /**\n     * @protected\n     * @type {HTMLElement}\n     */\n    this.element = document.createElement('div');\n    this.element.className =\n      options.className !== undefined\n        ? options.className\n        : 'ol-overlay-container ' + CLASS_SELECTABLE;\n    this.element.style.position = 'absolute';\n    this.element.style.pointerEvents = 'auto';\n\n    /**\n     * @protected\n     * @type {PanIntoViewOptions|undefined}\n     */\n    this.autoPan = options.autoPan === true ? {} : options.autoPan || undefined;\n\n    /**\n     * @protected\n     * @type {{transform_: string,\n     *         visible: boolean}}\n     */\n    this.rendered = {\n      transform_: '',\n      visible: true,\n    };\n\n    /**\n     * @protected\n     * @type {?import(\"./events.js\").EventsKey}\n     */\n    this.mapPostrenderListenerKey = null;\n\n    this.addChangeListener(Property.ELEMENT, this.handleElementChanged);\n    this.addChangeListener(Property.MAP, this.handleMapChanged);\n    this.addChangeListener(Property.OFFSET, this.handleOffsetChanged);\n    this.addChangeListener(Property.POSITION, this.handlePositionChanged);\n    this.addChangeListener(Property.POSITIONING, this.handlePositioningChanged);\n\n    if (options.element !== undefined) {\n      this.setElement(options.element);\n    }\n\n    this.setOffset(options.offset !== undefined ? options.offset : [0, 0]);\n\n    this.setPositioning(options.positioning || 'top-left');\n\n    if (options.position !== undefined) {\n      this.setPosition(options.position);\n    }\n  }\n\n  /**\n   * Get the DOM element of this overlay.\n   * @return {HTMLElement|undefined} The Element containing the overlay.\n   * @observable\n   * @api\n   */\n  getElement() {\n    return /** @type {HTMLElement|undefined} */ (this.get(Property.ELEMENT));\n  }\n\n  /**\n   * Get the overlay identifier which is set on constructor.\n   * @return {number|string|undefined} Id.\n   * @api\n   */\n  getId() {\n    return this.id;\n  }\n\n  /**\n   * Get the map associated with this overlay.\n   * @return {import(\"./Map.js\").default|null} The map that the\n   * overlay is part of.\n   * @observable\n   * @api\n   */\n  getMap() {\n    return /** @type {import(\"./Map.js\").default|null} */ (\n      this.get(Property.MAP) || null\n    );\n  }\n\n  /**\n   * Get the offset of this overlay.\n   * @return {Array<number>} The offset.\n   * @observable\n   * @api\n   */\n  getOffset() {\n    return /** @type {Array<number>} */ (this.get(Property.OFFSET));\n  }\n\n  /**\n   * Get the current position of this overlay.\n   * @return {import(\"./coordinate.js\").Coordinate|undefined} The spatial point that the overlay is\n   *     anchored at.\n   * @observable\n   * @api\n   */\n  getPosition() {\n    return /** @type {import(\"./coordinate.js\").Coordinate|undefined} */ (\n      this.get(Property.POSITION)\n    );\n  }\n\n  /**\n   * Get the current positioning of this overlay.\n   * @return {Positioning} How the overlay is positioned\n   *     relative to its point on the map.\n   * @observable\n   * @api\n   */\n  getPositioning() {\n    return /** @type {Positioning} */ (this.get(Property.POSITIONING));\n  }\n\n  /**\n   * @protected\n   */\n  handleElementChanged() {\n    removeChildren(this.element);\n    const element = this.getElement();\n    if (element) {\n      this.element.appendChild(element);\n    }\n  }\n\n  /**\n   * @protected\n   */\n  handleMapChanged() {\n    if (this.mapPostrenderListenerKey) {\n      this.element?.remove();\n      unlistenByKey(this.mapPostrenderListenerKey);\n      this.mapPostrenderListenerKey = null;\n    }\n    const map = this.getMap();\n    if (map) {\n      this.mapPostrenderListenerKey = listen(\n        map,\n        MapEventType.POSTRENDER,\n        this.render,\n        this,\n      );\n      this.updatePixelPosition();\n      const container = this.stopEvent\n        ? map.getOverlayContainerStopEvent()\n        : map.getOverlayContainer();\n      if (this.insertFirst) {\n        container.insertBefore(this.element, container.childNodes[0] || null);\n      } else {\n        container.appendChild(this.element);\n      }\n      this.performAutoPan();\n    }\n  }\n\n  /**\n   * @protected\n   */\n  render() {\n    this.updatePixelPosition();\n  }\n\n  /**\n   * @protected\n   */\n  handleOffsetChanged() {\n    this.updatePixelPosition();\n  }\n\n  /**\n   * @protected\n   */\n  handlePositionChanged() {\n    this.updatePixelPosition();\n    this.performAutoPan();\n  }\n\n  /**\n   * @protected\n   */\n  handlePositioningChanged() {\n    this.updatePixelPosition();\n  }\n\n  /**\n   * Set the DOM element to be associated with this overlay.\n   * @param {HTMLElement|undefined} element The Element containing the overlay.\n   * @observable\n   * @api\n   */\n  setElement(element) {\n    this.set(Property.ELEMENT, element);\n  }\n\n  /**\n   * Set the map to be associated with this overlay.\n   * @param {import(\"./Map.js\").default|null} map The map that the\n   * overlay is part of. Pass `null` to just remove the overlay from the current map.\n   * @observable\n   * @api\n   */\n  setMap(map) {\n    this.set(Property.MAP, map);\n  }\n\n  /**\n   * Set the offset for this overlay.\n   * @param {Array<number>} offset Offset.\n   * @observable\n   * @api\n   */\n  setOffset(offset) {\n    this.set(Property.OFFSET, offset);\n  }\n\n  /**\n   * Set the position for this overlay. If the position is `undefined` the\n   * overlay is hidden.\n   * @param {import(\"./coordinate.js\").Coordinate|undefined} position The spatial point that the overlay\n   *     is anchored at.\n   * @observable\n   * @api\n   */\n  setPosition(position) {\n    this.set(Property.POSITION, position);\n  }\n\n  /**\n   * Pan the map so that the overlay is entirely visible in the current viewport\n   * (if necessary) using the configured autoPan parameters\n   * @protected\n   */\n  performAutoPan() {\n    if (this.autoPan) {\n      this.panIntoView(this.autoPan);\n    }\n  }\n\n  /**\n   * Pan the map so that the overlay is entirely visible in the current viewport\n   * (if necessary).\n   * @param {PanIntoViewOptions} [panIntoViewOptions] Options for the pan action\n   * @api\n   */\n  panIntoView(panIntoViewOptions) {\n    const map = this.getMap();\n\n    if (!map || !map.getTargetElement() || !this.get(Property.POSITION)) {\n      return;\n    }\n\n    const mapRect = this.getRect(map.getTargetElement(), map.getSize());\n    const element = this.getElement();\n    const overlayRect = this.getRect(element, [\n      outerWidth(element),\n      outerHeight(element),\n    ]);\n\n    panIntoViewOptions = panIntoViewOptions || {};\n\n    const myMargin =\n      panIntoViewOptions.margin === undefined ? 20 : panIntoViewOptions.margin;\n    if (!containsExtent(mapRect, overlayRect)) {\n      // the overlay is not completely inside the viewport, so pan the map\n      const offsetLeft = overlayRect[0] - mapRect[0];\n      const offsetRight = mapRect[2] - overlayRect[2];\n      const offsetTop = overlayRect[1] - mapRect[1];\n      const offsetBottom = mapRect[3] - overlayRect[3];\n\n      const delta = [0, 0];\n      if (offsetLeft < 0) {\n        // move map to the left\n        delta[0] = offsetLeft - myMargin;\n      } else if (offsetRight < 0) {\n        // move map to the right\n        delta[0] = Math.abs(offsetRight) + myMargin;\n      }\n      if (offsetTop < 0) {\n        // move map up\n        delta[1] = offsetTop - myMargin;\n      } else if (offsetBottom < 0) {\n        // move map down\n        delta[1] = Math.abs(offsetBottom) + myMargin;\n      }\n\n      if (delta[0] !== 0 || delta[1] !== 0) {\n        const center = /** @type {import(\"./coordinate.js\").Coordinate} */ (\n          map.getView().getCenterInternal()\n        );\n        const centerPx = map.getPixelFromCoordinateInternal(center);\n        if (!centerPx) {\n          return;\n        }\n        const newCenterPx = [centerPx[0] + delta[0], centerPx[1] + delta[1]];\n\n        const panOptions = panIntoViewOptions.animation || {};\n        map.getView().animateInternal({\n          center: map.getCoordinateFromPixelInternal(newCenterPx),\n          duration: panOptions.duration,\n          easing: panOptions.easing,\n        });\n      }\n    }\n  }\n\n  /**\n   * Get the extent of an element relative to the document\n   * @param {HTMLElement} element The element.\n   * @param {import(\"./size.js\").Size} size The size of the element.\n   * @return {import(\"./extent.js\").Extent} The extent.\n   * @protected\n   */\n  getRect(element, size) {\n    const box = element.getBoundingClientRect();\n    const offsetX = box.left + window.pageXOffset;\n    const offsetY = box.top + window.pageYOffset;\n    return [offsetX, offsetY, offsetX + size[0], offsetY + size[1]];\n  }\n\n  /**\n   * Set the positioning for this overlay.\n   * @param {Positioning} positioning how the overlay is\n   *     positioned relative to its point on the map.\n   * @observable\n   * @api\n   */\n  setPositioning(positioning) {\n    this.set(Property.POSITIONING, positioning);\n  }\n\n  /**\n   * Modify the visibility of the element.\n   * @param {boolean} visible Element visibility.\n   * @protected\n   */\n  setVisible(visible) {\n    if (this.rendered.visible !== visible) {\n      this.element.style.display = visible ? '' : 'none';\n      this.rendered.visible = visible;\n    }\n  }\n\n  /**\n   * Update pixel position.\n   * @protected\n   */\n  updatePixelPosition() {\n    const map = this.getMap();\n    const position = this.getPosition();\n    if (!map || !map.isRendered() || !position) {\n      this.setVisible(false);\n      return;\n    }\n\n    const pixel = map.getPixelFromCoordinate(position);\n    const mapSize = map.getSize();\n    this.updateRenderedPosition(pixel, mapSize);\n  }\n\n  /**\n   * @param {import(\"./pixel.js\").Pixel} pixel The pixel location.\n   * @param {import(\"./size.js\").Size|undefined} mapSize The map size.\n   * @protected\n   */\n  updateRenderedPosition(pixel, mapSize) {\n    const style = this.element.style;\n    const offset = this.getOffset();\n\n    const positioning = this.getPositioning();\n\n    this.setVisible(true);\n\n    const x = `${pixel[0] + offset[0]}px`;\n    const y = `${pixel[1] + offset[1]}px`;\n    let posX = '0%';\n    let posY = '0%';\n    if (\n      positioning == 'bottom-right' ||\n      positioning == 'center-right' ||\n      positioning == 'top-right'\n    ) {\n      posX = '-100%';\n    } else if (\n      positioning == 'bottom-center' ||\n      positioning == 'center-center' ||\n      positioning == 'top-center'\n    ) {\n      posX = '-50%';\n    }\n    if (\n      positioning == 'bottom-left' ||\n      positioning == 'bottom-center' ||\n      positioning == 'bottom-right'\n    ) {\n      posY = '-100%';\n    } else if (\n      positioning == 'center-left' ||\n      positioning == 'center-center' ||\n      positioning == 'center-right'\n    ) {\n      posY = '-50%';\n    }\n    const transform = `translate(${posX}, ${posY}) translate(${x}, ${y})`;\n    if (this.rendered.transform_ != transform) {\n      this.rendered.transform_ = transform;\n      style.transform = transform;\n    }\n  }\n\n  /**\n   * returns the options this Overlay has been created with\n   * @return {Options} overlay options\n   */\n  getOptions() {\n    return this.options;\n  }\n}\n\nexport default Overlay;\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/VectorRenderTile\n */\nimport Tile from './Tile.js';\nimport {createCanvasContext2D, releaseCanvas} from './dom.js';\nimport {getUid} from './util.js';\n\n/**\n * @typedef {Object} ReplayState\n * @property {boolean} dirty Dirty.\n * @property {null|import(\"./render.js\").OrderFunction} renderedRenderOrder RenderedRenderOrder.\n * @property {number} renderedTileRevision RenderedTileRevision.\n * @property {number} renderedResolution RenderedResolution.\n * @property {number} renderedPixelRatio RenderedPixelRatio.\n * @property {number} renderedRevision RenderedRevision.\n * @property {number} renderedTileResolution RenderedTileResolution.\n * @property {number} renderedTileZ RenderedTileZ.\n */\n\n/**\n * @type {Array<HTMLCanvasElement|OffscreenCanvas>}\n */\nconst canvasPool = [];\n\nclass VectorRenderTile extends Tile {\n  /**\n   * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n   * @param {import(\"./TileState.js\").default} state State.\n   * @param {import(\"./tilecoord.js\").TileCoord} urlTileCoord Wrapped tile coordinate for source urls.\n   * @param {function(VectorRenderTile):Array<import(\"./VectorTile.js\").default>} getSourceTiles Function.\n   * @param {function(VectorRenderTile):void} removeSourceTiles Function.\n   */\n  constructor(\n    tileCoord,\n    state,\n    urlTileCoord,\n    getSourceTiles,\n    removeSourceTiles,\n  ) {\n    super(tileCoord, state, {transition: 0});\n\n    /**\n     * @private\n     * @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D|null}\n     */\n    this.context_ = null;\n\n    /**\n     * Executor groups. Read/written by the renderer.\n     * @type {Object<string, Array<import(\"./render/canvas/ExecutorGroup.js\").default>>}\n     */\n    this.executorGroups = {};\n\n    /**\n     * Number of loading source tiles. Read/written by the source.\n     * @type {number}\n     */\n    this.loadingSourceTiles = 0;\n\n    /**\n     * @type {Object<string, ImageData>}\n     */\n    this.hitDetectionImageData = {};\n\n    /**\n     * @private\n     * @type {!Object<string, ReplayState>}\n     */\n    this.replayState_ = {};\n\n    /**\n     * @type {Array<import(\"./VectorTile.js\").default>}\n     */\n    this.sourceTiles = [];\n\n    /**\n     * @type {Object<string, boolean>}\n     */\n    this.errorTileKeys = {};\n\n    /**\n     * @type {number}\n     */\n    this.wantedResolution;\n\n    /**\n     * @type {!function():Array<import(\"./VectorTile.js\").default>}\n     */\n    this.getSourceTiles = getSourceTiles.bind(undefined, this);\n\n    /**\n     * @type {!function(VectorRenderTile):void}\n     * @private\n     */\n    this.removeSourceTiles_ = removeSourceTiles;\n\n    /**\n     * @type {import(\"./tilecoord.js\").TileCoord}\n     */\n    this.wrappedTileCoord = urlTileCoord;\n  }\n\n  /**\n   * @return {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} The rendering context.\n   */\n  getContext() {\n    if (!this.context_) {\n      this.context_ = createCanvasContext2D(1, 1, canvasPool);\n    }\n    return this.context_;\n  }\n\n  /**\n   * @return {boolean} Tile has a rendering context.\n   */\n  hasContext() {\n    return !!this.context_;\n  }\n\n  /**\n   * Get the Canvas for this tile.\n   * @return {HTMLCanvasElement|OffscreenCanvas} Canvas.\n   */\n  getImage() {\n    return this.hasContext() ? this.getContext().canvas : null;\n  }\n\n  /**\n   * @param {import(\"./layer/Layer.js\").default} layer Layer.\n   * @return {ReplayState} The replay state.\n   */\n  getReplayState(layer) {\n    const key = getUid(layer);\n    if (!(key in this.replayState_)) {\n      this.replayState_[key] = {\n        dirty: false,\n        renderedRenderOrder: null,\n        renderedResolution: NaN,\n        renderedPixelRatio: NaN,\n        renderedRevision: -1,\n        renderedTileResolution: NaN,\n        renderedTileRevision: -1,\n        renderedTileZ: -1,\n      };\n    }\n    return this.replayState_[key];\n  }\n\n  /**\n   * Load the tile.\n   * @override\n   */\n  load() {\n    this.getSourceTiles();\n  }\n\n  /**\n   * Remove from the cache due to expiry\n   * @override\n   */\n  release() {\n    if (this.context_) {\n      releaseCanvas(this.context_);\n      canvasPool.push(this.context_.canvas);\n      this.context_ = null;\n    }\n    this.removeSourceTiles_(this);\n    this.sourceTiles.length = 0;\n    super.release();\n  }\n}\n\nexport default VectorRenderTile;\n","/**\n * @module ol/featureloader\n */\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 3 arguments: an {@link module:ol/extent~Extent} representing\n * the area to be loaded, a `{number}` representing the resolution (map units per pixel), and a\n * {@link module:ol/proj/Projection~Projection} for the projection. The function is expeced to return\n * a promise that resolves to an array of features.\n *\n * There are also a deprecated signature, with `void` as\n * return, and two additional arguments: an optional success callback that should get\n * the loaded features passed as an argument and an optional failure callback with no arguments.\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\").FeatureLike]\n * @typedef {(\n *           extent: import(\"./extent.js\").Extent,\n *           resolution: number,\n *           projection: import(\"./proj/Projection.js\").default,\n *           success?: (features: Array<FeatureType>) => void,\n *           failure?: () => void) => void|Promise<Array<FeatureType>>} 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<FeatureType>} 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<FeatureType>, 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<FeatureType>} */\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 *\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<FeatureType>} format Feature format.\n * @return {FeatureLoader<FeatureType>} 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<FeatureType>): void} [success] Success\n   *      Function called when loading succeeded.\n   * @param {function(): void} [failure] Failure\n   *      Function called when loading failed.\n   * @this {import(\"./source/Vector.js\").default<FeatureType>}\n   */\n  return function (extent, resolution, projection, success, failure) {\n    loadFeaturesXhr(\n      url,\n      format,\n      extent,\n      resolution,\n      projection,\n      /**\n       * @param {Array<FeatureType>} features The loaded features.\n       * @param {import(\"./proj/Projection.js\").default} dataProjection Data\n       * projection.\n       */\n      (features, dataProjection) => {\n        this.addFeatures(features);\n        if (success !== undefined) {\n          success(features);\n        }\n      },\n      () => {\n        this.changed();\n        if (failure !== undefined) {\n          failure();\n        }\n      },\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/net\n */\nimport {getUid} from './util.js';\n\n/**\n * Simple JSONP helper. Supports error callbacks and a custom callback param.\n * The error callback will be called when no JSONP is executed after 10 seconds.\n *\n * @param {string} url Request url. A 'callback' query parameter will be\n *     appended.\n * @param {Function} callback Callback on success.\n * @param {Function} [errback] Callback on error.\n * @param {string} [callbackParam] Custom query parameter for the JSONP\n *     callback. Default is 'callback'.\n */\nexport function jsonp(url, callback, errback, callbackParam) {\n  const script = document.createElement('script');\n  const key = 'olc_' + getUid(callback);\n  function cleanup() {\n    delete window[key];\n    script.parentNode.removeChild(script);\n  }\n  script.async = true;\n  script.src =\n    url +\n    (url.includes('?') ? '&' : '?') +\n    (callbackParam || 'callback') +\n    '=' +\n    key;\n  const timer = setTimeout(function () {\n    cleanup();\n    if (errback) {\n      errback();\n    }\n  }, 10000);\n  window[key] = function (data) {\n    clearTimeout(timer);\n    cleanup();\n    callback(data);\n  };\n  document.head.appendChild(script);\n}\n\nexport class ResponseError extends Error {\n  /**\n   * @param {XMLHttpRequest} response The XHR object.\n   */\n  constructor(response) {\n    const message = 'Unexpected response status: ' + response.status;\n    super(message);\n\n    /**\n     * @type {string}\n     */\n    this.name = 'ResponseError';\n\n    /**\n     * @type {XMLHttpRequest}\n     */\n    this.response = response;\n  }\n}\n\nexport class ClientError extends Error {\n  /**\n   * @param {XMLHttpRequest} client The XHR object.\n   */\n  constructor(client) {\n    super('Failed to issue request');\n\n    /**\n     * @type {string}\n     */\n    this.name = 'ClientError';\n\n    /**\n     * @type {XMLHttpRequest}\n     */\n    this.client = client;\n  }\n}\n\n/**\n * @param {string} url The URL.\n * @return {Promise<Object>} A promise that resolves to the JSON response.\n */\nexport function getJSON(url) {\n  return new Promise(function (resolve, reject) {\n    /**\n     * @param {ProgressEvent<XMLHttpRequest>} event The load event.\n     */\n    function onLoad(event) {\n      const client = event.target;\n      // status will be 0 for file:// urls\n      if (!client.status || (client.status >= 200 && client.status < 300)) {\n        let data;\n        try {\n          data = JSON.parse(client.responseText);\n        } catch (err) {\n          const message = 'Error parsing response text as JSON: ' + err.message;\n          reject(new Error(message));\n          return;\n        }\n        resolve(data);\n        return;\n      }\n\n      reject(new ResponseError(client));\n    }\n\n    /**\n     * @param {ProgressEvent<XMLHttpRequest>} event The error event.\n     */\n    function onError(event) {\n      reject(new ClientError(event.target));\n    }\n\n    const client = new XMLHttpRequest();\n    client.addEventListener('load', onLoad);\n    client.addEventListener('error', onError);\n    client.open('GET', url);\n    client.setRequestHeader('Accept', 'application/json');\n    client.send();\n  });\n}\n\n/**\n * @param {string} base The base URL.\n * @param {string} url The potentially relative URL.\n * @return {string} The full URL.\n */\nexport function resolveUrl(base, url) {\n  if (url.includes('://')) {\n    return url;\n  }\n  return new URL(url, base).href;\n}\n\nlet originalXHR;\nexport function overrideXHR(xhr) {\n  if (typeof XMLHttpRequest !== 'undefined') {\n    originalXHR = XMLHttpRequest;\n  }\n  globalThis.XMLHttpRequest = xhr;\n}\n\nexport function restoreXHR() {\n  globalThis.XMLHttpRequest = originalXHR;\n}\n","/**\n * @module ol/loadingstrategy\n */\n\nimport {fromUserExtent, fromUserResolution, toUserExtent} from './proj.js';\n\n/**\n * Strategy function for loading all features with a single request.\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number} resolution Resolution.\n * @return {Array<import(\"./extent.js\").Extent>} Extents.\n * @api\n */\nexport function all(extent, resolution) {\n  return [[-Infinity, -Infinity, Infinity, Infinity]];\n}\n\n/**\n * Strategy function for loading features based on the view's extent and\n * resolution.\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number} resolution Resolution.\n * @return {Array<import(\"./extent.js\").Extent>} Extents.\n * @api\n */\nexport function bbox(extent, resolution) {\n  return [extent];\n}\n\n/**\n * Creates a strategy function for loading features based on a tile grid.\n * @param {import(\"./tilegrid/TileGrid.js\").default} tileGrid Tile grid.\n * @return {function(import(\"./extent.js\").Extent, number, import(\"./proj.js\").Projection): Array<import(\"./extent.js\").Extent>} Loading strategy.\n * @api\n */\nexport function tile(tileGrid) {\n  return (\n    /**\n     * @param {import(\"./extent.js\").Extent} extent Extent.\n     * @param {number} resolution Resolution.\n     * @param {import(\"./proj.js\").Projection} projection Projection.\n     * @return {Array<import(\"./extent.js\").Extent>} Extents.\n     */\n    function (extent, resolution, projection) {\n      const z = tileGrid.getZForResolution(\n        fromUserResolution(resolution, projection),\n      );\n      const tileRange = tileGrid.getTileRangeForExtentAndZ(\n        fromUserExtent(extent, projection),\n        z,\n      );\n      /** @type {Array<import(\"./extent.js\").Extent>} */\n      const extents = [];\n      /** @type {import(\"./tilecoord.js\").TileCoord} */\n      const tileCoord = [z, 0, 0];\n      for (\n        tileCoord[1] = tileRange.minX;\n        tileCoord[1] <= tileRange.maxX;\n        ++tileCoord[1]\n      ) {\n        for (\n          tileCoord[2] = tileRange.minY;\n          tileCoord[2] <= tileRange.maxY;\n          ++tileCoord[2]\n        ) {\n          extents.push(\n            toUserExtent(tileGrid.getTileCoordExtent(tileCoord), projection),\n          );\n        }\n      }\n      return extents;\n    }\n  );\n}\n","import {angleBetween} from '../../coordinate.js';\n\n/**\n * Offsets a line string to the left / right along its segments direction.\n * Offset is applied to each segment of the line in the direciton of the segment normal (positive offset goes \"right\" relative to the line direction).\n * For very sharp angles between segments, the function falls back to offsetting along the segment normal direction to avoid excessively long miters.\n *\n * Coordinates and the offset should be in the same units — either pixels or the same spatial reference system as the input line coordinates.\n *\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} start Start index.\n * @param {number} end End index.\n * @param {number} stride Stride.\n * @param {number} offset Offset distance along the segment normal direction.\n *   Positive values offset to the right relative to the direction of the line.\n *   Negative values offset to the left.\n * @param {boolean} isClosedRing If coordinates build a closed circle (in this the first and the last coordinate offsets will consider previous / next ring coordinate)\n * @param {Array<number>} [dest] Destination coordinate array. If not provided a new one will be created\n * @param {number} [destinationStride] Stride of destination coordinates. If unspecified, assumed to be same as the source coordinates stride.\n * @return {Array<number>} Result flat coordinates of the offset line.\n */\nexport function offsetLineString(\n  flatCoordinates,\n  start,\n  end,\n  stride,\n  offset,\n  isClosedRing,\n  dest,\n  destinationStride,\n) {\n  dest = dest ?? [];\n  destinationStride = destinationStride ?? stride;\n\n  const secondPointX = flatCoordinates[start + stride];\n  const secondPointY = flatCoordinates[start + stride + 1];\n  const secondToLastPointX = flatCoordinates[end - 2 * stride];\n  const secondToLastPointY = flatCoordinates[end - 2 * stride + 1];\n  let x, y, prevX, prevY, nextX, nextY, offsetX, offsetY;\n\n  let i = 0;\n  for (let j = start; j < end; j += stride) {\n    // 1. Detect previous and next coordinates of a current vertex\n    prevX = x;\n    prevY = y;\n    nextX = undefined;\n    nextY = undefined;\n    if (j + stride < end) {\n      nextX = flatCoordinates[j + stride];\n      nextY = flatCoordinates[j + stride + 1];\n    }\n    // First coordinate of a closed ring -> previous coordinate is the second to last one\n    if (isClosedRing && j === start) {\n      prevX = secondToLastPointX;\n      prevY = secondToLastPointY;\n    }\n    // Last coordinate of a closed ring -> next coordinate is the second vertex of a line string (the last one is same as the first one for a closed ring)\n    if (isClosedRing && j === end - stride) {\n      nextX = secondPointX;\n      nextY = secondPointY;\n    }\n\n    // 2. Current vertex to offset\n    x = flatCoordinates[j];\n    y = flatCoordinates[j + 1];\n\n    // 3. Offset the vertex\n    [offsetX, offsetY] = offsetLineVertex(\n      x,\n      y,\n      prevX,\n      prevY,\n      nextX,\n      nextY,\n      offset,\n    );\n    dest[i++] = offsetX;\n    dest[i++] = offsetY;\n\n    // 4. Copy over other dimension values if any\n    for (let k = 2; k < destinationStride; k++) {\n      dest[i++] = flatCoordinates[j + k];\n    }\n  }\n\n  if (dest.length != i) {\n    dest.length = i;\n  }\n  return dest;\n}\n\n/**\n * Computes the offset of a single vertex of a line string.\n *\n * The function calculates a new vertex coordinate offset along the normal/miter direction of the line at this vertex.\n * Offset is applied along the segment normal (positive offset goes \"right\" relative to the line direction).\n * It handles first and last vertices (caps) as well as joins between two segments (mitering).\n * For very sharp angles, the function falls back to offsetting along the segment normal direction to avoid excessively long miters.\n *\n * Coordinates and the offset should be in the same units — either pixels or the same spatial reference system as the input line coordinates.\n *\n * @param {number} x Vertex x-coordinate.\n * @param {number} y Vertex y-coordinate.\n * @param {number|undefined} prevX Previous vertex x-coordinate.\n *   Pass undefined if computing the offset for the first vertex (no previous vertex).\n * @param {number|undefined} prevY Previous vertex y-coordinate.\n *   Pass undefined if computing the offset for the first vertex (no previous vertex).\n * @param {number|undefined} nextX Next vertex x-coordinate.\n *   Pass undefined if computing the offset for the last vertex (no next vertex).\n * @param {number|undefined} nextY Next vertex y-coordinate.\n *   Pass undefined if computing the offset for the last vertex (no next vertex).\n * @param {number} offset Offset distance along the segment normal direction.\n *   Positive values offset to the right relative to the direction from previous to next vertex.\n *   Negative values offset to the left.\n * @return {import(\"../../coordinate.js\").Coordinate} Offset vertex coordinate as `[x, y]`.\n */\nfunction offsetLineVertex(x, y, prevX, prevY, nextX, nextY, offset) {\n  // Compute segment direction\n  let nx, ny;\n  if (prevX !== undefined && prevY !== undefined) {\n    nx = x - prevX;\n    ny = y - prevY;\n  } else if (nextX !== undefined && nextY !== undefined) {\n    nx = nextX - x;\n    ny = nextY - y;\n  } else {\n    // no next, no previous point given -> just assume some default (horizontal) direction\n    nx = 1;\n    ny = 0;\n  }\n\n  // Normalize -> tangent\n  const len = Math.hypot(nx, ny);\n  const tx = nx / len;\n  const ty = ny / len;\n\n  // Rotate tangent 90° -> normal\n  nx = -ty;\n  ny = tx;\n\n  // First / last vertex -> offset the point in the direction of the normal vector\n  if (prevX === undefined || prevY === undefined) {\n    return [x + nx * offset, y + ny * offset];\n  }\n  if (nextX === undefined || nextY === undefined) {\n    return [x + nx * offset, y + ny * offset];\n  }\n\n  // Compute join angle - angle between 2 segments of the vertex.\n  const joinAngle = angleBetween([x, y], [prevX, prevY], [nextX, nextY]);\n\n  // Avoid huge or infinite miter joins for very sharp angles, offset in the segment direction in this case.\n  if (Math.cos(joinAngle) > 0.998) {\n    return [x + tx * offset, y + ty * offset];\n  }\n\n  // Compute join offset direction.\n  // We rotate the normal vector by half of the join angle.\n  // This gives the direction of the miter at the vertex.\n  const cos = Math.cos(joinAngle / 2);\n  const sin = Math.sin(joinAngle / 2);\n\n  // Rotate the normal vector (nx, ny) by half of the join angle.\n  // bx/by = bisector direction before normalization\n  const bx = sin * nx + cos * ny;\n  const by = -cos * nx + sin * ny;\n\n  // Scale the bisector so that moving along it preserves the correct offset distance.\n  // Dividing by sin(half of angle) converts the bisector into the true miter vector.\n  // (This expands the miter for sharp angles and shortens it for wide ones.)\n  const dx = bx * (1 / sin);\n  const dy = by * (1 / sin);\n\n  // Offset final vertex along miter direction\n  return [x + dx * offset, y + dy * offset];\n}\n\n/**\n * Removes self-intersection loops (cycles) from an offset line.\n * When a polyline is offset, sharp turns can create self-intersecting loops.\n * This function detects those crossings and splices out the looped portions,\n * replacing them with the intersection point.\n *\n * @param {Array<number>} coords Flat offset coordinates (modified in-place).\n * @param {number} stride Coordinate stride (typically 2).\n * @return {Array<number>} The cleaned coordinate array.\n */\nexport function removeOffsetCycles(coords, stride) {\n  for (let i = 0, ii = coords.length - 2; i < ii; i += stride) {\n    for (let j = coords.length - 2 * stride; j > i + stride; j -= stride) {\n      const p1x = coords[i];\n      const p1y = coords[i + 1];\n      const p2x = coords[i + stride];\n      const p2y = coords[i + stride + 1];\n      const p3x = coords[j];\n      const p3y = coords[j + 1];\n      const p4x = coords[j + stride];\n      const p4y = coords[j + stride + 1];\n      const d = (p4y - p3y) * (p2x - p1x) - (p4x - p3x) * (p2y - p1y);\n      if (d === 0) {\n        continue;\n      }\n      const t = ((p4x - p3x) * (p1y - p3y) - (p4y - p3y) * (p1x - p3x)) / d;\n      const u = ((p2x - p1x) * (p1y - p3y) - (p2y - p1y) * (p1x - p3x)) / d;\n      if (t > 0 && t < 1 && u > 0 && u < 1) {\n        const ix = p1x + t * (p2x - p1x);\n        const iy = p1y + t * (p2y - p1y);\n        coords[i + stride] = ix;\n        coords[i + stride + 1] = iy;\n        coords.splice(i + 2 * stride, j - i - stride);\n        break;\n      }\n    }\n  }\n  return coords;\n}\n","/**\n * @module ol/render/VectorContext\n */\n\n/**\n * @classdesc\n * Context for drawing geometries.  A vector context is available on render\n * events and does not need to be constructed directly.\n * @api\n */\nclass VectorContext {\n  /**\n   * Render a geometry with a custom renderer.\n   *\n   * @param {import(\"../geom/SimpleGeometry.js\").default} geometry Geometry.\n   * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n   * @param {Function} renderer Renderer.\n   * @param {Function} hitDetectionRenderer Renderer.\n   * @param {number} [index] Render order index.\n   */\n  drawCustom(geometry, feature, renderer, hitDetectionRenderer, index) {}\n\n  /**\n   * Render a geometry.\n   *\n   * @param {import(\"../geom/Geometry.js\").default} geometry The geometry to render.\n   */\n  drawGeometry(geometry) {}\n\n  /**\n   * Set the rendering style.\n   *\n   * @param {import(\"../style/Style.js\").default} style The rendering style.\n   */\n  setStyle(style) {}\n\n  /**\n   * @param {import(\"../geom/Circle.js\").default} circleGeometry Circle geometry.\n   * @param {import(\"../Feature.js\").default} feature Feature.\n   * @param {number} [index] Render order index.\n   */\n  drawCircle(circleGeometry, feature, index) {}\n\n  /**\n   * @param {import(\"../Feature.js\").default} feature Feature.\n   * @param {import(\"../style/Style.js\").default} style Style.\n   * @param {number} [index] Render order index.\n   */\n  drawFeature(feature, style, index) {}\n\n  /**\n   * @param {import(\"../geom/GeometryCollection.js\").default} geometryCollectionGeometry Geometry collection.\n   * @param {import(\"../Feature.js\").default} feature Feature.\n   * @param {number} [index] Render order index.\n   */\n  drawGeometryCollection(geometryCollectionGeometry, feature, index) {}\n\n  /**\n   * @param {import(\"../geom/LineString.js\").default|import(\"./Feature.js\").default} lineStringGeometry Line string geometry.\n   * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} [index] Render order index.\n   */\n  drawLineString(lineStringGeometry, feature, index) {}\n\n  /**\n   * @param {import(\"../geom/MultiLineString.js\").default|import(\"./Feature.js\").default} multiLineStringGeometry MultiLineString geometry.\n   * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} [index] Render order index.\n   */\n  drawMultiLineString(multiLineStringGeometry, feature, index) {}\n\n  /**\n   * @param {import(\"../geom/MultiPoint.js\").default|import(\"./Feature.js\").default} multiPointGeometry MultiPoint geometry.\n   * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} [index] Render order index.\n   */\n  drawMultiPoint(multiPointGeometry, feature, index) {}\n\n  /**\n   * @param {import(\"../geom/MultiPolygon.js\").default} multiPolygonGeometry MultiPolygon geometry.\n   * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} [index] Render order index.\n   */\n  drawMultiPolygon(multiPolygonGeometry, feature, index) {}\n\n  /**\n   * @param {import(\"../geom/Point.js\").default|import(\"./Feature.js\").default} pointGeometry Point geometry.\n   * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} [index] Render order index.\n   */\n  drawPoint(pointGeometry, feature, index) {}\n\n  /**\n   * @param {import(\"../geom/Polygon.js\").default|import(\"./Feature.js\").default} polygonGeometry Polygon geometry.\n   * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} [index] Render order index.\n   */\n  drawPolygon(polygonGeometry, feature, index) {}\n\n  /**\n   * @param {import(\"../geom/SimpleGeometry.js\").default|import(\"./Feature.js\").default} geometry Geometry.\n   * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} [index] Render order index.\n   */\n  drawText(geometry, feature, index) {}\n\n  /**\n   * @param {import(\"../style/Fill.js\").default} fillStyle Fill style.\n   * @param {import(\"../style/Stroke.js\").default} strokeStyle Stroke style.\n   */\n  setFillStrokeStyle(fillStyle, strokeStyle) {}\n\n  /**\n   * @param {import(\"../style/Image.js\").default} imageStyle Image style.\n   * @param {import(\"../render/canvas.js\").DeclutterImageWithText} [declutterImageWithText] Shared data for combined decluttering with a text style.\n   */\n  setImageStyle(imageStyle, declutterImageWithText) {}\n\n  /**\n   * @param {import(\"../style/Text.js\").default} textStyle Text style.\n   * @param {import(\"../render/canvas.js\").DeclutterImageWithText} [declutterImageWithText] Shared data for combined decluttering with an image style.\n   */\n  setTextStyle(textStyle, declutterImageWithText) {}\n}\n\nexport default VectorContext;\n","/**\n * @module ol/render/canvas/Immediate\n */\n// FIXME test, especially polygons with holes and multipolygons\n// FIXME need to handle large thick features (where pixel size matters)\n// FIXME add offset and end to ol/geom/flat/transform~transform2D?\n\nimport {equals} from '../../array.js';\nimport {asColorLike} from '../../colorlike.js';\nimport {intersects} from '../../extent.js';\nimport {transformGeom2D} from '../../geom/SimpleGeometry.js';\nimport {\n  offsetLineString,\n  removeOffsetCycles,\n} from '../../geom/flat/lineoffset.js';\nimport {transform2D} from '../../geom/flat/transform.js';\nimport {toFixed} from '../../math.js';\nimport {\n  compose as composeTransform,\n  create as createTransform,\n} from '../../transform.js';\nimport VectorContext from '../VectorContext.js';\nimport {\n  defaultFillStyle,\n  defaultFont,\n  defaultLineCap,\n  defaultLineDash,\n  defaultLineDashOffset,\n  defaultLineJoin,\n  defaultLineWidth,\n  defaultMiterLimit,\n  defaultStrokeStyle,\n  defaultTextAlign,\n  defaultTextBaseline,\n} from '../canvas.js';\n\n/**\n * @classdesc\n * A concrete subclass of {@link module:ol/render/VectorContext~VectorContext} that implements\n * direct rendering of features and geometries to an HTML5 Canvas context.\n * Instances of this class are created internally by the library and\n * provided to application code as vectorContext member of the\n * {@link module:ol/render/Event~RenderEvent} object associated with postcompose, precompose and\n * render events emitted by layers and maps.\n */\nclass CanvasImmediateRenderer extends VectorContext {\n  /**\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context Context.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../../extent.js\").Extent} extent Extent.\n   * @param {import(\"../../transform.js\").Transform} transform Transform.\n   * @param {number} viewRotation View rotation.\n   * @param {number} [squaredTolerance] Optional squared tolerance for simplification.\n   * @param {import(\"../../proj.js\").TransformFunction} [userTransform] Transform from user to view projection.\n   */\n  constructor(\n    context,\n    pixelRatio,\n    extent,\n    transform,\n    viewRotation,\n    squaredTolerance,\n    userTransform,\n  ) {\n    super();\n\n    /**\n     * @private\n     * @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D}\n     */\n    this.context_ = context;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.pixelRatio_ = pixelRatio;\n\n    /**\n     * @private\n     * @type {import(\"../../extent.js\").Extent}\n     */\n    this.extent_ = extent;\n\n    /**\n     * @private\n     * @type {import(\"../../transform.js\").Transform}\n     */\n    this.transform_ = transform;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.transformRotation_ = transform\n      ? toFixed(Math.atan2(transform[1], transform[0]), 10)\n      : 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.viewRotation_ = viewRotation;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.squaredTolerance_ = squaredTolerance;\n\n    /**\n     * @private\n     * @type {import(\"../../proj.js\").TransformFunction}\n     */\n    this.userTransform_ = userTransform;\n\n    /**\n     * @private\n     * @type {?import(\"../canvas.js\").FillState}\n     */\n    this.contextFillState_ = null;\n\n    /**\n     * @private\n     * @type {?import(\"../canvas.js\").StrokeState}\n     */\n    this.contextStrokeState_ = null;\n\n    /**\n     * @private\n     * @type {?import(\"../canvas.js\").TextState}\n     */\n    this.contextTextState_ = null;\n\n    /**\n     * @private\n     * @type {?import(\"../canvas.js\").FillState}\n     */\n    this.fillState_ = null;\n\n    /**\n     * @private\n     * @type {?import(\"../canvas.js\").StrokeState}\n     */\n    this.strokeState_ = null;\n\n    /**\n     * @private\n     * @type {import('../../DataTile.js').ImageLike}\n     */\n    this.image_ = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.imageAnchorX_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.imageAnchorY_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.imageHeight_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.imageOpacity_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.imageOriginX_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.imageOriginY_ = 0;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.imageRotateWithView_ = false;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.imageRotation_ = 0;\n\n    /**\n     * @private\n     * @type {import(\"../../size.js\").Size}\n     */\n    this.imageScale_ = [0, 0];\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.imageWidth_ = 0;\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.text_ = '';\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.textOffsetX_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.textOffsetY_ = 0;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.textRotateWithView_ = false;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.textRotation_ = 0;\n\n    /**\n     * @private\n     * @type {import(\"../../size.js\").Size}\n     */\n    this.textScale_ = [0, 0];\n\n    /**\n     * @private\n     * @type {?import(\"../canvas.js\").FillState}\n     */\n    this.textFillState_ = null;\n\n    /**\n     * @private\n     * @type {?import(\"../canvas.js\").StrokeState}\n     */\n    this.textStrokeState_ = null;\n\n    /**\n     * @private\n     * @type {?import(\"../canvas.js\").TextState}\n     */\n    this.textState_ = null;\n\n    /**\n     * @private\n     * @type {Array<number>}\n     */\n    this.pixelCoordinates_ = [];\n\n    /**\n     * @private\n     * @type {import(\"../../transform.js\").Transform}\n     */\n    this.tmpLocalTransform_ = createTransform();\n  }\n\n  /**\n   * @param {Array<number>} flatCoordinates Flat coordinates.\n   * @param {number} offset Offset.\n   * @param {number} end End.\n   * @param {number} stride Stride.\n   * @private\n   */\n  drawImages_(flatCoordinates, offset, end, stride) {\n    if (!this.image_) {\n      return;\n    }\n    const pixelCoordinates = transform2D(\n      flatCoordinates,\n      offset,\n      end,\n      stride,\n      this.transform_,\n      this.pixelCoordinates_,\n    );\n    const context = this.context_;\n    const localTransform = this.tmpLocalTransform_;\n    const alpha = context.globalAlpha;\n    if (this.imageOpacity_ != 1) {\n      context.globalAlpha = alpha * this.imageOpacity_;\n    }\n    let rotation = this.imageRotation_;\n    if (this.transformRotation_ === 0) {\n      rotation -= this.viewRotation_;\n    }\n    if (this.imageRotateWithView_) {\n      rotation += this.viewRotation_;\n    }\n    for (let i = 0, ii = pixelCoordinates.length; i < ii; i += 2) {\n      const x = pixelCoordinates[i] - this.imageAnchorX_;\n      const y = pixelCoordinates[i + 1] - this.imageAnchorY_;\n      if (\n        rotation !== 0 ||\n        this.imageScale_[0] != 1 ||\n        this.imageScale_[1] != 1\n      ) {\n        const centerX = x + this.imageAnchorX_;\n        const centerY = y + this.imageAnchorY_;\n        composeTransform(\n          localTransform,\n          centerX,\n          centerY,\n          1,\n          1,\n          rotation,\n          -centerX,\n          -centerY,\n        );\n        context.save();\n        context.transform.apply(context, localTransform);\n        context.translate(centerX, centerY);\n        context.scale(this.imageScale_[0], this.imageScale_[1]);\n        context.drawImage(\n          this.image_,\n          this.imageOriginX_,\n          this.imageOriginY_,\n          this.imageWidth_,\n          this.imageHeight_,\n          -this.imageAnchorX_,\n          -this.imageAnchorY_,\n          this.imageWidth_,\n          this.imageHeight_,\n        );\n        context.restore();\n      } else {\n        context.drawImage(\n          this.image_,\n          this.imageOriginX_,\n          this.imageOriginY_,\n          this.imageWidth_,\n          this.imageHeight_,\n          x,\n          y,\n          this.imageWidth_,\n          this.imageHeight_,\n        );\n      }\n    }\n    if (this.imageOpacity_ != 1) {\n      context.globalAlpha = alpha;\n    }\n  }\n\n  /**\n   * @param {Array<number>} flatCoordinates Flat coordinates.\n   * @param {number} offset Offset.\n   * @param {number} end End.\n   * @param {number} stride Stride.\n   * @private\n   */\n  drawText_(flatCoordinates, offset, end, stride) {\n    if (!this.textState_ || this.text_ === '') {\n      return;\n    }\n    if (this.textFillState_) {\n      this.setContextFillState_(this.textFillState_);\n    }\n    if (this.textStrokeState_) {\n      this.setContextStrokeState_(this.textStrokeState_);\n    }\n    this.setContextTextState_(this.textState_);\n    const pixelCoordinates = transform2D(\n      flatCoordinates,\n      offset,\n      end,\n      stride,\n      this.transform_,\n      this.pixelCoordinates_,\n    );\n    const context = this.context_;\n    let rotation = this.textRotation_;\n    if (this.transformRotation_ === 0) {\n      rotation -= this.viewRotation_;\n    }\n    if (this.textRotateWithView_) {\n      rotation += this.viewRotation_;\n    }\n    for (; offset < end; offset += stride) {\n      const x = pixelCoordinates[offset] + this.textOffsetX_;\n      const y = pixelCoordinates[offset + 1] + this.textOffsetY_;\n      if (\n        rotation !== 0 ||\n        this.textScale_[0] != 1 ||\n        this.textScale_[1] != 1\n      ) {\n        context.save();\n        context.translate(x - this.textOffsetX_, y - this.textOffsetY_);\n        context.rotate(rotation);\n        context.translate(this.textOffsetX_, this.textOffsetY_);\n        context.scale(this.textScale_[0], this.textScale_[1]);\n        if (this.textStrokeState_) {\n          context.strokeText(this.text_, 0, 0);\n        }\n        if (this.textFillState_) {\n          context.fillText(this.text_, 0, 0);\n        }\n        context.restore();\n      } else {\n        if (this.textStrokeState_) {\n          context.strokeText(this.text_, x, y);\n        }\n        if (this.textFillState_) {\n          context.fillText(this.text_, x, y);\n        }\n      }\n    }\n  }\n\n  /**\n   * @param {Array<number>} flatCoordinates Flat coordinates.\n   * @param {number} offset Offset.\n   * @param {number} end End.\n   * @param {number} stride Stride.\n   * @param {boolean} close Close.\n   * @param {number} [strokeOffset] Stroke Offset.\n   * @private\n   * @return {number} end End.\n   */\n  moveToLineTo_(flatCoordinates, offset, end, stride, close, strokeOffset) {\n    const context = this.context_;\n    let pixelCoordinates = transform2D(\n      flatCoordinates,\n      offset,\n      end,\n      stride,\n      this.transform_,\n      this.pixelCoordinates_,\n    );\n    if (Math.abs(strokeOffset) > 0) {\n      pixelCoordinates = offsetLineString(\n        pixelCoordinates,\n        0,\n        pixelCoordinates.length,\n        2,\n        strokeOffset,\n        close,\n        pixelCoordinates,\n      );\n      removeOffsetCycles(pixelCoordinates, 2);\n    }\n    context.moveTo(pixelCoordinates[0], pixelCoordinates[1]);\n    let length = pixelCoordinates.length;\n    if (close) {\n      length -= 2;\n    }\n    for (let i = 2; i < length; i += 2) {\n      context.lineTo(pixelCoordinates[i], pixelCoordinates[i + 1]);\n    }\n    if (close) {\n      context.closePath();\n    }\n    return end;\n  }\n\n  /**\n   * @param {Array<number>} flatCoordinates Flat coordinates.\n   * @param {number} offset Offset.\n   * @param {Array<number>} ends Ends.\n   * @param {number} stride Stride.\n   * @param {number} [strokeOffset] Stroke Offset.\n   * @private\n   * @return {number} End.\n   */\n  drawRings_(flatCoordinates, offset, ends, stride, strokeOffset) {\n    for (let i = 0, ii = ends.length; i < ii; ++i) {\n      offset = this.moveToLineTo_(\n        flatCoordinates,\n        offset,\n        ends[i],\n        stride,\n        true,\n        strokeOffset,\n      );\n    }\n    return offset;\n  }\n\n  /**\n   * Render a circle geometry into the canvas.  Rendering is immediate and uses\n   * the current fill and stroke styles.\n   *\n   * @param {import(\"../../geom/Circle.js\").default} geometry Circle geometry.\n   * @api\n   * @override\n   */\n  drawCircle(geometry) {\n    if (this.squaredTolerance_) {\n      geometry = /** @type {import(\"../../geom/Circle.js\").default} */ (\n        geometry.simplifyTransformed(\n          this.squaredTolerance_,\n          this.userTransform_,\n        )\n      );\n    }\n    if (!intersects(this.extent_, geometry.getExtent())) {\n      return;\n    }\n    if (this.fillState_ || this.strokeState_) {\n      if (this.fillState_) {\n        this.setContextFillState_(this.fillState_);\n      }\n      if (this.strokeState_) {\n        this.setContextStrokeState_(this.strokeState_);\n      }\n      const pixelCoordinates = transformGeom2D(\n        geometry,\n        this.transform_,\n        this.pixelCoordinates_,\n      );\n      const dx = pixelCoordinates[2] - pixelCoordinates[0];\n      const dy = pixelCoordinates[3] - pixelCoordinates[1];\n      const radius = Math.sqrt(dx * dx + dy * dy);\n      const context = this.context_;\n      context.beginPath();\n      context.arc(\n        pixelCoordinates[0],\n        pixelCoordinates[1],\n        radius,\n        0,\n        2 * Math.PI,\n      );\n      if (this.fillState_) {\n        context.fill();\n      }\n      if (this.strokeState_) {\n        context.stroke();\n      }\n    }\n    if (this.text_ !== '') {\n      this.drawText_(geometry.getCenter(), 0, 2, 2);\n    }\n  }\n\n  /**\n   * Set the rendering style.  Note that since this is an immediate rendering API,\n   * any `zIndex` on the provided style will be ignored.\n   *\n   * @param {import(\"../../style/Style.js\").default} style The rendering style.\n   * @api\n   * @override\n   */\n  setStyle(style) {\n    this.setFillStrokeStyle(style.getFill(), style.getStroke());\n    this.setImageStyle(style.getImage());\n    this.setTextStyle(style.getText());\n  }\n\n  /**\n   * @param {import(\"../../transform.js\").Transform} transform Transform.\n   */\n  setTransform(transform) {\n    this.transform_ = transform;\n  }\n\n  /**\n   * Render a geometry into the canvas.  Call\n   * {@link module:ol/render/canvas/Immediate~CanvasImmediateRenderer#setStyle renderer.setStyle()} first to set the rendering style.\n   *\n   * @param {import(\"../../geom/Geometry.js\").default|import(\"../Feature.js\").default} geometry The geometry to render.\n   * @api\n   * @override\n   */\n  drawGeometry(geometry) {\n    const type = geometry.getType();\n    switch (type) {\n      case 'Point':\n        this.drawPoint(\n          /** @type {import(\"../../geom/Point.js\").default} */ (geometry),\n        );\n        break;\n      case 'LineString':\n        this.drawLineString(\n          /** @type {import(\"../../geom/LineString.js\").default} */ (geometry),\n        );\n        break;\n      case 'Polygon':\n        this.drawPolygon(\n          /** @type {import(\"../../geom/Polygon.js\").default} */ (geometry),\n        );\n        break;\n      case 'MultiPoint':\n        this.drawMultiPoint(\n          /** @type {import(\"../../geom/MultiPoint.js\").default} */ (geometry),\n        );\n        break;\n      case 'MultiLineString':\n        this.drawMultiLineString(\n          /** @type {import(\"../../geom/MultiLineString.js\").default} */ (\n            geometry\n          ),\n        );\n        break;\n      case 'MultiPolygon':\n        this.drawMultiPolygon(\n          /** @type {import(\"../../geom/MultiPolygon.js\").default} */ (\n            geometry\n          ),\n        );\n        break;\n      case 'GeometryCollection':\n        this.drawGeometryCollection(\n          /** @type {import(\"../../geom/GeometryCollection.js\").default} */ (\n            geometry\n          ),\n        );\n        break;\n      case 'Circle':\n        this.drawCircle(\n          /** @type {import(\"../../geom/Circle.js\").default} */ (geometry),\n        );\n        break;\n      default:\n    }\n  }\n\n  /**\n   * Render a feature into the canvas.  Note that any `zIndex` on the provided\n   * style will be ignored - features are rendered immediately in the order that\n   * this method is called.  If you need `zIndex` support, you should be using an\n   * {@link module:ol/layer/Vector~VectorLayer} instead.\n   *\n   * @param {import(\"../../Feature.js\").default} feature Feature.\n   * @param {import(\"../../style/Style.js\").default} style Style.\n   * @api\n   * @override\n   */\n  drawFeature(feature, style) {\n    const geometry = style.getGeometryFunction()(feature);\n    if (!geometry) {\n      return;\n    }\n    this.setStyle(style);\n    this.drawGeometry(geometry);\n  }\n\n  /**\n   * Render a GeometryCollection to the canvas.  Rendering is immediate and\n   * uses the current styles appropriate for each geometry in the collection.\n   *\n   * @param {import(\"../../geom/GeometryCollection.js\").default} geometry Geometry collection.\n   * @override\n   */\n  drawGeometryCollection(geometry) {\n    const geometries = geometry.getGeometriesArray();\n    for (let i = 0, ii = geometries.length; i < ii; ++i) {\n      this.drawGeometry(geometries[i]);\n    }\n  }\n\n  /**\n   * Render a Point geometry into the canvas.  Rendering is immediate and uses\n   * the current style.\n   *\n   * @param {import(\"../../geom/Point.js\").default|import(\"../Feature.js\").default} geometry Point geometry.\n   * @override\n   */\n  drawPoint(geometry) {\n    if (this.squaredTolerance_) {\n      geometry = /** @type {import(\"../../geom/Point.js\").default} */ (\n        geometry.simplifyTransformed(\n          this.squaredTolerance_,\n          this.userTransform_,\n        )\n      );\n    }\n    const flatCoordinates = geometry.getFlatCoordinates();\n    const stride = geometry.getStride();\n    if (this.image_) {\n      this.drawImages_(flatCoordinates, 0, flatCoordinates.length, stride);\n    }\n    if (this.text_ !== '') {\n      this.drawText_(flatCoordinates, 0, flatCoordinates.length, stride);\n    }\n  }\n\n  /**\n   * Render a MultiPoint geometry  into the canvas.  Rendering is immediate and\n   * uses the current style.\n   *\n   * @param {import(\"../../geom/MultiPoint.js\").default|import(\"../Feature.js\").default} geometry MultiPoint geometry.\n   * @override\n   */\n  drawMultiPoint(geometry) {\n    if (this.squaredTolerance_) {\n      geometry = /** @type {import(\"../../geom/MultiPoint.js\").default} */ (\n        geometry.simplifyTransformed(\n          this.squaredTolerance_,\n          this.userTransform_,\n        )\n      );\n    }\n    const flatCoordinates = geometry.getFlatCoordinates();\n    const stride = geometry.getStride();\n    if (this.image_) {\n      this.drawImages_(flatCoordinates, 0, flatCoordinates.length, stride);\n    }\n    if (this.text_ !== '') {\n      this.drawText_(flatCoordinates, 0, flatCoordinates.length, stride);\n    }\n  }\n\n  /**\n   * Render a LineString into the canvas.  Rendering is immediate and uses\n   * the current style.\n   *\n   * @param {import(\"../../geom/LineString.js\").default|import(\"../Feature.js\").default} geometry LineString geometry.\n   * @override\n   */\n  drawLineString(geometry) {\n    if (this.squaredTolerance_) {\n      geometry = /** @type {import(\"../../geom/LineString.js\").default} */ (\n        geometry.simplifyTransformed(\n          this.squaredTolerance_,\n          this.userTransform_,\n        )\n      );\n    }\n    if (!intersects(this.extent_, geometry.getExtent())) {\n      return;\n    }\n    if (this.strokeState_) {\n      this.setContextStrokeState_(this.strokeState_);\n      const context = this.context_;\n      const flatCoordinates = geometry.getFlatCoordinates();\n      context.beginPath();\n      this.moveToLineTo_(\n        flatCoordinates,\n        0,\n        flatCoordinates.length,\n        geometry.getStride(),\n        false,\n        this.strokeState_.strokeOffset,\n      );\n      context.stroke();\n    }\n    if (this.text_ !== '') {\n      const flatMidpoint = geometry.getFlatMidpoint();\n      this.drawText_(flatMidpoint, 0, 2, 2);\n    }\n  }\n\n  /**\n   * Render a MultiLineString geometry into the canvas.  Rendering is immediate\n   * and uses the current style.\n   *\n   * @param {import(\"../../geom/MultiLineString.js\").default|import(\"../Feature.js\").default} geometry MultiLineString geometry.\n   * @override\n   */\n  drawMultiLineString(geometry) {\n    if (this.squaredTolerance_) {\n      geometry =\n        /** @type {import(\"../../geom/MultiLineString.js\").default} */ (\n          geometry.simplifyTransformed(\n            this.squaredTolerance_,\n            this.userTransform_,\n          )\n        );\n    }\n    const geometryExtent = geometry.getExtent();\n    if (!intersects(this.extent_, geometryExtent)) {\n      return;\n    }\n    if (this.strokeState_) {\n      this.setContextStrokeState_(this.strokeState_);\n      const context = this.context_;\n      const flatCoordinates = geometry.getFlatCoordinates();\n      let offset = 0;\n      const ends = /** @type {Array<number>} */ (geometry.getEnds());\n      const stride = geometry.getStride();\n      context.beginPath();\n      for (let i = 0, ii = ends.length; i < ii; ++i) {\n        offset = this.moveToLineTo_(\n          flatCoordinates,\n          offset,\n          ends[i],\n          stride,\n          false,\n          this.strokeState_.strokeOffset,\n        );\n      }\n      context.stroke();\n    }\n    if (this.text_ !== '') {\n      const flatMidpoints = geometry.getFlatMidpoints();\n      this.drawText_(flatMidpoints, 0, flatMidpoints.length, 2);\n    }\n  }\n\n  /**\n   * Render a Polygon geometry into the canvas.  Rendering is immediate and uses\n   * the current style.\n   *\n   * @param {import(\"../../geom/Polygon.js\").default|import(\"../Feature.js\").default} geometry Polygon geometry.\n   * @override\n   */\n  drawPolygon(geometry) {\n    if (this.squaredTolerance_) {\n      geometry = /** @type {import(\"../../geom/Polygon.js\").default} */ (\n        geometry.simplifyTransformed(\n          this.squaredTolerance_,\n          this.userTransform_,\n        )\n      );\n    }\n    if (!intersects(this.extent_, geometry.getExtent())) {\n      return;\n    }\n    if (this.strokeState_ || this.fillState_) {\n      if (this.fillState_) {\n        this.setContextFillState_(this.fillState_);\n      }\n      if (this.strokeState_) {\n        this.setContextStrokeState_(this.strokeState_);\n      }\n      const context = this.context_;\n      context.beginPath();\n      this.drawRings_(\n        geometry.getOrientedFlatCoordinates(),\n        0,\n        /** @type {Array<number>} */ (geometry.getEnds()),\n        geometry.getStride(),\n        this.strokeState_?.strokeOffset,\n      );\n      if (this.fillState_) {\n        context.fill();\n      }\n      if (this.strokeState_) {\n        context.stroke();\n      }\n    }\n    if (this.text_ !== '') {\n      const flatInteriorPoint = geometry.getFlatInteriorPoint();\n      this.drawText_(flatInteriorPoint, 0, 2, 2);\n    }\n  }\n\n  /**\n   * Render MultiPolygon geometry into the canvas.  Rendering is immediate and\n   * uses the current style.\n   * @param {import(\"../../geom/MultiPolygon.js\").default} geometry MultiPolygon geometry.\n   * @override\n   */\n  drawMultiPolygon(geometry) {\n    if (this.squaredTolerance_) {\n      geometry = /** @type {import(\"../../geom/MultiPolygon.js\").default} */ (\n        geometry.simplifyTransformed(\n          this.squaredTolerance_,\n          this.userTransform_,\n        )\n      );\n    }\n    if (!intersects(this.extent_, geometry.getExtent())) {\n      return;\n    }\n    if (this.strokeState_ || this.fillState_) {\n      if (this.fillState_) {\n        this.setContextFillState_(this.fillState_);\n      }\n      if (this.strokeState_) {\n        this.setContextStrokeState_(this.strokeState_);\n      }\n      const context = this.context_;\n      const flatCoordinates = geometry.getOrientedFlatCoordinates();\n      let offset = 0;\n      const endss = geometry.getEndss();\n      const stride = geometry.getStride();\n      context.beginPath();\n      for (let i = 0, ii = endss.length; i < ii; ++i) {\n        const ends = endss[i];\n        offset = this.drawRings_(\n          flatCoordinates,\n          offset,\n          ends,\n          stride,\n          this.strokeState_?.strokeOffset,\n        );\n      }\n      if (this.fillState_) {\n        context.fill();\n      }\n      if (this.strokeState_) {\n        context.stroke();\n      }\n    }\n    if (this.text_ !== '') {\n      const flatInteriorPoints = geometry.getFlatInteriorPoints();\n      this.drawText_(flatInteriorPoints, 0, flatInteriorPoints.length, 2);\n    }\n  }\n\n  /**\n   * @param {import(\"../canvas.js\").FillState} fillState Fill state.\n   * @private\n   */\n  setContextFillState_(fillState) {\n    const context = this.context_;\n    const contextFillState = this.contextFillState_;\n    if (!contextFillState) {\n      context.fillStyle = fillState.fillStyle;\n      this.contextFillState_ = {\n        fillStyle: fillState.fillStyle,\n      };\n    } else {\n      if (contextFillState.fillStyle != fillState.fillStyle) {\n        contextFillState.fillStyle = fillState.fillStyle;\n        context.fillStyle = fillState.fillStyle;\n      }\n    }\n  }\n\n  /**\n   * @param {import(\"../canvas.js\").StrokeState} strokeState Stroke state.\n   * @private\n   */\n  setContextStrokeState_(strokeState) {\n    const context = this.context_;\n    const contextStrokeState = this.contextStrokeState_;\n    if (!contextStrokeState) {\n      context.lineCap = strokeState.lineCap;\n      context.setLineDash(strokeState.lineDash);\n      context.lineDashOffset = strokeState.lineDashOffset;\n      context.lineJoin = strokeState.lineJoin;\n      context.lineWidth = strokeState.lineWidth;\n      context.miterLimit = strokeState.miterLimit;\n      context.strokeStyle = strokeState.strokeStyle;\n      this.contextStrokeState_ = {\n        lineCap: strokeState.lineCap,\n        lineDash: strokeState.lineDash,\n        lineDashOffset: strokeState.lineDashOffset,\n        lineJoin: strokeState.lineJoin,\n        lineWidth: strokeState.lineWidth,\n        miterLimit: strokeState.miterLimit,\n        strokeStyle: strokeState.strokeStyle,\n      };\n    } else {\n      if (contextStrokeState.lineCap != strokeState.lineCap) {\n        contextStrokeState.lineCap = strokeState.lineCap;\n        context.lineCap = strokeState.lineCap;\n      }\n      if (!equals(contextStrokeState.lineDash, strokeState.lineDash)) {\n        context.setLineDash(\n          (contextStrokeState.lineDash = strokeState.lineDash),\n        );\n      }\n      if (contextStrokeState.lineDashOffset != strokeState.lineDashOffset) {\n        contextStrokeState.lineDashOffset = strokeState.lineDashOffset;\n        context.lineDashOffset = strokeState.lineDashOffset;\n      }\n      if (contextStrokeState.lineJoin != strokeState.lineJoin) {\n        contextStrokeState.lineJoin = strokeState.lineJoin;\n        context.lineJoin = strokeState.lineJoin;\n      }\n      if (contextStrokeState.lineWidth != strokeState.lineWidth) {\n        contextStrokeState.lineWidth = strokeState.lineWidth;\n        context.lineWidth = strokeState.lineWidth;\n      }\n      if (contextStrokeState.miterLimit != strokeState.miterLimit) {\n        contextStrokeState.miterLimit = strokeState.miterLimit;\n        context.miterLimit = strokeState.miterLimit;\n      }\n      if (contextStrokeState.strokeStyle != strokeState.strokeStyle) {\n        contextStrokeState.strokeStyle = strokeState.strokeStyle;\n        context.strokeStyle = strokeState.strokeStyle;\n      }\n    }\n  }\n\n  /**\n   * @param {import(\"../canvas.js\").TextState} textState Text state.\n   * @private\n   */\n  setContextTextState_(textState) {\n    const context = this.context_;\n    const contextTextState = this.contextTextState_;\n    const textAlign = textState.textAlign\n      ? textState.textAlign\n      : defaultTextAlign;\n    if (!contextTextState) {\n      context.font = textState.font;\n      context.textAlign = textAlign;\n      context.textBaseline = textState.textBaseline;\n      this.contextTextState_ = {\n        font: textState.font,\n        textAlign: textAlign,\n        textBaseline: textState.textBaseline,\n      };\n    } else {\n      if (contextTextState.font != textState.font) {\n        contextTextState.font = textState.font;\n        context.font = textState.font;\n      }\n      if (contextTextState.textAlign != textAlign) {\n        contextTextState.textAlign = textAlign;\n        context.textAlign = textAlign;\n      }\n      if (contextTextState.textBaseline != textState.textBaseline) {\n        contextTextState.textBaseline = textState.textBaseline;\n        context.textBaseline = textState.textBaseline;\n      }\n    }\n  }\n\n  /**\n   * Set the fill and stroke style for subsequent draw operations.  To clear\n   * either fill or stroke styles, pass null for the appropriate parameter.\n   *\n   * @param {import(\"../../style/Fill.js\").default} fillStyle Fill style.\n   * @param {import(\"../../style/Stroke.js\").default} strokeStyle Stroke style.\n   * @override\n   */\n  setFillStrokeStyle(fillStyle, strokeStyle) {\n    if (!fillStyle) {\n      this.fillState_ = null;\n    } else {\n      const fillStyleColor = fillStyle.getColor();\n      this.fillState_ = {\n        fillStyle: asColorLike(\n          fillStyleColor ? fillStyleColor : defaultFillStyle,\n        ),\n      };\n    }\n    if (!strokeStyle) {\n      this.strokeState_ = null;\n    } else {\n      const strokeStyleColor = strokeStyle.getColor();\n      const strokeStyleLineCap = strokeStyle.getLineCap();\n      const strokeStyleLineDash = strokeStyle.getLineDash();\n      const strokeStyleLineDashOffset = strokeStyle.getLineDashOffset();\n      const strokeStyleLineJoin = strokeStyle.getLineJoin();\n      const strokeStyleWidth = strokeStyle.getWidth();\n      const strokeStyleMiterLimit = strokeStyle.getMiterLimit();\n      const lineDash = strokeStyleLineDash\n        ? strokeStyleLineDash\n        : defaultLineDash;\n      const strokeOffset = strokeStyle.getOffset();\n      this.strokeState_ = {\n        lineCap:\n          strokeStyleLineCap !== undefined\n            ? strokeStyleLineCap\n            : defaultLineCap,\n        lineDash:\n          this.pixelRatio_ === 1\n            ? lineDash\n            : lineDash.map((n) => n * this.pixelRatio_),\n        lineDashOffset:\n          (strokeStyleLineDashOffset\n            ? strokeStyleLineDashOffset\n            : defaultLineDashOffset) * this.pixelRatio_,\n        lineJoin:\n          strokeStyleLineJoin !== undefined\n            ? strokeStyleLineJoin\n            : defaultLineJoin,\n        lineWidth:\n          (strokeStyleWidth !== undefined\n            ? strokeStyleWidth\n            : defaultLineWidth) * this.pixelRatio_,\n        miterLimit:\n          strokeStyleMiterLimit !== undefined\n            ? strokeStyleMiterLimit\n            : defaultMiterLimit,\n        strokeStyle: asColorLike(\n          strokeStyleColor ? strokeStyleColor : defaultStrokeStyle,\n        ),\n        strokeOffset: (strokeOffset ?? 0) * this.pixelRatio_,\n      };\n    }\n  }\n\n  /**\n   * Set the image style for subsequent draw operations.  Pass null to remove\n   * the image style.\n   *\n   * @param {import(\"../../style/Image.js\").default} imageStyle Image style.\n   * @override\n   */\n  setImageStyle(imageStyle) {\n    let imageSize;\n    if (!imageStyle || !(imageSize = imageStyle.getSize())) {\n      this.image_ = null;\n      return;\n    }\n    const imagePixelRatio = imageStyle.getPixelRatio(this.pixelRatio_);\n    const imageAnchor = imageStyle.getAnchor();\n    const imageOrigin = imageStyle.getOrigin();\n    this.image_ = imageStyle.getImage(this.pixelRatio_);\n    this.imageAnchorX_ = imageAnchor[0] * imagePixelRatio;\n    this.imageAnchorY_ = imageAnchor[1] * imagePixelRatio;\n    this.imageHeight_ = imageSize[1] * imagePixelRatio;\n    this.imageOpacity_ = imageStyle.getOpacity();\n    this.imageOriginX_ = imageOrigin[0];\n    this.imageOriginY_ = imageOrigin[1];\n    this.imageRotateWithView_ = imageStyle.getRotateWithView();\n    this.imageRotation_ = imageStyle.getRotation();\n    const imageScale = imageStyle.getScaleArray();\n    this.imageScale_ = [\n      (imageScale[0] * this.pixelRatio_) / imagePixelRatio,\n      (imageScale[1] * this.pixelRatio_) / imagePixelRatio,\n    ];\n    this.imageWidth_ = imageSize[0] * imagePixelRatio;\n  }\n\n  /**\n   * Set the text style for subsequent draw operations.  Pass null to\n   * remove the text style.\n   *\n   * @param {import(\"../../style/Text.js\").default} textStyle Text style.\n   * @override\n   */\n  setTextStyle(textStyle) {\n    if (!textStyle) {\n      this.text_ = '';\n    } else {\n      const textFillStyle = textStyle.getFill();\n      if (!textFillStyle) {\n        this.textFillState_ = null;\n      } else {\n        const textFillStyleColor = textFillStyle.getColor();\n        this.textFillState_ = {\n          fillStyle: asColorLike(\n            textFillStyleColor ? textFillStyleColor : defaultFillStyle,\n          ),\n        };\n      }\n      const textStrokeStyle = textStyle.getStroke();\n      if (!textStrokeStyle) {\n        this.textStrokeState_ = null;\n      } else {\n        const textStrokeStyleColor = textStrokeStyle.getColor();\n        const textStrokeStyleLineCap = textStrokeStyle.getLineCap();\n        const textStrokeStyleLineDash = textStrokeStyle.getLineDash();\n        const textStrokeStyleLineDashOffset =\n          textStrokeStyle.getLineDashOffset();\n        const textStrokeStyleLineJoin = textStrokeStyle.getLineJoin();\n        const textStrokeStyleWidth = textStrokeStyle.getWidth();\n        const textStrokeStyleMiterLimit = textStrokeStyle.getMiterLimit();\n        this.textStrokeState_ = {\n          lineCap:\n            textStrokeStyleLineCap !== undefined\n              ? textStrokeStyleLineCap\n              : defaultLineCap,\n          lineDash: textStrokeStyleLineDash\n            ? textStrokeStyleLineDash\n            : defaultLineDash,\n          lineDashOffset: textStrokeStyleLineDashOffset\n            ? textStrokeStyleLineDashOffset\n            : defaultLineDashOffset,\n          lineJoin:\n            textStrokeStyleLineJoin !== undefined\n              ? textStrokeStyleLineJoin\n              : defaultLineJoin,\n          lineWidth:\n            textStrokeStyleWidth !== undefined\n              ? textStrokeStyleWidth\n              : defaultLineWidth,\n          miterLimit:\n            textStrokeStyleMiterLimit !== undefined\n              ? textStrokeStyleMiterLimit\n              : defaultMiterLimit,\n          strokeStyle: asColorLike(\n            textStrokeStyleColor ? textStrokeStyleColor : defaultStrokeStyle,\n          ),\n        };\n      }\n      const textFont = textStyle.getFont();\n      const textOffsetX = textStyle.getOffsetX();\n      const textOffsetY = textStyle.getOffsetY();\n      const textRotateWithView = textStyle.getRotateWithView();\n      const textRotation = textStyle.getRotation();\n      const textScale = textStyle.getScaleArray();\n      const textText = textStyle.getText();\n      const textTextAlign = textStyle.getTextAlign();\n      const textTextBaseline = textStyle.getTextBaseline();\n      this.textState_ = {\n        font: textFont !== undefined ? textFont : defaultFont,\n        textAlign:\n          textTextAlign !== undefined ? textTextAlign : defaultTextAlign,\n        textBaseline:\n          textTextBaseline !== undefined\n            ? textTextBaseline\n            : defaultTextBaseline,\n      };\n      this.text_ =\n        textText !== undefined\n          ? Array.isArray(textText)\n            ? textText.reduce((acc, t, i) => (acc += i % 2 ? ' ' : t), '')\n            : textText\n          : '';\n      this.textOffsetX_ =\n        textOffsetX !== undefined ? this.pixelRatio_ * textOffsetX : 0;\n      this.textOffsetY_ =\n        textOffsetY !== undefined ? this.pixelRatio_ * textOffsetY : 0;\n      this.textRotateWithView_ =\n        textRotateWithView !== undefined ? textRotateWithView : false;\n      this.textRotation_ = textRotation !== undefined ? textRotation : 0;\n      this.textScale_ = [\n        this.pixelRatio_ * textScale[0],\n        this.pixelRatio_ * textScale[1],\n      ];\n    }\n  }\n}\n\nexport default CanvasImmediateRenderer;\n","/**\n * @module ol/renderer/vector\n */\nimport ImageState from '../ImageState.js';\nimport {getUid} from '../util.js';\n\n/**\n * Feature callback. The callback will be called with three arguments. The first\n * argument is one {@link module:ol/Feature~Feature feature} or {@link module:ol/render/Feature~RenderFeature render feature}\n * at the pixel, the second is the {@link module:ol/layer/Layer~Layer layer} of the feature and will be null for\n * unmanaged layers. The third is the {@link module:ol/geom/SimpleGeometry~SimpleGeometry} of the feature. For features\n * with a GeometryCollection geometry, it will be the first detected geometry from the collection.\n * @template T\n * @typedef {function(import(\"../Feature.js\").FeatureLike, import(\"../layer/Layer.js\").default<import(\"../source/Source.js\").default>, import(\"../geom/SimpleGeometry.js\").default): T} FeatureCallback\n */\n\n/**\n * Tolerance for geometry simplification in device pixels.\n * @type {number}\n */\nconst SIMPLIFY_TOLERANCE = 0.5;\n\n/**\n * @const\n * @type {Object<import(\"../geom/Geometry.js\").Type,\n *                function(import(\"../render/canvas/BuilderGroup.js\").default, import(\"../geom/Geometry.js\").default,\n *                         import(\"../style/Style.js\").default, Object): void>}\n */\nconst GEOMETRY_RENDERERS = {\n  'Point': renderPointGeometry,\n  'LineString': renderLineStringGeometry,\n  'Polygon': renderPolygonGeometry,\n  'MultiPoint': renderMultiPointGeometry,\n  'MultiLineString': renderMultiLineStringGeometry,\n  'MultiPolygon': renderMultiPolygonGeometry,\n  'GeometryCollection': renderGeometryCollectionGeometry,\n  'Circle': renderCircleGeometry,\n};\n\n/**\n * @param {import(\"../Feature.js\").FeatureLike} feature1 Feature 1.\n * @param {import(\"../Feature.js\").FeatureLike} feature2 Feature 2.\n * @return {number} Order.\n */\nexport function defaultOrder(feature1, feature2) {\n  return parseInt(getUid(feature1), 10) - parseInt(getUid(feature2), 10);\n}\n\n/**\n * @param {number} resolution Resolution.\n * @param {number} pixelRatio Pixel ratio.\n * @return {number} Squared pixel tolerance.\n */\nexport function getSquaredTolerance(resolution, pixelRatio) {\n  const tolerance = getTolerance(resolution, pixelRatio);\n  return tolerance * tolerance;\n}\n\n/**\n * @param {number} resolution Resolution.\n * @param {number} pixelRatio Pixel ratio.\n * @return {number} Pixel tolerance.\n */\nexport function getTolerance(resolution, pixelRatio) {\n  return (SIMPLIFY_TOLERANCE * resolution) / pixelRatio;\n}\n\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} builderGroup Builder group.\n * @param {import(\"../geom/Circle.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").default} feature Feature.\n * @param {number} [index] Render order index.\n */\nfunction renderCircleGeometry(builderGroup, geometry, style, feature, index) {\n  const fillStyle = style.getFill();\n  const strokeStyle = style.getStroke();\n  if (fillStyle || strokeStyle) {\n    const circleReplay = builderGroup.getBuilder(style.getZIndex(), 'Circle');\n    circleReplay.setFillStrokeStyle(fillStyle, strokeStyle);\n    circleReplay.drawCircle(geometry, feature, index);\n  }\n  const textStyle = style.getText();\n  if (textStyle && textStyle.getText()) {\n    const textReplay = builderGroup.getBuilder(style.getZIndex(), 'Text');\n    textReplay.setTextStyle(textStyle);\n    textReplay.drawText(geometry, feature, index);\n  }\n}\n\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} replayGroup Replay group.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\n * @param {import(\"../proj.js\").TransformFunction} [transform] Transform from user to view projection.\n * @param {boolean} [declutter] Enable decluttering.\n * @param {number} [index] Render order index..\n * @return {boolean} `true` if style is loading.\n */\nexport function renderFeature(\n  replayGroup,\n  feature,\n  style,\n  squaredTolerance,\n  listener,\n  transform,\n  declutter,\n  index,\n) {\n  const loadingPromises = [];\n  const imageStyle = style.getImage();\n  if (imageStyle) {\n    let loading = true;\n    const imageState = imageStyle.getImageState();\n    if (imageState == ImageState.LOADED || imageState == ImageState.ERROR) {\n      loading = false;\n    } else {\n      if (imageState == ImageState.IDLE) {\n        imageStyle.load();\n      }\n    }\n    if (loading) {\n      loadingPromises.push(imageStyle.ready());\n    }\n  }\n  const fillStyle = style.getFill();\n  if (fillStyle && fillStyle.loading()) {\n    loadingPromises.push(fillStyle.ready());\n  }\n  const loading = loadingPromises.length > 0;\n  if (loading) {\n    Promise.all(loadingPromises).then(() => listener(null));\n  }\n  renderFeatureInternal(\n    replayGroup,\n    feature,\n    style,\n    squaredTolerance,\n    transform,\n    declutter,\n    index,\n  );\n\n  return loading;\n}\n\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} replayGroup Replay group.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {import(\"../proj.js\").TransformFunction} [transform] Optional transform function.\n * @param {boolean} [declutter] Enable decluttering.\n * @param {number} [index] Render order index..\n */\nfunction renderFeatureInternal(\n  replayGroup,\n  feature,\n  style,\n  squaredTolerance,\n  transform,\n  declutter,\n  index,\n) {\n  const geometry = style.getGeometryFunction()(feature);\n  if (!geometry) {\n    return;\n  }\n  const simplifiedGeometry = geometry.simplifyTransformed(\n    squaredTolerance,\n    transform,\n  );\n  const renderer = style.getRenderer();\n  if (renderer) {\n    renderGeometry(replayGroup, simplifiedGeometry, style, feature, index);\n  } else {\n    const geometryRenderer = GEOMETRY_RENDERERS[simplifiedGeometry.getType()];\n    geometryRenderer(\n      replayGroup,\n      simplifiedGeometry,\n      style,\n      feature,\n      index,\n      declutter,\n    );\n  }\n}\n\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} replayGroup Replay group.\n * @param {import(\"../geom/Geometry.js\").default|import(\"../render/Feature.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {number} [index] Render order index.\n */\nfunction renderGeometry(replayGroup, geometry, style, feature, index) {\n  if (geometry.getType() == 'GeometryCollection') {\n    const geometries =\n      /** @type {import(\"../geom/GeometryCollection.js\").default} */ (\n        geometry\n      ).getGeometries();\n    for (let i = 0, ii = geometries.length; i < ii; ++i) {\n      renderGeometry(replayGroup, geometries[i], style, feature, index);\n    }\n    return;\n  }\n  const replay = replayGroup.getBuilder(style.getZIndex(), 'Default');\n  replay.drawCustom(\n    /** @type {import(\"../geom/SimpleGeometry.js\").default} */ (geometry),\n    feature,\n    style.getRenderer(),\n    style.getHitDetectionRenderer(),\n    index,\n  );\n}\n\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} replayGroup Replay group.\n * @param {import(\"../geom/GeometryCollection.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").default} feature Feature.\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} [declutterBuilderGroup] Builder for decluttering.\n * @param {number} [index] Render order index.\n */\nfunction renderGeometryCollectionGeometry(\n  replayGroup,\n  geometry,\n  style,\n  feature,\n  declutterBuilderGroup,\n  index,\n) {\n  const geometries = geometry.getGeometriesArray();\n  let i, ii;\n  for (i = 0, ii = geometries.length; i < ii; ++i) {\n    const geometryRenderer = GEOMETRY_RENDERERS[geometries[i].getType()];\n    geometryRenderer(\n      replayGroup,\n      geometries[i],\n      style,\n      feature,\n      declutterBuilderGroup,\n      index,\n    );\n  }\n}\n\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} builderGroup Replay group.\n * @param {import(\"../geom/LineString.js\").default|import(\"../render/Feature.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {number} [index] Render order index.\n */\nfunction renderLineStringGeometry(\n  builderGroup,\n  geometry,\n  style,\n  feature,\n  index,\n) {\n  const strokeStyle = style.getStroke();\n  if (strokeStyle) {\n    const lineStringReplay = builderGroup.getBuilder(\n      style.getZIndex(),\n      'LineString',\n    );\n    lineStringReplay.setFillStrokeStyle(null, strokeStyle);\n    lineStringReplay.drawLineString(geometry, feature, index);\n  }\n  const textStyle = style.getText();\n  if (textStyle && textStyle.getText()) {\n    const textReplay = builderGroup.getBuilder(style.getZIndex(), 'Text');\n    textReplay.setTextStyle(textStyle);\n    textReplay.drawText(geometry, feature, index);\n  }\n}\n\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} builderGroup Replay group.\n * @param {import(\"../geom/MultiLineString.js\").default|import(\"../render/Feature.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {number} [index] Render order index.\n */\nfunction renderMultiLineStringGeometry(\n  builderGroup,\n  geometry,\n  style,\n  feature,\n  index,\n) {\n  const strokeStyle = style.getStroke();\n  if (strokeStyle) {\n    const lineStringReplay = builderGroup.getBuilder(\n      style.getZIndex(),\n      'LineString',\n    );\n    lineStringReplay.setFillStrokeStyle(null, strokeStyle);\n    lineStringReplay.drawMultiLineString(geometry, feature, index);\n  }\n  const textStyle = style.getText();\n  if (textStyle && textStyle.getText()) {\n    const textReplay = builderGroup.getBuilder(style.getZIndex(), 'Text');\n    textReplay.setTextStyle(textStyle);\n    textReplay.drawText(geometry, feature, index);\n  }\n}\n\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} builderGroup Replay group.\n * @param {import(\"../geom/MultiPolygon.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").default} feature Feature.\n * @param {number} [index] Render order index.\n */\nfunction renderMultiPolygonGeometry(\n  builderGroup,\n  geometry,\n  style,\n  feature,\n  index,\n) {\n  const fillStyle = style.getFill();\n  const strokeStyle = style.getStroke();\n  if (strokeStyle || fillStyle) {\n    const polygonReplay = builderGroup.getBuilder(style.getZIndex(), 'Polygon');\n    polygonReplay.setFillStrokeStyle(fillStyle, strokeStyle);\n    polygonReplay.drawMultiPolygon(geometry, feature, index);\n  }\n  const textStyle = style.getText();\n  if (textStyle && textStyle.getText()) {\n    const textReplay = builderGroup.getBuilder(style.getZIndex(), 'Text');\n    textReplay.setTextStyle(textStyle);\n    textReplay.drawText(geometry, feature, index);\n  }\n}\n\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} builderGroup Replay group.\n * @param {import(\"../geom/Point.js\").default|import(\"../render/Feature.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {number} [index] Render order index.\n * @param {boolean} [declutter] Enable decluttering.\n */\nfunction renderPointGeometry(\n  builderGroup,\n  geometry,\n  style,\n  feature,\n  index,\n  declutter,\n) {\n  const imageStyle = style.getImage();\n  const textStyle = style.getText();\n  const hasText = textStyle && textStyle.getText();\n  /** @type {import(\"../render/canvas.js\").DeclutterImageWithText} */\n  const declutterImageWithText =\n    declutter && imageStyle && hasText ? {} : undefined;\n  if (imageStyle) {\n    if (imageStyle.getImageState() != ImageState.LOADED) {\n      return;\n    }\n    const imageReplay = builderGroup.getBuilder(style.getZIndex(), 'Image');\n    imageReplay.setImageStyle(imageStyle, declutterImageWithText);\n    imageReplay.drawPoint(geometry, feature, index);\n  }\n  if (hasText) {\n    const textReplay = builderGroup.getBuilder(style.getZIndex(), 'Text');\n    textReplay.setTextStyle(textStyle, declutterImageWithText);\n    textReplay.drawText(geometry, feature, index);\n  }\n}\n\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} builderGroup Replay group.\n * @param {import(\"../geom/MultiPoint.js\").default|import(\"../render/Feature.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {number} [index] Render order index.\n * @param {boolean} [declutter] Enable decluttering.\n */\nfunction renderMultiPointGeometry(\n  builderGroup,\n  geometry,\n  style,\n  feature,\n  index,\n  declutter,\n) {\n  const imageStyle = style.getImage();\n  const hasImage = imageStyle && imageStyle.getOpacity() !== 0;\n  const textStyle = style.getText();\n  const hasText = textStyle && textStyle.getText();\n  /** @type {import(\"../render/canvas.js\").DeclutterImageWithText} */\n  const declutterImageWithText =\n    declutter && hasImage && hasText ? {} : undefined;\n  if (hasImage) {\n    if (imageStyle.getImageState() != ImageState.LOADED) {\n      return;\n    }\n    const imageReplay = builderGroup.getBuilder(style.getZIndex(), 'Image');\n    imageReplay.setImageStyle(imageStyle, declutterImageWithText);\n    imageReplay.drawMultiPoint(geometry, feature, index);\n  }\n  if (hasText) {\n    const textReplay = builderGroup.getBuilder(style.getZIndex(), 'Text');\n    textReplay.setTextStyle(textStyle, declutterImageWithText);\n    textReplay.drawText(geometry, feature, index);\n  }\n}\n\n/**\n * @param {import(\"../render/canvas/BuilderGroup.js\").default} builderGroup Replay group.\n * @param {import(\"../geom/Polygon.js\").default|import(\"../render/Feature.js\").default} geometry Geometry.\n * @param {import(\"../style/Style.js\").default} style Style.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {number} [index] Render order index.\n */\nfunction renderPolygonGeometry(builderGroup, geometry, style, feature, index) {\n  const fillStyle = style.getFill();\n  const strokeStyle = style.getStroke();\n  if (fillStyle || strokeStyle) {\n    const polygonReplay = builderGroup.getBuilder(style.getZIndex(), 'Polygon');\n    polygonReplay.setFillStrokeStyle(fillStyle, strokeStyle);\n    polygonReplay.drawPolygon(geometry, feature, index);\n  }\n  const textStyle = style.getText();\n  if (textStyle && textStyle.getText()) {\n    const textReplay = builderGroup.getBuilder(style.getZIndex(), 'Text');\n    textReplay.setTextStyle(textStyle);\n    textReplay.drawText(geometry, feature, index);\n  }\n}\n","/**\n * @module ol/render\n */\nimport {DEVICE_PIXEL_RATIO} from './has.js';\nimport {getTransformFromProjections, getUserProjection} from './proj.js';\nimport CanvasImmediateRenderer from './render/canvas/Immediate.js';\nimport {getSquaredTolerance} from './renderer/vector.js';\nimport {\n  apply as applyTransform,\n  create as createTransform,\n  multiply as multiplyTransform,\n  scale as scaleTransform,\n} from './transform.js';\n\n/**\n * @typedef {Object} State\n * @property {CanvasRenderingContext2D} context Canvas context that the layer is being rendered to.\n * @property {import(\"./Feature.js\").FeatureLike} feature Feature.\n * @property {import(\"./geom/SimpleGeometry.js\").default} geometry Geometry.\n * @property {number} pixelRatio Pixel ratio used by the layer renderer.\n * @property {number} resolution Resolution that the render batch was created and optimized for.\n * This is not the view's resolution that is being rendered.\n * @property {number} rotation Rotation of the rendered layer in radians.\n */\n\n/**\n * A function to be used when sorting features before rendering.\n * It takes two instances of {@link module:ol/Feature~Feature} or\n * {@link module:ol/render/Feature~RenderFeature} and returns a `{number}`.\n *\n * @typedef {function(import(\"./Feature.js\").FeatureLike, import(\"./Feature.js\").FeatureLike):number} OrderFunction\n */\n\n/**\n * @typedef {Object} ToContextOptions\n * @property {import(\"./size.js\").Size} [size] Desired size of the canvas in css\n * pixels. When provided, both canvas and css size will be set according to the\n * `pixelRatio`. If not provided, the current canvas and css sizes will not be\n * altered.\n * @property {number} [pixelRatio=window.devicePixelRatio] Pixel ratio (canvas\n * pixel to css pixel ratio) for the canvas.\n */\n\n/**\n * Binds a Canvas Immediate API to a canvas context, to allow drawing geometries\n * to the context's canvas.\n *\n * The units for geometry coordinates are css pixels relative to the top left\n * corner of the canvas element.\n * ```js\n * import {toContext} from 'ol/render.js';\n * import Fill from 'ol/style/Fill.js';\n * import Polygon from 'ol/geom/Polygon.js';\n *\n * const canvas = document.createElement('canvas');\n * const render = toContext(\n *     canvas.getContext('2d'),\n *     {size: [100, 100]}\n * );\n * render.setFillStrokeStyle(new Fill({ color: blue }));\n * render.drawPolygon(\n *     new Polygon([[[0, 0], [100, 100], [100, 0], [0, 0]]])\n * );\n * ```\n *\n * @param {CanvasRenderingContext2D} context Canvas context.\n * @param {ToContextOptions} [options] Options.\n * @return {CanvasImmediateRenderer} Canvas Immediate.\n * @api\n */\nexport function toContext(context, options) {\n  const canvas = context.canvas;\n  options = options ? options : {};\n  const pixelRatio = options.pixelRatio || DEVICE_PIXEL_RATIO;\n  const size = options.size;\n  if (size) {\n    canvas.width = size[0] * pixelRatio;\n    canvas.height = size[1] * pixelRatio;\n    canvas.style.width = size[0] + 'px';\n    canvas.style.height = size[1] + 'px';\n  }\n  const extent = [0, 0, canvas.width, canvas.height];\n  const transform = scaleTransform(createTransform(), pixelRatio, pixelRatio);\n  const squaredTolerance = getSquaredTolerance(1, pixelRatio);\n  return new CanvasImmediateRenderer(\n    context,\n    pixelRatio,\n    extent,\n    transform,\n    0,\n    squaredTolerance,\n  );\n}\n\n/**\n * Gets a vector context for drawing to the event's canvas.\n * @param {import(\"./render/Event.js\").default} event Render event.\n * @return {CanvasImmediateRenderer} Vector context.\n * @api\n */\nexport function getVectorContext(event) {\n  if (!(event.context instanceof CanvasRenderingContext2D)) {\n    throw new Error('Only works for render events from Canvas 2D layers');\n  }\n\n  // canvas may be at a different pixel ratio than frameState.pixelRatio\n  const a = event.inversePixelTransform[0];\n  const b = event.inversePixelTransform[1];\n  const canvasPixelRatio = Math.sqrt(a * a + b * b);\n  const frameState = event.frameState;\n  const transform = multiplyTransform(\n    event.inversePixelTransform.slice(),\n    frameState.coordinateToPixelTransform,\n  );\n  const squaredTolerance = getSquaredTolerance(\n    frameState.viewState.resolution,\n    canvasPixelRatio,\n  );\n  let userTransform;\n  const userProjection = getUserProjection();\n  if (userProjection) {\n    userTransform = getTransformFromProjections(\n      userProjection,\n      frameState.viewState.projection,\n    );\n  }\n\n  return new CanvasImmediateRenderer(\n    event.context,\n    canvasPixelRatio,\n    frameState.extent,\n    transform,\n    frameState.viewState.rotation,\n    squaredTolerance,\n    userTransform,\n  );\n}\n\n/**\n * Gets the pixel of the event's canvas context from the map viewport's CSS pixel.\n * @param {import(\"./render/Event.js\").default} event Render event.\n * @param {import(\"./pixel.js\").Pixel} pixel CSS pixel relative to the top-left\n * corner of the map viewport.\n * @return {import(\"./pixel.js\").Pixel} Pixel on the event's canvas context.\n * @api\n */\nexport function getRenderPixel(event, pixel) {\n  return applyTransform(event.inversePixelTransform, pixel.slice(0));\n}\n","/**\n * @module ol/reproj\n */\nimport {createCanvasContext2D, releaseCanvas} from './dom.js';\nimport {\n  containsCoordinate,\n  createEmpty,\n  extend,\n  forEachCorner,\n  getCenter,\n  getHeight,\n  getTopLeft,\n  getWidth,\n} from './extent.js';\nimport {solveLinearSystem} from './math.js';\nimport {getPointResolution, transform} from './proj.js';\n\nlet brokenDiagonalRendering_;\n\n/**\n * @type {Array<HTMLCanvasElement|OffscreenCanvas>}\n */\nexport const canvasPool = [];\n\n/**\n * This draws a small triangle into a canvas by setting the triangle as the clip region\n * and then drawing a (too large) rectangle\n *\n * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} ctx The context in which to draw the triangle\n * @param {number} u1 The x-coordinate of the second point. The first point is 0,0.\n * @param {number} v1 The y-coordinate of the second point.\n * @param {number} u2 The x-coordinate of the third point.\n * @param {number} v2 The y-coordinate of the third point.\n */\nfunction drawTestTriangle(ctx, u1, v1, u2, v2) {\n  ctx.beginPath();\n  ctx.moveTo(0, 0);\n  ctx.lineTo(u1, v1);\n  ctx.lineTo(u2, v2);\n  ctx.closePath();\n  ctx.save();\n  ctx.clip();\n  ctx.fillRect(0, 0, Math.max(u1, u2) + 1, Math.max(v1, v2));\n  ctx.restore();\n}\n\n/**\n * Given the data from getImageData, see if the right values appear at the provided offset.\n * Returns true if either the color or transparency is off\n *\n * @param {Uint8ClampedArray} data The data returned from getImageData\n * @param {number} offset The pixel offset from the start of data.\n * @return {boolean} true if the diagonal rendering is broken\n */\nfunction verifyBrokenDiagonalRendering(data, offset) {\n  // the values ought to be close to the rgba(210, 0, 0, 0.75)\n  return (\n    Math.abs(data[offset * 4] - 210) > 2 ||\n    Math.abs(data[offset * 4 + 3] - 0.75 * 255) > 2\n  );\n}\n\n/**\n * Determines if the current browser configuration can render triangular clip regions correctly.\n * This value is cached so the function is only expensive the first time called.\n * Firefox on Windows (as of now) does not if HWA is enabled. See https://bugzilla.mozilla.org/show_bug.cgi?id=1606976\n * Chrome works, and everything seems to work on OSX and Android. This function caches the\n * result. I suppose that it is conceivably possible that a browser might flip modes while the app is\n * running, but lets hope not.\n *\n * @return {boolean} true if the Diagonal Rendering is broken.\n */\nfunction isBrokenDiagonalRendering() {\n  if (brokenDiagonalRendering_ === undefined) {\n    const ctx = createCanvasContext2D(6, 6, canvasPool);\n    ctx.globalCompositeOperation = 'lighter';\n    ctx.fillStyle = 'rgba(210, 0, 0, 0.75)';\n    drawTestTriangle(ctx, 4, 5, 4, 0);\n    drawTestTriangle(ctx, 4, 5, 0, 5);\n    const data = ctx.getImageData(0, 0, 3, 3).data;\n    brokenDiagonalRendering_ =\n      verifyBrokenDiagonalRendering(data, 0) ||\n      verifyBrokenDiagonalRendering(data, 4) ||\n      verifyBrokenDiagonalRendering(data, 8);\n    releaseCanvas(ctx);\n    canvasPool.push(ctx.canvas);\n  }\n\n  return brokenDiagonalRendering_;\n}\n\n/**\n * Calculates ideal resolution to use from the source in order to achieve\n * pixel mapping as close as possible to 1:1 during reprojection.\n * The resolution is calculated regardless of what resolutions\n * are actually available in the dataset (TileGrid, Image, ...).\n *\n * @param {import(\"./proj/Projection.js\").default} sourceProj Source projection.\n * @param {import(\"./proj/Projection.js\").default} targetProj Target projection.\n * @param {import(\"./coordinate.js\").Coordinate} targetCenter Target center.\n * @param {number} targetResolution Target resolution.\n * @return {number} The best resolution to use. Can be +-Infinity, NaN or 0.\n */\nexport function calculateSourceResolution(\n  sourceProj,\n  targetProj,\n  targetCenter,\n  targetResolution,\n) {\n  const sourceCenter = transform(targetCenter, targetProj, sourceProj);\n\n  // calculate the ideal resolution of the source data\n  let sourceResolution = getPointResolution(\n    targetProj,\n    targetResolution,\n    targetCenter,\n  );\n\n  const targetMetersPerUnit = targetProj.getMetersPerUnit();\n  if (targetMetersPerUnit !== undefined) {\n    sourceResolution *= targetMetersPerUnit;\n  }\n  const sourceMetersPerUnit = sourceProj.getMetersPerUnit();\n  if (sourceMetersPerUnit !== undefined) {\n    sourceResolution /= sourceMetersPerUnit;\n  }\n\n  // Based on the projection properties, the point resolution at the specified\n  // coordinates may be slightly different. We need to reverse-compensate this\n  // in order to achieve optimal results.\n\n  const sourceExtent = sourceProj.getExtent();\n  if (!sourceExtent || containsCoordinate(sourceExtent, sourceCenter)) {\n    const compensationFactor =\n      getPointResolution(sourceProj, sourceResolution, sourceCenter) /\n      sourceResolution;\n    if (isFinite(compensationFactor) && compensationFactor > 0) {\n      sourceResolution /= compensationFactor;\n    }\n  }\n\n  return sourceResolution;\n}\n\n/**\n * Calculates ideal resolution to use from the source in order to achieve\n * pixel mapping as close as possible to 1:1 during reprojection.\n * The resolution is calculated regardless of what resolutions\n * are actually available in the dataset (TileGrid, Image, ...).\n *\n * @param {import(\"./proj/Projection.js\").default} sourceProj Source projection.\n * @param {import(\"./proj/Projection.js\").default} targetProj Target projection.\n * @param {import(\"./extent.js\").Extent} targetExtent Target extent\n * @param {number} targetResolution Target resolution.\n * @return {number} The best resolution to use. Can be +-Infinity, NaN or 0.\n */\nexport function calculateSourceExtentResolution(\n  sourceProj,\n  targetProj,\n  targetExtent,\n  targetResolution,\n) {\n  const targetCenter = getCenter(targetExtent);\n  let sourceResolution = calculateSourceResolution(\n    sourceProj,\n    targetProj,\n    targetCenter,\n    targetResolution,\n  );\n\n  if (!isFinite(sourceResolution) || sourceResolution <= 0) {\n    forEachCorner(targetExtent, function (corner) {\n      sourceResolution = calculateSourceResolution(\n        sourceProj,\n        targetProj,\n        corner,\n        targetResolution,\n      );\n      return isFinite(sourceResolution) && sourceResolution > 0;\n    });\n  }\n\n  return sourceResolution;\n}\n\n/**\n * @typedef {Object} ImageExtent\n * @property {import(\"./extent.js\").Extent} extent Extent.\n * @property {import(\"./extent.js\").Extent} [clipExtent] Clip extent.\n * @property {import('./DataTile.js').ImageLike} image Image.\n */\n\n/**\n * Renders the source data into new canvas based on the triangulation.\n *\n * @param {number} width Width of the canvas.\n * @param {number} height Height of the canvas.\n * @param {number} pixelRatio Pixel ratio.\n * @param {number} sourceResolution Source resolution.\n * @param {import(\"./extent.js\").Extent} sourceExtent Extent of the data source.\n * @param {number} targetResolution Target resolution.\n * @param {import(\"./extent.js\").Extent} targetExtent Target extent.\n * @param {import(\"./reproj/Triangulation.js\").default} triangulation Calculated triangulation.\n * @param {Array<ImageExtent>} sources Array of sources.\n * @param {number} gutter Gutter of the sources.\n * @param {boolean} [renderEdges] Render reprojection edges.\n * @param {boolean} [interpolate] Use linear interpolation when resampling.\n * @param {boolean} [drawSingle] Draw single source images directly without stitchContext.\n * @param {boolean} [clipExtent] Clip stitchContext to sourceExtent.\n * @return {HTMLCanvasElement|OffscreenCanvas} Canvas with reprojected data.\n */\nexport function render(\n  width,\n  height,\n  pixelRatio,\n  sourceResolution,\n  sourceExtent,\n  targetResolution,\n  targetExtent,\n  triangulation,\n  sources,\n  gutter,\n  renderEdges,\n  interpolate,\n  drawSingle,\n  clipExtent,\n) {\n  const context = createCanvasContext2D(\n    Math.round(pixelRatio * width),\n    Math.round(pixelRatio * height),\n    canvasPool,\n  );\n\n  if (!interpolate) {\n    context.imageSmoothingEnabled = false;\n  }\n\n  if (sources.length === 0) {\n    return context.canvas;\n  }\n\n  context.scale(pixelRatio, pixelRatio);\n\n  function pixelRound(value) {\n    return Math.round(value * pixelRatio) / pixelRatio;\n  }\n\n  context.globalCompositeOperation = 'lighter';\n\n  const sourceDataExtent = createEmpty();\n  sources.forEach(function (src, i, arr) {\n    extend(sourceDataExtent, src.extent);\n  });\n\n  let stitchContext;\n  const stitchScale = pixelRatio / sourceResolution;\n  // Round up Float32 scale values to prevent interpolation in Firefox.\n  const inverseScale = (interpolate ? 1 : 1 + Math.pow(2, -24)) / stitchScale;\n\n  if (!drawSingle || sources.length !== 1 || gutter !== 0) {\n    stitchContext = createCanvasContext2D(\n      Math.round(getWidth(sourceDataExtent) * stitchScale),\n      Math.round(getHeight(sourceDataExtent) * stitchScale),\n      canvasPool,\n    );\n\n    if (!interpolate) {\n      stitchContext.imageSmoothingEnabled = false;\n    }\n    if (sourceExtent && clipExtent) {\n      const xPos = (sourceExtent[0] - sourceDataExtent[0]) * stitchScale;\n      const yPos = -(sourceExtent[3] - sourceDataExtent[3]) * stitchScale;\n      const width = getWidth(sourceExtent) * stitchScale;\n      const height = getHeight(sourceExtent) * stitchScale;\n      stitchContext.rect(xPos, yPos, width, height);\n      stitchContext.clip();\n    }\n\n    sources.forEach(function (src, i, arr) {\n      // This test should never fail -- but it does. Need to find a fix the upstream condition\n      if (src.image.width > 0 && src.image.height > 0) {\n        if (src.clipExtent) {\n          stitchContext.save();\n          const xPos = (src.clipExtent[0] - sourceDataExtent[0]) * stitchScale;\n          const yPos = -(src.clipExtent[3] - sourceDataExtent[3]) * stitchScale;\n          const width = getWidth(src.clipExtent) * stitchScale;\n          const height = getHeight(src.clipExtent) * stitchScale;\n          stitchContext.rect(\n            interpolate ? xPos : Math.round(xPos),\n            interpolate ? yPos : Math.round(yPos),\n            interpolate ? width : Math.round(xPos + width) - Math.round(xPos),\n            interpolate ? height : Math.round(yPos + height) - Math.round(yPos),\n          );\n          stitchContext.clip();\n        }\n\n        const xPos = (src.extent[0] - sourceDataExtent[0]) * stitchScale;\n        const yPos = -(src.extent[3] - sourceDataExtent[3]) * stitchScale;\n        const srcWidth = getWidth(src.extent) * stitchScale;\n        const srcHeight = getHeight(src.extent) * stitchScale;\n        stitchContext.drawImage(\n          src.image,\n          gutter,\n          gutter,\n          src.image.width - 2 * gutter,\n          src.image.height - 2 * gutter,\n          interpolate ? xPos : Math.round(xPos),\n          interpolate ? yPos : Math.round(yPos),\n          interpolate\n            ? srcWidth\n            : Math.round(xPos + srcWidth) - Math.round(xPos),\n          interpolate\n            ? srcHeight\n            : Math.round(yPos + srcHeight) - Math.round(yPos),\n        );\n\n        if (src.clipExtent) {\n          stitchContext.restore();\n        }\n      }\n    });\n  }\n  const targetTopLeft = getTopLeft(targetExtent);\n\n  triangulation.getTriangles().forEach(function (triangle, i, arr) {\n    /* Calculate affine transform (src -> dst)\n     * Resulting matrix can be used to transform coordinate\n     * from `sourceProjection` to destination pixels.\n     *\n     * To optimize number of context calls and increase numerical stability,\n     * we also do the following operations:\n     * trans(-topLeftExtentCorner), scale(1 / targetResolution), scale(1, -1)\n     * here before solving the linear system so [ui, vi] are pixel coordinates.\n     *\n     * Src points: xi, yi\n     * Dst points: ui, vi\n     * Affine coefficients: aij\n     *\n     * | x0 y0 1  0  0 0 |   |a00|   |u0|\n     * | x1 y1 1  0  0 0 |   |a01|   |u1|\n     * | x2 y2 1  0  0 0 | x |a02| = |u2|\n     * |  0  0 0 x0 y0 1 |   |a10|   |v0|\n     * |  0  0 0 x1 y1 1 |   |a11|   |v1|\n     * |  0  0 0 x2 y2 1 |   |a12|   |v2|\n     */\n    const source = triangle.source;\n    const target = triangle.target;\n    let x0 = source[0][0],\n      y0 = source[0][1];\n    let x1 = source[1][0],\n      y1 = source[1][1];\n    let x2 = source[2][0],\n      y2 = source[2][1];\n    // Make sure that everything is on pixel boundaries\n    const u0 = pixelRound((target[0][0] - targetTopLeft[0]) / targetResolution);\n    const v0 = pixelRound(\n      -(target[0][1] - targetTopLeft[1]) / targetResolution,\n    );\n    const u1 = pixelRound((target[1][0] - targetTopLeft[0]) / targetResolution);\n    const v1 = pixelRound(\n      -(target[1][1] - targetTopLeft[1]) / targetResolution,\n    );\n    const u2 = pixelRound((target[2][0] - targetTopLeft[0]) / targetResolution);\n    const v2 = pixelRound(\n      -(target[2][1] - targetTopLeft[1]) / targetResolution,\n    );\n\n    // Shift all the source points to improve numerical stability\n    // of all the subsequent calculations. The [x0, y0] is used here.\n    // This is also used to simplify the linear system.\n    const sourceNumericalShiftX = x0;\n    const sourceNumericalShiftY = y0;\n    x0 = 0;\n    y0 = 0;\n    x1 -= sourceNumericalShiftX;\n    y1 -= sourceNumericalShiftY;\n    x2 -= sourceNumericalShiftX;\n    y2 -= sourceNumericalShiftY;\n\n    const augmentedMatrix = [\n      [x1, y1, 0, 0, u1 - u0],\n      [x2, y2, 0, 0, u2 - u0],\n      [0, 0, x1, y1, v1 - v0],\n      [0, 0, x2, y2, v2 - v0],\n    ];\n    const affineCoefs = solveLinearSystem(augmentedMatrix);\n    if (!affineCoefs) {\n      return;\n    }\n\n    context.save();\n    context.beginPath();\n\n    if (isBrokenDiagonalRendering() || !interpolate) {\n      // Make sure that all lines are horizontal or vertical\n      context.moveTo(u1, v1);\n      // This is the diagonal line. Do it in 4 steps\n      const steps = 4;\n      const ud = u0 - u1;\n      const vd = v0 - v1;\n      for (let step = 0; step < steps; step++) {\n        // Go horizontally\n        context.lineTo(\n          u1 + pixelRound(((step + 1) * ud) / steps),\n          v1 + pixelRound((step * vd) / (steps - 1)),\n        );\n        // Go vertically\n        if (step != steps - 1) {\n          context.lineTo(\n            u1 + pixelRound(((step + 1) * ud) / steps),\n            v1 + pixelRound(((step + 1) * vd) / (steps - 1)),\n          );\n        }\n      }\n      // We are almost at u0r, v0r\n      context.lineTo(u2, v2);\n    } else {\n      context.moveTo(u1, v1);\n      context.lineTo(u0, v0);\n      context.lineTo(u2, v2);\n    }\n\n    context.clip();\n\n    context.transform(\n      affineCoefs[0],\n      affineCoefs[2],\n      affineCoefs[1],\n      affineCoefs[3],\n      u0,\n      v0,\n    );\n\n    context.translate(\n      sourceDataExtent[0] - sourceNumericalShiftX,\n      sourceDataExtent[3] - sourceNumericalShiftY,\n    );\n\n    let image;\n    if (stitchContext) {\n      image = stitchContext.canvas;\n      context.scale(inverseScale, -inverseScale);\n    } else {\n      const source = sources[0];\n      const extent = source.extent;\n      image = source.image;\n      context.scale(\n        getWidth(extent) / image.width,\n        -getHeight(extent) / image.height,\n      );\n    }\n\n    context.drawImage(image, 0, 0);\n    context.restore();\n  });\n\n  if (stitchContext) {\n    releaseCanvas(stitchContext);\n    canvasPool.push(stitchContext.canvas);\n  }\n\n  if (renderEdges) {\n    context.save();\n\n    context.globalCompositeOperation = 'source-over';\n    context.strokeStyle = 'black';\n    context.lineWidth = 1;\n\n    triangulation.getTriangles().forEach(function (triangle, i, arr) {\n      const target = triangle.target;\n      const u0 = (target[0][0] - targetTopLeft[0]) / targetResolution;\n      const v0 = -(target[0][1] - targetTopLeft[1]) / targetResolution;\n      const u1 = (target[1][0] - targetTopLeft[0]) / targetResolution;\n      const v1 = -(target[1][1] - targetTopLeft[1]) / targetResolution;\n      const u2 = (target[2][0] - targetTopLeft[0]) / targetResolution;\n      const v2 = -(target[2][1] - targetTopLeft[1]) / targetResolution;\n\n      context.beginPath();\n      context.moveTo(u1, v1);\n      context.lineTo(u0, v0);\n      context.lineTo(u2, v2);\n      context.closePath();\n      context.stroke();\n    });\n\n    context.restore();\n  }\n  return context.canvas;\n}\n","/**\n * @module ol/resolution\n */\n\n/**\n * @typedef {number|Array<number>} ResolutionLike\n */\n\n/**\n * @param {ResolutionLike} resolution Resolution.\n * @return {number} Resolution.\n */\nexport function fromResolutionLike(resolution) {\n  if (Array.isArray(resolution)) {\n    return Math.min(...resolution);\n  }\n  return resolution;\n}\n","/**\n * @module ol/structs/LRUCache\n */\n\nimport Disposable from '../Disposable.js';\nimport {assert} from '../asserts.js';\n\n/**\n * @typedef {Object} Entry\n * @property {string} key_ Key.\n * @property {Entry|null} newer Newer.\n * @property {Entry|null} older Older.\n * @property {*} value_ Value.\n */\n\n/**\n * @classdesc\n * Implements a Least-Recently-Used cache where the keys do not conflict with\n * Object's properties (e.g. 'hasOwnProperty' is not allowed as a key). Expiring\n * items from the cache is the responsibility of the user.\n *\n * @fires import(\"../events/Event.js\").default\n * @template T\n */\nclass LRUCache {\n  /**\n   * @param {number} [highWaterMark] High water mark.\n   */\n  constructor(highWaterMark) {\n    /**\n     * Desired max cache size after expireCache(). If set to 0, no cache entries\n     * will be pruned at all.\n     * @type {number}\n     */\n    this.highWaterMark = highWaterMark !== undefined ? highWaterMark : 2048;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.count_ = 0;\n\n    /**\n     * @private\n     * @type {!Object<string, Entry>}\n     */\n    this.entries_ = {};\n\n    /**\n     * @private\n     * @type {?Entry}\n     */\n    this.oldest_ = null;\n\n    /**\n     * @private\n     * @type {?Entry}\n     */\n    this.newest_ = null;\n  }\n\n  deleteOldest() {\n    const entry = this.pop();\n    if (entry instanceof Disposable) {\n      entry.dispose();\n    }\n  }\n\n  /**\n   * @return {boolean} Can expire cache.\n   */\n  canExpireCache() {\n    return this.highWaterMark > 0 && this.getCount() > this.highWaterMark;\n  }\n\n  /**\n   * Expire the cache. When the cache entry is a {@link module:ol/Disposable~Disposable},\n   * the entry will be disposed.\n   * @param {!Object<string, boolean>} [keep] Keys to keep. To be implemented by subclasses.\n   */\n  expireCache(keep) {\n    while (this.canExpireCache()) {\n      this.deleteOldest();\n    }\n  }\n\n  /**\n   * FIXME empty description for jsdoc\n   */\n  clear() {\n    while (this.oldest_) {\n      this.deleteOldest();\n    }\n  }\n\n  /**\n   * @param {string} key Key.\n   * @return {boolean} Contains key.\n   */\n  containsKey(key) {\n    return this.entries_.hasOwnProperty(key);\n  }\n\n  /**\n   * @param {function(T, string, LRUCache<T>): ?} f The function\n   *     to call for every entry from the oldest to the newer. This function takes\n   *     3 arguments (the entry value, the entry key and the LRUCache object).\n   *     The return value is ignored.\n   */\n  forEach(f) {\n    let entry = this.oldest_;\n    while (entry) {\n      f(entry.value_, entry.key_, this);\n      entry = entry.newer;\n    }\n  }\n\n  /**\n   * @param {string} key Key.\n   * @param {*} [options] Options (reserved for subclasses).\n   * @return {T} Value.\n   */\n  get(key, options) {\n    const entry = this.entries_[key];\n    assert(\n      entry !== undefined,\n      'Tried to get a value for a key that does not exist in the cache',\n    );\n    if (entry === this.newest_) {\n      return entry.value_;\n    }\n    if (entry === this.oldest_) {\n      this.oldest_ = /** @type {Entry} */ (this.oldest_.newer);\n      this.oldest_.older = null;\n    } else {\n      entry.newer.older = entry.older;\n      entry.older.newer = entry.newer;\n    }\n    entry.newer = null;\n    entry.older = this.newest_;\n    this.newest_.newer = entry;\n    this.newest_ = entry;\n    return entry.value_;\n  }\n\n  /**\n   * Remove an entry from the cache.\n   * @param {string} key The entry key.\n   * @return {T} The removed entry.\n   */\n  remove(key) {\n    const entry = this.entries_[key];\n    assert(\n      entry !== undefined,\n      'Tried to get a value for a key that does not exist in the cache',\n    );\n    if (entry === this.newest_) {\n      this.newest_ = /** @type {Entry} */ (entry.older);\n      if (this.newest_) {\n        this.newest_.newer = null;\n      }\n    } else if (entry === this.oldest_) {\n      this.oldest_ = /** @type {Entry} */ (entry.newer);\n      if (this.oldest_) {\n        this.oldest_.older = null;\n      }\n    } else {\n      entry.newer.older = entry.older;\n      entry.older.newer = entry.newer;\n    }\n    delete this.entries_[key];\n    --this.count_;\n    return entry.value_;\n  }\n\n  /**\n   * @return {number} Count.\n   */\n  getCount() {\n    return this.count_;\n  }\n\n  /**\n   * @return {Array<string>} Keys.\n   */\n  getKeys() {\n    const keys = new Array(this.count_);\n    let i = 0;\n    let entry;\n    for (entry = this.newest_; entry; entry = entry.older) {\n      keys[i++] = entry.key_;\n    }\n    return keys;\n  }\n\n  /**\n   * @return {Array<T>} Values.\n   */\n  getValues() {\n    const values = new Array(this.count_);\n    let i = 0;\n    let entry;\n    for (entry = this.newest_; entry; entry = entry.older) {\n      values[i++] = entry.value_;\n    }\n    return values;\n  }\n\n  /**\n   * @return {T} Last value.\n   */\n  peekLast() {\n    return this.oldest_.value_;\n  }\n\n  /**\n   * @return {string} Last key.\n   */\n  peekLastKey() {\n    return this.oldest_.key_;\n  }\n\n  /**\n   * Get the key of the newest item in the cache.  Throws if the cache is empty.\n   * @return {string} The newest key.\n   */\n  peekFirstKey() {\n    return this.newest_.key_;\n  }\n\n  /**\n   * Return an entry without updating least recently used time.\n   * @param {string} key Key.\n   * @return {T|undefined} Value.\n   */\n  peek(key) {\n    return this.entries_[key]?.value_;\n  }\n\n  /**\n   * @return {T} value Value.\n   */\n  pop() {\n    const entry = this.oldest_;\n    delete this.entries_[entry.key_];\n    if (entry.newer) {\n      entry.newer.older = null;\n    }\n    this.oldest_ = /** @type {Entry} */ (entry.newer);\n    if (!this.oldest_) {\n      this.newest_ = null;\n    }\n    --this.count_;\n    return entry.value_;\n  }\n\n  /**\n   * @param {string} key Key.\n   * @param {T} value Value.\n   */\n  replace(key, value) {\n    this.get(key); // update `newest_`\n    this.entries_[key].value_ = value;\n  }\n\n  /**\n   * @param {string} key Key.\n   * @param {T} value Value.\n   */\n  set(key, value) {\n    assert(\n      !(key in this.entries_),\n      'Tried to set a value for a key that is used already',\n    );\n    const entry = {\n      key_: key,\n      newer: null,\n      older: this.newest_,\n      value_: value,\n    };\n    if (!this.newest_) {\n      this.oldest_ = entry;\n    } else {\n      this.newest_.newer = entry;\n    }\n    this.newest_ = entry;\n    this.entries_[key] = entry;\n    ++this.count_;\n  }\n\n  /**\n   * Set a maximum number of entries for the cache.\n   * @param {number} size Cache size.\n   * @api\n   */\n  setSize(size) {\n    this.highWaterMark = size;\n  }\n}\n\nexport default LRUCache;\n","/**\n * @module ol/tilecoord\n */\n\nimport {getUid} from './util.js';\n\n/**\n * An array of three numbers representing the location of a tile in a tile\n * grid. The order is `z` (zoom level), `x` (column), and `y` (row).\n * @typedef {Array<number>} TileCoord\n * @api\n */\n\n/**\n * @param {number} z Z.\n * @param {number} x X.\n * @param {number} y Y.\n * @param {TileCoord} [tileCoord] Tile coordinate.\n * @return {TileCoord} Tile coordinate.\n */\nexport function createOrUpdate(z, x, y, tileCoord) {\n  if (tileCoord !== undefined) {\n    tileCoord[0] = z;\n    tileCoord[1] = x;\n    tileCoord[2] = y;\n    return tileCoord;\n  }\n  return [z, x, y];\n}\n\n/**\n * @param {number} z Z.\n * @param {number} x X.\n * @param {number} y Y.\n * @return {string} Key.\n */\nexport function getKeyZXY(z, x, y) {\n  return z + '/' + x + '/' + y;\n}\n\n/**\n * Get the key for a tile coord.\n * @param {TileCoord} tileCoord The tile coord.\n * @return {string} Key.\n */\nexport function getKey(tileCoord) {\n  return getKeyZXY(tileCoord[0], tileCoord[1], tileCoord[2]);\n}\n\n/**\n * Get the tile cache key for a tile key obtained through `tile.getKey()`.\n * @param {string} tileKey The tile key.\n * @return {string} The cache key.\n */\nexport function getCacheKeyForTileKey(tileKey) {\n  const [z, x, y] = tileKey\n    .substring(tileKey.lastIndexOf('/') + 1, tileKey.length)\n    .split(',')\n    .map(Number);\n  return getKeyZXY(z, x, y);\n}\n\n/**\n * @param {import(\"./source/Tile.js\").default} source The tile source.\n * @param {string} sourceKey The source key.\n * @param {number} z The tile z level.\n * @param {number} x The tile x level.\n * @param {number} y The tile y level.\n * @return {string} The cache key.\n */\nexport function getCacheKey(source, sourceKey, z, x, y) {\n  return `${getUid(source)},${sourceKey},${getKeyZXY(z, x, y)}`;\n}\n\n/**\n * Get a tile coord given a key.\n * @param {string} key The tile coord key.\n * @return {TileCoord} The tile coord.\n */\nexport function fromKey(key) {\n  return key.split('/').map(Number);\n}\n\n/**\n * @param {TileCoord} tileCoord Tile coord.\n * @return {number} Hash.\n */\nexport function hash(tileCoord) {\n  return hashZXY(tileCoord[0], tileCoord[1], tileCoord[2]);\n}\n\n/**\n * @param {number} z The tile z coordinate.\n * @param {number} x The tile x coordinate.\n * @param {number} y The tile y coordinate.\n * @return {number} Hash.\n */\nexport function hashZXY(z, x, y) {\n  return (x << z) + y;\n}\n\n/**\n * @param {TileCoord} tileCoord Tile coordinate.\n * @param {!import(\"./tilegrid/TileGrid.js\").default} tileGrid Tile grid.\n * @return {boolean} Tile coordinate is within extent and zoom level range.\n */\nexport function withinExtentAndZ(tileCoord, tileGrid) {\n  const z = tileCoord[0];\n  const x = tileCoord[1];\n  const y = tileCoord[2];\n\n  if (tileGrid.getMinZoom() > z || z > tileGrid.getMaxZoom()) {\n    return false;\n  }\n  const tileRange = tileGrid.getFullTileRange(z);\n  if (!tileRange) {\n    return true;\n  }\n  return tileRange.containsXY(x, y);\n}\n","/**\n * @module ol/uri\n */\n\nimport {modulo} from './math.js';\nimport {hashZXY} from './tilecoord.js';\n\n/**\n * Appends query parameters to a URI.\n *\n * @param {string} uri The original URI, which may already have query data.\n * @param {!Object} params An object where keys are URI-encoded parameter keys,\n *     and the values are arbitrary types or arrays.\n * @return {string} The new URI.\n */\nexport function appendParams(uri, params) {\n  /** @type {Array<string>} */\n  const keyParams = [];\n  // Skip any null or undefined parameter values\n  Object.keys(params).forEach(function (k) {\n    if (params[k] !== null && params[k] !== undefined) {\n      keyParams.push(k + '=' + encodeURIComponent(params[k]));\n    }\n  });\n  const qs = keyParams.join('&');\n  // remove any trailing ? or &\n  uri = uri.replace(/[?&]$/, '');\n  // append ? or & depending on whether uri has existing parameters\n  uri += uri.includes('?') ? '&' : '?';\n  return uri + qs;\n}\n\nconst zRegEx = /\\{z\\}/g;\nconst xRegEx = /\\{x\\}/g;\nconst yRegEx = /\\{y\\}/g;\nconst dashYRegEx = /\\{-y\\}/g;\n\n/**\n * @param {string} template The URL template.  Should have `{x}`, `{y}`, and `{z}` placeholders.  If\n * the template has a `{-y}` placeholder, the `maxY` parameter must be supplied.\n * @param {number} z The tile z coordinate.\n * @param {number} x The tile x coordinate.\n * @param {number} y The tile y coordinate.\n * @param {number} [maxY] The maximum y coordinate at the given z level.\n * @return {string} The URL.\n */\nexport function renderXYZTemplate(template, z, x, y, maxY) {\n  return template\n    .replace(zRegEx, z.toString())\n    .replace(xRegEx, x.toString())\n    .replace(yRegEx, y.toString())\n    .replace(dashYRegEx, function () {\n      if (maxY === undefined) {\n        throw new Error(\n          'If the URL template has a {-y} placeholder, the grid extent must be known',\n        );\n      }\n      return (maxY - y).toString();\n    });\n}\n\n/**\n * @param {Array<string>} urls List of URLs.\n * @param {number} z The tile z coordinate.\n * @param {number} x The tile x coordinate.\n * @param {number} y The tile y coordinate.\n * @return {string} The chosen URL.\n */\nexport function pickUrl(urls, z, x, y) {\n  const hash = hashZXY(z, x, y);\n  const index = modulo(hash, urls.length);\n  return urls[index];\n}\n\n/**\n * @param {string} url URL.\n * @return {Array<string>} Array of urls.\n */\nexport function expandUrl(url) {\n  const urls = [];\n  let match = /\\{([a-z])-([a-z])\\}/.exec(url);\n  if (match) {\n    // char range\n    const startCharCode = match[1].charCodeAt(0);\n    const stopCharCode = match[2].charCodeAt(0);\n    let charCode;\n    for (charCode = startCharCode; charCode <= stopCharCode; ++charCode) {\n      urls.push(url.replace(match[0], String.fromCharCode(charCode)));\n    }\n    return urls;\n  }\n  match = /\\{(\\d+)-(\\d+)\\}/.exec(url);\n  if (match) {\n    // number range\n    const stop = parseInt(match[2], 10);\n    for (let i = parseInt(match[1], 10); i <= stop; i++) {\n      urls.push(url.replace(match[0], i.toString()));\n    }\n    return urls;\n  }\n  urls.push(url);\n  return urls;\n}\n","/**\n * @module ol/reproj/Triangulation\n */\nimport {\n  boundingExtent,\n  createEmpty,\n  extendCoordinate,\n  getArea,\n  getBottomLeft,\n  getBottomRight,\n  getTopLeft,\n  getTopRight,\n  getWidth,\n  intersects,\n} from '../extent.js';\nimport {modulo} from '../math.js';\nimport {\n  createTransformFromCoordinateTransform,\n  getTransform,\n  transform,\n} from '../proj.js';\nimport {apply as applyMatrix} from '../transform.js';\n\n/**\n * Single triangle; consists of 3 source points and 3 target points.\n * @typedef {Object} Triangle\n * @property {Array<import(\"../coordinate.js\").Coordinate>} source Source.\n * @property {Array<import(\"../coordinate.js\").Coordinate>} target Target.\n */\n\n/**\n * Maximum number of subdivision steps during raster reprojection triangulation.\n * Prevents high memory usage and large number of proj4 calls (for certain\n * transformations and areas). At most `2*(2^this)` triangles are created for\n * each triangulated extent (tile/image).\n * @type {number}\n */\nconst MAX_SUBDIVISION = 10;\n\n/**\n * Maximum allowed size of triangle relative to world width. When transforming\n * corners of world extent between certain projections, the resulting\n * triangulation seems to have zero error and no subdivision is performed. If\n * the triangle width is more than this (relative to world width; 0-1),\n * subdivison is forced (up to `MAX_SUBDIVISION`). Default is `0.25`.\n * @type {number}\n */\nconst MAX_TRIANGLE_WIDTH = 0.25;\n\n/**\n * @classdesc\n * Class containing triangulation of the given target extent.\n * Used for determining source data and the reprojection itself.\n */\nclass Triangulation {\n  /**\n   * @param {import(\"../proj/Projection.js\").default} sourceProj Source projection.\n   * @param {import(\"../proj/Projection.js\").default} targetProj Target projection.\n   * @param {import(\"../extent.js\").Extent} targetExtent Target extent to triangulate.\n   * @param {import(\"../extent.js\").Extent} maxSourceExtent Maximal source extent that can be used.\n   * @param {number} errorThreshold Acceptable error (in source units).\n   * @param {?number} destinationResolution The (optional) resolution of the destination.\n   * @param {import(\"../transform.js\").Transform} [sourceMatrix] Source transform matrix.\n   */\n  constructor(\n    sourceProj,\n    targetProj,\n    targetExtent,\n    maxSourceExtent,\n    errorThreshold,\n    destinationResolution,\n    sourceMatrix,\n  ) {\n    /**\n     * @type {import(\"../proj/Projection.js\").default}\n     * @private\n     */\n    this.sourceProj_ = sourceProj;\n\n    /**\n     * @type {import(\"../proj/Projection.js\").default}\n     * @private\n     */\n    this.targetProj_ = targetProj;\n\n    /** @type {!Object<string, import(\"../coordinate.js\").Coordinate>} */\n    let transformInvCache = {};\n    const transformInv = sourceMatrix\n      ? createTransformFromCoordinateTransform((input) =>\n          applyMatrix(\n            sourceMatrix,\n            transform(input, this.targetProj_, this.sourceProj_),\n          ),\n        )\n      : getTransform(this.targetProj_, this.sourceProj_);\n\n    /**\n     * @param {import(\"../coordinate.js\").Coordinate} c A coordinate.\n     * @return {import(\"../coordinate.js\").Coordinate} Transformed coordinate.\n     * @private\n     */\n    this.transformInv_ = function (c) {\n      const key = c[0] + '/' + c[1];\n      if (!transformInvCache[key]) {\n        transformInvCache[key] = transformInv(c);\n      }\n      return transformInvCache[key];\n    };\n\n    /**\n     * @type {import(\"../extent.js\").Extent}\n     * @private\n     */\n    this.maxSourceExtent_ = maxSourceExtent;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.errorThresholdSquared_ = errorThreshold * errorThreshold;\n\n    /**\n     * @type {Array<Triangle>}\n     * @private\n     */\n    this.triangles_ = [];\n\n    /**\n     * Indicates that the triangulation crosses edge of the source projection.\n     * @type {boolean}\n     * @private\n     */\n    this.wrapsXInSource_ = false;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.canWrapXInSource_ =\n      this.sourceProj_.canWrapX() &&\n      !!maxSourceExtent &&\n      !!this.sourceProj_.getExtent() &&\n      getWidth(maxSourceExtent) >= getWidth(this.sourceProj_.getExtent());\n\n    /**\n     * @type {?number}\n     * @private\n     */\n    this.sourceWorldWidth_ = this.sourceProj_.getExtent()\n      ? getWidth(this.sourceProj_.getExtent())\n      : null;\n\n    /**\n     * @type {?number}\n     * @private\n     */\n    this.targetWorldWidth_ = this.targetProj_.getExtent()\n      ? getWidth(this.targetProj_.getExtent())\n      : null;\n\n    const destinationTopLeft = getTopLeft(targetExtent);\n    const destinationTopRight = getTopRight(targetExtent);\n    const destinationBottomRight = getBottomRight(targetExtent);\n    const destinationBottomLeft = getBottomLeft(targetExtent);\n    const sourceTopLeft = this.transformInv_(destinationTopLeft);\n    const sourceTopRight = this.transformInv_(destinationTopRight);\n    const sourceBottomRight = this.transformInv_(destinationBottomRight);\n    const sourceBottomLeft = this.transformInv_(destinationBottomLeft);\n\n    /*\n     * The maxSubdivision controls how many splittings of the target area can\n     * be done. The idea here is to do a linear mapping of the target areas\n     * but the actual overall reprojection (can be) extremely non-linear. The\n     * default value of MAX_SUBDIVISION was chosen based on mapping a 256x256\n     * tile size. However this function is also called to remap canvas rendered\n     * layers which can be much larger. This calculation increases the maxSubdivision\n     * value by the right factor so that each 256x256 pixel area has\n     * MAX_SUBDIVISION divisions.\n     */\n    const maxSubdivision =\n      MAX_SUBDIVISION +\n      (destinationResolution\n        ? Math.max(\n            0,\n            Math.ceil(\n              Math.log2(\n                getArea(targetExtent) /\n                  (destinationResolution * destinationResolution * 256 * 256),\n              ),\n            ),\n          )\n        : 0);\n\n    this.addQuad_(\n      destinationTopLeft,\n      destinationTopRight,\n      destinationBottomRight,\n      destinationBottomLeft,\n      sourceTopLeft,\n      sourceTopRight,\n      sourceBottomRight,\n      sourceBottomLeft,\n      maxSubdivision,\n    );\n\n    if (this.wrapsXInSource_) {\n      let leftBound = Infinity;\n      this.triangles_.forEach(function (triangle, i, arr) {\n        leftBound = Math.min(\n          leftBound,\n          triangle.source[0][0],\n          triangle.source[1][0],\n          triangle.source[2][0],\n        );\n      });\n\n      // Shift triangles to be as close to `leftBound` as possible\n      // (if the distance is more than `worldWidth / 2` it can be closer.\n      this.triangles_.forEach((triangle) => {\n        if (\n          Math.max(\n            triangle.source[0][0],\n            triangle.source[1][0],\n            triangle.source[2][0],\n          ) -\n            leftBound >\n          this.sourceWorldWidth_ / 2\n        ) {\n          const newTriangle = [\n            [triangle.source[0][0], triangle.source[0][1]],\n            [triangle.source[1][0], triangle.source[1][1]],\n            [triangle.source[2][0], triangle.source[2][1]],\n          ];\n          if (newTriangle[0][0] - leftBound > this.sourceWorldWidth_ / 2) {\n            newTriangle[0][0] -= this.sourceWorldWidth_;\n          }\n          if (newTriangle[1][0] - leftBound > this.sourceWorldWidth_ / 2) {\n            newTriangle[1][0] -= this.sourceWorldWidth_;\n          }\n          if (newTriangle[2][0] - leftBound > this.sourceWorldWidth_ / 2) {\n            newTriangle[2][0] -= this.sourceWorldWidth_;\n          }\n\n          // Rarely (if the extent contains both the dateline and prime meridian)\n          // the shift can in turn break some triangles.\n          // Detect this here and don't shift in such cases.\n          const minX = Math.min(\n            newTriangle[0][0],\n            newTriangle[1][0],\n            newTriangle[2][0],\n          );\n          const maxX = Math.max(\n            newTriangle[0][0],\n            newTriangle[1][0],\n            newTriangle[2][0],\n          );\n          if (maxX - minX < this.sourceWorldWidth_ / 2) {\n            triangle.source = newTriangle;\n          }\n        }\n      });\n    }\n\n    transformInvCache = {};\n  }\n\n  /**\n   * Adds triangle to the triangulation.\n   * @param {import(\"../coordinate.js\").Coordinate} a The target a coordinate.\n   * @param {import(\"../coordinate.js\").Coordinate} b The target b coordinate.\n   * @param {import(\"../coordinate.js\").Coordinate} c The target c coordinate.\n   * @param {import(\"../coordinate.js\").Coordinate} aSrc The source a coordinate.\n   * @param {import(\"../coordinate.js\").Coordinate} bSrc The source b coordinate.\n   * @param {import(\"../coordinate.js\").Coordinate} cSrc The source c coordinate.\n   * @private\n   */\n  addTriangle_(a, b, c, aSrc, bSrc, cSrc) {\n    this.triangles_.push({\n      source: [aSrc, bSrc, cSrc],\n      target: [a, b, c],\n    });\n  }\n\n  /**\n   * Adds quad (points in clock-wise order) to the triangulation\n   * (and reprojects the vertices) if valid.\n   * Performs quad subdivision if needed to increase precision.\n   *\n   * @param {import(\"../coordinate.js\").Coordinate} a The target a coordinate.\n   * @param {import(\"../coordinate.js\").Coordinate} b The target b coordinate.\n   * @param {import(\"../coordinate.js\").Coordinate} c The target c coordinate.\n   * @param {import(\"../coordinate.js\").Coordinate} d The target d coordinate.\n   * @param {import(\"../coordinate.js\").Coordinate} aSrc The source a coordinate.\n   * @param {import(\"../coordinate.js\").Coordinate} bSrc The source b coordinate.\n   * @param {import(\"../coordinate.js\").Coordinate} cSrc The source c coordinate.\n   * @param {import(\"../coordinate.js\").Coordinate} dSrc The source d coordinate.\n   * @param {number} maxSubdivision Maximal allowed subdivision of the quad.\n   * @private\n   */\n  addQuad_(a, b, c, d, aSrc, bSrc, cSrc, dSrc, maxSubdivision) {\n    const sourceQuadExtent = boundingExtent([aSrc, bSrc, cSrc, dSrc]);\n    const sourceCoverageX = this.sourceWorldWidth_\n      ? getWidth(sourceQuadExtent) / this.sourceWorldWidth_\n      : null;\n    const sourceWorldWidth = /** @type {number} */ (this.sourceWorldWidth_);\n\n    // when the quad is wrapped in the source projection\n    // it covers most of the projection extent, but not fully\n    const wrapsX =\n      this.sourceProj_.canWrapX() &&\n      sourceCoverageX > 0.5 &&\n      sourceCoverageX < 1;\n\n    let needsSubdivision = false;\n\n    if (maxSubdivision > 0) {\n      if (this.targetProj_.isGlobal() && this.targetWorldWidth_) {\n        const targetQuadExtent = boundingExtent([a, b, c, d]);\n        const targetCoverageX =\n          getWidth(targetQuadExtent) / this.targetWorldWidth_;\n        needsSubdivision =\n          targetCoverageX > MAX_TRIANGLE_WIDTH || needsSubdivision;\n      }\n      if (!wrapsX && this.sourceProj_.isGlobal() && sourceCoverageX) {\n        needsSubdivision =\n          sourceCoverageX > MAX_TRIANGLE_WIDTH || needsSubdivision;\n      }\n    }\n\n    if (!needsSubdivision && this.maxSourceExtent_) {\n      if (\n        isFinite(sourceQuadExtent[0]) &&\n        isFinite(sourceQuadExtent[1]) &&\n        isFinite(sourceQuadExtent[2]) &&\n        isFinite(sourceQuadExtent[3])\n      ) {\n        if (!intersects(sourceQuadExtent, this.maxSourceExtent_)) {\n          // whole quad outside source projection extent -> ignore\n          return;\n        }\n      }\n    }\n\n    let isNotFinite = 0;\n\n    if (!needsSubdivision) {\n      if (\n        !isFinite(aSrc[0]) ||\n        !isFinite(aSrc[1]) ||\n        !isFinite(bSrc[0]) ||\n        !isFinite(bSrc[1]) ||\n        !isFinite(cSrc[0]) ||\n        !isFinite(cSrc[1]) ||\n        !isFinite(dSrc[0]) ||\n        !isFinite(dSrc[1])\n      ) {\n        if (maxSubdivision > 0) {\n          needsSubdivision = true;\n        } else {\n          // It might be the case that only 1 of the points is infinite. In this case\n          // we can draw a single triangle with the other three points\n          isNotFinite =\n            (!isFinite(aSrc[0]) || !isFinite(aSrc[1]) ? 8 : 0) +\n            (!isFinite(bSrc[0]) || !isFinite(bSrc[1]) ? 4 : 0) +\n            (!isFinite(cSrc[0]) || !isFinite(cSrc[1]) ? 2 : 0) +\n            (!isFinite(dSrc[0]) || !isFinite(dSrc[1]) ? 1 : 0);\n          if (\n            isNotFinite != 1 &&\n            isNotFinite != 2 &&\n            isNotFinite != 4 &&\n            isNotFinite != 8\n          ) {\n            return;\n          }\n        }\n      }\n    }\n\n    if (maxSubdivision > 0) {\n      if (!needsSubdivision) {\n        const center = [(a[0] + c[0]) / 2, (a[1] + c[1]) / 2];\n        const centerSrc = this.transformInv_(center);\n\n        let dx;\n        if (wrapsX) {\n          const centerSrcEstimX =\n            (modulo(aSrc[0], sourceWorldWidth) +\n              modulo(cSrc[0], sourceWorldWidth)) /\n            2;\n          dx = centerSrcEstimX - modulo(centerSrc[0], sourceWorldWidth);\n        } else {\n          dx = (aSrc[0] + cSrc[0]) / 2 - centerSrc[0];\n        }\n        const dy = (aSrc[1] + cSrc[1]) / 2 - centerSrc[1];\n        const centerSrcErrorSquared = dx * dx + dy * dy;\n        needsSubdivision = centerSrcErrorSquared > this.errorThresholdSquared_;\n      }\n      if (needsSubdivision) {\n        if (Math.abs(a[0] - c[0]) <= Math.abs(a[1] - c[1])) {\n          // split horizontally (top & bottom)\n          const bc = [(b[0] + c[0]) / 2, (b[1] + c[1]) / 2];\n          const bcSrc = this.transformInv_(bc);\n          const da = [(d[0] + a[0]) / 2, (d[1] + a[1]) / 2];\n          const daSrc = this.transformInv_(da);\n\n          this.addQuad_(\n            a,\n            b,\n            bc,\n            da,\n            aSrc,\n            bSrc,\n            bcSrc,\n            daSrc,\n            maxSubdivision - 1,\n          );\n          this.addQuad_(\n            da,\n            bc,\n            c,\n            d,\n            daSrc,\n            bcSrc,\n            cSrc,\n            dSrc,\n            maxSubdivision - 1,\n          );\n        } else {\n          // split vertically (left & right)\n          const ab = [(a[0] + b[0]) / 2, (a[1] + b[1]) / 2];\n          const abSrc = this.transformInv_(ab);\n          const cd = [(c[0] + d[0]) / 2, (c[1] + d[1]) / 2];\n          const cdSrc = this.transformInv_(cd);\n\n          this.addQuad_(\n            a,\n            ab,\n            cd,\n            d,\n            aSrc,\n            abSrc,\n            cdSrc,\n            dSrc,\n            maxSubdivision - 1,\n          );\n          this.addQuad_(\n            ab,\n            b,\n            c,\n            cd,\n            abSrc,\n            bSrc,\n            cSrc,\n            cdSrc,\n            maxSubdivision - 1,\n          );\n        }\n        return;\n      }\n    }\n\n    if (wrapsX) {\n      if (!this.canWrapXInSource_) {\n        return;\n      }\n      this.wrapsXInSource_ = true;\n    }\n\n    // Exactly zero or one of *Src is not finite\n    // The triangles must have the diagonal line as the first side\n    // This is to allow easy code in reproj.s to make it straight for broken\n    // browsers that can't handle diagonal clipping\n    if ((isNotFinite & 0xb) == 0) {\n      this.addTriangle_(a, c, d, aSrc, cSrc, dSrc);\n    }\n    if ((isNotFinite & 0xe) == 0) {\n      this.addTriangle_(a, c, b, aSrc, cSrc, bSrc);\n    }\n    if (isNotFinite) {\n      // Try the other two triangles\n      if ((isNotFinite & 0xd) == 0) {\n        this.addTriangle_(b, d, a, bSrc, dSrc, aSrc);\n      }\n      if ((isNotFinite & 0x7) == 0) {\n        this.addTriangle_(b, d, c, bSrc, dSrc, cSrc);\n      }\n    }\n  }\n\n  /**\n   * Calculates extent of the `source` coordinates from all the triangles.\n   *\n   * @return {import(\"../extent.js\").Extent} Calculated extent.\n   */\n  calculateSourceExtent() {\n    const extent = createEmpty();\n\n    this.triangles_.forEach(function (triangle, i, arr) {\n      const src = triangle.source;\n      extendCoordinate(extent, src[0]);\n      extendCoordinate(extent, src[1]);\n      extendCoordinate(extent, src[2]);\n    });\n\n    return extent;\n  }\n\n  /**\n   * @return {Array<Triangle>} Array of the calculated triangles.\n   */\n  getTriangles() {\n    return this.triangles_;\n  }\n}\n\nexport default Triangulation;\n","/**\n * @module ol/reproj/common\n */\n\n/**\n * Default maximum allowed threshold  (in pixels) for reprojection\n * triangulation.\n * @type {number}\n */\nexport const ERROR_THRESHOLD = 0.5;\n","/**\n * @module ol/reproj/Image\n */\n\nimport ImageWrapper from '../Image.js';\nimport ImageState from '../ImageState.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport EventType from '../events/EventType.js';\nimport {\n  getCenter,\n  getHeight,\n  getIntersection,\n  getWidth,\n  isEmpty,\n} from '../extent.js';\nimport {\n  calculateSourceResolution,\n  render as renderReprojected,\n} from '../reproj.js';\nimport {fromResolutionLike} from '../resolution.js';\nimport Triangulation from './Triangulation.js';\nimport {ERROR_THRESHOLD} from './common.js';\n\n/**\n * @typedef {function(import(\"../extent.js\").Extent, number, number) : import(\"../Image.js\").default} FunctionType\n */\n\n/**\n * @classdesc\n * Class encapsulating single reprojected image.\n * See {@link module:ol/source/Image~ImageSource}.\n */\nclass ReprojImage extends ImageWrapper {\n  /**\n   * @param {import(\"../proj/Projection.js\").default} sourceProj Source projection (of the data).\n   * @param {import(\"../proj/Projection.js\").default} targetProj Target projection.\n   * @param {import(\"../extent.js\").Extent} targetExtent Target extent.\n   * @param {number} targetResolution Target resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {FunctionType} getImageFunction\n   *     Function returning source images (extent, resolution, pixelRatio).\n   * @param {boolean} interpolate Use linear interpolation when resampling.\n   */\n  constructor(\n    sourceProj,\n    targetProj,\n    targetExtent,\n    targetResolution,\n    pixelRatio,\n    getImageFunction,\n    interpolate,\n  ) {\n    let maxSourceExtent = sourceProj.getExtent();\n    if (maxSourceExtent && sourceProj.canWrapX()) {\n      maxSourceExtent = maxSourceExtent.slice();\n      maxSourceExtent[0] = -Infinity;\n      maxSourceExtent[2] = Infinity;\n    }\n    let maxTargetExtent = targetProj.getExtent();\n    if (maxTargetExtent && targetProj.canWrapX()) {\n      maxTargetExtent = maxTargetExtent.slice();\n      maxTargetExtent[0] = -Infinity;\n      maxTargetExtent[2] = Infinity;\n    }\n\n    const limitedTargetExtent = maxTargetExtent\n      ? getIntersection(targetExtent, maxTargetExtent)\n      : targetExtent;\n\n    const targetCenter = getCenter(limitedTargetExtent);\n    const sourceResolution = calculateSourceResolution(\n      sourceProj,\n      targetProj,\n      targetCenter,\n      targetResolution,\n    );\n\n    const errorThresholdInPixels = ERROR_THRESHOLD;\n\n    const triangulation = new Triangulation(\n      sourceProj,\n      targetProj,\n      limitedTargetExtent,\n      maxSourceExtent,\n      sourceResolution * errorThresholdInPixels,\n      targetResolution,\n    );\n\n    const sourceExtent = triangulation.calculateSourceExtent();\n    const sourceImage = isEmpty(sourceExtent)\n      ? null\n      : getImageFunction(sourceExtent, sourceResolution, pixelRatio);\n    const state = sourceImage ? ImageState.IDLE : ImageState.EMPTY;\n    const sourcePixelRatio = sourceImage ? sourceImage.getPixelRatio() : 1;\n\n    super(targetExtent, targetResolution, sourcePixelRatio, state);\n\n    /**\n     * @private\n     * @type {import(\"../proj/Projection.js\").default}\n     */\n    this.targetProj_ = targetProj;\n\n    /**\n     * @private\n     * @type {import(\"../extent.js\").Extent}\n     */\n    this.maxSourceExtent_ = maxSourceExtent;\n\n    /**\n     * @private\n     * @type {!import(\"./Triangulation.js\").default}\n     */\n    this.triangulation_ = triangulation;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.targetResolution_ = targetResolution;\n\n    /**\n     * @private\n     * @type {import(\"../extent.js\").Extent}\n     */\n    this.targetExtent_ = targetExtent;\n\n    /**\n     * @private\n     * @type {import(\"../Image.js\").default}\n     */\n    this.sourceImage_ = sourceImage;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.sourcePixelRatio_ = sourcePixelRatio;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.interpolate_ = interpolate;\n\n    /**\n     * @private\n     * @type {HTMLCanvasElement|OffscreenCanvas}\n     */\n    this.canvas_ = null;\n\n    /**\n     * @private\n     * @type {?import(\"../events.js\").EventsKey}\n     */\n    this.sourceListenerKey_ = null;\n  }\n\n  /**\n   * Clean up.\n   * @override\n   */\n  disposeInternal() {\n    if (this.state == ImageState.LOADING) {\n      this.unlistenSource_();\n    }\n    super.disposeInternal();\n  }\n\n  /**\n   * @return {HTMLCanvasElement|OffscreenCanvas} Image.\n   * @override\n   */\n  getImage() {\n    return this.canvas_;\n  }\n\n  /**\n   * @return {import(\"../proj/Projection.js\").default} Projection.\n   */\n  getProjection() {\n    return this.targetProj_;\n  }\n\n  /**\n   * @private\n   */\n  reproject_() {\n    const sourceState = this.sourceImage_.getState();\n    if (sourceState == ImageState.LOADED) {\n      const width = getWidth(this.targetExtent_) / this.targetResolution_;\n      const height = getHeight(this.targetExtent_) / this.targetResolution_;\n      this.canvas_ = renderReprojected(\n        width,\n        height,\n        this.sourcePixelRatio_,\n        fromResolutionLike(this.sourceImage_.getResolution()),\n        this.maxSourceExtent_,\n        this.targetResolution_,\n        this.targetExtent_,\n        this.triangulation_,\n        [\n          {\n            extent: this.sourceImage_.getExtent(),\n            image: this.sourceImage_.getImage(),\n          },\n        ],\n        0,\n        undefined,\n        this.interpolate_,\n        true,\n      );\n    }\n    this.state = sourceState;\n    this.changed();\n  }\n\n  /**\n   * Load not yet loaded URI.\n   * @override\n   */\n  load() {\n    if (this.state == ImageState.IDLE) {\n      this.state = ImageState.LOADING;\n      this.changed();\n\n      const sourceState = this.sourceImage_.getState();\n      if (sourceState == ImageState.LOADED || sourceState == ImageState.ERROR) {\n        this.reproject_();\n      } else {\n        this.sourceListenerKey_ = listen(\n          this.sourceImage_,\n          EventType.CHANGE,\n          (e) => {\n            const sourceState = this.sourceImage_.getState();\n            if (\n              sourceState == ImageState.LOADED ||\n              sourceState == ImageState.ERROR\n            ) {\n              this.unlistenSource_();\n              this.reproject_();\n            }\n          },\n        );\n        this.sourceImage_.load();\n      }\n    }\n  }\n\n  /**\n   * @private\n   */\n  unlistenSource_() {\n    unlistenByKey(\n      /** @type {!import(\"../events.js\").EventsKey} */ (\n        this.sourceListenerKey_\n      ),\n    );\n    this.sourceListenerKey_ = null;\n  }\n}\n\nexport default ReprojImage;\n","/**\n * @module ol/source/Source\n */\nimport BaseObject from '../Object.js';\nimport {get as getProjection} from '../proj.js';\n\n/**\n * @typedef {'undefined' | 'loading' | 'ready' | 'error'} State\n * State of the source, one of 'undefined', 'loading', 'ready' or 'error'.\n */\n\n/**\n * A function that takes a {@link import(\"../View.js\").ViewStateLayerStateExtent} and returns a string or\n * an array of strings representing source attributions.\n *\n * @typedef {function(import(\"../View.js\").ViewStateLayerStateExtent): (string|Array<string>)} Attribution\n */\n\n/**\n * A type that can be used to provide attribution information for data sources.\n *\n * It represents either\n * a simple string (e.g. `'© Acme Inc.'`)\n * an array of simple strings (e.g. `['© Acme Inc.', '© Bacme Inc.']`)\n * a function that returns a string or array of strings ({@link module:ol/source/Source~Attribution})\n *\n * @typedef {string|Array<string>|Attribution} AttributionLike\n */\n\n/**\n * @typedef {Object} Options\n * @property {AttributionLike} [attributions] Attributions.\n * @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is the view projection.\n * @property {import(\"./Source.js\").State} [state='ready'] State.\n * @property {boolean} [wrapX=false] WrapX.\n * @property {boolean} [interpolate=false] Use interpolated values when resampling.  By default,\n * the nearest neighbor is used when resampling.\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 {@link module:ol/layer/Layer~Layer} sources.\n *\n * A generic `change` event is triggered when the state of the source changes.\n * @abstract\n * @api\n */\nclass Source extends BaseObject {\n  /**\n   * @param {Options} options Source options.\n   */\n  constructor(options) {\n    super();\n\n    /**\n     * @protected\n     * @type {import(\"../proj/Projection.js\").default|null}\n     */\n    this.projection = getProjection(options.projection);\n\n    /**\n     * @private\n     * @type {?Attribution}\n     */\n    this.attributions_ = adaptAttributions(options.attributions);\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.attributionsCollapsible_ = options.attributionsCollapsible ?? true;\n\n    /**\n     * This source is currently loading data. Sources that defer loading to the\n     * map's tile queue never set this to a `truthy` value.\n     * @type {boolean|number}\n     */\n    this.loading = false;\n\n    /**\n     * @private\n     * @type {import(\"./Source.js\").State}\n     */\n    this.state_ = options.state !== undefined ? options.state : 'ready';\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.wrapX_ = options.wrapX !== undefined ? options.wrapX : false;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.interpolate_ = !!options.interpolate;\n\n    /**\n     * @protected\n     * @type {function(import(\"../View.js\").ViewOptions):void}\n     */\n    this.viewResolver = null;\n\n    /**\n     * @protected\n     * @type {function(Error):void}\n     */\n    this.viewRejector = null;\n\n    const self = this;\n    /**\n     * @private\n     * @type {Promise<import(\"../View.js\").ViewOptions>}\n     */\n    this.viewPromise_ = new Promise(function (resolve, reject) {\n      self.viewResolver = resolve;\n      self.viewRejector = reject;\n    });\n  }\n\n  /**\n   * Get the attribution function for the source.\n   * @return {?Attribution} Attribution function.\n   * @api\n   */\n  getAttributions() {\n    return this.attributions_;\n  }\n\n  /**\n   * @return {boolean} Attributions are collapsible.\n   * @api\n   */\n  getAttributionsCollapsible() {\n    return this.attributionsCollapsible_;\n  }\n\n  /**\n   * Get the projection of the source.\n   * @return {import(\"../proj/Projection.js\").default|null} Projection.\n   * @api\n   */\n  getProjection() {\n    return this.projection;\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} [projection] Projection.\n   * @return {Array<number>|null} Resolutions.\n   */\n  getResolutions(projection) {\n    return null;\n  }\n\n  /**\n   * @return {Promise<import(\"../View.js\").ViewOptions>} A promise for view-related properties.\n   */\n  getView() {\n    return this.viewPromise_;\n  }\n\n  /**\n   * Get the state of the source, see {@link import(\"./Source.js\").State} for possible states.\n   * @return {import(\"./Source.js\").State} State.\n   * @api\n   */\n  getState() {\n    return this.state_;\n  }\n\n  /**\n   * @return {boolean|undefined} Wrap X.\n   */\n  getWrapX() {\n    return this.wrapX_;\n  }\n\n  /**\n   * @return {boolean} Use linear interpolation when resampling.\n   */\n  getInterpolate() {\n    return this.interpolate_;\n  }\n\n  /**\n   * Refreshes the source. The source will be cleared, and data from the server will be reloaded.\n   * @api\n   */\n  refresh() {\n    this.changed();\n  }\n\n  /**\n   * Set the attributions of the source.\n   * @param {AttributionLike|undefined} attributions Attributions.\n   *     Can be passed as `string`, `Array<string>`, {@link module:ol/source/Source~Attribution},\n   *     or `undefined`.\n   * @api\n   */\n  setAttributions(attributions) {\n    this.attributions_ = adaptAttributions(attributions);\n    this.changed();\n  }\n\n  /**\n   * Set the state of the source.\n   * @param {import(\"./Source.js\").State} state State.\n   */\n  setState(state) {\n    this.state_ = state;\n    this.changed();\n  }\n}\n\n/**\n * Turns the attributions option into an attributions function.\n * @param {AttributionLike|undefined} attributionLike The attribution option.\n * @return {Attribution|null} An attribution function (or null).\n */\nfunction adaptAttributions(attributionLike) {\n  if (!attributionLike) {\n    return null;\n  }\n  if (typeof attributionLike === 'function') {\n    return attributionLike;\n  }\n  if (!Array.isArray(attributionLike)) {\n    attributionLike = [attributionLike];\n  }\n  return (frameState) => attributionLike;\n}\n\nexport default Source;\n","/**\n * @module ol/source/common\n */\n\n/**\n * Default WMS version.\n * @type {string}\n */\nexport const DEFAULT_WMS_VERSION = '1.3.0';\n\n/**\n * Number of decimal digits to consider in integer values when rounding.\n * @type {number}\n */\nexport const DECIMALS = 4;\n","/**\n * @module ol/source/Image\n */\nimport ImageWrapper from '../Image.js';\nimport ImageState from '../ImageState.js';\nimport {linearFindNearest} from '../array.js';\nimport Event from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport {\n  containsExtent,\n  equals,\n  getCenter,\n  getForViewAndSize,\n  getHeight,\n  getWidth,\n} from '../extent.js';\nimport {ceil} from '../math.js';\nimport {equivalent} from '../proj.js';\nimport ReprojImage from '../reproj/Image.js';\nimport {fromResolutionLike} from '../resolution.js';\nimport Source from './Source.js';\nimport {DECIMALS} from './common.js';\n\n/**\n * @enum {string}\n */\nexport const ImageSourceEventType = {\n  /**\n   * Triggered when an image starts loading.\n   * @event module:ol/source/Image.ImageSourceEvent#imageloadstart\n   * @api\n   */\n  IMAGELOADSTART: 'imageloadstart',\n\n  /**\n   * Triggered when an image finishes loading.\n   * @event module:ol/source/Image.ImageSourceEvent#imageloadend\n   * @api\n   */\n  IMAGELOADEND: 'imageloadend',\n\n  /**\n   * Triggered if image loading results in an error.\n   * @event module:ol/source/Image.ImageSourceEvent#imageloaderror\n   * @api\n   */\n  IMAGELOADERROR: 'imageloaderror',\n};\n\n/**\n * @typedef {'imageloadend'|'imageloaderror'|'imageloadstart'} ImageSourceEventTypes\n */\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/source/Image~ImageSource} instances are instances of this\n * type.\n */\nexport class ImageSourceEvent extends Event {\n  /**\n   * @param {string} type Type.\n   * @param {import(\"../Image.js\").default} image The image.\n   */\n  constructor(type, image) {\n    super(type);\n\n    /**\n     * The image related to the event.\n     * @type {import(\"../Image.js\").default}\n     * @api\n     */\n    this.image = image;\n  }\n}\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types, import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<ImageSourceEventTypes, ImageSourceEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"../ObjectEventType.js\").Types\n *     |ImageSourceEventTypes, Return>} ImageSourceOnSignature\n */\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * linear interpolation is used when resampling.  Set to false to use the nearest neighbor instead.\n * @property {import(\"../Image.js\").Loader} [loader] Loader. Can either be a custom loader, or one of the\n * loaders created with a `createLoader()` function ({@link module:ol/source/wms.createLoader wms},\n * {@link module:ol/source/arcgisRest.createLoader arcgisRest}, {@link module:ol/source/mapguide.createLoader mapguide},\n * {@link module:ol/source/static.createLoader static}).\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection.\n * @property {Array<number>} [resolutions] Resolutions.\n * @property {import(\"./Source.js\").State} [state] State.\n */\n\n/**\n * @classdesc\n * Base class for sources providing a single image.\n * @fires module:ol/source/Image.ImageSourceEvent\n * @api\n */\nclass ImageSource extends Source {\n  /**\n   * @param {Options} options Single image source options.\n   */\n  constructor(options) {\n    super({\n      attributions: options.attributions,\n      projection: options.projection,\n      state: options.state,\n      interpolate:\n        options.interpolate !== undefined ? options.interpolate : true,\n    });\n\n    /***\n     * @type {ImageSourceOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {ImageSourceOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {ImageSourceOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @protected\n     * @type {import(\"../Image.js\").Loader}\n     */\n    this.loader = options.loader || null;\n\n    /**\n     * @private\n     * @type {Array<number>|null}\n     */\n    this.resolutions_ =\n      options.resolutions !== undefined ? options.resolutions : null;\n\n    /**\n     * @private\n     * @type {import(\"../reproj/Image.js\").default}\n     */\n    this.reprojectedImage_ = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.reprojectedRevision_ = 0;\n\n    /**\n     * @protected\n     * @type {import(\"../Image.js\").default}\n     */\n    this.image = null;\n\n    /**\n     * @private\n     * @type {import(\"../extent.js\").Extent}\n     */\n    this.wantedExtent_;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.wantedResolution_;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.static_ = options.loader ? options.loader.length === 0 : false;\n\n    /**\n     * @private\n     * @type {import(\"../proj/Projection.js\").default}\n     */\n    this.wantedProjection_ = null;\n  }\n\n  /**\n   * @return {Array<number>|null} Resolutions.\n   * @override\n   */\n  getResolutions() {\n    return this.resolutions_;\n  }\n\n  /**\n   * @param {Array<number>|null} resolutions Resolutions.\n   */\n  setResolutions(resolutions) {\n    this.resolutions_ = resolutions;\n  }\n\n  /**\n   * @protected\n   * @param {number} resolution Resolution.\n   * @return {number} Resolution.\n   */\n  findNearestResolution(resolution) {\n    const resolutions = this.getResolutions();\n    if (resolutions) {\n      const idx = linearFindNearest(resolutions, resolution, 0);\n      resolution = resolutions[idx];\n    }\n    return resolution;\n  }\n\n  /**\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {import(\"../Image.js\").default} Single image.\n   */\n  getImage(extent, resolution, pixelRatio, projection) {\n    const sourceProjection = this.getProjection();\n    if (\n      !sourceProjection ||\n      !projection ||\n      equivalent(sourceProjection, projection)\n    ) {\n      if (sourceProjection) {\n        projection = sourceProjection;\n      }\n\n      return this.getImageInternal(extent, resolution, pixelRatio, projection);\n    }\n    if (this.reprojectedImage_) {\n      if (\n        this.reprojectedRevision_ == this.getRevision() &&\n        equivalent(this.reprojectedImage_.getProjection(), projection) &&\n        this.reprojectedImage_.getResolution() == resolution &&\n        equals(this.reprojectedImage_.getExtent(), extent)\n      ) {\n        return this.reprojectedImage_;\n      }\n      this.reprojectedImage_.dispose();\n      this.reprojectedImage_ = null;\n    }\n\n    this.reprojectedImage_ = new ReprojImage(\n      sourceProjection,\n      projection,\n      extent,\n      resolution,\n      pixelRatio,\n      (extent, resolution, pixelRatio) =>\n        this.getImageInternal(extent, resolution, pixelRatio, sourceProjection),\n      this.getInterpolate(),\n    );\n    this.reprojectedRevision_ = this.getRevision();\n\n    return this.reprojectedImage_;\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {import(\"../Image.js\").default} Single image.\n   * @protected\n   */\n  getImageInternal(extent, resolution, pixelRatio, projection) {\n    if (this.loader) {\n      const requestExtent = getRequestExtent(extent, resolution, pixelRatio, 1);\n      const requestResolution = this.findNearestResolution(resolution);\n      if (\n        this.image &&\n        (this.static_ ||\n          (this.wantedProjection_ === projection &&\n            ((this.wantedExtent_ &&\n              containsExtent(this.wantedExtent_, requestExtent)) ||\n              containsExtent(this.image.getExtent(), requestExtent)) &&\n            ((this.wantedResolution_ &&\n              fromResolutionLike(this.wantedResolution_) ===\n                requestResolution) ||\n              fromResolutionLike(this.image.getResolution()) ===\n                requestResolution)))\n      ) {\n        return this.image;\n      }\n      this.wantedProjection_ = projection;\n      this.wantedExtent_ = requestExtent;\n      this.wantedResolution_ = requestResolution;\n      this.image = new ImageWrapper(\n        requestExtent,\n        requestResolution,\n        pixelRatio,\n        this.loader,\n      );\n      this.image.addEventListener(\n        EventType.CHANGE,\n        this.handleImageChange.bind(this),\n      );\n    }\n    return this.image;\n  }\n\n  /**\n   * Handle image change events.\n   * @param {import(\"../events/Event.js\").default} event Event.\n   * @protected\n   */\n  handleImageChange(event) {\n    const image = /** @type {import(\"../Image.js\").default} */ (event.target);\n    let type;\n    switch (image.getState()) {\n      case ImageState.LOADING:\n        this.loading = true;\n        type = ImageSourceEventType.IMAGELOADSTART;\n        break;\n      case ImageState.LOADED:\n        this.loading = false;\n        type = ImageSourceEventType.IMAGELOADEND;\n        break;\n      case ImageState.ERROR:\n        this.loading = false;\n        type = ImageSourceEventType.IMAGELOADERROR;\n        break;\n      default:\n        return;\n    }\n    if (this.hasListener(type)) {\n      this.dispatchEvent(new ImageSourceEvent(type, image));\n    }\n  }\n}\n\n/**\n * Default image load function for image sources that use import(\"../Image.js\").Image image\n * instances.\n * @param {import(\"../Image.js\").default} image Image.\n * @param {string} src Source.\n */\nexport function defaultImageLoadFunction(image, src) {\n  /** @type {HTMLImageElement|HTMLVideoElement} */ (image.getImage()).src = src;\n}\n\n/**\n * Adjusts the extent so it aligns with pixel boundaries.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @param {number} resolution Reolution.\n * @param {number} pixelRatio Pixel ratio.\n * @param {number} ratio Ratio between request size and view size.\n * @return {import(\"../extent.js\").Extent} Request extent.\n */\nexport function getRequestExtent(extent, resolution, pixelRatio, ratio) {\n  const imageResolution = resolution / pixelRatio;\n  const center = getCenter(extent);\n  const viewWidth = ceil(getWidth(extent) / imageResolution, DECIMALS);\n  const viewHeight = ceil(getHeight(extent) / imageResolution, DECIMALS);\n  const marginWidth = ceil(((ratio - 1) * viewWidth) / 2, DECIMALS);\n  const requestWidth = viewWidth + 2 * marginWidth;\n  const marginHeight = ceil(((ratio - 1) * viewHeight) / 2, DECIMALS);\n  const requestHeight = viewHeight + 2 * marginHeight;\n  return getForViewAndSize(center, imageResolution, 0, [\n    requestWidth,\n    requestHeight,\n  ]);\n}\n\nexport default ImageSource;\n","/**\n * @module ol/source/arcgisRest\n */\n\nimport {decode} from '../Image.js';\nimport {getHeight, getWidth} from '../extent.js';\nimport {round} from '../math.js';\nimport {get as getProjection} from '../proj.js';\nimport {appendParams} from '../uri.js';\nimport {getRequestExtent} from './Image.js';\nimport {DECIMALS} from './common.js';\n\n/**\n * @param {string} baseUrl Base URL for the ArcGIS Rest service.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @param {number} resolution Resolution.\n * @param {number} pixelRatio Pixel ratio.\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @param {Object} params Params.\n * @return {string} Request URL.\n */\nexport function getRequestUrl(\n  baseUrl,\n  extent,\n  resolution,\n  pixelRatio,\n  projection,\n  params,\n) {\n  // ArcGIS Server only wants the numeric portion of the projection ID.\n  // (if there is no numeric portion the entire projection code must\n  // form a valid ArcGIS SpatialReference definition).\n  const srid = projection\n    .getCode()\n    .split(/:(?=\\d+$)/)\n    .pop();\n\n  const imageResolution = resolution / pixelRatio;\n\n  const imageSize = [\n    round(getWidth(extent) / imageResolution, DECIMALS),\n    round(getHeight(extent) / imageResolution, DECIMALS),\n  ];\n\n  params['SIZE'] = imageSize[0] + ',' + imageSize[1];\n  params['BBOX'] = extent.join(',');\n  params['BBOXSR'] = srid;\n  params['IMAGESR'] = srid;\n  params['DPI'] = Math.round(\n    params['DPI'] ? params['DPI'] * pixelRatio : 90 * pixelRatio,\n  );\n\n  const modifiedUrl = baseUrl\n    .replace(/MapServer\\/?$/, 'MapServer/export')\n    .replace(/ImageServer\\/?$/, 'ImageServer/exportImage');\n  return appendParams(modifiedUrl, params);\n}\n\n/**\n * @typedef {Object} LoaderOptions\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images.  Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for loaded images.\n * @property {boolean} [hidpi=true] Use the `ol/Map#pixelRatio` value when requesting the image from\n * the remote server.\n * @property {Object<string,*>} [params] ArcGIS Rest parameters. This field is optional. Service\n * defaults will be used for any fields not specified. `FORMAT` is `PNG32` by default. `F` is\n * `IMAGE` by default. `TRANSPARENT` is `true` by default.  `BBOX`, `SIZE`, `BBOXSR`, and `IMAGESR`\n * will be set dynamically. Set `LAYERS` to override the default service layer visibility. See\n * https://developers.arcgis.com/rest/services-reference/export-map.htm\n * for further reference.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is 'EPSG:3857'.\n * The projection code must contain a numeric end portion separated by :\n * or the entire code must form a valid ArcGIS SpatialReference definition.\n * @property {number} [ratio=1.5] Ratio. `1` means image requests are the size of the map viewport,\n * `2` means twice the size of the map viewport, and so on.\n * @property {string} url ArcGIS Rest service URL for a Map Service or Image Service. The url\n * should include /MapServer or /ImageServer.\n * @property {function(HTMLImageElement, string): Promise<import('../DataTile.js').ImageLike>} [load] Function\n * to perform loading of the image. Receives the created `HTMLImageElement` and the desired `src` as argument and\n * returns a promise resolving to the loaded or decoded image. Default is {@link module:ol/Image.decode}.\n */\n\n/**\n * Creates a loader for ArcGIS Rest images.\n * @param {LoaderOptions} options Image ArcGIS Rest Options.\n * @return {import('../Image.js').ImageObjectPromiseLoader} ArcGIS Rest image.\n * @api\n */\nexport function createLoader(options) {\n  const load = options.load ? options.load : decode;\n  const projection = getProjection(options.projection || 'EPSG:3857');\n  const ratio = options.ratio ?? 1.5;\n  const crossOrigin = options.crossOrigin ?? null;\n  const referrerPolicy = options.referrerPolicy;\n\n  return function (extent, resolution, pixelRatio) {\n    pixelRatio = options.hidpi ? pixelRatio : 1;\n\n    const params = {\n      'F': 'image',\n      'FORMAT': 'PNG32',\n      'TRANSPARENT': true,\n    };\n    Object.assign(params, options.params);\n\n    extent = getRequestExtent(extent, resolution, pixelRatio, ratio);\n\n    const src = getRequestUrl(\n      options.url,\n      extent,\n      resolution,\n      pixelRatio,\n      projection,\n      params,\n    );\n\n    const image = new Image();\n    image.crossOrigin = crossOrigin;\n    if (referrerPolicy !== undefined) {\n      image.referrerPolicy = referrerPolicy;\n    }\n\n    return load(image, src).then((image) => {\n      // Update resolution, because the server may return a smaller size than requested\n      const resolution = (getWidth(extent) / image.width) * pixelRatio;\n      return {image, extent, resolution, pixelRatio};\n    });\n  };\n}\n","/**\n * @module ol/tilegrid/TileGrid\n */\nimport TileRange, {\n  createOrUpdate as createOrUpdateTileRange,\n} from '../TileRange.js';\nimport {isSorted, linearFindNearest} from '../array.js';\nimport {assert} from '../asserts.js';\nimport {createOrUpdate, getTopLeft} from '../extent.js';\nimport {intersectsLinearRing} from '../geom/flat/intersectsextent.js';\nimport {ceil, clamp, floor} from '../math.js';\nimport {toSize} from '../size.js';\nimport {createOrUpdate as createOrUpdateTileCoord} from '../tilecoord.js';\nimport {DEFAULT_TILE_SIZE} from './common.js';\n\n/**\n * @private\n * @type {import(\"../tilecoord.js\").TileCoord}\n */\nconst tmpTileCoord = [0, 0, 0];\n\n/**\n * Number of decimal digits to consider in integer values when rounding.\n * @type {number}\n */\nconst DECIMALS = 5;\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../extent.js\").Extent} [extent] Extent for the tile grid. No tiles outside this\n * extent will be requested by {@link module:ol/source/Tile~TileSource} sources. When no `origin` or\n * `origins` are configured, the `origin` will be set to the top-left corner of the extent.\n * @property {number} [minZoom=0] Minimum zoom.\n * @property {import(\"../coordinate.js\").Coordinate} [origin] The tile grid origin, i.e. where the `x`\n * and `y` axes meet (`[z, 0, 0]`). Tile coordinates increase left to right and downwards. If not\n * specified, `extent` or `origins` must be provided.\n * @property {Array<import(\"../coordinate.js\").Coordinate>} [origins] Tile grid origins, i.e. where\n * the `x` and `y` axes meet (`[z, 0, 0]`), for each zoom level. If given, the array length\n * should match the length of the `resolutions` array, i.e. each resolution can have a different\n * origin. Tile coordinates increase left to right and downwards. If not specified, `extent` or\n * `origin` must be provided.\n * @property {!Array<number>} resolutions Resolutions. The array index of each resolution needs\n * to match the zoom level. This means that even if a `minZoom` is configured, the resolutions\n * array will have a length of `maxZoom + 1`.\n * @property {Array<import(\"../size.js\").Size>} [sizes] Number of tile rows and columns\n * of the grid for each zoom level. If specified the values\n * define each zoom level's extent together with the `origin` or `origins`.\n * A grid `extent` can be configured in addition, and will further limit the extent\n * for which tile requests are made by sources. If the bottom-left corner of\n * an extent is used as `origin` or `origins`, then the `y` value must be\n * negative because OpenLayers tile coordinates use the top left as the origin.\n * @property {number|import(\"../size.js\").Size} [tileSize] Tile size.\n * Default is `[256, 256]`.\n * @property {Array<number|import(\"../size.js\").Size>} [tileSizes] Tile sizes. If given, the array length\n * should match the length of the `resolutions` array, i.e. each resolution can have a different\n * tile size.\n */\n\n/**\n * @classdesc\n * Base class for setting the grid pattern for sources accessing tiled-image\n * servers.\n * @api\n */\nclass TileGrid {\n  /**\n   * @param {Options} options Tile grid options.\n   */\n  constructor(options) {\n    /**\n     * @protected\n     * @type {number}\n     */\n    this.minZoom = options.minZoom !== undefined ? options.minZoom : 0;\n\n    /**\n     * @private\n     * @type {!Array<number>}\n     */\n    this.resolutions_ = options.resolutions;\n    assert(\n      isSorted(\n        this.resolutions_,\n        /**\n         * @param {number} a First resolution\n         * @param {number} b Second resolution\n         * @return {number} Comparison result\n         */\n        (a, b) => b - a,\n        true,\n      ),\n      '`resolutions` must be sorted in descending order',\n    );\n\n    // check if we've got a consistent zoom factor and origin\n    let zoomFactor;\n    if (!options.origins) {\n      for (let i = 0, ii = this.resolutions_.length - 1; i < ii; ++i) {\n        if (!zoomFactor) {\n          zoomFactor = this.resolutions_[i] / this.resolutions_[i + 1];\n        } else {\n          if (this.resolutions_[i] / this.resolutions_[i + 1] !== zoomFactor) {\n            zoomFactor = undefined;\n            break;\n          }\n        }\n      }\n    }\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.zoomFactor_ = zoomFactor;\n\n    /**\n     * @protected\n     * @type {number}\n     */\n    this.maxZoom = this.resolutions_.length - 1;\n\n    /**\n     * @private\n     * @type {import(\"../coordinate.js\").Coordinate|null}\n     */\n    this.origin_ = options.origin !== undefined ? options.origin : null;\n\n    /**\n     * @private\n     * @type {Array<import(\"../coordinate.js\").Coordinate>}\n     */\n    this.origins_ = null;\n    if (options.origins !== undefined) {\n      this.origins_ = options.origins;\n      assert(\n        this.origins_.length == this.resolutions_.length,\n        'Number of `origins` and `resolutions` must be equal',\n      );\n    }\n\n    const extent = options.extent;\n\n    if (extent !== undefined && !this.origin_ && !this.origins_) {\n      this.origin_ = getTopLeft(extent);\n    }\n\n    assert(\n      (!this.origin_ && this.origins_) || (this.origin_ && !this.origins_),\n      'Either `origin` or `origins` must be configured, never both',\n    );\n\n    /**\n     * @private\n     * @type {Array<number|import(\"../size.js\").Size>}\n     */\n    this.tileSizes_ = null;\n    if (options.tileSizes !== undefined) {\n      this.tileSizes_ = options.tileSizes;\n      assert(\n        this.tileSizes_.length == this.resolutions_.length,\n        'Number of `tileSizes` and `resolutions` must be equal',\n      );\n    }\n\n    /**\n     * @private\n     * @type {number|import(\"../size.js\").Size}\n     */\n    this.tileSize_ =\n      options.tileSize !== undefined\n        ? options.tileSize\n        : !this.tileSizes_\n          ? DEFAULT_TILE_SIZE\n          : null;\n    assert(\n      (!this.tileSize_ && this.tileSizes_) ||\n        (this.tileSize_ && !this.tileSizes_),\n      'Either `tileSize` or `tileSizes` must be configured, never both',\n    );\n\n    /**\n     * @private\n     * @type {import(\"../extent.js\").Extent}\n     */\n    this.extent_ = extent !== undefined ? extent : null;\n\n    /**\n     * @private\n     * @type {Array<import(\"../TileRange.js\").default>}\n     */\n    this.fullTileRanges_ = null;\n\n    /**\n     * @private\n     * @type {import(\"../size.js\").Size}\n     */\n    this.tmpSize_ = [0, 0];\n\n    /**\n     * @private\n     * @type {import(\"../extent.js\").Extent}\n     */\n    this.tmpExtent_ = [0, 0, 0, 0];\n\n    if (options.sizes !== undefined) {\n      this.fullTileRanges_ = options.sizes.map((size, z) => {\n        const tileRange = new TileRange(\n          Math.min(0, size[0]),\n          Math.max(size[0] - 1, -1),\n          Math.min(0, size[1]),\n          Math.max(size[1] - 1, -1),\n        );\n        if (extent) {\n          const restrictedTileRange = this.getTileRangeForExtentAndZ(extent, z);\n          tileRange.minX = Math.max(restrictedTileRange.minX, tileRange.minX);\n          tileRange.maxX = Math.min(restrictedTileRange.maxX, tileRange.maxX);\n          tileRange.minY = Math.max(restrictedTileRange.minY, tileRange.minY);\n          tileRange.maxY = Math.min(restrictedTileRange.maxY, tileRange.maxY);\n        }\n        return tileRange;\n      });\n    } else if (extent) {\n      this.calculateTileRanges_(extent);\n    }\n  }\n\n  /**\n   * Call a function with each tile coordinate for a given extent and zoom level.\n   *\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} zoom Integer zoom level.\n   * @param {function(import(\"../tilecoord.js\").TileCoord): void} callback Function called with each tile coordinate.\n   * @api\n   */\n  forEachTileCoord(extent, zoom, callback) {\n    const tileRange = this.getTileRangeForExtentAndZ(extent, zoom);\n    for (let i = tileRange.minX, ii = tileRange.maxX; i <= ii; ++i) {\n      for (let j = tileRange.minY, jj = tileRange.maxY; j <= jj; ++j) {\n        callback([zoom, i, j]);\n      }\n    }\n  }\n\n  /**\n   * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n   * @param {function(number, import(\"../TileRange.js\").default): boolean} callback Callback.\n   * @param {import(\"../TileRange.js\").default} [tempTileRange] Temporary import(\"../TileRange.js\").default object.\n   * @param {import(\"../extent.js\").Extent} [tempExtent] Temporary import(\"../extent.js\").Extent object.\n   * @return {boolean} Callback succeeded.\n   */\n  forEachTileCoordParentTileRange(\n    tileCoord,\n    callback,\n    tempTileRange,\n    tempExtent,\n  ) {\n    let tileRange, x, y;\n    let tileCoordExtent = null;\n    let z = tileCoord[0] - 1;\n    if (this.zoomFactor_ === 2) {\n      x = tileCoord[1];\n      y = tileCoord[2];\n    } else {\n      tileCoordExtent = this.getTileCoordExtent(tileCoord, tempExtent);\n    }\n    while (z >= this.minZoom) {\n      if (x !== undefined && y !== undefined) {\n        x = Math.floor(x / 2);\n        y = Math.floor(y / 2);\n        tileRange = createOrUpdateTileRange(x, x, y, y, tempTileRange);\n      } else {\n        tileRange = this.getTileRangeForExtentAndZ(\n          tileCoordExtent,\n          z,\n          tempTileRange,\n        );\n      }\n      if (callback(z, tileRange)) {\n        return true;\n      }\n      --z;\n    }\n    return false;\n  }\n\n  /**\n   * Get the extent for this tile grid, if it was configured.\n   * @return {import(\"../extent.js\").Extent} Extent.\n   * @api\n   */\n  getExtent() {\n    return this.extent_;\n  }\n\n  /**\n   * Get the maximum zoom level for the grid.\n   * @return {number} Max zoom.\n   * @api\n   */\n  getMaxZoom() {\n    return this.maxZoom;\n  }\n\n  /**\n   * Get the minimum zoom level for the grid.\n   * @return {number} Min zoom.\n   * @api\n   */\n  getMinZoom() {\n    return this.minZoom;\n  }\n\n  /**\n   * Get the origin for the grid at the given zoom level.\n   * @param {number} z Integer zoom level.\n   * @return {import(\"../coordinate.js\").Coordinate} Origin.\n   * @api\n   */\n  getOrigin(z) {\n    if (this.origin_) {\n      return this.origin_;\n    }\n    return this.origins_[z];\n  }\n\n  /**\n   * Get the list of origins for the grid.\n   * @return {Array<import(\"../coordinate.js\").Coordinate>|null} Origin.\n   */\n  getOrigins() {\n    return this.origins_;\n  }\n\n  /**\n   * Get the resolution for the given zoom level.\n   * @param {number} z Integer zoom level.\n   * @return {number} Resolution.\n   * @api\n   */\n  getResolution(z) {\n    return this.resolutions_[z];\n  }\n\n  /**\n   * Get the list of resolutions for the tile grid.\n   * @return {Array<number>} Resolutions.\n   * @api\n   */\n  getResolutions() {\n    return this.resolutions_;\n  }\n\n  /**\n   * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n   * @param {import(\"../TileRange.js\").default} [tempTileRange] Temporary import(\"../TileRange.js\").default object.\n   * @param {import(\"../extent.js\").Extent} [tempExtent] Temporary import(\"../extent.js\").Extent object.\n   * @return {import(\"../TileRange.js\").default|null} Tile range.\n   */\n  getTileCoordChildTileRange(tileCoord, tempTileRange, tempExtent) {\n    if (tileCoord[0] < this.maxZoom) {\n      if (this.zoomFactor_ === 2) {\n        const minX = tileCoord[1] * 2;\n        const minY = tileCoord[2] * 2;\n        return createOrUpdateTileRange(\n          minX,\n          minX + 1,\n          minY,\n          minY + 1,\n          tempTileRange,\n        );\n      }\n      const tileCoordExtent = this.getTileCoordExtent(\n        tileCoord,\n        tempExtent || this.tmpExtent_,\n      );\n      return this.getTileRangeForExtentAndZ(\n        tileCoordExtent,\n        tileCoord[0] + 1,\n        tempTileRange,\n      );\n    }\n    return null;\n  }\n\n  /**\n   * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n   * @param {number} z Integer zoom level.\n   * @param {import(\"../TileRange.js\").default} [tempTileRange] Temporary import(\"../TileRange.js\").default object.\n   * @return {import(\"../TileRange.js\").default|null} Tile range.\n   */\n  getTileRangeForTileCoordAndZ(tileCoord, z, tempTileRange) {\n    if (z > this.maxZoom || z < this.minZoom) {\n      return null;\n    }\n\n    const tileCoordZ = tileCoord[0];\n    const tileCoordX = tileCoord[1];\n    const tileCoordY = tileCoord[2];\n\n    if (z === tileCoordZ) {\n      return createOrUpdateTileRange(\n        tileCoordX,\n        tileCoordY,\n        tileCoordX,\n        tileCoordY,\n        tempTileRange,\n      );\n    }\n\n    if (this.zoomFactor_) {\n      const factor = Math.pow(this.zoomFactor_, z - tileCoordZ);\n      const minX = Math.floor(tileCoordX * factor);\n      const minY = Math.floor(tileCoordY * factor);\n      if (z < tileCoordZ) {\n        return createOrUpdateTileRange(minX, minX, minY, minY, tempTileRange);\n      }\n\n      const maxX = Math.floor(factor * (tileCoordX + 1)) - 1;\n      const maxY = Math.floor(factor * (tileCoordY + 1)) - 1;\n      return createOrUpdateTileRange(minX, maxX, minY, maxY, tempTileRange);\n    }\n\n    const tileCoordExtent = this.getTileCoordExtent(tileCoord, this.tmpExtent_);\n    return this.getTileRangeForExtentAndZ(tileCoordExtent, z, tempTileRange);\n  }\n\n  /**\n   * Get a tile range for the given extent and integer zoom level.\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} z Integer zoom level.\n   * @param {import(\"../TileRange.js\").default} [tempTileRange] Temporary tile range object.\n   * @return {import(\"../TileRange.js\").default} Tile range.\n   */\n  getTileRangeForExtentAndZ(extent, z, tempTileRange) {\n    this.getTileCoordForXYAndZ_(extent[0], extent[3], z, false, tmpTileCoord);\n    const minX = tmpTileCoord[1];\n    const minY = tmpTileCoord[2];\n    this.getTileCoordForXYAndZ_(extent[2], extent[1], z, true, tmpTileCoord);\n    const maxX = tmpTileCoord[1];\n    const maxY = tmpTileCoord[2];\n    return createOrUpdateTileRange(minX, maxX, minY, maxY, tempTileRange);\n  }\n\n  /**\n   * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n   * @return {import(\"../coordinate.js\").Coordinate} Tile center.\n   */\n  getTileCoordCenter(tileCoord) {\n    const origin = this.getOrigin(tileCoord[0]);\n    const resolution = this.getResolution(tileCoord[0]);\n    const tileSize = toSize(this.getTileSize(tileCoord[0]), this.tmpSize_);\n    return [\n      origin[0] + (tileCoord[1] + 0.5) * tileSize[0] * resolution,\n      origin[1] - (tileCoord[2] + 0.5) * tileSize[1] * resolution,\n    ];\n  }\n\n  /**\n   * Get the extent of a tile coordinate.\n   *\n   * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n   * @param {import(\"../extent.js\").Extent} [tempExtent] Temporary extent object.\n   * @return {import(\"../extent.js\").Extent} Extent.\n   * @api\n   */\n  getTileCoordExtent(tileCoord, tempExtent) {\n    const origin = this.getOrigin(tileCoord[0]);\n    const resolution = this.getResolution(tileCoord[0]);\n    const tileSize = toSize(this.getTileSize(tileCoord[0]), this.tmpSize_);\n    const minX = origin[0] + tileCoord[1] * tileSize[0] * resolution;\n    const minY = origin[1] - (tileCoord[2] + 1) * tileSize[1] * resolution;\n    const maxX = minX + tileSize[0] * resolution;\n    const maxY = minY + tileSize[1] * resolution;\n    return createOrUpdate(minX, minY, maxX, maxY, tempExtent);\n  }\n\n  /**\n   * Get the tile coordinate for the given map coordinate and resolution.  This\n   * method considers that coordinates that intersect tile boundaries should be\n   * assigned the higher tile coordinate.\n   *\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @param {number} resolution Resolution.\n   * @param {import(\"../tilecoord.js\").TileCoord} [opt_tileCoord] Destination import(\"../tilecoord.js\").TileCoord object.\n   * @return {import(\"../tilecoord.js\").TileCoord} Tile coordinate.\n   * @api\n   */\n  getTileCoordForCoordAndResolution(coordinate, resolution, opt_tileCoord) {\n    return this.getTileCoordForXYAndResolution_(\n      coordinate[0],\n      coordinate[1],\n      resolution,\n      false,\n      opt_tileCoord,\n    );\n  }\n\n  /**\n   * Note that this method should not be called for resolutions that correspond\n   * to an integer zoom level.  Instead call the `getTileCoordForXYAndZ_` method.\n   * @param {number} x X.\n   * @param {number} y Y.\n   * @param {number} resolution Resolution (for a non-integer zoom level).\n   * @param {boolean} reverseIntersectionPolicy Instead of letting edge\n   *     intersections go to the higher tile coordinate, let edge intersections\n   *     go to the lower tile coordinate.\n   * @param {import(\"../tilecoord.js\").TileCoord} [opt_tileCoord] Temporary import(\"../tilecoord.js\").TileCoord object.\n   * @return {import(\"../tilecoord.js\").TileCoord} Tile coordinate.\n   * @private\n   */\n  getTileCoordForXYAndResolution_(\n    x,\n    y,\n    resolution,\n    reverseIntersectionPolicy,\n    opt_tileCoord,\n  ) {\n    const z = this.getZForResolution(resolution);\n    const scale = resolution / this.getResolution(z);\n    const origin = this.getOrigin(z);\n    const tileSize = toSize(this.getTileSize(z), this.tmpSize_);\n\n    let tileCoordX = (scale * (x - origin[0])) / resolution / tileSize[0];\n    let tileCoordY = (scale * (origin[1] - y)) / resolution / tileSize[1];\n\n    if (reverseIntersectionPolicy) {\n      tileCoordX = ceil(tileCoordX, DECIMALS) - 1;\n      tileCoordY = ceil(tileCoordY, DECIMALS) - 1;\n    } else {\n      tileCoordX = floor(tileCoordX, DECIMALS);\n      tileCoordY = floor(tileCoordY, DECIMALS);\n    }\n\n    return createOrUpdateTileCoord(z, tileCoordX, tileCoordY, opt_tileCoord);\n  }\n\n  /**\n   * Although there is repetition between this method and `getTileCoordForXYAndResolution_`,\n   * they should have separate implementations.  This method is for integer zoom\n   * levels.  The other method should only be called for resolutions corresponding\n   * to non-integer zoom levels.\n   * @param {number} x Map x coordinate.\n   * @param {number} y Map y coordinate.\n   * @param {number} z Integer zoom level.\n   * @param {boolean} reverseIntersectionPolicy Instead of letting edge\n   *     intersections go to the higher tile coordinate, let edge intersections\n   *     go to the lower tile coordinate.\n   * @param {import(\"../tilecoord.js\").TileCoord} [opt_tileCoord] Temporary import(\"../tilecoord.js\").TileCoord object.\n   * @return {import(\"../tilecoord.js\").TileCoord} Tile coordinate.\n   * @private\n   */\n  getTileCoordForXYAndZ_(x, y, z, reverseIntersectionPolicy, opt_tileCoord) {\n    const origin = this.getOrigin(z);\n    const resolution = this.getResolution(z);\n    const tileSize = toSize(this.getTileSize(z), this.tmpSize_);\n\n    let tileCoordX = (x - origin[0]) / resolution / tileSize[0];\n    let tileCoordY = (origin[1] - y) / resolution / tileSize[1];\n\n    if (reverseIntersectionPolicy) {\n      tileCoordX = ceil(tileCoordX, DECIMALS) - 1;\n      tileCoordY = ceil(tileCoordY, DECIMALS) - 1;\n    } else {\n      tileCoordX = floor(tileCoordX, DECIMALS);\n      tileCoordY = floor(tileCoordY, DECIMALS);\n    }\n\n    return createOrUpdateTileCoord(z, tileCoordX, tileCoordY, opt_tileCoord);\n  }\n\n  /**\n   * Get a tile coordinate given a map coordinate and zoom level.\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @param {number} z Integer zoom level, e.g. the result of a `getZForResolution()` method call\n   * @param {import(\"../tilecoord.js\").TileCoord} [opt_tileCoord] Destination import(\"../tilecoord.js\").TileCoord object.\n   * @return {import(\"../tilecoord.js\").TileCoord} Tile coordinate.\n   * @api\n   */\n  getTileCoordForCoordAndZ(coordinate, z, opt_tileCoord) {\n    return this.getTileCoordForXYAndZ_(\n      coordinate[0],\n      coordinate[1],\n      z,\n      false,\n      opt_tileCoord,\n    );\n  }\n\n  /**\n   * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n   * @return {number} Tile resolution.\n   */\n  getTileCoordResolution(tileCoord) {\n    return this.resolutions_[tileCoord[0]];\n  }\n\n  /**\n   * Get the tile size for a zoom level. The type of the return value matches the\n   * `tileSize` or `tileSizes` that the tile grid was configured with. To always\n   * get an {@link import(\"../size.js\").Size}, run the result through {@link module:ol/size.toSize}.\n   * @param {number} z Z.\n   * @return {number|import(\"../size.js\").Size} Tile size.\n   * @api\n   */\n  getTileSize(z) {\n    if (this.tileSize_) {\n      return this.tileSize_;\n    }\n    return this.tileSizes_[z];\n  }\n\n  /**\n   * @param {number} z Zoom level.\n   * @return {import(\"../TileRange.js\").default|null} Extent tile range for the specified zoom level.\n   */\n  getFullTileRange(z) {\n    if (!this.fullTileRanges_) {\n      return this.extent_\n        ? this.getTileRangeForExtentAndZ(this.extent_, z)\n        : null;\n    }\n    return this.fullTileRanges_[z];\n  }\n\n  /**\n   * @param {number} resolution Resolution.\n   * @param {number|import(\"../array.js\").NearestDirectionFunction} [opt_direction]\n   *     If 0, the nearest resolution will be used.\n   *     If 1, the nearest higher resolution (lower Z) will be used. If -1, the\n   *     nearest lower resolution (higher Z) will be used. Default is 0.\n   *     Use a {@link module:ol/array~NearestDirectionFunction} for more precise control.\n   *\n   * For example to change tile Z at the midpoint of zoom levels\n   * ```js\n   * function(value, high, low) {\n   *   return value - low * Math.sqrt(high / low);\n   * }\n   * ```\n   * @return {number} Z.\n   * @api\n   */\n  getZForResolution(resolution, opt_direction) {\n    const z = linearFindNearest(\n      this.resolutions_,\n      resolution,\n      opt_direction || 0,\n    );\n    return clamp(z, this.minZoom, this.maxZoom);\n  }\n\n  /**\n   * The tile with the provided tile coordinate intersects the given viewport.\n   * @param {import('../tilecoord.js').TileCoord} tileCoord Tile coordinate.\n   * @param {Array<number>} viewport Viewport as returned from {@link module:ol/extent.getRotatedViewport}.\n   * @return {boolean} The tile with the provided tile coordinate intersects the given viewport.\n   */\n  tileCoordIntersectsViewport(tileCoord, viewport) {\n    return intersectsLinearRing(\n      viewport,\n      0,\n      viewport.length,\n      2,\n      this.getTileCoordExtent(tileCoord),\n    );\n  }\n\n  /**\n   * @param {!import(\"../extent.js\").Extent} extent Extent for this tile grid.\n   * @private\n   */\n  calculateTileRanges_(extent) {\n    const length = this.resolutions_.length;\n    const fullTileRanges = new Array(length);\n    for (let z = this.minZoom; z < length; ++z) {\n      fullTileRanges[z] = this.getTileRangeForExtentAndZ(extent, z);\n    }\n    this.fullTileRanges_ = fullTileRanges;\n  }\n}\n\nexport default TileGrid;\n","/**\n * @module ol/tilegrid/WMTS\n */\n\nimport {get as getProjection} from '../proj.js';\nimport TileGrid from './TileGrid.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../extent.js\").Extent} [extent] Extent for the tile grid. No tiles\n * outside this extent will be requested by {@link module:ol/source/Tile~TileSource} sources.\n * When no `origin` or `origins` are configured, the `origin` will be set to the\n * top-left corner of the extent.\n * @property {import(\"../coordinate.js\").Coordinate} [origin] The tile grid origin, i.e.\n * where the `x` and `y` axes meet (`[z, 0, 0]`). Tile coordinates increase left\n * to right and downwards. If not specified, `extent` or `origins` must be provided.\n * @property {Array<import(\"../coordinate.js\").Coordinate>} [origins] Tile grid origins,\n * i.e. where the `x` and `y` axes meet (`[z, 0, 0]`), for each zoom level. If\n * given, the array length should match the length of the `resolutions` array, i.e.\n * each resolution can have a different origin. Tile coordinates increase left to\n * right and downwards. If not specified, `extent` or `origin` must be provided.\n * @property {!Array<number>} resolutions Resolutions. The array index of each\n * resolution needs to match the zoom level. This means that even if a `minZoom`\n * is configured, the resolutions array will have a length of `maxZoom + 1`\n * @property {!Array<string>} matrixIds matrix IDs. The length of this array needs\n * to match the length of the `resolutions` array.\n * @property {Array<import(\"../size.js\").Size>} [sizes] Number of tile rows and columns\n * of the grid for each zoom level. The values here are the `TileMatrixWidth` and\n * `TileMatrixHeight` advertised in the GetCapabilities response of the WMTS, and\n * define each zoom level's extent together with the `origin` or `origins`.\n * A grid `extent` can be configured in addition, and will further limit the extent for\n * which tile requests are made by sources. If the bottom-left corner of\n * an extent is used as `origin` or `origins`, then the `y` value must be\n * negative because OpenLayers tile coordinates use the top left as the origin.\n * @property {number|import(\"../size.js\").Size} [tileSize] Tile size.\n * @property {Array<number|import(\"../size.js\").Size>} [tileSizes] Tile sizes. The length of\n * this array needs to match the length of the `resolutions` array.\n */\n\n/**\n * @classdesc\n * Set the grid pattern for sources accessing WMTS tiled-image servers.\n * @api\n */\nclass WMTSTileGrid extends TileGrid {\n  /**\n   * @param {Options} options WMTS options.\n   */\n  constructor(options) {\n    super({\n      extent: options.extent,\n      origin: options.origin,\n      origins: options.origins,\n      resolutions: options.resolutions,\n      tileSize: options.tileSize,\n      tileSizes: options.tileSizes,\n      sizes: options.sizes,\n    });\n\n    /**\n     * @private\n     * @type {!Array<string>}\n     */\n    this.matrixIds_ = options.matrixIds;\n  }\n\n  /**\n   * @param {number} z Z.\n   * @return {string} MatrixId..\n   */\n  getMatrixId(z) {\n    return this.matrixIds_[z];\n  }\n\n  /**\n   * Get the list of matrix identifiers.\n   * @return {Array<string>} MatrixIds.\n   * @api\n   */\n  getMatrixIds() {\n    return this.matrixIds_;\n  }\n}\n\nexport default WMTSTileGrid;\n\n/**\n * Create a tile grid from a WMTS capabilities matrix set and an\n * optional TileMatrixSetLimits.\n * @param {Object} matrixSet An object representing a matrixSet in the\n *     capabilities document.\n * @param {import(\"../extent.js\").Extent} [extent] An optional extent to restrict the tile\n *     ranges the server provides.\n * @param {Array<Object>} [matrixLimits] An optional object representing\n *     the available matrices for tileGrid.\n * @return {WMTSTileGrid} WMTS tileGrid instance.\n * @api\n */\nexport function createFromCapabilitiesMatrixSet(\n  matrixSet,\n  extent,\n  matrixLimits,\n) {\n  /** @type {!Array<number>} */\n  const resolutions = [];\n  /** @type {!Array<string>} */\n  const matrixIds = [];\n  /** @type {!Array<import(\"../coordinate.js\").Coordinate>} */\n  const origins = [];\n  /** @type {!Array<number|import(\"../size.js\").Size>} */\n  const tileSizes = [];\n  /** @type {!Array<import(\"../size.js\").Size>} */\n  const sizes = [];\n\n  matrixLimits = matrixLimits !== undefined ? matrixLimits : [];\n\n  const supportedCRSPropName = 'SupportedCRS';\n  const matrixIdsPropName = 'TileMatrix';\n  const identifierPropName = 'Identifier';\n  const scaleDenominatorPropName = 'ScaleDenominator';\n  const topLeftCornerPropName = 'TopLeftCorner';\n  const tileWidthPropName = 'TileWidth';\n  const tileHeightPropName = 'TileHeight';\n\n  const code = matrixSet[supportedCRSPropName];\n  const projection = getProjection(code);\n  const metersPerUnit = projection.getMetersPerUnit();\n  // swap origin x and y coordinates if axis orientation is lat/long\n  const switchOriginXY = projection.getAxisOrientation().startsWith('ne');\n\n  matrixSet[matrixIdsPropName].sort(function (a, b) {\n    return b[scaleDenominatorPropName] - a[scaleDenominatorPropName];\n  });\n\n  matrixSet[matrixIdsPropName].forEach(function (elt) {\n    let matrixAvailable;\n    // use of matrixLimits to filter TileMatrices from GetCapabilities\n    // TileMatrixSet from unavailable matrix levels.\n    if (matrixLimits.length > 0) {\n      matrixAvailable = matrixLimits.find(function (elt_ml) {\n        if (elt[identifierPropName] == elt_ml[matrixIdsPropName]) {\n          return true;\n        }\n        // Fallback for tileMatrix identifiers that don't get prefixed\n        // by their tileMatrixSet identifiers.\n        if (!elt[identifierPropName].includes(':')) {\n          return (\n            matrixSet[identifierPropName] + ':' + elt[identifierPropName] ===\n            elt_ml[matrixIdsPropName]\n          );\n        }\n        return false;\n      });\n    } else {\n      matrixAvailable = true;\n    }\n\n    if (matrixAvailable) {\n      matrixIds.push(elt[identifierPropName]);\n      const resolution =\n        (elt[scaleDenominatorPropName] * 0.28e-3) / metersPerUnit;\n      const tileWidth = elt[tileWidthPropName];\n      const tileHeight = elt[tileHeightPropName];\n      if (switchOriginXY) {\n        origins.push([\n          elt[topLeftCornerPropName][1],\n          elt[topLeftCornerPropName][0],\n        ]);\n      } else {\n        origins.push(elt[topLeftCornerPropName]);\n      }\n      resolutions.push(resolution);\n      tileSizes.push(\n        tileWidth == tileHeight ? tileWidth : [tileWidth, tileHeight],\n      );\n      sizes.push([elt['MatrixWidth'], elt['MatrixHeight']]);\n    }\n  });\n\n  return new WMTSTileGrid({\n    extent: extent,\n    origins: origins,\n    resolutions: resolutions,\n    matrixIds: matrixIds,\n    tileSizes: tileSizes,\n    sizes: sizes,\n  });\n}\n","/**\n * @module ol/tilegrid\n */\nimport {\n  containsCoordinate,\n  createOrUpdate,\n  getCorner,\n  getHeight,\n  getWidth,\n} from './extent.js';\nimport {METERS_PER_UNIT, get as getProjection} from './proj.js';\nimport {toSize} from './size.js';\nimport TileGrid from './tilegrid/TileGrid.js';\nimport {DEFAULT_MAX_ZOOM, DEFAULT_TILE_SIZE} from './tilegrid/common.js';\n\nexport {default as WMTS} from './tilegrid/WMTS.js';\nexport {TileGrid};\n\n/**\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @return {!TileGrid} Default tile grid for the\n * passed projection.\n */\nexport function getForProjection(projection) {\n  let tileGrid = projection.getDefaultTileGrid();\n  if (!tileGrid) {\n    tileGrid = createForProjection(projection);\n    projection.setDefaultTileGrid(tileGrid);\n  }\n  return tileGrid;\n}\n\n/**\n * @param {TileGrid} tileGrid Tile grid.\n * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @return {import(\"./tilecoord.js\").TileCoord} Tile coordinate.\n */\nexport function wrapX(tileGrid, tileCoord, projection) {\n  const z = tileCoord[0];\n  const center = tileGrid.getTileCoordCenter(tileCoord);\n  const projectionExtent = extentFromProjection(projection);\n  if (!containsCoordinate(projectionExtent, center)) {\n    const worldWidth = getWidth(projectionExtent);\n    const worldsAway = Math.ceil(\n      (projectionExtent[0] - center[0]) / worldWidth,\n    );\n    center[0] += worldWidth * worldsAway;\n    return tileGrid.getTileCoordForCoordAndZ(center, z);\n  }\n  return tileCoord;\n}\n\n/**\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number} [maxZoom] Maximum zoom level (default is\n *     DEFAULT_MAX_ZOOM).\n * @param {number|import(\"./size.js\").Size} [tileSize] Tile size (default uses\n *     DEFAULT_TILE_SIZE).\n * @param {import(\"./extent.js\").Corner} [corner] Extent corner (default is `'top-left'`).\n * @return {!TileGrid} TileGrid instance.\n */\nexport function createForExtent(extent, maxZoom, tileSize, corner) {\n  corner = corner !== undefined ? corner : 'top-left';\n\n  const resolutions = resolutionsFromExtent(extent, maxZoom, tileSize);\n\n  return new TileGrid({\n    extent: extent,\n    origin: getCorner(extent, corner),\n    resolutions: resolutions,\n    tileSize: tileSize,\n  });\n}\n\n/**\n * @typedef {Object} XYZOptions\n * @property {import(\"./extent.js\").Extent} [extent] Extent for the tile grid. The origin for an XYZ tile grid is the\n * top-left corner of the extent. If `maxResolution` is not provided the zero level of the grid is defined by the resolution\n * at which one tile fits in the provided extent. If not provided, the extent of the EPSG:3857 projection is used.\n * @property {number} [maxResolution] Resolution at level zero.\n * @property {number} [maxZoom] Maximum zoom. The default is `42`. This determines the number of levels\n * in the grid set. For example, a `maxZoom` of 21 means there are 22 levels in the grid set.\n * @property {number} [minZoom=0] Minimum zoom.\n * @property {number|import(\"./size.js\").Size} [tileSize=[256, 256]] Tile size in pixels.\n */\n\n/**\n * Creates a tile grid with a standard XYZ tiling scheme.\n * @param {XYZOptions} [options] Tile grid options.\n * @return {!TileGrid} Tile grid instance.\n * @api\n */\nexport function createXYZ(options) {\n  const xyzOptions = options || {};\n\n  const extent = xyzOptions.extent || getProjection('EPSG:3857').getExtent();\n\n  const gridOptions = {\n    extent: extent,\n    minZoom: xyzOptions.minZoom,\n    tileSize: xyzOptions.tileSize,\n    resolutions: resolutionsFromExtent(\n      extent,\n      xyzOptions.maxZoom,\n      xyzOptions.tileSize,\n      xyzOptions.maxResolution,\n    ),\n  };\n  return new TileGrid(gridOptions);\n}\n\n/**\n * Create a resolutions array from an extent.  A zoom factor of 2 is assumed.\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number} [maxZoom] Maximum zoom level (default is\n *     DEFAULT_MAX_ZOOM).\n * @param {number|import(\"./size.js\").Size} [tileSize] Tile size (default uses\n *     DEFAULT_TILE_SIZE).\n * @param {number} [maxResolution] Resolution at level zero.\n * @return {!Array<number>} Resolutions array.\n */\nfunction resolutionsFromExtent(extent, maxZoom, tileSize, maxResolution) {\n  maxZoom = maxZoom !== undefined ? maxZoom : DEFAULT_MAX_ZOOM;\n  tileSize = toSize(tileSize !== undefined ? tileSize : DEFAULT_TILE_SIZE);\n\n  const height = getHeight(extent);\n  const width = getWidth(extent);\n\n  maxResolution =\n    maxResolution > 0\n      ? maxResolution\n      : Math.max(width / tileSize[0], height / tileSize[1]);\n\n  const length = maxZoom + 1;\n  const resolutions = new Array(length);\n  for (let z = 0; z < length; ++z) {\n    resolutions[z] = maxResolution / Math.pow(2, z);\n  }\n  return resolutions;\n}\n\n/**\n * @param {import(\"./proj.js\").ProjectionLike} projection Projection.\n * @param {number} [maxZoom] Maximum zoom level (default is\n *     DEFAULT_MAX_ZOOM).\n * @param {number|import(\"./size.js\").Size} [tileSize] Tile size (default uses\n *     DEFAULT_TILE_SIZE).\n * @param {import(\"./extent.js\").Corner} [corner] Extent corner (default is `'top-left'`).\n * @return {!TileGrid} TileGrid instance.\n */\nexport function createForProjection(projection, maxZoom, tileSize, corner) {\n  const extent = extentFromProjection(projection);\n  return createForExtent(extent, maxZoom, tileSize, corner);\n}\n\n/**\n * Generate a tile grid extent from a projection.  If the projection has an\n * extent, it is used.  If not, a global extent is assumed.\n * @param {import(\"./proj.js\").ProjectionLike} projection Projection.\n * @return {import(\"./extent.js\").Extent} Extent.\n */\nexport function extentFromProjection(projection) {\n  projection = getProjection(projection);\n  let extent = projection.getExtent();\n  if (!extent) {\n    const half =\n      (180 * METERS_PER_UNIT.degrees) / projection.getMetersPerUnit();\n    extent = createOrUpdate(-half, -half, half, half);\n  }\n  return extent;\n}\n","/**\n * @module ol/tileurlfunction\n */\nimport {modulo} from './math.js';\nimport {hash as tileCoordHash} from './tilecoord.js';\nimport {renderXYZTemplate} from './uri.js';\n\n/**\n * @param {string} template Template.\n * @param {import(\"./tilegrid/TileGrid.js\").default|null} tileGrid Tile grid.\n * @return {import(\"./Tile.js\").UrlFunction} Tile URL function.\n */\nexport function createFromTemplate(template, tileGrid) {\n  return (\n    /**\n     * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile Coordinate.\n     * @param {number} pixelRatio Pixel ratio.\n     * @param {import(\"./proj/Projection.js\").default} projection Projection.\n     * @return {string|undefined} Tile URL.\n     */\n    function (tileCoord, pixelRatio, projection) {\n      if (!tileCoord) {\n        return undefined;\n      }\n      let maxY;\n      const z = tileCoord[0];\n      if (tileGrid) {\n        // The `{-y}` placeholder only works for sources that have a tile grid at construction\n        const range = tileGrid.getFullTileRange(z);\n        if (range) {\n          maxY = range.getHeight() - 1;\n        }\n      }\n      return renderXYZTemplate(template, z, tileCoord[1], tileCoord[2], maxY);\n    }\n  );\n}\n\n/**\n * @param {Array<string>} templates Templates.\n * @param {import(\"./tilegrid/TileGrid.js\").default} tileGrid Tile grid.\n * @return {import(\"./Tile.js\").UrlFunction} Tile URL function.\n */\nexport function createFromTemplates(templates, tileGrid) {\n  const len = templates.length;\n  const tileUrlFunctions = new Array(len);\n  for (let i = 0; i < len; ++i) {\n    tileUrlFunctions[i] = createFromTemplate(templates[i], tileGrid);\n  }\n  return createFromTileUrlFunctions(tileUrlFunctions);\n}\n\n/**\n * @param {Array<import(\"./Tile.js\").UrlFunction>} tileUrlFunctions Tile URL Functions.\n * @return {import(\"./Tile.js\").UrlFunction} Tile URL function.\n */\nexport function createFromTileUrlFunctions(tileUrlFunctions) {\n  if (tileUrlFunctions.length === 1) {\n    return tileUrlFunctions[0];\n  }\n  return (\n    /**\n     * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile Coordinate.\n     * @param {number} pixelRatio Pixel ratio.\n     * @param {import(\"./proj/Projection.js\").default} projection Projection.\n     * @return {string|undefined} Tile URL.\n     */\n    function (tileCoord, pixelRatio, projection) {\n      if (!tileCoord) {\n        return undefined;\n      }\n      const h = tileCoordHash(tileCoord);\n      const index = modulo(h, tileUrlFunctions.length);\n      return tileUrlFunctions[index](tileCoord, pixelRatio, projection);\n    }\n  );\n}\n\n/**\n * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @param {number} pixelRatio Pixel ratio.\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @return {string|undefined} Tile URL.\n */\nexport function nullTileUrlFunction(tileCoord, pixelRatio, projection) {\n  return undefined;\n}\n","/**\n * @module ol/reproj/Tile\n */\n\nimport Tile from '../Tile.js';\nimport TileState from '../TileState.js';\nimport {releaseCanvas} from '../dom.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport EventType from '../events/EventType.js';\nimport {getArea, getIntersection, getWidth, wrapAndSliceX} from '../extent.js';\nimport {clamp} from '../math.js';\nimport {\n  calculateSourceExtentResolution,\n  canvasPool,\n  render as renderReprojected,\n} from '../reproj.js';\nimport Triangulation from './Triangulation.js';\nimport {ERROR_THRESHOLD} from './common.js';\n\n/**\n * @typedef {function(number, number, number, number) : (import(\"../ImageTile.js\").default)} FunctionType\n */\n\n/**\n * @typedef {Object} TileOffset\n * @property {import(\"../ImageTile.js\").default} [tile] Tile.\n * @property {function(): import(\"../ImageTile.js\").default} getTile Tile getter.\n * @property {number} offset Offset.\n */\n\n/**\n * @classdesc\n * Class encapsulating single reprojected tile.\n * See {@link module:ol/source/TileImage~TileImage}.\n *\n */\nclass ReprojTile extends Tile {\n  /**\n   * @param {import(\"../proj/Projection.js\").default} sourceProj Source projection.\n   * @param {import(\"../tilegrid/TileGrid.js\").default} sourceTileGrid Source tile grid.\n   * @param {import(\"../proj/Projection.js\").default} targetProj Target projection.\n   * @param {import(\"../tilegrid/TileGrid.js\").default} targetTileGrid Target tile grid.\n   * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Coordinate of the tile.\n   * @param {import(\"../tilecoord.js\").TileCoord} wrappedTileCoord Coordinate of the tile wrapped in X.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {number} gutter Gutter of the source tiles.\n   * @param {FunctionType} getTileFunction\n   *     Function returning source tiles (z, x, y, pixelRatio).\n   * @param {number} [errorThreshold] Acceptable reprojection error (in px).\n   * @param {boolean} [renderEdges] Render reprojection edges.\n   * @param {import(\"../Tile.js\").Options} [options] Tile options.\n   */\n  constructor(\n    sourceProj,\n    sourceTileGrid,\n    targetProj,\n    targetTileGrid,\n    tileCoord,\n    wrappedTileCoord,\n    pixelRatio,\n    gutter,\n    getTileFunction,\n    errorThreshold,\n    renderEdges,\n    options,\n  ) {\n    super(tileCoord, TileState.IDLE, options);\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.renderEdges_ = renderEdges !== undefined ? renderEdges : false;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.pixelRatio_ = pixelRatio;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.gutter_ = gutter;\n\n    /**\n     * @private\n     * @type {HTMLCanvasElement|OffscreenCanvas}\n     */\n    this.canvas_ = null;\n\n    /**\n     * @private\n     * @type {import(\"../tilegrid/TileGrid.js\").default}\n     */\n    this.sourceTileGrid_ = sourceTileGrid;\n\n    /**\n     * @private\n     * @type {import(\"../tilegrid/TileGrid.js\").default}\n     */\n    this.targetTileGrid_ = targetTileGrid;\n\n    /**\n     * @private\n     * @type {import(\"../tilecoord.js\").TileCoord}\n     */\n    this.wrappedTileCoord_ = wrappedTileCoord ? wrappedTileCoord : tileCoord;\n\n    /**\n     * @private\n     * @type {!Array<TileOffset>}\n     */\n    this.sourceTiles_ = [];\n\n    /**\n     * @private\n     * @type {?Array<import(\"../events.js\").EventsKey>}\n     */\n    this.sourcesListenerKeys_ = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.sourceZ_ = 0;\n\n    /**\n     * @private\n     * @type {import(\"../extent.js\").Extent}\n     */\n    this.clipExtent_ = sourceProj.canWrapX()\n      ? sourceProj.getExtent()\n      : undefined;\n\n    const targetExtent = targetTileGrid.getTileCoordExtent(\n      this.wrappedTileCoord_,\n    );\n    const maxTargetExtent = this.targetTileGrid_.getExtent();\n    let maxSourceExtent = this.sourceTileGrid_.getExtent();\n\n    const limitedTargetExtent = maxTargetExtent\n      ? getIntersection(targetExtent, maxTargetExtent)\n      : targetExtent;\n\n    if (getArea(limitedTargetExtent) === 0) {\n      // Tile is completely outside range -> EMPTY\n      // TODO: is it actually correct that the source even creates the tile ?\n      this.state = TileState.EMPTY;\n      return;\n    }\n\n    const sourceProjExtent = sourceProj.getExtent();\n    if (sourceProjExtent) {\n      if (!maxSourceExtent) {\n        maxSourceExtent = sourceProjExtent;\n      } else {\n        maxSourceExtent = getIntersection(maxSourceExtent, sourceProjExtent);\n      }\n    }\n\n    const targetResolution = targetTileGrid.getResolution(\n      this.wrappedTileCoord_[0],\n    );\n\n    const sourceResolution = calculateSourceExtentResolution(\n      sourceProj,\n      targetProj,\n      limitedTargetExtent,\n      targetResolution,\n    );\n\n    if (!isFinite(sourceResolution) || sourceResolution <= 0) {\n      // invalid sourceResolution -> EMPTY\n      // probably edges of the projections when no extent is defined\n      this.state = TileState.EMPTY;\n      return;\n    }\n\n    const errorThresholdInPixels =\n      errorThreshold !== undefined ? errorThreshold : ERROR_THRESHOLD;\n\n    /**\n     * @private\n     * @type {!import(\"./Triangulation.js\").default}\n     */\n    this.triangulation_ = new Triangulation(\n      sourceProj,\n      targetProj,\n      limitedTargetExtent,\n      maxSourceExtent,\n      sourceResolution * errorThresholdInPixels,\n      targetResolution,\n    );\n\n    if (this.triangulation_.getTriangles().length === 0) {\n      // no valid triangles -> EMPTY\n      this.state = TileState.EMPTY;\n      return;\n    }\n\n    this.sourceZ_ = sourceTileGrid.getZForResolution(sourceResolution);\n    let sourceExtent = this.triangulation_.calculateSourceExtent();\n\n    if (maxSourceExtent) {\n      if (sourceProj.canWrapX()) {\n        sourceExtent[1] = clamp(\n          sourceExtent[1],\n          maxSourceExtent[1],\n          maxSourceExtent[3],\n        );\n        sourceExtent[3] = clamp(\n          sourceExtent[3],\n          maxSourceExtent[1],\n          maxSourceExtent[3],\n        );\n      } else {\n        sourceExtent = getIntersection(sourceExtent, maxSourceExtent);\n      }\n    }\n\n    if (!getArea(sourceExtent)) {\n      this.state = TileState.EMPTY;\n    } else {\n      let worldWidth = 0;\n      let worldsAway = 0;\n      if (sourceProj.canWrapX()) {\n        worldWidth = getWidth(sourceProjExtent);\n        worldsAway = Math.floor(\n          (sourceExtent[0] - sourceProjExtent[0]) / worldWidth,\n        );\n      }\n\n      const sourceExtents = wrapAndSliceX(\n        sourceExtent.slice(),\n        sourceProj,\n        true,\n      );\n      sourceExtents.forEach((extent) => {\n        const sourceRange = sourceTileGrid.getTileRangeForExtentAndZ(\n          extent,\n          this.sourceZ_,\n        );\n\n        for (let srcX = sourceRange.minX; srcX <= sourceRange.maxX; srcX++) {\n          for (let srcY = sourceRange.minY; srcY <= sourceRange.maxY; srcY++) {\n            const offset = worldsAway * worldWidth;\n            this.sourceTiles_.push({\n              getTile: () =>\n                getTileFunction(this.sourceZ_, srcX, srcY, pixelRatio),\n              offset,\n            });\n          }\n        }\n        ++worldsAway;\n      });\n\n      if (this.sourceTiles_.length === 0) {\n        this.state = TileState.EMPTY;\n      }\n    }\n  }\n\n  /**\n   * Get the HTML Canvas element for this tile.\n   * @return {HTMLCanvasElement|OffscreenCanvas} Canvas.\n   */\n  getImage() {\n    return this.canvas_;\n  }\n\n  /**\n   * @private\n   */\n  reproject_() {\n    const sources = [];\n    this.sourceTiles_.forEach((source) => {\n      const tile = source.tile;\n      if (tile && tile.getState() == TileState.LOADED) {\n        const extent = this.sourceTileGrid_.getTileCoordExtent(tile.tileCoord);\n        extent[0] += source.offset;\n        extent[2] += source.offset;\n        const clipExtent = this.clipExtent_?.slice();\n        if (clipExtent) {\n          clipExtent[0] += source.offset;\n          clipExtent[2] += source.offset;\n        }\n        sources.push({\n          extent: extent,\n          clipExtent: clipExtent,\n          image: tile.getImage(),\n        });\n      }\n    });\n    this.sourceTiles_.length = 0;\n\n    if (sources.length === 0) {\n      this.state = TileState.ERROR;\n    } else {\n      const z = this.wrappedTileCoord_[0];\n      const size = this.targetTileGrid_.getTileSize(z);\n      const width = typeof size === 'number' ? size : size[0];\n      const height = typeof size === 'number' ? size : size[1];\n      const targetResolution = this.targetTileGrid_.getResolution(z);\n      const sourceResolution = this.sourceTileGrid_.getResolution(\n        this.sourceZ_,\n      );\n\n      const targetExtent = this.targetTileGrid_.getTileCoordExtent(\n        this.wrappedTileCoord_,\n      );\n\n      this.canvas_ = renderReprojected(\n        width,\n        height,\n        this.pixelRatio_,\n        sourceResolution,\n        this.sourceTileGrid_.getExtent(),\n        targetResolution,\n        targetExtent,\n        this.triangulation_,\n        sources,\n        this.gutter_,\n        this.renderEdges_,\n        this.interpolate,\n      );\n\n      this.state = TileState.LOADED;\n    }\n    this.changed();\n  }\n\n  /**\n   * Load not yet loaded URI.\n   * @override\n   */\n  load() {\n    for (const sourceTile of this.sourceTiles_) {\n      sourceTile.tile = sourceTile.getTile();\n    }\n    if (this.state == TileState.IDLE) {\n      this.state = TileState.LOADING;\n      this.changed();\n\n      let leftToLoad = 0;\n\n      this.sourcesListenerKeys_ = [];\n      this.sourceTiles_.forEach(({tile}) => {\n        const state = tile.getState();\n        if (state == TileState.IDLE || state == TileState.LOADING) {\n          leftToLoad++;\n\n          const sourceListenKey = listen(tile, EventType.CHANGE, (e) => {\n            const state = tile.getState();\n            if (\n              state == TileState.LOADED ||\n              state == TileState.ERROR ||\n              state == TileState.EMPTY\n            ) {\n              unlistenByKey(sourceListenKey);\n              leftToLoad--;\n              if (leftToLoad === 0) {\n                this.unlistenSources_();\n                this.reproject_();\n              }\n            }\n          });\n          this.sourcesListenerKeys_.push(sourceListenKey);\n        }\n      });\n\n      if (leftToLoad === 0) {\n        setTimeout(this.reproject_.bind(this), 0);\n      } else {\n        this.sourceTiles_.forEach(function ({tile}, i, arr) {\n          const state = tile.getState();\n          if (state == TileState.IDLE) {\n            tile.load();\n          }\n        });\n      }\n    }\n  }\n\n  /**\n   * @private\n   */\n  unlistenSources_() {\n    this.sourcesListenerKeys_.forEach(unlistenByKey);\n    this.sourcesListenerKeys_ = null;\n  }\n\n  /**\n   * Remove from the cache due to expiry\n   * @override\n   */\n  release() {\n    if (this.canvas_) {\n      releaseCanvas(\n        /** @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} */ (\n          this.canvas_.getContext('2d')\n        ),\n      );\n      canvasPool.push(this.canvas_);\n      this.canvas_ = null;\n    }\n    this.sourceTiles_.length = 0;\n    super.release();\n  }\n}\n\nexport default ReprojTile;\n","/**\n * @module ol/source/Tile\n */\nimport Event from '../events/Event.js';\nimport {scale as scaleSize, toSize} from '../size.js';\nimport {withinExtentAndZ} from '../tilecoord.js';\nimport {\n  getForProjection as getTileGridForProjection,\n  wrapX,\n} from '../tilegrid.js';\nimport {abstract, getUid} from '../util.js';\nimport Source from './Source.js';\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types, import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"./TileEventType.js\").TileSourceEventTypes, TileSourceEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"../ObjectEventType.js\").Types|\n *     import(\"./TileEventType.js\").TileSourceEventTypes, Return>} TileSourceOnSignature\n */\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.\n * @property {number} [cacheSize] Deprecated.  Use the cacheSize option on the layer instead.\n * @property {number} [tilePixelRatio] TilePixelRatio.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection.\n * @property {import(\"./Source.js\").State} [state] State.\n * @property {import(\"../tilegrid/TileGrid.js\").default} [tileGrid] TileGrid.\n * @property {boolean} [wrapX=false] WrapX.\n * @property {number} [transition] Transition.\n * @property {string} [key] Key.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0] ZDirection.\n * @property {boolean} [interpolate=false] Use interpolated values when resampling.  By default,\n * the nearest neighbor is used when resampling.\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 sources providing images divided into a tile grid.\n *\n * @template {import(\"../Tile.js\").default} [TileType=import(\"../Tile.js\").default]\n * @abstract\n * @api\n */\nclass TileSource extends Source {\n  /**\n   * @param {Options} options SourceTile source options.\n   */\n  constructor(options) {\n    super({\n      attributions: options.attributions,\n      attributionsCollapsible: options.attributionsCollapsible,\n      projection: options.projection,\n      state: options.state,\n      wrapX: options.wrapX,\n      interpolate: options.interpolate,\n    });\n\n    /***\n     * @type {TileSourceOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {TileSourceOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {TileSourceOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.tilePixelRatio_ =\n      options.tilePixelRatio !== undefined ? options.tilePixelRatio : 1;\n\n    /**\n     * @type {import(\"../tilegrid/TileGrid.js\").default|null}\n     * @protected\n     */\n    this.tileGrid = options.tileGrid !== undefined ? options.tileGrid : null;\n\n    const tileSize = [256, 256];\n    if (this.tileGrid) {\n      toSize(this.tileGrid.getTileSize(this.tileGrid.getMinZoom()), tileSize);\n    }\n\n    /**\n     * @protected\n     * @type {import(\"../size.js\").Size}\n     */\n    this.tmpSize = [0, 0];\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.key_ = options.key || getUid(this);\n\n    /**\n     * @protected\n     * @type {import(\"../Tile.js\").Options}\n     */\n    this.tileOptions = {\n      transition: options.transition,\n      interpolate: options.interpolate,\n    };\n\n    /**\n     * zDirection hint, read by the renderer. Indicates which resolution should be used\n     * by a renderer if the views 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     * @type {number|import(\"../array.js\").NearestDirectionFunction}\n     */\n    this.zDirection = options.zDirection ? options.zDirection : 0;\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {number} Gutter.\n   */\n  getGutterForProjection(projection) {\n    return 0;\n  }\n\n  /**\n   * Return the key to be used for all tiles in the source.\n   * @return {string} The key for all tiles.\n   */\n  getKey() {\n    return this.key_;\n  }\n\n  /**\n   * Set the value to be used as the key for all tiles in the source.\n   * @param {string} key The key for tiles.\n   * @protected\n   */\n  setKey(key) {\n    if (this.key_ !== key) {\n      this.key_ = key;\n      this.changed();\n    }\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} [projection] Projection.\n   * @return {Array<number>|null} Resolutions.\n   * @override\n   */\n  getResolutions(projection) {\n    const tileGrid = projection\n      ? this.getTileGridForProjection(projection)\n      : this.tileGrid;\n    if (!tileGrid) {\n      return null;\n    }\n    return tileGrid.getResolutions();\n  }\n\n  /**\n   * @abstract\n   * @param {number} z Tile coordinate z.\n   * @param {number} x Tile coordinate x.\n   * @param {number} y Tile coordinate y.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @param {import(\"../structs/LRUCache.js\").default<import(\"../Tile.js\").default>} [tileCache] Tile cache.\n   * @return {TileType|null} Tile.\n   */\n  getTile(z, x, y, pixelRatio, projection, tileCache) {\n    return abstract();\n  }\n\n  /**\n   * Return the tile grid of the tile source.\n   * @return {import(\"../tilegrid/TileGrid.js\").default|null} Tile grid.\n   * @api\n   */\n  getTileGrid() {\n    return this.tileGrid;\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {!import(\"../tilegrid/TileGrid.js\").default} Tile grid.\n   */\n  getTileGridForProjection(projection) {\n    if (!this.tileGrid) {\n      return getTileGridForProjection(projection);\n    }\n    return this.tileGrid;\n  }\n\n  /**\n   * Get the tile pixel ratio for this source. Subclasses may override this\n   * method, which is meant to return a supported pixel ratio that matches the\n   * provided `pixelRatio` as close as possible.\n   * @param {number} pixelRatio Pixel ratio.\n   * @return {number} Tile pixel ratio.\n   */\n  getTilePixelRatio(pixelRatio) {\n    return this.tilePixelRatio_;\n  }\n\n  /**\n   * @param {number} z Z.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {import(\"../size.js\").Size} Tile size.\n   */\n  getTilePixelSize(z, pixelRatio, projection) {\n    const tileGrid = this.getTileGridForProjection(projection);\n    const tilePixelRatio = this.getTilePixelRatio(pixelRatio);\n    const tileSize = toSize(tileGrid.getTileSize(z), this.tmpSize);\n    if (tilePixelRatio == 1) {\n      return tileSize;\n    }\n    return scaleSize(tileSize, tilePixelRatio, this.tmpSize);\n  }\n\n  /**\n   * Returns a tile coordinate wrapped around the x-axis. When the tile coordinate\n   * is outside the resolution and extent range of the tile grid, `null` will be\n   * returned.\n   * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n   * @param {import(\"../proj/Projection.js\").default} [projection] Projection.\n   * @return {import(\"../tilecoord.js\").TileCoord} Tile coordinate to be passed to the tileUrlFunction or\n   *     null if no tile URL should be created for the passed `tileCoord`.\n   */\n  getTileCoordForTileUrlFunction(tileCoord, projection) {\n    const gridProjection =\n      projection !== undefined ? projection : this.getProjection();\n    const tileGrid =\n      projection !== undefined\n        ? this.getTileGridForProjection(gridProjection)\n        : this.tileGrid || this.getTileGridForProjection(gridProjection);\n    if (this.getWrapX() && gridProjection.isGlobal()) {\n      tileCoord = wrapX(tileGrid, tileCoord, gridProjection);\n    }\n    return withinExtentAndZ(tileCoord, tileGrid) ? tileCoord : null;\n  }\n\n  /**\n   * Remove all cached reprojected tiles from the source. The next render cycle will create new tiles.\n   * @api\n   */\n  clear() {}\n\n  /**\n   * @override\n   */\n  refresh() {\n    this.clear();\n    super.refresh();\n  }\n}\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/source/Tile~TileSource} instances are instances of this\n * type.\n */\nexport class TileSourceEvent extends Event {\n  /**\n   * @param {string} type Type.\n   * @param {import(\"../Tile.js\").default} tile The tile.\n   */\n  constructor(type, tile) {\n    super(type);\n\n    /**\n     * The tile related to the event.\n     * @type {import(\"../Tile.js\").default}\n     * @api\n     */\n    this.tile = tile;\n  }\n}\n\nexport default TileSource;\n","/**\n * @module ol/source/TileEventType\n */\n\n/**\n * @enum {string}\n */\nexport default {\n  /**\n   * Triggered when a tile starts loading.\n   * @event module:ol/source/Tile.TileSourceEvent#tileloadstart\n   * @api\n   */\n  TILELOADSTART: 'tileloadstart',\n\n  /**\n   * Triggered when a tile finishes loading, either when its data is loaded,\n   * or when loading was aborted because the tile is no longer needed.\n   * @event module:ol/source/Tile.TileSourceEvent#tileloadend\n   * @api\n   */\n  TILELOADEND: 'tileloadend',\n\n  /**\n   * Triggered if tile loading results in an error. Note that this is not the\n   * right place to re-fetch tiles. See {@link module:ol/ImageTile~ImageTile#load}\n   * for details.\n   * @event module:ol/source/Tile.TileSourceEvent#tileloaderror\n   * @api\n   */\n  TILELOADERROR: 'tileloaderror',\n};\n\n/**\n * @typedef {'tileloadstart'|'tileloadend'|'tileloaderror'} TileSourceEventTypes\n */\n","/**\n * @module ol/source/UrlTile\n */\nimport TileState from '../TileState.js';\nimport {createFromTemplates} from '../tileurlfunction.js';\nimport {expandUrl} from '../uri.js';\nimport {getUid} from '../util.js';\nimport TileSource, {TileSourceEvent} from './Tile.js';\nimport TileEventType from './TileEventType.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.\n * @property {number} [cacheSize] Deprecated.  Use the cacheSize option on the layer instead.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection.\n * @property {import(\"./Source.js\").State} [state] State.\n * @property {import(\"../tilegrid/TileGrid.js\").default} [tileGrid] TileGrid.\n * @property {import(\"../Tile.js\").LoadFunction} tileLoadFunction TileLoadFunction.\n * @property {number} [tilePixelRatio] TilePixelRatio.\n * @property {import(\"../Tile.js\").UrlFunction} [tileUrlFunction] Deprecated.  Use an ImageTile source and provide a function\n * for the url option instead.\n * @property {string} [url] Url.\n * @property {Array<string>} [urls] Urls.\n * @property {boolean} [wrapX=true] WrapX.\n * @property {number} [transition] Transition.\n * @property {string} [key] Key.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0] ZDirection.\n * @property {boolean} [interpolate=false] Use interpolated values when resampling.  By default,\n * the nearest neighbor is used when resampling.\n */\n\n/**\n * @deprecated Use the ol/source/ImageTile.js instead.\n *\n * @fires import(\"./Tile.js\").TileSourceEvent\n */\nclass UrlTile extends TileSource {\n  /**\n   * @param {Options} options Image tile options.\n   */\n  constructor(options) {\n    super({\n      attributions: options.attributions,\n      cacheSize: options.cacheSize,\n      projection: options.projection,\n      state: options.state,\n      tileGrid: options.tileGrid,\n      tilePixelRatio: options.tilePixelRatio,\n      wrapX: options.wrapX,\n      transition: options.transition,\n      interpolate: options.interpolate,\n      key: options.key,\n      attributionsCollapsible: options.attributionsCollapsible,\n      zDirection: options.zDirection,\n    });\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.generateTileUrlFunction_ =\n      this.tileUrlFunction === UrlTile.prototype.tileUrlFunction;\n\n    /**\n     * @protected\n     * @type {import(\"../Tile.js\").LoadFunction}\n     */\n    this.tileLoadFunction = options.tileLoadFunction;\n\n    if (options.tileUrlFunction) {\n      this.tileUrlFunction = options.tileUrlFunction;\n    }\n\n    /**\n     * @protected\n     * @type {!Array<string>|null}\n     */\n    this.urls = null;\n\n    if (options.urls) {\n      this.setUrls(options.urls);\n    } else if (options.url) {\n      this.setUrl(options.url);\n    }\n\n    /**\n     * @private\n     * @type {!Object<string, boolean>}\n     */\n    this.tileLoadingKeys_ = {};\n  }\n\n  /**\n   * Deprecated.  Use an ImageTile source instead.\n   * Return the tile load function of the source.\n   * @return {import(\"../Tile.js\").LoadFunction} TileLoadFunction\n   * @api\n   */\n  getTileLoadFunction() {\n    return this.tileLoadFunction;\n  }\n\n  /**\n   * Deprecated.  Use an ImageTile source instead.\n   * Return the tile URL function of the source.\n   * @return {import(\"../Tile.js\").UrlFunction} TileUrlFunction\n   * @api\n   */\n  getTileUrlFunction() {\n    return Object.getPrototypeOf(this).tileUrlFunction === this.tileUrlFunction\n      ? this.tileUrlFunction.bind(this)\n      : this.tileUrlFunction;\n  }\n\n  /**\n   * Deprecated.  Use an ImageTile source instead.\n   * Return the URLs used for this source.\n   * When a tileUrlFunction is used instead of url or urls,\n   * null will be returned.\n   * @return {!Array<string>|null} URLs.\n   * @api\n   */\n  getUrls() {\n    return this.urls;\n  }\n\n  /**\n   * Handle tile change events.\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 uid = getUid(tile);\n    const tileState = tile.getState();\n    let type;\n    if (tileState == TileState.LOADING) {\n      this.tileLoadingKeys_[uid] = true;\n      type = TileEventType.TILELOADSTART;\n    } else if (uid in this.tileLoadingKeys_) {\n      delete this.tileLoadingKeys_[uid];\n      type =\n        tileState == TileState.ERROR\n          ? TileEventType.TILELOADERROR\n          : tileState == TileState.LOADED\n            ? TileEventType.TILELOADEND\n            : undefined;\n    }\n    if (type != undefined) {\n      this.dispatchEvent(new TileSourceEvent(type, tile));\n    }\n  }\n\n  /**\n   * Deprecated.  Use an ImageTile source instead.\n   * Set the tile load function of the source.\n   * @param {import(\"../Tile.js\").LoadFunction} tileLoadFunction Tile load function.\n   * @api\n   */\n  setTileLoadFunction(tileLoadFunction) {\n    this.tileLoadFunction = tileLoadFunction;\n    this.changed();\n  }\n\n  /**\n   * Deprecated.  Use an ImageTile source instead.\n   * Set the tile URL function of the source.\n   * @param {import(\"../Tile.js\").UrlFunction} tileUrlFunction Tile URL function.\n   * @param {string} [key] Optional new tile key for the source.\n   * @api\n   */\n  setTileUrlFunction(tileUrlFunction, key) {\n    this.tileUrlFunction = tileUrlFunction;\n    if (typeof key !== 'undefined') {\n      this.setKey(key);\n    } else {\n      this.changed();\n    }\n  }\n\n  /**\n   * Set the URL to use for requests.\n   * @param {string} url URL.\n   * @api\n   */\n  setUrl(url) {\n    const urls = expandUrl(url);\n    this.urls = urls;\n    this.setUrls(urls);\n  }\n\n  /**\n   * Deprecated.  Use an ImageTile source instead.\n   * Set the URLs to use for requests.\n   * @param {Array<string>} urls URLs.\n   * @api\n   */\n  setUrls(urls) {\n    this.urls = urls;\n    const key = urls.join('\\n');\n    if (this.generateTileUrlFunction_) {\n      this.setTileUrlFunction(createFromTemplates(urls, this.tileGrid), key);\n    } else {\n      this.setKey(key);\n    }\n  }\n\n  /**\n   * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {string|undefined} Tile URL.\n   */\n  tileUrlFunction(tileCoord, pixelRatio, projection) {\n    return undefined;\n  }\n}\n\nexport default UrlTile;\n","/**\n * @module ol/source/TileImage\n */\nimport ImageTile from '../ImageTile.js';\nimport TileState from '../TileState.js';\nimport EventType from '../events/EventType.js';\nimport {WORKER_OFFSCREEN_CANVAS} from '../has.js';\nimport {equivalent, get as getProjection} from '../proj.js';\nimport ReprojTile from '../reproj/Tile.js';\nimport {getCacheKey} from '../tilecoord.js';\nimport {getForProjection as getTileGridForProjection} from '../tilegrid.js';\nimport {getUid} from '../util.js';\nimport UrlTile from './UrlTile.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.\n * @property {number} [cacheSize] Deprecated.  Use the cacheSize option on the layer instead.\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images.  Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for loaded images.\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * linear interpolation is used when resampling.  Set to false to use the nearest neighbor instead.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is the view projection.\n * @property {number} [reprojectionErrorThreshold=0.5] Maximum allowed reprojection error (in pixels).\n * Higher values can increase reprojection performance, but decrease precision.\n * @property {import(\"./Source.js\").State} [state] Source state.\n * @property {typeof import(\"../ImageTile.js\").default} [tileClass] Class used to instantiate image tiles.\n * Default is {@link module:ol/ImageTile~ImageTile}.\n * @property {import(\"../tilegrid/TileGrid.js\").default} [tileGrid] Tile grid.\n * @property {import(\"../Tile.js\").LoadFunction} [tileLoadFunction] Optional function to load a tile given a URL. The default is\n * ```js\n * function(imageTile, src) {\n *   imageTile.getImage().src = src;\n * };\n * ```\n * @property {number} [tilePixelRatio=1] The pixel ratio used by the tile service. For example, if the tile\n * service advertizes 256px by 256px tiles but actually sends 512px\n * by 512px images (for retina/hidpi devices) then `tilePixelRatio`\n * should be set to `2`.\n * @property {import(\"../Tile.js\").UrlFunction} [tileUrlFunction] Deprecated.  Use an ImageTile source and provide a function\n * for the url option instead.\n * @property {string} [url] URL template. Must include `{x}`, `{y}` or `{-y}`, and `{z}` placeholders.\n * A `{?-?}` template pattern, for example `subdomain{a-f}.domain.com`, may be\n * used instead of defining each one separately in the `urls` option.\n * @property {Array<string>} [urls] An array of URL templates.\n * @property {boolean} [wrapX] Whether to wrap the world horizontally. The default, is to\n * request out-of-bounds tiles from the server. When set to `false`, only one\n * world will be rendered. When set to `true`, tiles will be requested for one\n * world only, but they will be wrapped horizontally to render multiple worlds.\n * @property {number} [transition] Duration of the opacity transition for rendering.\n * To disable the opacity transition, pass `transition: 0`.\n * @property {string} [key] Optional tile key for proper cache fetching\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n */\n\n/**\n * @deprecated Use the ol/source/ImageTile.js instead.\n *\n * @fires import(\"./Tile.js\").TileSourceEvent\n * @api\n */\nclass TileImage extends UrlTile {\n  /**\n   * @param {!Options} options Image tile options.\n   */\n  constructor(options) {\n    super({\n      attributions: options.attributions,\n      cacheSize: options.cacheSize,\n      projection: options.projection,\n      state: options.state,\n      tileGrid: options.tileGrid,\n      tileLoadFunction: options.tileLoadFunction\n        ? options.tileLoadFunction\n        : defaultTileLoadFunction,\n      tilePixelRatio: options.tilePixelRatio,\n      tileUrlFunction: options.tileUrlFunction,\n      url: options.url,\n      urls: options.urls,\n      wrapX: options.wrapX,\n      transition: options.transition,\n      interpolate:\n        options.interpolate !== undefined ? options.interpolate : true,\n      key: options.key,\n      attributionsCollapsible: options.attributionsCollapsible,\n      zDirection: options.zDirection,\n    });\n\n    /**\n     * @protected\n     * @type {?string}\n     */\n    this.crossOrigin =\n      options.crossOrigin !== undefined ? options.crossOrigin : null;\n\n    /**\n     * @protected\n     * @type {ReferrerPolicy}\n     */\n    this.referrerPolicy = options.referrerPolicy;\n\n    /**\n     * @protected\n     * @type {typeof ImageTile}\n     */\n    this.tileClass =\n      options.tileClass !== undefined ? options.tileClass : ImageTile;\n\n    /**\n     * @protected\n     * @type {!Object<string, import(\"../tilegrid/TileGrid.js\").default>}\n     */\n    this.tileGridForProjection = {};\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.reprojectionErrorThreshold_ = options.reprojectionErrorThreshold;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.renderReprojectionEdges_ = false;\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {number} Gutter.\n   * @override\n   */\n  getGutterForProjection(projection) {\n    if (\n      this.getProjection() &&\n      projection &&\n      !equivalent(this.getProjection(), projection)\n    ) {\n      return 0;\n    }\n    return this.getGutter();\n  }\n\n  /**\n   * @return {number} Gutter.\n   */\n  getGutter() {\n    return 0;\n  }\n\n  /**\n   * Return the key to be used for all tiles in the source.\n   * @return {string} The key for all tiles.\n   * @override\n   */\n  getKey() {\n    let key = super.getKey();\n    if (!this.getInterpolate()) {\n      key += ':disable-interpolation';\n    }\n    return key;\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {!import(\"../tilegrid/TileGrid.js\").default} Tile grid.\n   * @override\n   */\n  getTileGridForProjection(projection) {\n    const thisProj = this.getProjection();\n    if (this.tileGrid && (!thisProj || equivalent(thisProj, projection))) {\n      return this.tileGrid;\n    }\n    const projKey = getUid(projection);\n    if (!(projKey in this.tileGridForProjection)) {\n      this.tileGridForProjection[projKey] =\n        getTileGridForProjection(projection);\n    }\n    return this.tileGridForProjection[projKey];\n  }\n\n  /**\n   * @param {number} z Tile coordinate z.\n   * @param {number} x Tile coordinate x.\n   * @param {number} y Tile coordinate y.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @param {string} key The key set on the tile.\n   * @return {!ImageTile} Tile.\n   * @private\n   */\n  createTile_(z, x, y, pixelRatio, projection, key) {\n    const tileCoord = [z, x, y];\n    const urlTileCoord = this.getTileCoordForTileUrlFunction(\n      tileCoord,\n      projection,\n    );\n    const tileUrl = urlTileCoord\n      ? this.tileUrlFunction(urlTileCoord, pixelRatio, projection)\n      : undefined;\n    const tile = new this.tileClass(\n      tileCoord,\n      tileUrl !== undefined ? TileState.IDLE : TileState.EMPTY,\n      tileUrl !== undefined ? tileUrl : '',\n      {\n        crossOrigin: this.crossOrigin,\n        referrerPolicy: this.referrerPolicy,\n      },\n      this.tileLoadFunction,\n      this.tileOptions,\n    );\n    tile.key = key;\n    tile.addEventListener(EventType.CHANGE, this.handleTileChange.bind(this));\n    return tile;\n  }\n\n  /**\n   * @param {number} z Tile coordinate z.\n   * @param {number} x Tile coordinate x.\n   * @param {number} y Tile coordinate y.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @param {import(\"../structs/LRUCache.js\").default<import(\"../Tile.js\").default>} [tileCache] Tile cache.\n   * @return {!(ImageTile|ReprojTile)} Tile.\n   * @override\n   */\n  getTile(z, x, y, pixelRatio, projection, tileCache) {\n    const sourceProjection = this.getProjection();\n    if (\n      !sourceProjection ||\n      !projection ||\n      equivalent(sourceProjection, projection)\n    ) {\n      return this.getTileInternal(\n        z,\n        x,\n        y,\n        pixelRatio,\n        sourceProjection || projection,\n      );\n    }\n    const tileCoord = [z, x, y];\n    const key = this.getKey();\n    const sourceTileGrid = this.getTileGridForProjection(sourceProjection);\n    const targetTileGrid = this.getTileGridForProjection(projection);\n    const wrappedTileCoord = this.getTileCoordForTileUrlFunction(\n      tileCoord,\n      projection,\n    );\n    const tile = new ReprojTile(\n      sourceProjection,\n      sourceTileGrid,\n      projection,\n      targetTileGrid,\n      tileCoord,\n      wrappedTileCoord,\n      this.getTilePixelRatio(pixelRatio),\n      this.getGutter(),\n      (z, x, y, pixelRatio) =>\n        this.getTileInternal(z, x, y, pixelRatio, sourceProjection, tileCache),\n      this.reprojectionErrorThreshold_,\n      this.renderReprojectionEdges_,\n      this.tileOptions,\n    );\n    tile.key = key;\n    return tile;\n  }\n\n  /**\n   * @param {number} z Tile coordinate z.\n   * @param {number} x Tile coordinate x.\n   * @param {number} y Tile coordinate y.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {!import(\"../proj/Projection.js\").default} projection Projection.\n   * @param {import(\"../structs/LRUCache.js\").default<import(\"../Tile.js\").default>} [tileCache] Tile cache.\n   * @return {!ImageTile} Tile.\n   * @protected\n   */\n  getTileInternal(z, x, y, pixelRatio, projection, tileCache) {\n    const key = this.getKey();\n    const cacheKey = getCacheKey(this, key, z, x, y);\n    if (tileCache && tileCache.containsKey(cacheKey)) {\n      const tile = /** @type {!ImageTile} */ (tileCache.get(cacheKey));\n      return tile;\n    }\n    const tile = this.createTile_(z, x, y, pixelRatio, projection, key);\n    tileCache?.set(cacheKey, tile);\n    return tile;\n  }\n\n  /**\n   * Sets whether to render reprojection edges or not (usually for debugging).\n   * @param {boolean} render Render the edges.\n   * @api\n   */\n  setRenderReprojectionEdges(render) {\n    if (this.renderReprojectionEdges_ == render) {\n      return;\n    }\n    this.renderReprojectionEdges_ = render;\n    this.changed();\n  }\n\n  /**\n   * Sets the tile grid to use when reprojecting the tiles to the given\n   * projection instead of the default tile grid for the projection.\n   *\n   * This can be useful when the default tile grid cannot be created\n   * (e.g. projection has no extent defined) or\n   * for optimization reasons (custom tile size, resolutions, ...).\n   *\n   * @param {import(\"../proj.js\").ProjectionLike} projection Projection.\n   * @param {import(\"../tilegrid/TileGrid.js\").default} tilegrid Tile grid to use for the projection.\n   * @api\n   */\n  setTileGridForProjection(projection, tilegrid) {\n    const proj = getProjection(projection);\n    if (proj) {\n      const projKey = getUid(proj);\n      if (!(projKey in this.tileGridForProjection)) {\n        this.tileGridForProjection[projKey] = tilegrid;\n      }\n    }\n  }\n}\n\n/**\n * @param {ImageTile} imageTile Image tile.\n * @param {string} src Source.\n */\nexport function defaultTileLoadFunction(imageTile, src) {\n  if (WORKER_OFFSCREEN_CANVAS) {\n    // special treatment for offscreen canvas\n    const crossOrigin = imageTile.getCrossOrigin();\n\n    /** @type {RequestMode} */\n    let mode = 'same-origin';\n    /** @type {RequestCredentials} */\n    let credentials = 'same-origin';\n    if (crossOrigin === 'anonymous' || crossOrigin === '') {\n      mode = 'cors';\n      credentials = 'omit';\n    } else if (crossOrigin === 'use-credentials') {\n      mode = 'cors';\n      credentials = 'include';\n    }\n\n    const options = {\n      mode,\n      credentials,\n      referrerPolicy: imageTile.getReferrerPolicy(),\n    };\n\n    fetch(src, options)\n      .then((response) => {\n        if (!response.ok) {\n          throw new Error(`HTTP ${response.status}`);\n        }\n        return response.blob();\n      })\n      .then((blob) => {\n        return createImageBitmap(blob);\n      })\n      .then((imageBitmap) => {\n        const canvas = imageTile.getImage();\n        canvas.width = imageBitmap.width;\n        canvas.height = imageBitmap.height;\n        const ctx = /** @type {OffscreenCanvas} */ (canvas).getContext('2d');\n        ctx.drawImage(imageBitmap, 0, 0);\n        imageBitmap.close?.();\n        // mock the image 'load' event\n        canvas.dispatchEvent(new Event('load'));\n      })\n      .catch(() => {\n        const canvas = imageTile.getImage();\n        canvas.dispatchEvent(new Event('error'));\n      });\n    return;\n  }\n\n  /** @type {HTMLImageElement|HTMLVideoElement} */ (imageTile.getImage()).src =\n    src;\n}\n\nexport default TileImage;\n","/**\n * @module ol/source/BingMaps\n */\n\nimport {applyTransform, intersects} from '../extent.js';\nimport {get as getProjection, getTransformFromProjections} from '../proj.js';\nimport {createOrUpdate} from '../tilecoord.js';\nimport {createXYZ, extentFromProjection} from '../tilegrid.js';\nimport {createFromTileUrlFunctions} from '../tileurlfunction.js';\nimport TileImage from './TileImage.js';\n\n/**\n * @param {import('../tilecoord.js').TileCoord} tileCoord Tile coord.\n * @return {string} Quad key.\n */\nexport function quadKey(tileCoord) {\n  const z = tileCoord[0];\n  const digits = new Array(z);\n  let mask = 1 << (z - 1);\n  let i, charCode;\n  for (i = 0; i < z; ++i) {\n    // 48 is charCode for 0 - '0'.charCodeAt(0)\n    charCode = 48;\n    if (tileCoord[1] & mask) {\n      charCode += 1;\n    }\n    if (tileCoord[2] & mask) {\n      charCode += 2;\n    }\n    digits[i] = String.fromCharCode(charCode);\n    mask >>= 1;\n  }\n  return digits.join('');\n}\n\n/**\n * The attribution containing a link to the Microsoft® Bing™ Maps Platform APIs’\n * Terms Of Use.\n * @const\n * @type {string}\n */\nconst TOS_ATTRIBUTION =\n  '<a class=\"ol-attribution-bing-tos\" ' +\n  'href=\"https://www.microsoft.com/maps/product/terms.html\" target=\"_blank\">' +\n  'Terms of Use</a>';\n\n/**\n * @typedef {Object} Options\n * @property {number} [cacheSize] Deprecated.  Use the cacheSize option on the layer instead.\n * @property {boolean} [hidpi=false] If `true` hidpi tiles will be requested.\n * @property {string} [culture='en-us'] Culture code.\n * @property {string} key Bing Maps API key. Get yours at https://www.bingmapsportal.com/.\n * @property {string} imagerySet Type of imagery.\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * linear interpolation is used when resampling.  Set to false to use the nearest neighbor instead.\n * @property {number} [maxZoom=21] Max zoom. Default is what's advertized by the BingMaps service.\n * @property {number} [reprojectionErrorThreshold=0.5] Maximum allowed reprojection error (in pixels).\n * Higher values can increase reprojection performance, but decrease precision.\n * @property {import(\"../Tile.js\").LoadFunction} [tileLoadFunction] Optional function to load a tile given a URL. The default is\n * ```js\n * function(imageTile, src) {\n *   imageTile.getImage().src = src;\n * };\n * ```\n * @property {boolean} [wrapX=true] Whether to wrap the world horizontally.\n * @property {number} [transition] Duration of the opacity transition for rendering.\n * To disable the opacity transition, pass `transition: 0`.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n * @property {boolean} [placeholderTiles] Whether to show BingMaps placeholder tiles when zoomed past the maximum level provided in an area. When `false`, requests beyond\n * the maximum zoom level will return no tile. When `true`, the placeholder tile will be returned. When not set, the default behaviour of the imagery set takes place,\n * which is unique for each imagery set in BingMaps.\n * @property {string} [url='https://dev.virtualearth.net/REST/v1/Imagery/Metadata/'] The Bing Map Metadata API URL.\n */\n\n/**\n * @typedef {Object} BingMapsImageryMetadataResponse\n * @property {number} statusCode The response status code\n * @property {string} statusDescription The response status description\n * @property {string} authenticationResultCode The authentication result code\n * @property {Array<ResourceSet>} resourceSets The array of resource sets\n */\n\n/**\n * @typedef {Object} ResourceSet\n * @property {Array<Resource>} resources Resources.\n */\n\n/**\n * @typedef {Object} Resource\n * @property {number} imageHeight The image height\n * @property {number} imageWidth The image width\n * @property {number} zoomMin The minimum zoom level\n * @property {number} zoomMax The maximum zoom level\n * @property {string} imageUrl The image URL\n * @property {Array<string>} imageUrlSubdomains The image URL subdomains for rotation\n * @property {Array<ImageryProvider>} [imageryProviders] The array of ImageryProviders\n */\n\n/**\n * @typedef {Object} ImageryProvider\n * @property {Array<CoverageArea>} coverageAreas The coverage areas\n * @property {string} [attribution] The attribution\n */\n\n/**\n * @typedef {Object} CoverageArea\n * @property {number} zoomMin The minimum zoom\n * @property {number} zoomMax The maximum zoom\n * @property {Array<number>} bbox The coverage bounding box\n */\n\n/**\n * @classdesc\n * Layer source for Bing Maps tile data.\n * @api\n */\nclass BingMaps extends TileImage {\n  /**\n   * @param {Options} options Bing Maps options.\n   */\n  constructor(options) {\n    const hidpi = options.hidpi !== undefined ? options.hidpi : false;\n\n    super({\n      cacheSize: options.cacheSize,\n      crossOrigin: 'anonymous',\n      interpolate: options.interpolate,\n      projection: getProjection('EPSG:3857'),\n      reprojectionErrorThreshold: options.reprojectionErrorThreshold,\n      state: 'loading',\n      tileLoadFunction: options.tileLoadFunction,\n      tilePixelRatio: hidpi ? 2 : 1,\n      wrapX: options.wrapX !== undefined ? options.wrapX : true,\n      transition: options.transition,\n      zDirection: options.zDirection,\n    });\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.hidpi_ = hidpi;\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.culture_ = options.culture !== undefined ? options.culture : 'en-us';\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.maxZoom_ = options.maxZoom !== undefined ? options.maxZoom : -1;\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.apiKey_ = options.key;\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.imagerySet_ = options.imagerySet;\n\n    /**\n     * @private\n     * @type {boolean|undefined}\n     */\n    this.placeholderTiles_ = options.placeholderTiles;\n\n    const url =\n      (options.url ||\n        'https://dev.virtualearth.net/REST/v1/Imagery/Metadata/') +\n      this.imagerySet_ +\n      '?uriScheme=https&include=ImageryProviders&key=' +\n      this.apiKey_ +\n      '&c=' +\n      this.culture_;\n\n    fetch(url)\n      .then((response) => response.json())\n      .then((json) => this.handleImageryMetadataResponse(json));\n  }\n\n  /**\n   * Get the api key used for this source.\n   *\n   * @return {string} The api key.\n   * @api\n   */\n  getApiKey() {\n    return this.apiKey_;\n  }\n\n  /**\n   * Get the imagery set associated with this source.\n   *\n   * @return {string} The imagery set.\n   * @api\n   */\n  getImagerySet() {\n    return this.imagerySet_;\n  }\n\n  /**\n   * @param {BingMapsImageryMetadataResponse} response Response.\n   */\n  handleImageryMetadataResponse(response) {\n    if (\n      response.statusCode != 200 ||\n      response.statusDescription != 'OK' ||\n      response.authenticationResultCode != 'ValidCredentials' ||\n      response.resourceSets.length != 1 ||\n      response.resourceSets[0].resources.length != 1\n    ) {\n      this.setState('error');\n      return;\n    }\n\n    const resource = response.resourceSets[0].resources[0];\n    const maxZoom = this.maxZoom_ == -1 ? resource.zoomMax : this.maxZoom_;\n\n    const sourceProjection = this.getProjection();\n    const extent = extentFromProjection(sourceProjection);\n    const scale = this.hidpi_ ? 2 : 1;\n    const tileSize =\n      resource.imageWidth == resource.imageHeight\n        ? resource.imageWidth / scale\n        : [resource.imageWidth / scale, resource.imageHeight / scale];\n\n    const tileGrid = createXYZ({\n      extent: extent,\n      minZoom: resource.zoomMin,\n      maxZoom: maxZoom,\n      tileSize: tileSize,\n    });\n    this.tileGrid = tileGrid;\n\n    const culture = this.culture_;\n    const hidpi = this.hidpi_;\n    const placeholderTiles = this.placeholderTiles_;\n    this.tileUrlFunction = createFromTileUrlFunctions(\n      resource.imageUrlSubdomains.map(function (subdomain) {\n        /** @type {import('../tilecoord.js').TileCoord} */\n        const quadKeyTileCoord = [0, 0, 0];\n        const imageUrl = resource.imageUrl\n          .replace('{subdomain}', subdomain)\n          .replace('{culture}', culture);\n        return (\n          /**\n           * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n           * @param {number} pixelRatio Pixel ratio.\n           * @param {import(\"../proj/Projection.js\").default} projection Projection.\n           * @return {string|undefined} Tile URL.\n           */\n          function (tileCoord, pixelRatio, projection) {\n            if (!tileCoord) {\n              return undefined;\n            }\n            createOrUpdate(\n              tileCoord[0],\n              tileCoord[1],\n              tileCoord[2],\n              quadKeyTileCoord,\n            );\n            const url = new URL(\n              imageUrl.replace('{quadkey}', quadKey(quadKeyTileCoord)),\n            );\n            const params = url.searchParams;\n            if (hidpi) {\n              params.set('dpi', 'd1');\n              params.set('device', 'mobile');\n            }\n            if (placeholderTiles === true) {\n              params.delete('n');\n            } else if (placeholderTiles === false) {\n              params.set('n', 'z');\n            }\n            return url.toString();\n          }\n        );\n      }),\n    );\n\n    if (resource.imageryProviders) {\n      const transform = getTransformFromProjections(\n        getProjection('EPSG:4326'),\n        this.getProjection(),\n      );\n\n      this.setAttributions((frameState) => {\n        const attributions = [];\n        const viewState = frameState.viewState;\n        const tileGrid = this.getTileGrid();\n        const z = tileGrid.getZForResolution(\n          viewState.resolution,\n          this.zDirection,\n        );\n        const tileCoord = tileGrid.getTileCoordForCoordAndZ(\n          viewState.center,\n          z,\n        );\n        const zoom = tileCoord[0];\n        resource.imageryProviders.map(function (imageryProvider) {\n          let intersecting = false;\n          const coverageAreas = imageryProvider.coverageAreas;\n          for (let i = 0, ii = coverageAreas.length; i < ii; ++i) {\n            const coverageArea = coverageAreas[i];\n            if (zoom >= coverageArea.zoomMin && zoom <= coverageArea.zoomMax) {\n              const bbox = coverageArea.bbox;\n              const epsg4326Extent = [bbox[1], bbox[0], bbox[3], bbox[2]];\n              const extent = applyTransform(epsg4326Extent, transform);\n              if (intersects(extent, frameState.extent)) {\n                intersecting = true;\n                break;\n              }\n            }\n          }\n          if (intersecting) {\n            attributions.push(imageryProvider.attribution);\n          }\n        });\n\n        attributions.push(TOS_ATTRIBUTION);\n        return attributions;\n      });\n    }\n\n    this.setState('ready');\n  }\n}\n\nexport default BingMaps;\n","/**\n * @module ol/source/XYZ\n */\n\nimport {createXYZ, extentFromProjection} from '../tilegrid.js';\nimport TileImage from './TileImage.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.\n * @property {number} [cacheSize] Deprecated.  Use the cacheSize option on the layer instead.\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images.  Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for loaded images.\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * linear interpolation is used when resampling.  Set to false to use the nearest neighbor instead.\n * @property {import(\"../proj.js\").ProjectionLike} [projection='EPSG:3857'] Projection.\n * @property {number} [reprojectionErrorThreshold=0.5] Maximum allowed reprojection error (in pixels).\n * Higher values can increase reprojection performance, but decrease precision.\n * @property {number} [maxZoom=42] Optional max zoom level. Not used if `tileGrid` is provided.\n * @property {number} [minZoom=0] Optional min zoom level. Not used if `tileGrid` is provided.\n * @property {number} [maxResolution] Optional tile grid resolution at level zero. Not used if `tileGrid` is provided.\n * @property {import(\"../tilegrid/TileGrid.js\").default} [tileGrid] Tile grid.\n * @property {import(\"../Tile.js\").LoadFunction} [tileLoadFunction] Deprecated.  Use an ImageTile source with a loader\n * instead.  Optional function to load a tile given a URL. The default is\n * ```js\n * function(imageTile, src) {\n *   imageTile.getImage().src = src;\n * };\n * ```\n * @property {number} [tilePixelRatio=1] The pixel ratio used by the tile service.\n * For example, if the tile service advertizes 256px by 256px tiles but actually sends 512px\n * by 512px images (for retina/hidpi devices) then `tilePixelRatio`\n * should be set to `2`.\n * @property {number|import(\"../size.js\").Size} [tileSize=[256, 256]] The tile size used by the tile service.\n * Not used if `tileGrid` is provided.\n * @property {number} [gutter=0] The size in pixels of the gutter around image tiles to ignore.\n * This allows artifacts of rendering at tile edges to be ignored.\n * Supported images should be wider and taller than the tile size by a value of `2 x gutter`.\n * @property {import(\"../Tile.js\").UrlFunction} [tileUrlFunction] Deprecated.  Use an ImageTile source and provide a function\n * for the url option instead.\n * @property {string} [url] URL template. Must include `{x}`, `{y}` or `{-y}`,\n * and `{z}` placeholders. A `{?-?}` template pattern, for example `subdomain{a-f}.domain.com`,\n * may be used instead of defining each one separately in the `urls` option.\n * @property {Array<string>} [urls] Deprecated.  Use an ImageTile source and provide an array of URLs for the\n * url option instead.\n * @property {boolean} [wrapX=true] Whether to wrap the world horizontally.\n * @property {number} [transition=250] Duration of the opacity transition for rendering.\n * To disable the opacity transition, pass `transition: 0`.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n */\n\n/**\n * @classdesc\n * Layer source for tile data with URLs in a set XYZ format that are\n * defined in a URL template. By default, this follows the widely-used\n * Google grid where `x` 0 and `y` 0 are in the top left. Grids like\n * TMS where `x` 0 and `y` 0 are in the bottom left can be used by\n * using the `{-y}` placeholder in the URL template, so long as the\n * source does not have a custom tile grid. In this case\n * a `tileUrlFunction` can be used, such as:\n * ```js\n *  tileUrlFunction: function(coordinate) {\n *    return 'http://mapserver.com/' + coordinate[0] + '/' +\n *      coordinate[1] + '/' + (-coordinate[2] - 1) + '.png';\n *  }\n * ```\n * @api\n */\nclass XYZ extends TileImage {\n  /**\n   * @param {Options} [options] XYZ options.\n   */\n  constructor(options) {\n    options = options || {};\n\n    const projection =\n      options.projection !== undefined ? options.projection : 'EPSG:3857';\n\n    const tileGrid =\n      options.tileGrid !== undefined\n        ? options.tileGrid\n        : createXYZ({\n            extent: extentFromProjection(projection),\n            maxResolution: options.maxResolution,\n            maxZoom: options.maxZoom,\n            minZoom: options.minZoom,\n            tileSize: options.tileSize,\n          });\n\n    super({\n      attributions: options.attributions,\n      cacheSize: options.cacheSize,\n      crossOrigin: options.crossOrigin,\n      referrerPolicy: options.referrerPolicy,\n      interpolate: options.interpolate,\n      projection: projection,\n      reprojectionErrorThreshold: options.reprojectionErrorThreshold,\n      tileGrid: tileGrid,\n      tileLoadFunction: options.tileLoadFunction,\n      tilePixelRatio: options.tilePixelRatio,\n      tileUrlFunction: options.tileUrlFunction,\n      url: options.url,\n      urls: options.urls,\n      wrapX: options.wrapX !== undefined ? options.wrapX : true,\n      transition: options.transition,\n      attributionsCollapsible: options.attributionsCollapsible,\n      zDirection: options.zDirection,\n    });\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.gutter_ = options.gutter !== undefined ? options.gutter : 0;\n  }\n\n  /**\n   * @return {number} Gutter.\n   * @override\n   */\n  getGutter() {\n    return this.gutter_;\n  }\n}\n\nexport default XYZ;\n","/**\n * @module ol/geom/flat/interpolate\n */\nimport {binarySearch} from '../../array.js';\nimport {lerp} from '../../math.js';\n\n/**\n * @param {Array<number>} 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<number>} [dest] Destination.\n * @param {number} [dimension] Destination dimension (default is `2`)\n * @return {Array<number>} 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<number>} 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<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<number>} 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/length\n */\n\n/**\n * @param {Array<number>} 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<number>} 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/LineString\n */\nimport {extend} from '../array.js';\nimport {closestSquaredDistanceXY} from '../extent.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {assignClosestPoint, maxSquaredDelta} from './flat/closest.js';\nimport {deflateCoordinates} from './flat/deflate.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';\nimport {forEach as forEachSegment} from './flat/segments.js';\nimport {douglasPeucker} from './flat/simplify.js';\n\n/**\n * @classdesc\n * Linestring geometry.\n *\n * @api\n */\nclass LineString extends SimpleGeometry {\n  /**\n   * @param {Array<import(\"../coordinate.js\").Coordinate>|Array<number>} 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<number>} */ (coordinates),\n      );\n    } else {\n      this.setCoordinates(\n        /** @type {Array<import(\"../coordinate.js\").Coordinate>} */ (\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<import(\"../coordinate.js\").Coordinate>} 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<number>} 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<number>} */ (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<number>} */\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      this.getExtent(),\n    );\n  }\n\n  /**\n   * Set the coordinates of the linestring.\n   * @param {!Array<import(\"../coordinate.js\").Coordinate>} 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 {extend} from '../array.js';\nimport {closestSquaredDistanceXY} from '../extent.js';\nimport LineString from './LineString.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {arrayMaxSquaredDelta, assignClosestArrayPoint} from './flat/closest.js';\nimport {deflateCoordinatesArray} from './flat/deflate.js';\nimport {inflateCoordinatesArray} from './flat/inflate.js';\nimport {\n  interpolatePoint,\n  lineStringsCoordinateAtM,\n} from './flat/interpolate.js';\nimport {intersectsLineStringArray} from './flat/intersectsextent.js';\nimport {lineStringLength} from './flat/length.js';\nimport {douglasPeuckerArray} from './flat/simplify.js';\n\n/**\n * @classdesc\n * Multi-linestring geometry.\n *\n * @api\n */\nclass MultiLineString extends SimpleGeometry {\n  /**\n   * @param {Array<Array<import(\"../coordinate.js\").Coordinate>|LineString>|Array<number>} 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<number>} [ends] Flat coordinate ends for internal use.\n   */\n  constructor(coordinates, layout, ends) {\n    super();\n\n    /**\n     * @type {Array<number>}\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<Array<import(\"../coordinate.js\").Coordinate>>} */ (\n          coordinates\n        ),\n        layout,\n      );\n    } else if (layout !== undefined && ends) {\n      this.setFlatCoordinates(\n        layout,\n        /** @type {Array<number>} */ (coordinates),\n      );\n      this.ends_ = ends;\n    } else {\n      const lineStrings = /** @type {Array<LineString>} */ (coordinates);\n      /** @type {Array<number>} */\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<Array<import(\"../coordinate.js\").Coordinate>>} 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<number>} 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<LineString>} LineStrings.\n   * @api\n   */\n  getLineStrings() {\n    const flatCoordinates = this.flatCoordinates;\n    const ends = this.ends_;\n    const layout = this.layout;\n    /** @type {Array<LineString>} */\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 the sum of all line string lengths\n   * @return {number} Length (on projected plane).\n   * @api\n   */\n  getLength() {\n    const ends = this.ends_;\n    let start = 0;\n    let length = 0;\n    for (let i = 0, ii = ends.length; i < ii; ++i) {\n      length += lineStringLength(\n        this.flatCoordinates,\n        start,\n        ends[i],\n        this.stride,\n      );\n      start = ends[i];\n    }\n    return length;\n  }\n\n  /**\n   * @return {Array<number>} Flat midpoints.\n   */\n  getFlatMidpoints() {\n    /** @type {Array<number>} */\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<number>} */\n    const simplifiedFlatCoordinates = [];\n    /** @type {Array<number>} */\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<Array<import(\"../coordinate.js\").Coordinate>>} 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 {extend} from '../array.js';\nimport {closestSquaredDistanceXY, containsXY} from '../extent.js';\nimport {squaredDistance as squaredDx} from '../math.js';\nimport Point from './Point.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {deflateCoordinates} from './flat/deflate.js';\nimport {inflateCoordinates} from './flat/inflate.js';\n\n/**\n * @classdesc\n * Multi-point geometry.\n *\n * @api\n */\nclass MultiPoint extends SimpleGeometry {\n  /**\n   * @param {Array<import(\"../coordinate.js\").Coordinate>|Array<number>} 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<number>} */ (coordinates),\n      );\n    } else {\n      this.setCoordinates(\n        /** @type {Array<import(\"../coordinate.js\").Coordinate>} */ (\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<import(\"../coordinate.js\").Coordinate>} 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<Point>} Points.\n   * @api\n   */\n  getPoints() {\n    const flatCoordinates = this.flatCoordinates;\n    const layout = this.layout;\n    const stride = this.stride;\n    /** @type {Array<Point>} */\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<import(\"../coordinate.js\").Coordinate>} 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/flat/center\n */\nimport {createEmpty, createOrUpdateFromFlatCoordinates} from '../../extent.js';\n\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array<Array<number>>} endss Endss.\n * @param {number} stride Stride.\n * @return {Array<number>} 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/MultiPolygon\n */\nimport {extend} from '../array.js';\nimport {closestSquaredDistanceXY} from '../extent.js';\nimport MultiPoint from './MultiPoint.js';\nimport Polygon from './Polygon.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {linearRingss as linearRingssArea} from './flat/area.js';\nimport {linearRingss as linearRingssCenter} from './flat/center.js';\nimport {\n  assignClosestMultiArrayPoint,\n  multiArrayMaxSquaredDelta,\n} from './flat/closest.js';\nimport {linearRingssContainsXY} from './flat/contains.js';\nimport {deflateMultiCoordinatesArray} from './flat/deflate.js';\nimport {inflateMultiCoordinatesArray} from './flat/inflate.js';\nimport {getInteriorPointsOfMultiArray} from './flat/interiorpoint.js';\nimport {intersectsLinearRingMultiArray} from './flat/intersectsextent.js';\nimport {\n  linearRingssAreOriented,\n  orientLinearRingsArray,\n} from './flat/orient.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<Array<Array<import(\"../coordinate.js\").Coordinate>>|Polygon>|Array<number>} 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<Array<number>>} [endss] Array of ends for internal use with flat coordinates.\n   */\n  constructor(coordinates, layout, endss) {\n    super();\n\n    /**\n     * @type {Array<Array<number>>}\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<number>|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<number>|null}\n     */\n    this.orientedFlatCoordinates_ = null;\n\n    if (!endss && !Array.isArray(coordinates[0])) {\n      const polygons = /** @type {Array<Polygon>} */ (coordinates);\n      /** @type {Array<number>} */\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<number>} */ (coordinates),\n      );\n      this.endss_ = endss;\n    } else {\n      this.setCoordinates(\n        /** @type {Array<Array<Array<import(\"../coordinate.js\").Coordinate>>>} */ (\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<number>} */\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<Array<Array<import(\"../coordinate.js\").Coordinate>>>} 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<Array<number>>} Endss.\n   */\n  getEndss() {\n    return this.endss_;\n  }\n\n  /**\n   * @return {Array<number>} 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<number>} */ (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<number>} 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<number>} */ (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<number>} */\n    const simplifiedFlatCoordinates = [];\n    /** @type {Array<Array<number>>} */\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<Polygon>} 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<Array<Array<import(\"../coordinate.js\").Coordinate>>>} 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/render/Feature\n */\nimport Feature from '../Feature.js';\nimport {extend} from '../array.js';\nimport {\n  createOrUpdateFromCoordinate,\n  createOrUpdateFromFlatCoordinates,\n  getCenter,\n  getHeight,\n} from '../extent.js';\nimport {memoizeOne} from '../functions.js';\nimport LineString from '../geom/LineString.js';\nimport MultiLineString from '../geom/MultiLineString.js';\nimport MultiPoint from '../geom/MultiPoint.js';\nimport MultiPolygon from '../geom/MultiPolygon.js';\nimport Point from '../geom/Point.js';\nimport Polygon from '../geom/Polygon.js';\nimport {linearRingss as linearRingssCenter} from '../geom/flat/center.js';\nimport {\n  getInteriorPointOfArray,\n  getInteriorPointsOfMultiArray,\n} from '../geom/flat/interiorpoint.js';\nimport {interpolatePoint} from '../geom/flat/interpolate.js';\nimport {inflateEnds} from '../geom/flat/orient.js';\nimport {\n  douglasPeucker,\n  douglasPeuckerArray,\n  quantizeArray,\n} from '../geom/flat/simplify.js';\nimport {transform2D} from '../geom/flat/transform.js';\nimport {get as getProjection} from '../proj.js';\nimport {\n  compose as composeTransform,\n  create as createTransform,\n} from '../transform.js';\n\n/**\n * @typedef {'Point' | 'LineString' | 'LinearRing' | 'Polygon' | 'MultiPoint' | 'MultiLineString'} Type\n * The geometry type.  One of `'Point'`, `'LineString'`, `'LinearRing'`,\n * `'Polygon'`, `'MultiPoint'` or 'MultiLineString'`.\n */\n\n/**\n * @type {import(\"../transform.js\").Transform}\n */\nconst tmpTransform = createTransform();\n\n/**\n * Lightweight, read-only, {@link module:ol/Feature~Feature} and {@link module:ol/geom/Geometry~Geometry} like\n * structure, optimized for vector tile rendering and styling. Geometry access\n * through the API is limited to getting the type and extent of the geometry.\n */\nclass RenderFeature {\n  /**\n   * @param {Type} type Geometry type.\n   * @param {Array<number>} flatCoordinates Flat coordinates. These always need\n   *     to be right-handed for polygons.\n   * @param {Array<number>} ends Ends.\n   * @param {number} stride Stride.\n   * @param {Object<string, *>} properties Properties.\n   * @param {number|string|undefined} id Feature id.\n   */\n  constructor(type, flatCoordinates, ends, stride, properties, id) {\n    /**\n     * @type {import(\"../style/Style.js\").StyleFunction|undefined}\n     */\n    this.styleFunction;\n\n    /**\n     * @private\n     * @type {import(\"../extent.js\").Extent|undefined}\n     */\n    this.extent_;\n\n    /**\n     * @private\n     * @type {number|string|undefined}\n     */\n    this.id_ = id;\n\n    /**\n     * @private\n     * @type {Type}\n     */\n    this.type_ = type;\n\n    /**\n     * @private\n     * @type {Array<number>}\n     */\n    this.flatCoordinates_ = flatCoordinates;\n\n    /**\n     * @private\n     * @type {Array<number>}\n     */\n    this.flatInteriorPoints_ = null;\n\n    /**\n     * @private\n     * @type {Array<number>}\n     */\n    this.flatMidpoints_ = null;\n\n    /**\n     * @private\n     * @type {Array<number>|null}\n     */\n    this.ends_ = ends || null;\n\n    /**\n     * @private\n     * @type {Object<string, *>}\n     */\n    this.properties_ = properties;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.squaredTolerance_;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.stride_ = stride;\n\n    /**\n     * @private\n     * @type {RenderFeature}\n     */\n    this.simplifiedGeometry_;\n  }\n\n  /**\n   * Get a feature property by its key.\n   * @param {string} key Key\n   * @return {*} Value for the requested key.\n   * @api\n   */\n  get(key) {\n    return this.properties_[key];\n  }\n\n  /**\n   * Get the extent of this feature's geometry.\n   * @return {import(\"../extent.js\").Extent} Extent.\n   * @api\n   */\n  getExtent() {\n    if (!this.extent_) {\n      this.extent_ =\n        this.type_ === 'Point'\n          ? createOrUpdateFromCoordinate(this.flatCoordinates_)\n          : createOrUpdateFromFlatCoordinates(\n              this.flatCoordinates_,\n              0,\n              this.flatCoordinates_.length,\n              this.stride_,\n            );\n    }\n    return this.extent_;\n  }\n\n  /**\n   * @return {Array<number>} Flat interior points.\n   */\n  getFlatInteriorPoint() {\n    if (!this.flatInteriorPoints_) {\n      const flatCenter = getCenter(this.getExtent());\n      this.flatInteriorPoints_ = getInteriorPointOfArray(\n        this.flatCoordinates_,\n        0,\n        this.ends_,\n        this.stride_,\n        flatCenter,\n        0,\n      );\n    }\n    return this.flatInteriorPoints_;\n  }\n\n  /**\n   * @return {Array<number>} Flat interior points.\n   */\n  getFlatInteriorPoints() {\n    if (!this.flatInteriorPoints_) {\n      const ends = inflateEnds(this.flatCoordinates_, this.ends_);\n      const flatCenters = linearRingssCenter(\n        this.flatCoordinates_,\n        0,\n        ends,\n        this.stride_,\n      );\n      this.flatInteriorPoints_ = getInteriorPointsOfMultiArray(\n        this.flatCoordinates_,\n        0,\n        ends,\n        this.stride_,\n        flatCenters,\n      );\n    }\n    return this.flatInteriorPoints_;\n  }\n\n  /**\n   * @return {Array<number>} Flat midpoint.\n   */\n  getFlatMidpoint() {\n    if (!this.flatMidpoints_) {\n      this.flatMidpoints_ = interpolatePoint(\n        this.flatCoordinates_,\n        0,\n        this.flatCoordinates_.length,\n        this.stride_,\n        0.5,\n      );\n    }\n    return this.flatMidpoints_;\n  }\n\n  /**\n   * @return {Array<number>} Flat midpoints.\n   */\n  getFlatMidpoints() {\n    if (!this.flatMidpoints_) {\n      this.flatMidpoints_ = [];\n      const flatCoordinates = this.flatCoordinates_;\n      let offset = 0;\n      const ends = /** @type {Array<number>} */ (this.ends_);\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          this.stride_,\n          0.5,\n        );\n        extend(this.flatMidpoints_, midpoint);\n        offset = end;\n      }\n    }\n    return this.flatMidpoints_;\n  }\n\n  /**\n   * Get the feature identifier.  This is a stable identifier for the feature and\n   * is set when reading data from a remote source.\n   * @return {number|string|undefined} Id.\n   * @api\n   */\n  getId() {\n    return this.id_;\n  }\n\n  /**\n   * @return {Array<number>} Flat coordinates.\n   */\n  getOrientedFlatCoordinates() {\n    return this.flatCoordinates_;\n  }\n\n  /**\n   * For API compatibility with {@link module:ol/Feature~Feature}, this method is useful when\n   * determining the geometry type in style function (see {@link #getType}).\n   * @return {RenderFeature} Feature.\n   * @api\n   */\n  getGeometry() {\n    return this;\n  }\n\n  /**\n   * @param {number} squaredTolerance Squared tolerance.\n   * @return {RenderFeature} Simplified geometry.\n   */\n  getSimplifiedGeometry(squaredTolerance) {\n    return this;\n  }\n\n  /**\n   * Get a transformed and simplified version of the geometry.\n   * @param {number} squaredTolerance Squared tolerance.\n   * @param {import(\"../proj.js\").TransformFunction} [transform] Optional transform function.\n   * @return {RenderFeature} Simplified geometry.\n   */\n  simplifyTransformed(squaredTolerance, transform) {\n    return this;\n  }\n\n  /**\n   * Get the feature properties.\n   * @return {Object<string, *>} Feature properties.\n   * @api\n   */\n  getProperties() {\n    return this.properties_;\n  }\n\n  /**\n   * Get an object of all property names and values.  This has the same behavior as getProperties,\n   * but is here to conform with the {@link module:ol/Feature~Feature} interface.\n   * @return {Object<string, *>?} Object.\n   */\n  getPropertiesInternal() {\n    return this.properties_;\n  }\n\n  /**\n   * @return {number} Stride.\n   */\n  getStride() {\n    return this.stride_;\n  }\n\n  /**\n   * @return {import('../style/Style.js').StyleFunction|undefined} Style\n   */\n  getStyleFunction() {\n    return this.styleFunction;\n  }\n\n  /**\n   * Get the type of this feature's geometry.\n   * @return {Type} Geometry type.\n   * @api\n   */\n  getType() {\n    return this.type_;\n  }\n\n  /**\n   * Transform geometry coordinates from tile pixel space to projected.\n   *\n   * @param {import(\"../proj.js\").ProjectionLike} projection The data projection\n   */\n  transform(projection) {\n    projection = getProjection(projection);\n    const pixelExtent = projection.getExtent();\n    const projectedExtent = projection.getWorldExtent();\n    if (pixelExtent && projectedExtent) {\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        this.flatCoordinates_,\n        0,\n        this.flatCoordinates_.length,\n        this.stride_,\n        tmpTransform,\n        this.flatCoordinates_,\n      );\n    }\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   */\n  applyTransform(transformFn) {\n    transformFn(this.flatCoordinates_, this.flatCoordinates_, this.stride_);\n  }\n\n  /**\n   * @return {RenderFeature} A cloned render feature.\n   */\n  clone() {\n    return new RenderFeature(\n      this.type_,\n      this.flatCoordinates_.slice(),\n      this.ends_?.slice(),\n      this.stride_,\n      Object.assign({}, this.properties_),\n      this.id_,\n    );\n  }\n\n  /**\n   * @return {Array<number>|null} Ends.\n   */\n  getEnds() {\n    return this.ends_;\n  }\n\n  /**\n   * Add transform and resolution based geometry simplification to this instance.\n   * @return {RenderFeature} This render feature.\n   */\n  enableSimplifyTransformed() {\n    this.simplifyTransformed = memoizeOne((squaredTolerance, transform) => {\n      if (squaredTolerance === this.squaredTolerance_) {\n        return this.simplifiedGeometry_;\n      }\n      this.simplifiedGeometry_ = this.clone();\n      if (transform) {\n        this.simplifiedGeometry_.applyTransform(transform);\n      }\n      const simplifiedFlatCoordinates =\n        this.simplifiedGeometry_.getFlatCoordinates();\n      let simplifiedEnds;\n      switch (this.type_) {\n        case 'LineString':\n          simplifiedFlatCoordinates.length = douglasPeucker(\n            simplifiedFlatCoordinates,\n            0,\n            this.simplifiedGeometry_.flatCoordinates_.length,\n            this.simplifiedGeometry_.stride_,\n            squaredTolerance,\n            simplifiedFlatCoordinates,\n            0,\n          );\n          simplifiedEnds = [simplifiedFlatCoordinates.length];\n          break;\n        case 'MultiLineString':\n          simplifiedEnds = [];\n          simplifiedFlatCoordinates.length = douglasPeuckerArray(\n            simplifiedFlatCoordinates,\n            0,\n            this.simplifiedGeometry_.ends_,\n            this.simplifiedGeometry_.stride_,\n            squaredTolerance,\n            simplifiedFlatCoordinates,\n            0,\n            simplifiedEnds,\n          );\n          break;\n        case 'Polygon':\n          simplifiedEnds = [];\n          simplifiedFlatCoordinates.length = quantizeArray(\n            simplifiedFlatCoordinates,\n            0,\n            this.simplifiedGeometry_.ends_,\n            this.simplifiedGeometry_.stride_,\n            Math.sqrt(squaredTolerance),\n            simplifiedFlatCoordinates,\n            0,\n            simplifiedEnds,\n          );\n          break;\n        default:\n      }\n      if (simplifiedEnds) {\n        this.simplifiedGeometry_ = new RenderFeature(\n          this.type_,\n          simplifiedFlatCoordinates,\n          simplifiedEnds,\n          this.stride_,\n          this.properties_,\n          this.id_,\n        );\n      }\n      this.squaredTolerance_ = squaredTolerance;\n      return this.simplifiedGeometry_;\n    });\n    return this;\n  }\n}\n\n/**\n * @return {Array<number>} Flat coordinates.\n */\nRenderFeature.prototype.getFlatCoordinates =\n  RenderFeature.prototype.getOrientedFlatCoordinates;\n\n/**\n * Create a geometry from an `ol/render/Feature`\n * @param {RenderFeature} renderFeature\n * Render Feature\n * @return {Point|MultiPoint|LineString|MultiLineString|Polygon|MultiPolygon}\n * New geometry instance.\n * @api\n */\nexport function toGeometry(renderFeature) {\n  const geometryType = renderFeature.getType();\n  switch (geometryType) {\n    case 'Point':\n      return new Point(renderFeature.getFlatCoordinates());\n    case 'MultiPoint':\n      return new MultiPoint(renderFeature.getFlatCoordinates(), 'XY');\n    case 'LineString':\n      return new LineString(renderFeature.getFlatCoordinates(), 'XY');\n    case 'MultiLineString':\n      return new MultiLineString(\n        renderFeature.getFlatCoordinates(),\n        'XY',\n        /** @type {Array<number>} */ (renderFeature.getEnds()),\n      );\n    case 'Polygon':\n      const flatCoordinates = renderFeature.getFlatCoordinates();\n      const ends = renderFeature.getEnds();\n      const endss = inflateEnds(flatCoordinates, ends);\n      return endss.length > 1\n        ? new MultiPolygon(flatCoordinates, 'XY', endss)\n        : new Polygon(flatCoordinates, 'XY', ends);\n    default:\n      throw new Error('Invalid geometry type:' + geometryType);\n  }\n}\n\n/**\n * Create an `ol/Feature` from an `ol/render/Feature`\n * @param {RenderFeature} renderFeature RenderFeature\n * @param {string} [geometryName] Geometry name to use\n * when creating the Feature.\n * @return {Feature} Newly constructed `ol/Feature` with properties,\n * geometry, and id copied over.\n * @api\n */\nexport function toFeature(renderFeature, geometryName) {\n  const id = renderFeature.getId();\n  const geometry = toGeometry(renderFeature);\n  const properties = renderFeature.getProperties();\n  const feature = new Feature();\n  if (geometryName !== undefined) {\n    feature.setGeometryName(geometryName);\n  }\n  feature.setGeometry(geometry);\n  if (id !== undefined) {\n    feature.setId(id);\n  }\n  feature.setProperties(properties, true);\n  return feature;\n}\n\nexport default RenderFeature;\n","/**\n * @module ol/structs/RBush\n */\nimport RBush_ from 'rbush';\nimport {createOrUpdate, equals} from '../extent.js';\nimport {isEmpty} from '../obj.js';\nimport {getUid} from '../util.js';\n\n/**\n * @typedef {import(\"rbush\").BBox & {value: T}} Entry\n * @template T\n */\n\n/**\n * @classdesc\n * Wrapper around the RBush by Vladimir Agafonkin.\n * See https://github.com/mourner/rbush.\n *\n * @template {Object} T\n */\nclass RBush {\n  /**\n   * @param {number} [maxEntries] Max entries.\n   */\n  constructor(maxEntries) {\n    /**\n     * @private\n     * @type {RBush_<Entry<T>>}\n     */\n    this.rbush_ = new RBush_(maxEntries);\n\n    /**\n     * A mapping between the objects added to this rbush wrapper\n     * and the objects that are actually added to the internal rbush.\n     * @private\n     * @type {Object<string, Entry<T>>}\n     */\n    this.items_ = {};\n  }\n\n  /**\n   * Insert a value into the RBush.\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {T} value Value.\n   */\n  insert(extent, value) {\n    /** @type {Entry<T>} */\n    const item = {\n      minX: extent[0],\n      minY: extent[1],\n      maxX: extent[2],\n      maxY: extent[3],\n      value: value,\n    };\n\n    this.rbush_.insert(item);\n    this.items_[getUid(value)] = item;\n  }\n\n  /**\n   * Bulk-insert values into the RBush.\n   * @param {Array<import(\"../extent.js\").Extent>} extents Extents.\n   * @param {Array<T>} values Values.\n   */\n  load(extents, values) {\n    const items = new Array(values.length);\n    for (let i = 0, l = values.length; i < l; i++) {\n      const extent = extents[i];\n      const value = values[i];\n\n      /** @type {Entry<T>} */\n      const item = {\n        minX: extent[0],\n        minY: extent[1],\n        maxX: extent[2],\n        maxY: extent[3],\n        value: value,\n      };\n      items[i] = item;\n      this.items_[getUid(value)] = item;\n    }\n    this.rbush_.load(items);\n  }\n\n  /**\n   * Remove a value from the RBush.\n   * @param {T} value Value.\n   * @return {boolean} Removed.\n   */\n  remove(value) {\n    const uid = getUid(value);\n\n    // get the object in which the value was wrapped when adding to the\n    // internal rbush. then use that object to do the removal.\n    const item = this.items_[uid];\n    delete this.items_[uid];\n    return this.rbush_.remove(item) !== null;\n  }\n\n  /**\n   * Update the extent of a value in the RBush.\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {T} value Value.\n   */\n  update(extent, value) {\n    const item = this.items_[getUid(value)];\n    const bbox = [item.minX, item.minY, item.maxX, item.maxY];\n    if (!equals(bbox, extent)) {\n      this.remove(value);\n      this.insert(extent, value);\n    }\n  }\n\n  /**\n   * Return all values in the RBush.\n   * @return {Array<T>} All.\n   */\n  getAll() {\n    const items = this.rbush_.all();\n    return items.map(function (item) {\n      return item.value;\n    });\n  }\n\n  /**\n   * Return all values in the given extent.\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @return {Array<T>} All in extent.\n   */\n  getInExtent(extent) {\n    /** @type {import(\"rbush\").BBox} */\n    const bbox = {\n      minX: extent[0],\n      minY: extent[1],\n      maxX: extent[2],\n      maxY: extent[3],\n    };\n    const items = this.rbush_.search(bbox);\n    return items.map(function (item) {\n      return item.value;\n    });\n  }\n\n  /**\n   * Calls a callback function with each value in the tree.\n   * If the callback returns a truthy value, this value is returned without\n   * checking the rest of the tree.\n   * @param {function(T): R} callback Callback.\n   * @return {R|undefined} Callback return value.\n   * @template R\n   */\n  forEach(callback) {\n    return this.forEach_(this.getAll(), callback);\n  }\n\n  /**\n   * Calls a callback function with each value in the provided extent.\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {function(T): R} callback Callback.\n   * @return {R|undefined} Callback return value.\n   * @template R\n   */\n  forEachInExtent(extent, callback) {\n    return this.forEach_(this.getInExtent(extent), callback);\n  }\n\n  /**\n   * @param {Array<T>} values Values.\n   * @param {function(T): R} callback Callback.\n   * @return {R|undefined} Callback return value.\n   * @template R\n   * @private\n   */\n  forEach_(values, callback) {\n    let result;\n    for (let i = 0, l = values.length; i < l; i++) {\n      result = callback(values[i]);\n      if (result) {\n        return result;\n      }\n    }\n    return result;\n  }\n\n  /**\n   * @return {boolean} Is empty.\n   */\n  isEmpty() {\n    return isEmpty(this.items_);\n  }\n\n  /**\n   * Remove all values from the RBush.\n   */\n  clear() {\n    this.rbush_.clear();\n    this.items_ = {};\n  }\n\n  /**\n   * @param {import(\"../extent.js\").Extent} [extent] Extent.\n   * @return {import(\"../extent.js\").Extent} Extent.\n   */\n  getExtent(extent) {\n    const data = this.rbush_.toJSON();\n    return createOrUpdate(data.minX, data.minY, data.maxX, data.maxY, extent);\n  }\n\n  /**\n   * @param {RBush<T>} rbush R-Tree.\n   */\n  concat(rbush) {\n    this.rbush_.load(rbush.rbush_.all());\n    for (const i in rbush.items_) {\n      this.items_[i] = rbush.items_[i];\n    }\n  }\n}\n\nexport default RBush;\n","/**\n * @module ol/source/VectorEventType\n */\n\n/**\n * @enum {string}\n */\nexport default {\n  /**\n   * Triggered when a feature is added to the source.\n   * @event module:ol/source/Vector.VectorSourceEvent#addfeature\n   * @api\n   */\n  ADDFEATURE: 'addfeature',\n\n  /**\n   * Triggered when a feature is updated.\n   * @event module:ol/source/Vector.VectorSourceEvent#changefeature\n   * @api\n   */\n  CHANGEFEATURE: 'changefeature',\n\n  /**\n   * Triggered when the clear method is called on the source.\n   * @event module:ol/source/Vector.VectorSourceEvent#clear\n   * @api\n   */\n  CLEAR: 'clear',\n\n  /**\n   * Triggered when a feature is removed from the source.\n   * See {@link module:ol/source/Vector~VectorSource#clear source.clear()} for exceptions.\n   * @event module:ol/source/Vector.VectorSourceEvent#removefeature\n   * @api\n   */\n  REMOVEFEATURE: 'removefeature',\n\n  /**\n   * Triggered when features starts loading.\n   * @event module:ol/source/Vector.VectorSourceEvent#featuresloadstart\n   * @api\n   */\n  FEATURESLOADSTART: 'featuresloadstart',\n\n  /**\n   * Triggered when features finishes loading.\n   * @event module:ol/source/Vector.VectorSourceEvent#featuresloadend\n   * @api\n   */\n  FEATURESLOADEND: 'featuresloadend',\n\n  /**\n   * Triggered if feature loading results in an error.\n   * @event module:ol/source/Vector.VectorSourceEvent#featuresloaderror\n   * @api\n   */\n  FEATURESLOADERROR: 'featuresloaderror',\n};\n\n/**\n * @typedef {'addfeature'|'changefeature'|'clear'|'removefeature'|'featuresloadstart'|'featuresloadend'|'featuresloaderror'} VectorSourceEventTypes\n */\n","/**\n * @module ol/source/Vector\n */\n\nimport Collection from '../Collection.js';\nimport CollectionEventType from '../CollectionEventType.js';\nimport ObjectEventType from '../ObjectEventType.js';\nimport {extend} from '../array.js';\nimport {assert} from '../asserts.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport Event from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport {containsExtent, equals, wrapAndSliceX} from '../extent.js';\nimport {xhr} from '../featureloader.js';\nimport {TRUE, VOID} from '../functions.js';\nimport {all as allStrategy} from '../loadingstrategy.js';\nimport {isEmpty} from '../obj.js';\nimport RenderFeature from '../render/Feature.js';\nimport RBush from '../structs/RBush.js';\nimport {getUid} from '../util.js';\nimport Source from './Source.js';\nimport VectorEventType from './VectorEventType.js';\n\n/**\n * A function that takes an {@link module:ol/extent~Extent} and a resolution as arguments, and\n * returns an array of {@link module:ol/extent~Extent} with the extents to load. Usually this\n * is one of the standard {@link module:ol/loadingstrategy} strategies.\n *\n * @typedef {function(import(\"../extent.js\").Extent, number, import(\"../proj/Projection.js\").default): Array<import(\"../extent.js\").Extent>} LoadingStrategy\n * @api\n */\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/source/Vector~VectorSource} instances are instances of this\n * type.\n * @template {import(\"../Feature.js\").FeatureLike} [FeatureType=import(\"../Feature.js\").default]\n */\nexport class VectorSourceEvent extends Event {\n  /**\n   * @param {string} type Type.\n   * @param {FeatureType} [feature] Feature.\n   * @param {Array<FeatureType>} [features] Features.\n   */\n  constructor(type, feature, features) {\n    super(type);\n\n    /**\n     * The added or removed feature for the `ADDFEATURE` and `REMOVEFEATURE` events, `undefined` otherwise.\n     * @type {FeatureType|undefined}\n     * @api\n     */\n    this.feature = feature;\n\n    /**\n     * The loaded features for the `FEATURESLOADED` event, `undefined` otherwise.\n     * @type {Array<FeatureType>|undefined}\n     * @api\n     */\n    this.features = features;\n  }\n}\n\n/***\n * @template {import(\"../Feature.js\").FeatureLike} [T=import(\"../Feature.js\").default]\n * @typedef {T extends RenderFeature ? T|Array<T> : T} FeatureClassOrArrayOfRenderFeatures\n */\n\n/***\n * @template Return\n * @template {import(\"../Feature.js\").FeatureLike} [FeatureType=import(\"../Feature.js\").default]\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types, import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"./VectorEventType.js\").VectorSourceEventTypes, VectorSourceEvent<FeatureType>, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"../ObjectEventType.js\").Types|\n *     import(\"./VectorEventType.js\").VectorSourceEventTypes, Return>} VectorSourceOnSignature\n */\n\n/**\n * @template {import(\"../Feature.js\").FeatureLike} [FeatureType=import(\"../Feature.js\").default]\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {Array<FeatureType>|Collection<FeatureType>} [features]\n * Features. If provided as {@link module:ol/Collection~Collection}, the features in the source\n * and the collection will stay in sync.\n * @property {import(\"../format/Feature.js\").default<FeatureType>} [format] The feature format used by the XHR\n * feature loader when `url` is set. Required if `url` is set, otherwise ignored.\n * @property {import(\"../featureloader.js\").FeatureLoader<FeatureType>} [loader]\n * The loader function used to load features, from a remote source for example.\n * If this is not set and `url` is set, the source will create and use an XHR\n * feature loader. The `'featuresloadend'` and `'featuresloaderror'` events\n * will only fire if the `success` and `failure` callbacks are used.\n *\n * Example:\n *\n * ```js\n * import Vector from 'ol/source/Vector.js';\n * import GeoJSON from 'ol/format/GeoJSON.js';\n * import {bbox} from 'ol/loadingstrategy.js';\n *\n * const vectorSource = new Vector({\n *   loader: async (extent, resolution, projection) => {\n *      const url = 'https://ahocevar.com/geoserver/wfs?service=WFS&' +\n *          'version=1.1.0&request=GetFeature&typename=osm:water_areas&' +\n *          'outputFormat=application/json' +\n *          'bbox=' + extent.join(',') + ',' + projection.getCode();\n *      const response = await fetch(url);\n *      if (!response.ok) {\n *        throw new Error('Network response was not ok');\n *      }\n *      const json = await response.json();\n *      const features = new GeoJSON().readFeatures(json, {\n *        featureProjection: projection,\n *      });\n *      return features;\n *    },\n *    strategy: bbox,\n *  });\n * ```\n *\n * When you want to retry a failed request, use\n * ```js\n * vectorSource.removeLoadedExtent(extent);\n * vectorSource.changed();\n * ```\n *\n * @property {boolean} [overlaps=true] This source may have overlapping geometries.\n * Setting this to `false` (e.g. for sources with polygons that represent administrative\n * boundaries or TopoJSON sources) allows the renderer to optimise fill and\n * stroke operations.\n * @property {LoadingStrategy} [strategy] The loading strategy to use.\n * By default an {@link module:ol/loadingstrategy.all}\n * strategy is used, a one-off strategy which loads all features at once.\n * @property {string|import(\"../featureloader.js\").FeatureUrlFunction} [url]\n * Setting this option instructs the source to load features using an XHR loader\n * (see {@link module:ol/featureloader.xhr}). Use a `string` and an\n * {@link module:ol/loadingstrategy.all} for a one-off download of all features from\n * the given URL. Use a {@link module:ol/featureloader~FeatureUrlFunction} to generate the url with\n * other loading strategies.\n * Requires `format` to be set as well.\n * When default XHR feature loader is provided, the features will\n * be transformed from the data projection to the view projection\n * during parsing. If your remote data source does not advertise its projection\n * properly, this transformation will be incorrect. For some formats, the\n * default projection (usually EPSG:4326) can be overridden by setting the\n * dataProjection constructor option on the format.\n * Note that if a source contains non-feature data, such as a GeoJSON geometry\n * or a KML NetworkLink, these will be ignored. Use a custom loader to load these.\n * @property {boolean} [useSpatialIndex=true]\n * By default, an RTree is used as spatial index. When features are removed and\n * added frequently, and the total number of features is low, setting this to\n * `false` may improve performance.\n *\n * Note that\n * {@link module:ol/source/Vector~VectorSource#getFeaturesInExtent},\n * {@link module:ol/source/Vector~VectorSource#getClosestFeatureToCoordinate} and\n * {@link module:ol/source/Vector~VectorSource#getExtent} cannot be used when `useSpatialIndex` is\n * set to `false`, and {@link module:ol/source/Vector~VectorSource#forEachFeatureInExtent} will loop\n * through all features.\n *\n * When set to `false`, the features will be maintained in an\n * {@link module:ol/Collection~Collection}, which can be retrieved through\n * {@link module:ol/source/Vector~VectorSource#getFeaturesCollection}.\n * @property {boolean} [wrapX=true] Wrap the world horizontally. For vector editing across the\n * -180° and 180° meridians to work properly, this should be set to `false`. The\n * resulting geometry coordinates will then exceed the world bounds.\n */\n\n/**\n * @classdesc\n * Provides a source of features for vector layers. Vector features provided\n * by this source are suitable for editing. See {@link module:ol/source/VectorTile~VectorTile} for\n * vector data that is optimized for rendering.\n *\n * @fires VectorSourceEvent\n * @api\n * @template {import(\"../Feature.js\").FeatureLike} [FeatureType=import(\"../Feature.js\").default]\n */\nclass VectorSource extends Source {\n  /**\n   * @param {Options<FeatureType>} [options] Vector source options.\n   */\n  constructor(options) {\n    options = options || {};\n\n    super({\n      attributions: options.attributions,\n      interpolate: true,\n      projection: undefined,\n      state: 'ready',\n      wrapX: options.wrapX !== undefined ? options.wrapX : true,\n    });\n\n    /***\n     * @type {VectorSourceOnSignature<import(\"../events.js\").EventsKey, FeatureType>}\n     */\n    this.on;\n\n    /***\n     * @type {VectorSourceOnSignature<import(\"../events.js\").EventsKey, FeatureType>}\n     */\n    this.once;\n\n    /***\n     * @type {VectorSourceOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @private\n     * @type {import(\"../featureloader.js\").FeatureLoader<import(\"../Feature.js\").FeatureLike>}\n     */\n    this.loader_ = VOID;\n\n    /**\n     * @private\n     * @type {import(\"../format/Feature.js\").default<FeatureType>|null}\n     */\n    this.format_ = options.format || null;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.overlaps_ = options.overlaps === undefined ? true : options.overlaps;\n\n    /**\n     * @private\n     * @type {string|import(\"../featureloader.js\").FeatureUrlFunction|undefined}\n     */\n    this.url_ = options.url;\n\n    if (options.loader !== undefined) {\n      this.loader_ = options.loader;\n    } else if (this.url_ !== undefined) {\n      assert(this.format_, '`format` must be set when `url` is set');\n      // create a XHR feature loader for \"url\" and \"format\"\n      this.loader_ = xhr(this.url_, this.format_);\n    }\n\n    /**\n     * @private\n     * @type {LoadingStrategy}\n     */\n    this.strategy_ =\n      options.strategy !== undefined ? options.strategy : allStrategy;\n\n    const useSpatialIndex =\n      options.useSpatialIndex !== undefined ? options.useSpatialIndex : true;\n\n    /**\n     * @private\n     * @type {RBush<FeatureType>}\n     */\n    this.featuresRtree_ = useSpatialIndex ? new RBush() : null;\n\n    /**\n     * @private\n     * @type {RBush<{extent: import(\"../extent.js\").Extent}>}\n     */\n    this.loadedExtentsRtree_ = new RBush();\n\n    /**\n     * @private\n     * @type {!Object<string, FeatureType>}\n     */\n    this.nullGeometryFeatures_ = {};\n\n    /**\n     * A lookup of features by id (the return from feature.getId()).\n     * @private\n     * @type {!Object<string, import('../Feature.js').FeatureLike|Array<import('../Feature.js').FeatureLike>>}\n     */\n    this.idIndex_ = {};\n\n    /**\n     * A lookup of features by uid (using getUid(feature)).\n     * @private\n     * @type {!Object<string, FeatureType>}\n     */\n    this.uidIndex_ = {};\n\n    /**\n     * @private\n     * @type {Object<string, Array<import(\"../events.js\").EventsKey>>}\n     */\n    this.featureChangeKeys_ = {};\n\n    /**\n     * @private\n     * @type {Collection<FeatureType>|null}\n     */\n    this.featuresCollection_ = null;\n\n    /** @type {Collection<FeatureType>} */\n    let collection;\n    /** @type {Array<FeatureType>} */\n    let features;\n    if (Array.isArray(options.features)) {\n      features = options.features;\n    } else if (options.features) {\n      collection = options.features;\n      features = collection.getArray();\n    }\n    if (!useSpatialIndex && collection === undefined) {\n      collection = new Collection(features);\n    }\n    if (features !== undefined) {\n      this.addFeaturesInternal(features);\n    }\n    if (collection !== undefined) {\n      this.bindFeaturesCollection_(collection);\n    }\n  }\n\n  /**\n   * Add a single feature to the source.  If you want to add a batch of features\n   * at once, call {@link module:ol/source/Vector~VectorSource#addFeatures #addFeatures()}\n   * instead. A feature will not be added to the source if feature with\n   * the same id is already there. The reason for this behavior is to avoid\n   * feature duplication when using bbox or tile loading strategies.\n   * Note: this also applies if a {@link module:ol/Collection~Collection} is used for features,\n   * meaning that if a feature with a duplicate id is added in the collection, it will\n   * be removed from it right away.\n   * @param {FeatureType} feature Feature to add.\n   * @api\n   */\n  addFeature(feature) {\n    this.addFeatureInternal(feature);\n    this.changed();\n  }\n\n  /**\n   * Add a feature without firing a `change` event.\n   * @param {FeatureType} feature Feature.\n   * @protected\n   */\n  addFeatureInternal(feature) {\n    const featureKey = getUid(feature);\n\n    if (!this.addToIndex_(featureKey, feature)) {\n      if (this.featuresCollection_) {\n        this.featuresCollection_.remove(feature);\n      }\n      return;\n    }\n\n    this.setupChangeEvents_(featureKey, feature);\n\n    const geometry = feature.getGeometry();\n    if (geometry) {\n      const extent = geometry.getExtent();\n      if (this.featuresRtree_) {\n        this.featuresRtree_.insert(extent, feature);\n      }\n    } else {\n      this.nullGeometryFeatures_[featureKey] = feature;\n    }\n\n    this.dispatchEvent(\n      new VectorSourceEvent(VectorEventType.ADDFEATURE, feature),\n    );\n  }\n\n  /**\n   * @param {string} featureKey Unique identifier for the feature.\n   * @param {FeatureType} feature The feature.\n   * @private\n   */\n  setupChangeEvents_(featureKey, feature) {\n    if (feature instanceof RenderFeature) {\n      return;\n    }\n    this.featureChangeKeys_[featureKey] = [\n      listen(feature, EventType.CHANGE, this.handleFeatureChange_, this),\n      listen(\n        feature,\n        ObjectEventType.PROPERTYCHANGE,\n        this.handleFeatureChange_,\n        this,\n      ),\n    ];\n  }\n\n  /**\n   * @param {string} featureKey Unique identifier for the feature.\n   * @param {FeatureType} feature The feature.\n   * @return {boolean} The feature is \"valid\", in the sense that it is also a\n   *     candidate for insertion into the Rtree.\n   * @private\n   */\n  addToIndex_(featureKey, feature) {\n    let valid = true;\n    if (feature.getId() !== undefined) {\n      const id = String(feature.getId());\n      if (!(id in this.idIndex_)) {\n        this.idIndex_[id] = feature;\n      } else if (feature instanceof RenderFeature) {\n        const indexedFeature = this.idIndex_[id];\n        if (!(indexedFeature instanceof RenderFeature)) {\n          valid = false;\n        } else if (!Array.isArray(indexedFeature)) {\n          this.idIndex_[id] = [indexedFeature, feature];\n        } else {\n          indexedFeature.push(feature);\n        }\n      } else {\n        valid = false;\n      }\n    }\n    if (valid) {\n      assert(\n        !(featureKey in this.uidIndex_),\n        'The passed `feature` was already added to the source',\n      );\n      this.uidIndex_[featureKey] = feature;\n    }\n    return valid;\n  }\n\n  /**\n   * Add a batch of features to the source.\n   * @param {Array<FeatureType>} features Features to add.\n   * @api\n   */\n  addFeatures(features) {\n    this.addFeaturesInternal(features);\n    this.changed();\n  }\n\n  /**\n   * Add features without firing a `change` event.\n   * @param {Array<FeatureType>} features Features.\n   * @protected\n   */\n  addFeaturesInternal(features) {\n    const extents = [];\n    /** @type {Array<FeatureType>} */\n    const newFeatures = [];\n    /** @type {Array<FeatureType>} */\n    const geometryFeatures = [];\n\n    for (let i = 0, length = features.length; i < length; i++) {\n      const feature = features[i];\n      const featureKey = getUid(feature);\n      if (this.addToIndex_(featureKey, feature)) {\n        newFeatures.push(feature);\n      }\n    }\n\n    for (let i = 0, length = newFeatures.length; i < length; i++) {\n      const feature = newFeatures[i];\n      const featureKey = getUid(feature);\n      this.setupChangeEvents_(featureKey, feature);\n\n      const geometry = feature.getGeometry();\n      if (geometry) {\n        const extent = geometry.getExtent();\n        extents.push(extent);\n        geometryFeatures.push(feature);\n      } else {\n        this.nullGeometryFeatures_[featureKey] = feature;\n      }\n    }\n    if (this.featuresRtree_) {\n      this.featuresRtree_.load(extents, geometryFeatures);\n    }\n\n    if (this.hasListener(VectorEventType.ADDFEATURE)) {\n      for (let i = 0, length = newFeatures.length; i < length; i++) {\n        this.dispatchEvent(\n          new VectorSourceEvent(VectorEventType.ADDFEATURE, newFeatures[i]),\n        );\n      }\n    }\n  }\n\n  /**\n   * @param {!Collection<FeatureType>} collection Collection.\n   * @private\n   */\n  bindFeaturesCollection_(collection) {\n    let modifyingCollection = false;\n    this.addEventListener(\n      VectorEventType.ADDFEATURE,\n      /**\n       * @param {VectorSourceEvent<FeatureType>} evt The vector source event\n       */\n      function (evt) {\n        if (!modifyingCollection) {\n          modifyingCollection = true;\n          collection.push(evt.feature);\n          modifyingCollection = false;\n        }\n      },\n    );\n    this.addEventListener(\n      VectorEventType.REMOVEFEATURE,\n      /**\n       * @param {VectorSourceEvent<FeatureType>} evt The vector source event\n       */\n      function (evt) {\n        if (!modifyingCollection) {\n          modifyingCollection = true;\n          collection.remove(evt.feature);\n          modifyingCollection = false;\n        }\n      },\n    );\n    collection.addEventListener(\n      CollectionEventType.ADD,\n      /**\n       * @param {import(\"../Collection.js\").CollectionEvent<FeatureType>} evt The collection event\n       */\n      (evt) => {\n        if (!modifyingCollection) {\n          modifyingCollection = true;\n          this.addFeature(evt.element);\n          modifyingCollection = false;\n        }\n      },\n    );\n    collection.addEventListener(\n      CollectionEventType.REMOVE,\n      /**\n       * @param {import(\"../Collection.js\").CollectionEvent<FeatureType>} evt The collection event\n       */\n      (evt) => {\n        if (!modifyingCollection) {\n          modifyingCollection = true;\n          this.removeFeature(evt.element);\n          modifyingCollection = false;\n        }\n      },\n    );\n    this.featuresCollection_ = collection;\n  }\n\n  /**\n   * Remove all features from the source.\n   * @param {boolean} [fast] Skip dispatching of {@link module:ol/source/Vector.VectorSourceEvent#event:removefeature} events.\n   * @api\n   */\n  clear(fast) {\n    if (fast) {\n      for (const featureId in this.featureChangeKeys_) {\n        const keys = this.featureChangeKeys_[featureId];\n        keys.forEach(unlistenByKey);\n      }\n      if (!this.featuresCollection_) {\n        this.featureChangeKeys_ = {};\n        this.idIndex_ = {};\n        this.uidIndex_ = {};\n      }\n    } else {\n      if (this.featuresRtree_) {\n        this.featuresRtree_.forEach((feature) => {\n          this.removeFeatureInternal(feature);\n        });\n        for (const id in this.nullGeometryFeatures_) {\n          this.removeFeatureInternal(this.nullGeometryFeatures_[id]);\n        }\n      }\n    }\n    if (this.featuresCollection_) {\n      this.featuresCollection_.clear();\n    }\n\n    if (this.featuresRtree_) {\n      this.featuresRtree_.clear();\n    }\n    this.nullGeometryFeatures_ = {};\n\n    const clearEvent = new VectorSourceEvent(VectorEventType.CLEAR);\n    this.dispatchEvent(clearEvent);\n    this.changed();\n  }\n\n  /**\n   * Iterate through all features on the source, calling the provided callback\n   * with each one.  If the callback returns any \"truthy\" value, iteration will\n   * stop and the function will return the same value.\n   * Note: this function only iterate through the feature that have a defined geometry.\n   *\n   * @param {function(FeatureType): T} callback Called with each feature\n   *     on the source.  Return a truthy value to stop iteration.\n   * @return {T|undefined} The return value from the last call to the callback.\n   * @template T\n   * @api\n   */\n  forEachFeature(callback) {\n    if (this.featuresRtree_) {\n      return this.featuresRtree_.forEach(callback);\n    }\n    if (this.featuresCollection_) {\n      this.featuresCollection_.forEach(callback);\n    }\n  }\n\n  /**\n   * Iterate through all features whose geometries contain the provided\n   * coordinate, calling the callback with each feature.  If the callback returns\n   * a \"truthy\" value, iteration will stop and the function will return the same\n   * value.\n   *\n   * For {@link module:ol/render/Feature~RenderFeature} features, the callback will be\n   * called for all features.\n   *\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @param {function(FeatureType): T} callback Called with each feature\n   *     whose goemetry contains the provided coordinate.\n   * @return {T|undefined} The return value from the last call to the callback.\n   * @template T\n   */\n  forEachFeatureAtCoordinateDirect(coordinate, callback) {\n    const extent = [coordinate[0], coordinate[1], coordinate[0], coordinate[1]];\n    return this.forEachFeatureInExtent(extent, function (feature) {\n      const geometry = feature.getGeometry();\n      if (\n        geometry instanceof RenderFeature ||\n        geometry.intersectsCoordinate(coordinate)\n      ) {\n        return callback(feature);\n      }\n      return undefined;\n    });\n  }\n\n  /**\n   * Iterate through all features whose bounding box intersects the provided\n   * extent (note that the feature's geometry may not intersect the extent),\n   * calling the callback with each feature.  If the callback returns a \"truthy\"\n   * value, iteration will stop and the function will return the same value.\n   *\n   * If you are interested in features whose geometry intersects an extent, call\n   * the {@link module:ol/source/Vector~VectorSource#forEachFeatureIntersectingExtent #forEachFeatureIntersectingExtent()} method instead.\n   *\n   * When `useSpatialIndex` is set to false, this method will loop through all\n   * features, equivalent to {@link module:ol/source/Vector~VectorSource#forEachFeature #forEachFeature()}.\n   *\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {function(FeatureType): T} callback Called with each feature\n   *     whose bounding box intersects the provided extent.\n   * @return {T|undefined} The return value from the last call to the callback.\n   * @template T\n   * @api\n   */\n  forEachFeatureInExtent(extent, callback) {\n    if (this.featuresRtree_) {\n      return this.featuresRtree_.forEachInExtent(extent, callback);\n    }\n    if (this.featuresCollection_) {\n      this.featuresCollection_.forEach(callback);\n    }\n  }\n\n  /**\n   * Iterate through all features whose geometry intersects the provided extent,\n   * calling the callback with each feature.  If the callback returns a \"truthy\"\n   * value, iteration will stop and the function will return the same value.\n   *\n   * If you only want to test for bounding box intersection, call the\n   * {@link module:ol/source/Vector~VectorSource#forEachFeatureInExtent #forEachFeatureInExtent()} method instead.\n   *\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {function(FeatureType): T} callback Called with each feature\n   *     whose geometry intersects the provided extent.\n   * @return {T|undefined} The return value from the last call to the callback.\n   * @template T\n   * @api\n   */\n  forEachFeatureIntersectingExtent(extent, callback) {\n    return this.forEachFeatureInExtent(\n      extent,\n      /**\n       * @param {FeatureType} feature Feature.\n       * @return {T|undefined} The return value from the last call to the callback.\n       */\n      function (feature) {\n        const geometry = feature.getGeometry();\n        if (\n          geometry instanceof RenderFeature ||\n          geometry.intersectsExtent(extent)\n        ) {\n          const result = callback(feature);\n          if (result) {\n            return result;\n          }\n        }\n      },\n    );\n  }\n\n  /**\n   * Get the features collection associated with this source. Will be `null`\n   * unless the source was configured with `useSpatialIndex` set to `false`, or\n   * with a {@link module:ol/Collection~Collection} as `features`.\n   * @return {Collection<FeatureType>|null} The collection of features.\n   * @api\n   */\n  getFeaturesCollection() {\n    return this.featuresCollection_;\n  }\n\n  /**\n   * Get a snapshot of the features currently on the source in random order. The returned array\n   * is a copy, the features are references to the features in the source.\n   * @return {Array<FeatureType>} Features.\n   * @api\n   */\n  getFeatures() {\n    let features;\n    if (this.featuresCollection_) {\n      features = this.featuresCollection_.getArray().slice(0);\n    } else if (this.featuresRtree_) {\n      features = this.featuresRtree_.getAll();\n      if (!isEmpty(this.nullGeometryFeatures_)) {\n        extend(features, Object.values(this.nullGeometryFeatures_));\n      }\n    }\n    return features;\n  }\n\n  /**\n   * Get all features whose geometry intersects the provided coordinate.\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @return {Array<FeatureType>} Features.\n   * @api\n   */\n  getFeaturesAtCoordinate(coordinate) {\n    /** @type {Array<FeatureType>} */\n    const features = [];\n    this.forEachFeatureAtCoordinateDirect(coordinate, function (feature) {\n      features.push(feature);\n    });\n    return features;\n  }\n\n  /**\n   * Get all features whose bounding box intersects the provided extent.  Note that this returns an array of\n   * all features intersecting the given extent in random order (so it may include\n   * features whose geometries do not intersect the extent).\n   *\n   * When `useSpatialIndex` is set to false, this method will return all\n   * features.\n   *\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {import(\"../proj/Projection.js\").default} [projection] Include features\n   * where `extent` exceeds the x-axis bounds of `projection` and wraps around the world.\n   * @return {Array<FeatureType>} Features.\n   * @api\n   */\n  getFeaturesInExtent(extent, projection) {\n    if (this.featuresRtree_) {\n      const multiWorld = projection && projection.canWrapX() && this.getWrapX();\n\n      if (!multiWorld) {\n        return this.featuresRtree_.getInExtent(extent);\n      }\n\n      const extents = wrapAndSliceX(extent, projection);\n\n      return [].concat(\n        ...extents.map((anExtent) => this.featuresRtree_.getInExtent(anExtent)),\n      );\n    }\n    if (this.featuresCollection_) {\n      return this.featuresCollection_.getArray().slice(0);\n    }\n    return [];\n  }\n\n  /**\n   * Get the closest feature to the provided coordinate.\n   *\n   * This method is not available when the source is configured with\n   * `useSpatialIndex` set to `false` and the features in this source are of type\n   * {@link module:ol/Feature~Feature}.\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @param {function(FeatureType):boolean} [filter] Feature filter function.\n   *     The filter function will receive one argument, the {@link module:ol/Feature~Feature feature}\n   *     and it should return a boolean value. By default, no filtering is made.\n   * @return {FeatureType|null} Closest feature (or `null` if none found).\n   * @api\n   */\n  getClosestFeatureToCoordinate(coordinate, filter) {\n    // Find the closest feature using branch and bound.  We start searching an\n    // infinite extent, and find the distance from the first feature found.  This\n    // becomes the closest feature.  We then compute a smaller extent which any\n    // closer feature must intersect.  We continue searching with this smaller\n    // extent, trying to find a closer feature.  Every time we find a closer\n    // feature, we update the extent being searched so that any even closer\n    // feature must intersect it.  We continue until we run out of features.\n    const x = coordinate[0];\n    const y = coordinate[1];\n    let closestFeature = null;\n    const closestPoint = [NaN, NaN];\n    let minSquaredDistance = Infinity;\n    const extent = [-Infinity, -Infinity, Infinity, Infinity];\n    filter = filter ? filter : TRUE;\n    this.featuresRtree_.forEachInExtent(\n      extent,\n      /**\n       * @param {FeatureType} feature Feature.\n       */\n      function (feature) {\n        if (filter(feature)) {\n          const geometry = feature.getGeometry();\n          const previousMinSquaredDistance = minSquaredDistance;\n          minSquaredDistance =\n            geometry instanceof RenderFeature\n              ? 0\n              : geometry.closestPointXY(x, y, closestPoint, minSquaredDistance);\n          if (minSquaredDistance < previousMinSquaredDistance) {\n            closestFeature = feature;\n            // This is sneaky.  Reduce the extent that it is currently being\n            // searched while the R-Tree traversal using this same extent object\n            // is still in progress.  This is safe because the new extent is\n            // strictly contained by the old extent.\n            const minDistance = Math.sqrt(minSquaredDistance);\n            extent[0] = x - minDistance;\n            extent[1] = y - minDistance;\n            extent[2] = x + minDistance;\n            extent[3] = y + minDistance;\n          }\n        }\n      },\n    );\n    return closestFeature;\n  }\n\n  /**\n   * Get the extent of the features currently in the source.\n   *\n   * This will return `null` when the source is configured with\n   * `useSpatialIndex` set to `false`.\n   * @param {import(\"../extent.js\").Extent} [extent] Destination extent. If provided, no new extent\n   *     will be created. Instead, that extent's coordinates will be overwritten.\n   * @return {import(\"../extent.js\").Extent | null} Extent.\n   * @api\n   */\n  getExtent(extent) {\n    return this.featuresRtree_?.getExtent(extent) ?? null;\n  }\n\n  /**\n   * Get a feature by its identifier (the value returned by feature.getId()). When `RenderFeature`s\n   * are used, `getFeatureById()` can return an array of `RenderFeature`s. This allows for handling\n   * of `GeometryCollection` geometries, where format readers create one `RenderFeature` per\n   * `GeometryCollection` member.\n   * Note that the index treats string and numeric identifiers as the same.  So\n   * `source.getFeatureById(2)` will return a feature with id `'2'` or `2`.\n   *\n   * @param {string|number} id Feature identifier.\n   * @return {FeatureClassOrArrayOfRenderFeatures<FeatureType>|null} The feature (or `null` if not found).\n   * @api\n   */\n  getFeatureById(id) {\n    const feature = this.idIndex_[id.toString()];\n    return feature !== undefined\n      ? /** @type {FeatureClassOrArrayOfRenderFeatures<FeatureType>} */ (\n          feature\n        )\n      : null;\n  }\n\n  /**\n   * Get a feature by its internal unique identifier (using `getUid`).\n   *\n   * @param {string} uid Feature identifier.\n   * @return {FeatureType|null} The feature (or `null` if not found).\n   */\n  getFeatureByUid(uid) {\n    const feature = this.uidIndex_[uid];\n    return feature !== undefined ? feature : null;\n  }\n\n  /**\n   * Get the format associated with this source.\n   *\n   * @return {import(\"../format/Feature.js\").default<FeatureType>|null}} The feature format.\n   * @api\n   */\n  getFormat() {\n    return this.format_;\n  }\n\n  /**\n   * @return {boolean} The source can have overlapping geometries.\n   */\n  getOverlaps() {\n    return this.overlaps_;\n  }\n\n  /**\n   * Get the url associated with this source.\n   *\n   * @return {string|import(\"../featureloader.js\").FeatureUrlFunction|undefined} The url.\n   * @api\n   */\n  getUrl() {\n    return this.url_;\n  }\n\n  /**\n   * @param {Event} event Event.\n   * @private\n   */\n  handleFeatureChange_(event) {\n    const feature = /** @type {FeatureType} */ (event.target);\n    const featureKey = getUid(feature);\n    const geometry = feature.getGeometry();\n    if (!geometry) {\n      if (!(featureKey in this.nullGeometryFeatures_)) {\n        if (this.featuresRtree_) {\n          this.featuresRtree_.remove(feature);\n        }\n        this.nullGeometryFeatures_[featureKey] = feature;\n      }\n    } else {\n      const extent = geometry.getExtent();\n      if (featureKey in this.nullGeometryFeatures_) {\n        delete this.nullGeometryFeatures_[featureKey];\n        if (this.featuresRtree_) {\n          this.featuresRtree_.insert(extent, feature);\n        }\n      } else {\n        if (this.featuresRtree_) {\n          this.featuresRtree_.update(extent, feature);\n        }\n      }\n    }\n    const id = feature.getId();\n    if (id !== undefined) {\n      const sid = id.toString();\n      if (this.idIndex_[sid] !== feature) {\n        this.removeFromIdIndex_(feature);\n        this.idIndex_[sid] = feature;\n      }\n    } else {\n      this.removeFromIdIndex_(feature);\n      this.uidIndex_[featureKey] = feature;\n    }\n    this.changed();\n    this.dispatchEvent(\n      new VectorSourceEvent(VectorEventType.CHANGEFEATURE, feature),\n    );\n  }\n\n  /**\n   * Returns true if the feature is contained within the source.\n   * @param {FeatureType} feature Feature.\n   * @return {boolean} Has feature.\n   * @api\n   */\n  hasFeature(feature) {\n    const id = feature.getId();\n    if (id !== undefined) {\n      return id in this.idIndex_;\n    }\n    return getUid(feature) in this.uidIndex_;\n  }\n\n  /**\n   * @return {boolean} Is empty.\n   */\n  isEmpty() {\n    if (this.featuresRtree_) {\n      return (\n        this.featuresRtree_.isEmpty() && isEmpty(this.nullGeometryFeatures_)\n      );\n    }\n    if (this.featuresCollection_) {\n      return this.featuresCollection_.getLength() === 0;\n    }\n    return true;\n  }\n\n  /**\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} resolution Resolution.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   */\n  loadFeatures(extent, resolution, projection) {\n    const loadedExtentsRtree = this.loadedExtentsRtree_;\n    const extentsToLoad = this.strategy_(extent, resolution, projection);\n    for (let i = 0, ii = extentsToLoad.length; i < ii; ++i) {\n      const extentToLoad = extentsToLoad[i];\n      const alreadyLoaded = loadedExtentsRtree.forEachInExtent(\n        extentToLoad,\n        /**\n         * @param {{extent: import(\"../extent.js\").Extent}} object Object.\n         * @return {boolean} Contains.\n         */\n        function (object) {\n          return containsExtent(object.extent, extentToLoad);\n        },\n      );\n      if (!alreadyLoaded) {\n        this.loading = Number(this.loading) + 1;\n        this.dispatchEvent(\n          new VectorSourceEvent(VectorEventType.FEATURESLOADSTART),\n        );\n\n        /**\n         * @param {Array<FeatureType>} features Loaded features\n         */\n        const success = (features) => {\n          this.loading = Number(this.loading) - 1;\n          this.dispatchEvent(\n            new VectorSourceEvent(\n              VectorEventType.FEATURESLOADEND,\n              undefined,\n              features,\n            ),\n          );\n        };\n\n        const failure = () => {\n          this.changed();\n          this.loading = Number(this.loading) - 1;\n          this.dispatchEvent(\n            new VectorSourceEvent(VectorEventType.FEATURESLOADERROR),\n          );\n        };\n\n        //TODO Remove this when the deprecatedsuccess and failure arguments are removed\n        let disableCallbacks = false;\n\n        const loaded = this.loader_.call(\n          this,\n          extentToLoad,\n          resolution,\n          projection,\n          (features) => disableCallbacks || success(features),\n          () => disableCallbacks || failure(),\n        );\n        if (loaded instanceof Promise) {\n          //TODO Remove this when the deprecatedsuccess and failure arguments are removed\n          disableCallbacks = true;\n          loaded\n            .then((features) => {\n              this.addFeatures(features);\n              success(features);\n            })\n            .catch(failure);\n        } else if (this.loader_.length < 4) {\n          this.loading = false;\n        }\n        loadedExtentsRtree.insert(extentToLoad, {extent: extentToLoad.slice()});\n      }\n    }\n  }\n\n  /**\n   * @override\n   */\n  refresh() {\n    this.clear(true);\n    this.loadedExtentsRtree_.clear();\n    super.refresh();\n  }\n\n  /**\n   * Remove an extent from the list of loaded extents.\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @api\n   */\n  removeLoadedExtent(extent) {\n    const loadedExtentsRtree = this.loadedExtentsRtree_;\n    const obj = loadedExtentsRtree.forEachInExtent(extent, function (object) {\n      if (equals(object.extent, extent)) {\n        return object;\n      }\n    });\n    if (obj) {\n      loadedExtentsRtree.remove(obj);\n    }\n  }\n\n  /**\n   * Batch remove features from the source.  If you want to remove all features\n   * at once, use the {@link module:ol/source/Vector~VectorSource#clear #clear()} method\n   * instead.\n   * @param {Array<FeatureType>} features Features to remove.\n   * @api\n   */\n  removeFeatures(features) {\n    let removed = false;\n    for (let i = 0, ii = features.length; i < ii; ++i) {\n      removed = this.removeFeatureInternal(features[i]) || removed;\n    }\n    if (removed) {\n      this.changed();\n    }\n  }\n\n  /**\n   * Remove a single feature from the source. If you want to batch remove\n   * features, use the {@link module:ol/source/Vector~VectorSource#removeFeatures #removeFeatures()} method\n   * instead.\n   * @param {FeatureType} feature Feature to remove.\n   * @api\n   */\n  removeFeature(feature) {\n    if (!feature) {\n      return;\n    }\n    const removed = this.removeFeatureInternal(feature);\n    if (removed) {\n      this.changed();\n    }\n  }\n\n  /**\n   * Remove feature without firing a `change` event.\n   * @param {FeatureType} feature Feature.\n   * @return {boolean} True if the feature was removed, false if it was not found.\n   * @protected\n   */\n  removeFeatureInternal(feature) {\n    const featureKey = getUid(feature);\n    if (!(featureKey in this.uidIndex_)) {\n      return false;\n    }\n\n    if (featureKey in this.nullGeometryFeatures_) {\n      delete this.nullGeometryFeatures_[featureKey];\n    } else {\n      if (this.featuresRtree_) {\n        this.featuresRtree_.remove(feature);\n      }\n    }\n\n    const featureChangeKeys = this.featureChangeKeys_[featureKey];\n    featureChangeKeys?.forEach(unlistenByKey);\n    delete this.featureChangeKeys_[featureKey];\n\n    const id = feature.getId();\n    if (id !== undefined) {\n      const idString = id.toString();\n      const indexedFeature = this.idIndex_[idString];\n      if (indexedFeature === feature) {\n        delete this.idIndex_[idString];\n      } else if (Array.isArray(indexedFeature)) {\n        indexedFeature.splice(indexedFeature.indexOf(feature), 1);\n        if (indexedFeature.length === 1) {\n          this.idIndex_[idString] = indexedFeature[0];\n        }\n      }\n    }\n    delete this.uidIndex_[featureKey];\n    if (this.hasListener(VectorEventType.REMOVEFEATURE)) {\n      this.dispatchEvent(\n        new VectorSourceEvent(VectorEventType.REMOVEFEATURE, feature),\n      );\n    }\n    return true;\n  }\n\n  /**\n   * Remove a feature from the id index.  Called internally when the feature id\n   * may have changed.\n   * @param {FeatureType} feature The feature.\n   * @private\n   */\n  removeFromIdIndex_(feature) {\n    for (const id in this.idIndex_) {\n      if (this.idIndex_[id] === feature) {\n        delete this.idIndex_[id];\n        break;\n      }\n    }\n  }\n\n  /**\n   * Set the new loader of the source. The next render cycle will use the\n   * new loader.\n   * @param {import(\"../featureloader.js\").FeatureLoader} loader The loader to set.\n   * @api\n   */\n  setLoader(loader) {\n    this.loader_ = loader;\n  }\n\n  /**\n   * Points the source to a new url. The next render cycle will use the new url.\n   * @param {string|import(\"../featureloader.js\").FeatureUrlFunction} url Url.\n   * @api\n   */\n  setUrl(url) {\n    assert(this.format_, '`format` must be set when `url` is set');\n    this.url_ = url;\n    this.setLoader(xhr(url, this.format_));\n  }\n\n  /**\n   * @param {boolean} overlaps The source can have overlapping geometries.\n   */\n  setOverlaps(overlaps) {\n    this.overlaps_ = overlaps;\n    this.changed();\n  }\n}\n\nexport default VectorSource;\n","/**\n * @module ol/vec/mat4\n */\n\n/** @typedef {Array<number>} Mat4 */\n\n/**\n * @return {Mat4} \"4x4 matrix representing a 3D identity transform.\"\n */\nexport function create() {\n  return [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1];\n}\n\n/**\n * @param {Mat4} mat4 Flattened 4x4 matrix receiving the result.\n * @param {import(\"../transform.js\").Transform} transform Transformation matrix.\n * @return {Mat4} \"2D transformation matrix as flattened 4x4 matrix.\"\n */\nexport function fromTransform(mat4, transform) {\n  mat4[0] = transform[0];\n  mat4[1] = transform[1];\n  mat4[4] = transform[2];\n  mat4[5] = transform[3];\n  mat4[12] = transform[4];\n  mat4[13] = transform[5];\n  return mat4;\n}\n\n/**\n * Generates a orthogonal projection matrix with the given bounds\n *\n * @param {number} left Left bound of the frustum\n * @param {number} right Right bound of the frustum\n * @param {number} bottom Bottom bound of the frustum\n * @param {number} top Top bound of the frustum\n * @param {number} near Near bound of the frustum\n * @param {number} far Far bound of the frustum\n * @param {Mat4} [out] mat4 frustum matrix will be written into\n * @return {Mat4} out\n */\nexport function orthographic(left, right, bottom, top, near, far, out) {\n  out = out ?? create();\n  const lr = 1 / (left - right),\n    bt = 1 / (bottom - top),\n    nf = 1 / (near - far);\n  out[0] = -2 * lr;\n  out[1] = 0;\n  out[2] = 0;\n  out[3] = 0;\n  out[4] = 0;\n  out[5] = -2 * bt;\n  out[6] = 0;\n  out[7] = 0;\n  out[8] = 0;\n  out[9] = 0;\n  out[10] = 2 * nf;\n  out[11] = 0;\n  out[12] = (left + right) * lr;\n  out[13] = (top + bottom) * bt;\n  out[14] = (far + near) * nf;\n  out[15] = 1;\n  return out;\n}\n\n/**\n * Scales the mat4 by the dimensions in the given vec3\n *\n * @param {Mat4} m The matrix to scale.\n * @param {number} x How much to scale in the x direction.\n * @param {number} y How much to scale in the y direction.\n * @param {number} z How much to scale in the z direction.\n * @param {Mat4} [out] The matrix to write to.\n * @return {Mat4} out\n */\nexport function scale(m, x, y, z, out) {\n  out = out ?? create();\n  out[0] = m[0] * x;\n  out[1] = m[1] * x;\n  out[2] = m[2] * x;\n  out[3] = m[3] * x;\n  out[4] = m[4] * y;\n  out[5] = m[5] * y;\n  out[6] = m[6] * y;\n  out[7] = m[7] * y;\n  out[8] = m[8] * z;\n  out[9] = m[9] * z;\n  out[10] = m[10] * z;\n  out[11] = m[11] * z;\n  out[12] = m[12];\n  out[13] = m[13];\n  out[14] = m[14];\n  out[15] = m[15];\n  return out;\n}\n\n/**\n * Translate a matrix.\n *\n * @param {Mat4} m the matrix to translate\n * @param {number} x How much to translate in the x direction.\n * @param {number} y How much to translate in the y direction.\n * @param {number} z How much to translate in the z direction.\n * @param {Mat4} [out] the receiving matrix\n * @return {Mat4} out\n */\nexport function translate(m, x, y, z, out) {\n  out = out ?? create();\n  let a00, a01, a02, a03, a10, a11, a12, a13, a20, a21, a22, a23;\n\n  if (m === out) {\n    out[12] = m[0] * x + m[4] * y + m[8] * z + m[12];\n    out[13] = m[1] * x + m[5] * y + m[9] * z + m[13];\n    out[14] = m[2] * x + m[6] * y + m[10] * z + m[14];\n    out[15] = m[3] * x + m[7] * y + m[11] * z + m[15];\n  } else {\n    a00 = m[0];\n    a01 = m[1];\n    a02 = m[2];\n    a03 = m[3];\n    a10 = m[4];\n    a11 = m[5];\n    a12 = m[6];\n    a13 = m[7];\n    a20 = m[8];\n    a21 = m[9];\n    a22 = m[10];\n    a23 = m[11];\n\n    out[0] = a00;\n    out[1] = a01;\n    out[2] = a02;\n    out[3] = a03;\n    out[4] = a10;\n    out[5] = a11;\n    out[6] = a12;\n    out[7] = a13;\n    out[8] = a20;\n    out[9] = a21;\n    out[10] = a22;\n    out[11] = a23;\n\n    out[12] = a00 * x + a10 * y + a20 * z + m[12];\n    out[13] = a01 * x + a11 * y + a21 * z + m[13];\n    out[14] = a02 * x + a12 * y + a22 * z + m[14];\n    out[15] = a03 * x + a13 * y + a23 * z + m[15];\n  }\n\n  return out;\n}\n\n/**\n * @param {number} x x translation.\n * @param {number} y y translation.\n * @param {number} z z translation.\n * @param {Mat4} [out] optional matrix to store result\n * @return {Mat4} out\n */\nexport function translation(x, y, z, out) {\n  out = out ?? create();\n\n  out[0] = 1;\n  out[1] = 0;\n  out[2] = 0;\n  out[3] = 0;\n  out[4] = 0;\n  out[5] = 1;\n  out[6] = 0;\n  out[7] = 0;\n  out[8] = 0;\n  out[9] = 0;\n  out[10] = 1;\n  out[11] = 0;\n  out[12] = x;\n  out[13] = y;\n  out[14] = z;\n  out[15] = 1;\n\n  return out;\n}\n","import * as mat4 from '../vec/mat4.js';\n\n/**\n * @module ol/webgl/Canvas\n */\n\nconst VERTEX_SHADER = `\n  attribute vec4 a_position;\n  attribute vec4 a_texcoord;\n\n  uniform mat4 u_matrix;\n  uniform mat4 u_textureMatrix;\n\n  varying vec2 v_texcoord;\n\n  void main() {\n    gl_Position = u_matrix * a_position;\n    vec2 texcoord = (u_textureMatrix * a_texcoord).xy;\n    v_texcoord = texcoord;\n  }\n`;\n\nconst FRAGMENT_SHADER = `\n  precision mediump float;\n\n  varying vec2 v_texcoord;\n\n  uniform sampler2D u_texture;\n\n  void main() {\n    if (\n      v_texcoord.x < 0.0 ||\n      v_texcoord.y < 0.0 ||\n      v_texcoord.x > 1.0 ||\n      v_texcoord.y > 1.0\n    ) {\n      discard;\n    }\n    gl_FragColor = texture2D(u_texture, v_texcoord);\n  }\n`;\n\n/** @typedef {import(\"../transform.js\").Transform} Matrix */\n\n/**\n * Canvas-like operations implemented in webgl.\n */\nexport class Canvas {\n  /**\n   * @param {WebGLRenderingContext} gl Context to render in.\n   */\n  constructor(gl) {\n    /**\n     * @private\n     * @type {WebGLRenderingContext}\n     */\n    this.gl_ = gl;\n\n    /**\n     * @private\n     * @type {WebGLProgram}\n     */\n    this.program_ = createProgram(gl, FRAGMENT_SHADER, VERTEX_SHADER);\n\n    this.positionLocation = gl.getAttribLocation(this.program_, 'a_position');\n    this.texcoordLocation = gl.getAttribLocation(this.program_, 'a_texcoord');\n\n    this.matrixLocation = gl.getUniformLocation(this.program_, 'u_matrix');\n    this.textureMatrixLocation = gl.getUniformLocation(\n      this.program_,\n      'u_textureMatrix',\n    );\n    this.textureLocation = gl.getUniformLocation(this.program_, 'u_texture');\n\n    this.positionBuffer = gl.createBuffer();\n    gl.bindBuffer(gl.ARRAY_BUFFER, this.positionBuffer);\n\n    this.positions = [0, 0, 0, 1, 1, 0, 1, 0, 0, 1, 1, 1];\n    gl.bufferData(\n      gl.ARRAY_BUFFER,\n      new Float32Array(this.positions),\n      gl.STATIC_DRAW,\n    );\n\n    this.texcoordBuffer = gl.createBuffer();\n    gl.bindBuffer(gl.ARRAY_BUFFER, this.texcoordBuffer);\n\n    this.texcoords = [0, 0, 0, 1, 1, 0, 1, 0, 0, 1, 1, 1];\n    gl.bufferData(\n      gl.ARRAY_BUFFER,\n      new Float32Array(this.texcoords),\n      gl.STATIC_DRAW,\n    );\n  }\n\n  /**\n   * 2dContext drawImage call implemented in webgl.\n   * Unlike images, textures do not have a width and height associated\n   * with them so we'll pass in the width and height of the texture.\n   *\n   * @param {WebGLTexture} tex Image to draw.\n   * @param {number} texWidth Image width.\n   * @param {number} texHeight Image height.\n   * @param {number} srcX Top-left x-point to read src image.\n   * @param {number} srcY Top-left y-point to read src image.\n   * @param {number} [srcWidth] Width of source to read.\n   * @param {number} [srcHeight] Height of source to read.\n   * @param {number} [dstX] Top-left x-point of destination.\n   * @param {number} [dstY] Top-left y-point of destination.\n   * @param {number} [dstWidth] Width of written image in destination.\n   * @param {number} [dstHeight] Height of written image in destination.\n   * @param {number} [width] Width of canvas.\n   * @param {number} [height] Height of canvas.\n   */\n  drawImage(\n    tex,\n    texWidth,\n    texHeight,\n    srcX,\n    srcY,\n    srcWidth,\n    srcHeight,\n    dstX,\n    dstY,\n    dstWidth,\n    dstHeight,\n    width,\n    height,\n  ) {\n    const gl = this.gl_;\n\n    if (dstX === undefined) {\n      dstX = srcX;\n    }\n    if (dstY === undefined) {\n      dstY = srcY;\n    }\n    if (srcWidth === undefined) {\n      srcWidth = texWidth;\n    }\n    if (srcHeight === undefined) {\n      srcHeight = texHeight;\n    }\n    if (dstWidth === undefined) {\n      dstWidth = srcWidth;\n    }\n    if (dstHeight === undefined) {\n      dstHeight = srcHeight;\n    }\n    if (width === undefined) {\n      width = gl.canvas.width;\n    }\n    if (height === undefined) {\n      height = gl.canvas.height;\n    }\n\n    gl.bindTexture(gl.TEXTURE_2D, tex);\n\n    gl.useProgram(this.program_);\n\n    gl.bindBuffer(gl.ARRAY_BUFFER, this.positionBuffer);\n    gl.enableVertexAttribArray(this.positionLocation);\n    gl.vertexAttribPointer(this.positionLocation, 2, gl.FLOAT, false, 0, 0);\n    gl.bindBuffer(gl.ARRAY_BUFFER, this.texcoordBuffer);\n    gl.enableVertexAttribArray(this.texcoordLocation);\n    gl.vertexAttribPointer(this.texcoordLocation, 2, gl.FLOAT, false, 0, 0);\n\n    // matrix for converting pixels to clip space\n    let matrix = mat4.orthographic(0, width, 0, height, -1, 1);\n    matrix = mat4.translate(matrix, dstX, dstY, 0);\n    matrix = mat4.scale(matrix, dstWidth, dstHeight, 1);\n    gl.uniformMatrix4fv(this.matrixLocation, false, matrix);\n\n    let texMatrix = mat4.translation(srcX / texWidth, srcY / texHeight, 0);\n    texMatrix = mat4.scale(\n      texMatrix,\n      srcWidth / texWidth,\n      srcHeight / texHeight,\n      1,\n    );\n\n    gl.uniformMatrix4fv(this.textureMatrixLocation, false, texMatrix);\n    gl.uniform1i(this.textureLocation, 0);\n    gl.drawArrays(gl.TRIANGLES, 0, this.positions.length / 2);\n  }\n}\n\n/**\n * @param {WebGLRenderingContext} gl Rendering Context.\n * @param {GLenum} type Type of shader.\n * @param {string} source source of shader.\n * @return {WebGLShader} [progam] The program.\n */\nfunction createShader(gl, type, source) {\n  const shader = gl.createShader(type);\n\n  if (shader === null) {\n    throw new Error('Shader compilation failed');\n  }\n\n  gl.shaderSource(shader, source);\n\n  gl.compileShader(shader);\n  if (!gl.getShaderParameter(shader, gl.COMPILE_STATUS)) {\n    const log = gl.getShaderInfoLog(shader);\n    if (log === null) {\n      throw new Error('Shader info log creation failed');\n    }\n    throw new Error(log);\n  }\n\n  return shader;\n}\n\n/**\n * @param {WebGLRenderingContext} gl Rendering Context.\n * @param {string} fragmentSource Fragment shader source.\n * @param {string} vertexSource Vertex shader source.\n * @return {WebGLProgram} [progam] The program.\n */\nexport function createProgram(gl, fragmentSource, vertexSource) {\n  const program = gl.createProgram();\n\n  const vertexShader = createShader(gl, gl.VERTEX_SHADER, vertexSource);\n  const fragmentShader = createShader(gl, gl.FRAGMENT_SHADER, fragmentSource);\n  if (program === null) {\n    throw new Error('Program creation failed');\n  }\n\n  gl.attachShader(program, vertexShader);\n  gl.attachShader(program, fragmentShader);\n\n  gl.linkProgram(program);\n  if (!gl.getProgramParameter(program, gl.LINK_STATUS)) {\n    const log = gl.getProgramInfoLog(program);\n    if (log === null) {\n      throw new Error('Program info log creation failed');\n    }\n    throw new Error();\n  }\n  return program;\n}\n","/**\n * @module ol/reproj/glreproj\n */\nimport {\n  createEmpty,\n  extend,\n  getHeight,\n  getTopLeft,\n  getWidth,\n} from '../extent.js';\nimport {WORKER_OFFSCREEN_CANVAS} from '../has.js';\nimport * as mat4 from '../vec/mat4.js';\nimport {Canvas as WebGLCanvas, createProgram} from '../webgl/Canvas.js';\n\nconst EDGE_VERTEX_SHADER = `\n  attribute vec4 a_position;\n\n  uniform mat4 u_matrix;\n\n  void main() {\n     gl_Position = u_matrix * a_position;\n  }\n`;\nconst EDGE_FRAGMENT_SHADER = `\n  precision mediump float;\n\n  uniform vec4 u_val;\n  void main() {\n     gl_FragColor = u_val;\n  }\n`;\n\nconst TRIANGLE_VERTEX_SHADER = `\n  attribute vec4 a_position;\n  attribute vec2 a_texcoord;\n\n  varying vec2 v_texcoord;\n\n  uniform mat4 u_matrix;\n\n  void main() {\n     gl_Position = u_matrix * a_position;\n     v_texcoord = a_texcoord;\n  }\n`;\nconst TRIANGLE_FRAGMENT_SHADER = `\n  precision mediump float;\n\n  varying vec2 v_texcoord;\n\n  uniform sampler2D u_texture;\n\n  void main() {\n    if (v_texcoord.x < 0.0 || v_texcoord.x > 1.0 || v_texcoord.y < 0.0 || v_texcoord.y > 1.0) {\n      discard;\n    }\n    gl_FragColor = texture2D(u_texture, v_texcoord);\n  }\n`;\n\n/**\n * Create an html canvas element and returns its webgl context.\n * @param {number} [width] Canvas width.\n * @param {number} [height] Canvas height.\n * @param {Array<HTMLCanvasElement | OffscreenCanvas>} [canvasPool] Canvas pool to take existing canvas from.\n * @param {WebGLContextAttributes} [settings] CanvasRenderingContext2DSettings\n * @return {WebGLRenderingContext} The context.\n */\nexport function createCanvasContextWebGL(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 {WebGLRenderingContext} */ (\n    canvas.getContext('webgl', settings)\n  );\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 {WebGLRenderingContext} gl Context.\n */\nexport function releaseGLCanvas(gl) {\n  const canvas = gl.canvas;\n  canvas.width = 1;\n  canvas.height = 1;\n  gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT | gl.STENCIL_BUFFER_BIT);\n}\n\n/**\n * @type {Array<HTMLCanvasElement | OffscreenCanvas>}\n */\nexport const canvasGLPool = [];\n\n/**\n * @typedef {Object} ImageExtent\n * @property {import(\"../extent.js\").Extent} extent Extent.\n * @property {import(\"../extent.js\").Extent} [clipExtent] Clip extent.\n * @property {WebGLTexture} texture Texture.\n * @property {number} width Width of texture.\n * @property {number} height Height of texture.\n */\n\n/**\n * Renders the source data into new canvas based on the triangulation.\n *\n * @param {WebGLRenderingContext} gl the context to render in.\n * @param {number} width_ Width of the canvas.\n * @param {number} height_ Height of the canvas.\n * @param {number} pixelRatio Pixel ratio.\n * @param {number} sourceResolution Source resolution.\n * @param {number} targetResolution Target resolution.\n * @param {import(\"../extent.js\").Extent} targetExtent Target extent (tile).\n * @param {import(\"../reproj/Triangulation.js\").default} triangulation Calculated triangulation.\n * @param {Array<ImageExtent>} sources Array of sources.\n * @param {number} gutter Gutter of the sources.\n * @param {number} dataType What kind of data is the textures, must be gl.FLOAT or gl.UNSIGNED_BYTE\n * TODO: Allow setting renderEdges value in the data as this is done in \"data-space\".\n * @param {boolean | Array<number>} [renderEdges] Render reprojection edges.\n * @param {boolean} [interpolate] Use linear interpolation when resampling.\n * @param {boolean} [drawSingle] Draw single source images directly without stitchTexture.\n * @return {{framebuffer: WebGLFramebuffer, width: number, height: number, texture: WebGLTexture}} Canvas with reprojected data.\n */\nexport function render(\n  gl,\n  width_,\n  height_,\n  pixelRatio,\n  sourceResolution,\n  targetResolution,\n  targetExtent,\n  triangulation,\n  sources,\n  gutter,\n  dataType,\n  renderEdges,\n  interpolate,\n  drawSingle,\n) {\n  const width = Math.round(pixelRatio * width_);\n  const height = Math.round(pixelRatio * height_);\n  gl.canvas.width = width;\n  gl.canvas.height = height;\n\n  /** @type {WebGLFramebuffer | null} */\n  let resultFrameBuffer;\n  /** @type {WebGLTexture | null} */\n  let resultTexture;\n  {\n    resultTexture = gl.createTexture();\n    gl.bindTexture(gl.TEXTURE_2D, resultTexture);\n\n    gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n    gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n    if (interpolate) {\n      gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n      gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n    } else {\n      gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);\n      gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);\n    }\n    gl.texImage2D(\n      gl.TEXTURE_2D,\n      0,\n      gl.RGBA,\n      width,\n      height,\n      0,\n      gl.RGBA,\n      dataType,\n      null,\n    );\n\n    resultFrameBuffer = gl.createFramebuffer();\n    gl.bindFramebuffer(gl.FRAMEBUFFER, resultFrameBuffer);\n    gl.framebufferTexture2D(\n      gl.FRAMEBUFFER,\n      gl.COLOR_ATTACHMENT0,\n      gl.TEXTURE_2D,\n      resultTexture,\n      0,\n    );\n  }\n\n  if (resultFrameBuffer === null) {\n    throw new Error('Could not create framebuffer');\n  }\n  if (resultTexture === null) {\n    throw new Error('Could not create texture');\n  }\n\n  if (sources.length === 0) {\n    return {\n      width,\n      height,\n      framebuffer: resultFrameBuffer,\n      texture: resultTexture,\n    };\n  }\n\n  const sourceDataExtent = createEmpty();\n  sources.forEach(function (src, i, arr) {\n    extend(sourceDataExtent, src.extent);\n  });\n\n  /** @type {WebGLTexture | null} */\n  let stitchTexture;\n  /** @type {number} */\n  let stitchWidth;\n  /** @type {number} */\n  let stitchHeight;\n  const stitchScale = 1 / sourceResolution;\n\n  if (!drawSingle || sources.length !== 1 || gutter !== 0) {\n    stitchTexture = gl.createTexture();\n    if (resultTexture === null) {\n      throw new Error('Could not create texture');\n    }\n    stitchWidth = Math.round(getWidth(sourceDataExtent) * stitchScale);\n    stitchHeight = Math.round(getHeight(sourceDataExtent) * stitchScale);\n\n    // Make sure we do not exceed the max texture size by lowering the resolution for this image.\n    // https://github.com/openlayers/openlayers/pull/15860#issuecomment-2254123580\n    const maxTexSize = gl.getParameter(gl.MAX_TEXTURE_SIZE);\n    const largeSide = Math.max(stitchWidth, stitchHeight);\n    const scaleFactor = largeSide > maxTexSize ? maxTexSize / largeSide : 1;\n    const stitchWidthFixed = Math.round(stitchWidth * scaleFactor);\n    const stitchHeightFixed = Math.round(stitchHeight * scaleFactor);\n\n    gl.bindTexture(gl.TEXTURE_2D, stitchTexture);\n\n    gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n    gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n    if (interpolate) {\n      gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n      gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n    } else {\n      gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);\n      gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);\n    }\n    gl.texImage2D(\n      gl.TEXTURE_2D,\n      0,\n      gl.RGBA,\n      stitchWidthFixed,\n      stitchHeightFixed,\n      0,\n      gl.RGBA,\n      dataType,\n      null,\n    );\n\n    const fb = gl.createFramebuffer();\n    gl.bindFramebuffer(gl.FRAMEBUFFER, fb);\n    gl.framebufferTexture2D(\n      gl.FRAMEBUFFER,\n      gl.COLOR_ATTACHMENT0,\n      gl.TEXTURE_2D,\n      stitchTexture,\n      0,\n    );\n    const webGLCanvas = new WebGLCanvas(gl);\n\n    sources.forEach(function (src, i, arr) {\n      const xPos =\n        (src.extent[0] - sourceDataExtent[0]) * stitchScale * scaleFactor;\n      const yPos =\n        -(src.extent[3] - sourceDataExtent[3]) * stitchScale * scaleFactor;\n      const srcWidth = getWidth(src.extent) * stitchScale * scaleFactor;\n      const srcHeight = getHeight(src.extent) * stitchScale * scaleFactor;\n      gl.bindFramebuffer(gl.FRAMEBUFFER, fb);\n      gl.viewport(0, 0, stitchWidthFixed, stitchHeightFixed);\n\n      if (src.clipExtent) {\n        const xPos =\n          (src.clipExtent[0] - sourceDataExtent[0]) * stitchScale * scaleFactor;\n        const yPos =\n          -(src.clipExtent[3] - sourceDataExtent[3]) *\n          stitchScale *\n          scaleFactor;\n        const width = getWidth(src.clipExtent) * stitchScale * scaleFactor;\n        const height = getHeight(src.clipExtent) * stitchScale * scaleFactor;\n        gl.enable(gl.SCISSOR_TEST);\n        gl.scissor(\n          interpolate ? xPos : Math.round(xPos),\n          interpolate ? yPos : Math.round(yPos),\n          interpolate ? width : Math.round(xPos + width) - Math.round(xPos),\n          interpolate ? height : Math.round(yPos + height) - Math.round(yPos),\n        );\n      }\n\n      webGLCanvas.drawImage(\n        src.texture,\n        src.width,\n        src.height,\n        gutter,\n        gutter,\n        src.width - 2 * gutter,\n        src.height - 2 * gutter,\n        interpolate ? xPos : Math.round(xPos),\n        interpolate ? yPos : Math.round(yPos),\n        interpolate ? srcWidth : Math.round(xPos + srcWidth) - Math.round(xPos),\n        interpolate\n          ? srcHeight\n          : Math.round(yPos + srcHeight) - Math.round(yPos),\n        stitchWidthFixed,\n        stitchHeightFixed,\n      );\n\n      gl.disable(gl.SCISSOR_TEST);\n    });\n    gl.deleteFramebuffer(fb);\n  } else {\n    stitchTexture = sources[0].texture;\n    stitchWidth = sources[0].width;\n    stitchHeight = sources[0].width;\n  }\n\n  const targetTopLeft = getTopLeft(targetExtent);\n  const sourceTopLeft = getTopLeft(sourceDataExtent);\n\n  const getUVs = (\n    /** @type {Array<import(\"../coordinate.js\").Coordinate>} */ target,\n  ) => {\n    const u0 =\n      ((target[0][0] - targetTopLeft[0]) / targetResolution) * pixelRatio;\n    const v0 =\n      (-(target[0][1] - targetTopLeft[1]) / targetResolution) * pixelRatio;\n    const u1 =\n      ((target[1][0] - targetTopLeft[0]) / targetResolution) * pixelRatio;\n    const v1 =\n      (-(target[1][1] - targetTopLeft[1]) / targetResolution) * pixelRatio;\n    const u2 =\n      ((target[2][0] - targetTopLeft[0]) / targetResolution) * pixelRatio;\n    const v2 =\n      (-(target[2][1] - targetTopLeft[1]) / targetResolution) * pixelRatio;\n    return {u1, v1, u0, v0, u2, v2};\n  };\n\n  gl.bindFramebuffer(gl.FRAMEBUFFER, resultFrameBuffer);\n  gl.viewport(0, 0, width, height);\n\n  // Draw source to reprojtile\n  {\n    /** @type {Array<number>} */\n    const vertices = [];\n    /** @type {Array<number>} */\n    const texcoords = [];\n\n    const triProgram = createProgram(\n      gl,\n      TRIANGLE_FRAGMENT_SHADER,\n      TRIANGLE_VERTEX_SHADER,\n    );\n    gl.useProgram(triProgram);\n\n    // Bind image\n    const textureLocation = gl.getUniformLocation(triProgram, 'u_texture');\n    gl.bindTexture(gl.TEXTURE_2D, stitchTexture);\n\n    // Tell the shader to get the texture from texture unit 0\n    gl.uniform1i(textureLocation, 0);\n\n    // Calculate vert and tex coordinates.\n    triangulation.getTriangles().forEach(function (triangle, i, arr) {\n      const source = triangle.source;\n      const target = triangle.target;\n      // Make sure that everything is on pixel boundaries\n      const {u1, v1, u0, v0, u2, v2} = getUVs(target);\n\n      const su0 =\n        (source[0][0] - sourceTopLeft[0]) / sourceResolution / stitchWidth;\n      const sv0 =\n        -(source[0][1] - sourceTopLeft[1]) / sourceResolution / stitchHeight;\n      const su1 =\n        (source[1][0] - sourceTopLeft[0]) / sourceResolution / stitchWidth;\n      const sv1 =\n        -(source[1][1] - sourceTopLeft[1]) / sourceResolution / stitchHeight;\n      const su2 =\n        (source[2][0] - sourceTopLeft[0]) / sourceResolution / stitchWidth;\n      const sv2 =\n        -(source[2][1] - sourceTopLeft[1]) / sourceResolution / stitchHeight;\n\n      vertices.push(u1, v1, u0, v0, u2, v2);\n      texcoords.push(su1, sv1, su0, sv0, su2, sv2);\n    });\n\n    // Convert pixel space to clip space.\n    const matrix = mat4.orthographic(0, width, height, 0, -1, 1);\n    const matrixLocation = gl.getUniformLocation(triProgram, 'u_matrix');\n    gl.uniformMatrix4fv(matrixLocation, false, matrix);\n\n    const positionLocation = gl.getAttribLocation(triProgram, 'a_position');\n    const positionBuffer = gl.createBuffer();\n    gl.bindBuffer(gl.ARRAY_BUFFER, positionBuffer);\n    gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);\n    gl.vertexAttribPointer(positionLocation, 2, gl.FLOAT, false, 0, 0);\n    gl.enableVertexAttribArray(positionLocation);\n\n    const texcoordLocation = gl.getAttribLocation(triProgram, 'a_texcoord');\n    const texcoordBuffer = gl.createBuffer();\n    gl.bindBuffer(gl.ARRAY_BUFFER, texcoordBuffer);\n    gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(texcoords), gl.STATIC_DRAW);\n    gl.vertexAttribPointer(texcoordLocation, 2, gl.FLOAT, false, 0, 0);\n    gl.enableVertexAttribArray(texcoordLocation);\n\n    gl.drawArrays(gl.TRIANGLES, 0, vertices.length / 2);\n  }\n\n  if (renderEdges) {\n    const edgeProgram = createProgram(\n      gl,\n      EDGE_FRAGMENT_SHADER,\n      EDGE_VERTEX_SHADER,\n    );\n    gl.useProgram(edgeProgram);\n    const matrix = mat4.orthographic(0, width, height, 0, -1, 1);\n    const matrixLocation = gl.getUniformLocation(edgeProgram, 'u_matrix');\n    gl.uniformMatrix4fv(matrixLocation, false, matrix);\n\n    const burnval = Array.isArray(renderEdges) ? renderEdges : [0, 0, 0, 255];\n    const burnvalLocation = gl.getUniformLocation(edgeProgram, 'u_val');\n    const isFloat = true;\n    if (isFloat) {\n      gl.uniform4fv(burnvalLocation, burnval);\n    } else {\n      gl.uniform4iv(burnvalLocation, burnval);\n    }\n\n    const positionLocation = gl.getAttribLocation(edgeProgram, 'a_position');\n    const positionBuffer = gl.createBuffer();\n    gl.bindBuffer(gl.ARRAY_BUFFER, positionBuffer);\n    gl.vertexAttribPointer(positionLocation, 2, gl.FLOAT, false, 0, 0);\n    gl.enableVertexAttribArray(positionLocation);\n\n    /** @type {Array<number>} */\n    const lines = triangulation.getTriangles().reduce(function (\n      /** @type {Array<number>} */ lines,\n      triangle,\n    ) {\n      const target = triangle.target;\n      const {u1, v1, u0, v0, u2, v2} = getUVs(target);\n\n      return lines.concat([u1, v1, u0, v0, u0, v0, u2, v2, u2, v2, u1, v1]);\n    }, []);\n    gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(lines), gl.STATIC_DRAW);\n    gl.drawArrays(gl.LINES, 0, lines.length / 2);\n  }\n\n  return {\n    width,\n    height,\n    framebuffer: resultFrameBuffer,\n    texture: resultTexture,\n  };\n}\n","/**\n * @module ol/reproj/DataTile\n */\n\nimport DataTile, {asArrayLike, asImageLike, toArray} from '../DataTile.js';\nimport TileState from '../TileState.js';\nimport {createCanvasContext2D} from '../dom.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport EventType from '../events/EventType.js';\nimport {getArea, getIntersection, getWidth, wrapAndSliceX} from '../extent.js';\nimport {clamp} from '../math.js';\nimport {calculateSourceExtentResolution} from '../reproj.js';\nimport Triangulation from './Triangulation.js';\nimport {ERROR_THRESHOLD} from './common.js';\nimport {\n  canvasGLPool,\n  createCanvasContextWebGL,\n  releaseGLCanvas,\n  render as renderReprojected,\n} from './glreproj.js';\n\n/**\n * @typedef {function(number, number, number, number) : import(\"../DataTile.js\").default} TileGetter\n */\n\n/**\n * @typedef {Object} TileOffset\n * @property {DataTile} tile Tile.\n * @property {number} offset Offset.\n */\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../proj/Projection.js\").default} sourceProj Source projection.\n * @property {import(\"../tilegrid/TileGrid.js\").default} sourceTileGrid Source tile grid.\n * @property {import(\"../proj/Projection.js\").default} targetProj Target projection.\n * @property {import(\"../tilegrid/TileGrid.js\").default} targetTileGrid Target tile grid.\n * @property {import(\"../tilecoord.js\").TileCoord} tileCoord Coordinate of the tile.\n * @property {import(\"../tilecoord.js\").TileCoord} [wrappedTileCoord] Coordinate of the tile wrapped in X.\n * @property {number} pixelRatio Pixel ratio.\n * @property {number} gutter Gutter of the source tiles.\n * @property {TileGetter} getTileFunction Function returning source tiles (z, x, y, pixelRatio).\n * @property {boolean} [interpolate=false] Use interpolated values when resampling.  By default,\n * the nearest neighbor is used when resampling.\n * @property {number} [errorThreshold] Acceptable reprojection error (in px).\n * @property {number} [transition=250] A duration for tile opacity\n * transitions in milliseconds. A duration of 0 disables the opacity transition.\n * @property {import(\"../transform.js\").Transform} [transformMatrix] Source transform matrix.\n * @property {boolean} [renderEdges] Render reprojection edges.\n */\n\n/**\n * @classdesc\n * Class encapsulating single reprojected data tile.\n * See {@link module:ol/source/DataTile~DataTileSource}.\n *\n */\nclass ReprojDataTile extends DataTile {\n  /**\n   * @param {Options} options Tile options.\n   */\n  constructor(options) {\n    super({\n      tileCoord: options.tileCoord,\n      loader: () => Promise.resolve(new Uint8ClampedArray(4)),\n      interpolate: options.interpolate,\n      transition: options.transition,\n    });\n\n    /**\n     * @private\n     * @type {boolean | Array<number>}\n     */\n    this.renderEdges_ =\n      options.renderEdges !== undefined ? options.renderEdges : false;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.pixelRatio_ = options.pixelRatio;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.gutter_ = options.gutter;\n\n    /**\n     * @type {import(\"../DataTile.js\").Data}\n     * @private\n     */\n    this.reprojData_ = null;\n\n    /**\n     * @type {Error}\n     * @private\n     */\n    this.reprojError_ = null;\n\n    /**\n     * @type {import('../size.js').Size}\n     * @private\n     */\n    this.reprojSize_ = undefined;\n\n    /**\n     * @private\n     * @type {import(\"../tilegrid/TileGrid.js\").default}\n     */\n    this.sourceTileGrid_ = options.sourceTileGrid;\n\n    /**\n     * @private\n     * @type {import(\"../tilegrid/TileGrid.js\").default}\n     */\n    this.targetTileGrid_ = options.targetTileGrid;\n\n    /**\n     * @private\n     * @type {import(\"../tilecoord.js\").TileCoord}\n     */\n    this.wrappedTileCoord_ = options.wrappedTileCoord || options.tileCoord;\n\n    /**\n     * @private\n     * @type {!Array<TileOffset>}\n     */\n    this.sourceTiles_ = [];\n\n    /**\n     * @private\n     * @type {?Array<import(\"../events.js\").EventsKey>}\n     */\n    this.sourcesListenerKeys_ = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.sourceZ_ = 0;\n\n    const sourceProj = options.sourceProj;\n    const sourceProjExtent = sourceProj.getExtent();\n    const sourceTileGridExtent = options.sourceTileGrid.getExtent();\n\n    /**\n     * @private\n     * @type {import(\"../extent.js\").Extent}\n     */\n    this.clipExtent_ = sourceProj.canWrapX()\n      ? sourceTileGridExtent\n        ? getIntersection(sourceProjExtent, sourceTileGridExtent)\n        : sourceProjExtent\n      : sourceTileGridExtent;\n\n    const targetExtent = this.targetTileGrid_.getTileCoordExtent(\n      this.wrappedTileCoord_,\n    );\n    const maxTargetExtent = this.targetTileGrid_.getExtent();\n    let maxSourceExtent = this.sourceTileGrid_.getExtent();\n\n    const limitedTargetExtent = maxTargetExtent\n      ? getIntersection(targetExtent, maxTargetExtent)\n      : targetExtent;\n\n    if (getArea(limitedTargetExtent) === 0) {\n      // Tile is completely outside range -> EMPTY\n      // TODO: is it actually correct that the source even creates the tile ?\n      this.state = TileState.EMPTY;\n      return;\n    }\n\n    if (sourceProjExtent) {\n      if (!maxSourceExtent) {\n        maxSourceExtent = sourceProjExtent;\n      } else {\n        maxSourceExtent = getIntersection(maxSourceExtent, sourceProjExtent);\n      }\n    }\n\n    const targetResolution = this.targetTileGrid_.getResolution(\n      this.wrappedTileCoord_[0],\n    );\n\n    const targetProj = options.targetProj;\n    const sourceResolution = calculateSourceExtentResolution(\n      sourceProj,\n      targetProj,\n      limitedTargetExtent,\n      targetResolution,\n    );\n\n    if (!isFinite(sourceResolution) || sourceResolution <= 0) {\n      // invalid sourceResolution -> EMPTY\n      // probably edges of the projections when no extent is defined\n      this.state = TileState.EMPTY;\n      return;\n    }\n\n    const errorThresholdInPixels =\n      options.errorThreshold !== undefined\n        ? options.errorThreshold\n        : ERROR_THRESHOLD;\n\n    /**\n     * @private\n     * @type {!import(\"./Triangulation.js\").default}\n     */\n    this.triangulation_ = new Triangulation(\n      sourceProj,\n      targetProj,\n      limitedTargetExtent,\n      maxSourceExtent,\n      sourceResolution * errorThresholdInPixels,\n      targetResolution,\n      options.transformMatrix,\n    );\n\n    if (this.triangulation_.getTriangles().length === 0) {\n      // no valid triangles -> EMPTY\n      this.state = TileState.EMPTY;\n      return;\n    }\n\n    this.sourceZ_ = this.sourceTileGrid_.getZForResolution(sourceResolution);\n    let sourceExtent = this.triangulation_.calculateSourceExtent();\n\n    if (maxSourceExtent) {\n      if (sourceProj.canWrapX()) {\n        sourceExtent[1] = clamp(\n          sourceExtent[1],\n          maxSourceExtent[1],\n          maxSourceExtent[3],\n        );\n        sourceExtent[3] = clamp(\n          sourceExtent[3],\n          maxSourceExtent[1],\n          maxSourceExtent[3],\n        );\n      } else {\n        sourceExtent = getIntersection(sourceExtent, maxSourceExtent);\n      }\n    }\n\n    if (!getArea(sourceExtent)) {\n      this.state = TileState.EMPTY;\n    } else {\n      let worldWidth = 0;\n      let worldsAway = 0;\n      if (sourceProj.canWrapX()) {\n        worldWidth = getWidth(sourceProjExtent);\n        worldsAway = Math.floor(\n          (sourceExtent[0] - sourceProjExtent[0]) / worldWidth,\n        );\n      }\n\n      const sourceExtents = wrapAndSliceX(\n        sourceExtent.slice(),\n        sourceProj,\n        true,\n      );\n      sourceExtents.forEach((extent) => {\n        const sourceRange = this.sourceTileGrid_.getTileRangeForExtentAndZ(\n          extent,\n          this.sourceZ_,\n        );\n        const getTile = options.getTileFunction;\n        for (let srcX = sourceRange.minX; srcX <= sourceRange.maxX; srcX++) {\n          for (let srcY = sourceRange.minY; srcY <= sourceRange.maxY; srcY++) {\n            const tile = getTile(this.sourceZ_, srcX, srcY, this.pixelRatio_);\n            if (tile) {\n              const offset = worldsAway * worldWidth;\n              this.sourceTiles_.push({tile, offset});\n            }\n          }\n        }\n        ++worldsAway;\n      });\n\n      if (this.sourceTiles_.length === 0) {\n        this.state = TileState.EMPTY;\n      }\n    }\n  }\n\n  /**\n   * Get the tile size.\n   * @return {import('../size.js').Size} Tile size.\n   * @override\n   */\n  getSize() {\n    return this.reprojSize_;\n  }\n\n  /**\n   * Get the data for the tile.\n   * @return {import(\"../DataTile.js\").Data} Tile data.\n   * @override\n   */\n  getData() {\n    return this.reprojData_;\n  }\n\n  /**\n   * Get any loading error.\n   * @return {Error} Loading error.\n   * @override\n   */\n  getError() {\n    return this.reprojError_;\n  }\n\n  /**\n   * @private\n   */\n  reproject_() {\n    const dataSources = [];\n    let imageLike = false;\n    this.sourceTiles_.forEach((source) => {\n      const tile = source.tile;\n      if (!tile || tile.getState() !== TileState.LOADED) {\n        return;\n      }\n      const size = tile.getSize();\n      const gutter = this.gutter_;\n      /**\n       * @type {import(\"../DataTile.js\").ArrayLike}\n       */\n      let tileData;\n      const arrayData = asArrayLike(tile.getData());\n      if (arrayData) {\n        tileData = arrayData;\n      } else {\n        imageLike = true;\n        tileData = toArray(asImageLike(tile.getData()));\n      }\n      const pixelSize = [size[0] + 2 * gutter, size[1] + 2 * gutter];\n      const isFloat = tileData instanceof Float32Array;\n      const pixelCount = pixelSize[0] * pixelSize[1];\n      const DataType = isFloat ? Float32Array : Uint8ClampedArray;\n      const tileDataR = new DataType(\n        /** @type {ArrayBuffer} */ (tileData.buffer),\n      );\n      const bytesPerElement = DataType.BYTES_PER_ELEMENT;\n      const bytesPerPixel = (bytesPerElement * tileDataR.length) / pixelCount;\n      const bytesPerRow = tileDataR.byteLength / pixelSize[1];\n      const bandCount = Math.floor(\n        bytesPerRow / bytesPerElement / pixelSize[0],\n      );\n      const extent = this.sourceTileGrid_.getTileCoordExtent(tile.tileCoord);\n      extent[0] += source.offset;\n      extent[2] += source.offset;\n      const clipExtent = this.clipExtent_?.slice();\n      if (clipExtent) {\n        clipExtent[0] += source.offset;\n        clipExtent[2] += source.offset;\n      }\n      dataSources.push({\n        extent: extent,\n        clipExtent: clipExtent,\n        data: tileDataR,\n        dataType: DataType,\n        bytesPerPixel: bytesPerPixel,\n        pixelSize: pixelSize,\n        bandCount: bandCount,\n      });\n    });\n    this.sourceTiles_.length = 0;\n\n    if (dataSources.length === 0) {\n      this.state = TileState.ERROR;\n      this.changed();\n      return;\n    }\n\n    const z = this.wrappedTileCoord_[0];\n    const size = this.targetTileGrid_.getTileSize(z);\n    const targetWidth = typeof size === 'number' ? size : size[0];\n    const targetHeight = typeof size === 'number' ? size : size[1];\n    const outWidth = Math.round(targetWidth * this.pixelRatio_);\n    const outHeight = Math.round(targetHeight * this.pixelRatio_);\n    const targetResolution = this.targetTileGrid_.getResolution(z);\n    const sourceResolution = this.sourceTileGrid_.getResolution(this.sourceZ_);\n\n    const targetExtent = this.targetTileGrid_.getTileCoordExtent(\n      this.wrappedTileCoord_,\n    );\n\n    const bandCount = dataSources[0].bandCount;\n    const dataR = new dataSources[0].dataType(bandCount * outWidth * outHeight);\n\n    const gl = createCanvasContextWebGL(outWidth, outHeight, canvasGLPool, {\n      premultipliedAlpha: false,\n      antialias: false,\n    });\n\n    let willInterpolate;\n    const format = gl.RGBA;\n    let textureType;\n    if (dataSources[0].dataType == Float32Array) {\n      textureType = gl.FLOAT;\n      gl.getExtension('WEBGL_color_buffer_float');\n      gl.getExtension('OES_texture_float');\n      gl.getExtension('EXT_float_blend');\n      const extension = gl.getExtension('OES_texture_float_linear');\n      const canInterpolate = extension !== null;\n      willInterpolate = canInterpolate && this.interpolate;\n    } else {\n      textureType = gl.UNSIGNED_BYTE;\n      willInterpolate = this.interpolate;\n    }\n\n    const BANDS_PR_REPROJ = 4;\n    const reprojs = Math.ceil(bandCount / BANDS_PR_REPROJ);\n    for (let reproj = reprojs - 1; reproj >= 0; --reproj) {\n      const sources = [];\n      for (let i = 0, len = dataSources.length; i < len; ++i) {\n        const dataSource = dataSources[i];\n\n        const pixelSize = dataSource.pixelSize;\n        const width = pixelSize[0];\n        const height = pixelSize[1];\n\n        const data = new dataSource.dataType(BANDS_PR_REPROJ * width * height);\n        const dataS = dataSource.data;\n        let offset = reproj * BANDS_PR_REPROJ;\n        for (let j = 0, len = data.length; j < len; j += BANDS_PR_REPROJ) {\n          data[j] = dataS[offset];\n          data[j + 1] = dataS[offset + 1];\n          data[j + 2] = dataS[offset + 2];\n          data[j + 3] = dataS[offset + 3];\n          offset += bandCount;\n        }\n\n        const texture = gl.createTexture();\n        gl.bindTexture(gl.TEXTURE_2D, texture);\n\n        if (willInterpolate) {\n          gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n          gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);\n        } else {\n          gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);\n          gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);\n        }\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n        gl.texImage2D(\n          gl.TEXTURE_2D,\n          0,\n          format,\n          width,\n          height,\n          0,\n          format,\n          textureType,\n          data,\n        );\n\n        sources.push({\n          extent: dataSource.extent,\n          clipExtent: dataSource.clipExtent,\n          texture: texture,\n          width: width,\n          height: height,\n        });\n      }\n\n      const {framebuffer, width, height} = renderReprojected(\n        gl,\n        targetWidth,\n        targetHeight,\n        this.pixelRatio_,\n        sourceResolution,\n        targetResolution,\n        targetExtent,\n        this.triangulation_,\n        sources,\n        this.gutter_,\n        textureType,\n        this.renderEdges_,\n        willInterpolate,\n      );\n\n      // The texture is always RGBA.\n      const rows = width;\n      const cols = height * BANDS_PR_REPROJ;\n      const data = new dataSources[0].dataType(rows * cols);\n      gl.bindFramebuffer(gl.FRAMEBUFFER, framebuffer);\n      gl.readPixels(0, 0, width, height, gl.RGBA, textureType, data);\n\n      let offset = reproj * BANDS_PR_REPROJ;\n      for (let i = 0, len = data.length; i < len; i += BANDS_PR_REPROJ) {\n        // The data read by `readPixels` is flipped in the y-axis so flip it again.\n        const flipY = (rows - 1 - ((i / cols) | 0)) * cols + (i % cols);\n        dataR[offset] = data[flipY];\n        dataR[offset + 1] = data[flipY + 1];\n        dataR[offset + 2] = data[flipY + 2];\n        dataR[offset + 3] = data[flipY + 3];\n        offset += bandCount;\n      }\n    }\n\n    releaseGLCanvas(gl);\n    canvasGLPool.push(gl.canvas);\n\n    if (imageLike) {\n      const context = createCanvasContext2D(targetWidth, targetHeight);\n      const imageData = new ImageData(dataR, targetWidth);\n      context.putImageData(imageData, 0, 0);\n      this.reprojData_ = context.canvas;\n    } else {\n      this.reprojData_ = dataR;\n    }\n    this.reprojSize_ = [outWidth, outHeight];\n    this.state = TileState.LOADED;\n    this.changed();\n  }\n\n  /**\n   * Load not yet loaded URI.\n   * @override\n   */\n  load() {\n    if (this.state !== TileState.IDLE && this.state !== TileState.ERROR) {\n      return;\n    }\n    this.state = TileState.LOADING;\n    this.changed();\n\n    let leftToLoad = 0;\n\n    this.sourcesListenerKeys_ = [];\n    this.sourceTiles_.forEach(({tile}) => {\n      const state = tile.getState();\n      if (state !== TileState.IDLE && state !== TileState.LOADING) {\n        return;\n      }\n      leftToLoad++;\n\n      const sourceListenKey = listen(tile, EventType.CHANGE, () => {\n        const state = tile.getState();\n        if (\n          state == TileState.LOADED ||\n          state == TileState.ERROR ||\n          state == TileState.EMPTY\n        ) {\n          unlistenByKey(sourceListenKey);\n          leftToLoad--;\n          if (leftToLoad === 0) {\n            this.unlistenSources_();\n            this.reproject_();\n          }\n        }\n      });\n      this.sourcesListenerKeys_.push(sourceListenKey);\n    });\n\n    if (leftToLoad === 0) {\n      setTimeout(this.reproject_.bind(this), 0);\n    } else {\n      this.sourceTiles_.forEach(function ({tile}) {\n        const state = tile.getState();\n        if (state == TileState.IDLE) {\n          tile.load();\n        }\n      });\n    }\n  }\n\n  /**\n   * @private\n   */\n  unlistenSources_() {\n    this.sourcesListenerKeys_.forEach(unlistenByKey);\n    this.sourcesListenerKeys_ = null;\n  }\n}\n\nexport default ReprojDataTile;\n","/**\n * @module ol/source/DataTile\n */\nimport DataTile from '../DataTile.js';\nimport TileState from '../TileState.js';\nimport EventType from '../events/EventType.js';\nimport {getHeight, getWidth} from '../extent.js';\nimport {toPromise} from '../functions.js';\nimport {equivalent, get as getProjection} from '../proj.js';\nimport ReprojDataTile from '../reproj/DataTile.js';\nimport {toSize} from '../size.js';\nimport {getCacheKey} from '../tilecoord.js';\nimport {\n  createForProjection,\n  createXYZ,\n  extentFromProjection,\n  getForProjection as getTileGridForProjection,\n} from '../tilegrid.js';\nimport {DEFAULT_TILE_SIZE} from '../tilegrid/common.js';\nimport {getUid} from '../util.js';\nimport TileSource, {TileSourceEvent} from './Tile.js';\nimport TileEventType from './TileEventType.js';\n\n/**\n * @typedef {'anonymous'|'use-credentials'} CrossOriginAttribute\n */\n\n/**\n * @typedef {Object} LoaderOptions\n * @property {AbortSignal} signal An abort controller signal.\n * @property {CrossOriginAttribute} [crossOrigin] The cross-origin attribute for images.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for images.\n * @property {number} [maxY] The maximum y coordinate at the given z level.  Will be undefined if the\n * underlying tile grid does not have a known extent.\n */\n\n/**\n * Data tile loading function.  The function is called with z, x, and y tile coordinates and\n * returns {@link import(\"../DataTile.js\").Data data} for a tile or a promise for the same.\n * @typedef {function(number, number, number, LoaderOptions) : (import(\"../DataTile.js\").Data|Promise<import(\"../DataTile.js\").Data>)} Loader\n */\n\n/**\n * @typedef {Object} Options\n * @property {Loader} [loader] Data loader.  Called with z, x, and y tile coordinates.\n * Returns {@link import(\"../DataTile.js\").Data data} for a tile or a promise for the same.\n * For loaders that generate images, the promise should not resolve until the image is loaded.\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.\n * @property {number} [maxZoom=42] Optional max zoom level. Not used if `tileGrid` is provided.\n * @property {number} [minZoom=0] Optional min zoom level. Not used if `tileGrid` is provided.\n * @property {number|import(\"../size.js\").Size} [tileSize=[256, 256]] The pixel width and height of the source tiles.\n * This may be different than the rendered pixel size if a `tileGrid` is provided.\n * @property {number} [gutter=0] The size in pixels of the gutter around data tiles to ignore.\n * This allows artifacts of rendering at tile edges to be ignored.\n * Supported data should be wider and taller than the tile size by a value of `2 x gutter`.\n * @property {number} [maxResolution] Optional tile grid resolution at level zero. Not used if `tileGrid` is provided.\n * @property {import(\"../proj.js\").ProjectionLike} [projection='EPSG:3857'] Tile projection.\n * @property {import(\"../tilegrid/TileGrid.js\").default} [tileGrid] Tile grid.\n * @property {import(\"./Source.js\").State} [state] The source state.\n * @property {boolean} [wrapX=false] Render tiles beyond the antimeridian.\n * @property {number} [transition] Transition time when fading in new tiles (in milliseconds).\n * @property {number} [bandCount=4] Number of bands represented in the data.\n * @property {boolean} [interpolate=false] Use interpolated values when resampling.  By default,\n * the nearest neighbor is used when resampling.\n * @property {CrossOriginAttribute} [crossOrigin='anonymous'] The crossOrigin property to pass to loaders for image data.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for loaded images.\n * @property {string} [key] Key for use in caching tiles.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n */\n\n/**\n * @classdesc\n * A source for typed array data tiles.\n *\n * @fires import(\"./Tile.js\").TileSourceEvent\n * @template {import(\"../Tile.js\").default} [TileType=DataTile]\n * @extends TileSource<TileType>\n * @api\n */\nclass DataTileSource extends TileSource {\n  /**\n   * @param {Options} options DataTile source options.\n   */\n  constructor(options) {\n    const projection =\n      options.projection === undefined ? 'EPSG:3857' : options.projection;\n\n    let tileGrid = options.tileGrid;\n    if (tileGrid === undefined && projection) {\n      tileGrid = createXYZ({\n        extent: extentFromProjection(projection),\n        maxResolution: options.maxResolution,\n        maxZoom: options.maxZoom,\n        minZoom: options.minZoom,\n        tileSize: options.tileSize,\n      });\n    }\n\n    super({\n      cacheSize: 0.1, // don't cache on the source\n      attributions: options.attributions,\n      attributionsCollapsible: options.attributionsCollapsible,\n      projection: projection,\n      tileGrid: tileGrid,\n      state: options.state,\n      wrapX: options.wrapX,\n      transition: options.transition,\n      interpolate: options.interpolate,\n      key: options.key,\n      zDirection: options.zDirection,\n    });\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.gutter_ = options.gutter !== undefined ? options.gutter : 0;\n\n    /**\n     * @private\n     * @type {import('../size.js').Size|null}\n     */\n    this.tileSize_ = options.tileSize ? toSize(options.tileSize) : null;\n\n    /**\n     * @private\n     * @type {Array<import('../size.js').Size>|null}\n     */\n    this.tileSizes_ = null;\n\n    /**\n     * @private\n     * @type {!Object<string, boolean>}\n     */\n    this.tileLoadingKeys_ = {};\n\n    /**\n     * @private\n     */\n    this.loader_ = options.loader;\n\n    /**\n     * @private\n     */\n    this.handleTileChange_ = this.handleTileChange_.bind(this);\n\n    /**\n     * @type {number}\n     */\n    this.bandCount = options.bandCount === undefined ? 4 : options.bandCount; // assume RGBA if undefined\n\n    /**\n     * The 1-based band index for the nodata alpha band.\n     * @type {number|undefined}\n     */\n    this.nodataBandIndex;\n\n    /**\n     * @private\n     * @type {!Object<string, import(\"../tilegrid/TileGrid.js\").default>}\n     */\n    this.tileGridForProjection_ = {};\n\n    /**\n     * @private\n     * @type {CrossOriginAttribute}\n     */\n    this.crossOrigin_ = options.crossOrigin || 'anonymous';\n\n    /**\n     * @private\n     * @type {ReferrerPolicy}\n     */\n    this.referrerPolicy_ = options.referrerPolicy;\n\n    /**\n     * @type {import(\"../transform.js\").Transform|null}\n     */\n    this.transformMatrix = null;\n  }\n\n  /**\n   * Set the source tile sizes.  The length of the array is expected to match the number of\n   * levels in the tile grid.\n   * @protected\n   * @param {Array<import('../size.js').Size>} tileSizes An array of tile sizes.\n   */\n  setTileSizes(tileSizes) {\n    this.tileSizes_ = tileSizes;\n  }\n\n  /**\n   * Get the source tile size at the given zoom level.  This may be different than the rendered tile\n   * size.\n   * @protected\n   * @param {number} z Tile zoom level.\n   * @return {import('../size.js').Size} The source tile size.\n   */\n  getTileSize(z) {\n    if (this.tileSizes_) {\n      return this.tileSizes_[z];\n    }\n    if (this.tileSize_) {\n      return this.tileSize_;\n    }\n    const tileGrid = this.getTileGrid();\n    return tileGrid ? toSize(tileGrid.getTileSize(z)) : [256, 256];\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {number} Gutter.\n   * @override\n   */\n  getGutterForProjection(projection) {\n    const thisProj = this.getProjection();\n    if (\n      (!thisProj || equivalent(thisProj, projection)) &&\n      !this.transformMatrix\n    ) {\n      return this.gutter_;\n    }\n\n    return 0;\n  }\n\n  /**\n   * @param {Loader} loader The data loader.\n   * @protected\n   */\n  setLoader(loader) {\n    this.loader_ = loader;\n  }\n\n  /**\n   * @param {number} z Tile coordinate z.\n   * @param {number} x Tile coordinate x.\n   * @param {number} y Tile coordinate y.\n   * @param {import(\"../proj/Projection.js\").default} targetProj The output projection.\n   * @param {import(\"../proj/Projection.js\").default} sourceProj The input projection.\n   * @param {import(\"../structs/LRUCache.js\").default<import(\"../Tile.js\").default>} [tileCache] Tile cache.\n   * @return {!TileType} Tile.\n   */\n  getReprojTile_(z, x, y, targetProj, sourceProj, tileCache) {\n    const sourceTileGrid =\n      this.tileGrid || this.getTileGridForProjection(sourceProj || targetProj);\n    const reprojTilePixelRatio = Math.max.apply(\n      null,\n      sourceTileGrid.getResolutions().map((r, z) => {\n        const tileSize = toSize(sourceTileGrid.getTileSize(z));\n        const textureSize = this.getTileSize(z);\n        return Math.max(\n          textureSize[0] / tileSize[0],\n          textureSize[1] / tileSize[1],\n        );\n      }),\n    );\n\n    const targetTileGrid = this.getTileGridForProjection(targetProj);\n    const tileCoord = [z, x, y];\n    const wrappedTileCoord = this.getTileCoordForTileUrlFunction(\n      tileCoord,\n      targetProj,\n    );\n\n    const options = Object.assign(\n      {\n        sourceProj: sourceProj || targetProj,\n        sourceTileGrid,\n        targetProj,\n        targetTileGrid,\n        tileCoord,\n        wrappedTileCoord,\n        pixelRatio: reprojTilePixelRatio,\n        gutter: this.gutter_,\n        getTileFunction: (z, x, y, pixelRatio) =>\n          this.getTile(z, x, y, pixelRatio, undefined, tileCache),\n        transformMatrix: this.transformMatrix,\n      },\n      /** @type {import(\"../reproj/DataTile.js\").Options} */ (this.tileOptions),\n    );\n    const tile = /** @type {TileType} */ (\n      /** @type {*} */ (new ReprojDataTile(options))\n    );\n    tile.key = this.getKey();\n    return tile;\n  }\n\n  /**\n   * @param {number} z Tile coordinate z.\n   * @param {number} x Tile coordinate x.\n   * @param {number} y Tile coordinate y.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} [projection] Projection.\n   * @param {import(\"../structs/LRUCache.js\").default<import(\"../Tile.js\").default>} [tileCache] Tile cache.\n   * @return {TileType|null} Tile (or null if outside source extent).\n   * @override\n   */\n  getTile(z, x, y, pixelRatio, projection, tileCache) {\n    const sourceProjection = this.getProjection();\n    if (\n      projection &&\n      ((sourceProjection && !equivalent(sourceProjection, projection)) ||\n        this.transformMatrix)\n    ) {\n      return this.getReprojTile_(\n        z,\n        x,\n        y,\n        projection,\n        sourceProjection,\n        tileCache,\n      );\n    }\n\n    const size = this.getTileSize(z);\n\n    const sourceLoader = this.loader_;\n\n    const controller = new AbortController();\n\n    /**\n     * @type {LoaderOptions}\n     */\n    const loaderOptions = {\n      signal: controller.signal,\n      crossOrigin: this.crossOrigin_,\n      referrerPolicy: this.referrerPolicy_,\n    };\n\n    const tileCoord = this.getTileCoordForTileUrlFunction([z, x, y]);\n    if (!tileCoord) {\n      return null;\n    }\n\n    const key = this.getKey();\n    const cacheKey = getCacheKey(this, key, z, x, y);\n    if (tileCache && tileCache.containsKey(cacheKey)) {\n      return /** @type {TileType} */ (tileCache.get(cacheKey));\n    }\n\n    const requestZ = tileCoord[0];\n    const requestX = tileCoord[1];\n    const requestY = tileCoord[2];\n    const range = this.getTileGrid()?.getFullTileRange(requestZ);\n    if (range) {\n      loaderOptions.maxY = range.getHeight() - 1;\n    }\n    function loader() {\n      return toPromise(function () {\n        return sourceLoader(requestZ, requestX, requestY, loaderOptions);\n      });\n    }\n\n    /**\n     * @type {import(\"../DataTile.js\").Options}\n     */\n    const options = Object.assign(\n      {\n        tileCoord: [z, x, y],\n        loader: loader,\n        size: size,\n        controller: controller,\n      },\n      this.tileOptions,\n    );\n\n    const tile = /** @type {TileType} */ (\n      /** @type {*} */ (new DataTile(options))\n    );\n    tile.key = this.getKey();\n    tile.addEventListener(EventType.CHANGE, this.handleTileChange_);\n\n    tileCache?.set(cacheKey, tile);\n    return tile;\n  }\n\n  /**\n   * Handle tile change events.\n   * @param {import(\"../events/Event.js\").default} event Event.\n   */\n  handleTileChange_(event) {\n    const tile = /** @type {import(\"../Tile.js\").default} */ (event.target);\n    const uid = getUid(tile);\n    const tileState = tile.getState();\n    let type;\n    if (tileState == TileState.LOADING) {\n      this.tileLoadingKeys_[uid] = true;\n      type = TileEventType.TILELOADSTART;\n    } else if (uid in this.tileLoadingKeys_) {\n      delete this.tileLoadingKeys_[uid];\n      type =\n        tileState == TileState.ERROR\n          ? TileEventType.TILELOADERROR\n          : tileState == TileState.LOADED\n            ? TileEventType.TILELOADEND\n            : undefined;\n    }\n    if (type) {\n      this.dispatchEvent(new TileSourceEvent(type, tile));\n    }\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {!import(\"../tilegrid/TileGrid.js\").default} Tile grid.\n   * @override\n   */\n  getTileGridForProjection(projection) {\n    const thisProj = this.getProjection();\n    if (\n      this.tileGrid &&\n      (!thisProj || equivalent(thisProj, projection)) &&\n      !this.transformMatrix\n    ) {\n      return this.tileGrid;\n    }\n\n    const projKey = getUid(projection);\n    if (!(projKey in this.tileGridForProjection_)) {\n      if (this.tileGrid && thisProj && !equivalent(thisProj, projection)) {\n        // Limit the target tile grid's zoom levels based on the source's\n        // finest available resolution to avoid creating excessive target\n        // tiles that all map to the same source data.\n        const sourceResolutions = this.tileGrid.getResolutions();\n        const sourceFinestRes = sourceResolutions[sourceResolutions.length - 1];\n        const sourceMetersPerUnit = thisProj.getMetersPerUnit() || 1;\n        const targetMetersPerUnit = projection.getMetersPerUnit() || 1;\n        const targetFinestRes =\n          (sourceFinestRes * sourceMetersPerUnit) / targetMetersPerUnit;\n        const extent = extentFromProjection(projection);\n        const tileSize = DEFAULT_TILE_SIZE;\n        const maxResolution = Math.max(\n          getWidth(extent) / tileSize,\n          getHeight(extent) / tileSize,\n        );\n        const maxZoom = Math.max(\n          0,\n          Math.ceil(Math.log2(maxResolution / targetFinestRes)) + 1,\n        );\n        this.tileGridForProjection_[projKey] = createForProjection(\n          projection,\n          maxZoom,\n        );\n      } else {\n        this.tileGridForProjection_[projKey] =\n          getTileGridForProjection(projection);\n      }\n    }\n    return this.tileGridForProjection_[projKey];\n  }\n\n  /**\n   * Sets the tile grid to use when reprojecting the tiles to the given\n   * projection instead of the default tile grid for the projection.\n   *\n   * This can be useful when the default tile grid cannot be created\n   * (e.g. projection has no extent defined) or\n   * for optimization reasons (custom tile size, resolutions, ...).\n   *\n   * @param {import(\"../proj.js\").ProjectionLike} projection Projection.\n   * @param {import(\"../tilegrid/TileGrid.js\").default} tilegrid Tile grid to use for the projection.\n   * @api\n   */\n  setTileGridForProjection(projection, tilegrid) {\n    const proj = getProjection(projection);\n    if (proj) {\n      const projKey = getUid(proj);\n      if (!(projKey in this.tileGridForProjection_)) {\n        this.tileGridForProjection_[projKey] = tilegrid;\n      }\n    }\n  }\n}\n\nexport default DataTileSource;\n","/**\n * @module ol/proj/proj4\n */\nimport {\n  addCoordinateTransforms,\n  addEquivalentProjections,\n  addProjection,\n  createSafeCoordinateTransform,\n} from '../proj.js';\nimport Projection from './Projection.js';\nimport {get as getCachedProjection} from './projections.js';\nimport {get as getTransform} from './transforms.js';\n\n/**\n * @type {import(\"proj4\")|null}\n */\nlet registered = null;\n\n/**\n * @return {boolean} Proj4 has been registered.\n */\nexport function isRegistered() {\n  return !!registered;\n}\n\n/**\n * Unsets the shared proj4 previously set with register.\n */\nexport function unregister() {\n  registered = null;\n}\n\n/**\n * Make projections defined in proj4 (with `proj4.defs()`) available in\n * OpenLayers. Requires proj4 >= 2.8.0.\n *\n * This function should be called whenever changes are made to the proj4\n * registry, e.g. after calling `proj4.defs()`. Existing transforms will not be\n * modified by this function.\n *\n * @param {import(\"proj4\")} proj4 Proj4.\n * @api\n */\nexport function register(proj4) {\n  registered = proj4;\n\n  const projCodes = Object.keys(proj4.defs);\n  const len = projCodes.length;\n  let i, j;\n  for (i = 0; i < len; ++i) {\n    const code = projCodes[i];\n    if (!getCachedProjection(code)) {\n      const def = proj4.defs(code);\n      let units = /** @type {import(\"./Units.js\").Units} */ (def.units);\n      if (!units && def.projName === 'longlat') {\n        units = 'degrees';\n      }\n      addProjection(\n        new Projection({\n          code: code,\n          axisOrientation: def.axis,\n          metersPerUnit: def.to_meter,\n          units,\n        }),\n      );\n    }\n  }\n  for (i = 0; i < len; ++i) {\n    const code1 = projCodes[i];\n    const proj1 = getCachedProjection(code1);\n    for (j = 0; j < len; ++j) {\n      const code2 = projCodes[j];\n      const proj2 = getCachedProjection(code2);\n      if (!getTransform(code1, code2)) {\n        if (proj4.defs[code1] === proj4.defs[code2]) {\n          addEquivalentProjections([proj1, proj2]);\n        } else {\n          const transform = proj4(code1, code2);\n          addCoordinateTransforms(\n            proj1,\n            proj2,\n            createSafeCoordinateTransform(proj1, proj2, transform.forward),\n            createSafeCoordinateTransform(proj2, proj1, transform.inverse),\n          );\n        }\n      }\n    }\n  }\n}\n\n/**\n * @param {string} code The projection code.\n * @return {Promise<string>} The WKT definition.\n */\nlet projLookup = async function (code) {\n  if (typeof code !== 'string' || !code.includes(':')) {\n    throw new Error('Invalid code');\n  }\n  const [authority, num] = code.toLowerCase().split(':', 2);\n  const response = await fetch(\n    `https://spatialreference.org/ref/${authority}/${num}/ogcwkt/`,\n  );\n  if (!response.ok) {\n    throw new Error(\n      `Unexpected response from spatialreference.org: ${response.status}`,\n    );\n  }\n  return response.text();\n};\n\n/**\n * Set the lookup function for getting proj4 or WKT definitions given an\n * projection code. By default, the {@link module:ol/proj/proj4.fromProjectionCode}\n * function uses the spatialreference.org website for WKT definitions.\n * This can be changed by providing a different lookup function.\n *\n * @param {function(string):Promise<string>} func The lookup function.\n * @api\n */\nexport function setProjectionCodeLookup(func) {\n  projLookup = func;\n}\n\n/**\n * Get the current projection code lookup function.\n *\n * @return {function(string):Promise<string>} The projection lookup function.\n */\nexport function getProjectionCodeLookup() {\n  return projLookup;\n}\n\n/**\n * Get a projection from a projection code (i.e., authority:number).\n * This function fetches the projection definition from the\n * https://spatialreference.org website, registers this definition for use with\n * proj4, and returns a configured projection.  You must call import proj4 and\n * call {@link module:ol/proj/proj4.register} before using this function.\n *\n * If the projection definition is already registered with proj4, it will not\n * be fetched again (so it is ok to call this function multiple times with the\n * same code).\n *\n * @param {string} code The projection code (e.g., 'EPSG:4326' or 'OGC:CRS84').\n * @return {Promise<Projection>} The projection.\n * @api\n */\nexport async function fromProjectionCode(code) {\n  const proj4 = registered;\n  if (!proj4) {\n    throw new Error('Proj4 must be registered first with register(proj4)');\n  }\n\n  if (proj4.defs(code)) {\n    return getCachedProjection(code);\n  }\n\n  proj4.defs(code, await projLookup(code));\n  register(proj4);\n\n  return getCachedProjection(code);\n}\n\n/**\n * @param {number} code The EPSG code.\n * @return {Promise<string>} The proj4 or WKT definition.\n * @deprecated Use {@link module:ol/proj/proj4.projLookup} instead.\n */\nlet epsgLookup = async function (code) {\n  return await projLookup('EPSG:' + code);\n};\n\n/**\n * Set the lookup function for getting proj4 or WKT definitions given an EPSG code.\n * By default, the {@link module:ol/proj/proj4.fromEPSGCode} function uses the\n * spatialreference.org website for WKT definitions.\n * This can be changed by providing a different lookup function.\n *\n * @param {function(number):Promise<string>} func The lookup function.\n * @api\n * @deprecated Use {@link module:ol/proj/proj4.setProjectionCodeLookup} instead.\n */\nexport function setEPSGLookup(func) {\n  epsgLookup = func;\n}\n\n/**\n * Get the current EPSG lookup function.\n *\n * @return {function(number):Promise<string>} The EPSG lookup function.\n * @deprecated Use {@link module:ol/proj/proj4.getProjectionCodeLookup} instead.\n */\nexport function getEPSGLookup() {\n  return epsgLookup;\n}\n\n/**\n * Get a projection from an EPSG code.  This function fetches the projection\n * definition from the spatialreference.org website, registers this definition\n * for use with proj4, and returns a configured projection.  You must call\n * import proj4 and call {@link module:ol/proj/proj4.register} before using this\n * function.\n *\n * If the projection definition is already registered with proj4, it will not\n * be fetched again (so it is ok to call this function multiple times with the\n * same code).\n *\n * @param {number|string} code The EPSG code (e.g. 4326 or 'EPSG:4326').\n * @return {Promise<Projection>} The projection.\n * @api\n * @deprecated Use {@link module:ol/proj/proj4.fromProjectionCode} instead.\n */\nexport async function fromEPSGCode(code) {\n  if (typeof code === 'number') {\n    code = 'EPSG:' + code;\n  }\n  return await fromProjectionCode(code);\n}\n\n/**\n * Generate an EPSG lookup function which uses the MapTiler Coordinates API to find projection\n * definitions which do not require proj4 to be configured to handle `+nadgrids` parameters.\n * Call {@link module:ol/proj/proj4.setEPSGLookup} use the function for lookups\n * `setEPSGLookup(epsgLookupMapTiler('{YOUR_MAPTILER_API_KEY_HERE}'))`.\n *\n * @param {string} key MapTiler API key.  Get your own API key at https://www.maptiler.com/cloud/.\n * @return {function(number):Promise<string>} The EPSG lookup function.\n * @api\n * @deprecated Not needed any more, the default lookup provides this functionality now.\n */\nexport function epsgLookupMapTiler(key) {\n  return async function (code) {\n    const response = await fetch(\n      `https://api.maptiler.com/coordinates/search/code:${code}.json?transformations=true&exports=true&key=${key}`,\n    );\n    if (!response.ok) {\n      throw new Error(\n        `Unexpected response from maptiler.com: ${response.status}`,\n      );\n    }\n    return response.json().then((json) => {\n      const results = json['results'];\n      if (results?.length > 0) {\n        const result = results.filter(\n          (r) =>\n            r['id']?.['authority'] === 'EPSG' && r['id']?.['code'] === code,\n        )[0];\n        if (result) {\n          const transforms = result['transformations'];\n          if (transforms?.length > 0) {\n            // use default transform if it does not require grids\n            const defaultTransform = result['default_transformation'];\n            if (\n              transforms.filter(\n                (t) =>\n                  t['id']?.['authority'] === defaultTransform?.['authority'] &&\n                  t['id']?.['code'] === defaultTransform?.['code'] &&\n                  t['grids']?.length === 0,\n              ).length > 0\n            ) {\n              return result['exports']?.['proj4'];\n            }\n            // otherwise use most accurate alternative without grids\n            const transform = transforms\n              .filter(\n                (t) =>\n                  t['grids']?.length === 0 &&\n                  t['target_crs']?.['authority'] === 'EPSG' &&\n                  t['target_crs']?.['code'] === 4326 &&\n                  t['deprecated'] === false &&\n                  t['usable'] === true,\n              )\n              .sort((t1, t2) => t1['accuracy'] - t2['accuracy'])[0]?.[\n              'exports'\n            ]?.['proj4'];\n            if (transform) {\n              return transform;\n            }\n          }\n          // fallback to default\n          return result['exports']?.['proj4'];\n        }\n      }\n    });\n  };\n}\n","/**\n * @module ol/source/static\n */\n\nimport {decode} from '../Image.js';\nimport {getHeight, getWidth} from '../extent.js';\n\n/**\n * @typedef {Object} LoaderOptions\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images.  Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for loaded images.\n * @property {import(\"../extent.js\").Extent} imageExtent Extent of the image in map coordinates.\n * This is the [left, bottom, right, top] map coordinates of your image. When using this loader with an\n * `ol/source/Image`, the same extent must be set as `extent` of the `ol/layer/Image`.\n * @property {string} url Image URL.\n * @property {function(HTMLImageElement, string): Promise<import('../DataTile.js').ImageLike>} [load] Function\n * to perform loading of the image. Receives the created `HTMLImageElement` and the desired `src` as argument and\n * returns a promise resolving to the loaded or decoded image. Default is {@link module:ol/Image.decode}.\n */\n\n/**\n * Creates a loader for static images.\n * @param {LoaderOptions} options Loader options.\n * @return {import(\"../Image.js\").ImageObjectPromiseLoader} Loader.\n * @api\n */\nexport function createLoader(options) {\n  const load = options.load || decode;\n  const extent = options.imageExtent;\n  const crossOrigin = options.crossOrigin ?? null;\n\n  return () => {\n    const image = new Image();\n    image.crossOrigin = crossOrigin;\n    if (options.referrerPolicy !== undefined) {\n      image.referrerPolicy = options.referrerPolicy;\n    }\n    return load(image, options.url).then((image) => {\n      const resolutionX = getWidth(extent) / image.width;\n      const resolutionY = getHeight(extent) / image.height;\n      const resolution =\n        resolutionX !== resolutionY ? [resolutionX, resolutionY] : resolutionY;\n      return {image, extent, resolution, pixelRatio: 1};\n    });\n  };\n}\n","/**\n * @module ol/source/ImageTile\n */\nimport {expandUrl, pickUrl, renderXYZTemplate} from '../uri.js';\nimport DataTileSource from './DataTile.js';\n\n/**\n * Image tile loading function.  The function is called with z, x, and y tile coordinates and\n * returns an {@link import(\"../DataTile.js\").ImageLike image} or a promise for the same.\n *\n * @typedef {function(number, number, number, import(\"./DataTile.js\").LoaderOptions):(import(\"../DataTile.js\").ImageLike|Promise<import(\"../DataTile.js\").ImageLike>)} Loader\n */\n\n/**\n * @typedef {function(number, number, number, import(\"./DataTile.js\").LoaderOptions):string} UrlGetter\n */\n\n/**\n * @typedef {string | Array<string> | UrlGetter} UrlLike\n */\n\n/**\n * @typedef {Object} Options\n * @property {UrlLike} [url] The image URL template.  In addition to a single URL template, an array of URL templates or a function\n * can be provided.  If a function is provided, it will be called with z, x, y tile coordinates and loader options and should\n * return a URL.\n * @property {Loader} [loader] Data loader.  Called with z, x, and y tile coordinates.\n * Returns an {@link import(\"../DataTile.js\").ImageLike image} for a tile or a promise for the same.\n * The promise should not resolve until the image is loaded.  If the `url` option is provided, a loader will be created.\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.\n * @property {number} [maxZoom=42] Optional max zoom level. Not used if `tileGrid` is provided.\n * @property {number} [minZoom=0] Optional min zoom level. Not used if `tileGrid` is provided.\n * @property {number|import(\"../size.js\").Size} [tileSize=[256, 256]] The pixel width and height of the source tiles.\n * This may be different than the rendered pixel size if a `tileGrid` is provided.\n * @property {number} [gutter=0] The size in pixels of the gutter around data tiles to ignore.\n * This allows artifacts of rendering at tile edges to be ignored.\n * Supported data should be wider and taller than the tile size by a value of `2 x gutter`.\n * @property {number} [maxResolution] Optional tile grid resolution at level zero. Not used if `tileGrid` is provided.\n * @property {import(\"../proj.js\").ProjectionLike} [projection='EPSG:3857'] Tile projection.\n * @property {import(\"../tilegrid/TileGrid.js\").default} [tileGrid] Tile grid.\n * @property {import(\"./Source.js\").State} [state] The source state.\n * @property {boolean} [wrapX=true] Render tiles beyond the antimeridian.\n * @property {number} [transition] Transition time when fading in new tiles (in miliseconds).\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.\n * @property {import('./DataTile.js').CrossOriginAttribute} [crossOrigin='anonymous'] The crossOrigin property to pass to loaders for image data.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for loaded images.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n */\n\nconst loadError = new Error('Image failed to load');\n\n/**\n * @param {string} template The image url template.\n * @param {number} z The tile z coordinate.\n * @param {number} x The tile x coordinate.\n * @param {number} y The tile y coordinate.\n * @param {import('./DataTile.js').LoaderOptions} options The loader options.\n * @return {Promise<HTMLImageElement>} Resolves with a loaded image.\n */\nfunction loadImage(template, z, x, y, options) {\n  return new Promise((resolve, reject) => {\n    const image = new Image();\n    image.crossOrigin = options.crossOrigin ?? null;\n    if (options.referrerPolicy !== undefined) {\n      image.referrerPolicy = options.referrerPolicy;\n    }\n    image.addEventListener('load', () => resolve(image));\n    image.addEventListener('error', () => reject(loadError));\n    image.src = renderXYZTemplate(template, z, x, y, options.maxY);\n  });\n}\n\n/**\n * @param {Array<string>} templates The url templates.\n * @return {Loader} The image loader.\n */\nfunction makeLoaderFromTemplates(templates) {\n  return function (z, x, y, options) {\n    const template = pickUrl(templates, z, x, y);\n    return loadImage(template, z, x, y, options);\n  };\n}\n\n/**\n * @param {UrlGetter} getter The url getter.\n * @return {Loader} The image loader.\n */\nfunction makeLoaderFromGetter(getter) {\n  return function (z, x, y, options) {\n    const url = getter(z, x, y, options);\n    return loadImage(url, z, x, y, options);\n  };\n}\n\n/**\n * @param {UrlLike} url The URL-like option.\n * @return {Loader} The tile loader.\n */\nfunction makeLoaderFromUrlLike(url) {\n  /**\n   * @type {Loader}\n   */\n  let loader;\n\n  if (Array.isArray(url)) {\n    loader = makeLoaderFromTemplates(url);\n  } else if (typeof url === 'string') {\n    const urls = expandUrl(url);\n    loader = makeLoaderFromTemplates(urls);\n  } else if (typeof url === 'function') {\n    loader = makeLoaderFromGetter(url);\n  } else {\n    throw new Error(\n      'The url option must be a single template, an array of templates, or a function for getting a URL',\n    );\n  }\n  return loader;\n}\n\nlet keyCount = 0;\n\n/**\n * @param {UrlLike} url The URL-like option.\n * @return {string} A key for the URL.\n */\nfunction keyFromUrlLike(url) {\n  if (Array.isArray(url)) {\n    return url.join('\\n');\n  }\n\n  if (typeof url === 'string') {\n    return url;\n  }\n\n  ++keyCount;\n  return 'url-function-key-' + keyCount;\n}\n\n/**\n * @classdesc\n * A source for typed array data tiles.\n *\n * @extends DataTileSource<import(\"../ImageTile.js\").default>\n * @fires import(\"./Tile.js\").TileSourceEvent\n * @api\n */\nclass ImageTileSource extends DataTileSource {\n  /**\n   * @param {Options} [options] DataTile source options.\n   */\n  constructor(options) {\n    options = options || {};\n\n    /**\n     * @type {Loader}\n     */\n    let loader = options.loader;\n\n    /**\n     * @type {string}\n     */\n    let key;\n\n    if (options.url) {\n      loader = makeLoaderFromUrlLike(options.url);\n      key = keyFromUrlLike(options.url);\n    }\n\n    /**\n     * @type {import('./Source.js').State}\n     */\n    const state = !loader ? 'loading' : options.state;\n\n    const wrapX = options.wrapX === undefined ? true : options.wrapX;\n\n    super({\n      loader: loader,\n      key: key,\n      attributions: options.attributions,\n      attributionsCollapsible: options.attributionsCollapsible,\n      maxZoom: options.maxZoom,\n      minZoom: options.minZoom,\n      tileSize: options.tileSize,\n      gutter: options.gutter,\n      maxResolution: options.maxResolution,\n      projection: options.projection,\n      tileGrid: options.tileGrid,\n      state: state,\n      wrapX: wrapX,\n      transition: options.transition,\n      interpolate: options.interpolate !== false,\n      crossOrigin: options.crossOrigin,\n      referrerPolicy: options.referrerPolicy,\n      zDirection: options.zDirection,\n    });\n  }\n\n  /**\n   * @param {UrlLike} url The new URL.\n   * @api\n   */\n  setUrl(url) {\n    const loader = makeLoaderFromUrlLike(url);\n    this.setLoader(loader);\n    this.setKey(keyFromUrlLike(url));\n    if (this.getState() !== 'ready') {\n      this.setState('ready');\n    }\n  }\n}\n\nexport default ImageTileSource;\n","/**\n * @module ol/source/wms\n */\n\nimport {decode} from '../Image.js';\nimport {getForViewAndSize, getHeight, getWidth} from '../extent.js';\nimport {floor, round} from '../math.js';\nimport {get as getProjection} from '../proj.js';\nimport {compareVersions} from '../string.js';\nimport {appendParams} from '../uri.js';\nimport {getRequestExtent} from './Image.js';\nimport {DECIMALS} from './common.js';\n\n/**\n * Default WMS version.\n * @type {string}\n */\nexport const DEFAULT_VERSION = '1.3.0';\n\n/**\n * @const\n * @type {import(\"../size.js\").Size}\n */\nconst GETFEATUREINFO_IMAGE_SIZE = [101, 101];\n\n/**\n * @api\n * @typedef {'carmentaserver' | 'geoserver' | 'mapserver' | 'qgis'} ServerType\n * Set the server type to use implementation-specific parameters beyond the WMS specification.\n *  - `'carmentaserver'`: HiDPI support for [Carmenta Server](https://www.carmenta.com/en/products/carmenta-server)\n *  - `'geoserver'`: HiDPI support for [GeoServer](https://geoserver.org/)\n *  - `'mapserver'`: HiDPI support for [MapServer](https://mapserver.org/)\n *  - `'qgis'`: HiDPI support for [QGIS](https://qgis.org/)\n */\n\n/**\n * @param {string} baseUrl Base URL.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @param {import(\"../size.js\").Size} size Size.\n * @param {import(\"../proj/Projection.js\").default} projection Projection.\n * @param {Object} params WMS params. Will be modified in place.\n * @return {string} Request URL.\n */\nexport function getRequestUrl(baseUrl, extent, size, projection, params) {\n  params['WIDTH'] = size[0];\n  params['HEIGHT'] = size[1];\n\n  const axisOrientation = projection.getAxisOrientation();\n  const v13 = compareVersions(params['VERSION'], '1.3') >= 0;\n  params[v13 ? 'CRS' : 'SRS'] = projection.getCode();\n  const bbox =\n    v13 && axisOrientation.startsWith('ne')\n      ? [extent[1], extent[0], extent[3], extent[2]]\n      : extent;\n  params['BBOX'] = bbox.join(',');\n\n  return appendParams(baseUrl, params);\n}\n\n/**\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @param {number} resolution Resolution.\n * @param {number} pixelRatio pixel ratio.\n * @param {import(\"../proj.js\").Projection} projection Projection.\n * @param {string} url WMS service url.\n * @param {Object} params WMS params.\n * @param {import(\"./wms.js\").ServerType} serverType The type of the remote WMS server.\n * @return {string} Image src.\n */\nexport function getImageSrc(\n  extent,\n  resolution,\n  pixelRatio,\n  projection,\n  url,\n  params,\n  serverType,\n) {\n  params = Object.assign({REQUEST: 'GetMap'}, params);\n\n  const imageResolution = resolution / pixelRatio;\n\n  const imageSize = [\n    round(getWidth(extent) / imageResolution, DECIMALS),\n    round(getHeight(extent) / imageResolution, DECIMALS),\n  ];\n\n  if (pixelRatio != 1) {\n    switch (serverType) {\n      case 'geoserver':\n        const dpi = (90 * pixelRatio + 0.5) | 0;\n        if ('FORMAT_OPTIONS' in params) {\n          params['FORMAT_OPTIONS'] += ';dpi:' + dpi;\n        } else {\n          params['FORMAT_OPTIONS'] = 'dpi:' + dpi;\n        }\n        break;\n      case 'mapserver':\n        params['MAP_RESOLUTION'] = 90 * pixelRatio;\n        break;\n      case 'carmentaserver':\n      case 'qgis':\n        params['DPI'] = 90 * pixelRatio;\n        break;\n      default:\n        throw new Error('Unknown `serverType` configured');\n    }\n  }\n\n  const src = getRequestUrl(url, extent, imageSize, projection, params);\n  return src;\n}\n\n/**\n * @param {Object} params WMS params.\n * @param {string} request WMS `REQUEST`.\n * @return {Object} WMS params with required properties set.\n */\nexport function getRequestParams(params, request) {\n  return Object.assign(\n    {\n      'REQUEST': request,\n      'SERVICE': 'WMS',\n      'VERSION': DEFAULT_VERSION,\n      'FORMAT': 'image/png',\n      'STYLES': '',\n      'TRANSPARENT': 'TRUE',\n    },\n    params,\n  );\n}\n\n/**\n * @typedef {Object} LoaderOptions\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images.  Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for loaded images.\n * @property {boolean} [hidpi=true] Use the `ol/Map#pixelRatio` value when requesting\n * the image from the remote server.\n * @property {Object<string,*>} [params] WMS request parameters.\n * At least a `LAYERS` param is required. `STYLES` is\n * `''` by default. `VERSION` is `1.3.0` by default. `WIDTH`, `HEIGHT` and `BBOX` will be set\n * dynamically. `CRS` (`SRS` for WMS version < 1.3.0) will is derived from the `proection` config.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is 'EPSG:3857'.\n * @property {number} [ratio=1.5] Ratio. `1` means image requests are the size of the map viewport, `2` means\n * twice the width and height of the map viewport, and so on. Must be `1` or higher.\n * @property {import(\"./wms.js\").ServerType} [serverType] The type of\n * the remote WMS server: `mapserver`, `geoserver`, `carmentaserver`, or `qgis`.\n * Only needed if `hidpi` is `true`.\n * @property {string} url WMS service URL.\n * @property {function(HTMLImageElement, string): Promise<import('../DataTile.js').ImageLike>} [load] Function\n * to perform loading of the image. Receives the created `HTMLImageElement` and the desired `src` as argument and\n * returns a promise resolving to the loaded or decoded image. Default is {@link module:ol/Image.decode}.\n */\n\n/**\n * Creates a loader for WMS images.\n * @param {LoaderOptions} options Loader options.\n * @return {import(\"../Image.js\").ImageObjectPromiseLoader} Loader.\n * @api\n */\nexport function createLoader(options) {\n  const hidpi = options.hidpi === undefined ? true : options.hidpi;\n  const projection = getProjection(options.projection || 'EPSG:3857');\n  const ratio = options.ratio || 1.5;\n  const load = options.load || decode;\n  const crossOrigin = options.crossOrigin ?? null;\n  const referrerPolicy = options.referrerPolicy;\n\n  return (extent, resolution, pixelRatio) => {\n    extent = getRequestExtent(extent, resolution, pixelRatio, ratio);\n    if (pixelRatio != 1 && (!hidpi || options.serverType === undefined)) {\n      pixelRatio = 1;\n    }\n    const src = getImageSrc(\n      extent,\n      resolution,\n      pixelRatio,\n      projection,\n      options.url,\n      getRequestParams(options.params, 'GetMap'),\n      options.serverType,\n    );\n    const image = new Image();\n    image.crossOrigin = crossOrigin;\n    if (referrerPolicy !== undefined) {\n      image.referrerPolicy = referrerPolicy;\n    }\n    return load(image, src).then((image) => ({image, extent, pixelRatio}));\n  };\n}\n\n/**\n * Get the GetFeatureInfo URL for the passed coordinate and resolution. Returns `undefined` if the\n * GetFeatureInfo URL cannot be constructed.\n * @param {LoaderOptions} options Options passed the `createWMSLoader()` function. In addition to\n * the params required by the loader, `INFO_FORMAT` should be specified, it defaults to\n * `application/json`. If `QUERY_LAYERS` is not provided, then the layers specified in the `LAYERS`\n * parameter will be used.\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {number} resolution Resolution.\n * @return {string|undefined} GetFeatureInfo URL.\n * @api\n */\nexport function getFeatureInfoUrl(options, coordinate, resolution) {\n  if (options.url === undefined) {\n    return undefined;\n  }\n\n  const projectionObj = getProjection(options.projection || 'EPSG:3857');\n\n  const extent = getForViewAndSize(\n    coordinate,\n    resolution,\n    0,\n    GETFEATUREINFO_IMAGE_SIZE,\n  );\n\n  const baseParams = {\n    'QUERY_LAYERS': options.params['LAYERS'],\n    'INFO_FORMAT': 'application/json',\n  };\n  Object.assign(\n    baseParams,\n    getRequestParams(options.params, 'GetFeatureInfo'),\n    options.params,\n  );\n\n  const x = floor((coordinate[0] - extent[0]) / resolution, DECIMALS);\n  const y = floor((extent[3] - coordinate[1]) / resolution, DECIMALS);\n  const v13 = compareVersions(baseParams['VERSION'], '1.3') >= 0;\n  baseParams[v13 ? 'I' : 'X'] = x;\n  baseParams[v13 ? 'J' : 'Y'] = y;\n\n  return getRequestUrl(\n    options.url,\n    extent,\n    GETFEATUREINFO_IMAGE_SIZE,\n    projectionObj,\n    baseParams,\n  );\n}\n\n/**\n * Get the GetLegendGraphic URL, optionally optimized for the passed resolution and possibly\n * including any passed specific parameters. Returns `undefined` if the GetLegendGraphic URL\n * cannot be constructed.\n *\n * @param {LoaderOptions} options Options passed the `createWMSLoader()` function.\n * @param {number} [resolution] Resolution. If not provided, `SCALE` will not be calculated and\n * included in URL.\n * @return {string|undefined} GetLegendGraphic URL.\n * @api\n */\nexport function getLegendUrl(options, resolution) {\n  if (options.url === undefined) {\n    return undefined;\n  }\n\n  const baseParams = {\n    'SERVICE': 'WMS',\n    'VERSION': DEFAULT_VERSION,\n    'REQUEST': 'GetLegendGraphic',\n    'FORMAT': 'image/png',\n  };\n\n  if (resolution !== undefined) {\n    const mpu =\n      getProjection(options.projection || 'EPSG:3857').getMetersPerUnit() || 1;\n    const pixelSize = 0.00028;\n    baseParams['SCALE'] = (resolution * mpu) / pixelSize;\n  }\n\n  Object.assign(baseParams, options.params);\n\n  if (options.params !== undefined && baseParams['LAYER'] === undefined) {\n    const layers = baseParams['LAYERS'];\n    const isSingleLayer = !Array.isArray(layers) || layers.length !== 1;\n    if (!isSingleLayer) {\n      return undefined;\n    }\n    baseParams['LAYER'] = layers;\n  }\n\n  return appendParams(options.url, baseParams);\n}\n","/**\n * @module ol/source/ogcTileUtil\n */\n\nimport {error as logError} from '../console.js';\nimport {getIntersection as intersectExtents} from '../extent.js';\nimport {getJSON, resolveUrl} from '../net.js';\nimport {get as getProjection} from '../proj.js';\nimport TileGrid from '../tilegrid/WMTS.js';\n\n/**\n * See https://ogcapi.ogc.org/tiles/.\n */\n\n/**\n * @typedef {'map' | 'vector'} TileType\n */\n\n/**\n * @typedef {'topLeft' | 'bottomLeft'} CornerOfOrigin\n */\n\n/**\n * @typedef {Object} TileSet\n * @property {TileType} dataType Type of data represented in the tileset.\n * @property {string} [tileMatrixSetDefinition] Reference to a tile matrix set definition.\n * @property {TileMatrixSet} [tileMatrixSet] Tile matrix set definition.\n * @property {Array<TileMatrixSetLimit>} [tileMatrixSetLimits] Tile matrix set limits.\n * @property {Array<Link>} links Tileset links.\n */\n\n/**\n * @typedef {Object} Link\n * @property {string} rel The link rel attribute.\n * @property {string} href The link URL.\n * @property {string} type The link type.\n */\n\n/**\n * @typedef {Object} TileMatrixSetLimit\n * @property {string} tileMatrix The tile matrix id.\n * @property {number} minTileRow The minimum tile row.\n * @property {number} maxTileRow The maximum tile row.\n * @property {number} minTileCol The minimum tile column.\n * @property {number} maxTileCol The maximum tile column.\n */\n\n/**\n * @typedef {Object} TileMatrixSet\n * @property {string} id The tile matrix set identifier.\n * @property {string|CrsUri|CrsWkt|CrsReferenceSystem} crs The coordinate reference system.\n * @property {Array<string>} [orderedAxes] Axis order.\n * @property {Array<TileMatrix>} tileMatrices Array of tile matrices.\n */\n\n/**\n * @typedef {Object} CrsUri\n * @property {string} uri Reference to one coordinate reference system (CRS).\n */\n\n/**\n * @typedef {Object} CrsWkt\n * @property {Object} wkt JSON encoding for WKT representation of CRS 2.0.\n */\n\n/**\n * @typedef {Object} CrsReferenceSystem\n * @property {Object} referenceSystem Data structure as defined in the MD_ReferenceSystem of the ISO 19115.\n */\n\n/**\n * @typedef {Object} TileMatrix\n * @property {string} id The tile matrix identifier.\n * @property {number} cellSize The pixel resolution (map units per pixel).\n * @property {Array<number>} pointOfOrigin The map location of the matrix origin.\n * @property {CornerOfOrigin} [cornerOfOrigin='topLeft'] The corner of the matrix that represents the origin ('topLeft' or 'bottomLeft').\n * @property {number} matrixWidth The number of columns.\n * @property {number} matrixHeight The number of rows.\n * @property {number} tileWidth The pixel width of a tile.\n * @property {number} tileHeight The pixel height of a tile.\n */\n\n/**\n * @type {Object<string, boolean>}\n */\nconst knownMapMediaTypes = {\n  'image/png': true,\n  'image/jpeg': true,\n  'image/gif': true,\n  'image/webp': true,\n};\n\n/**\n * @type {Object<string, boolean>}\n */\nconst knownVectorMediaTypes = {\n  'application/vnd.mapbox-vector-tile': true,\n  'application/geo+json': true,\n};\n\n/**\n * @typedef {Object} TileSetInfo\n * @property {string} [urlTemplate] The tile URL template.\n * @property {import(\"../proj/Projection.js\").default} projection The source projection.\n * @property {import(\"../tilegrid/WMTS.js\").default} grid The tile grid.\n * @property {import(\"../Tile.js\").UrlFunction} [urlFunction] The tile URL function.\n */\n\n/**\n * @typedef {Object} SourceInfo\n * @property {string} [url] The tile set URL.\n * @property {string} [mediaType] The preferred tile media type.\n * @property {Array<string>} [supportedMediaTypes] The supported media types.\n * @property {import(\"../proj/Projection.js\").default} [projection] The source projection.\n * @property {Object} [context] Optional context for constructing the URL.\n * @property {Array<string>} [collections] Optional collections to append the URL with.\n */\n\n/**\n * @param {string} tileUrlTemplate Tile URL template.\n * @param {Array<string>} collections List of collections to include as query parameter.\n * @return {string} The tile URL template with appended collections query parameter.\n */\nexport function appendCollectionsQueryParam(tileUrlTemplate, collections) {\n  if (!collections.length) {\n    return tileUrlTemplate;\n  }\n\n  // making sure we can always construct a URL instance.\n  const url = new URL(tileUrlTemplate, 'file:/');\n\n  if (url.pathname.split('/').includes('collections')) {\n    logError(\n      'The \"collections\" query parameter cannot be added to collection endpoints',\n    );\n    return tileUrlTemplate;\n  }\n  // According to conformance class\n  // http://www.opengis.net/spec/ogcapi-tiles-1/1.0/conf/collections-selection\n  // commata in the identifiers of the `collections` query parameter\n  // need to be URLEncoded, while the commata separating the identifiers\n  // should not.\n  const encodedCollections = collections\n    .map((c) => encodeURIComponent(c))\n    .join(',');\n\n  url.searchParams.append('collections', encodedCollections);\n  const baseUrl = tileUrlTemplate.split('?')[0];\n  const queryParams = decodeURIComponent(url.searchParams.toString());\n  return `${baseUrl}?${queryParams}`;\n}\n\n/**\n * @param {Array<Link>} links Tileset links.\n * @param {string} [mediaType] The preferred media type.\n * @param {Array<string>} [collections] Optional collections to append the URL with.\n * @return {string} The tile URL template.\n */\nexport function getMapTileUrlTemplate(links, mediaType, collections) {\n  let tileUrlTemplate;\n  let fallbackUrlTemplate;\n  for (let i = 0; i < links.length; ++i) {\n    const link = links[i];\n    if (link.rel === 'item') {\n      if (link.type === mediaType) {\n        tileUrlTemplate = link.href;\n        break;\n      }\n      if (knownMapMediaTypes[link.type]) {\n        fallbackUrlTemplate = link.href;\n      } else if (!fallbackUrlTemplate && link.type.startsWith('image/')) {\n        fallbackUrlTemplate = link.href;\n      }\n    }\n  }\n\n  if (!tileUrlTemplate) {\n    if (fallbackUrlTemplate) {\n      tileUrlTemplate = fallbackUrlTemplate;\n    } else {\n      throw new Error('Could not find \"item\" link');\n    }\n  }\n\n  if (collections) {\n    tileUrlTemplate = appendCollectionsQueryParam(tileUrlTemplate, collections);\n  }\n\n  return tileUrlTemplate;\n}\n\n/**\n * @param {Array<Link>} links Tileset links.\n * @param {string} [mediaType] The preferred media type.\n * @param {Array<string>} [supportedMediaTypes] The media types supported by the parser.\n * @param {Array<string>} [collections] Optional collections to append the URL with.\n * @return {string} The tile URL template.\n */\nexport function getVectorTileUrlTemplate(\n  links,\n  mediaType,\n  supportedMediaTypes,\n  collections,\n) {\n  let tileUrlTemplate;\n  let fallbackUrlTemplate;\n\n  /**\n   * Lookup of URL by media type.\n   * @type {Object<string, string>}\n   */\n  const hrefLookup = {};\n\n  for (let i = 0; i < links.length; ++i) {\n    const link = links[i];\n    hrefLookup[link.type] = link.href;\n    if (link.rel === 'item') {\n      if (link.type === mediaType) {\n        tileUrlTemplate = link.href;\n        break;\n      }\n      if (knownVectorMediaTypes[link.type]) {\n        fallbackUrlTemplate = link.href;\n      }\n    }\n  }\n\n  if (!tileUrlTemplate && supportedMediaTypes) {\n    for (let i = 0; i < supportedMediaTypes.length; ++i) {\n      const supportedMediaType = supportedMediaTypes[i];\n      if (hrefLookup[supportedMediaType]) {\n        tileUrlTemplate = hrefLookup[supportedMediaType];\n        break;\n      }\n    }\n  }\n\n  if (!tileUrlTemplate) {\n    if (fallbackUrlTemplate) {\n      tileUrlTemplate = fallbackUrlTemplate;\n    } else {\n      throw new Error('Could not find \"item\" link');\n    }\n  }\n\n  if (collections) {\n    tileUrlTemplate = appendCollectionsQueryParam(tileUrlTemplate, collections);\n  }\n\n  return tileUrlTemplate;\n}\n\n/**\n * @param {SourceInfo} sourceInfo The source info.\n * @param {TileMatrixSet} tileMatrixSet Tile matrix set.\n * @param {string} [tileUrlTemplate] Tile URL template.\n * @param {Array<TileMatrixSetLimit>} [tileMatrixSetLimits] Tile matrix set limits.\n * @return {TileSetInfo} Tile set info.\n */\nexport function parseTileMatrixSet(\n  sourceInfo,\n  tileMatrixSet,\n  tileUrlTemplate,\n  tileMatrixSetLimits,\n) {\n  let projection = sourceInfo.projection;\n  if (!projection) {\n    if (typeof tileMatrixSet.crs === 'string') {\n      projection = getProjection(tileMatrixSet.crs);\n    } else if ('uri' in tileMatrixSet.crs) {\n      projection = getProjection(tileMatrixSet.crs.uri);\n    }\n    if (!projection) {\n      throw new Error(`Unsupported CRS: ${JSON.stringify(tileMatrixSet.crs)}`);\n    }\n  }\n  const orderedAxes = tileMatrixSet.orderedAxes;\n  const axisOrientation = orderedAxes\n    ? orderedAxes\n        .slice(0, 2)\n        .map((s) => s.replace(/E|X|Lon/i, 'e').replace(/N|Y|Lat/i, 'n'))\n        .join('')\n    : projection.getAxisOrientation();\n  const backwards = !axisOrientation.startsWith('en');\n\n  const matrices = tileMatrixSet.tileMatrices.sort(function (a, b) {\n    return b.cellSize - a.cellSize;\n  });\n\n  /**\n   * @type {Object<string, TileMatrix>}\n   */\n  const matrixLookup = {};\n  for (let i = 0; i < matrices.length; ++i) {\n    const matrix = matrices[i];\n    matrixLookup[matrix.id] = matrix;\n  }\n\n  /**\n   * @type {Object<string, TileMatrixSetLimit>}\n   */\n  const limitLookup = {};\n\n  /**\n   * @type {Array<string>}\n   */\n  const matrixIds = [];\n\n  if (tileMatrixSetLimits) {\n    for (let i = 0; i < tileMatrixSetLimits.length; ++i) {\n      const limit = tileMatrixSetLimits[i];\n      const id = limit.tileMatrix;\n      const matrix = matrixLookup[id];\n      const zoomLevel = matrices.indexOf(matrix);\n      matrixIds[zoomLevel] = id;\n      limitLookup[id] = limit;\n    }\n  } else {\n    for (let i = 0; i < matrices.length; ++i) {\n      const id = matrices[i].id;\n      matrixIds.push(id);\n    }\n  }\n\n  const length = matrixIds.length;\n  const origins = new Array(length);\n  const resolutions = new Array(length);\n  const sizes = new Array(length);\n  const tileSizes = new Array(length);\n  const extent = [-Infinity, -Infinity, Infinity, Infinity];\n\n  for (let i = 0; i < length; ++i) {\n    const id = matrixIds[i];\n    const matrix = matrixLookup[id];\n    const origin = matrix.pointOfOrigin;\n    if (backwards) {\n      origins[i] = [origin[1], origin[0]];\n    } else {\n      origins[i] = origin;\n    }\n    resolutions[i] = matrix.cellSize;\n    sizes[i] = [matrix.matrixWidth, matrix.matrixHeight];\n    tileSizes[i] = [matrix.tileWidth, matrix.tileHeight];\n    const limit = limitLookup[id];\n    if (limit) {\n      const tileMapWidth = matrix.cellSize * matrix.tileWidth;\n      const minX = origins[i][0] + limit.minTileCol * tileMapWidth;\n      const maxX = origins[i][0] + (limit.maxTileCol + 1) * tileMapWidth;\n\n      const tileMapHeight = matrix.cellSize * matrix.tileHeight;\n      const upsideDown = matrix.cornerOfOrigin === 'bottomLeft';\n\n      let minY;\n      let maxY;\n      if (upsideDown) {\n        minY = origins[i][1] + limit.minTileRow * tileMapHeight;\n        maxY = origins[i][1] + (limit.maxTileRow + 1) * tileMapHeight;\n      } else {\n        minY = origins[i][1] - (limit.maxTileRow + 1) * tileMapHeight;\n        maxY = origins[i][1] - limit.minTileRow * tileMapHeight;\n      }\n\n      intersectExtents(extent, [minX, minY, maxX, maxY], extent);\n    }\n  }\n\n  const tileGrid = new TileGrid({\n    origins,\n    resolutions,\n    sizes,\n    tileSizes,\n    extent: tileMatrixSetLimits ? extent : undefined,\n    matrixIds,\n  });\n\n  if (!tileUrlTemplate) {\n    return {\n      grid: tileGrid,\n      projection: projection,\n    };\n  }\n\n  const context = sourceInfo.context;\n  const base = sourceInfo.url;\n\n  /** @type {import('../Tile.js').UrlFunction} */\n  function tileUrlFunction(tileCoord, pixelRatio, projection) {\n    if (!tileCoord) {\n      return undefined;\n    }\n\n    const id = matrixIds[tileCoord[0]];\n    const matrix = matrixLookup[id];\n    const upsideDown = matrix.cornerOfOrigin === 'bottomLeft';\n\n    const localContext = {\n      tileMatrix: id,\n      tileCol: tileCoord[1],\n      tileRow: upsideDown ? -tileCoord[2] - 1 : tileCoord[2],\n    };\n\n    if (tileMatrixSetLimits) {\n      const limit = limitLookup[matrix.id];\n      if (\n        localContext.tileCol < limit.minTileCol ||\n        localContext.tileCol > limit.maxTileCol ||\n        localContext.tileRow < limit.minTileRow ||\n        localContext.tileRow > limit.maxTileRow\n      ) {\n        return undefined;\n      }\n    }\n\n    Object.assign(\n      localContext,\n      {\n        z: localContext.tileMatrix,\n        x: localContext.tileCol,\n        y: localContext.tileRow,\n      },\n      context,\n    );\n\n    const url = tileUrlTemplate.replace(/\\{(\\w+?)\\}/g, function (m, p) {\n      return localContext[p];\n    });\n\n    return resolveUrl(base, url);\n  }\n\n  return {\n    grid: tileGrid,\n    projection: projection,\n    urlTemplate: tileUrlTemplate,\n    urlFunction: tileUrlFunction,\n  };\n}\n\n/**\n * @param {SourceInfo} sourceInfo The source info.\n * @param {TileSet} tileSet Tile set.\n * @return {TileSetInfo|Promise<TileSetInfo>} Tile set info.\n */\nfunction parseTileSetMetadata(sourceInfo, tileSet) {\n  const tileMatrixSetLimits = tileSet.tileMatrixSetLimits;\n  /** @type {string} */\n  let tileUrlTemplate;\n\n  if (tileSet.dataType === 'map') {\n    tileUrlTemplate = getMapTileUrlTemplate(\n      tileSet.links,\n      sourceInfo.mediaType,\n      sourceInfo.collections,\n    );\n  } else if (tileSet.dataType === 'vector') {\n    tileUrlTemplate = getVectorTileUrlTemplate(\n      tileSet.links,\n      sourceInfo.mediaType,\n      sourceInfo.supportedMediaTypes,\n      sourceInfo.collections,\n    );\n  } else {\n    throw new Error('Expected tileset data type to be \"map\" or \"vector\"');\n  }\n\n  if (tileSet.tileMatrixSet) {\n    return parseTileMatrixSet(\n      sourceInfo,\n      tileSet.tileMatrixSet,\n      tileUrlTemplate,\n      tileMatrixSetLimits,\n    );\n  }\n\n  const tileMatrixSetLink = tileSet.links.find(\n    (link) =>\n      link.rel === 'http://www.opengis.net/def/rel/ogc/1.0/tiling-scheme',\n  );\n  if (!tileMatrixSetLink) {\n    throw new Error(\n      'Expected http://www.opengis.net/def/rel/ogc/1.0/tiling-scheme link or tileMatrixSet',\n    );\n  }\n  const tileMatrixSetDefinition = tileMatrixSetLink.href;\n\n  const url = resolveUrl(sourceInfo.url, tileMatrixSetDefinition);\n  return getJSON(url).then(function (tileMatrixSet) {\n    return parseTileMatrixSet(\n      sourceInfo,\n      tileMatrixSet,\n      tileUrlTemplate,\n      tileMatrixSetLimits,\n    );\n  });\n}\n\n/**\n * @param {SourceInfo} sourceInfo Source info.\n * @return {Promise<TileSetInfo>} Tile set info.\n */\nexport function getTileSetInfo(sourceInfo) {\n  return getJSON(sourceInfo.url).then(function (tileSet) {\n    return parseTileSetMetadata(sourceInfo, tileSet);\n  });\n}\n","/**\n * @module ol/source/OSM\n */\n\nimport XYZ from './XYZ.js';\n\n/**\n * The attribution containing a link to the OpenStreetMap Copyright and License\n * page.\n * @const\n * @type {string}\n * @api\n */\nexport const ATTRIBUTION =\n  '&#169; ' +\n  '<a href=\"https://www.openstreetmap.org/copyright\" target=\"_blank\">OpenStreetMap</a> ' +\n  'contributors.';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {number} [cacheSize] Deprecated.  Use the cacheSize option on the layer instead.\n * @property {null|string} [crossOrigin='anonymous'] The `crossOrigin` attribute for loaded images.  Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {ReferrerPolicy} [referrerPolicy='origin-when-cross-origin'] The `referrerPolicy` property for loaded images.\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * linear interpolation is used when resampling.  Set to false to use the nearest neighbor instead.\n * @property {number} [maxZoom=19] Max zoom.\n * @property {number} [reprojectionErrorThreshold=0.5] Maximum allowed reprojection error (in pixels).\n * Higher values can increase reprojection performance, but decrease precision.\n * @property {import(\"../Tile.js\").LoadFunction} [tileLoadFunction] Optional function to load a tile given a URL. The default is\n * ```js\n * function(imageTile, src) {\n *   imageTile.getImage().src = src;\n * };\n * ```\n * @property {number} [transition=250] Duration of the opacity transition for rendering.\n * To disable the opacity transition, pass `transition: 0`.\n * @property {string} [url='https://tile.openstreetmap.org/{z}/{x}/{y}.png'] URL template.\n * Must include `{x}`, `{y}` or `{-y}`, and `{z}` placeholders.\n * @property {boolean} [wrapX=true] Whether to wrap the world horizontally.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n */\n\n/**\n * @classdesc\n * Layer source for the OpenStreetMap tile server.\n * @api\n */\nclass OSM extends XYZ {\n  /**\n   * @param {Options} [options] Open Street Map options.\n   */\n  constructor(options) {\n    options = options || {};\n\n    let attributions;\n    if (options.attributions !== undefined) {\n      attributions = options.attributions;\n    } else {\n      attributions = [ATTRIBUTION];\n    }\n\n    const url =\n      options.url !== undefined\n        ? options.url\n        : 'https://tile.openstreetmap.org/{z}/{x}/{y}.png';\n\n    super({\n      attributions: attributions,\n      attributionsCollapsible: false,\n      cacheSize: options.cacheSize,\n      crossOrigin:\n        options.crossOrigin !== undefined ? options.crossOrigin : 'anonymous',\n      referrerPolicy: options.referrerPolicy || 'origin-when-cross-origin',\n      interpolate: options.interpolate,\n      maxZoom: options.maxZoom !== undefined ? options.maxZoom : 19,\n      reprojectionErrorThreshold: options.reprojectionErrorThreshold,\n      tileLoadFunction: options.tileLoadFunction,\n      transition: options.transition,\n      url: url,\n      wrapX: options.wrapX,\n      zDirection: options.zDirection,\n    });\n  }\n}\n\nexport default OSM;\n","/**\n * @module ol/render/canvas/ZIndexContext\n */\n\nimport {getSharedCanvasContext2D} from '../../dom.js';\n\n/** @typedef {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D & {globalAlpha: any}} ZIndexContextProxy */\n\n/**\n * @extends {CanvasRenderingContext2D}\n */\nclass ZIndexContext {\n  constructor() {\n    /**\n     * @private\n     * @type {Array<Array<*>>}\n     */\n    this.instructions_ = [];\n    /**\n     * @type {number}\n     */\n    this.zIndex = 0;\n    /**\n     * @private\n     * @type {number}\n     */\n    this.offset_ = 0;\n\n    /**\n     * @private\n     * @type {ZIndexContextProxy}\n     */\n    this.context_ = /** @type {ZIndexContextProxy} */ (\n      new Proxy(getSharedCanvasContext2D(), {\n        get: (target, property) => {\n          if (\n            typeof (/** @type {*} */ (getSharedCanvasContext2D())[property]) !==\n            'function'\n          ) {\n            // we only accept calling functions on the proxy, not accessing properties\n            return undefined;\n          }\n          this.push_(property);\n          return this.pushMethodArgs_;\n        },\n        set: (target, property, value) => {\n          this.push_(property, value);\n          return true;\n        },\n      })\n    );\n  }\n\n  /**\n   * @param {...*} args Arguments to push to the instructions array.\n   * @private\n   */\n  push_(...args) {\n    const instructions = this.instructions_;\n    const index = this.zIndex + this.offset_;\n    if (!instructions[index]) {\n      instructions[index] = [];\n    }\n    instructions[index].push(...args);\n  }\n\n  /**\n   * @private\n   * @param {...*} args Args.\n   * @return {ZIndexContext} This.\n   */\n  pushMethodArgs_ = (...args) => {\n    this.push_(args);\n    return this;\n  };\n\n  /**\n   * Push a function that renders to the context directly.\n   * @param {function(CanvasRenderingContext2D): void} render Function.\n   */\n  pushFunction(render) {\n    this.push_(render);\n  }\n\n  /**\n   * Get a proxy for CanvasRenderingContext2D which does not support getting state\n   * (e.g. `context.globalAlpha`, which will return `undefined`). To set state, if it relies on a\n   * previous state (e.g. `context.globalAlpha = context.globalAlpha / 2`), set a function,\n   * e.g. `context.globalAlpha = (context) => context.globalAlpha / 2`.\n   * @return {ZIndexContextProxy} Context.\n   */\n  getContext() {\n    return this.context_;\n  }\n\n  /**\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context Context.\n   */\n  draw(context) {\n    this.instructions_.forEach((instructionsAtIndex) => {\n      for (let i = 0, ii = instructionsAtIndex.length; i < ii; ++i) {\n        const property = instructionsAtIndex[i];\n        if (typeof property === 'function') {\n          property(context);\n          continue;\n        }\n        const instructionAtIndex = instructionsAtIndex[++i];\n        if (typeof (/** @type {*} */ (context)[property]) === 'function') {\n          /** @type {*} */ (context)[property](...instructionAtIndex);\n        } else {\n          if (typeof instructionAtIndex === 'function') {\n            /** @type {*} */ (context)[property] = instructionAtIndex(context);\n            continue;\n          }\n          /** @type {*} */ (context)[property] = instructionAtIndex;\n        }\n      }\n    });\n  }\n\n  clear() {\n    this.instructions_.length = 0;\n    this.zIndex = 0;\n    this.offset_ = 0;\n  }\n\n  /**\n   * Offsets the zIndex by the highest current zIndex. Useful for rendering multiple worlds or tiles, to\n   * avoid conflicting context.clip() or context.save()/restore() calls.\n   */\n  offset() {\n    this.offset_ = this.instructions_.length;\n    this.zIndex = 0;\n  }\n}\n\nexport default ZIndexContext;\n","/**\n * @module ol/renderer/Layer\n */\nimport ImageState from '../ImageState.js';\nimport Observable from '../Observable.js';\nimport EventType from '../events/EventType.js';\nimport {abstract} from '../util.js';\n\nconst maxStaleKeys = 5;\n\n/**\n * @template {import(\"../layer/Layer.js\").default} LayerType\n */\nclass LayerRenderer extends Observable {\n  /**\n   * @param {LayerType} layer Layer.\n   */\n  constructor(layer) {\n    super();\n\n    /**\n     * The renderer is initialized and ready to render.\n     * @type {boolean}\n     */\n    this.ready = true;\n\n    /** @private */\n    this.boundHandleImageChange_ = this.handleImageChange_.bind(this);\n\n    /**\n     * @private\n     * @type {LayerType}\n     */\n    this.layer_ = layer;\n\n    /**\n     * @type {Array<string>}\n     * @private\n     */\n    this.staleKeys_ = new Array();\n\n    /**\n     * @type {number}\n     * @protected\n     */\n    this.maxStaleKeys = maxStaleKeys;\n  }\n\n  /**\n   * @return {Array<string>} Get the list of stale keys.\n   */\n  getStaleKeys() {\n    return this.staleKeys_;\n  }\n\n  /**\n   * @param {string} key The new stale key.\n   */\n  prependStaleKey(key) {\n    this.staleKeys_.unshift(key);\n    if (this.staleKeys_.length > this.maxStaleKeys) {\n      this.staleKeys_.length = this.maxStaleKeys;\n    }\n  }\n\n  /**\n   * Asynchronous layer level hit detection.\n   * @param {import(\"../pixel.js\").Pixel} pixel Pixel.\n   * @return {Promise<Array<import(\"../Feature.js\").FeatureLike>>} Promise that resolves with\n   * an array of features.\n   */\n  getFeatures(pixel) {\n    return abstract();\n  }\n\n  /**\n   * @param {import(\"../pixel.js\").Pixel} pixel Pixel.\n   * @return {Uint8ClampedArray|Uint8Array|Float32Array|DataView|null} Pixel data.\n   */\n  getData(pixel) {\n    return null;\n  }\n\n  /**\n   * Determine whether render should be called.\n   * @abstract\n   * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n   * @return {boolean} Layer is ready to be rendered.\n   */\n  prepareFrame(frameState) {\n    return abstract();\n  }\n\n  /**\n   * Render the layer.\n   * @abstract\n   * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n   * @param {HTMLElement|null} target Target that may be used to render content to.\n   * @return {HTMLElement} The rendered element.\n   */\n  renderFrame(frameState, target) {\n    return abstract();\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n   * @param {number} hitTolerance Hit tolerance in pixels.\n   * @param {import(\"./vector.js\").FeatureCallback<T>} callback Feature callback.\n   * @param {Array<import(\"./Map.js\").HitMatch<T>>} matches The hit detected matches with tolerance.\n   * @return {T|undefined} Callback result.\n   * @template T\n   */\n  forEachFeatureAtCoordinate(\n    coordinate,\n    frameState,\n    hitTolerance,\n    callback,\n    matches,\n  ) {\n    return undefined;\n  }\n\n  /**\n   * @return {LayerType} Layer.\n   */\n  getLayer() {\n    return this.layer_;\n  }\n\n  /**\n   * Perform action necessary to get the layer rendered after new fonts have loaded\n   * @abstract\n   */\n  handleFontsChanged() {}\n\n  /**\n   * Handle changes in image state.\n   * @param {import(\"../events/Event.js\").default} event Image change event.\n   * @private\n   */\n  handleImageChange_(event) {\n    const image = /** @type {import(\"../Image.js\").default} */ (event.target);\n    if (\n      image.getState() === ImageState.LOADED ||\n      image.getState() === ImageState.ERROR\n    ) {\n      this.renderIfReadyAndVisible();\n    }\n  }\n\n  /**\n   * Load the image if not already loaded, and register the image change\n   * listener if needed.\n   * @param {import(\"../Image.js\").default} image Image.\n   * @return {boolean} `true` if the image is already loaded, `false` otherwise.\n   * @protected\n   */\n  loadImage(image) {\n    let imageState = image.getState();\n    if (imageState != ImageState.LOADED && imageState != ImageState.ERROR) {\n      image.addEventListener(EventType.CHANGE, this.boundHandleImageChange_);\n    }\n    if (imageState == ImageState.IDLE) {\n      image.load();\n      imageState = image.getState();\n    }\n    return imageState == ImageState.LOADED;\n  }\n\n  /**\n   * @protected\n   */\n  renderIfReadyAndVisible() {\n    const layer = this.getLayer();\n    if (layer && layer.getVisible() && layer.getSourceState() === 'ready') {\n      layer.changed();\n    }\n  }\n\n  /**\n   * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n   */\n  renderDeferred(frameState) {}\n\n  /**\n   * Clean up.\n   * @override\n   */\n  disposeInternal() {\n    delete this.layer_;\n    super.disposeInternal();\n  }\n}\n\nexport default LayerRenderer;\n","/**\n * @module ol/renderer/canvas/Layer\n */\nimport {equals} from '../../array.js';\nimport {asArray} from '../../color.js';\nimport {createCanvasContext2D, createMockDiv, isCanvas} from '../../dom.js';\nimport {\n  getBottomLeft,\n  getBottomRight,\n  getHeight,\n  getTopLeft,\n  getTopRight,\n  getWidth,\n} from '../../extent.js';\nimport {WORKER_OFFSCREEN_CANVAS} from '../../has.js';\nimport RenderEvent from '../../render/Event.js';\nimport RenderEventType from '../../render/EventType.js';\nimport ZIndexContext from '../../render/canvas/ZIndexContext.js';\nimport {\n  apply as applyTransform,\n  compose as composeTransform,\n  create as createTransform,\n  equivalent,\n  makeInverse,\n  toString as toTransformString,\n} from '../../transform.js';\nimport LayerRenderer from '../Layer.js';\n\n/**\n * @type {Array<HTMLCanvasElement|OffscreenCanvas>}\n */\nexport const canvasPool = [];\n\n/**\n * @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D}\n */\nlet pixelContext = null;\n\nfunction createPixelContext() {\n  pixelContext = createCanvasContext2D(1, 1, undefined, {\n    willReadFrequently: true,\n  });\n}\n\n/**\n * @abstract\n * @template {import(\"../../layer/Layer.js\").default} LayerType\n * @extends {LayerRenderer<LayerType>}\n */\nclass CanvasLayerRenderer extends LayerRenderer {\n  /**\n   * @param {LayerType} layer Layer.\n   */\n  constructor(layer) {\n    super(layer);\n\n    /**\n     * HTMLElement container for the layer to be rendered in.\n     * @protected\n     * @type {HTMLElement}\n     */\n    this.container = null;\n\n    /**\n     * @protected\n     * @type {number}\n     */\n    this.renderedResolution;\n\n    /**\n     * A temporary transform.  The values in this transform should only be used in a\n     * function that sets the values.\n     * @protected\n     * @type {import(\"../../transform.js\").Transform}\n     */\n    this.tempTransform = createTransform();\n\n    /**\n     * The transform for rendered pixels to viewport CSS pixels.  This transform must\n     * be set when rendering a frame and may be used by other functions after rendering.\n     * @protected\n     * @type {import(\"../../transform.js\").Transform}\n     */\n    this.pixelTransform = createTransform();\n\n    /**\n     * The transform for viewport CSS pixels to rendered pixels.  This transform must\n     * be set when rendering a frame and may be used by other functions after rendering.\n     * @protected\n     * @type {import(\"../../transform.js\").Transform}\n     */\n    this.inversePixelTransform = createTransform();\n\n    /**\n     * @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D}\n     */\n    this.context = null;\n\n    /**\n     * @private\n     * @type {ZIndexContext}\n     */\n    this.deferredContext_ = null;\n\n    /**\n     * true if the container has been reused from the previous renderer\n     * @type {boolean}\n     */\n    this.containerReused = false;\n\n    /**\n     * @protected\n     * @type {import(\"../../Map.js\").FrameState|null}\n     */\n    this.frameState = null;\n  }\n\n  /**\n   * @param {import('../../DataTile.js').ImageLike} image Image.\n   * @param {number} col The column index.\n   * @param {number} row The row index.\n   * @return {Uint8ClampedArray|null} The image data.\n   */\n  getImageData(image, col, row) {\n    if (!pixelContext) {\n      createPixelContext();\n    }\n    pixelContext.clearRect(0, 0, 1, 1);\n\n    let data;\n    try {\n      pixelContext.drawImage(image, col, row, 1, 1, 0, 0, 1, 1);\n      data = pixelContext.getImageData(0, 0, 1, 1).data;\n    } catch {\n      pixelContext = null;\n      return null;\n    }\n    return data;\n  }\n\n  /**\n   * @param {import('../../Map.js').FrameState} frameState Frame state.\n   * @return {string} Background color.\n   */\n  getBackground(frameState) {\n    const layer = this.getLayer();\n    let background = layer.getBackground();\n    if (typeof background === 'function') {\n      background = background(frameState.viewState.resolution);\n    }\n    return background || undefined;\n  }\n\n  /**\n   * Get a rendering container from an existing target, if compatible.\n   * @param {HTMLElement} target Potential render target.\n   * @param {string} transform CSS transform matrix.\n   * @param {string} [backgroundColor] Background color.\n   */\n  useContainer(target, transform, backgroundColor) {\n    // renderer canvas to target canvas\n    const layerClassName = this.getLayer().getClassName();\n    let container, context;\n    if (\n      target &&\n      target.className === layerClassName &&\n      (!backgroundColor ||\n        (target &&\n          target.style.backgroundColor &&\n          equals(\n            asArray(target.style.backgroundColor),\n            asArray(backgroundColor),\n          )))\n    ) {\n      const canvas = target.firstElementChild;\n      if (isCanvas(canvas)) {\n        context = canvas.getContext('2d');\n      }\n    }\n    if (context && equivalent(context.canvas.style.transform, transform)) {\n      // Container of the previous layer renderer can be used.\n      this.container = target;\n      this.context = context;\n      this.containerReused = true;\n    } else if (this.containerReused) {\n      // Previously reused container cannot be used any more.\n      this.container = null;\n      this.context = null;\n      this.containerReused = false;\n    } else if (this.container) {\n      this.container.style.backgroundColor = null;\n    }\n    if (!this.container) {\n      container = WORKER_OFFSCREEN_CANVAS\n        ? createMockDiv()\n        : document.createElement('div');\n      container.className = layerClassName;\n      let style = container.style;\n      style.position = 'absolute';\n      style.width = '100%';\n      style.height = '100%';\n      context = createCanvasContext2D();\n      const canvas = /** @type {HTMLCanvasElement} */ (context.canvas);\n      container.appendChild(canvas);\n      style = canvas.style;\n      style.position = 'absolute';\n      style.left = '0';\n      style.transformOrigin = 'top left';\n      this.container = container;\n      this.context = context;\n    }\n    if (\n      !this.containerReused &&\n      backgroundColor &&\n      !this.container.style.backgroundColor\n    ) {\n      this.container.style.backgroundColor = backgroundColor;\n    }\n  }\n\n  /**\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context Context.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @param {import(\"../../extent.js\").Extent} extent Clip extent.\n   * @protected\n   */\n  clipUnrotated(context, frameState, extent) {\n    const topLeft = getTopLeft(extent);\n    const topRight = getTopRight(extent);\n    const bottomRight = getBottomRight(extent);\n    const bottomLeft = getBottomLeft(extent);\n\n    applyTransform(frameState.coordinateToPixelTransform, topLeft);\n    applyTransform(frameState.coordinateToPixelTransform, topRight);\n    applyTransform(frameState.coordinateToPixelTransform, bottomRight);\n    applyTransform(frameState.coordinateToPixelTransform, bottomLeft);\n\n    const inverted = this.inversePixelTransform;\n    applyTransform(inverted, topLeft);\n    applyTransform(inverted, topRight);\n    applyTransform(inverted, bottomRight);\n    applyTransform(inverted, bottomLeft);\n\n    context.save();\n    context.beginPath();\n    context.moveTo(Math.round(topLeft[0]), Math.round(topLeft[1]));\n    context.lineTo(Math.round(topRight[0]), Math.round(topRight[1]));\n    context.lineTo(Math.round(bottomRight[0]), Math.round(bottomRight[1]));\n    context.lineTo(Math.round(bottomLeft[0]), Math.round(bottomLeft[1]));\n    context.clip();\n  }\n\n  /**\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @param {HTMLElement} target Target that may be used to render content to.\n   * @protected\n   */\n  prepareContainer(frameState, target) {\n    const extent = frameState.extent;\n    const resolution = frameState.viewState.resolution;\n    const rotation = frameState.viewState.rotation;\n    const pixelRatio = frameState.pixelRatio;\n    const width = Math.round((getWidth(extent) / resolution) * pixelRatio);\n    const height = Math.round((getHeight(extent) / resolution) * pixelRatio);\n    // set forward and inverse pixel transforms\n    composeTransform(\n      this.pixelTransform,\n      frameState.size[0] / 2,\n      frameState.size[1] / 2,\n      1 / pixelRatio,\n      1 / pixelRatio,\n      rotation,\n      -width / 2,\n      -height / 2,\n    );\n    makeInverse(this.inversePixelTransform, this.pixelTransform);\n\n    const canvasTransform = toTransformString(this.pixelTransform);\n    this.useContainer(target, canvasTransform, this.getBackground(frameState));\n    if (!this.containerReused) {\n      const canvas = this.context.canvas;\n      if (canvas.width != width || canvas.height != height) {\n        canvas.width = width;\n        canvas.height = height;\n      } else {\n        this.context.clearRect(0, 0, width, height);\n      }\n      if (\n        canvasTransform !==\n        /** @type {HTMLCanvasElement} */ (canvas).style.transform\n      ) {\n        /** @type {HTMLCanvasElement} */ (canvas).style.transform =\n          canvasTransform;\n      }\n    }\n  }\n\n  /**\n   * @param {import(\"../../render/EventType.js\").default} type Event type.\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context Context.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @private\n   */\n  dispatchRenderEvent_(type, context, frameState) {\n    const layer = this.getLayer();\n    if (layer.hasListener(type)) {\n      const event = new RenderEvent(\n        type,\n        this.inversePixelTransform,\n        frameState,\n        context,\n      );\n      layer.dispatchEvent(event);\n    }\n  }\n\n  /**\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context Context.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @protected\n   */\n  preRender(context, frameState) {\n    this.frameState = frameState;\n    if (frameState.declutter) {\n      return;\n    }\n    this.dispatchRenderEvent_(RenderEventType.PRERENDER, context, frameState);\n  }\n\n  /**\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context Context.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @protected\n   */\n  postRender(context, frameState) {\n    if (frameState.declutter) {\n      return;\n    }\n    this.dispatchRenderEvent_(RenderEventType.POSTRENDER, context, frameState);\n  }\n\n  /**\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   */\n  renderDeferredInternal(frameState) {}\n\n  /**\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @return {import('../../render/canvas/ZIndexContext.js').ZIndexContextProxy} Context.\n   */\n  getRenderContext(frameState) {\n    if (frameState.declutter && !this.deferredContext_) {\n      this.deferredContext_ = new ZIndexContext();\n    }\n    return frameState.declutter\n      ? this.deferredContext_.getContext()\n      : this.context;\n  }\n\n  /**\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @override\n   */\n  renderDeferred(frameState) {\n    if (!frameState.declutter) {\n      return;\n    }\n    this.dispatchRenderEvent_(\n      RenderEventType.PRERENDER,\n      this.context,\n      frameState,\n    );\n    if (frameState.declutter && this.deferredContext_) {\n      this.deferredContext_.draw(this.context);\n      this.deferredContext_.clear();\n    }\n    this.renderDeferredInternal(frameState);\n    this.dispatchRenderEvent_(\n      RenderEventType.POSTRENDER,\n      this.context,\n      frameState,\n    );\n  }\n\n  /**\n   * Creates a transform for rendering to an element that will be rotated after rendering.\n   * @param {import(\"../../coordinate.js\").Coordinate} center Center.\n   * @param {number} resolution Resolution.\n   * @param {number} rotation Rotation.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {number} width Width of the rendered element (in pixels).\n   * @param {number} height Height of the rendered element (in pixels).\n   * @param {number} offsetX Offset on the x-axis in view coordinates.\n   * @protected\n   * @return {!import(\"../../transform.js\").Transform} Transform.\n   */\n  getRenderTransform(\n    center,\n    resolution,\n    rotation,\n    pixelRatio,\n    width,\n    height,\n    offsetX,\n  ) {\n    const dx1 = width / 2;\n    const dy1 = height / 2;\n    const sx = pixelRatio / resolution;\n    const sy = -sx;\n    const dx2 = -center[0] + offsetX;\n    const dy2 = -center[1];\n    return composeTransform(\n      this.tempTransform,\n      dx1,\n      dy1,\n      sx,\n      sy,\n      -rotation,\n      dx2,\n      dy2,\n    );\n  }\n\n  /**\n   * Clean up.\n   * @override\n   */\n  disposeInternal() {\n    delete this.frameState;\n    super.disposeInternal();\n  }\n}\n\nexport default CanvasLayerRenderer;\n","/**\n * @module ol/renderer/canvas/ImageLayer\n */\nimport ImageState from '../../ImageState.js';\nimport ViewHint from '../../ViewHint.js';\nimport {\n  containsCoordinate,\n  containsExtent,\n  getHeight,\n  getIntersection,\n  getWidth,\n  intersects as intersectsExtent,\n  isEmpty,\n} from '../../extent.js';\nimport {fromUserExtent} from '../../proj.js';\nimport {\n  apply as applyTransform,\n  compose as composeTransform,\n} from '../../transform.js';\nimport CanvasLayerRenderer from './Layer.js';\n\n/**\n * @classdesc\n * Canvas renderer for image layers.\n * @api\n */\nclass CanvasImageLayerRenderer extends CanvasLayerRenderer {\n  /**\n   * @param {import(\"../../layer/Image.js\").default} imageLayer Image layer.\n   */\n  constructor(imageLayer) {\n    super(imageLayer);\n\n    /**\n     * @protected\n     * @type {?import(\"../../Image.js\").default}\n     */\n    this.image = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.renderedSourceRevision_ = 0;\n  }\n\n  /**\n   * @return {import('../../DataTile.js').ImageLike} Image.\n   */\n  getImage() {\n    return !this.image ? null : this.image.getImage();\n  }\n\n  /**\n   * Determine whether render should be called.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @return {boolean} Layer is ready to be rendered.\n   * @override\n   */\n  prepareFrame(frameState) {\n    const layerState = frameState.layerStatesArray[frameState.layerIndex];\n    const pixelRatio = frameState.pixelRatio;\n    const viewState = frameState.viewState;\n    const viewResolution = viewState.resolution;\n\n    const imageSource = this.getLayer().getSource();\n\n    const hints = frameState.viewHints;\n\n    let renderedExtent = frameState.extent;\n    if (layerState.extent !== undefined) {\n      renderedExtent = getIntersection(\n        renderedExtent,\n        fromUserExtent(layerState.extent, viewState.projection),\n      );\n    }\n\n    if (\n      !hints[ViewHint.ANIMATING] &&\n      !hints[ViewHint.INTERACTING] &&\n      !isEmpty(renderedExtent)\n    ) {\n      if (imageSource) {\n        if (\n          !this.getLayer().rendered &&\n          this.renderedSourceRevision_ !== imageSource.getRevision()\n        ) {\n          this.image = null;\n        }\n        this.renderedSourceRevision_ = imageSource.getRevision();\n\n        const projection = viewState.projection;\n        const image = imageSource.getImage(\n          renderedExtent,\n          viewResolution,\n          pixelRatio,\n          projection,\n        );\n        if (image) {\n          if (this.loadImage(image)) {\n            this.image = image;\n          } else if (image.getState() === ImageState.EMPTY) {\n            this.image = null;\n          }\n        }\n      } else {\n        this.image = null;\n      }\n    }\n\n    return !!this.image;\n  }\n\n  /**\n   * @param {import(\"../../pixel.js\").Pixel} pixel Pixel.\n   * @return {Uint8ClampedArray} Data at the pixel location.\n   * @override\n   */\n  getData(pixel) {\n    const frameState = this.frameState;\n    if (!frameState) {\n      return null;\n    }\n\n    const layer = this.getLayer();\n    const coordinate = applyTransform(\n      frameState.pixelToCoordinateTransform,\n      pixel.slice(),\n    );\n\n    const layerExtent = layer.getExtent();\n    if (layerExtent) {\n      if (!containsCoordinate(layerExtent, coordinate)) {\n        return null;\n      }\n    }\n\n    const imageExtent = this.image.getExtent();\n    const img = this.image.getImage();\n\n    const imageMapWidth = getWidth(imageExtent);\n    const col = Math.floor(\n      img.width * ((coordinate[0] - imageExtent[0]) / imageMapWidth),\n    );\n    if (col < 0 || col >= img.width) {\n      return null;\n    }\n\n    const imageMapHeight = getHeight(imageExtent);\n    const row = Math.floor(\n      img.height * ((imageExtent[3] - coordinate[1]) / imageMapHeight),\n    );\n    if (row < 0 || row >= img.height) {\n      return null;\n    }\n\n    return this.getImageData(img, col, row);\n  }\n\n  /**\n   * Render the layer.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @param {HTMLElement} target Target that may be used to render content to.\n   * @return {HTMLElement} The rendered element.\n   * @override\n   */\n  renderFrame(frameState, target) {\n    const image = this.image;\n    const imageExtent = image.getExtent();\n    const imageResolution = image.getResolution();\n    const [imageResolutionX, imageResolutionY] = Array.isArray(imageResolution)\n      ? imageResolution\n      : [imageResolution, imageResolution];\n    const imagePixelRatio = image.getPixelRatio();\n    const layerState = frameState.layerStatesArray[frameState.layerIndex];\n    const pixelRatio = frameState.pixelRatio;\n    const viewState = frameState.viewState;\n    const viewCenter = viewState.center;\n    const viewResolution = viewState.resolution;\n    const scaleX =\n      (pixelRatio * imageResolutionX) / (viewResolution * imagePixelRatio);\n    const scaleY =\n      (pixelRatio * imageResolutionY) / (viewResolution * imagePixelRatio);\n\n    this.prepareContainer(frameState, target);\n\n    // desired dimensions of the canvas in pixels\n    const width = this.context.canvas.width;\n    const height = this.context.canvas.height;\n\n    const context = this.getRenderContext(frameState);\n\n    // clipped rendering if layer extent is set\n    let clipped = false;\n    let render = true;\n    if (layerState.extent) {\n      const layerExtent = fromUserExtent(\n        layerState.extent,\n        viewState.projection,\n      );\n      render = intersectsExtent(layerExtent, frameState.extent);\n      clipped = render && !containsExtent(layerExtent, frameState.extent);\n      if (clipped) {\n        this.clipUnrotated(context, frameState, layerExtent);\n      }\n    }\n\n    const img = image.getImage();\n\n    const transform = composeTransform(\n      this.tempTransform,\n      width / 2,\n      height / 2,\n      scaleX,\n      scaleY,\n      0,\n      (imagePixelRatio * (imageExtent[0] - viewCenter[0])) / imageResolutionX,\n      (imagePixelRatio * (viewCenter[1] - imageExtent[3])) / imageResolutionY,\n    );\n\n    this.renderedResolution = (imageResolutionY * pixelRatio) / imagePixelRatio;\n\n    const dw = img.width * transform[0];\n    const dh = img.height * transform[3];\n\n    if (!this.getLayer().getSource().getInterpolate()) {\n      context.imageSmoothingEnabled = false;\n    }\n\n    this.preRender(context, frameState);\n    if (render && dw >= 0.5 && dh >= 0.5) {\n      const dx = transform[4];\n      const dy = transform[5];\n      const opacity = layerState.opacity;\n      if (opacity !== 1) {\n        context.save();\n        context.globalAlpha = opacity;\n      }\n      context.drawImage(img, 0, 0, +img.width, +img.height, dx, dy, dw, dh);\n      if (opacity !== 1) {\n        context.restore();\n      }\n    }\n    this.postRender(this.context, frameState);\n\n    if (clipped) {\n      context.restore();\n    }\n    context.imageSmoothingEnabled = true;\n    return this.container;\n  }\n}\n\nexport default CanvasImageLayerRenderer;\n","/**\n * @module ol/layer/BaseImage\n */\nimport Layer from './Layer.js';\n\n/**\n * @template {import(\"../source/Image.js\").default} ImageSourceType\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} [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 {import(\"../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 {@link import(\"../Map.js\").default#addLayer map.addLayer()}.\n * @property {ImageSourceType} [source] Source for this layer.\n * @property {import('./Base.js').BackgroundColor} [background] Background color for the layer. If not specified, no background\n * will be rendered.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n\n/**\n * @classdesc\n * Server-rendered images that are available for arbitrary extents and\n * resolutions.\n * Note that any property set in the options is set as a {@link module:ol/Object~BaseObject}\n * property on the layer object; for example, setting `title: 'My Title'` in the\n * options means that `title` is observable, and has get/set accessors.\n *\n * @template {import(\"../source/Image.js\").default} ImageSourceType\n * @template {import(\"../renderer/Layer.js\").default} RendererType\n * @extends {Layer<ImageSourceType, RendererType>}\n * @api\n */\nclass BaseImageLayer extends Layer {\n  /**\n   * @param {Options<ImageSourceType>} [options] Layer options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n    super(options);\n  }\n}\n\nexport default BaseImageLayer;\n","/**\n * @module ol/layer/Image\n */\nimport CanvasImageLayerRenderer from '../renderer/canvas/ImageLayer.js';\nimport BaseImageLayer from './BaseImage.js';\n\n/**\n * @classdesc\n * Server-rendered images that are available for arbitrary extents and\n * resolutions.\n * Note that any property set in the options is set as a {@link module:ol/Object~BaseObject}\n * property on the layer object; for example, setting `title: 'My Title'` in the\n * options means that `title` is observable, and has get/set accessors.\n *\n * @template {import(\"../source/Image.js\").default} ImageSourceType\n * @extends {BaseImageLayer<ImageSourceType, CanvasImageLayerRenderer>}\n * @api\n */\nclass ImageLayer extends BaseImageLayer {\n  /**\n   * @param {import(\"./BaseImage.js\").Options<ImageSourceType>} [options] Layer options.\n   */\n  constructor(options) {\n    super(options);\n  }\n\n  /**\n   * @override\n   */\n  createRenderer() {\n    return new CanvasImageLayerRenderer(this);\n  }\n\n  /**\n   * Get data for a pixel location.  A four element RGBA array will be returned.  For requests outside the\n   * layer extent, `null` will be returned.  Data for an image can only be retrieved if the\n   * source's `crossOrigin` property is set.\n   *\n   * ```js\n   * // display layer data on every pointer move\n   * map.on('pointermove', (event) => {\n   *   console.log(layer.getData(event.pixel));\n   * });\n   * ```\n   * @param {import(\"../pixel.js\").Pixel} pixel Pixel.\n   * @return {Uint8ClampedArray|Uint8Array|Float32Array|DataView|null} Pixel data.\n   * @api\n   * @override\n   */\n  getData(pixel) {\n    return super.getData(pixel);\n  }\n}\n\nexport default ImageLayer;\n","/**\n * @module ol/renderer/canvas/TileLayer\n */\nimport DataTile, {asImageLike} from '../../DataTile.js';\nimport ImageTile from '../../ImageTile.js';\nimport TileRange from '../../TileRange.js';\nimport TileState from '../../TileState.js';\nimport {ascending} from '../../array.js';\nimport {\n  containsCoordinate,\n  createEmpty,\n  equals,\n  getIntersection,\n  getRotatedViewport,\n  getTopLeft,\n  intersects,\n} from '../../extent.js';\nimport {equivalent, fromUserExtent} from '../../proj.js';\nimport ReprojTile from '../../reproj/Tile.js';\nimport {toSize} from '../../size.js';\nimport LRUCache from '../../structs/LRUCache.js';\nimport {\n  createOrUpdate as createTileCoord,\n  getCacheKey,\n} from '../../tilecoord.js';\nimport {\n  apply as applyTransform,\n  compose as composeTransform,\n} from '../../transform.js';\nimport {getUid} from '../../util.js';\nimport CanvasLayerRenderer from './Layer.js';\n\n/**\n * @typedef {Object<number, Set<import(\"../../Tile.js\").default>>} TileLookup\n */\n\n/**\n * Add a tile to the lookup.\n * @param {TileLookup} tilesByZ Lookup of tiles by zoom level.\n * @param {import(\"../../Tile.js\").default} tile A tile.\n * @param {number} z The zoom level.\n * @return {boolean} The tile was added to the lookup.\n */\nfunction addTileToLookup(tilesByZ, tile, z) {\n  if (!(z in tilesByZ)) {\n    tilesByZ[z] = new Set([tile]);\n    return true;\n  }\n  const set = tilesByZ[z];\n  const existing = set.has(tile);\n  if (!existing) {\n    set.add(tile);\n  }\n  return !existing;\n}\n\n/**\n * Remove a tile from the lookup.\n * @param {TileLookup} tilesByZ Lookup of tiles by zoom level.\n * @param {import(\"../../Tile.js\").default} tile A tile.\n * @param {number} z The zoom level.\n * @return {boolean} The tile was removed from the lookup.\n */\nfunction removeTileFromLookup(tilesByZ, tile, z) {\n  const set = tilesByZ[z];\n  if (set) {\n    return set.delete(tile);\n  }\n  return false;\n}\n\n/**\n * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n * @param {import(\"../../extent.js\").Extent} extent The frame extent.\n * @return {import(\"../../extent.js\").Extent} Frame extent intersected with layer extents.\n */\nfunction getRenderExtent(frameState, extent) {\n  const layerState = frameState.layerStatesArray[frameState.layerIndex];\n  if (layerState.extent) {\n    extent = getIntersection(\n      extent,\n      fromUserExtent(layerState.extent, frameState.viewState.projection),\n    );\n  }\n  const source = /** @type {import(\"../../source/Tile.js\").default} */ (\n    layerState.layer.getRenderSource()\n  );\n  if (!source.getWrapX()) {\n    const gridExtent = source\n      .getTileGridForProjection(frameState.viewState.projection)\n      .getExtent();\n    if (gridExtent) {\n      extent = getIntersection(extent, gridExtent);\n    }\n  }\n  return extent;\n}\n\n/**\n * @typedef {Object} Options\n * @property {number} [cacheSize=512] The cache size.\n */\n\n/**\n * @classdesc\n * Canvas renderer for tile layers.\n * @api\n * @template {import(\"../../layer/Tile.js\").default|import(\"../../layer/VectorTile.js\").default} [LayerType=import(\"../../layer/Tile.js\").default<import(\"../../source/Tile.js\").default>|import(\"../../layer/VectorTile.js\").default]\n * @extends {CanvasLayerRenderer<LayerType>}\n */\nclass CanvasTileLayerRenderer extends CanvasLayerRenderer {\n  /**\n   * @param {LayerType} tileLayer Tile layer.\n   * @param {Options} [options] Options.\n   */\n  constructor(tileLayer, options) {\n    super(tileLayer);\n\n    options = options || {};\n\n    /**\n     * Rendered extent has changed since the previous `renderFrame()` call\n     * @type {boolean}\n     */\n    this.extentChanged = true;\n\n    /**\n     * The last call to `renderFrame` was completed with all tiles loaded\n     * @type {boolean}\n     */\n    this.renderComplete = false;\n\n    /**\n     * @private\n     * @type {?import(\"../../extent.js\").Extent}\n     */\n    this.renderedExtent_ = null;\n\n    /**\n     * @protected\n     * @type {number}\n     */\n    this.renderedPixelRatio;\n\n    /**\n     * @protected\n     * @type {import(\"../../proj/Projection.js\").default|null}\n     */\n    this.renderedProjection = null;\n\n    /**\n     * @protected\n     * @type {!Array<import(\"../../Tile.js\").default>}\n     */\n    this.renderedTiles = [];\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.renderedSourceKey_;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.renderedSourceRevision_;\n\n    /**\n     * @protected\n     * @type {import(\"../../extent.js\").Extent}\n     */\n    this.tempExtent = createEmpty();\n\n    /**\n     * @private\n     * @type {import(\"../../TileRange.js\").default}\n     */\n    this.tempTileRange_ = new TileRange(0, 0, 0, 0);\n\n    /**\n     * @type {import(\"../../tilecoord.js\").TileCoord}\n     * @private\n     */\n    this.tempTileCoord_ = createTileCoord(0, 0, 0);\n\n    const cacheSize = options.cacheSize !== undefined ? options.cacheSize : 512;\n\n    /**\n     * @type {import(\"../../structs/LRUCache.js\").default<import(\"../../Tile.js\").default>}\n     * @private\n     */\n    this.tileCache_ = new LRUCache(cacheSize);\n\n    /**\n     * @type {import(\"../../structs/LRUCache.js\").default<import(\"../../Tile.js\").default|null>}\n     * @private\n     */\n    this.sourceTileCache_ = null;\n\n    /**\n     * @protected\n     * @type {import(\"../../extent.js\").Extent|null}\n     */\n    this.layerExtent = null;\n\n    this.maxStaleKeys = cacheSize * 0.5;\n  }\n\n  /**\n   * @return {LRUCache} Tile cache.\n   */\n  getTileCache() {\n    return this.tileCache_;\n  }\n\n  /**\n   * @return {LRUCache} Tile cache.\n   */\n  getSourceTileCache() {\n    if (!this.sourceTileCache_) {\n      this.sourceTileCache_ = new LRUCache(512);\n    }\n    return this.sourceTileCache_;\n  }\n\n  /**\n   * Get a tile from the cache or create one if needed.\n   *\n   * @param {number} z Tile coordinate z.\n   * @param {number} x Tile coordinate x.\n   * @param {number} y Tile coordinate y.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @return {import(\"../../Tile.js\").default|null} Tile (or null if outside source extent).\n   * @protected\n   */\n  getOrCreateTile(z, x, y, frameState) {\n    const tileCache = this.tileCache_;\n    const tileLayer = this.getLayer();\n    const tileSource = tileLayer.getSource();\n    const cacheKey = getCacheKey(tileSource, tileSource.getKey(), z, x, y);\n\n    /** @type {import(\"../../Tile.js\").default} */\n    let tile;\n\n    if (tileCache.containsKey(cacheKey)) {\n      tile = tileCache.get(cacheKey);\n    } else {\n      const projection = frameState.viewState.projection;\n      const sourceProjection = tileSource.getProjection();\n      tile = tileSource.getTile(\n        z,\n        x,\n        y,\n        frameState.pixelRatio,\n        projection,\n        !sourceProjection || equivalent(sourceProjection, projection)\n          ? undefined\n          : this.getSourceTileCache(),\n      );\n      if (!tile) {\n        return null;\n      }\n      tileCache.set(cacheKey, tile);\n    }\n    return tile;\n  }\n\n  /**\n   * @param {number} z Tile coordinate z.\n   * @param {number} x Tile coordinate x.\n   * @param {number} y Tile coordinate y.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @return {import(\"../../Tile.js\").default|null} Tile (or null if outside source extent).\n   * @protected\n   */\n  getTile(z, x, y, frameState) {\n    const tile = this.getOrCreateTile(z, x, y, frameState);\n    if (!tile) {\n      return null;\n    }\n    return tile;\n  }\n\n  /**\n   * @param {import(\"../../pixel.js\").Pixel} pixel Pixel.\n   * @return {Uint8ClampedArray} Data at the pixel location.\n   * @override\n   */\n  getData(pixel) {\n    const frameState = this.frameState;\n    if (!frameState) {\n      return null;\n    }\n\n    const layer = this.getLayer();\n    const coordinate = applyTransform(\n      frameState.pixelToCoordinateTransform,\n      pixel.slice(),\n    );\n\n    const layerExtent = layer.getExtent();\n    if (layerExtent) {\n      if (!containsCoordinate(layerExtent, coordinate)) {\n        return null;\n      }\n    }\n\n    const viewState = frameState.viewState;\n    const source = layer.getRenderSource();\n    const tileGrid = source.getTileGridForProjection(viewState.projection);\n    const tilePixelRatio = source.getTilePixelRatio(frameState.pixelRatio);\n\n    for (\n      let z = tileGrid.getZForResolution(viewState.resolution);\n      z >= tileGrid.getMinZoom();\n      --z\n    ) {\n      const tileCoord = tileGrid.getTileCoordForCoordAndZ(coordinate, z);\n      const tile = this.getTile(z, tileCoord[1], tileCoord[2], frameState);\n      if (!tile || tile.getState() !== TileState.LOADED) {\n        continue;\n      }\n\n      const tileOrigin = tileGrid.getOrigin(z);\n      const tileSize = toSize(tileGrid.getTileSize(z));\n      const tileResolution = tileGrid.getResolution(z);\n\n      /**\n       * @type {import('../../DataTile.js').ImageLike}\n       */\n      let image;\n      if (tile instanceof ImageTile || tile instanceof ReprojTile) {\n        image = tile.getImage();\n      } else if (tile instanceof DataTile) {\n        image = asImageLike(tile.getData());\n        if (!image) {\n          continue;\n        }\n      } else {\n        continue;\n      }\n\n      const col = Math.floor(\n        tilePixelRatio *\n          ((coordinate[0] - tileOrigin[0]) / tileResolution -\n            tileCoord[1] * tileSize[0]),\n      );\n\n      const row = Math.floor(\n        tilePixelRatio *\n          ((tileOrigin[1] - coordinate[1]) / tileResolution -\n            tileCoord[2] * tileSize[1]),\n      );\n\n      const gutter = Math.round(\n        tilePixelRatio * source.getGutterForProjection(viewState.projection),\n      );\n\n      return this.getImageData(image, col + gutter, row + gutter);\n    }\n\n    return null;\n  }\n\n  /**\n   * Determine whether render should be called.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @return {boolean} Layer is ready to be rendered.\n   * @override\n   */\n  prepareFrame(frameState) {\n    if (!this.renderedProjection) {\n      this.renderedProjection = frameState.viewState.projection;\n    } else if (frameState.viewState.projection !== this.renderedProjection) {\n      this.tileCache_.clear();\n      this.renderedProjection = frameState.viewState.projection;\n    }\n\n    const source = this.getLayer().getSource();\n    if (!source) {\n      return false;\n    }\n    const sourceRevision = source.getRevision();\n    if (!this.renderedSourceRevision_) {\n      this.renderedSourceRevision_ = sourceRevision;\n    } else if (this.renderedSourceRevision_ !== sourceRevision) {\n      this.renderedSourceRevision_ = sourceRevision;\n      if (this.renderedSourceKey_ === source.getKey()) {\n        this.tileCache_.clear();\n        this.sourceTileCache_?.clear();\n      }\n    }\n    return true;\n  }\n\n  /**\n   * Determine whether tiles for next extent should be enqueued for rendering.\n   * @return {boolean} Rendering tiles for next extent is supported.\n   * @protected\n   */\n  enqueueTilesForNextExtent() {\n    return true;\n  }\n\n  /**\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @param {import(\"../../extent.js\").Extent} extent The extent to be rendered.\n   * @param {number} initialZ The zoom level.\n   * @param {TileLookup} tilesByZ Lookup of tiles by zoom level.\n   * @param {number} preload Number of additional levels to load.\n   */\n  enqueueTiles(frameState, extent, initialZ, tilesByZ, preload) {\n    const viewState = frameState.viewState;\n    const tileLayer = this.getLayer();\n    const tileSource = tileLayer.getRenderSource();\n    const tileGrid = tileSource.getTileGridForProjection(viewState.projection);\n\n    const tileSourceKey = getUid(tileSource);\n    if (!(tileSourceKey in frameState.wantedTiles)) {\n      frameState.wantedTiles[tileSourceKey] = {};\n    }\n\n    const wantedTiles = frameState.wantedTiles[tileSourceKey];\n\n    const map = tileLayer.getMapInternal();\n    const minZ = Math.max(\n      initialZ - preload,\n      tileGrid.getMinZoom(),\n      tileGrid.getZForResolution(\n        Math.min(\n          tileLayer.getMaxResolution(),\n          map\n            ? map\n                .getView()\n                .getResolutionForZoom(Math.max(tileLayer.getMinZoom(), 0))\n            : tileGrid.getResolution(0),\n        ),\n        tileSource.zDirection,\n      ),\n    );\n    const rotation = viewState.rotation;\n    const viewport = rotation\n      ? getRotatedViewport(\n          viewState.center,\n          viewState.resolution,\n          rotation,\n          frameState.size,\n        )\n      : undefined;\n    for (let z = initialZ; z >= minZ; --z) {\n      const tileRange = tileGrid.getTileRangeForExtentAndZ(\n        extent,\n        z,\n        this.tempTileRange_,\n      );\n\n      const tileResolution = tileGrid.getResolution(z);\n\n      for (let x = tileRange.minX; x <= tileRange.maxX; ++x) {\n        for (let y = tileRange.minY; y <= tileRange.maxY; ++y) {\n          if (\n            rotation &&\n            !tileGrid.tileCoordIntersectsViewport([z, x, y], viewport)\n          ) {\n            continue;\n          }\n          const tile = this.getTile(z, x, y, frameState);\n          if (!tile) {\n            continue;\n          }\n          const added = addTileToLookup(tilesByZ, tile, z);\n          if (!added) {\n            continue;\n          }\n\n          const tileQueueKey = tile.getKey();\n          wantedTiles[tileQueueKey] = true;\n\n          if (tile.getState() === TileState.IDLE) {\n            if (!frameState.tileQueue.isKeyQueued(tileQueueKey)) {\n              const tileCoord = createTileCoord(z, x, y, this.tempTileCoord_);\n              frameState.tileQueue.enqueue([\n                tile,\n                tileSourceKey,\n                tileGrid.getTileCoordCenter(tileCoord),\n                tileResolution,\n              ]);\n            }\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * Look for tiles covering the provided tile coordinate at an alternate\n   * zoom level.  Loaded tiles will be added to the provided tile texture lookup.\n   * @param {import(\"../../tilecoord.js\").TileCoord} tileCoord The target tile coordinate.\n   * @param {TileLookup} tilesByZ Lookup of tiles by zoom level.\n   * @return {boolean} The tile coordinate is covered by loaded tiles at the alternate zoom level.\n   * @private\n   */\n  findStaleTile_(tileCoord, tilesByZ) {\n    const tileCache = this.tileCache_;\n    const z = tileCoord[0];\n    const x = tileCoord[1];\n    const y = tileCoord[2];\n    const staleKeys = this.getStaleKeys();\n    for (let i = 0; i < staleKeys.length; ++i) {\n      const cacheKey = getCacheKey(\n        this.getLayer().getSource(),\n        staleKeys[i],\n        z,\n        x,\n        y,\n      );\n      if (tileCache.containsKey(cacheKey)) {\n        const tile = tileCache.peek(cacheKey);\n        if (tile.getState() === TileState.LOADED) {\n          tile.endTransition(getUid(this));\n          addTileToLookup(tilesByZ, tile, z);\n          return true;\n        }\n      }\n    }\n    return false;\n  }\n\n  /**\n   * Look for tiles covering the provided tile coordinate at an alternate\n   * zoom level.  Loaded tiles will be added to the provided tile texture lookup.\n   * @param {import(\"../../tilegrid/TileGrid.js\").default} tileGrid The tile grid.\n   * @param {import(\"../../tilecoord.js\").TileCoord} tileCoord The target tile coordinate.\n   * @param {number} altZ The alternate zoom level.\n   * @param {TileLookup} tilesByZ Lookup of tiles by zoom level.\n   * @return {boolean} The tile coordinate is covered by loaded tiles at the alternate zoom level.\n   * @private\n   */\n  findAltTiles_(tileGrid, tileCoord, altZ, tilesByZ) {\n    const tileRange = tileGrid.getTileRangeForTileCoordAndZ(\n      tileCoord,\n      altZ,\n      this.tempTileRange_,\n    );\n\n    if (!tileRange) {\n      return false;\n    }\n\n    let covered = true;\n    const tileCache = this.tileCache_;\n    const source = this.getLayer().getRenderSource();\n    const sourceKey = source.getKey();\n    for (let x = tileRange.minX; x <= tileRange.maxX; ++x) {\n      for (let y = tileRange.minY; y <= tileRange.maxY; ++y) {\n        const cacheKey = getCacheKey(source, sourceKey, altZ, x, y);\n        let loaded = false;\n        if (tileCache.containsKey(cacheKey)) {\n          const tile = tileCache.peek(cacheKey);\n          if (tile.getState() === TileState.LOADED) {\n            addTileToLookup(tilesByZ, tile, altZ);\n            loaded = true;\n          }\n        }\n        if (!loaded) {\n          covered = false;\n        }\n      }\n    }\n    return covered;\n  }\n\n  /**\n   * Render the layer.\n   *\n   * The frame rendering logic has three parts:\n   *\n   *  1. Enqueue tiles\n   *  2. Find alt tiles for those that are not yet loaded\n   *  3. Render loaded tiles\n   *\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @param {HTMLElement} target Target that may be used to render content to.\n   * @return {HTMLElement} The rendered element.\n   * @override\n   */\n  renderFrame(frameState, target) {\n    this.renderComplete = true;\n    /**\n     * TODO:\n     *  maybe skip transition when not fully opaque\n     *  decide if this.renderComplete is useful\n     */\n\n    const layerState = frameState.layerStatesArray[frameState.layerIndex];\n    const viewState = frameState.viewState;\n    const projection = viewState.projection;\n    const viewResolution = viewState.resolution;\n    const viewCenter = viewState.center;\n    const pixelRatio = frameState.pixelRatio;\n\n    const tileLayer = this.getLayer();\n    const tileSource = tileLayer.getSource();\n    const tileGrid = tileSource.getTileGridForProjection(projection);\n    const z = tileGrid.getZForResolution(viewResolution, tileSource.zDirection);\n    const tileResolution = tileGrid.getResolution(z);\n\n    const sourceKey = tileSource.getKey();\n    if (!this.renderedSourceKey_) {\n      this.renderedSourceKey_ = sourceKey;\n    } else if (this.renderedSourceKey_ !== sourceKey) {\n      this.prependStaleKey(this.renderedSourceKey_);\n      this.renderedSourceKey_ = sourceKey;\n    }\n\n    let frameExtent = frameState.extent;\n    const tilePixelRatio = tileSource.getTilePixelRatio(pixelRatio);\n\n    this.prepareContainer(frameState, target);\n\n    // desired dimensions of the canvas in pixels\n    const width = this.context.canvas.width;\n    const height = this.context.canvas.height;\n\n    this.layerExtent = layerState.extent\n      ? fromUserExtent(layerState.extent, projection)\n      : null;\n    if (this.layerExtent) {\n      frameExtent = getIntersection(frameExtent, this.layerExtent);\n    }\n\n    const dx = (tileResolution * width) / 2 / tilePixelRatio;\n    const dy = (tileResolution * height) / 2 / tilePixelRatio;\n    const canvasExtent = [\n      viewCenter[0] - dx,\n      viewCenter[1] - dy,\n      viewCenter[0] + dx,\n      viewCenter[1] + dy,\n    ];\n\n    /**\n     * @type {TileLookup}\n     */\n    const tilesByZ = {};\n\n    this.renderedTiles.length = 0;\n\n    /**\n     * Part 1: Enqueue tiles\n     */\n\n    const preload = tileLayer.getPreload();\n    if (frameState.nextExtent && this.enqueueTilesForNextExtent()) {\n      const targetZ = tileGrid.getZForResolution(\n        viewState.nextResolution,\n        tileSource.zDirection,\n      );\n      const nextExtent = getRenderExtent(frameState, frameState.nextExtent);\n      this.enqueueTiles(frameState, nextExtent, targetZ, tilesByZ, preload);\n    }\n\n    const renderExtent = getRenderExtent(frameState, frameExtent);\n    this.enqueueTiles(frameState, renderExtent, z, tilesByZ, 0);\n    if (preload > 0) {\n      setTimeout(() => {\n        this.enqueueTiles(\n          frameState,\n          renderExtent,\n          z - 1,\n          tilesByZ,\n          preload - 1,\n        );\n      }, 0);\n    }\n\n    if (!(z in tilesByZ)) {\n      return this.container;\n    }\n\n    /**\n     * Part 2: Find alt tiles for those that are not yet loaded\n     */\n\n    const uid = getUid(this);\n    const time = frameState.time;\n\n    // look for cached tiles to use if a target tile is not ready\n    for (const tile of tilesByZ[z]) {\n      const tileState = tile.getState();\n      if (tileState === TileState.EMPTY) {\n        continue;\n      }\n      const tileCoord = tile.tileCoord;\n\n      if (tileState === TileState.LOADED) {\n        const alpha = tile.getAlpha(uid, time);\n        if (alpha === 1) {\n          // no need to look for alt tiles\n          tile.endTransition(uid);\n          continue;\n        }\n      }\n      if (tileState !== TileState.ERROR) {\n        this.renderComplete = false;\n      }\n\n      const hasStaleTile = this.findStaleTile_(tileCoord, tilesByZ);\n      if (hasStaleTile) {\n        // use the stale tile before the new tile's transition has completed\n        removeTileFromLookup(tilesByZ, tile, z);\n        frameState.animate = true;\n        continue;\n      }\n\n      // first look for child tiles (at z + 1)\n      const coveredByChildren = this.findAltTiles_(\n        tileGrid,\n        tileCoord,\n        z + 1,\n        tilesByZ,\n      );\n\n      if (coveredByChildren) {\n        continue;\n      }\n\n      // next look for parent tiles\n      const minZoom = tileGrid.getMinZoom();\n      for (let parentZ = z - 1; parentZ >= minZoom; --parentZ) {\n        const coveredByParent = this.findAltTiles_(\n          tileGrid,\n          tileCoord,\n          parentZ,\n          tilesByZ,\n        );\n\n        if (coveredByParent) {\n          break;\n        }\n      }\n    }\n\n    /**\n     * Part 3: Render loaded tiles\n     */\n\n    const canvasScale =\n      ((tileResolution / viewResolution) * pixelRatio) / tilePixelRatio;\n\n    const context = this.getRenderContext(frameState);\n\n    // set scale transform for calculating tile positions on the canvas\n    composeTransform(\n      this.tempTransform,\n      width / 2,\n      height / 2,\n      canvasScale,\n      canvasScale,\n      0,\n      -width / 2,\n      -height / 2,\n    );\n\n    if (this.layerExtent) {\n      this.clipUnrotated(context, frameState, this.layerExtent);\n    }\n\n    if (!tileSource.getInterpolate()) {\n      context.imageSmoothingEnabled = false;\n    }\n\n    this.preRender(context, frameState);\n\n    /** @type {Array<number>} */\n    const zs = Object.keys(tilesByZ).map(Number);\n    zs.sort(ascending);\n\n    let currentClip;\n    const clips = [];\n    const clipZs = [];\n    for (let i = zs.length - 1; i >= 0; --i) {\n      const currentZ = zs[i];\n      const currentTilePixelSize = tileSource.getTilePixelSize(\n        currentZ,\n        pixelRatio,\n        projection,\n      );\n      const currentResolution = tileGrid.getResolution(currentZ);\n      const currentScale = currentResolution / tileResolution;\n      const dx = currentTilePixelSize[0] * currentScale * canvasScale;\n      const dy = currentTilePixelSize[1] * currentScale * canvasScale;\n      const originTileCoord = tileGrid.getTileCoordForCoordAndZ(\n        getTopLeft(canvasExtent),\n        currentZ,\n      );\n      const originTileExtent = tileGrid.getTileCoordExtent(originTileCoord);\n      const origin = applyTransform(this.tempTransform, [\n        (tilePixelRatio * (originTileExtent[0] - canvasExtent[0])) /\n          tileResolution,\n        (tilePixelRatio * (canvasExtent[3] - originTileExtent[3])) /\n          tileResolution,\n      ]);\n      const tileGutter =\n        tilePixelRatio * tileSource.getGutterForProjection(projection);\n      for (const tile of tilesByZ[currentZ]) {\n        if (tile.getState() !== TileState.LOADED) {\n          continue;\n        }\n        const tileCoord = tile.tileCoord;\n\n        // Calculate integer positions and sizes so that tiles align\n        const xIndex = originTileCoord[1] - tileCoord[1];\n        const nextX = Math.round(origin[0] - (xIndex - 1) * dx);\n        const yIndex = originTileCoord[2] - tileCoord[2];\n        const nextY = Math.round(origin[1] - (yIndex - 1) * dy);\n        const x = Math.round(origin[0] - xIndex * dx);\n        const y = Math.round(origin[1] - yIndex * dy);\n        const w = nextX - x;\n        const h = nextY - y;\n        const transition = zs.length === 1;\n\n        let contextSaved = false;\n\n        // Clip mask for regions in this tile that already filled by a higher z tile\n        currentClip = [x, y, x + w, y, x + w, y + h, x, y + h];\n        for (let i = 0, ii = clips.length; i < ii; ++i) {\n          if (!transition && currentZ < clipZs[i]) {\n            const clip = clips[i];\n            if (\n              intersects(\n                [x, y, x + w, y + h],\n                [clip[0], clip[3], clip[4], clip[7]],\n              )\n            ) {\n              if (!contextSaved) {\n                context.save();\n                contextSaved = true;\n              }\n              context.beginPath();\n              // counter-clockwise (outer ring) for current tile\n              context.moveTo(currentClip[0], currentClip[1]);\n              context.lineTo(currentClip[2], currentClip[3]);\n              context.lineTo(currentClip[4], currentClip[5]);\n              context.lineTo(currentClip[6], currentClip[7]);\n              // clockwise (inner ring) for higher z tile\n              context.moveTo(clip[6], clip[7]);\n              context.lineTo(clip[4], clip[5]);\n              context.lineTo(clip[2], clip[3]);\n              context.lineTo(clip[0], clip[1]);\n              context.clip();\n            }\n          }\n        }\n        clips.push(currentClip);\n        clipZs.push(currentZ);\n\n        this.drawTile(tile, frameState, x, y, w, h, tileGutter, transition);\n        if (contextSaved) {\n          context.restore();\n        }\n        this.renderedTiles.unshift(tile);\n\n        // TODO: decide if this is necessary\n        this.updateUsedTiles(frameState.usedTiles, tileSource, tile);\n      }\n    }\n\n    this.renderedResolution = tileResolution;\n    this.extentChanged =\n      !this.renderedExtent_ || !equals(this.renderedExtent_, canvasExtent);\n    this.renderedExtent_ = canvasExtent;\n    this.renderedPixelRatio = pixelRatio;\n\n    this.postRender(this.context, frameState);\n\n    if (this.layerExtent) {\n      context.restore();\n    }\n    context.imageSmoothingEnabled = true;\n\n    if (this.renderComplete) {\n      /**\n       * @param {import(\"../../Map.js\").default} map Map.\n       * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n       */\n      const postRenderFunction = (map, frameState) => {\n        const tileSourceKey = getUid(tileSource);\n        const wantedTiles = frameState.wantedTiles[tileSourceKey];\n        const tilesCount = wantedTiles ? Object.keys(wantedTiles).length : 0;\n        this.updateCacheSize(tilesCount);\n        this.tileCache_.expireCache();\n        this.sourceTileCache_?.expireCache();\n      };\n\n      frameState.postRenderFunctions.push(postRenderFunction);\n    }\n\n    // this normally is `div.ol-layer` and is a mocked div in worker\n    return this.container;\n  }\n\n  /**\n   * Increases the cache size if needed\n   * @param {number} tileCount Minimum number of tiles needed.\n   */\n  updateCacheSize(tileCount) {\n    this.tileCache_.highWaterMark = Math.max(\n      this.tileCache_.highWaterMark,\n      tileCount * 2,\n    );\n  }\n\n  /**\n   * @param {import(\"../../Tile.js\").default} tile Tile.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @param {number} x Left of the tile.\n   * @param {number} y Top of the tile.\n   * @param {number} w Width of the tile.\n   * @param {number} h Height of the tile.\n   * @param {number} gutter Tile gutter.\n   * @param {boolean} transition Apply an alpha transition.\n   * @protected\n   */\n  drawTile(tile, frameState, x, y, w, h, gutter, transition) {\n    let image;\n    if (tile instanceof DataTile) {\n      image = asImageLike(tile.getData());\n      if (!image) {\n        throw new Error('Rendering array data is not yet supported');\n      }\n    } else {\n      image = this.getTileImage(\n        /** @type {import(\"../../ImageTile.js\").default} */ (tile),\n      );\n    }\n\n    if (!image) {\n      return;\n    }\n    const context = this.getRenderContext(frameState);\n    const uid = getUid(this);\n    const layerState = frameState.layerStatesArray[frameState.layerIndex];\n    const alpha =\n      layerState.opacity *\n      (transition ? tile.getAlpha(uid, frameState.time) : 1);\n    const alphaChanged = alpha !== context.globalAlpha;\n    if (alphaChanged) {\n      context.save();\n      context.globalAlpha = alpha;\n    }\n    context.drawImage(\n      image,\n      gutter,\n      gutter,\n      image.width - 2 * gutter,\n      image.height - 2 * gutter,\n      x,\n      y,\n      w,\n      h,\n    );\n\n    if (alphaChanged) {\n      context.restore();\n    }\n    if (alpha !== layerState.opacity) {\n      frameState.animate = true;\n    } else if (transition) {\n      tile.endTransition(uid);\n    }\n  }\n\n  /**\n   * @return {HTMLCanvasElement|OffscreenCanvas} Image\n   */\n  getImage() {\n    const context = this.context;\n    return context ? context.canvas : null;\n  }\n\n  /**\n   * Get the image from a tile.\n   * @param {import(\"../../ImageTile.js\").default} tile Tile.\n   * @return {HTMLCanvasElement|OffscreenCanvas|HTMLImageElement|HTMLVideoElement} Image.\n   * @protected\n   */\n  getTileImage(tile) {\n    return tile.getImage();\n  }\n\n  /**\n   * @param {!Object<string, !Object<string, boolean>>} usedTiles Used tiles.\n   * @param {import(\"../../source/Tile.js\").default} tileSource Tile source.\n   * @param {import('../../Tile.js').default} tile Tile.\n   * @protected\n   */\n  updateUsedTiles(usedTiles, tileSource, tile) {\n    // FIXME should we use tilesToDrawByZ instead?\n    const tileSourceKey = getUid(tileSource);\n    if (!(tileSourceKey in usedTiles)) {\n      usedTiles[tileSourceKey] = {};\n    }\n    usedTiles[tileSourceKey][tile.getKey()] = true;\n  }\n}\n\nexport default CanvasTileLayerRenderer;\n","/**\n * @module ol/layer/TileProperty\n */\n\n/**\n * @enum {string}\n */\nexport default {\n  PRELOAD: 'preload',\n  USE_INTERIM_TILES_ON_ERROR: 'useInterimTilesOnError',\n};\n","/**\n * @module ol/layer/BaseTile\n */\nimport Layer from './Layer.js';\nimport TileProperty from './TileProperty.js';\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"./Base.js\").BaseLayerObjectEventTypes|\n *     import(\"./Layer.js\").LayerEventType|'change:preload'|'change:useInterimTilesOnError', import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../render/EventType.js\").LayerRenderEventTypes, import(\"../render/Event.js\").default, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"./Base.js\").BaseLayerObjectEventTypes|\n *   import(\"./Layer.js\").LayerEventType|'change:preload'|'change:useInterimTilesOnError'|import(\"../render/EventType.js\").LayerRenderEventTypes, Return>} BaseTileLayerOnSignature\n */\n\n/**\n * @template {import(\"../source/Tile.js\").default} TileSourceType\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} [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 {number} [preload=0] Preload. Load low-resolution tiles up to `preload` levels. `0`\n * means no preloading.\n * @property {TileSourceType} [source] Source for this layer.\n * @property {import(\"../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 {@link import(\"../Map.js\").default#addLayer map.addLayer()}.\n * @property {import(\"./Base.js\").BackgroundColor} [background] Background color for the layer. If not specified, no background\n * will be rendered.\n * @property {boolean} [useInterimTilesOnError=true] Deprecated.  Use interim tiles on error.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n * @property {number} [cacheSize=512] The internal tile cache size.  This needs to be large enough to render\n * two zoom levels worth of tiles.\n */\n\n/**\n * @classdesc\n * For layer sources that provide pre-rendered, tiled images in grids that are\n * organized by zoom levels for specific resolutions.\n * Note that any property set in the options is set as a {@link module:ol/Object~BaseObject}\n * property on the layer object; for example, setting `title: 'My Title'` in the\n * options means that `title` is observable, and has get/set accessors.\n *\n * @template {import(\"../source/Tile.js\").default} TileSourceType\n * @template {import(\"../renderer/Layer.js\").default} RendererType\n * @extends {Layer<TileSourceType, RendererType>}\n * @api\n */\nclass BaseTileLayer extends Layer {\n  /**\n   * @param {Options<TileSourceType>} [options] Tile layer options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    const baseOptions = Object.assign({}, options);\n\n    const cacheSize = options.cacheSize;\n    delete options.cacheSize;\n\n    delete baseOptions.preload;\n    delete baseOptions.useInterimTilesOnError;\n    super(baseOptions);\n\n    /***\n     * @type {BaseTileLayerOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {BaseTileLayerOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {BaseTileLayerOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @type {number|undefined}\n     * @private\n     */\n    this.cacheSize_ = cacheSize;\n\n    this.setPreload(options.preload !== undefined ? options.preload : 0);\n    this.setUseInterimTilesOnError(\n      options.useInterimTilesOnError !== undefined\n        ? options.useInterimTilesOnError\n        : true,\n    );\n  }\n\n  /**\n   * @return {number|undefined} The suggested cache size\n   * @protected\n   */\n  getCacheSize() {\n    return this.cacheSize_;\n  }\n\n  /**\n   * Return the level as number to which we will preload tiles up to.\n   * @return {number} The level to preload tiles up to.\n   * @observable\n   * @api\n   */\n  getPreload() {\n    return /** @type {number} */ (this.get(TileProperty.PRELOAD));\n  }\n\n  /**\n   * Set the level as number to which we will preload tiles up to.\n   * @param {number} preload The level to preload tiles up to.\n   * @observable\n   * @api\n   */\n  setPreload(preload) {\n    this.set(TileProperty.PRELOAD, preload);\n  }\n\n  /**\n   * Deprecated.  Whether we use interim tiles on error.\n   * @return {boolean} Use interim tiles on error.\n   * @observable\n   * @api\n   */\n  getUseInterimTilesOnError() {\n    return /** @type {boolean} */ (\n      this.get(TileProperty.USE_INTERIM_TILES_ON_ERROR)\n    );\n  }\n\n  /**\n   * Deprecated.  Set whether we use interim tiles on error.\n   * @param {boolean} useInterimTilesOnError Use interim tiles on error.\n   * @observable\n   * @api\n   */\n  setUseInterimTilesOnError(useInterimTilesOnError) {\n    this.set(TileProperty.USE_INTERIM_TILES_ON_ERROR, useInterimTilesOnError);\n  }\n\n  /**\n   * Get data for a pixel location.  The return type depends on the source data.  For image tiles,\n   * a four element RGBA array will be returned.  For data tiles, the array length will match the\n   * number of bands in the dataset.  For requests outside the layer extent, `null` will be returned.\n   * Data for a image tiles can only be retrieved if the source's `crossOrigin` property is set.\n   *\n   * ```js\n   * // display layer data on every pointer move\n   * map.on('pointermove', (event) => {\n   *   console.log(layer.getData(event.pixel));\n   * });\n   * ```\n   * @param {import(\"../pixel.js\").Pixel} pixel Pixel.\n   * @return {Uint8ClampedArray|Uint8Array|Float32Array|DataView|null} Pixel data.\n   * @api\n   * @override\n   */\n  getData(pixel) {\n    return super.getData(pixel);\n  }\n}\n\nexport default BaseTileLayer;\n","/**\n * @module ol/layer/Tile\n */\nimport CanvasTileLayerRenderer from '../renderer/canvas/TileLayer.js';\nimport BaseTileLayer from './BaseTile.js';\n\n/**\n * @classdesc\n * For layer sources that provide pre-rendered, tiled images in grids that are\n * organized by zoom levels for specific resolutions.\n * Note that any property set in the options is set as a {@link module:ol/Object~BaseObject}\n * property on the layer object; for example, setting `title: 'My Title'` in the\n * options means that `title` is observable, and has get/set accessors.\n *\n * @template {import(\"../source/Tile.js\").default} [TileSourceType=import(\"../source/Tile.js\").default]\n * @extends BaseTileLayer<TileSourceType, CanvasTileLayerRenderer>\n * @api\n */\nclass TileLayer extends BaseTileLayer {\n  /**\n   * @param {import(\"./BaseTile.js\").Options<TileSourceType>} [options] Tile layer options.\n   */\n  constructor(options) {\n    super(options);\n  }\n\n  /**\n   * @override\n   */\n  createRenderer() {\n    return new CanvasTileLayerRenderer(this, {\n      cacheSize: this.getCacheSize(),\n    });\n  }\n}\n\nexport default TileLayer;\n","/**\n * @module ol/source/Raster\n */\nimport Disposable from '../Disposable.js';\nimport ImageCanvas from '../ImageCanvas.js';\nimport TileQueue from '../TileQueue.js';\nimport {createCanvasContext2D} from '../dom.js';\nimport Event from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport {equals, getCenter, getHeight, getWidth} from '../extent.js';\nimport ImageLayer from '../layer/Image.js';\nimport TileLayer from '../layer/Tile.js';\nimport {create as createTransform} from '../transform.js';\nimport {getUid} from '../util.js';\nimport ImageSource from './Image.js';\nimport Source from './Source.js';\nimport TileSource from './Tile.js';\n\n/**\n * @typedef {Object} MinionData\n * @property {Array<ArrayBuffer>} buffers Array of buffers.\n * @property {Object} meta Operation metadata.\n * @property {boolean} imageOps The operation is an image operation.\n * @property {number} width The width of the image.\n * @property {number} height The height of the image.\n */\n\n/* istanbul ignore next */\n/**\n * Create a function for running operations.  This function is serialized for\n * use in a worker.\n * @param {function(Array, Object):*} operation The operation.\n * @return {function(MinionData):ArrayBuffer} A function that takes an object with\n * buffers, meta, imageOps, width, and height properties and returns an array\n * buffer.\n */\nfunction createMinion(operation) {\n  return function (data) {\n    // bracket notation for minification support\n    const buffers = data['buffers'];\n    const meta = data['meta'];\n    const imageOps = data['imageOps'];\n    const width = data['width'];\n    const height = data['height'];\n\n    const numBuffers = buffers.length;\n    const numBytes = buffers[0].byteLength;\n\n    if (imageOps) {\n      const images = new Array(numBuffers);\n      for (let b = 0; b < numBuffers; ++b) {\n        images[b] = new ImageData(\n          new Uint8ClampedArray(buffers[b]),\n          width,\n          height,\n        );\n      }\n      const output = operation(images, meta).data;\n      return output.buffer;\n    }\n\n    const output = new Uint8ClampedArray(numBytes);\n    const arrays = new Array(numBuffers);\n    const pixels = new Array(numBuffers);\n    for (let b = 0; b < numBuffers; ++b) {\n      arrays[b] = new Uint8ClampedArray(buffers[b]);\n      pixels[b] = [0, 0, 0, 0];\n    }\n    for (let i = 0; i < numBytes; i += 4) {\n      for (let j = 0; j < numBuffers; ++j) {\n        const array = arrays[j];\n        pixels[j][0] = array[i];\n        pixels[j][1] = array[i + 1];\n        pixels[j][2] = array[i + 2];\n        pixels[j][3] = array[i + 3];\n      }\n      const pixel = operation(pixels, meta);\n      output[i] = pixel[0];\n      output[i + 1] = pixel[1];\n      output[i + 2] = pixel[2];\n      output[i + 3] = pixel[3];\n    }\n    return output.buffer;\n  };\n}\n\n/**\n * Create a worker for running operations.\n * @param {ProcessorOptions} config Processor options.\n * @param {function(MessageEvent): void} onMessage Called with a message event.\n * @return {Worker} The worker.\n */\nfunction createWorker(config, onMessage) {\n  const lib = Object.keys(config.lib || {}).map(function (name) {\n    return 'const ' + name + ' = ' + config.lib[name].toString() + ';';\n  });\n\n  const lines = lib.concat([\n    'const __minion__ = (' + createMinion.toString() + ')(',\n    config.operation.toString(),\n    ');',\n    'self.addEventListener(\"message\", function(event) {',\n    '  const buffer = __minion__(event.data);',\n    '  self.postMessage({buffer: buffer, meta: event.data.meta}, [buffer]);',\n    '});',\n  ]);\n\n  const worker = new Worker(\n    typeof Blob === 'undefined'\n      ? 'data:text/javascript;base64,' +\n        //@ts-expect-error\n        Buffer.from(lines.join('\\n'), 'binary').toString('base64')\n      : URL.createObjectURL(new Blob(lines, {type: 'text/javascript'})),\n  );\n  worker.addEventListener('message', onMessage);\n  return worker;\n}\n\n/**\n * @typedef {Object} FauxMessageEvent\n * @property {Object} data Message data.\n */\n\n/**\n * Create a faux worker for running operations.\n * @param {ProcessorOptions} config Configuration.\n * @param {function(FauxMessageEvent): void} onMessage Called with a message event.\n * @return {Object} The faux worker.\n */\nfunction createFauxWorker(config, onMessage) {\n  const minion = createMinion(config.operation);\n  let terminated = false;\n  return {\n    postMessage: function (data) {\n      setTimeout(function () {\n        if (terminated) {\n          return;\n        }\n        onMessage({data: {buffer: minion(data), meta: data['meta']}});\n      }, 0);\n    },\n    terminate: function () {\n      terminated = true;\n    },\n  };\n}\n\n/**\n * @typedef {function(Error, ImageData, (Object|Array<Object>)): void} JobCallback\n */\n\n/**\n * @typedef {Object} Job\n * @property {Object} meta Job metadata.\n * @property {Array<ImageData>} inputs Array of input data.\n * @property {JobCallback} callback Called when the job is complete.\n */\n\n/**\n * @typedef {Object} ProcessorOptions\n * @property {number} threads Number of workers to spawn.\n * @property {Operation} operation The operation.\n * @property {Object<string, Function>} [lib] Functions that will be made available to operations run in a worker.\n * @property {number} queue The number of queued jobs to allow.\n * @property {boolean} [imageOps=false] Pass all the image data to the operation instead of a single pixel.\n */\n\n/**\n * @classdesc\n * A processor runs pixel or image operations in workers.\n */\nexport class Processor extends Disposable {\n  /**\n   * @param {ProcessorOptions} config Configuration.\n   */\n  constructor(config) {\n    super();\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.imageOps_ = !!config.imageOps;\n    let threads;\n    if (config.threads === 0) {\n      threads = 0;\n    } else if (this.imageOps_) {\n      threads = 1;\n    } else {\n      threads = config.threads || 1;\n    }\n\n    /**\n     * @type {Array<Worker>}\n     */\n    const workers = new Array(threads);\n    if (threads) {\n      for (let i = 0; i < threads; ++i) {\n        workers[i] = createWorker(config, this.onWorkerMessage_.bind(this, i));\n      }\n    } else {\n      workers[0] = createFauxWorker(\n        config,\n        this.onWorkerMessage_.bind(this, 0),\n      );\n    }\n    /**\n     * @type {Array<Worker>}\n     * @private\n     */\n    this.workers_ = workers;\n\n    /**\n     * @type {Array<Job>}\n     * @private\n     */\n    this.queue_ = [];\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.maxQueueLength_ = config.queue || Infinity;\n    /**\n     * @type {number}\n     * @private\n     */\n    this.running_ = 0;\n\n    /**\n     * @type {Object<number, any>}\n     * @private\n     */\n    this.dataLookup_ = {};\n\n    /**\n     * @type {Job|null}\n     * @private\n     */\n    this.job_ = null;\n  }\n\n  /**\n   * Run operation on input data.\n   * @param {Array<ImageData>} inputs Array of image data.\n   * @param {Object} meta A user data object.  This is passed to all operations\n   *     and must be serializable.\n   * @param {function(Error, ImageData, Object): void} callback Called when work\n   *     completes.  The first argument is any error.  The second is the ImageData\n   *     generated by operations.  The third is the user data object.\n   */\n  process(inputs, meta, callback) {\n    this.enqueue_({\n      inputs: inputs,\n      meta: meta,\n      callback: callback,\n    });\n    this.dispatch_();\n  }\n\n  /**\n   * Add a job to the queue.\n   * @param {Job} job The job.\n   */\n  enqueue_(job) {\n    this.queue_.push(job);\n    while (this.queue_.length > this.maxQueueLength_) {\n      this.queue_.shift().callback(null, null);\n    }\n  }\n\n  /**\n   * Dispatch a job.\n   */\n  dispatch_() {\n    if (this.running_ || this.queue_.length === 0) {\n      return;\n    }\n\n    const job = this.queue_.shift();\n    this.job_ = job;\n    const width = job.inputs[0].width;\n    const height = job.inputs[0].height;\n    const buffers = job.inputs.map(function (input) {\n      return input.data.buffer;\n    });\n    const threads = this.workers_.length;\n    this.running_ = threads;\n    if (threads === 1) {\n      this.workers_[0].postMessage(\n        {\n          buffers: buffers,\n          meta: job.meta,\n          imageOps: this.imageOps_,\n          width: width,\n          height: height,\n        },\n        buffers,\n      );\n      return;\n    }\n\n    const length = job.inputs[0].data.length;\n    const segmentLength = 4 * Math.ceil(length / 4 / threads);\n    for (let i = 0; i < threads; ++i) {\n      const offset = i * segmentLength;\n      const slices = [];\n      for (let j = 0, jj = buffers.length; j < jj; ++j) {\n        slices.push(buffers[j].slice(offset, offset + segmentLength));\n      }\n      this.workers_[i].postMessage(\n        {\n          buffers: slices,\n          meta: job.meta,\n          imageOps: this.imageOps_,\n          width: width,\n          height: height,\n        },\n        slices,\n      );\n    }\n  }\n\n  /**\n   * Handle messages from the worker.\n   * @param {number} index The worker index.\n   * @param {MessageEvent} event The message event.\n   */\n  onWorkerMessage_(index, event) {\n    if (this.disposed) {\n      return;\n    }\n    this.dataLookup_[index] = event.data;\n    --this.running_;\n    if (this.running_ === 0) {\n      this.resolveJob_();\n    }\n  }\n\n  /**\n   * Resolve a job.  If there are no more worker threads, the processor callback\n   * will be called.\n   */\n  resolveJob_() {\n    const job = this.job_;\n    const threads = this.workers_.length;\n    let data, meta;\n    if (threads === 1) {\n      data = new Uint8ClampedArray(this.dataLookup_[0]['buffer']);\n      meta = this.dataLookup_[0]['meta'];\n    } else {\n      const length = job.inputs[0].data.length;\n      data = new Uint8ClampedArray(length);\n      meta = new Array(threads);\n      const segmentLength = 4 * Math.ceil(length / 4 / threads);\n      for (let i = 0; i < threads; ++i) {\n        const buffer = this.dataLookup_[i]['buffer'];\n        const offset = i * segmentLength;\n        data.set(new Uint8ClampedArray(buffer), offset);\n        meta[i] = this.dataLookup_[i]['meta'];\n      }\n    }\n    this.job_ = null;\n    this.dataLookup_ = {};\n    job.callback(\n      null,\n      new ImageData(data, job.inputs[0].width, job.inputs[0].height),\n      meta,\n    );\n    this.dispatch_();\n  }\n\n  /**\n   * Terminate all workers associated with the processor.\n   * @override\n   */\n  disposeInternal() {\n    for (let i = 0; i < this.workers_.length; ++i) {\n      this.workers_[i].terminate();\n    }\n    this.workers_.length = 0;\n  }\n}\n\n/**\n * A function that takes an array of input data, performs some operation, and\n * returns an array of output data.\n * For `pixel` type operations, the function will be called with an array of\n * pixels, where each pixel is an array of four numbers (`[r, g, b, a]`) in the\n * range of 0 - 255. It should return a single pixel array.\n * For `'image'` type operations, functions will be called with an array of\n * [ImageData](https://developer.mozilla.org/en-US/docs/Web/API/ImageData)\n * and should return a single\n * [ImageData](https://developer.mozilla.org/en-US/docs/Web/API/ImageData).\n * The operations\n * are called with a second \"data\" argument, which can be used for storage.  The\n * data object is accessible from raster events, where it can be initialized in\n * \"beforeoperations\" and accessed again in \"afteroperations\".\n *\n * @typedef {function((Array<Array<number>>|Array<ImageData>), Object):\n *     (Array<number>|ImageData)} Operation\n */\n\n/**\n * @enum {string}\n */\nconst RasterEventType = {\n  /**\n   * Triggered before operations are run.  Listeners will receive an event object with\n   * a `data` property that can be used to make data available to operations.\n   * @event module:ol/source/Raster.RasterSourceEvent#beforeoperations\n   * @api\n   */\n  BEFOREOPERATIONS: 'beforeoperations',\n\n  /**\n   * Triggered after operations are run.  Listeners will receive an event object with\n   * a `data` property.  If more than one thread is used, `data` will be an array of\n   * objects.  If a single thread is used, `data` will be a single object.\n   * @event module:ol/source/Raster.RasterSourceEvent#afteroperations\n   * @api\n   */\n  AFTEROPERATIONS: 'afteroperations',\n};\n\n/**\n * @typedef {'pixel' | 'image'} RasterOperationType\n * Raster operation type. Supported values are `'pixel'` and `'image'`.\n */\n\n/**\n * @typedef {import(\"./Image.js\").ImageSourceEventTypes|'beforeoperations'|'afteroperations'} RasterSourceEventTypes\n */\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/source/Raster~RasterSource} instances are instances of this\n * type.\n */\nexport class RasterSourceEvent extends Event {\n  /**\n   * @param {string} type Type.\n   * @param {import(\"../Map.js\").FrameState} frameState The frame state.\n   * @param {Object|Array<Object>} data An object made available to operations.  For \"afteroperations\" evenets\n   * this will be an array of objects if more than one thread is used.\n   */\n  constructor(type, frameState, data) {\n    super(type);\n\n    /**\n     * The raster extent.\n     * @type {import(\"../extent.js\").Extent}\n     * @api\n     */\n    this.extent = frameState.extent;\n\n    /**\n     * The pixel resolution (map units per pixel).\n     * @type {number}\n     * @api\n     */\n    this.resolution = frameState.viewState.resolution / frameState.pixelRatio;\n\n    /**\n     * An object made available to all operations.  This can be used by operations\n     * as a storage object (e.g. for calculating statistics).\n     * @type {Object}\n     * @api\n     */\n    this.data = data;\n  }\n}\n\n/**\n * @typedef {Object} Options\n * @property {Array<import(\"./Source.js\").default|import(\"../layer/Layer.js\").default>} sources Input\n * sources or layers.\n * @property {Operation} [operation] Raster operation.\n * The operation will be called with data from input sources\n * and the output will be assigned to the raster source.\n * @property {Object} [lib] Functions that will be made available to operations run in a worker.\n * @property {number} [threads] By default, operations will be run in a single worker thread.\n * To avoid using workers altogether, set `threads: 0`.  For pixel operations, operations can\n * be run in multiple worker threads.  Note that there is additional overhead in\n * transferring data to multiple workers, and that depending on the user's\n * system, it may not be possible to parallelize the work.\n * @property {RasterOperationType} [operationType='pixel'] Operation type.\n * Supported values are `'pixel'` and `'image'`.  By default,\n * `'pixel'` operations are assumed, and operations will be called with an\n * array of pixels from input sources.  If set to `'image'`, operations will\n * be called with an array of ImageData objects from input sources.\n * @property {Array<number>|null} [resolutions] Resolutions. If specified, raster operations will only\n * be run at the given resolutions.  By default, the resolutions of the first source with resolutions\n * specified will be used, if any. Set to `null` to use any view resolution instead.\n */\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types, import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"./Image.js\").ImageSourceEventTypes, import(\"./Image.js\").ImageSourceEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<RasterSourceEventTypes, RasterSourceEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"../ObjectEventType.js\").Types\n *     |RasterSourceEventTypes, Return>} RasterSourceOnSignature\n */\n\n/**\n * @classdesc\n * A source that transforms data from any number of input sources using an\n * {@link module:ol/source/Raster~Operation} function to transform input pixel values into\n * output pixel values.\n *\n * @fires module:ol/source/Raster.RasterSourceEvent\n * @api\n */\nclass RasterSource extends ImageSource {\n  /**\n   * @param {Options} options Options.\n   */\n  constructor(options) {\n    super({\n      projection: null,\n    });\n\n    /***\n     * @type {RasterSourceOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {RasterSourceOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {RasterSourceOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @private\n     * @type {Processor}\n     */\n    this.processor_ = null;\n\n    /**\n     * @private\n     * @type {RasterOperationType}\n     */\n    this.operationType_ =\n      options.operationType !== undefined ? options.operationType : 'pixel';\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.threads_ = options.threads !== undefined ? options.threads : 1;\n\n    /**\n     * @private\n     * @type {Array<import(\"../layer/Layer.js\").default>}\n     */\n    this.layers_ = createLayers(options.sources);\n\n    const changed = this.changed.bind(this);\n    for (let i = 0, ii = this.layers_.length; i < ii; ++i) {\n      this.layers_[i].addEventListener(EventType.CHANGE, changed);\n    }\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.useResolutions_ = options.resolutions !== null;\n\n    /**\n     * @private\n     * @type {import(\"../TileQueue.js\").default}\n     */\n    this.tileQueue_ = new TileQueue(function () {\n      return 1;\n    }, this.processSources_.bind(this));\n\n    /**\n     * The most recently requested frame state.\n     * @type {import(\"../Map.js\").FrameState}\n     * @private\n     */\n    this.requestedFrameState_;\n\n    /**\n     * The most recently rendered image canvas.\n     * @type {import(\"../ImageCanvas.js\").default}\n     * @private\n     */\n    this.renderedImageCanvas_ = null;\n\n    /**\n     * The most recently rendered revision.\n     * @type {number}\n     * @private\n     */\n    this.renderedRevision_;\n\n    /**\n     * @private\n     * @type {import(\"../Map.js\").FrameState}\n     */\n    this.frameState_ = {\n      animate: false,\n      coordinateToPixelTransform: createTransform(),\n      declutter: null,\n      extent: null,\n      index: 0,\n      layerIndex: 0,\n      layerStatesArray: getLayerStatesArray(this.layers_),\n      pixelRatio: 1,\n      pixelToCoordinateTransform: createTransform(),\n      postRenderFunctions: [],\n      size: [0, 0],\n      tileQueue: this.tileQueue_,\n      time: Date.now(),\n      usedTiles: {},\n      viewState: /** @type {import(\"../View.js\").State} */ ({\n        rotation: 0,\n      }),\n      viewHints: [],\n      wantedTiles: {},\n      mapId: getUid(this),\n      renderTargets: {},\n    };\n\n    this.setAttributions(function (frameState) {\n      /** @type {Array<string>} */\n      const attributions = [];\n      for (let i = 0, iMax = options.sources.length; i < iMax; ++i) {\n        const sourceOrLayer = options.sources[i];\n        const source =\n          sourceOrLayer instanceof Source\n            ? sourceOrLayer\n            : sourceOrLayer.getSource();\n        if (!source) {\n          continue;\n        }\n        const sourceAttributions = source.getAttributions()?.(frameState);\n        if (typeof sourceAttributions === 'string') {\n          attributions.push(sourceAttributions);\n        } else if (sourceAttributions !== undefined) {\n          attributions.push(...sourceAttributions);\n        }\n      }\n      return attributions;\n    });\n\n    if (options.operation !== undefined) {\n      this.setOperation(options.operation, options.lib);\n    }\n  }\n\n  /**\n   * Set the operation.\n   * @param {Operation} operation New operation.\n   * @param {Object} [lib] Functions that will be available to operations run\n   *     in a worker.\n   * @api\n   */\n  setOperation(operation, lib) {\n    if (this.processor_) {\n      this.processor_.dispose();\n    }\n\n    this.processor_ = new Processor({\n      operation: operation,\n      imageOps: this.operationType_ === 'image',\n      queue: 1,\n      lib: lib,\n      threads: this.threads_,\n    });\n    this.changed();\n  }\n\n  /**\n   * Update the stored frame state.\n   * @param {import(\"../extent.js\").Extent} extent The view extent (in map units).\n   * @param {number} resolution The view resolution.\n   * @param {import(\"../proj/Projection.js\").default} projection The view projection.\n   * @return {import(\"../Map.js\").FrameState} The updated frame state.\n   * @private\n   */\n  updateFrameState_(extent, resolution, projection) {\n    const frameState = /** @type {import(\"../Map.js\").FrameState} */ (\n      Object.assign({}, this.frameState_)\n    );\n\n    frameState.viewState = /** @type {import(\"../View.js\").State} */ (\n      Object.assign({}, frameState.viewState)\n    );\n\n    const center = getCenter(extent);\n\n    frameState.size[0] = Math.ceil(getWidth(extent) / resolution);\n    frameState.size[1] = Math.ceil(getHeight(extent) / resolution);\n    frameState.extent = [\n      center[0] - (frameState.size[0] * resolution) / 2,\n      center[1] - (frameState.size[1] * resolution) / 2,\n      center[0] + (frameState.size[0] * resolution) / 2,\n      center[1] + (frameState.size[1] * resolution) / 2,\n    ];\n    frameState.time = Date.now();\n\n    const viewState = frameState.viewState;\n    viewState.center = center;\n    viewState.projection = projection;\n    viewState.resolution = resolution;\n    return frameState;\n  }\n\n  /**\n   * Determine if all sources are ready.\n   * @return {boolean} All sources are ready.\n   * @private\n   */\n  allSourcesReady_() {\n    let ready = true;\n    let source;\n    for (let i = 0, ii = this.layers_.length; i < ii; ++i) {\n      source = this.layers_[i].getSource();\n      if (!source || source.getState() !== 'ready') {\n        ready = false;\n        break;\n      }\n    }\n    return ready;\n  }\n\n  /**\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {import(\"../ImageCanvas.js\").default} Single image.\n   * @override\n   */\n  getImage(extent, resolution, pixelRatio, projection) {\n    if (!this.allSourcesReady_()) {\n      return null;\n    }\n\n    this.tileQueue_.loadMoreTiles(16, 16);\n\n    resolution = this.findNearestResolution(resolution);\n    const frameState = this.updateFrameState_(extent, resolution, projection);\n    this.requestedFrameState_ = frameState;\n\n    // check if we can't reuse the existing ol/ImageCanvas\n    if (this.renderedImageCanvas_) {\n      const renderedResolution = this.renderedImageCanvas_.getResolution();\n      const renderedExtent = this.renderedImageCanvas_.getExtent();\n      if (\n        resolution !== renderedResolution ||\n        !equals(frameState.extent, renderedExtent)\n      ) {\n        this.renderedImageCanvas_ = null;\n      }\n    }\n\n    if (\n      !this.renderedImageCanvas_ ||\n      this.getRevision() !== this.renderedRevision_\n    ) {\n      this.processSources_();\n    }\n\n    if (frameState.animate) {\n      requestAnimationFrame(this.changed.bind(this));\n    }\n\n    return this.renderedImageCanvas_;\n  }\n\n  /**\n   * Start processing source data.\n   * @private\n   */\n  processSources_() {\n    const frameState = this.requestedFrameState_;\n    const len = this.layers_.length;\n    const imageDatas = new Array(len);\n    for (let i = 0; i < len; ++i) {\n      frameState.layerIndex = i;\n      frameState.renderTargets = {};\n      const imageData = getImageData(this.layers_[i], frameState);\n      if (imageData) {\n        imageDatas[i] = imageData;\n      } else {\n        return;\n      }\n    }\n\n    const data = {};\n    this.dispatchEvent(\n      new RasterSourceEvent(RasterEventType.BEFOREOPERATIONS, frameState, data),\n    );\n    this.processor_.process(\n      imageDatas,\n      data,\n      this.onWorkerComplete_.bind(this, frameState),\n    );\n  }\n\n  /**\n   * Called when pixel processing is complete.\n   * @param {import(\"../Map.js\").FrameState} frameState The frame state.\n   * @param {Error} err Any error during processing.\n   * @param {ImageData} output The output image data.\n   * @param {Object|Array<Object>} data The user data (or an array if more than one thread).\n   * @private\n   */\n  onWorkerComplete_(frameState, err, output, data) {\n    if (err || !output) {\n      return;\n    }\n\n    // do nothing if extent or resolution changed\n    const extent = frameState.extent;\n    const resolution = frameState.viewState.resolution;\n    if (\n      resolution !== this.requestedFrameState_.viewState.resolution ||\n      !equals(extent, this.requestedFrameState_.extent)\n    ) {\n      return;\n    }\n\n    let context;\n    if (this.renderedImageCanvas_) {\n      context =\n        /** @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} */ (\n          this.renderedImageCanvas_.getImage().getContext('2d')\n        );\n    } else {\n      const width = Math.round(getWidth(extent) / resolution);\n      const height = Math.round(getHeight(extent) / resolution);\n      context = createCanvasContext2D(width, height);\n      this.renderedImageCanvas_ = new ImageCanvas(\n        extent,\n        resolution,\n        1,\n        context.canvas,\n      );\n    }\n    context.putImageData(output, 0, 0);\n\n    if (frameState.animate) {\n      requestAnimationFrame(this.changed.bind(this));\n    } else {\n      this.changed();\n    }\n    this.renderedRevision_ = this.getRevision();\n\n    this.dispatchEvent(\n      new RasterSourceEvent(RasterEventType.AFTEROPERATIONS, frameState, data),\n    );\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} [projection] Projection.\n   * @return {Array<number>|null} Resolutions.\n   * @override\n   */\n  getResolutions(projection) {\n    if (!this.useResolutions_) {\n      return null;\n    }\n    let resolutions = super.getResolutions();\n    if (!resolutions) {\n      for (let i = 0, ii = this.layers_.length; i < ii; ++i) {\n        const source = this.layers_[i].getSource();\n        resolutions = source.getResolutions(projection);\n        if (resolutions) {\n          break;\n        }\n      }\n    }\n    return resolutions;\n  }\n\n  /**\n   * @override\n   */\n  disposeInternal() {\n    if (this.processor_) {\n      this.processor_.dispose();\n    }\n    super.disposeInternal();\n  }\n}\n\n/**\n * Clean up and unregister the worker.\n * @function\n * @api\n */\nRasterSource.prototype.dispose;\n\n/**\n * A reusable canvas context.\n * @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D}\n * @private\n */\nlet sharedContext = null;\n\n/**\n * Get image data from a layer.\n * @param {import(\"../layer/Layer.js\").default} layer Layer to render.\n * @param {import(\"../Map.js\").FrameState} frameState The frame state.\n * @return {ImageData} The image data.\n */\nfunction getImageData(layer, frameState) {\n  const renderer = layer.getRenderer();\n  if (!renderer) {\n    throw new Error('Unsupported layer type: ' + layer);\n  }\n\n  if (!renderer.prepareFrame(frameState)) {\n    return null;\n  }\n  const width = frameState.size[0];\n  const height = frameState.size[1];\n  if (width === 0 || height === 0) {\n    return null;\n  }\n  const container = renderer.renderFrame(frameState, null);\n  let element;\n  if (container instanceof HTMLCanvasElement) {\n    element = container;\n  } else {\n    if (container) {\n      element = container.firstElementChild;\n    }\n    if (!(element instanceof HTMLCanvasElement)) {\n      throw new Error('Unsupported rendered element: ' + element);\n    }\n    if (element.width === width && element.height === height) {\n      const context = element.getContext('2d');\n      return context.getImageData(0, 0, width, height);\n    }\n  }\n\n  if (!sharedContext) {\n    sharedContext = createCanvasContext2D(width, height, undefined, {\n      willReadFrequently: true,\n    });\n  } else {\n    const canvas = sharedContext.canvas;\n    if (canvas.width !== width || canvas.height !== height) {\n      sharedContext = createCanvasContext2D(width, height, undefined, {\n        willReadFrequently: true,\n      });\n    } else {\n      sharedContext.clearRect(0, 0, width, height);\n    }\n  }\n  sharedContext.drawImage(element, 0, 0, width, height);\n  return sharedContext.getImageData(0, 0, width, height);\n}\n\n/**\n * Get a list of layer states from a list of layers.\n * @param {Array<import(\"../layer/Layer.js\").default>} layers Layers.\n * @return {Array<import(\"../layer/Layer.js\").State>} The layer states.\n */\nfunction getLayerStatesArray(layers) {\n  return layers.map(function (layer) {\n    return layer.getLayerState();\n  });\n}\n\n/**\n * Create layers for all sources.\n * @param {Array<import(\"./Source.js\").default|import(\"../layer/Layer.js\").default>} sources The sources.\n * @return {Array<import(\"../layer/Layer.js\").default>} Array of layers.\n */\nfunction createLayers(sources) {\n  const len = sources.length;\n  const layers = new Array(len);\n  for (let i = 0; i < len; ++i) {\n    layers[i] = createLayer(sources[i]);\n  }\n  return layers;\n}\n\n/**\n * Create a layer for the provided source.\n * @param {import(\"./Source.js\").default|import(\"../layer/Layer.js\").default} layerOrSource The layer or source.\n * @return {import(\"../layer/Layer.js\").default} The layer.\n */\nfunction createLayer(layerOrSource) {\n  // @type {import(\"../layer/Layer.js\").default}\n  let layer;\n  if (layerOrSource instanceof Source) {\n    if (layerOrSource instanceof TileSource) {\n      layer = new TileLayer({source: layerOrSource});\n    } else if (layerOrSource instanceof ImageSource) {\n      layer = new ImageLayer({source: layerOrSource});\n    }\n  } else {\n    layer = layerOrSource;\n  }\n  return layer;\n}\n\nexport default RasterSource;\n","/**\n * @module ol/source/StadiaMaps\n */\n\nimport {ATTRIBUTION as OSM_ATTRIBUTION} from './OSM.js';\nimport XYZ from './XYZ.js';\n\n/**\n * @type {string}\n */\nconst STADIA_ATTRIBUTION =\n  '&copy; <a href=\"https://www.stadiamaps.com/\" target=\"_blank\">Stadia Maps</a>';\n\n/**\n * @type {string}\n */\nconst OMT_ATTRIBUTION =\n  '&copy; <a href=\"https://openmaptiles.org/\" target=\"_blank\">OpenMapTiles</a>';\n\n/**\n * @type {string}\n */\nconst STAMEN_ATTRIBUTION =\n  '&copy; <a href=\"https://stamen.com/\" target=\"_blank\">Stamen Design</a>';\n\n/**\n * @type {Object<string, {extension: string}>}\n */\nconst LayerConfig = {\n  'stamen_terrain': {\n    extension: 'png',\n  },\n  'stamen_terrain_background': {\n    extension: 'png',\n  },\n  'stamen_terrain_labels': {\n    extension: 'png',\n  },\n  'stamen_terrain_lines': {\n    extension: 'png',\n  },\n  'stamen_toner_background': {\n    extension: 'png',\n  },\n  'stamen_toner': {\n    extension: 'png',\n  },\n  'stamen_toner_labels': {\n    extension: 'png',\n  },\n  'stamen_toner_lines': {\n    extension: 'png',\n  },\n  'stamen_toner_lite': {\n    extension: 'png',\n  },\n  'stamen_toner_dark': {\n    extension: 'png',\n  },\n  'stamen_toner_blacklite': {\n    extension: 'png',\n  },\n  'stamen_watercolor': {\n    extension: 'jpg',\n  },\n  'alidade_smooth': {\n    extension: 'png',\n  },\n  'alidade_smooth_dark': {\n    extension: 'png',\n  },\n  'alidade_satellite': {\n    extension: 'png',\n  },\n  'outdoors': {\n    extension: 'png',\n  },\n  'osm_bright': {\n    extension: 'png',\n  },\n};\n\n/**\n * @type {Object<string, {minZoom: number, maxZoom: number, retina: boolean}>}\n */\nconst ProviderConfig = {\n  'stamen_terrain': {\n    minZoom: 0,\n    maxZoom: 18,\n    retina: true,\n  },\n  'stamen_toner': {\n    minZoom: 0,\n    maxZoom: 20,\n    retina: true,\n  },\n  'stamen_toner_dark': {\n    minZoom: 0,\n    maxZoom: 20,\n    retina: true,\n  },\n  'stamen_toner_blacklite': {\n    minZoom: 0,\n    maxZoom: 20,\n    retina: true,\n  },\n  'stamen_watercolor': {\n    minZoom: 1,\n    maxZoom: 18,\n    retina: false,\n  },\n};\n\n/**\n * @typedef {Object} Options\n * @property {number} [cacheSize] Deprecated.  Use the cacheSize option on the layer instead.\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * linear interpolation is used when resampling.  Set to false to use the nearest neighbor instead.\n * @property {string} layer Layer name. Valid values: `alidade_smooth`, `alidade_smooth_dark`, `outdoors`, `stamen_terrain`, `stamen_terrain_background`, `stamen_terrain_labels`, `stamen_terrain_lines`, `stamen_toner_background`, `stamen_toner`, `stamen_toner_labels`, `stamen_toner_lines`, `stamen_toner_lite`, `stamen_watercolor`, and `osm_bright`.\n * @property {number} [minZoom] Minimum zoom.\n * @property {number} [maxZoom] Maximum zoom.\n * @property {number} [reprojectionErrorThreshold=0.5] Maximum allowed reprojection error (in pixels).\n * Higher values can increase reprojection performance, but decrease precision.\n * @property {import(\"../Tile.js\").LoadFunction} [tileLoadFunction]\n * Optional function to load a tile given a URL. The default is\n * ```js\n * function(imageTile, src) {\n *   imageTile.getImage().src = src;\n * };\n * ```\n * @property {number} [transition=250] Duration of the opacity transition for rendering.\n * To disable the opacity transition, pass `transition: 0`.\n * @property {string} [url] URL template. Must include `{x}`, `{y}` or `{-y}`, and `{z}` placeholders.\n * @property {boolean} [wrapX=true] Whether to wrap the world horizontally.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n * @property {string} [apiKey] Stadia Maps API key. Not required for localhost or most public web deployments. See https://docs.stadiamaps.com/authentication/ for details.\n * @property {boolean} [retina] Use retina tiles (if available; not available for Stamen Watercolor).\n */\n\n/**\n * @classdesc\n * Layer source for the Stadia Maps tile server.\n * @api\n */\nclass StadiaMaps extends XYZ {\n  /**\n   * @param {Options} options StadiaMaps options.\n   */\n  constructor(options) {\n    const i = options.layer.indexOf('-');\n    const provider = i == -1 ? options.layer : options.layer.slice(0, i);\n    const providerConfig = ProviderConfig[provider] || {\n      'minZoom': 0,\n      'maxZoom': 20,\n      'retina': true,\n    };\n\n    const layerConfig = LayerConfig[options.layer];\n    const query = options.apiKey ? '?api_key=' + options.apiKey : '';\n    const retina = providerConfig.retina && options.retina ? '@2x' : '';\n\n    const url =\n      options.url !== undefined\n        ? options.url\n        : 'https://tiles.stadiamaps.com/tiles/' +\n          options.layer +\n          '/{z}/{x}/{y}' +\n          retina +\n          '.' +\n          layerConfig.extension +\n          query;\n\n    const attributions = [STADIA_ATTRIBUTION, OMT_ATTRIBUTION, OSM_ATTRIBUTION];\n\n    if (options.layer.startsWith('stamen_')) {\n      attributions.splice(1, 0, STAMEN_ATTRIBUTION);\n    }\n\n    super({\n      attributions: attributions,\n      cacheSize: options.cacheSize,\n      crossOrigin: 'anonymous',\n      interpolate: options.interpolate,\n      maxZoom:\n        options.maxZoom !== undefined\n          ? options.maxZoom\n          : providerConfig.maxZoom,\n      minZoom:\n        options.minZoom !== undefined\n          ? options.minZoom\n          : providerConfig.minZoom,\n      reprojectionErrorThreshold: options.reprojectionErrorThreshold,\n      tileLoadFunction: options.tileLoadFunction,\n      transition: options.transition,\n      url: url,\n      tilePixelRatio: retina ? 2 : 1,\n      wrapX: options.wrapX,\n      zDirection: options.zDirection,\n    });\n  }\n}\n\nexport default StadiaMaps;\n","/**\n * @module ol/source/UTFGrid\n */\n\nimport Tile from '../Tile.js';\nimport TileState from '../TileState.js';\nimport {listenOnce} from '../events.js';\nimport EventType from '../events/EventType.js';\nimport {applyTransform, intersects} from '../extent.js';\nimport {jsonp as requestJSONP} from '../net.js';\nimport {get as getProjection, getTransformFromProjections} from '../proj.js';\nimport LRUCache from '../structs/LRUCache.js';\nimport {getKeyZXY} from '../tilecoord.js';\nimport {createXYZ, extentFromProjection} from '../tilegrid.js';\nimport {createFromTemplates, nullTileUrlFunction} from '../tileurlfunction.js';\nimport TileSource from './Tile.js';\n\n/**\n * @typedef {Object} UTFGridJSON\n * @property {Array<string>} grid The grid.\n * @property {Array<string>} keys The keys.\n * @property {Object<string, Object>} [data] Optional data.\n */\n\nexport class CustomTile 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 {import(\"../extent.js\").Extent} extent Extent of the tile.\n   * @param {boolean} preemptive Load the tile when visible (before it's needed).\n   * @param {boolean} jsonp Load the tile as a script.\n   */\n  constructor(tileCoord, state, src, extent, preemptive, jsonp) {\n    super(tileCoord, state);\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.src_ = src;\n\n    /**\n     * @private\n     * @type {import(\"../extent.js\").Extent}\n     */\n    this.extent_ = extent;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.preemptive_ = preemptive;\n\n    /**\n     * @private\n     * @type {Array<string>}\n     */\n    this.grid_ = null;\n\n    /**\n     * @private\n     * @type {Array<string>}\n     */\n    this.keys_ = null;\n\n    /**\n     * @private\n     * @type {Object<string, Object>|undefined}\n     */\n    this.data_ = null;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.jsonp_ = jsonp;\n  }\n\n  /**\n   * Get the image element for this tile.\n   * @return {HTMLImageElement} Image.\n   */\n  getImage() {\n    return null;\n  }\n\n  /**\n   * Synchronously returns data at given coordinate (if available).\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @return {*} The data.\n   */\n  getData(coordinate) {\n    if (!this.grid_ || !this.keys_) {\n      return null;\n    }\n    const xRelative =\n      (coordinate[0] - this.extent_[0]) / (this.extent_[2] - this.extent_[0]);\n    const yRelative =\n      (coordinate[1] - this.extent_[1]) / (this.extent_[3] - this.extent_[1]);\n\n    const row = this.grid_[Math.floor((1 - yRelative) * this.grid_.length)];\n\n    if (typeof row !== 'string') {\n      return null;\n    }\n\n    let code = row.charCodeAt(Math.floor(xRelative * row.length));\n    if (code >= 93) {\n      code--;\n    }\n    if (code >= 35) {\n      code--;\n    }\n    code -= 32;\n\n    let data = null;\n    if (code in this.keys_) {\n      const id = this.keys_[code];\n      if (this.data_ && id in this.data_) {\n        data = this.data_[id];\n      } else {\n        data = id;\n      }\n    }\n    return data;\n  }\n\n  /**\n   * Calls the callback (synchronously by default) with the available data\n   * for given coordinate (or `null` if not yet loaded).\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @param {function(*): void} callback Callback.\n   * @param {boolean} [request] If `true` the callback is always async.\n   *                               The tile data is requested if not yet loaded.\n   */\n  forDataAtCoordinate(coordinate, callback, request) {\n    if (this.state == TileState.EMPTY && request === true) {\n      this.state = TileState.IDLE;\n      listenOnce(this, EventType.CHANGE, (e) => {\n        callback(this.getData(coordinate));\n      });\n      this.loadInternal_();\n    } else {\n      if (request === true) {\n        setTimeout(() => {\n          callback(this.getData(coordinate));\n        }, 0);\n      } else {\n        callback(this.getData(coordinate));\n      }\n    }\n  }\n\n  /**\n   * Return the key to be used for all tiles in the source.\n   * @return {string} The key for all tiles.\n   * @override\n   */\n  getKey() {\n    return this.src_;\n  }\n\n  /**\n   * @private\n   */\n  handleError_() {\n    this.state = TileState.ERROR;\n    this.changed();\n  }\n\n  /**\n   * @param {!UTFGridJSON} json UTFGrid data.\n   * @private\n   */\n  handleLoad_(json) {\n    this.grid_ = json['grid'];\n    this.keys_ = json['keys'];\n    this.data_ = json['data'];\n\n    this.state = TileState.LOADED;\n    this.changed();\n  }\n\n  /**\n   * @private\n   */\n  loadInternal_() {\n    if (this.state == TileState.IDLE) {\n      this.state = TileState.LOADING;\n      if (this.jsonp_) {\n        requestJSONP(\n          this.src_,\n          this.handleLoad_.bind(this),\n          this.handleError_.bind(this),\n        );\n      } else {\n        const client = new XMLHttpRequest();\n        client.addEventListener('load', this.onXHRLoad_.bind(this));\n        client.addEventListener('error', this.onXHRError_.bind(this));\n        client.open('GET', this.src_);\n        client.send();\n      }\n    }\n  }\n\n  /**\n   * @private\n   * @param {Event} event The load event.\n   */\n  onXHRLoad_(event) {\n    const client = /** @type {XMLHttpRequest} */ (event.target);\n    // status will be 0 for file:// urls\n    if (!client.status || (client.status >= 200 && client.status < 300)) {\n      let response;\n      try {\n        response = /** @type {!UTFGridJSON} */ (\n          JSON.parse(client.responseText)\n        );\n      } catch {\n        this.handleError_();\n        return;\n      }\n      this.handleLoad_(response);\n    } else {\n      this.handleError_();\n    }\n  }\n\n  /**\n   * @private\n   * @param {Event} event The error event.\n   */\n  onXHRError_(event) {\n    this.handleError_();\n  }\n\n  /**\n   * @override\n   */\n  load() {\n    if (this.preemptive_) {\n      this.loadInternal_();\n    } else {\n      this.setState(TileState.EMPTY);\n    }\n  }\n}\n\n/**\n * @typedef {Object} Options\n * @property {boolean} [preemptive=true]\n * If `true` the UTFGrid source loads the tiles based on their \"visibility\".\n * This improves the speed of response, but increases traffic.\n * Note that if set to `false` (lazy loading), you need to pass `true` as\n * `request` to the `forDataAtCoordinateAndResolution` method otherwise no\n * data will ever be loaded.\n * @property {boolean} [jsonp=false] Use JSONP with callback to load the TileJSON.\n * Useful when the server does not support CORS..\n * @property {import(\"./TileJSON.js\").Config} [tileJSON] TileJSON configuration for this source.\n * If not provided, `url` must be configured.\n * @property {string} [url] TileJSON endpoint that provides the configuration for this source.\n * Request will be made through JSONP. If not provided, `tileJSON` must be configured.\n * @property {boolean} [wrapX=true] Whether to wrap the world horizontally.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n */\n\n/**\n * @classdesc\n * Layer source for UTFGrid interaction data loaded from TileJSON format.\n * @api\n */\nclass UTFGrid extends TileSource {\n  /**\n   * @param {Options} options Source options.\n   */\n  constructor(options) {\n    super({\n      projection: getProjection('EPSG:3857'),\n      state: 'loading',\n      wrapX: options.wrapX !== undefined ? options.wrapX : true,\n      zDirection: options.zDirection,\n    });\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.preemptive_ =\n      options.preemptive !== undefined ? options.preemptive : true;\n\n    /**\n     * @private\n     * @type {!import(\"../Tile.js\").UrlFunction}\n     */\n    this.tileUrlFunction_ = nullTileUrlFunction;\n\n    /**\n     * @private\n     * @type {string|undefined}\n     */\n    this.template_ = undefined;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.jsonp_ = options.jsonp || false;\n\n    /**\n     * @private\n     * @type {LRUCache}\n     */\n    this.tileCache_ = new LRUCache(512);\n\n    if (options.url) {\n      if (this.jsonp_) {\n        requestJSONP(\n          options.url,\n          this.handleTileJSONResponse.bind(this),\n          this.handleTileJSONError.bind(this),\n        );\n      } else {\n        const client = new XMLHttpRequest();\n        client.addEventListener('load', this.onXHRLoad_.bind(this));\n        client.addEventListener('error', this.onXHRError_.bind(this));\n        client.open('GET', options.url);\n        client.send();\n      }\n    } else if (options.tileJSON) {\n      this.handleTileJSONResponse(options.tileJSON);\n    } else {\n      throw new Error('Either `url` or `tileJSON` options must be provided');\n    }\n  }\n\n  /**\n   * @private\n   * @param {Event} event The load event.\n   */\n  onXHRLoad_(event) {\n    const client = /** @type {XMLHttpRequest} */ (event.target);\n    // status will be 0 for file:// urls\n    if (!client.status || (client.status >= 200 && client.status < 300)) {\n      let response;\n      try {\n        response = /** @type {import(\"./TileJSON.js\").Config} */ (\n          JSON.parse(client.responseText)\n        );\n      } catch {\n        this.handleTileJSONError();\n        return;\n      }\n      this.handleTileJSONResponse(response);\n    } else {\n      this.handleTileJSONError();\n    }\n  }\n\n  /**\n   * @private\n   * @param {Event} event The error event.\n   */\n  onXHRError_(event) {\n    this.handleTileJSONError();\n  }\n\n  /**\n   * Return the template from TileJSON.\n   * @return {string|undefined} The template from TileJSON.\n   * @api\n   */\n  getTemplate() {\n    return this.template_;\n  }\n\n  /**\n   * Calls the callback (synchronously by default) with the available data\n   * for given coordinate and resolution (or `null` if not yet loaded or\n   * in case of an error).\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @param {number} resolution Resolution.\n   * @param {function(*): void} callback Callback.\n   * @param {boolean} [request] If `true` the callback is always async.\n   *                               The tile data is requested if not yet loaded.\n   * @api\n   */\n  forDataAtCoordinateAndResolution(coordinate, resolution, callback, request) {\n    if (this.tileGrid) {\n      const z = this.tileGrid.getZForResolution(resolution, this.zDirection);\n      const tileCoord = this.tileGrid.getTileCoordForCoordAndZ(coordinate, z);\n      const tile = /** @type {!CustomTile} */ (\n        this.getTile(\n          tileCoord[0],\n          tileCoord[1],\n          tileCoord[2],\n          1,\n          this.getProjection(),\n        )\n      );\n      if (tile.getState() == TileState.IDLE) {\n        tile.load();\n      }\n      tile.forDataAtCoordinate(coordinate, callback, request);\n    } else {\n      if (request === true) {\n        setTimeout(function () {\n          callback(null);\n        }, 0);\n      } else {\n        callback(null);\n      }\n    }\n  }\n\n  /**\n   * @protected\n   */\n  handleTileJSONError() {\n    this.setState('error');\n  }\n\n  /**\n   * TODO: very similar to ol/source/TileJSON#handleTileJSONResponse\n   * @protected\n   * @param {import(\"./TileJSON.js\").Config} tileJSON Tile JSON.\n   */\n  handleTileJSONResponse(tileJSON) {\n    const epsg4326Projection = getProjection('EPSG:4326');\n\n    const sourceProjection = this.getProjection();\n    let extent;\n    if (tileJSON['bounds'] !== undefined) {\n      const transform = getTransformFromProjections(\n        epsg4326Projection,\n        sourceProjection,\n      );\n      extent = applyTransform(tileJSON['bounds'], transform);\n    }\n\n    const gridExtent = extentFromProjection(sourceProjection);\n    const minZoom = tileJSON['minzoom'] || 0;\n    const maxZoom = tileJSON['maxzoom'] || 22;\n    const tileGrid = createXYZ({\n      extent: gridExtent,\n      maxZoom: maxZoom,\n      minZoom: minZoom,\n    });\n    this.tileGrid = tileGrid;\n\n    this.template_ = tileJSON['template'];\n\n    const grids = tileJSON['grids'];\n    if (!grids) {\n      this.setState('error');\n      return;\n    }\n\n    this.tileUrlFunction_ = createFromTemplates(grids, tileGrid);\n\n    if (tileJSON['attribution']) {\n      const attributionExtent = extent !== undefined ? extent : gridExtent;\n      this.setAttributions(function (frameState) {\n        if (intersects(attributionExtent, frameState.extent)) {\n          return [tileJSON['attribution']];\n        }\n        return null;\n      });\n    }\n\n    this.setState('ready');\n  }\n\n  /**\n   * @param {number} z Tile coordinate z.\n   * @param {number} x Tile coordinate x.\n   * @param {number} y Tile coordinate y.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {!CustomTile} Tile.\n   * @override\n   */\n  getTile(z, x, y, pixelRatio, projection) {\n    const tileCoord = [z, x, y];\n    const urlTileCoord = this.getTileCoordForTileUrlFunction(\n      tileCoord,\n      projection,\n    );\n    const tileUrl = this.tileUrlFunction_(urlTileCoord, pixelRatio, projection);\n    const tileKey = `${this.getKey()},${getKeyZXY(z, x, y)}`;\n    if (this.tileCache_.containsKey(tileKey)) {\n      return this.tileCache_.get(tileKey);\n    }\n    this.tileCache_.expireCache();\n    const tile = new CustomTile(\n      tileCoord,\n      tileUrl !== undefined ? TileState.IDLE : TileState.EMPTY,\n      tileUrl !== undefined ? tileUrl : '',\n      this.tileGrid.getTileCoordExtent(tileCoord),\n      this.preemptive_,\n      this.jsonp_,\n    );\n    this.tileCache_.set(tileKey, tile);\n    return tile;\n  }\n}\n\nexport default UTFGrid;\n","/**\n * @module ol/xml\n */\nimport {extend} from './array.js';\n\n/**\n * When using {@link module:ol/xml.makeChildAppender} or\n * {@link module:ol/xml.makeSimpleNodeFactory}, the top `objectStack` item needs\n * to have this structure.\n * @typedef {Object} NodeStackItem\n * @property {Element} node Node.\n */\n\n/**\n * @typedef {function(Element, Array<*>): void} Parser\n */\n\n/**\n * @typedef {function(Element, *, Array<*>): void} Serializer\n */\n\n/**\n * @type {string}\n */\nexport const XML_SCHEMA_INSTANCE_URI =\n  'http://www.w3.org/2001/XMLSchema-instance';\n\n/**\n * @param {string} namespaceURI Namespace URI.\n * @param {string} qualifiedName Qualified name.\n * @return {Element} Node.\n */\nexport function createElementNS(namespaceURI, qualifiedName) {\n  return getDocument().createElementNS(namespaceURI, qualifiedName);\n}\n\n/**\n * Recursively grab all text content of child nodes into a single string.\n * @param {Node} node Node.\n * @param {boolean} normalizeWhitespace Normalize whitespace: remove all line\n * breaks.\n * @return {string} All text content.\n * @api\n */\nexport function getAllTextContent(node, normalizeWhitespace) {\n  return getAllTextContent_(node, normalizeWhitespace, []).join('');\n}\n\n/**\n * Recursively grab all text content of child nodes into a single string.\n * @param {Node} node Node.\n * @param {boolean} normalizeWhitespace Normalize whitespace: remove all line\n * breaks.\n * @param {Array<string>} accumulator Accumulator.\n * @private\n * @return {Array<string>} Accumulator.\n */\nexport function getAllTextContent_(node, normalizeWhitespace, accumulator) {\n  if (\n    node.nodeType == Node.CDATA_SECTION_NODE ||\n    node.nodeType == Node.TEXT_NODE\n  ) {\n    if (normalizeWhitespace) {\n      accumulator.push(String(node.nodeValue).replace(/(\\r\\n|\\r|\\n)/g, ''));\n    } else {\n      accumulator.push(node.nodeValue);\n    }\n  } else {\n    let n;\n    for (n = node.firstChild; n; n = n.nextSibling) {\n      getAllTextContent_(n, normalizeWhitespace, accumulator);\n    }\n  }\n  return accumulator;\n}\n\n/**\n * @param {Object} object Object.\n * @return {boolean} Is a document.\n */\nexport function isDocument(object) {\n  return 'documentElement' in object;\n}\n\n/**\n * @param {Element} node Node.\n * @param {?string} namespaceURI Namespace URI.\n * @param {string} name Attribute name.\n * @return {string} Value\n */\nexport function getAttributeNS(node, namespaceURI, name) {\n  return node.getAttributeNS(namespaceURI, name) || '';\n}\n\n/**\n * Parse an XML string to an XML Document.\n * @param {string} xml XML.\n * @return {Document} Document.\n * @api\n */\nexport function parse(xml) {\n  return new DOMParser().parseFromString(xml, 'application/xml');\n}\n\n/**\n * Make an array extender function for extending the array at the top of the\n * object stack.\n * @param {function(this: T, Node, Array<*>): (Array<*>|undefined)} valueReader Value reader.\n * @param {T} [thisArg] The object to use as `this` in `valueReader`.\n * @return {Parser} Parser.\n * @template T\n */\nexport function makeArrayExtender(valueReader, thisArg) {\n  return (\n    /**\n     * @param {Node} node Node.\n     * @param {Array<*>} objectStack Object stack.\n     * @this {*}\n     */\n    function (node, objectStack) {\n      const value = valueReader.call(thisArg ?? this, node, objectStack);\n      if (value !== undefined) {\n        const array = /** @type {Array<*>} */ (\n          objectStack[objectStack.length - 1]\n        );\n        extend(array, value);\n      }\n    }\n  );\n}\n\n/**\n * Make an array pusher function for pushing to the array at the top of the\n * object stack.\n * @param {function(this: T, Element, Array<*>): *} valueReader Value reader.\n * @param {T} [thisArg] The object to use as `this` in `valueReader`.\n * @return {Parser} Parser.\n * @template T\n */\nexport function makeArrayPusher(valueReader, thisArg) {\n  return (\n    /**\n     * @param {Element} node Node.\n     * @param {Array<*>} objectStack Object stack.\n     * @this {*}\n     */\n    function (node, objectStack) {\n      const value = valueReader.call(thisArg ?? this, node, objectStack);\n      if (value !== undefined) {\n        const array = /** @type {Array<*>} */ (\n          objectStack[objectStack.length - 1]\n        );\n        array.push(value);\n      }\n    }\n  );\n}\n\n/**\n * Make an object stack replacer function for replacing the object at the\n * top of the stack.\n * @param {function(this: T, Node, Array<*>): *} valueReader Value reader.\n * @param {T} [thisArg] The object to use as `this` in `valueReader`.\n * @return {Parser} Parser.\n * @template T\n */\nexport function makeReplacer(valueReader, thisArg) {\n  return (\n    /**\n     * @param {Node} node Node.\n     * @param {Array<*>} objectStack Object stack.\n     * @this {*}\n     */\n    function (node, objectStack) {\n      const value = valueReader.call(thisArg ?? this, node, objectStack);\n      if (value !== undefined) {\n        objectStack[objectStack.length - 1] = value;\n      }\n    }\n  );\n}\n\n/**\n * Make an object property pusher function for adding a property to the\n * object at the top of the stack.\n * @param {function(this: T, Element, Array<*>): *} valueReader Value reader.\n * @param {string} [property] Property.\n * @param {T} [thisArg] The object to use as `this` in `valueReader`.\n * @return {Parser} Parser.\n * @template T\n */\nexport function makeObjectPropertyPusher(valueReader, property, thisArg) {\n  return (\n    /**\n     * @param {Element} node Node.\n     * @param {Array<*>} objectStack Object stack.\n     * @this {*}\n     */\n    function (node, objectStack) {\n      const value = valueReader.call(thisArg ?? this, node, objectStack);\n      if (value !== undefined) {\n        const object = /** @type {!Object} */ (\n          objectStack[objectStack.length - 1]\n        );\n        const name = property !== undefined ? property : node.localName;\n        let array;\n        if (name in object) {\n          array = object[name];\n        } else {\n          array = [];\n          object[name] = array;\n        }\n        array.push(value);\n      }\n    }\n  );\n}\n\n/**\n * Make an object property setter function.\n * @param {function(this: T, Element, Array<*>): *} valueReader Value reader.\n * @param {string} [property] Property.\n * @param {T} [thisArg] The object to use as `this` in `valueReader`.\n * @return {Parser} Parser.\n * @template T\n */\nexport function makeObjectPropertySetter(valueReader, property, thisArg) {\n  return (\n    /**\n     * @param {Element} node Node.\n     * @param {Array<*>} objectStack Object stack.\n     * @this {*}\n     */\n    function (node, objectStack) {\n      const value = valueReader.call(thisArg ?? this, node, objectStack);\n      if (value !== undefined) {\n        const object = /** @type {!Object} */ (\n          objectStack[objectStack.length - 1]\n        );\n        const name = property !== undefined ? property : node.localName;\n        object[name] = value;\n      }\n    }\n  );\n}\n\n/**\n * Create a serializer that appends nodes written by its `nodeWriter` to its\n * designated parent. The parent is the `node` of the\n * {@link module:ol/xml~NodeStackItem} at the top of the `objectStack`.\n * @param {function(this: T, Node, V, Array<*>): void} nodeWriter Node writer.\n * @param {T} [thisArg] The object to use as `this` in `nodeWriter`.\n * @return {Serializer} Serializer.\n * @template T, V\n */\nexport function makeChildAppender(nodeWriter, thisArg) {\n  return (\n    /**\n     * @param {Element} node Node.\n     * @param {*} value Value to be written.\n     * @param {Array<*>} objectStack Object stack.\n     * @this {*}\n     */\n    function (node, value, objectStack) {\n      nodeWriter.call(thisArg ?? this, node, value, objectStack);\n      const parent = /** @type {NodeStackItem} */ (\n        objectStack[objectStack.length - 1]\n      );\n      const parentNode = parent.node;\n      parentNode.appendChild(node);\n    }\n  );\n}\n\n/**\n * Create a serializer that calls the provided `nodeWriter` from\n * {@link module:ol/xml.serialize}. This can be used by the parent writer to have the\n * `nodeWriter` called with an array of values when the `nodeWriter` was\n * designed to serialize a single item. An example would be a LineString\n * geometry writer, which could be reused for writing MultiLineString\n * geometries.\n * @param {function(this: T, Element, V, Array<*>): void} nodeWriter Node writer.\n * @param {T} [thisArg] The object to use as `this` in `nodeWriter`.\n * @return {Serializer} Serializer.\n * @template T, V\n */\nexport function makeArraySerializer(nodeWriter, thisArg) {\n  let serializersNS, nodeFactory;\n  return function (node, value, objectStack) {\n    if (serializersNS === undefined) {\n      serializersNS = {};\n      const serializers = {};\n      serializers[node.localName] = nodeWriter;\n      serializersNS[node.namespaceURI] = serializers;\n      nodeFactory = makeSimpleNodeFactory(node.localName);\n    }\n    serialize(serializersNS, nodeFactory, value, objectStack);\n  };\n}\n\n/**\n * Create a node factory which can use the `keys` passed to\n * {@link module:ol/xml.serialize} or {@link module:ol/xml.pushSerializeAndPop} as node names,\n * or a fixed node name. The namespace of the created nodes can either be fixed,\n * or the parent namespace will be used.\n * @param {string} [fixedNodeName] Fixed node name which will be used for all\n *     created nodes. If not provided, the 3rd argument to the resulting node\n *     factory needs to be provided and will be the nodeName.\n * @param {string} [fixedNamespaceURI] Fixed namespace URI which will be used for\n *     all created nodes. If not provided, the namespace of the parent node will\n *     be used.\n * @return {function(*, Array<*>, string=): (Node|undefined)} Node factory.\n */\nexport function makeSimpleNodeFactory(fixedNodeName, fixedNamespaceURI) {\n  return (\n    /**\n     * @param {*} value Value.\n     * @param {Array<*>} objectStack Object stack.\n     * @param {string} [newNodeName] Node name.\n     * @return {Node} Node.\n     */\n    function (value, objectStack, newNodeName) {\n      const context = /** @type {NodeStackItem} */ (\n        objectStack[objectStack.length - 1]\n      );\n      const node = context.node;\n      let nodeName = fixedNodeName;\n      if (nodeName === undefined) {\n        nodeName = newNodeName;\n      }\n\n      const namespaceURI =\n        fixedNamespaceURI !== undefined ? fixedNamespaceURI : node.namespaceURI;\n      return createElementNS(namespaceURI, /** @type {string} */ (nodeName));\n    }\n  );\n}\n\n/**\n * A node factory that creates a node using the parent's `namespaceURI` and the\n * `nodeName` passed by {@link module:ol/xml.serialize} or\n * {@link module:ol/xml.pushSerializeAndPop} to the node factory.\n * @const\n * @type {function(*, Array<*>, string=): (Node|undefined)}\n */\nexport const OBJECT_PROPERTY_NODE_FACTORY = makeSimpleNodeFactory();\n\n/**\n * Create an array of `values` to be used with {@link module:ol/xml.serialize} or\n * {@link module:ol/xml.pushSerializeAndPop}, where `orderedKeys` has to be provided as\n * `key` argument.\n * @param {Object<string, *>} object Key-value pairs for the sequence. Keys can\n *     be a subset of the `orderedKeys`.\n * @param {Array<string>} orderedKeys Keys in the order of the sequence.\n * @return {Array<*>} Values in the order of the sequence. The resulting array\n *     has the same length as the `orderedKeys` array. Values that are not\n *     present in `object` will be `undefined` in the resulting array.\n */\nexport function makeSequence(object, orderedKeys) {\n  const length = orderedKeys.length;\n  const sequence = new Array(length);\n  for (let i = 0; i < length; ++i) {\n    sequence[i] = object[orderedKeys[i]];\n  }\n  return sequence;\n}\n\n/**\n * Create a namespaced structure, using the same values for each namespace.\n * This can be used as a starting point for versioned parsers, when only a few\n * values are version specific.\n * @param {Array<string>} namespaceURIs Namespace URIs.\n * @param {T} structure Structure.\n * @param {Object<string, T>} [structureNS] Namespaced structure to add to.\n * @return {Object<string, T>} Namespaced structure.\n * @template T\n */\nexport function makeStructureNS(namespaceURIs, structure, structureNS) {\n  structureNS = structureNS !== undefined ? structureNS : {};\n  let i, ii;\n  for (i = 0, ii = namespaceURIs.length; i < ii; ++i) {\n    structureNS[namespaceURIs[i]] = structure;\n  }\n  return structureNS;\n}\n\n/**\n * Parse a node using the parsers and object stack.\n * @param {Object<string, Object<string, Parser>>} parsersNS\n *     Parsers by namespace.\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @param {*} [thisArg] The object to use as `this`.\n */\nexport function parseNode(parsersNS, node, objectStack, thisArg) {\n  let n;\n  for (n = node.firstElementChild; n; n = n.nextElementSibling) {\n    const parsers = parsersNS[n.namespaceURI];\n    if (parsers !== undefined) {\n      const parser = parsers[n.localName];\n      if (parser !== undefined) {\n        parser.call(thisArg, n, objectStack);\n      }\n    }\n  }\n}\n\n/**\n * Push an object on top of the stack, parse and return the popped object.\n * @param {T} object Object.\n * @param {Object<string, Object<string, Parser>>} parsersNS\n *     Parsers by namespace.\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @param {*} [thisArg] The object to use as `this`.\n * @return {T} Object.\n * @template T\n */\nexport function pushParseAndPop(object, parsersNS, node, objectStack, thisArg) {\n  objectStack.push(object);\n  parseNode(parsersNS, node, objectStack, thisArg);\n  return /** @type {T} */ (objectStack.pop());\n}\n\n/**\n * Walk through an array of `values` and call a serializer for each value.\n * @param {Object<string, Object<string, Serializer>>} serializersNS\n *     Namespaced serializers.\n * @param {function(this: T, *, Array<*>, (string|undefined)): (Node|undefined)} nodeFactory\n *     Node factory. The `nodeFactory` creates the node whose namespace and name\n *     will be used to choose a node writer from `serializersNS`. This\n *     separation allows us to decide what kind of node to create, depending on\n *     the value we want to serialize. An example for this would be different\n *     geometry writers based on the geometry type.\n * @param {Array<*>} values Values to serialize. An example would be an array\n *     of {@link module:ol/Feature~Feature} instances.\n * @param {Array<*>} objectStack Node stack.\n * @param {Array<string>} [keys] Keys of the `values`. Will be passed to the\n *     `nodeFactory`. This is used for serializing object literals where the\n *     node name relates to the property key. The array length of `keys` has\n *     to match the length of `values`. For serializing a sequence, `keys`\n *     determines the order of the sequence.\n * @param {T} [thisArg] The object to use as `this` for the node factory and\n *     serializers.\n * @template T\n */\nexport function serialize(\n  serializersNS,\n  nodeFactory,\n  values,\n  objectStack,\n  keys,\n  thisArg,\n) {\n  const length = (keys !== undefined ? keys : values).length;\n  let value, node;\n  for (let i = 0; i < length; ++i) {\n    value = values[i];\n    if (value !== undefined) {\n      node = nodeFactory.call(\n        thisArg,\n        value,\n        objectStack,\n        keys !== undefined ? keys[i] : undefined,\n      );\n      if (node !== undefined) {\n        serializersNS[node.namespaceURI][node.localName].call(\n          thisArg,\n          node,\n          value,\n          objectStack,\n        );\n      }\n    }\n  }\n}\n\n/**\n * @param {O} object Object.\n * @param {Object<string, Object<string, Serializer>>} serializersNS\n *     Namespaced serializers.\n * @param {function(this: T, *, Array<*>, (string|undefined)): (Node|undefined)} nodeFactory\n *     Node factory. The `nodeFactory` creates the node whose namespace and name\n *     will be used to choose a node writer from `serializersNS`. This\n *     separation allows us to decide what kind of node to create, depending on\n *     the value we want to serialize. An example for this would be different\n *     geometry writers based on the geometry type.\n * @param {Array<*>} values Values to serialize. An example would be an array\n *     of {@link module:ol/Feature~Feature} instances.\n * @param {Array<*>} objectStack Node stack.\n * @param {Array<string>} [keys] Keys of the `values`. Will be passed to the\n *     `nodeFactory`. This is used for serializing object literals where the\n *     node name relates to the property key. The array length of `keys` has\n *     to match the length of `values`. For serializing a sequence, `keys`\n *     determines the order of the sequence.\n * @param {T} [thisArg] The object to use as `this` for the node factory and\n *     serializers.\n * @return {O|undefined} Object.\n * @template O, T\n */\nexport function pushSerializeAndPop(\n  object,\n  serializersNS,\n  nodeFactory,\n  values,\n  objectStack,\n  keys,\n  thisArg,\n) {\n  objectStack.push(object);\n  serialize(serializersNS, nodeFactory, values, objectStack, keys, thisArg);\n  return /** @type {O|undefined} */ (objectStack.pop());\n}\n\nlet xmlSerializer_ = undefined;\n\n/**\n * Register a XMLSerializer. Can be used  to inject a XMLSerializer\n * where there is no globally available implementation.\n *\n * @param {XMLSerializer} xmlSerializer A XMLSerializer.\n * @api\n */\nexport function registerXMLSerializer(xmlSerializer) {\n  xmlSerializer_ = xmlSerializer;\n}\n\n/**\n * @return {XMLSerializer} The XMLSerializer.\n */\nexport function getXMLSerializer() {\n  if (xmlSerializer_ === undefined && typeof XMLSerializer !== 'undefined') {\n    xmlSerializer_ = new XMLSerializer();\n  }\n  return xmlSerializer_;\n}\n\nlet document_ = undefined;\n\n/**\n * Register a Document to use when creating nodes for XML serializations. Can be used\n * to inject a Document where there is no globally available implementation.\n *\n * @param {Document} document A Document.\n * @api\n */\nexport function registerDocument(document) {\n  document_ = document;\n}\n\n/**\n * Get a document that should be used when creating nodes for XML serializations.\n * @return {Document} The document.\n */\nexport function getDocument() {\n  if (document_ === undefined && typeof document !== 'undefined') {\n    document_ = document.implementation.createDocument('', '', null);\n  }\n  return document_;\n}\n","/**\n * @module ol/style/flat\n */\n\n/**\n * @api\n * @fileoverview Vector layers can be styled with an object literal containing properties for\n * stroke, fill, image, and text styles.  The types below can be composed into a single object.\n * For example, a style with both stroke and fill properties could look like this:\n *\n *     const style = {\n *       'stroke-color': 'yellow',\n *       'stroke-width': 1.5,\n *       'fill-color': 'orange',\n *     };\n *\n * See details about the available properties depending on what type of symbolizer should be applied:\n *  {@link module:ol/style/flat~FlatStroke Stroke} - properties for applying a stroke to lines and polygons\n *  {@link module:ol/style/flat~FlatFill Fill} - properties for filling polygons\n *  {@link module:ol/style/flat~FlatText Text} - properties for labeling points, lines, and polygons\n *  {@link module:ol/style/flat~FlatIcon Icon} - properties for rendering points with an icon\n *  {@link module:ol/style/flat~FlatCircle Circle} - properties for rendering points with a circle\n *  {@link module:ol/style/flat~FlatShape Shape} - properties for rendering points with a regular shape\n *\n * To conditionally apply styles based on a filter, a list of {@link module:ol/style/flat~Rule rules} can be used.\n * For example, to style points with a big orange circle if the population is greater than 1 million and\n * a smaller blue circle otherwise:\n *\n *     const rules = [\n *       {\n *         filter: ['>', ['get', 'population'], 1_000_000],\n *         style: {\n *           'circle-radius': 10,\n *           'circle-fill-color': 'red',\n *         }\n *       },\n *       {\n *         else: true,\n *         style: {\n *           'circle-radius': 5,\n *           'circle-fill-color': 'blue',\n *         },\n *       },\n *     ];\n */\n\n/**\n * A literal boolean (e.g. `true`) or an expression that evaluates to a boolean (e.g. `['>', ['get', 'population'], 1_000_000]`).\n *\n * @typedef {boolean|Array} BooleanExpression\n */\n\n/**\n * A literal string (e.g. `'hello'`) or an expression that evaluates to a string (e.g. `['get', 'greeting']`).\n *\n * @typedef {string|Array} StringExpression\n */\n\n/**\n * A literal number (e.g. `42`) or an expression that evaluates to a number (e.g. `['+', 40, 2]`).\n *\n * @typedef {number|Array} NumberExpression\n */\n\n/**\n * A CSS named color (e.g. `'blue'`), an array of 3 RGB values (e.g. `[0, 255, 0]`), an array of 4 RGBA values\n * (e.g. `[0, 255, 0, 0.5]`), or an expression that evaluates to one of these color types (e.g. `['get', 'color']`).\n *\n * @typedef {import(\"../color.js\").Color|string|Array} ColorExpression\n */\n\n/**\n * An array of numbers (e.g. `[1, 2, 3]`) or an expression that evaluates to the same (e.g. `['get', 'values']`).\n *\n * @typedef {Array<number>|Array} NumberArrayExpression\n */\n\n/**\n * An array of two numbers (e.g. `[10, 20]`) or an expression that evaluates to the same (e.g. `['get', 'size']`).\n *\n * @typedef {number|Array<number>|Array} SizeExpression\n */\n\n/**\n * For static styling, the [layer.setStyle()]{@link module:ol/layer/Vector~VectorLayer#setStyle} method\n * can be called with an object literal that has fill, stroke, text, icon, regular shape, and/or circle properties.\n * @api\n *\n * @typedef {FlatFill & FlatStroke & FlatText & FlatIcon & FlatShape & FlatCircle} FlatStyle\n */\n\n/**\n * A flat style literal or an array of the same.\n *\n * @typedef {FlatStyle|Array<FlatStyle>|Array<Rule>} FlatStyleLike\n */\n\n/**\n * Fill style properties applied to polygon features.\n *\n * @typedef {Object} FlatFill\n * @property {ColorExpression} [fill-color] The fill color. `'none'` means no fill and no hit detection (applies to Canvas only).\n * @property {StringExpression} [fill-pattern-src] Fill pattern image source URI. If `fill-color` is defined as well,\n * it will be used to tint this image. (Expressions only in Canvas)\n * @property {SizeExpression} [fill-pattern-size] Fill pattern image size in pixels.\n * Can be used together with `fill-pattern-offset` to define the sub-rectangle to use\n * from a fill pattern image sprite sheet.\n * @property {SizeExpression} [fill-pattern-offset=[0, 0]] Offset, which, together with the size and the offset origin, define the\n * sub-rectangle to use from the original fill pattern image.\n * @property {import(\"./Icon.js\").IconOrigin} [fill-pattern-offset-origin='top-left'] Origin of the offset: `bottom-left`, `bottom-right`,\n * `top-left` or `top-right`. (WebGL only)\n */\n\n/**\n * Stroke style properties applied to line strings and polygon boundaries. To apply a stroke, at least one of\n * `stroke-color` or `stroke-width` must be provided.\n *\n * @typedef {Object} FlatStroke\n * @property {ColorExpression} [stroke-color] The stroke color.\n * @property {NumberExpression} [stroke-width] Stroke pixel width.\n * @property {StringExpression} [stroke-line-cap='round'] Line cap style: `butt`, `round`, or `square`.\n * @property {StringExpression} [stroke-line-join='round'] Line join style: `bevel`, `round`, or `miter`.\n * @property {NumberArrayExpression} [stroke-line-dash] Line dash pattern.\n * @property {NumberExpression} [stroke-line-dash-offset=0] Line dash offset.\n * @property {NumberExpression} [stroke-miter-limit=10] Miter limit.\n * @property {NumberExpression} [stroke-offset] Stroke offset in pixel along the normal. A positive value offsets the line to the right,\n * relative to the direction of the line.\n * @property {string} [stroke-pattern-src] Stroke pattern image source URI. If `stroke-color` is defined as well,\n * it will be used to tint this image. (WebGL only)\n * @property {SizeExpression} [stroke-pattern-offset=[0, 0]] Offset, which, together with the size and the offset origin,\n * define the sub-rectangle to use from the original stroke pattern image. (WebGL only)\n * @property {import(\"./Icon.js\").IconOrigin} [stroke-pattern-offset-origin='top-left'] Origin of the offset: `bottom-left`, `bottom-right`,\n * `top-left` or `top-right`. (WebGL only)\n * @property {SizeExpression} [stroke-pattern-size] Stroke pattern image size in pixel. Can be used together with `stroke-pattern-offset` to define the\n * sub-rectangle to use from the origin (sprite) fill pattern image. (WebGL only)\n * @property {NumberExpression} [stroke-pattern-spacing] Spacing between each pattern occurrence in pixels; 0 if undefined. (WebGL only)\n * @property {NumberExpression} [stroke-pattern-start-offset] Stroke pattern offset in pixels at the start of the line. (WebGL only)\n * @property {NumberExpression} [z-index] The zIndex of the style.\n */\n\n/**\n * Label style properties applied to all features. At a minimum, a `text-value` must be provided.\n * Note: text style is currently not supported in WebGL layers\n *\n * @typedef {Object} FlatText\n * @property {StringExpression} [text-value] Text content (with `\\n` for line breaks).\n * @property {StringExpression} [text-font='10px sans-serif'] Font style as [CSS `font`](https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/font) value.\n * @property {NumberExpression} [text-max-angle=Math.PI/4] When `text-placement` is set to `'line'`, allow a maximum angle between adjacent characters.\n * The expected value is in radians, and the default is 45° (`Math.PI / 4`).\n * @property {NumberExpression} [text-offset-x=0] Horizontal text offset in pixels. A positive will shift the text right.\n * @property {NumberExpression} [text-offset-y=0] Vertical text offset in pixels. A positive will shift the text down.\n * @property {BooleanExpression} [text-overflow=false] For polygon labels or when `placement` is set to `'line'`, allow text to exceed\n * the width of the polygon at the label position or the length of the path that it follows.\n * @property {StringExpression} [text-placement='point'] Text placement.\n * @property {NumberExpression} [text-repeat] Repeat interval in pixels. When set, the text will be repeated at this interval. Only available when\n * `text-placement` is set to `'line'`. Overrides `text-align`.\n * @property {SizeExpression} [text-scale] Scale.\n * @property {BooleanExpression} [text-rotate-with-view=false] Whether to rotate the text with the view.\n * @property {NumberExpression} [text-rotation=0] Rotation in radians (positive rotation clockwise).\n * @property {StringExpression} [text-align] Text alignment. Possible values: `'left'`, `'right'`, `'center'`, `'end'` or `'start'`.\n * Default is `'center'` for `'text-placement': 'point'`. For `'text-placement': 'line'`, the default is to let the renderer choose a\n * placement where `text-max-angle` is not exceeded.\n * @property {StringExpression} [text-justify] Text justification within the text box.\n * If not set, text is justified towards the `textAlign` anchor.\n * Otherwise, use options `'left'`, `'center'`, or `'right'` to justify the text within the text box.\n * **Note:** `text-justify` is ignored for immediate rendering and also for `'text-placement': 'line'`.\n * @property {StringExpression} [text-baseline='middle'] Text base line. Possible values: `'bottom'`, `'top'`, `'middle'`, `'alphabetic'`,\n * `'hanging'`, `'ideographic'`.\n * @property {NumberArrayExpression} [text-padding=[0, 0, 0, 0]] Padding in pixels around the text for decluttering and background. The order of\n * values in the array is `[top, right, bottom, left]`.\n * @property {ColorExpression} [text-fill-color] The fill color. `'none'` means no fill and no hit detection.\n * @property {ColorExpression} [text-background-fill-color] The fill color. `'none'` means no fill and no hit detection.\n * @property {ColorExpression} [text-stroke-color] The stroke color.\n * @property {StringExpression} [text-stroke-line-cap='round'] Line cap style: `butt`, `round`, or `square`.\n * @property {StringExpression} [text-stroke-line-join='round'] Line join style: `bevel`, `round`, or `miter`.\n * @property {NumberArrayExpression} [text-stroke-line-dash] Line dash pattern.\n * @property {NumberExpression} [text-stroke-line-dash-offset=0] Line dash offset.\n * @property {NumberExpression} [text-stroke-miter-limit=10] Miter limit.\n * @property {NumberExpression} [text-stroke-width] Stroke pixel width.\n * @property {ColorExpression} [text-background-stroke-color] The stroke color.\n * @property {StringExpression} [text-background-stroke-line-cap='round'] Line cap style: `butt`, `round`, or `square`.\n * @property {StringExpression} [text-background-stroke-line-join='round'] Line join style: `bevel`, `round`, or `miter`.\n * @property {NumberArrayExpression} [text-background-stroke-line-dash] Line dash pattern.\n * @property {NumberExpression} [text-background-stroke-line-dash-offset=0] Line dash offset.\n * @property {NumberExpression} [text-background-stroke-miter-limit=10] Miter limit.\n * @property {NumberExpression} [text-background-stroke-width] Stroke pixel width.\n * @property {import(\"./Style.js\").DeclutterMode} [text-declutter-mode] Declutter mode\n * @property {NumberExpression} [z-index] The zIndex of the style.\n */\n\n/**\n * Icon style properties applied to point features. `icon-src` must be provided to render\n * points with an icon.\n *\n * @typedef {Object} FlatIcon\n * @property {string} [icon-src] Image source URI.\n * @property {NumberArrayExpression} [icon-anchor=[0.5, 0.5]] Anchor. Default value is the icon center.\n * @property {import(\"./Icon.js\").IconOrigin} [icon-anchor-origin='top-left'] Origin of the anchor: `bottom-left`, `bottom-right`,\n * `top-left` or `top-right`.\n * @property {import(\"./Icon.js\").IconAnchorUnits} [icon-anchor-x-units='fraction'] Units in which the anchor x value is\n * specified. A value of `'fraction'` indicates the x value is a fraction of the icon. A value of `'pixels'` indicates\n * the x value in pixels.\n * @property {import(\"./Icon.js\").IconAnchorUnits} [icon-anchor-y-units='fraction'] Units in which the anchor y value is\n * specified. A value of `'fraction'` indicates the y value is a fraction of the icon. A value of `'pixels'` indicates\n * the y value in pixels.\n * @property {ColorExpression} [icon-color] Color to tint the icon. If not specified,\n * the icon will be left as is.\n * @property {null|string} [icon-cross-origin] The `crossOrigin` attribute for loaded images. Note that you must provide a\n * `icon-cross-origin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {SizeExpression} [icon-offset=[0, 0]] Offset, which, together with the size and the offset origin, define the\n * sub-rectangle to use from the original icon image.\n * @property {NumberArrayExpression} [icon-displacement=[0,0]] Displacement of the icon.\n * @property {import(\"./Icon.js\").IconOrigin} [icon-offset-origin='top-left'] Origin of the offset: `bottom-left`, `bottom-right`,\n * `top-left` or `top-right`.\n * @property {NumberExpression} [icon-opacity=1] Opacity of the icon.\n * @property {SizeExpression} [icon-scale=1] Scale.\n * @property {NumberExpression} [icon-width] Width of the icon. If not specified, the actual image width will be used. Cannot be combined\n * with `scale`. (Expressions only in WebGL)\n * @property {NumberExpression} [icon-height] Height of the icon. If not specified, the actual image height will be used. Cannot be combined\n * with `scale`. (Expressions only in WebGL)\n * @property {NumberExpression} [icon-rotation=0] Rotation in radians (positive rotation clockwise).\n * @property {BooleanExpression} [icon-rotate-with-view=false] Whether to rotate the icon with the view. (Expressions only supported in Canvas)\n * @property {SizeExpression} [icon-size] Icon size in pixel. Can be used together with `icon-offset` to define the\n * sub-rectangle to use from the origin (sprite) icon image. (Expressions only in WebGL)\n * @property {import(\"./Style.js\").DeclutterMode} [icon-declutter-mode] Declutter mode (Canvas only)\n * @property {NumberExpression} [z-index] The zIndex of the style. (Canvas only)\n */\n\n/**\n * Regular shape style properties for rendering point features. At least `shape-points` must be provided.\n *\n * @typedef {Object} FlatShape\n * @property {NumberExpression} [shape-points] Number of points for stars and regular polygons. In case of a polygon, the number of points\n * is the number of sides. (Expressions only in WebGL)\n * @property {ColorExpression} [shape-fill-color] The fill color. `'none'` means no fill and no hit detection.\n * @property {ColorExpression} [shape-stroke-color] The stroke color.\n * @property {NumberExpression} [shape-stroke-width] Stroke pixel width.\n * @property {StringExpression} [shape-stroke-line-cap='round'] Line cap style: `butt`, `round`, or `square`. (Canvas only)\n * @property {StringExpression} [shape-stroke-line-join='round'] Line join style: `bevel`, `round`, or `miter`. (Canvas only)\n * @property {NumberArrayExpression} [shape-stroke-line-dash] Line dash pattern. (Canvas only)\n * @property {NumberExpression} [shape-stroke-line-dash-offset=0] Line dash offset. (Canvas only)\n * @property {NumberExpression} [shape-stroke-miter-limit=10] Miter limit. (Canvas only)\n * @property {NumberExpression} [shape-radius] Radius of a regular polygon. (Expressions only in WebGL)\n * @property {NumberExpression} [shape-radius2] Second radius to make a star instead of a regular polygon. (Expressions only in WebGL)\n * @property {NumberExpression} [shape-angle=0] Shape's angle in radians. A value of 0 will have one of the shape's point facing up. (Expressions only in WebGL)\n * @property {NumberArrayExpression} [shape-displacement=[0,0]] Displacement of the shape\n * @property {NumberExpression} [shape-opacity] Shape opacity. (WebGL only)\n * @property {NumberExpression} [shape-rotation=0] Rotation in radians (positive rotation clockwise).\n * @property {BooleanExpression} [shape-rotate-with-view=false] Whether to rotate the shape with the view. (Expression only supported in Canvas)\n * @property {SizeExpression} [shape-scale=1] Scale. Unless two-dimensional scaling is required a better\n * result may be obtained with appropriate settings for `shape-radius` and `shape-radius2`.\n * @property {import(\"./Style.js\").DeclutterMode} [shape-declutter-mode] Declutter mode. (Canvas only)\n * @property {NumberExpression} [z-index] The zIndex of the style. (Canvas only)\n */\n\n/**\n * Circle style properties for rendering point features. At least `circle-radius` must be provided.\n *\n * @typedef {Object} FlatCircle\n * @property {NumberExpression} [circle-radius] Circle radius.\n * @property {ColorExpression} [circle-fill-color] The fill color. `'none'` means no fill and no hit detection.\n * @property {ColorExpression} [circle-stroke-color] The stroke color.\n * @property {NumberExpression} [circle-stroke-width] Stroke pixel width.\n * @property {StringExpression} [circle-stroke-line-cap='round'] Line cap style: `butt`, `round`, or `square`. (Canvas only)\n * @property {StringExpression} [circle-stroke-line-join='round'] Line join style: `bevel`, `round`, or `miter`. (Canvas only)\n * @property {NumberArrayExpression} [circle-stroke-line-dash] Line dash pattern. (Canvas only)\n * @property {NumberExpression} [circle-stroke-line-dash-offset=0] Line dash offset. (Canvas only)\n * @property {NumberExpression} [circle-stroke-miter-limit=10] Miter limit. (Canvas only)\n * @property {NumberArrayExpression} [circle-displacement=[0,0]] displacement\n * @property {SizeExpression} [circle-scale=1] Scale. A two-dimensional scale will produce an ellipse.\n * Unless two-dimensional scaling is required a better result may be obtained with an appropriate setting for `circle-radius`.\n * @property {NumberExpression} [circle-opacity] Circle opacity. (WebGL only)\n * @property {NumberExpression} [circle-rotation=0] Rotation in radians\n * (positive rotation clockwise, meaningful only when used in conjunction with a two-dimensional scale).\n * @property {BooleanExpression} [circle-rotate-with-view=false] Whether to rotate the shape with the view (Expression only supported in Canvas)\n * (meaningful only when used in conjunction with a two-dimensional scale).\n * @property {import(\"./Style.js\").DeclutterMode} [circle-declutter-mode] Declutter mode (Canvas only)\n * @property {NumberExpression} [z-index] The zIndex of the style. (Canvas only)\n */\n\n/**\n * These default style properties are applied when no other style is given.\n *\n * @typedef {Object} DefaultStyle\n * @property {string} fill-color `'rgba(255,255,255,0.4)'`\n * @property {string} stroke-color `'#3399CC'`\n * @property {number} stroke-width `1.25`\n * @property {number} circle-radius `5`\n * @property {string} circle-fill-color `'rgba(255,255,255,0.4)'`\n * @property {number} circle-stroke-width `1.25`\n * @property {string} circle-stroke-color `'#3399CC'`\n */\n\n/**\n * @return {DefaultStyle} The default flat style.\n */\nexport function createDefaultStyle() {\n  return {\n    'fill-color': 'rgba(255,255,255,0.4)',\n    'stroke-color': '#3399CC',\n    'stroke-width': 1.25,\n    'circle-radius': 5,\n    'circle-fill-color': 'rgba(255,255,255,0.4)',\n    'circle-stroke-width': 1.25,\n    'circle-stroke-color': '#3399CC',\n  };\n}\n\n/**\n * A rule is used to conditionally apply a style. If the rule's filter evaluates to true,\n * the style will be applied.\n *\n * @typedef {Object} Rule\n * @property {FlatStyle|Array<FlatStyle>} style The style to be applied if the filter matches.\n * @property {import(\"../expr/expression.js\").EncodedExpression} [filter] The filter used\n * to determine if a style applies. If no filter is included, the rule always applies\n * (unless it is an else rule).\n * @property {boolean} [else] If true, the rule applies only if no other previous rule applies.\n * If the else rule also has a filter, the rule will not apply if the filter does not match.\n */\n\n/**\n * Style variables are provided as an object. The variables can be read in a {@link import(\"../expr/expression.js\").ExpressionValue style expression}\n * using the `['var', 'varName']` operator.\n * Each variable must hold a literal value (not an expression).\n * @typedef {Object<string, number|Array<number>|string|boolean>} StyleVariables\n */\n","/**\n * @module ol/render/canvas/Instruction\n */\n\n/**\n * @enum {number}\n */\nconst Instruction = {\n  BEGIN_GEOMETRY: 0,\n  BEGIN_PATH: 1,\n  CIRCLE: 2,\n  CLOSE_PATH: 3,\n  CUSTOM: 4,\n  DRAW_CHARS: 5,\n  DRAW_IMAGE: 6,\n  END_GEOMETRY: 7,\n  FILL: 8,\n  MOVE_TO_LINE_TO: 9,\n  SET_FILL_STYLE: 10,\n  SET_STROKE_STYLE: 11,\n  STROKE: 12,\n};\n\n/**\n * @type {Array<Instruction>}\n */\nexport const fillInstruction = [Instruction.FILL];\n\n/**\n * @type {Array<Instruction>}\n */\nexport const strokeInstruction = [Instruction.STROKE];\n\n/**\n * @type {Array<Instruction>}\n */\nexport const beginPathInstruction = [Instruction.BEGIN_PATH];\n\n/**\n * @type {Array<Instruction>}\n */\nexport const closePathInstruction = [Instruction.CLOSE_PATH];\n\nexport default Instruction;\n","/**\n * @module ol/render/canvas/Builder\n */\nimport {equals, reverseSubArray} from '../../array.js';\nimport {asColorLike} from '../../colorlike.js';\nimport {\n  buffer,\n  clone,\n  containsCoordinate,\n  coordinateRelationship,\n} from '../../extent.js';\nimport Relationship from '../../extent/Relationship.js';\nimport {\n  inflateCoordinates,\n  inflateCoordinatesArray,\n  inflateMultiCoordinatesArray,\n} from '../../geom/flat/inflate.js';\nimport VectorContext from '../VectorContext.js';\nimport {\n  defaultFillStyle,\n  defaultLineCap,\n  defaultLineDash,\n  defaultLineDashOffset,\n  defaultLineJoin,\n  defaultLineWidth,\n  defaultMiterLimit,\n  defaultStrokeOffset,\n  defaultStrokeStyle,\n} from '../canvas.js';\nimport CanvasInstruction from './Instruction.js';\n\nclass CanvasBuilder extends VectorContext {\n  /**\n   * @param {number} tolerance Tolerance.\n   * @param {import(\"../../extent.js\").Extent} maxExtent Maximum extent.\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   */\n  constructor(tolerance, maxExtent, resolution, pixelRatio) {\n    super();\n\n    /**\n     * @protected\n     * @type {number}\n     */\n    this.tolerance = tolerance;\n\n    /**\n     * @protected\n     * @const\n     * @type {import(\"../../extent.js\").Extent}\n     */\n    this.maxExtent = maxExtent;\n\n    /**\n     * @protected\n     * @type {number}\n     */\n    this.pixelRatio = pixelRatio;\n\n    /**\n     * @protected\n     * @type {number}\n     */\n    this.maxLineWidth = 0;\n\n    /**\n     * @protected\n     * @const\n     * @type {number}\n     */\n    this.resolution = resolution;\n\n    /**\n     * @private\n     * @type {Array<*>}\n     */\n    this.beginGeometryInstruction1_ = null;\n\n    /**\n     * @private\n     * @type {Array<*>}\n     */\n    this.beginGeometryInstruction2_ = null;\n\n    /**\n     * @private\n     * @type {import(\"../../extent.js\").Extent}\n     */\n    this.bufferedMaxExtent_ = null;\n\n    /**\n     * @protected\n     * @type {Array<*>}\n     */\n    this.instructions = [];\n\n    /**\n     * @protected\n     * @type {Array<number>}\n     */\n    this.coordinates = [];\n\n    /**\n     * @private\n     * @type {import(\"../../coordinate.js\").Coordinate}\n     */\n    this.tmpCoordinate_ = [];\n\n    /**\n     * @protected\n     * @type {Array<*>}\n     */\n    this.hitDetectionInstructions = [];\n\n    /**\n     * @protected\n     * @type {import(\"../canvas.js\").FillStrokeState}\n     */\n    this.state = /** @type {import(\"../canvas.js\").FillStrokeState} */ ({});\n  }\n\n  /**\n   * @protected\n   * @param {Array<number>} dashArray Dash array.\n   * @return {Array<number>} Dash array with pixel ratio applied\n   */\n  applyPixelRatio(dashArray) {\n    const pixelRatio = this.pixelRatio;\n    return pixelRatio == 1\n      ? dashArray\n      : dashArray.map(function (dash) {\n          return dash * pixelRatio;\n        });\n  }\n\n  /**\n   * @param {Array<number>} flatCoordinates Flat coordinates.\n   * @param {number} stride Stride.\n   * @protected\n   * @return {number} My end\n   */\n  appendFlatPointCoordinates(flatCoordinates, stride) {\n    const extent = this.getBufferedMaxExtent();\n    const tmpCoord = this.tmpCoordinate_;\n    const coordinates = this.coordinates;\n    let myEnd = coordinates.length;\n    for (let i = 0, ii = flatCoordinates.length; i < ii; i += stride) {\n      tmpCoord[0] = flatCoordinates[i];\n      tmpCoord[1] = flatCoordinates[i + 1];\n      if (containsCoordinate(extent, tmpCoord)) {\n        coordinates[myEnd++] = tmpCoord[0];\n        coordinates[myEnd++] = tmpCoord[1];\n      }\n    }\n    return myEnd;\n  }\n\n  /**\n   * @param {Array<number>} flatCoordinates Flat coordinates.\n   * @param {number} offset Offset.\n   * @param {number} end End.\n   * @param {number} stride Stride.\n   * @param {boolean} closed Last input coordinate equals first.\n   * @param {boolean} skipFirst Skip first coordinate.\n   * @protected\n   * @return {number} My end.\n   */\n  appendFlatLineCoordinates(\n    flatCoordinates,\n    offset,\n    end,\n    stride,\n    closed,\n    skipFirst,\n  ) {\n    const coordinates = this.coordinates;\n    let myEnd = coordinates.length;\n    const extent = this.getBufferedMaxExtent();\n    if (skipFirst) {\n      offset += stride;\n    }\n    let lastXCoord = flatCoordinates[offset];\n    let lastYCoord = flatCoordinates[offset + 1];\n    const nextCoord = this.tmpCoordinate_;\n    let skipped = true;\n\n    let i, lastRel, nextRel;\n    for (i = offset + stride; i < end; i += stride) {\n      nextCoord[0] = flatCoordinates[i];\n      nextCoord[1] = flatCoordinates[i + 1];\n      nextRel = coordinateRelationship(extent, nextCoord);\n      if (nextRel !== lastRel) {\n        if (skipped) {\n          coordinates[myEnd++] = lastXCoord;\n          coordinates[myEnd++] = lastYCoord;\n          skipped = false;\n        }\n        coordinates[myEnd++] = nextCoord[0];\n        coordinates[myEnd++] = nextCoord[1];\n      } else if (nextRel === Relationship.INTERSECTING) {\n        coordinates[myEnd++] = nextCoord[0];\n        coordinates[myEnd++] = nextCoord[1];\n        skipped = false;\n      } else {\n        skipped = true;\n      }\n      lastXCoord = nextCoord[0];\n      lastYCoord = nextCoord[1];\n      lastRel = nextRel;\n    }\n\n    // Last coordinate equals first or only one point to append:\n    if ((closed && skipped) || i === offset + stride) {\n      coordinates[myEnd++] = lastXCoord;\n      coordinates[myEnd++] = lastYCoord;\n    }\n    return myEnd;\n  }\n\n  /**\n   * @param {Array<number>} flatCoordinates Flat coordinates.\n   * @param {number} offset Offset.\n   * @param {Array<number>} ends Ends.\n   * @param {number} stride Stride.\n   * @param {Array<number>} builderEnds Builder ends.\n   * @return {number} Offset.\n   */\n  drawCustomCoordinates_(flatCoordinates, offset, ends, stride, builderEnds) {\n    for (let i = 0, ii = ends.length; i < ii; ++i) {\n      const end = ends[i];\n      const builderEnd = this.appendFlatLineCoordinates(\n        flatCoordinates,\n        offset,\n        end,\n        stride,\n        false,\n        false,\n      );\n      builderEnds.push(builderEnd);\n      offset = end;\n    }\n    return offset;\n  }\n\n  /**\n   * @param {import(\"../../geom/SimpleGeometry.js\").default} geometry Geometry.\n   * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n   * @param {Function} renderer Renderer.\n   * @param {Function} hitDetectionRenderer Renderer.\n   * @param {number} [index] Render order index.\n   * @override\n   */\n  drawCustom(geometry, feature, renderer, hitDetectionRenderer, index) {\n    this.beginGeometry(geometry, feature, index);\n\n    const type = geometry.getType();\n    const stride = geometry.getStride();\n    const builderBegin = this.coordinates.length;\n\n    let flatCoordinates, builderEnd, builderEnds, builderEndss;\n    let offset;\n\n    switch (type) {\n      case 'MultiPolygon':\n        flatCoordinates =\n          /** @type {import(\"../../geom/MultiPolygon.js\").default} */ (\n            geometry\n          ).getOrientedFlatCoordinates();\n        builderEndss = [];\n        const endss =\n          /** @type {import(\"../../geom/MultiPolygon.js\").default} */ (\n            geometry\n          ).getEndss();\n        offset = 0;\n        for (let i = 0, ii = endss.length; i < ii; ++i) {\n          const myEnds = [];\n          offset = this.drawCustomCoordinates_(\n            flatCoordinates,\n            offset,\n            endss[i],\n            stride,\n            myEnds,\n          );\n          builderEndss.push(myEnds);\n        }\n        this.instructions.push([\n          CanvasInstruction.CUSTOM,\n          builderBegin,\n          builderEndss,\n          geometry,\n          renderer,\n          inflateMultiCoordinatesArray,\n          index,\n        ]);\n        this.hitDetectionInstructions.push([\n          CanvasInstruction.CUSTOM,\n          builderBegin,\n          builderEndss,\n          geometry,\n          hitDetectionRenderer || renderer,\n          inflateMultiCoordinatesArray,\n          index,\n        ]);\n        break;\n      case 'Polygon':\n      case 'MultiLineString':\n        builderEnds = [];\n        flatCoordinates =\n          type == 'Polygon'\n            ? /** @type {import(\"../../geom/Polygon.js\").default} */ (\n                geometry\n              ).getOrientedFlatCoordinates()\n            : geometry.getFlatCoordinates();\n        offset = this.drawCustomCoordinates_(\n          flatCoordinates,\n          0,\n          /** @type {import(\"../../geom/Polygon.js\").default|import(\"../../geom/MultiLineString.js\").default} */ (\n            geometry\n          ).getEnds(),\n          stride,\n          builderEnds,\n        );\n        this.instructions.push([\n          CanvasInstruction.CUSTOM,\n          builderBegin,\n          builderEnds,\n          geometry,\n          renderer,\n          inflateCoordinatesArray,\n          index,\n        ]);\n        this.hitDetectionInstructions.push([\n          CanvasInstruction.CUSTOM,\n          builderBegin,\n          builderEnds,\n          geometry,\n          hitDetectionRenderer || renderer,\n          inflateCoordinatesArray,\n          index,\n        ]);\n        break;\n      case 'LineString':\n      case 'Circle':\n        flatCoordinates = geometry.getFlatCoordinates();\n        builderEnd = this.appendFlatLineCoordinates(\n          flatCoordinates,\n          0,\n          flatCoordinates.length,\n          stride,\n          false,\n          false,\n        );\n        this.instructions.push([\n          CanvasInstruction.CUSTOM,\n          builderBegin,\n          builderEnd,\n          geometry,\n          renderer,\n          inflateCoordinates,\n          index,\n        ]);\n        this.hitDetectionInstructions.push([\n          CanvasInstruction.CUSTOM,\n          builderBegin,\n          builderEnd,\n          geometry,\n          hitDetectionRenderer || renderer,\n          inflateCoordinates,\n          index,\n        ]);\n        break;\n      case 'MultiPoint':\n        flatCoordinates = geometry.getFlatCoordinates();\n        builderEnd = this.appendFlatPointCoordinates(flatCoordinates, stride);\n\n        if (builderEnd > builderBegin) {\n          this.instructions.push([\n            CanvasInstruction.CUSTOM,\n            builderBegin,\n            builderEnd,\n            geometry,\n            renderer,\n            inflateCoordinates,\n            index,\n          ]);\n          this.hitDetectionInstructions.push([\n            CanvasInstruction.CUSTOM,\n            builderBegin,\n            builderEnd,\n            geometry,\n            hitDetectionRenderer || renderer,\n            inflateCoordinates,\n            index,\n          ]);\n        }\n        break;\n      case 'Point':\n        flatCoordinates = geometry.getFlatCoordinates();\n        this.coordinates.push(flatCoordinates[0], flatCoordinates[1]);\n        builderEnd = this.coordinates.length;\n\n        this.instructions.push([\n          CanvasInstruction.CUSTOM,\n          builderBegin,\n          builderEnd,\n          geometry,\n          renderer,\n          undefined,\n          index,\n        ]);\n        this.hitDetectionInstructions.push([\n          CanvasInstruction.CUSTOM,\n          builderBegin,\n          builderEnd,\n          geometry,\n          hitDetectionRenderer || renderer,\n          undefined,\n          index,\n        ]);\n        break;\n      default:\n    }\n    this.endGeometry(feature);\n  }\n\n  /**\n   * @protected\n   * @param {import(\"../../geom/Geometry.js\").default|import(\"../Feature.js\").default} geometry The geometry.\n   * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} index Render order index\n   */\n  beginGeometry(geometry, feature, index) {\n    this.beginGeometryInstruction1_ = [\n      CanvasInstruction.BEGIN_GEOMETRY,\n      feature,\n      0,\n      geometry,\n      index,\n    ];\n    this.instructions.push(this.beginGeometryInstruction1_);\n    this.beginGeometryInstruction2_ = [\n      CanvasInstruction.BEGIN_GEOMETRY,\n      feature,\n      0,\n      geometry,\n      index,\n    ];\n    this.hitDetectionInstructions.push(this.beginGeometryInstruction2_);\n  }\n\n  /**\n   * @return {import(\"../canvas.js\").SerializableInstructions} the serializable instructions.\n   */\n  finish() {\n    return {\n      instructions: this.instructions,\n      hitDetectionInstructions: this.hitDetectionInstructions,\n      coordinates: this.coordinates,\n    };\n  }\n\n  /**\n   * Reverse the hit detection instructions.\n   */\n  reverseHitDetectionInstructions() {\n    const hitDetectionInstructions = this.hitDetectionInstructions;\n    // step 1 - reverse array\n    hitDetectionInstructions.reverse();\n    // step 2 - reverse instructions within geometry blocks\n    let i;\n    const n = hitDetectionInstructions.length;\n    let instruction;\n    let type;\n    let begin = -1;\n    for (i = 0; i < n; ++i) {\n      instruction = hitDetectionInstructions[i];\n      type = /** @type {import(\"./Instruction.js\").default} */ (instruction[0]);\n      if (type == CanvasInstruction.END_GEOMETRY) {\n        begin = i;\n      } else if (type == CanvasInstruction.BEGIN_GEOMETRY) {\n        instruction[2] = i;\n        reverseSubArray(this.hitDetectionInstructions, begin, i);\n        begin = -1;\n      }\n    }\n  }\n\n  /**\n   * @param {import(\"../../style/Fill.js\").default} fillStyle Fill style.\n   * @param {import('../canvas.js').FillStrokeState} [state] State.\n   * @return {import('../canvas.js').FillStrokeState} State.\n   */\n  fillStyleToState(\n    fillStyle,\n    state = /** @type {import('../canvas.js').FillStrokeState} */ ({}),\n  ) {\n    if (fillStyle) {\n      const fillStyleColor = fillStyle.getColor();\n      state.fillPatternScale =\n        fillStyleColor &&\n        typeof fillStyleColor === 'object' &&\n        'src' in fillStyleColor\n          ? this.pixelRatio\n          : 1;\n      state.fillStyle =\n        asColorLike(fillStyleColor ? fillStyleColor : defaultFillStyle) ??\n        undefined;\n    } else {\n      state.fillStyle = undefined;\n    }\n    return state;\n  }\n\n  /**\n   * @param {import(\"../../style/Stroke.js\").default} strokeStyle Stroke style.\n   * @param {import(\"../canvas.js\").FillStrokeState} state State.\n   * @return {import(\"../canvas.js\").FillStrokeState} State.\n   */\n  strokeStyleToState(\n    strokeStyle,\n    state = /** @type {import('../canvas.js').FillStrokeState} */ ({}),\n  ) {\n    if (strokeStyle) {\n      const strokeStyleColor = strokeStyle.getColor();\n      state.strokeStyle = asColorLike(\n        strokeStyleColor ? strokeStyleColor : defaultStrokeStyle,\n      );\n      const strokeStyleLineCap = strokeStyle.getLineCap();\n      state.lineCap =\n        strokeStyleLineCap !== undefined ? strokeStyleLineCap : defaultLineCap;\n      const strokeStyleLineDash = strokeStyle.getLineDash();\n      state.lineDash = strokeStyleLineDash\n        ? strokeStyleLineDash.slice()\n        : defaultLineDash;\n      const strokeStyleLineDashOffset = strokeStyle.getLineDashOffset();\n      state.lineDashOffset = strokeStyleLineDashOffset\n        ? strokeStyleLineDashOffset\n        : defaultLineDashOffset;\n      const strokeStyleLineJoin = strokeStyle.getLineJoin();\n      state.lineJoin =\n        strokeStyleLineJoin !== undefined\n          ? strokeStyleLineJoin\n          : defaultLineJoin;\n      const strokeStyleWidth = strokeStyle.getWidth();\n      state.lineWidth =\n        strokeStyleWidth !== undefined ? strokeStyleWidth : defaultLineWidth;\n      const strokeStyleMiterLimit = strokeStyle.getMiterLimit();\n      state.miterLimit =\n        strokeStyleMiterLimit !== undefined\n          ? strokeStyleMiterLimit\n          : defaultMiterLimit;\n      const strokeStyleOffset = strokeStyle.getOffset();\n      state.strokeOffset = strokeStyleOffset ?? defaultStrokeOffset;\n\n      if (state.lineWidth > this.maxLineWidth) {\n        this.maxLineWidth = state.lineWidth;\n        // invalidate the buffered max extent cache\n        this.bufferedMaxExtent_ = null;\n      }\n    } else {\n      state.strokeStyle = undefined;\n      state.lineCap = undefined;\n      state.lineDash = null;\n      state.lineDashOffset = undefined;\n      state.lineJoin = undefined;\n      state.lineWidth = undefined;\n      state.miterLimit = undefined;\n      state.strokeOffset = undefined;\n    }\n    return state;\n  }\n\n  /**\n   * @param {import(\"../../style/Fill.js\").default} fillStyle Fill style.\n   * @param {import(\"../../style/Stroke.js\").default} strokeStyle Stroke style.\n   * @override\n   */\n  setFillStrokeStyle(fillStyle, strokeStyle) {\n    const state = this.state;\n    this.fillStyleToState(fillStyle, state);\n    this.strokeStyleToState(strokeStyle, state);\n  }\n\n  /**\n   * @param {import(\"../canvas.js\").FillStrokeState} state State.\n   * @return {Array<*>} Fill instruction.\n   */\n  createFill(state) {\n    const fillStyle = state.fillStyle;\n    /** @type {Array<*>} */\n    const fillInstruction = [CanvasInstruction.SET_FILL_STYLE, fillStyle];\n    if (typeof fillStyle !== 'string') {\n      // Fill is a pattern or gradient - align and scale it!\n      fillInstruction.push(state.fillPatternScale);\n    }\n    return fillInstruction;\n  }\n\n  /**\n   * @param {import(\"../canvas.js\").FillStrokeState} state State.\n   */\n  applyStroke(state) {\n    this.instructions.push(this.createStroke(state));\n  }\n\n  /**\n   * @param {import(\"../canvas.js\").FillStrokeState} state State.\n   * @return {Array<*>} Stroke instruction.\n   */\n  createStroke(state) {\n    return [\n      CanvasInstruction.SET_STROKE_STYLE,\n      state.strokeStyle,\n      state.lineWidth * this.pixelRatio,\n      state.lineCap,\n      state.lineJoin,\n      state.miterLimit,\n      state.lineDash ? this.applyPixelRatio(state.lineDash) : null,\n      state.lineDashOffset * this.pixelRatio,\n    ];\n  }\n\n  /**\n   * @param {import(\"../canvas.js\").FillStrokeState} state State.\n   * @param {function(this:CanvasBuilder, import(\"../canvas.js\").FillStrokeState):Array<*>} createFill Create fill.\n   */\n  updateFillStyle(state, createFill) {\n    const fillStyle = state.fillStyle;\n    if (\n      (fillStyle !== undefined && typeof fillStyle !== 'string') ||\n      state.currentFillStyle != fillStyle\n    ) {\n      this.instructions.push(createFill.call(this, state));\n      state.currentFillStyle = fillStyle;\n    }\n  }\n\n  /**\n   * @param {import(\"../canvas.js\").FillStrokeState} state State.\n   * @param {function(this:CanvasBuilder, import(\"../canvas.js\").FillStrokeState): void} applyStroke Apply stroke.\n   */\n  updateStrokeStyle(state, applyStroke) {\n    const strokeStyle = state.strokeStyle;\n    const lineCap = state.lineCap;\n    const lineDash = state.lineDash;\n    const lineDashOffset = state.lineDashOffset;\n    const lineJoin = state.lineJoin;\n    const lineWidth = state.lineWidth;\n    const miterLimit = state.miterLimit;\n    const strokeOffset = state.strokeOffset;\n    if (\n      state.currentStrokeStyle != strokeStyle ||\n      state.currentLineCap != lineCap ||\n      (lineDash != state.currentLineDash &&\n        !equals(state.currentLineDash, lineDash)) ||\n      state.currentLineDashOffset != lineDashOffset ||\n      state.currentLineJoin != lineJoin ||\n      state.currentLineWidth != lineWidth ||\n      state.currentMiterLimit != miterLimit ||\n      state.currentStrokeOffset != strokeOffset\n    ) {\n      applyStroke.call(this, state);\n      state.currentStrokeStyle = strokeStyle;\n      state.currentLineCap = lineCap;\n      state.currentLineDash = lineDash;\n      state.currentLineDashOffset = lineDashOffset;\n      state.currentLineJoin = lineJoin;\n      state.currentLineWidth = lineWidth;\n      state.currentMiterLimit = miterLimit;\n      state.currentStrokeOffset = strokeOffset;\n    }\n  }\n\n  /**\n   * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n   */\n  endGeometry(feature) {\n    this.beginGeometryInstruction1_[2] = this.instructions.length;\n    this.beginGeometryInstruction1_ = null;\n    this.beginGeometryInstruction2_[2] = this.hitDetectionInstructions.length;\n    this.beginGeometryInstruction2_ = null;\n    const endGeometryInstruction = [CanvasInstruction.END_GEOMETRY, feature];\n    this.instructions.push(endGeometryInstruction);\n    this.hitDetectionInstructions.push(endGeometryInstruction);\n  }\n\n  /**\n   * Get the buffered rendering extent.  Rendering will be clipped to the extent\n   * provided to the constructor.  To account for symbolizers that may intersect\n   * this extent, we calculate a buffered extent (e.g. based on stroke width).\n   * @return {import(\"../../extent.js\").Extent} The buffered rendering extent.\n   * @protected\n   */\n  getBufferedMaxExtent() {\n    if (!this.bufferedMaxExtent_) {\n      this.bufferedMaxExtent_ = clone(this.maxExtent);\n      if (this.maxLineWidth > 0) {\n        const width = (this.resolution * (this.maxLineWidth + 1)) / 2;\n        buffer(this.bufferedMaxExtent_, width, this.bufferedMaxExtent_);\n      }\n    }\n    return this.bufferedMaxExtent_;\n  }\n}\n\nexport default CanvasBuilder;\n","/**\n * @module ol/render/canvas/ImageBuilder\n */\nimport {containsCoordinate} from '../../extent.js';\nimport CanvasBuilder from './Builder.js';\nimport CanvasInstruction from './Instruction.js';\n\nclass CanvasImageBuilder extends CanvasBuilder {\n  /**\n   * @param {number} tolerance Tolerance.\n   * @param {import(\"../../extent.js\").Extent} maxExtent Maximum extent.\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   */\n  constructor(tolerance, maxExtent, resolution, pixelRatio) {\n    super(tolerance, maxExtent, resolution, pixelRatio);\n\n    /**\n     * @private\n     * @type {import('../../DataTile.js').ImageLike}\n     */\n    this.hitDetectionImage_ = null;\n\n    /**\n     * @private\n     * @type {import('../../DataTile.js').ImageLike}\n     */\n    this.image_ = null;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.imagePixelRatio_ = undefined;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.anchorX_ = undefined;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.anchorY_ = undefined;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.height_ = undefined;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.opacity_ = undefined;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.originX_ = undefined;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.originY_ = undefined;\n\n    /**\n     * @private\n     * @type {boolean|undefined}\n     */\n    this.rotateWithView_ = undefined;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.rotation_ = undefined;\n\n    /**\n     * @private\n     * @type {import(\"../../size.js\").Size|undefined}\n     */\n    this.scale_ = undefined;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.width_ = undefined;\n\n    /**\n     * @private\n     * @type {import('../../style/Style.js').DeclutterMode}\n     */\n    this.declutterMode_ = undefined;\n\n    /**\n     * Data shared with a text builder for combined decluttering.\n     * @private\n     * @type {import(\"../canvas.js\").DeclutterImageWithText}\n     */\n    this.declutterImageWithText_ = undefined;\n  }\n\n  /**\n   * @param {import(\"../../geom/Point.js\").default|import(\"../Feature.js\").default} pointGeometry Point geometry.\n   * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} [index] Render order index.\n   * @override\n   */\n  drawPoint(pointGeometry, feature, index) {\n    if (\n      !this.image_ ||\n      (this.maxExtent &&\n        !containsCoordinate(this.maxExtent, pointGeometry.getFlatCoordinates()))\n    ) {\n      return;\n    }\n    this.beginGeometry(pointGeometry, feature, index);\n    const flatCoordinates = pointGeometry.getFlatCoordinates();\n    const stride = pointGeometry.getStride();\n    const myBegin = this.coordinates.length;\n    const myEnd = this.appendFlatPointCoordinates(flatCoordinates, stride);\n    this.instructions.push([\n      CanvasInstruction.DRAW_IMAGE,\n      myBegin,\n      myEnd,\n      this.image_,\n      // Remaining arguments to DRAW_IMAGE are in alphabetical order\n      this.anchorX_ * this.imagePixelRatio_,\n      this.anchorY_ * this.imagePixelRatio_,\n      Math.ceil(this.height_ * this.imagePixelRatio_),\n      this.opacity_,\n      this.originX_ * this.imagePixelRatio_,\n      this.originY_ * this.imagePixelRatio_,\n      this.rotateWithView_,\n      this.rotation_,\n      [\n        (this.scale_[0] * this.pixelRatio) / this.imagePixelRatio_,\n        (this.scale_[1] * this.pixelRatio) / this.imagePixelRatio_,\n      ],\n      Math.ceil(this.width_ * this.imagePixelRatio_),\n      this.declutterMode_,\n      this.declutterImageWithText_,\n    ]);\n    this.hitDetectionInstructions.push([\n      CanvasInstruction.DRAW_IMAGE,\n      myBegin,\n      myEnd,\n      this.hitDetectionImage_,\n      // Remaining arguments to DRAW_IMAGE are in alphabetical order\n      this.anchorX_,\n      this.anchorY_,\n      this.height_,\n      1,\n      this.originX_,\n      this.originY_,\n      this.rotateWithView_,\n      this.rotation_,\n      this.scale_,\n      this.width_,\n      this.declutterMode_,\n      this.declutterImageWithText_,\n    ]);\n    this.endGeometry(feature);\n  }\n\n  /**\n   * @param {import(\"../../geom/MultiPoint.js\").default|import(\"../Feature.js\").default} multiPointGeometry MultiPoint geometry.\n   * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} [index] Render order index.\n   * @override\n   */\n  drawMultiPoint(multiPointGeometry, feature, index) {\n    if (!this.image_) {\n      return;\n    }\n    this.beginGeometry(multiPointGeometry, feature, index);\n    const flatCoordinates = multiPointGeometry.getFlatCoordinates();\n    const filteredFlatCoordinates = [];\n    for (\n      let i = 0, ii = flatCoordinates.length;\n      i < ii;\n      i += multiPointGeometry.getStride()\n    ) {\n      if (\n        !this.maxExtent ||\n        containsCoordinate(this.maxExtent, flatCoordinates.slice(i, i + 2))\n      ) {\n        filteredFlatCoordinates.push(\n          flatCoordinates[i],\n          flatCoordinates[i + 1],\n        );\n      }\n    }\n    const myBegin = this.coordinates.length;\n    const myEnd = this.appendFlatPointCoordinates(filteredFlatCoordinates, 2);\n    this.instructions.push([\n      CanvasInstruction.DRAW_IMAGE,\n      myBegin,\n      myEnd,\n      this.image_,\n      // Remaining arguments to DRAW_IMAGE are in alphabetical order\n      this.anchorX_ * this.imagePixelRatio_,\n      this.anchorY_ * this.imagePixelRatio_,\n      Math.ceil(this.height_ * this.imagePixelRatio_),\n      this.opacity_,\n      this.originX_ * this.imagePixelRatio_,\n      this.originY_ * this.imagePixelRatio_,\n      this.rotateWithView_,\n      this.rotation_,\n      [\n        (this.scale_[0] * this.pixelRatio) / this.imagePixelRatio_,\n        (this.scale_[1] * this.pixelRatio) / this.imagePixelRatio_,\n      ],\n      Math.ceil(this.width_ * this.imagePixelRatio_),\n      this.declutterMode_,\n      this.declutterImageWithText_,\n    ]);\n    this.hitDetectionInstructions.push([\n      CanvasInstruction.DRAW_IMAGE,\n      myBegin,\n      myEnd,\n      this.hitDetectionImage_,\n      // Remaining arguments to DRAW_IMAGE are in alphabetical order\n      this.anchorX_,\n      this.anchorY_,\n      this.height_,\n      1,\n      this.originX_,\n      this.originY_,\n      this.rotateWithView_,\n      this.rotation_,\n      this.scale_,\n      this.width_,\n      this.declutterMode_,\n      this.declutterImageWithText_,\n    ]);\n    this.endGeometry(feature);\n  }\n\n  /**\n   * @return {import(\"../canvas.js\").SerializableInstructions} the serializable instructions.\n   * @override\n   */\n  finish() {\n    this.reverseHitDetectionInstructions();\n    // FIXME this doesn't really protect us against further calls to draw*Geometry\n    this.anchorX_ = undefined;\n    this.anchorY_ = undefined;\n    this.hitDetectionImage_ = null;\n    this.image_ = null;\n    this.imagePixelRatio_ = undefined;\n    this.height_ = undefined;\n    this.scale_ = undefined;\n    this.opacity_ = undefined;\n    this.originX_ = undefined;\n    this.originY_ = undefined;\n    this.rotateWithView_ = undefined;\n    this.rotation_ = undefined;\n    this.width_ = undefined;\n    return super.finish();\n  }\n\n  /**\n   * @param {import(\"../../style/Image.js\").default} imageStyle Image style.\n   * @param {Object} [sharedData] Shared data.\n   * @override\n   */\n  setImageStyle(imageStyle, sharedData) {\n    const anchor = imageStyle.getAnchor();\n    const size = imageStyle.getSize();\n    const origin = imageStyle.getOrigin();\n    this.imagePixelRatio_ = imageStyle.getPixelRatio(this.pixelRatio);\n    this.anchorX_ = anchor[0];\n    this.anchorY_ = anchor[1];\n    this.hitDetectionImage_ = imageStyle.getHitDetectionImage();\n    this.image_ = imageStyle.getImage(this.pixelRatio);\n    this.height_ = size[1];\n    this.opacity_ = imageStyle.getOpacity();\n    this.originX_ = origin[0];\n    this.originY_ = origin[1];\n    this.rotateWithView_ = imageStyle.getRotateWithView();\n    this.rotation_ = imageStyle.getRotation();\n    this.scale_ = imageStyle.getScaleArray();\n    this.width_ = size[0];\n    this.declutterMode_ = imageStyle.getDeclutterMode();\n    this.declutterImageWithText_ = sharedData;\n  }\n}\n\nexport default CanvasImageBuilder;\n","/**\n * @module ol/render/canvas/LineStringBuilder\n */\nimport {\n  defaultLineDash,\n  defaultLineDashOffset,\n  defaultStrokeStyle,\n} from '../canvas.js';\nimport CanvasBuilder from './Builder.js';\nimport CanvasInstruction, {\n  beginPathInstruction,\n  strokeInstruction,\n} from './Instruction.js';\n\nclass CanvasLineStringBuilder extends CanvasBuilder {\n  /**\n   * @param {number} tolerance Tolerance.\n   * @param {import(\"../../extent.js\").Extent} maxExtent Maximum extent.\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   */\n  constructor(tolerance, maxExtent, resolution, pixelRatio) {\n    super(tolerance, maxExtent, resolution, pixelRatio);\n  }\n\n  /**\n   * @param {Array<number>} flatCoordinates Flat coordinates.\n   * @param {number} offset Offset.\n   * @param {number} end End.\n   * @param {number} stride Stride.\n   * @param {number} [strokeOffset] Stroke Offset in pixels.\n   * @private\n   * @return {number} end.\n   */\n  drawFlatCoordinates_(flatCoordinates, offset, end, stride, strokeOffset) {\n    const myBegin = this.coordinates.length;\n    const myEnd = this.appendFlatLineCoordinates(\n      flatCoordinates,\n      offset,\n      end,\n      stride,\n      false,\n      false,\n    );\n    this.instructions.push([\n      CanvasInstruction.MOVE_TO_LINE_TO,\n      myBegin,\n      myEnd,\n      strokeOffset * this.pixelRatio,\n    ]);\n    this.hitDetectionInstructions.push([\n      CanvasInstruction.MOVE_TO_LINE_TO,\n      myBegin,\n      myEnd,\n      strokeOffset,\n    ]);\n    return end;\n  }\n\n  /**\n   * @param {import(\"../../geom/LineString.js\").default|import(\"../Feature.js\").default} lineStringGeometry Line string geometry.\n   * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} [index] Render order index.\n   * @override\n   */\n  drawLineString(lineStringGeometry, feature, index) {\n    const state = this.state;\n    const strokeStyle = state.strokeStyle;\n    const lineWidth = state.lineWidth;\n    const strokeOffset = state.strokeOffset;\n    if (strokeStyle === undefined || lineWidth === undefined) {\n      return;\n    }\n    this.updateStrokeStyle(state, this.applyStroke);\n    this.beginGeometry(lineStringGeometry, feature, index);\n    this.hitDetectionInstructions.push(\n      [\n        CanvasInstruction.SET_STROKE_STYLE,\n        defaultStrokeStyle,\n        state.lineWidth,\n        state.lineCap,\n        state.lineJoin,\n        state.miterLimit,\n        defaultLineDash,\n        defaultLineDashOffset,\n      ],\n      beginPathInstruction,\n    );\n    const flatCoordinates = lineStringGeometry.getFlatCoordinates();\n    const stride = lineStringGeometry.getStride();\n    this.drawFlatCoordinates_(\n      flatCoordinates,\n      0,\n      flatCoordinates.length,\n      stride,\n      strokeOffset,\n    );\n    this.hitDetectionInstructions.push(strokeInstruction);\n    this.endGeometry(feature);\n  }\n\n  /**\n   * @param {import(\"../../geom/MultiLineString.js\").default|import(\"../Feature.js\").default} multiLineStringGeometry MultiLineString geometry.\n   * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} [index] Render order index.\n   * @override\n   */\n  drawMultiLineString(multiLineStringGeometry, feature, index) {\n    const state = this.state;\n    const strokeStyle = state.strokeStyle;\n    const lineWidth = state.lineWidth;\n    const strokeOffset = state.strokeOffset;\n    if (strokeStyle === undefined || lineWidth === undefined) {\n      return;\n    }\n    this.updateStrokeStyle(state, this.applyStroke);\n    this.beginGeometry(multiLineStringGeometry, feature, index);\n    this.hitDetectionInstructions.push(\n      [\n        CanvasInstruction.SET_STROKE_STYLE,\n        defaultStrokeStyle,\n        state.lineWidth,\n        state.lineCap,\n        state.lineJoin,\n        state.miterLimit,\n        defaultLineDash,\n        defaultLineDashOffset,\n      ],\n      beginPathInstruction,\n    );\n    const ends = multiLineStringGeometry.getEnds();\n    const flatCoordinates = multiLineStringGeometry.getFlatCoordinates();\n    const stride = multiLineStringGeometry.getStride();\n    let offset = 0;\n    for (let i = 0, ii = ends.length; i < ii; ++i) {\n      offset = this.drawFlatCoordinates_(\n        flatCoordinates,\n        offset,\n        /** @type {number} */ (ends[i]),\n        stride,\n        strokeOffset,\n      );\n    }\n    this.hitDetectionInstructions.push(strokeInstruction);\n    this.endGeometry(feature);\n  }\n\n  /**\n   * @return {import(\"../canvas.js\").SerializableInstructions} the serializable instructions.\n   * @override\n   */\n  finish() {\n    const state = this.state;\n    if (\n      state.lastStroke != undefined &&\n      state.lastStroke != this.coordinates.length\n    ) {\n      this.instructions.push(strokeInstruction);\n    }\n    this.reverseHitDetectionInstructions();\n    this.state = null;\n    return super.finish();\n  }\n\n  /**\n   * @param {import(\"../canvas.js\").FillStrokeState} state State.\n   * @override\n   */\n  applyStroke(state) {\n    if (\n      state.lastStroke != undefined &&\n      state.lastStroke != this.coordinates.length\n    ) {\n      this.instructions.push(strokeInstruction);\n      state.lastStroke = this.coordinates.length;\n    }\n    state.lastStroke = 0;\n    super.applyStroke(state);\n    this.instructions.push(beginPathInstruction);\n  }\n}\n\nexport default CanvasLineStringBuilder;\n","/**\n * @module ol/render/canvas/PolygonBuilder\n */\nimport {snap} from '../../geom/flat/simplify.js';\nimport {\n  defaultFillStyle,\n  defaultLineDash,\n  defaultLineDashOffset,\n  defaultStrokeStyle,\n} from '../canvas.js';\nimport CanvasBuilder from './Builder.js';\nimport CanvasInstruction, {\n  beginPathInstruction,\n  closePathInstruction,\n  fillInstruction,\n  strokeInstruction,\n} from './Instruction.js';\n\nclass CanvasPolygonBuilder extends CanvasBuilder {\n  /**\n   * @param {number} tolerance Tolerance.\n   * @param {import(\"../../extent.js\").Extent} maxExtent Maximum extent.\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   */\n  constructor(tolerance, maxExtent, resolution, pixelRatio) {\n    super(tolerance, maxExtent, resolution, pixelRatio);\n  }\n\n  /**\n   * @param {Array<number>} flatCoordinates Flat coordinates.\n   * @param {number} offset Offset.\n   * @param {Array<number>} ends Ends.\n   * @param {number} stride Stride.\n   * @param {number} [strokeOffset] Stroke Offset in pixels.\n   * @private\n   * @return {number} End.\n   */\n  drawFlatCoordinatess_(flatCoordinates, offset, ends, stride, strokeOffset) {\n    const state = this.state;\n    const fill = state.fillStyle !== undefined;\n    const stroke = state.strokeStyle !== undefined;\n    const numEnds = ends.length;\n    this.instructions.push(beginPathInstruction);\n    this.hitDetectionInstructions.push(beginPathInstruction);\n    for (let i = 0; i < numEnds; ++i) {\n      const end = ends[i];\n      const myBegin = this.coordinates.length;\n      const myEnd = this.appendFlatLineCoordinates(\n        flatCoordinates,\n        offset,\n        end,\n        stride,\n        true,\n        !stroke,\n      );\n      this.instructions.push([\n        CanvasInstruction.MOVE_TO_LINE_TO,\n        myBegin,\n        myEnd,\n        strokeOffset * this.pixelRatio,\n        true,\n      ]);\n      this.hitDetectionInstructions.push([\n        CanvasInstruction.MOVE_TO_LINE_TO,\n        myBegin,\n        myEnd,\n        strokeOffset,\n        true,\n      ]);\n      if (stroke) {\n        // Performance optimization: only call closePath() when we have a stroke.\n        // Otherwise the ring is closed already (see appendFlatLineCoordinates above).\n        this.instructions.push(closePathInstruction);\n        this.hitDetectionInstructions.push(closePathInstruction);\n      }\n      offset = end;\n    }\n    if (fill) {\n      this.instructions.push(fillInstruction);\n      this.hitDetectionInstructions.push(fillInstruction);\n    }\n    if (stroke) {\n      this.instructions.push(strokeInstruction);\n      this.hitDetectionInstructions.push(strokeInstruction);\n    }\n    return offset;\n  }\n\n  /**\n   * @param {import(\"../../geom/Circle.js\").default} circleGeometry Circle geometry.\n   * @param {import(\"../../Feature.js\").default} feature Feature.\n   * @param {number} [index] Render order index.\n   * @override\n   */\n  drawCircle(circleGeometry, feature, index) {\n    const state = this.state;\n    const fillStyle = state.fillStyle;\n    const strokeStyle = state.strokeStyle;\n    const strokeOffset = state.strokeOffset;\n    if (fillStyle === undefined && strokeStyle === undefined) {\n      return;\n    }\n\n    if (\n      this.handleStrokeOffset_(() =>\n        this.drawCircle(circleGeometry, feature, index),\n      )\n    ) {\n      return;\n    }\n    this.setFillStrokeStyles_();\n    this.beginGeometry(circleGeometry, feature, index);\n    if (state.fillStyle !== undefined) {\n      this.hitDetectionInstructions.push([\n        CanvasInstruction.SET_FILL_STYLE,\n        defaultFillStyle,\n      ]);\n    }\n    if (state.strokeStyle !== undefined) {\n      this.hitDetectionInstructions.push([\n        CanvasInstruction.SET_STROKE_STYLE,\n        defaultStrokeStyle,\n        state.lineWidth,\n        state.lineCap,\n        state.lineJoin,\n        state.miterLimit,\n        defaultLineDash,\n        defaultLineDashOffset,\n      ]);\n    }\n    const flatCoordinates = circleGeometry.getFlatCoordinates();\n    const stride = circleGeometry.getStride();\n    const myBegin = this.coordinates.length;\n    this.appendFlatLineCoordinates(\n      flatCoordinates,\n      0,\n      flatCoordinates.length,\n      stride,\n      false,\n      false,\n    );\n    const circleInstruction = [CanvasInstruction.CIRCLE, myBegin, strokeOffset];\n    this.instructions.push(beginPathInstruction, circleInstruction);\n    this.hitDetectionInstructions.push(beginPathInstruction, circleInstruction);\n    if (state.fillStyle !== undefined) {\n      this.instructions.push(fillInstruction);\n      this.hitDetectionInstructions.push(fillInstruction);\n    }\n    if (state.strokeStyle !== undefined) {\n      this.instructions.push(strokeInstruction);\n      this.hitDetectionInstructions.push(strokeInstruction);\n    }\n    this.endGeometry(feature);\n  }\n\n  /**\n   * @param {import(\"../../geom/Polygon.js\").default|import(\"../Feature.js\").default} polygonGeometry Polygon geometry.\n   * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} [index] Render order index.\n   * @override\n   */\n  drawPolygon(polygonGeometry, feature, index) {\n    const state = this.state;\n    const fillStyle = state.fillStyle;\n    const strokeStyle = state.strokeStyle;\n    const strokeOffset = state.strokeOffset;\n    if (fillStyle === undefined && strokeStyle === undefined) {\n      return;\n    }\n    if (\n      this.handleStrokeOffset_(() =>\n        this.drawPolygon(polygonGeometry, feature, index),\n      )\n    ) {\n      return;\n    }\n\n    this.setFillStrokeStyles_();\n    this.beginGeometry(polygonGeometry, feature, index);\n    if (state.fillStyle !== undefined) {\n      this.hitDetectionInstructions.push([\n        CanvasInstruction.SET_FILL_STYLE,\n        defaultFillStyle,\n      ]);\n    }\n    if (state.strokeStyle !== undefined) {\n      this.hitDetectionInstructions.push([\n        CanvasInstruction.SET_STROKE_STYLE,\n        defaultStrokeStyle,\n        state.lineWidth,\n        state.lineCap,\n        state.lineJoin,\n        state.miterLimit,\n        defaultLineDash,\n        defaultLineDashOffset,\n      ]);\n    }\n    const ends = polygonGeometry.getEnds();\n    const flatCoordinates = polygonGeometry.getOrientedFlatCoordinates();\n    const stride = polygonGeometry.getStride();\n    this.drawFlatCoordinatess_(\n      flatCoordinates,\n      0,\n      /** @type {Array<number>} */ (ends),\n      stride,\n      strokeOffset,\n    );\n    this.endGeometry(feature);\n  }\n\n  /**\n   * @param {import(\"../../geom/MultiPolygon.js\").default} multiPolygonGeometry MultiPolygon geometry.\n   * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} [index] Render order index.\n   * @override\n   */\n  drawMultiPolygon(multiPolygonGeometry, feature, index) {\n    const state = this.state;\n    const fillStyle = state.fillStyle;\n    const strokeStyle = state.strokeStyle;\n    const strokeOffset = state.strokeOffset;\n    if (fillStyle === undefined && strokeStyle === undefined) {\n      return;\n    }\n    if (\n      this.handleStrokeOffset_(() =>\n        this.drawMultiPolygon(multiPolygonGeometry, feature, index),\n      )\n    ) {\n      return;\n    }\n    this.setFillStrokeStyles_();\n    this.beginGeometry(multiPolygonGeometry, feature, index);\n    if (state.fillStyle !== undefined) {\n      this.hitDetectionInstructions.push([\n        CanvasInstruction.SET_FILL_STYLE,\n        defaultFillStyle,\n      ]);\n    }\n    if (state.strokeStyle !== undefined) {\n      this.hitDetectionInstructions.push([\n        CanvasInstruction.SET_STROKE_STYLE,\n        defaultStrokeStyle,\n        state.lineWidth,\n        state.lineCap,\n        state.lineJoin,\n        state.miterLimit,\n        defaultLineDash,\n        defaultLineDashOffset,\n      ]);\n    }\n    const endss = multiPolygonGeometry.getEndss();\n    const flatCoordinates = multiPolygonGeometry.getOrientedFlatCoordinates();\n    const stride = multiPolygonGeometry.getStride();\n    let offset = 0;\n    for (let i = 0, ii = endss.length; i < ii; ++i) {\n      offset = this.drawFlatCoordinatess_(\n        flatCoordinates,\n        offset,\n        endss[i],\n        stride,\n        strokeOffset,\n      );\n    }\n    this.endGeometry(feature);\n  }\n\n  /**\n   * @return {import(\"../canvas.js\").SerializableInstructions} the serializable instructions.\n   * @override\n   */\n  finish() {\n    this.reverseHitDetectionInstructions();\n    this.state = null;\n    // We want to preserve topology when drawing polygons.  Polygons are\n    // simplified using quantization and point elimination. However, we might\n    // have received a mix of quantized and non-quantized geometries, so ensure\n    // that all are quantized by quantizing all coordinates in the batch.\n    const tolerance = this.tolerance;\n    if (tolerance !== 0) {\n      const coordinates = this.coordinates;\n      for (let i = 0, ii = coordinates.length; i < ii; ++i) {\n        coordinates[i] = snap(coordinates[i], tolerance);\n      }\n    }\n    return super.finish();\n  }\n\n  /**\n   * @private\n   */\n  setFillStrokeStyles_() {\n    const state = this.state;\n    this.updateFillStyle(state, this.createFill);\n    this.updateStrokeStyle(state, this.applyStroke);\n  }\n\n  handleStrokeOffset_(drawGeometryCallback) {\n    const state = this.state;\n    const fillStyle = state.fillStyle;\n    const strokeStyle = state.strokeStyle;\n    const strokeOffset = state.strokeOffset;\n\n    // In case both fill style and stroke style are defined and the stroke style has an offset,\n    // the stroke and fill should be done in separate steps, because offset stroke shape will\n    // be different from the original shape used for the fill.\n    if (\n      Math.abs(strokeOffset) > 0 &&\n      fillStyle !== undefined &&\n      strokeStyle !== undefined\n    ) {\n      // First do only fill\n      state.strokeStyle = undefined;\n      state.strokeOffset = 0;\n      drawGeometryCallback();\n      // Now separately do the stroke\n      state.fillStyle = undefined;\n      state.strokeStyle = strokeStyle;\n      state.strokeOffset = strokeOffset;\n      drawGeometryCallback();\n      // Reset the state to the original\n      state.fillStyle = fillStyle;\n      return true;\n    }\n    return false;\n  }\n}\n\nexport default CanvasPolygonBuilder;\n","import {lerp} from '../../math.js';\n\n/**\n * Creates chunks of equal length from a linestring\n * @param {number} chunkLength Length of each chunk.\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Start offset of the `flatCoordinates`.\n * @param {number} end End offset of the `flatCoordinates`.\n * @param {number} stride Stride.\n * @return {Array<Array<number>>} Chunks of linestrings with stride 2.\n */\nexport function lineChunk(chunkLength, flatCoordinates, offset, end, stride) {\n  const chunks = [];\n  let cursor = offset;\n  let chunkM = 0;\n  let currentChunk = flatCoordinates.slice(offset, 2);\n  while (chunkM < chunkLength && cursor + stride < end) {\n    const [x1, y1] = currentChunk.slice(-2);\n    const x2 = flatCoordinates[cursor + stride];\n    const y2 = flatCoordinates[cursor + stride + 1];\n    const segmentLength = Math.sqrt(\n      (x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1),\n    );\n    chunkM += segmentLength;\n    if (chunkM >= chunkLength) {\n      const m = (chunkLength - chunkM + segmentLength) / segmentLength;\n      const x = lerp(x1, x2, m);\n      const y = lerp(y1, y2, m);\n      currentChunk.push(x, y);\n      chunks.push(currentChunk);\n      currentChunk = [x, y];\n      if (chunkM == chunkLength) {\n        cursor += stride;\n      }\n      chunkM = 0;\n    } else if (chunkM < chunkLength) {\n      currentChunk.push(\n        flatCoordinates[cursor + stride],\n        flatCoordinates[cursor + stride + 1],\n      );\n      cursor += stride;\n    } else {\n      const missing = segmentLength - chunkM;\n      const x = lerp(x1, x2, missing / segmentLength);\n      const y = lerp(y1, y2, missing / segmentLength);\n      currentChunk.push(x, y);\n      chunks.push(currentChunk);\n      currentChunk = [x, y];\n      chunkM = 0;\n      cursor += stride;\n    }\n  }\n  if (chunkM > 0) {\n    chunks.push(currentChunk);\n  }\n  return chunks;\n}\n","/**\n * @module ol/geom/flat/straightchunk\n */\n\n/**\n * @param {number} maxAngle Maximum acceptable angle delta between segments.\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @return {Array<number>} Start and end of the first suitable chunk of the\n * given `flatCoordinates`.\n */\nexport function matchingChunk(maxAngle, flatCoordinates, offset, end, stride) {\n  let chunkStart = offset;\n  let chunkEnd = offset;\n  let chunkM = 0;\n  let m = 0;\n  let start = offset;\n  let acos, i, m12, m23, x1, y1, x12, y12, x23, y23;\n  for (i = offset; i < end; i += stride) {\n    const x2 = flatCoordinates[i];\n    const y2 = flatCoordinates[i + 1];\n    if (x1 !== undefined) {\n      x23 = x2 - x1;\n      y23 = y2 - y1;\n      m23 = Math.sqrt(x23 * x23 + y23 * y23);\n      if (x12 !== undefined) {\n        m += m12;\n        acos = Math.acos((x12 * x23 + y12 * y23) / (m12 * m23));\n        if (acos > maxAngle) {\n          if (m > chunkM) {\n            chunkM = m;\n            chunkStart = start;\n            chunkEnd = i;\n          }\n          m = 0;\n          start = i - stride;\n        }\n      }\n      m12 = m23;\n      x12 = x23;\n      y12 = y23;\n    }\n    x1 = x2;\n    y1 = y2;\n  }\n  m += m23;\n  return m > chunkM ? [start, i] : [chunkStart, chunkEnd];\n}\n","/**\n * @module ol/render/canvas/TextBuilder\n */\nimport {asColorLike} from '../../colorlike.js';\nimport {intersects} from '../../extent.js';\nimport {lineChunk} from '../../geom/flat/linechunk.js';\nimport {matchingChunk} from '../../geom/flat/straightchunk.js';\nimport {getUid} from '../../util.js';\nimport {\n  defaultFillStyle,\n  defaultFont,\n  defaultLineCap,\n  defaultLineDash,\n  defaultLineDashOffset,\n  defaultLineJoin,\n  defaultLineWidth,\n  defaultMiterLimit,\n  defaultPadding,\n  defaultStrokeStyle,\n  defaultTextAlign,\n  defaultTextBaseline,\n  registerFont,\n} from '../canvas.js';\nimport CanvasBuilder from './Builder.js';\nimport CanvasInstruction from './Instruction.js';\n/**\n * @const\n * @type {{left: 0, center: 0.5, right: 1, top: 0, middle: 0.5, hanging: 0.2, alphabetic: 0.8, ideographic: 0.8, bottom: 1}}\n */\nexport const TEXT_ALIGN = {\n  'left': 0,\n  'center': 0.5,\n  'right': 1,\n  'top': 0,\n  'middle': 0.5,\n  'hanging': 0.2,\n  'alphabetic': 0.8,\n  'ideographic': 0.8,\n  'bottom': 1,\n};\n\nclass CanvasTextBuilder extends CanvasBuilder {\n  /**\n   * @param {number} tolerance Tolerance.\n   * @param {import(\"../../extent.js\").Extent} maxExtent Maximum extent.\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   */\n  constructor(tolerance, maxExtent, resolution, pixelRatio) {\n    super(tolerance, maxExtent, resolution, pixelRatio);\n\n    /**\n     * @private\n     * @type {Array<HTMLCanvasElement>}\n     */\n    this.labels_ = null;\n\n    /**\n     * @private\n     * @type {string|Array<string>}\n     */\n    this.text_ = '';\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.textOffsetX_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.textOffsetY_ = 0;\n\n    /**\n     * @private\n     * @type {boolean|undefined}\n     */\n    this.textRotateWithView_ = undefined;\n\n    /**\n     * @private\n     * @type {boolean|undefined}\n     */\n    this.textKeepUpright_ = undefined;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.textRotation_ = 0;\n\n    /**\n     * @private\n     * @type {?import(\"../canvas.js\").FillState}\n     */\n    this.textFillState_ = null;\n\n    /**\n     * @type {!Object<string, import(\"../canvas.js\").FillState>}\n     */\n    this.fillStates = {};\n    this.fillStates[defaultFillStyle] = {fillStyle: defaultFillStyle};\n\n    /**\n     * @private\n     * @type {?import(\"../canvas.js\").StrokeState}\n     */\n    this.textStrokeState_ = null;\n\n    /**\n     * @type {!Object<string, import(\"../canvas.js\").StrokeState>}\n     */\n    this.strokeStates = {};\n\n    /**\n     * @private\n     * @type {import(\"../canvas.js\").TextState}\n     */\n    this.textState_ = /** @type {import(\"../canvas.js\").TextState} */ ({});\n\n    /**\n     * @type {!Object<string, import(\"../canvas.js\").TextState>}\n     */\n    this.textStates = {};\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.textKey_ = '';\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.fillKey_ = '';\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.strokeKey_ = '';\n\n    /**\n     * @private\n     * @type {import('../../style/Style.js').DeclutterMode}\n     */\n    this.declutterMode_ = undefined;\n\n    /**\n     * Data shared with an image builder for combined decluttering.\n     * @private\n     * @type {import(\"../canvas.js\").DeclutterImageWithText}\n     */\n    this.declutterImageWithText_ = undefined;\n  }\n\n  /**\n   * @return {import(\"../canvas.js\").SerializableInstructions} the serializable instructions.\n   * @override\n   */\n  finish() {\n    const instructions = super.finish();\n    instructions.textStates = this.textStates;\n    instructions.fillStates = this.fillStates;\n    instructions.strokeStates = this.strokeStates;\n    return instructions;\n  }\n\n  /**\n   * @param {import(\"../../geom/SimpleGeometry.js\").default|import(\"../Feature.js\").default} geometry Geometry.\n   * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} [index] Render order index.\n   * @override\n   */\n  drawText(geometry, feature, index) {\n    const fillState = this.textFillState_;\n    const strokeState = this.textStrokeState_;\n    const textState = this.textState_;\n    if (this.text_ === '' || !textState || (!fillState && !strokeState)) {\n      return;\n    }\n\n    const coordinates = this.coordinates;\n    let begin = coordinates.length;\n\n    const geometryType = geometry.getType();\n    let flatCoordinates = null;\n    let stride = geometry.getStride();\n\n    if (\n      textState.placement === 'line' &&\n      (geometryType == 'LineString' ||\n        geometryType == 'MultiLineString' ||\n        geometryType == 'Polygon' ||\n        geometryType == 'MultiPolygon')\n    ) {\n      if (!intersects(this.maxExtent, geometry.getExtent())) {\n        return;\n      }\n      let ends;\n      flatCoordinates = geometry.getFlatCoordinates();\n      if (geometryType == 'LineString') {\n        ends = [flatCoordinates.length];\n      } else if (geometryType == 'MultiLineString') {\n        ends = /** @type {import(\"../../geom/MultiLineString.js\").default} */ (\n          geometry\n        ).getEnds();\n      } else if (geometryType == 'Polygon') {\n        ends = /** @type {import(\"../../geom/Polygon.js\").default} */ (geometry)\n          .getEnds()\n          .slice(0, 1);\n      } else if (geometryType == 'MultiPolygon') {\n        const endss =\n          /** @type {import(\"../../geom/MultiPolygon.js\").default} */ (\n            geometry\n          ).getEndss();\n        ends = [];\n        for (let i = 0, ii = endss.length; i < ii; ++i) {\n          ends.push(endss[i][0]);\n        }\n      }\n      this.beginGeometry(geometry, feature, index);\n      const repeat = textState.repeat;\n      const textAlign = repeat ? undefined : textState.textAlign;\n      // No `justify` support for line placement.\n      let flatOffset = 0;\n      for (let o = 0, oo = ends.length; o < oo; ++o) {\n        let chunks;\n        if (repeat) {\n          chunks = lineChunk(\n            repeat * this.resolution,\n            flatCoordinates,\n            flatOffset,\n            ends[o],\n            stride,\n          );\n        } else {\n          chunks = [flatCoordinates.slice(flatOffset, ends[o])];\n        }\n        for (let c = 0, cc = chunks.length; c < cc; ++c) {\n          const chunk = chunks[c];\n          let chunkBegin = 0;\n          let chunkEnd = chunk.length;\n          if (textAlign == undefined) {\n            const range = matchingChunk(\n              textState.maxAngle,\n              chunk,\n              0,\n              chunk.length,\n              2,\n            );\n            chunkBegin = range[0];\n            chunkEnd = range[1];\n          }\n          for (let i = chunkBegin; i < chunkEnd; i += stride) {\n            coordinates.push(chunk[i], chunk[i + 1]);\n          }\n          const end = coordinates.length;\n          flatOffset = ends[o];\n          this.drawChars_(begin, end);\n          begin = end;\n        }\n      }\n      this.endGeometry(feature);\n    } else {\n      let geometryWidths = textState.overflow ? null : [];\n      switch (geometryType) {\n        case 'Point':\n        case 'MultiPoint':\n          flatCoordinates =\n            /** @type {import(\"../../geom/MultiPoint.js\").default} */ (\n              geometry\n            ).getFlatCoordinates();\n          break;\n        case 'LineString':\n          flatCoordinates =\n            /** @type {import(\"../../geom/LineString.js\").default} */ (\n              geometry\n            ).getFlatMidpoint();\n          break;\n        case 'Circle':\n          flatCoordinates =\n            /** @type {import(\"../../geom/Circle.js\").default} */ (\n              geometry\n            ).getCenter();\n          break;\n        case 'MultiLineString':\n          flatCoordinates =\n            /** @type {import(\"../../geom/MultiLineString.js\").default} */ (\n              geometry\n            ).getFlatMidpoints();\n          stride = 2;\n          break;\n        case 'Polygon':\n          flatCoordinates =\n            /** @type {import(\"../../geom/Polygon.js\").default} */ (\n              geometry\n            ).getFlatInteriorPoint();\n          if (!textState.overflow) {\n            geometryWidths.push(flatCoordinates[2] / this.resolution);\n          }\n          stride = 3;\n          break;\n        case 'MultiPolygon':\n          const interiorPoints =\n            /** @type {import(\"../../geom/MultiPolygon.js\").default} */ (\n              geometry\n            ).getFlatInteriorPoints();\n          flatCoordinates = [];\n          for (let i = 0, ii = interiorPoints.length; i < ii; i += 3) {\n            if (!textState.overflow) {\n              geometryWidths.push(interiorPoints[i + 2] / this.resolution);\n            }\n            flatCoordinates.push(interiorPoints[i], interiorPoints[i + 1]);\n          }\n          if (flatCoordinates.length === 0) {\n            return;\n          }\n          stride = 2;\n          break;\n        default:\n      }\n      const end = this.appendFlatPointCoordinates(flatCoordinates, stride);\n      if (end === begin) {\n        return;\n      }\n      if (\n        geometryWidths &&\n        (end - begin) / 2 !== flatCoordinates.length / stride\n      ) {\n        let beg = begin / 2;\n        geometryWidths = geometryWidths.filter((w, i) => {\n          const keep =\n            coordinates[(beg + i) * 2] === flatCoordinates[i * stride] &&\n            coordinates[(beg + i) * 2 + 1] === flatCoordinates[i * stride + 1];\n          if (!keep) {\n            --beg;\n          }\n          return keep;\n        });\n      }\n\n      this.saveTextStates_();\n\n      const backgroundFill = textState.backgroundFill\n        ? this.createFill(this.fillStyleToState(textState.backgroundFill))\n        : null;\n      const backgroundStroke = textState.backgroundStroke\n        ? this.createStroke(this.strokeStyleToState(textState.backgroundStroke))\n        : null;\n\n      this.beginGeometry(geometry, feature, index);\n\n      // adjust padding for negative scale\n      let padding = textState.padding;\n      if (\n        padding != defaultPadding &&\n        (textState.scale[0] < 0 || textState.scale[1] < 0)\n      ) {\n        let p0 = textState.padding[0];\n        let p1 = textState.padding[1];\n        let p2 = textState.padding[2];\n        let p3 = textState.padding[3];\n        if (textState.scale[0] < 0) {\n          p1 = -p1;\n          p3 = -p3;\n        }\n        if (textState.scale[1] < 0) {\n          p0 = -p0;\n          p2 = -p2;\n        }\n        padding = [p0, p1, p2, p3];\n      }\n\n      // The image is unknown at this stage so we pass null; it will be computed at render time.\n      // For clarity, we pass NaN for offsetX, offsetY, width and height, which will be computed at\n      // render time.\n      const pixelRatio = this.pixelRatio;\n      this.instructions.push([\n        CanvasInstruction.DRAW_IMAGE,\n        begin,\n        end,\n        null,\n        NaN,\n        NaN,\n        NaN,\n        1,\n        0,\n        0,\n        this.textRotateWithView_,\n        this.textRotation_,\n        [1, 1],\n        NaN,\n        this.declutterMode_,\n        this.declutterImageWithText_,\n        padding == defaultPadding\n          ? defaultPadding\n          : padding.map(function (p) {\n              return p * pixelRatio;\n            }),\n        backgroundFill,\n        backgroundStroke,\n        this.text_,\n        this.textKey_,\n        this.strokeKey_,\n        this.fillKey_,\n        this.textOffsetX_,\n        this.textOffsetY_,\n        geometryWidths,\n      ]);\n      const scale = 1 / pixelRatio;\n      // Set default fill for hit detection background\n      const hitDetectionBackgroundFill = backgroundFill\n        ? backgroundFill.slice(0)\n        : null;\n      if (hitDetectionBackgroundFill) {\n        hitDetectionBackgroundFill[1] = defaultFillStyle;\n      }\n      this.hitDetectionInstructions.push([\n        CanvasInstruction.DRAW_IMAGE,\n        begin,\n        end,\n        null,\n        NaN,\n        NaN,\n        NaN,\n        1,\n        0,\n        0,\n        this.textRotateWithView_,\n        this.textRotation_,\n        [scale, scale],\n        NaN,\n        this.declutterMode_,\n        this.declutterImageWithText_,\n        padding,\n        hitDetectionBackgroundFill,\n        backgroundStroke,\n        this.text_,\n        this.textKey_,\n        this.strokeKey_,\n        this.fillKey_ ? defaultFillStyle : this.fillKey_,\n        this.textOffsetX_,\n        this.textOffsetY_,\n        geometryWidths,\n      ]);\n\n      this.endGeometry(feature);\n    }\n  }\n\n  /**\n   * @private\n   */\n  saveTextStates_() {\n    const strokeState = this.textStrokeState_;\n    const textState = this.textState_;\n    const fillState = this.textFillState_;\n\n    const strokeKey = this.strokeKey_;\n    if (strokeState) {\n      if (!(strokeKey in this.strokeStates)) {\n        this.strokeStates[strokeKey] = {\n          strokeStyle: strokeState.strokeStyle,\n          lineCap: strokeState.lineCap,\n          lineDashOffset: strokeState.lineDashOffset,\n          lineWidth: strokeState.lineWidth,\n          lineJoin: strokeState.lineJoin,\n          miterLimit: strokeState.miterLimit,\n          lineDash: strokeState.lineDash,\n        };\n      }\n    }\n    const textKey = this.textKey_;\n    if (!(textKey in this.textStates)) {\n      this.textStates[textKey] = {\n        font: textState.font,\n        textAlign: textState.textAlign || defaultTextAlign,\n        justify: textState.justify,\n        textBaseline: textState.textBaseline || defaultTextBaseline,\n        scale: textState.scale,\n      };\n    }\n    const fillKey = this.fillKey_;\n    if (fillState) {\n      if (!(fillKey in this.fillStates)) {\n        this.fillStates[fillKey] = {\n          fillStyle: fillState.fillStyle,\n        };\n      }\n    }\n  }\n\n  /**\n   * @private\n   * @param {number} begin Begin.\n   * @param {number} end End.\n   */\n  drawChars_(begin, end) {\n    const strokeState = this.textStrokeState_;\n    const textState = this.textState_;\n\n    const strokeKey = this.strokeKey_;\n    const textKey = this.textKey_;\n    const fillKey = this.fillKey_;\n    this.saveTextStates_();\n\n    const pixelRatio = this.pixelRatio;\n    const baseline = TEXT_ALIGN[textState.textBaseline];\n\n    const offsetY = this.textOffsetY_ * pixelRatio;\n    const text = this.text_;\n    const strokeWidth = strokeState\n      ? (strokeState.lineWidth * Math.abs(textState.scale[0])) / 2\n      : 0;\n\n    this.instructions.push([\n      CanvasInstruction.DRAW_CHARS,\n      begin,\n      end,\n      baseline,\n      textState.overflow,\n      fillKey,\n      textState.maxAngle,\n      pixelRatio,\n      offsetY,\n      strokeKey,\n      strokeWidth * pixelRatio,\n      text,\n      textKey,\n      1,\n      this.declutterMode_,\n      this.textKeepUpright_,\n    ]);\n    this.hitDetectionInstructions.push([\n      CanvasInstruction.DRAW_CHARS,\n      begin,\n      end,\n      baseline,\n      textState.overflow,\n      fillKey ? defaultFillStyle : fillKey,\n      textState.maxAngle,\n      pixelRatio,\n      offsetY,\n      strokeKey,\n      strokeWidth * pixelRatio,\n      text,\n      textKey,\n      1 / pixelRatio,\n      this.declutterMode_,\n      this.textKeepUpright_,\n    ]);\n  }\n\n  /**\n   * @param {import(\"../../style/Text.js\").default} textStyle Text style.\n   * @param {Object} [sharedData] Shared data.\n   * @override\n   */\n  setTextStyle(textStyle, sharedData) {\n    let textState, fillState, strokeState;\n    if (!textStyle) {\n      this.text_ = '';\n    } else {\n      const textFillStyle = textStyle.getFill();\n      if (!textFillStyle) {\n        fillState = null;\n        this.textFillState_ = fillState;\n      } else {\n        fillState = this.textFillState_;\n        if (!fillState) {\n          fillState = /** @type {import(\"../canvas.js\").FillState} */ ({});\n          this.textFillState_ = fillState;\n        }\n        fillState.fillStyle = asColorLike(\n          textFillStyle.getColor() || defaultFillStyle,\n        );\n      }\n\n      const textStrokeStyle = textStyle.getStroke();\n      if (!textStrokeStyle) {\n        strokeState = null;\n        this.textStrokeState_ = strokeState;\n      } else {\n        strokeState = this.textStrokeState_;\n        if (!strokeState) {\n          strokeState = /** @type {import(\"../canvas.js\").StrokeState} */ ({});\n          this.textStrokeState_ = strokeState;\n        }\n        const lineDash = textStrokeStyle.getLineDash();\n        const lineDashOffset = textStrokeStyle.getLineDashOffset();\n        const lineWidth = textStrokeStyle.getWidth();\n        const miterLimit = textStrokeStyle.getMiterLimit();\n        strokeState.lineCap = textStrokeStyle.getLineCap() || defaultLineCap;\n        strokeState.lineDash = lineDash ? lineDash.slice() : defaultLineDash;\n        strokeState.lineDashOffset =\n          lineDashOffset === undefined ? defaultLineDashOffset : lineDashOffset;\n        strokeState.lineJoin = textStrokeStyle.getLineJoin() || defaultLineJoin;\n        strokeState.lineWidth =\n          lineWidth === undefined ? defaultLineWidth : lineWidth;\n        strokeState.miterLimit =\n          miterLimit === undefined ? defaultMiterLimit : miterLimit;\n        strokeState.strokeStyle = asColorLike(\n          textStrokeStyle.getColor() || defaultStrokeStyle,\n        );\n      }\n\n      textState = this.textState_;\n      const font = textStyle.getFont() || defaultFont;\n      registerFont(font);\n      const textScale = textStyle.getScaleArray();\n      textState.overflow = textStyle.getOverflow();\n      textState.font = font;\n      textState.maxAngle = textStyle.getMaxAngle();\n      textState.placement = textStyle.getPlacement();\n      textState.textAlign = textStyle.getTextAlign();\n      textState.repeat = textStyle.getRepeat();\n      textState.justify = textStyle.getJustify();\n      textState.textBaseline =\n        textStyle.getTextBaseline() || defaultTextBaseline;\n      textState.backgroundFill = textStyle.getBackgroundFill();\n      textState.backgroundStroke = textStyle.getBackgroundStroke();\n      textState.padding = textStyle.getPadding() || defaultPadding;\n      textState.scale = textScale === undefined ? [1, 1] : textScale;\n\n      const textOffsetX = textStyle.getOffsetX();\n      const textOffsetY = textStyle.getOffsetY();\n      const textRotateWithView = textStyle.getRotateWithView();\n      const textKeepUpright = textStyle.getKeepUpright();\n      const textRotation = textStyle.getRotation();\n      this.text_ = textStyle.getText() || '';\n      this.textOffsetX_ = textOffsetX === undefined ? 0 : textOffsetX;\n      this.textOffsetY_ = textOffsetY === undefined ? 0 : textOffsetY;\n      this.textRotateWithView_ =\n        textRotateWithView === undefined ? false : textRotateWithView;\n      this.textKeepUpright_ =\n        textKeepUpright === undefined ? true : textKeepUpright;\n      this.textRotation_ = textRotation === undefined ? 0 : textRotation;\n\n      this.strokeKey_ = strokeState\n        ? (typeof strokeState.strokeStyle == 'string'\n            ? strokeState.strokeStyle\n            : getUid(strokeState.strokeStyle)) +\n          strokeState.lineCap +\n          strokeState.lineDashOffset +\n          '|' +\n          strokeState.lineWidth +\n          strokeState.lineJoin +\n          strokeState.miterLimit +\n          '[' +\n          strokeState.lineDash.join() +\n          ']'\n        : '';\n      this.textKey_ =\n        textState.font +\n        textState.scale +\n        (textState.textAlign || '?') +\n        (textState.repeat || '?') +\n        (textState.justify || '?') +\n        (textState.textBaseline || '?');\n      this.fillKey_ =\n        fillState && fillState.fillStyle\n          ? typeof fillState.fillStyle == 'string'\n            ? fillState.fillStyle\n            : '|' + getUid(fillState.fillStyle)\n          : '';\n    }\n    this.declutterMode_ = textStyle.getDeclutterMode();\n    this.declutterImageWithText_ = sharedData;\n  }\n}\n\nexport default CanvasTextBuilder;\n","/**\n * @module ol/render/canvas/BuilderGroup\n */\n\nimport Builder from './Builder.js';\nimport ImageBuilder from './ImageBuilder.js';\nimport LineStringBuilder from './LineStringBuilder.js';\nimport PolygonBuilder from './PolygonBuilder.js';\nimport TextBuilder from './TextBuilder.js';\n\n/**\n * @type {Object<import(\"../canvas.js\").BuilderType, typeof Builder>}\n */\nconst BATCH_CONSTRUCTORS = {\n  'Circle': PolygonBuilder,\n  'Default': Builder,\n  'Image': ImageBuilder,\n  'LineString': LineStringBuilder,\n  'Polygon': PolygonBuilder,\n  'Text': TextBuilder,\n};\n\nclass BuilderGroup {\n  /**\n   * @param {number} tolerance Tolerance.\n   * @param {import(\"../../extent.js\").Extent} maxExtent Max extent.\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   */\n  constructor(tolerance, maxExtent, resolution, pixelRatio) {\n    /**\n     * @private\n     * @type {number}\n     */\n    this.tolerance_ = tolerance;\n\n    /**\n     * @private\n     * @type {import(\"../../extent.js\").Extent}\n     */\n    this.maxExtent_ = maxExtent;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.pixelRatio_ = pixelRatio;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.resolution_ = resolution;\n\n    /**\n     * @private\n     * @type {!Object<string, !Object<import(\"../canvas.js\").BuilderType, Builder>>}\n     */\n    this.buildersByZIndex_ = {};\n  }\n\n  /**\n   * @return {!Object<string, !Object<import(\"../canvas.js\").BuilderType, import(\"./Builder.js\").SerializableInstructions>>} The serializable instructions\n   */\n  finish() {\n    const builderInstructions = {};\n    for (const zKey in this.buildersByZIndex_) {\n      builderInstructions[zKey] = builderInstructions[zKey] || {};\n      const builders = this.buildersByZIndex_[zKey];\n      for (const builderKey in builders) {\n        const builderInstruction = builders[builderKey].finish();\n        builderInstructions[zKey][builderKey] = builderInstruction;\n      }\n    }\n    return builderInstructions;\n  }\n\n  /**\n   * @param {number|undefined} zIndex Z index.\n   * @param {import(\"../canvas.js\").BuilderType} builderType Replay type.\n   * @return {import(\"../VectorContext.js\").default} Replay.\n   */\n  getBuilder(zIndex, builderType) {\n    const zIndexKey = zIndex !== undefined ? zIndex.toString() : '0';\n    let replays = this.buildersByZIndex_[zIndexKey];\n    if (replays === undefined) {\n      replays = {};\n      this.buildersByZIndex_[zIndexKey] = replays;\n    }\n    let replay = replays[builderType];\n    if (replay === undefined) {\n      const Constructor = BATCH_CONSTRUCTORS[builderType];\n      replay = new Constructor(\n        this.tolerance_,\n        this.maxExtent_,\n        this.resolution_,\n        this.pixelRatio_,\n      );\n      replays[builderType] = replay;\n    }\n    return replay;\n  }\n}\n\nexport default BuilderGroup;\n","/**\n * @module ol/geom/flat/textpath\n */\nimport {lerp} from '../../math.js';\nimport {rotate} from './transform.js';\n\n/**\n * @param {Array<number>} flatCoordinates Path to put text on.\n * @param {number} offset Start offset of the `flatCoordinates`.\n * @param {number} end End offset of the `flatCoordinates`.\n * @param {number} stride Stride.\n * @param {string} text Text to place on the path.\n * @param {number} startM m along the path where the text starts.\n * @param {number} maxAngle Max angle between adjacent chars in radians.\n * @param {number} scale The product of the text scale and the device pixel ratio.\n * @param {function(string, string, Object<string, number>):number} measureAndCacheTextWidth Measure and cache text width.\n * @param {string} font The font.\n * @param {Object<string, number>} cache A cache of measured widths.\n * @param {number} rotation Rotation to apply to the flatCoordinates to determine whether text needs to be reversed.\n * @param {boolean} keepUpright Whether the text needs to be kept upright\n * @return {Array<Array<*>>|null} The result array (or null if `maxAngle` was\n * exceeded). Entries of the array are x, y, anchorX, angle, chunk.\n */\nexport function drawTextOnPath(\n  flatCoordinates,\n  offset,\n  end,\n  stride,\n  text,\n  startM,\n  maxAngle,\n  scale,\n  measureAndCacheTextWidth,\n  font,\n  cache,\n  rotation,\n  keepUpright = true,\n) {\n  let x2 = flatCoordinates[offset];\n  let y2 = flatCoordinates[offset + 1];\n  let x1 = 0;\n  let y1 = 0;\n  let segmentLength = 0;\n  let segmentM = 0;\n\n  function advance() {\n    x1 = x2;\n    y1 = y2;\n    offset += stride;\n    x2 = flatCoordinates[offset];\n    y2 = flatCoordinates[offset + 1];\n    segmentM += segmentLength;\n    segmentLength = Math.sqrt((x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1));\n  }\n  do {\n    advance();\n  } while (offset < end - stride && segmentM + segmentLength < startM);\n\n  let interpolate =\n    segmentLength === 0 ? 0 : (startM - segmentM) / segmentLength;\n  const beginX = lerp(x1, x2, interpolate);\n  const beginY = lerp(y1, y2, interpolate);\n\n  const startOffset = offset - stride;\n  const startLength = segmentM;\n  const endM = startM + scale * measureAndCacheTextWidth(font, text, cache);\n  while (offset < end - stride && segmentM + segmentLength < endM) {\n    advance();\n  }\n  interpolate = segmentLength === 0 ? 0 : (endM - segmentM) / segmentLength;\n  const endX = lerp(x1, x2, interpolate);\n  const endY = lerp(y1, y2, interpolate);\n\n  // Keep text upright if the option is selected\n  let reverse = false;\n  if (keepUpright) {\n    if (rotation) {\n      const flat = [beginX, beginY, endX, endY];\n      rotate(flat, 0, 4, 2, rotation, flat, flat);\n      reverse = flat[0] > flat[2];\n    } else {\n      reverse = beginX > endX;\n    }\n  }\n\n  const PI = Math.PI;\n  const result = [];\n  const singleSegment = startOffset + stride === offset;\n\n  offset = startOffset;\n  segmentLength = 0;\n  segmentM = startLength;\n  x2 = flatCoordinates[offset];\n  y2 = flatCoordinates[offset + 1];\n\n  let previousAngle;\n  // All on the same segment\n  if (singleSegment) {\n    advance();\n\n    previousAngle = Math.atan2(y2 - y1, x2 - x1);\n    if (reverse) {\n      previousAngle += previousAngle > 0 ? -PI : PI;\n    }\n    const x = (endX + beginX) / 2;\n    const y = (endY + beginY) / 2;\n    result[0] = [x, y, (endM - startM) / 2, previousAngle, text];\n    return result;\n  }\n\n  // rendering across line segments\n  text = text.replace(/\\n/g, ' '); // ensure rendering in single-line as all calculations below don't handle multi-lines\n\n  for (let i = 0, ii = text.length; i < ii; ) {\n    advance();\n    let angle = Math.atan2(y2 - y1, x2 - x1);\n    if (reverse) {\n      angle += angle > 0 ? -PI : PI;\n    }\n    if (previousAngle !== undefined) {\n      let delta = angle - previousAngle;\n      delta += delta > PI ? -2 * PI : delta < -PI ? 2 * PI : 0;\n      if (Math.abs(delta) > maxAngle) {\n        return null;\n      }\n    }\n    previousAngle = angle;\n\n    const iStart = i;\n    let charLength = 0;\n    for (; i < ii; ++i) {\n      const index = reverse ? ii - i - 1 : i;\n      const len = scale * measureAndCacheTextWidth(font, text[index], cache);\n      if (\n        offset + stride < end &&\n        segmentM + segmentLength < startM + charLength + len / 2\n      ) {\n        break;\n      }\n      charLength += len;\n    }\n    if (i === iStart) {\n      continue;\n    }\n    const chars = reverse\n      ? text.substring(ii - iStart, ii - i)\n      : text.substring(iStart, i);\n    interpolate =\n      segmentLength === 0\n        ? 0\n        : (startM + charLength / 2 - segmentM) / segmentLength;\n    const x = lerp(x1, x2, interpolate);\n    const y = lerp(y1, y2, interpolate);\n    result.push([x, y, charLength / 2, angle, chars]);\n    startM += charLength;\n  }\n  return result;\n}\n","/**\n * @module ol/render/canvas/Executor\n */\nimport {equals} from '../../array.js';\nimport {createEmpty, createOrUpdate, intersects} from '../../extent.js';\nimport {lineStringLength} from '../../geom/flat/length.js';\nimport {\n  offsetLineString,\n  removeOffsetCycles,\n} from '../../geom/flat/lineoffset.js';\nimport {drawTextOnPath} from '../../geom/flat/textpath.js';\nimport {transform2D} from '../../geom/flat/transform.js';\nimport {\n  apply as applyTransform,\n  compose as composeTransform,\n  create as createTransform,\n  setFromArray as transformSetFromArray,\n} from '../../transform.js';\nimport {\n  defaultPadding,\n  defaultTextAlign,\n  defaultTextBaseline,\n  drawImageOrLabel,\n  getTextDimensions,\n  measureAndCacheTextWidth,\n} from '../canvas.js';\nimport ZIndexContext from '../canvas/ZIndexContext.js';\nimport CanvasInstruction from './Instruction.js';\nimport {TEXT_ALIGN} from './TextBuilder.js';\n\n/**\n * @typedef {import('../../structs/RBush.js').Entry<import('../../Feature.js').FeatureLike>} DeclutterEntry\n */\n\n/**\n * @typedef {Object} ImageOrLabelDimensions\n * @property {number} drawImageX DrawImageX.\n * @property {number} drawImageY DrawImageY.\n * @property {number} drawImageW DrawImageW.\n * @property {number} drawImageH DrawImageH.\n * @property {number} originX OriginX.\n * @property {number} originY OriginY.\n * @property {Array<number>} scale Scale.\n * @property {DeclutterEntry} declutterBox DeclutterBox.\n * @property {import(\"../../transform.js\").Transform} canvasTransform CanvasTransform.\n */\n\n/**\n * @typedef {{0: CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D, 1: import('../../size.js').Size, 2: import(\"../canvas.js\").Label|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement, 3: ImageOrLabelDimensions, 4: number, 5: Array<*>, 6: Array<*>}} ReplayImageOrLabelArgs\n */\n\n/**\n * @template T\n * @typedef {function(import(\"../../Feature.js\").FeatureLike, import(\"../../geom/SimpleGeometry.js\").default, import(\"../../style/Style.js\").DeclutterMode): T} FeatureCallback\n */\n\n/**\n * @type {import(\"../../extent.js\").Extent}\n */\nconst tmpExtent = createEmpty();\n\n/** @type {import(\"../../coordinate.js\").Coordinate} */\nconst p1 = [];\n/** @type {import(\"../../coordinate.js\").Coordinate} */\nconst p2 = [];\n/** @type {import(\"../../coordinate.js\").Coordinate} */\nconst p3 = [];\n/** @type {import(\"../../coordinate.js\").Coordinate} */\nconst p4 = [];\n\n/**\n * @param {ReplayImageOrLabelArgs} replayImageOrLabelArgs Arguments to replayImageOrLabel\n * @return {DeclutterEntry} Declutter rbush entry.\n */\nfunction getDeclutterBox(replayImageOrLabelArgs) {\n  return replayImageOrLabelArgs[3].declutterBox;\n}\n\nconst rtlRegEx = new RegExp(\n  /* eslint-disable prettier/prettier */\n  '[' +\n    String.fromCharCode(0x00591) + '-' + String.fromCharCode(0x008ff) +\n    String.fromCharCode(0x0fb1d) + '-' + String.fromCharCode(0x0fdff) +\n    String.fromCharCode(0x0fe70) + '-' + String.fromCharCode(0x0fefc) +\n    String.fromCharCode(0x10800) + '-' + String.fromCharCode(0x10fff) +\n    String.fromCharCode(0x1e800) + '-' + String.fromCharCode(0x1efff) +\n  ']'\n  /* eslint-enable prettier/prettier */\n);\n\n/**\n * @param {string} text Text.\n * @param {CanvasTextAlign} align Alignment.\n * @return {number} Text alignment.\n */\nfunction horizontalTextAlign(text, align) {\n  if (align === 'start') {\n    align = rtlRegEx.test(text) ? 'right' : 'left';\n  } else if (align === 'end') {\n    align = rtlRegEx.test(text) ? 'left' : 'right';\n  }\n  return TEXT_ALIGN[align];\n}\n\n/**\n * @param {Array<string>} acc Accumulator.\n * @param {string} line Line of text.\n * @param {number} i Index\n * @return {Array<string>} Accumulator.\n */\nfunction createTextChunks(acc, line, i) {\n  if (i > 0) {\n    acc.push('\\n', '');\n  }\n  acc.push(line, '');\n  return acc;\n}\n\n/**\n * Converts rich text to plain text for text along lines.\n * @param {string} result The resulting plain text.\n * @param {string} part Item of the rich text array.\n * @param {number} index Index of the item in the rich text array.\n * @return {string} The resulting plain text.\n */\nfunction richTextToPlainText(result, part, index) {\n  if (index % 2 === 0) {\n    result += part;\n  }\n  return result;\n}\n\nclass Executor {\n  /**\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {boolean} overlaps The replay can have overlapping geometries.\n   * @param {import(\"../canvas.js\").SerializableInstructions} instructions The serializable instructions.\n   * @param {boolean} [deferredRendering] Enable deferred rendering.\n   */\n  constructor(\n    resolution,\n    pixelRatio,\n    overlaps,\n    instructions,\n    deferredRendering,\n  ) {\n    /**\n     * @protected\n     * @type {boolean}\n     */\n    this.overlaps = overlaps;\n\n    /**\n     * @protected\n     * @type {number}\n     */\n    this.pixelRatio = pixelRatio;\n\n    /**\n     * @protected\n     * @const\n     * @type {number}\n     */\n    this.resolution = resolution;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.alignAndScaleFill_;\n\n    /**\n     * @protected\n     * @type {Array<*>}\n     */\n    this.instructions = instructions.instructions;\n\n    /**\n     * @protected\n     * @type {Array<number>}\n     */\n    this.coordinates = instructions.coordinates;\n\n    /**\n     * @private\n     * @type {!Object<number,import(\"../../coordinate.js\").Coordinate|Array<import(\"../../coordinate.js\").Coordinate>|Array<Array<import(\"../../coordinate.js\").Coordinate>>>}\n     */\n    this.coordinateCache_ = {};\n\n    /**\n     * @private\n     * @type {!import(\"../../transform.js\").Transform}\n     */\n    this.renderedTransform_ = createTransform();\n\n    /**\n     * @protected\n     * @type {Array<*>}\n     */\n    this.hitDetectionInstructions = instructions.hitDetectionInstructions;\n\n    /**\n     * @private\n     * @type {Array<number>}\n     */\n    this.pixelCoordinates_ = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.viewRotation_ = 0;\n\n    /**\n     * @type {!Object<string, import(\"../canvas.js\").FillState>}\n     */\n    this.fillStates = instructions.fillStates || {};\n\n    /**\n     * @type {!Object<string, import(\"../canvas.js\").StrokeState>}\n     */\n    this.strokeStates = instructions.strokeStates || {};\n\n    /**\n     * @type {!Object<string, import(\"../canvas.js\").TextState>}\n     */\n    this.textStates = instructions.textStates || {};\n\n    /**\n     * @private\n     * @type {Object<string, Object<string, number>>}\n     */\n    this.widths_ = {};\n\n    /**\n     * @private\n     * @type {Object<string, import(\"../canvas.js\").Label>}\n     */\n    this.labels_ = {};\n\n    /**\n     * @private\n     * @type {import(\"../canvas/ZIndexContext.js\").default}\n     */\n    this.zIndexContext_ = deferredRendering ? new ZIndexContext() : null;\n  }\n\n  /**\n   * @return {ZIndexContext} ZIndex context.\n   */\n  getZIndexContext() {\n    return this.zIndexContext_;\n  }\n\n  /**\n   * @param {string|Array<string>} text Text.\n   * @param {string} textKey Text style key.\n   * @param {string} fillKey Fill style key.\n   * @param {string} strokeKey Stroke style key.\n   * @return {import(\"../canvas.js\").Label} Label.\n   */\n  createLabel(text, textKey, fillKey, strokeKey) {\n    const key = text + textKey + fillKey + strokeKey;\n    if (this.labels_[key]) {\n      return this.labels_[key];\n    }\n    const strokeState = strokeKey ? this.strokeStates[strokeKey] : null;\n    const fillState = fillKey ? this.fillStates[fillKey] : null;\n    const textState = this.textStates[textKey];\n    const pixelRatio = this.pixelRatio;\n    const scale = [\n      textState.scale[0] * pixelRatio,\n      textState.scale[1] * pixelRatio,\n    ];\n    const align = textState.justify\n      ? TEXT_ALIGN[textState.justify]\n      : horizontalTextAlign(\n          Array.isArray(text) ? text[0] : text,\n          textState.textAlign || defaultTextAlign,\n        );\n    const strokeWidth =\n      strokeKey && strokeState.lineWidth ? strokeState.lineWidth : 0;\n\n    const chunks = Array.isArray(text)\n      ? text\n      : String(text).split('\\n').reduce(createTextChunks, []);\n\n    const {width, height, widths, heights, lineWidths} = getTextDimensions(\n      textState,\n      chunks,\n    );\n    const renderWidth = width + strokeWidth;\n    const contextInstructions = [];\n    // make canvas 2 pixels wider to account for italic text width measurement errors\n    const w = (renderWidth + 2) * scale[0];\n    const h = (height + strokeWidth) * scale[1];\n    /** @type {import(\"../canvas.js\").Label} */\n    const label = {\n      width: w < 0 ? Math.floor(w) : Math.ceil(w),\n      height: h < 0 ? Math.floor(h) : Math.ceil(h),\n      contextInstructions: contextInstructions,\n    };\n    if (scale[0] != 1 || scale[1] != 1) {\n      contextInstructions.push('scale', scale);\n    }\n    if (strokeKey) {\n      contextInstructions.push('strokeStyle', strokeState.strokeStyle);\n      contextInstructions.push('lineWidth', strokeWidth);\n      contextInstructions.push('lineCap', strokeState.lineCap);\n      contextInstructions.push('lineJoin', strokeState.lineJoin);\n      contextInstructions.push('miterLimit', strokeState.miterLimit);\n      contextInstructions.push('setLineDash', [strokeState.lineDash]);\n      contextInstructions.push('lineDashOffset', strokeState.lineDashOffset);\n    }\n    if (fillKey) {\n      contextInstructions.push('fillStyle', fillState.fillStyle);\n    }\n    contextInstructions.push('textBaseline', 'middle');\n    contextInstructions.push('textAlign', 'center');\n    const leftRight = 0.5 - align;\n    let x = align * renderWidth + leftRight * strokeWidth;\n    const strokeInstructions = [];\n    const fillInstructions = [];\n    let lineHeight = 0;\n    let lineOffset = 0;\n    let widthHeightIndex = 0;\n    let lineWidthIndex = 0;\n    let previousFont;\n    for (let i = 0, ii = chunks.length; i < ii; i += 2) {\n      const text = chunks[i];\n      if (text === '\\n') {\n        lineOffset += lineHeight;\n        lineHeight = 0;\n        x = align * renderWidth + leftRight * strokeWidth;\n        ++lineWidthIndex;\n        continue;\n      }\n      const font = chunks[i + 1] || textState.font;\n      if (font !== previousFont) {\n        if (strokeKey) {\n          strokeInstructions.push('font', font);\n        }\n        if (fillKey) {\n          fillInstructions.push('font', font);\n        }\n        previousFont = font;\n      }\n      lineHeight = Math.max(lineHeight, heights[widthHeightIndex]);\n      const fillStrokeArgs = [\n        text,\n        x +\n          leftRight * widths[widthHeightIndex] +\n          align * (widths[widthHeightIndex] - lineWidths[lineWidthIndex]),\n        0.5 * (strokeWidth + lineHeight) + lineOffset,\n      ];\n      x += widths[widthHeightIndex];\n      if (strokeKey) {\n        strokeInstructions.push('strokeText', fillStrokeArgs);\n      }\n      if (fillKey) {\n        fillInstructions.push('fillText', fillStrokeArgs);\n      }\n      ++widthHeightIndex;\n    }\n    Array.prototype.push.apply(contextInstructions, strokeInstructions);\n    Array.prototype.push.apply(contextInstructions, fillInstructions);\n    this.labels_[key] = label;\n    return label;\n  }\n\n  /**\n   * @param {CanvasRenderingContext2D} context Context.\n   * @param {import(\"../../coordinate.js\").Coordinate} p1 1st point of the background box.\n   * @param {import(\"../../coordinate.js\").Coordinate} p2 2nd point of the background box.\n   * @param {import(\"../../coordinate.js\").Coordinate} p3 3rd point of the background box.\n   * @param {import(\"../../coordinate.js\").Coordinate} p4 4th point of the background box.\n   * @param {Array<*>} fillInstruction Fill instruction.\n   * @param {Array<*>} strokeInstruction Stroke instruction.\n   */\n  replayTextBackground_(\n    context,\n    p1,\n    p2,\n    p3,\n    p4,\n    fillInstruction,\n    strokeInstruction,\n  ) {\n    context.beginPath();\n    context.moveTo.apply(context, p1);\n    context.lineTo.apply(context, p2);\n    context.lineTo.apply(context, p3);\n    context.lineTo.apply(context, p4);\n    context.lineTo.apply(context, p1);\n    if (fillInstruction) {\n      this.alignAndScaleFill_ = /** @type {number} */ (fillInstruction[2]);\n      context.fillStyle = /** @type {string} */ (fillInstruction[1]);\n      this.fill_(context);\n    }\n    if (strokeInstruction) {\n      this.setStrokeStyle_(\n        context,\n        /** @type {Array<*>} */ (strokeInstruction),\n      );\n      context.stroke();\n    }\n  }\n\n  /**\n   * @private\n   * @param {number} sheetWidth Width of the sprite sheet.\n   * @param {number} sheetHeight Height of the sprite sheet.\n   * @param {number} centerX X.\n   * @param {number} centerY Y.\n   * @param {number} width Width.\n   * @param {number} height Height.\n   * @param {number} anchorX Anchor X.\n   * @param {number} anchorY Anchor Y.\n   * @param {number} originX Origin X.\n   * @param {number} originY Origin Y.\n   * @param {number} rotation Rotation.\n   * @param {import(\"../../size.js\").Size} scale Scale.\n   * @param {boolean} snapToPixel Snap to pixel.\n   * @param {Array<number>} padding Padding.\n   * @param {boolean} fillStroke Background fill or stroke.\n   * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n   * @return {ImageOrLabelDimensions} Dimensions for positioning and decluttering the image or label.\n   */\n  calculateImageOrLabelDimensions_(\n    sheetWidth,\n    sheetHeight,\n    centerX,\n    centerY,\n    width,\n    height,\n    anchorX,\n    anchorY,\n    originX,\n    originY,\n    rotation,\n    scale,\n    snapToPixel,\n    padding,\n    fillStroke,\n    feature,\n  ) {\n    anchorX *= scale[0];\n    anchorY *= scale[1];\n    let x = centerX - anchorX;\n    let y = centerY - anchorY;\n\n    const w = width + originX > sheetWidth ? sheetWidth - originX : width;\n    const h = height + originY > sheetHeight ? sheetHeight - originY : height;\n    const boxW = padding[3] + w * scale[0] + padding[1];\n    const boxH = padding[0] + h * scale[1] + padding[2];\n    const boxX = x - padding[3];\n    const boxY = y - padding[0];\n\n    if (fillStroke || rotation !== 0) {\n      p1[0] = boxX;\n      p4[0] = boxX;\n      p1[1] = boxY;\n      p2[1] = boxY;\n      p2[0] = boxX + boxW;\n      p3[0] = p2[0];\n      p3[1] = boxY + boxH;\n      p4[1] = p3[1];\n    }\n\n    let transform;\n    if (rotation !== 0) {\n      transform = composeTransform(\n        createTransform(),\n        centerX,\n        centerY,\n        1,\n        1,\n        rotation,\n        -centerX,\n        -centerY,\n      );\n\n      applyTransform(transform, p1);\n      applyTransform(transform, p2);\n      applyTransform(transform, p3);\n      applyTransform(transform, p4);\n      createOrUpdate(\n        Math.min(p1[0], p2[0], p3[0], p4[0]),\n        Math.min(p1[1], p2[1], p3[1], p4[1]),\n        Math.max(p1[0], p2[0], p3[0], p4[0]),\n        Math.max(p1[1], p2[1], p3[1], p4[1]),\n        tmpExtent,\n      );\n    } else {\n      createOrUpdate(\n        Math.min(boxX, boxX + boxW),\n        Math.min(boxY, boxY + boxH),\n        Math.max(boxX, boxX + boxW),\n        Math.max(boxY, boxY + boxH),\n        tmpExtent,\n      );\n    }\n    if (snapToPixel) {\n      x = Math.round(x);\n      y = Math.round(y);\n    }\n    return {\n      drawImageX: x,\n      drawImageY: y,\n      drawImageW: w,\n      drawImageH: h,\n      originX: originX,\n      originY: originY,\n      declutterBox: {\n        minX: tmpExtent[0],\n        minY: tmpExtent[1],\n        maxX: tmpExtent[2],\n        maxY: tmpExtent[3],\n        value: feature,\n      },\n      canvasTransform: transform,\n      scale: scale,\n    };\n  }\n\n  /**\n   * @private\n   * @param {CanvasRenderingContext2D} context Context.\n   * @param {import('../../size.js').Size} scaledCanvasSize Scaled canvas size.\n   * @param {import(\"../canvas.js\").Label|HTMLImageElement|HTMLCanvasElement|HTMLVideoElement} imageOrLabel Image.\n   * @param {ImageOrLabelDimensions} dimensions Dimensions.\n   * @param {number} opacity Opacity.\n   * @param {Array<*>} fillInstruction Fill instruction.\n   * @param {Array<*>} strokeInstruction Stroke instruction.\n   * @return {boolean} The image or label was rendered.\n   */\n  replayImageOrLabel_(\n    context,\n    scaledCanvasSize,\n    imageOrLabel,\n    dimensions,\n    opacity,\n    fillInstruction,\n    strokeInstruction,\n  ) {\n    const fillStroke = !!(fillInstruction || strokeInstruction);\n\n    const box = dimensions.declutterBox;\n    const strokePadding = strokeInstruction\n      ? (strokeInstruction[2] * dimensions.scale[0]) / 2\n      : 0;\n    const intersects =\n      box.minX - strokePadding <= scaledCanvasSize[0] &&\n      box.maxX + strokePadding >= 0 &&\n      box.minY - strokePadding <= scaledCanvasSize[1] &&\n      box.maxY + strokePadding >= 0;\n\n    if (intersects) {\n      if (fillStroke) {\n        this.replayTextBackground_(\n          context,\n          p1,\n          p2,\n          p3,\n          p4,\n          /** @type {Array<*>} */ (fillInstruction),\n          /** @type {Array<*>} */ (strokeInstruction),\n        );\n      }\n      drawImageOrLabel(\n        context,\n        dimensions.canvasTransform,\n        opacity,\n        imageOrLabel,\n        dimensions.originX,\n        dimensions.originY,\n        dimensions.drawImageW,\n        dimensions.drawImageH,\n        dimensions.drawImageX,\n        dimensions.drawImageY,\n        dimensions.scale,\n      );\n    }\n    return true;\n  }\n\n  /**\n   * @private\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context Context.\n   */\n  fill_(context) {\n    const alignAndScale = this.alignAndScaleFill_;\n    if (alignAndScale) {\n      const origin = applyTransform(this.renderedTransform_, [0, 0]);\n      const repeatSize = 512 * this.pixelRatio;\n      context.save();\n      context.translate(origin[0] % repeatSize, origin[1] % repeatSize);\n      if (alignAndScale !== 1) {\n        context.scale(alignAndScale, alignAndScale);\n      }\n    }\n    context.fill();\n    if (alignAndScale) {\n      context.restore();\n    }\n  }\n\n  /**\n   * @private\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context Context.\n   * @param {Array<*>} instruction Instruction.\n   */\n  setStrokeStyle_(context, instruction) {\n    context.strokeStyle =\n      /** @type {import(\"../../colorlike.js\").ColorLike} */ (instruction[1]);\n    if (!instruction[1]) {\n      return;\n    }\n    context.lineWidth = /** @type {number} */ (instruction[2]);\n    context.lineCap = /** @type {CanvasLineCap} */ (instruction[3]);\n    context.lineJoin = /** @type {CanvasLineJoin} */ (instruction[4]);\n    context.miterLimit = /** @type {number} */ (instruction[5]);\n    context.lineDashOffset = /** @type {number} */ (instruction[7]);\n    context.setLineDash(/** @type {Array<number>} */ (instruction[6]));\n  }\n\n  /**\n   * @private\n   * @param {string|Array<string>} text The text to draw.\n   * @param {string} textKey The key of the text state.\n   * @param {string} strokeKey The key for the stroke state.\n   * @param {string} fillKey The key for the fill state.\n   * @return {{label: import(\"../canvas.js\").Label, anchorX: number, anchorY: number}} The text image and its anchor.\n   */\n  drawLabelWithPointPlacement_(text, textKey, strokeKey, fillKey) {\n    const textState = this.textStates[textKey];\n\n    const label = this.createLabel(text, textKey, fillKey, strokeKey);\n\n    const strokeState = this.strokeStates[strokeKey];\n    const pixelRatio = this.pixelRatio;\n    const align = horizontalTextAlign(\n      Array.isArray(text) ? text[0] : text,\n      textState.textAlign || defaultTextAlign,\n    );\n    const baseline = TEXT_ALIGN[textState.textBaseline || defaultTextBaseline];\n    const strokeWidth =\n      strokeState && strokeState.lineWidth ? strokeState.lineWidth : 0;\n\n    // Remove the 2 pixels we added in createLabel() for the anchor\n    const width = label.width / pixelRatio - 2 * textState.scale[0];\n    const anchorX = align * width + 2 * (0.5 - align) * strokeWidth;\n    const anchorY =\n      (baseline * label.height) / pixelRatio +\n      2 * (0.5 - baseline) * strokeWidth;\n\n    return {\n      label: label,\n      anchorX: anchorX,\n      anchorY: anchorY,\n    };\n  }\n\n  /**\n   * @private\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context Context.\n   * @param {import('../../size.js').Size} scaledCanvasSize Scaled canvas size\n   * @param {import(\"../../transform.js\").Transform} transform Transform.\n   * @param {Array<*>} instructions Instructions array.\n   * @param {boolean} snapToPixel Snap point symbols and text to integer pixels.\n   * @param {FeatureCallback<T>} [featureCallback] Feature callback.\n   * @param {import(\"../../extent.js\").Extent} [hitExtent] Only check\n   *     features that intersect this extent.\n   * @param {import(\"rbush\").default<DeclutterEntry>} [declutterTree] Declutter tree.\n   * @return {T|undefined} Callback result.\n   * @template T\n   */\n  execute_(\n    context,\n    scaledCanvasSize,\n    transform,\n    instructions,\n    snapToPixel,\n    featureCallback,\n    hitExtent,\n    declutterTree,\n  ) {\n    const zIndexContext = this.zIndexContext_;\n    /** @type {Array<number>} */\n    let pixelCoordinates;\n    if (this.pixelCoordinates_ && equals(transform, this.renderedTransform_)) {\n      pixelCoordinates = this.pixelCoordinates_;\n    } else {\n      if (!this.pixelCoordinates_) {\n        this.pixelCoordinates_ = [];\n      }\n      pixelCoordinates = transform2D(\n        this.coordinates,\n        0,\n        this.coordinates.length,\n        2,\n        transform,\n        this.pixelCoordinates_,\n      );\n      transformSetFromArray(this.renderedTransform_, transform);\n    }\n    let i = 0; // instruction index\n    const ii = instructions.length; // end of instructions\n    let d = 0; // data index\n    let dd; // end of per-instruction data\n    const offsetCoords = [];\n    let anchorX,\n      anchorY,\n      lineOffsetPx,\n      /** @type {import('../../style/Style.js').DeclutterMode} */\n      declutterMode,\n      prevX,\n      prevY,\n      roundX,\n      roundY,\n      image,\n      text,\n      textKey,\n      strokeKey,\n      fillKey;\n    let pendingFill = 0;\n    let pendingStroke = 0;\n    const coordinateCache = this.coordinateCache_;\n    const viewRotation = this.viewRotation_;\n    const viewRotationFromTransform =\n      Math.round(Math.atan2(-transform[1], transform[0]) * 1e12) / 1e12;\n\n    const state = /** @type {import(\"../../render.js\").State} */ ({\n      context: context,\n      pixelRatio: this.pixelRatio,\n      resolution: this.resolution,\n      rotation: viewRotation,\n    });\n\n    // When the batch size gets too big, performance decreases. 200 is a good\n    // balance between batch size and number of fill/stroke instructions.\n    const batchSize =\n      this.instructions != instructions || this.overlaps ? 0 : 200;\n    let /** @type {import(\"../../Feature.js\").FeatureLike} */ feature;\n    let x, y, currentGeometry;\n    while (i < ii) {\n      const instruction = instructions[i];\n      const type = /** @type {import(\"./Instruction.js\").default} */ (\n        instruction[0]\n      );\n      switch (type) {\n        case CanvasInstruction.BEGIN_GEOMETRY:\n          feature = /** @type {import(\"../../Feature.js\").FeatureLike} */ (\n            instruction[1]\n          );\n          currentGeometry = instruction[3];\n          if (!feature.getGeometry()) {\n            i = /** @type {number} */ (instruction[2]);\n          } else if (\n            hitExtent !== undefined &&\n            !intersects(hitExtent, currentGeometry.getExtent())\n          ) {\n            i = /** @type {number} */ (instruction[2]) + 1;\n          } else {\n            ++i;\n          }\n          if (zIndexContext) {\n            zIndexContext.zIndex = instruction[4];\n          }\n          break;\n        case CanvasInstruction.BEGIN_PATH:\n          if (pendingFill > batchSize) {\n            this.fill_(context);\n            pendingFill = 0;\n          }\n          if (pendingStroke > batchSize) {\n            context.stroke();\n            pendingStroke = 0;\n          }\n          if (!pendingFill && !pendingStroke) {\n            context.beginPath();\n            prevX = NaN;\n            prevY = NaN;\n          }\n          ++i;\n          break;\n        case CanvasInstruction.CIRCLE:\n          d = /** @type {number} */ (instruction[1]);\n          lineOffsetPx = /** @type {number} */ instruction[2] ?? 0;\n          const x1 = pixelCoordinates[d];\n          const y1 = pixelCoordinates[d + 1];\n          const x2 = pixelCoordinates[d + 2] - lineOffsetPx;\n          const y2 = pixelCoordinates[d + 3] - lineOffsetPx;\n          const dx = x2 - x1;\n          const dy = y2 - y1;\n          const r = Math.sqrt(dx * dx + dy * dy);\n          context.moveTo(x1 + r, y1);\n          context.arc(x1, y1, r, 0, 2 * Math.PI, true);\n          ++i;\n          break;\n        case CanvasInstruction.CLOSE_PATH:\n          context.closePath();\n          ++i;\n          break;\n        case CanvasInstruction.CUSTOM:\n          d = /** @type {number} */ (instruction[1]);\n          dd = instruction[2];\n          const geometry =\n            /** @type {import(\"../../geom/SimpleGeometry.js\").default} */ (\n              instruction[3]\n            );\n          const renderer = instruction[4];\n          const fn = instruction[5];\n          state.geometry = geometry;\n          state.feature = feature;\n          if (!(i in coordinateCache)) {\n            coordinateCache[i] = [];\n          }\n          const coords = coordinateCache[i];\n          if (fn) {\n            fn(pixelCoordinates, d, dd, 2, coords);\n          } else {\n            coords[0] = pixelCoordinates[d];\n            coords[1] = pixelCoordinates[d + 1];\n            coords.length = 2;\n          }\n          if (zIndexContext) {\n            zIndexContext.zIndex = instruction[6];\n          }\n          renderer(coords, state);\n          ++i;\n          break;\n        case CanvasInstruction.DRAW_IMAGE:\n          d = /** @type {number} */ (instruction[1]);\n          dd = /** @type {number} */ (instruction[2]);\n          image =\n            /** @type {HTMLCanvasElement|HTMLVideoElement|HTMLImageElement} */ (\n              instruction[3]\n            );\n\n          // Remaining arguments in DRAW_IMAGE are in alphabetical order\n          anchorX = /** @type {number} */ (instruction[4]);\n          anchorY = /** @type {number} */ (instruction[5]);\n          let height = /** @type {number} */ (instruction[6]);\n          const opacity = /** @type {number} */ (instruction[7]);\n          const originX = /** @type {number} */ (instruction[8]);\n          const originY = /** @type {number} */ (instruction[9]);\n          const rotateWithView = /** @type {boolean} */ (instruction[10]);\n          let rotation = /** @type {number} */ (instruction[11]);\n          const scale = /** @type {import(\"../../size.js\").Size} */ (\n            instruction[12]\n          );\n          let width = /** @type {number} */ (instruction[13]);\n          declutterMode = instruction[14] || 'declutter';\n          const declutterImageWithText =\n            /** @type {{args: import(\"../canvas.js\").DeclutterImageWithText, declutterMode: import('../../style/Style.js').DeclutterMode}} */ (\n              instruction[15]\n            );\n\n          if (!image && instruction.length >= 20) {\n            // create label images\n            text = /** @type {string} */ (instruction[19]);\n            textKey = /** @type {string} */ (instruction[20]);\n            strokeKey = /** @type {string} */ (instruction[21]);\n            fillKey = /** @type {string} */ (instruction[22]);\n            const labelWithAnchor = this.drawLabelWithPointPlacement_(\n              text,\n              textKey,\n              strokeKey,\n              fillKey,\n            );\n            image = labelWithAnchor.label;\n            instruction[3] = image;\n            const textOffsetX = /** @type {number} */ (instruction[23]);\n            anchorX = (labelWithAnchor.anchorX - textOffsetX) * this.pixelRatio;\n            instruction[4] = anchorX;\n            const textOffsetY = /** @type {number} */ (instruction[24]);\n            anchorY = (labelWithAnchor.anchorY - textOffsetY) * this.pixelRatio;\n            instruction[5] = anchorY;\n            height = image.height;\n            instruction[6] = height;\n            width = image.width;\n            instruction[13] = width;\n          }\n\n          let geometryWidths;\n          if (instruction.length > 25) {\n            geometryWidths = /** @type {number} */ (instruction[25]);\n          }\n\n          let padding, backgroundFillInstruction, backgroundStrokeInstruction;\n          if (instruction.length > 17) {\n            padding = /** @type {Array<number>} */ (instruction[16]);\n            backgroundFillInstruction = /** @type {Array<*>} */ (\n              instruction[17]\n            );\n            backgroundStrokeInstruction = /** @type {Array<*>} */ (\n              instruction[18]\n            );\n          } else {\n            padding = defaultPadding;\n            backgroundFillInstruction = null;\n            backgroundStrokeInstruction = null;\n          }\n\n          if (rotateWithView && viewRotationFromTransform) {\n            // Canvas is expected to be rotated to reverse view rotation.\n            rotation += viewRotation;\n          } else if (!rotateWithView && !viewRotationFromTransform) {\n            // Canvas is not rotated, images need to be rotated back to be north-up.\n            rotation -= viewRotation;\n          }\n          let widthIndex = 0;\n          for (; d < dd; d += 2) {\n            if (\n              geometryWidths &&\n              geometryWidths[widthIndex++] < width / this.pixelRatio\n            ) {\n              continue;\n            }\n            const dimensions = this.calculateImageOrLabelDimensions_(\n              image.width,\n              image.height,\n              pixelCoordinates[d],\n              pixelCoordinates[d + 1],\n              width,\n              height,\n              anchorX,\n              anchorY,\n              originX,\n              originY,\n              rotation,\n              scale,\n              snapToPixel,\n              padding,\n              !!backgroundFillInstruction || !!backgroundStrokeInstruction,\n              feature,\n            );\n            /** @type {ReplayImageOrLabelArgs} */\n            const args = [\n              context,\n              scaledCanvasSize,\n              image,\n              dimensions,\n              opacity,\n              backgroundFillInstruction,\n              backgroundStrokeInstruction,\n            ];\n            if (declutterTree) {\n              let imageArgs, imageDeclutterMode, imageDeclutterBox;\n              if (declutterImageWithText) {\n                const index = dd - d;\n                if (!declutterImageWithText[index]) {\n                  // We now have the image for an image+text combination.\n                  declutterImageWithText[index] = {args, declutterMode};\n                  // Don't render anything for now, wait for the text.\n                  continue;\n                }\n                const imageDeclutter = declutterImageWithText[index];\n                imageArgs = imageDeclutter.args;\n                imageDeclutterMode = imageDeclutter.declutterMode;\n                delete declutterImageWithText[index];\n                imageDeclutterBox = getDeclutterBox(imageArgs);\n              }\n              // We now have image and text for an image+text combination.\n              let renderImage, renderText;\n              if (\n                imageArgs &&\n                (imageDeclutterMode !== 'declutter' ||\n                  !declutterTree.collides(imageDeclutterBox))\n              ) {\n                renderImage = true;\n              }\n              if (\n                declutterMode !== 'declutter' ||\n                !declutterTree.collides(dimensions.declutterBox)\n              ) {\n                renderText = true;\n              }\n              if (\n                imageDeclutterMode === 'declutter' &&\n                declutterMode === 'declutter'\n              ) {\n                const render = renderImage && renderText;\n                renderImage = render;\n                renderText = render;\n              }\n              if (renderImage) {\n                if (imageDeclutterMode !== 'none') {\n                  declutterTree.insert(imageDeclutterBox);\n                }\n                this.replayImageOrLabel_.apply(this, imageArgs);\n              }\n              if (renderText) {\n                if (declutterMode !== 'none') {\n                  declutterTree.insert(dimensions.declutterBox);\n                }\n                this.replayImageOrLabel_.apply(this, args);\n              }\n            } else {\n              this.replayImageOrLabel_.apply(this, args);\n            }\n          }\n          ++i;\n          break;\n        case CanvasInstruction.DRAW_CHARS:\n          const begin = /** @type {number} */ (instruction[1]);\n          const end = /** @type {number} */ (instruction[2]);\n          const baseline = /** @type {number} */ (instruction[3]);\n          const overflow = /** @type {number} */ (instruction[4]);\n          fillKey = /** @type {string} */ (instruction[5]);\n          const maxAngle = /** @type {number} */ (instruction[6]);\n          const measurePixelRatio = /** @type {number} */ (instruction[7]);\n          const offsetY = /** @type {number} */ (instruction[8]);\n          strokeKey = /** @type {string} */ (instruction[9]);\n          const strokeWidth = /** @type {number} */ (instruction[10]);\n          text = /** @type {string|Array<string>} */ (instruction[11]);\n          if (Array.isArray(text)) {\n            //FIXME Add support for rich text along lines\n            text = text.reduce(richTextToPlainText, '');\n          }\n          textKey = /** @type {string} */ (instruction[12]);\n          const pixelRatioScale = [\n            /** @type {number} */ (instruction[13]),\n            /** @type {number} */ (instruction[13]),\n          ];\n          declutterMode = instruction[14] || 'declutter';\n\n          const textKeepUpright = /** @type {boolean} */ (instruction[15]);\n          const textState = this.textStates[textKey];\n          const font = textState.font;\n          const textScale = [\n            textState.scale[0] * measurePixelRatio,\n            textState.scale[1] * measurePixelRatio,\n          ];\n\n          let cachedWidths;\n          if (font in this.widths_) {\n            cachedWidths = this.widths_[font];\n          } else {\n            cachedWidths = {};\n            this.widths_[font] = cachedWidths;\n          }\n\n          const pathLength = lineStringLength(pixelCoordinates, begin, end, 2);\n          const textLength =\n            Math.abs(textScale[0]) *\n            measureAndCacheTextWidth(font, text, cachedWidths);\n          if (overflow || textLength <= pathLength) {\n            const textAlign = this.textStates[textKey].textAlign;\n            const startM =\n              (pathLength - textLength) * horizontalTextAlign(text, textAlign);\n            const parts = drawTextOnPath(\n              pixelCoordinates,\n              begin,\n              end,\n              2,\n              text,\n              startM,\n              maxAngle,\n              Math.abs(textScale[0]),\n              measureAndCacheTextWidth,\n              font,\n              cachedWidths,\n              viewRotationFromTransform ? 0 : this.viewRotation_,\n              textKeepUpright,\n            );\n            drawChars: if (parts) {\n              /** @type {Array<ReplayImageOrLabelArgs>} */\n              const replayImageOrLabelArgs = [];\n              let c, cc, chars, label, part;\n              if (strokeKey) {\n                for (c = 0, cc = parts.length; c < cc; ++c) {\n                  part = parts[c]; // x, y, anchorX, rotation, chunk\n                  chars = /** @type {string} */ (part[4]);\n                  label = this.createLabel(chars, textKey, '', strokeKey);\n                  anchorX =\n                    /** @type {number} */ (part[2]) +\n                    (textScale[0] < 0 ? -strokeWidth : strokeWidth);\n                  anchorY =\n                    baseline * label.height +\n                    ((0.5 - baseline) * 2 * strokeWidth * textScale[1]) /\n                      textScale[0] -\n                    offsetY;\n                  const dimensions = this.calculateImageOrLabelDimensions_(\n                    label.width,\n                    label.height,\n                    part[0],\n                    part[1],\n                    label.width,\n                    label.height,\n                    anchorX,\n                    anchorY,\n                    0,\n                    0,\n                    part[3],\n                    pixelRatioScale,\n                    false,\n                    defaultPadding,\n                    false,\n                    feature,\n                  );\n                  if (\n                    declutterTree &&\n                    declutterMode === 'declutter' &&\n                    declutterTree.collides(dimensions.declutterBox)\n                  ) {\n                    break drawChars;\n                  }\n                  replayImageOrLabelArgs.push([\n                    context,\n                    scaledCanvasSize,\n                    label,\n                    dimensions,\n                    1,\n                    null,\n                    null,\n                  ]);\n                }\n              }\n              if (fillKey) {\n                for (c = 0, cc = parts.length; c < cc; ++c) {\n                  part = parts[c]; // x, y, anchorX, rotation, chunk\n                  chars = /** @type {string} */ (part[4]);\n                  label = this.createLabel(chars, textKey, fillKey, '');\n                  anchorX = /** @type {number} */ (part[2]);\n                  anchorY = baseline * label.height - offsetY;\n                  const dimensions = this.calculateImageOrLabelDimensions_(\n                    label.width,\n                    label.height,\n                    part[0],\n                    part[1],\n                    label.width,\n                    label.height,\n                    anchorX,\n                    anchorY,\n                    0,\n                    0,\n                    part[3],\n                    pixelRatioScale,\n                    false,\n                    defaultPadding,\n                    false,\n                    feature,\n                  );\n                  if (\n                    declutterTree &&\n                    declutterMode === 'declutter' &&\n                    declutterTree.collides(dimensions.declutterBox)\n                  ) {\n                    break drawChars;\n                  }\n                  replayImageOrLabelArgs.push([\n                    context,\n                    scaledCanvasSize,\n                    label,\n                    dimensions,\n                    1,\n                    null,\n                    null,\n                  ]);\n                }\n              }\n              if (declutterTree && declutterMode !== 'none') {\n                declutterTree.load(replayImageOrLabelArgs.map(getDeclutterBox));\n              }\n              for (let i = 0, ii = replayImageOrLabelArgs.length; i < ii; ++i) {\n                this.replayImageOrLabel_.apply(this, replayImageOrLabelArgs[i]);\n              }\n            }\n          }\n          ++i;\n          break;\n        case CanvasInstruction.END_GEOMETRY:\n          if (featureCallback !== undefined) {\n            feature = /** @type {import(\"../../Feature.js\").FeatureLike} */ (\n              instruction[1]\n            );\n            const result = featureCallback(\n              feature,\n              currentGeometry,\n              declutterMode,\n            );\n            if (result) {\n              return result;\n            }\n          }\n          ++i;\n          break;\n        case CanvasInstruction.FILL:\n          if (batchSize) {\n            pendingFill++;\n          } else {\n            this.fill_(context);\n          }\n          ++i;\n          break;\n        case CanvasInstruction.MOVE_TO_LINE_TO:\n          d = /** @type {number} */ (instruction[1]);\n          dd = /** @type {number} */ (instruction[2]);\n          lineOffsetPx = /** @type {number|undefined} */ (instruction[3]);\n\n          let lineCoords, lineStart, lineEnd;\n          if (lineOffsetPx) {\n            const isClosedRing =\n              /** @type {boolean|undefined} */ (instruction[4]) ?? false;\n            offsetLineString(\n              pixelCoordinates,\n              d,\n              dd,\n              2,\n              lineOffsetPx,\n              isClosedRing,\n              offsetCoords,\n            );\n            removeOffsetCycles(offsetCoords, 2);\n            lineCoords = offsetCoords;\n            lineStart = 0;\n            lineEnd = lineCoords.length;\n          } else {\n            lineCoords = pixelCoordinates;\n            lineStart = d;\n            lineEnd = dd;\n          }\n          x = lineCoords[lineStart];\n          y = lineCoords[lineStart + 1];\n          context.moveTo(x, y);\n          prevX = (x + 0.5) | 0;\n          prevY = (y + 0.5) | 0;\n          for (let k = lineStart + 2; k < lineEnd; k += 2) {\n            x = lineCoords[k];\n            y = lineCoords[k + 1];\n            roundX = (x + 0.5) | 0;\n            roundY = (y + 0.5) | 0;\n            if (k == lineEnd - 2 || roundX !== prevX || roundY !== prevY) {\n              context.lineTo(x, y);\n              prevX = roundX;\n              prevY = roundY;\n            }\n          }\n          ++i;\n          break;\n        case CanvasInstruction.SET_FILL_STYLE:\n          this.alignAndScaleFill_ = instruction[2];\n\n          if (pendingFill) {\n            this.fill_(context);\n            pendingFill = 0;\n            if (pendingStroke) {\n              context.stroke();\n              pendingStroke = 0;\n            }\n          } else if (pendingStroke && instruction[1]) {\n            context.stroke();\n            pendingStroke = 0;\n          }\n\n          /** @type {import(\"../../colorlike.js\").ColorLike} */\n          context.fillStyle = instruction[1];\n          ++i;\n          break;\n        case CanvasInstruction.SET_STROKE_STYLE:\n          if (pendingFill && instruction[1]) {\n            this.fill_(context);\n            pendingFill = 0;\n          }\n          if (pendingStroke) {\n            context.stroke();\n            pendingStroke = 0;\n          }\n          this.setStrokeStyle_(context, /** @type {Array<*>} */ (instruction));\n          ++i;\n          break;\n        case CanvasInstruction.STROKE:\n          if (batchSize) {\n            pendingStroke++;\n          } else {\n            context.stroke();\n          }\n          ++i;\n          break;\n        default: // consume the instruction anyway, to avoid an infinite loop\n          ++i;\n          break;\n      }\n    }\n    if (pendingFill) {\n      this.fill_(context);\n    }\n    if (pendingStroke) {\n      context.stroke();\n    }\n    return undefined;\n  }\n\n  /**\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context Context.\n   * @param {import('../../size.js').Size} scaledCanvasSize Scaled canvas size.\n   * @param {import(\"../../transform.js\").Transform} transform Transform.\n   * @param {number} viewRotation View rotation.\n   * @param {boolean} snapToPixel Snap point symbols and text to integer pixels.\n   * @param {import(\"rbush\").default<DeclutterEntry>} [declutterTree] Declutter tree.\n   */\n  execute(\n    context,\n    scaledCanvasSize,\n    transform,\n    viewRotation,\n    snapToPixel,\n    declutterTree,\n  ) {\n    this.viewRotation_ = viewRotation;\n    this.execute_(\n      context,\n      scaledCanvasSize,\n      transform,\n      this.instructions,\n      snapToPixel,\n      undefined,\n      undefined,\n      declutterTree,\n    );\n  }\n\n  /**\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context Context.\n   * @param {import(\"../../transform.js\").Transform} transform Transform.\n   * @param {number} viewRotation View rotation.\n   * @param {FeatureCallback<T>} [featureCallback] Feature callback.\n   * @param {import(\"../../extent.js\").Extent} [hitExtent] Only check\n   *     features that intersect this extent.\n   * @return {T|undefined} Callback result.\n   * @template T\n   */\n  executeHitDetection(\n    context,\n    transform,\n    viewRotation,\n    featureCallback,\n    hitExtent,\n  ) {\n    this.viewRotation_ = viewRotation;\n    return this.execute_(\n      context,\n      [context.canvas.width, context.canvas.height],\n      transform,\n      this.hitDetectionInstructions,\n      true,\n      featureCallback,\n      hitExtent,\n    );\n  }\n}\n\nexport default Executor;\n","/**\n * @module ol/render/canvas/ExecutorGroup\n */\n\nimport {ascending, descending} from '../../array.js';\nimport {createCanvasContext2D} from '../../dom.js';\nimport {buffer, createEmpty, extendCoordinate} from '../../extent.js';\nimport {transform2D} from '../../geom/flat/transform.js';\nimport {isEmpty} from '../../obj.js';\nimport {\n  compose as composeTransform,\n  create as createTransform,\n} from '../../transform.js';\nimport Executor from './Executor.js';\n\n/**\n * @const\n * @type {Array<import(\"../canvas.js\").BuilderType>}\n */\nexport const ALL = [\n  'Polygon',\n  'Circle',\n  'LineString',\n  'Image',\n  'Text',\n  'Default',\n];\n\n/**\n * @const\n * @type {Array<import(\"../canvas.js\").BuilderType>}\n */\nexport const DECLUTTER = ['Image', 'Text'];\n\n/**\n * @const\n * @type {Array<import(\"../canvas.js\").BuilderType>}\n */\nexport const NON_DECLUTTER = ALL.filter(\n  (builderType) => !DECLUTTER.includes(builderType),\n);\n\n/** @type {boolean|undefined} */\nlet willReadFrequently = false;\n\n/** @type {boolean|undefined} */\nlet canvasReadsBenchmarked = false;\n\n/** Determine if canvas read operations are faster with willReadFrequently set to true or false */\nfunction benchmarkCanvasReads() {\n  let bestResult = 0;\n  /**\n   * @param {boolean} willReadFrequently Will read frequently.\n   * @return {number} Operation count.\n   */\n  const measure = (willReadFrequently) => {\n    const context = createCanvasContext2D(1, 1, null, {willReadFrequently});\n    let count = 0;\n    const start = performance.now();\n    for (; performance.now() - start < 50; ++count) {\n      context.fillStyle = `rgba(255,0,${count % 256},1)`;\n      context.fillRect(0, 0, 1, 1);\n      context.getImageData(0, 0, 1, 1);\n    }\n    bestResult = count > bestResult ? count : bestResult;\n    return count;\n  };\n\n  const measures = {\n    [measure(true)]: true,\n    [measure(false)]: false,\n    [measure(undefined)]: undefined,\n  };\n  willReadFrequently = measures[bestResult];\n  canvasReadsBenchmarked = true;\n}\n\nclass ExecutorGroup {\n  /**\n   * @param {import(\"../../extent.js\").Extent} maxExtent Max extent for clipping. When a\n   * `maxExtent` was set on the Builder for this executor group, the same `maxExtent`\n   * should be set here, unless the target context does not exceed that extent (which\n   * can be the case when rendering to tiles).\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {boolean} overlaps The executor group can have overlapping geometries.\n   * @param {!Object<string, !Object<import(\"../canvas.js\").BuilderType, import(\"../canvas.js\").SerializableInstructions>>} allInstructions\n   * The serializable instructions.\n   * @param {number} [renderBuffer] Optional rendering buffer.\n   * @param {boolean} [deferredRendering] Enable deferred rendering with renderDeferred().\n   */\n  constructor(\n    maxExtent,\n    resolution,\n    pixelRatio,\n    overlaps,\n    allInstructions,\n    renderBuffer,\n    deferredRendering,\n  ) {\n    /**\n     * @private\n     * @type {import(\"../../extent.js\").Extent}\n     */\n    this.maxExtent_ = maxExtent;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.overlaps_ = overlaps;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.pixelRatio_ = pixelRatio;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.resolution_ = resolution;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.renderBuffer_ = renderBuffer;\n\n    /**\n     * @private\n     * @type {!Object<string, !Object<string, import(\"./Executor.js\").default>>}\n     */\n    this.executorsByZIndex_ = {};\n\n    /**\n     * @private\n     * @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D}\n     */\n    this.hitDetectionContext_ = null;\n\n    /**\n     * @private\n     * @type {import(\"../../transform.js\").Transform}\n     */\n    this.hitDetectionTransform_ = createTransform();\n\n    /**\n     * @private\n     * @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D}\n     */\n    this.renderedContext_ = null;\n\n    /**\n     * @private\n     * @type {Object<number, Array<import(\"./ZIndexContext.js\").default>>}\n     */\n    this.deferredZIndexContexts_ = {};\n\n    this.createExecutors_(allInstructions, deferredRendering);\n  }\n\n  /**\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} context Context.\n   * @param {import(\"../../transform.js\").Transform} transform Transform.\n   */\n  clip(context, transform) {\n    const flatClipCoords = this.getClipCoords(transform);\n    context.beginPath();\n    context.moveTo(flatClipCoords[0], flatClipCoords[1]);\n    context.lineTo(flatClipCoords[2], flatClipCoords[3]);\n    context.lineTo(flatClipCoords[4], flatClipCoords[5]);\n    context.lineTo(flatClipCoords[6], flatClipCoords[7]);\n    context.clip();\n  }\n\n  /**\n   * Create executors and populate them using the provided instructions.\n   * @private\n   * @param {!Object<string, !Object<string, import(\"../canvas.js\").SerializableInstructions>>} allInstructions The serializable instructions\n   * @param {boolean} deferredRendering Enable deferred rendering.\n   */\n  createExecutors_(allInstructions, deferredRendering) {\n    for (const zIndex in allInstructions) {\n      let executors = this.executorsByZIndex_[zIndex];\n      if (executors === undefined) {\n        executors = {};\n        this.executorsByZIndex_[zIndex] = executors;\n      }\n      const instructionByZindex = allInstructions[zIndex];\n      for (const builderType in instructionByZindex) {\n        const instructions = instructionByZindex[builderType];\n        executors[builderType] = new Executor(\n          this.resolution_,\n          this.pixelRatio_,\n          this.overlaps_,\n          instructions,\n          deferredRendering,\n        );\n      }\n    }\n  }\n\n  /**\n   * @param {Array<import(\"../canvas.js\").BuilderType>} executors Executors.\n   * @return {boolean} Has executors of the provided types.\n   */\n  hasExecutors(executors) {\n    for (const zIndex in this.executorsByZIndex_) {\n      const candidates = this.executorsByZIndex_[zIndex];\n      for (let i = 0, ii = executors.length; i < ii; ++i) {\n        if (executors[i] in candidates) {\n          return true;\n        }\n      }\n    }\n    return false;\n  }\n\n  /**\n   * @param {import(\"../../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @param {number} resolution Resolution.\n   * @param {number} rotation Rotation.\n   * @param {number} hitTolerance Hit tolerance in pixels.\n   * @param {function(import(\"../../Feature.js\").FeatureLike, import(\"../../geom/SimpleGeometry.js\").default, number): T} callback Feature callback.\n   * @param {Array<import(\"../../Feature.js\").FeatureLike>} declutteredFeatures Decluttered features.\n   * @return {T|undefined} Callback result.\n   * @template T\n   */\n  forEachFeatureAtCoordinate(\n    coordinate,\n    resolution,\n    rotation,\n    hitTolerance,\n    callback,\n    declutteredFeatures,\n  ) {\n    if (canvasReadsBenchmarked === false) {\n      benchmarkCanvasReads();\n    }\n\n    hitTolerance = Math.round(hitTolerance);\n    const contextSize = hitTolerance * 2 + 1;\n    const transform = composeTransform(\n      this.hitDetectionTransform_,\n      hitTolerance + 0.5,\n      hitTolerance + 0.5,\n      1 / resolution,\n      -1 / resolution,\n      -rotation,\n      -coordinate[0],\n      -coordinate[1],\n    );\n\n    const newContext = !this.hitDetectionContext_;\n    if (newContext) {\n      this.hitDetectionContext_ = createCanvasContext2D(\n        contextSize,\n        contextSize,\n        null,\n        {willReadFrequently},\n      );\n    }\n    const context = this.hitDetectionContext_;\n\n    if (\n      context.canvas.width !== contextSize ||\n      context.canvas.height !== contextSize\n    ) {\n      context.canvas.width = contextSize;\n      context.canvas.height = contextSize;\n    } else if (!newContext) {\n      context.clearRect(0, 0, contextSize, contextSize);\n    }\n\n    /** @type {import(\"../../extent.js\").Extent|undefined} */\n    let hitExtent;\n    if (this.renderBuffer_ !== undefined) {\n      hitExtent = createEmpty();\n      extendCoordinate(hitExtent, coordinate);\n      buffer(\n        hitExtent,\n        resolution * (this.renderBuffer_ + hitTolerance),\n        hitExtent,\n      );\n    }\n\n    const indexes = getPixelIndexArray(hitTolerance);\n\n    /** @type {import(\"../canvas.js\").BuilderType} */\n    let builderType;\n\n    /**\n     * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n     * @param {import(\"../../geom/SimpleGeometry.js\").default} geometry Geometry.\n     * @param {import('../../style/Style.js').DeclutterMode} declutterMode Declutter mode.\n     * @return {T|undefined} Callback result.\n     */\n    function featureCallback(feature, geometry, declutterMode) {\n      const imageData = context.getImageData(\n        0,\n        0,\n        contextSize,\n        contextSize,\n      ).data;\n      for (let i = 0, ii = indexes.length; i < ii; i++) {\n        if (imageData[indexes[i]] > 0) {\n          if (\n            !declutteredFeatures ||\n            declutterMode === 'none' ||\n            (builderType !== 'Image' && builderType !== 'Text') ||\n            declutteredFeatures.includes(feature)\n          ) {\n            const idx = (indexes[i] - 3) / 4;\n            const x = hitTolerance - (idx % contextSize);\n            const y = hitTolerance - ((idx / contextSize) | 0);\n            const result = callback(feature, geometry, x * x + y * y);\n            if (result) {\n              return result;\n            }\n          }\n          context.clearRect(0, 0, contextSize, contextSize);\n          break;\n        }\n      }\n      return undefined;\n    }\n\n    /** @type {Array<number>} */\n    const zs = Object.keys(this.executorsByZIndex_).map(Number);\n    zs.sort(ascending);\n\n    let i, j, executors, executor, result;\n    for (i = zs.length - 1; i >= 0; --i) {\n      const zIndexKey = zs[i].toString();\n      executors = this.executorsByZIndex_[zIndexKey];\n      for (j = ALL.length - 1; j >= 0; --j) {\n        builderType = ALL[j];\n        executor = executors[builderType];\n        if (executor !== undefined) {\n          result = executor.executeHitDetection(\n            context,\n            transform,\n            rotation,\n            featureCallback,\n            hitExtent,\n          );\n          if (result) {\n            return result;\n          }\n        }\n      }\n    }\n    return undefined;\n  }\n\n  /**\n   * @param {import(\"../../transform.js\").Transform} transform Transform.\n   * @return {Array<number>|null} Clip coordinates.\n   */\n  getClipCoords(transform) {\n    const maxExtent = this.maxExtent_;\n    if (!maxExtent) {\n      return null;\n    }\n    const minX = maxExtent[0];\n    const minY = maxExtent[1];\n    const maxX = maxExtent[2];\n    const maxY = maxExtent[3];\n    const flatClipCoords = [minX, minY, minX, maxY, maxX, maxY, maxX, minY];\n    transform2D(flatClipCoords, 0, 8, 2, transform, flatClipCoords);\n    return flatClipCoords;\n  }\n\n  /**\n   * @return {boolean} Is empty.\n   */\n  isEmpty() {\n    return isEmpty(this.executorsByZIndex_);\n  }\n\n  /**\n   * @param {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D} targetContext Context.\n   * @param {import('../../size.js').Size} scaledCanvasSize Scale of the context.\n   * @param {import(\"../../transform.js\").Transform} transform Transform.\n   * @param {number} viewRotation View rotation.\n   * @param {boolean} snapToPixel Snap point symbols and test to integer pixel.\n   * @param {Array<import(\"../canvas.js\").BuilderType>} [builderTypes] Ordered replay types to replay.\n   *     Default is {@link module:ol/render/replay~ALL}\n   * @param {import(\"rbush\").default<import('./Executor.js').DeclutterEntry>|null} [declutterTree] Declutter tree.\n   *     When set to null, no decluttering is done, even when the executor group has a `ZIndexContext`.\n   */\n  execute(\n    targetContext,\n    scaledCanvasSize,\n    transform,\n    viewRotation,\n    snapToPixel,\n    builderTypes,\n    declutterTree,\n  ) {\n    const zs = Object.keys(this.executorsByZIndex_).map(Number);\n    zs.sort(declutterTree ? descending : ascending);\n\n    builderTypes = builderTypes ? builderTypes : ALL;\n    const maxBuilderTypes = ALL.length;\n    for (let i = 0, ii = zs.length; i < ii; ++i) {\n      const zIndexKey = zs[i].toString();\n      const replays = this.executorsByZIndex_[zIndexKey];\n      for (let j = 0, jj = builderTypes.length; j < jj; ++j) {\n        const builderType = builderTypes[j];\n        const replay = replays[builderType];\n        if (replay !== undefined) {\n          const zIndexContext =\n            declutterTree === null ? undefined : replay.getZIndexContext();\n          const context = zIndexContext\n            ? zIndexContext.getContext()\n            : targetContext;\n          const requireClip =\n            this.maxExtent_ &&\n            builderType !== 'Image' &&\n            builderType !== 'Text';\n          if (requireClip) {\n            context.save();\n            // setup clipping so that the parts of over-simplified geometries are not\n            // visible outside the current extent when panning\n            this.clip(context, transform);\n          }\n          if (\n            !zIndexContext ||\n            builderType === 'Text' ||\n            builderType === 'Image'\n          ) {\n            replay.execute(\n              context,\n              scaledCanvasSize,\n              transform,\n              viewRotation,\n              snapToPixel,\n              declutterTree,\n            );\n          } else {\n            zIndexContext.pushFunction((context) =>\n              replay.execute(\n                context,\n                scaledCanvasSize,\n                transform,\n                viewRotation,\n                snapToPixel,\n                declutterTree,\n              ),\n            );\n          }\n          if (requireClip) {\n            context.restore();\n          }\n          if (zIndexContext) {\n            zIndexContext.offset();\n            const index = zs[i] * maxBuilderTypes + ALL.indexOf(builderType);\n            if (!this.deferredZIndexContexts_[index]) {\n              this.deferredZIndexContexts_[index] = [];\n            }\n            this.deferredZIndexContexts_[index].push(zIndexContext);\n          }\n        }\n      }\n    }\n\n    this.renderedContext_ = targetContext;\n  }\n\n  getDeferredZIndexContexts() {\n    return this.deferredZIndexContexts_;\n  }\n\n  getRenderedContext() {\n    return this.renderedContext_;\n  }\n\n  renderDeferred() {\n    const deferredZIndexContexts = this.deferredZIndexContexts_;\n    const zs = Object.keys(deferredZIndexContexts).map(Number).sort(ascending);\n    for (let i = 0, ii = zs.length; i < ii; ++i) {\n      deferredZIndexContexts[zs[i]].forEach((zIndexContext) => {\n        zIndexContext.draw(this.renderedContext_); // FIXME Pass clip to replay for temporarily enabling clip\n        zIndexContext.clear();\n      });\n      deferredZIndexContexts[zs[i]].length = 0;\n    }\n  }\n}\n\n/**\n * This cache is used to store arrays of indexes for calculated pixel circles\n * to increase performance.\n * It is a static property to allow each Replaygroup to access it.\n * @type {Object<number, Array<number>>}\n */\nconst circlePixelIndexArrayCache = {};\n\n/**\n * This methods creates an array with indexes of all pixels within a circle,\n * ordered by how close they are to the center.\n * A cache is used to increase performance.\n * @param {number} radius Radius.\n * @return {Array<number>} An array with indexes within a circle.\n */\nexport function getPixelIndexArray(radius) {\n  if (circlePixelIndexArrayCache[radius] !== undefined) {\n    return circlePixelIndexArrayCache[radius];\n  }\n\n  const size = radius * 2 + 1;\n  const maxDistanceSq = radius * radius;\n  const distances = new Array(maxDistanceSq + 1);\n  for (let i = 0; i <= radius; ++i) {\n    for (let j = 0; j <= radius; ++j) {\n      const distanceSq = i * i + j * j;\n      if (distanceSq > maxDistanceSq) {\n        break;\n      }\n      let distance = distances[distanceSq];\n      if (!distance) {\n        distance = [];\n        distances[distanceSq] = distance;\n      }\n      distance.push(((radius + i) * size + (radius + j)) * 4 + 3);\n      if (i > 0) {\n        distance.push(((radius - i) * size + (radius + j)) * 4 + 3);\n      }\n      if (j > 0) {\n        distance.push(((radius + i) * size + (radius - j)) * 4 + 3);\n        if (i > 0) {\n          distance.push(((radius - i) * size + (radius - j)) * 4 + 3);\n        }\n      }\n    }\n  }\n\n  const pixelIndex = [];\n  for (let i = 0, ii = distances.length; i < ii; ++i) {\n    if (distances[i]) {\n      pixelIndex.push(...distances[i]);\n    }\n  }\n\n  circlePixelIndexArrayCache[radius] = pixelIndex;\n  return pixelIndex;\n}\n\nexport default ExecutorGroup;\n","/**\n * @module ol/render/canvas/hitdetect\n */\n\nimport {ascending} from '../../array.js';\nimport {createCanvasContext2D} from '../../dom.js';\nimport {intersects} from '../../extent.js';\nimport {clamp} from '../../math.js';\nimport {\n  getTransformFromProjections,\n  getUserProjection,\n  toUserExtent,\n} from '../../proj.js';\nimport Icon from '../../style/Icon.js';\nimport CanvasImmediateRenderer from './Immediate.js';\n\nexport const HIT_DETECT_RESOLUTION = 0.5;\n\n/**\n * @param {import(\"../../size.js\").Size} size Canvas size in css pixels.\n * @param {Array<import(\"../../transform.js\").Transform>} transforms Transforms\n * for rendering features to all worlds of the viewport, from coordinates to css\n * pixels.\n * @param {Array<import(\"../../Feature.js\").FeatureLike>} features\n * Features to consider for hit detection.\n * @param {import(\"../../style/Style.js\").StyleFunction|undefined} styleFunction\n * Layer style function.\n * @param {import(\"../../extent.js\").Extent} extent Extent in render projection.\n * @param {number} resolution Resolution.\n * @param {number} rotation Rotation.\n * @param {number} [squaredTolerance] Squared tolerance.\n * @param {import(\"../../proj/Projection.js\").default} [projection] Render projection.\n * @return {ImageData} Hit detection image data.\n */\nexport function createHitDetectionImageData(\n  size,\n  transforms,\n  features,\n  styleFunction,\n  extent,\n  resolution,\n  rotation,\n  squaredTolerance,\n  projection,\n) {\n  const userExtent = projection ? toUserExtent(extent, projection) : extent;\n  const width = size[0] * HIT_DETECT_RESOLUTION;\n  const height = size[1] * HIT_DETECT_RESOLUTION;\n  const context = createCanvasContext2D(width, height);\n  context.imageSmoothingEnabled = false;\n  const canvas = context.canvas;\n  const renderer = new CanvasImmediateRenderer(\n    context,\n    HIT_DETECT_RESOLUTION,\n    extent,\n    null,\n    rotation,\n    squaredTolerance,\n    projection\n      ? getTransformFromProjections(getUserProjection(), projection)\n      : null,\n  );\n  const featureCount = features.length;\n  // Stretch hit detection index to use the whole available color range\n  const indexFactor = Math.floor((256 * 256 * 256 - 1) / featureCount);\n  const featuresByZIndex = {};\n  for (let i = 1; i <= featureCount; ++i) {\n    const feature = features[i - 1];\n    const featureStyleFunction = feature.getStyleFunction() || styleFunction;\n    if (!featureStyleFunction) {\n      continue;\n    }\n    let styles = featureStyleFunction(feature, resolution);\n    if (!styles) {\n      continue;\n    }\n    if (!Array.isArray(styles)) {\n      styles = [styles];\n    }\n    const index = i * indexFactor;\n    const color = index.toString(16).padStart(7, '#00000');\n    for (let j = 0, jj = styles.length; j < jj; ++j) {\n      const originalStyle = styles[j];\n      const geometry = originalStyle.getGeometryFunction()(feature);\n      if (!geometry || !intersects(userExtent, geometry.getExtent())) {\n        continue;\n      }\n      const style = originalStyle.clone();\n      const fill = style.getFill();\n      if (fill) {\n        fill.setColor(color);\n      }\n      const stroke = style.getStroke();\n      if (stroke) {\n        stroke.setColor(color);\n        stroke.setLineDash(null);\n      }\n      style.setText(undefined);\n      const image = originalStyle.getImage();\n      if (image) {\n        const imgSize = image.getImageSize();\n        if (!imgSize) {\n          continue;\n        }\n\n        const imgContext = createCanvasContext2D(\n          imgSize[0],\n          imgSize[1],\n          undefined,\n          {alpha: false},\n        );\n        const img = imgContext.canvas;\n        imgContext.fillStyle = color;\n        imgContext.fillRect(0, 0, img.width, img.height);\n        style.setImage(\n          new Icon({\n            img: img,\n            anchor: image.getAnchor(),\n            anchorXUnits: 'pixels',\n            anchorYUnits: 'pixels',\n            offset: image.getOrigin(),\n            opacity: 1,\n            size: image.getSize(),\n            scale: image.getScale(),\n            rotation: image.getRotation(),\n            rotateWithView: image.getRotateWithView(),\n          }),\n        );\n      }\n      const zIndex = style.getZIndex() || 0;\n      let byGeometryType = featuresByZIndex[zIndex];\n      if (!byGeometryType) {\n        byGeometryType = {};\n        featuresByZIndex[zIndex] = byGeometryType;\n        byGeometryType['Polygon'] = [];\n        byGeometryType['Circle'] = [];\n        byGeometryType['LineString'] = [];\n        byGeometryType['Point'] = [];\n      }\n      const type = geometry.getType();\n      if (type === 'GeometryCollection') {\n        const geometries =\n          /** @type {import(\"../../geom/GeometryCollection.js\").default} */ (\n            geometry\n          ).getGeometriesArrayRecursive();\n        for (let i = 0, ii = geometries.length; i < ii; ++i) {\n          const geometry = geometries[i];\n          byGeometryType[geometry.getType().replace('Multi', '')].push(\n            geometry,\n            style,\n          );\n        }\n      } else {\n        byGeometryType[type.replace('Multi', '')].push(geometry, style);\n      }\n    }\n  }\n\n  const zIndexKeys = Object.keys(featuresByZIndex).map(Number).sort(ascending);\n  for (let i = 0, ii = zIndexKeys.length; i < ii; ++i) {\n    const byGeometryType = featuresByZIndex[zIndexKeys[i]];\n    for (const type in byGeometryType) {\n      const geomAndStyle = byGeometryType[type];\n      for (let j = 0, jj = geomAndStyle.length; j < jj; j += 2) {\n        renderer.setStyle(geomAndStyle[j + 1]);\n        for (let k = 0, kk = transforms.length; k < kk; ++k) {\n          renderer.setTransform(transforms[k]);\n          renderer.drawGeometry(geomAndStyle[j]);\n        }\n      }\n    }\n  }\n  return context.getImageData(0, 0, canvas.width, canvas.height);\n}\n\n/**\n * @param {import(\"../../pixel.js\").Pixel} pixel Pixel coordinate on the hit\n * detection canvas in css pixels.\n * @param {Array<F>} features Features. Has to\n * match the `features` array that was passed to `createHitDetectionImageData()`.\n * @param {ImageData} imageData Hit detection image data generated by\n * `createHitDetectionImageData()`.\n * @return {Array<F>} Features.\n * @template {import(\"../../Feature.js\").FeatureLike} F\n */\nexport function hitDetect(pixel, features, imageData) {\n  /** @type {Array<F>} */\n  const resultFeatures = [];\n  if (imageData) {\n    const x = Math.floor(Math.round(pixel[0]) * HIT_DETECT_RESOLUTION);\n    const y = Math.floor(Math.round(pixel[1]) * HIT_DETECT_RESOLUTION);\n    // The pixel coordinate is clamped down to the hit-detect canvas' size to account\n    // for browsers returning coordinates slightly larger than the actual canvas size\n    // due to a non-integer pixel ratio.\n    const index =\n      (clamp(x, 0, imageData.width - 1) +\n        clamp(y, 0, imageData.height - 1) * imageData.width) *\n      4;\n    const r = imageData.data[index];\n    const g = imageData.data[index + 1];\n    const b = imageData.data[index + 2];\n    const i = b + 256 * (g + 256 * r);\n    const indexFactor = Math.floor((256 * 256 * 256 - 1) / features.length);\n    if (i && i % indexFactor === 0) {\n      resultFeatures.push(features[i / indexFactor - 1]);\n    }\n  }\n  return resultFeatures;\n}\n","/**\n * @module ol/renderer/canvas/VectorLayer\n */\nimport ViewHint from '../../ViewHint.js';\nimport {equals} from '../../array.js';\nimport {wrapX as wrapCoordinateX} from '../../coordinate.js';\nimport {createCanvasContext2D, releaseCanvas} from '../../dom.js';\nimport {\n  buffer,\n  containsExtent,\n  createEmpty,\n  getHeight,\n  getWidth,\n  intersects as intersectsExtent,\n  isEmpty,\n  wrapX as wrapExtentX,\n} from '../../extent.js';\nimport {\n  fromUserExtent,\n  getTransformFromProjections,\n  getUserProjection,\n  toUserExtent,\n  toUserResolution,\n} from '../../proj.js';\nimport RenderEventType from '../../render/EventType.js';\nimport CanvasBuilderGroup from '../../render/canvas/BuilderGroup.js';\nimport ExecutorGroup, {\n  ALL,\n  DECLUTTER,\n  NON_DECLUTTER,\n} from '../../render/canvas/ExecutorGroup.js';\nimport {\n  HIT_DETECT_RESOLUTION,\n  createHitDetectionImageData,\n  hitDetect,\n} from '../../render/canvas/hitdetect.js';\nimport {getUid} from '../../util.js';\nimport {\n  defaultOrder as defaultRenderOrder,\n  getTolerance as getRenderTolerance,\n  getSquaredTolerance as getSquaredRenderTolerance,\n  renderFeature,\n} from '../vector.js';\nimport CanvasLayerRenderer, {canvasPool} from './Layer.js';\n\n/**\n * @classdesc\n * Canvas renderer for vector layers.\n * @api\n */\nclass CanvasVectorLayerRenderer extends CanvasLayerRenderer {\n  /**\n   * @param {import(\"../../layer/BaseVector.js\").default} vectorLayer Vector layer.\n   */\n  constructor(vectorLayer) {\n    super(vectorLayer);\n\n    /** @private */\n    this.boundHandleStyleImageChange_ = this.handleStyleImageChange_.bind(this);\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.animatingOrInteracting_;\n\n    /**\n     * @private\n     * @type {ImageData|null}\n     */\n    this.hitDetectionImageData_ = null;\n\n    /**\n     * @private\n     * @type {import(\"../../extent.js\").Extent}\n     */\n    this.clipExtent_ = null;\n\n    /**\n     * Do we need to extend the rendered area on the x-axis to handle\n     * features that cross the antimeridian?\n     * @private\n     * @type {boolean}\n     */\n    this.extendX_ = false;\n\n    /**\n     * @private\n     * @type {Array<import(\"../../Feature.js\").default>}\n     */\n    this.renderedFeatures_ = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.renderedRevision_ = -1;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.renderedResolution_ = NaN;\n\n    /**\n     * @private\n     * @type {import(\"../../extent.js\").Extent}\n     */\n    this.renderedExtent_ = createEmpty();\n\n    /**\n     * @private\n     * @type {import(\"../../extent.js\").Extent}\n     */\n    this.wrappedRenderedExtent_ = createEmpty();\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.renderedRotation_;\n\n    /**\n     * @private\n     * @type {import(\"../../coordinate.js\").Coordinate}\n     */\n    this.renderedCenter_ = null;\n\n    /**\n     * @private\n     * @type {import(\"../../proj/Projection.js\").default}\n     */\n    this.renderedProjection_ = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.renderedPixelRatio_ = 1;\n\n    /**\n     * @private\n     * @type {import(\"../../render.js\").OrderFunction|null}\n     */\n    this.renderedRenderOrder_ = null;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.renderedFrameDeclutter_;\n\n    /**\n     * @private\n     * @type {import(\"../../render/canvas/ExecutorGroup.js\").default}\n     */\n    this.replayGroup_ = null;\n\n    /**\n     * A new replay group had to be created by `prepareFrame()`\n     * @type {boolean}\n     */\n    this.replayGroupChanged = true;\n\n    /**\n     * Clipping to be performed by `renderFrame()`\n     * @type {boolean}\n     */\n    this.clipping = true;\n\n    /**\n     * @private\n     * @type {CanvasRenderingContext2D|OffscreenCanvasRenderingContext2D}\n     */\n    this.targetContext_ = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.opacity_ = 1;\n  }\n\n  /**\n   * @param {ExecutorGroup} executorGroup Executor group.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @param {boolean} [declutterable] `true` to only render declutterable items,\n   *     `false` to only render non-declutterable items, `undefined` to render all.\n   */\n  renderWorlds(executorGroup, frameState, declutterable) {\n    const extent = frameState.extent;\n    const viewState = frameState.viewState;\n    const center = viewState.center;\n    const resolution = viewState.resolution;\n    const projection = viewState.projection;\n    const rotation = viewState.rotation;\n    const projectionExtent = projection.getExtent();\n    const vectorSource = this.getLayer().getSource();\n    const declutter = this.getLayer().getDeclutter();\n    const pixelRatio = frameState.pixelRatio;\n    const viewHints = frameState.viewHints;\n    const snapToPixel = !(\n      viewHints[ViewHint.ANIMATING] || viewHints[ViewHint.INTERACTING]\n    );\n    const context = this.context;\n    const width = Math.round((getWidth(extent) / resolution) * pixelRatio);\n    const height = Math.round((getHeight(extent) / resolution) * pixelRatio);\n\n    const multiWorld = vectorSource.getWrapX() && projection.canWrapX();\n    const worldWidth = multiWorld ? getWidth(projectionExtent) : null;\n    const endWorld = multiWorld\n      ? Math.ceil((extent[2] - projectionExtent[2]) / worldWidth) +\n        (this.extendX_ ? 2 : 1)\n      : 1;\n    let world = multiWorld\n      ? Math.floor((extent[0] - projectionExtent[0]) / worldWidth) -\n        (this.extendX_ ? 1 : 0)\n      : 0;\n    do {\n      let transform = this.getRenderTransform(\n        center,\n        resolution,\n        0,\n        pixelRatio,\n        width,\n        height,\n        world * worldWidth,\n      );\n      if (frameState.declutter) {\n        transform = transform.slice(0);\n      }\n      executorGroup.execute(\n        context,\n        [context.canvas.width, context.canvas.height],\n        transform,\n        rotation,\n        snapToPixel,\n        declutterable === undefined\n          ? ALL\n          : declutterable\n            ? DECLUTTER\n            : NON_DECLUTTER,\n        declutterable\n          ? declutter && frameState.declutter[declutter]\n          : undefined,\n      );\n    } while (++world < endWorld);\n  }\n\n  /**\n   * @private\n   */\n  setDrawContext_() {\n    if (this.opacity_ !== 1) {\n      this.targetContext_ = this.context;\n      this.context = createCanvasContext2D(\n        this.context.canvas.width,\n        this.context.canvas.height,\n        canvasPool,\n      );\n    }\n  }\n\n  /**\n   * @private\n   */\n  resetDrawContext_() {\n    if (this.opacity_ !== 1 && this.targetContext_) {\n      const alpha = this.targetContext_.globalAlpha;\n      this.targetContext_.globalAlpha = this.opacity_;\n      this.targetContext_.drawImage(this.context.canvas, 0, 0);\n      this.targetContext_.globalAlpha = alpha;\n      releaseCanvas(this.context);\n      canvasPool.push(this.context.canvas);\n      this.context = this.targetContext_;\n      this.targetContext_ = null;\n    }\n  }\n\n  /**\n   * Render declutter items for this layer\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   */\n  renderDeclutter(frameState) {\n    if (!this.replayGroup_ || !this.getLayer().getDeclutter()) {\n      return;\n    }\n    this.renderWorlds(this.replayGroup_, frameState, true);\n  }\n\n  /**\n   * Render deferred instructions.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @override\n   */\n  renderDeferredInternal(frameState) {\n    if (!this.replayGroup_) {\n      return;\n    }\n    if (this.clipExtent_) {\n      this.clipUnrotated(this.context, frameState, this.clipExtent_);\n    }\n    this.replayGroup_.renderDeferred();\n    if (this.clipExtent_) {\n      this.context.restore();\n      this.clipExtent_ = null;\n    }\n    this.resetDrawContext_();\n  }\n\n  /**\n   * Render the layer.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @param {HTMLElement|null} target Target that may be used to render content to.\n   * @return {HTMLElement} The rendered element.\n   * @override\n   */\n  renderFrame(frameState, target) {\n    const layerState = frameState.layerStatesArray[frameState.layerIndex];\n    this.opacity_ = layerState.opacity;\n    const viewState = frameState.viewState;\n\n    this.prepareContainer(frameState, target);\n    const context = this.context;\n\n    const replayGroup = this.replayGroup_;\n    let render = replayGroup && !replayGroup.isEmpty();\n    if (!render) {\n      const hasRenderListeners =\n        this.getLayer().hasListener(RenderEventType.PRERENDER) ||\n        this.getLayer().hasListener(RenderEventType.POSTRENDER);\n      if (!hasRenderListeners) {\n        return this.container;\n      }\n    }\n\n    this.setDrawContext_();\n\n    this.preRender(context, frameState);\n\n    const projection = viewState.projection;\n\n    // clipped rendering if layer extent is set\n    this.clipExtent_ = null;\n    let clipped = false;\n    if (render && layerState.extent && this.clipping) {\n      const layerExtent = fromUserExtent(layerState.extent, projection);\n      render = intersectsExtent(layerExtent, frameState.extent);\n      const needsClip =\n        render && !containsExtent(layerExtent, frameState.extent);\n      if (needsClip) {\n        if (frameState.declutter) {\n          // Store extent for deferred clipping\n          this.clipExtent_ = layerExtent;\n        } else {\n          // Apply clipping immediately for non-declutter rendering\n          this.clipUnrotated(context, frameState, layerExtent);\n          clipped = true;\n        }\n      }\n    }\n\n    if (render) {\n      this.renderWorlds(\n        replayGroup,\n        frameState,\n        this.getLayer().getDeclutter() ? false : undefined,\n      );\n    }\n\n    if (clipped) {\n      context.restore();\n    }\n\n    this.postRender(context, frameState);\n\n    if (this.renderedRotation_ !== viewState.rotation) {\n      this.renderedRotation_ = viewState.rotation;\n      this.hitDetectionImageData_ = null;\n    }\n    if (!frameState.declutter) {\n      this.resetDrawContext_();\n    }\n    return this.container;\n  }\n\n  /**\n   * Asynchronous layer level hit detection.\n   * @param {import(\"../../pixel.js\").Pixel} pixel Pixel.\n   * @return {Promise<Array<import(\"../../Feature.js\").default>>} Promise\n   * that resolves with an array of features.\n   * @override\n   */\n  getFeatures(pixel) {\n    return new Promise((resolve) => {\n      if (\n        this.frameState &&\n        !this.hitDetectionImageData_ &&\n        !this.animatingOrInteracting_\n      ) {\n        const size = this.frameState.size.slice();\n        const center = this.renderedCenter_;\n        const resolution = this.renderedResolution_;\n        const rotation = this.renderedRotation_;\n        const projection = this.renderedProjection_;\n        const extent = this.wrappedRenderedExtent_;\n        const layer = this.getLayer();\n        const transforms = [];\n        const width = size[0] * HIT_DETECT_RESOLUTION;\n        const height = size[1] * HIT_DETECT_RESOLUTION;\n        transforms.push(\n          this.getRenderTransform(\n            center,\n            resolution,\n            rotation,\n            HIT_DETECT_RESOLUTION,\n            width,\n            height,\n            0,\n          ).slice(),\n        );\n        const source = layer.getSource();\n        const projectionExtent = projection.getExtent();\n        if (\n          source.getWrapX() &&\n          projection.canWrapX() &&\n          !containsExtent(projectionExtent, extent)\n        ) {\n          let startX = extent[0];\n          const worldWidth = getWidth(projectionExtent);\n          let world = 0;\n          let offsetX;\n          while (startX < projectionExtent[0]) {\n            --world;\n            offsetX = worldWidth * world;\n            transforms.push(\n              this.getRenderTransform(\n                center,\n                resolution,\n                rotation,\n                HIT_DETECT_RESOLUTION,\n                width,\n                height,\n                offsetX,\n              ).slice(),\n            );\n            startX += worldWidth;\n          }\n          world = 0;\n          startX = extent[2];\n          while (startX > projectionExtent[2]) {\n            ++world;\n            offsetX = worldWidth * world;\n            transforms.push(\n              this.getRenderTransform(\n                center,\n                resolution,\n                rotation,\n                HIT_DETECT_RESOLUTION,\n                width,\n                height,\n                offsetX,\n              ).slice(),\n            );\n            startX -= worldWidth;\n          }\n        }\n        const userProjection = getUserProjection();\n        this.hitDetectionImageData_ = createHitDetectionImageData(\n          size,\n          transforms,\n          this.renderedFeatures_,\n          layer.getStyleFunction(),\n          extent,\n          resolution,\n          rotation,\n          getSquaredRenderTolerance(resolution, this.renderedPixelRatio_),\n          userProjection ? projection : null,\n        );\n      }\n      resolve(\n        hitDetect(pixel, this.renderedFeatures_, this.hitDetectionImageData_),\n      );\n    });\n  }\n\n  /**\n   * @param {import(\"../../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @param {number} hitTolerance Hit tolerance in pixels.\n   * @param {import(\"../vector.js\").FeatureCallback<T>} callback Feature callback.\n   * @param {Array<import(\"../Map.js\").HitMatch<T>>} matches The hit detected matches with tolerance.\n   * @return {T|undefined} Callback result.\n   * @template T\n   * @override\n   */\n  forEachFeatureAtCoordinate(\n    coordinate,\n    frameState,\n    hitTolerance,\n    callback,\n    matches,\n  ) {\n    if (!this.replayGroup_) {\n      return undefined;\n    }\n    const resolution = frameState.viewState.resolution;\n    const rotation = frameState.viewState.rotation;\n    const layer = this.getLayer();\n\n    /** @type {!Object<string, import(\"../Map.js\").HitMatch<T>|true>} */\n    const features = {};\n\n    /**\n     * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n     * @param {import(\"../../geom/SimpleGeometry.js\").default} geometry Geometry.\n     * @param {number} distanceSq The squared distance to the click position\n     * @return {T|undefined} Callback result.\n     */\n    const featureCallback = function (feature, geometry, distanceSq) {\n      const key = getUid(feature);\n      const match = features[key];\n      if (!match) {\n        if (distanceSq === 0) {\n          features[key] = true;\n          return callback(feature, layer, geometry);\n        }\n        matches.push(\n          (features[key] = {\n            feature: feature,\n            layer: layer,\n            geometry: geometry,\n            distanceSq: distanceSq,\n            callback: callback,\n          }),\n        );\n      } else if (match !== true && distanceSq < match.distanceSq) {\n        if (distanceSq === 0) {\n          features[key] = true;\n          matches.splice(matches.lastIndexOf(match), 1);\n          return callback(feature, layer, geometry);\n        }\n        match.geometry = geometry;\n        match.distanceSq = distanceSq;\n      }\n      return undefined;\n    };\n\n    const declutter = this.getLayer().getDeclutter();\n    return this.replayGroup_.forEachFeatureAtCoordinate(\n      coordinate,\n      resolution,\n      rotation,\n      hitTolerance,\n      featureCallback,\n      declutter\n        ? frameState.declutter?.[declutter]?.all().map((item) => item.value)\n        : null,\n    );\n  }\n\n  /**\n   * Perform action necessary to get the layer rendered after new fonts have loaded\n   * @override\n   */\n  handleFontsChanged() {\n    const layer = this.getLayer();\n    if (layer.getVisible() && this.replayGroup_) {\n      layer.changed();\n    }\n  }\n\n  /**\n   * Handle changes in image style state.\n   * @param {import(\"../../events/Event.js\").default} event Image style change event.\n   * @private\n   */\n  handleStyleImageChange_(event) {\n    this.renderIfReadyAndVisible();\n  }\n\n  /**\n   * Determine whether render should be called.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @return {boolean} Layer is ready to be rendered.\n   * @override\n   */\n  prepareFrame(frameState) {\n    const vectorLayer = this.getLayer();\n    const vectorSource = vectorLayer.getSource();\n    if (!vectorSource) {\n      return false;\n    }\n\n    const animating = frameState.viewHints[ViewHint.ANIMATING];\n    const interacting = frameState.viewHints[ViewHint.INTERACTING];\n    const updateWhileAnimating = vectorLayer.getUpdateWhileAnimating();\n    const updateWhileInteracting = vectorLayer.getUpdateWhileInteracting();\n\n    if (\n      (this.ready && !updateWhileAnimating && animating) ||\n      (!updateWhileInteracting && interacting)\n    ) {\n      this.animatingOrInteracting_ = true;\n      return true;\n    }\n    this.animatingOrInteracting_ = false;\n\n    const frameStateExtent = frameState.extent;\n    const viewState = frameState.viewState;\n    const projection = viewState.projection;\n    const resolution = viewState.resolution;\n    const pixelRatio = frameState.pixelRatio;\n    const vectorLayerRevision = vectorLayer.getRevision();\n    const vectorLayerRenderBuffer = vectorLayer.getRenderBuffer();\n    let vectorLayerRenderOrder = vectorLayer.getRenderOrder();\n\n    if (vectorLayerRenderOrder === undefined) {\n      vectorLayerRenderOrder = defaultRenderOrder;\n    }\n\n    const center = viewState.center.slice();\n    const extent = buffer(\n      frameStateExtent,\n      vectorLayerRenderBuffer * resolution,\n    );\n    const renderedExtent = extent.slice();\n    const loadExtents = [extent.slice()];\n    const projectionExtent = projection.getExtent();\n\n    const canWrapX = vectorSource.getWrapX() && projection.canWrapX();\n    this.extendX_ = false;\n    if (canWrapX) {\n      const sourceExtent = vectorSource.getExtent();\n      if (sourceExtent && !isEmpty(sourceExtent)) {\n        this.extendX_ =\n          sourceExtent[0] < projectionExtent[0] ||\n          sourceExtent[2] > projectionExtent[2];\n      }\n    }\n\n    if (\n      canWrapX &&\n      (!containsExtent(projectionExtent, frameState.extent) || this.extendX_)\n    ) {\n      // For the replay group, we need an extent that intersects the real world\n      // (-180° to +180°). To support geometries in a coordinate range from -540°\n      // to +540°, we add at least 1 world width on each side of the projection\n      // extent. If the viewport is wider than the world, we need to add half of\n      // the viewport width to make sure we cover the whole viewport.\n      const worldWidth = getWidth(projectionExtent);\n      const gutter = Math.max(getWidth(extent) / 2, worldWidth);\n      let projMinX = projectionExtent[0];\n      let projMaxX = projectionExtent[2];\n      if (this.extendX_) {\n        projMinX -= worldWidth;\n        projMaxX += worldWidth;\n      }\n      extent[0] = projMinX - gutter;\n      extent[2] = projMaxX + gutter;\n      wrapCoordinateX(center, projection);\n      const loadExtent = wrapExtentX(loadExtents[0], projection);\n      // If the extent crosses the date line, we load data for both edges of the worlds\n      if (\n        loadExtent[0] < projectionExtent[0] &&\n        loadExtent[2] < projectionExtent[2]\n      ) {\n        loadExtents.push([\n          loadExtent[0] + worldWidth,\n          loadExtent[1],\n          loadExtent[2] + worldWidth,\n          loadExtent[3],\n        ]);\n      } else if (\n        loadExtent[0] > projectionExtent[0] &&\n        loadExtent[2] > projectionExtent[2]\n      ) {\n        loadExtents.push([\n          loadExtent[0] - worldWidth,\n          loadExtent[1],\n          loadExtent[2] - worldWidth,\n          loadExtent[3],\n        ]);\n      }\n    }\n\n    if (\n      this.ready &&\n      this.renderedResolution_ == resolution &&\n      this.renderedPixelRatio_ === pixelRatio &&\n      this.renderedRevision_ == vectorLayerRevision &&\n      this.renderedRenderOrder_ == vectorLayerRenderOrder &&\n      this.renderedFrameDeclutter_ === !!frameState.declutter &&\n      containsExtent(this.wrappedRenderedExtent_, extent)\n    ) {\n      if (!equals(this.renderedExtent_, renderedExtent)) {\n        this.hitDetectionImageData_ = null;\n        this.renderedExtent_ = renderedExtent;\n      }\n      this.renderedCenter_ = center;\n      this.replayGroupChanged = false;\n      return true;\n    }\n\n    this.replayGroup_ = null;\n\n    const replayGroup = new CanvasBuilderGroup(\n      getRenderTolerance(resolution, pixelRatio),\n      extent,\n      resolution,\n      pixelRatio,\n    );\n\n    const userProjection = getUserProjection();\n    let userTransform;\n    if (userProjection) {\n      for (let i = 0, ii = loadExtents.length; i < ii; ++i) {\n        const extent = loadExtents[i];\n        const userExtent = toUserExtent(extent, projection);\n        vectorSource.loadFeatures(\n          userExtent,\n          toUserResolution(resolution, projection),\n          userProjection,\n        );\n      }\n      userTransform = getTransformFromProjections(userProjection, projection);\n    } else {\n      for (let i = 0, ii = loadExtents.length; i < ii; ++i) {\n        vectorSource.loadFeatures(loadExtents[i], resolution, projection);\n      }\n    }\n\n    const squaredTolerance = getSquaredRenderTolerance(resolution, pixelRatio);\n    let ready = true;\n    const render =\n      /**\n       * @param {import(\"../../Feature.js\").default} feature Feature.\n       * @param {number} index Index.\n       */\n      (feature, index) => {\n        let styles;\n        const styleFunction =\n          feature.getStyleFunction() || vectorLayer.getStyleFunction();\n        if (styleFunction) {\n          styles = styleFunction(feature, resolution);\n        }\n        if (styles) {\n          const dirty = this.renderFeature(\n            feature,\n            squaredTolerance,\n            styles,\n            replayGroup,\n            userTransform,\n            this.getLayer().getDeclutter(),\n            index,\n          );\n          ready = ready && !dirty;\n        }\n      };\n\n    const userExtent = toUserExtent(extent, projection);\n    /** @type {Array<import(\"../../Feature.js\").default>} */\n    const features = vectorSource.getFeaturesInExtent(userExtent);\n    if (vectorLayerRenderOrder) {\n      features.sort(vectorLayerRenderOrder);\n    }\n    for (let i = 0, ii = features.length; i < ii; ++i) {\n      render(features[i], i);\n    }\n    this.renderedFeatures_ = features;\n    this.ready = ready;\n\n    const replayGroupInstructions = replayGroup.finish();\n    const executorGroup = new ExecutorGroup(\n      extent,\n      resolution,\n      pixelRatio,\n      vectorSource.getOverlaps(),\n      replayGroupInstructions,\n      vectorLayer.getRenderBuffer(),\n      !!frameState.declutter,\n    );\n\n    this.renderedResolution_ = resolution;\n    this.renderedRevision_ = vectorLayerRevision;\n    this.renderedRenderOrder_ = vectorLayerRenderOrder;\n    this.renderedFrameDeclutter_ = !!frameState.declutter;\n    this.renderedExtent_ = renderedExtent;\n    this.wrappedRenderedExtent_ = extent;\n    this.renderedCenter_ = center;\n    this.renderedProjection_ = projection;\n    this.renderedPixelRatio_ = pixelRatio;\n    this.replayGroup_ = executorGroup;\n    this.hitDetectionImageData_ = null;\n\n    this.replayGroupChanged = true;\n    return true;\n  }\n\n  /**\n   * @param {import(\"../../Feature.js\").default} feature Feature.\n   * @param {number} squaredTolerance Squared render tolerance.\n   * @param {import(\"../../style/Style.js\").default|Array<import(\"../../style/Style.js\").default>} styles The style or array of styles.\n   * @param {import(\"../../render/canvas/BuilderGroup.js\").default} builderGroup Builder group.\n   * @param {import(\"../../proj.js\").TransformFunction} [transform] Transform from user to view projection.\n   * @param {boolean} [declutter] Enable decluttering.\n   * @param {number} [index] Render order index.\n   * @return {boolean} `true` if an image is loading.\n   */\n  renderFeature(\n    feature,\n    squaredTolerance,\n    styles,\n    builderGroup,\n    transform,\n    declutter,\n    index,\n  ) {\n    if (!styles) {\n      return false;\n    }\n    let loading = false;\n    if (Array.isArray(styles)) {\n      for (let i = 0, ii = styles.length; i < ii; ++i) {\n        loading =\n          renderFeature(\n            builderGroup,\n            feature,\n            styles[i],\n            squaredTolerance,\n            this.boundHandleStyleImageChange_,\n            transform,\n            declutter,\n            index,\n          ) || loading;\n      }\n    } else {\n      loading = renderFeature(\n        builderGroup,\n        feature,\n        styles,\n        squaredTolerance,\n        this.boundHandleStyleImageChange_,\n        transform,\n        declutter,\n        index,\n      );\n    }\n    return loading;\n  }\n}\n\nexport default CanvasVectorLayerRenderer;\n","/**\n * @module ol/renderer/canvas/VectorImageLayer\n */\nimport RBush from 'rbush';\nimport ImageCanvas from '../../ImageCanvas.js';\nimport ImageState from '../../ImageState.js';\nimport ViewHint from '../../ViewHint.js';\nimport EventType from '../../events/EventType.js';\nimport {getHeight, getWidth, isEmpty, scaleFromCenter} from '../../extent.js';\nimport {fromResolutionLike} from '../../resolution.js';\nimport {apply, compose, create} from '../../transform.js';\nimport CanvasImageLayerRenderer from './ImageLayer.js';\nimport CanvasVectorLayerRenderer from './VectorLayer.js';\n\n/**\n * @classdesc\n * Canvas renderer for image layers.\n * @api\n */\nclass CanvasVectorImageLayerRenderer extends CanvasImageLayerRenderer {\n  /**\n   * @param {import(\"../../layer/VectorImage.js\").default} layer Vector image layer.\n   */\n  constructor(layer) {\n    super(layer);\n\n    /**\n     * @private\n     * @type {import(\"./VectorLayer.js\").default}\n     */\n    this.vectorRenderer_ = new CanvasVectorLayerRenderer(layer);\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.layerImageRatio_ = layer.getImageRatio();\n\n    /**\n     * @private\n     * @type {import(\"../../transform.js\").Transform}\n     */\n    this.coordinateToVectorPixelTransform_ = create();\n\n    /**\n     * @private\n     * @type {import(\"../../transform.js\").Transform}\n     */\n    this.renderedPixelToCoordinateTransform_ = null;\n  }\n\n  /**\n   * Clean up.\n   * @override\n   */\n  disposeInternal() {\n    this.vectorRenderer_.dispose();\n    super.disposeInternal();\n  }\n\n  /**\n   * Asynchronous layer level hit detection.\n   * @param {import(\"../../pixel.js\").Pixel} pixel Pixel.\n   * @return {Promise<Array<import(\"../../Feature.js\").default>>} Promise that resolves with an array of features.\n   * @override\n   */\n  getFeatures(pixel) {\n    if (!this.vectorRenderer_) {\n      return Promise.resolve([]);\n    }\n    const vectorPixel = apply(\n      this.coordinateToVectorPixelTransform_,\n      apply(this.renderedPixelToCoordinateTransform_, pixel.slice()),\n    );\n    return this.vectorRenderer_.getFeatures(vectorPixel);\n  }\n\n  /**\n   * Perform action necessary to get the layer rendered after new fonts have loaded\n   * @override\n   */\n  handleFontsChanged() {\n    this.vectorRenderer_.handleFontsChanged();\n  }\n\n  /**\n   * Determine whether render should be called.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @return {boolean} Layer is ready to be rendered.\n   * @override\n   */\n  prepareFrame(frameState) {\n    const pixelRatio = frameState.pixelRatio;\n    const viewState = frameState.viewState;\n    const viewResolution = viewState.resolution;\n\n    const hints = frameState.viewHints;\n    const vectorRenderer = this.vectorRenderer_;\n    let renderedExtent = frameState.extent;\n    if (this.layerImageRatio_ !== 1) {\n      renderedExtent = renderedExtent.slice(0);\n      scaleFromCenter(renderedExtent, this.layerImageRatio_);\n    }\n    const width = getWidth(renderedExtent) / viewResolution;\n    const height = getHeight(renderedExtent) / viewResolution;\n\n    if (\n      !hints[ViewHint.ANIMATING] &&\n      !hints[ViewHint.INTERACTING] &&\n      !isEmpty(renderedExtent)\n    ) {\n      vectorRenderer.useContainer(null, null);\n      const context = vectorRenderer.context;\n      const layerState = frameState.layerStatesArray[frameState.layerIndex];\n      const imageLayerState = Object.assign({}, layerState, {opacity: 1});\n      const imageFrameState = /** @type {import(\"../../Map.js\").FrameState} */ (\n        Object.assign({}, frameState, {\n          extent: renderedExtent,\n          size: [width, height],\n          viewState: /** @type {import(\"../../View.js\").State} */ (\n            Object.assign({}, frameState.viewState, {\n              rotation: 0,\n            })\n          ),\n          layerStatesArray: [imageLayerState],\n          layerIndex: 0,\n          declutter: null,\n        })\n      );\n      const declutter = this.getLayer().getDeclutter();\n      if (declutter) {\n        imageFrameState.declutter = {\n          [declutter]: new RBush(9),\n        };\n      }\n      const image = new ImageCanvas(\n        renderedExtent,\n        viewResolution,\n        pixelRatio,\n        context.canvas,\n        function (callback) {\n          if (\n            vectorRenderer.prepareFrame(imageFrameState) &&\n            vectorRenderer.replayGroupChanged\n          ) {\n            vectorRenderer.clipping = false;\n            vectorRenderer.renderFrame(imageFrameState, null);\n            vectorRenderer.renderDeclutter(imageFrameState);\n            vectorRenderer.renderDeferred(imageFrameState);\n            callback();\n          }\n        },\n      );\n\n      image.addEventListener(EventType.CHANGE, () => {\n        if (image.getState() !== ImageState.LOADED) {\n          return;\n        }\n        this.image = image;\n        const imagePixelRatio = image.getPixelRatio();\n        const renderedResolution =\n          (fromResolutionLike(image.getResolution()) * pixelRatio) /\n          imagePixelRatio;\n        this.renderedResolution = renderedResolution;\n        this.coordinateToVectorPixelTransform_ = compose(\n          this.coordinateToVectorPixelTransform_,\n          width / 2,\n          height / 2,\n          1 / renderedResolution,\n          -1 / renderedResolution,\n          0,\n          -viewState.center[0],\n          -viewState.center[1],\n        );\n      });\n      image.load();\n    }\n\n    if (this.image) {\n      this.renderedPixelToCoordinateTransform_ =\n        frameState.pixelToCoordinateTransform.slice();\n    }\n\n    return !this.getLayer().getSource()?.loading && !!this.image;\n  }\n\n  /**\n   * @override\n   */\n  preRender() {}\n\n  /**\n   * @override\n   */\n  postRender() {}\n\n  /**\n   */\n  renderDeclutter() {}\n\n  /**\n   * @param {import(\"../../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @param {number} hitTolerance Hit tolerance in pixels.\n   * @param {import(\"../vector.js\").FeatureCallback<T>} callback Feature callback.\n   * @param {Array<import(\"../Map.js\").HitMatch<T>>} matches The hit detected matches with tolerance.\n   * @return {T|undefined} Callback result.\n   * @template T\n   * @override\n   */\n  forEachFeatureAtCoordinate(\n    coordinate,\n    frameState,\n    hitTolerance,\n    callback,\n    matches,\n  ) {\n    if (this.vectorRenderer_) {\n      return this.vectorRenderer_.forEachFeatureAtCoordinate(\n        coordinate,\n        frameState,\n        hitTolerance,\n        callback,\n        matches,\n      );\n    }\n    return super.forEachFeatureAtCoordinate(\n      coordinate,\n      frameState,\n      hitTolerance,\n      callback,\n      matches,\n    );\n  }\n}\n\nexport default CanvasVectorImageLayerRenderer;\n","/**\n * @module ol/geom/flat/geodesic\n */\nimport {squaredSegmentDistance, toDegrees, toRadians} from '../../math.js';\nimport {get as getProjection, getTransform} from '../../proj.js';\n\n/**\n * @param {function(number): import(\"../../coordinate.js\").Coordinate} interpolate Interpolate function.\n * @param {import(\"../../proj.js\").TransformFunction} transform Transform from longitude/latitude to\n *     projected coordinates.\n * @param {number} squaredTolerance Squared tolerance.\n * @return {Array<number>} Flat coordinates.\n */\nfunction line(interpolate, transform, squaredTolerance) {\n  // FIXME reduce garbage generation\n  // FIXME optimize stack operations\n\n  /** @type {Array<number>} */\n  const flatCoordinates = [];\n\n  let geoA = interpolate(0);\n  let geoB = interpolate(1);\n\n  let a = transform(geoA);\n  let b = transform(geoB);\n\n  /** @type {Array<import(\"../../coordinate.js\").Coordinate>} */\n  const geoStack = [geoB, geoA];\n  /** @type {Array<import(\"../../coordinate.js\").Coordinate>} */\n  const stack = [b, a];\n  /** @type {Array<number>} */\n  const fractionStack = [1, 0];\n\n  /** @type {!Object<string, boolean>} */\n  const fractions = {};\n\n  let maxIterations = 1e5;\n  let geoM, m, fracA, fracB, fracM, key;\n\n  while (--maxIterations > 0 && fractionStack.length > 0) {\n    // Pop the a coordinate off the stack\n    fracA = fractionStack.pop();\n    geoA = geoStack.pop();\n    a = stack.pop();\n    // Add the a coordinate if it has not been added yet\n    key = fracA.toString();\n    if (!(key in fractions)) {\n      flatCoordinates.push(a[0], a[1]);\n      fractions[key] = true;\n    }\n    // Pop the b coordinate off the stack\n    fracB = fractionStack.pop();\n    geoB = geoStack.pop();\n    b = stack.pop();\n    // Find the m point between the a and b coordinates\n    fracM = (fracA + fracB) / 2;\n    geoM = interpolate(fracM);\n    m = transform(geoM);\n    if (\n      squaredSegmentDistance(m[0], m[1], a[0], a[1], b[0], b[1]) <\n      squaredTolerance\n    ) {\n      // If the m point is sufficiently close to the straight line, then we\n      // discard it.  Just use the b coordinate and move on to the next line\n      // segment.\n      flatCoordinates.push(b[0], b[1]);\n      key = fracB.toString();\n      fractions[key] = true;\n    } else {\n      // Otherwise, we need to subdivide the current line segment.  Split it\n      // into two and push the two line segments onto the stack.\n      fractionStack.push(fracB, fracM, fracM, fracA);\n      stack.push(b, m, m, a);\n      geoStack.push(geoB, geoM, geoM, geoA);\n    }\n  }\n\n  return flatCoordinates;\n}\n\n/**\n * Generate a great-circle arcs between two lat/lon points.\n * @param {number} lon1 Longitude 1 in degrees.\n * @param {number} lat1 Latitude 1 in degrees.\n * @param {number} lon2 Longitude 2 in degrees.\n * @param {number} lat2 Latitude 2 in degrees.\n * @param {import(\"../../proj/Projection.js\").default} projection Projection.\n * @param {number} squaredTolerance Squared tolerance.\n * @return {Array<number>} Flat coordinates.\n */\nexport function greatCircleArc(\n  lon1,\n  lat1,\n  lon2,\n  lat2,\n  projection,\n  squaredTolerance,\n) {\n  const geoProjection = getProjection('EPSG:4326');\n\n  const cosLat1 = Math.cos(toRadians(lat1));\n  const sinLat1 = Math.sin(toRadians(lat1));\n  const cosLat2 = Math.cos(toRadians(lat2));\n  const sinLat2 = Math.sin(toRadians(lat2));\n  const cosDeltaLon = Math.cos(toRadians(lon2 - lon1));\n  const sinDeltaLon = Math.sin(toRadians(lon2 - lon1));\n  const d = sinLat1 * sinLat2 + cosLat1 * cosLat2 * cosDeltaLon;\n\n  return line(\n    /**\n     * @param {number} frac Fraction.\n     * @return {import(\"../../coordinate.js\").Coordinate} Coordinate.\n     */\n    function (frac) {\n      if (1 <= d) {\n        return [lon2, lat2];\n      }\n      const D = frac * Math.acos(d);\n      const cosD = Math.cos(D);\n      const sinD = Math.sin(D);\n      const y = sinDeltaLon * cosLat2;\n      const x = cosLat1 * sinLat2 - sinLat1 * cosLat2 * cosDeltaLon;\n      const theta = Math.atan2(y, x);\n      const lat = Math.asin(sinLat1 * cosD + cosLat1 * sinD * Math.cos(theta));\n      const lon =\n        toRadians(lon1) +\n        Math.atan2(\n          Math.sin(theta) * sinD * cosLat1,\n          cosD - sinLat1 * Math.sin(lat),\n        );\n      return [toDegrees(lon), toDegrees(lat)];\n    },\n    getTransform(geoProjection, projection),\n    squaredTolerance,\n  );\n}\n\n/**\n * Generate a meridian (line at constant longitude).\n * @param {number} lon Longitude.\n * @param {number} lat1 Latitude 1.\n * @param {number} lat2 Latitude 2.\n * @param {import(\"../../proj/Projection.js\").default} projection Projection.\n * @param {number} squaredTolerance Squared tolerance.\n * @return {Array<number>} Flat coordinates.\n */\nexport function meridian(lon, lat1, lat2, projection, squaredTolerance) {\n  const epsg4326Projection = getProjection('EPSG:4326');\n  return line(\n    /**\n     * @param {number} frac Fraction.\n     * @return {import(\"../../coordinate.js\").Coordinate} Coordinate.\n     */\n    function (frac) {\n      return [lon, lat1 + (lat2 - lat1) * frac];\n    },\n    getTransform(epsg4326Projection, projection),\n    squaredTolerance,\n  );\n}\n\n/**\n * Generate a parallel (line at constant latitude).\n * @param {number} lat Latitude.\n * @param {number} lon1 Longitude 1.\n * @param {number} lon2 Longitude 2.\n * @param {import(\"../../proj/Projection.js\").default} projection Projection.\n * @param {number} squaredTolerance Squared tolerance.\n * @return {Array<number>} Flat coordinates.\n */\nexport function parallel(lat, lon1, lon2, projection, squaredTolerance) {\n  const epsg4326Projection = getProjection('EPSG:4326');\n  return line(\n    /**\n     * @param {number} frac Fraction.\n     * @return {import(\"../../coordinate.js\").Coordinate} Coordinate.\n     */\n    function (frac) {\n      return [lon1 + (lon2 - lon1) * frac, lat];\n    },\n    getTransform(epsg4326Projection, projection),\n    squaredTolerance,\n  );\n}\n","/**\n * @module ol/layer/Vector\n */\nimport CanvasVectorLayerRenderer from '../renderer/canvas/VectorLayer.js';\nimport BaseVectorLayer from './BaseVector.js';\n\n/**\n * @template {import(\"../source/Vector.js\").default<FeatureType>} [VectorSourceType=import(\"../source/Vector.js\").default<*>]\n * @template {import('../Feature.js').FeatureLike} [FeatureType=import(\"./BaseVector.js\").ExtractedFeatureType<VectorSourceType>]\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} [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 {import(\"../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 viewport extent used by the\n * renderer when getting features from the vector source for the rendering or hit-detection.\n * Recommended value: the size of the largest symbol, line width or label.\n * @property {VectorSourceType} [source] Source.\n * @property {import(\"../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()]{@link import(\"../Map.js\").default#addLayer}.\n * @property {boolean|string|number} [declutter=false] Declutter images and text. Any truthy value will enable\n * decluttering. Within a layer, a feature rendered before another has higher priority. All layers with the\n * same `declutter` value will be decluttered together. The priority is determined by the drawing order of the\n * layers with the same `declutter` value. Higher in the layer stack means higher priority. To declutter distinct\n * layers or groups of layers separately, use different truthy values for `declutter`.\n * @property {import(\"../style/Style.js\").StyleLike|import(\"../style/flat.js\").FlatStyleLike|null} [style] Layer style. When set to `null`, only\n * features that have their own style will be rendered. See {@link module:ol/style/Style~Style} for the default style\n * which will be used if this is not set.\n * @property {import(\"./Base.js\").BackgroundColor} [background] Background color for the layer. If not specified, no background\n * will be rendered.\n * @property {boolean} [updateWhileAnimating=false] When set to `true`, feature batches will\n * be recreated during animations. This means that no vectors will be shown clipped, but the\n * setting will have a performance impact for large amounts of vector data. When set to `false`,\n * batches will be recreated when no animation is active.\n * @property {boolean} [updateWhileInteracting=false] When set to `true`, feature batches will\n * be recreated during interactions. See also `updateWhileAnimating`.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n\n/**\n * @classdesc\n * Vector data is rendered client-side, as vectors. This layer type provides most accurate rendering\n * even during animations. Points and labels stay upright on rotated views. For very large\n * amounts of vector data, performance may suffer during pan and zoom animations. In this case,\n * try {@link module:ol/layer/VectorImage~VectorImageLayer}.\n *\n * Note that any property set in the options is set as a {@link module:ol/Object~BaseObject}\n * property on the layer object; for example, setting `title: 'My Title'` in the\n * options means that `title` is observable, and has get/set accessors.\n *\n * @template {import(\"../source/Vector.js\").default<FeatureType>} [VectorSourceType=import(\"../source/Vector.js\").default<*>]\n * @template {import('../Feature.js').FeatureLike} [FeatureType=import(\"./BaseVector.js\").ExtractedFeatureType<VectorSourceType>]\n * @extends {BaseVectorLayer<FeatureType, VectorSourceType, CanvasVectorLayerRenderer>}\n * @api\n */\nclass VectorLayer extends BaseVectorLayer {\n  /**\n   * @param {Options<VectorSourceType, FeatureType>} [options] Options.\n   */\n  constructor(options) {\n    super(options);\n  }\n\n  /**\n   * @override\n   */\n  createRenderer() {\n    return new CanvasVectorLayerRenderer(this);\n  }\n}\n\nexport default VectorLayer;\n","/**\n * @module ol/layer/Graticule\n */\nimport Collection from '../Collection.js';\nimport Feature from '../Feature.js';\nimport {degreesToStringHDMS} from '../coordinate.js';\nimport {\n  applyTransform,\n  approximatelyEquals,\n  containsCoordinate,\n  containsExtent,\n  equals,\n  getCenter,\n  getIntersection,\n  getWidth,\n  intersects,\n  isEmpty,\n  wrapX as wrapExtentX,\n} from '../extent.js';\nimport LineString from '../geom/LineString.js';\nimport Point from '../geom/Point.js';\nimport {meridian, parallel} from '../geom/flat/geodesic.js';\nimport {clamp} from '../math.js';\nimport {\n  equivalent as equivalentProjection,\n  get as getProjection,\n  getTransform,\n} from '../proj.js';\nimport {getVectorContext} from '../render.js';\nimport EventType from '../render/EventType.js';\nimport VectorSource from '../source/Vector.js';\nimport Fill from '../style/Fill.js';\nimport Stroke from '../style/Stroke.js';\nimport Style from '../style/Style.js';\nimport Text from '../style/Text.js';\nimport VectorLayer from './Vector.js';\n\n/**\n * @type {Stroke}\n * @private\n * @const\n */\nconst DEFAULT_STROKE_STYLE = new Stroke({\n  color: 'rgba(0,0,0,0.2)',\n});\n\n/**\n * @type {Array<number>}\n * @private\n */\nconst INTERVALS = [\n  90,\n  45,\n  30,\n  20,\n  10,\n  5,\n  2,\n  1,\n  30 / 60,\n  20 / 60,\n  10 / 60,\n  5 / 60,\n  2 / 60,\n  1 / 60,\n  30 / 3600,\n  20 / 3600,\n  10 / 3600,\n  5 / 3600,\n  2 / 3600,\n  1 / 3600,\n];\n\n/**\n * @typedef {Object} GraticuleLabelDataType\n * @property {Point} geom Geometry.\n * @property {string} text Text.\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} [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 {number} [maxLines=100] The maximum number of meridians and\n * parallels from the center of the map. The default value of 100 means that at\n * most 200 meridians and 200 parallels will be displayed. The default value is\n * appropriate for conformal projections like Spherical Mercator. If you\n * increase the value, more lines will be drawn and the drawing performance will\n * decrease.\n * @property {Stroke} [strokeStyle] The\n * stroke style to use for drawing the graticule. If not provided, the following stroke will be used:\n * ```js\n * new Stroke({\n *   color: 'rgba(0, 0, 0, 0.2)' // a not fully opaque black\n * });\n * ```\n * @property {number} [targetSize=100] The target size of the graticule cells,\n * in pixels.\n * @property {boolean} [showLabels=false] Render a label with the respective\n * latitude/longitude for each graticule line.\n * @property {function(number):string} [lonLabelFormatter] Label formatter for\n * longitudes. This function is called with the longitude as argument, and\n * should return a formatted string representing the longitude. By default,\n * labels are formatted as degrees, minutes, seconds and hemisphere.\n * @property {function(number):string} [latLabelFormatter] Label formatter for\n * latitudes. This function is called with the latitude as argument, and\n * should return a formatted string representing the latitude. By default,\n * labels are formatted as degrees, minutes, seconds and hemisphere.\n * @property {number} [lonLabelPosition=0] Longitude label position in fractions\n * (0..1) of view extent. 0 means at the bottom of the viewport, 1 means at the\n * top.\n * @property {number} [latLabelPosition=1] Latitude label position in fractions\n * (0..1) of view extent. 0 means at the left of the viewport, 1 means at the\n * right.\n * @property {Text} [lonLabelStyle] Longitude label text\n * style. If not provided, the following style will be used:\n * ```js\n * new Text({\n *   font: '12px Calibri,sans-serif',\n *   textBaseline: 'bottom',\n *   fill: new Fill({\n *     color: 'rgba(0,0,0,1)'\n *   }),\n *   stroke: new Stroke({\n *     color: 'rgba(255,255,255,1)',\n *     width: 3\n *   })\n * });\n * ```\n * Note that the default's `textBaseline` configuration will not work well for\n * `lonLabelPosition` configurations that position labels close to the top of\n * the viewport.\n * @property {Text} [latLabelStyle] Latitude label text style.\n * If not provided, the following style will be used:\n * ```js\n * new Text({\n *   font: '12px Calibri,sans-serif',\n *   textAlign: 'end',\n *   fill: new Fill({\n *     color: 'rgba(0,0,0,1)'\n *   }),\n *   stroke: Stroke({\n *     color: 'rgba(255,255,255,1)',\n *     width: 3\n *   })\n * });\n * ```\n * Note that the default's `textAlign` configuration will not work well for\n * `latLabelPosition` configurations that position labels close to the left of\n * the viewport.\n * @property {Array<number>} [intervals=[90, 45, 30, 20, 10, 5, 2, 1, 30/60, 20/60, 10/60, 5/60, 2/60, 1/60, 30/3600, 20/3600, 10/3600, 5/3600, 2/3600, 1/3600]]\n * Intervals (in degrees) for the graticule. Example to limit graticules to 30 and 10 degrees intervals:\n * ```js\n * [30, 10]\n * ```\n * @property {boolean} [wrapX=true] Whether to repeat the graticule horizontally.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n\n/**\n * @classdesc\n * Layer that renders a grid for a coordinate system (currently only EPSG:4326 is supported).\n * Note that the view projection must define both extent and worldExtent.\n *\n * @fires import(\"../render/Event.js\").RenderEvent#prerender\n * @fires import(\"../render/Event.js\").RenderEvent#postrender\n * @extends {VectorLayer<VectorSource<Feature>>}\n * @api\n */\nclass Graticule extends VectorLayer {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    const baseOptions = Object.assign(\n      {\n        updateWhileAnimating: true,\n        updateWhileInteracting: true,\n        renderBuffer: 0,\n      },\n      options,\n    );\n\n    delete baseOptions.maxLines;\n    delete baseOptions.strokeStyle;\n    delete baseOptions.targetSize;\n    delete baseOptions.showLabels;\n    delete baseOptions.lonLabelFormatter;\n    delete baseOptions.latLabelFormatter;\n    delete baseOptions.lonLabelPosition;\n    delete baseOptions.latLabelPosition;\n    delete baseOptions.lonLabelStyle;\n    delete baseOptions.latLabelStyle;\n    delete baseOptions.intervals;\n    super(baseOptions);\n\n    /**\n     * @type {import(\"../proj/Projection.js\").default}\n     * @private\n     */\n    this.projection_ = null;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.maxLat_ = Infinity;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.maxLon_ = Infinity;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.minLat_ = -Infinity;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.minLon_ = -Infinity;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.maxX_ = Infinity;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.maxY_ = Infinity;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.minX_ = -Infinity;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.minY_ = -Infinity;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.targetSize_ =\n      options.targetSize !== undefined ? options.targetSize : 100;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.maxLines_ = options.maxLines !== undefined ? options.maxLines : 100;\n\n    /**\n     * @type {Array<LineString>}\n     * @private\n     */\n    this.meridians_ = [];\n\n    /**\n     * @type {Array<LineString>}\n     * @private\n     */\n    this.parallels_ = [];\n\n    /**\n     * @type {Stroke}\n     * @private\n     */\n    this.strokeStyle_ =\n      options.strokeStyle !== undefined\n        ? options.strokeStyle\n        : DEFAULT_STROKE_STYLE;\n\n    /**\n     * @type {import(\"../proj.js\").TransformFunction|undefined}\n     * @private\n     */\n    this.fromLonLatTransform_ = undefined;\n\n    /**\n     * @type {import(\"../proj.js\").TransformFunction|undefined}\n     * @private\n     */\n    this.toLonLatTransform_ = undefined;\n\n    /**\n     * @type {import(\"../coordinate.js\").Coordinate}\n     * @private\n     */\n    this.projectionCenterLonLat_ = null;\n\n    /**\n     * @type {import(\"../coordinate.js\").Coordinate}\n     * @private\n     */\n    this.bottomLeft_ = null;\n\n    /**\n     * @type {import(\"../coordinate.js\").Coordinate}\n     * @private\n     */\n    this.bottomRight_ = null;\n\n    /**\n     * @type {import(\"../coordinate.js\").Coordinate}\n     * @private\n     */\n    this.topLeft_ = null;\n\n    /**\n     * @type {import(\"../coordinate.js\").Coordinate}\n     * @private\n     */\n    this.topRight_ = null;\n\n    /**\n     * @type {Array<GraticuleLabelDataType>}\n     * @private\n     */\n    this.meridiansLabels_ = null;\n\n    /**\n     * @type {Array<GraticuleLabelDataType>}\n     * @private\n     */\n    this.parallelsLabels_ = null;\n\n    if (options.showLabels) {\n      /**\n       * @type {null|function(number):string}\n       * @private\n       */\n      this.lonLabelFormatter_ =\n        options.lonLabelFormatter == undefined\n          ? degreesToStringHDMS.bind(this, 'EW')\n          : options.lonLabelFormatter;\n\n      /**\n       * @type {function(number):string}\n       * @private\n       */\n      this.latLabelFormatter_ =\n        options.latLabelFormatter == undefined\n          ? degreesToStringHDMS.bind(this, 'NS')\n          : options.latLabelFormatter;\n\n      /**\n       * Longitude label position in fractions (0..1) of view extent. 0 means\n       * bottom, 1 means top.\n       * @type {number}\n       * @private\n       */\n      this.lonLabelPosition_ =\n        options.lonLabelPosition == undefined ? 0 : options.lonLabelPosition;\n\n      /**\n       * Latitude Label position in fractions (0..1) of view extent. 0 means left, 1\n       * means right.\n       * @type {number}\n       * @private\n       */\n      this.latLabelPosition_ =\n        options.latLabelPosition == undefined ? 1 : options.latLabelPosition;\n\n      /**\n       * @type {Style}\n       * @private\n       */\n      this.lonLabelStyleBase_ = new Style({\n        text:\n          options.lonLabelStyle !== undefined\n            ? options.lonLabelStyle.clone()\n            : new Text({\n                font: '12px Calibri,sans-serif',\n                textBaseline: 'bottom',\n                fill: new Fill({\n                  color: 'rgba(0,0,0,1)',\n                }),\n                stroke: new Stroke({\n                  color: 'rgba(255,255,255,1)',\n                  width: 3,\n                }),\n              }),\n      });\n\n      /**\n       * @private\n       * @param {import(\"../Feature.js\").default} feature Feature\n       * @return {Style} style\n       */\n      this.lonLabelStyle_ = (feature) => {\n        const label = feature.get('graticule_label');\n        this.lonLabelStyleBase_.getText().setText(label);\n        return this.lonLabelStyleBase_;\n      };\n\n      /**\n       * @type {Style}\n       * @private\n       */\n      this.latLabelStyleBase_ = new Style({\n        text:\n          options.latLabelStyle !== undefined\n            ? options.latLabelStyle.clone()\n            : new Text({\n                font: '12px Calibri,sans-serif',\n                textAlign: 'right',\n                fill: new Fill({\n                  color: 'rgba(0,0,0,1)',\n                }),\n                stroke: new Stroke({\n                  color: 'rgba(255,255,255,1)',\n                  width: 3,\n                }),\n              }),\n      });\n\n      /**\n       * @private\n       * @param {import(\"../Feature.js\").default} feature Feature\n       * @return {Style} style\n       */\n      this.latLabelStyle_ = (feature) => {\n        const label = feature.get('graticule_label');\n        this.latLabelStyleBase_.getText().setText(label);\n        return this.latLabelStyleBase_;\n      };\n\n      this.meridiansLabels_ = [];\n      this.parallelsLabels_ = [];\n\n      this.addEventListener(EventType.POSTRENDER, this.drawLabels_.bind(this));\n    }\n\n    /**\n     * @type {Array<number>}\n     * @private\n     */\n    this.intervals_ =\n      options.intervals !== undefined ? options.intervals : INTERVALS;\n\n    // use a source with a custom loader for lines & text\n    this.setSource(\n      new VectorSource({\n        loader: this.loaderFunction.bind(this),\n        strategy: this.strategyFunction.bind(this),\n        features: new Collection(),\n        overlaps: false,\n        useSpatialIndex: false,\n        wrapX: options.wrapX,\n      }),\n    );\n\n    /**\n     * feature pool to use when updating graticule\n     * @type {Array<Feature>}\n     * @private\n     */\n    this.featurePool_ = [];\n\n    /**\n     * @type {Style}\n     * @private\n     */\n    this.lineStyle_ = new Style({\n      stroke: this.strokeStyle_,\n    });\n\n    /**\n     * @type {?import(\"../extent.js\").Extent}\n     * @private\n     */\n    this.loadedExtent_ = null;\n\n    /**\n     * @type {?import(\"../extent.js\").Extent}\n     * @private\n     */\n    this.renderedExtent_ = null;\n\n    /**\n     * @type {?number}\n     * @private\n     */\n    this.renderedResolution_ = null;\n\n    this.setRenderOrder(null);\n  }\n\n  /**\n   * Strategy function for loading features based on the view's extent and\n   * resolution.\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} resolution Resolution.\n   * @return {Array<import(\"../extent.js\").Extent>} Extents.\n   */\n  strategyFunction(extent, resolution) {\n    // extents may be passed in different worlds, to avoid endless loop we use only one\n    let realWorldExtent = extent.slice();\n    if (this.projection_ && this.getSource().getWrapX()) {\n      wrapExtentX(realWorldExtent, this.projection_);\n    }\n    if (this.loadedExtent_) {\n      if (\n        approximatelyEquals(this.loadedExtent_, realWorldExtent, resolution)\n      ) {\n        // make sure result is exactly equal to previous extent\n        realWorldExtent = this.loadedExtent_.slice();\n      } else {\n        // we should not keep track of loaded extents\n        this.getSource().removeLoadedExtent(this.loadedExtent_);\n      }\n    }\n    return [realWorldExtent];\n  }\n\n  /**\n   * Update geometries in the source based on current view\n   * @param {import(\"../extent.js\").Extent} extent Extent\n   * @param {number} resolution Resolution\n   * @param {import(\"../proj/Projection.js\").default} projection Projection\n   */\n  loaderFunction(extent, resolution, projection) {\n    this.loadedExtent_ = extent;\n    const source = this.getSource();\n\n    // only consider the intersection between our own extent & the requested one\n    const layerExtent = this.getExtent() || [\n      -Infinity,\n      -Infinity,\n      Infinity,\n      Infinity,\n    ];\n    const renderExtent = getIntersection(layerExtent, extent);\n\n    if (\n      this.renderedExtent_ &&\n      equals(this.renderedExtent_, renderExtent) &&\n      this.renderedResolution_ === resolution\n    ) {\n      return;\n    }\n    this.renderedExtent_ = renderExtent;\n    this.renderedResolution_ = resolution;\n\n    // bail out if nothing to render\n    if (isEmpty(renderExtent)) {\n      return;\n    }\n\n    // update projection info\n    const center = getCenter(renderExtent);\n    const squaredTolerance = (resolution * resolution) / 4;\n\n    const updateProjectionInfo =\n      !this.projection_ || !equivalentProjection(this.projection_, projection);\n\n    if (updateProjectionInfo) {\n      this.updateProjectionInfo_(projection);\n    }\n\n    this.createGraticule_(renderExtent, center, resolution, squaredTolerance);\n\n    // first make sure we have enough features in the pool\n    let featureCount = this.meridians_.length + this.parallels_.length;\n    if (this.meridiansLabels_) {\n      featureCount += this.meridians_.length;\n    }\n    if (this.parallelsLabels_) {\n      featureCount += this.parallels_.length;\n    }\n\n    let feature;\n    while (featureCount > this.featurePool_.length) {\n      feature = new Feature();\n      this.featurePool_.push(feature);\n    }\n\n    const featuresColl = source.getFeaturesCollection();\n    featuresColl.clear();\n    let poolIndex = 0;\n\n    // add features for the lines & labels\n    let i, l;\n    for (i = 0, l = this.meridians_.length; i < l; ++i) {\n      feature = this.featurePool_[poolIndex++];\n      feature.setGeometry(this.meridians_[i]);\n      feature.setStyle(this.lineStyle_);\n      featuresColl.push(feature);\n    }\n    for (i = 0, l = this.parallels_.length; i < l; ++i) {\n      feature = this.featurePool_[poolIndex++];\n      feature.setGeometry(this.parallels_[i]);\n      feature.setStyle(this.lineStyle_);\n      featuresColl.push(feature);\n    }\n  }\n\n  /**\n   * @param {number} lon Longitude.\n   * @param {number} minLat Minimal latitude.\n   * @param {number} maxLat Maximal latitude.\n   * @param {number} squaredTolerance Squared tolerance.\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} index Index.\n   * @return {number} Index.\n   * @private\n   */\n  addMeridian_(lon, minLat, maxLat, squaredTolerance, extent, index) {\n    const lineString = this.getMeridian_(\n      lon,\n      minLat,\n      maxLat,\n      squaredTolerance,\n      index,\n    );\n    if (intersects(lineString.getExtent(), extent)) {\n      if (this.meridiansLabels_) {\n        const text = this.lonLabelFormatter_(lon);\n        if (index in this.meridiansLabels_) {\n          this.meridiansLabels_[index].text = text;\n        } else {\n          this.meridiansLabels_[index] = {\n            geom: new Point([]),\n            text: text,\n          };\n        }\n      }\n      this.meridians_[index++] = lineString;\n    }\n    return index;\n  }\n\n  /**\n   * @param {number} lat Latitude.\n   * @param {number} minLon Minimal longitude.\n   * @param {number} maxLon Maximal longitude.\n   * @param {number} squaredTolerance Squared tolerance.\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} index Index.\n   * @return {number} Index.\n   * @private\n   */\n  addParallel_(lat, minLon, maxLon, squaredTolerance, extent, index) {\n    const lineString = this.getParallel_(\n      lat,\n      minLon,\n      maxLon,\n      squaredTolerance,\n      index,\n    );\n    if (intersects(lineString.getExtent(), extent)) {\n      if (this.parallelsLabels_) {\n        const text = this.latLabelFormatter_(lat);\n        if (index in this.parallelsLabels_) {\n          this.parallelsLabels_[index].text = text;\n        } else {\n          this.parallelsLabels_[index] = {\n            geom: new Point([]),\n            text: text,\n          };\n        }\n      }\n      this.parallels_[index++] = lineString;\n    }\n    return index;\n  }\n\n  /**\n   * @param {import(\"../render/Event.js\").default} event Render event.\n   * @private\n   */\n  drawLabels_(event) {\n    const rotation = event.frameState.viewState.rotation;\n    const resolution = event.frameState.viewState.resolution;\n    const size = event.frameState.size;\n    const extent = event.frameState.extent;\n    const rotationCenter = getCenter(extent);\n    let rotationExtent = extent;\n    if (rotation) {\n      const unrotatedWidth = size[0] * resolution;\n      const unrotatedHeight = size[1] * resolution;\n      rotationExtent = [\n        rotationCenter[0] - unrotatedWidth / 2,\n        rotationCenter[1] - unrotatedHeight / 2,\n        rotationCenter[0] + unrotatedWidth / 2,\n        rotationCenter[1] + unrotatedHeight / 2,\n      ];\n    }\n\n    let startWorld = 0;\n    let endWorld = 0;\n    let labelsAtStart = this.latLabelPosition_ < 0.5;\n    const projectionExtent = this.projection_.getExtent();\n    const worldWidth = getWidth(projectionExtent);\n    if (\n      this.getSource().getWrapX() &&\n      this.projection_.canWrapX() &&\n      !containsExtent(projectionExtent, extent)\n    ) {\n      startWorld = Math.floor((extent[0] - projectionExtent[0]) / worldWidth);\n      endWorld = Math.ceil((extent[2] - projectionExtent[2]) / worldWidth);\n      const inverted = Math.abs(rotation) > Math.PI / 2;\n      labelsAtStart = labelsAtStart !== inverted;\n    }\n    const vectorContext = getVectorContext(event);\n\n    for (let world = startWorld; world <= endWorld; ++world) {\n      let poolIndex = this.meridians_.length + this.parallels_.length;\n      let feature, index, l, textPoint;\n\n      if (this.meridiansLabels_) {\n        for (index = 0, l = this.meridiansLabels_.length; index < l; ++index) {\n          const lineString = this.meridians_[index];\n          if (!rotation && world === 0) {\n            textPoint = this.getMeridianPoint_(lineString, extent, index);\n          } else {\n            const clone = lineString.clone();\n            clone.translate(world * worldWidth, 0);\n            clone.rotate(-rotation, rotationCenter);\n            textPoint = this.getMeridianPoint_(clone, rotationExtent, index);\n            textPoint.rotate(rotation, rotationCenter);\n          }\n          feature = this.featurePool_[poolIndex++];\n          feature.setGeometry(textPoint);\n          feature.set('graticule_label', this.meridiansLabels_[index].text);\n          vectorContext.drawFeature(feature, this.lonLabelStyle_(feature));\n        }\n      }\n      if (this.parallelsLabels_) {\n        if (\n          (world === startWorld && labelsAtStart) ||\n          (world === endWorld && !labelsAtStart)\n        ) {\n          for (index = 0, l = this.parallels_.length; index < l; ++index) {\n            const lineString = this.parallels_[index];\n            if (!rotation && world === 0) {\n              textPoint = this.getParallelPoint_(lineString, extent, index);\n            } else {\n              const clone = lineString.clone();\n              clone.translate(world * worldWidth, 0);\n              clone.rotate(-rotation, rotationCenter);\n              textPoint = this.getParallelPoint_(clone, rotationExtent, index);\n              textPoint.rotate(rotation, rotationCenter);\n            }\n            feature = this.featurePool_[poolIndex++];\n            feature.setGeometry(textPoint);\n            feature.set('graticule_label', this.parallelsLabels_[index].text);\n            vectorContext.drawFeature(feature, this.latLabelStyle_(feature));\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {import(\"../coordinate.js\").Coordinate} center Center.\n   * @param {number} resolution Resolution.\n   * @param {number} squaredTolerance Squared tolerance.\n   * @private\n   */\n  createGraticule_(extent, center, resolution, squaredTolerance) {\n    const interval = this.getInterval_(resolution);\n    if (interval == -1) {\n      this.meridians_.length = 0;\n      this.parallels_.length = 0;\n      if (this.meridiansLabels_) {\n        this.meridiansLabels_.length = 0;\n      }\n      if (this.parallelsLabels_) {\n        this.parallelsLabels_.length = 0;\n      }\n      return;\n    }\n\n    let wrapX = false;\n    const projectionExtent = this.projection_.getExtent();\n    const worldWidth = getWidth(projectionExtent);\n    if (\n      this.getSource().getWrapX() &&\n      this.projection_.canWrapX() &&\n      !containsExtent(projectionExtent, extent)\n    ) {\n      if (getWidth(extent) >= worldWidth) {\n        extent[0] = projectionExtent[0];\n        extent[2] = projectionExtent[2];\n      } else {\n        wrapX = true;\n      }\n    }\n\n    // Constrain the center to fit into the extent available to the graticule\n\n    const validCenterP = [\n      clamp(center[0], this.minX_, this.maxX_),\n      clamp(center[1], this.minY_, this.maxY_),\n    ];\n\n    // Transform the center to lon lat\n    // Some projections may have a void area at the poles\n    // so replace any NaN latitudes with the min or max value closest to a pole\n\n    const centerLonLat = this.toLonLatTransform_(validCenterP);\n    if (isNaN(centerLonLat[1])) {\n      centerLonLat[1] =\n        Math.abs(this.maxLat_) >= Math.abs(this.minLat_)\n          ? this.maxLat_\n          : this.minLat_;\n    }\n    let centerLon = clamp(centerLonLat[0], this.minLon_, this.maxLon_);\n    let centerLat = clamp(centerLonLat[1], this.minLat_, this.maxLat_);\n    const maxLines = this.maxLines_;\n    let cnt, idx, lat, lon;\n\n    // Limit the extent to fit into the extent available to the graticule\n\n    let validExtentP = extent;\n    if (!wrapX) {\n      validExtentP = [\n        clamp(extent[0], this.minX_, this.maxX_),\n        clamp(extent[1], this.minY_, this.maxY_),\n        clamp(extent[2], this.minX_, this.maxX_),\n        clamp(extent[3], this.minY_, this.maxY_),\n      ];\n    }\n\n    // Transform the extent to get the lon lat ranges for the edges of the extent\n\n    const validExtent = applyTransform(\n      validExtentP,\n      this.toLonLatTransform_,\n      undefined,\n      8,\n    );\n\n    let maxLat = validExtent[3];\n    let maxLon = validExtent[2];\n    let minLat = validExtent[1];\n    let minLon = validExtent[0];\n\n    if (!wrapX) {\n      // Check if extremities of the world extent lie inside the extent\n      // (for example the pole in a polar projection)\n      // and extend the extent as appropriate\n\n      if (containsCoordinate(validExtentP, this.bottomLeft_)) {\n        minLon = this.minLon_;\n        minLat = this.minLat_;\n      }\n      if (containsCoordinate(validExtentP, this.bottomRight_)) {\n        maxLon = this.maxLon_;\n        minLat = this.minLat_;\n      }\n      if (containsCoordinate(validExtentP, this.topLeft_)) {\n        minLon = this.minLon_;\n        maxLat = this.maxLat_;\n      }\n      if (containsCoordinate(validExtentP, this.topRight_)) {\n        maxLon = this.maxLon_;\n        maxLat = this.maxLat_;\n      }\n\n      // The transformed center may also extend the lon lat ranges used for rendering\n\n      maxLat = clamp(maxLat, centerLat, this.maxLat_);\n      maxLon = clamp(maxLon, centerLon, this.maxLon_);\n      minLat = clamp(minLat, this.minLat_, centerLat);\n      minLon = clamp(minLon, this.minLon_, centerLon);\n    }\n\n    // Create meridians\n\n    centerLon = Math.floor(centerLon / interval) * interval;\n    lon = clamp(centerLon, this.minLon_, this.maxLon_);\n\n    idx = this.addMeridian_(lon, minLat, maxLat, squaredTolerance, extent, 0);\n\n    cnt = 0;\n    if (wrapX) {\n      while ((lon -= interval) >= minLon && cnt++ < maxLines) {\n        idx = this.addMeridian_(\n          lon,\n          minLat,\n          maxLat,\n          squaredTolerance,\n          extent,\n          idx,\n        );\n      }\n    } else {\n      while (lon != this.minLon_ && cnt++ < maxLines) {\n        lon = Math.max(lon - interval, this.minLon_);\n        idx = this.addMeridian_(\n          lon,\n          minLat,\n          maxLat,\n          squaredTolerance,\n          extent,\n          idx,\n        );\n      }\n    }\n\n    lon = clamp(centerLon, this.minLon_, this.maxLon_);\n\n    cnt = 0;\n    if (wrapX) {\n      while ((lon += interval) <= maxLon && cnt++ < maxLines) {\n        idx = this.addMeridian_(\n          lon,\n          minLat,\n          maxLat,\n          squaredTolerance,\n          extent,\n          idx,\n        );\n      }\n    } else {\n      while (lon != this.maxLon_ && cnt++ < maxLines) {\n        lon = Math.min(lon + interval, this.maxLon_);\n        idx = this.addMeridian_(\n          lon,\n          minLat,\n          maxLat,\n          squaredTolerance,\n          extent,\n          idx,\n        );\n      }\n    }\n\n    this.meridians_.length = idx;\n    if (this.meridiansLabels_) {\n      this.meridiansLabels_.length = idx;\n    }\n\n    // Create parallels\n\n    centerLat = Math.floor(centerLat / interval) * interval;\n    lat = clamp(centerLat, this.minLat_, this.maxLat_);\n\n    idx = this.addParallel_(lat, minLon, maxLon, squaredTolerance, extent, 0);\n\n    cnt = 0;\n    while (lat != this.minLat_ && cnt++ < maxLines) {\n      lat = Math.max(lat - interval, this.minLat_);\n      idx = this.addParallel_(\n        lat,\n        minLon,\n        maxLon,\n        squaredTolerance,\n        extent,\n        idx,\n      );\n    }\n\n    lat = clamp(centerLat, this.minLat_, this.maxLat_);\n\n    cnt = 0;\n    while (lat != this.maxLat_ && cnt++ < maxLines) {\n      lat = Math.min(lat + interval, this.maxLat_);\n      idx = this.addParallel_(\n        lat,\n        minLon,\n        maxLon,\n        squaredTolerance,\n        extent,\n        idx,\n      );\n    }\n\n    this.parallels_.length = idx;\n    if (this.parallelsLabels_) {\n      this.parallelsLabels_.length = idx;\n    }\n  }\n\n  /**\n   * @param {number} resolution Resolution.\n   * @return {number} The interval in degrees.\n   * @private\n   */\n  getInterval_(resolution) {\n    const centerLon = this.projectionCenterLonLat_[0];\n    const centerLat = this.projectionCenterLonLat_[1];\n    let interval = -1;\n    const target = Math.pow(this.targetSize_ * resolution, 2);\n    /** @type {Array<number>} **/\n    const p1 = [];\n    /** @type {Array<number>} **/\n    const p2 = [];\n    for (let i = 0, ii = this.intervals_.length; i < ii; ++i) {\n      const delta = clamp(this.intervals_[i] / 2, 0, 90);\n      // Don't attempt to transform latitudes beyond the poles!\n      const clampedLat = clamp(centerLat, -90 + delta, 90 - delta);\n      p1[0] = centerLon - delta;\n      p1[1] = clampedLat - delta;\n      p2[0] = centerLon + delta;\n      p2[1] = clampedLat + delta;\n      this.fromLonLatTransform_(p1, p1);\n      this.fromLonLatTransform_(p2, p2);\n      const dist = Math.pow(p2[0] - p1[0], 2) + Math.pow(p2[1] - p1[1], 2);\n      if (dist <= target) {\n        break;\n      }\n      interval = this.intervals_[i];\n    }\n    return interval;\n  }\n\n  /**\n   * @param {number} lon Longitude.\n   * @param {number} minLat Minimal latitude.\n   * @param {number} maxLat Maximal latitude.\n   * @param {number} squaredTolerance Squared tolerance.\n   * @return {LineString} The meridian line string.\n   * @param {number} index Index.\n   * @private\n   */\n  getMeridian_(lon, minLat, maxLat, squaredTolerance, index) {\n    const flatCoordinates = meridian(\n      lon,\n      minLat,\n      maxLat,\n      this.projection_,\n      squaredTolerance,\n    );\n    let lineString = this.meridians_[index];\n    if (!lineString) {\n      lineString = new LineString(flatCoordinates, 'XY');\n      this.meridians_[index] = lineString;\n    } else {\n      lineString.setFlatCoordinates('XY', flatCoordinates);\n      lineString.changed();\n    }\n    return lineString;\n  }\n\n  /**\n   * @param {LineString} lineString Meridian\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} index Index.\n   * @return {Point} Meridian point.\n   * @private\n   */\n  getMeridianPoint_(lineString, extent, index) {\n    const flatCoordinates = lineString.getFlatCoordinates();\n    let bottom = 1;\n    let top = flatCoordinates.length - 1;\n    if (flatCoordinates[bottom] > flatCoordinates[top]) {\n      bottom = top;\n      top = 1;\n    }\n    const clampedBottom = Math.max(extent[1], flatCoordinates[bottom]);\n    const clampedTop = Math.min(extent[3], flatCoordinates[top]);\n    const lat = clamp(\n      extent[1] + Math.abs(extent[1] - extent[3]) * this.lonLabelPosition_,\n      clampedBottom,\n      clampedTop,\n    );\n    const coordinate0 =\n      flatCoordinates[bottom - 1] +\n      ((flatCoordinates[top - 1] - flatCoordinates[bottom - 1]) *\n        (lat - flatCoordinates[bottom])) /\n        (flatCoordinates[top] - flatCoordinates[bottom]);\n    const coordinate = [coordinate0, lat];\n    const point = this.meridiansLabels_[index].geom;\n    point.setCoordinates(coordinate);\n    return point;\n  }\n\n  /**\n   * Get the list of meridians.  Meridians are lines of equal longitude.\n   * @return {Array<LineString>} The meridians.\n   * @api\n   */\n  getMeridians() {\n    return this.meridians_;\n  }\n\n  /**\n   * @param {number} lat Latitude.\n   * @param {number} minLon Minimal longitude.\n   * @param {number} maxLon Maximal longitude.\n   * @param {number} squaredTolerance Squared tolerance.\n   * @return {LineString} The parallel line string.\n   * @param {number} index Index.\n   * @private\n   */\n  getParallel_(lat, minLon, maxLon, squaredTolerance, index) {\n    const flatCoordinates = parallel(\n      lat,\n      minLon,\n      maxLon,\n      this.projection_,\n      squaredTolerance,\n    );\n    let lineString = this.parallels_[index];\n    if (!lineString) {\n      lineString = new LineString(flatCoordinates, 'XY');\n    } else {\n      lineString.setFlatCoordinates('XY', flatCoordinates);\n      lineString.changed();\n    }\n    return lineString;\n  }\n\n  /**\n   * @param {LineString} lineString Parallels.\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} index Index.\n   * @return {Point} Parallel point.\n   * @private\n   */\n  getParallelPoint_(lineString, extent, index) {\n    const flatCoordinates = lineString.getFlatCoordinates();\n    let left = 0;\n    let right = flatCoordinates.length - 2;\n    if (flatCoordinates[left] > flatCoordinates[right]) {\n      left = right;\n      right = 0;\n    }\n    const clampedLeft = Math.max(extent[0], flatCoordinates[left]);\n    const clampedRight = Math.min(extent[2], flatCoordinates[right]);\n    const lon = clamp(\n      extent[0] + Math.abs(extent[0] - extent[2]) * this.latLabelPosition_,\n      clampedLeft,\n      clampedRight,\n    );\n    const coordinate1 =\n      flatCoordinates[left + 1] +\n      ((flatCoordinates[right + 1] - flatCoordinates[left + 1]) *\n        (lon - flatCoordinates[left])) /\n        (flatCoordinates[right] - flatCoordinates[left]);\n    const coordinate = [lon, coordinate1];\n    const point = this.parallelsLabels_[index].geom;\n    point.setCoordinates(coordinate);\n    return point;\n  }\n\n  /**\n   * Get the list of parallels.  Parallels are lines of equal latitude.\n   * @return {Array<LineString>} The parallels.\n   * @api\n   */\n  getParallels() {\n    return this.parallels_;\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @private\n   */\n  updateProjectionInfo_(projection) {\n    const epsg4326Projection = getProjection('EPSG:4326');\n\n    const worldExtent = projection.getWorldExtent();\n\n    this.maxLat_ = worldExtent[3];\n    this.maxLon_ = worldExtent[2];\n    this.minLat_ = worldExtent[1];\n    this.minLon_ = worldExtent[0];\n\n    // If the world extent crosses the dateline define a custom transform to\n    // return longitudes which wrap the dateline\n\n    const toLonLatTransform = getTransform(projection, epsg4326Projection);\n    if (this.minLon_ < this.maxLon_) {\n      this.toLonLatTransform_ = toLonLatTransform;\n    } else {\n      const split = this.minLon_ + this.maxLon_ / 2;\n      this.maxLon_ += 360;\n      this.toLonLatTransform_ = function (coordinates, output, dimension) {\n        dimension = dimension || 2;\n        const lonLatCoordinates = toLonLatTransform(\n          coordinates,\n          output,\n          dimension,\n        );\n        for (let i = 0, l = lonLatCoordinates.length; i < l; i += dimension) {\n          if (lonLatCoordinates[i] < split) {\n            lonLatCoordinates[i] += 360;\n          }\n        }\n        return lonLatCoordinates;\n      };\n    }\n\n    // Transform the extent to get the limits of the view projection extent\n    // which should be available to the graticule\n\n    this.fromLonLatTransform_ = getTransform(epsg4326Projection, projection);\n    const worldExtentP = applyTransform(\n      [this.minLon_, this.minLat_, this.maxLon_, this.maxLat_],\n      this.fromLonLatTransform_,\n      undefined,\n      8,\n    );\n\n    this.minX_ = worldExtentP[0];\n    this.maxX_ = worldExtentP[2];\n    this.minY_ = worldExtentP[1];\n    this.maxY_ = worldExtentP[3];\n\n    // Determine the view projection coordinates of the extremities of the world extent\n    // as these may lie inside a view extent (for example the pole in a polar projection)\n\n    this.bottomLeft_ = this.fromLonLatTransform_([this.minLon_, this.minLat_]);\n    this.bottomRight_ = this.fromLonLatTransform_([this.maxLon_, this.minLat_]);\n    this.topLeft_ = this.fromLonLatTransform_([this.minLon_, this.maxLat_]);\n    this.topRight_ = this.fromLonLatTransform_([this.maxLon_, this.maxLat_]);\n\n    // Transform the projection center to lon lat\n    // Some projections may have a void area at the poles\n    // so replace any NaN latitudes with the min or max value closest to a pole\n\n    this.projectionCenterLonLat_ = this.toLonLatTransform_(\n      getCenter(projection.getExtent()),\n    );\n    if (isNaN(this.projectionCenterLonLat_[1])) {\n      this.projectionCenterLonLat_[1] =\n        Math.abs(this.maxLat_) >= Math.abs(this.minLat_)\n          ? this.maxLat_\n          : this.minLat_;\n    }\n\n    this.projection_ = projection;\n  }\n}\n\nexport default Graticule;\n","/**\n * @module ol/webgl\n */\n\nimport {SAFARI_BUG_237906} from './has.js';\n\n/**\n * Constants taken from goog.webgl\n */\n\n/**\n * Used by {@link module:ol/webgl/Helper~WebGLHelper} for buffers containing vertices data, such as\n * position, color, texture coordinate, etc. These vertices are then referenced by an index buffer\n * to be drawn on screen (see {@link module:ol/webgl.ELEMENT_ARRAY_BUFFER}).\n * @const\n * @type {number}\n * @api\n */\nexport const ARRAY_BUFFER = 0x8892;\n\n/**\n * Used by {@link module:ol/webgl/Helper~WebGLHelper} for buffers containing indices data.\n * Index buffers are essentially lists of references to vertices defined in a vertex buffer\n * (see {@link module:ol/webgl.ARRAY_BUFFER}), and define the primitives (triangles) to be drawn.\n * @const\n * @type {number}\n * @api\n */\nexport const ELEMENT_ARRAY_BUFFER = 0x8893;\n\n/**\n * Used by {link module:ol/webgl/Buffer~WebGLArrayBuffer}.\n * @const\n * @type {number}\n * @api\n */\nexport const STREAM_DRAW = 0x88e0;\n\n/**\n * Used by {link module:ol/webgl/Buffer~WebGLArrayBuffer}.\n * @const\n * @type {number}\n * @api\n */\nexport const STATIC_DRAW = 0x88e4;\n\n/**\n * Used by {link module:ol/webgl/Buffer~WebGLArrayBuffer}.\n * @const\n * @type {number}\n * @api\n */\nexport const DYNAMIC_DRAW = 0x88e8;\n\n/**\n * @const\n * @type {number}\n */\nexport const UNSIGNED_BYTE = 0x1401;\n\n/**\n * @const\n * @type {number}\n */\nexport const UNSIGNED_SHORT = 0x1403;\n\n/**\n * @const\n * @type {number}\n */\nexport const UNSIGNED_INT = 0x1405;\n\n/**\n * @const\n * @type {number}\n */\nexport const FLOAT = 0x1406;\n\n/**\n  end of goog.webgl constants\n */\n\n/**\n * @const\n * @type {Array<string>}\n */\nconst CONTEXT_IDS = ['experimental-webgl', 'webgl', 'webkit-3d', 'moz-webgl'];\n\n/**\n * @param {HTMLCanvasElement} canvas Canvas.\n * @param {Object} [attributes] Attributes.\n * @return {WebGLRenderingContext|null} WebGL rendering context.\n */\nexport function getContext(canvas, attributes) {\n  attributes = Object.assign(\n    {\n      preserveDrawingBuffer: true,\n      antialias: SAFARI_BUG_237906 ? false : true, // https://bugs.webkit.org/show_bug.cgi?id=237906\n    },\n    attributes,\n  );\n  const ii = CONTEXT_IDS.length;\n  for (let i = 0; i < ii; ++i) {\n    try {\n      const context = canvas.getContext(CONTEXT_IDS[i], attributes);\n      if (context) {\n        return /** @type {!WebGLRenderingContext} */ (context);\n      }\n    } catch {\n      // pass\n    }\n  }\n  return null;\n}\n\n/**\n * @type {Array<string>|null}\n */\nlet supportedExtensions = null;\n\n/**\n * @return {Array<string>|null} List of supported WebGL extensions.\n */\nexport function getSupportedExtensions() {\n  if (!supportedExtensions) {\n    const canvas = document.createElement('canvas');\n    const gl = getContext(canvas);\n    if (gl) {\n      supportedExtensions = gl.getSupportedExtensions();\n    }\n  }\n  return supportedExtensions;\n}\n","/**\n * @module ol/webgl/Buffer\n */\nimport {assert} from '../asserts.js';\nimport {\n  ARRAY_BUFFER,\n  DYNAMIC_DRAW,\n  ELEMENT_ARRAY_BUFFER,\n  STATIC_DRAW,\n  STREAM_DRAW,\n} from '../webgl.js';\n\n/**\n * Used to describe the intended usage for the data: `STATIC_DRAW`, `STREAM_DRAW`\n * or `DYNAMIC_DRAW`.\n * @enum {number}\n */\nexport const BufferUsage = {\n  STATIC_DRAW: STATIC_DRAW,\n  STREAM_DRAW: STREAM_DRAW,\n  DYNAMIC_DRAW: DYNAMIC_DRAW,\n};\n\n/**\n * @classdesc\n * Object used to store an array of data as well as usage information for that data.\n * Stores typed arrays internally, either Float32Array or Uint16/32Array depending on\n * the buffer type (ARRAY_BUFFER or ELEMENT_ARRAY_BUFFER) and available extensions.\n *\n * To populate the array, you can either use:\n * A size using `#ofSize(buffer)`\n * An `ArrayBuffer` object using `#fromArrayBuffer(buffer)`\n * A plain array using `#fromArray(array)`\n *\n * Note:\n * See the documentation of [WebGLRenderingContext.bufferData](https://developer.mozilla.org/en-US/docs/Web/API/WebGLRenderingContext/bufferData)\n * for more info on buffer usage.\n */\nclass WebGLArrayBuffer {\n  /**\n   * @param {number} type Buffer type, either ARRAY_BUFFER or ELEMENT_ARRAY_BUFFER.\n   * @param {number} [usage] Intended usage, either `STATIC_DRAW`, `STREAM_DRAW` or `DYNAMIC_DRAW`.\n   * Default is `STATIC_DRAW`.\n   */\n  constructor(type, usage) {\n    /**\n     * @private\n     * @type {Float32Array|Uint32Array|null}\n     */\n    this.array_ = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.type_ = type;\n\n    assert(\n      type === ARRAY_BUFFER || type === ELEMENT_ARRAY_BUFFER,\n      'A `WebGLArrayBuffer` must either be of type `ELEMENT_ARRAY_BUFFER` or `ARRAY_BUFFER`',\n    );\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.usage_ = usage !== undefined ? usage : BufferUsage.STATIC_DRAW;\n  }\n\n  /**\n   * Populates the buffer with an array of the given size (all values will be zeroes).\n   * @param {number} size Array size\n   * @return {WebGLArrayBuffer} This\n   */\n  ofSize(size) {\n    this.array_ = new (getArrayClassForType(this.type_))(size);\n    return this;\n  }\n\n  /**\n   * Populates the buffer with an array of the given size.\n   * @param {Array<number>} array Numerical array\n   * @return {WebGLArrayBuffer} This\n   */\n  fromArray(array) {\n    this.array_ = getArrayClassForType(this.type_).from(array);\n    return this;\n  }\n\n  /**\n   * Populates the buffer with a raw binary array buffer.\n   * @param {ArrayBuffer} buffer Raw binary buffer to populate the array with. Note that this buffer must have been\n   * initialized for the same typed array class.\n   * @return {WebGLArrayBuffer} This\n   */\n  fromArrayBuffer(buffer) {\n    this.array_ = new (getArrayClassForType(this.type_))(buffer);\n    return this;\n  }\n\n  /**\n   * @return {number} Buffer type.\n   */\n  getType() {\n    return this.type_;\n  }\n\n  /**\n   * Will return null if the buffer was not initialized\n   * @return {Float32Array|Uint32Array|null} Array.\n   */\n  getArray() {\n    return this.array_;\n  }\n\n  /**\n   * @param {Float32Array|Uint32Array} array Array.\n   */\n  setArray(array) {\n    const ArrayType = getArrayClassForType(this.type_);\n    if (!(array instanceof ArrayType)) {\n      throw new Error(`Expected ${ArrayType}`);\n    }\n    this.array_ = array;\n  }\n\n  /**\n   * @return {number} Usage.\n   */\n  getUsage() {\n    return this.usage_;\n  }\n\n  /**\n   * Will return 0 if the buffer is not initialized\n   * @return {number} Array size\n   */\n  getSize() {\n    return this.array_ ? this.array_.length : 0;\n  }\n}\n\n/**\n * Returns a typed array constructor based on the given buffer type\n * @param {number} type Buffer type, either ARRAY_BUFFER or ELEMENT_ARRAY_BUFFER.\n * @return {Float32ArrayConstructor|Uint32ArrayConstructor} The typed array class to use for this buffer.\n */\nexport function getArrayClassForType(type) {\n  switch (type) {\n    case ARRAY_BUFFER:\n      return Float32Array;\n    case ELEMENT_ARRAY_BUFFER:\n      return Uint32Array;\n    default:\n      return Float32Array;\n  }\n}\n\nexport default WebGLArrayBuffer;\n","/**\n * @module ol/webgl/ContextEventType\n */\n\n/**\n * @enum {string}\n */\nexport default {\n  LOST: 'webglcontextlost',\n  RESTORED: 'webglcontextrestored',\n};\n","/**\n * @module ol/webgl/PostProcessingPass\n */\n\nimport {getUid} from '../util.js';\n\nconst DEFAULT_VERTEX_SHADER = `\n  precision mediump float;\n\n  attribute vec2 a_position;\n  varying vec2 v_texCoord;\n  varying vec2 v_screenCoord;\n\n  uniform vec2 u_screenSize;\n\n  void main() {\n    v_texCoord = a_position * 0.5 + 0.5;\n    v_screenCoord = v_texCoord * u_screenSize;\n    gl_Position = vec4(a_position, 0.0, 1.0);\n  }\n`;\n\nconst DEFAULT_FRAGMENT_SHADER = `\n  precision mediump float;\n\n  uniform sampler2D u_image;\n  uniform float u_opacity;\n\n  varying vec2 v_texCoord;\n\n  void main() {\n    gl_FragColor = texture2D(u_image, v_texCoord) * u_opacity;\n  }\n`;\n\n/**\n * @typedef {Object} Options\n * @property {WebGLRenderingContext} webGlContext WebGL context; mandatory.\n * @property {number} [scaleRatio] Scale ratio; if < 1, the post process will render to a texture smaller than\n * the main canvas that will then be sampled up (useful for saving resource on blur steps).\n * @property {string} [vertexShader] Vertex shader source\n * @property {string} [fragmentShader] Fragment shader source\n * @property {Object<string,import(\"./Helper.js\").UniformValue>} [uniforms] Uniform definitions for the post process step\n */\n\n/**\n * @typedef {Object} UniformInternalDescription\n * @property {import(\"./Helper.js\").UniformValue} value Value\n * @property {WebGLUniformLocation} location Location\n * @property {WebGLTexture} [texture] Texture\n * @private\n */\n\n/**\n * @classdesc\n * This class is used to define Post Processing passes with custom shaders and uniforms.\n * This is used internally by {@link module:ol/webgl/Helper~WebGLHelper}.\n *\n * Please note that the final output on the DOM canvas is expected to have premultiplied alpha, which means that\n * a pixel which is 100% red with an opacity of 50% must have a color of (r=0.5, g=0, b=0, a=0.5).\n * Failing to provide pixel colors with premultiplied alpha will result in render anomalies.\n *\n * The default post-processing pass does *not* multiply color values with alpha value, it expects color values to be\n * premultiplied.\n *\n * Default shaders are shown hereafter:\n *\n * Vertex shader:\n *\n *   ```\n *   precision mediump float;\n *\n *   attribute vec2 a_position;\n *   varying vec2 v_texCoord;\n *   varying vec2 v_screenCoord;\n *\n *   uniform vec2 u_screenSize;\n *\n *   void main() {\n *     v_texCoord = a_position * 0.5 + 0.5;\n *     v_screenCoord = v_texCoord * u_screenSize;\n *     gl_Position = vec4(a_position, 0.0, 1.0);\n *   }\n *   ```\n *\n * Fragment shader:\n *\n *   ```\n *   precision mediump float;\n *\n *   uniform sampler2D u_image;\n *   uniform float u_opacity;\n *\n *   varying vec2 v_texCoord;\n *\n *   void main() {\n *     gl_FragColor = texture2D(u_image, v_texCoord) * u_opacity;\n *   }\n *   ```\n */\nclass WebGLPostProcessingPass {\n  /**\n   * @param {Options} options Options.\n   */\n  constructor(options) {\n    /**\n     * @private\n     */\n    this.gl_ = options.webGlContext;\n    const gl = this.gl_;\n\n    /**\n     * @private\n     */\n    this.scaleRatio_ = options.scaleRatio || 1;\n\n    /**\n     * @type {WebGLTexture}\n     * @private\n     */\n    this.renderTargetTexture_ = gl.createTexture();\n\n    /**\n     * @type {import('../size.js').Size|null}\n     * @private\n     */\n    this.renderTargetTextureSize_ = null;\n\n    /**\n     * @private\n     */\n    this.frameBuffer_ = gl.createFramebuffer();\n    /**\n     * @private\n     */\n    this.depthBuffer_ = gl.createRenderbuffer();\n\n    // compile the program for the frame buffer\n    // TODO: make compilation errors show up\n    const vertexShader = gl.createShader(gl.VERTEX_SHADER);\n    gl.shaderSource(\n      vertexShader,\n      options.vertexShader || DEFAULT_VERTEX_SHADER,\n    );\n    gl.compileShader(vertexShader);\n    const fragmentShader = gl.createShader(gl.FRAGMENT_SHADER);\n    gl.shaderSource(\n      fragmentShader,\n      options.fragmentShader || DEFAULT_FRAGMENT_SHADER,\n    );\n    gl.compileShader(fragmentShader);\n    /**\n     * @private\n     */\n    this.renderTargetProgram_ = gl.createProgram();\n    gl.attachShader(this.renderTargetProgram_, vertexShader);\n    gl.attachShader(this.renderTargetProgram_, fragmentShader);\n    gl.linkProgram(this.renderTargetProgram_);\n\n    // bind the vertices buffer for the frame buffer\n    /**\n     * @private\n     */\n    this.renderTargetVerticesBuffer_ = gl.createBuffer();\n    const verticesArray = [-1, -1, 1, -1, -1, 1, 1, -1, 1, 1, -1, 1];\n    gl.bindBuffer(gl.ARRAY_BUFFER, this.renderTargetVerticesBuffer_);\n    gl.bufferData(\n      gl.ARRAY_BUFFER,\n      new Float32Array(verticesArray),\n      gl.STATIC_DRAW,\n    );\n\n    /**\n     * @private\n     */\n    this.renderTargetAttribLocation_ = gl.getAttribLocation(\n      this.renderTargetProgram_,\n      'a_position',\n    );\n    /**\n     * @private\n     */\n    this.renderTargetUniformLocation_ = gl.getUniformLocation(\n      this.renderTargetProgram_,\n      'u_screenSize',\n    );\n    /**\n     * @private\n     */\n    this.renderTargetOpacityLocation_ = gl.getUniformLocation(\n      this.renderTargetProgram_,\n      'u_opacity',\n    );\n    /**\n     * @private\n     */\n    this.renderTargetTextureLocation_ = gl.getUniformLocation(\n      this.renderTargetProgram_,\n      'u_image',\n    );\n\n    /**\n     * Holds info about custom uniforms used in the post processing pass\n     * @type {Array<UniformInternalDescription>}\n     * @private\n     */\n    this.uniforms_ = [];\n    options.uniforms &&\n      Object.keys(options.uniforms).forEach((name) => {\n        this.uniforms_.push({\n          value: options.uniforms[name],\n          location: gl.getUniformLocation(this.renderTargetProgram_, name),\n        });\n      });\n  }\n\n  getRenderTargetTexture() {\n    return this.renderTargetTexture_;\n  }\n\n  /**\n   * Get the WebGL rendering context\n   * @return {WebGLRenderingContext} The rendering context.\n   */\n  getGL() {\n    return this.gl_;\n  }\n\n  /**\n   * Initialize the render target texture of the post process, make sure it is at the\n   * right size and bind it as a render target for the next draw calls.\n   * The last step to be initialized will be the one where the primitives are rendered.\n   * @param {import(\"../Map.js\").FrameState} frameState current frame state\n   */\n  init(frameState) {\n    const gl = this.getGL();\n    const textureSize = [\n      gl.drawingBufferWidth * this.scaleRatio_,\n      gl.drawingBufferHeight * this.scaleRatio_,\n    ];\n\n    // rendering goes to my buffer\n    gl.bindFramebuffer(gl.FRAMEBUFFER, this.getFrameBuffer());\n    gl.bindRenderbuffer(gl.RENDERBUFFER, this.getDepthBuffer());\n    gl.viewport(0, 0, textureSize[0], textureSize[1]);\n\n    // if size has changed: adjust canvas & render target texture\n    if (\n      !this.renderTargetTextureSize_ ||\n      this.renderTargetTextureSize_[0] !== textureSize[0] ||\n      this.renderTargetTextureSize_[1] !== textureSize[1]\n    ) {\n      this.renderTargetTextureSize_ = textureSize;\n\n      // create a new texture\n      const level = 0;\n      const internalFormat = gl.RGBA;\n      const border = 0;\n      const format = gl.RGBA;\n      const type = gl.UNSIGNED_BYTE;\n      const data = null;\n      gl.bindTexture(gl.TEXTURE_2D, this.renderTargetTexture_);\n      gl.texImage2D(\n        gl.TEXTURE_2D,\n        level,\n        internalFormat,\n        textureSize[0],\n        textureSize[1],\n        border,\n        format,\n        type,\n        data,\n      );\n\n      gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n      gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n      gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n\n      // bind the texture to the framebuffer\n      gl.framebufferTexture2D(\n        gl.FRAMEBUFFER,\n        gl.COLOR_ATTACHMENT0,\n        gl.TEXTURE_2D,\n        this.renderTargetTexture_,\n        0,\n      );\n\n      gl.renderbufferStorage(\n        gl.RENDERBUFFER,\n        gl.DEPTH_COMPONENT16,\n        textureSize[0],\n        textureSize[1],\n      );\n      gl.framebufferRenderbuffer(\n        gl.FRAMEBUFFER,\n        gl.DEPTH_ATTACHMENT,\n        gl.RENDERBUFFER,\n        this.depthBuffer_,\n      );\n    }\n  }\n\n  /**\n   * Render to the next postprocessing pass (or to the canvas if final pass).\n   * @param {import(\"../Map.js\").FrameState} frameState current frame state\n   * @param {WebGLPostProcessingPass} [nextPass] Next pass, optional\n   * @param {function(WebGLRenderingContext, import(\"../Map.js\").FrameState):void} [preCompose] Called before composing.\n   * @param {function(WebGLRenderingContext, import(\"../Map.js\").FrameState):void} [postCompose] Called before composing.\n   */\n  apply(frameState, nextPass, preCompose, postCompose) {\n    const gl = this.getGL();\n    const size = frameState.size;\n\n    gl.bindFramebuffer(\n      gl.FRAMEBUFFER,\n      nextPass ? nextPass.getFrameBuffer() : null,\n    );\n    gl.activeTexture(gl.TEXTURE0);\n    gl.bindTexture(gl.TEXTURE_2D, this.renderTargetTexture_);\n\n    if (!nextPass) {\n      // clear the canvas if we are the first to render to it\n      // and preserveDrawingBuffer is true\n      const canvasId = getUid(gl.canvas);\n      if (!frameState.renderTargets[canvasId]) {\n        const attributes = gl.getContextAttributes();\n        if (attributes && attributes.preserveDrawingBuffer) {\n          gl.clearColor(0.0, 0.0, 0.0, 0.0);\n          gl.clearDepth(1.0);\n          gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);\n        }\n\n        frameState.renderTargets[canvasId] = true;\n      }\n    }\n\n    gl.disable(gl.DEPTH_TEST);\n    gl.enable(gl.BLEND);\n    gl.blendFunc(gl.ONE, gl.ONE_MINUS_SRC_ALPHA);\n    gl.viewport(0, 0, gl.drawingBufferWidth, gl.drawingBufferHeight);\n\n    gl.bindBuffer(gl.ARRAY_BUFFER, this.renderTargetVerticesBuffer_);\n\n    gl.useProgram(this.renderTargetProgram_);\n    gl.enableVertexAttribArray(this.renderTargetAttribLocation_);\n    gl.vertexAttribPointer(\n      this.renderTargetAttribLocation_,\n      2,\n      gl.FLOAT,\n      false,\n      0,\n      0,\n    );\n    gl.uniform2f(this.renderTargetUniformLocation_, size[0], size[1]);\n    gl.uniform1i(this.renderTargetTextureLocation_, 0);\n\n    const opacity = frameState.layerStatesArray[frameState.layerIndex].opacity;\n    gl.uniform1f(this.renderTargetOpacityLocation_, opacity);\n\n    this.applyUniforms(frameState);\n\n    if (preCompose) {\n      preCompose(gl, frameState);\n    }\n    gl.drawArrays(gl.TRIANGLES, 0, 6);\n    if (postCompose) {\n      postCompose(gl, frameState);\n    }\n  }\n\n  /**\n   * @return {WebGLFramebuffer} Frame buffer\n   */\n  getFrameBuffer() {\n    return this.frameBuffer_;\n  }\n\n  /**\n   * @return {WebGLRenderbuffer} Depth buffer\n   */\n  getDepthBuffer() {\n    return this.depthBuffer_;\n  }\n\n  /**\n   * Sets the custom uniforms based on what was given in the constructor.\n   * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n   * @private\n   */\n  applyUniforms(frameState) {\n    const gl = this.getGL();\n\n    let value;\n    let textureSlot = 1;\n    this.uniforms_.forEach(function (uniform) {\n      value =\n        typeof uniform.value === 'function'\n          ? uniform.value(frameState)\n          : uniform.value;\n\n      // apply value based on type\n      if (value instanceof HTMLCanvasElement || value instanceof ImageData) {\n        // create a texture & put data\n        if (!uniform.texture) {\n          uniform.texture = gl.createTexture();\n        }\n        gl.activeTexture(gl[`TEXTURE${textureSlot}`]);\n        gl.bindTexture(gl.TEXTURE_2D, uniform.texture);\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n\n        if (value instanceof ImageData) {\n          gl.texImage2D(\n            gl.TEXTURE_2D,\n            0,\n            gl.RGBA,\n            gl.RGBA,\n            value.width,\n            value.height,\n            0,\n            gl.UNSIGNED_BYTE,\n            new Uint8Array(value.data),\n          );\n        } else {\n          gl.texImage2D(\n            gl.TEXTURE_2D,\n            0,\n            gl.RGBA,\n            gl.RGBA,\n            gl.UNSIGNED_BYTE,\n            value,\n          );\n        }\n\n        // fill texture slots\n        gl.uniform1i(uniform.location, textureSlot++);\n      } else if (Array.isArray(value)) {\n        switch (value.length) {\n          case 2:\n            gl.uniform2f(uniform.location, value[0], value[1]);\n            return;\n          case 3:\n            gl.uniform3f(uniform.location, value[0], value[1], value[2]);\n            return;\n          case 4:\n            gl.uniform4f(\n              uniform.location,\n              value[0],\n              value[1],\n              value[2],\n              value[3],\n            );\n            return;\n          default:\n            return;\n        }\n      } else if (typeof value === 'number') {\n        gl.uniform1f(uniform.location, value);\n      }\n    });\n  }\n}\n\nexport default WebGLPostProcessingPass;\n","/**\n * @module ol/webgl/Helper\n */\nimport Disposable from '../Disposable.js';\nimport {assert} from '../asserts.js';\nimport {clear} from '../obj.js';\nimport {\n  compose as composeTransform,\n  create as createTransform,\n} from '../transform.js';\nimport {getUid} from '../util.js';\nimport {create, fromTransform} from '../vec/mat4.js';\nimport {\n  FLOAT,\n  UNSIGNED_BYTE,\n  UNSIGNED_INT,\n  UNSIGNED_SHORT,\n  getContext,\n} from '../webgl.js';\nimport ContextEventType from '../webgl/ContextEventType.js';\nimport WebGLPostProcessingPass from './PostProcessingPass.js';\n\n/**\n * @typedef {Object} BufferCacheEntry\n * @property {import(\"./Buffer.js\").default} buffer Buffer.\n * @property {WebGLBuffer} webGlBuffer WebGlBuffer.\n */\n\n/**\n * Shader types, either `FRAGMENT_SHADER` or `VERTEX_SHADER`.\n * @enum {number}\n */\nexport const ShaderType = {\n  FRAGMENT_SHADER: 0x8b30,\n  VERTEX_SHADER: 0x8b31,\n};\n\n/**\n * Names of uniforms made available to all shaders.\n * Please note: changing these *will* break custom shaders!\n * @enum {string}\n */\nexport const DefaultUniform = {\n  PROJECTION_MATRIX: 'u_projectionMatrix',\n  INVERT_PROJECTION_MATRIX: 'u_invertProjectionMatrix',\n  TIME: 'u_time',\n  ZOOM: 'u_zoom',\n  RESOLUTION: 'u_resolution',\n  ROTATION: 'u_rotation',\n  VIEWPORT_SIZE_PX: 'u_viewportSizePx',\n  PIXEL_RATIO: 'u_pixelRatio',\n  HIT_DETECTION: 'u_hitDetection',\n};\n\n/**\n * Attribute types, either `UNSIGNED_BYTE`, `UNSIGNED_SHORT`, `UNSIGNED_INT` or `FLOAT`\n * Note: an attribute stored in a `Float32Array` should be of type `FLOAT`.\n * @enum {number}\n */\nexport const AttributeType = {\n  UNSIGNED_BYTE: UNSIGNED_BYTE,\n  UNSIGNED_SHORT: UNSIGNED_SHORT,\n  UNSIGNED_INT: UNSIGNED_INT,\n  FLOAT: FLOAT,\n};\n\n/**\n * Description of an attribute in a buffer\n * @typedef {Object} AttributeDescription\n * @property {string|null} name Attribute name to use in shaders; if null, this attribute will not be enabled and is simply used as padding in the buffers\n * @property {number} size Number of components per attributes\n * @property {AttributeType} [type] Attribute type, i.e. number of bytes used to store the value. This is\n * determined by the class of typed array which the buffer uses (eg. `Float32Array` for a `FLOAT` attribute).\n * Default is `FLOAT`.\n */\n\n/**\n * @typedef {number|Array<number>|HTMLCanvasElement|HTMLImageElement|ImageData|WebGLTexture|import(\"../transform.js\").Transform} UniformLiteralValue\n */\n\n/**\n * Uniform value can be a number, array of numbers (2 to 4), canvas element or a callback returning\n * one of the previous types.\n * @typedef {UniformLiteralValue|function(import(\"../Map.js\").FrameState):UniformLiteralValue} UniformValue\n */\n\n/**\n * @typedef {Object} PostProcessesOptions\n * @property {number} [scaleRatio] Scale ratio; if < 1, the post process will render to a texture smaller than\n * the main canvas which will then be sampled up (useful for saving resource on blur steps).\n * @property {string} [vertexShader] Vertex shader source\n * @property {string} [fragmentShader] Fragment shader source\n * @property {Object<string,UniformValue>} [uniforms] Uniform definitions for the post process step\n */\n\n/**\n * @typedef {Object} Options\n * @property {Object<string,UniformValue>} [uniforms] Uniform definitions; property names must match the uniform\n * names in the provided or default shaders.\n * @property {Array<PostProcessesOptions>} [postProcesses] Post-processes definitions\n * @property {string} [canvasCacheKey] The cache key for the canvas.\n */\n\n/**\n * @typedef {Object} UniformInternalDescription\n * @property {string} name Name\n * @property {UniformValue} [value] Value\n * @property {UniformValue} [prevValue] The previous value.\n * @property {WebGLTexture} [texture] Texture\n * @private\n */\n\n/**\n * @typedef {Object} CanvasCacheItem\n * @property {WebGLRenderingContext} context The context of this canvas.\n * @property {number} users The count of users of this canvas.\n */\n\n/**\n * @type {Object<string,CanvasCacheItem>}\n */\nconst canvasCache = {};\n\n/**\n * @param {string} key The cache key for the canvas.\n * @return {string} The shared cache key.\n */\nfunction getSharedCanvasCacheKey(key) {\n  return 'shared/' + key;\n}\n\nlet uniqueCanvasCacheKeyCount = 0;\n\n/**\n * @return {string} The unique cache key.\n */\nfunction getUniqueCanvasCacheKey() {\n  const key = 'unique/' + uniqueCanvasCacheKeyCount;\n  uniqueCanvasCacheKeyCount += 1;\n  return key;\n}\n\n/**\n * @param {string} key The cache key for the canvas.\n * @return {WebGLRenderingContext} The canvas.\n */\nfunction getOrCreateContext(key) {\n  let cacheItem = canvasCache[key];\n  if (!cacheItem) {\n    const canvas = document.createElement('canvas');\n    canvas.width = 1;\n    canvas.height = 1;\n    canvas.style.position = 'absolute';\n    canvas.style.left = '0';\n    const context = getContext(canvas);\n    cacheItem = {users: 0, context};\n    canvasCache[key] = cacheItem;\n  }\n\n  cacheItem.users += 1;\n  return cacheItem.context;\n}\n\n/**\n * @param {string} key The cache key for the canvas.\n */\nfunction releaseCanvas(key) {\n  const cacheItem = canvasCache[key];\n  if (!cacheItem) {\n    return;\n  }\n\n  cacheItem.users -= 1;\n  if (cacheItem.users > 0) {\n    return;\n  }\n\n  const gl = cacheItem.context;\n  const extension = gl.getExtension('WEBGL_lose_context');\n  if (extension) {\n    extension.loseContext();\n  }\n  const canvas = gl.canvas;\n  canvas.width = 1;\n  canvas.height = 1;\n\n  delete canvasCache[key];\n}\n\n/**\n * @classdesc\n * This class is intended to provide low-level functions related to WebGL rendering, so that accessing\n * directly the WebGL API should not be required anymore.\n *\n * Several operations are handled by the `WebGLHelper` class:\n *\n * ### Define custom shaders and uniforms\n *\n *   Shaders* are low-level programs executed on the GPU and written in GLSL. There are two types of shaders:\n *\n *   Vertex shaders are used to manipulate the position and attribute of *vertices* of rendered primitives (ie. corners of a square).\n *   Outputs are:\n *\n *   `gl_Position`: position of the vertex in screen space\n *\n *   Varyings usually prefixed with `v_` are passed on to the fragment shader\n *\n *   Fragment shaders are used to control the actual color of the pixels drawn on screen. Their only output is `gl_FragColor`.\n *\n *   Both shaders can take *uniforms* or *attributes* as input. Attributes are explained later. Uniforms are common, read-only values that\n *   can be changed at every frame and can be of type float, arrays of float or images.\n *\n *   Shaders must be compiled and assembled into a program like so:\n *   ```js\n *   // here we simply create two shaders and assemble them in a program which is then used\n *   // for subsequent rendering calls; note how a frameState is required to set up a program,\n *   // as several default uniforms are computed from it (projection matrix, zoom level, etc.)\n *   const vertexShader = new WebGLVertex(VERTEX_SHADER);\n *   const fragmentShader = new WebGLFragment(FRAGMENT_SHADER);\n *   const program = this.context.getProgram(fragmentShader, vertexShader);\n *   helper.useProgram(this.program, frameState);\n *   ```\n *\n *   Uniforms are defined using the `uniforms` option and can either be explicit values or callbacks taking the frame state as argument.\n *   You can also change their value along the way like so:\n *   ```js\n *   helper.setUniformFloatValue('u_value', valueAsNumber);\n *   ```\n *\n * ### Defining post processing passes\n *\n *   Post processing* describes the act of rendering primitives to a texture, and then rendering this texture to the final canvas\n *   while applying special effects in screen space.\n *   Typical uses are: blurring, color manipulation, depth of field, filtering...\n *\n *   The `WebGLHelper` class offers the possibility to define post processes at creation time using the `postProcesses` option.\n *   A post process step accepts the following options:\n *\n *   `fragmentShader` and `vertexShader`: text literals in GLSL language that will be compiled and used in the post processing step.\n *   `uniforms`: uniforms can be defined for the post processing steps just like for the main render.\n *   `scaleRatio`: allows using an intermediate texture smaller or higher than the final canvas in the post processing step.\n *     This is typically used in blur steps to reduce the performance overhead by using an already downsampled texture as input.\n *\n *   The {@link module:ol/webgl/PostProcessingPass~WebGLPostProcessingPass} class is used internally, refer to its documentation for more info.\n *\n * ### Binding WebGL buffers and flushing data into them\n *\n *   Data that must be passed to the GPU has to be transferred using {@link module:ol/webgl/Buffer~WebGLArrayBuffer} objects.\n *   A buffer has to be created only once, but must be bound every time the buffer content will be used for rendering.\n *   This is done using {@link bindBuffer}.\n *   When the buffer's array content has changed, the new data has to be flushed to the GPU memory; this is done using\n *   {@link flushBufferData}. Note: this operation is expensive and should be done as infrequently as possible.\n *\n *   When binding an array buffer, a `target` parameter must be given: it should be either {@link module:ol/webgl.ARRAY_BUFFER}\n *   (if the buffer contains vertices data) or {@link module:ol/webgl.ELEMENT_ARRAY_BUFFER} (if the buffer contains indices data).\n *\n *   Examples below:\n *   ```js\n *   // at initialization phase\n *   const verticesBuffer = new WebGLArrayBuffer([], DYNAMIC_DRAW);\n *   const indicesBuffer = new WebGLArrayBuffer([], DYNAMIC_DRAW);\n *\n *   // when array values have changed\n *   helper.flushBufferData(ARRAY_BUFFER, this.verticesBuffer);\n *   helper.flushBufferData(ELEMENT_ARRAY_BUFFER, this.indicesBuffer);\n *\n *   // at rendering phase\n *   helper.bindBuffer(ARRAY_BUFFER, this.verticesBuffer);\n *   helper.bindBuffer(ELEMENT_ARRAY_BUFFER, this.indicesBuffer);\n *   ```\n *\n * ### Specifying attributes\n *\n *   The GPU only receives the data as arrays of numbers. These numbers must be handled differently depending on what it describes (position, texture coordinate...).\n *   Attributes are used to specify these uses. Specify the attribute names with\n *   {@link module:ol/webgl/Helper~WebGLHelper#enableAttributes} (see code snippet below).\n *\n *   Please note that you will have to specify the type and offset of the attributes in the data array. You can refer to the documentation of [WebGLRenderingContext.vertexAttribPointer](https://developer.mozilla.org/en-US/docs/Web/API/WebGLRenderingContext/vertexAttribPointer) for more explanation.\n *   ```js\n *   // here we indicate that the data array has the following structure:\n *   // [posX, posY, offsetX, offsetY, texCoordU, texCoordV, posX, posY, ...]\n *   helper.enableAttributes([\n *     {\n *        name: 'a_position',\n *        size: 2\n *     },\n *     {\n *       name: 'a_offset',\n *       size: 2\n *     },\n *     {\n *       name: 'a_texCoord',\n *       size: 2\n *     }\n *   ])\n *   ```\n *\n * ### Rendering primitives\n *\n *   Once all the steps above have been achieved, rendering primitives to the screen is done using {@link prepareDraw}, {@link drawElements} and {@link finalizeDraw}.\n *   ```js\n *   // frame preparation step\n *   helper.prepareDraw(frameState);\n *\n *   // call this for every data array that has to be rendered on screen\n *   helper.drawElements(0, this.indicesBuffer.getArray().length);\n *\n *   // finalize the rendering by applying post processes\n *   helper.finalizeDraw(frameState);\n *   ```\n *\n * For an example usage of this class, refer to {@link module:ol/renderer/webgl/PointsLayer~WebGLPointsLayerRenderer}.\n */\nclass WebGLHelper extends Disposable {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    super();\n    options = options || {};\n\n    /** @private */\n    this.boundHandleWebGLContextLost_ = this.handleWebGLContextLost.bind(this);\n\n    /** @private */\n    this.boundHandleWebGLContextRestored_ =\n      this.handleWebGLContextRestored.bind(this);\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.canvasCacheKey_ = options.canvasCacheKey\n      ? getSharedCanvasCacheKey(options.canvasCacheKey)\n      : getUniqueCanvasCacheKey();\n\n    /**\n     * @private\n     * @type {WebGLRenderingContext}\n     */\n    this.gl_ = getOrCreateContext(this.canvasCacheKey_);\n\n    /**\n     * @private\n     * @type {!Object<string, BufferCacheEntry>}\n     */\n    this.bufferCache_ = {};\n\n    /**\n     * @private\n     * @type {Object<string, Object>}\n     */\n    this.extensionCache_ = {};\n\n    /**\n     * @private\n     * @type {WebGLProgram}\n     */\n    this.currentProgram_ = null;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.needsToBeRecreated_ = false;\n\n    const canvas = this.gl_.canvas;\n\n    canvas.addEventListener(\n      ContextEventType.LOST,\n      this.boundHandleWebGLContextLost_,\n    );\n    canvas.addEventListener(\n      ContextEventType.RESTORED,\n      this.boundHandleWebGLContextRestored_,\n    );\n\n    /**\n     * @private\n     * @type {import(\"../transform.js\").Transform}\n     */\n    this.offsetRotateMatrix_ = createTransform();\n\n    /**\n     * @private\n     * @type {import(\"../transform.js\").Transform}\n     */\n    this.offsetScaleMatrix_ = createTransform();\n\n    /**\n     * @private\n     * @type {Array<number>}\n     */\n    this.tmpMat4_ = create();\n\n    /**\n     * @private\n     * @type {Object<string, Object<string, WebGLUniformLocation>>}\n     */\n    this.uniformLocationsByProgram_ = {};\n\n    /**\n     * @private\n     * @type {Object<string, Object<string, number>>}\n     */\n    this.attribLocationsByProgram_ = {};\n\n    /**\n     * Holds info about custom uniforms used in the post processing pass.\n     * If the uniform is a texture, the WebGL Texture object will be stored here.\n     * @type {Array<UniformInternalDescription>}\n     * @private\n     */\n    this.uniforms_ = [];\n    if (options.uniforms) {\n      this.setUniforms(options.uniforms);\n    }\n\n    /**\n     * An array of PostProcessingPass objects is kept in this variable, built from the steps provided in the\n     * options. If no post process was given, a default one is used (so as not to have to make an exception to\n     * the frame buffer logic).\n     * @type {Array<WebGLPostProcessingPass>}\n     * @private\n     */\n    this.postProcessPasses_ = options.postProcesses\n      ? options.postProcesses.map(\n          (options) =>\n            new WebGLPostProcessingPass({\n              webGlContext: this.gl_,\n              scaleRatio: options.scaleRatio,\n              vertexShader: options.vertexShader,\n              fragmentShader: options.fragmentShader,\n              uniforms: options.uniforms,\n            }),\n        )\n      : [new WebGLPostProcessingPass({webGlContext: this.gl_})];\n\n    /**\n     * @type {string|null}\n     * @private\n     */\n    this.shaderCompileErrors_ = null;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.startTime_ = Date.now();\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.maxAttributeCount_ = this.gl_.getParameter(\n      this.gl_.MAX_VERTEX_ATTRIBS,\n    );\n  }\n\n  /**\n   * @param {Object<string, UniformValue>} uniforms Uniform definitions.\n   */\n  setUniforms(uniforms) {\n    this.uniforms_ = [];\n    this.addUniforms(uniforms);\n  }\n\n  /**\n   * @param {Object<string, UniformValue>} uniforms Uniform definitions.\n   */\n  addUniforms(uniforms) {\n    for (const name in uniforms) {\n      this.uniforms_.push({\n        name: name,\n        value: uniforms[name],\n      });\n    }\n  }\n\n  /**\n   * @param {string} canvasCacheKey The canvas cache key.\n   * @return {boolean} The provided key matches the one this helper was constructed with.\n   */\n  canvasCacheKeyMatches(canvasCacheKey) {\n    return this.canvasCacheKey_ === getSharedCanvasCacheKey(canvasCacheKey);\n  }\n\n  /**\n   * Get a WebGL extension.  If the extension is not supported, null is returned.\n   * Extensions are cached after they are enabled for the first time.\n   * @param {string} name The extension name.\n   * @return {Object|null} The extension or null if not supported.\n   */\n  getExtension(name) {\n    if (name in this.extensionCache_) {\n      return this.extensionCache_[name];\n    }\n    const extension = this.gl_.getExtension(name);\n    this.extensionCache_[name] = extension;\n    return extension;\n  }\n\n  /**\n   * Will throw if the extension is not available\n   * @return {ANGLE_instanced_arrays} Extension\n   */\n  getInstancedRenderingExtension_() {\n    const ext = this.getExtension('ANGLE_instanced_arrays');\n    assert(\n      !!ext,\n      \"WebGL extension 'ANGLE_instanced_arrays' is required for vector rendering\",\n    );\n    return ext;\n  }\n\n  /**\n   * Just bind the buffer if it's in the cache. Otherwise create\n   * the WebGL buffer, bind it, populate it, and add an entry to\n   * the cache.\n   * @param {import(\"./Buffer.js\").default} buffer Buffer.\n   */\n  bindBuffer(buffer) {\n    const gl = this.gl_;\n    const bufferKey = getUid(buffer);\n    let bufferCache = this.bufferCache_[bufferKey];\n    if (!bufferCache) {\n      const webGlBuffer = gl.createBuffer();\n      bufferCache = {\n        buffer: buffer,\n        webGlBuffer: webGlBuffer,\n      };\n      this.bufferCache_[bufferKey] = bufferCache;\n    }\n    gl.bindBuffer(buffer.getType(), bufferCache.webGlBuffer);\n  }\n\n  /**\n   * Update the data contained in the buffer array; this is required for the\n   * new data to be rendered\n   * @param {import(\"./Buffer.js\").default} buffer Buffer.\n   */\n  flushBufferData(buffer) {\n    const gl = this.gl_;\n    this.bindBuffer(buffer);\n    gl.bufferData(buffer.getType(), buffer.getArray(), buffer.getUsage());\n  }\n\n  /**\n   * @param {import(\"./Buffer.js\").default} buf Buffer.\n   */\n  deleteBuffer(buf) {\n    const bufferKey = getUid(buf);\n    // Note: gl.deleteBuffer is not called here since we let WebGL garbage collect it automatically\n    delete this.bufferCache_[bufferKey];\n  }\n\n  /**\n   * Clean up.\n   * @override\n   */\n  disposeInternal() {\n    const canvas = this.gl_.canvas;\n    canvas.removeEventListener(\n      ContextEventType.LOST,\n      this.boundHandleWebGLContextLost_,\n    );\n    canvas.removeEventListener(\n      ContextEventType.RESTORED,\n      this.boundHandleWebGLContextRestored_,\n    );\n\n    releaseCanvas(this.canvasCacheKey_);\n\n    delete this.gl_;\n  }\n\n  /**\n   * Clear the buffer & set the viewport to draw.\n   * Post process passes will be initialized here, the first one being bound as a render target for\n   * subsequent draw calls.\n   * @param {import(\"../Map.js\").FrameState} frameState current frame state\n   * @param {boolean} [disableAlphaBlend] If true, no alpha blending will happen.\n   * @param {boolean} [enableDepth] If true, enables depth testing.\n   */\n  prepareDraw(frameState, disableAlphaBlend, enableDepth) {\n    const gl = this.gl_;\n    const canvas = this.getCanvas();\n    const size = frameState.size;\n    const pixelRatio = frameState.pixelRatio;\n\n    if (\n      canvas.width !== size[0] * pixelRatio ||\n      canvas.height !== size[1] * pixelRatio\n    ) {\n      canvas.width = size[0] * pixelRatio;\n      canvas.height = size[1] * pixelRatio;\n      canvas.style.width = size[0] + 'px';\n      canvas.style.height = size[1] + 'px';\n    }\n\n    // loop backwards in post processes list\n    for (let i = this.postProcessPasses_.length - 1; i >= 0; i--) {\n      this.postProcessPasses_[i].init(frameState);\n    }\n\n    gl.bindTexture(gl.TEXTURE_2D, null);\n\n    gl.clearColor(0.0, 0.0, 0.0, 0.0);\n    gl.depthRange(0.0, 1.0);\n    gl.clearDepth(1.0);\n    gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);\n\n    gl.enable(gl.BLEND);\n    gl.blendFunc(gl.ONE, disableAlphaBlend ? gl.ZERO : gl.ONE_MINUS_SRC_ALPHA);\n    if (enableDepth) {\n      gl.enable(gl.DEPTH_TEST);\n      gl.depthFunc(gl.LEQUAL);\n    } else {\n      gl.disable(gl.DEPTH_TEST);\n    }\n  }\n\n  /**\n   * @param {WebGLFramebuffer|null} frameBuffer The frame buffer.\n   * @param {WebGLTexture} [texture] The texture.\n   */\n  bindFrameBuffer(frameBuffer, texture) {\n    const gl = this.getGL();\n    gl.bindFramebuffer(gl.FRAMEBUFFER, frameBuffer);\n    if (texture) {\n      gl.framebufferTexture2D(\n        gl.FRAMEBUFFER,\n        gl.COLOR_ATTACHMENT0,\n        gl.TEXTURE_2D,\n        texture,\n        0,\n      );\n    }\n  }\n\n  /**\n   * Bind the frame buffer from the initial render.\n   */\n  bindInitialFrameBuffer() {\n    const gl = this.getGL();\n    const frameBuffer = this.postProcessPasses_[0].getFrameBuffer();\n    gl.bindFramebuffer(gl.FRAMEBUFFER, frameBuffer);\n    const texture = this.postProcessPasses_[0].getRenderTargetTexture();\n    gl.framebufferTexture2D(\n      gl.FRAMEBUFFER,\n      gl.COLOR_ATTACHMENT0,\n      gl.TEXTURE_2D,\n      texture,\n      0,\n    );\n  }\n\n  /**\n   * Prepare a program to use a texture.\n   * @param {WebGLTexture} texture The texture.\n   * @param {number} slot The texture slot.\n   * @param {string} uniformName The corresponding uniform name.\n   */\n  bindTexture(texture, slot, uniformName) {\n    const gl = this.gl_;\n    gl.activeTexture(gl.TEXTURE0 + slot);\n    gl.bindTexture(gl.TEXTURE_2D, texture);\n    gl.uniform1i(this.getUniformLocation(uniformName), slot);\n  }\n\n  /**\n   * Set up an attribute array buffer for use in the vertex shader.\n   * @param {import(\"./Buffer.js\").default} buffer The buffer.\n   * @param {string} attributeName The attribute name.\n   * @param {number} size The number of components per attribute vertex.\n   */\n  bindAttribute(buffer, attributeName, size) {\n    const gl = this.getGL();\n    this.bindBuffer(buffer);\n    const index = this.getAttributeLocation(attributeName);\n    gl.enableVertexAttribArray(index);\n    gl.vertexAttribPointer(index, size, gl.FLOAT, false, 0, 0);\n  }\n\n  /**\n   * Clear the render target & bind it for future draw operations.\n   * This is similar to `prepareDraw`, only post processes will not be applied.\n   * Note: the whole viewport will be drawn to the render target, regardless of its size.\n   * @param {import(\"../Map.js\").FrameState} frameState current frame state\n   * @param {import(\"./RenderTarget.js\").default} renderTarget Render target to draw to\n   * @param {boolean} [disableAlphaBlend] If true, no alpha blending will happen.\n   * @param {boolean} [enableDepth] If true, enables depth testing.\n   */\n  prepareDrawToRenderTarget(\n    frameState,\n    renderTarget,\n    disableAlphaBlend,\n    enableDepth,\n  ) {\n    const gl = this.gl_;\n    const size = renderTarget.getSize();\n\n    gl.bindFramebuffer(gl.FRAMEBUFFER, renderTarget.getFramebuffer());\n    gl.bindRenderbuffer(gl.RENDERBUFFER, renderTarget.getDepthbuffer());\n    gl.viewport(0, 0, size[0], size[1]);\n    gl.bindTexture(gl.TEXTURE_2D, renderTarget.getTexture());\n    gl.clearColor(0.0, 0.0, 0.0, 0.0);\n    gl.depthRange(0.0, 1.0);\n    gl.clearDepth(1.0);\n    gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);\n    gl.enable(gl.BLEND);\n    gl.blendFunc(gl.ONE, disableAlphaBlend ? gl.ZERO : gl.ONE_MINUS_SRC_ALPHA);\n    if (enableDepth) {\n      gl.enable(gl.DEPTH_TEST);\n      gl.depthFunc(gl.LEQUAL);\n    } else {\n      gl.disable(gl.DEPTH_TEST);\n    }\n  }\n\n  /**\n   * Execute a draw call based on the currently bound program, texture, buffers, attributes.\n   * @param {number} start Start index.\n   * @param {number} end End index.\n   */\n  drawElements(start, end) {\n    const gl = this.gl_;\n    this.getExtension('OES_element_index_uint');\n\n    const elementType = gl.UNSIGNED_INT;\n    const elementSize = 4;\n\n    const numItems = end - start;\n    const offsetInBytes = start * elementSize;\n    gl.drawElements(gl.TRIANGLES, numItems, elementType, offsetInBytes);\n  }\n\n  /**\n   * Execute a draw call similar to `drawElements`, but using instanced rendering.\n   * Will have no effect if `enableAttributesInstanced` was not called for this rendering pass.\n   * @param {number} start Start index.\n   * @param {number} end End index.\n   * @param {number} instanceCount The number of instances to render\n   */\n  drawElementsInstanced(start, end, instanceCount) {\n    const gl = this.gl_;\n    this.getExtension('OES_element_index_uint');\n    const ext = this.getInstancedRenderingExtension_();\n\n    const elementType = gl.UNSIGNED_INT;\n    const elementSize = 4;\n\n    const numItems = end - start;\n    const offsetInBytes = start * elementSize;\n    ext.drawElementsInstancedANGLE(\n      gl.TRIANGLES,\n      numItems,\n      elementType,\n      offsetInBytes,\n      instanceCount,\n    );\n\n    // reset divisor values to avoid side effects\n    for (let i = 0; i < this.maxAttributeCount_; i++) {\n      ext.vertexAttribDivisorANGLE(i, 0);\n    }\n  }\n\n  /**\n   * Apply the successive post process passes which will eventually render to the actual canvas.\n   * @param {import(\"../Map.js\").FrameState} frameState current frame state\n   * @param {function(WebGLRenderingContext, import(\"../Map.js\").FrameState):void} [preCompose] Called before composing.\n   * @param {function(WebGLRenderingContext, import(\"../Map.js\").FrameState):void} [postCompose] Called before composing.\n   */\n  finalizeDraw(frameState, preCompose, postCompose) {\n    // apply post processes using the next one as target\n    for (let i = 0, ii = this.postProcessPasses_.length; i < ii; i++) {\n      if (i === ii - 1) {\n        this.postProcessPasses_[i].apply(\n          frameState,\n          null,\n          preCompose,\n          postCompose,\n        );\n      } else {\n        this.postProcessPasses_[i].apply(\n          frameState,\n          this.postProcessPasses_[i + 1],\n        );\n      }\n    }\n  }\n\n  /**\n   * @return {HTMLCanvasElement} Canvas.\n   */\n  getCanvas() {\n    return /** @type {HTMLCanvasElement} */ (this.gl_.canvas);\n  }\n\n  /**\n   * Get the WebGL rendering context\n   * @return {WebGLRenderingContext} The rendering context.\n   */\n  getGL() {\n    return this.gl_;\n  }\n\n  /**\n   * Sets the default matrix uniforms for a given frame state. This is called internally in `prepareDraw`.\n   * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n   */\n  applyFrameState(frameState) {\n    const size = frameState.size;\n    const rotation = frameState.viewState.rotation;\n    const pixelRatio = frameState.pixelRatio;\n\n    this.setUniformFloatValue(\n      DefaultUniform.TIME,\n      (Date.now() - this.startTime_) * 0.001,\n    );\n    this.setUniformFloatValue(DefaultUniform.ZOOM, frameState.viewState.zoom);\n    this.setUniformFloatValue(\n      DefaultUniform.RESOLUTION,\n      frameState.viewState.resolution,\n    );\n    this.setUniformFloatValue(DefaultUniform.PIXEL_RATIO, pixelRatio);\n    this.setUniformFloatVec2(DefaultUniform.VIEWPORT_SIZE_PX, [\n      size[0],\n      size[1],\n    ]);\n    this.setUniformFloatValue(DefaultUniform.ROTATION, rotation);\n  }\n\n  /**\n   * Sets the `u_hitDetection` uniform.\n   * @param {boolean} enabled Whether to enable the hit detection code path\n   */\n  applyHitDetectionUniform(enabled) {\n    const loc = this.getUniformLocation(DefaultUniform.HIT_DETECTION);\n    this.getGL().uniform1i(loc, enabled ? 1 : 0);\n\n    // hit detection uses a fixed pixel ratio\n    if (enabled) {\n      this.setUniformFloatValue(DefaultUniform.PIXEL_RATIO, 0.5);\n    }\n  }\n\n  /**\n   * Sets the custom uniforms based on what was given in the constructor. This is called internally in `prepareDraw`.\n   * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n   */\n  applyUniforms(frameState) {\n    const gl = this.gl_;\n\n    let value;\n    let textureSlot = 0;\n    this.uniforms_.forEach((uniform) => {\n      value =\n        typeof uniform.value === 'function'\n          ? uniform.value(frameState)\n          : uniform.value;\n\n      // apply value based on type\n      if (\n        value instanceof HTMLCanvasElement ||\n        value instanceof HTMLImageElement ||\n        value instanceof ImageData ||\n        value instanceof WebGLTexture\n      ) {\n        // create a texture & put data\n        if (value instanceof WebGLTexture && !uniform.texture) {\n          uniform.prevValue = undefined;\n          uniform.texture = value;\n        } else if (!uniform.texture) {\n          uniform.prevValue = undefined;\n          uniform.texture = gl.createTexture();\n        }\n        this.bindTexture(uniform.texture, textureSlot, uniform.name);\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n        gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n\n        const imageReady =\n          !(value instanceof HTMLImageElement) ||\n          /** @type {HTMLImageElement} */ (value).complete;\n        if (\n          !(value instanceof WebGLTexture) &&\n          imageReady &&\n          uniform.prevValue !== value\n        ) {\n          uniform.prevValue = value;\n          gl.texImage2D(\n            gl.TEXTURE_2D,\n            0,\n            gl.RGBA,\n            gl.RGBA,\n            gl.UNSIGNED_BYTE,\n            value,\n          );\n        }\n        textureSlot++;\n      } else if (Array.isArray(value) && value.length === 6) {\n        this.setUniformMatrixValue(\n          uniform.name,\n          fromTransform(this.tmpMat4_, value),\n        );\n      } else if (Array.isArray(value) && value.length <= 4) {\n        switch (value.length) {\n          case 2:\n            gl.uniform2f(\n              this.getUniformLocation(uniform.name),\n              value[0],\n              value[1],\n            );\n            return;\n          case 3:\n            gl.uniform3f(\n              this.getUniformLocation(uniform.name),\n              value[0],\n              value[1],\n              value[2],\n            );\n            return;\n          case 4:\n            gl.uniform4f(\n              this.getUniformLocation(uniform.name),\n              value[0],\n              value[1],\n              value[2],\n              value[3],\n            );\n            return;\n          default:\n            return;\n        }\n      } else if (typeof value === 'number') {\n        gl.uniform1f(this.getUniformLocation(uniform.name), value);\n      }\n    });\n  }\n\n  /**\n   * Set up a program for use. The program will be set as the current one. Then, the uniforms used\n   * in the program will be set based on the current frame state and the helper configuration.\n   * @param {WebGLProgram} program Program.\n   * @param {import(\"../Map.js\").FrameState} [frameState] Frame state.\n   */\n  useProgram(program, frameState) {\n    this.disableAllAttributes_();\n    const gl = this.gl_;\n    gl.useProgram(program);\n    this.currentProgram_ = program;\n    if (frameState) {\n      this.applyFrameState(frameState);\n      this.applyUniforms(frameState);\n    }\n  }\n\n  /**\n   * Will attempt to compile a vertex or fragment shader based on source\n   * On error, the shader will be returned but\n   * `gl.getShaderParameter(shader, gl.COMPILE_STATUS)` will return `true`\n   * Use `gl.getShaderInfoLog(shader)` to have details\n   * @param {string} source Shader source\n   * @param {ShaderType} type VERTEX_SHADER or FRAGMENT_SHADER\n   * @return {WebGLShader} Shader object\n   */\n  compileShader(source, type) {\n    const gl = this.gl_;\n    const shader = gl.createShader(type);\n    gl.shaderSource(shader, source);\n    gl.compileShader(shader);\n    return shader;\n  }\n\n  /**\n   * Create a program for a vertex and fragment shader.  Throws if shader compilation fails.\n   * @param {string} fragmentShaderSource Fragment shader source.\n   * @param {string} vertexShaderSource Vertex shader source.\n   * @return {WebGLProgram} Program\n   */\n  getProgram(fragmentShaderSource, vertexShaderSource) {\n    const gl = this.gl_;\n\n    const fragmentShader = this.compileShader(\n      fragmentShaderSource,\n      gl.FRAGMENT_SHADER,\n    );\n\n    const vertexShader = this.compileShader(\n      vertexShaderSource,\n      gl.VERTEX_SHADER,\n    );\n\n    const program = gl.createProgram();\n    gl.attachShader(program, fragmentShader);\n    gl.attachShader(program, vertexShader);\n    gl.linkProgram(program);\n\n    if (!gl.getShaderParameter(fragmentShader, gl.COMPILE_STATUS)) {\n      const message = `Fragment shader compilation failed: ${gl.getShaderInfoLog(\n        fragmentShader,\n      )}`;\n      throw new Error(message);\n    }\n    gl.deleteShader(fragmentShader);\n\n    if (!gl.getShaderParameter(vertexShader, gl.COMPILE_STATUS)) {\n      const message = `Vertex shader compilation failed: ${gl.getShaderInfoLog(\n        vertexShader,\n      )}`;\n      throw new Error(message);\n    }\n    gl.deleteShader(vertexShader);\n\n    if (!gl.getProgramParameter(program, gl.LINK_STATUS)) {\n      const message = `GL program linking failed: ${gl.getProgramInfoLog(\n        program,\n      )}`;\n      throw new Error(message);\n    }\n\n    return program;\n  }\n\n  /**\n   * Will get the location from the shader or the cache\n   * @param {string} name Uniform name\n   * @return {WebGLUniformLocation} uniformLocation\n   */\n  getUniformLocation(name) {\n    const programUid = getUid(this.currentProgram_);\n    if (this.uniformLocationsByProgram_[programUid] === undefined) {\n      this.uniformLocationsByProgram_[programUid] = {};\n    }\n    if (this.uniformLocationsByProgram_[programUid][name] === undefined) {\n      this.uniformLocationsByProgram_[programUid][name] =\n        this.gl_.getUniformLocation(this.currentProgram_, name);\n    }\n    return this.uniformLocationsByProgram_[programUid][name];\n  }\n\n  /**\n   * Will get the location from the shader or the cache\n   * @param {string} name Attribute name\n   * @return {number} attribLocation\n   */\n  getAttributeLocation(name) {\n    const programUid = getUid(this.currentProgram_);\n    if (this.attribLocationsByProgram_[programUid] === undefined) {\n      this.attribLocationsByProgram_[programUid] = {};\n    }\n    if (this.attribLocationsByProgram_[programUid][name] === undefined) {\n      this.attribLocationsByProgram_[programUid][name] =\n        this.gl_.getAttribLocation(this.currentProgram_, name);\n    }\n    return this.attribLocationsByProgram_[programUid][name];\n  }\n\n  /**\n   * Sets the given transform to apply the rotation/translation/scaling of the given frame state.\n   * The resulting transform can be used to convert world space coordinates to view coordinates in the [-1, 1] range.\n   * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n   * @param {import(\"../transform.js\").Transform} transform Transform to update.\n   * @return {import(\"../transform.js\").Transform} The updated transform object.\n   */\n  makeProjectionTransform(frameState, transform) {\n    const size = frameState.size;\n    const rotation = frameState.viewState.rotation;\n    const resolution = frameState.viewState.resolution;\n    const center = frameState.viewState.center;\n    composeTransform(\n      transform,\n      0,\n      0,\n      2 / (resolution * size[0]),\n      2 / (resolution * size[1]),\n      -rotation,\n      -center[0],\n      -center[1],\n    );\n    return transform;\n  }\n\n  /**\n   * Give a value for a standard float uniform\n   * @param {string} uniform Uniform name\n   * @param {number} value Value\n   */\n  setUniformFloatValue(uniform, value) {\n    this.gl_.uniform1f(this.getUniformLocation(uniform), value);\n  }\n\n  /**\n   * Give a value for a vec2 uniform\n   * @param {string} uniform Uniform name\n   * @param {Array<number>} value Array of length 4.\n   */\n  setUniformFloatVec2(uniform, value) {\n    this.gl_.uniform2fv(this.getUniformLocation(uniform), value);\n  }\n\n  /**\n   * Give a value for a vec4 uniform\n   * @param {string} uniform Uniform name\n   * @param {Array<number>} value Array of length 4.\n   */\n  setUniformFloatVec4(uniform, value) {\n    this.gl_.uniform4fv(this.getUniformLocation(uniform), value);\n  }\n\n  /**\n   * Give a value for a standard matrix4 uniform\n   * @param {string} uniform Uniform name\n   * @param {Array<number>} value Matrix value\n   */\n  setUniformMatrixValue(uniform, value) {\n    this.gl_.uniformMatrix4fv(this.getUniformLocation(uniform), false, value);\n  }\n\n  /**\n   * Disable all vertex attributes.\n   * @private\n   */\n  disableAllAttributes_() {\n    for (let i = 0; i < this.maxAttributeCount_; i++) {\n      this.gl_.disableVertexAttribArray(i);\n    }\n  }\n\n  /**\n   * Will set the currently bound buffer to an attribute of the shader program. Used by `#enableAttributes`\n   * internally.\n   * @param {string} attribName Attribute name\n   * @param {number} size Number of components per attributes\n   * @param {number} type UNSIGNED_INT, UNSIGNED_BYTE, UNSIGNED_SHORT or FLOAT\n   * @param {number} stride Stride in bytes (0 means attribs are packed)\n   * @param {number} offset Offset in bytes\n   * @param {boolean} instanced Whether the attribute is used for instanced rendering\n   * @private\n   */\n  enableAttributeArray_(attribName, size, type, stride, offset, instanced) {\n    const location = this.getAttributeLocation(attribName);\n    // the attribute has not been found in the shaders or is not used; do not enable it\n    if (location < 0) {\n      return;\n    }\n    this.gl_.enableVertexAttribArray(location);\n    this.gl_.vertexAttribPointer(location, size, type, false, stride, offset);\n    if (instanced) {\n      // note: this is reset to 0 after drawElementsInstanced is called\n      this.getInstancedRenderingExtension_().vertexAttribDivisorANGLE(\n        location,\n        1,\n      );\n    }\n  }\n\n  /**\n   * @private\n   * @param {Array<AttributeDescription>} attributes Ordered list of attributes to read from the buffer\n   * @param {boolean} instanced Whether the attributes are instanced.\n   */\n  enableAttributes_(attributes, instanced) {\n    const stride = computeAttributesStride(attributes);\n    let offset = 0;\n    for (let i = 0; i < attributes.length; i++) {\n      const attr = attributes[i];\n      // if a name is not given, simply skip this slot in the buffer\n      if (attr.name) {\n        this.enableAttributeArray_(\n          attr.name,\n          attr.size,\n          attr.type || FLOAT,\n          stride,\n          offset,\n          instanced,\n        );\n      }\n      offset += attr.size * getByteSizeFromType(attr.type);\n    }\n  }\n\n  /**\n   * Will enable the following attributes to be read from the currently bound buffer,\n   * i.e. tell the GPU where to read the different attributes in the buffer. An error in the\n   * size/type/order of attributes will most likely break the rendering and throw a WebGL exception.\n   * @param {Array<AttributeDescription>} attributes Ordered list of attributes to read from the buffer\n   */\n  enableAttributes(attributes) {\n    this.enableAttributes_(attributes, false);\n  }\n\n  /**\n   * Will enable these attributes as instanced, meaning that they will only be read\n   * once per instance instead of per vertex.\n   * @param {Array<AttributeDescription>} attributes Ordered list of attributes to read from the buffer\n   */\n  enableAttributesInstanced(attributes) {\n    this.enableAttributes_(attributes, true);\n  }\n\n  /**\n   * WebGL context was lost\n   * @param {WebGLContextEvent} event The context loss event.\n   * @private\n   */\n  handleWebGLContextLost(event) {\n    clear(this.bufferCache_);\n    this.currentProgram_ = null;\n\n    event.preventDefault();\n  }\n\n  /**\n   * WebGL context was restored\n   * @private\n   */\n  handleWebGLContextRestored() {\n    this.needsToBeRecreated_ = true;\n  }\n\n  /**\n   * Returns whether this helper needs to be recreated, as the context was lost and then restored.\n   * @return {boolean} Whether this helper needs to be recreated.\n   */\n  needsToBeRecreated() {\n    return this.needsToBeRecreated_;\n  }\n\n  /**\n   * Will create or reuse a given webgl texture and apply the given size. If no image data\n   * specified, the texture will be empty, otherwise image data will be used and the `size`\n   * parameter will be ignored.  If a Uint8Array is provided for data, a size must also be provided.\n   * Note: wrap parameters are set to clamp to edge, min filter is set to linear.\n   * @param {Array<number>} size Expected size of the texture\n   * @param {ImageData|HTMLImageElement|HTMLCanvasElement|Uint8Array|null} data Image data/object to bind to the texture\n   * @param {WebGLTexture} [texture] Existing texture to reuse\n   * @param {boolean} [nearest] Use gl.NEAREST for min/mag filter.\n   * @return {WebGLTexture} The generated texture\n   */\n  createTexture(size, data, texture, nearest) {\n    const gl = this.gl_;\n    texture = texture || gl.createTexture();\n    const filter = nearest ? gl.NEAREST : gl.LINEAR;\n\n    gl.bindTexture(gl.TEXTURE_2D, texture);\n\n    gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, filter);\n    gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, filter);\n    gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n    gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n\n    const level = 0;\n    const internalFormat = gl.RGBA;\n    const border = 0;\n    const format = gl.RGBA;\n    const type = gl.UNSIGNED_BYTE;\n\n    if (data instanceof Uint8Array) {\n      gl.texImage2D(\n        gl.TEXTURE_2D,\n        level,\n        internalFormat,\n        size[0],\n        size[1],\n        border,\n        format,\n        type,\n        data,\n      );\n    } else if (data) {\n      gl.texImage2D(gl.TEXTURE_2D, level, internalFormat, format, type, data);\n    } else {\n      gl.texImage2D(\n        gl.TEXTURE_2D,\n        level,\n        internalFormat,\n        size[0],\n        size[1],\n        border,\n        format,\n        type,\n        null,\n      );\n    }\n    return texture;\n  }\n}\n\n/**\n * Compute a stride in bytes based on a list of attributes\n * @param {Array<AttributeDescription>} attributes Ordered list of attributes\n * @return {number} Stride, ie amount of values for each vertex in the vertex buffer\n */\nexport function computeAttributesStride(attributes) {\n  let stride = 0;\n  for (let i = 0; i < attributes.length; i++) {\n    const attr = attributes[i];\n    stride += attr.size * getByteSizeFromType(attr.type);\n  }\n  return stride;\n}\n\n/**\n * Computes the size in byte of an attribute type.\n * @param {AttributeType} type Attribute type\n * @return {number} The size in bytes\n */\nfunction getByteSizeFromType(type) {\n  switch (type) {\n    case AttributeType.UNSIGNED_BYTE:\n      return Uint8Array.BYTES_PER_ELEMENT;\n    case AttributeType.UNSIGNED_SHORT:\n      return Uint16Array.BYTES_PER_ELEMENT;\n    case AttributeType.UNSIGNED_INT:\n      return Uint32Array.BYTES_PER_ELEMENT;\n    case AttributeType.FLOAT:\n    default:\n      return Float32Array.BYTES_PER_ELEMENT;\n  }\n}\n\nexport default WebGLHelper;\n","/**\n * @module ol/renderer/webgl/Layer\n */\nimport LayerProperty from '../../layer/Property.js';\nimport RenderEvent from '../../render/Event.js';\nimport RenderEventType from '../../render/EventType.js';\nimport {\n  compose as composeTransform,\n  create as createTransform,\n} from '../../transform.js';\nimport WebGLHelper from '../../webgl/Helper.js';\nimport LayerRenderer from '../Layer.js';\n\n/**\n * @typedef {Object} PostProcessesOptions\n * @property {number} [scaleRatio] Scale ratio; if < 1, the post process will render to a texture smaller than\n * the main canvas that will then be sampled up (useful for saving resource on blur steps).\n * @property {string} [vertexShader] Vertex shader source\n * @property {string} [fragmentShader] Fragment shader source\n * @property {Object<string,import(\"../../webgl/Helper.js\").UniformValue>} [uniforms] Uniform definitions for the post process step\n */\n\n/**\n * @typedef {Object} Options\n * @property {Object<string,import(\"../../webgl/Helper.js\").UniformValue>} [uniforms] Uniform definitions for the post process steps\n * @property {Array<PostProcessesOptions>} [postProcesses] Post-processes definitions\n */\n\n/**\n * @classdesc\n * Base WebGL renderer class.\n * Holds all logic related to data manipulation & some common rendering logic\n * @template {import(\"../../layer/Layer.js\").default} LayerType\n * @extends {LayerRenderer<LayerType>}\n */\nclass WebGLLayerRenderer extends LayerRenderer {\n  /**\n   * @param {LayerType} layer Layer.\n   * @param {Options} [options] Options.\n   */\n  constructor(layer, options) {\n    super(layer);\n\n    options = options || {};\n\n    /**\n     * The transform for viewport CSS pixels to rendered pixels.  This transform is only\n     * set before dispatching rendering events.\n     * @private\n     * @type {import(\"../../transform.js\").Transform}\n     */\n    this.inversePixelTransform_ = createTransform();\n\n    /**\n     * @private\n     */\n    this.postProcesses_ = options.postProcesses;\n\n    /**\n     * @private\n     */\n    this.uniforms_ = options.uniforms;\n\n    /**\n     * @type {WebGLHelper}\n     * @protected\n     */\n    this.helper;\n\n    this.onMapChanged_ = () => {\n      this.clearCache();\n      this.removeHelper();\n    };\n\n    layer.addChangeListener(LayerProperty.MAP, this.onMapChanged_);\n\n    this.dispatchPreComposeEvent = this.dispatchPreComposeEvent.bind(this);\n    this.dispatchPostComposeEvent = this.dispatchPostComposeEvent.bind(this);\n  }\n\n  /**\n   * @param {WebGLRenderingContext} context The WebGL rendering context.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @protected\n   */\n  dispatchPreComposeEvent(context, frameState) {\n    const layer = this.getLayer();\n    if (layer.hasListener(RenderEventType.PRECOMPOSE)) {\n      const event = new RenderEvent(\n        RenderEventType.PRECOMPOSE,\n        undefined,\n        frameState,\n        context,\n      );\n      layer.dispatchEvent(event);\n    }\n  }\n\n  /**\n   * @param {WebGLRenderingContext} context The WebGL rendering context.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @protected\n   */\n  dispatchPostComposeEvent(context, frameState) {\n    const layer = this.getLayer();\n    if (layer.hasListener(RenderEventType.POSTCOMPOSE)) {\n      const event = new RenderEvent(\n        RenderEventType.POSTCOMPOSE,\n        undefined,\n        frameState,\n        context,\n      );\n      layer.dispatchEvent(event);\n    }\n  }\n\n  /**\n   * Reset options (only handles uniforms).\n   * @param {Options} options Options.\n   */\n  reset(options) {\n    this.uniforms_ = options.uniforms;\n    if (this.helper) {\n      this.helper.setUniforms(this.uniforms_);\n    }\n  }\n\n  /**\n   * @protected\n   */\n  removeHelper() {\n    if (this.helper) {\n      this.helper.dispose();\n      delete this.helper;\n    }\n  }\n\n  /**\n   * Determine whether renderFrame should be called.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @return {boolean} Layer is ready to be rendered.\n   * @override\n   */\n  prepareFrame(frameState) {\n    if (this.getLayer().getRenderSource()) {\n      let incrementGroup = true;\n      let groupNumber = -1;\n      let className;\n      for (let i = 0, ii = frameState.layerStatesArray.length; i < ii; i++) {\n        const layer = frameState.layerStatesArray[i].layer;\n        const renderer = layer.getRenderer();\n        if (!(renderer instanceof WebGLLayerRenderer)) {\n          incrementGroup = true;\n          continue;\n        }\n        const layerClassName = layer.getClassName();\n        if (incrementGroup || layerClassName !== className) {\n          groupNumber += 1;\n          incrementGroup = false;\n        }\n        className = layerClassName;\n        if (renderer === this) {\n          break;\n        }\n      }\n\n      const canvasCacheKey =\n        'map/' + frameState.mapId + '/group/' + groupNumber;\n\n      if (\n        !this.helper ||\n        !this.helper.canvasCacheKeyMatches(canvasCacheKey) ||\n        this.helper.needsToBeRecreated()\n      ) {\n        this.removeHelper();\n\n        this.helper = new WebGLHelper({\n          postProcesses: this.postProcesses_,\n          uniforms: this.uniforms_,\n          canvasCacheKey: canvasCacheKey,\n        });\n\n        if (className) {\n          this.helper.getCanvas().className = className;\n        }\n\n        this.afterHelperCreated();\n      }\n    }\n\n    return this.prepareFrameInternal(frameState);\n  }\n\n  /**\n   * @protected\n   */\n  afterHelperCreated() {}\n\n  /**\n   * Determine whether renderFrame should be called.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @return {boolean} Layer is ready to be rendered.\n   * @protected\n   */\n  prepareFrameInternal(frameState) {\n    return true;\n  }\n\n  /**\n   * @protected\n   */\n  clearCache() {}\n\n  /**\n   * Clean up.\n   * @override\n   */\n  disposeInternal() {\n    this.clearCache();\n    this.removeHelper();\n    this.getLayer()?.removeChangeListener(\n      LayerProperty.MAP,\n      this.onMapChanged_,\n    );\n    super.disposeInternal();\n  }\n\n  /**\n   * @param {import(\"../../render/EventType.js\").default} type Event type.\n   * @param {WebGLRenderingContext} context The rendering context.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @private\n   */\n  dispatchRenderEvent_(type, context, frameState) {\n    const layer = this.getLayer();\n    if (layer.hasListener(type)) {\n      composeTransform(\n        this.inversePixelTransform_,\n        0,\n        0,\n        frameState.pixelRatio,\n        -frameState.pixelRatio,\n        0,\n        0,\n        -frameState.size[1],\n      );\n\n      const event = new RenderEvent(\n        type,\n        this.inversePixelTransform_,\n        frameState,\n        context,\n      );\n      layer.dispatchEvent(event);\n    }\n  }\n\n  /**\n   * @param {WebGLRenderingContext} context The rendering context.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @protected\n   */\n  preRender(context, frameState) {\n    this.dispatchRenderEvent_(RenderEventType.PRERENDER, context, frameState);\n  }\n\n  /**\n   * @param {WebGLRenderingContext} context The rendering context.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @protected\n   */\n  postRender(context, frameState) {\n    this.dispatchRenderEvent_(RenderEventType.POSTRENDER, context, frameState);\n  }\n}\n\nexport default WebGLLayerRenderer;\n","/**\n * @module ol/renderer/webgl/TileLayer\n */\nimport TileState from '../../TileState.js';\nimport {\n  boundingExtent,\n  containsCoordinate,\n  getIntersection,\n} from '../../extent.js';\nimport {fromUserExtent} from '../../proj.js';\nimport {toSize} from '../../size.js';\nimport {\n  apply as applyTransform,\n  reset as resetTransform,\n  translate as translateTransform,\n} from '../../transform.js';\nimport {fromTransform as mat4FromTransform} from '../../vec/mat4.js';\nimport {ELEMENT_ARRAY_BUFFER, STATIC_DRAW} from '../../webgl.js';\nimport WebGLArrayBuffer from '../../webgl/Buffer.js';\nimport {AttributeType} from '../../webgl/Helper.js';\nimport TileTexture from '../../webgl/TileTexture.js';\nimport WebGLBaseTileLayerRenderer, {\n  Uniforms as BaseUniforms,\n  getCacheKey,\n} from './TileLayerBase.js';\n\nexport const Uniforms = {\n  ...BaseUniforms,\n  TILE_TEXTURE_ARRAY: 'u_tileTextures',\n  TEXTURE_PIXEL_WIDTH: 'u_texturePixelWidth',\n  TEXTURE_PIXEL_HEIGHT: 'u_texturePixelHeight',\n  TEXTURE_RESOLUTION: 'u_textureResolution', // map units per texture pixel\n};\n\nexport const Attributes = {\n  TEXTURE_COORD: 'a_textureCoord',\n};\n\n/**\n * @type {Array<import('../../webgl/Helper.js').AttributeDescription>}\n */\nconst attributeDescriptions = [\n  {\n    name: Attributes.TEXTURE_COORD,\n    size: 2,\n    type: AttributeType.FLOAT,\n  },\n];\n\n/**\n * @typedef {Object} Options\n * @property {string} vertexShader Vertex shader source.\n * @property {string} fragmentShader Fragment shader source.\n * @property {Object<string, import(\"../../webgl/Helper.js\").UniformValue>} [uniforms] Additional uniforms\n * made available to shaders.\n * @property {Array<import(\"../../webgl/PaletteTexture.js\").default>} [paletteTextures] Palette textures.\n * @property {number} [cacheSize=512] The texture cache size.\n * @property {Array<import('./Layer.js').PostProcessesOptions>} [postProcesses] Post-processes definitions.\n */\n\n/**\n * @typedef {import(\"../../webgl/TileTexture.js\").TileType} TileTextureType\n */\n\n/**\n * @typedef {import(\"../../webgl/TileTexture.js\").default} TileTextureRepresentation\n */\n\n/**\n * @classdesc\n * WebGL renderer for tile layers.\n * @template {import(\"../../layer/WebGLTile.js\").default|import(\"../../layer/Flow.js\").default} LayerType\n * @extends {WebGLBaseTileLayerRenderer<LayerType, TileTextureType, TileTextureRepresentation>}\n * @api\n */\nclass WebGLTileLayerRenderer extends WebGLBaseTileLayerRenderer {\n  /**\n   * @param {LayerType} tileLayer Tile layer.\n   * @param {Options} options Options.\n   */\n  constructor(tileLayer, options) {\n    super(tileLayer, options);\n\n    /**\n     * @type {WebGLProgram}\n     * @private\n     */\n    this.program_;\n\n    /**\n     * @private\n     */\n    this.vertexShader_ = options.vertexShader;\n\n    /**\n     * @private\n     */\n    this.fragmentShader_ = options.fragmentShader;\n\n    /**\n     * Tiles are rendered as a quad with the following structure:\n     *\n     *  [P3]---------[P2]\n     *   |`           |\n     *   |  `     B   |\n     *   |    `       |\n     *   |      `     |\n     *   |   A    `   |\n     *   |          ` |\n     *  [P0]---------[P1]\n     *\n     * Triangle A: P0, P1, P3\n     * Triangle B: P1, P2, P3\n     *\n     * @private\n     */\n    this.indices_ = new WebGLArrayBuffer(ELEMENT_ARRAY_BUFFER, STATIC_DRAW);\n    this.indices_.fromArray([0, 1, 3, 1, 2, 3]);\n\n    /**\n     * @type {Array<import(\"../../webgl/PaletteTexture.js\").default>}\n     * @private\n     */\n    this.paletteTextures_ = options.paletteTextures || [];\n  }\n\n  /**\n   * @param {Options} options Options.\n   * @override\n   */\n  reset(options) {\n    super.reset(options);\n    if (this.helper) {\n      const gl = this.helper.getGL();\n      for (const paletteTexture of this.paletteTextures_) {\n        paletteTexture.delete(gl);\n      }\n    }\n\n    this.vertexShader_ = options.vertexShader;\n    this.fragmentShader_ = options.fragmentShader;\n    this.paletteTextures_ = options.paletteTextures || [];\n\n    if (this.helper) {\n      this.program_ = this.helper.getProgram(\n        this.fragmentShader_,\n        this.vertexShader_,\n      );\n      const gl = this.helper.getGL();\n      for (const paletteTexture of this.paletteTextures_) {\n        // upload the texture data\n        paletteTexture.getTexture(gl);\n      }\n    }\n  }\n\n  /**\n   * @override\n   */\n  afterHelperCreated() {\n    super.afterHelperCreated();\n\n    const gl = this.helper.getGL();\n    for (const paletteTexture of this.paletteTextures_) {\n      // upload the texture data\n      paletteTexture.getTexture(gl);\n    }\n\n    this.program_ = this.helper.getProgram(\n      this.fragmentShader_,\n      this.vertexShader_,\n    );\n    this.helper.flushBufferData(this.indices_);\n  }\n\n  /**\n   * @override\n   */\n  removeHelper() {\n    if (this.helper) {\n      const gl = this.helper.getGL();\n      for (const paletteTexture of this.paletteTextures_) {\n        paletteTexture.delete(gl);\n      }\n    }\n\n    super.removeHelper();\n  }\n\n  /**\n   * @override\n   */\n  createTileRepresentation(options) {\n    return new TileTexture(options);\n  }\n\n  /**\n   * @override\n   */\n  beforeTilesRender(frameState, tilesWithAlpha) {\n    super.beforeTilesRender(frameState, tilesWithAlpha);\n    this.helper.useProgram(this.program_, frameState);\n  }\n\n  /**\n   * @override\n   */\n  renderTile(\n    tileTexture,\n    tileTransform,\n    frameState,\n    renderExtent,\n    tileResolution,\n    tileSize,\n    tileOrigin,\n    tileExtent,\n    depth,\n    gutter,\n    alpha,\n  ) {\n    const gl = this.helper.getGL();\n    this.helper.bindBuffer(tileTexture.coords);\n    this.helper.bindBuffer(this.indices_);\n    this.helper.enableAttributes(attributeDescriptions);\n\n    let textureSlot = 0;\n    while (textureSlot < tileTexture.textures.length) {\n      const uniformName = `${Uniforms.TILE_TEXTURE_ARRAY}[${textureSlot}]`;\n      this.helper.bindTexture(\n        tileTexture.textures[textureSlot],\n        textureSlot,\n        uniformName,\n      );\n      ++textureSlot;\n    }\n\n    for (\n      let paletteIndex = 0;\n      paletteIndex < this.paletteTextures_.length;\n      ++paletteIndex\n    ) {\n      const paletteTexture = this.paletteTextures_[paletteIndex];\n      const texture = paletteTexture.getTexture(gl);\n      this.helper.bindTexture(texture, textureSlot, paletteTexture.name);\n      ++textureSlot;\n    }\n\n    const viewState = frameState.viewState;\n\n    const tileWidthWithGutter = tileSize[0] + 2 * gutter;\n    const tileHeightWithGutter = tileSize[1] + 2 * gutter;\n\n    const tile = tileTexture.tile;\n    const tileCoord = tile.tileCoord;\n\n    const tileCenterI = tileCoord[1];\n    const tileCenterJ = tileCoord[2];\n\n    this.helper.setUniformMatrixValue(\n      Uniforms.TILE_TRANSFORM,\n      mat4FromTransform(this.tmpMat4_, tileTransform),\n    );\n\n    this.helper.setUniformFloatValue(Uniforms.TRANSITION_ALPHA, alpha);\n    this.helper.setUniformFloatValue(Uniforms.DEPTH, depth);\n\n    let gutterExtent = renderExtent;\n    if (gutter > 0) {\n      gutterExtent = tileExtent;\n      getIntersection(gutterExtent, renderExtent, gutterExtent);\n    }\n    const textureOriginX =\n      tileOrigin[0] +\n      tileCenterI * tileSize[0] * tileResolution -\n      gutter * tileResolution;\n    const textureOriginY =\n      tileOrigin[1] -\n      tileCenterJ * tileSize[1] * tileResolution +\n      gutter * tileResolution;\n    const extentTransform = translateTransform(\n      resetTransform(this.tmpTransform_),\n      -textureOriginX,\n      -textureOriginY,\n    );\n    this.applyRenderExtentUniform(gutterExtent, extentTransform);\n\n    this.helper.setUniformFloatValue(Uniforms.RESOLUTION, viewState.resolution);\n    this.helper.setUniformFloatValue(Uniforms.ZOOM, viewState.zoom);\n\n    this.helper.setUniformFloatValue(\n      Uniforms.TEXTURE_PIXEL_WIDTH,\n      tileWidthWithGutter,\n    );\n    this.helper.setUniformFloatValue(\n      Uniforms.TEXTURE_PIXEL_HEIGHT,\n      tileHeightWithGutter,\n    );\n    this.helper.setUniformFloatValue(\n      Uniforms.TEXTURE_RESOLUTION,\n      tileResolution,\n    );\n\n    this.helper.drawElements(0, this.indices_.getSize());\n  }\n\n  /**\n   * @param {import(\"../../pixel.js\").Pixel} pixel Pixel.\n   * @return {Uint8ClampedArray|Uint8Array|Float32Array|DataView} Data at the pixel location.\n   * @override\n   */\n  getData(pixel) {\n    const gl = this.helper.getGL();\n    if (!gl) {\n      return null;\n    }\n\n    const frameState = this.frameState;\n    if (!frameState) {\n      return null;\n    }\n\n    const layer = this.getLayer();\n    const coordinate = applyTransform(\n      frameState.pixelToCoordinateTransform,\n      pixel.slice(),\n    );\n\n    const viewState = frameState.viewState;\n    const layerExtent = layer.getExtent();\n    if (layerExtent) {\n      if (\n        !containsCoordinate(\n          fromUserExtent(layerExtent, viewState.projection),\n          coordinate,\n        )\n      ) {\n        return null;\n      }\n    }\n\n    // determine last source suitable for rendering at coordinate\n    const sources = layer.getSources(\n      boundingExtent([coordinate]),\n      viewState.resolution,\n    );\n    let i, source, tileGrid;\n    for (i = sources.length - 1; i >= 0; --i) {\n      source = sources[i];\n      if (source.getState() === 'ready') {\n        tileGrid = source.getTileGridForProjection(viewState.projection);\n        if (source.getWrapX()) {\n          break;\n        }\n        const gridExtent = tileGrid.getExtent();\n        if (!gridExtent || containsCoordinate(gridExtent, coordinate)) {\n          break;\n        }\n      }\n    }\n    if (i < 0) {\n      return null;\n    }\n\n    const tileTextureCache = this.tileRepresentationCache;\n    for (\n      let z = tileGrid.getZForResolution(viewState.resolution);\n      z >= tileGrid.getMinZoom();\n      --z\n    ) {\n      const tileCoord = tileGrid.getTileCoordForCoordAndZ(coordinate, z);\n      const cacheKey = getCacheKey(source, tileCoord);\n      if (!tileTextureCache.containsKey(cacheKey)) {\n        continue;\n      }\n      const tileTexture = tileTextureCache.get(cacheKey);\n      const tile = tileTexture.tile;\n      if (tile.getState() === TileState.EMPTY) {\n        return null;\n      }\n      if (!tileTexture.loaded) {\n        continue;\n      }\n      const tileOrigin = tileGrid.getOrigin(z);\n      const tileSize = toSize(tileGrid.getTileSize(z));\n      const tileResolution = tileGrid.getResolution(z);\n\n      const col =\n        (coordinate[0] - tileOrigin[0]) / tileResolution -\n        tileCoord[1] * tileSize[0];\n\n      const row =\n        (tileOrigin[1] - coordinate[1]) / tileResolution -\n        tileCoord[2] * tileSize[1];\n\n      return tileTexture.getPixelData(col, row);\n    }\n    return null;\n  }\n\n  /**\n   * Clean up.\n   * @override\n   */\n  disposeInternal() {\n    const helper = this.helper;\n    if (helper) {\n      const gl = helper.getGL();\n      for (const paletteTexture of this.paletteTextures_) {\n        paletteTexture.delete(gl);\n      }\n      this.paletteTextures_.length = 0;\n\n      gl.deleteProgram(this.program_);\n      delete this.program_;\n      helper.deleteBuffer(this.indices_);\n    }\n    super.disposeInternal();\n    delete this.indices_;\n  }\n}\n\nexport default WebGLTileLayerRenderer;\n","/**\n * @module ol/webgl/PaletteTexture\n */\n\nclass PaletteTexture {\n  /**\n   * @param {string} name The name of the texture.\n   * @param {Uint8Array} data The texture data.\n   */\n  constructor(name, data) {\n    this.name = name;\n    this.data = data;\n\n    /**\n     * @type {WebGLTexture|null}\n     * @private\n     */\n    this.texture_ = null;\n  }\n\n  /**\n   * @param {WebGLRenderingContext} gl Rendering context.\n   * @return {WebGLTexture} The texture.\n   */\n  getTexture(gl) {\n    if (!this.texture_) {\n      const texture = gl.createTexture();\n      gl.bindTexture(gl.TEXTURE_2D, texture);\n      gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);\n      gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);\n      gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);\n      gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);\n      gl.texImage2D(\n        gl.TEXTURE_2D,\n        0,\n        gl.RGBA,\n        this.data.length / 4,\n        1,\n        0,\n        gl.RGBA,\n        gl.UNSIGNED_BYTE,\n        this.data,\n      );\n      this.texture_ = texture;\n    }\n    return this.texture_;\n  }\n\n  /**\n   * @param {WebGLRenderingContext} gl Rendering context.\n   */\n  delete(gl) {\n    if (this.texture_) {\n      gl.deleteTexture(this.texture_);\n    }\n    this.texture_ = null;\n  }\n}\n\nexport default PaletteTexture;\n","/**\n * @module ol/expr/gpu\n */\nimport {asArray} from '../color.js';\nimport {Uniforms} from '../renderer/webgl/TileLayer.js';\nimport {toSize} from '../size.js';\nimport PaletteTexture from '../webgl/PaletteTexture.js';\nimport {\n  BooleanType,\n  CallExpression,\n  ColorType,\n  NumberArrayType,\n  NumberType,\n  Ops,\n  SizeType,\n  StringType,\n  isType,\n  parse,\n  typeName,\n} from './expression.js';\n\n/**\n * @param {string} operator Operator\n * @param {CompilationContext} context Compilation context\n * @return {string} A function name based on the operator, unique in the given context\n */\nfunction computeOperatorFunctionName(operator, context) {\n  return `operator_${operator}_${Object.keys(context.functions).length}`;\n}\n\n/**\n * Will return the number as a float with a dot separator, which is required by GLSL.\n * @param {number} v Numerical value.\n * @return {string} The value as string.\n */\nexport function numberToGlsl(v) {\n  const s = v.toString();\n  return s.includes('.') ? s : s + '.0';\n}\n\n/**\n * Will return the number array as a float with a dot separator, concatenated with ', '.\n * @param {Array<number>} array Numerical values array.\n * @return {string} The array as a vector, e. g.: `vec3(1.0, 2.0, 3.0)`.\n */\nexport function arrayToGlsl(array) {\n  if (array.length < 2 || array.length > 4) {\n    throw new Error(\n      '`formatArray` can only output `vec2`, `vec3` or `vec4` arrays.',\n    );\n  }\n  return `vec${array.length}(${array.map(numberToGlsl).join(', ')})`;\n}\n\n/**\n * Will normalize and converts to string a `vec4` color array compatible with GLSL.\n * @param {string|import(\"../color.js\").Color} color Color either in string format or [r, g, b, a] array format,\n * with RGB components in the 0..255 range and the alpha component in the 0..1 range.\n * Note that the final array will always have 4 components.\n * @return {string} The color expressed in the `vec4(1.0, 1.0, 1.0, 1.0)` form.\n */\nexport function colorToGlsl(color) {\n  const array = asArray(color);\n  const alpha = array.length > 3 ? array[3] : 1;\n  return arrayToGlsl([array[0] / 255, array[1] / 255, array[2] / 255, alpha]);\n}\n\n/**\n * Normalizes and converts a number or array toa `vec2` array compatible with GLSL.\n * @param {number|import('../size.js').Size} size Size.\n * @return {string} The color expressed in the `vec4(1.0, 1.0, 1.0, 1.0)` form.\n */\nexport function sizeToGlsl(size) {\n  const array = toSize(size);\n  return arrayToGlsl(array);\n}\n\n/** @type {Object<string, number>} */\nconst stringToFloatMap = {};\nlet stringToFloatCounter = 0;\n\n/**\n * Returns a stable equivalent number for the string literal.\n * @param {string} string String literal value\n * @return {number} Number equivalent\n */\nexport function getStringNumberEquivalent(string) {\n  if (!(string in stringToFloatMap)) {\n    stringToFloatMap[string] = stringToFloatCounter++;\n  }\n  return stringToFloatMap[string];\n}\n\n/**\n * Returns a stable equivalent number for the string literal, for use in shaders. This number is then\n * converted to be a GLSL-compatible string.\n * Note: with a float precision of `mediump`, the amount of unique strings supported is 16,777,216\n * @param {string} string String literal value\n * @return {string} GLSL-compatible string containing a number\n */\nexport function stringToGlsl(string) {\n  return numberToGlsl(getStringNumberEquivalent(string));\n}\n\n/**\n * Get the uniform name given a variable name.\n * @param {string} variableName The variable name.\n * @return {string} The uniform name.\n */\nexport function uniformNameForVariable(variableName) {\n  return 'u_var_' + variableName;\n}\n\n/**\n * @typedef {import('./expression.js').ParsingContext} ParsingContext\n */\n/**\n *\n * @typedef {import(\"./expression.js\").Expression} Expression\n */\n/**\n *\n * @typedef {import(\"./expression.js\").LiteralExpression} LiteralExpression\n */\n\n/**\n * @typedef {Object} CompilationContextProperty\n * @property {string} name Name\n * @property {number} type Resolved property type\n */\n\n/**\n * @typedef {Object} CompilationContextVariable\n * @property {string} name Name\n * @property {number} type Resolved variable type\n */\n\n/**\n * @typedef {Object} CompilationContext\n * @property {Object<string, CompilationContextProperty>} properties The values for properties used in 'get' expressions.\n * @property {Object<string, CompilationContextVariable>} variables The values for variables used in 'var' expressions.\n * @property {Object<string, string>} functions Lookup of functions used by the style.\n * @property {number} [bandCount] Number of bands per pixel.\n * @property {Array<PaletteTexture>} [paletteTextures] List of palettes used by the style.\n * @property {boolean} featureId Whether the feature ID is used in the expression\n * @property {boolean} geometryType Whether the geometry type is used in the expression\n */\n\n/**\n * @return {CompilationContext} A new compilation context.\n */\nexport function newCompilationContext() {\n  return {\n    variables: {},\n    properties: {},\n    functions: {},\n    bandCount: 0,\n    featureId: false,\n    geometryType: false,\n  };\n}\n\nconst GET_BAND_VALUE_FUNC = 'getBandValue';\n\nexport const PALETTE_TEXTURE_ARRAY = 'u_paletteTextures';\n\nexport const FEATURE_ID_PROPERTY_NAME = 'featureId';\nexport const GEOMETRY_TYPE_PROPERTY_NAME = 'geometryType';\n\n/**\n * The value `-9999999` will be used to indicate that a property on a feature is not defined, similar to a \"no data\" value.\n */\nexport const UNDEFINED_PROP_VALUE = -9999999;\n\n/**\n * @typedef {string} CompiledExpression\n */\n\n/**\n * @typedef {function(CompilationContext, CallExpression, number): string} Compiler\n * Third argument is the expected value types\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} parsingContext The parsing context.\n * @param {CompilationContext} compilationContext An existing compilation context\n * @return {CompiledExpression} The compiled expression.\n */\nexport function buildExpression(\n  encoded,\n  type,\n  parsingContext,\n  compilationContext,\n) {\n  const expression = parse(encoded, type, parsingContext);\n  return compile(expression, type, compilationContext);\n}\n\n/**\n * @param {function(Array<CompiledExpression>, CompilationContext): string} output Function that takes in parsed arguments and returns a string\n * @return {function(CompilationContext, import(\"./expression.js\").CallExpression, number): string} Compiler for the call expression\n */\nfunction createCompiler(output) {\n  return (context, expression, type) => {\n    const length = expression.args.length;\n    const args = new Array(length);\n    for (let i = 0; i < length; ++i) {\n      args[i] = compile(expression.args[i], type, context);\n    }\n    return output(args, context);\n  };\n}\n\n/**\n * @type {Object<string, Compiler>}\n */\nconst compilers = {\n  [Ops.Get]: (context, expression) => {\n    const firstArg = /** @type {LiteralExpression} */ (expression.args[0]);\n    const propName = /** @type {string} */ (firstArg.value);\n    const isExisting = propName in context.properties;\n    if (!isExisting) {\n      context.properties[propName] = {\n        name: propName,\n        type: expression.type,\n      };\n    }\n    let result = 'a_prop_' + propName;\n    if (isType(expression.type, BooleanType)) {\n      result = `(${result} > 0.0)`;\n    }\n    return result;\n  },\n  [Ops.Id]: (context) => {\n    context.featureId = true;\n    return 'a_' + FEATURE_ID_PROPERTY_NAME;\n  },\n  [Ops.GeometryType]: (context) => {\n    context.geometryType = true;\n    return 'a_' + GEOMETRY_TYPE_PROPERTY_NAME;\n  },\n  [Ops.LineMetric]: () => 'currentLineMetric', // this variable is assumed to always be present in shaders, default is 0.\n  [Ops.Var]: (context, expression) => {\n    const firstArg = /** @type {LiteralExpression} */ (expression.args[0]);\n    const varName = /** @type {string} */ (firstArg.value);\n    const isExisting = varName in context.variables;\n    if (!isExisting) {\n      context.variables[varName] = {\n        name: varName,\n        type: expression.type,\n      };\n    }\n    let result = uniformNameForVariable(varName);\n    if (isType(expression.type, BooleanType)) {\n      result = `(${result} > 0.0)`;\n    }\n    return result;\n  },\n  [Ops.Has]: (context, expression) => {\n    const firstArg = /** @type {LiteralExpression} */ (expression.args[0]);\n    const propName = /** @type {string} */ (firstArg.value);\n    const isExisting = propName in context.properties;\n    if (!isExisting) {\n      context.properties[propName] = {\n        name: propName,\n        type: expression.type,\n      };\n    }\n    return `(a_prop_${propName} != ${numberToGlsl(UNDEFINED_PROP_VALUE)})`;\n  },\n  [Ops.Resolution]: () => 'u_resolution',\n  [Ops.Zoom]: () => 'u_zoom',\n  [Ops.Time]: () => 'u_time',\n  [Ops.Any]: createCompiler((compiledArgs) => `(${compiledArgs.join(` || `)})`),\n  [Ops.All]: createCompiler((compiledArgs) => `(${compiledArgs.join(` && `)})`),\n  [Ops.Not]: createCompiler(([value]) => `(!${value})`),\n  [Ops.Equal]: createCompiler(\n    ([firstValue, secondValue]) => `(${firstValue} == ${secondValue})`,\n  ),\n  [Ops.NotEqual]: createCompiler(\n    ([firstValue, secondValue]) => `(${firstValue} != ${secondValue})`,\n  ),\n  [Ops.GreaterThan]: createCompiler(\n    ([firstValue, secondValue]) => `(${firstValue} > ${secondValue})`,\n  ),\n  [Ops.GreaterThanOrEqualTo]: createCompiler(\n    ([firstValue, secondValue]) => `(${firstValue} >= ${secondValue})`,\n  ),\n  [Ops.LessThan]: createCompiler(\n    ([firstValue, secondValue]) => `(${firstValue} < ${secondValue})`,\n  ),\n  [Ops.LessThanOrEqualTo]: createCompiler(\n    ([firstValue, secondValue]) => `(${firstValue} <= ${secondValue})`,\n  ),\n  [Ops.Multiply]: createCompiler(\n    (compiledArgs) => `(${compiledArgs.join(' * ')})`,\n  ),\n  [Ops.Divide]: createCompiler(\n    ([firstValue, secondValue]) => `(${firstValue} / ${secondValue})`,\n  ),\n  [Ops.Add]: createCompiler((compiledArgs) => `(${compiledArgs.join(' + ')})`),\n  [Ops.Subtract]: createCompiler(\n    ([firstValue, secondValue]) => `(${firstValue} - ${secondValue})`,\n  ),\n  [Ops.Clamp]: createCompiler(\n    ([value, min, max]) => `clamp(${value}, ${min}, ${max})`,\n  ),\n  [Ops.Mod]: createCompiler(([value, modulo]) => `mod(${value}, ${modulo})`),\n  [Ops.Pow]: createCompiler(([value, power]) => `pow(${value}, ${power})`),\n  [Ops.Abs]: createCompiler(([value]) => `abs(${value})`),\n  [Ops.Floor]: createCompiler(([value]) => `floor(${value})`),\n  [Ops.Ceil]: createCompiler(([value]) => `ceil(${value})`),\n  [Ops.Round]: createCompiler(([value]) => `floor(${value} + 0.5)`),\n  [Ops.Sin]: createCompiler(([value]) => `sin(${value})`),\n  [Ops.Cos]: createCompiler(([value]) => `cos(${value})`),\n  [Ops.Atan]: createCompiler(([firstValue, secondValue]) => {\n    return secondValue !== undefined\n      ? `atan(${firstValue}, ${secondValue})`\n      : `atan(${firstValue})`;\n  }),\n  [Ops.Sqrt]: createCompiler(([value]) => `sqrt(${value})`),\n  [Ops.Match]: createCompiler((compiledArgs) => {\n    const input = compiledArgs[0];\n    const fallback = compiledArgs[compiledArgs.length - 1];\n    let result = null;\n    for (let i = compiledArgs.length - 3; i >= 1; i -= 2) {\n      const match = compiledArgs[i];\n      const output = compiledArgs[i + 1];\n      result = `(${input} == ${match} ? ${output} : ${result || fallback})`;\n    }\n    return result;\n  }),\n  [Ops.Between]: createCompiler(\n    ([value, min, max]) => `(${value} >= ${min} && ${value} <= ${max})`,\n  ),\n  [Ops.Interpolate]: createCompiler(([exponent, input, ...compiledArgs]) => {\n    let result = '';\n    for (let i = 0; i < compiledArgs.length - 2; i += 2) {\n      const stop1 = compiledArgs[i];\n      const output1 = result || compiledArgs[i + 1];\n      const stop2 = compiledArgs[i + 2];\n      const output2 = compiledArgs[i + 3];\n      let ratio;\n      if (exponent === numberToGlsl(1)) {\n        ratio = `(${input} - ${stop1}) / (${stop2} - ${stop1})`;\n      } else {\n        ratio = `(pow(${exponent}, (${input} - ${stop1})) - 1.0) / (pow(${exponent}, (${stop2} - ${stop1})) - 1.0)`;\n      }\n      result = `mix(${output1}, ${output2}, clamp(${ratio}, 0.0, 1.0))`;\n    }\n    return result;\n  }),\n  [Ops.Case]: createCompiler((compiledArgs) => {\n    const fallback = compiledArgs[compiledArgs.length - 1];\n    let result = null;\n    for (let i = compiledArgs.length - 3; i >= 0; i -= 2) {\n      const condition = compiledArgs[i];\n      const output = compiledArgs[i + 1];\n      result = `(${condition} ? ${output} : ${result || fallback})`;\n    }\n    return result;\n  }),\n  [Ops.In]: createCompiler(([needle, ...haystack], context) => {\n    const funcName = computeOperatorFunctionName('in', context);\n    const tests = [];\n    for (let i = 0; i < haystack.length; i += 1) {\n      tests.push(`  if (inputValue == ${haystack[i]}) { return true; }`);\n    }\n    context.functions[funcName] = `bool ${funcName}(float inputValue) {\n${tests.join('\\n')}\n  return false;\n}`;\n    return `${funcName}(${needle})`;\n  }),\n  [Ops.Array]: createCompiler(\n    (args) => `vec${args.length}(${args.join(', ')})`,\n  ),\n  [Ops.Color]: createCompiler((compiledArgs) => {\n    if (compiledArgs.length === 1) {\n      //grayscale\n      return `vec4(vec3(${compiledArgs[0]} / 255.0), 1.0)`;\n    }\n    if (compiledArgs.length === 2) {\n      //grayscale with alpha\n      return `vec4(vec3(${compiledArgs[0]} / 255.0), ${compiledArgs[1]})`;\n    }\n    const rgb = compiledArgs.slice(0, 3).map((color) => `${color} / 255.0`);\n    if (compiledArgs.length === 3) {\n      return `vec4(${rgb.join(', ')}, 1.0)`;\n    }\n    const alpha = compiledArgs[3];\n    return `vec4(${rgb.join(', ')}, ${alpha})`;\n  }),\n  [Ops.Band]: createCompiler(([band, xOffset, yOffset], context) => {\n    if (!(GET_BAND_VALUE_FUNC in context.functions)) {\n      let ifBlocks = '';\n      const bandCount = context.bandCount || 1;\n      for (let i = 0; i < bandCount; i++) {\n        const colorIndex = Math.floor(i / 4);\n        let bandIndex = i % 4;\n        if (i === bandCount - 1 && bandIndex === 1) {\n          // LUMINANCE_ALPHA - band 1 assigned to rgb and band 2 assigned to alpha\n          bandIndex = 3;\n        }\n        const textureName = `${Uniforms.TILE_TEXTURE_ARRAY}[${colorIndex}]`;\n        ifBlocks += `  if (band == ${i + 1}.0) {\n    return texture2D(${textureName}, v_textureCoord + vec2(dx, dy))[${bandIndex}];\n  }\n`;\n      }\n\n      context.functions[GET_BAND_VALUE_FUNC] =\n        `float getBandValue(float band, float xOffset, float yOffset) {\n  float dx = xOffset / ${Uniforms.TEXTURE_PIXEL_WIDTH};\n  float dy = yOffset / ${Uniforms.TEXTURE_PIXEL_HEIGHT};\n${ifBlocks}\n}`;\n    }\n\n    return `${GET_BAND_VALUE_FUNC}(${band}, ${xOffset ?? '0.0'}, ${\n      yOffset ?? '0.0'\n    })`;\n  }),\n  [Ops.Palette]: (context, expression) => {\n    const [index, ...colors] = expression.args;\n    const numColors = colors.length;\n    const palette = new Uint8Array(numColors * 4);\n    for (let i = 0; i < colors.length; i++) {\n      const parsedValue = /** @type {string | Array<number>} */ (\n        /** @type {LiteralExpression} */ (colors[i]).value\n      );\n      const color = asArray(parsedValue);\n      const offset = i * 4;\n      palette[offset] = color[0];\n      palette[offset + 1] = color[1];\n      palette[offset + 2] = color[2];\n      palette[offset + 3] = color[3] * 255;\n    }\n    if (!context.paletteTextures) {\n      context.paletteTextures = [];\n    }\n    const paletteName = `${PALETTE_TEXTURE_ARRAY}[${context.paletteTextures.length}]`;\n    const paletteTexture = new PaletteTexture(paletteName, palette);\n    context.paletteTextures.push(paletteTexture);\n    const compiledIndex = compile(index, NumberType, context);\n    return `texture2D(${paletteName}, vec2((${compiledIndex} + 0.5) / ${numColors}.0, 0.5))`;\n  },\n  // TODO: unimplemented\n  // Ops.Number\n  // Ops.String\n  // Ops.Coalesce\n  // Ops.Concat\n  // Ops.ToString\n};\n\n/**\n * @param {Expression} expression The expression.\n * @param {number} returnType The expected return type.\n * @param {CompilationContext} context The compilation context.\n * @return {CompiledExpression} The compiled expression\n */\nfunction compile(expression, returnType, context) {\n  // operator\n  if (expression instanceof CallExpression) {\n    const compiler = compilers[expression.operator];\n    if (compiler === undefined) {\n      throw new Error(\n        `No compiler defined for this operator: ${JSON.stringify(\n          expression.operator,\n        )}`,\n      );\n    }\n    return compiler(context, expression, returnType);\n  }\n\n  if ((expression.type & NumberType) > 0) {\n    return numberToGlsl(/** @type {number} */ (expression.value));\n  }\n\n  if ((expression.type & BooleanType) > 0) {\n    return expression.value.toString();\n  }\n\n  if ((expression.type & StringType) > 0) {\n    return stringToGlsl(expression.value.toString());\n  }\n\n  if ((expression.type & ColorType) > 0) {\n    return colorToGlsl(\n      /** @type {Array<number> | string} */ (expression.value),\n    );\n  }\n\n  if ((expression.type & NumberArrayType) > 0) {\n    return arrayToGlsl(/** @type {Array<number>} */ (expression.value));\n  }\n\n  if ((expression.type & SizeType) > 0) {\n    return sizeToGlsl(\n      /** @type {number|import('../size.js').Size} */ (expression.value),\n    );\n  }\n\n  throw new Error(\n    `Unexpected expression ${expression.value} (expected type ${typeName(\n      returnType,\n    )})`,\n  );\n}\n","/**\n * Utilities for compiling expressions and turning them into WebGL concepts\n * @module ol/render/webgl/compileUtil\n */\n\nimport {asArray} from '../../color.js';\nimport {\n  ColorType,\n  NumberArrayType,\n  SizeType,\n  newParsingContext,\n} from '../../expr/expression.js';\nimport {\n  buildExpression,\n  getStringNumberEquivalent,\n  uniformNameForVariable,\n} from '../../expr/gpu.js';\n\n/**\n * Recursively parses a style expression and outputs a GLSL-compatible string. Takes in a compilation context that\n * will be read and modified during the parsing operation.\n * @param {import(\"../../expr/gpu.js\").CompilationContext} compilationContext Compilation context\n * @param {import(\"../../expr/expression.js\").EncodedExpression} value Value\n * @param {number} [expectedType] Expected final type (can be several types combined)\n * @param {import(\"../../expr/expression.js\").ParsingContext} [parsingContext] Optional parsing context to be used\n * @return {string} GLSL-compatible output\n */\nexport function expressionToGlsl(\n  compilationContext,\n  value,\n  expectedType,\n  parsingContext,\n) {\n  return buildExpression(\n    value,\n    expectedType,\n    parsingContext ?? newParsingContext(),\n    compilationContext,\n  );\n}\n\n/**\n * Packs all components of a color into a two-floats array\n * @param {import(\"../../color.js\").Color|string} color Color as array of numbers or string\n * @return {Array<number>} Vec2 array containing the color in compressed form\n */\nexport function packColor(color) {\n  const array = asArray(color);\n  const r = array[0] * 256;\n  const g = array[1];\n  const b = array[2] * 256;\n  const a = Math.round(array[3] * 255);\n  return [r + g, b + a];\n}\n\n/**\n * Unpacks a color from a packed color in two-floats array form\n * NOTE: this is only used for testing purposes\n * @param {Array<number>} packedColor Packed color generated by the `packColor` function\n * @return {Array<number>} Resulting unpacked color in array form with components in the range [0, 1]\n */\nexport function unpackColor(packedColor) {\n  return [\n    Math.min(Math.floor(packedColor[0] / 256.0) / 255.0, 1),\n    Math.min((packedColor[0] % 256.0) / 255.0, 1),\n    Math.min(Math.floor(packedColor[1] / 256.0) / 255.0, 1),\n    Math.min((packedColor[1] % 256.0) / 255.0, 1),\n  ];\n}\n\n/**\n * Equivalent of `unpackColor()` in GLSL\n * @type {string}\n */\nexport const UNPACK_COLOR_FN = `vec4 unpackColor(vec2 packedColor) {\n  return vec4(\n    min(floor(packedColor[0] / 256.0) / 255.0, 1.0),\n    min(mod(packedColor[0], 256.0) / 255.0, 1.0),\n    min(floor(packedColor[1] / 256.0) / 255.0, 1.0),\n    min(mod(packedColor[1], 256.0) / 255.0, 1.0)\n  );\n}`;\n\n/**\n * @param {number} type Value type\n * @return {1|2|3|4} The amount of components for this value\n */\nexport function getGlslSizeFromType(type) {\n  if (type === ColorType || type === SizeType) {\n    return 2;\n  }\n  if (type === NumberArrayType) {\n    return 4;\n  }\n  return 1;\n}\n\n/**\n * @param {number} type Value type\n * @return {'float'|'vec2'|'vec3'|'vec4'} The corresponding GLSL type for this value\n */\nexport function getGlslTypeFromType(type) {\n  const size = getGlslSizeFromType(type);\n  if (size > 1) {\n    return /** @type {'vec2'|'vec3'|'vec4'} */ (`vec${size}`);\n  }\n  return 'float';\n}\n\n/**\n * Applies the properties and variables collected in a compilation context to a ShaderBuilder instance:\n * properties will show up as attributes in shaders, and variables will show up as uniforms.\n * @param {import(\"./ShaderBuilder.js\").ShaderBuilder} builder Shader builder\n * @param {import(\"../../expr/gpu.js\").CompilationContext} context Compilation context\n */\nexport function applyContextToBuilder(builder, context) {\n  // define one uniform per variable\n  for (const varName in context.variables) {\n    const variable = context.variables[varName];\n    const uniformName = uniformNameForVariable(variable.name);\n    let glslType = getGlslTypeFromType(variable.type);\n    if (variable.type === ColorType) {\n      // we're not packing colors when they're passed as uniforms\n      glslType = 'vec4';\n    }\n    builder.addUniform(uniformName, glslType);\n  }\n\n  // for each feature attribute used in the fragment shader, define a varying that will be used to pass data\n  // from the vertex to the fragment shader, as well as an attribute in the vertex shader (if not already present)\n  for (const propName in context.properties) {\n    const property = context.properties[propName];\n    const glslType = getGlslTypeFromType(property.type);\n    const attributeName = `a_prop_${property.name}`;\n    if (property.type === ColorType) {\n      builder.addAttribute(\n        attributeName,\n        glslType,\n        `unpackColor(${attributeName})`,\n        'vec4',\n      );\n    } else {\n      builder.addAttribute(attributeName, glslType);\n    }\n  }\n\n  // add functions that were collected in the compilation contexts\n  for (const functionName in context.functions) {\n    builder.addVertexShaderFunction(context.functions[functionName]);\n    builder.addFragmentShaderFunction(context.functions[functionName]);\n  }\n}\n\n/**\n * Generates a set of uniforms from variables collected in a compilation context,\n * to be fed to a WebGLHelper instance\n * @param {import(\"../../expr/gpu.js\").CompilationContext} context Compilation context\n * @param {import('../../style/flat.js').StyleVariables} [variables] Style variables.\n * @return {Object<string,import(\"../../webgl/Helper.js\").UniformValue>} Uniforms\n */\nexport function generateUniformsFromContext(context, variables) {\n  /** @type {Object<string,import(\"../../webgl/Helper.js\").UniformValue>} */\n  const uniforms = {};\n\n  // define one uniform per variable\n  for (const varName in context.variables) {\n    const variable = context.variables[varName];\n    const uniformName = uniformNameForVariable(variable.name);\n\n    uniforms[uniformName] = () => {\n      const value = variables[variable.name];\n      if (typeof value === 'number') {\n        return value;\n      }\n      if (typeof value === 'boolean') {\n        return value ? 1 : 0;\n      }\n      if (variable.type === ColorType) {\n        const color = [...asArray(value || '#eee')];\n        color[0] /= 255;\n        color[1] /= 255;\n        color[2] /= 255;\n        color[3] ??= 1;\n        return color;\n      }\n      if (typeof value === 'string') {\n        return getStringNumberEquivalent(value);\n      }\n      return value;\n    };\n  }\n\n  return uniforms;\n}\n\n/**\n * Generates a set of attributes from properties collected in a compilation context,\n * to be fed to a WebGLHelper instance\n * @param {import(\"../../expr/gpu.js\").CompilationContext} context Compilation context\n * @return {import('./VectorStyleRenderer.js').AttributeDefinitions} Attributes\n */\nexport function generateAttributesFromContext(context) {\n  /**\n   * @type {import('./VectorStyleRenderer.js').AttributeDefinitions}\n   */\n  const attributes = {};\n\n  // Define attributes with their callback for each property used in the vertex shader\n  for (const propName in context.properties) {\n    const property = context.properties[propName];\n    const callback = (feature) => {\n      const value = feature.get(property.name);\n      if (property.type === ColorType) {\n        return packColor([...asArray(value || '#eee')]);\n      }\n      if (typeof value === 'string') {\n        return getStringNumberEquivalent(value);\n      }\n      if (typeof value === 'boolean') {\n        return value ? 1 : 0;\n      }\n      return value;\n    };\n\n    attributes[`prop_${property.name}`] = {\n      size: getGlslSizeFromType(property.type),\n      callback,\n    };\n  }\n  return attributes;\n}\n","/**\n * Returns a low part of a float value that can be encoded to Float32 without recision loss\n * @param {number} float Number in float64 precision\n * @return {number} Low part of the float value\n */\nexport function getLowPart(float) {\n  return float - getHighPart(float);\n}\n\n/**\n * Returns a high part of a float value that can be encoded to Float32 without precision loss\n * @param {number} float Number in float64 precision\n * @return {number} High part of the float value\n */\nexport function getHighPart(float) {\n  return Math.fround(float);\n}\n\n/**\n * These arithmetic functions are mostly inspired the ones in luma.gl: https://github.com/visgl/luma.gl/blob/master/modules/shadertools/src/modules/math/fp64/fp64-arithmetic-glsl.ts\n * and https://blog.cyclemap.link/2011-06-09-glsl-part2-emu/\n * Note that we use the `u_one` uniform here to ensure that the compiler doesn't simplify the calculations; otherwise these will have no effect at all\n * @type {string}\n */\n\nexport const FLOAT64_ARITHMETIC_FN = `\nvec2 df_from(float value) {\n  return vec2(value, 0.);\n}\n\nfloat df_float(vec2 df) {\n  return df.x;\n}\n\nvec2 df_add(vec2 dfa, vec2 dfb) {\n  vec2 dfc;\n  float t1, t2, e;\n  \n  t1 = dfa.x * u_one + dfb.x * u_one;\n  e = t1 * u_one - dfa.x * u_one;\n  t2 = ((dfb.x - e) + (dfa.x - (t1 - e))) * u_one + dfa.y + dfb.y * u_one;\n  \n  dfc.x = t1 * u_one + t2 * u_one;\n  dfc.y = t2 - (dfc.x - t1) * u_one;\n  return dfc;\n}\n\nvec2 df_sub(vec2 dfa, vec2 dfb) {\n  vec2 dfc;\n  float e, t1, t2;\n  \n  t1 = dfa.x - dfb.x;\n  e = t1 - dfa.x;\n  t2 = ((-dfb.x - e) + (dfa.x - (t1 - e))) + dfa.y - dfb.y;\n  \n  dfc.x = t1 + t2;\n  dfc.y = t2 - (dfc.x - t1);\n  return dfc;\n}\n\nvec2 df_mul(vec2 dfa, vec2 dfb) {\n  vec2 dfc;\n  float c11, c21, c2, e, t1, t2;\n  float a1, a2, b1, b2, cona, conb, split = 4097.;\n\n  cona = dfa.x * split * u_one;\n  conb = dfb.x * split * u_one;\n  a1 = cona * u_one - (cona - dfa.x);\n  b1 = conb * u_one - (conb - dfb.x);\n  a2 = dfa.x * u_one - a1;\n  b2 = dfb.x * u_one - b1 * u_one;\n\n  c11 = dfa.x * u_one * dfb.x * u_one;\n  c21 = a2 * b2 * u_one + (a2 * b1 + (a1 * b2 + (a1 * b1 - c11))) * u_one;\n\n  c2 = dfa.x * dfb.y * u_one + dfa.y * dfb.x * u_one;\n\n  t1 = c11 + c2 * u_one;\n  e = t1 - c11 * u_one;\n  t2 = dfa.y * dfb.y * u_one + ((c2 - e) + (c11 - (t1 - e))) + c21 * u_one;\n\n  dfc.x = t1 * u_one + t2 * u_one;\n  dfc.y = t2 - (dfc.x - t1) * u_one;\n\n  return dfc;\n}\n\nvec2 df_div(vec2 dfa, vec2 dfb) {\n  vec2 dfc;\n  float c11, c21, c2, e, t1, t2, t11, t12, t21, t22;\n  float a1, a2, b1, b2, cona, conb, split = 4097.;\n  float s1, s2;\n  \n  s1 = dfa.x / dfb.x * u_one;\n  cona = s1 * split * u_one;\n  conb = dfb.x * split * u_one;\n  a1 = cona - (cona - s1) * u_one;\n  b1 = conb - (conb - dfb.x) * u_one;\n  a2 = s1 - a1 * u_one;\n  b2 = dfb.x - b1 * u_one;\n  \n  c11 = s1 * dfb.x * u_one;\n  c21 = (((a1 * b1 - c11) + a1 * b2) + a2 * b1) + a2 * b2 * u_one;\n  \n  c2 = s1 * dfb.y * u_one;\n  \n  t1 = c11 + c2 * u_one;\n  e  = t1 - c11 * u_one;\n  t2 = ((c2 - e) + (c11 - (t1 - e))) + c21 * u_one;\n  \n  t12 = t1 + t2 * u_one;\n  t22 = t2 - (t12 - t1) * u_one;\n  \n  t11 = dfa.x - t12 * u_one;\n  e   = t11 - dfa.x * u_one;\n  t21 = ((-t12 - e) + (dfa.x - (t11 - e))) + dfa.y - t22 * u_one;\n  \n  s2 = (t11 + t21) / dfb.x * u_one;\n  \n  dfc.x = s1 + s2 * u_one;\n  dfc.y = s2 - (dfc.x - s1) * u_one;\n  \n  return dfc;\n}\n\nfloat df_mod(vec2 df, vec2 m) {\n  vec2 q = df_div(df, m) * u_one;\n  float qf = floor(q.x);\n  float frac = q.x - qf + q.y * u_one;\n  if (frac < 0.0) qf -= 1.0;\n  if (frac >= 1.0) qf += 1.0;\n  vec2 prod = df_mul(df_from(qf), m);\n  vec2 rem = df_add(df_from(df.x), df_from(-prod.x)) * u_one;\n  rem.y += df.y - prod.y;\n  return rem.x + rem.y * u_one;\n}\n`;\n","/**\n * Class for generating shaders from literal style objects\n * @module ol/render/webgl/ShaderBuilder\n */\nimport {colorToGlsl, numberToGlsl, stringToGlsl} from '../../expr/gpu.js';\nimport {createDefaultStyle} from '../../style/flat.js';\nimport {LINESTRING_ANGLE_COSINE_CUTOFF} from './bufferUtil.js';\nimport {UNPACK_COLOR_FN} from './compileUtil.js';\nimport {FLOAT64_ARITHMETIC_FN} from './float64Util.js';\n\nexport const COMMON_HEADER = `#ifdef GL_FRAGMENT_PRECISION_HIGH\nprecision highp float;\n#else\nprecision mediump float;\n#endif\nuniform float u_one;\nuniform mat4 u_projectionMatrix;\nuniform mat4 u_invertProjectionMatrix;\nuniform vec2 u_viewportSizePx;\nuniform float u_pixelRatio;\nuniform float u_globalAlpha;\nuniform float u_time;\nuniform float u_zoom;\nuniform float u_resolution;\nuniform float u_rotation;\nuniform vec4 u_renderExtent;\nuniform float u_depth;\nuniform mediump int u_hitDetection;\n\n// these 64-bits floats are split into high/low\nuniform vec2 u_df_patternOriginX;\nuniform vec2 u_df_patternOriginY;\nuniform vec2 u_df_patternScaleRatio;\n\nconst float PI = 3.141592653589793238;\nconst float TWO_PI = 2.0 * PI;\nfloat currentLineMetric = 0.; // an actual value will be used in the stroke shaders\n\nvec2 pxToWorld(vec2 pxPos) {\n  vec2 screenPos = 2.0 * pxPos / u_viewportSizePx - 1.0;\n  return (u_invertProjectionMatrix * vec4(screenPos, 0.0, 1.0)).xy;\n}\n\nvec2 worldToPx(vec2 worldPos) {\n  vec4 screenPos = u_projectionMatrix * vec4(worldPos, 0.0, 1.0);\n  return (0.5 * screenPos.xy + 0.5) * u_viewportSizePx;\n}\n${UNPACK_COLOR_FN}\n${FLOAT64_ARITHMETIC_FN}\n`;\n\nconst DEFAULT_STYLE = createDefaultStyle();\n\n/**\n * @typedef {Object} AttributeDescription\n * @property {string} name Attribute name, as will be declared in the header of the vertex shader (including a_)\n * @property {string} type Attribute GLSL type, either `float`, `vec2`, `vec4`...\n * @property {string} varyingName Varying name, as will be declared in the header of both shaders (including v_)\n * @property {string} varyingType Varying type, either `float`, `vec2`, `vec4`...\n * @property {string} varyingExpression GLSL expression to assign to the varying in the vertex shader (e.g. `unpackColor(a_myAttr)`)\n */\n\n/**\n * @typedef {Object} UniformDescription\n * @property {string} name Uniform name, as will be declared in the header of the vertex shader (including u_)\n * @property {string} type Uniform GLSL type, either `float`, `vec2`, `vec4`...\n */\n\n/**\n * @classdesc\n * This class implements a classic builder pattern for generating many different types of shaders.\n * Methods can be chained, e. g.:\n *\n * ```js\n * const shader = new ShaderBuilder()\n *   .addAttribute('a_width', 'float')\n *   .addUniform('u_time', 'float)\n *   .setColorExpression('...')\n *   .setSymbolSizeExpression('...')\n *   .getSymbolFragmentShader();\n * ```\n *\n * A note on [alpha premultiplication](https://en.wikipedia.org/wiki/Alpha_compositing#Straight_versus_premultiplied):\n * The ShaderBuilder class expects all colors to **not having been alpha-premultiplied!** This is because alpha\n * premultiplication is done at the end of each fragment shader.\n */\nexport class ShaderBuilder {\n  constructor() {\n    /**\n     * Uniforms; these will be declared in the header (should include the type).\n     * @type {Array<UniformDescription>}\n     * @private\n     */\n    this.uniforms_ = [];\n\n    /**\n     * Attributes; these will be declared in the header (should include the type).\n     * @type {Array<AttributeDescription>}\n     * @private\n     */\n    this.attributes_ = [];\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.hasSymbol_ = false;\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.symbolSizeExpression_ = `vec2(${numberToGlsl(\n      DEFAULT_STYLE['circle-radius'],\n    )} + ${numberToGlsl(DEFAULT_STYLE['circle-stroke-width'] * 0.5)})`;\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.symbolRotationExpression_ = '0.0';\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.symbolOffsetExpression_ = 'vec2(0.0)';\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.symbolColorExpression_ = colorToGlsl(\n      /** @type {string} */ (DEFAULT_STYLE['circle-fill-color']),\n    );\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.texCoordExpression_ = 'vec4(0.0, 0.0, 1.0, 1.0)';\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.fragmentDiscardExpression_ = null;\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.shapeDiscardExpression_ = null;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.symbolRotateWithView_ = false;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.hasStroke_ = false;\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.strokeWidthExpression_ = numberToGlsl(DEFAULT_STYLE['stroke-width']);\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.strokeColorExpression_ = colorToGlsl(\n      /** @type {string} */ (DEFAULT_STYLE['stroke-color']),\n    );\n\n    /**\n     * @private\n     */\n    this.strokeOffsetExpression_ = '0.';\n\n    /**\n     * @private\n     */\n    this.strokeCapExpression_ = stringToGlsl('round');\n\n    /**\n     * @private\n     */\n    this.strokeJoinExpression_ = stringToGlsl('round');\n\n    /**\n     * @private\n     */\n    this.strokeMiterLimitExpression_ = '10.';\n\n    /**\n     * @private\n     */\n    this.strokeDistanceFieldExpression_ = '-1000.';\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.strokePatternLengthExpression_ = null;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.hasFill_ = false;\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.fillColorExpression_ = colorToGlsl(\n      /** @type {string} */ (DEFAULT_STYLE['fill-color']),\n    );\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.fillPatternSizeExpression_ = null;\n\n    /**\n     * @type {Array<string>}\n     * @private\n     */\n    this.vertexShaderFunctions_ = [];\n\n    /**\n     * @type {Array<string>}\n     * @private\n     */\n    this.fragmentShaderFunctions_ = [];\n  }\n\n  /**\n   * Adds a uniform accessible in both fragment and vertex shaders.\n   * The given name should include a type, such as `sampler2D u_texture`.\n   * @param {string} name Uniform name, including the `u_` prefix\n   * @param {'float'|'vec2'|'vec3'|'vec4'|'sampler2D'} type GLSL type\n   * @return {ShaderBuilder} the builder object\n   */\n  addUniform(name, type) {\n    this.uniforms_.push({\n      name,\n      type,\n    });\n    return this;\n  }\n\n  /**\n   * Adds an attribute accessible in the vertex shader, read from the geometry buffer.\n   * The given name should include a type, such as `vec2 a_position`.\n   * Attributes will also be made available under the same name in fragment shaders.\n   * @param {string} name Attribute name, including the `a_` prefix\n   * @param {'float'|'vec2'|'vec3'|'vec4'} type GLSL type\n   * @param {string} [varyingExpression] Expression which will be assigned to the varying in the vertex shader, and\n   * passed on to the fragment shader.\n   * @param {'float'|'vec2'|'vec3'|'vec4'} [varyingType] Type of the attribute after transformation;\n   * e.g. `vec4` after unpacking color components\n   * @return {ShaderBuilder} the builder object\n   */\n  addAttribute(name, type, varyingExpression, varyingType) {\n    this.attributes_.push({\n      name,\n      type,\n      varyingName: name.replace(/^a_/, 'v_'),\n      varyingType: varyingType ?? type,\n      varyingExpression: varyingExpression ?? name,\n    });\n    return this;\n  }\n\n  /**\n   * Sets an expression to compute the size of the shape.\n   * This expression can use all the uniforms and attributes available\n   * in the vertex shader, and should evaluate to a `vec2` value.\n   * @param {string} expression Size expression\n   * @return {ShaderBuilder} the builder object\n   */\n  setSymbolSizeExpression(expression) {\n    this.hasSymbol_ = true;\n    this.symbolSizeExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * @return {string} The current symbol size expression\n   */\n  getSymbolSizeExpression() {\n    return this.symbolSizeExpression_;\n  }\n\n  /**\n   * Sets an expression to compute the rotation of the shape.\n   * This expression can use all the uniforms and attributes available\n   * in the vertex shader, and should evaluate to a `float` value in radians.\n   * @param {string} expression Size expression\n   * @return {ShaderBuilder} the builder object\n   */\n  setSymbolRotationExpression(expression) {\n    this.symbolRotationExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * Sets an expression to compute the offset of the symbol from the point center.\n   * This expression can use all the uniforms and attributes available\n   * in the vertex shader, and should evaluate to a `vec2` value.\n   * @param {string} expression Offset expression\n   * @return {ShaderBuilder} the builder object\n   */\n  setSymbolOffsetExpression(expression) {\n    this.symbolOffsetExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * @return {string} The current symbol offset expression\n   */\n  getSymbolOffsetExpression() {\n    return this.symbolOffsetExpression_;\n  }\n\n  /**\n   * Sets an expression to compute the color of the shape.\n   * This expression can use all the uniforms, varyings and attributes available\n   * in the fragment shader, and should evaluate to a `vec4` value.\n   * @param {string} expression Color expression\n   * @return {ShaderBuilder} the builder object\n   */\n  setSymbolColorExpression(expression) {\n    this.hasSymbol_ = true;\n    this.symbolColorExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * @return {string} The current symbol color expression\n   */\n  getSymbolColorExpression() {\n    return this.symbolColorExpression_;\n  }\n\n  /**\n   * Sets an expression to compute the texture coordinates of the vertices.\n   * This expression can use all the uniforms and attributes available\n   * in the vertex shader, and should evaluate to a `vec4` value.\n   * @param {string} expression Texture coordinate expression\n   * @return {ShaderBuilder} the builder object\n   */\n  setTextureCoordinateExpression(expression) {\n    this.texCoordExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * Sets an expression to determine whether a fragment (pixel) should be discarded,\n   * i.e. not drawn at all. If the expression evaluates to `true`, the fragment is discarded.\n   * This expression can use all the uniforms, varyings and attributes available\n   * in the fragment shader, and should evaluate to a `bool` value (it will be\n   * used in an `if` statement)\n   * @param {string} expression Fragment discard expression\n   * @return {ShaderBuilder} the builder object\n   */\n  setFragmentDiscardExpression(expression) {\n    this.fragmentDiscardExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * @return {string} The current fragment discard expression; null if none has been set\n   */\n  getFragmentDiscardExpression() {\n    return this.fragmentDiscardExpression_;\n  }\n\n  /**\n   * Sets an expression to determine whether a whole shape (triangle) should be filtered out\n   * and not rasterized at all. If the expression evaluates to `true`, the shape is discarded.\n   * This is more performant than the fragment discard expression because the fragment shader will not run at all.\n   * This expression can use all the uniforms, varyings and attributes available\n   * in the vertex shader, and should evaluate to a `bool` value.\n   * @param {string} expression Shape discard expression\n   * @return {ShaderBuilder} the builder object\n   */\n  setShapeDiscardExpression(expression) {\n    this.shapeDiscardExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * @return {string} The current shape discard expression; null if none has been set\n   */\n  getShapeDiscardExpression() {\n    return this.shapeDiscardExpression_;\n  }\n\n  /**\n   * Sets whether the symbols should rotate with the view or stay aligned with the map.\n   * Note: will only be used for point geometry shaders.\n   * @param {boolean} rotateWithView Rotate with view\n   * @return {ShaderBuilder} the builder object\n   */\n  setSymbolRotateWithView(rotateWithView) {\n    this.symbolRotateWithView_ = rotateWithView;\n    return this;\n  }\n\n  /**\n   * @param {string} expression Stroke width expression, returning value in pixels\n   * @return {ShaderBuilder} the builder object\n   */\n  setStrokeWidthExpression(expression) {\n    this.hasStroke_ = true;\n    this.strokeWidthExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * @param {string} expression Stroke color expression, evaluate to `vec4`: can rely on currentLengthPx and currentRadiusPx\n   * @return {ShaderBuilder} the builder object\n   */\n  setStrokeColorExpression(expression) {\n    this.hasStroke_ = true;\n    this.strokeColorExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * @return {string} The current stroke color expression\n   */\n  getStrokeColorExpression() {\n    return this.strokeColorExpression_;\n  }\n\n  /**\n   * @param {string} expression Stroke color expression, evaluate to `float`\n   * @return {ShaderBuilder} the builder object\n   */\n  setStrokeOffsetExpression(expression) {\n    this.strokeOffsetExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * @param {string} expression Stroke line cap expression, evaluate to `float`\n   * @return {ShaderBuilder} the builder object\n   */\n  setStrokeCapExpression(expression) {\n    this.strokeCapExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * @param {string} expression Stroke line join expression, evaluate to `float`\n   * @return {ShaderBuilder} the builder object\n   */\n  setStrokeJoinExpression(expression) {\n    this.strokeJoinExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * @param {string} expression Stroke miter limit expression, evaluate to `float`\n   * @return {ShaderBuilder} the builder object\n   */\n  setStrokeMiterLimitExpression(expression) {\n    this.strokeMiterLimitExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * @param {string} expression Stroke distance field expression, evaluate to `float`\n   * This can override the default distance field; can rely on currentLengthPx and currentRadiusPx\n   * @return {ShaderBuilder} the builder object\n   */\n  setStrokeDistanceFieldExpression(expression) {\n    this.strokeDistanceFieldExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * Defining a pattern length for a stroke lets us avoid having visual artifacts when\n   * a linestring is very long and thus has very high \"distance\" attributes on its vertices.\n   * If we apply a pattern or dash array to a stroke we know for certain that the full distance value\n   * is not necessary and can be trimmed down using `mod(currentDistance, patternLength)`.\n   * @param {string} expression Stroke expression that evaluates to a`float; value is expected to be\n   * in pixels.\n   * @return {ShaderBuilder} the builder object\n   */\n  setStrokePatternLengthExpression(expression) {\n    this.strokePatternLengthExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * @return {string} The current stroke pattern length expression.\n   */\n  getStrokePatternLengthExpression() {\n    return this.strokePatternLengthExpression_;\n  }\n\n  /**\n   * @param {string} expression Fill color expression, evaluate to `vec4`\n   * @return {ShaderBuilder} the builder object\n   */\n  setFillColorExpression(expression) {\n    this.hasFill_ = true;\n    this.fillColorExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * @return {string} The current fill color expression\n   */\n  getFillColorExpression() {\n    return this.fillColorExpression_;\n  }\n\n  /**\n   * Defining a pattern size for a fill pattern lets us avoid having visual artifacts that typically appear\n   * when zoomed in above zoom levels 14~15. If we can compute the fill pattern size we can more efficiently\n   * compute the offset of the pattern on screen, thus avoiding precision issues.\n   * @param {string} expression Size expression that evaluates to a `vec2` in pixels\n   * @return {ShaderBuilder} the builder object\n   */\n  setFillPatternSizeExpression(expression) {\n    this.fillPatternSizeExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * @return {string} The current fill pattern size expression.\n   */\n  getFillPatternSizeExpression() {\n    return this.fillPatternSizeExpression_;\n  }\n\n  addVertexShaderFunction(code) {\n    if (this.vertexShaderFunctions_.includes(code)) {\n      return this;\n    }\n    this.vertexShaderFunctions_.push(code);\n    return this;\n  }\n  addFragmentShaderFunction(code) {\n    if (this.fragmentShaderFunctions_.includes(code)) {\n      return this;\n    }\n    this.fragmentShaderFunctions_.push(code);\n    return this;\n  }\n\n  /**\n   * Generates a symbol vertex shader from the builder parameters\n   * @return {string|null} The full shader as a string; null if no size or color specified\n   */\n  getSymbolVertexShader() {\n    if (!this.hasSymbol_) {\n      return null;\n    }\n\n    return `${COMMON_HEADER}\n${this.uniforms_.map((uniform) => `uniform ${uniform.type} ${uniform.name};`).join('\\n')}\nattribute vec2 a_position;\nattribute vec2 a_localPosition;\nattribute vec2 a_hitColor;\n\nvarying vec2 v_texCoord;\nvarying vec2 v_quadCoord;\nvarying vec4 v_hitColor;\nvarying vec2 v_centerPx;\nvarying float v_angle;\nvarying vec2 v_quadSizePx;\n\n${this.attributes_\n  .map(\n    (attribute) => `attribute ${attribute.type} ${attribute.name};\nvarying ${attribute.varyingType} ${attribute.varyingName};`,\n  )\n  .join('\\n')}\n${this.vertexShaderFunctions_.join('\\n')}\nvec2 pxToScreen(vec2 coordPx) {\n  vec2 scaled = coordPx / u_viewportSizePx / 0.5;\n  return scaled;\n}\n\nvec2 screenToPx(vec2 coordScreen) {\n  return (coordScreen * 0.5 + 0.5) * u_viewportSizePx;\n}\n\nvoid main(void) {\n  v_quadSizePx = ${this.symbolSizeExpression_};\n  vec2 halfSizePx = v_quadSizePx * 0.5;\n  vec2 centerOffsetPx = ${this.symbolOffsetExpression_};\n  vec2 offsetPx = centerOffsetPx + a_localPosition * halfSizePx * vec2(1., -1.);\n  float angle = ${this.symbolRotationExpression_}${this.symbolRotateWithView_ ? ' + u_rotation' : ''};\n  float c = cos(-angle);\n  float s = sin(-angle);\n  offsetPx = vec2(c * offsetPx.x - s * offsetPx.y, s * offsetPx.x + c * offsetPx.y);\n  vec4 center = u_projectionMatrix * vec4(a_position, 0.0, 1.0);\n  gl_Position = center + vec4(pxToScreen(offsetPx), u_depth, 0.);\n  vec4 texCoord = ${this.texCoordExpression_};\n  float u = mix(texCoord.s, texCoord.p, a_localPosition.x * 0.5 + 0.5);\n  float v = mix(texCoord.t, texCoord.q, a_localPosition.y * 0.5 + 0.5);\n  v_texCoord = vec2(u, v);\n  v_hitColor = unpackColor(a_hitColor);\n  v_angle = angle;\n  c = cos(-v_angle);\n  s = sin(-v_angle);\n  centerOffsetPx = vec2(c * centerOffsetPx.x - s * centerOffsetPx.y, s * centerOffsetPx.x + c * centerOffsetPx.y);\n  v_centerPx = screenToPx(center.xy) + centerOffsetPx;\n${this.attributes_\n  .map(\n    (attribute) =>\n      `  ${attribute.varyingName} = ${attribute.varyingExpression};`,\n  )\n  .join('\\n')}\n${\n  this.shapeDiscardExpression_\n    ? `  if (${this.shapeDiscardExpression_}) { gl_Position = vec4(2.0, 2.0, 0.0, 0.0); }`\n    : ''\n}\n}`;\n  }\n\n  /**\n   * Generates a symbol fragment shader from the builder parameters\n   * @return {string|null} The full shader as a string; null if no size or color specified\n   */\n  getSymbolFragmentShader() {\n    if (!this.hasSymbol_) {\n      return null;\n    }\n\n    return `${COMMON_HEADER}\n${this.uniforms_.map((uniform) => `uniform ${uniform.type} ${uniform.name};`).join('\\n')}\nvarying vec2 v_texCoord;\nvarying vec4 v_hitColor;\nvarying vec2 v_centerPx;\nvarying float v_angle;\nvarying vec2 v_quadSizePx;\n${this.attributes_\n  .map(\n    (attribute) => `varying ${attribute.varyingType} ${attribute.varyingName};`,\n  )\n  .join('\\n')}\n${this.fragmentShaderFunctions_.join('\\n')}\n\nvoid main(void) {\n${this.attributes_\n  .map(\n    (attribute) =>\n      `  ${attribute.varyingType} ${attribute.name} = ${attribute.varyingName}; // assign to original attribute name`,\n  )\n  .join('\\n')}\n${this.fragmentDiscardExpression_ ? `  if (${this.fragmentDiscardExpression_}) { discard; }` : ''}\n  vec2 coordsPx = gl_FragCoord.xy / u_pixelRatio - v_centerPx; // relative to center\n  float c = cos(v_angle);\n  float s = sin(v_angle);\n  coordsPx = vec2(c * coordsPx.x - s * coordsPx.y, s * coordsPx.x + c * coordsPx.y);\n  gl_FragColor = ${this.symbolColorExpression_};\n  gl_FragColor.rgb *= gl_FragColor.a;\n  if (u_hitDetection > 0) {\n    if (gl_FragColor.a < 0.05) { discard; };\n    gl_FragColor = v_hitColor;\n  }\n}`;\n  }\n\n  /**\n   * Generates a stroke vertex shader from the builder parameters\n   * @return {string|null} The full shader as a string; null if no size or color specified\n   */\n  getStrokeVertexShader() {\n    if (!this.hasStroke_) {\n      return null;\n    }\n\n    return `${COMMON_HEADER}\n${this.uniforms_.map((uniform) => `uniform ${uniform.type} ${uniform.name};`).join('\\n')}\nattribute vec2 a_segmentStart;\nattribute vec2 a_segmentEnd;\nattribute vec2 a_localPosition;\nattribute float a_measureStart;\nattribute float a_measureEnd;\nattribute float a_angleTangentSum;\nattribute float a_distanceLow;\nattribute float a_distanceHigh;\nattribute vec2 a_joinAngles;\nattribute vec2 a_hitColor;\n\nvarying vec2 v_segmentStartPx;\nvarying vec2 v_segmentEndPx;\nvarying float v_angleStart;\nvarying float v_angleEnd;\nvarying float v_width;\nvarying vec4 v_hitColor;\nvarying float v_distancePx;\nvarying float v_measureStart;\nvarying float v_measureEnd;\n\n${this.attributes_\n  .map(\n    (attribute) => `attribute ${attribute.type} ${attribute.name};\nvarying ${attribute.varyingType} ${attribute.varyingName};`,\n  )\n  .join('\\n')}\n${this.vertexShaderFunctions_.join('\\n')}\n\nvec4 pxToScreen(vec2 pxPos) {\n  vec2 screenPos = 2.0 * pxPos / u_viewportSizePx - 1.0;\n  return vec4(screenPos, u_depth, 1.0);\n}\n\nbool isCap(float joinAngle) {\n  return joinAngle < -0.1;\n}\n\nvec2 getJoinOffsetDirection(vec2 normalPx, float joinAngle) {\n  float halfAngle = joinAngle / 2.0;\n  float c = cos(halfAngle);\n  float s = sin(halfAngle);\n  vec2 angleBisectorNormal = vec2(s * normalPx.x + c * normalPx.y, -c * normalPx.x + s * normalPx.y);\n  float length = 1.0 / s;\n  return angleBisectorNormal * length;\n}\n\nvec2 getOffsetPoint(vec2 point, vec2 normal, float joinAngle, float offsetPx) {\n  // if on a cap or the join angle is too high, offset the line along the segment normal\n  if (cos(joinAngle) > 0.998 || isCap(joinAngle)) {\n    return point - normal * offsetPx;\n  }\n  // offset is applied along the inverted normal (positive offset goes \"right\" relative to line direction)\n  return point - getJoinOffsetDirection(normal, joinAngle) * offsetPx;\n}\n\nvoid main(void) {\n  v_angleStart = a_joinAngles.x;\n  v_angleEnd = a_joinAngles.y;\n  float startEndRatio = a_localPosition.x * 0.5 + 0.5;\n  currentLineMetric = mix(a_measureStart, a_measureEnd, startEndRatio);\n  // we're reading the fractional part while keeping the sign (so -4.12 gives -0.12, 3.45 gives 0.45)\n\n  float lineWidth = ${this.strokeWidthExpression_};\n  float lineOffsetPx = ${this.strokeOffsetExpression_};\n\n  // compute segment start/end in px with offset\n  vec2 segmentStartPx = worldToPx(a_segmentStart);\n  vec2 segmentEndPx = worldToPx(a_segmentEnd);\n  vec2 tangentPx = normalize(segmentEndPx - segmentStartPx);\n  vec2 normalPx = vec2(-tangentPx.y, tangentPx.x);\n  segmentStartPx = getOffsetPoint(segmentStartPx, normalPx, v_angleStart, lineOffsetPx),\n  segmentEndPx = getOffsetPoint(segmentEndPx, normalPx, v_angleEnd, lineOffsetPx);\n\n  // compute current vertex position\n  float normalDir = -1. * a_localPosition.y;\n  float tangentDir = -1. * a_localPosition.x;\n  float angle = mix(v_angleStart, v_angleEnd, startEndRatio);\n  vec2 joinDirection;\n  vec2 positionPx = mix(segmentStartPx, segmentEndPx, startEndRatio);\n  // if angle is too high, do not make a proper join\n  if (cos(angle) > ${LINESTRING_ANGLE_COSINE_CUTOFF} || isCap(angle)) {\n    joinDirection = normalPx * normalDir - tangentPx * tangentDir;\n  } else {\n    joinDirection = getJoinOffsetDirection(normalPx * normalDir, angle);\n  }\n  positionPx = positionPx + joinDirection * (lineWidth * 0.5 + 1.); // adding 1 pixel for antialiasing\n  gl_Position = pxToScreen(positionPx);\n\n  v_segmentStartPx = segmentStartPx;\n  v_segmentEndPx = segmentEndPx;\n  v_width = lineWidth;\n  v_hitColor = unpackColor(a_hitColor);\n\n  v_distancePx = a_distanceLow / u_resolution - (lineOffsetPx * a_angleTangentSum);\n  float distanceHighPx = a_distanceHigh / u_resolution;\n  ${\n    this.strokePatternLengthExpression_ !== null\n      ? `v_distancePx = mod(v_distancePx, ${this.strokePatternLengthExpression_});\n  distanceHighPx = mod(distanceHighPx, ${this.strokePatternLengthExpression_});\n  `\n      : ''\n  }v_distancePx += distanceHighPx;\n\n  v_measureStart = a_measureStart;\n  v_measureEnd = a_measureEnd;\n${this.attributes_\n  .map(\n    (attribute) =>\n      `  ${attribute.varyingName} = ${attribute.varyingExpression};`,\n  )\n  .join('\\n')}\n${\n  this.shapeDiscardExpression_\n    ? `  if (${this.shapeDiscardExpression_}) { gl_Position = vec4(2.0, 2.0, 0.0, 0.0); }`\n    : ''\n}\n}`;\n  }\n\n  /**\n   * Generates a stroke fragment shader from the builder parameters\n   *\n   * @return {string|null} The full shader as a string; null if no size or color specified\n   */\n  getStrokeFragmentShader() {\n    if (!this.hasStroke_) {\n      return null;\n    }\n\n    return `${COMMON_HEADER}\n${this.uniforms_.map((uniform) => `uniform ${uniform.type} ${uniform.name};`).join('\\n')}\nvarying vec2 v_segmentStartPx;\nvarying vec2 v_segmentEndPx;\nvarying float v_angleStart;\nvarying float v_angleEnd;\nvarying float v_width;\nvarying vec4 v_hitColor;\nvarying float v_distancePx;\nvarying float v_measureStart;\nvarying float v_measureEnd;\n${this.attributes_\n  .map(\n    (attribute) => `varying ${attribute.varyingType} ${attribute.varyingName};`,\n  )\n  .join('\\n')}\n${this.fragmentShaderFunctions_.join('\\n')}\n\nbool isCap(float joinAngle) {\n  return joinAngle < -0.1;\n}\n\nfloat segmentDistanceField(vec2 point, vec2 start, vec2 end, float width) {\n  vec2 tangent = normalize(end - start);\n  vec2 normal = vec2(-tangent.y, tangent.x);\n  vec2 startToPoint = point - start;\n  return abs(dot(startToPoint, normal)) - width * 0.5;\n}\n\nfloat buttCapDistanceField(vec2 point, vec2 start, vec2 end) {\n  vec2 startToPoint = point - start;\n  vec2 tangent = normalize(end - start);\n  return dot(startToPoint, -tangent);\n}\n\nfloat squareCapDistanceField(vec2 point, vec2 start, vec2 end, float width) {\n  return buttCapDistanceField(point, start, end) - width * 0.5;\n}\n\nfloat roundCapDistanceField(vec2 point, vec2 start, vec2 end, float width) {\n  float onSegment = max(0., 1000. * dot(point - start, end - start)); // this is very high when inside the segment\n  return length(point - start) - width * 0.5 - onSegment;\n}\n\nfloat roundJoinDistanceField(vec2 point, vec2 start, vec2 end, float width) {\n  return roundCapDistanceField(point, start, end, width);\n}\n\nfloat bevelJoinField(vec2 point, vec2 start, vec2 end, float width, float joinAngle) {\n  vec2 startToPoint = point - start;\n  vec2 tangent = normalize(end - start);\n  float c = cos(joinAngle * 0.5);\n  float s = sin(joinAngle * 0.5);\n  float direction = -sign(sin(joinAngle));\n  vec2 bisector = vec2(c * tangent.x - s * tangent.y, s * tangent.x + c * tangent.y);\n  float radius = width * 0.5 * s;\n  return dot(startToPoint, bisector * direction) - radius;\n}\n\nfloat miterJoinDistanceField(vec2 point, vec2 start, vec2 end, float width, float joinAngle) {\n  if (cos(joinAngle) > ${LINESTRING_ANGLE_COSINE_CUTOFF}) { // avoid risking a division by zero\n    return bevelJoinField(point, start, end, width, joinAngle);\n  }\n  float miterLength = 1. / sin(joinAngle * 0.5);\n  float miterLimit = ${this.strokeMiterLimitExpression_};\n  if (miterLength > miterLimit) {\n    return bevelJoinField(point, start, end, width, joinAngle);\n  }\n  return -1000.;\n}\n\nfloat capDistanceField(vec2 point, vec2 start, vec2 end, float width, float capType) {\n   if (capType == ${stringToGlsl('butt')}) {\n    return buttCapDistanceField(point, start, end);\n  } else if (capType == ${stringToGlsl('square')}) {\n    return squareCapDistanceField(point, start, end, width);\n  }\n  return roundCapDistanceField(point, start, end, width);\n}\n\nfloat joinDistanceField(vec2 point, vec2 start, vec2 end, float width, float joinAngle, float joinType) {\n  if (joinType == ${stringToGlsl('bevel')}) {\n    return bevelJoinField(point, start, end, width, joinAngle);\n  } else if (joinType == ${stringToGlsl('miter')}) {\n    return miterJoinDistanceField(point, start, end, width, joinAngle);\n  }\n  return roundJoinDistanceField(point, start, end, width);\n}\n\nfloat computeSegmentPointDistance(vec2 point, vec2 start, vec2 end, float width, float joinAngle, float capType, float joinType) {\n  if (isCap(joinAngle)) {\n    return capDistanceField(point, start, end, width, capType);\n  }\n  return joinDistanceField(point, start, end, width, joinAngle, joinType);\n}\n\nfloat distanceFromSegment(vec2 point, vec2 start, vec2 end) {\n  vec2 tangent = end - start;\n  vec2 startToPoint = point - start;\n  // inspire by capsule fn in https://iquilezles.org/articles/distfunctions/\n  float h = clamp(dot(startToPoint, tangent) / dot(tangent, tangent), 0.0, 1.0);\n  return length(startToPoint - tangent * h);\n}\n\nvoid main(void) {\n${this.attributes_\n  .map(\n    (attribute) =>\n      `  ${attribute.varyingType} ${attribute.name} = ${attribute.varyingName}; // assign to original attribute name`,\n  )\n  .join('\\n')}\n\n  vec2 currentPointPx = gl_FragCoord.xy / u_pixelRatio;\n  vec2 worldPos = pxToWorld(currentPointPx);\n  if (\n    abs(u_renderExtent[0] - u_renderExtent[2]) > 0.0 && (\n      worldPos[0] < u_renderExtent[0] ||\n      worldPos[1] < u_renderExtent[1] ||\n      worldPos[0] > u_renderExtent[2] ||\n      worldPos[1] > u_renderExtent[3]\n    )\n  ) {\n    discard;\n  }\n\n  float segmentLengthPx = length(v_segmentEndPx - v_segmentStartPx);\n  segmentLengthPx = max(segmentLengthPx, 1.17549429e-38); // avoid divide by zero\n  vec2 segmentTangent = (v_segmentEndPx - v_segmentStartPx) / segmentLengthPx;\n  vec2 segmentNormal = vec2(-segmentTangent.y, segmentTangent.x);\n  vec2 startToPointPx = currentPointPx - v_segmentStartPx;\n  float lengthToPointPx = max(0., min(dot(segmentTangent, startToPointPx), segmentLengthPx));\n  float currentLengthPx = lengthToPointPx + v_distancePx;\n  float currentRadiusPx = distanceFromSegment(currentPointPx, v_segmentStartPx, v_segmentEndPx);\n  float currentRadiusRatio = dot(segmentNormal, startToPointPx) * 2. / v_width;\n  currentLineMetric = mix(v_measureStart, v_measureEnd, lengthToPointPx / segmentLengthPx);\n\n${this.fragmentDiscardExpression_ ? `  if (${this.fragmentDiscardExpression_}) { discard; }` : ''}\n\n  float capType = ${this.strokeCapExpression_};\n  float joinType = ${this.strokeJoinExpression_};\n  float segmentStartDistance = computeSegmentPointDistance(currentPointPx, v_segmentStartPx, v_segmentEndPx, v_width, v_angleStart, capType, joinType);\n  float segmentEndDistance = computeSegmentPointDistance(currentPointPx, v_segmentEndPx, v_segmentStartPx, v_width, v_angleEnd, capType, joinType);\n  float distanceField = max(\n    segmentDistanceField(currentPointPx, v_segmentStartPx, v_segmentEndPx, v_width),\n    max(segmentStartDistance, segmentEndDistance)\n  );\n  distanceField = max(distanceField, ${this.strokeDistanceFieldExpression_});\n\n  vec4 color = ${this.strokeColorExpression_};\n  color.a *= smoothstep(0.5, -0.5, distanceField);\n  gl_FragColor = color;\n  gl_FragColor.a *= u_globalAlpha;\n  gl_FragColor.rgb *= gl_FragColor.a;\n  if (u_hitDetection > 0) {\n    if (gl_FragColor.a < 0.1) { discard; };\n    gl_FragColor = v_hitColor;\n  }\n}`;\n  }\n\n  /**\n   * Generates a fill vertex shader from the builder parameters\n   *\n   * @return {string|null} The full shader as a string; null if no color specified\n   */\n  getFillVertexShader() {\n    if (!this.hasFill_) {\n      return null;\n    }\n\n    return `${COMMON_HEADER}\n${this.uniforms_.map((uniform) => `uniform ${uniform.type} ${uniform.name};`).join('\\n')}\nattribute vec2 a_position;\nattribute vec2 a_hitColor;\n\nvarying vec4 v_hitColor;\nvarying vec2 v_patternOriginPx;\nvarying vec2 v_patternSizePx;\n\n${this.attributes_\n  .map(\n    (attribute) => `attribute ${attribute.type} ${attribute.name};\nvarying ${attribute.varyingType} ${attribute.varyingName};`,\n  )\n  .join('\\n')}\n${this.vertexShaderFunctions_.join('\\n')}\nvoid main(void) {\n  gl_Position = u_projectionMatrix * vec4(a_position, u_depth, 1.0);\n  v_hitColor = unpackColor(a_hitColor);\n${\n  this.fillPatternSizeExpression_ !== null\n    ? `\n  // this computes the pattern offset in screenspace using double-float arithmetics\n  v_patternSizePx = ${this.fillPatternSizeExpression_};\n  vec2 patternSizeScaledX = df_mul(df_from(v_patternSizePx.x), u_df_patternScaleRatio);\n  vec2 patternSizeScaledY = df_mul(df_from(v_patternSizePx.y), u_df_patternScaleRatio);\n  v_patternOriginPx = vec2(\n    df_mod(u_df_patternOriginX, patternSizeScaledX),\n    df_mod(u_df_patternOriginY, patternSizeScaledY)\n  );\n\n  // reapply rotation to the pattern origin\n  v_patternOriginPx -= u_viewportSizePx / 2.; // translate to viewport center\n  v_patternOriginPx = vec2(\n    cos(-u_rotation) * v_patternOriginPx.x - sin(-u_rotation) * v_patternOriginPx.y,\n    sin(-u_rotation) * v_patternOriginPx.x + cos(-u_rotation) * v_patternOriginPx.y\n  );\n  v_patternOriginPx += u_viewportSizePx / 2.; // translate back\n`\n    : '  v_patternOriginPx = vec2(0.);'\n}\n${this.attributes_\n  .map(\n    (attribute) =>\n      `  ${attribute.varyingName} = ${attribute.varyingExpression};`,\n  )\n  .join('\\n')}\n${\n  this.shapeDiscardExpression_\n    ? `  if (${this.shapeDiscardExpression_}) { gl_Position = vec4(2.0, 2.0, 0.0, 0.0); }`\n    : ''\n}\n}`;\n  }\n\n  /**\n   * Generates a fill fragment shader from the builder parameters\n   * @return {string|null} The full shader as a string; null if no color specified\n   */\n  getFillFragmentShader() {\n    if (!this.hasFill_) {\n      return null;\n    }\n\n    return `${COMMON_HEADER}\n${this.uniforms_.map((uniform) => `uniform ${uniform.type} ${uniform.name};`).join('\\n')}\nvarying vec4 v_hitColor;\nvarying vec2 v_patternOriginPx;\nvarying vec2 v_patternSizePx;\n${this.attributes_\n  .map(\n    (attribute) => `varying ${attribute.varyingType} ${attribute.varyingName};`,\n  )\n  .join('\\n')}\n${this.fragmentShaderFunctions_.join('\\n')}\n\nvoid main(void) {\n${this.attributes_\n  .map(\n    (attribute) =>\n      `  ${attribute.varyingType} ${attribute.name} = ${attribute.varyingName}; // assign to original attribute name`,\n  )\n  .join('\\n')}\n  vec2 pxPos = gl_FragCoord.xy / u_pixelRatio;\n  vec2 worldPos = pxToWorld(pxPos);\n  if (\n    abs(u_renderExtent[0] - u_renderExtent[2]) > 0.0 && (\n      worldPos[0] < u_renderExtent[0] ||\n      worldPos[1] < u_renderExtent[1] ||\n      worldPos[0] > u_renderExtent[2] ||\n      worldPos[1] > u_renderExtent[3]\n    )\n  ) {\n    discard;\n  }\n${this.fragmentDiscardExpression_ ? `  if (${this.fragmentDiscardExpression_}) { discard; }` : ''}\n  gl_FragColor = ${this.fillColorExpression_};\n  gl_FragColor.a *= u_globalAlpha;\n  gl_FragColor.rgb *= gl_FragColor.a;\n  if (u_hitDetection > 0) {\n    if (gl_FragColor.a < 0.1) { discard; };\n    gl_FragColor = v_hitColor;\n  }\n}`;\n  }\n}\n","/**\n * @module ol/render/webgl/MixedGeometryBatch\n */\nimport {inflateEnds} from '../../geom/flat/orient.js';\nimport RenderFeature from '../../render/Feature.js';\nimport {getUid} from '../../util.js';\n\n/**\n * @typedef {import(\"../../Feature.js\").default} Feature\n */\n/**\n * @typedef {import(\"../../geom/Geometry.js\").Type} GeometryType\n */\n\n/**\n * @typedef {Object} GeometryBatchItem Object that holds a reference to a feature as well as the raw coordinates of its various geometries\n * @property {Feature|RenderFeature} feature Feature\n * @property {Array<Array<number>>} flatCoordss Array of flat coordinates arrays, one for each geometry related to the feature\n * @property {number} [verticesCount] Only defined for linestring and polygon batches\n * @property {number} [ringsCount] Only defined for polygon batches\n * @property {Array<Array<number>>} [ringsVerticesCounts] Array of vertices counts in each ring for each geometry; only defined for polygons batches\n * @property {number} [ref] The reference in the global batch (used for hit detection)\n */\n\n/**\n * @typedef {PointGeometryBatch|LineStringGeometryBatch|PolygonGeometryBatch} GeometryBatch\n */\n\n/**\n * @typedef {Object} PolygonGeometryBatch A geometry batch specific to polygons\n * @property {Object<string, GeometryBatchItem>} entries Dictionary of all entries in the batch with associated computed values.\n * One entry corresponds to one feature. Key is feature uid.\n * @property {number} geometriesCount Amount of geometries in the batch.\n * @property {number} verticesCount Amount of vertices from geometries in the batch.\n * @property {number} ringsCount How many outer and inner rings in this batch.\n */\n\n/**\n * @typedef {Object} LineStringGeometryBatch A geometry batch specific to lines\n * @property {Object<string, GeometryBatchItem>} entries Dictionary of all entries in the batch with associated computed values.\n * One entry corresponds to one feature. Key is feature uid.\n * @property {number} geometriesCount Amount of geometries in the batch.\n * @property {number} verticesCount Amount of vertices from geometries in the batch.\n */\n\n/**\n * @typedef {Object} PointGeometryBatch A geometry batch specific to points\n * @property {Object<string, GeometryBatchItem>} entries Dictionary of all entries in the batch with associated computed values.\n * One entry corresponds to one feature. Key is feature uid.\n * @property {number} geometriesCount Amount of geometries in the batch.\n */\n\n/**\n * @classdesc This class is used to group several geometries of various types together for faster rendering.\n * Three inner batches are maintained for polygons, lines and points. Each time a feature is added, changed or removed\n * from the batch, these inner batches are modified accordingly in order to keep them up-to-date.\n *\n * A feature can be present in several inner batches, for example a polygon geometry will be present in the polygon batch\n * and its linear rings will be present in the line batch. Multi geometries are also broken down into individual geometries\n * and added to the corresponding batches in a recursive manner.\n *\n * Corresponding {@link module:ol/render/webgl/BatchRenderer} instances are then used to generate the render instructions\n * and WebGL buffers (vertices and indices) for each inner batches; render instructions are stored on the inner batches,\n * alongside the transform used to convert world coords to screen coords at the time these instructions were generated.\n * The resulting WebGL buffers are stored on the batches as well.\n *\n * An important aspect of geometry batches is that there is no guarantee that render instructions and WebGL buffers\n * are synchronized, i.e. render instructions can describe a new state while WebGL buffers might not have been written yet.\n * This is why two world-to-screen transforms are stored on each batch: one for the render instructions and one for\n * the WebGL buffers.\n */\nclass MixedGeometryBatch {\n  constructor() {\n    /**\n     * @private\n     */\n    this.globalCounter_ = 0;\n\n    /**\n     * Refs are used as keys for hit detection.\n     * @type {Map<number, Feature|RenderFeature>}\n     * @private\n     */\n    this.refToFeature_ = new Map();\n\n    /**\n     * Features are split in \"entries\", which are individual geometries. We use the following map to share a single ref for all those entries.\n     * @type {Map<string, number>}\n     * @private\n     */\n    this.uidToRef_ = new Map();\n\n    /**\n     * The precision in WebGL shaders is limited.\n     * To keep the refs as small as possible we maintain an array of freed up references.\n     * @type {Array<number>}\n     * @private\n     */\n    this.freeGlobalRef_ = [];\n\n    /**\n     * @type {PolygonGeometryBatch}\n     */\n    this.polygonBatch = {\n      entries: {},\n      geometriesCount: 0,\n      verticesCount: 0,\n      ringsCount: 0,\n    };\n\n    /**\n     * @type {PointGeometryBatch}\n     */\n    this.pointBatch = {\n      entries: {},\n      geometriesCount: 0,\n    };\n\n    /**\n     * @type {LineStringGeometryBatch}\n     */\n    this.lineStringBatch = {\n      entries: {},\n      geometriesCount: 0,\n      verticesCount: 0,\n    };\n  }\n\n  /**\n   * @param {Array<Feature|RenderFeature>} features Array of features to add to the batch\n   * @param {import(\"../../proj.js\").TransformFunction} [projectionTransform] Projection transform.\n   */\n  addFeatures(features, projectionTransform) {\n    for (let i = 0; i < features.length; i++) {\n      this.addFeature(features[i], projectionTransform);\n    }\n  }\n\n  /**\n   * @param {Feature|RenderFeature} feature Feature to add to the batch\n   * @param {import(\"../../proj.js\").TransformFunction} [projectionTransform] Projection transform.\n   */\n  addFeature(feature, projectionTransform) {\n    let geometry = feature.getGeometry();\n    if (!geometry) {\n      return;\n    }\n    if (projectionTransform) {\n      geometry = geometry.clone();\n      geometry.applyTransform(projectionTransform);\n    }\n    this.addGeometry_(geometry, feature);\n  }\n\n  /**\n   * @param {Feature|RenderFeature} feature Feature\n   * @return {GeometryBatchItem|void} the cleared entry\n   * @private\n   */\n  clearFeatureEntryInPointBatch_(feature) {\n    const featureUid = getUid(feature);\n    const entry = this.pointBatch.entries[featureUid];\n    if (!entry) {\n      return;\n    }\n    this.pointBatch.geometriesCount -= entry.flatCoordss.length;\n    delete this.pointBatch.entries[featureUid];\n    return entry;\n  }\n\n  /**\n   * @param {Feature|RenderFeature} feature Feature\n   * @return {GeometryBatchItem|void} the cleared entry\n   * @private\n   */\n  clearFeatureEntryInLineStringBatch_(feature) {\n    const featureUid = getUid(feature);\n    const entry = this.lineStringBatch.entries[featureUid];\n    if (!entry) {\n      return;\n    }\n    this.lineStringBatch.verticesCount -= entry.verticesCount;\n    this.lineStringBatch.geometriesCount -= entry.flatCoordss.length;\n    delete this.lineStringBatch.entries[featureUid];\n    return entry;\n  }\n\n  /**\n   * @param {Feature|RenderFeature} feature Feature\n   * @return {GeometryBatchItem|void} the cleared entry\n   * @private\n   */\n  clearFeatureEntryInPolygonBatch_(feature) {\n    const featureUid = getUid(feature);\n    const entry = this.polygonBatch.entries[featureUid];\n    if (!entry) {\n      return;\n    }\n    this.polygonBatch.verticesCount -= entry.verticesCount;\n    this.polygonBatch.ringsCount -= entry.ringsCount;\n    this.polygonBatch.geometriesCount -= entry.flatCoordss.length;\n    delete this.polygonBatch.entries[featureUid];\n    return entry;\n  }\n\n  /**\n   * @param {import(\"../../geom.js\").Geometry|RenderFeature} geometry Geometry\n   * @param {Feature|RenderFeature} feature Feature\n   * @private\n   */\n  addGeometry_(geometry, feature) {\n    const type = geometry.getType();\n    switch (type) {\n      case 'GeometryCollection': {\n        const geometries =\n          /** @type {import(\"../../geom.js\").GeometryCollection} */ (\n            geometry\n          ).getGeometriesArray();\n        for (const geometry of geometries) {\n          this.addGeometry_(geometry, feature);\n        }\n        break;\n      }\n      case 'MultiPolygon': {\n        const multiPolygonGeom =\n          /** @type {import(\"../../geom.js\").MultiPolygon} */ (geometry);\n        this.addCoordinates_(\n          type,\n          multiPolygonGeom.getFlatCoordinates(),\n          multiPolygonGeom.getEndss(),\n          feature,\n          getUid(feature),\n          multiPolygonGeom.getStride(),\n        );\n        break;\n      }\n      case 'MultiLineString': {\n        const multiLineGeom =\n          /** @type {import(\"../../geom.js\").MultiLineString|RenderFeature} */ (\n            geometry\n          );\n        this.addCoordinates_(\n          type,\n          multiLineGeom.getFlatCoordinates(),\n          multiLineGeom.getEnds(),\n          feature,\n          getUid(feature),\n          multiLineGeom.getStride(),\n        );\n        break;\n      }\n      case 'MultiPoint': {\n        const multiPointGeom =\n          /** @type {import(\"../../geom.js\").MultiPoint|RenderFeature} */ (\n            geometry\n          );\n        this.addCoordinates_(\n          type,\n          multiPointGeom.getFlatCoordinates(),\n          null,\n          feature,\n          getUid(feature),\n          multiPointGeom.getStride(),\n        );\n        break;\n      }\n      case 'Polygon': {\n        const polygonGeom =\n          /** @type {import(\"../../geom.js\").Polygon|RenderFeature} */ (\n            geometry\n          );\n        this.addCoordinates_(\n          type,\n          polygonGeom.getFlatCoordinates(),\n          polygonGeom.getEnds(),\n          feature,\n          getUid(feature),\n          polygonGeom.getStride(),\n        );\n        break;\n      }\n      case 'Point': {\n        const pointGeom = /** @type {import(\"../../geom.js\").Point} */ (\n          geometry\n        );\n        this.addCoordinates_(\n          type,\n          pointGeom.getFlatCoordinates(),\n          null,\n          feature,\n          getUid(feature),\n          pointGeom.getStride(),\n        );\n        break;\n      }\n      case 'LineString':\n      case 'LinearRing': {\n        const lineGeom = /** @type {import(\"../../geom.js\").LineString} */ (\n          geometry\n        );\n\n        const stride = lineGeom.getStride();\n\n        this.addCoordinates_(\n          type,\n          lineGeom.getFlatCoordinates(),\n          null,\n          feature,\n          getUid(feature),\n          stride,\n          lineGeom.getLayout?.(),\n        );\n        break;\n      }\n      default:\n      // pass\n    }\n  }\n\n  /**\n   * @param {GeometryType} type Geometry type\n   * @param {Array<number>} flatCoords Flat coordinates\n   * @param {Array<number> | Array<Array<number>> | null} ends Coordinate ends\n   * @param {Feature|RenderFeature} feature Feature\n   * @param {string} featureUid Feature uid\n   * @param {number} stride Stride\n   * @param {import('../../geom/Geometry.js').GeometryLayout} [layout] Layout\n   * @private\n   */\n  addCoordinates_(type, flatCoords, ends, feature, featureUid, stride, layout) {\n    /** @type {number} */\n    let verticesCount;\n    switch (type) {\n      case 'MultiPolygon': {\n        const multiPolygonEndss = /** @type {Array<Array<number>>} */ (ends);\n        for (let i = 0, ii = multiPolygonEndss.length; i < ii; i++) {\n          let polygonEnds = multiPolygonEndss[i];\n          const prevPolygonEnds = i > 0 ? multiPolygonEndss[i - 1] : null;\n          const startIndex = prevPolygonEnds\n            ? prevPolygonEnds[prevPolygonEnds.length - 1]\n            : 0;\n          const endIndex = polygonEnds[polygonEnds.length - 1];\n          polygonEnds =\n            startIndex > 0\n              ? polygonEnds.map((end) => end - startIndex)\n              : polygonEnds;\n          this.addCoordinates_(\n            'Polygon',\n            flatCoords.slice(startIndex, endIndex),\n            polygonEnds,\n            feature,\n            featureUid,\n            stride,\n            layout,\n          );\n        }\n        break;\n      }\n      case 'MultiLineString': {\n        const multiLineEnds = /** @type {Array<number>} */ (ends);\n        for (let i = 0, ii = multiLineEnds.length; i < ii; i++) {\n          const startIndex = i > 0 ? multiLineEnds[i - 1] : 0;\n          this.addCoordinates_(\n            'LineString',\n            flatCoords.slice(startIndex, multiLineEnds[i]),\n            null,\n            feature,\n            featureUid,\n            stride,\n            layout,\n          );\n        }\n        break;\n      }\n      case 'MultiPoint':\n        for (let i = 0, ii = flatCoords.length; i < ii; i += stride) {\n          this.addCoordinates_(\n            'Point',\n            flatCoords.slice(i, i + 2),\n            null,\n            feature,\n            featureUid,\n            null,\n            null,\n          );\n        }\n        break;\n      case 'Polygon': {\n        const polygonEnds = /** @type {Array<number>} */ (ends);\n        if (feature instanceof RenderFeature) {\n          const multiPolygonEnds = inflateEnds(flatCoords, polygonEnds);\n          if (multiPolygonEnds.length > 1) {\n            this.addCoordinates_(\n              'MultiPolygon',\n              flatCoords,\n              multiPolygonEnds,\n              feature,\n              featureUid,\n              stride,\n              layout,\n            );\n            return;\n          }\n        }\n        if (!this.polygonBatch.entries[featureUid]) {\n          this.polygonBatch.entries[featureUid] = this.addRefToEntry_(\n            featureUid,\n            {\n              feature: feature,\n              flatCoordss: [],\n              verticesCount: 0,\n              ringsCount: 0,\n              ringsVerticesCounts: [],\n            },\n          );\n        }\n        verticesCount = flatCoords.length / stride;\n        const ringsCount = ends.length;\n        const ringsVerticesCount = ends.map((end, ind, arr) =>\n          ind > 0 ? (end - arr[ind - 1]) / stride : end / stride,\n        );\n        this.polygonBatch.verticesCount += verticesCount;\n        this.polygonBatch.ringsCount += ringsCount;\n        this.polygonBatch.geometriesCount++;\n        this.polygonBatch.entries[featureUid].flatCoordss.push(\n          getFlatCoordinatesXY(flatCoords, stride),\n        );\n        this.polygonBatch.entries[featureUid].ringsVerticesCounts.push(\n          ringsVerticesCount,\n        );\n        this.polygonBatch.entries[featureUid].verticesCount += verticesCount;\n        this.polygonBatch.entries[featureUid].ringsCount += ringsCount;\n        for (let i = 0, ii = polygonEnds.length; i < ii; i++) {\n          const startIndex = i > 0 ? polygonEnds[i - 1] : 0;\n          this.addCoordinates_(\n            'LinearRing',\n            flatCoords.slice(startIndex, polygonEnds[i]),\n            null,\n            feature,\n            featureUid,\n            stride,\n            layout,\n          );\n        }\n        break;\n      }\n      case 'Point':\n        if (!this.pointBatch.entries[featureUid]) {\n          this.pointBatch.entries[featureUid] = this.addRefToEntry_(\n            featureUid,\n            {\n              feature: feature,\n              flatCoordss: [],\n            },\n          );\n        }\n        this.pointBatch.geometriesCount++;\n        this.pointBatch.entries[featureUid].flatCoordss.push(flatCoords);\n        break;\n      case 'LineString':\n      case 'LinearRing':\n        if (!this.lineStringBatch.entries[featureUid]) {\n          this.lineStringBatch.entries[featureUid] = this.addRefToEntry_(\n            featureUid,\n            {\n              feature: feature,\n              flatCoordss: [],\n              verticesCount: 0,\n            },\n          );\n        }\n        verticesCount = flatCoords.length / stride;\n        this.lineStringBatch.verticesCount += verticesCount;\n        this.lineStringBatch.geometriesCount++;\n        this.lineStringBatch.entries[featureUid].flatCoordss.push(\n          getFlatCoordinatesXYM(flatCoords, stride, layout),\n        );\n        this.lineStringBatch.entries[featureUid].verticesCount += verticesCount;\n        break;\n      default:\n      // pass\n    }\n  }\n\n  /**\n   * @param {string} featureUid Feature uid\n   * @param {GeometryBatchItem} entry The entry to add\n   * @return {GeometryBatchItem} the added entry\n   * @private\n   */\n  addRefToEntry_(featureUid, entry) {\n    const currentRef = this.uidToRef_.get(featureUid);\n\n    // the ref starts at 1 to distinguish from white color (no feature)\n    const ref =\n      currentRef || this.freeGlobalRef_.pop() || ++this.globalCounter_;\n    entry.ref = ref;\n    if (!currentRef) {\n      this.refToFeature_.set(ref, entry.feature);\n      this.uidToRef_.set(featureUid, ref);\n    }\n    return entry;\n  }\n\n  /**\n   * Return a ref to the pool of available refs.\n   * @param {number} ref the ref to return\n   * @param {string} featureUid the feature uid\n   * @private\n   */\n  removeRef_(ref, featureUid) {\n    if (!ref) {\n      throw new Error('This feature has no ref: ' + featureUid);\n    }\n    this.refToFeature_.delete(ref);\n    this.uidToRef_.delete(featureUid);\n    this.freeGlobalRef_.push(ref);\n  }\n\n  /**\n   * @param {Feature|RenderFeature} feature Feature\n   * @param {import(\"../../proj.js\").TransformFunction} [projectionTransform] Projection transform.\n   */\n  changeFeature(feature, projectionTransform) {\n    // the feature is not present in the batch; do not add it to avoid unexpected behaviors\n    if (!this.uidToRef_.get(getUid(feature))) {\n      return;\n    }\n    this.removeFeature(feature);\n    let geometry = feature.getGeometry();\n    if (!geometry) {\n      return;\n    }\n    if (projectionTransform) {\n      geometry = geometry.clone();\n      geometry.applyTransform(projectionTransform);\n    }\n    this.addGeometry_(geometry, feature);\n  }\n\n  /**\n   * @param {Feature|RenderFeature} feature Feature\n   */\n  removeFeature(feature) {\n    let entry = this.clearFeatureEntryInPointBatch_(feature);\n    entry = this.clearFeatureEntryInPolygonBatch_(feature) || entry;\n    entry = this.clearFeatureEntryInLineStringBatch_(feature) || entry;\n    if (entry) {\n      this.removeRef_(entry.ref, getUid(entry.feature));\n    }\n  }\n\n  clear() {\n    this.polygonBatch.entries = {};\n    this.polygonBatch.geometriesCount = 0;\n    this.polygonBatch.verticesCount = 0;\n    this.polygonBatch.ringsCount = 0;\n    this.lineStringBatch.entries = {};\n    this.lineStringBatch.geometriesCount = 0;\n    this.lineStringBatch.verticesCount = 0;\n    this.pointBatch.entries = {};\n    this.pointBatch.geometriesCount = 0;\n    this.globalCounter_ = 0;\n    this.freeGlobalRef_ = [];\n    this.refToFeature_.clear();\n    this.uidToRef_.clear();\n  }\n\n  /**\n   * Resolve the feature associated to a ref.\n   * @param {number} ref Hit detected ref\n   * @return {Feature|RenderFeature} feature\n   */\n  getFeatureFromRef(ref) {\n    return this.refToFeature_.get(ref);\n  }\n\n  isEmpty() {\n    return this.globalCounter_ === 0;\n  }\n\n  /**\n   * Will return a new instance of this class that only contains the features\n   * for which the provided callback returned true\n   * @param {function((Feature|RenderFeature)): boolean} featureFilter Feature filter callback\n   * @return {MixedGeometryBatch} Filtered geometry batch\n   */\n  filter(featureFilter) {\n    const filtered = new MixedGeometryBatch();\n    filtered.globalCounter_ = this.globalCounter_;\n    filtered.uidToRef_ = this.uidToRef_;\n    filtered.refToFeature_ = this.refToFeature_;\n    let empty = true;\n    for (const feature of this.refToFeature_.values()) {\n      if (featureFilter(feature)) {\n        filtered.addFeature(feature);\n        empty = false;\n      }\n    }\n    // no feature was added at all; simply return an empty batch for consistency downstream\n    if (empty) {\n      return new MixedGeometryBatch();\n    }\n    return filtered;\n  }\n}\n\n/**\n * @param {Array<number>} flatCoords Flat coords\n * @param {number} stride Stride\n * @return {Array<number>} Flat coords with only XY components\n */\nfunction getFlatCoordinatesXY(flatCoords, stride) {\n  if (stride === 2) {\n    return flatCoords;\n  }\n  return flatCoords.filter((v, i) => i % stride < 2);\n}\n\n/**\n * @param {Array<number>} flatCoords Flat coords\n * @param {number} stride Stride\n * @param {string} layout Layout\n * @return {Array<number>} Flat coords with only XY components\n */\nfunction getFlatCoordinatesXYM(flatCoords, stride, layout) {\n  if (stride === 3 && layout === 'XYM') {\n    return flatCoords;\n  }\n  // this is XYZM layout\n  if (stride === 4) {\n    return flatCoords.filter((v, i) => i % stride !== 2);\n  }\n  // this is XYZ layout\n  if (stride === 3) {\n    return flatCoords.map((v, i) => (i % stride !== 2 ? v : 0));\n  }\n  // this is XY layout\n  return new Array(flatCoords.length * 1.5)\n    .fill(0)\n    .map((v, i) => (i % 3 === 2 ? 0 : flatCoords[Math.round(i / 1.5)]));\n}\n\nexport default MixedGeometryBatch;\n","/**\n * @module ol/render/webgl/constants\n */\n\n/**\n * @enum {string}\n */\nexport const WebGLWorkerMessageType = {\n  GENERATE_POLYGON_BUFFERS: 'GENERATE_POLYGON_BUFFERS',\n  GENERATE_POINT_BUFFERS: 'GENERATE_POINT_BUFFERS',\n  GENERATE_LINE_STRING_BUFFERS: 'GENERATE_LINE_STRING_BUFFERS',\n};\n\n/**\n * @typedef {Object} WebGLWorkerGenerateBuffersMessage\n * This message will trigger the generation of a vertex and an index buffer based on the given render instructions.\n * When the buffers are generated, the worked will send a message of the same type to the main thread, with\n * the generated buffers in it.\n * Note that any addition properties present in the message *will* be sent back to the main thread.\n * @property {number} id Message id; will be used both in request and response as a means of identification\n * @property {WebGLWorkerMessageType} type Message type\n * @property {ArrayBufferLike} renderInstructions render instructions raw binary buffer.\n * @property {number} [customAttributesSize] Amount of hit detection + custom attributes count in the render instructions.\n * @property {ArrayBuffer} [indicesBuffer] Indices array raw binary buffer (sent by the worker).\n * @property {ArrayBuffer} [vertexAttributesBuffer] Vertex attributes array raw binary buffer (sent by the worker).\n * @property {ArrayBuffer} [instanceAttributesBuffer] Instance attributes array raw binary buffer (sent by the worker).\n * @property {import(\"../../transform.js\").Transform} [renderInstructionsTransform] Transformation matrix used to project the instructions coordinates\n */\n","/**\n * @module ol/render/webgl/renderinstructions\n */\nimport {UNDEFINED_PROP_VALUE} from '../../expr/gpu.js';\nimport {transform2D} from '../../geom/flat/transform.js';\nimport {apply as applyTransform} from '../../transform.js';\n\n/**\n * @param {Float32Array} renderInstructions Render instructions\n * @param {import('./VectorStyleRenderer.js').AttributeDefinitions} customAttributes Custom attributes\n * @param {import(\"./MixedGeometryBatch.js\").GeometryBatchItem} batchEntry Batch item\n * @param {number} currentIndex Current index\n * @return {number} The amount of values pushed\n */\nfunction pushCustomAttributesInRenderInstructions(\n  renderInstructions,\n  customAttributes,\n  batchEntry,\n  currentIndex,\n) {\n  let shift = 0;\n  for (const key in customAttributes) {\n    const attr = customAttributes[key];\n    const value = attr.callback.call(batchEntry, batchEntry.feature);\n    let first = value?.[0] ?? value;\n    if (first === UNDEFINED_PROP_VALUE) {\n      console.warn('The \"has\" operator might return false positives.'); // eslint-disable-line no-console\n    }\n    if (first === undefined) {\n      first = UNDEFINED_PROP_VALUE;\n    } else if (first === null) {\n      first = 0;\n    }\n    renderInstructions[currentIndex + shift++] = first;\n    if (!attr.size || attr.size === 1) {\n      continue;\n    }\n    renderInstructions[currentIndex + shift++] = value[1];\n    if (attr.size < 3) {\n      continue;\n    }\n    renderInstructions[currentIndex + shift++] = value[2];\n    if (attr.size < 4) {\n      continue;\n    }\n    renderInstructions[currentIndex + shift++] = value[3];\n  }\n  return shift;\n}\n\n/**\n * @param {import('./VectorStyleRenderer.js').AttributeDefinitions} customAttributes Custom attributes\n * @return {number} Cumulated size of all attributes\n */\nexport function getCustomAttributesSize(customAttributes) {\n  return Object.keys(customAttributes).reduce(\n    (prev, curr) => prev + (customAttributes[curr].size || 1),\n    0,\n  );\n}\n\n/**\n * Render instructions for lines are structured like so:\n * [ x0, y0, customAttr0, ... , xN, yN, customAttrN ]\n * @param {import(\"./MixedGeometryBatch.js\").PointGeometryBatch} batch Point geometry batch\n * @param {Float32Array} renderInstructions Render instructions\n * @param {import('./VectorStyleRenderer.js').AttributeDefinitions} customAttributes Custom attributes\n * @param {import(\"../../transform.js\").Transform} transform Transform to apply to coordinates\n * @return {Float32Array} Generated render instructions\n */\nexport function generatePointRenderInstructions(\n  batch,\n  renderInstructions,\n  customAttributes,\n  transform,\n) {\n  // here we anticipate the amount of render instructions for points:\n  // 2 instructions per vertex for position (x and y)\n  // + 1 instruction per vertex per custom attributes\n  const totalInstructionsCount =\n    (2 + getCustomAttributesSize(customAttributes)) * batch.geometriesCount;\n  if (\n    !renderInstructions ||\n    renderInstructions.length !== totalInstructionsCount\n  ) {\n    renderInstructions = new Float32Array(totalInstructionsCount);\n  }\n\n  // loop on features to fill the render instructions\n  const tmpCoords = [];\n  let renderIndex = 0;\n  for (const featureUid in batch.entries) {\n    const batchEntry = batch.entries[featureUid];\n    for (let i = 0, ii = batchEntry.flatCoordss.length; i < ii; i++) {\n      tmpCoords[0] = batchEntry.flatCoordss[i][0];\n      tmpCoords[1] = batchEntry.flatCoordss[i][1];\n      applyTransform(transform, tmpCoords);\n\n      renderInstructions[renderIndex++] = tmpCoords[0];\n      renderInstructions[renderIndex++] = tmpCoords[1];\n      renderIndex += pushCustomAttributesInRenderInstructions(\n        renderInstructions,\n        customAttributes,\n        batchEntry,\n        renderIndex,\n      );\n    }\n  }\n  return renderInstructions;\n}\n\n/**\n * Render instructions for lines are structured like so:\n * [ customAttr0, ... , customAttrN, numberOfVertices0, x0, y0, ... , xN, yN, numberOfVertices1, ... ]\n * @param {import(\"./MixedGeometryBatch.js\").LineStringGeometryBatch} batch Line String geometry batch\n * @param {Float32Array} renderInstructions Render instructions\n * @param {import('./VectorStyleRenderer.js').AttributeDefinitions} customAttributes Custom attributes\n * @param {import(\"../../transform.js\").Transform} transform Transform to apply to coordinates\n * @return {Float32Array} Generated render instructions\n */\nexport function generateLineStringRenderInstructions(\n  batch,\n  renderInstructions,\n  customAttributes,\n  transform,\n) {\n  // here we anticipate the amount of render instructions for lines:\n  // 3 instructions per vertex for position (x, y and m)\n  // + 1 instruction per line per custom attributes\n  // + 1 instruction per line (for vertices count)\n  const totalInstructionsCount =\n    3 * batch.verticesCount +\n    (1 + getCustomAttributesSize(customAttributes)) * batch.geometriesCount;\n  if (\n    !renderInstructions ||\n    renderInstructions.length !== totalInstructionsCount\n  ) {\n    renderInstructions = new Float32Array(totalInstructionsCount);\n  }\n\n  // loop on features to fill the render instructions\n  const flatCoords = [];\n  let renderIndex = 0;\n  for (const featureUid in batch.entries) {\n    const batchEntry = batch.entries[featureUid];\n    for (let i = 0, ii = batchEntry.flatCoordss.length; i < ii; i++) {\n      flatCoords.length = batchEntry.flatCoordss[i].length;\n      transform2D(\n        batchEntry.flatCoordss[i],\n        0,\n        flatCoords.length,\n        3,\n        transform,\n        flatCoords,\n        3,\n      );\n      renderIndex += pushCustomAttributesInRenderInstructions(\n        renderInstructions,\n        customAttributes,\n        batchEntry,\n        renderIndex,\n      );\n\n      // vertices count\n      renderInstructions[renderIndex++] = flatCoords.length / 3;\n\n      // looping on points for positions\n      for (let j = 0, jj = flatCoords.length; j < jj; j += 3) {\n        renderInstructions[renderIndex++] = flatCoords[j];\n        renderInstructions[renderIndex++] = flatCoords[j + 1];\n        renderInstructions[renderIndex++] = flatCoords[j + 2];\n      }\n    }\n  }\n  return renderInstructions;\n}\n\n/**\n * Render instructions for polygons are structured like so:\n * [ customAttr0, ..., customAttrN, numberOfRings, numberOfVerticesInRing0, ..., numberOfVerticesInRingN, x0, y0, ..., xN, yN, numberOfRings,... ]\n * @param {import(\"./MixedGeometryBatch.js\").PolygonGeometryBatch} batch Polygon geometry batch\n * @param {Float32Array} renderInstructions Render instructions\n * @param {import('./VectorStyleRenderer.js').AttributeDefinitions} customAttributes Custom attributes\n * @param {import(\"../../transform.js\").Transform} transform Transform to apply to coordinates\n * @return {Float32Array} Generated render instructions\n */\nexport function generatePolygonRenderInstructions(\n  batch,\n  renderInstructions,\n  customAttributes,\n  transform,\n) {\n  // here we anticipate the amount of render instructions for polygons:\n  // 2 instructions per vertex for position (x and y)\n  // + 1 instruction per polygon per custom attributes\n  // + 1 instruction per polygon (for vertices count in polygon)\n  // + 1 instruction per ring (for vertices count in ring)\n  const totalInstructionsCount =\n    2 * batch.verticesCount +\n    (1 + getCustomAttributesSize(customAttributes)) * batch.geometriesCount +\n    batch.ringsCount;\n  if (\n    !renderInstructions ||\n    renderInstructions.length !== totalInstructionsCount\n  ) {\n    renderInstructions = new Float32Array(totalInstructionsCount);\n  }\n\n  // loop on features to fill the render instructions\n  const flatCoords = [];\n  let renderIndex = 0;\n  for (const featureUid in batch.entries) {\n    const batchEntry = batch.entries[featureUid];\n    for (let i = 0, ii = batchEntry.flatCoordss.length; i < ii; i++) {\n      flatCoords.length = batchEntry.flatCoordss[i].length;\n      transform2D(\n        batchEntry.flatCoordss[i],\n        0,\n        flatCoords.length,\n        2,\n        transform,\n        flatCoords,\n      );\n      renderIndex += pushCustomAttributesInRenderInstructions(\n        renderInstructions,\n        customAttributes,\n        batchEntry,\n        renderIndex,\n      );\n\n      // ring count\n      renderInstructions[renderIndex++] =\n        batchEntry.ringsVerticesCounts[i].length;\n\n      // vertices count in each ring\n      for (\n        let j = 0, jj = batchEntry.ringsVerticesCounts[i].length;\n        j < jj;\n        j++\n      ) {\n        renderInstructions[renderIndex++] =\n          batchEntry.ringsVerticesCounts[i][j];\n      }\n\n      // looping on points for positions\n      for (let j = 0, jj = flatCoords.length; j < jj; j += 2) {\n        renderInstructions[renderIndex++] = flatCoords[j];\n        renderInstructions[renderIndex++] = flatCoords[j + 1];\n      }\n    }\n  }\n  return renderInstructions;\n}\n","/**\n * Utilities for parsing flat styles for WebGL renderers\n * @module ol/render/webgl/style\n */\nimport {assert} from '../../asserts.js';\nimport {\n  BooleanType,\n  ColorType,\n  NumberArrayType,\n  NumberType,\n  SizeType,\n  StringType,\n  computeGeometryType,\n  newParsingContext,\n} from '../../expr/expression.js';\nimport {\n  FEATURE_ID_PROPERTY_NAME,\n  GEOMETRY_TYPE_PROPERTY_NAME,\n  getStringNumberEquivalent,\n  newCompilationContext,\n  stringToGlsl,\n} from '../../expr/gpu.js';\nimport {ShaderBuilder} from './ShaderBuilder.js';\nimport {\n  applyContextToBuilder,\n  expressionToGlsl,\n  generateAttributesFromContext,\n  generateUniformsFromContext,\n  getGlslSizeFromType,\n  getGlslTypeFromType,\n} from './compileUtil.js';\n\n/**\n * see https://stackoverflow.com/questions/7616461/generate-a-hash-from-string-in-javascript\n * @param {Object|string} input The hash input, either an object or string\n * @return {string} Hash (if the object cannot be serialized, it is based on `getUid`)\n */\nexport function computeHash(input) {\n  const hash = JSON.stringify(input)\n    .split('')\n    .reduce((prev, curr) => (prev << 5) - prev + curr.charCodeAt(0), 0);\n  return (hash >>> 0).toString();\n}\n\n/**\n * @param {import(\"../../style/flat.js\").FlatStyle} style Style\n * @param {ShaderBuilder} builder Shader builder\n * @param {import(\"../../expr/gpu.js\").CompilationContext} vertContext Vertex shader compilation context\n * @param {'shape-'|'circle-'|'icon-'} prefix Properties prefix\n */\nfunction parseCommonSymbolProperties(style, builder, vertContext, prefix) {\n  if (`${prefix}radius` in style && prefix !== 'icon-') {\n    let radius = expressionToGlsl(\n      vertContext,\n      style[`${prefix}radius`],\n      NumberType,\n    );\n    if (`${prefix}radius2` in style) {\n      const radius2 = expressionToGlsl(\n        vertContext,\n        style[`${prefix}radius2`],\n        NumberType,\n      );\n      radius = `max(${radius}, ${radius2})`;\n    }\n    if (`${prefix}stroke-width` in style) {\n      radius = `(${radius} + ${expressionToGlsl(\n        vertContext,\n        style[`${prefix}stroke-width`],\n        NumberType,\n      )} * 0.5)`;\n    }\n    builder.setSymbolSizeExpression(`vec2(${radius} * 2. + 0.5)`); // adding some padding for antialiasing\n  }\n  if (`${prefix}scale` in style) {\n    const scale = expressionToGlsl(\n      vertContext,\n      style[`${prefix}scale`],\n      SizeType,\n    );\n    builder.setSymbolSizeExpression(\n      `${builder.getSymbolSizeExpression()} * ${scale}`,\n    );\n  }\n  if (`${prefix}displacement` in style) {\n    builder.setSymbolOffsetExpression(\n      expressionToGlsl(\n        vertContext,\n        style[`${prefix}displacement`],\n        NumberArrayType,\n      ),\n    );\n  }\n  if (`${prefix}rotation` in style) {\n    builder.setSymbolRotationExpression(\n      expressionToGlsl(vertContext, style[`${prefix}rotation`], NumberType),\n    );\n  }\n  if (`${prefix}rotate-with-view` in style) {\n    builder.setSymbolRotateWithView(!!style[`${prefix}rotate-with-view`]);\n  }\n}\n\n/**\n * @param {string} distanceField The distance field expression\n * @param {string|null} fillColor The fill color expression; null if no fill\n * @param {string|null} strokeColor The stroke color expression; null if no stroke\n * @param {string|null} strokeWidth The stroke width expression; null if no stroke\n * @param {string|null} opacity The opacity expression; null if no stroke\n * @return {string} The final color expression, based on the distance field and given params\n */\nfunction getColorFromDistanceField(\n  distanceField,\n  fillColor,\n  strokeColor,\n  strokeWidth,\n  opacity,\n) {\n  let color = 'vec4(0.)';\n  if (fillColor !== null) {\n    color = fillColor;\n  }\n  if (strokeColor !== null && strokeWidth !== null) {\n    const strokeFillRatio = `smoothstep(-${strokeWidth} + 0.63, -${strokeWidth} - 0.58, ${distanceField})`;\n    color = `mix(${strokeColor}, ${color}, ${strokeFillRatio})`;\n  }\n  const shapeOpacity = `(1.0 - smoothstep(-0.63, 0.58, ${distanceField}))`;\n  let result = `${color} * vec4(1.0, 1.0, 1.0, ${shapeOpacity})`;\n  if (opacity !== null) {\n    result = `${result} * vec4(1.0, 1.0, 1.0, ${opacity})`;\n  }\n  return result;\n}\n\n/**\n * This will parse an image property provided by `<prefix>-src`\n * The image size expression in GLSL will be returned\n * @param {import(\"../../style/flat.js\").FlatStyle} style Style\n * @param {ShaderBuilder} builder Shader builder\n * @param {Object<string,import(\"../../webgl/Helper.js\").UniformValue>} uniforms Uniforms\n * @param {'icon-'|'fill-pattern-'|'stroke-pattern-'} prefix Property prefix\n * @param {string} textureId A identifier that will be used in the generated uniforms: `sample2d u_texture<id>` and `vec2 u_texture<id>_size`\n * @return {string} The image size expression\n */\nfunction parseImageProperties(style, builder, uniforms, prefix, textureId) {\n  const image = new Image();\n  image.crossOrigin =\n    style[`${prefix}cross-origin`] === undefined\n      ? 'anonymous'\n      : style[`${prefix}cross-origin`];\n  assert(\n    typeof style[`${prefix}src`] === 'string',\n    `WebGL layers do not support expressions for the ${prefix}src style property`,\n  );\n  image.src = /** @type {string} */ (style[`${prefix}src`]);\n\n  // the size is provided asynchronously using a uniform\n  uniforms[`u_texture${textureId}_size`] = () => {\n    return image.complete ? [image.width, image.height] : [0, 0];\n  };\n  builder.addUniform(`u_texture${textureId}_size`, 'vec2');\n  const size = `u_texture${textureId}_size`;\n\n  uniforms[`u_texture${textureId}`] = image;\n  builder.addUniform(`u_texture${textureId}`, 'sampler2D');\n  return size;\n}\n\n/**\n * This will parse an image's offset properties provided by `<prefix>-offset`, `<prefix>-offset-origin` and `<prefix>-size`\n * @param {import(\"../../style/flat.js\").FlatStyle} style Style\n * @param {'icon-'|'fill-pattern-'|'stroke-pattern-'} prefix Property prefix\n * @param {import(\"../../expr/gpu.js\").CompilationContext} context Shader compilation context (vertex or fragment)\n * @param {string} imageSize Pixel size of the full image as a GLSL expression\n * @param {string} sampleSize Pixel size of the sample in the image as a GLSL expression\n * @return {string} The offset expression\n */\nfunction parseImageOffsetProperties(\n  style,\n  prefix,\n  context,\n  imageSize,\n  sampleSize,\n) {\n  let offsetExpression = expressionToGlsl(\n    context,\n    style[`${prefix}offset`],\n    SizeType,\n  );\n  if (`${prefix}offset-origin` in style) {\n    switch (style[`${prefix}offset-origin`]) {\n      case 'top-right':\n        offsetExpression = `vec2(${imageSize}.x, 0.) + ${sampleSize} * vec2(-1., 0.) + ${offsetExpression} * vec2(-1., 1.)`;\n        break;\n      case 'bottom-left':\n        offsetExpression = `vec2(0., ${imageSize}.y) + ${sampleSize} * vec2(0., -1.) + ${offsetExpression} * vec2(1., -1.)`;\n        break;\n      case 'bottom-right':\n        offsetExpression = `${imageSize} - ${sampleSize} - ${offsetExpression}`;\n        break;\n      default: // pass\n    }\n  }\n  return offsetExpression;\n}\n\n/**\n * @param {import(\"../../style/flat.js\").FlatStyle} style Style\n * @param {ShaderBuilder} builder Shader builder\n * @param {Object<string,import(\"../../webgl/Helper.js\").UniformValue>} uniforms Uniforms\n * @param {import(\"../../expr/gpu.js\").CompilationContext} context Shader compilation context\n */\nfunction parseCircleProperties(style, builder, uniforms, context) {\n  // this function takes in screen coordinates in pixels and returns the signed distance field\n  // (0 on the boundary, negative inside the circle, positive outside, values in pixels)\n  context.functions['circleDistanceField'] =\n    `float circleDistanceField(vec2 point, float radius) {\n  return length(point) - radius;\n}`;\n\n  parseCommonSymbolProperties(style, builder, context, 'circle-');\n\n  // OPACITY\n  let opacity = null;\n  if ('circle-opacity' in style) {\n    opacity = expressionToGlsl(context, style['circle-opacity'], NumberType);\n  }\n\n  // SCALE\n  let currentPoint = 'coordsPx';\n  if ('circle-scale' in style) {\n    const scale = expressionToGlsl(context, style['circle-scale'], SizeType);\n    currentPoint = `coordsPx / ${scale}`;\n  }\n\n  // FILL COLOR\n  let fillColor = null;\n  if ('circle-fill-color' in style) {\n    fillColor = expressionToGlsl(\n      context,\n      style['circle-fill-color'],\n      ColorType,\n    );\n  }\n\n  // STROKE COLOR\n  let strokeColor = null;\n  if ('circle-stroke-color' in style) {\n    strokeColor = expressionToGlsl(\n      context,\n      style['circle-stroke-color'],\n      ColorType,\n    );\n  }\n\n  // RADIUS\n  let radius = expressionToGlsl(context, style['circle-radius'], NumberType);\n\n  // STROKE WIDTH\n  let strokeWidth = null;\n  if ('circle-stroke-width' in style) {\n    strokeWidth = expressionToGlsl(\n      context,\n      style['circle-stroke-width'],\n      NumberType,\n    );\n    radius = `(${radius} + ${strokeWidth} * 0.5)`;\n  }\n\n  // FINAL COLOR\n  const distanceField = `circleDistanceField(${currentPoint}, ${radius})`;\n  const colorExpression = getColorFromDistanceField(\n    distanceField,\n    fillColor,\n    strokeColor,\n    strokeWidth,\n    opacity,\n  );\n  builder.setSymbolColorExpression(colorExpression);\n}\n\n/**\n * @param {import(\"../../style/flat.js\").FlatStyle} style Style\n * @param {ShaderBuilder} builder Shader builder\n * @param {Object<string,import(\"../../webgl/Helper.js\").UniformValue>} uniforms Uniforms\n * @param {import(\"../../expr/gpu.js\").CompilationContext} context Shader compilation context\n */\nfunction parseShapeProperties(style, builder, uniforms, context) {\n  context.functions['round'] = `float round(float v) {\n  return sign(v) * floor(abs(v) + 0.5);\n}`;\n\n  // these functions take in screen coordinates in pixels and returns the signed distance field\n  // (0 on the boundary, negative inside the polygon, positive outside, values in pixels)\n  // inspired by https://github.com/zranger1/PixelblazePatterns/blob/master/Toolkit/sdf2d.md#n-sided-regular-polygon\n  context.functions['starDistanceField'] =\n    `float starDistanceField(vec2 point, float numPoints, float radius, float radius2, float angle) {\n  float startAngle = -PI * 0.5 + angle; // tip starts upwards and rotates clockwise with angle\n  float c = cos(startAngle);\n  float s = sin(startAngle);\n  vec2 pointRotated = vec2(c * point.x - s * point.y, s * point.x + c * point.y);\n  float alpha = TWO_PI / numPoints; // the angle of one sector\n  float beta = atan(pointRotated.y, pointRotated.x);\n  float gamma = round(beta / alpha) * alpha; // angle in sector\n  c = cos(-gamma);\n  s = sin(-gamma);\n  vec2 inSector = vec2(c * pointRotated.x - s * pointRotated.y, abs(s * pointRotated.x + c * pointRotated.y));\n  vec2 tipToPoint = inSector + vec2(-radius, 0.);\n  vec2 edgeNormal = vec2(radius2 * sin(alpha * 0.5), -radius2 * cos(alpha * 0.5) + radius);\n  return dot(normalize(edgeNormal), tipToPoint);\n}`;\n  context.functions['regularDistanceField'] =\n    `float regularDistanceField(vec2 point, float numPoints, float radius, float angle) {\n  float startAngle = -PI * 0.5 + angle; // tip starts upwards and rotates clockwise with angle\n  float c = cos(startAngle);\n  float s = sin(startAngle);\n  vec2 pointRotated = vec2(c * point.x - s * point.y, s * point.x + c * point.y);\n  float alpha = TWO_PI / numPoints; // the angle of one sector\n  float radiusIn = radius * cos(PI / numPoints);\n  float beta = atan(pointRotated.y, pointRotated.x);\n  float gamma = round((beta - alpha * 0.5) / alpha) * alpha + alpha * 0.5; // angle in sector from mid\n  c = cos(-gamma);\n  s = sin(-gamma);\n  vec2 inSector = vec2(c * pointRotated.x - s * pointRotated.y, abs(s * pointRotated.x + c * pointRotated.y));\n  return inSector.x - radiusIn;\n}`;\n\n  parseCommonSymbolProperties(style, builder, context, 'shape-');\n\n  // OPACITY\n  let opacity = null;\n  if ('shape-opacity' in style) {\n    opacity = expressionToGlsl(context, style['shape-opacity'], NumberType);\n  }\n\n  // SCALE\n  let currentPoint = 'coordsPx';\n  if ('shape-scale' in style) {\n    const scale = expressionToGlsl(context, style['shape-scale'], SizeType);\n    currentPoint = `coordsPx / ${scale}`;\n  }\n\n  // FILL COLOR\n  let fillColor = null;\n  if ('shape-fill-color' in style) {\n    fillColor = expressionToGlsl(context, style['shape-fill-color'], ColorType);\n  }\n\n  // STROKE COLOR\n  let strokeColor = null;\n  if ('shape-stroke-color' in style) {\n    strokeColor = expressionToGlsl(\n      context,\n      style['shape-stroke-color'],\n      ColorType,\n    );\n  }\n\n  // STROKE WIDTH\n  let strokeWidth = null;\n  if ('shape-stroke-width' in style) {\n    strokeWidth = expressionToGlsl(\n      context,\n      style['shape-stroke-width'],\n      NumberType,\n    );\n  }\n\n  // SHAPE TYPE\n  const numPoints = expressionToGlsl(\n    context,\n    style['shape-points'],\n    NumberType,\n  );\n  let angle = '0.';\n  if ('shape-angle' in style) {\n    angle = expressionToGlsl(context, style['shape-angle'], NumberType);\n  }\n  let shapeField;\n  let radius = expressionToGlsl(context, style['shape-radius'], NumberType);\n  if (strokeWidth !== null) {\n    radius = `${radius} + ${strokeWidth} * 0.5`;\n  }\n  if ('shape-radius2' in style) {\n    let radius2 = expressionToGlsl(context, style['shape-radius2'], NumberType);\n    if (strokeWidth !== null) {\n      radius2 = `${radius2} + ${strokeWidth} * 0.5`;\n    }\n    shapeField = `starDistanceField(${currentPoint}, ${numPoints}, ${radius}, ${radius2}, ${angle})`;\n  } else {\n    shapeField = `regularDistanceField(${currentPoint}, ${numPoints}, ${radius}, ${angle})`;\n  }\n\n  // FINAL COLOR\n  const colorExpression = getColorFromDistanceField(\n    shapeField,\n    fillColor,\n    strokeColor,\n    strokeWidth,\n    opacity,\n  );\n  builder.setSymbolColorExpression(colorExpression);\n}\n\n/**\n * @param {import(\"../../style/flat.js\").FlatStyle} style Style\n * @param {ShaderBuilder} builder Shader builder\n * @param {Object<string,import(\"../../webgl/Helper.js\").UniformValue>} uniforms Uniforms\n * @param {import(\"../../expr/gpu.js\").CompilationContext} context Shader compilation context\n */\nfunction parseIconProperties(style, builder, uniforms, context) {\n  // COLOR\n  let color = 'vec4(1.0)';\n  if ('icon-color' in style) {\n    color = expressionToGlsl(context, style['icon-color'], ColorType);\n  }\n\n  // OPACITY\n  if ('icon-opacity' in style) {\n    color = `${color} * vec4(1.0, 1.0, 1.0, ${expressionToGlsl(\n      context,\n      style['icon-opacity'],\n      NumberType,\n    )})`;\n  }\n\n  // IMAGE & SIZE\n  const textureId = computeHash(style['icon-src']);\n  const sizeExpression = parseImageProperties(\n    style,\n    builder,\n    uniforms,\n    'icon-',\n    textureId,\n  );\n  builder\n    .setSymbolColorExpression(\n      `${color} * texture2D(u_texture${textureId}, v_texCoord)`,\n    )\n    .setSymbolSizeExpression(sizeExpression);\n\n  // override size if width/height were specified\n  if ('icon-width' in style && 'icon-height' in style) {\n    builder.setSymbolSizeExpression(\n      `vec2(${expressionToGlsl(\n        context,\n        style['icon-width'],\n        NumberType,\n      )}, ${expressionToGlsl(context, style['icon-height'], NumberType)})`,\n    );\n  }\n\n  // tex coord\n  if ('icon-offset' in style && 'icon-size' in style) {\n    const sampleSize = expressionToGlsl(\n      context,\n      style['icon-size'],\n      NumberArrayType,\n    );\n    const fullsize = builder.getSymbolSizeExpression();\n    builder.setSymbolSizeExpression(sampleSize);\n    const offset = parseImageOffsetProperties(\n      style,\n      'icon-',\n      context,\n      'v_quadSizePx',\n      sampleSize,\n    );\n    builder.setTextureCoordinateExpression(\n      `(vec4((${offset}).xyxy) + vec4(0., 0., ${sampleSize})) / (${fullsize}).xyxy`,\n    );\n  }\n\n  parseCommonSymbolProperties(style, builder, context, 'icon-');\n\n  if ('icon-anchor' in style) {\n    const anchor = expressionToGlsl(\n      context,\n      style['icon-anchor'],\n      NumberArrayType,\n    );\n    let scale = `1.0`;\n    if (`icon-scale` in style) {\n      scale = expressionToGlsl(context, style[`icon-scale`], SizeType);\n    }\n    let shiftPx;\n    if (\n      style['icon-anchor-x-units'] === 'pixels' &&\n      style['icon-anchor-y-units'] === 'pixels'\n    ) {\n      shiftPx = `${anchor} * ${scale}`;\n    } else if (style['icon-anchor-x-units'] === 'pixels') {\n      shiftPx = `${anchor} * vec2(vec2(${scale}).x, v_quadSizePx.y)`;\n    } else if (style['icon-anchor-y-units'] === 'pixels') {\n      shiftPx = `${anchor} * vec2(v_quadSizePx.x, vec2(${scale}).x)`;\n    } else {\n      shiftPx = `${anchor} * v_quadSizePx`;\n    }\n    // default origin is top-left\n    let offsetPx = `v_quadSizePx * vec2(0.5, -0.5) + ${shiftPx} * vec2(-1., 1.)`;\n    if ('icon-anchor-origin' in style) {\n      switch (style['icon-anchor-origin']) {\n        case 'top-right':\n          offsetPx = `v_quadSizePx * -0.5 + ${shiftPx}`;\n          break;\n        case 'bottom-left':\n          offsetPx = `v_quadSizePx * 0.5 - ${shiftPx}`;\n          break;\n        case 'bottom-right':\n          offsetPx = `v_quadSizePx * vec2(-0.5, 0.5) + ${shiftPx} * vec2(1., -1.)`;\n          break;\n        default: // pass\n      }\n    }\n    builder.setSymbolOffsetExpression(\n      `${builder.getSymbolOffsetExpression()} + ${offsetPx}`,\n    );\n  }\n}\n\n/**\n * @param {import(\"../../style/flat.js\").FlatStyle} style Style\n * @param {ShaderBuilder} builder Shader Builder\n * @param {Object<string,import(\"../../webgl/Helper.js\").UniformValue>} uniforms Uniforms\n * @param {import(\"../../expr/gpu.js\").CompilationContext} context Shader compilation context\n */\nfunction parseStrokeProperties(style, builder, uniforms, context) {\n  if ('stroke-color' in style) {\n    builder.setStrokeColorExpression(\n      expressionToGlsl(context, style['stroke-color'], ColorType),\n    );\n  }\n  if ('stroke-pattern-src' in style) {\n    const textureId = computeHash(style['stroke-pattern-src']);\n    const sizeExpression = parseImageProperties(\n      style,\n      builder,\n      uniforms,\n      'stroke-pattern-',\n      textureId,\n    );\n    let sampleSizeExpression = sizeExpression;\n    let offsetExpression = 'vec2(0.)';\n    if ('stroke-pattern-offset' in style && 'stroke-pattern-size' in style) {\n      sampleSizeExpression = expressionToGlsl(\n        context,\n        style[`stroke-pattern-size`],\n        NumberArrayType,\n      );\n      offsetExpression = parseImageOffsetProperties(\n        style,\n        'stroke-pattern-',\n        context,\n        sizeExpression,\n        sampleSizeExpression,\n      );\n    }\n    let spacingExpression = '0.';\n    if ('stroke-pattern-spacing' in style) {\n      spacingExpression = expressionToGlsl(\n        context,\n        style['stroke-pattern-spacing'],\n        NumberType,\n      );\n    }\n    let startOffsetExpression = '0.';\n    if ('stroke-pattern-start-offset' in style) {\n      startOffsetExpression = expressionToGlsl(\n        context,\n        style['stroke-pattern-start-offset'],\n        NumberType,\n      );\n    }\n    context.functions['sampleStrokePattern'] =\n      `vec4 sampleStrokePattern(sampler2D texture, vec2 textureSize, vec2 textureOffset, vec2 sampleSize, float spacingPx, float startOffsetPx, float currentLengthPx, float currentRadiusRatio, float lineWidth) {\n  float currentLengthScaled = (currentLengthPx - startOffsetPx) * sampleSize.y / lineWidth;\n  float spacingScaled = spacingPx * sampleSize.y / lineWidth;\n  float uCoordPx = mod(currentLengthScaled, (sampleSize.x + spacingScaled));\n  float isInsideOfPattern = step(uCoordPx, sampleSize.x);\n  float vCoordPx = (-currentRadiusRatio * 0.5 + 0.5) * sampleSize.y;\n  // make sure that we're not sampling too close to the borders to avoid interpolation with outside pixels\n  uCoordPx = clamp(uCoordPx, 0.5, sampleSize.x - 0.5);\n  vCoordPx = clamp(vCoordPx, 0.5, sampleSize.y - 0.5);\n  vec2 texCoord = (vec2(uCoordPx, vCoordPx) + textureOffset) / textureSize;\n  return texture2D(texture, texCoord) * vec4(1.0, 1.0, 1.0, isInsideOfPattern);\n}`;\n    const textureName = `u_texture${textureId}`;\n    let tintExpression = '1.';\n    if ('stroke-color' in style) {\n      tintExpression = builder.getStrokeColorExpression();\n    }\n    builder.setStrokeColorExpression(\n      `${tintExpression} * sampleStrokePattern(${textureName}, ${sizeExpression}, ${offsetExpression}, ${sampleSizeExpression}, ${spacingExpression}, ${startOffsetExpression}, currentLengthPx, currentRadiusRatio, v_width)`,\n    );\n\n    context.functions['computeStrokePatternLength'] =\n      `float computeStrokePatternLength(vec2 sampleSize, float spacingPx, float lineWidth) {\n  float patternLengthPx = sampleSize.x / sampleSize.y * lineWidth;\n  return patternLengthPx + spacingPx;\n}`;\n\n    // apply a stroke pattern length to avoid visual artifacts\n    builder.setStrokePatternLengthExpression(\n      `computeStrokePatternLength(${sampleSizeExpression}, ${spacingExpression}, v_width)`,\n    );\n  }\n\n  if ('stroke-width' in style) {\n    builder.setStrokeWidthExpression(\n      expressionToGlsl(context, style['stroke-width'], NumberType),\n    );\n  }\n\n  if ('stroke-offset' in style) {\n    builder.setStrokeOffsetExpression(\n      expressionToGlsl(context, style['stroke-offset'], NumberType),\n    );\n  }\n\n  if ('stroke-line-cap' in style) {\n    builder.setStrokeCapExpression(\n      expressionToGlsl(context, style['stroke-line-cap'], StringType),\n    );\n  }\n\n  if ('stroke-line-join' in style) {\n    builder.setStrokeJoinExpression(\n      expressionToGlsl(context, style['stroke-line-join'], StringType),\n    );\n  }\n\n  if ('stroke-miter-limit' in style) {\n    builder.setStrokeMiterLimitExpression(\n      expressionToGlsl(context, style['stroke-miter-limit'], NumberType),\n    );\n  }\n\n  if ('stroke-line-dash' in style) {\n    context.functions['getSingleDashDistance'] =\n      `float getSingleDashDistance(float distance, float radius, float dashOffset, float dashLength, float dashLengthTotal, float capType, float lineWidth) {\n  float localDistance = mod(distance, dashLengthTotal);\n  float distanceSegment = abs(localDistance - dashOffset - dashLength * 0.5) - dashLength * 0.5;\n  distanceSegment = min(distanceSegment, dashLengthTotal - localDistance);\n  if (capType == ${stringToGlsl('square')}) {\n    distanceSegment -= lineWidth * 0.5;\n  } else if (capType == ${stringToGlsl('round')}) {\n    distanceSegment = min(distanceSegment, sqrt(distanceSegment * distanceSegment + radius * radius) - lineWidth * 0.5);\n  }\n  return distanceSegment;\n}`;\n\n    let dashPattern = style['stroke-line-dash'].map((v) =>\n      expressionToGlsl(context, v, NumberType),\n    );\n    // if pattern has odd length, concatenate it with itself to be even\n    if (dashPattern.length % 2 === 1) {\n      dashPattern = [...dashPattern, ...dashPattern];\n    }\n\n    let offsetExpression = '0.';\n    if ('stroke-line-dash-offset' in style) {\n      offsetExpression = expressionToGlsl(\n        context,\n        style['stroke-line-dash-offset'],\n        NumberType,\n      );\n    }\n\n    // define a function for this dash specifically\n    const uniqueDashKey = computeHash(style['stroke-line-dash']);\n    const dashFunctionName = `dashDistanceField_${uniqueDashKey}`;\n\n    const dashLengthsParamsDef = dashPattern\n      .map((v, i) => `float dashLength${i}`)\n      .join(', ');\n    const totalLengthDef = dashPattern\n      .map((v, i) => `dashLength${i}`)\n      .join(' + ');\n    let currentDashOffset = '0.';\n    let distanceExpression = `getSingleDashDistance(distance, radius, ${currentDashOffset}, dashLength0, totalDashLength, capType, lineWidth)`;\n    for (let i = 2; i < dashPattern.length; i += 2) {\n      currentDashOffset = `${currentDashOffset} + dashLength${\n        i - 2\n      } + dashLength${i - 1}`;\n      distanceExpression = `min(${distanceExpression}, getSingleDashDistance(distance, radius, ${currentDashOffset}, dashLength${i}, totalDashLength, capType, lineWidth))`;\n    }\n\n    context.functions[dashFunctionName] =\n      `float ${dashFunctionName}(float distance, float radius, float capType, float lineWidth, ${dashLengthsParamsDef}) {\n  float totalDashLength = ${totalLengthDef};\n  return ${distanceExpression};\n}`;\n    const dashLengthsCalls = dashPattern.map((v, i) => `${v}`).join(', ');\n    builder.setStrokeDistanceFieldExpression(\n      `${dashFunctionName}(currentLengthPx + ${offsetExpression}, currentRadiusPx, capType, v_width, ${dashLengthsCalls})`,\n    );\n\n    // apply a stroke pattern length to avoid visual artifacts\n    let patternLength = dashPattern.join(' + ');\n    if (builder.getStrokePatternLengthExpression()) {\n      context.functions['combinePatternLengths'] =\n        `float combinePatternLengths(float patternLength1, float patternLength2) {\n  return patternLength1 * patternLength2;\n}`;\n      patternLength = `combinePatternLengths(${builder.getStrokePatternLengthExpression()}, ${patternLength})`;\n    }\n    builder.setStrokePatternLengthExpression(patternLength);\n  }\n}\n\n/**\n * @param {import(\"../../style/flat.js\").FlatStyle} style Style\n * @param {ShaderBuilder} builder Shader Builder\n * @param {Object<string,import(\"../../webgl/Helper.js\").UniformValue>} uniforms Uniforms\n * @param {import(\"../../expr/gpu.js\").CompilationContext} context Shader compilation context\n */\nfunction parseFillProperties(style, builder, uniforms, context) {\n  if ('fill-color' in style) {\n    builder.setFillColorExpression(\n      expressionToGlsl(context, style['fill-color'], ColorType),\n    );\n  }\n  if ('fill-pattern-src' in style) {\n    const textureId = computeHash(style['fill-pattern-src']);\n    const sizeExpression = parseImageProperties(\n      style,\n      builder,\n      uniforms,\n      'fill-pattern-',\n      textureId,\n    );\n    builder.setFillPatternSizeExpression(sizeExpression);\n    let offsetExpression = 'vec2(0.)';\n    if ('fill-pattern-offset' in style && 'fill-pattern-size' in style) {\n      const specifiedSizeExpression = expressionToGlsl(\n        context,\n        style[`fill-pattern-size`],\n        NumberArrayType,\n      );\n      builder.setFillPatternSizeExpression(specifiedSizeExpression);\n      offsetExpression = parseImageOffsetProperties(\n        style,\n        'fill-pattern-',\n        context,\n        sizeExpression,\n        `v_patternSizePx`,\n      );\n    }\n    context.functions['sampleFillPattern'] =\n      `vec4 sampleFillPattern(sampler2D texture, vec2 textureSize, vec2 textureOffset, vec2 sampleSize, vec2 patternOriginPx, vec2 pxPosition, float sampleScaleRatio) {\n  vec2 pxRelativePos = pxPosition - patternOriginPx;\n\n  // rotate the relative position from origin by the current view rotation\n  pxRelativePos = vec2(pxRelativePos.x * cos(u_rotation) - pxRelativePos.y * sin(u_rotation), pxRelativePos.x * sin(u_rotation) + pxRelativePos.y * cos(u_rotation));\n  // sample position is computed according to the sample offset & size\n  vec2 samplePos = mod(pxRelativePos / sampleScaleRatio, sampleSize);\n  // also make sure that we're not sampling too close to the borders to avoid interpolation with outside pixels\n  samplePos = clamp(samplePos, vec2(0.5), sampleSize - vec2(0.5));\n  samplePos.y = sampleSize.y - samplePos.y; // invert y axis so that images appear upright\n  return texture2D(texture, (samplePos + textureOffset) / textureSize);\n}`;\n    const textureName = `u_texture${textureId}`;\n    let tintExpression = '1.';\n    if ('fill-color' in style) {\n      tintExpression = builder.getFillColorExpression();\n    }\n\n    builder.setFillColorExpression(\n      `${tintExpression} * sampleFillPattern(${textureName}, ${sizeExpression}, ${offsetExpression}, v_patternSizePx, v_patternOriginPx, pxPos, df_float(u_df_patternScaleRatio))`,\n    );\n  }\n}\n\n/**\n * @typedef {Object} StyleParseResult\n * @property {ShaderBuilder} builder Shader builder pre-configured according to a given style\n * @property {import(\"./VectorStyleRenderer.js\").UniformDefinitions} uniforms Uniform definitions\n * @property {import(\"./VectorStyleRenderer.js\").AttributeDefinitions} attributes Attribute definitions\n */\n\n/**\n * Parses a {@link import(\"../../style/flat.js\").FlatStyle} object and returns a {@link ShaderBuilder}\n * object that has been configured according to the given style, as well as `attributes` and `uniforms`\n * arrays to be fed to the `WebGLPointsRenderer` class.\n *\n * Also returns `uniforms` and `attributes` properties as expected by the\n * {@link module:ol/renderer/webgl/PointsLayer~WebGLPointsLayerRenderer}.\n *\n * @param {import(\"../../style/flat.js\").FlatStyle} style Flat style.\n * @param {import('../../style/flat.js').StyleVariables} [variables] Style variables.\n * @param {import(\"../../expr/expression.js\").EncodedExpression} [filter] Filter (if any)\n * @return {StyleParseResult} Result containing shader params, attributes and uniforms.\n */\nexport function parseLiteralStyle(style, variables, filter) {\n  const context = newCompilationContext();\n\n  const builder = new ShaderBuilder();\n\n  /** @type {Object<string,import(\"../../webgl/Helper.js\").UniformValue>} */\n  const uniforms = {};\n\n  if ('icon-src' in style) {\n    parseIconProperties(style, builder, uniforms, context);\n  } else if ('shape-points' in style) {\n    parseShapeProperties(style, builder, uniforms, context);\n  } else if ('circle-radius' in style) {\n    parseCircleProperties(style, builder, uniforms, context);\n  }\n  parseStrokeProperties(style, builder, uniforms, context);\n  parseFillProperties(style, builder, uniforms, context);\n\n  // note that the style filter may have already been applied earlier when building the rendering instructions\n  // this is still needed in case a filter cannot be evaluated statically beforehand (e.g. depending on time)\n  if (filter) {\n    const filterContext = newParsingContext();\n    const parsedFilter = expressionToGlsl(\n      context,\n      filter,\n      BooleanType,\n      filterContext,\n    );\n    if (filterContext.mCoordinate) {\n      builder.setFragmentDiscardExpression(`!${parsedFilter}`);\n    } else {\n      builder.setShapeDiscardExpression(`!${parsedFilter}`);\n    }\n  }\n\n  /**\n   * @type {import('./VectorStyleRenderer.js').AttributeDefinitions}\n   */\n  const attributes = {};\n\n  // Define attributes for special inputs\n  function defineSpecialInput(contextPropName, glslPropName, type, callback) {\n    if (!context[contextPropName]) {\n      return;\n    }\n    const glslType = getGlslTypeFromType(type);\n    const attrSize = getGlslSizeFromType(type);\n    builder.addAttribute(`a_${glslPropName}`, glslType);\n\n    attributes[glslPropName] = {\n      size: attrSize,\n      callback,\n    };\n  }\n  defineSpecialInput(\n    'geometryType',\n    GEOMETRY_TYPE_PROPERTY_NAME,\n    StringType,\n    (feature) =>\n      getStringNumberEquivalent(computeGeometryType(feature.getGeometry())),\n  );\n  defineSpecialInput(\n    'featureId',\n    FEATURE_ID_PROPERTY_NAME,\n    StringType | NumberType,\n    (feature) => {\n      const id = feature.getId() ?? null;\n      return typeof id === 'string' ? getStringNumberEquivalent(id) : id;\n    },\n  );\n\n  applyContextToBuilder(builder, context);\n\n  return {\n    builder,\n    attributes: {...attributes, ...generateAttributesFromContext(context)},\n    uniforms: {\n      ...uniforms,\n      ...generateUniformsFromContext(context, variables),\n    },\n  };\n}\n","/**\n * @module ol/render/webgl/VectorStyleRenderer\n */\nimport {\n  create as createTransform,\n  makeInverse as makeInverseTransform,\n} from '../../transform.js';\nimport {ARRAY_BUFFER, DYNAMIC_DRAW, ELEMENT_ARRAY_BUFFER} from '../../webgl.js';\nimport WebGLArrayBuffer from '../../webgl/Buffer.js';\nimport {AttributeType} from '../../webgl/Helper.js';\nimport {create as createWebGLWorker} from '../../worker/webgl.js';\nimport {WebGLWorkerMessageType} from './constants.js';\nimport {colorEncodeIdAndPack} from './encodeUtil.js';\nimport {\n  generateLineStringRenderInstructions,\n  generatePointRenderInstructions,\n  generatePolygonRenderInstructions,\n  getCustomAttributesSize,\n} from './renderinstructions.js';\nimport {parseLiteralStyle} from './style.js';\n\nconst tmpColor = [];\n/** @type {Worker|undefined} */\nlet WEBGL_WORKER;\nfunction getWebGLWorker() {\n  if (!WEBGL_WORKER) {\n    WEBGL_WORKER = createWebGLWorker();\n  }\n  return WEBGL_WORKER;\n}\nlet workerMessageCounter = 0;\n\n/**\n * Names of attributes made available to the vertex shader.\n * Please note: changing these *will* break custom shaders!\n * @enum {string}\n */\nexport const Attributes = {\n  POSITION: 'a_position',\n  LOCAL_POSITION: 'a_localPosition',\n  SEGMENT_START: 'a_segmentStart',\n  SEGMENT_END: 'a_segmentEnd',\n  MEASURE_START: 'a_measureStart',\n  MEASURE_END: 'a_measureEnd',\n  ANGLE_TANGENT_SUM: 'a_angleTangentSum',\n  JOIN_ANGLES: 'a_joinAngles',\n  DISTANCE_LOW: 'a_distanceLow',\n  DISTANCE_HIGH: 'a_distanceHigh',\n};\n\n/**\n * @typedef {Object} AttributeDefinition A description of a custom attribute to be passed on to the GPU, with a value different\n * for each feature.\n * @property {number} [size] Amount of numerical values composing the attribute, either 1, 2, 3 or 4; in case size is > 1, the return value\n * of the callback should be an array; if unspecified, assumed to be a single float value\n * @property {function(this:import(\"./MixedGeometryBatch.js\").GeometryBatchItem, import(\"../../Feature.js\").FeatureLike):number|Array<number>} callback This callback computes the numerical value of the\n * attribute for a given feature.\n */\n\n/**\n * @typedef {Object<string, AttributeDefinition>} AttributeDefinitions\n * @typedef {Object<string, import(\"../../webgl/Helper.js\").UniformValue>} UniformDefinitions\n */\n\n/**\n * @typedef {Array<WebGLArrayBuffer>} WebGLArrayBufferSet Buffers organized like so: [indicesBuffer, vertexAttributesBuffer, instanceAttributesBuffer]\n */\n\n/**\n * @typedef {Object} WebGLBuffers\n * @property {WebGLArrayBufferSet} polygonBuffers Array containing indices and vertices buffers for polygons\n * @property {WebGLArrayBufferSet} lineStringBuffers Array containing indices and vertices buffers for line strings\n * @property {WebGLArrayBufferSet} pointBuffers Array containing indices and vertices buffers for points\n * @property {import(\"../../transform.js\").Transform} invertVerticesTransform Inverse of the transform applied when generating buffers\n */\n\n/**\n * @typedef {Object} RenderInstructions\n * @property {Float32Array|null} polygonInstructions Polygon instructions; null if nothing to render\n * @property {Float32Array|null} lineStringInstructions LineString instructions; null if nothing to render\n * @property {Float32Array|null} pointInstructions Point instructions; null if nothing to render\n */\n\n/**\n * @typedef {Object} ShaderProgram An object containing both shaders (vertex and fragment)\n * @property {string} vertex Vertex shader source\n * @property {string} fragment Fragment shader source\n */\n\n/**\n * @typedef {import('./style.js').StyleParseResult} StyleShaders\n */\n\n/**\n * @typedef {import('../../style/flat.js').FlatStyleLike} FlatStyleLike\n */\n/**\n * @typedef {import('../../style/flat.js').FlatStyle} FlatStyle\n */\n/**\n * @typedef {import('../../style/flat.js').Rule} FlatStyleRule\n */\n\n/**\n * @typedef {Object} SubRenderPass\n * @property {string} vertexShader Vertex shader\n * @property {string} fragmentShader Fragment shader\n * @property {Array<import('../../webgl/Helper.js').AttributeDescription>} attributesDesc Attributes description, defined for each primitive vertex\n * @property {Array<import('../../webgl/Helper.js').AttributeDescription>} instancedAttributesDesc Attributes description, defined once per primitive\n * @property {number} instancePrimitiveVertexCount Number of vertices per instance primitive in this render pass\n * @property {WebGLProgram} [program] Program; this has to be recreated if the helper is lost/changed\n */\n\n/**\n * @typedef {Object} RenderPass\n * @property {SubRenderPass} [fillRenderPass] Fill render pass; undefined if no fill in pass\n * @property {SubRenderPass} [strokeRenderPass] Stroke render pass; undefined if no stroke in pass\n * @property {SubRenderPass} [symbolRenderPass] Symbol render pass; undefined if no symbol in pass\n */\n\n/**\n * @classdesc This class is responsible for:\n * 1. generating WebGL buffers according to a provided style, using a MixedGeometryBatch as input\n * 2. rendering geometries contained in said buffers\n *\n * A VectorStyleRenderer instance can be created either from a literal style or from shaders.\n * The shaders should not be provided explicitly but instead as a preconfigured ShaderBuilder instance.\n *\n * The `generateBuffers` method returns a promise resolving to WebGL buffers that are intended to be rendered by the\n * same renderer.\n */\nclass VectorStyleRenderer {\n  /**\n   * @param {FlatStyleLike|StyleShaders|Array<StyleShaders>} styles Vector styles expressed as flat styles, flat style rules or style shaders\n   * @param {import('../../style/flat.js').StyleVariables} variables Style variables\n   * @param {import('../../webgl/Helper.js').default} helper Helper\n   * @param {boolean} [enableHitDetection] Whether to enable the hit detection (needs compatible shader)\n   */\n  constructor(styles, variables, helper, enableHitDetection) {\n    /**\n     * @private\n     * @type {import('../../webgl/Helper.js').default}\n     */\n    this.helper_;\n\n    /**\n     * @private\n     */\n    this.hitDetectionEnabled_ = !!enableHitDetection;\n\n    /**\n     * @type {Array<StyleShaders>}\n     * @private\n     */\n    this.styleShaders = convertStyleToShaders(styles, variables);\n\n    /**\n     * @type {AttributeDefinitions}\n     * @private\n     */\n    this.customAttributes_ = {};\n\n    /**\n     @type {UniformDefinitions}\n     * @private\n     */\n    this.uniforms_ = {};\n\n    // add hit detection attribute if enabled\n    if (this.hitDetectionEnabled_) {\n      this.customAttributes_['hitColor'] = {\n        callback() {\n          return colorEncodeIdAndPack(this.ref, tmpColor);\n        },\n        size: 2,\n      };\n    }\n\n    // add attributes & uniforms coming from all shaders\n    for (const styleShader of this.styleShaders) {\n      for (const attributeName in styleShader.attributes) {\n        if (attributeName in this.customAttributes_) {\n          // already defined: skip\n          continue;\n        }\n        this.customAttributes_[attributeName] =\n          styleShader.attributes[attributeName];\n      }\n      for (const uniformName in styleShader.uniforms) {\n        if (uniformName in this.uniforms_) {\n          // already defined: skip\n          continue;\n        }\n        this.uniforms_[uniformName] = styleShader.uniforms[uniformName];\n      }\n    }\n\n    // create a render pass for each shader\n    /**\n     * @type {Array<RenderPass>}\n     * @private\n     */\n    this.renderPasses_ = this.styleShaders.map((styleShader) => {\n      /** @type {RenderPass} */\n      const renderPass = {};\n\n      const customAttributesDesc = Object.entries(this.customAttributes_).map(\n        ([name, value]) => {\n          const isUsed = name in styleShader.attributes || name === 'hitColor';\n          return {\n            name: isUsed ? `a_${name}` : null, // giving a null name means this is only used for \"spacing\" in between attributes\n            size: value.size || 1,\n            type: AttributeType.FLOAT,\n          };\n        },\n      );\n\n      // set up each subpass\n      if (styleShader.builder.getFillVertexShader()) {\n        renderPass.fillRenderPass = {\n          vertexShader: styleShader.builder.getFillVertexShader(),\n          fragmentShader: styleShader.builder.getFillFragmentShader(),\n          attributesDesc: [\n            {\n              name: Attributes.POSITION,\n              size: 2,\n              type: AttributeType.FLOAT,\n            },\n            ...customAttributesDesc,\n          ],\n          instancedAttributesDesc: [], // no instanced rendering for polygons\n          instancePrimitiveVertexCount: 3,\n        };\n      }\n      if (styleShader.builder.getStrokeVertexShader()) {\n        renderPass.strokeRenderPass = {\n          vertexShader: styleShader.builder.getStrokeVertexShader(),\n          fragmentShader: styleShader.builder.getStrokeFragmentShader(),\n          attributesDesc: [\n            {\n              name: Attributes.LOCAL_POSITION,\n              size: 2,\n              type: AttributeType.FLOAT,\n            },\n          ],\n          instancedAttributesDesc: [\n            {\n              name: Attributes.SEGMENT_START,\n              size: 2,\n              type: AttributeType.FLOAT,\n            },\n            {\n              name: Attributes.MEASURE_START,\n              size: 1,\n              type: AttributeType.FLOAT,\n            },\n            {\n              name: Attributes.SEGMENT_END,\n              size: 2,\n              type: AttributeType.FLOAT,\n            },\n            {\n              name: Attributes.MEASURE_END,\n              size: 1,\n              type: AttributeType.FLOAT,\n            },\n            {\n              name: Attributes.JOIN_ANGLES,\n              size: 2,\n              type: AttributeType.FLOAT,\n            },\n            {\n              name: Attributes.DISTANCE_LOW,\n              size: 1,\n              type: AttributeType.FLOAT,\n            },\n            {\n              name: Attributes.DISTANCE_HIGH,\n              size: 1,\n              type: AttributeType.FLOAT,\n            },\n            {\n              name: Attributes.ANGLE_TANGENT_SUM,\n              size: 1,\n              type: AttributeType.FLOAT,\n            },\n            ...customAttributesDesc,\n          ],\n          instancePrimitiveVertexCount: 6,\n        };\n      }\n      if (styleShader.builder.getSymbolVertexShader()) {\n        renderPass.symbolRenderPass = {\n          vertexShader: styleShader.builder.getSymbolVertexShader(),\n          fragmentShader: styleShader.builder.getSymbolFragmentShader(),\n          attributesDesc: [\n            {\n              name: Attributes.LOCAL_POSITION,\n              size: 2,\n              type: AttributeType.FLOAT,\n            },\n          ],\n          instancedAttributesDesc: [\n            {\n              name: Attributes.POSITION,\n              size: 2,\n              type: AttributeType.FLOAT,\n            },\n            ...customAttributesDesc,\n          ],\n          instancePrimitiveVertexCount: 6,\n        };\n      }\n      return renderPass;\n    });\n\n    this.hasFill_ = this.renderPasses_.some((pass) => pass.fillRenderPass);\n    this.hasStroke_ = this.renderPasses_.some((pass) => pass.strokeRenderPass);\n    this.hasSymbol_ = this.renderPasses_.some((pass) => pass.symbolRenderPass);\n\n    // this will initialize render passes with the given helper\n    this.setHelper(helper);\n  }\n\n  /**\n   * @param {import('./MixedGeometryBatch.js').default} geometryBatch Geometry batch\n   * @param {import(\"../../transform.js\").Transform} transform Transform to apply to coordinates\n   * @return {Promise<WebGLBuffers|null>} A promise resolving to WebGL buffers; returns null if buffers are empty\n   */\n  async generateBuffers(geometryBatch, transform) {\n    if (geometryBatch.isEmpty()) {\n      return null;\n    }\n    const renderInstructions = this.generateRenderInstructions_(\n      geometryBatch,\n      transform,\n    );\n    const [polygonBuffers, lineStringBuffers, pointBuffers] = await Promise.all(\n      [\n        this.generateBuffersForType_(\n          renderInstructions.polygonInstructions,\n          'Polygon',\n          transform,\n        ),\n        this.generateBuffersForType_(\n          renderInstructions.lineStringInstructions,\n          'LineString',\n          transform,\n        ),\n        this.generateBuffersForType_(\n          renderInstructions.pointInstructions,\n          'Point',\n          transform,\n        ),\n      ],\n    );\n    // also return the inverse of the transform that was applied when generating buffers\n    const invertVerticesTransform = makeInverseTransform(\n      createTransform(),\n      transform,\n    );\n    return {\n      polygonBuffers: polygonBuffers,\n      lineStringBuffers: lineStringBuffers,\n      pointBuffers: pointBuffers,\n      invertVerticesTransform: invertVerticesTransform,\n    };\n  }\n\n  /**\n   * @param {import('./MixedGeometryBatch.js').default} geometryBatch Geometry batch\n   * @param {import(\"../../transform.js\").Transform} transform Transform to apply to coordinates\n   * @return {RenderInstructions} Render instructions\n   * @private\n   */\n  generateRenderInstructions_(geometryBatch, transform) {\n    const polygonInstructions = this.hasFill_\n      ? generatePolygonRenderInstructions(\n          geometryBatch.polygonBatch,\n          new Float32Array(0),\n          this.customAttributes_,\n          transform,\n        )\n      : null;\n    const lineStringInstructions = this.hasStroke_\n      ? generateLineStringRenderInstructions(\n          geometryBatch.lineStringBatch,\n          new Float32Array(0),\n          this.customAttributes_,\n          transform,\n        )\n      : null;\n    const pointInstructions = this.hasSymbol_\n      ? generatePointRenderInstructions(\n          geometryBatch.pointBatch,\n          new Float32Array(0),\n          this.customAttributes_,\n          transform,\n        )\n      : null;\n\n    return {\n      polygonInstructions,\n      lineStringInstructions,\n      pointInstructions,\n    };\n  }\n\n  /**\n   * @param {Float32Array|null} renderInstructions Render instructions\n   * @param {import(\"../../geom/Geometry.js\").Type} geometryType Geometry type\n   * @param {import(\"../../transform.js\").Transform} transform Transform to apply to coordinates\n   * @return {Promise<WebGLArrayBufferSet>|null} Indices buffer and vertices buffer; null if nothing to render\n   * @private\n   */\n  generateBuffersForType_(renderInstructions, geometryType, transform) {\n    if (renderInstructions === null) {\n      return null;\n    }\n\n    const messageId = workerMessageCounter++;\n    let messageType;\n    switch (geometryType) {\n      case 'Polygon':\n        messageType = WebGLWorkerMessageType.GENERATE_POLYGON_BUFFERS;\n        break;\n      case 'LineString':\n        messageType = WebGLWorkerMessageType.GENERATE_LINE_STRING_BUFFERS;\n        break;\n      case 'Point':\n        messageType = WebGLWorkerMessageType.GENERATE_POINT_BUFFERS;\n        break;\n      default:\n      // pass\n    }\n\n    /** @type {import('./constants.js').WebGLWorkerGenerateBuffersMessage} */\n    const message = {\n      id: messageId,\n      type: messageType,\n      renderInstructions: renderInstructions.buffer,\n      renderInstructionsTransform: transform,\n      customAttributesSize: getCustomAttributesSize(this.customAttributes_),\n    };\n    const WEBGL_WORKER = getWebGLWorker();\n    WEBGL_WORKER.postMessage(message, [renderInstructions.buffer]);\n\n    // leave ownership of render instructions\n    renderInstructions = null;\n\n    return new Promise((resolve) => {\n      /**\n       * @param {{data: import('./constants.js').WebGLWorkerGenerateBuffersMessage}} event Event.\n       */\n      const handleMessage = (event) => {\n        const received = event.data;\n\n        // this is not the response to our request: skip\n        if (received.id !== messageId) {\n          return;\n        }\n\n        // we've received our response: stop listening\n        WEBGL_WORKER.removeEventListener('message', handleMessage);\n\n        // the helper has disposed in the meantime; the promise will not be resolved\n        if (!this.helper_.getGL()) {\n          return;\n        }\n\n        // copy & flush received buffers to GPU\n        const indicesBuffer = new WebGLArrayBuffer(\n          ELEMENT_ARRAY_BUFFER,\n          DYNAMIC_DRAW,\n        ).fromArrayBuffer(received.indicesBuffer);\n        const vertexAttributesBuffer = new WebGLArrayBuffer(\n          ARRAY_BUFFER,\n          DYNAMIC_DRAW,\n        ).fromArrayBuffer(received.vertexAttributesBuffer);\n        const instanceAttributesBuffer = new WebGLArrayBuffer(\n          ARRAY_BUFFER,\n          DYNAMIC_DRAW,\n        ).fromArrayBuffer(received.instanceAttributesBuffer);\n        this.helper_.flushBufferData(indicesBuffer);\n        this.helper_.flushBufferData(vertexAttributesBuffer);\n        this.helper_.flushBufferData(instanceAttributesBuffer);\n\n        resolve([\n          indicesBuffer,\n          vertexAttributesBuffer,\n          instanceAttributesBuffer,\n        ]);\n      };\n\n      WEBGL_WORKER.addEventListener('message', handleMessage);\n    });\n  }\n\n  /**\n   * Render the geometries in the given buffers.\n   * @param {WebGLBuffers} buffers WebGL Buffers to draw\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state\n   * @param {function(): void} preRenderCallback This callback will be called right before drawing, and can be used to set uniforms\n   */\n  render(buffers, frameState, preRenderCallback) {\n    for (const renderPass of this.renderPasses_) {\n      renderPass.fillRenderPass &&\n        this.renderInternal_(\n          buffers.polygonBuffers[0],\n          buffers.polygonBuffers[1],\n          buffers.polygonBuffers[2],\n          renderPass.fillRenderPass,\n          frameState,\n          preRenderCallback,\n        );\n      renderPass.strokeRenderPass &&\n        this.renderInternal_(\n          buffers.lineStringBuffers[0],\n          buffers.lineStringBuffers[1],\n          buffers.lineStringBuffers[2],\n          renderPass.strokeRenderPass,\n          frameState,\n          preRenderCallback,\n        );\n      renderPass.symbolRenderPass &&\n        this.renderInternal_(\n          buffers.pointBuffers[0],\n          buffers.pointBuffers[1],\n          buffers.pointBuffers[2],\n          renderPass.symbolRenderPass,\n          frameState,\n          preRenderCallback,\n        );\n    }\n  }\n\n  /**\n   * @param {WebGLArrayBuffer} indicesBuffer Indices buffer\n   * @param {WebGLArrayBuffer} vertexAttributesBuffer Vertex attributes buffer\n   * @param {WebGLArrayBuffer} instanceAttributesBuffer Instance attributes buffer\n   * @param {SubRenderPass} subRenderPass Render pass (program, attributes, etc.) specific to one geometry type\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @param {function(): void} preRenderCallback This callback will be called right before drawing, and can be used to set uniforms\n   * @private\n   */\n  renderInternal_(\n    indicesBuffer,\n    vertexAttributesBuffer,\n    instanceAttributesBuffer,\n    subRenderPass,\n    frameState,\n    preRenderCallback,\n  ) {\n    const renderCount = indicesBuffer.getSize();\n    if (renderCount === 0) {\n      return;\n    }\n\n    const usesInstancedRendering = subRenderPass.instancedAttributesDesc.length;\n\n    this.helper_.useProgram(subRenderPass.program, frameState);\n    this.helper_.bindBuffer(vertexAttributesBuffer);\n    this.helper_.bindBuffer(indicesBuffer);\n    this.helper_.enableAttributes(subRenderPass.attributesDesc);\n    this.helper_.bindBuffer(instanceAttributesBuffer);\n    this.helper_.enableAttributesInstanced(\n      subRenderPass.instancedAttributesDesc,\n    );\n\n    preRenderCallback();\n\n    if (usesInstancedRendering) {\n      const instanceAttributesStride =\n        subRenderPass.instancedAttributesDesc.reduce(\n          (prev, curr) => prev + (curr.size || 1),\n          0,\n        );\n      const instanceCount =\n        instanceAttributesBuffer.getSize() / instanceAttributesStride;\n\n      this.helper_.drawElementsInstanced(0, renderCount, instanceCount);\n    } else {\n      this.helper_.drawElements(0, renderCount);\n    }\n  }\n\n  /**\n   * @param {import('../../webgl/Helper.js').default} helper Helper\n   * @param {WebGLBuffers} buffers WebGL Buffers to reload if any\n   */\n  setHelper(helper, buffers = null) {\n    this.helper_ = helper;\n\n    for (const renderPass of this.renderPasses_) {\n      if (renderPass.fillRenderPass) {\n        renderPass.fillRenderPass.program = this.helper_.getProgram(\n          renderPass.fillRenderPass.fragmentShader,\n          renderPass.fillRenderPass.vertexShader,\n        );\n      }\n      if (renderPass.strokeRenderPass) {\n        renderPass.strokeRenderPass.program = this.helper_.getProgram(\n          renderPass.strokeRenderPass.fragmentShader,\n          renderPass.strokeRenderPass.vertexShader,\n        );\n      }\n      if (renderPass.symbolRenderPass) {\n        renderPass.symbolRenderPass.program = this.helper_.getProgram(\n          renderPass.symbolRenderPass.fragmentShader,\n          renderPass.symbolRenderPass.vertexShader,\n        );\n      }\n    }\n    this.helper_.addUniforms(this.uniforms_);\n\n    if (buffers) {\n      if (buffers.polygonBuffers) {\n        this.helper_.flushBufferData(buffers.polygonBuffers[0]);\n        this.helper_.flushBufferData(buffers.polygonBuffers[1]);\n        this.helper_.flushBufferData(buffers.polygonBuffers[2]);\n      }\n      if (buffers.lineStringBuffers) {\n        this.helper_.flushBufferData(buffers.lineStringBuffers[0]);\n        this.helper_.flushBufferData(buffers.lineStringBuffers[1]);\n        this.helper_.flushBufferData(buffers.lineStringBuffers[2]);\n      }\n      if (buffers.pointBuffers) {\n        this.helper_.flushBufferData(buffers.pointBuffers[0]);\n        this.helper_.flushBufferData(buffers.pointBuffers[1]);\n        this.helper_.flushBufferData(buffers.pointBuffers[2]);\n      }\n    }\n  }\n}\n\nexport default VectorStyleRenderer;\n\n/**\n * Breaks down a vector style into an array of prebuilt shader builders with attributes and uniforms\n * @param {FlatStyleLike|StyleShaders|Array<StyleShaders>} style Vector style\n * @param {import('../../style/flat.js').StyleVariables} variables Style variables\n * @return {Array<StyleShaders>} Array of style shaders\n */\nexport function convertStyleToShaders(style, variables) {\n  // possible cases:\n  // - single shader\n  // - multiple shaders\n  // - single style\n  // - multiple styles\n  // - multiple rules\n  const asArray = Array.isArray(style) ? style : [style];\n\n  // if array of rules: break rules into separate styles, compute \"else\" filters\n  if ('style' in asArray[0]) {\n    /** @type {Array<StyleShaders>} */\n    const shaders = [];\n    const rules = /** @type {Array<FlatStyleRule>} */ (asArray);\n    const previousFilters = [];\n    for (const rule of rules) {\n      /** @type {Array<FlatStyle>} */\n      const ruleStyles = Array.isArray(rule.style) ? rule.style : [rule.style];\n      /** @type {import(\"../../expr/expression.js\").EncodedExpression} */\n      let currentFilter = rule.filter;\n      if (rule.else && previousFilters.length) {\n        currentFilter = [\n          'all',\n          ...previousFilters.map((filter) => ['!', filter]),\n        ];\n        if (rule.filter) {\n          currentFilter.push(rule.filter);\n        }\n        if (currentFilter.length < 3) {\n          currentFilter = currentFilter[1];\n        }\n      }\n      if (rule.filter) {\n        previousFilters.push(rule.filter);\n      }\n      // parse each style and convert to shader\n      const styleShaders = ruleStyles.map((style) =>\n        parseLiteralStyle(style, variables, currentFilter),\n      );\n      shaders.push(...styleShaders);\n    }\n    return shaders;\n  }\n\n  // if array of shaders: return as is\n  if ('builder' in asArray[0]) {\n    return /** @type {Array<StyleShaders>} */ (asArray);\n  }\n\n  // array of flat styles: simply convert to shaders\n  return /** @type {Array<FlatStyle>} */ (asArray).map((style) =>\n    parseLiteralStyle(style, variables, null),\n  );\n}\n","\n        export function create() {\n          const source = \"function t(t,n,x=2){const o=n&&n.length,i=o?n[0]*x:t.length;let f=e(t,0,i,x,!0);const l=[];if(!f||f.next===f.prev)return l;let c,y,h;if(o&&(f=function(t,n,r,x){const o=[];for(let r=0,i=n.length;r<i;r++){const f=e(t,n[r]*x,r<i-1?n[r+1]*x:t.length,x,!1);f===f.next&&(f.steiner=!0),o.push(a(f))}o.sort(u);for(let t=0;t<o.length;t++)r=s(o[t],r);return r}(t,n,f,x)),t.length>80*x){c=t[0],y=t[1];let e=c,n=y;for(let r=x;r<i;r+=x){const x=t[r],o=t[r+1];x<c&&(c=x),o<y&&(y=o),x>e&&(e=x),o>n&&(n=o)}h=Math.max(e-c,n-y),h=0!==h?32767/h:0}return r(f,l,x,c,y,h,0),l}function e(t,e,n,r,x){let o;if(x===function(t,e,n,r){let x=0;for(let o=e,i=n-r;o<n;o+=r)x+=(t[i]-t[o])*(t[o+1]+t[i+1]),i=o;return x}(t,e,n,r)>0)for(let x=e;x<n;x+=r)o=d(x/r|0,t[x],t[x+1],o);else for(let x=n-r;x>=e;x-=r)o=d(x/r|0,t[x],t[x+1],o);return o&&b(o,o.next)&&(w(o),o=o.next),o}function n(t,e){if(!t)return t;e||(e=t);let n,r=t;do{if(n=!1,r.steiner||!b(r,r.next)&&0!==v(r.prev,r,r.next))r=r.next;else{if(w(r),r=e=r.prev,r===r.next)break;n=!0}}while(n||r!==e);return e}function r(t,e,u,s,l,a,y){if(!t)return;!y&&a&&function(t,e,n,r){let x=t;do{0===x.z&&(x.z=c(x.x,x.y,e,n,r)),x.prevZ=x.prev,x.nextZ=x.next,x=x.next}while(x!==t);x.prevZ.nextZ=null,x.prevZ=null,function(t){let e,n=1;do{let r,x=t;t=null;let o=null;for(e=0;x;){e++;let i=x,f=0;for(let t=0;t<n&&(f++,i=i.nextZ,i);t++);let u=n;for(;f>0||u>0&&i;)0!==f&&(0===u||!i||x.z<=i.z)?(r=x,x=x.nextZ,f--):(r=i,i=i.nextZ,u--),o?o.nextZ=r:t=r,r.prevZ=o,o=r;x=i}o.nextZ=null,n*=2}while(e>1)}(x)}(t,s,l,a);let h=t;for(;t.prev!==t.next;){const c=t.prev,p=t.next;if(a?o(t,s,l,a):x(t))e.push(c.i,t.i,p.i),w(t),t=p.next,h=p.next;else if((t=p)===h){y?1===y?r(t=i(n(t),e),e,u,s,l,a,2):2===y&&f(t,e,u,s,l,a):r(n(t),e,u,s,l,a,1);break}}}function x(t){const e=t.prev,n=t,r=t.next;if(v(e,n,r)>=0)return!1;const x=e.x,o=n.x,i=r.x,f=e.y,u=n.y,s=r.y,l=Math.min(x,o,i),c=Math.min(f,u,s),a=Math.max(x,o,i),y=Math.max(f,u,s);let p=r.next;for(;p!==e;){if(p.x>=l&&p.x<=a&&p.y>=c&&p.y<=y&&h(x,f,o,u,i,s,p.x,p.y)&&v(p.prev,p,p.next)>=0)return!1;p=p.next}return!0}function o(t,e,n,r){const x=t.prev,o=t,i=t.next;if(v(x,o,i)>=0)return!1;const f=x.x,u=o.x,s=i.x,l=x.y,a=o.y,y=i.y,p=Math.min(f,u,s),b=Math.min(l,a,y),M=Math.max(f,u,s),m=Math.max(l,a,y),A=c(p,b,e,n,r),g=c(M,m,e,n,r);let Z=t.prevZ,d=t.nextZ;for(;Z&&Z.z>=A&&d&&d.z<=g;){if(Z.x>=p&&Z.x<=M&&Z.y>=b&&Z.y<=m&&Z!==x&&Z!==i&&h(f,l,u,a,s,y,Z.x,Z.y)&&v(Z.prev,Z,Z.next)>=0)return!1;if(Z=Z.prevZ,d.x>=p&&d.x<=M&&d.y>=b&&d.y<=m&&d!==x&&d!==i&&h(f,l,u,a,s,y,d.x,d.y)&&v(d.prev,d,d.next)>=0)return!1;d=d.nextZ}for(;Z&&Z.z>=A;){if(Z.x>=p&&Z.x<=M&&Z.y>=b&&Z.y<=m&&Z!==x&&Z!==i&&h(f,l,u,a,s,y,Z.x,Z.y)&&v(Z.prev,Z,Z.next)>=0)return!1;Z=Z.prevZ}for(;d&&d.z<=g;){if(d.x>=p&&d.x<=M&&d.y>=b&&d.y<=m&&d!==x&&d!==i&&h(f,l,u,a,s,y,d.x,d.y)&&v(d.prev,d,d.next)>=0)return!1;d=d.nextZ}return!0}function i(t,e){let r=t;do{const n=r.prev,x=r.next.next;!b(n,x)&&M(n,r,r.next,x)&&g(n,x)&&g(x,n)&&(e.push(n.i,r.i,x.i),w(r),w(r.next),r=t=x),r=r.next}while(r!==t);return n(r)}function f(t,e,x,o,i,f){let u=t;do{let t=u.next.next;for(;t!==u.prev;){if(u.i!==t.i&&p(u,t)){let s=Z(u,t);return u=n(u,u.next),s=n(s,s.next),r(u,e,x,o,i,f,0),void r(s,e,x,o,i,f,0)}t=t.next}u=u.next}while(u!==t)}function u(t,e){let n=t.x-e.x;if(0===n&&(n=t.y-e.y,0===n)){n=(t.next.y-t.y)/(t.next.x-t.x)-(e.next.y-e.y)/(e.next.x-e.x)}return n}function s(t,e){const r=function(t,e){let n=e;const r=t.x,x=t.y;let o,i=-1/0;if(b(t,n))return n;do{if(b(t,n.next))return n.next;if(x<=n.y&&x>=n.next.y&&n.next.y!==n.y){const t=n.x+(x-n.y)*(n.next.x-n.x)/(n.next.y-n.y);if(t<=r&&t>i&&(i=t,o=n.x<n.next.x?n:n.next,t===r))return o}n=n.next}while(n!==e);if(!o)return null;const f=o,u=o.x,s=o.y;let c=1/0;n=o;do{if(r>=n.x&&n.x>=u&&r!==n.x&&y(x<s?r:i,x,u,s,x<s?i:r,x,n.x,n.y)){const e=Math.abs(x-n.y)/(r-n.x);g(n,t)&&(e<c||e===c&&(n.x>o.x||n.x===o.x&&l(o,n)))&&(o=n,c=e)}n=n.next}while(n!==f);return o}(t,e);if(!r)return e;const x=Z(r,t);return n(x,x.next),n(r,r.next)}function l(t,e){return v(t.prev,t,e.prev)<0&&v(e.next,t,t.next)<0}function c(t,e,n,r,x){return(t=1431655765&((t=858993459&((t=252645135&((t=16711935&((t=(t-n)*x|0)|t<<8))|t<<4))|t<<2))|t<<1))|(e=1431655765&((e=858993459&((e=252645135&((e=16711935&((e=(e-r)*x|0)|e<<8))|e<<4))|e<<2))|e<<1))<<1}function a(t){let e=t,n=t;do{(e.x<n.x||e.x===n.x&&e.y<n.y)&&(n=e),e=e.next}while(e!==t);return n}function y(t,e,n,r,x,o,i,f){return(x-i)*(e-f)>=(t-i)*(o-f)&&(t-i)*(r-f)>=(n-i)*(e-f)&&(n-i)*(o-f)>=(x-i)*(r-f)}function h(t,e,n,r,x,o,i,f){return!(t===i&&e===f)&&y(t,e,n,r,x,o,i,f)}function p(t,e){return t.next.i!==e.i&&t.prev.i!==e.i&&!function(t,e){let n=t;do{if(n.i!==t.i&&n.next.i!==t.i&&n.i!==e.i&&n.next.i!==e.i&&M(n,n.next,t,e))return!0;n=n.next}while(n!==t);return!1}(t,e)&&(g(t,e)&&g(e,t)&&function(t,e){let n=t,r=!1;const x=(t.x+e.x)/2,o=(t.y+e.y)/2;do{n.y>o!=n.next.y>o&&n.next.y!==n.y&&x<(n.next.x-n.x)*(o-n.y)/(n.next.y-n.y)+n.x&&(r=!r),n=n.next}while(n!==t);return r}(t,e)&&(v(t.prev,t,e.prev)||v(t,e.prev,e))||b(t,e)&&v(t.prev,t,t.next)>0&&v(e.prev,e,e.next)>0)}function v(t,e,n){return(e.y-t.y)*(n.x-e.x)-(e.x-t.x)*(n.y-e.y)}function b(t,e){return t.x===e.x&&t.y===e.y}function M(t,e,n,r){const x=A(v(t,e,n)),o=A(v(t,e,r)),i=A(v(n,r,t)),f=A(v(n,r,e));return x!==o&&i!==f||(!(0!==x||!m(t,n,e))||(!(0!==o||!m(t,r,e))||(!(0!==i||!m(n,t,r))||!(0!==f||!m(n,e,r)))))}function m(t,e,n){return e.x<=Math.max(t.x,n.x)&&e.x>=Math.min(t.x,n.x)&&e.y<=Math.max(t.y,n.y)&&e.y>=Math.min(t.y,n.y)}function A(t){return t>0?1:t<0?-1:0}function g(t,e){return v(t.prev,t,t.next)<0?v(t,e,t.next)>=0&&v(t,t.prev,e)>=0:v(t,e,t.prev)<0||v(t,t.next,e)<0}function Z(t,e){const n=F(t.i,t.x,t.y),r=F(e.i,e.x,e.y),x=t.next,o=e.prev;return t.next=e,e.prev=t,n.next=x,x.prev=n,r.next=n,n.prev=r,o.next=r,r.prev=o,r}function d(t,e,n,r){const x=F(t,e,n);return r?(x.next=r.next,x.prev=r,r.next.prev=x,r.next=x):(x.prev=x,x.next=x),x}function w(t){t.next.prev=t.prev,t.prev.next=t.next,t.prevZ&&(t.prevZ.nextZ=t.nextZ),t.nextZ&&(t.nextZ.prevZ=t.prevZ)}function F(t,e,n){return{i:t,x:e,y:n,prev:null,next:null,z:0,prevZ:null,nextZ:null,steiner:!1}}function E(t,e,n){const r=Math.sqrt((e[0]-t[0])*(e[0]-t[0])+(e[1]-t[1])*(e[1]-t[1])),x=[(e[0]-t[0])/r,(e[1]-t[1])/r],o=[-x[1],x[0]],i=Math.sqrt((n[0]-t[0])*(n[0]-t[0])+(n[1]-t[1])*(n[1]-t[1])),f=[(n[0]-t[0])/i,(n[1]-t[1])/i];let u=0===r||0===i?0:Math.acos((s=f[0]*x[0]+f[1]*x[1],l=-1,c=1,Math.min(Math.max(s,l),c)));var s,l,c;u=Math.max(u,1e-5);return f[0]*o[0]+f[1]*o[1]>0?u:2*Math.PI-u}function I(t,e){const n=e[0],r=e[1];return e[0]=t[0]*n+t[2]*r+t[4],e[1]=t[1]*n+t[3]*r+t[5],e}function z(t,e){const n=(r=e)[0]*r[3]-r[1]*r[2];var r;!function(t,e){if(!t)throw new Error(e)}(0!==n,\\\"Transformation matrix cannot be inverted\\\");const x=e[0],o=e[1],i=e[2],f=e[3],u=e[4],s=e[5];return t[0]=f/n,t[1]=-o/n,t[2]=-i/n,t[3]=x/n,t[4]=(i*s-f*u)/n,t[5]=-(x*s-o*u)/n,t}new Array(6);const B=[],P={vertexAttributesPosition:0,instanceAttributesPosition:0,indicesPosition:0};function N(t,e,n,r,x){const o=t[e++],i=t[e++],f=B;f.length=r;for(let n=0;n<f.length;n++)f[n]=t[e+n];let u=x?x.instanceAttributesPosition:0;return n[u++]=o,n[u++]=i,f.length&&(n.set(f,u),u+=f.length),P.instanceAttributesPosition=u,P}function R(t,e,n,r,x,o,i,f,u,s){const l=[t[e],t[e+1]],c=[t[n],t[n+1]],a=t[e+2],y=t[n+2],h=I(f,[...l]),p=I(f,[...c]);let v=-1,b=-1,M=s;const m=null!==x;if(null!==r){v=E(h,p,I(f,[...[t[r],t[r+1]]])),Math.cos(v)<=.985&&(M+=Math.tan((v-Math.PI)/2))}if(m){b=E(p,h,I(f,[...[t[x],t[x+1]]])),Math.cos(b)<=.985&&(M+=Math.tan((Math.PI-b)/2))}const A=Math.pow(2,24),g=u%A,Z=Math.floor(u/A)*A;return o.push(l[0],l[1],a,c[0],c[1],y,v,b,g,Z,s),o.push(...i),{length:u+Math.sqrt((p[0]-h[0])*(p[0]-h[0])+(p[1]-h[1])*(p[1]-h[1])),angle:M}}function S(e,n,r,x,o){const i=2+o;let f=n;const u=e.slice(f,f+o);f+=o;const s=e[f++];let l=0;const c=new Array(s-1);for(let t=0;t<s;t++)l+=e[f++],t<s-1&&(c[t]=l);const a=e.slice(f,f+2*l),y=t(a,c,2);for(let t=0;t<y.length;t++)x.push(y[t]+r.length/i);for(let t=0;t<a.length;t+=2)r.push(a[t],a[t+1],...u);return f+2*l}const T=\\\"GENERATE_POLYGON_BUFFERS\\\",_=\\\"GENERATE_POINT_BUFFERS\\\",O=\\\"GENERATE_LINE_STRING_BUFFERS\\\",U=self;U.onmessage=t=>{const e=t.data;switch(e.type){case _:{const t=2,n=2,r=e.customAttributesSize,x=n+r,o=new Float32Array(e.renderInstructions),i=o.length/x*(t+r),f=Uint32Array.from([0,1,3,1,2,3]),u=Float32Array.from([-1,-1,1,-1,1,1,-1,1]),s=new Float32Array(i);let l;for(let t=0;t<o.length;t+=x)l=N(o,t,s,r,l);const c=Object.assign({indicesBuffer:f.buffer,vertexAttributesBuffer:u.buffer,instanceAttributesBuffer:s.buffer,renderInstructions:o.buffer},e);U.postMessage(c,[u.buffer,s.buffer,f.buffer,o.buffer]);break}case O:{const t=[],n=e.customAttributesSize,r=3,x=new Float32Array(e.renderInstructions);let o=0;const i=[1,0,0,1,0,0];let f,u;for(z(i,e.renderInstructionsTransform);o<x.length;){u=Array.from(x.slice(o,o+n)),o+=n,f=x[o++];const e=o,s=o+(f-1)*r,l=x[e]===x[s]&&x[e+1]===x[s+1];let c=0,a=0;for(let n=0;n<f-1;n++){let y=null;n>0?y=o+(n-1)*r:l&&(y=s-r);let h=null;n<f-2?h=o+(n+2)*r:l&&(h=e+r);const p=R(x,o+n*r,o+(n+1)*r,y,h,t,u,i,c,a);c=p.length,a=p.angle}o+=f*r}const s=Uint32Array.from([0,1,3,1,2,3]),l=Float32Array.from([-1,-1,1,-1,1,1,-1,1]),c=Float32Array.from(t),a=Object.assign({indicesBuffer:s.buffer,vertexAttributesBuffer:l.buffer,instanceAttributesBuffer:c.buffer,renderInstructions:x.buffer},e);U.postMessage(a,[l.buffer,c.buffer,s.buffer,x.buffer]);break}case T:{const t=[],n=[],r=e.customAttributesSize,x=new Float32Array(e.renderInstructions);let o=0;for(;o<x.length;)o=S(x,o,t,n,r);const i=Uint32Array.from(n),f=Float32Array.from(t),u=Float32Array.from([]),s=Object.assign({indicesBuffer:i.buffer,vertexAttributesBuffer:f.buffer,instanceAttributesBuffer:u.buffer,renderInstructions:x.buffer},e);U.postMessage(s,[f.buffer,u.buffer,i.buffer,x.buffer]);break}}};\";\n          return new Worker(typeof Blob === 'undefined'\n            ? 'data:application/javascript;base64,' + Buffer.from(source, 'binary').toString('base64')\n            : URL.createObjectURL(new Blob([source], {type: 'application/javascript'})));\n        }\n      \n","/**\n * Utilities for encoding/decoding values to be used in shaders\n * @module ol/render/webgl/encodeUtil\n */\n\n/**\n * Generates a color array based on a numerical id, and pack it just like the `packColor` function of 'ol/render/webgl/compileUtil.js'.\n * Note: the range for each component is 0 to 1 with 256 steps\n * @param {number} id Id\n * @param {Array<number>} [array] Reusable array\n * @return {Array<number>} Packed color array with two components\n */\nexport function colorEncodeIdAndPack(id, array) {\n  array = array || [];\n  const radix = 256;\n  const divide = radix - 1;\n  const r = Math.floor(id / radix / radix / radix) / divide;\n  const g = (Math.floor(id / radix / radix) % radix) / divide;\n  const b = (Math.floor(id / radix) % radix) / divide;\n  const a = (id % radix) / divide;\n  array[0] = r * 256 * 255 + g * 255;\n  array[1] = b * 256 * 255 + a * 255;\n  return array;\n}\n\n/**\n * Reads an id from a color-encoded array\n * Note: the expected range for each component is 0 to 1 with 256 steps.\n * @param {Array<number>} color Color array containing the encoded id; color components are in the range 0 to 1\n * @return {number} Decoded id\n */\nexport function colorDecodeId(color) {\n  let id = 0;\n  const radix = 256;\n  const mult = radix - 1;\n  id += Math.round(color[0] * radix * radix * radix * mult);\n  id += Math.round(color[1] * radix * radix * mult);\n  id += Math.round(color[2] * radix * mult);\n  id += Math.round(color[3] * mult);\n  return id;\n}\n","/**\n * A wrapper class to simplify rendering to a texture instead of the final canvas\n * @module ol/webgl/RenderTarget\n */\nimport {equals} from '../array.js';\n\n// for pixel color reading\nconst tmpArray4 = new Uint8Array(4);\n\n/**\n * @classdesc\n * This class is a wrapper around the association of both a `WebGLTexture` and a `WebGLFramebuffer` instances,\n * simplifying initialization and binding for rendering.\n */\nclass WebGLRenderTarget {\n  /**\n   * @param {import(\"./Helper.js\").default} helper WebGL helper; mandatory.\n   * @param {Array<number>} [size] Expected size of the render target texture; note: this can be changed later on.\n   */\n  constructor(helper, size) {\n    /**\n     * @private\n     * @type {import(\"./Helper.js\").default}\n     */\n    this.helper_ = helper;\n    const gl = helper.getGL();\n\n    /**\n     * @private\n     * @type {WebGLTexture}\n     */\n    this.texture_ = gl.createTexture();\n\n    /**\n     * @private\n     * @type {WebGLFramebuffer}\n     */\n    this.framebuffer_ = gl.createFramebuffer();\n\n    /**\n     * @private\n     * @type {WebGLRenderbuffer}\n     */\n    this.depthbuffer_ = gl.createRenderbuffer();\n\n    /**\n     * @type {Array<number>}\n     * @private\n     */\n    this.size_ = size || [1, 1];\n\n    /**\n     * @type {Uint8Array}\n     * @private\n     */\n    this.data_ = new Uint8Array(0);\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.dataCacheDirty_ = true;\n\n    this.updateSize_();\n  }\n\n  /**\n   * Changes the size of the render target texture. Note: will do nothing if the size\n   * is already the same.\n   * @param {Array<number>} size Expected size of the render target texture\n   */\n  setSize(size) {\n    if (equals(size, this.size_)) {\n      return;\n    }\n    this.size_[0] = size[0];\n    this.size_[1] = size[1];\n    this.updateSize_();\n  }\n\n  /**\n   * Returns the size of the render target texture\n   * @return {Array<number>} Size of the render target texture\n   */\n  getSize() {\n    return this.size_;\n  }\n\n  /**\n   * This will cause following calls to `#readAll` or `#readPixel` to download the content of the\n   * render target into memory, which is an expensive operation.\n   * This content will be kept in cache but should be cleared after each new render.\n   */\n  clearCachedData() {\n    this.dataCacheDirty_ = true;\n  }\n\n  /**\n   * Returns the full content of the frame buffer as a series of r, g, b, a components\n   * in the 0-255 range (unsigned byte).\n   * @return {Uint8Array} Integer array of color values\n   */\n  readAll() {\n    if (this.dataCacheDirty_) {\n      const size = this.size_;\n      const gl = this.helper_.getGL();\n\n      gl.bindFramebuffer(gl.FRAMEBUFFER, this.framebuffer_);\n      gl.readPixels(\n        0,\n        0,\n        size[0],\n        size[1],\n        gl.RGBA,\n        gl.UNSIGNED_BYTE,\n        this.data_,\n      );\n      this.dataCacheDirty_ = false;\n    }\n    return this.data_;\n  }\n\n  /**\n   * Reads one pixel of the frame buffer as an array of r, g, b, a components\n   * in the 0-255 range (unsigned byte).\n   * If x and/or y are outside of existing data, an array filled with 0 is returned.\n   * @param {number} x Pixel coordinate\n   * @param {number} y Pixel coordinate\n   * @return {Uint8Array} Integer array with one color value (4 components)\n   */\n  readPixel(x, y) {\n    if (x < 0 || y < 0 || x > this.size_[0] || y >= this.size_[1]) {\n      tmpArray4[0] = 0;\n      tmpArray4[1] = 0;\n      tmpArray4[2] = 0;\n      tmpArray4[3] = 0;\n      return tmpArray4;\n    }\n\n    this.readAll();\n    const index =\n      Math.floor(x) + (this.size_[1] - Math.floor(y) - 1) * this.size_[0];\n    tmpArray4[0] = this.data_[index * 4];\n    tmpArray4[1] = this.data_[index * 4 + 1];\n    tmpArray4[2] = this.data_[index * 4 + 2];\n    tmpArray4[3] = this.data_[index * 4 + 3];\n    return tmpArray4;\n  }\n\n  /**\n   * @return {WebGLTexture} Texture to render to\n   */\n  getTexture() {\n    return this.texture_;\n  }\n\n  /**\n   * @return {WebGLFramebuffer} Frame buffer of the render target\n   */\n  getFramebuffer() {\n    return this.framebuffer_;\n  }\n\n  /**\n   * @return {WebGLRenderbuffer} Depth buffer of the render target\n   */\n  getDepthbuffer() {\n    return this.depthbuffer_;\n  }\n\n  /**\n   * @private\n   */\n  updateSize_() {\n    const size = this.size_;\n    const gl = this.helper_.getGL();\n\n    this.texture_ = this.helper_.createTexture(size, null, this.texture_);\n\n    gl.bindFramebuffer(gl.FRAMEBUFFER, this.framebuffer_);\n    gl.viewport(0, 0, size[0], size[1]);\n    gl.framebufferTexture2D(\n      gl.FRAMEBUFFER,\n      gl.COLOR_ATTACHMENT0,\n      gl.TEXTURE_2D,\n      this.texture_,\n      0,\n    );\n\n    gl.bindRenderbuffer(gl.RENDERBUFFER, this.depthbuffer_);\n    gl.renderbufferStorage(\n      gl.RENDERBUFFER,\n      gl.DEPTH_COMPONENT16,\n      size[0],\n      size[1],\n    );\n    gl.framebufferRenderbuffer(\n      gl.FRAMEBUFFER,\n      gl.DEPTH_ATTACHMENT,\n      gl.RENDERBUFFER,\n      this.depthbuffer_,\n    );\n\n    this.data_ = new Uint8Array(size[0] * size[1] * 4);\n  }\n}\n\nexport default WebGLRenderTarget;\n","/**\n * @module ol/renderer/webgl/vectorUtil\n */\n\nimport {getHighPart, getLowPart} from '../../render/webgl/float64Util.js';\nimport {\n  apply as applyTransform,\n  compose as composeTransform,\n  create as createTransform,\n  makeInverse as makeInverseTransform,\n  multiply as multiplyTransform,\n  setFromArray as setFromTransform,\n} from '../../transform.js';\nimport {\n  create as createMat4,\n  fromTransform as mat4FromTransform,\n} from '../../vec/mat4.js';\nimport {DefaultUniform} from '../../webgl/Helper.js';\n\nexport const VectorUniforms = {\n  // the patterns origin is computed on the CPU; it is expressed in the same coordinate system as the geometries rendered,\n  // except the rotation which is left to 0 in order to efficiently compute pattern offsets without involving sin/cos\n  PATTERN_ORIGIN_X_DOUBLE: 'u_df_patternOriginX',\n  PATTERN_ORIGIN_Y_DOUBLE: 'u_df_patternOriginY',\n\n  // patterns are scaled slightly up/down to match zoom levels; this is computed on the CPU for better precision and passed as a double float\n  PATTERN_SCALE_RATIO_DOUBLE: 'u_df_patternScaleRatio',\n\n  // this is used in double-float arithmetics to prevent precision-handling logic from being compiled out\n  ONE: 'u_one',\n};\n\nconst tmpCoords = [0, 0];\nconst tmpCoords2 = [0, 0];\nconst tmpTransform = createTransform();\nconst tmpMat4 = createMat4();\n\n/**\n * Applies uniforms used in vector rendering\n * @param {import('../../webgl/Helper.js').default} helper Helper\n * @param {import('../../transform.js').Transform} worldToViewTransform Transform\n * @param {import('../../transform.js').Transform} geometryInvertTransform Transform.\n * @param {import('../../Map.js').FrameState} frameState Frame state.\n */\nexport function applyVectorUniforms(\n  helper,\n  worldToViewTransform,\n  geometryInvertTransform,\n  frameState,\n) {\n  // world to screen matrix\n  setFromTransform(tmpTransform, worldToViewTransform);\n  multiplyTransform(tmpTransform, geometryInvertTransform);\n  helper.setUniformMatrixValue(\n    DefaultUniform.PROJECTION_MATRIX,\n    mat4FromTransform(tmpMat4, tmpTransform),\n  );\n\n  // screen to world matrix\n  makeInverseTransform(tmpTransform, tmpTransform);\n  helper.setUniformMatrixValue(\n    DefaultUniform.INVERT_PROJECTION_MATRIX,\n    mat4FromTransform(tmpMat4, tmpTransform),\n  );\n\n  // pattern origin: compute pixel position of world [0,0] in pixel coordinates _without rotation_\n  // these coordinates will be given as double-floats to the shader to avoid float32 precision loss\n  // (see https://github.com/openlayers/openlayers/issues/16705)\n  tmpCoords[0] = 0;\n  tmpCoords[1] = 0;\n\n  // compute & apply the transformation from world to pixel (without rotation)\n  const size = frameState.size;\n  const resolution = frameState.viewState.resolution;\n  const center = frameState.viewState.center;\n  composeTransform(\n    tmpTransform,\n    size[0] / 2,\n    size[1] / 2,\n    1 / resolution,\n    1 / resolution,\n    0,\n    -center[0],\n    -center[1],\n  );\n  applyTransform(tmpTransform, tmpCoords);\n\n  // set uniforms\n  tmpCoords2[0] = getHighPart(tmpCoords[0]);\n  tmpCoords2[1] = getLowPart(tmpCoords[0]);\n  helper.setUniformFloatVec2(\n    VectorUniforms.PATTERN_ORIGIN_X_DOUBLE,\n    tmpCoords2,\n  );\n  tmpCoords2[0] = getHighPart(tmpCoords[1]);\n  tmpCoords2[1] = getLowPart(tmpCoords[1]);\n  helper.setUniformFloatVec2(\n    VectorUniforms.PATTERN_ORIGIN_Y_DOUBLE,\n    tmpCoords2,\n  );\n\n  // we're also computing the scale ratio of the pattern so that we don't encounter\n  // precision issues on the GPU\n  const scaleRatio = Math.pow(2, ((frameState.viewState.zoom + 0.5) % 1) - 0.5);\n  tmpCoords[0] = getHighPart(scaleRatio);\n  tmpCoords[1] = getLowPart(scaleRatio);\n  helper.setUniformFloatVec2(\n    VectorUniforms.PATTERN_SCALE_RATIO_DOUBLE,\n    tmpCoords,\n  );\n}\n","/**\n * @module ol/renderer/webgl/VectorLayer\n */\nimport ViewHint from '../../ViewHint.js';\nimport {assert} from '../../asserts.js';\nimport {listen, unlistenByKey} from '../../events.js';\nimport {buffer, createEmpty, equals} from '../../extent.js';\nimport BaseVector from '../../layer/BaseVector.js';\nimport {\n  getTransformFromProjections,\n  getUserProjection,\n  toUserExtent,\n  toUserResolution,\n} from '../../proj.js';\nimport MixedGeometryBatch from '../../render/webgl/MixedGeometryBatch.js';\nimport VectorStyleRenderer from '../../render/webgl/VectorStyleRenderer.js';\nimport {colorDecodeId} from '../../render/webgl/encodeUtil.js';\nimport VectorEventType from '../../source/VectorEventType.js';\nimport {\n  apply as applyTransform,\n  create as createTransform,\n  translate as translateTransform,\n} from '../../transform.js';\nimport {DefaultUniform} from '../../webgl/Helper.js';\nimport WebGLRenderTarget from '../../webgl/RenderTarget.js';\nimport WebGLLayerRenderer from './Layer.js';\nimport {VectorUniforms, applyVectorUniforms} from './vectorUtil.js';\nimport {getWorldParameters} from './worldUtil.js';\n\nexport const Uniforms = {\n  ...DefaultUniform,\n  ...VectorUniforms,\n  RENDER_EXTENT: 'u_renderExtent', // intersection of layer, source, and view extent\n  GLOBAL_ALPHA: 'u_globalAlpha',\n};\n\n/**\n * @typedef {import('../../render/webgl/VectorStyleRenderer.js').StyleShaders} StyleShaders\n */\n/**\n * @typedef {import('../../style/flat.js').FlatStyleLike | Array<StyleShaders> | StyleShaders} LayerStyle\n */\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-layer'] A CSS class name to set to the canvas element.\n * @property {LayerStyle} style Flat vector style; also accepts shaders\n * @property {Object<string, number|Array<number>|string|boolean>} variables Style variables\n * @property {boolean} [disableHitDetection=false] Setting this to true will provide a slight performance boost, but will\n * prevent all hit detection on the layer.\n * @property {Array<import(\"./Layer.js\").PostProcessesOptions>} [postProcesses] Post-processes definitions\n */\n\n/**\n * @classdesc\n * Experimental WebGL vector renderer. Supports polygons, lines and points:\n *  Polygons are broken down into triangles\n *  Lines are rendered as strips of quads\n *  Points are rendered as quads\n *\n * You need to provide vertex and fragment shaders as well as custom attributes for each type of geometry. All shaders\n * can access the uniforms in the {@link module:ol/webgl/Helper~DefaultUniform} enum.\n * The vertex shaders can access the following attributes depending on the geometry type:\n *  For polygons: {@link module:ol/render/webgl/PolygonBatchRenderer~Attributes}\n *  For line strings: {@link module:ol/render/webgl/LineStringBatchRenderer~Attributes}\n *  For points: {@link module:ol/render/webgl/PointBatchRenderer~Attributes}\n *\n * Please note that the fragment shaders output should have premultiplied alpha, otherwise visual anomalies may occur.\n *\n * Note: this uses {@link module:ol/webgl/Helper~WebGLHelper} internally.\n */\nclass WebGLVectorLayerRenderer extends WebGLLayerRenderer {\n  /**\n   * @param {import(\"../../layer/Layer.js\").default} layer Layer.\n   * @param {Options} options Options.\n   */\n  constructor(layer, options) {\n    const uniforms = {\n      [Uniforms.RENDER_EXTENT]: [0, 0, 0, 0],\n      [Uniforms.GLOBAL_ALPHA]: 1,\n      [Uniforms.ONE]: 1,\n    };\n\n    super(layer, {\n      uniforms: uniforms,\n      postProcesses: options.postProcesses,\n    });\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.hitDetectionEnabled_ = !options.disableHitDetection;\n\n    /**\n     * @type {WebGLRenderTarget}\n     * @private\n     */\n    this.hitRenderTarget_;\n\n    /**\n     * @private\n     */\n    this.sourceRevision_ = -1;\n\n    /**\n     * @private\n     */\n    this.previousExtent_ = createEmpty();\n\n    /**\n     * This transform is updated on every frame and is the composition of:\n     * - invert of the world->screen transform that was used when rebuilding buffers (see `this.renderTransform_`)\n     * - current world->screen transform\n     * @type {import(\"../../transform.js\").Transform}\n     * @private\n     */\n    this.currentTransform_ = createTransform();\n\n    /**\n     * @type {import(\"../../transform.js\").Transform}\n     * @private\n     */\n    this.currentFrameStateTransform_ = createTransform();\n\n    /**\n     * @type {import('../../style/flat.js').StyleVariables}\n     * @private\n     */\n    this.styleVariables_ = {};\n\n    /**\n     * @type {LayerStyle}\n     * @private\n     */\n    this.style_ = [];\n\n    /**\n     * @type {VectorStyleRenderer}\n     * @public\n     */\n    this.styleRenderer_ = null;\n\n    /**\n     * @type {import('../../render/webgl/VectorStyleRenderer.js').WebGLBuffers}\n     * @private\n     */\n    this.buffers_ = null;\n\n    this.applyOptions_(options);\n\n    /**\n     * @private\n     */\n    this.batch_ = new MixedGeometryBatch();\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.initialFeaturesAdded_ = false;\n\n    /**\n     * @private\n     * @type {Array<import(\"../../events.js\").EventsKey|null>}\n     */\n    this.sourceListenKeys_ = null;\n  }\n\n  /**\n   * @private\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   */\n  addInitialFeatures_(frameState) {\n    const source = this.getLayer().getSource();\n    const userProjection = getUserProjection();\n    let projectionTransform;\n    if (userProjection) {\n      projectionTransform = getTransformFromProjections(\n        userProjection,\n        frameState.viewState.projection,\n      );\n    }\n    this.batch_.addFeatures(source.getFeatures(), projectionTransform);\n    this.sourceListenKeys_ = [\n      listen(\n        source,\n        VectorEventType.ADDFEATURE,\n        this.handleSourceFeatureAdded_.bind(this, projectionTransform),\n      ),\n      listen(\n        source,\n        VectorEventType.CHANGEFEATURE,\n        this.handleSourceFeatureChanged_.bind(this, projectionTransform),\n        this,\n      ),\n      listen(\n        source,\n        VectorEventType.REMOVEFEATURE,\n        this.handleSourceFeatureDelete_,\n        this,\n      ),\n      listen(\n        source,\n        VectorEventType.CLEAR,\n        this.handleSourceFeatureClear_,\n        this,\n      ),\n    ];\n  }\n\n  /**\n   * @param {Options} options Options.\n   * @private\n   */\n  applyOptions_(options) {\n    this.styleVariables_ = options.variables;\n    this.style_ = options.style;\n  }\n\n  /**\n   * @private\n   */\n  createRenderers_() {\n    this.buffers_ = null;\n    this.styleRenderer_ = new VectorStyleRenderer(\n      this.style_,\n      this.styleVariables_,\n      this.helper,\n      this.hitDetectionEnabled_,\n    );\n  }\n\n  /**\n   * @override\n   */\n  reset(options) {\n    this.applyOptions_(options);\n    if (this.helper) {\n      this.createRenderers_();\n    }\n    super.reset(options);\n  }\n\n  /**\n   * @override\n   */\n  afterHelperCreated() {\n    if (this.styleRenderer_) {\n      // To reuse buffers\n      this.styleRenderer_.setHelper(this.helper, this.buffers_);\n    } else {\n      this.createRenderers_();\n    }\n\n    if (this.hitDetectionEnabled_) {\n      this.hitRenderTarget_ = new WebGLRenderTarget(this.helper);\n    }\n  }\n\n  /**\n   * @param {import(\"../../proj.js\").TransformFunction} projectionTransform Transform function.\n   * @param {import(\"../../source/Vector.js\").VectorSourceEvent} event Event.\n   * @private\n   */\n  handleSourceFeatureAdded_(projectionTransform, event) {\n    const feature = event.feature;\n    this.batch_.addFeature(feature, projectionTransform);\n  }\n\n  /**\n   * @param {import(\"../../proj.js\").TransformFunction} projectionTransform Transform function.\n   * @param {import(\"../../source/Vector.js\").VectorSourceEvent} event Event.\n   * @private\n   */\n  handleSourceFeatureChanged_(projectionTransform, event) {\n    const feature = event.feature;\n    this.batch_.changeFeature(feature, projectionTransform);\n  }\n\n  /**\n   * @param {import(\"../../source/Vector.js\").VectorSourceEvent} event Event.\n   * @private\n   */\n  handleSourceFeatureDelete_(event) {\n    const feature = event.feature;\n    this.batch_.removeFeature(feature);\n  }\n\n  /**\n   * @private\n   */\n  handleSourceFeatureClear_() {\n    this.batch_.clear();\n  }\n\n  /**\n   * @param {import(\"../../transform.js\").Transform} batchInvertTransform Inverse of the transformation in which geometries are expressed\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @private\n   */\n  applyUniforms_(batchInvertTransform, frameState) {\n    applyVectorUniforms(\n      this.helper,\n      this.currentFrameStateTransform_,\n      batchInvertTransform,\n      frameState,\n    );\n  }\n\n  /**\n   * Render the layer.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @return {HTMLElement} The rendered element.\n   * @override\n   */\n  renderFrame(frameState) {\n    const gl = this.helper.getGL();\n    this.preRender(gl, frameState);\n\n    const [startWorld, endWorld, worldWidth] = getWorldParameters(\n      frameState,\n      this.getLayer(),\n    );\n\n    // draw the normal canvas\n    this.helper.prepareDraw(frameState);\n    this.renderWorlds(frameState, false, startWorld, endWorld, worldWidth);\n    this.helper.finalizeDraw(\n      frameState,\n      this.dispatchPreComposeEvent,\n      this.dispatchPostComposeEvent,\n    );\n\n    const canvas = this.helper.getCanvas();\n\n    if (this.hitDetectionEnabled_) {\n      this.renderWorlds(frameState, true, startWorld, endWorld, worldWidth);\n      this.hitRenderTarget_.clearCachedData();\n    }\n\n    this.postRender(gl, frameState);\n\n    return canvas;\n  }\n\n  /**\n   * Determine whether renderFrame should be called.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @return {boolean} Layer is ready to be rendered.\n   * @override\n   */\n  prepareFrameInternal(frameState) {\n    if (!this.initialFeaturesAdded_) {\n      this.addInitialFeatures_(frameState);\n      this.initialFeaturesAdded_ = true;\n    }\n\n    const layer = this.getLayer();\n    const vectorSource = layer.getSource();\n    const viewState = frameState.viewState;\n    const viewNotMoving =\n      !frameState.viewHints[ViewHint.ANIMATING] &&\n      !frameState.viewHints[ViewHint.INTERACTING];\n    const extentChanged = !equals(this.previousExtent_, frameState.extent);\n    const sourceChanged = this.sourceRevision_ < vectorSource.getRevision();\n\n    if (sourceChanged) {\n      this.sourceRevision_ = vectorSource.getRevision();\n    }\n\n    if (viewNotMoving && (extentChanged || sourceChanged)) {\n      const projection = viewState.projection;\n      const resolution = viewState.resolution;\n\n      const renderBuffer =\n        layer instanceof BaseVector ? layer.getRenderBuffer() : 0;\n      const extent = buffer(frameState.extent, renderBuffer * resolution);\n\n      const userProjection = getUserProjection();\n      if (userProjection) {\n        vectorSource.loadFeatures(\n          toUserExtent(extent, userProjection),\n          toUserResolution(resolution, projection),\n          userProjection,\n        );\n      } else {\n        vectorSource.loadFeatures(extent, resolution, projection);\n      }\n\n      this.ready = false;\n\n      const transform = this.helper.makeProjectionTransform(\n        frameState,\n        createTransform(),\n      );\n\n      this.styleRenderer_\n        .generateBuffers(this.batch_, transform)\n        .then((buffers) => {\n          if (this.buffers_) {\n            this.disposeBuffers(this.buffers_);\n          }\n          this.buffers_ = buffers;\n          this.ready = true;\n          this.getLayer().changed();\n        });\n\n      this.previousExtent_ = frameState.extent.slice();\n    }\n\n    return true;\n  }\n\n  /**\n   * Render the world, either to the main framebuffer or to the hit framebuffer\n   * @param {import(\"../../Map.js\").FrameState} frameState current frame state\n   * @param {boolean} forHitDetection whether the rendering is for hit detection\n   * @param {number} startWorld the world to render in the first iteration\n   * @param {number} endWorld the last world to render\n   * @param {number} worldWidth the width of the worlds being rendered\n   */\n  renderWorlds(frameState, forHitDetection, startWorld, endWorld, worldWidth) {\n    let world = startWorld;\n\n    if (forHitDetection) {\n      this.hitRenderTarget_.setSize([\n        Math.floor(frameState.size[0] / 2),\n        Math.floor(frameState.size[1] / 2),\n      ]);\n      this.helper.prepareDrawToRenderTarget(\n        frameState,\n        this.hitRenderTarget_,\n        true,\n      );\n    }\n\n    do {\n      this.helper.makeProjectionTransform(\n        frameState,\n        this.currentFrameStateTransform_,\n      );\n      translateTransform(\n        this.currentFrameStateTransform_,\n        world * worldWidth,\n        0,\n      );\n      if (!this.buffers_) {\n        continue;\n      }\n      this.styleRenderer_.render(this.buffers_, frameState, () => {\n        this.applyUniforms_(this.buffers_.invertVerticesTransform, frameState);\n        this.helper.applyHitDetectionUniform(forHitDetection);\n      });\n    } while (++world < endWorld);\n  }\n\n  /**\n   * @param {import(\"../../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @param {number} hitTolerance Hit tolerance in pixels.\n   * @param {import(\"../vector.js\").FeatureCallback<T>} callback Feature callback.\n   * @param {Array<import(\"../Map.js\").HitMatch<T>>} matches The hit detected matches with tolerance.\n   * @return {T|undefined} Callback result.\n   * @template T\n   * @override\n   */\n  forEachFeatureAtCoordinate(\n    coordinate,\n    frameState,\n    hitTolerance,\n    callback,\n    matches,\n  ) {\n    assert(\n      this.hitDetectionEnabled_,\n      '`forEachFeatureAtCoordinate` cannot be used on a WebGL layer if the hit detection logic has been disabled using the `disableHitDetection: true` option.',\n    );\n    if (!this.styleRenderer_ || !this.hitDetectionEnabled_) {\n      return undefined;\n    }\n\n    const pixel = applyTransform(\n      frameState.coordinateToPixelTransform,\n      coordinate.slice(),\n    );\n\n    const data = this.hitRenderTarget_.readPixel(pixel[0] / 2, pixel[1] / 2);\n    const color = [data[0] / 255, data[1] / 255, data[2] / 255, data[3] / 255];\n    const ref = colorDecodeId(color);\n    const feature = this.batch_.getFeatureFromRef(ref);\n    if (feature) {\n      return callback(feature, this.getLayer(), null);\n    }\n    return undefined;\n  }\n\n  /**\n   * Will release a set of Webgl buffers\n   * @param {import('../../render/webgl/VectorStyleRenderer.js').WebGLBuffers} buffers Buffers\n   */\n  disposeBuffers(buffers) {\n    /**\n     * @param {Array<import('../../webgl/Buffer.js').default>} typeBuffers Buffers\n     */\n    const disposeBuffersOfType = (typeBuffers) => {\n      for (const buffer of typeBuffers) {\n        if (buffer) {\n          this.helper.deleteBuffer(buffer);\n        }\n      }\n    };\n    if (buffers.pointBuffers) {\n      disposeBuffersOfType(buffers.pointBuffers);\n    }\n    if (buffers.lineStringBuffers) {\n      disposeBuffersOfType(buffers.lineStringBuffers);\n    }\n    if (buffers.polygonBuffers) {\n      disposeBuffersOfType(buffers.polygonBuffers);\n    }\n  }\n\n  /**\n   * Clean up.\n   * @override\n   */\n  disposeInternal() {\n    if (this.buffers_) {\n      this.disposeBuffers(this.buffers_);\n    }\n    if (this.sourceListenKeys_) {\n      this.sourceListenKeys_.forEach(function (key) {\n        unlistenByKey(key);\n      });\n      this.sourceListenKeys_ = null;\n    }\n    super.disposeInternal();\n  }\n\n  renderDeclutter() {}\n}\n\nexport default WebGLVectorLayerRenderer;\n","import {getWidth} from '../../extent.js';\n\n/**\n * Compute world params\n * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n * @param {any} layer The layer\n * @return {Array<number>} The world start, end and width.\n */\nexport function getWorldParameters(frameState, layer) {\n  const projection = frameState.viewState.projection;\n\n  const vectorSource = layer.getSource();\n  const multiWorld = vectorSource.getWrapX() && projection.canWrapX();\n  const projectionExtent = projection.getExtent();\n\n  const extent = frameState.extent;\n  const worldWidth = multiWorld ? getWidth(projectionExtent) : null;\n  const endWorld = multiWorld\n    ? Math.ceil((extent[2] - projectionExtent[2]) / worldWidth) + 1\n    : 1;\n\n  const startWorld = multiWorld\n    ? Math.floor((extent[0] - projectionExtent[0]) / worldWidth)\n    : 0;\n\n  return [startWorld, endWorld, worldWidth];\n}\n","/**\n * @module ol/layer/Heatmap\n */\nimport {createCanvasContext2D} from '../dom.js';\nimport {\n  BooleanType,\n  NumberType,\n  newParsingContext,\n} from '../expr/expression.js';\nimport {newCompilationContext} from '../expr/gpu.js';\nimport {clamp} from '../math.js';\nimport {ShaderBuilder} from '../render/webgl/ShaderBuilder.js';\nimport {\n  applyContextToBuilder,\n  expressionToGlsl,\n  generateAttributesFromContext,\n  generateUniformsFromContext,\n} from '../render/webgl/compileUtil.js';\nimport WebGLVectorLayerRenderer from '../renderer/webgl/VectorLayer.js';\nimport BaseVector from './BaseVector.js';\n\n/**\n * @typedef {'change:blur'|'change:radius'|'change:gradient'} HeatmapEventTypes\n */\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"./Base.js\").BaseLayerObjectEventTypes|\n *     import(\"./Layer.js\").LayerEventType|HeatmapEventTypes, import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../render/EventType.js\").LayerRenderEventTypes, import(\"../render/Event.js\").default, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"./Base.js\").BaseLayerObjectEventTypes|\n *     import(\"./Layer.js\").LayerEventType|HeatmapEventTypes|import(\"../render/EventType.js\").LayerRenderEventTypes, Return>} HeatmapOnSignature\n */\n\n/**\n * @typedef {import(\"../style/flat.js\").NumberExpression|string|function(import(\"../Feature.js\").default):number} WeightExpression\n */\n\n/**\n * @template {import(\"../Feature.js\").FeatureLike} [FeatureType=import(\"../Feature.js\").default]\n * @template {import(\"../source/Vector.js\").default<FeatureType>} [VectorSourceType=import(\"../source/Vector.js\").default<FeatureType>]\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} [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 {Array<string>} [gradient=['#00f', '#0ff', '#0f0', '#ff0', '#f00']] The color gradient\n * of the heatmap, specified as an array of CSS color strings.\n * @property {import(\"../style/flat.js\").NumberExpression} [radius=8] Radius size in pixels. Note that for LineStrings,\n * the width of the line will be double the radius.\n * @property {import(\"../style/flat.js\").NumberExpression} [blur=15] Blur size in pixels. This is added to the `radius`\n * parameter above to create the final size of the blur effect.\n * @property {WeightExpression} [weight='weight'] The feature\n * attribute to use for the weight. This also supports expressions returning a number or a function that returns a weight from a feature. Weight values\n * should range from 0 to 1 (and values outside will be clamped to that range).\n * @property {import(\"../style/flat.js\").BooleanExpression} [filter] Optional filter expression.\n * @property {Object<string, number|Array<number>|string|boolean>} [variables] Variables used in expressions (optional)\n * @property {VectorSourceType} [source] Point source.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n\n/**\n * @enum {string}\n * @private\n */\nconst Property = {\n  BLUR: 'blur',\n  GRADIENT: 'gradient',\n  RADIUS: 'radius',\n};\n\n/**\n * @const\n * @type {Array<string>}\n */\nconst DEFAULT_GRADIENT = ['#00f', '#0ff', '#0f0', '#ff0', '#f00'];\n\n/**\n * @classdesc\n * Layer for rendering vector data as a heatmap.\n * Note that any property set in the options is set as a {@link module:ol/Object~BaseObject}\n * property on the layer object; for example, setting `title: 'My Title'` in the\n * options means that `title` is observable, and has get/set accessors.\n *\n * @fires import(\"../render/Event.js\").RenderEvent#prerender\n * @fires import(\"../render/Event.js\").RenderEvent#postrender\n * @template {import(\"../Feature.js\").FeatureLike} [FeatureType=import(\"../Feature.js\").default]\n * @template {import(\"../source/Vector.js\").default<FeatureType>} [VectorSourceType=import(\"../source/Vector.js\").default<FeatureType>]\n * @extends {BaseVector<FeatureType, VectorSourceType, WebGLVectorLayerRenderer>}\n * @api\n */\nclass Heatmap extends BaseVector {\n  /**\n   * @param {Options<FeatureType, VectorSourceType>} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    const baseOptions = Object.assign({}, options);\n\n    delete baseOptions.gradient;\n    delete baseOptions.radius;\n    delete baseOptions.blur;\n    delete baseOptions.weight;\n    super(baseOptions);\n\n    /***\n     * @type {HeatmapOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {HeatmapOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {HeatmapOnSignature<void>}\n     */\n    this.un;\n\n    this.filter_ = options.filter ?? true;\n\n    /**\n     * @type {import('../style/flat.js').StyleVariables}\n     * @private\n     */\n    this.styleVariables_ = options.variables || {};\n\n    /**\n     * @private\n     * @type {HTMLCanvasElement|OffscreenCanvas}\n     */\n    this.gradient_ = null;\n\n    this.addChangeListener(Property.GRADIENT, this.handleGradientChanged_);\n\n    this.setGradient(options.gradient ? options.gradient : DEFAULT_GRADIENT);\n\n    this.setBlur(options.blur !== undefined ? options.blur : 15);\n\n    this.setRadius(options.radius !== undefined ? options.radius : 8);\n\n    const weight = options.weight ? options.weight : 'weight';\n\n    /**\n     * @private\n     */\n    this.weight_ = weight;\n\n    // For performance reasons, don't sort the features before rendering.\n    // The render order is not relevant for a heatmap representation.\n    this.setRenderOrder(null);\n  }\n\n  /**\n   * Return the blur size in pixels.\n   * @return {import(\"../style/flat.js\").NumberExpression} Blur size in pixels.\n   * @api\n   * @observable\n   */\n  getBlur() {\n    return /** @type {import(\"../style/flat.js\").NumberExpression} */ (\n      this.get(Property.BLUR)\n    );\n  }\n\n  /**\n   * Return the gradient colors as array of strings.\n   * @return {Array<string>} Colors.\n   * @api\n   * @observable\n   */\n  getGradient() {\n    return /** @type {Array<string>} */ (this.get(Property.GRADIENT));\n  }\n\n  /**\n   * Return the size of the radius in pixels.\n   * @return {import(\"../style/flat.js\").NumberExpression} Radius size in pixel.\n   * @api\n   * @observable\n   */\n  getRadius() {\n    return /** @type {import(\"../style/flat.js\").NumberExpression} */ (\n      this.get(Property.RADIUS)\n    );\n  }\n\n  /**\n   * @private\n   */\n  handleGradientChanged_() {\n    this.gradient_ = createGradient(this.getGradient());\n  }\n\n  /**\n   * Set the blur size in pixels.\n   * @param {import(\"../style/flat.js\").NumberExpression} blur Blur size in pixels (supports expressions).\n   * @api\n   * @observable\n   */\n  setBlur(blur) {\n    const previousValue = this.get(Property.BLUR);\n    this.set(Property.BLUR, blur);\n    // if the value stays numerical, simply refresh the layer\n    if (typeof blur === 'number' && typeof previousValue === 'number') {\n      this.changed();\n      return;\n    }\n    this.clearRenderer();\n  }\n\n  /**\n   * Set the gradient colors as array of strings.\n   * @param {Array<string>} colors Gradient.\n   * @api\n   * @observable\n   */\n  setGradient(colors) {\n    this.set(Property.GRADIENT, colors);\n  }\n\n  /**\n   * Set the size of the radius in pixels.\n   * @param {import(\"../style/flat.js\").NumberExpression} radius Radius size in pixel (supports expressions).\n   * @api\n   * @observable\n   */\n  setRadius(radius) {\n    const previousValue = this.get(Property.RADIUS);\n    this.set(Property.RADIUS, radius);\n    // if the value stays numerical, simply refresh the layer\n    if (typeof radius === 'number' && typeof previousValue === 'number') {\n      this.changed();\n      return;\n    }\n    this.clearRenderer();\n  }\n\n  /**\n   * Set the filter expression\n   * @param {import(\"../style/flat.js\").BooleanExpression} filter Filter expression\n   * @api\n   */\n  setFilter(filter) {\n    this.filter_ = filter;\n    this.changed();\n    this.clearRenderer();\n  }\n\n  /**\n   * Set the weight expression\n   * @param {WeightExpression} weight Weight expression\n   * @api\n   */\n  setWeight(weight) {\n    this.weight_ = weight;\n    this.changed();\n    this.clearRenderer();\n  }\n\n  /**\n   * @override\n   */\n  createRenderer() {\n    const builder = new ShaderBuilder();\n\n    const context = newCompilationContext();\n    const filterParsingContext = newParsingContext();\n    const filterCompiled = expressionToGlsl(\n      context,\n      this.filter_,\n      BooleanType,\n      filterParsingContext,\n    );\n    let radiusCompiled = expressionToGlsl(\n      context,\n      this.getRadius(),\n      NumberType,\n    );\n    let blurCompiled = expressionToGlsl(context, this.getBlur(), NumberType);\n\n    /** @type {import('../render/webgl/VectorStyleRenderer.js').UniformDefinitions} */\n    const blurRadiusUniforms = {};\n    if (typeof this.getBlur() === 'number') {\n      blurCompiled = 'a_blur';\n      blurRadiusUniforms['a_blur'] = () => this.getBlur();\n      builder.addUniform('a_blur', 'float');\n    }\n    if (typeof this.getRadius() === 'number') {\n      radiusCompiled = 'a_radius';\n      blurRadiusUniforms['a_radius'] = () => this.getRadius();\n      builder.addUniform('a_radius', 'float');\n    }\n\n    /** @type {import('../render/webgl/VectorStyleRenderer.js').AttributeDefinitions} */\n    const weightAttribute = {};\n    let weightExpression = null;\n    if (\n      typeof this.weight_ === 'string' ||\n      typeof this.weight_ === 'function'\n    ) {\n      const weightFunction =\n        typeof this.weight_ === 'string'\n          ? (feature) => feature.get(this.weight_)\n          : this.weight_;\n      weightAttribute['prop_weight'] = {\n        size: 1,\n        callback: (feature) => {\n          const weightValue = weightFunction(feature);\n          return weightValue !== undefined ? clamp(weightValue, 0, 1) : 1;\n        },\n      };\n      weightExpression = 'a_prop_weight';\n      builder.addAttribute('a_prop_weight', 'float');\n    } else {\n      const clampedWeight = ['clamp', this.weight_, 0, 1];\n      weightExpression = expressionToGlsl(context, clampedWeight, NumberType);\n    }\n\n    const blurSlopeExpr = `(${radiusCompiled} / max(1., ${blurCompiled}))`;\n\n    builder\n      .setSymbolSizeExpression(`vec2(${radiusCompiled} + ${blurCompiled}) * 2.`)\n      .setSymbolColorExpression(\n        `vec4(smoothstep(0., 1., (1. - length(coordsPx * 2. / v_quadSizePx)) * ${blurSlopeExpr}) * ${weightExpression})`,\n      )\n      .setStrokeColorExpression(\n        `vec4(smoothstep(0., 1., (1. - length(currentRadiusPx * 2. / v_width)) * ${blurSlopeExpr}) * ${weightExpression})`,\n      )\n      .setStrokeWidthExpression(`(${radiusCompiled} + ${blurCompiled}) * 2.`)\n      .setFillColorExpression(`vec4(${weightExpression})`);\n\n    if (filterParsingContext.mCoordinate) {\n      builder.setFragmentDiscardExpression(`!${filterCompiled}`);\n    } else {\n      builder.setShapeDiscardExpression(`!${filterCompiled}`);\n    }\n\n    applyContextToBuilder(builder, context);\n    const attributes = generateAttributesFromContext(context);\n    const uniforms = generateUniformsFromContext(context, this.styleVariables_);\n\n    return new WebGLVectorLayerRenderer(this, {\n      className: this.getClassName(),\n      variables: this.styleVariables_,\n      style: {\n        builder,\n        attributes: {\n          ...attributes,\n          ...weightAttribute,\n        },\n        uniforms: {\n          ...uniforms,\n          ...blurRadiusUniforms,\n        },\n      },\n      disableHitDetection: false,\n      postProcesses: [\n        {\n          fragmentShader: `\n            precision mediump float;\n\n            uniform sampler2D u_image;\n            uniform sampler2D u_gradientTexture;\n            uniform float u_opacity;\n\n            varying vec2 v_texCoord;\n\n            void main() {\n              vec4 color = texture2D(u_image, v_texCoord);\n              gl_FragColor.a = color.a * u_opacity;\n              gl_FragColor.rgb = texture2D(u_gradientTexture, vec2(0.5, color.a)).rgb;\n              gl_FragColor.rgb *= gl_FragColor.a;\n            }`,\n          uniforms: {\n            u_gradientTexture: () => this.gradient_,\n            u_opacity: () => this.getOpacity(),\n          },\n        },\n      ],\n    });\n  }\n\n  /**\n   * Update any variables used by the layer style and trigger a re-render.\n   * @param {import('../style/flat.js').StyleVariables} variables Variables to update.\n   */\n  updateStyleVariables(variables) {\n    Object.assign(this.styleVariables_, variables);\n    this.changed();\n  }\n\n  /**\n   * @override\n   */\n  renderDeclutter() {}\n}\n\n/**\n * @param {Array<string>} colors A list of colored.\n * @return {HTMLCanvasElement|OffscreenCanvas} canvas with gradient texture.\n */\nfunction createGradient(colors) {\n  const width = 1;\n  const height = 256;\n  const context = createCanvasContext2D(width, height);\n\n  const gradient = context.createLinearGradient(0, 0, width, height);\n  const step = 1 / (colors.length - 1);\n  for (let i = 0, ii = colors.length; i < ii; ++i) {\n    gradient.addColorStop(i * step, colors[i]);\n  }\n\n  context.fillStyle = gradient;\n  context.fillRect(0, 0, width, height);\n\n  return context.canvas;\n}\n\nexport default Heatmap;\n","/**\n * @module ol/interaction/DragAndDrop\n */\n// FIXME should handle all geo-referenced data, not just vector data\n\nimport {listen, unlistenByKey} from '../events.js';\nimport Event from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport {TRUE} from '../functions.js';\nimport {get as getProjection, getUserProjection} from '../proj.js';\nimport Interaction from './Interaction.js';\n\n/**\n * @typedef {Object} Options\n * @property {Array<typeof import(\"../format/Feature.js\").default|import(\"../format/Feature.js\").default>} [formatConstructors] Format constructors\n * (and/or formats pre-constructed with options).\n * @property {import(\"../source/Vector.js\").default} [source] Optional vector source where features will be added.  If a source is provided\n * all existing features will be removed and new features will be added when\n * they are dropped on the target.  If you want to add features to a vector\n * source without removing the existing features (append only), instead of\n * providing the source option listen for the \"addfeatures\" event.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Target projection. By default, the map's view's projection is used.\n * @property {HTMLElement} [target] The element that is used as the drop target, default is the viewport element.\n */\n\n/**\n * @enum {string}\n */\nconst DragAndDropEventType = {\n  /**\n   * Triggered when features are added\n   * @event DragAndDropEvent#addfeatures\n   * @api\n   */\n  ADD_FEATURES: 'addfeatures',\n};\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/interaction/DragAndDrop~DragAndDrop} instances are instances\n * of this type.\n */\nexport class DragAndDropEvent extends Event {\n  /**\n   * @param {DragAndDropEventType} type Type.\n   * @param {File} file File.\n   * @param {Array<import(\"../Feature.js\").default>} [features] Features.\n   * @param {import(\"../proj/Projection.js\").default} [projection] Projection.\n   */\n  constructor(type, file, features, projection) {\n    super(type);\n\n    /**\n     * The features parsed from dropped data.\n     * @type {Array<import(\"../Feature.js\").FeatureLike>|undefined}\n     * @api\n     */\n    this.features = features;\n\n    /**\n     * The dropped file.\n     * @type {File}\n     * @api\n     */\n    this.file = file;\n\n    /**\n     * The feature projection.\n     * @type {import(\"../proj/Projection.js\").default|undefined}\n     * @api\n     */\n    this.projection = projection;\n  }\n}\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types|\n *     'change:active', import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<'addfeatures', DragAndDropEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"../ObjectEventType.js\").Types|\n *     'change:active'|'addfeatures', Return>} DragAndDropOnSignature\n */\n\n/**\n * @classdesc\n * Handles input of vector data by drag and drop.\n *\n * @api\n *\n * @fires DragAndDropEvent\n */\nclass DragAndDrop extends Interaction {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super({\n      handleEvent: TRUE,\n    });\n\n    /***\n     * @type {DragAndDropOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {DragAndDropOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {DragAndDropOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.readAsBuffer_ = false;\n\n    /**\n     * @private\n     * @type {Array<import(\"../format/Feature.js\").default>}\n     */\n    this.formats_ = [];\n    const formatConstructors = options.formatConstructors\n      ? options.formatConstructors\n      : [];\n    for (let i = 0, ii = formatConstructors.length; i < ii; ++i) {\n      let format = formatConstructors[i];\n      if (typeof format === 'function') {\n        format = new format();\n      }\n      this.formats_.push(format);\n      this.readAsBuffer_ =\n        this.readAsBuffer_ || format.getType() === 'arraybuffer';\n    }\n\n    /**\n     * @private\n     * @type {import(\"../proj/Projection.js\").default}\n     */\n    this.projection_ = options.projection\n      ? getProjection(options.projection)\n      : null;\n\n    /**\n     * @private\n     * @type {?Array<import(\"../events.js\").EventsKey>}\n     */\n    this.dropListenKeys_ = null;\n\n    /**\n     * @private\n     * @type {import(\"../source/Vector.js\").default}\n     */\n    this.source_ = options.source || null;\n\n    /**\n     * @private\n     * @type {HTMLElement|null}\n     */\n    this.target = options.target ? options.target : null;\n  }\n\n  /**\n   * @param {File} file File.\n   * @param {Event} event Load event.\n   * @private\n   */\n  handleResult_(file, event) {\n    const result = event.target.result;\n    const map = this.getMap();\n    let projection = this.projection_;\n    if (!projection) {\n      projection = getUserProjection();\n      if (!projection) {\n        const view = map.getView();\n        projection = view.getProjection();\n      }\n    }\n\n    let text;\n    const formats = this.formats_;\n    for (let i = 0, ii = formats.length; i < ii; ++i) {\n      const format = formats[i];\n      let input = result;\n      if (this.readAsBuffer_ && format.getType() !== 'arraybuffer') {\n        if (text === undefined) {\n          text = new TextDecoder().decode(result);\n        }\n        input = text;\n      }\n      const features = this.tryReadFeatures_(format, input, {\n        featureProjection: projection,\n      });\n      if (features && features.length > 0) {\n        if (this.source_) {\n          this.source_.clear();\n          this.source_.addFeatures(features);\n        }\n        this.dispatchEvent(\n          new DragAndDropEvent(\n            DragAndDropEventType.ADD_FEATURES,\n            file,\n            features,\n            projection,\n          ),\n        );\n        break;\n      }\n    }\n  }\n\n  /**\n   * @private\n   */\n  registerListeners_() {\n    const map = this.getMap();\n    if (map) {\n      const dropArea = this.target ? this.target : map.getViewport();\n      this.dropListenKeys_ = [\n        listen(dropArea, EventType.DROP, this.handleDrop, this),\n        listen(dropArea, EventType.DRAGENTER, this.handleStop, this),\n        listen(dropArea, EventType.DRAGOVER, this.handleStop, this),\n        listen(dropArea, EventType.DROP, this.handleStop, this),\n      ];\n    }\n  }\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 (!this.getActive() && active) {\n      this.registerListeners_();\n    }\n    if (this.getActive() && !active) {\n      this.unregisterListeners_();\n    }\n    super.setActive(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} map Map.\n   * @override\n   */\n  setMap(map) {\n    this.unregisterListeners_();\n    super.setMap(map);\n    if (this.getActive()) {\n      this.registerListeners_();\n    }\n  }\n\n  /**\n   * @param {import(\"../format/Feature.js\").default} format Format.\n   * @param {string} text Text.\n   * @param {import(\"../format/Feature.js\").ReadOptions} options Read options.\n   * @private\n   * @return {Array<import(\"../Feature.js\").default>} Features.\n   */\n  tryReadFeatures_(format, text, options) {\n    try {\n      return (\n        /** @type {Array<import(\"../Feature.js\").default>} */\n        (format.readFeatures(text, options))\n      );\n    } catch {\n      return null;\n    }\n  }\n\n  /**\n   * @private\n   */\n  unregisterListeners_() {\n    if (this.dropListenKeys_) {\n      this.dropListenKeys_.forEach(unlistenByKey);\n      this.dropListenKeys_ = null;\n    }\n  }\n\n  /**\n   * @param {DragEvent} event Event.\n   */\n  handleDrop(event) {\n    const files = event.dataTransfer.files;\n    for (let i = 0, ii = files.length; i < ii; ++i) {\n      const file = files.item(i);\n      const reader = new FileReader();\n      reader.addEventListener(\n        EventType.LOAD,\n        this.handleResult_.bind(this, file),\n      );\n      if (this.readAsBuffer_) {\n        reader.readAsArrayBuffer(file);\n      } else {\n        reader.readAsText(file);\n      }\n    }\n  }\n\n  /**\n   * @param {DragEvent} event Event.\n   */\n  handleStop(event) {\n    event.stopPropagation();\n    event.preventDefault();\n    event.dataTransfer.dropEffect = 'copy';\n  }\n}\n\nexport default DragAndDrop;\n","/**\n * @module ol/geom/Circle\n */\nimport {createOrUpdate, forEachCorner, intersects} from '../extent.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {deflateCoordinate} from './flat/deflate.js';\nimport {rotate} from './flat/transform.js';\n\n/**\n * @classdesc\n * Circle geometry.\n *\n * @api\n */\nclass Circle extends SimpleGeometry {\n  /**\n   * @param {!import(\"../coordinate.js\").Coordinate} center Center.\n   *     For internal use, flat coordinates in combination with `layout` and no\n   *     `radius` are also accepted.\n   * @param {number} [radius] Radius in units of the projection.\n   * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n   */\n  constructor(center, radius, layout) {\n    super();\n    if (layout !== undefined && radius === undefined) {\n      this.setFlatCoordinates(layout, center);\n    } else {\n      radius = radius ? radius : 0;\n      this.setCenterAndRadius(center, radius, layout);\n    }\n  }\n\n  /**\n   * Make a complete copy of the geometry.\n   * @return {!Circle} Clone.\n   * @api\n   * @override\n   */\n  clone() {\n    const circle = new Circle(\n      this.flatCoordinates.slice(),\n      undefined,\n      this.layout,\n    );\n    circle.applyProperties(this);\n    return circle;\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 dx = x - flatCoordinates[0];\n    const dy = y - flatCoordinates[1];\n    const squaredDistance = dx * dx + dy * dy;\n    if (squaredDistance < minSquaredDistance) {\n      if (squaredDistance === 0) {\n        for (let i = 0; i < this.stride; ++i) {\n          closestPoint[i] = flatCoordinates[i];\n        }\n      } else {\n        const delta = this.getRadius() / Math.sqrt(squaredDistance);\n        closestPoint[0] = flatCoordinates[0] + delta * dx;\n        closestPoint[1] = flatCoordinates[1] + delta * dy;\n        for (let i = 2; i < this.stride; ++i) {\n          closestPoint[i] = flatCoordinates[i];\n        }\n      }\n      closestPoint.length = this.stride;\n      return squaredDistance;\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 flatCoordinates = this.flatCoordinates;\n    const dx = x - flatCoordinates[0];\n    const dy = y - flatCoordinates[1];\n    return dx * dx + dy * dy <= this.getRadiusSquared_();\n  }\n\n  /**\n   * Return the center of the circle as {@link module:ol/coordinate~Coordinate coordinate}.\n   * @return {import(\"../coordinate.js\").Coordinate} Center.\n   * @api\n   */\n  getCenter() {\n    return this.flatCoordinates.slice(0, this.stride);\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    const flatCoordinates = this.flatCoordinates;\n    const radius = flatCoordinates[this.stride] - flatCoordinates[0];\n    return createOrUpdate(\n      flatCoordinates[0] - radius,\n      flatCoordinates[1] - radius,\n      flatCoordinates[0] + radius,\n      flatCoordinates[1] + radius,\n      extent,\n    );\n  }\n\n  /**\n   * Return the radius of the circle.\n   * @return {number} Radius.\n   * @api\n   */\n  getRadius() {\n    return Math.sqrt(this.getRadiusSquared_());\n  }\n\n  /**\n   * @private\n   * @return {number} Radius squared.\n   */\n  getRadiusSquared_() {\n    const dx = this.flatCoordinates[this.stride] - this.flatCoordinates[0];\n    const dy = this.flatCoordinates[this.stride + 1] - this.flatCoordinates[1];\n    return dx * dx + dy * dy;\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 'Circle';\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 circleExtent = this.getExtent();\n    if (intersects(extent, circleExtent)) {\n      const center = this.getCenter();\n\n      if (extent[0] <= center[0] && extent[2] >= center[0]) {\n        return true;\n      }\n      if (extent[1] <= center[1] && extent[3] >= center[1]) {\n        return true;\n      }\n\n      return forEachCorner(extent, this.intersectsCoordinate.bind(this));\n    }\n    return false;\n  }\n\n  /**\n   * Set the center of the circle as {@link module:ol/coordinate~Coordinate coordinate}.\n   * @param {import(\"../coordinate.js\").Coordinate} center Center.\n   * @api\n   */\n  setCenter(center) {\n    const stride = this.stride;\n    const radius = this.flatCoordinates[stride] - this.flatCoordinates[0];\n    const flatCoordinates = center.slice();\n    flatCoordinates[stride] = flatCoordinates[0] + radius;\n    for (let i = 1; i < stride; ++i) {\n      flatCoordinates[stride + i] = center[i];\n    }\n    this.setFlatCoordinates(this.layout, flatCoordinates);\n    this.changed();\n  }\n\n  /**\n   * Set the center (as {@link module:ol/coordinate~Coordinate coordinate}) and the radius (as\n   * number) of the circle.\n   * @param {!import(\"../coordinate.js\").Coordinate} center Center.\n   * @param {number} radius Radius.\n   * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n   * @api\n   */\n  setCenterAndRadius(center, radius, layout) {\n    this.setLayout(layout, center, 0);\n    if (!this.flatCoordinates) {\n      this.flatCoordinates = [];\n    }\n    /** @type {Array<number>} */\n    const flatCoordinates = this.flatCoordinates;\n    let offset = deflateCoordinate(flatCoordinates, 0, center, this.stride);\n    flatCoordinates[offset++] = flatCoordinates[0] + radius;\n    for (let i = 1, ii = this.stride; i < ii; ++i) {\n      flatCoordinates[offset++] = flatCoordinates[i];\n    }\n    flatCoordinates.length = offset;\n    this.changed();\n  }\n\n  /**\n   * @override\n   */\n  getCoordinates() {\n    return null;\n  }\n\n  /**\n   * @override\n   */\n  setCoordinates(coordinates, layout) {}\n\n  /**\n   * Set the radius of the circle. The radius is in the units of the projection.\n   * @param {number} radius Radius.\n   * @api\n   */\n  setRadius(radius) {\n    this.flatCoordinates[this.stride] = this.flatCoordinates[0] + radius;\n    this.changed();\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 center = this.getCenter();\n    const stride = this.getStride();\n    this.setCenter(\n      rotate(center, 0, center.length, stride, angle, anchor, center),\n    );\n    this.changed();\n  }\n}\n\n/**\n * Transform each coordinate of the circle from one coordinate reference system\n * to another. 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 *\n * Internally a circle is currently represented by two points: the center of\n * the circle `[cx, cy]`, and the point to the right of the circle\n * `[cx + r, cy]`. This `transform` function just transforms these two points.\n * So the resulting geometry is also a circle, and that circle does not\n * correspond to the shape that would be obtained by transforming every point\n * of the original circle.\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 {Circle} This geometry.  Note that original geometry is\n *     modified in place.\n * @function\n * @api\n */\nCircle.prototype.transform;\nexport default Circle;\n","/**\n * @module ol/geom/GeometryCollection\n */\nimport {listen, unlistenByKey} from '../events.js';\nimport EventType from '../events/EventType.js';\nimport {\n  closestSquaredDistanceXY,\n  createOrUpdateEmpty,\n  extend,\n  getCenter,\n} from '../extent.js';\nimport Geometry from './Geometry.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<Geometry>} geometries Geometries.\n   */\n  constructor(geometries) {\n    super();\n\n    /**\n     * @private\n     * @type {Array<Geometry>}\n     */\n    this.geometries_ = geometries;\n\n    /**\n     * @private\n     * @type {Array<import(\"../events.js\").EventsKey>}\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<Geometry>} Geometries.\n   * @api\n   */\n  getGeometries() {\n    return cloneGeometries(this.geometries_);\n  }\n\n  /**\n   * @return {Array<Geometry>} Geometries.\n   */\n  getGeometriesArray() {\n    return this.geometries_;\n  }\n\n  /**\n   * @return {Array<Geometry>} Geometries.\n   */\n  getGeometriesArrayRecursive() {\n    /** @type {Array<Geometry>} */\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<Geometry>} geometries Geometries.\n   * @api\n   */\n  setGeometries(geometries) {\n    this.setGeometriesArray(cloneGeometries(geometries));\n  }\n\n  /**\n   * @param {Array<Geometry>} 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<Geometry>} geometries Geometries.\n * @return {Array<Geometry>} Cloned geometries.\n */\nfunction cloneGeometries(geometries) {\n  return geometries.map((geometry) => geometry.clone());\n}\n\nexport default GeometryCollection;\n","/**\n * Coordinate type when drawing lines.\n * @typedef {Array<import(\"../coordinate.js\").Coordinate>} LineCoordType\n */\n\nimport {distance} from '../coordinate.js';\nimport GeometryCollection from '../geom/GeometryCollection.js';\nimport LineString from '../geom/LineString.js';\nimport MultiLineString from '../geom/MultiLineString.js';\nimport MultiPolygon from '../geom/MultiPolygon.js';\nimport Polygon from '../geom/Polygon.js';\nimport {clamp, squaredDistance, toFixed} from '../math.js';\n\n/**\n * @param {LineCoordType} coordinates The ring coordinates.\n * @param {number} index The index.  May be wrapped.\n * @return {import(\"../coordinate.js\").Coordinate} The coordinate.\n */\nexport function getCoordinate(coordinates, index) {\n  const count = coordinates.length;\n  if (index < 0) {\n    return coordinates[index + count];\n  }\n  if (index >= count) {\n    return coordinates[index - count];\n  }\n  return coordinates[index];\n}\n\n/**\n * @param {LineCoordType} coordinates The coordinates.\n * @param {number} index The index.  May be fractional and may wrap.\n * @return {import(\"../coordinate.js\").Coordinate} The interpolated coordinate.\n */\nexport function interpolateCoordinate(coordinates, index) {\n  const count = coordinates.length;\n\n  let startIndex = Math.floor(index);\n  const along = index - startIndex;\n  if (startIndex >= count) {\n    startIndex -= count;\n  } else if (startIndex < 0) {\n    startIndex += count;\n  }\n\n  let endIndex = startIndex + 1;\n  if (endIndex >= count) {\n    endIndex -= count;\n  }\n\n  const start = coordinates[startIndex];\n  const x0 = start[0];\n  const y0 = start[1];\n  const end = coordinates[endIndex];\n  const dx = end[0] - x0;\n  const dy = end[1] - y0;\n\n  return [x0 + dx * along, y0 + dy * along];\n}\n\n/**\n * @typedef {Object} TraceTarget\n * @property {Array<import(\"../coordinate.js\").Coordinate>} coordinates Target coordinates.\n * @property {boolean} ring The target coordinates are a linear ring.\n * @property {number} startIndex The index of first traced coordinate.  A fractional index represents an\n * edge intersection.  Index values for rings will wrap (may be negative or larger than coordinates length).\n * @property {number} endIndex The index of last traced coordinate.  Details from startIndex also apply here.\n */\n\n/**\n * @typedef {Object} TraceState\n * @property {boolean} active Tracing active.\n * @property {import(\"../coordinate.js\").Coordinate} [startCoord] The initially clicked coordinate.\n * @property {Array<TraceTarget>} [targets] Targets available for tracing.\n * @property {number} [targetIndex] The index of the currently traced target.  A value of -1 indicates\n * that no trace target is active.\n */\n\n/**\n * @typedef {Object} TraceTargetUpdateInfo\n * @property {number} index The new target index.\n * @property {number} endIndex The new segment end index.\n * @property {number} closestTargetDistance The squared distance to the closest target.\n */\n\n/**\n * @type {TraceTargetUpdateInfo}\n */\nconst sharedUpdateInfo = {\n  index: -1,\n  endIndex: NaN,\n  closestTargetDistance: Infinity,\n};\n\n/**\n * @param {import(\"../coordinate.js\").Coordinate} coordinate The coordinate.\n * @param {TraceState} traceState The trace state.\n * @param {import(\"../Map.js\").default} map The map.\n * @param {number} snapTolerance The snap tolerance.\n * @return {TraceTargetUpdateInfo} Information about the new trace target.  The returned\n * object is reused between calls and must not be modified by the caller.\n */\nexport function getTraceTargetUpdate(\n  coordinate,\n  traceState,\n  map,\n  snapTolerance,\n) {\n  const x = coordinate[0];\n  const y = coordinate[1];\n\n  let closestTargetDistance = Infinity;\n\n  let newTargetIndex = -1;\n  let newEndIndex = NaN;\n\n  for (\n    let targetIndex = 0;\n    targetIndex < traceState.targets.length;\n    ++targetIndex\n  ) {\n    const target = traceState.targets[targetIndex];\n    const coordinates = target.coordinates;\n\n    let minSegmentDistance = Infinity;\n    let endIndex;\n    for (\n      let coordinateIndex = 0;\n      coordinateIndex < coordinates.length - 1;\n      ++coordinateIndex\n    ) {\n      const start = coordinates[coordinateIndex];\n      const end = coordinates[coordinateIndex + 1];\n      const rel = getPointSegmentRelationship(x, y, start, end);\n      if (rel.squaredDistance < minSegmentDistance) {\n        minSegmentDistance = rel.squaredDistance;\n        endIndex = coordinateIndex + rel.along;\n      }\n    }\n\n    if (minSegmentDistance < closestTargetDistance) {\n      closestTargetDistance = minSegmentDistance;\n      if (target.ring && traceState.targetIndex === targetIndex) {\n        // same target, maintain the same trace direction\n        if (target.endIndex > target.startIndex) {\n          // forward trace\n          if (endIndex < target.startIndex) {\n            endIndex += coordinates.length;\n          }\n        } else if (target.endIndex < target.startIndex) {\n          // reverse trace\n          if (endIndex > target.startIndex) {\n            endIndex -= coordinates.length;\n          }\n        }\n      }\n      newEndIndex = endIndex;\n      newTargetIndex = targetIndex;\n    }\n  }\n\n  const newTarget = traceState.targets[newTargetIndex];\n  let considerBothDirections = newTarget.ring;\n  if (traceState.targetIndex === newTargetIndex && considerBothDirections) {\n    // only consider switching trace direction if close to the start\n    const newCoordinate = interpolateCoordinate(\n      newTarget.coordinates,\n      newEndIndex,\n    );\n    const pixel = map.getPixelFromCoordinate(newCoordinate);\n    const startPx = map.getPixelFromCoordinate(traceState.startCoord);\n    if (distance(pixel, startPx) > snapTolerance) {\n      considerBothDirections = false;\n    }\n  }\n\n  if (considerBothDirections) {\n    const coordinates = newTarget.coordinates;\n    const count = coordinates.length;\n    const startIndex = newTarget.startIndex;\n    const endIndex = newEndIndex;\n    if (startIndex < endIndex) {\n      const forwardDistance = getCumulativeSquaredDistance(\n        coordinates,\n        startIndex,\n        endIndex,\n      );\n      const reverseDistance = getCumulativeSquaredDistance(\n        coordinates,\n        startIndex,\n        endIndex - count,\n      );\n      if (reverseDistance < forwardDistance) {\n        newEndIndex -= count;\n      }\n    } else {\n      const reverseDistance = getCumulativeSquaredDistance(\n        coordinates,\n        startIndex,\n        endIndex,\n      );\n      const forwardDistance = getCumulativeSquaredDistance(\n        coordinates,\n        startIndex,\n        endIndex + count,\n      );\n      if (forwardDistance < reverseDistance) {\n        newEndIndex += count;\n      }\n    }\n  }\n\n  sharedUpdateInfo.index = newTargetIndex;\n  sharedUpdateInfo.endIndex = newEndIndex;\n  sharedUpdateInfo.closestTargetDistance = closestTargetDistance;\n  return sharedUpdateInfo;\n}\n\n/**\n * @param {import(\"../coordinate.js\").Coordinate} coordinate The coordinate.\n * @param {Array<import(\"../Feature.js\").default>} features The candidate features.\n * @return {Array<TraceTarget>} The trace targets.\n */\nexport function getTraceTargets(coordinate, features) {\n  /**\n   * @type {Array<TraceTarget>}\n   */\n  const targets = [];\n\n  for (let i = 0; i < features.length; ++i) {\n    const feature = features[i];\n    const geometry = feature.getGeometry();\n    appendGeometryTraceTargets(coordinate, geometry, targets);\n  }\n\n  return targets;\n}\n\n/**\n * @param {import(\"../coordinate.js\").Coordinate} coordinate The coordinate.\n * @param {import(\"../geom/Geometry.js\").default} geometry The candidate geometry.\n * @param {Array<TraceTarget>} targets The trace targets.\n */\nfunction appendGeometryTraceTargets(coordinate, geometry, targets) {\n  if (geometry instanceof LineString) {\n    appendTraceTarget(coordinate, geometry.getCoordinates(), false, targets);\n    return;\n  }\n  if (geometry instanceof MultiLineString) {\n    const coordinates = geometry.getCoordinates();\n    for (let i = 0, ii = coordinates.length; i < ii; ++i) {\n      appendTraceTarget(coordinate, coordinates[i], false, targets);\n    }\n    return;\n  }\n  if (geometry instanceof Polygon) {\n    const coordinates = geometry.getCoordinates();\n    for (let i = 0, ii = coordinates.length; i < ii; ++i) {\n      appendTraceTarget(coordinate, coordinates[i], true, targets);\n    }\n    return;\n  }\n  if (geometry instanceof MultiPolygon) {\n    const polys = geometry.getCoordinates();\n    for (let i = 0, ii = polys.length; i < ii; ++i) {\n      const coordinates = polys[i];\n      for (let j = 0, jj = coordinates.length; j < jj; ++j) {\n        appendTraceTarget(coordinate, coordinates[j], true, targets);\n      }\n    }\n    return;\n  }\n  if (geometry instanceof GeometryCollection) {\n    const geometries = geometry.getGeometries();\n    for (let i = 0; i < geometries.length; ++i) {\n      appendGeometryTraceTargets(coordinate, geometries[i], targets);\n    }\n    return;\n  }\n  // other types cannot be traced\n}\n\n/**\n * @param {import(\"../coordinate.js\").Coordinate} coordinate The clicked coordinate.\n * @param {Array<import(\"../coordinate.js\").Coordinate>} coordinates The geometry component coordinates.\n * @param {boolean} ring The coordinates represent a linear ring.\n * @param {Array<TraceTarget>} targets The trace targets.\n */\nfunction appendTraceTarget(coordinate, coordinates, ring, targets) {\n  const x = coordinate[0];\n  const y = coordinate[1];\n  for (let i = 0, ii = coordinates.length - 1; i < ii; ++i) {\n    const start = coordinates[i];\n    const end = coordinates[i + 1];\n    const rel = getPointSegmentRelationship(x, y, start, end);\n    if (rel.squaredDistance === 0) {\n      const index = i + rel.along;\n      targets.push({\n        coordinates: coordinates,\n        ring: ring,\n        startIndex: index,\n        endIndex: index,\n      });\n      return;\n    }\n  }\n}\n\n/**\n * @param {import(\"../coordinate.js\").Coordinate} a One coordinate.\n * @param {import(\"../coordinate.js\").Coordinate} b Another coordinate.\n * @return {number} The squared distance between the two coordinates.\n */\nfunction getSquaredDistance(a, b) {\n  return squaredDistance(a[0], a[1], b[0], b[1]);\n}\n\n/**\n * Get the cumulative squared distance along a ring path.  The end index index may be \"wrapped\" and it may\n * be less than the start index to indicate the direction of travel.  The start and end index may have\n * a fractional part to indicate a point between two coordinates.\n * @param {LineCoordType} coordinates Ring coordinates.\n * @param {number} startIndex The start index.\n * @param {number} endIndex The end index.\n * @return {number} The cumulative squared distance along the ring path.\n */\nfunction getCumulativeSquaredDistance(coordinates, startIndex, endIndex) {\n  let lowIndex, highIndex;\n  if (startIndex < endIndex) {\n    lowIndex = startIndex;\n    highIndex = endIndex;\n  } else {\n    lowIndex = endIndex;\n    highIndex = startIndex;\n  }\n  const lowWholeIndex = Math.ceil(lowIndex);\n  const highWholeIndex = Math.floor(highIndex);\n\n  if (lowWholeIndex > highWholeIndex) {\n    // both start and end are on the same segment\n    const start = interpolateCoordinate(coordinates, lowIndex);\n    const end = interpolateCoordinate(coordinates, highIndex);\n    return getSquaredDistance(start, end);\n  }\n\n  let sd = 0;\n\n  if (lowIndex < lowWholeIndex) {\n    const start = interpolateCoordinate(coordinates, lowIndex);\n    const end = getCoordinate(coordinates, lowWholeIndex);\n    sd += getSquaredDistance(start, end);\n  }\n\n  if (highWholeIndex < highIndex) {\n    const start = getCoordinate(coordinates, highWholeIndex);\n    const end = interpolateCoordinate(coordinates, highIndex);\n    sd += getSquaredDistance(start, end);\n  }\n\n  for (let i = lowWholeIndex; i < highWholeIndex - 1; ++i) {\n    const start = getCoordinate(coordinates, i);\n    const end = getCoordinate(coordinates, i + 1);\n    sd += getSquaredDistance(start, end);\n  }\n\n  return sd;\n}\n\n/**\n * @typedef {Object} PointSegmentRelationship\n * @property {number} along The closest point expressed as a fraction along the segment length.\n * @property {number} squaredDistance The squared distance of the point to the segment.\n */\n\n/**\n * @type {PointSegmentRelationship}\n */\nconst sharedRel = {along: 0, squaredDistance: 0};\n\n/**\n * @param {number} x The point x.\n * @param {number} y The point y.\n * @param {import(\"../coordinate.js\").Coordinate} start The segment start.\n * @param {import(\"../coordinate.js\").Coordinate} end The segment end.\n * @return {PointSegmentRelationship} The point segment relationship.  The returned object is\n * shared between calls and must not be modified by the caller.\n */\nexport function getPointSegmentRelationship(x, y, start, end) {\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  let along = 0;\n  let px = x1;\n  let py = y1;\n  if (dx !== 0 || dy !== 0) {\n    along = clamp(((x - x1) * dx + (y - y1) * dy) / (dx * dx + dy * dy), 0, 1);\n    px += dx * along;\n    py += dy * along;\n  }\n\n  sharedRel.along = along;\n  sharedRel.squaredDistance = toFixed(squaredDistance(x, y, px, py), 10);\n  return sharedRel;\n}\n","/**\n * @module ol/interaction/Draw\n */\nimport Feature from '../Feature.js';\nimport MapBrowserEvent from '../MapBrowserEvent.js';\nimport MapBrowserEventType from '../MapBrowserEventType.js';\nimport {\n  distance,\n  squaredDistance as squaredCoordinateDistance,\n} from '../coordinate.js';\nimport Event from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport {\n  always,\n  never,\n  noModifierKeys,\n  shiftKeyOnly,\n} from '../events/condition.js';\nimport {\n  boundingExtent,\n  getBottomLeft,\n  getBottomRight,\n  getTopLeft,\n  getTopRight,\n} from '../extent.js';\nimport {FALSE, TRUE} from '../functions.js';\nimport Circle from '../geom/Circle.js';\nimport LineString from '../geom/LineString.js';\nimport MultiLineString from '../geom/MultiLineString.js';\nimport MultiPoint from '../geom/MultiPoint.js';\nimport MultiPolygon from '../geom/MultiPolygon.js';\nimport Point from '../geom/Point.js';\nimport Polygon, {fromCircle, makeRegular} from '../geom/Polygon.js';\nimport {getStrideForLayout} from '../geom/SimpleGeometry.js';\nimport VectorLayer from '../layer/Vector.js';\nimport {fromUserCoordinate, getUserProjection} from '../proj.js';\nimport VectorSource from '../source/Vector.js';\nimport {createEditingStyle} from '../style/Style.js';\nimport PointerInteraction from './Pointer.js';\nimport InteractionProperty from './Property.js';\nimport {\n  getCoordinate,\n  getTraceTargetUpdate,\n  getTraceTargets,\n  interpolateCoordinate,\n} from './tracing.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../geom/Geometry.js\").Type} type Geometry type of\n * the geometries being drawn with this instance.\n * @property {number} [clickTolerance=6] The maximum distance in pixels between\n * \"down\" and \"up\" for a \"up\" event to be considered a \"click\" event and\n * actually add a point/vertex to the geometry being drawn.  The default of `6`\n * was chosen for the draw interaction to behave correctly on mouse as well as\n * on touch devices.\n * @property {import(\"../Collection.js\").default<Feature>} [features]\n * Destination collection for the drawn features.\n * @property {VectorSource} [source] Destination source for\n * the drawn features.\n * @property {number} [dragVertexDelay=500] Delay in milliseconds after pointerdown\n * before the current vertex can be dragged to its exact position.\n * @property {number} [snapTolerance=12] Pixel distance for snapping to the\n * drawing finish. Must be greater than `0`.\n * @property {boolean} [stopClick=false] Stop click, singleclick, and\n * doubleclick events from firing during drawing.\n * @property {number} [maxPoints] The number of points that can be drawn before\n * a polygon ring or line string is finished. By default there is no\n * restriction.\n * @property {number} [minPoints] The number of points that must be drawn\n * before a polygon ring or line string can be finished. Default is `3` for\n * polygon rings and `2` for line strings.\n * @property {import(\"../events/condition.js\").Condition} [finishCondition] A function\n * that takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * boolean to indicate whether the drawing can be finished. Not used when drawing\n * POINT or MULTI_POINT geometries.\n * @property {import(\"../style/Style.js\").StyleLike|import(\"../style/flat.js\").FlatStyleLike} [style]\n * Style for sketch features. The draw interaction can have up to three sketch features, depending on the mode.\n * It will always contain a feature with a `Point` geometry that corresponds to the current cursor position.\n * If the mode is `LineString` or `Polygon`, and there is at least one drawn point, it will also contain a feature with\n * a `LineString` geometry that corresponds to the line between the already drawn points and the current cursor position.\n * If the mode is `Polygon`, and there is at least one drawn point, it will also contain a feature with a `Polygon`\n * geometry that corresponds to the polygon between the already drawn points and the current cursor position\n * (note that this polygon has only two points if only one point is drawn).\n * If the mode is `Circle`, and there is one point drawn, it will also contain a feature with a `Circle` geometry whose\n * center is the drawn point and the radius is determined by the distance between the drawn point and the cursor.\n * @property {GeometryFunction} [geometryFunction]\n * Function that is called when a geometry's coordinates are updated.\n * @property {string} [geometryName] Geometry name to use for features created\n * by the draw interaction.\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 * By default {@link module:ol/events/condition.noModifierKeys}, i.e. a click,\n * adds a vertex or deactivates freehand drawing.\n * @property {boolean} [freehand=false] Operate in freehand mode for lines,\n * polygons, and circles.  This makes the interaction always operate in freehand\n * mode and takes precedence over any `freehandCondition` option.\n * @property {import(\"../events/condition.js\").Condition} [freehandCondition]\n * Condition that activates freehand drawing for lines and polygons. This\n * function takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and\n * returns a boolean to indicate whether that event should be handled. The\n * default is {@link module:ol/events/condition.shiftKeyOnly}, meaning that the\n * Shift key activates freehand drawing.\n * @property {boolean|import(\"../events/condition.js\").Condition} [trace=false] Trace a portion of another geometry.\n * Ignored when in freehand mode.\n * @property {VectorSource} [traceSource] Source for features to trace.  If tracing is active and a `traceSource` is\n * not provided, the interaction's `source` will be used.  Tracing requires that the interaction is configured with\n * either a `traceSource` or a `source`.\n * @property {boolean} [wrapX=false] Wrap the world horizontally on the sketch\n * overlay.\n * @property {import(\"../geom/Geometry.js\").GeometryLayout} [geometryLayout='XY'] Layout of the\n * feature geometries created by the draw interaction.\n */\n\n/**\n * Coordinate type when drawing points.\n * @typedef {import(\"../coordinate.js\").Coordinate} PointCoordType\n */\n\n/**\n * @typedef {import('./tracing.js').LineCoordType} LineCoordType\n */\n\n/**\n * Coordinate type when drawing polygons.\n * @typedef {Array<Array<import(\"../coordinate.js\").Coordinate>>} PolyCoordType\n */\n\n/**\n * Types used for drawing coordinates.\n * @typedef {PointCoordType|LineCoordType|PolyCoordType} SketchCoordType\n */\n\n/** @typedef {import('./tracing.js').TraceState} TraceState */\n\n/** @typedef {import('./tracing.js').TraceTarget} TraceTarget */\n\n/**\n * Function that takes an array of coordinates and an optional existing geometry\n * and a projection as arguments, and returns a geometry. The optional existing\n * geometry is the geometry that is returned when the function is called without\n * a second argument.\n * @typedef {function(!SketchCoordType, import(\"../geom/SimpleGeometry.js\").default,\n *     import(\"../proj/Projection.js\").default):\n *     import(\"../geom/SimpleGeometry.js\").default} GeometryFunction\n */\n\n/**\n * @typedef {'Point' | 'LineString' | 'Polygon' | 'Circle'} Mode\n * Draw mode.  This collapses multi-part geometry types with their single-part\n * cousins.\n */\n\n/**\n * @enum {string}\n */\nconst DrawEventType = {\n  /**\n   * Triggered upon feature draw start\n   * @event DrawEvent#drawstart\n   * @api\n   */\n  DRAWSTART: 'drawstart',\n  /**\n   * Triggered upon feature draw end\n   * @event DrawEvent#drawend\n   * @api\n   */\n  DRAWEND: 'drawend',\n  /**\n   * Triggered upon feature draw abortion\n   * @event DrawEvent#drawabort\n   * @api\n   */\n  DRAWABORT: 'drawabort',\n};\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/interaction/Draw~Draw} instances are\n * instances of this type.\n */\nexport class DrawEvent extends Event {\n  /**\n   * @param {DrawEventType} type Type.\n   * @param {Feature} feature The feature drawn.\n   */\n  constructor(type, feature) {\n    super(type);\n\n    /**\n     * The feature being drawn.\n     * @type {Feature}\n     * @api\n     */\n    this.feature = feature;\n  }\n}\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types|\n *     'change:active', import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<'drawabort'|'drawend'|'drawstart', DrawEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"../ObjectEventType.js\").Types|\n *     'change:active'|'drawabort'|'drawend'|'drawstart', Return>} DrawOnSignature\n */\n\n/**\n * @classdesc\n * Interaction for drawing feature geometries.\n *\n * @fires DrawEvent\n * @api\n */\nclass Draw extends PointerInteraction {\n  /**\n   * @param {Options} options Options.\n   */\n  constructor(options) {\n    const pointerOptions = /** @type {import(\"./Pointer.js\").Options} */ (\n      options\n    );\n    if (!pointerOptions.stopDown) {\n      pointerOptions.stopDown = FALSE;\n    }\n\n    super(pointerOptions);\n\n    /***\n     * @type {DrawOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {DrawOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {DrawOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @type {Options}\n     * @private\n     */\n    this.options_ = options;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.shouldHandle_ = false;\n\n    /**\n     * @type {import(\"../pixel.js\").Pixel}\n     * @private\n     */\n    this.downPx_ = null;\n\n    /**\n     * @type {ReturnType<typeof setTimeout>}\n     * @private\n     */\n    this.downTimeout_;\n\n    /**\n     * @type {number|undefined}\n     * @private\n     */\n    this.lastDragTime_;\n\n    /**\n     * Pointer type of the last pointermove event\n     * @type {string}\n     * @private\n     */\n    this.pointerType_;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.freehand_ = false;\n\n    /**\n     * Target source for drawn features.\n     * @type {VectorSource|null}\n     * @private\n     */\n    this.source_ = options.source ? options.source : null;\n\n    /**\n     * Target collection for drawn features.\n     * @type {import(\"../Collection.js\").default<Feature>|null}\n     * @private\n     */\n    this.features_ = options.features ? options.features : null;\n\n    /**\n     * Pixel distance for snapping.\n     * @type {number}\n     * @private\n     */\n    this.snapTolerance_ = options.snapTolerance ? options.snapTolerance : 12;\n\n    /**\n     * Geometry type.\n     * @type {import(\"../geom/Geometry.js\").Type}\n     * @private\n     */\n    this.type_ = /** @type {import(\"../geom/Geometry.js\").Type} */ (\n      options.type\n    );\n\n    /**\n     * Drawing mode (derived from geometry type.\n     * @type {Mode}\n     * @private\n     */\n    this.mode_ = getMode(this.type_);\n\n    /**\n     * Stop click, singleclick, and doubleclick events from firing during drawing.\n     * Default is `false`.\n     * @type {boolean}\n     * @private\n     */\n    this.stopClick_ = !!options.stopClick;\n\n    /**\n     * Ignore the next up event. This is set to `true` when a drag event is encountered,\n     * e.g. when the user pans the map while drawing. In this case, we do not want to bail\n     * out of tracing.\n     * @type {boolean}\n     * @private\n     */\n    this.ignoreNextUpEvent_ = false;\n\n    /**\n     * The number of points that must be drawn before a polygon ring or line\n     * string can be finished.  The default is 3 for polygon rings and 2 for\n     * line strings.\n     * @type {number}\n     * @private\n     */\n    this.minPoints_ = options.minPoints\n      ? options.minPoints\n      : this.mode_ === 'Polygon'\n        ? 3\n        : 2;\n\n    /**\n     * The number of points that can be drawn before a polygon ring or line string\n     * is finished. The default is no restriction.\n     * @type {number}\n     * @private\n     */\n    this.maxPoints_ =\n      this.mode_ === 'Circle'\n        ? 2\n        : options.maxPoints\n          ? options.maxPoints\n          : Infinity;\n\n    /**\n     * A function to decide if a potential finish coordinate is permissible\n     * @private\n     * @type {import(\"../events/condition.js\").Condition}\n     */\n    this.finishCondition_ = options.finishCondition\n      ? options.finishCondition\n      : TRUE;\n\n    /**\n     * @private\n     * @type {import(\"../geom/Geometry.js\").GeometryLayout}\n     */\n    this.geometryLayout_ = options.geometryLayout\n      ? options.geometryLayout\n      : 'XY';\n\n    let geometryFunction = options.geometryFunction;\n    if (!geometryFunction) {\n      const mode = this.mode_;\n      if (mode === 'Circle') {\n        /**\n         * @param {!LineCoordType} coordinates The coordinates.\n         * @param {import(\"../geom/SimpleGeometry.js\").default|undefined} geometry Optional geometry.\n         * @param {import(\"../proj/Projection.js\").default} projection The view projection.\n         * @return {import(\"../geom/SimpleGeometry.js\").default} A geometry.\n         */\n        geometryFunction = (coordinates, geometry, projection) => {\n          const circle = geometry\n            ? /** @type {Circle} */ (geometry)\n            : new Circle([NaN, NaN]);\n          const center = fromUserCoordinate(coordinates[0], projection);\n          const squaredLength = squaredCoordinateDistance(\n            center,\n            fromUserCoordinate(coordinates[coordinates.length - 1], projection),\n          );\n          circle.setCenterAndRadius(\n            center,\n            Math.sqrt(squaredLength),\n            this.geometryLayout_,\n          );\n          const userProjection = getUserProjection();\n          if (userProjection) {\n            circle.transform(projection, userProjection);\n          }\n          return circle;\n        };\n      } else {\n        let Constructor;\n        if (mode === 'Point') {\n          Constructor = Point;\n        } else if (mode === 'LineString') {\n          Constructor = LineString;\n        } else if (mode === 'Polygon') {\n          Constructor = Polygon;\n        }\n        /**\n         * @param {!LineCoordType} coordinates The coordinates.\n         * @param {import(\"../geom/SimpleGeometry.js\").default|undefined} geometry Optional geometry.\n         * @param {import(\"../proj/Projection.js\").default} projection The view projection.\n         * @return {import(\"../geom/SimpleGeometry.js\").default} A geometry.\n         */\n        geometryFunction = (coordinates, geometry, projection) => {\n          if (geometry) {\n            if (mode === 'Polygon') {\n              if (coordinates[0].length) {\n                // Add a closing coordinate to match the first\n                geometry.setCoordinates(\n                  [coordinates[0].concat([coordinates[0][0]])],\n                  this.geometryLayout_,\n                );\n              } else {\n                geometry.setCoordinates([], this.geometryLayout_);\n              }\n            } else {\n              geometry.setCoordinates(coordinates, this.geometryLayout_);\n            }\n          } else {\n            geometry = new Constructor(coordinates, this.geometryLayout_);\n          }\n          return geometry;\n        };\n      }\n    }\n\n    /**\n     * @type {GeometryFunction}\n     * @private\n     */\n    this.geometryFunction_ = geometryFunction;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.dragVertexDelay_ =\n      options.dragVertexDelay !== undefined ? options.dragVertexDelay : 500;\n\n    /**\n     * Finish coordinate for the feature (first point for polygons, last point for\n     * linestrings).\n     * @type {import(\"../coordinate.js\").Coordinate}\n     * @private\n     */\n    this.finishCoordinate_ = null;\n\n    /**\n     * Sketch feature.\n     * @type {Feature<import('../geom/SimpleGeometry.js').default>}\n     * @private\n     */\n    this.sketchFeature_ = null;\n\n    /**\n     * Sketch point.\n     * @type {Feature<Point>}\n     * @private\n     */\n    this.sketchPoint_ = null;\n\n    /**\n     * Sketch coordinates. Used when drawing a line or polygon.\n     * @type {SketchCoordType}\n     * @private\n     */\n    this.sketchCoords_ = null;\n\n    /**\n     * Sketch line. Used when drawing polygon.\n     * @type {Feature<LineString>}\n     * @private\n     */\n    this.sketchLine_ = null;\n\n    /**\n     * Sketch line coordinates. Used when drawing a polygon or circle.\n     * @type {LineCoordType}\n     * @private\n     */\n    this.sketchLineCoords_ = null;\n\n    /**\n     * Squared tolerance for handling up events.  If the squared distance\n     * between a down and up event is greater than this tolerance, up events\n     * will not be handled.\n     * @type {number}\n     * @private\n     */\n    this.squaredClickTolerance_ = options.clickTolerance\n      ? options.clickTolerance * options.clickTolerance\n      : 36;\n\n    /**\n     * Draw overlay where our sketch features are drawn.\n     * @type {VectorLayer}\n     * @private\n     */\n    this.overlay_ = new VectorLayer({\n      source: new VectorSource({\n        useSpatialIndex: false,\n        wrapX: options.wrapX ? options.wrapX : false,\n      }),\n      style: options.style ? options.style : getDefaultStyleFunction(),\n      updateWhileInteracting: true,\n    });\n\n    /**\n     * Name of the geometry attribute for newly created features.\n     * @type {string|undefined}\n     * @private\n     */\n    this.geometryName_ = options.geometryName;\n\n    /**\n     * @private\n     * @type {import(\"../events/condition.js\").Condition}\n     */\n    this.condition_ = options.condition ? options.condition : noModifierKeys;\n\n    /**\n     * @private\n     * @type {import(\"../events/condition.js\").Condition}\n     */\n    this.freehandCondition_;\n    if (options.freehand) {\n      this.freehandCondition_ = always;\n    } else {\n      this.freehandCondition_ = options.freehandCondition\n        ? options.freehandCondition\n        : shiftKeyOnly;\n    }\n\n    /**\n     * @type {import(\"../events/condition.js\").Condition}\n     * @private\n     */\n    this.traceCondition_;\n    this.setTrace(options.trace || false);\n\n    /**\n     * @type {TraceState}\n     * @private\n     */\n    this.traceState_ = {active: false};\n\n    /**\n     * @type {VectorSource|null}\n     * @private\n     */\n    this.traceSource_ = options.traceSource || options.source || null;\n\n    this.addChangeListener(InteractionProperty.ACTIVE, this.updateState_);\n  }\n\n  /**\n   * Toggle tracing mode or set a tracing condition.\n   *\n   * @param {boolean|import(\"../events/condition.js\").Condition} trace A boolean to toggle tracing mode or an event\n   *     condition that will be checked when a feature is clicked to determine if tracing should be active.\n   */\n  setTrace(trace) {\n    let condition;\n    if (!trace) {\n      condition = never;\n    } else if (trace === true) {\n      condition = always;\n    } else {\n      condition = trace;\n    }\n    this.traceCondition_ = condition;\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} map Map.\n   * @override\n   */\n  setMap(map) {\n    super.setMap(map);\n    this.updateState_();\n  }\n\n  /**\n   * Set whether the drawing is done in freehand mode.\n   *\n   * @param {boolean} freehand Freehand drawing.\n   * @api\n   */\n  setFreehand(freehand) {\n    this.freehand_ = freehand;\n    if (this.freehand_) {\n      this.freehandCondition_ = always;\n    } else {\n      this.freehandCondition_ =\n        this.options_ && this.options_.freehandCondition\n          ? this.options_.freehandCondition\n          : shiftKeyOnly;\n    }\n  }\n\n  /**\n   * Get the overlay layer that this interaction renders sketch features to.\n   * @return {VectorLayer} Overlay layer.\n   * @api\n   */\n  getOverlay() {\n    return this.overlay_;\n  }\n\n  /**\n   * Get if this interaction is in freehand mode.\n   * @return {boolean} Freehand drawing.\n   * @api\n   */\n  getFreehand() {\n    return this.freehand_;\n  }\n\n  /**\n   * Handles the {@link module:ol/MapBrowserEvent~MapBrowserEvent map browser event} and may actually draw or finish the drawing.\n   * @param {import(\"../MapBrowserEvent.js\").default<PointerEvent>} event Map browser event.\n   * @return {boolean} `false` to stop event propagation.\n   * @api\n   * @override\n   */\n  handleEvent(event) {\n    if (event.originalEvent.type === EventType.CONTEXTMENU) {\n      // Avoid context menu for long taps when drawing on mobile\n      event.originalEvent.preventDefault();\n    }\n    this.freehand_ = this.mode_ !== 'Point' && this.freehandCondition_(event);\n    let move = event.type === MapBrowserEventType.POINTERMOVE;\n    let pass = true;\n    if (\n      !this.freehand_ &&\n      this.lastDragTime_ &&\n      event.type === MapBrowserEventType.POINTERDRAG\n    ) {\n      const now = Date.now();\n      if (now - this.lastDragTime_ >= this.dragVertexDelay_) {\n        this.downPx_ = event.pixel;\n        this.shouldHandle_ = !this.freehand_;\n        move = true;\n      } else {\n        this.lastDragTime_ = undefined;\n      }\n      if (this.shouldHandle_ && this.downTimeout_ !== undefined) {\n        clearTimeout(this.downTimeout_);\n        this.downTimeout_ = undefined;\n      }\n    }\n    if (\n      this.freehand_ &&\n      event.type === MapBrowserEventType.POINTERDRAG &&\n      this.sketchFeature_ !== null\n    ) {\n      this.addToDrawing_(event.coordinate);\n      pass = false;\n    } else if (\n      this.freehand_ &&\n      event.type === MapBrowserEventType.POINTERDOWN\n    ) {\n      pass = false;\n    } else if (move && this.getPointerCount() < 2) {\n      pass = event.type === MapBrowserEventType.POINTERMOVE;\n      if (pass && this.freehand_) {\n        this.handlePointerMove_(event);\n        if (this.shouldHandle_) {\n          // Avoid page scrolling when freehand drawing on mobile\n          event.originalEvent.preventDefault();\n        }\n      } else if (\n        event.originalEvent.pointerType === 'mouse' ||\n        (event.type === MapBrowserEventType.POINTERDRAG &&\n          this.downTimeout_ === undefined)\n      ) {\n        this.handlePointerMove_(event);\n      }\n    } else if (event.type === MapBrowserEventType.DBLCLICK) {\n      pass = false;\n    }\n\n    return super.handleEvent(event) && pass;\n  }\n\n  /**\n   * Handle pointer down events.\n   * @param {import(\"../MapBrowserEvent.js\").default<PointerEvent>} event Event.\n   * @return {boolean} If the event was consumed.\n   * @override\n   */\n  handleDownEvent(event) {\n    this.shouldHandle_ = !this.freehand_;\n\n    if (this.freehand_) {\n      this.downPx_ = event.pixel;\n      if (!this.finishCoordinate_) {\n        this.startDrawing_(event.coordinate);\n      }\n      return true;\n    }\n\n    if (!this.condition_(event)) {\n      this.lastDragTime_ = undefined;\n      return false;\n    }\n\n    this.lastDragTime_ = Date.now();\n    this.downTimeout_ = setTimeout(() => {\n      this.handlePointerMove_(\n        new MapBrowserEvent(\n          MapBrowserEventType.POINTERMOVE,\n          event.map,\n          event.originalEvent,\n          false,\n          event.frameState,\n        ),\n      );\n    }, this.dragVertexDelay_);\n    this.downPx_ = event.pixel;\n    return true;\n  }\n\n  /**\n   * @private\n   */\n  deactivateTrace_() {\n    this.traceState_ = {active: false};\n  }\n\n  /**\n   * Activate or deactivate trace state based on a browser event.\n   * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n   * @private\n   */\n  toggleTraceState_(event) {\n    if (!this.traceSource_ || !this.traceCondition_(event)) {\n      return;\n    }\n\n    if (this.traceState_.active) {\n      this.deactivateTrace_();\n      return;\n    }\n\n    const map = this.getMap();\n    const lowerLeft = map.getCoordinateFromPixel([\n      event.pixel[0] - this.snapTolerance_,\n      event.pixel[1] + this.snapTolerance_,\n    ]);\n    const upperRight = map.getCoordinateFromPixel([\n      event.pixel[0] + this.snapTolerance_,\n      event.pixel[1] - this.snapTolerance_,\n    ]);\n    const extent = boundingExtent([lowerLeft, upperRight]);\n    const features = this.traceSource_.getFeaturesInExtent(extent);\n    if (features.length === 0) {\n      return;\n    }\n\n    const targets = getTraceTargets(event.coordinate, features);\n    if (targets.length) {\n      this.traceState_ = {\n        active: true,\n        startCoord: event.coordinate.slice(),\n        targets: targets,\n        targetIndex: -1,\n      };\n    }\n  }\n\n  /**\n   * @param {TraceTarget} target The trace target.\n   * @param {number} endIndex The new end index of the trace.\n   * @private\n   */\n  addOrRemoveTracedCoordinates_(target, endIndex) {\n    // three cases to handle:\n    //  1. traced in the same direction and points need adding\n    //  2. traced in the same direction and points need removing\n    //  3. traced in a new direction\n    const previouslyForward = target.startIndex <= target.endIndex;\n    const currentlyForward = target.startIndex <= endIndex;\n    if (previouslyForward === currentlyForward) {\n      // same direction\n      if (\n        (previouslyForward && endIndex > target.endIndex) ||\n        (!previouslyForward && endIndex < target.endIndex)\n      ) {\n        // case 1 - add new points\n        this.addTracedCoordinates_(target, target.endIndex, endIndex);\n      } else if (\n        (previouslyForward && endIndex < target.endIndex) ||\n        (!previouslyForward && endIndex > target.endIndex)\n      ) {\n        // case 2 - remove old points\n        this.removeTracedCoordinates_(endIndex, target.endIndex);\n      }\n    } else {\n      // case 3 - remove old points, add new points\n      this.removeTracedCoordinates_(target.startIndex, target.endIndex);\n      this.addTracedCoordinates_(target, target.startIndex, endIndex);\n    }\n  }\n\n  /**\n   * @param {number} fromIndex The start index.\n   * @param {number} toIndex The end index.\n   * @private\n   */\n  removeTracedCoordinates_(fromIndex, toIndex) {\n    if (fromIndex === toIndex) {\n      return;\n    }\n\n    let remove = 0;\n    if (fromIndex < toIndex) {\n      const start = Math.ceil(fromIndex);\n      let end = Math.floor(toIndex);\n      if (end === toIndex) {\n        end -= 1;\n      }\n      remove = end - start + 1;\n    } else {\n      const start = Math.floor(fromIndex);\n      let end = Math.ceil(toIndex);\n      if (end === toIndex) {\n        end += 1;\n      }\n      remove = start - end + 1;\n    }\n\n    if (remove > 0) {\n      this.removeLastPoints_(remove);\n    }\n  }\n\n  /**\n   * @param {TraceTarget} target The trace target.\n   * @param {number} fromIndex The start index.\n   * @param {number} toIndex The end index.\n   * @private\n   */\n  addTracedCoordinates_(target, fromIndex, toIndex) {\n    if (fromIndex === toIndex) {\n      return;\n    }\n\n    const coordinates = [];\n    if (fromIndex < toIndex) {\n      // forward trace\n      const start = Math.ceil(fromIndex);\n      let end = Math.floor(toIndex);\n      if (end === toIndex) {\n        // if end is snapped to a vertex, it will be added later\n        end -= 1;\n      }\n      for (let i = start; i <= end; ++i) {\n        coordinates.push(getCoordinate(target.coordinates, i));\n      }\n    } else {\n      // reverse trace\n      const start = Math.floor(fromIndex);\n      let end = Math.ceil(toIndex);\n      if (end === toIndex) {\n        end += 1;\n      }\n      for (let i = start; i >= end; --i) {\n        coordinates.push(getCoordinate(target.coordinates, i));\n      }\n    }\n    if (coordinates.length) {\n      this.appendCoordinates(coordinates);\n    }\n  }\n\n  /**\n   * Update the trace.\n   * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n   * @private\n   */\n  updateTrace_(event) {\n    const traceState = this.traceState_;\n    if (!traceState.active) {\n      return;\n    }\n\n    if (traceState.targetIndex === -1) {\n      // check if we are ready to pick a target\n      const startPx = event.map.getPixelFromCoordinate(traceState.startCoord);\n      if (distance(startPx, event.pixel) < this.snapTolerance_) {\n        return;\n      }\n    }\n\n    const updatedTraceTarget = getTraceTargetUpdate(\n      event.coordinate,\n      traceState,\n      this.getMap(),\n      this.snapTolerance_,\n    );\n\n    if (traceState.targetIndex !== updatedTraceTarget.index) {\n      // target changed\n      if (traceState.targetIndex !== -1) {\n        // remove points added during previous trace\n        const oldTarget = traceState.targets[traceState.targetIndex];\n        this.removeTracedCoordinates_(oldTarget.startIndex, oldTarget.endIndex);\n      }\n      // add points for the new target\n      const newTarget = traceState.targets[updatedTraceTarget.index];\n      this.addTracedCoordinates_(\n        newTarget,\n        newTarget.startIndex,\n        updatedTraceTarget.endIndex,\n      );\n    } else {\n      // target stayed the same\n      const target = traceState.targets[traceState.targetIndex];\n      this.addOrRemoveTracedCoordinates_(target, updatedTraceTarget.endIndex);\n    }\n\n    // modify the state with updated info\n    traceState.targetIndex = updatedTraceTarget.index;\n    const target = traceState.targets[traceState.targetIndex];\n    target.endIndex = updatedTraceTarget.endIndex;\n\n    // update event coordinate and pixel to match end point of final segment\n    const coordinate = interpolateCoordinate(\n      target.coordinates,\n      target.endIndex,\n    );\n    const pixel = this.getMap().getPixelFromCoordinate(coordinate);\n    event.coordinate = coordinate;\n    event.pixel = [Math.round(pixel[0]), Math.round(pixel[1])];\n  }\n\n  /**\n   * Handle drag events.\n   * @param {import(\"../MapBrowserEvent.js\").default<PointerEvent>} event Event.\n   * @override\n   */\n  handleDragEvent(event) {\n    this.ignoreNextUpEvent_ = true;\n    super.handleDragEvent(event);\n  }\n\n  /**\n   * Handle pointer up events.\n   * @param {import(\"../MapBrowserEvent.js\").default<PointerEvent>} event Event.\n   * @return {boolean} If the event was consumed.\n   * @override\n   */\n  handleUpEvent(event) {\n    let pass = true;\n\n    if (this.getPointerCount() === 0) {\n      if (this.downTimeout_) {\n        clearTimeout(this.downTimeout_);\n        this.downTimeout_ = undefined;\n      }\n\n      this.handlePointerMove_(event);\n      const tracing = this.traceState_.active;\n      if (!this.ignoreNextUpEvent_) {\n        this.toggleTraceState_(event);\n      }\n\n      if (this.shouldHandle_) {\n        const startingToDraw = !this.finishCoordinate_;\n        if (startingToDraw) {\n          this.startDrawing_(event.coordinate);\n        }\n        if (!startingToDraw && this.freehand_) {\n          this.finishDrawing();\n        } else if (\n          !this.freehand_ &&\n          (!startingToDraw || this.mode_ === 'Point')\n        ) {\n          if (this.atFinish_(event.pixel, tracing)) {\n            if (this.finishCondition_(event)) {\n              this.finishDrawing();\n            }\n          } else {\n            this.addToDrawing_(event.coordinate);\n          }\n        }\n        pass = false;\n      } else if (this.freehand_) {\n        this.abortDrawing();\n      }\n    }\n    this.ignoreNextUpEvent_ = false;\n\n    if (!pass && this.stopClick_) {\n      event.preventDefault();\n    }\n    return pass;\n  }\n\n  /**\n   * Handle move events.\n   * @param {import(\"../MapBrowserEvent.js\").default<PointerEvent>} event A move event.\n   * @private\n   */\n  handlePointerMove_(event) {\n    this.pointerType_ = event.originalEvent.pointerType;\n    if (\n      this.downPx_ &&\n      ((!this.freehand_ && this.shouldHandle_) ||\n        (this.freehand_ && !this.shouldHandle_))\n    ) {\n      const downPx = this.downPx_;\n      const clickPx = event.pixel;\n      const dx = downPx[0] - clickPx[0];\n      const dy = downPx[1] - clickPx[1];\n      const squaredDistance = dx * dx + dy * dy;\n      this.shouldHandle_ = this.freehand_\n        ? squaredDistance > this.squaredClickTolerance_\n        : squaredDistance <= this.squaredClickTolerance_;\n      if (!this.shouldHandle_) {\n        return;\n      }\n    }\n\n    if (!this.finishCoordinate_) {\n      this.createOrUpdateSketchPoint_(event.coordinate.slice());\n      return;\n    }\n\n    this.updateTrace_(event);\n    this.modifyDrawing_(event.coordinate);\n  }\n\n  /**\n   * Determine if an event is within the snapping tolerance of the start coord.\n   * @param {import(\"../pixel.js\").Pixel} pixel Pixel.\n   * @param {boolean} [tracing] Drawing in trace mode (only stop if at the starting point).\n   * @return {boolean} The event is within the snapping tolerance of the start.\n   * @private\n   */\n  atFinish_(pixel, tracing) {\n    let at = false;\n    if (this.sketchFeature_) {\n      let potentiallyDone = false;\n      let potentiallyFinishCoordinates = [this.finishCoordinate_];\n      const mode = this.mode_;\n      if (mode === 'Point') {\n        at = true;\n      } else if (mode === 'Circle') {\n        at = this.sketchCoords_.length === 2;\n      } else if (mode === 'LineString') {\n        potentiallyDone =\n          !tracing && this.sketchCoords_.length > this.minPoints_;\n      } else if (mode === 'Polygon') {\n        const sketchCoords = /** @type {PolyCoordType} */ (this.sketchCoords_);\n        potentiallyDone = sketchCoords[0].length > this.minPoints_;\n        potentiallyFinishCoordinates = [\n          sketchCoords[0][0],\n          sketchCoords[0][sketchCoords[0].length - 2],\n        ];\n        if (tracing) {\n          potentiallyFinishCoordinates = [sketchCoords[0][0]];\n        } else {\n          potentiallyFinishCoordinates = [\n            sketchCoords[0][0],\n            sketchCoords[0][sketchCoords[0].length - 2],\n          ];\n        }\n      }\n      if (potentiallyDone) {\n        const map = this.getMap();\n        for (let i = 0, ii = potentiallyFinishCoordinates.length; i < ii; i++) {\n          const finishCoordinate = potentiallyFinishCoordinates[i];\n          const finishPixel = map.getPixelFromCoordinate(finishCoordinate);\n          const dx = pixel[0] - finishPixel[0];\n          const dy = pixel[1] - finishPixel[1];\n          const snapTolerance = this.freehand_ ? 1 : this.snapTolerance_;\n          at = Math.sqrt(dx * dx + dy * dy) <= snapTolerance;\n          if (at) {\n            this.finishCoordinate_ = finishCoordinate;\n            break;\n          }\n        }\n      }\n    }\n    return at;\n  }\n\n  /**\n   * @param {import(\"../coordinate.js\").Coordinate} coordinates Coordinate.\n   * @private\n   */\n  createOrUpdateSketchPoint_(coordinates) {\n    if (!this.sketchPoint_) {\n      this.sketchPoint_ = new Feature(new Point(coordinates));\n      this.updateSketchFeatures_();\n    } else {\n      const sketchPointGeom = this.sketchPoint_.getGeometry();\n      sketchPointGeom.setCoordinates(coordinates);\n    }\n  }\n\n  /**\n   * @param {import(\"../geom/Polygon.js\").default} geometry Polygon geometry.\n   * @private\n   */\n  createOrUpdateCustomSketchLine_(geometry) {\n    if (!this.sketchLine_) {\n      this.sketchLine_ = new Feature();\n    }\n    const ring = geometry.getLinearRing(0);\n    let sketchLineGeom = this.sketchLine_.getGeometry();\n    if (!sketchLineGeom) {\n      sketchLineGeom = new LineString(\n        ring.getFlatCoordinates(),\n        ring.getLayout(),\n      );\n      this.sketchLine_.setGeometry(sketchLineGeom);\n    } else {\n      sketchLineGeom.setFlatCoordinates(\n        ring.getLayout(),\n        ring.getFlatCoordinates(),\n      );\n      sketchLineGeom.changed();\n    }\n  }\n\n  /**\n   * Start the drawing.\n   * @param {import(\"../coordinate.js\").Coordinate} start Start coordinate.\n   * @private\n   */\n  startDrawing_(start) {\n    const projection = this.getMap().getView().getProjection();\n    const stride = getStrideForLayout(this.geometryLayout_);\n    while (start.length < stride) {\n      start.push(0);\n    }\n    this.finishCoordinate_ = start;\n    if (this.mode_ === 'Point') {\n      this.sketchCoords_ = start.slice();\n    } else if (this.mode_ === 'Polygon') {\n      this.sketchCoords_ = [[start.slice(), start.slice()]];\n      this.sketchLineCoords_ = this.sketchCoords_[0];\n    } else {\n      this.sketchCoords_ = [start.slice(), start.slice()];\n    }\n    if (this.sketchLineCoords_) {\n      this.sketchLine_ = new Feature(new LineString(this.sketchLineCoords_));\n    }\n    const geometry = this.geometryFunction_(\n      this.sketchCoords_,\n      undefined,\n      projection,\n    );\n    this.sketchFeature_ = new Feature();\n    if (this.geometryName_) {\n      this.sketchFeature_.setGeometryName(this.geometryName_);\n    }\n    this.sketchFeature_.setGeometry(geometry);\n    this.updateSketchFeatures_();\n    this.dispatchEvent(\n      new DrawEvent(DrawEventType.DRAWSTART, this.sketchFeature_),\n    );\n  }\n\n  /**\n   * Modify the drawing.\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @private\n   */\n  modifyDrawing_(coordinate) {\n    const map = this.getMap();\n    const geometry = this.sketchFeature_.getGeometry();\n    const projection = map.getView().getProjection();\n    const stride = getStrideForLayout(this.geometryLayout_);\n    let coordinates, last;\n    while (coordinate.length < stride) {\n      coordinate.push(0);\n    }\n    if (this.mode_ === 'Point') {\n      last = this.sketchCoords_;\n    } else if (this.mode_ === 'Polygon') {\n      coordinates = /** @type {PolyCoordType} */ (this.sketchCoords_)[0];\n      last = coordinates[coordinates.length - 1];\n      if (this.atFinish_(map.getPixelFromCoordinate(coordinate))) {\n        // snap to finish\n        coordinate = this.finishCoordinate_.slice();\n      }\n    } else {\n      coordinates = this.sketchCoords_;\n      last = coordinates[coordinates.length - 1];\n    }\n    last[0] = coordinate[0];\n    last[1] = coordinate[1];\n    this.geometryFunction_(\n      /** @type {!LineCoordType} */ (this.sketchCoords_),\n      geometry,\n      projection,\n    );\n    if (this.sketchPoint_) {\n      const sketchPointGeom = this.sketchPoint_.getGeometry();\n      sketchPointGeom.setCoordinates(coordinate);\n    }\n    if (geometry.getType() === 'Polygon' && this.mode_ !== 'Polygon') {\n      this.createOrUpdateCustomSketchLine_(/** @type {Polygon} */ (geometry));\n    } else if (this.sketchLineCoords_) {\n      const sketchLineGeom = this.sketchLine_.getGeometry();\n      sketchLineGeom.setCoordinates(this.sketchLineCoords_);\n    }\n    this.updateSketchFeatures_();\n  }\n\n  /**\n   * Add a new coordinate to the drawing.\n   * @param {!PointCoordType} coordinate Coordinate\n   * @return {Feature<import(\"../geom/SimpleGeometry.js\").default>} The sketch feature.\n   * @private\n   */\n  addToDrawing_(coordinate) {\n    const geometry = this.sketchFeature_.getGeometry();\n    const projection = this.getMap().getView().getProjection();\n    let done;\n    let coordinates;\n    const mode = this.mode_;\n    if (mode === 'LineString' || mode === 'Circle') {\n      this.finishCoordinate_ = coordinate.slice();\n      coordinates = /** @type {LineCoordType} */ (this.sketchCoords_);\n      if (coordinates.length >= this.maxPoints_) {\n        if (this.freehand_) {\n          coordinates.pop();\n        } else {\n          done = true;\n        }\n      }\n      coordinates.push(coordinate.slice());\n      this.geometryFunction_(coordinates, geometry, projection);\n    } else if (mode === 'Polygon') {\n      coordinates = /** @type {PolyCoordType} */ (this.sketchCoords_)[0];\n      if (coordinates.length >= this.maxPoints_) {\n        if (this.freehand_) {\n          coordinates.pop();\n        } else {\n          done = true;\n        }\n      }\n      coordinates.push(coordinate.slice());\n      if (done) {\n        this.finishCoordinate_ = coordinates[0];\n      }\n      this.geometryFunction_(this.sketchCoords_, geometry, projection);\n    }\n    this.createOrUpdateSketchPoint_(coordinate.slice());\n    this.updateSketchFeatures_();\n    if (done) {\n      return this.finishDrawing();\n    }\n    return this.sketchFeature_;\n  }\n\n  /**\n   * @param {number} n The number of points to remove.\n   */\n  removeLastPoints_(n) {\n    if (!this.sketchFeature_) {\n      return;\n    }\n    const geometry = this.sketchFeature_.getGeometry();\n    const projection = this.getMap().getView().getProjection();\n    const mode = this.mode_;\n    for (let i = 0; i < n; ++i) {\n      let coordinates;\n      if (mode === 'LineString' || mode === 'Circle') {\n        coordinates = /** @type {LineCoordType} */ (this.sketchCoords_);\n        coordinates.splice(-2, 1);\n        if (coordinates.length >= 2) {\n          this.finishCoordinate_ = coordinates[coordinates.length - 2].slice();\n          const finishCoordinate = this.finishCoordinate_.slice();\n          coordinates[coordinates.length - 1] = finishCoordinate;\n          this.createOrUpdateSketchPoint_(finishCoordinate);\n        }\n        this.geometryFunction_(coordinates, geometry, projection);\n        if (geometry.getType() === 'Polygon' && this.sketchLine_) {\n          this.createOrUpdateCustomSketchLine_(\n            /** @type {Polygon} */ (geometry),\n          );\n        }\n      } else if (mode === 'Polygon') {\n        coordinates = /** @type {PolyCoordType} */ (this.sketchCoords_)[0];\n        coordinates.splice(-2, 1);\n        const sketchLineGeom = this.sketchLine_.getGeometry();\n        if (coordinates.length >= 2) {\n          const finishCoordinate = coordinates[coordinates.length - 2].slice();\n          coordinates[coordinates.length - 1] = finishCoordinate;\n          this.createOrUpdateSketchPoint_(finishCoordinate);\n        }\n        sketchLineGeom.setCoordinates(coordinates);\n        this.geometryFunction_(this.sketchCoords_, geometry, projection);\n      }\n\n      if (coordinates.length === 1) {\n        this.abortDrawing();\n        break;\n      }\n    }\n\n    this.updateSketchFeatures_();\n  }\n\n  /**\n   * Remove last point of the feature currently being drawn. Does not do anything when\n   * drawing POINT or MULTI_POINT geometries.\n   * @api\n   */\n  removeLastPoint() {\n    this.removeLastPoints_(1);\n  }\n\n  /**\n   * Stop drawing and add the sketch feature to the target layer.\n   * The {@link module:ol/interaction/Draw~DrawEventType.DRAWEND} event is\n   * dispatched before inserting the feature.\n   * @return {Feature<import(\"../geom/SimpleGeometry.js\").default>|null} The drawn feature.\n   * @api\n   */\n  finishDrawing() {\n    const sketchFeature = this.abortDrawing_();\n    if (!sketchFeature) {\n      return null;\n    }\n    let coordinates = this.sketchCoords_;\n    const geometry = sketchFeature.getGeometry();\n    const projection = this.getMap().getView().getProjection();\n    if (this.mode_ === 'LineString') {\n      // remove the redundant last point\n      coordinates.pop();\n      this.geometryFunction_(coordinates, geometry, projection);\n    } else if (this.mode_ === 'Polygon') {\n      // remove the redundant last point in ring\n      /** @type {PolyCoordType} */ (coordinates)[0].pop();\n      this.geometryFunction_(coordinates, geometry, projection);\n      coordinates = geometry.getCoordinates();\n    }\n\n    // cast multi-part geometries\n    if (this.type_ === 'MultiPoint') {\n      sketchFeature.setGeometry(\n        new MultiPoint([/** @type {PointCoordType} */ (coordinates)]),\n      );\n    } else if (this.type_ === 'MultiLineString') {\n      sketchFeature.setGeometry(\n        new MultiLineString([/** @type {LineCoordType} */ (coordinates)]),\n      );\n    } else if (this.type_ === 'MultiPolygon') {\n      sketchFeature.setGeometry(\n        new MultiPolygon([/** @type {PolyCoordType} */ (coordinates)]),\n      );\n    }\n\n    // First dispatch event to allow full set up of feature\n    this.dispatchEvent(new DrawEvent(DrawEventType.DRAWEND, sketchFeature));\n\n    // Then insert feature\n    if (this.features_) {\n      this.features_.push(sketchFeature);\n    }\n    if (this.source_) {\n      this.source_.addFeature(sketchFeature);\n    }\n    return sketchFeature;\n  }\n\n  /**\n   * Stop drawing without adding the sketch feature to the target layer.\n   * @return {Feature<import(\"../geom/SimpleGeometry.js\").default>|null} The sketch feature (or null if none).\n   * @private\n   */\n  abortDrawing_() {\n    this.finishCoordinate_ = null;\n    const sketchFeature = this.sketchFeature_;\n    this.sketchFeature_ = null;\n    this.sketchPoint_ = null;\n    this.sketchLine_ = null;\n    this.overlay_.getSource().clear(true);\n    this.deactivateTrace_();\n    return sketchFeature;\n  }\n\n  /**\n   * Stop drawing without adding the sketch feature to the target layer.\n   * @api\n   */\n  abortDrawing() {\n    const sketchFeature = this.abortDrawing_();\n    if (sketchFeature) {\n      this.dispatchEvent(new DrawEvent(DrawEventType.DRAWABORT, sketchFeature));\n    }\n  }\n\n  /**\n   * Append coordinates to the end of the geometry that is currently being drawn.\n   * This can be used when drawing LineStrings or Polygons. Coordinates will\n   * either be appended to the current LineString or the outer ring of the current\n   * Polygon. If no geometry is being drawn, a new one will be created.\n   * @param {!LineCoordType} coordinates Linear coordinates to be appended to\n   * the coordinate array.\n   * @api\n   */\n  appendCoordinates(coordinates) {\n    const mode = this.mode_;\n    const newDrawing = !this.sketchFeature_;\n    if (newDrawing) {\n      this.startDrawing_(coordinates[0]);\n    }\n    /** @type {LineCoordType} */\n    let sketchCoords;\n    if (mode === 'LineString' || mode === 'Circle') {\n      sketchCoords = /** @type {LineCoordType} */ (this.sketchCoords_);\n    } else if (mode === 'Polygon') {\n      sketchCoords =\n        this.sketchCoords_ && this.sketchCoords_.length\n          ? /** @type {PolyCoordType} */ (this.sketchCoords_)[0]\n          : [];\n    } else {\n      return;\n    }\n\n    if (newDrawing) {\n      sketchCoords.shift();\n    }\n\n    // Remove last coordinate from sketch drawing (this coordinate follows cursor position)\n    sketchCoords.pop();\n\n    // Append coordinate list\n    for (let i = 0; i < coordinates.length; i++) {\n      this.addToDrawing_(coordinates[i]);\n    }\n\n    const ending = coordinates[coordinates.length - 1];\n    // Duplicate last coordinate for sketch drawing (cursor position)\n    this.sketchFeature_ = this.addToDrawing_(ending);\n    this.modifyDrawing_(ending);\n  }\n\n  /**\n   * Initiate draw mode by starting from an existing geometry which will\n   * receive new additional points. This only works on features with\n   * `LineString` geometries, where the interaction will extend lines by adding\n   * points to the end of the coordinates array.\n   * This will change the original feature, instead of drawing a copy.\n   *\n   * The function will dispatch a `drawstart` event.\n   *\n   * @param {!Feature<LineString>} feature Feature to be extended.\n   * @api\n   */\n  extend(feature) {\n    const geometry = feature.getGeometry();\n    const lineString = geometry;\n    this.sketchFeature_ = feature;\n    this.sketchCoords_ = lineString.getCoordinates();\n    const last = this.sketchCoords_[this.sketchCoords_.length - 1];\n    this.finishCoordinate_ = last.slice();\n    this.sketchCoords_.push(last.slice());\n    this.sketchPoint_ = new Feature(new Point(last));\n    this.updateSketchFeatures_();\n    this.dispatchEvent(\n      new DrawEvent(DrawEventType.DRAWSTART, this.sketchFeature_),\n    );\n  }\n\n  /**\n   * Redraw the sketch features.\n   * @private\n   */\n  updateSketchFeatures_() {\n    const sketchFeatures = [];\n    if (this.sketchFeature_) {\n      sketchFeatures.push(this.sketchFeature_);\n    }\n    if (this.sketchLine_) {\n      sketchFeatures.push(this.sketchLine_);\n    }\n    if (this.sketchPoint_) {\n      sketchFeatures.push(this.sketchPoint_);\n    }\n    const overlaySource = this.overlay_.getSource();\n    overlaySource.clear(true);\n    overlaySource.addFeatures(sketchFeatures);\n  }\n\n  /**\n   * @private\n   */\n  updateState_() {\n    const map = this.getMap();\n    const active = this.getActive();\n    if (!map || !active) {\n      this.abortDrawing();\n    }\n    this.overlay_.setMap(active ? map : null);\n  }\n}\n\n/**\n * @return {import(\"../style/Style.js\").StyleFunction} Styles.\n */\nfunction getDefaultStyleFunction() {\n  const styles = createEditingStyle();\n  return function (feature, resolution) {\n    return styles[feature.getGeometry().getType()];\n  };\n}\n\n/**\n * Create a `geometryFunction` for `type: 'Circle'` that will create a regular\n * polygon with a user specified number of sides and start angle instead of a\n * {@link import(\"../geom/Circle.js\").Circle} geometry.\n * @param {number} [sides] Number of sides of the regular polygon.\n *     Default is 32.\n * @param {number} [angle] Angle of the first point in counter-clockwise\n *     radians. 0 means East.\n *     Default is the angle defined by the heading from the center of the\n *     regular polygon to the current pointer position.\n * @return {GeometryFunction} Function that draws a polygon.\n * @api\n */\nexport function createRegularPolygon(sides, angle) {\n  return function (coordinates, geometry, projection) {\n    const center = fromUserCoordinate(\n      /** @type {LineCoordType} */ (coordinates)[0],\n      projection,\n    );\n    const end = fromUserCoordinate(\n      /** @type {LineCoordType} */ (coordinates)[coordinates.length - 1],\n      projection,\n    );\n    const radius = Math.sqrt(squaredCoordinateDistance(center, end));\n    geometry = geometry || fromCircle(new Circle(center), sides);\n\n    let internalAngle = angle;\n    if (!angle && angle !== 0) {\n      const x = end[0] - center[0];\n      const y = end[1] - center[1];\n      internalAngle = Math.atan2(y, x);\n    }\n    makeRegular(\n      /** @type {Polygon} */ (geometry),\n      center,\n      radius,\n      internalAngle,\n    );\n\n    const userProjection = getUserProjection();\n    if (userProjection) {\n      geometry.transform(projection, userProjection);\n    }\n    return geometry;\n  };\n}\n\n/**\n * Create a `geometryFunction` that will create a box-shaped polygon (aligned\n * with the coordinate system axes).  Use this with the draw interaction and\n * `type: 'Circle'` to return a box instead of a circle geometry.\n * @return {GeometryFunction} Function that draws a box-shaped polygon.\n * @api\n */\nexport function createBox() {\n  return function (coordinates, geometry, projection) {\n    const extent = boundingExtent(\n      /** @type {LineCoordType} */ ([\n        coordinates[0],\n        coordinates[coordinates.length - 1],\n      ]).map(function (coordinate) {\n        return fromUserCoordinate(coordinate, projection);\n      }),\n    );\n    const boxCoordinates = [\n      [\n        getBottomLeft(extent),\n        getBottomRight(extent),\n        getTopRight(extent),\n        getTopLeft(extent),\n        getBottomLeft(extent),\n      ],\n    ];\n    if (geometry) {\n      geometry.setCoordinates(boxCoordinates);\n    } else {\n      geometry = new Polygon(boxCoordinates);\n    }\n    const userProjection = getUserProjection();\n    if (userProjection) {\n      geometry.transform(projection, userProjection);\n    }\n    return geometry;\n  };\n}\n\n/**\n * Get the drawing mode.  The mode for multi-part geometries is the same as for\n * their single-part cousins.\n * @param {import(\"../geom/Geometry.js\").Type} type Geometry type.\n * @return {Mode} Drawing mode.\n */\nfunction getMode(type) {\n  switch (type) {\n    case 'Point':\n    case 'MultiPoint':\n      return 'Point';\n    case 'LineString':\n    case 'MultiLineString':\n      return 'LineString';\n    case 'Polygon':\n    case 'MultiPolygon':\n      return 'Polygon';\n    case 'Circle':\n      return 'Circle';\n    default:\n      throw new Error('Invalid type: ' + type);\n  }\n}\n\nexport default Draw;\n","/**\n * @module ol/interaction/Extent\n */\nimport Feature from '../Feature.js';\nimport MapBrowserEventType from '../MapBrowserEventType.js';\nimport {\n  closestOnSegment,\n  distance as coordinateDistance,\n  squaredDistance as squaredCoordinateDistance,\n  squaredDistanceToSegment,\n} from '../coordinate.js';\nimport Event from '../events/Event.js';\nimport {always} from '../events/condition.js';\nimport {boundingExtent, containsCoordinate, getArea} from '../extent.js';\nimport Point from '../geom/Point.js';\nimport {fromExtent as polygonFromExtent} from '../geom/Polygon.js';\nimport VectorLayer from '../layer/Vector.js';\nimport {toUserExtent} from '../proj.js';\nimport VectorSource from '../source/Vector.js';\nimport {createEditingStyle} from '../style/Style.js';\nimport PointerInteraction from './Pointer.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.\n * Default is {@link module:ol/events/condition.always}.\n * @property {import(\"../events/condition.js\").Condition|null} [createCondition=null] A function that\n * takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * boolean to indicate whether that event should be handled to create a new extent.\n * If `null`, the `condition` will also be used as `createCondition`.\n * @property {boolean} [drag=false] An extent can be dragged.\n * @property {import(\"../extent.js\").Extent} [extent] Initial extent. Defaults to no\n * initial extent.\n * @property {import(\"../style/Style.js\").StyleLike} [boxStyle]\n * Style for the drawn extent box. Defaults to the `Polygon` editing style\n * documented in {@link module:ol/style/Style~Style}\n * @property {number} [pixelTolerance=10] Pixel tolerance for considering the\n * pointer close enough to a segment or vertex for editing.\n * @property {import(\"../style/Style.js\").StyleLike} [pointerStyle]\n * Style for the cursor used to draw the extent. Defaults to the `Point` editing style\n * documented in {@link module:ol/style/Style~Style}\n * @property {boolean} [wrapX=false] Wrap the drawn extent across multiple maps\n * in the X direction? Only affects visuals, not functionality.\n */\n\n/**\n * @enum {string}\n */\nconst ExtentEventType = {\n  /**\n   * Triggered after the extent is changed\n   * @event ExtentEvent#extentchanged\n   * @api\n   */\n  EXTENTCHANGED: 'extentchanged',\n};\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/interaction/Extent~Extent} instances are\n * instances of this type.\n */\nexport class ExtentEvent extends Event {\n  /**\n   * @param {import(\"../extent.js\").Extent} extent the new extent\n   */\n  constructor(extent) {\n    super(ExtentEventType.EXTENTCHANGED);\n\n    /**\n     * The current extent.\n     * @type {import(\"../extent.js\").Extent}\n     * @api\n     */\n    this.extent = extent;\n  }\n}\n\n/**\n * @typedef {function (import(\"../coordinate.js\").Coordinate): import(\"../extent.js\").Extent} PointerHandler\n */\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types|\n *     'change:active', import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<'extentchanged', ExtentEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"../ObjectEventType.js\").Types|\n *     'change:active'|'extentchanged', Return>} ExtentOnSignature\n */\n\n/**\n * @classdesc\n * Allows the user to draw a vector box by clicking and dragging on the map.\n * Once drawn, the vector box can be modified by dragging its vertices or edges.\n * The interaction can also be configured with an initial extent and a `createCondition`\n * to prevent the creation of a new extent on `pointerdown`, if desired.\n *\n * @fires ExtentEvent\n * @api\n */\nclass Extent extends PointerInteraction {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options || {};\n\n    super(/** @type {import(\"./Pointer.js\").Options} */ (options));\n\n    /***\n     * @type {ExtentOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {ExtentOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {ExtentOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * Condition\n     * @type {import(\"../events/condition.js\").Condition}\n     * @private\n     */\n    this.condition_ = options.condition ? options.condition : always;\n\n    /**\n     * @type {import(\"../events/condition.js\").Condition}\n     * @private\n     */\n    this.createCondition_ = options.createCondition || this.condition_;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.drag_ = options.drag || false;\n\n    /**\n     * Extent of the drawn box\n     * @type {import(\"../extent.js\").Extent}\n     * @private\n     */\n    this.extent_ = null;\n\n    /**\n     * Handler for pointer move events\n     * @type {PointerHandler|null}\n     * @private\n     */\n    this.pointerHandler_ = null;\n\n    /**\n     * Pixel threshold to snap to extent\n     * @type {number}\n     * @private\n     */\n    this.pixelTolerance_ =\n      options.pixelTolerance !== undefined ? options.pixelTolerance : 10;\n\n    /**\n     * Is the pointer snapped to an extent vertex\n     * @type {boolean}\n     * @private\n     */\n    this.snappedToVertex_ = false;\n\n    /**\n     * Feature for displaying the visible extent\n     * @type {Feature}\n     * @private\n     */\n    this.extentFeature_ = null;\n\n    /**\n     * Feature for displaying the visible pointer\n     * @type {Feature<Point>}\n     * @private\n     */\n    this.vertexFeature_ = null;\n\n    if (!options) {\n      options = {};\n    }\n\n    /**\n     * Layer for the extentFeature\n     * @type {VectorLayer}\n     * @private\n     */\n    this.extentOverlay_ = new VectorLayer({\n      source: new VectorSource({\n        useSpatialIndex: false,\n        wrapX: !!options.wrapX,\n      }),\n      style: options.boxStyle\n        ? options.boxStyle\n        : getDefaultExtentStyleFunction(),\n      updateWhileAnimating: true,\n      updateWhileInteracting: true,\n    });\n\n    /**\n     * Layer for the vertexFeature\n     * @type {VectorLayer}\n     * @private\n     */\n    this.vertexOverlay_ = new VectorLayer({\n      source: new VectorSource({\n        useSpatialIndex: false,\n        wrapX: !!options.wrapX,\n      }),\n      style: options.pointerStyle\n        ? options.pointerStyle\n        : getDefaultPointerStyleFunction(),\n      updateWhileAnimating: true,\n      updateWhileInteracting: true,\n    });\n\n    if (options.extent) {\n      this.setExtent(options.extent);\n    }\n  }\n\n  /**\n   * @param {import(\"../pixel.js\").Pixel} pixel cursor location\n   * @param {import(\"../Map.js\").default} map map\n   * @return {import(\"../coordinate.js\").Coordinate|null} snapped vertex on extent\n   * @private\n   */\n  snapToVertex_(pixel, map) {\n    const pixelCoordinate = map.getCoordinateFromPixelInternal(pixel);\n    const sortByDistance = function (a, b) {\n      return (\n        squaredDistanceToSegment(pixelCoordinate, a) -\n        squaredDistanceToSegment(pixelCoordinate, b)\n      );\n    };\n    const extent = this.getExtentInternal();\n    if (extent) {\n      //convert extents to line segments and find the segment closest to pixelCoordinate\n      const segments = getSegments(extent);\n      segments.sort(sortByDistance);\n      const closestSegment = segments[0];\n\n      let vertex = closestOnSegment(pixelCoordinate, closestSegment);\n      const vertexPixel = map.getPixelFromCoordinateInternal(vertex);\n\n      //if the distance is within tolerance, snap to the segment\n      if (coordinateDistance(pixel, vertexPixel) <= this.pixelTolerance_) {\n        //test if we should further snap to a vertex\n        const pixel1 = map.getPixelFromCoordinateInternal(closestSegment[0]);\n        const pixel2 = map.getPixelFromCoordinateInternal(closestSegment[1]);\n        const squaredDist1 = squaredCoordinateDistance(vertexPixel, pixel1);\n        const squaredDist2 = squaredCoordinateDistance(vertexPixel, pixel2);\n        const dist = Math.sqrt(Math.min(squaredDist1, squaredDist2));\n        this.snappedToVertex_ = dist <= this.pixelTolerance_;\n        if (this.snappedToVertex_) {\n          vertex =\n            squaredDist1 > squaredDist2 ? closestSegment[1] : closestSegment[0];\n        }\n        return vertex;\n      }\n    }\n    return null;\n  }\n\n  /**\n   * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent pointer move event\n   * @return {boolean} The event was handled.\n   * @private\n   */\n  handlePointerMove_(mapBrowserEvent) {\n    const pixel = mapBrowserEvent.pixel;\n    const map = mapBrowserEvent.map;\n    const draggable =\n      this.drag_ &&\n      containsCoordinate(this.extent_, mapBrowserEvent.coordinate);\n\n    let vertex = this.snapToVertex_(pixel, map);\n    if (!vertex && this.createCondition_(mapBrowserEvent) && !draggable) {\n      vertex = map.getCoordinateFromPixelInternal(pixel);\n    }\n    if (draggable && !vertex) {\n      this.getMap().getViewport().classList.add('ol-grab');\n    } else {\n      this.getMap().getViewport().classList.remove('ol-grab');\n    }\n    if (vertex) {\n      this.updatePointerFeature_(vertex);\n      return true;\n    }\n    this.noVertexFeature_();\n    return false;\n  }\n\n  /**\n   * @param {import(\"../extent.js\").Extent} extent extent\n   * @return {Feature} extent as featrue\n   * @private\n   */\n  createOrUpdateExtentFeature_(extent) {\n    let extentFeature = this.extentFeature_;\n\n    if (!extentFeature) {\n      if (!extent) {\n        extentFeature = new Feature({});\n      } else {\n        extentFeature = new Feature(polygonFromExtent(extent));\n      }\n      this.extentFeature_ = extentFeature;\n      this.extentOverlay_.getSource().addFeature(extentFeature);\n    } else {\n      if (!extent) {\n        extentFeature.setGeometry(undefined);\n      } else {\n        extentFeature.setGeometry(polygonFromExtent(extent));\n      }\n    }\n    return extentFeature;\n  }\n\n  /**\n   * @param {import(\"../coordinate.js\").Coordinate} vertex location of feature\n   * @param {boolean} [createIfNotExists] create the feature if it does not exist\n   * @return {Feature} vertex as feature\n   * @private\n   */\n  updatePointerFeature_(vertex, createIfNotExists = true) {\n    let vertexFeature = this.vertexFeature_;\n    if (createIfNotExists && !vertexFeature) {\n      vertexFeature = new Feature(new Point(vertex));\n      this.vertexFeature_ = vertexFeature;\n      this.vertexOverlay_.getSource().addFeature(vertexFeature);\n    }\n    if (vertexFeature) {\n      const geometry = vertexFeature.getGeometry();\n      geometry.setCoordinates(vertex);\n    }\n    return vertexFeature;\n  }\n\n  /**\n   * Remove the vertex feature if it exists.\n   * @private\n   */\n  noVertexFeature_() {\n    if (this.vertexFeature_) {\n      this.vertexOverlay_.getSource().removeFeature(this.vertexFeature_);\n      this.vertexFeature_ = null;\n    }\n  }\n\n  /**\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 (!mapBrowserEvent.originalEvent || !this.condition_(mapBrowserEvent)) {\n      this.noVertexFeature_();\n      return true;\n    }\n\n    let handled = this.handlingDownUpSequence;\n\n    //display pointer (if not dragging)\n    if (\n      mapBrowserEvent.type == MapBrowserEventType.POINTERMOVE &&\n      !this.handlingDownUpSequence\n    ) {\n      handled = this.handlePointerMove_(mapBrowserEvent);\n    }\n    //call pointer to determine up/down/drag\n    super.handleEvent(mapBrowserEvent);\n    //return false to stop propagation\n    return !handled;\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    const pixel = mapBrowserEvent.pixel;\n    const map = mapBrowserEvent.map;\n\n    const extent = this.getExtentInternal();\n    let vertex = this.snapToVertex_(pixel, map);\n\n    //find the extent corner opposite the passed corner\n    const getOpposingPoint = function (point) {\n      let x_ = null;\n      let y_ = null;\n      if (point[0] == extent[0]) {\n        x_ = extent[2];\n      } else if (point[0] == extent[2]) {\n        x_ = extent[0];\n      }\n      if (point[1] == extent[1]) {\n        y_ = extent[3];\n      } else if (point[1] == extent[3]) {\n        y_ = extent[1];\n      }\n      if (x_ !== null && y_ !== null) {\n        return [x_, y_];\n      }\n      return null;\n    };\n    if (vertex && extent) {\n      const x =\n        vertex[0] == extent[0] || vertex[0] == extent[2] ? vertex[0] : null;\n      const y =\n        vertex[1] == extent[1] || vertex[1] == extent[3] ? vertex[1] : null;\n\n      //snap to point\n      if (x !== null && y !== null) {\n        this.pointerHandler_ = getPointHandler(getOpposingPoint(vertex));\n        //snap to edge\n      } else if (x !== null) {\n        this.pointerHandler_ = getEdgeHandler(\n          getOpposingPoint([x, extent[1]]),\n          getOpposingPoint([x, extent[3]]),\n        );\n      } else if (y !== null) {\n        this.pointerHandler_ = getEdgeHandler(\n          getOpposingPoint([extent[0], y]),\n          getOpposingPoint([extent[2], y]),\n        );\n      }\n      //no snap - new bbox or dragging existing bbox\n    } else {\n      vertex = map.getCoordinateFromPixelInternal(pixel);\n      let drag = false;\n      if (this.drag_) {\n        if (containsCoordinate(extent, vertex)) {\n          this.pointerHandler_ = getDragHandler(extent, vertex);\n          drag = true;\n        }\n      }\n      if (!drag && this.createCondition_(mapBrowserEvent)) {\n        this.setExtent([vertex[0], vertex[1], vertex[0], vertex[1]]);\n        this.pointerHandler_ = getPointHandler(vertex);\n      }\n    }\n    return !!this.pointerHandler_; //event handled; start downup sequence\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.pointerHandler_) {\n      const pixelCoordinate = mapBrowserEvent.coordinate;\n      this.setExtent(this.pointerHandler_(pixelCoordinate));\n      this.updatePointerFeature_(pixelCoordinate, false);\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    this.pointerHandler_ = null;\n    //If bbox is zero area, set to null;\n    const extent = this.getExtentInternal();\n    if (!extent || getArea(extent) === 0) {\n      this.setExtent(null);\n    }\n    return false; //Stop handling downup sequence\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} map Map.\n   * @override\n   */\n  setMap(map) {\n    this.extentOverlay_.setMap(map);\n    this.vertexOverlay_.setMap(map);\n    super.setMap(map);\n  }\n\n  /**\n   * Returns the current drawn extent in the view projection (or user projection if set)\n   *\n   * @return {import(\"../extent.js\").Extent} Drawn extent in the view projection.\n   * @api\n   */\n  getExtent() {\n    return toUserExtent(\n      this.getExtentInternal(),\n      this.getMap().getView().getProjection(),\n    );\n  }\n\n  /**\n   * Returns the current drawn extent in the view projection\n   *\n   * @return {import(\"../extent.js\").Extent} Drawn extent in the view projection.\n   * @api\n   * @deprecated Use {@link module:ol/interaction/Extent~Extent#getExtent} instead.\n   */\n  getExtentInternal() {\n    return this.extent_;\n  }\n\n  /**\n   * Manually sets the drawn extent, using the view projection.\n   *\n   * @param {import(\"../extent.js\").Extent} extent Extent\n   * @api\n   */\n  setExtent(extent) {\n    //Null extent means no bbox\n    this.extent_ = extent ? extent : null;\n    this.createOrUpdateExtentFeature_(extent);\n    this.dispatchEvent(new ExtentEvent(this.extent_));\n  }\n}\n\n/**\n * Returns the default style for the drawn bbox\n *\n * @return {import(\"../style/Style.js\").StyleFunction} Default Extent style\n */\nfunction getDefaultExtentStyleFunction() {\n  const style = createEditingStyle();\n  return function (feature, resolution) {\n    return style['Polygon'];\n  };\n}\n\n/**\n * Returns the default style for the pointer\n *\n * @return {import(\"../style/Style.js\").StyleFunction} Default pointer style\n */\nfunction getDefaultPointerStyleFunction() {\n  const style = createEditingStyle();\n  return function (feature, resolution) {\n    return style['Point'];\n  };\n}\n\n/**\n * @param {import(\"../coordinate.js\").Coordinate} fixedPoint corner that will be unchanged in the new extent\n * @return {function (import(\"../coordinate.js\").Coordinate): import(\"../extent.js\").Extent} event handler\n */\nfunction getPointHandler(fixedPoint) {\n  return function (point) {\n    return boundingExtent([fixedPoint, point]);\n  };\n}\n\n/**\n * @param {import(\"../coordinate.js\").Coordinate} fixedP1 first corner that will be unchanged in the new extent\n * @param {import(\"../coordinate.js\").Coordinate} fixedP2 second corner that will be unchanged in the new extent\n * @return {PointerHandler|null} event handler\n */\nfunction getEdgeHandler(fixedP1, fixedP2) {\n  if (fixedP1[0] == fixedP2[0]) {\n    return function (point) {\n      return boundingExtent([fixedP1, [point[0], fixedP2[1]]]);\n    };\n  }\n  if (fixedP1[1] == fixedP2[1]) {\n    return function (point) {\n      return boundingExtent([fixedP1, [fixedP2[0], point[1]]]);\n    };\n  }\n  return null;\n}\n\n/**\n * @param {import(\"../extent.js\").Extent} extent The extent that will be dragged\n * @param {import(\"../coordinate.js\").Coordinate} vertex The vertex that drag delta is calculated from\n * @return {PointerHandler|null} event handler\n */\nfunction getDragHandler(extent, vertex) {\n  return function (point) {\n    const deltaX = point[0] - vertex[0];\n    const deltaY = point[1] - vertex[1];\n    return [\n      extent[0] + deltaX,\n      extent[1] + deltaY,\n      extent[2] + deltaX,\n      extent[3] + deltaY,\n    ];\n  };\n}\n\n/**\n * @param {import(\"../extent.js\").Extent} extent extent\n * @return {Array<Array<import(\"../coordinate.js\").Coordinate>>} extent line segments\n */\nfunction getSegments(extent) {\n  return [\n    [\n      [extent[0], extent[1]],\n      [extent[0], extent[3]],\n    ],\n    [\n      [extent[0], extent[3]],\n      [extent[2], extent[3]],\n    ],\n    [\n      [extent[2], extent[3]],\n      [extent[2], extent[1]],\n    ],\n    [\n      [extent[2], extent[1]],\n      [extent[0], extent[1]],\n    ],\n  ];\n}\n\nexport default Extent;\n","/**\n * @module ol/interaction/Link\n */\nimport MapEventType from '../MapEventType.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport EventType from '../events/EventType.js';\nimport {toFixed} from '../math.js';\nimport Interaction from './Interaction.js';\n\n/**\n * @param {number} number A number.\n * @return {number} A number with at most 5 decimal places.\n */\nfunction to5(number) {\n  return toFixed(number, 5);\n}\n\n/**\n * @param {string} string A string.\n * @return {number} A number representing the string.\n */\nfunction readNumber(string) {\n  return parseFloat(string);\n}\n\n/**\n * @param {number} number A number.\n * @return {string} A string representing the number.\n */\nfunction writeNumber(number) {\n  return to5(number).toString();\n}\n\n/**\n * @param {number} a A number.\n * @param {number} b A number.\n * @return {boolean} The numbers are different.\n */\nfunction differentNumber(a, b) {\n  if (isNaN(a)) {\n    return false;\n  }\n  return a !== readNumber(writeNumber(b));\n}\n\n/**\n * @param {Array<number>} a An array of two numbers.\n * @param {Array<number>} b An array of two numbers.\n * @return {boolean} The arrays are different.\n */\nfunction differentArray(a, b) {\n  return differentNumber(a[0], b[0]) || differentNumber(a[1], b[1]);\n}\n\n/** @typedef {'x'|'y'|'z'|'r'|'l'} Params */\n\n/**\n * @typedef {function(string):void} Callback\n */\n\n/**\n * @typedef {Object} Options\n * @property {boolean|import('../View.js').AnimationOptions} [animate=true] Animate view transitions.\n * @property {Array<Params>} [params=['x', 'y', 'z', 'r', 'l']] Properties to track. Default is to track\n * `x` (center x), `y` (center y), `z` (zoom), `r` (rotation) and `l` (layers).\n * @property {boolean} [replace=false] Replace the current URL without creating the new entry in browser history.\n * By default, changes in the map state result in a new entry being added to the browser history.\n * @property {string} [prefix=''] By default, the URL will be updated with search parameters x, y, z, and r.  To\n * avoid collisions with existing search parameters that your application uses, you can supply a custom prefix for\n * the ones used by this interaction (e.g. 'ol:').\n */\n\n/**\n * @classdesc\n * An interaction that synchronizes the map state with the URL.\n *\n * @api\n */\nclass Link extends Interaction {\n  /**\n   * @param {Options} [options] Link options.\n   */\n  constructor(options) {\n    super();\n\n    options = Object.assign(\n      {\n        animate: true,\n        params: ['x', 'y', 'z', 'r', 'l'],\n        replace: false,\n        prefix: '',\n      },\n      options || {},\n    );\n\n    let animationOptions;\n    if (options.animate === true) {\n      animationOptions = {duration: 250};\n    } else if (!options.animate) {\n      animationOptions = null;\n    } else {\n      animationOptions = options.animate;\n    }\n\n    /**\n     * @type {import('../View.js').AnimationOptions|null}\n     * @private\n     */\n    this.animationOptions_ = animationOptions;\n\n    /**\n     * @type {Object<Params, boolean>}\n     * @private\n     */\n    this.params_ = options.params.reduce((acc, value) => {\n      acc[value] = true;\n      return acc;\n    }, {});\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.replace_ = options.replace;\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.prefix_ = options.prefix;\n\n    /**\n     * @private\n     * @type {!Array<import(\"../events.js\").EventsKey>}\n     */\n    this.listenerKeys_ = [];\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.initial_ = true;\n\n    /**\n     * @private\n     */\n    this.updateState_ = this.updateState_.bind(this);\n\n    /**\n     * The tracked parameter callbacks.\n     * @private\n     * @type {Object<string, Callback>}\n     */\n    this.trackedCallbacks_ = {};\n\n    /**\n     * The tracked parameter values.\n     * @private\n     * @type {Object<string, string|null>}\n     */\n    this.trackedValues_ = {};\n  }\n\n  /**\n   * @private\n   * @param {string} name A parameter name.\n   * @return {string} A name with the prefix applied.\n   */\n  getParamName_(name) {\n    if (!this.prefix_) {\n      return name;\n    }\n    return this.prefix_ + name;\n  }\n\n  /**\n   * @private\n   * @param {URLSearchParams} params The search params.\n   * @param {string} name The unprefixed parameter name.\n   * @return {string|null} The parameter value.\n   */\n  get_(params, name) {\n    return params.get(this.getParamName_(name));\n  }\n\n  /**\n   * @private\n   * @param {URLSearchParams} params The search params.\n   * @param {string} name The unprefixed parameter name.\n   * @param {string} value The param value.\n   */\n  set_(params, name, value) {\n    if (!(name in this.params_)) {\n      return;\n    }\n    params.set(this.getParamName_(name), value);\n  }\n\n  /**\n   * @private\n   * @param {URLSearchParams} params The search params.\n   * @param {string} name The unprefixed parameter name.\n   */\n  delete_(params, name) {\n    if (!(name in this.params_)) {\n      return;\n    }\n    params.delete(this.getParamName_(name));\n  }\n\n  /**\n   * @param {import(\"../Map.js\").default|null} map Map.\n   * @override\n   */\n  setMap(map) {\n    const oldMap = this.getMap();\n    super.setMap(map);\n    if (map === oldMap) {\n      return;\n    }\n    if (oldMap) {\n      this.unregisterListeners_(oldMap);\n    }\n    if (map) {\n      this.initial_ = true;\n      this.updateState_();\n      this.registerListeners_(map);\n    }\n  }\n\n  /**\n   * @param {import(\"../Map.js\").default} map Map.\n   * @private\n   */\n  registerListeners_(map) {\n    this.listenerKeys_.push(\n      listen(map, MapEventType.MOVEEND, this.updateUrl_, this),\n      listen(map.getLayerGroup(), EventType.CHANGE, this.updateUrl_, this),\n      listen(map, 'change:layergroup', this.handleChangeLayerGroup_, this),\n    );\n\n    if (!this.replace_) {\n      addEventListener('popstate', this.updateState_);\n    }\n  }\n\n  /**\n   * @param {import(\"../Map.js\").default} map Map.\n   * @private\n   */\n  unregisterListeners_(map) {\n    for (let i = 0, ii = this.listenerKeys_.length; i < ii; ++i) {\n      unlistenByKey(this.listenerKeys_[i]);\n    }\n    this.listenerKeys_.length = 0;\n\n    if (!this.replace_) {\n      removeEventListener('popstate', this.updateState_);\n    }\n\n    const url = new URL(window.location.href);\n    const params = url.searchParams;\n    this.delete_(params, 'x');\n    this.delete_(params, 'y');\n    this.delete_(params, 'z');\n    this.delete_(params, 'r');\n    this.delete_(params, 'l');\n    window.history.replaceState(null, '', url);\n  }\n\n  /**\n   * @private\n   */\n  handleChangeLayerGroup_() {\n    const map = this.getMap();\n    if (!map) {\n      return;\n    }\n    this.unregisterListeners_(map);\n    this.registerListeners_(map);\n    this.initial_ = true;\n    this.updateUrl_();\n  }\n\n  /**\n   * @private\n   */\n  updateState_() {\n    const url = new URL(window.location.href);\n    const params = url.searchParams;\n    for (const key in this.trackedCallbacks_) {\n      const value = params.get(key);\n      if (key in this.trackedCallbacks_ && value !== this.trackedValues_[key]) {\n        this.trackedValues_[key] = value;\n        this.trackedCallbacks_[key](value);\n      }\n    }\n\n    const map = this.getMap();\n    if (!map) {\n      return;\n    }\n    const view = map.getView();\n    if (!view || !view.isDef()) {\n      return;\n    }\n\n    let updateView = false;\n\n    /**\n     * @type {import('../View.js').AnimationOptions}\n     */\n    const viewProperties = {};\n\n    const zoom = readNumber(this.get_(params, 'z'));\n    if ('z' in this.params_ && differentNumber(zoom, view.getZoom())) {\n      updateView = true;\n      viewProperties.zoom = zoom;\n    }\n\n    const rotation = readNumber(this.get_(params, 'r'));\n    if ('r' in this.params_ && differentNumber(rotation, view.getRotation())) {\n      updateView = true;\n      viewProperties.rotation = rotation;\n    }\n\n    const center = [\n      readNumber(this.get_(params, 'x')),\n      readNumber(this.get_(params, 'y')),\n    ];\n    if (\n      ('x' in this.params_ || 'y' in this.params_) &&\n      differentArray(center, view.getCenter())\n    ) {\n      updateView = true;\n      viewProperties.center = center;\n    }\n\n    if (updateView) {\n      if (!this.initial_ && this.animationOptions_) {\n        view.animate(Object.assign(viewProperties, this.animationOptions_));\n      } else {\n        if (viewProperties.center) {\n          view.setCenter(viewProperties.center);\n        }\n        if ('zoom' in viewProperties) {\n          view.setZoom(viewProperties.zoom);\n        }\n        if ('rotation' in viewProperties) {\n          view.setRotation(viewProperties.rotation);\n        }\n      }\n    }\n\n    const layers = map.getAllLayers();\n    const layersParam = this.get_(params, 'l');\n    if (\n      'l' in this.params_ &&\n      layersParam &&\n      layersParam.length === layers.length\n    ) {\n      for (let i = 0, ii = layers.length; i < ii; ++i) {\n        const value = parseInt(layersParam[i]);\n        if (!isNaN(value)) {\n          const visible = Boolean(value);\n          const layer = layers[i];\n          if (layer.getVisible() !== visible) {\n            layer.setVisible(visible);\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * Register a listener for a URL search parameter.  The callback will be called with a new value\n   * when the corresponding search parameter changes due to history events (e.g. browser navigation).\n   *\n   * @param {string} key The URL search parameter.\n   * @param {Callback} callback The function to call when the search parameter changes.\n   * @return {string|null} The initial value of the search parameter (or null if absent from the URL).\n   * @api\n   */\n  track(key, callback) {\n    this.trackedCallbacks_[key] = callback;\n    const url = new URL(window.location.href);\n    const params = url.searchParams;\n    const value = params.get(key);\n    this.trackedValues_[key] = value;\n    return value;\n  }\n\n  /**\n   * Update the URL with a new search parameter value.  If the value is null, it will be\n   * deleted from the search parameters.\n   *\n   * @param {string} key The URL search parameter.\n   * @param {string|null} value The updated value (or null to remove it from the URL).\n   * @api\n   */\n  update(key, value) {\n    const url = new URL(window.location.href);\n    const params = url.searchParams;\n    if (value === null) {\n      params.delete(key);\n    } else {\n      params.set(key, value);\n    }\n    if (key in this.trackedValues_) {\n      this.trackedValues_[key] = value;\n    }\n    this.updateHistory_(url);\n  }\n\n  /**\n   * @private\n   */\n  updateUrl_() {\n    const map = this.getMap();\n    if (!map) {\n      return;\n    }\n    const view = map.getView();\n    if (!view || !view.isDef()) {\n      return;\n    }\n\n    const center = view.getCenter();\n    const zoom = view.getZoom();\n    const rotation = view.getRotation();\n\n    const layers = map.getAllLayers();\n    const visibilities = new Array(layers.length);\n    for (let i = 0, ii = layers.length; i < ii; ++i) {\n      visibilities[i] = layers[i].getVisible() ? '1' : '0';\n    }\n\n    const url = new URL(window.location.href);\n    const params = url.searchParams;\n\n    this.set_(params, 'x', writeNumber(center[0]));\n    this.set_(params, 'y', writeNumber(center[1]));\n    this.set_(params, 'z', writeNumber(zoom));\n    this.set_(params, 'r', writeNumber(rotation));\n    this.set_(params, 'l', visibilities.join(''));\n\n    this.updateHistory_(url);\n    this.initial_ = false;\n  }\n\n  /**\n   * @private\n   * @param {URL} url The URL.\n   */\n  updateHistory_(url) {\n    if (url.href !== window.location.href) {\n      if (this.initial_ || this.replace_) {\n        window.history.replaceState(history.state, '', url);\n      } else {\n        window.history.pushState(null, '', url);\n      }\n    }\n  }\n}\n\nexport default Link;\n","/**\n * @module ol/interaction/Modify\n */\nimport Collection from '../Collection.js';\nimport CollectionEventType from '../CollectionEventType.js';\nimport Feature from '../Feature.js';\nimport MapBrowserEventType from '../MapBrowserEventType.js';\nimport ObjectEventType from '../ObjectEventType.js';\nimport {equals} from '../array.js';\nimport {\n  closestOnSegment,\n  distance as coordinateDistance,\n  equals as coordinatesEqual,\n  squaredDistance as squaredCoordinateDistance,\n  squaredDistanceToSegment,\n} from '../coordinate.js';\nimport Event from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport {\n  altKeyOnly,\n  always,\n  never,\n  primaryAction,\n  singleClick,\n} from '../events/condition.js';\nimport {\n  boundingExtent,\n  buffer as bufferExtent,\n  createOrUpdateFromCoordinate as createExtent,\n} from '../extent.js';\nimport Point from '../geom/Point.js';\nimport {fromCircle} from '../geom/Polygon.js';\nimport VectorLayer from '../layer/Vector.js';\nimport {\n  fromUserCoordinate,\n  fromUserExtent,\n  getUserProjection,\n  toUserCoordinate,\n  toUserExtent,\n} from '../proj.js';\nimport VectorSource from '../source/Vector.js';\nimport VectorEventType from '../source/VectorEventType.js';\nimport RBush from '../structs/RBush.js';\nimport {createEditingStyle} from '../style/Style.js';\nimport {getUid} from '../util.js';\nimport PointerInteraction from './Pointer.js';\nimport {\n  getCoordinate,\n  getTraceTargetUpdate,\n  getTraceTargets,\n} from './tracing.js';\n\n/**\n * The segment index assigned to a circle's center when\n * breaking up a circle into ModifySegmentDataType segments.\n * @type {number}\n */\nconst CIRCLE_CENTER_INDEX = 0;\n\n/**\n * The segment index assigned to a circle's circumference when\n * breaking up a circle into ModifySegmentDataType segments.\n * @type {number}\n */\nconst CIRCLE_CIRCUMFERENCE_INDEX = 1;\n\nconst tempExtent = [0, 0, 0, 0];\nconst tempSegment = [];\n\n/**\n * @enum {string}\n */\nconst ModifyEventType = {\n  /**\n   * Triggered upon feature modification start\n   * @event ModifyEvent#modifystart\n   * @api\n   */\n  MODIFYSTART: 'modifystart',\n  /**\n   * Triggered upon feature modification end\n   * @event ModifyEvent#modifyend\n   * @api\n   */\n  MODIFYEND: 'modifyend',\n};\n\n/**\n * @typedef {Object} SegmentData\n * @property {Array<number>} [depth] Depth.\n * @property {Feature} feature Feature.\n * @property {import(\"../geom/SimpleGeometry.js\").default} geometry Geometry.\n * @property {number} [index] Index.\n * @property {Array<Array<number>>} segment Segment.\n * @property {Array<SegmentData>} [featureSegments] FeatureSegments.\n */\n\n/**\n * A function that takes a {@link module:ol/Feature~Feature} and  returns `true` if\n * the feature may be modified or `false` otherwise.\n * @typedef {function(Feature):boolean} FilterFunction\n */\n\n/**\n * @typedef {[SegmentData, number]} DragSegment\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 will be considered to add or move a\n * vertex to the sketch. Default is\n * {@link module:ol/events/condition.primaryAction}.\n * @property {import(\"../events/condition.js\").Condition} [deleteCondition] A function\n * that takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * boolean to indicate whether that event should be handled. By default,\n * {@link module:ol/events/condition.singleClick} with\n * {@link module:ol/events/condition.altKeyOnly} results in a vertex deletion.\n * This combination is handled by wrapping the two condition checks in a single function:\n * ```js\n * import { altKeyOnly, singleClick } from 'ol/events/condition.js';\n *\n * function (event) {\n *   return altKeyOnly(event) && singleClick(event)\n * }\n * ```\n * @property {import(\"../events/condition.js\").Condition} [insertVertexCondition] A\n * function that takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and\n * returns a boolean to indicate whether a new vertex should be added to the sketch\n * features. Default is {@link module:ol/events/condition.always}.\n * @property {number} [pixelTolerance=10] Pixel tolerance for considering the\n * pointer close enough to a segment or vertex for editing.\n * @property {import(\"../style/Style.js\").StyleLike|import(\"../style/flat.js\").FlatStyleLike} [style]\n * Style used for the modification point or vertex. For linestrings and polygons, this will\n * be the affected vertex, for circles a point along the circle, and for points the actual\n * point. If not configured, the default edit style is used (see {@link module:ol/style/Style~Style}).\n * When using a style function, the point feature passed to the function will have an `existing` property -\n * indicating whether there is an existing vertex underneath or not, a `features`\n * property - an array whose entries are the features that are being modified, and a `geometries`\n * property - an array whose entries are the geometries that are being modified. Both arrays are\n * in the same order. The `geometries` are only useful when modifying geometry collections, where\n * the geometry will be the particular geometry from the collection that is being modified.\n * @property {VectorSource} [source] The vector source with\n * features to modify.  If a vector source is not provided, a feature collection\n * must be provided with the `features` option.\n * @property {boolean|import(\"../layer/BaseVector.js\").default} [hitDetection] When configured, point\n * features will be considered for modification based on their visual appearance, instead of being within\n * the `pixelTolerance` from the pointer location. When a {@link module:ol/layer/BaseVector~BaseVectorLayer} is\n * provided, only the rendered representation of the features on that layer will be considered.\n * @property {Collection<Feature>} [features]\n * The features the interaction works on.  If a feature collection is not\n * provided, a vector source must be provided with the `source` option.\n * @property {FilterFunction} [filter] A function that takes a {@link module:ol/Feature~Feature}\n * and returns `true` if the feature may be modified or `false` otherwise.\n * @property {boolean|import(\"../events/condition.js\").Condition} [trace=false] Trace a portion of another geometry.\n * Tracing starts when two neighboring vertices are dragged onto a trace target, without any other modification in between..\n * @property {VectorSource} [traceSource] Source for features to trace.  If tracing is active and a `traceSource` is\n * not provided, the interaction's `source` will be used.  Tracing requires that the interaction is configured with\n * either a `traceSource` or a `source`.\n * @property {boolean} [wrapX=false] Wrap the world horizontally on the sketch\n * overlay.\n * @property {boolean} [snapToPointer=!hitDetection] The vertex, point or segment being modified snaps to the\n * pointer coordinate when clicked within the `pixelTolerance`.\n * @property {function(import(\"../coordinate.js\").Coordinate, import(\"../coordinate.js\").Coordinate): boolean} [sharedVerticesEqual]\n * A function that takes two coordinates and returns whether they should be\n * considered equal for vertex matching purposes. By default, all coordinate\n * dimensions are compared. This is useful when features have mixed coordinate\n * dimensions (e.g., XY and XYZ) but should still be treated as sharing vertices\n * at the same 2D position.\n */\n\nfunction getCoordinatesArray(coordinates, geometryType, depth) {\n  let coordinatesArray;\n  switch (geometryType) {\n    case 'LineString':\n      coordinatesArray = coordinates;\n      break;\n    case 'MultiLineString':\n    case 'Polygon':\n      coordinatesArray = coordinates[depth[0]];\n      break;\n    case 'MultiPolygon':\n      coordinatesArray = coordinates[depth[1]][depth[0]];\n      break;\n    default:\n    // pass\n  }\n  return coordinatesArray;\n}\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/interaction/Modify~Modify} instances are\n * instances of this type.\n */\nexport class ModifyEvent extends Event {\n  /**\n   * @param {ModifyEventType} type Type.\n   * @param {Collection<Feature>} features\n   * The features modified.\n   * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent\n   * Associated {@link module:ol/MapBrowserEvent~MapBrowserEvent}.\n   */\n  constructor(type, features, mapBrowserEvent) {\n    super(type);\n\n    /**\n     * The features being modified.\n     * @type {Collection<Feature>}\n     * @api\n     */\n    this.features = features;\n\n    /**\n     * Associated {@link module:ol/MapBrowserEvent~MapBrowserEvent}.\n     * @type {import(\"../MapBrowserEvent.js\").default}\n     * @api\n     */\n    this.mapBrowserEvent = mapBrowserEvent;\n  }\n}\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types|\n *     'change:active', import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<'modifyend'|'modifystart', ModifyEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"../ObjectEventType.js\").Types|\n *     'change:active'|'modifyend'|'modifystart', Return>} ModifyOnSignature\n */\n\n/**\n * @classdesc\n * Interaction for modifying feature geometries.  To modify features that have\n * been added to an existing source, construct the modify interaction with the\n * `source` option.  If you want to modify features in a collection (for example,\n * the collection used by a select interaction), construct the interaction with\n * the `features` option.  The interaction must be constructed with either a\n * `source` or `features` option.\n *\n * Cartesian distance from the pointer is used to determine the features that\n * will be modified. This means that geometries will only be considered for\n * modification when they are within the configured `pixelTolerance`. For point\n * geometries, the `hitDetection` option can be used to match their visual\n * appearance.\n *\n * By default, the interaction will allow deletion of vertices when the `alt`\n * key is pressed.  To configure the interaction with a different condition\n * for deletion, use the `deleteCondition` option.\n * @fires ModifyEvent\n * @api\n */\nclass Modify extends PointerInteraction {\n  /**\n   * @param {Options} options Options.\n   */\n  constructor(options) {\n    super(/** @type {import(\"./Pointer.js\").Options} */ (options));\n\n    //Maintain a ref to event handlers for later unregistering\n    /** @private */\n    this.handleSourceAdd_ = this.handleSourceAdd_.bind(this);\n\n    /** @private */\n    this.handleSourceRemove_ = this.handleSourceRemove_.bind(this);\n\n    /** @private */\n    this.handleExternalCollectionAdd_ =\n      this.handleExternalCollectionAdd_.bind(this);\n\n    /** @private */\n    this.handleExternalCollectionRemove_ =\n      this.handleExternalCollectionRemove_.bind(this);\n\n    /** @private */\n    this.handleFeatureChange_ = this.handleFeatureChange_.bind(this);\n\n    /***\n     * @type {ModifyOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {ModifyOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {ModifyOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @private\n     * @type {import(\"../events/condition.js\").Condition}\n     */\n    this.condition_ = options.condition ? options.condition : primaryAction;\n\n    /**\n     * @private\n     * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Browser event.\n     * @return {boolean} Combined condition result.\n     */\n    this.defaultDeleteCondition_ = function (mapBrowserEvent) {\n      return altKeyOnly(mapBrowserEvent) && singleClick(mapBrowserEvent);\n    };\n\n    /**\n     * @type {import(\"../events/condition.js\").Condition}\n     * @private\n     */\n    this.deleteCondition_ = options.deleteCondition\n      ? options.deleteCondition\n      : this.defaultDeleteCondition_;\n\n    /**\n     * @type {import(\"../events/condition.js\").Condition}\n     * @private\n     */\n    this.insertVertexCondition_ = options.insertVertexCondition\n      ? options.insertVertexCondition\n      : always;\n\n    /**\n     * Editing vertex.\n     * @type {Feature<Point>}\n     * @private\n     */\n    this.vertexFeature_ = null;\n\n    /**\n     * Segments intersecting {@link this.vertexFeature_} by segment uid.\n     * @type {Object<string, boolean>}\n     * @private\n     */\n    this.vertexSegments_ = null;\n\n    /**\n     * @type {import(\"../coordinate.js\").Coordinate}\n     * @private\n     */\n    this.lastCoordinate_ = [0, 0];\n\n    /**\n     * Tracks if the next `singleclick` event should be ignored to prevent\n     * accidental deletion right after vertex creation.\n     * @type {boolean}\n     * @private\n     */\n    this.ignoreNextSingleClick_ = false;\n\n    /**\n     * @type {Collection<Feature>}\n     * @private\n     */\n    this.featuresBeingModified_ = null;\n\n    /**\n     * Segment RTree for each layer\n     * @type {RBush<SegmentData>}\n     * @private\n     */\n    this.rBush_ = new RBush();\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.pixelTolerance_ =\n      options.pixelTolerance !== undefined ? options.pixelTolerance : 10;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.snappedToVertex_ = false;\n\n    /**\n     * Indicate whether the interaction is currently changing a feature's\n     * coordinates.\n     * @type {boolean}\n     * @private\n     */\n    this.changingFeature_ = false;\n\n    /**\n     * @type {Array<DragSegment>}\n     * @private\n     */\n    this.dragSegments_ = [];\n\n    /**\n     * Draw overlay where sketch features are drawn.\n     * @type {VectorLayer}\n     * @private\n     */\n    this.overlay_ = new VectorLayer({\n      source: new VectorSource({\n        useSpatialIndex: false,\n        wrapX: !!options.wrapX,\n      }),\n      style: options.style ? options.style : getDefaultStyleFunction(),\n      updateWhileAnimating: true,\n      updateWhileInteracting: true,\n    });\n\n    /**\n     * @const\n     * @private\n     * @type {!Object<string, function(Feature, import(\"../geom/Geometry.js\").default): void>}\n     */\n    this.SEGMENT_WRITERS_ = {\n      Point: this.writePointGeometry_.bind(this),\n      LineString: this.writeLineStringGeometry_.bind(this),\n      LinearRing: this.writeLineStringGeometry_.bind(this),\n      Polygon: this.writePolygonGeometry_.bind(this),\n      MultiPoint: this.writeMultiPointGeometry_.bind(this),\n      MultiLineString: this.writeMultiLineStringGeometry_.bind(this),\n      MultiPolygon: this.writeMultiPolygonGeometry_.bind(this),\n      Circle: this.writeCircleGeometry_.bind(this),\n      GeometryCollection: this.writeGeometryCollectionGeometry_.bind(this),\n    };\n\n    /**\n     * @type {VectorSource}\n     * @private\n     */\n    this.source_ = null;\n\n    /**\n     * @type {VectorSource|null}\n     * @private\n     */\n    this.traceSource_ = options.traceSource || options.source || null;\n\n    /**\n     * @type {import(\"../events/condition.js\").Condition}\n     * @private\n     */\n    this.traceCondition_;\n    this.setTrace(options.trace || false);\n\n    /**\n     * @type {import('./tracing.js').TraceState}\n     * @private\n     */\n    this.traceState_ = {active: false};\n\n    /**\n     * @type {Array<DragSegment>|null}\n     * @private\n     */\n    this.traceSegments_ = null;\n\n    /**\n     * @type {boolean|import(\"../layer/BaseVector.js\").default}\n     * @private\n     */\n    this.hitDetection_ = null;\n\n    /**\n     * Useful for performance optimization\n     * @private\n     * @type boolean\n     */\n    this.filterFunctionWasSupplied_ =\n      options.filter != undefined ? true : false;\n\n    /**\n     * @private\n     * @type {FilterFunction}\n     */\n    this.filter_ = options.filter ? options.filter : () => true;\n\n    /**\n     * @private\n     * @type {function(import(\"../coordinate.js\").Coordinate, import(\"../coordinate.js\").Coordinate): boolean}\n     */\n    this.coordinatesEqual_ = options.sharedVerticesEqual\n      ? options.sharedVerticesEqual\n      : coordinatesEqual;\n\n    if (!(options.features || options.source)) {\n      throw new Error(\n        'The modify interaction requires features collection or a source',\n      );\n    }\n    /** @type {Array<Feature>} */\n    let features;\n    if (options.features) {\n      features = options.features.getArray();\n      //setup listeners on external features collection and features\n      options.features.addEventListener(\n        CollectionEventType.ADD,\n        this.handleExternalCollectionAdd_,\n      );\n      options.features.addEventListener(\n        CollectionEventType.REMOVE,\n        this.handleExternalCollectionRemove_,\n      );\n      //keep ref for unsubscribe on dispose\n      this.featuresCollection_ = options.features;\n    } else if (options.source) {\n      features = options.source.getFeatures();\n      //setup listeners on external source and features\n      options.source.addEventListener(\n        VectorEventType.ADDFEATURE,\n        this.handleSourceAdd_,\n      );\n      options.source.addEventListener(\n        VectorEventType.REMOVEFEATURE,\n        this.handleSourceRemove_,\n      );\n      //keep ref for unsubscribe on dispose\n      this.source_ = options.source;\n    }\n    features.forEach((feature) => {\n      //any modification to the feature requires filter to be re-run\n      feature.addEventListener(EventType.CHANGE, this.handleFeatureChange_);\n      //prop change handler is only to re-run the filter\n      if (this.filterFunctionWasSupplied_) {\n        feature.addEventListener(\n          ObjectEventType.PROPERTYCHANGE,\n          this.handleFeatureChange_,\n        );\n      }\n    });\n\n    if (options.hitDetection) {\n      this.hitDetection_ = options.hitDetection;\n    }\n\n    /**\n     * Internal features array.  When adding or removing features, be sure to use\n     * addFeature_()/removeFeature_() so that the the segment index is adjusted.\n     * @type {Array<Feature>}\n     * @private\n     */\n    this.features_ = [];\n    features\n      .filter(this.filter_)\n      .forEach((feature) => this.addFeature_(feature));\n\n    /**\n     * @type {import(\"../MapBrowserEvent.js\").default}\n     * @private\n     */\n    this.lastPointerEvent_ = null;\n\n    /**\n     * Delta (x, y in map units) between matched rtree vertex and pointer vertex.\n     * @type {Array<number>}\n     * @private\n     */\n    this.delta_ = [0, 0];\n\n    /**\n     * @private\n     */\n    this.snapToPointer_ =\n      options.snapToPointer === undefined\n        ? !this.hitDetection_\n        : options.snapToPointer;\n  }\n\n  /**\n   * Toggle tracing mode or set a tracing condition.\n   *\n   * @param {boolean|import(\"../events/condition.js\").Condition} trace A boolean to toggle tracing mode or an event\n   *     condition that will be checked when a feature is clicked to determine if tracing should be active.\n   */\n  setTrace(trace) {\n    let condition;\n    if (!trace) {\n      condition = never;\n    } else if (trace === true) {\n      condition = always;\n    } else {\n      condition = trace;\n    }\n    this.traceCondition_ = condition;\n  }\n\n  /**\n   * Called when a feature is added to the internal features collection\n   * @param {Feature} feature Feature.\n   * @private\n   */\n  addFeature_(feature) {\n    this.features_.push(feature);\n    const geometry = feature.getGeometry();\n    if (geometry) {\n      const writer = this.SEGMENT_WRITERS_[geometry.getType()];\n      if (writer) {\n        writer(feature, geometry);\n      }\n    }\n    const map = this.getMap();\n    if (map && map.isRendered() && this.getActive()) {\n      this.handlePointerAtPixel_(this.lastCoordinate_);\n    }\n  }\n\n  /**\n   * @param {import(\"../MapBrowserEvent.js\").default} evt Map browser event.\n   * @param {Array<SegmentData>} segments The segments subject to modification.\n   * @private\n   */\n  willModifyFeatures_(evt, segments) {\n    if (!this.featuresBeingModified_) {\n      this.featuresBeingModified_ = new Collection();\n      const features = this.featuresBeingModified_.getArray();\n      for (let i = 0, ii = segments.length; i < ii; ++i) {\n        const feature = segments[i].feature;\n        if (feature && !features.includes(feature)) {\n          this.featuresBeingModified_.push(feature);\n        }\n      }\n      if (this.featuresBeingModified_.getLength() === 0) {\n        this.featuresBeingModified_ = null;\n      } else {\n        this.dispatchEvent(\n          new ModifyEvent(\n            ModifyEventType.MODIFYSTART,\n            this.featuresBeingModified_,\n            evt,\n          ),\n        );\n      }\n    }\n  }\n\n  /**\n   * Removes a feature from the internal features collection and updates internal state\n   * accordingly.\n   * @param {Feature} feature Feature.\n   * @private\n   */\n  removeFeature_(feature) {\n    const itemIndex = this.features_.indexOf(feature);\n    this.features_.splice(itemIndex, 1);\n    this.removeFeatureSegmentData_(feature);\n    // Remove the vertex feature if the collection of candidate features is empty.\n    if (this.vertexFeature_ && this.features_.length === 0) {\n      this.overlay_.getSource().removeFeature(this.vertexFeature_);\n      this.vertexFeature_ = null;\n    }\n  }\n\n  /**\n   * @param {Feature} feature Feature.\n   * @private\n   */\n  removeFeatureSegmentData_(feature) {\n    const rBush = this.rBush_;\n    /** @type {Array<SegmentData>} */\n    const nodesToRemove = [];\n    rBush.forEach(\n      /**\n       * @param {SegmentData} node RTree node.\n       */\n      function (node) {\n        if (feature === node.feature) {\n          nodesToRemove.push(node);\n        }\n      },\n    );\n    for (let i = nodesToRemove.length - 1; i >= 0; --i) {\n      const nodeToRemove = nodesToRemove[i];\n      for (let j = this.dragSegments_.length - 1; j >= 0; --j) {\n        if (this.dragSegments_[j][0] === nodeToRemove) {\n          this.dragSegments_.splice(j, 1);\n        }\n      }\n      rBush.remove(nodeToRemove);\n    }\n  }\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 (this.vertexFeature_ && !active) {\n      this.overlay_.getSource().removeFeature(this.vertexFeature_);\n      this.vertexFeature_ = null;\n    }\n    super.setActive(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} map Map.\n   * @override\n   */\n  setMap(map) {\n    this.overlay_.setMap(map);\n    super.setMap(map);\n  }\n\n  /**\n   * Get the overlay layer that this interaction renders the modification point or vertex to.\n   * @return {VectorLayer} Overlay layer.\n   * @api\n   */\n  getOverlay() {\n    return this.overlay_;\n  }\n\n  /**\n   * @param {import(\"../source/Vector.js\").VectorSourceEvent} event Event.\n   * @private\n   */\n  handleSourceAdd_(event) {\n    const feature = event.feature;\n    if (feature) {\n      this.externalAddFeatureHandler_(feature);\n    }\n  }\n\n  /**\n   * @param {import(\"../source/Vector.js\").VectorSourceEvent} event Event.\n   * @private\n   */\n  handleSourceRemove_(event) {\n    const feature = event.feature;\n    if (feature) {\n      this.externalRemoveFeatureHandler_(feature);\n    }\n  }\n\n  /**\n   * @param {import(\"../Collection.js\").CollectionEvent} event Event.\n   * @private\n   */\n  handleExternalCollectionAdd_(event) {\n    const feature = event.element;\n    if (feature) {\n      this.externalAddFeatureHandler_(feature);\n    }\n  }\n\n  /**\n   * @param {import(\"../Collection.js\").CollectionEvent} event Event.\n   * @private\n   */\n  handleExternalCollectionRemove_(event) {\n    const feature = event.element;\n    if (feature) {\n      this.externalRemoveFeatureHandler_(feature);\n    }\n  }\n\n  /**\n   * Common handler for event signaling addition of feature to the supplied features source\n   * or collection.\n   * @param {Feature} feature Feature.\n   */\n  externalAddFeatureHandler_(feature) {\n    feature.addEventListener(EventType.CHANGE, this.handleFeatureChange_);\n    //prop change handler is only for reapplying the filter\n    if (this.filterFunctionWasSupplied_) {\n      feature.addEventListener(\n        ObjectEventType.PROPERTYCHANGE,\n        this.handleFeatureChange_,\n      );\n    }\n    if (this.filter_(feature)) {\n      this.addFeature_(feature);\n    }\n  }\n\n  /**\n   * Common handler for event signaling removal of feature from the supplied features source\n   * or collection.\n   * @param {Feature} feature Feature.\n   */\n  externalRemoveFeatureHandler_(feature) {\n    feature.removeEventListener(EventType.CHANGE, this.handleFeatureChange_);\n    if (this.filterFunctionWasSupplied_) {\n      feature.removeEventListener(\n        ObjectEventType.PROPERTYCHANGE,\n        this.handleFeatureChange_,\n      );\n    }\n    this.removeFeature_(feature);\n  }\n\n  /**\n   * Listener for features in external source or features collection.  Ensures the feature filter\n   * is re-run and segment data is updated.\n   * @param {import(\"../events/Event.js\").default | import(\"../Object.js\").ObjectEvent} evt Event.\n   * @private\n   */\n  handleFeatureChange_(evt) {\n    if (!this.changingFeature_) {\n      const feature = /** @type {Feature} */ (evt.target);\n      this.removeFeature_(feature);\n      //safe to remove handler on a feature if there isn't one, but need to apply the filter\n      // before adding the feature.\n      this.filter_(feature) && this.addFeature_(feature);\n    }\n  }\n\n  /**\n   * @param {Feature} feature Feature\n   * @param {Point} geometry Geometry.\n   * @private\n   */\n  writePointGeometry_(feature, geometry) {\n    const coordinates = geometry.getCoordinates();\n\n    /** @type {SegmentData} */\n    const segmentData = {\n      feature: feature,\n      geometry: geometry,\n      segment: [coordinates, coordinates],\n    };\n\n    this.rBush_.insert(geometry.getExtent(), segmentData);\n  }\n\n  /**\n   * @param {Feature} feature Feature\n   * @param {import(\"../geom/MultiPoint.js\").default} geometry Geometry.\n   * @private\n   */\n  writeMultiPointGeometry_(feature, geometry) {\n    const points = geometry.getCoordinates();\n    for (let i = 0, ii = points.length; i < ii; ++i) {\n      const coordinates = points[i];\n\n      /** @type {SegmentData} */\n      const segmentData = {\n        feature: feature,\n        geometry: geometry,\n        depth: [i],\n        index: i,\n        segment: [coordinates, coordinates],\n      };\n\n      this.rBush_.insert(geometry.getExtent(), segmentData);\n    }\n  }\n\n  /**\n   * @param {Feature} feature Feature\n   * @param {import(\"../geom/LineString.js\").default} geometry Geometry.\n   * @private\n   */\n  writeLineStringGeometry_(feature, geometry) {\n    const coordinates = geometry.getCoordinates();\n    for (let i = 0, ii = coordinates.length - 1; i < ii; ++i) {\n      const segment = coordinates.slice(i, i + 2);\n\n      /** @type {SegmentData} */\n      const segmentData = {\n        feature: feature,\n        geometry: geometry,\n        index: i,\n        segment: segment,\n      };\n\n      this.rBush_.insert(boundingExtent(segment), segmentData);\n    }\n  }\n\n  /**\n   * @param {Feature} feature Feature\n   * @param {import(\"../geom/MultiLineString.js\").default} geometry Geometry.\n   * @private\n   */\n  writeMultiLineStringGeometry_(feature, geometry) {\n    const lines = geometry.getCoordinates();\n    for (let j = 0, jj = lines.length; j < jj; ++j) {\n      const coordinates = lines[j];\n      for (let i = 0, ii = coordinates.length - 1; i < ii; ++i) {\n        const segment = coordinates.slice(i, i + 2);\n\n        /** @type {SegmentData} */\n        const segmentData = {\n          feature: feature,\n          geometry: geometry,\n          depth: [j],\n          index: i,\n          segment: segment,\n        };\n\n        this.rBush_.insert(boundingExtent(segment), segmentData);\n      }\n    }\n  }\n\n  /**\n   * @param {Feature} feature Feature\n   * @param {import(\"../geom/Polygon.js\").default} geometry Geometry.\n   * @private\n   */\n  writePolygonGeometry_(feature, geometry) {\n    const rings = geometry.getCoordinates();\n    for (let j = 0, jj = rings.length; j < jj; ++j) {\n      const coordinates = rings[j];\n      for (let i = 0, ii = coordinates.length - 1; i < ii; ++i) {\n        const segment = coordinates.slice(i, i + 2);\n\n        /** @type {SegmentData} */\n        const segmentData = {\n          feature: feature,\n          geometry: geometry,\n          depth: [j],\n          index: i,\n          segment: segment,\n        };\n\n        this.rBush_.insert(boundingExtent(segment), segmentData);\n      }\n    }\n  }\n\n  /**\n   * @param {Feature} feature Feature\n   * @param {import(\"../geom/MultiPolygon.js\").default} geometry Geometry.\n   * @private\n   */\n  writeMultiPolygonGeometry_(feature, geometry) {\n    const polygons = geometry.getCoordinates();\n    for (let k = 0, kk = polygons.length; k < kk; ++k) {\n      const rings = polygons[k];\n      for (let j = 0, jj = rings.length; j < jj; ++j) {\n        const coordinates = rings[j];\n        for (let i = 0, ii = coordinates.length - 1; i < ii; ++i) {\n          const segment = coordinates.slice(i, i + 2);\n\n          /** @type {SegmentData} */\n          const segmentData = {\n            feature: feature,\n            geometry: geometry,\n            depth: [j, k],\n            index: i,\n            segment: segment,\n          };\n\n          this.rBush_.insert(boundingExtent(segment), segmentData);\n        }\n      }\n    }\n  }\n\n  /**\n   * We convert a circle into two segments.  The segment at index\n   * {@link CIRCLE_CENTER_INDEX} is the\n   * circle's center (a point).  The segment at index\n   * {@link CIRCLE_CIRCUMFERENCE_INDEX} is\n   * the circumference, and is not a line segment.\n   *\n   * @param {Feature} feature Feature.\n   * @param {import(\"../geom/Circle.js\").default} geometry Geometry.\n   * @private\n   */\n  writeCircleGeometry_(feature, geometry) {\n    const coordinates = geometry.getCenter();\n\n    /** @type {SegmentData} */\n    const centerSegmentData = {\n      feature: feature,\n      geometry: geometry,\n      index: CIRCLE_CENTER_INDEX,\n      segment: [coordinates, coordinates],\n    };\n\n    /** @type {SegmentData} */\n    const circumferenceSegmentData = {\n      feature: feature,\n      geometry: geometry,\n      index: CIRCLE_CIRCUMFERENCE_INDEX,\n      segment: [coordinates, coordinates],\n    };\n\n    const featureSegments = [centerSegmentData, circumferenceSegmentData];\n    centerSegmentData.featureSegments = featureSegments;\n    circumferenceSegmentData.featureSegments = featureSegments;\n    this.rBush_.insert(createExtent(coordinates), centerSegmentData);\n    let circleGeometry = /** @type {import(\"../geom/Geometry.js\").default} */ (\n      geometry\n    );\n    const userProjection = getUserProjection();\n    if (userProjection && this.getMap()) {\n      const projection = this.getMap().getView().getProjection();\n      circleGeometry = circleGeometry\n        .clone()\n        .transform(userProjection, projection);\n      circleGeometry = fromCircle(\n        /** @type {import(\"../geom/Circle.js\").default} */ (circleGeometry),\n      ).transform(projection, userProjection);\n    }\n    this.rBush_.insert(circleGeometry.getExtent(), circumferenceSegmentData);\n  }\n\n  /**\n   * @param {Feature} feature Feature\n   * @param {import(\"../geom/GeometryCollection.js\").default} geometry Geometry.\n   * @private\n   */\n  writeGeometryCollectionGeometry_(feature, geometry) {\n    const geometries = geometry.getGeometriesArray();\n    for (let i = 0; i < geometries.length; ++i) {\n      const geometry = geometries[i];\n      const writer = this.SEGMENT_WRITERS_[geometry.getType()];\n      writer(feature, geometry);\n    }\n  }\n\n  /**\n   * @param {import(\"../coordinate.js\").Coordinate} coordinates Coordinates.\n   * @param {Array<Feature>} features The features being modified.\n   * @param {Array<import(\"../geom/SimpleGeometry.js\").default>} geometries The geometries being modified.\n   * @param {boolean} existing The vertex represents an existing vertex.\n   * @return {Feature} Vertex feature.\n   * @private\n   */\n  createOrUpdateVertexFeature_(coordinates, features, geometries, existing) {\n    let vertexFeature = this.vertexFeature_;\n    if (!vertexFeature) {\n      vertexFeature = new Feature(new Point(coordinates));\n      this.vertexFeature_ = vertexFeature;\n      this.overlay_.getSource().addFeature(vertexFeature);\n    } else {\n      const geometry = vertexFeature.getGeometry();\n      geometry.setCoordinates(coordinates);\n    }\n    vertexFeature.set('features', features);\n    vertexFeature.set('geometries', geometries);\n    vertexFeature.set('existing', existing);\n    return vertexFeature;\n  }\n\n  /**\n   * Handles the {@link module:ol/MapBrowserEvent~MapBrowserEvent map browser event} and may modify the geometry.\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 (!mapBrowserEvent.originalEvent) {\n      return true;\n    }\n    this.lastPointerEvent_ = mapBrowserEvent;\n\n    let handled;\n    if (\n      !mapBrowserEvent.map.getView().getInteracting() &&\n      mapBrowserEvent.type == MapBrowserEventType.POINTERMOVE &&\n      !this.handlingDownUpSequence\n    ) {\n      this.handlePointerMove_(mapBrowserEvent);\n    }\n    if (this.vertexFeature_ && this.deleteCondition_(mapBrowserEvent)) {\n      if (\n        mapBrowserEvent.type != MapBrowserEventType.SINGLECLICK ||\n        !this.ignoreNextSingleClick_\n      ) {\n        handled = this.removePoint();\n      } else {\n        handled = true;\n      }\n    }\n\n    if (mapBrowserEvent.type == MapBrowserEventType.SINGLECLICK) {\n      this.ignoreNextSingleClick_ = false;\n    }\n\n    return super.handleEvent(mapBrowserEvent) && !handled;\n  }\n\n  /**\n   * @param {import(\"../coordinate.js\").Coordinate} pixelCoordinate Pixel coordinate.\n   * @return {Array<SegmentData>|undefined} Insert vertices and update drag segments.\n   * @private\n   */\n  findInsertVerticesAndUpdateDragSegments_(pixelCoordinate) {\n    this.handlePointerAtPixel_(pixelCoordinate);\n    this.dragSegments_.length = 0;\n    this.featuresBeingModified_ = null;\n    const vertexFeature = this.vertexFeature_;\n    if (!vertexFeature) {\n      return;\n    }\n\n    const projection = this.getMap().getView().getProjection();\n    /** @type {Array<SegmentData>} */\n    const insertVertices = [];\n    const vertex = this.vertexFeature_.getGeometry().getCoordinates();\n    const vertexExtent = boundingExtent([vertex]);\n    const segmentDataMatches = this.rBush_.getInExtent(vertexExtent);\n    const componentSegments = {};\n    segmentDataMatches.sort(compareIndexes);\n    for (let i = 0, ii = segmentDataMatches.length; i < ii; ++i) {\n      const segmentDataMatch = segmentDataMatches[i];\n      const segment = segmentDataMatch.segment;\n      let uid = getUid(segmentDataMatch.geometry);\n      const depth = segmentDataMatch.depth;\n      if (depth) {\n        uid += '-' + depth.join('-'); // separate feature components\n      }\n      if (!componentSegments[uid]) {\n        componentSegments[uid] = new Array(2);\n      }\n\n      if (\n        segmentDataMatch.geometry.getType() === 'Circle' &&\n        segmentDataMatch.index === CIRCLE_CIRCUMFERENCE_INDEX\n      ) {\n        const closestVertex = closestOnSegmentData(\n          pixelCoordinate,\n          segmentDataMatch,\n          projection,\n        );\n        if (\n          this.coordinatesEqual_(closestVertex, vertex) &&\n          !componentSegments[uid][0]\n        ) {\n          this.dragSegments_.push([segmentDataMatch, 0]);\n          componentSegments[uid][0] = segmentDataMatch;\n        }\n        continue;\n      }\n\n      if (\n        this.coordinatesEqual_(segment[0], vertex) &&\n        !componentSegments[uid][0]\n      ) {\n        this.dragSegments_.push([segmentDataMatch, 0]);\n        componentSegments[uid][0] = segmentDataMatch;\n        continue;\n      }\n\n      if (\n        this.coordinatesEqual_(segment[1], vertex) &&\n        !componentSegments[uid][1]\n      ) {\n        if (\n          componentSegments[uid][0] &&\n          componentSegments[uid][0].index === 0\n        ) {\n          let coordinates = segmentDataMatch.geometry.getCoordinates();\n          switch (segmentDataMatch.geometry.getType()) {\n            // prevent dragging closed linestrings by the connecting node\n            case 'LineString':\n            case 'MultiLineString':\n              continue;\n            // if dragging the first vertex of a polygon, ensure the other segment\n            // belongs to the closing vertex of the linear ring\n            case 'MultiPolygon':\n              coordinates = coordinates[depth[1]];\n            /* falls through */\n            case 'Polygon':\n              if (segmentDataMatch.index !== coordinates[depth[0]].length - 2) {\n                continue;\n              }\n              break;\n            default:\n            // pass\n          }\n        }\n\n        this.dragSegments_.push([segmentDataMatch, 1]);\n        componentSegments[uid][1] = segmentDataMatch;\n        continue;\n      }\n\n      if (\n        getUid(segment) in this.vertexSegments_ &&\n        !componentSegments[uid][0] &&\n        !componentSegments[uid][1]\n      ) {\n        insertVertices.push(segmentDataMatch);\n      }\n    }\n\n    return insertVertices;\n  }\n\n  /**\n   * @private\n   */\n  deactivateTrace_() {\n    this.traceState_ = {active: false};\n  }\n\n  /**\n   * Update the trace.\n   * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n   * @private\n   */\n  updateTrace_(event) {\n    const traceState = this.traceState_;\n    if (!traceState.active) {\n      return;\n    }\n\n    if (traceState.targetIndex === -1) {\n      // check if we are ready to pick a target\n      const startPx = event.map.getPixelFromCoordinate(traceState.startCoord);\n      if (coordinateDistance(startPx, event.pixel) < this.pixelTolerance_) {\n        return;\n      }\n    }\n\n    const updatedTraceTarget = getTraceTargetUpdate(\n      event.coordinate,\n      traceState,\n      event.map,\n      this.pixelTolerance_,\n    );\n\n    if (\n      traceState.targetIndex === -1 &&\n      Math.sqrt(updatedTraceTarget.closestTargetDistance) /\n        event.map.getView().getResolution() >\n        this.pixelTolerance_\n    ) {\n      return;\n    }\n\n    if (traceState.targetIndex !== updatedTraceTarget.index) {\n      // target changed\n      if (traceState.targetIndex !== -1) {\n        // remove points added during previous trace\n        const oldTarget = traceState.targets[traceState.targetIndex];\n        this.removeTracedCoordinates_(oldTarget.startIndex, oldTarget.endIndex);\n      } else {\n        for (const traceSegment of this.traceSegments_) {\n          const segmentData = traceSegment[0];\n          const geometry = segmentData.geometry;\n          const index = traceSegment[1];\n          const coordinates = geometry.getCoordinates();\n          const coordinatesArray = getCoordinatesArray(\n            coordinates,\n            geometry.getType(),\n            segmentData.depth,\n          );\n          coordinatesArray.splice(segmentData.index + index, 1);\n          geometry.setCoordinates(coordinates);\n          if (index === 0) {\n            segmentData.index -= 1;\n          }\n        }\n      }\n      // add points for the new target\n      const newTarget = traceState.targets[updatedTraceTarget.index];\n      this.addTracedCoordinates_(\n        newTarget,\n        newTarget.startIndex,\n        updatedTraceTarget.endIndex,\n      );\n    } else {\n      // target stayed the same\n      const target = traceState.targets[traceState.targetIndex];\n      this.addOrRemoveTracedCoordinates_(target, updatedTraceTarget.endIndex);\n    }\n\n    // modify the state with updated info\n    traceState.targetIndex = updatedTraceTarget.index;\n    const target = traceState.targets[traceState.targetIndex];\n    target.endIndex = updatedTraceTarget.endIndex;\n  }\n\n  getTraceCandidates_(event) {\n    const map = this.getMap();\n    const tolerance = this.pixelTolerance_;\n    const lowerLeft = map.getCoordinateFromPixel([\n      event.pixel[0] - tolerance,\n      event.pixel[1] + tolerance,\n    ]);\n    const upperRight = map.getCoordinateFromPixel([\n      event.pixel[0] + tolerance,\n      event.pixel[1] - tolerance,\n    ]);\n    const extent = boundingExtent([lowerLeft, upperRight]);\n    const features = this.traceSource_.getFeaturesInExtent(extent);\n    return features;\n  }\n\n  /**\n   * Activate or deactivate trace state based on a browser event.\n   * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n   * @private\n   */\n  toggleTraceState_(event) {\n    if (!this.traceSource_ || !this.traceCondition_(event)) {\n      return;\n    }\n\n    if (this.traceState_.active) {\n      this.deactivateTrace_();\n      this.traceSegments_ = null;\n      return;\n    }\n\n    const features = this.getTraceCandidates_(event);\n    if (features.length === 0) {\n      return;\n    }\n\n    const targets = getTraceTargets(event.coordinate, features);\n    if (targets.length) {\n      this.traceState_ = {\n        active: true,\n        startCoord: event.coordinate.slice(),\n        targets: targets,\n        targetIndex: -1,\n      };\n    }\n  }\n\n  /**\n   * @param {import('./tracing.js').TraceTarget} target The trace target.\n   * @param {number} endIndex The new end index of the trace.\n   * @private\n   */\n  addOrRemoveTracedCoordinates_(target, endIndex) {\n    // three cases to handle:\n    //  1. traced in the same direction and points need adding\n    //  2. traced in the same direction and points need removing\n    //  3. traced in a new direction\n    const previouslyForward = target.startIndex <= target.endIndex;\n    const currentlyForward = target.startIndex <= endIndex;\n    if (previouslyForward === currentlyForward) {\n      // same direction\n      if (\n        (previouslyForward && endIndex > target.endIndex) ||\n        (!previouslyForward && endIndex < target.endIndex)\n      ) {\n        // case 1 - add new points\n        this.addTracedCoordinates_(target, target.endIndex, endIndex);\n      } else if (\n        (previouslyForward && endIndex < target.endIndex) ||\n        (!previouslyForward && endIndex > target.endIndex)\n      ) {\n        // case 2 - remove old points\n        this.removeTracedCoordinates_(endIndex, target.endIndex);\n      }\n    } else {\n      // case 3 - remove old points, add new points\n      this.removeTracedCoordinates_(target.startIndex, target.endIndex);\n      this.addTracedCoordinates_(target, target.startIndex, endIndex);\n    }\n  }\n\n  /**\n   * @param {number} fromIndex The start index.\n   * @param {number} toIndex The end index.\n   * @private\n   */\n  removeTracedCoordinates_(fromIndex, toIndex) {\n    if (fromIndex === toIndex) {\n      return;\n    }\n\n    let remove = 0;\n    if (fromIndex < toIndex) {\n      const start = Math.ceil(fromIndex);\n      let end = Math.floor(toIndex);\n      if (end === toIndex) {\n        end -= 1;\n      }\n      remove = end - start + 1;\n    } else {\n      const start = Math.floor(fromIndex);\n      let end = Math.ceil(toIndex);\n      if (end === toIndex) {\n        end += 1;\n      }\n      remove = start - end + 1;\n    }\n\n    if (remove > 0) {\n      for (const traceSegment of this.traceSegments_) {\n        const segmentData = traceSegment[0];\n        const geometry = segmentData.geometry;\n        const index = traceSegment[1];\n        let removeIndex = traceSegment[0].index + 1;\n        if (index === 1) {\n          removeIndex -= remove;\n        }\n        const coordinates = geometry.getCoordinates();\n        const coordinatesArray = getCoordinatesArray(\n          coordinates,\n          geometry.getType(),\n          segmentData.depth,\n        );\n        coordinatesArray.splice(removeIndex, remove);\n        geometry.setCoordinates(coordinates);\n        if (index === 1) {\n          segmentData.index -= remove;\n        }\n      }\n    }\n  }\n\n  /**\n   * @param {import('./tracing.js').TraceTarget} target The trace target.\n   * @param {number} fromIndex The start index.\n   * @param {number} toIndex The end index.\n   * @private\n   */\n  addTracedCoordinates_(target, fromIndex, toIndex) {\n    if (fromIndex === toIndex) {\n      return;\n    }\n\n    const newCoordinates = [];\n    if (fromIndex < toIndex) {\n      // forward trace\n      const start = Math.ceil(fromIndex);\n      let end = Math.floor(toIndex);\n      if (end === toIndex) {\n        // if end is snapped to a vertex, it will be added later\n        end -= 1;\n      }\n      for (let i = start; i <= end; ++i) {\n        newCoordinates.push(getCoordinate(target.coordinates, i));\n      }\n    } else {\n      // reverse trace\n      const start = Math.floor(fromIndex);\n      let end = Math.ceil(toIndex);\n      if (end === toIndex) {\n        end += 1;\n      }\n      for (let i = start; i >= end; --i) {\n        newCoordinates.push(getCoordinate(target.coordinates, i));\n      }\n    }\n\n    if (newCoordinates.length) {\n      for (const traceSegment of this.traceSegments_) {\n        const segmentData = traceSegment[0];\n        const geometry = segmentData.geometry;\n        const index = traceSegment[1];\n        const insertIndex = segmentData.index + 1;\n        if (index === 0) {\n          newCoordinates.reverse();\n        }\n        const coordinates = geometry.getCoordinates();\n        const coordinatesArray = getCoordinatesArray(\n          coordinates,\n          geometry.getType(),\n          segmentData.depth,\n        );\n        coordinatesArray.splice(insertIndex, 0, ...newCoordinates);\n        geometry.setCoordinates(coordinates);\n        if (index === 1) {\n          segmentData.index += newCoordinates.length;\n        }\n      }\n    }\n  }\n\n  /**\n   * @param {import('../coordinate.js').Coordinate} vertex Vertex.\n   * @param {DragSegment} dragSegment Drag segment.\n   */\n  updateGeometry_(vertex, dragSegment) {\n    const segmentData = dragSegment[0];\n    const depth = segmentData.depth;\n    let coordinates;\n    const segment = segmentData.segment;\n    const geometry = segmentData.geometry;\n    const index = dragSegment[1];\n\n    const stride = geometry.getStride();\n    for (let i = 2; i < stride; ++i) {\n      vertex[i] = segment[index][i];\n    }\n    vertex.length = stride;\n    switch (geometry.getType()) {\n      case 'Point':\n        coordinates = vertex;\n        segment[0] = vertex;\n        segment[1] = vertex;\n        break;\n      case 'MultiPoint':\n        coordinates = geometry.getCoordinates();\n        coordinates[segmentData.index] = vertex;\n        segment[0] = vertex;\n        segment[1] = vertex;\n        break;\n      case 'LineString':\n        coordinates = geometry.getCoordinates();\n        coordinates[segmentData.index + index] = vertex;\n        segment[index] = vertex;\n        break;\n      case 'MultiLineString':\n        coordinates = geometry.getCoordinates();\n        coordinates[depth[0]][segmentData.index + index] = vertex;\n        segment[index] = vertex;\n        break;\n      case 'Polygon': {\n        coordinates = geometry.getCoordinates();\n        const ring = coordinates[depth[0]];\n        const targetIndex = segmentData.index + index;\n\n        // Prevent duplicate change events when vertex already at position\n        if (\n          ring[targetIndex][0] === vertex[0] &&\n          ring[targetIndex][1] === vertex[1]\n        ) {\n          coordinates = null;\n        } else {\n          ring[targetIndex] = vertex;\n          if (targetIndex === 0) {\n            ring[ring.length - 1] = vertex;\n          } else if (targetIndex === ring.length - 1) {\n            ring[0] = vertex;\n          }\n        }\n        segment[index] = vertex;\n        break;\n      }\n      case 'MultiPolygon': {\n        coordinates = geometry.getCoordinates();\n        const mRing = coordinates[depth[1]][depth[0]];\n        const mTargetIndex = segmentData.index + index;\n\n        // Prevent duplicate change events when vertex already at position\n        if (\n          mRing[mTargetIndex][0] === vertex[0] &&\n          mRing[mTargetIndex][1] === vertex[1]\n        ) {\n          coordinates = null;\n        } else {\n          mRing[mTargetIndex] = vertex;\n          if (mTargetIndex === 0) {\n            mRing[mRing.length - 1] = vertex;\n          } else if (mTargetIndex === mRing.length - 1) {\n            mRing[0] = vertex;\n          }\n        }\n        segment[index] = vertex;\n        break;\n      }\n      case 'Circle':\n        const circle = /** @type {import(\"../geom/Circle.js\").default} */ (\n          geometry\n        );\n        segment[0] = vertex;\n        segment[1] = vertex;\n        if (segmentData.index === CIRCLE_CENTER_INDEX) {\n          this.changingFeature_ = true;\n          circle.setCenter(vertex);\n          this.changingFeature_ = false;\n        } else {\n          // We're dragging the circle's circumference:\n          this.changingFeature_ = true;\n          const projection = this.getMap().getView().getProjection();\n          let radius = coordinateDistance(\n            fromUserCoordinate(circle.getCenter(), projection),\n            fromUserCoordinate(vertex, projection),\n          );\n          const userProjection = getUserProjection();\n          if (userProjection) {\n            const circleGeometry = circle\n              .clone()\n              .transform(userProjection, projection);\n            circleGeometry.setRadius(radius);\n            radius = circleGeometry\n              .transform(projection, userProjection)\n              .getRadius();\n          }\n          circle.setRadius(radius);\n          this.changingFeature_ = false;\n        }\n        break;\n      default:\n      // pass\n    }\n    if (coordinates) {\n      this.setGeometryCoordinates_(geometry, coordinates);\n    }\n  }\n\n  /**\n   * Handle pointer drag events.\n   * @param {import(\"../MapBrowserEvent.js\").default} evt Event.\n   * @override\n   */\n  handleDragEvent(evt) {\n    this.ignoreNextSingleClick_ = false;\n    this.willModifyFeatures_(\n      evt,\n      this.dragSegments_.map(([segment]) => segment),\n    );\n\n    const vertex = [\n      evt.coordinate[0] + this.delta_[0],\n      evt.coordinate[1] + this.delta_[1],\n    ];\n    const features = [];\n    const geometries = [];\n    const startTraceCoord =\n      this.traceState_.active && !this.traceSegments_\n        ? this.traceState_.startCoord\n        : null;\n    if (startTraceCoord) {\n      this.traceSegments_ = [];\n      for (const dragSegment of this.dragSegments_) {\n        const segmentData = dragSegment[0];\n        const eligibleForTracing =\n          coordinateDistance(\n            closestOnSegment(startTraceCoord, segmentData.segment),\n            startTraceCoord,\n          ) /\n            evt.map.getView().getResolution() <\n          1;\n        if (eligibleForTracing) {\n          this.traceSegments_.push(dragSegment);\n        }\n      }\n    }\n    for (let i = 0, ii = this.dragSegments_.length; i < ii; ++i) {\n      const dragSegment = this.dragSegments_[i];\n      const segmentData = dragSegment[0];\n      const feature = segmentData.feature;\n      if (!features.includes(feature)) {\n        features.push(feature);\n      }\n      const geometry = segmentData.geometry;\n      if (!geometries.includes(geometry)) {\n        geometries.push(geometry);\n      }\n\n      this.updateGeometry_(vertex, dragSegment);\n    }\n    this.updateTrace_(evt);\n    this.createOrUpdateVertexFeature_(vertex, features, geometries, true);\n  }\n\n  /**\n   * Handle pointer down events.\n   * @param {import(\"../MapBrowserEvent.js\").default} evt Event.\n   * @return {boolean} If the event was consumed.\n   * @override\n   */\n  handleDownEvent(evt) {\n    if (!this.condition_(evt)) {\n      return false;\n    }\n    const pixelCoordinate = evt.coordinate;\n    const insertVertices =\n      this.findInsertVerticesAndUpdateDragSegments_(pixelCoordinate);\n\n    if (insertVertices?.length && this.insertVertexCondition_(evt)) {\n      this.willModifyFeatures_(evt, insertVertices);\n\n      if (this.vertexFeature_) {\n        const vertex = this.vertexFeature_.getGeometry().getCoordinates();\n        for (let j = insertVertices.length - 1; j >= 0; --j) {\n          this.insertVertex_(insertVertices[j], vertex);\n        }\n        this.ignoreNextSingleClick_ = true;\n      }\n    }\n\n    return !!this.vertexFeature_;\n  }\n\n  /**\n   * Handle pointer up events.\n   * @param {import(\"../MapBrowserEvent.js\").default} evt Event.\n   * @return {boolean} If the event was consumed.\n   * @override\n   */\n  handleUpEvent(evt) {\n    for (let i = this.dragSegments_.length - 1; i >= 0; --i) {\n      const segmentData = this.dragSegments_[i][0];\n      const geometry = segmentData.geometry;\n      if (geometry.getType() === 'Circle') {\n        const circle = /** @type {import(\"../geom/Circle.js\").default} */ (\n          geometry\n        );\n        // Update a circle object in the R* bush:\n        const coordinates = circle.getCenter();\n        const centerSegmentData = segmentData.featureSegments[0];\n        const circumferenceSegmentData = segmentData.featureSegments[1];\n        centerSegmentData.segment[0] = coordinates;\n        centerSegmentData.segment[1] = coordinates;\n        circumferenceSegmentData.segment[0] = coordinates;\n        circumferenceSegmentData.segment[1] = coordinates;\n        this.rBush_.update(createExtent(coordinates), centerSegmentData);\n        /** @type {import(\"../geom/Circle.js\").default | import(\"../geom/Polygon.js\").default} */\n        let circleGeometry = circle;\n        const userProjection = getUserProjection();\n        if (userProjection) {\n          const projection = evt.map.getView().getProjection();\n          circleGeometry = circleGeometry\n            .clone()\n            .transform(userProjection, projection);\n          circleGeometry = fromCircle(circleGeometry).transform(\n            projection,\n            userProjection,\n          );\n        }\n        this.rBush_.update(\n          circleGeometry.getExtent(),\n          circumferenceSegmentData,\n        );\n      } else {\n        this.rBush_.update(boundingExtent(segmentData.segment), segmentData);\n      }\n    }\n    if (this.featuresBeingModified_) {\n      this.toggleTraceState_(evt);\n      this.dispatchEvent(\n        new ModifyEvent(\n          ModifyEventType.MODIFYEND,\n          this.featuresBeingModified_,\n          evt,\n        ),\n      );\n      this.featuresBeingModified_ = null;\n    }\n    return false;\n  }\n\n  /**\n   * @param {import(\"../MapBrowserEvent.js\").default} evt Event.\n   * @private\n   */\n  handlePointerMove_(evt) {\n    this.lastCoordinate_ = evt.coordinate;\n    this.handlePointerAtPixel_(this.lastCoordinate_);\n  }\n\n  /**\n   * @param {import(\"../coordinate.js\").Coordinate} pixelCoordinate The pixel Coordinate.\n   * @private\n   */\n  handlePointerAtPixel_(pixelCoordinate) {\n    const map = this.getMap();\n    const pixel = map.getPixelFromCoordinate(pixelCoordinate);\n    const projection = map.getView().getProjection();\n    const sortByDistance = function (a, b) {\n      return (\n        projectedDistanceToSegmentDataSquared(pixelCoordinate, a, projection) -\n        projectedDistanceToSegmentDataSquared(pixelCoordinate, b, projection)\n      );\n    };\n\n    /** @type {Array<SegmentData>|undefined} */\n    let nodes;\n    /** @type {Point|undefined} */\n    let hitPointGeometry;\n    if (this.hitDetection_) {\n      const layerFilter =\n        typeof this.hitDetection_ === 'object'\n          ? (layer) => layer === this.hitDetection_\n          : undefined;\n      map.forEachFeatureAtPixel(\n        pixel,\n        (feature, layer, geometry) => {\n          if (geometry && geometry.getType() === 'Point') {\n            geometry = new Point(\n              toUserCoordinate(geometry.getCoordinates(), projection),\n            );\n          }\n          const geom = geometry || feature.getGeometry();\n\n          if (\n            geom &&\n            geom.getType() === 'Point' &&\n            feature instanceof Feature &&\n            this.features_.includes(feature)\n          ) {\n            hitPointGeometry = /** @type {Point} */ (geom);\n            const coordinate = /** @type {Point} */ (feature.getGeometry())\n              .getFlatCoordinates()\n              .slice(0, 2);\n            nodes = [\n              {\n                feature,\n                geometry: hitPointGeometry,\n                segment: [coordinate, coordinate],\n              },\n            ];\n          }\n          return true;\n        },\n        {layerFilter},\n      );\n    }\n    if (!nodes) {\n      const viewExtent = fromUserExtent(\n        createExtent(pixelCoordinate, tempExtent),\n        projection,\n      );\n      const buffer = map.getView().getResolution() * this.pixelTolerance_;\n      const box = toUserExtent(\n        bufferExtent(viewExtent, buffer, tempExtent),\n        projection,\n      );\n      nodes = this.rBush_.getInExtent(box);\n    }\n\n    if (nodes && nodes.length > 0) {\n      const node = nodes.sort(sortByDistance)[0];\n      const closestSegment = node.segment;\n      let vertex = closestOnSegmentData(pixelCoordinate, node, projection);\n      const vertexPixel = map.getPixelFromCoordinate(vertex);\n      let dist = coordinateDistance(pixel, vertexPixel);\n      if (hitPointGeometry || dist <= this.pixelTolerance_) {\n        /** @type {Object<string, boolean>} */\n        const vertexSegments = {};\n        vertexSegments[getUid(closestSegment)] = true;\n\n        if (!this.snapToPointer_) {\n          this.delta_[0] = vertex[0] - pixelCoordinate[0];\n          this.delta_[1] = vertex[1] - pixelCoordinate[1];\n        }\n        if (\n          node.geometry.getType() === 'Circle' &&\n          node.index === CIRCLE_CIRCUMFERENCE_INDEX\n        ) {\n          this.snappedToVertex_ = true;\n          this.createOrUpdateVertexFeature_(\n            vertex,\n            [node.feature],\n            [node.geometry],\n            this.snappedToVertex_,\n          );\n        } else {\n          const pixel1 = map.getPixelFromCoordinate(closestSegment[0]);\n          const pixel2 = map.getPixelFromCoordinate(closestSegment[1]);\n          const squaredDist1 = squaredCoordinateDistance(vertexPixel, pixel1);\n          const squaredDist2 = squaredCoordinateDistance(vertexPixel, pixel2);\n          dist = Math.sqrt(Math.min(squaredDist1, squaredDist2));\n          this.snappedToVertex_ = dist <= this.pixelTolerance_;\n          // Stop and cleanup overlay vertex feature if a segment was hit and new vertex creation is not allowed by the insertVertexCondition\n          if (\n            !this.snappedToVertex_ &&\n            !this.insertVertexCondition_(this.lastPointerEvent_)\n          ) {\n            if (this.vertexFeature_) {\n              this.overlay_.getSource().removeFeature(this.vertexFeature_);\n              this.vertexFeature_ = null;\n            }\n            return;\n          }\n          if (this.snappedToVertex_) {\n            vertex =\n              squaredDist1 > squaredDist2\n                ? closestSegment[1]\n                : closestSegment[0];\n          }\n          this.createOrUpdateVertexFeature_(\n            vertex,\n            [node.feature],\n            [node.geometry],\n            this.snappedToVertex_,\n          );\n          const geometries = {};\n          geometries[getUid(node.geometry)] = true;\n          for (let i = 1, ii = nodes.length; i < ii; ++i) {\n            const segment = nodes[i].segment;\n            if (\n              (this.coordinatesEqual_(closestSegment[0], segment[0]) &&\n                this.coordinatesEqual_(closestSegment[1], segment[1])) ||\n              (this.coordinatesEqual_(closestSegment[0], segment[1]) &&\n                this.coordinatesEqual_(closestSegment[1], segment[0]))\n            ) {\n              const geometryUid = getUid(nodes[i].geometry);\n              if (!(geometryUid in geometries)) {\n                geometries[geometryUid] = true;\n                vertexSegments[getUid(segment)] = true;\n              }\n            } else {\n              break;\n            }\n          }\n        }\n\n        this.vertexSegments_ = vertexSegments;\n        return;\n      }\n    }\n    if (this.vertexFeature_) {\n      this.overlay_.getSource().removeFeature(this.vertexFeature_);\n      this.vertexFeature_ = null;\n    }\n  }\n\n  /**\n   * @param {SegmentData} segmentData Segment data.\n   * @param {import(\"../coordinate.js\").Coordinate} vertex Vertex.\n   * @return {boolean} A vertex was inserted.\n   * @private\n   */\n  insertVertex_(segmentData, vertex) {\n    const segment = segmentData.segment;\n    const feature = segmentData.feature;\n    const geometry = segmentData.geometry;\n    const depth = segmentData.depth;\n    const index = segmentData.index;\n    let coordinates;\n\n    while (vertex.length < geometry.getStride()) {\n      vertex.push(0);\n    }\n\n    switch (geometry.getType()) {\n      case 'MultiLineString':\n        coordinates = geometry.getCoordinates();\n        coordinates[depth[0]].splice(index + 1, 0, vertex);\n        break;\n      case 'Polygon':\n        coordinates = geometry.getCoordinates();\n        coordinates[depth[0]].splice(index + 1, 0, vertex);\n        break;\n      case 'MultiPolygon':\n        coordinates = geometry.getCoordinates();\n        coordinates[depth[1]][depth[0]].splice(index + 1, 0, vertex);\n        break;\n      case 'LineString':\n        coordinates = geometry.getCoordinates();\n        coordinates.splice(index + 1, 0, vertex);\n        break;\n      default:\n        return false;\n    }\n\n    this.setGeometryCoordinates_(geometry, coordinates);\n    const rTree = this.rBush_;\n    rTree.remove(segmentData);\n    this.updateSegmentIndices_(geometry, index, depth, 1);\n\n    /** @type {SegmentData} */\n    const newSegmentData = {\n      segment: [segment[0], vertex],\n      feature: feature,\n      geometry: geometry,\n      depth: depth,\n      index: index,\n    };\n\n    rTree.insert(boundingExtent(newSegmentData.segment), newSegmentData);\n    this.dragSegments_.push([newSegmentData, 1]);\n\n    /** @type {SegmentData} */\n    const newSegmentData2 = {\n      segment: [vertex, segment[1]],\n      feature: feature,\n      geometry: geometry,\n      depth: depth,\n      index: index + 1,\n    };\n\n    rTree.insert(boundingExtent(newSegmentData2.segment), newSegmentData2);\n    this.dragSegments_.push([newSegmentData2, 0]);\n    return true;\n  }\n\n  /**\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate The coordinate.\n   * @return {import(\"../coordinate.js\").Coordinate} The updated pointer coordinate.\n   * @private\n   */\n  updatePointer_(coordinate) {\n    if (coordinate) {\n      this.findInsertVerticesAndUpdateDragSegments_(coordinate);\n    }\n    return this.vertexFeature_?.getGeometry().getCoordinates();\n  }\n\n  /**\n   * Get the current pointer position.\n   * @return {import(\"../coordinate.js\").Coordinate | null} The current pointer coordinate.\n   */\n  getPoint() {\n    const coordinate = this.vertexFeature_?.getGeometry().getCoordinates();\n    if (!coordinate) {\n      return null;\n    }\n    return toUserCoordinate(\n      coordinate,\n      this.getMap().getView().getProjection(),\n    );\n  }\n\n  /**\n   * Check if a point can be removed from the current linestring or polygon at the current\n   * pointer position.\n   * @return {boolean} A point can be deleted at the current pointer position.\n   * @api\n   */\n  canRemovePoint() {\n    if (!this.vertexFeature_) {\n      return false;\n    }\n    if (\n      this.vertexFeature_\n        .get('geometries')\n        .every(\n          (geometry) =>\n            geometry.getType() === 'Circle' ||\n            geometry.getType().endsWith('Point'),\n        )\n    ) {\n      return false;\n    }\n    const coordinate = this.vertexFeature_.getGeometry().getCoordinates();\n    const segments = this.rBush_.getInExtent(boundingExtent([coordinate]));\n    return segments.some(\n      ({segment}) =>\n        this.coordinatesEqual_(segment[0], coordinate) ||\n        this.coordinatesEqual_(segment[1], coordinate),\n    );\n  }\n\n  /**\n   * Removes the vertex currently being pointed from the current linestring or polygon.\n   * @param {import('../coordinate.js').Coordinate} [coordinate] If provided, the pointer\n   * will be set to the provided coordinate. If not, the current pointer coordinate will be used.\n   * @return {boolean} True when a vertex was removed.\n   * @api\n   */\n  removePoint(coordinate) {\n    if (coordinate) {\n      coordinate = fromUserCoordinate(\n        coordinate,\n        this.getMap().getView().getProjection(),\n      );\n      this.updatePointer_(coordinate);\n    }\n    if (\n      !this.lastPointerEvent_ ||\n      (this.lastPointerEvent_ &&\n        this.lastPointerEvent_.type != MapBrowserEventType.POINTERDRAG)\n    ) {\n      const evt = this.lastPointerEvent_;\n      this.willModifyFeatures_(\n        evt,\n        this.dragSegments_.map(([segment]) => segment),\n      );\n      const removed = this.removeVertex_();\n      if (this.featuresBeingModified_) {\n        this.dispatchEvent(\n          new ModifyEvent(\n            ModifyEventType.MODIFYEND,\n            this.featuresBeingModified_,\n            evt,\n          ),\n        );\n      }\n\n      this.featuresBeingModified_ = null;\n      return removed;\n    }\n    return false;\n  }\n\n  /**\n   * Removes a vertex from all matching features.\n   * @return {boolean} True when a vertex was removed.\n   * @private\n   */\n  removeVertex_() {\n    const dragSegments = this.dragSegments_;\n    const segmentsByFeature = {};\n    let deleted = false;\n    let component, coordinates, dragSegment, geometry, i, index, left;\n    let newIndex, right, segmentData, uid;\n    for (i = dragSegments.length - 1; i >= 0; --i) {\n      dragSegment = dragSegments[i];\n      segmentData = dragSegment[0];\n      uid = getUid(segmentData.feature);\n      if (segmentData.depth) {\n        // separate feature components\n        uid += '-' + segmentData.depth.join('-');\n      }\n      if (!(uid in segmentsByFeature)) {\n        segmentsByFeature[uid] = {};\n      }\n      if (dragSegment[1] === 0) {\n        segmentsByFeature[uid].right = segmentData;\n        segmentsByFeature[uid].index = segmentData.index;\n      } else if (dragSegment[1] == 1) {\n        segmentsByFeature[uid].left = segmentData;\n        segmentsByFeature[uid].index = segmentData.index + 1;\n      }\n    }\n    for (uid in segmentsByFeature) {\n      right = segmentsByFeature[uid].right;\n      left = segmentsByFeature[uid].left;\n      index = segmentsByFeature[uid].index;\n      newIndex = index - 1;\n      if (left !== undefined) {\n        segmentData = left;\n      } else {\n        segmentData = right;\n      }\n      if (newIndex < 0) {\n        newIndex = 0;\n      }\n      geometry = segmentData.geometry;\n      coordinates = geometry.getCoordinates();\n      component = coordinates;\n      deleted = false;\n      switch (geometry.getType()) {\n        case 'MultiLineString':\n          if (coordinates[segmentData.depth[0]].length > 2) {\n            coordinates[segmentData.depth[0]].splice(index, 1);\n            deleted = true;\n          }\n          break;\n        case 'LineString':\n          if (coordinates.length > 2) {\n            coordinates.splice(index, 1);\n            deleted = true;\n          }\n          break;\n        case 'MultiPolygon':\n          component = component[segmentData.depth[1]];\n        /* falls through */\n        case 'Polygon':\n          component = component[segmentData.depth[0]];\n          if (component.length > 4) {\n            if (index == component.length - 1) {\n              index = 0;\n            }\n            component.splice(index, 1);\n            deleted = true;\n            if (index === 0) {\n              // close the ring again\n              component.pop();\n              component.push(component[0]);\n              newIndex = component.length - 1;\n            }\n          }\n          break;\n        default:\n        // pass\n      }\n\n      if (deleted) {\n        this.setGeometryCoordinates_(geometry, coordinates);\n        const segments = [];\n        if (left !== undefined) {\n          this.rBush_.remove(left);\n          segments.push(left.segment[0]);\n        }\n        if (right !== undefined) {\n          this.rBush_.remove(right);\n          segments.push(right.segment[1]);\n        }\n        if (left !== undefined && right !== undefined) {\n          /** @type {SegmentData} */\n          const newSegmentData = {\n            depth: segmentData.depth,\n            feature: segmentData.feature,\n            geometry: segmentData.geometry,\n            index: newIndex,\n            segment: segments,\n          };\n\n          this.rBush_.insert(\n            boundingExtent(newSegmentData.segment),\n            newSegmentData,\n          );\n        }\n        this.updateSegmentIndices_(geometry, index, segmentData.depth, -1);\n        if (this.vertexFeature_) {\n          this.overlay_.getSource().removeFeature(this.vertexFeature_);\n          this.vertexFeature_ = null;\n        }\n        dragSegments.length = 0;\n      }\n    }\n    return deleted;\n  }\n\n  /**\n   * Check if a point can be inserted to the current linestring or polygon at the current\n   * pointer position.\n   * @return {boolean} A point can be inserted at the current pointer position.\n   * @api\n   */\n  canInsertPoint() {\n    if (!this.vertexFeature_) {\n      return false;\n    }\n    if (\n      this.vertexFeature_\n        .get('geometries')\n        .every(\n          (geometry) =>\n            geometry.getType() === 'Circle' ||\n            geometry.getType().endsWith('Point'),\n        )\n    ) {\n      return false;\n    }\n    const coordinate = this.vertexFeature_.getGeometry().getCoordinates();\n    const segments = this.rBush_.getInExtent(boundingExtent([coordinate]));\n    return segments.some(\n      ({segment}) =>\n        !(\n          this.coordinatesEqual_(segment[0], coordinate) ||\n          this.coordinatesEqual_(segment[1], coordinate)\n        ),\n    );\n  }\n\n  /**\n   * Inserts the vertex currently being pointed to the current linestring or polygon.\n   * @param {import('../coordinate.js').Coordinate} [coordinate] If provided, the pointer\n   * will be set to the provided coordinate. If not, the current pointer coordinate will be used.\n   * @return {boolean} A vertex was inserted.\n   * @api\n   */\n  insertPoint(coordinate) {\n    const pixelCoordinate = coordinate\n      ? fromUserCoordinate(coordinate, this.getMap().getView().getProjection())\n      : this.vertexFeature_?.getGeometry().getCoordinates();\n    if (!pixelCoordinate) {\n      return false;\n    }\n    const insertVertices =\n      this.findInsertVerticesAndUpdateDragSegments_(pixelCoordinate);\n    return insertVertices.reduce(\n      (prev, segmentData) =>\n        prev || this.insertVertex_(segmentData, pixelCoordinate),\n      false,\n    );\n  }\n\n  /**\n   * @param {import(\"../geom/SimpleGeometry.js\").default} geometry Geometry.\n   * @param {Array} coordinates Coordinates.\n   * @private\n   */\n  setGeometryCoordinates_(geometry, coordinates) {\n    this.changingFeature_ = true;\n    geometry.setCoordinates(coordinates);\n    this.changingFeature_ = false;\n  }\n\n  /**\n   * @param {import(\"../geom/SimpleGeometry.js\").default} geometry Geometry.\n   * @param {number} index Index.\n   * @param {Array<number>|undefined} depth Depth.\n   * @param {number} delta Delta (1 or -1).\n   * @private\n   */\n  updateSegmentIndices_(geometry, index, depth, delta) {\n    this.rBush_.forEachInExtent(\n      geometry.getExtent(),\n      function (segmentDataMatch) {\n        if (\n          segmentDataMatch.geometry === geometry &&\n          (depth === undefined ||\n            segmentDataMatch.depth === undefined ||\n            equals(segmentDataMatch.depth, depth)) &&\n          segmentDataMatch.index > index\n        ) {\n          segmentDataMatch.index += delta;\n        }\n      },\n    );\n  }\n\n  /**\n   * @override\n   */\n  disposeInternal() {\n    super.disposeInternal();\n    if (this.featuresCollection_) {\n      this.featuresCollection_.removeEventListener(\n        CollectionEventType.ADD,\n        this.handleExternalCollectionAdd_,\n      );\n      this.featuresCollection_.removeEventListener(\n        CollectionEventType.REMOVE,\n        this.handleExternalCollectionRemove_,\n      );\n      //change and propertychange event handlers were placed on all features in the external\n      // collection, not just the ones that passed the filter.  Remove these too.\n      for (const feature of this.featuresCollection_.getArray()) {\n        feature.removeEventListener(\n          EventType.CHANGE,\n          this.handleFeatureChange_,\n        );\n        if (this.filterFunctionWasSupplied_) {\n          feature.removeEventListener(\n            ObjectEventType.PROPERTYCHANGE,\n            this.handleFeatureChange_,\n          );\n        }\n      }\n    } else if (this.source_) {\n      this.source_.removeEventListener(\n        VectorEventType.ADDFEATURE,\n        this.handleSourceAdd_,\n      );\n      this.source_.removeEventListener(\n        VectorEventType.REMOVEFEATURE,\n        this.handleSourceRemove_,\n      );\n      //change and propertychange event handlers were placed on all features in the source, not\n      // just the ones that passed the filter.  Remove these too.\n      for (const feature of this.source_.getFeatures()) {\n        feature.removeEventListener(\n          EventType.CHANGE,\n          this.handleFeatureChange_,\n        );\n        if (this.filterFunctionWasSupplied_) {\n          feature.removeEventListener(\n            ObjectEventType.PROPERTYCHANGE,\n            this.handleFeatureChange_,\n          );\n        }\n      }\n    }\n  }\n}\n\n/**\n * @param {SegmentData} a The first segment data.\n * @param {SegmentData} b The second segment data.\n * @return {number} The difference in indexes.\n */\nfunction compareIndexes(a, b) {\n  return a.index - b.index;\n}\n\n/**\n * Returns the distance from a point to a line segment.\n *\n * @param {import(\"../coordinate.js\").Coordinate} pointCoordinates The coordinates of the point from\n *        which to calculate the distance.\n * @param {SegmentData} segmentData The object describing the line\n *        segment we are calculating the distance to.\n * @param {import(\"../proj/Projection.js\").default} projection The view projection.\n * @return {number} The square of the distance between a point and a line segment.\n */\nfunction projectedDistanceToSegmentDataSquared(\n  pointCoordinates,\n  segmentData,\n  projection,\n) {\n  const geometry = segmentData.geometry;\n\n  if (geometry.getType() === 'Circle') {\n    let circleGeometry = /** @type {import(\"../geom/Circle.js\").default} */ (\n      geometry\n    );\n\n    if (segmentData.index === CIRCLE_CIRCUMFERENCE_INDEX) {\n      const userProjection = getUserProjection();\n      if (userProjection) {\n        circleGeometry = circleGeometry\n          .clone()\n          .transform(userProjection, projection);\n      }\n      const distanceToCenterSquared = squaredCoordinateDistance(\n        circleGeometry.getCenter(),\n        fromUserCoordinate(pointCoordinates, projection),\n      );\n      const distanceToCircumference =\n        Math.sqrt(distanceToCenterSquared) - circleGeometry.getRadius();\n      return distanceToCircumference * distanceToCircumference;\n    }\n  }\n\n  const coordinate = fromUserCoordinate(pointCoordinates, projection);\n  tempSegment[0] = fromUserCoordinate(segmentData.segment[0], projection);\n  tempSegment[1] = fromUserCoordinate(segmentData.segment[1], projection);\n  return squaredDistanceToSegment(coordinate, tempSegment);\n}\n\n/**\n * Returns the point closest to a given line segment.\n *\n * @param {import(\"../coordinate.js\").Coordinate} pointCoordinates The point to which a closest point\n *        should be found.\n * @param {SegmentData} segmentData The object describing the line\n *        segment which should contain the closest point.\n * @param {import(\"../proj/Projection.js\").default} projection The view projection.\n * @return {import(\"../coordinate.js\").Coordinate} The point closest to the specified line segment.\n */\nfunction closestOnSegmentData(pointCoordinates, segmentData, projection) {\n  const geometry = segmentData.geometry;\n\n  if (\n    geometry.getType() === 'Circle' &&\n    segmentData.index === CIRCLE_CIRCUMFERENCE_INDEX\n  ) {\n    let circleGeometry = /** @type {import(\"../geom/Circle.js\").default} */ (\n      geometry\n    );\n    const userProjection = getUserProjection();\n    if (userProjection) {\n      circleGeometry = circleGeometry\n        .clone()\n        .transform(userProjection, projection);\n    }\n    return toUserCoordinate(\n      circleGeometry.getClosestPoint(\n        fromUserCoordinate(pointCoordinates, projection),\n      ),\n      projection,\n    );\n  }\n  const coordinate = fromUserCoordinate(pointCoordinates, projection);\n  tempSegment[0] = fromUserCoordinate(segmentData.segment[0], projection);\n  tempSegment[1] = fromUserCoordinate(segmentData.segment[1], projection);\n  return toUserCoordinate(\n    closestOnSegment(coordinate, tempSegment),\n    projection,\n  );\n}\n\n/**\n * @return {import(\"../style/Style.js\").StyleFunction} Styles.\n */\nfunction getDefaultStyleFunction() {\n  const style = createEditingStyle();\n  return function (feature, resolution) {\n    return style['Point'];\n  };\n}\n\nexport default Modify;\n","/**\n * @module ol/interaction/Select\n */\nimport Collection from '../Collection.js';\nimport CollectionEventType from '../CollectionEventType.js';\nimport Feature from '../Feature.js';\nimport {extend} from '../array.js';\nimport Event from '../events/Event.js';\nimport {never, shiftKeyOnly, singleClick} from '../events/condition.js';\nimport {TRUE} from '../functions.js';\nimport VectorLayer from '../layer/Vector.js';\nimport {createEditingStyle} from '../style/Style.js';\nimport {getUid} from '../util.js';\nimport Interaction from './Interaction.js';\n\n/**\n * @enum {string}\n */\nconst SelectEventType = {\n  /**\n   * Triggered when feature(s) has been (de)selected.\n   * @event SelectEvent#select\n   * @api\n   */\n  SELECT: 'select',\n};\n\n/**\n * A function that takes a {@link module:ol/Feature~Feature} and returns `true` if the feature may be\n * selected or `false` otherwise.\n * @typedef {function(import(\"../Feature.js\").default, import(\"../layer/Layer.js\").default<import(\"../source/Source.js\").default>):boolean} FilterFunction\n */\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [addCondition] A function\n * that takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * boolean to indicate whether that event should be handled.\n * By default, this is {@link module:ol/events/condition.never}. Use this if you\n * want to use different events for add and remove instead of `toggle`.\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. This is the event\n * for the selected features as a whole. By default, this is\n * {@link module:ol/events/condition.singleClick}. Clicking on a feature selects that\n * feature and removes any that were in the selection. Clicking outside any\n * feature removes all from the selection.\n * See `toggle`, `add`, `remove` options for adding/removing extra features to/\n * from the selection.\n * @property {Array<import(\"../layer/Layer.js\").default>|function(import(\"../layer/Layer.js\").default<import(\"../source/Source.js\").default>): boolean} [layers]\n * A list of layers from which features should be selected. Alternatively, a\n * filter function can be provided. The function will be called for each layer\n * in the map and should return `true` for layers that you want to be\n * selectable. If the option is absent, all visible layers will be considered\n * selectable.\n * @property {import(\"../style/Style.js\").StyleLike|null} [style]\n * Style for the selected features. By default the default edit style is used\n * (see {@link module:ol/style/Style~Style}). Set to `null` if this interaction should not apply\n * any style changes for selected features.\n * If set to a falsey value, the selected feature's style will not change.\n * @property {import(\"../events/condition.js\").Condition} [removeCondition] A function\n * that takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * boolean to indicate whether that event should be handled.\n * By default, this is {@link module:ol/events/condition.never}. Use this if you\n * want to use different events for add and remove instead of `toggle`.\n * @property {import(\"../events/condition.js\").Condition} [toggleCondition] A function\n * that takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * boolean to indicate whether that event should be handled. This is in addition\n * to the `condition` event. By default,\n * {@link module:ol/events/condition.shiftKeyOnly}, i.e. pressing `shift` as\n * well as the `condition` event, adds that feature to the current selection if\n * it is not currently selected, and removes it if it is. See `add` and `remove`\n * if you want to use different events instead of a toggle.\n * @property {boolean} [multi=false] A boolean that determines if the default\n * behaviour should select only single features or all (overlapping) features at\n * the clicked map position. The default of `false` means single select.\n * @property {Collection<Feature>} [features]\n * Collection where the interaction will place selected features. Optional. If\n * not set the interaction will create a collection. In any case the collection\n * used by the interaction is returned by\n * {@link module:ol/interaction/Select~Select#getFeatures}.\n * @property {FilterFunction} [filter] A function\n * that takes a {@link module:ol/Feature~Feature} and a\n * {@link module:ol/layer/Layer~Layer} and returns `true` if the feature may be\n * selected or `false` otherwise.\n * @property {number} [hitTolerance=0] Hit-detection tolerance. Pixels inside\n * the radius around the given position will be checked for features.\n */\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/interaction/Select~Select} instances are instances of\n * this type.\n */\nexport class SelectEvent extends Event {\n  /**\n   * @param {SelectEventType} type The event type.\n   * @param {Array<import(\"../Feature.js\").default>} selected Selected features.\n   * @param {Array<import(\"../Feature.js\").default>} deselected Deselected features.\n   * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Associated\n   *     {@link module:ol/MapBrowserEvent~MapBrowserEvent}.\n   */\n  constructor(type, selected, deselected, mapBrowserEvent) {\n    super(type);\n\n    /**\n     * Selected features array.\n     * @type {Array<import(\"../Feature.js\").default>}\n     * @api\n     */\n    this.selected = selected;\n\n    /**\n     * Deselected features array.\n     * @type {Array<import(\"../Feature.js\").default>}\n     * @api\n     */\n    this.deselected = deselected;\n\n    /**\n     * Associated {@link module:ol/MapBrowserEvent~MapBrowserEvent}.\n     * @type {import(\"../MapBrowserEvent.js\").default}\n     * @api\n     */\n    this.mapBrowserEvent = mapBrowserEvent;\n  }\n}\n\n/**\n * Original feature styles to reset to when features are no longer selected.\n * @type {Object<number, import(\"../style/Style.js\").default|Array<import(\"../style/Style.js\").default>|import(\"../style/Style.js\").StyleFunction>}\n */\nconst originalFeatureStyles = {};\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types|\n *     'change:active', import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<'select', SelectEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"../ObjectEventType.js\").Types|\n *     'change:active'|'select', Return>} SelectOnSignature\n */\n\n/**\n * @classdesc\n * Interaction for selecting vector features. By default, selected features are\n * styled differently, so this interaction can be used for visual highlighting,\n * as well as selecting features for other actions, such as modification or\n * output. There are three ways of controlling which features are selected:\n * using the browser event as defined by the `condition` and optionally the\n * `toggle`, `add`/`remove`, and `multi` options; a `layers` filter; and a\n * further feature filter using the `filter` option.\n *\n * @fires SelectEvent\n * @api\n */\nclass Select extends Interaction {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    super();\n\n    /***\n     * @type {SelectOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {SelectOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {SelectOnSignature<void>}\n     */\n    this.un;\n\n    options = options ? options : {};\n\n    /**\n     * @private\n     */\n    this.boundAddFeature_ = this.addFeature_.bind(this);\n\n    /**\n     * @private\n     */\n    this.boundRemoveFeature_ = this.removeFeature_.bind(this);\n\n    /**\n     * @private\n     * @type {import(\"../events/condition.js\").Condition}\n     */\n    this.condition_ = options.condition ? options.condition : singleClick;\n\n    /**\n     * @private\n     * @type {import(\"../events/condition.js\").Condition}\n     */\n    this.addCondition_ = options.addCondition ? options.addCondition : never;\n\n    /**\n     * @private\n     * @type {import(\"../events/condition.js\").Condition}\n     */\n    this.removeCondition_ = options.removeCondition\n      ? options.removeCondition\n      : never;\n\n    /**\n     * @private\n     * @type {import(\"../events/condition.js\").Condition}\n     */\n    this.toggleCondition_ = options.toggleCondition\n      ? options.toggleCondition\n      : shiftKeyOnly;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.multi_ = options.multi ? options.multi : false;\n\n    /**\n     * @private\n     * @type {FilterFunction}\n     */\n    this.filter_ = options.filter ? options.filter : TRUE;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.hitTolerance_ = options.hitTolerance ? options.hitTolerance : 0;\n\n    /**\n     * @private\n     * @type {import(\"../style/Style.js\").default|Array<import(\"../style/Style.js\").default>|import(\"../style/Style.js\").StyleFunction|null}\n     */\n    this.style_ =\n      options.style !== undefined ? options.style : getDefaultStyleFunction();\n\n    /**\n     * @private\n     * @type {Collection<Feature>}\n     */\n    this.features_ = options.features || new Collection();\n\n    /** @type {function(import(\"../layer/Layer.js\").default<import(\"../source/Source.js\").default>): boolean} */\n    let layerFilter;\n    if (options.layers) {\n      if (typeof options.layers === 'function') {\n        layerFilter = options.layers;\n      } else {\n        const layers = options.layers;\n        layerFilter = function (layer) {\n          return layers.includes(layer);\n        };\n      }\n    } else {\n      layerFilter = TRUE;\n    }\n\n    /**\n     * @private\n     * @type {function(import(\"../layer/Layer.js\").default<import(\"../source/Source.js\").default>): boolean}\n     */\n    this.layerFilter_ = layerFilter;\n\n    /**\n     * An association between selected feature (key)\n     * and layer (value)\n     * @private\n     * @type {Object<string, import(\"../layer/Layer.js\").default>}\n     */\n    this.featureLayerAssociation_ = {};\n  }\n\n  /**\n   * @param {import(\"../Feature.js\").default} feature Feature.\n   * @param {import(\"../layer/Layer.js\").default} layer Layer.\n   * @private\n   */\n  addFeatureLayerAssociation_(feature, layer) {\n    this.featureLayerAssociation_[getUid(feature)] = layer;\n  }\n\n  /**\n   * Get the selected features.\n   * @return {Collection<Feature>} Features collection.\n   * @api\n   */\n  getFeatures() {\n    return this.features_;\n  }\n\n  /**\n   * Returns the Hit-detection tolerance.\n   * @return {number} Hit tolerance in pixels.\n   * @api\n   */\n  getHitTolerance() {\n    return this.hitTolerance_;\n  }\n\n  /**\n   * Returns the associated {@link module:ol/layer/Vector~VectorLayer vector layer} of\n   * a selected feature.\n   * @param {import(\"../Feature.js\").default} feature Feature\n   * @return {import('../layer/Vector.js').default} Layer.\n   * @api\n   */\n  getLayer(feature) {\n    return /** @type {import('../layer/Vector.js').default} */ (\n      this.featureLayerAssociation_[getUid(feature)]\n    );\n  }\n\n  /**\n   * Hit-detection tolerance. Pixels inside the radius around the given position\n   * will be checked for features.\n   * @param {number} hitTolerance Hit tolerance in pixels.\n   * @api\n   */\n  setHitTolerance(hitTolerance) {\n    this.hitTolerance_ = hitTolerance;\n  }\n\n  /**\n   * Remove the interaction from its current map, if any,  and attach it to a new\n   * map, if any. Pass `null` to just remove the interaction from the current map.\n   * @param {import(\"../Map.js\").default|null} map Map.\n   * @api\n   * @override\n   */\n  setMap(map) {\n    const currentMap = this.getMap();\n    if (currentMap && this.style_) {\n      this.features_.forEach(this.restorePreviousStyle_.bind(this));\n    }\n    super.setMap(map);\n    if (map) {\n      this.features_.addEventListener(\n        CollectionEventType.ADD,\n        this.boundAddFeature_,\n      );\n      this.features_.addEventListener(\n        CollectionEventType.REMOVE,\n        this.boundRemoveFeature_,\n      );\n\n      if (this.style_) {\n        this.features_.forEach(this.applySelectedStyle_.bind(this));\n      }\n    } else {\n      this.features_.removeEventListener(\n        CollectionEventType.ADD,\n        this.boundAddFeature_,\n      );\n      this.features_.removeEventListener(\n        CollectionEventType.REMOVE,\n        this.boundRemoveFeature_,\n      );\n    }\n  }\n\n  /**\n   * @param {import(\"../Collection.js\").CollectionEvent<Feature>} evt Event.\n   * @private\n   */\n  addFeature_(evt) {\n    const feature = evt.element;\n    if (this.style_) {\n      this.applySelectedStyle_(feature);\n    }\n    if (!this.getLayer(feature)) {\n      const layer = this.findLayerOfFeature_(feature);\n      if (layer) {\n        this.addFeatureLayerAssociation_(feature, layer);\n      }\n    }\n  }\n\n  /**\n   * @param {import(\"../Collection.js\").CollectionEvent<Feature>} evt Event.\n   * @private\n   */\n  removeFeature_(evt) {\n    if (this.style_) {\n      this.restorePreviousStyle_(evt.element);\n    }\n    this.removeFeatureLayerAssociation_(evt.element);\n  }\n\n  /**\n   * @param {Feature} feature Feature of which to get the layer\n   * @return {VectorLayer} layer, if one was found.\n   * @private\n   */\n  findLayerOfFeature_(feature) {\n    const layer = /** @type {VectorLayer} */ (\n      this.getMap()\n        .getAllLayers()\n        .find(function (layer) {\n          if (\n            layer instanceof VectorLayer &&\n            layer.getSource() &&\n            layer.getSource().hasFeature(feature)\n          ) {\n            return layer;\n          }\n        })\n    );\n    return layer;\n  }\n\n  /**\n   * @return {import(\"../style/Style.js\").StyleLike|null} Select style.\n   */\n  getStyle() {\n    return this.style_;\n  }\n\n  /**\n   * @param {Feature} feature Feature\n   * @private\n   */\n  applySelectedStyle_(feature) {\n    const key = getUid(feature);\n    if (!(key in originalFeatureStyles)) {\n      originalFeatureStyles[key] = feature.getStyle();\n    }\n    feature.setStyle(this.style_);\n  }\n\n  /**\n   * @param {Feature} feature Feature\n   * @private\n   */\n  restorePreviousStyle_(feature) {\n    const interactions = this.getMap().getInteractions().getArray();\n    for (let i = interactions.length - 1; i >= 0; --i) {\n      const interaction = interactions[i];\n      if (\n        interaction !== this &&\n        interaction instanceof Select &&\n        interaction.getStyle() &&\n        interaction.getFeatures().getArray().lastIndexOf(feature) !== -1\n      ) {\n        feature.setStyle(interaction.getStyle());\n        return;\n      }\n    }\n\n    const key = getUid(feature);\n    feature.setStyle(originalFeatureStyles[key]);\n    delete originalFeatureStyles[key];\n  }\n\n  /**\n   * @param {Feature} feature Feature.\n   * @private\n   */\n  removeFeatureLayerAssociation_(feature) {\n    delete this.featureLayerAssociation_[getUid(feature)];\n  }\n\n  /**\n   * Try to select a feature as if it was clicked and `addCondition` evaluated to True.\n   * Unlike modifying `select.getFeatures()` directly, this respects the `filter` and `layers` options (except `multi`, which is ignored).\n   * The {@link module:ol/interaction/Select~SelectEvent} fired by this won't have a mapBrowserEvent property\n   * @param {Feature} feature The feature to select\n   * @return {boolean} True if the feature was selected\n   * @api\n   */\n  selectFeature(feature) {\n    const layer = this.findLayerOfFeature_(feature);\n    if (!this.layerFilter_(layer) || !this.filter_(feature, layer)) {\n      return false;\n    }\n    const features = this.getFeatures();\n    if (features.getArray().includes(feature)) {\n      return false;\n    }\n    this.addFeatureLayerAssociation_(feature, layer);\n    features.push(feature);\n    this.dispatchEvent(\n      new SelectEvent(SelectEventType.SELECT, [feature], [], undefined),\n    );\n    return true;\n  }\n\n  /**\n   * Try to deselect a feature as if it was clicked.\n   * Compared to `select.getFeatures().remove(feature)` this causes a SelectEvent.\n   * The {@link module:ol/interaction/Select~SelectEvent} fired by this won't have a mapBrowserEvent property\n   * @param {Feature} feature The feature to deselect\n   * @return {boolean} True if the feature was deselected\n   * @api\n   */\n  deselectFeature(feature) {\n    const features = this.getFeatures();\n    const index = features.getArray().indexOf(feature);\n    if (index === -1) {\n      return false;\n    }\n    features.removeAt(index);\n    this.dispatchEvent(\n      new SelectEvent(SelectEventType.SELECT, [], [feature], undefined),\n    );\n    return true;\n  }\n\n  /**\n   * Try to toggle a feature as if it was clicked and `toggleCondition` was True.\n   * Unlike modifying `select.getFeatures()` directly, this respects the `filter` and `layers` options (except `multi`, which is ignored).\n   * The {@link module:ol/interaction/Select~SelectEvent} fired by this won't have a mapBrowserEvent property\n   * @param {Feature} feature The feature to deselect\n   * @api\n   */\n  toggleFeature(feature) {\n    if (!this.deselectFeature(feature)) {\n      this.selectFeature(feature);\n    }\n  }\n\n  /**\n   * Deselect all features as if a user deselected them.\n   * Compared to `select.getFeatures().clear()` this causes a SelectEvent.\n   * The {@link module:ol/interaction/Select~SelectEvent} fired by this won't have a mapBrowserEvent property\n   * @api\n   */\n  clearSelection() {\n    const features = this.getFeatures();\n    if (features.getLength() !== 0) {\n      const deselected = features.getArray().slice(); // shallow copy\n      features.clear();\n      this.dispatchEvent(\n        new SelectEvent(SelectEventType.SELECT, [], deselected, undefined),\n      );\n    }\n  }\n\n  /**\n   * Handles the {@link module:ol/MapBrowserEvent~MapBrowserEvent map browser event} and may change the\n   * selected state of features.\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 add = this.addCondition_(mapBrowserEvent);\n    const remove = this.removeCondition_(mapBrowserEvent);\n    const toggle = this.toggleCondition_(mapBrowserEvent);\n    const set = !add && !remove && !toggle;\n    const map = mapBrowserEvent.map;\n    const features = this.getFeatures();\n\n    /**\n     * @type {Array<Feature>}\n     */\n    const deselected = [];\n\n    /**\n     * @type {Array<Feature>}\n     */\n    const selected = [];\n\n    if (set) {\n      // Replace the currently selected feature(s) with the feature(s) at the\n      // pixel, or clear the selected feature(s) if there is no feature at\n      // the pixel.\n      map.forEachFeatureAtPixel(\n        mapBrowserEvent.pixel,\n        (feature, layer) => {\n          if (!(feature instanceof Feature) || !this.filter_(feature, layer)) {\n            return;\n          }\n          this.addFeatureLayerAssociation_(feature, layer);\n          selected.push(feature);\n          return !this.multi_;\n        },\n        {\n          layerFilter: this.layerFilter_,\n          hitTolerance: this.hitTolerance_,\n        },\n      );\n\n      for (let i = features.getLength() - 1; i >= 0; --i) {\n        const feature = features.item(i);\n        const index = selected.indexOf(feature);\n        if (index === -1) {\n          features.removeAt(i);\n          deselected.push(feature);\n        } else {\n          // feature is already selected\n          selected.splice(index, 1);\n        }\n      }\n      if (selected.length !== 0) {\n        features.extend(selected);\n      }\n    } else {\n      // Modify the currently selected feature(s).\n      map.forEachFeatureAtPixel(\n        mapBrowserEvent.pixel,\n        (feature, layer) => {\n          if (!(feature instanceof Feature) || !this.filter_(feature, layer)) {\n            return;\n          }\n          const hasFeature = features.getArray().includes(feature);\n          if (hasFeature && (remove || toggle)) {\n            deselected.push(feature);\n          } else if (!hasFeature && (add || toggle)) {\n            this.addFeatureLayerAssociation_(feature, layer);\n            selected.push(feature);\n          }\n          return !this.multi_; // stop if not multi\n        },\n        {\n          layerFilter: this.layerFilter_,\n          hitTolerance: this.hitTolerance_,\n        },\n      );\n      for (let j = deselected.length - 1; j >= 0; --j) {\n        features.remove(deselected[j]);\n      }\n      features.extend(selected);\n    }\n    if (selected.length > 0 || deselected.length > 0) {\n      this.dispatchEvent(\n        new SelectEvent(\n          SelectEventType.SELECT,\n          selected,\n          deselected,\n          mapBrowserEvent,\n        ),\n      );\n    }\n    return true;\n  }\n}\n\n/**\n * @return {import(\"../style/Style.js\").StyleFunction} Styles.\n */\nfunction getDefaultStyleFunction() {\n  const styles = createEditingStyle();\n  extend(styles['Polygon'], styles['LineString']);\n  extend(styles['GeometryCollection'], styles['LineString']);\n\n  return function (feature) {\n    if (!feature.getGeometry()) {\n      return null;\n    }\n    return styles[feature.getGeometry().getType()];\n  };\n}\n\nexport default Select;\n","/**\n * @module ol/events/SnapEvent\n */\nimport Event from './Event.js';\n\n/**\n * @enum {string}\n */\nexport const SnapEventType = {\n  /**\n   * Triggered upon snapping to vertex or edge\n   * @event SnapEvent#snap\n   * @api\n   */\n  SNAP: 'snap',\n  /**\n   * Triggered if no longer snapped\n   * @event SnapEvent#unsnap\n   * @api\n   */\n  UNSNAP: 'unsnap',\n};\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/interaction/Snap~Snap} instances are instances of this\n */\nexport class SnapEvent extends Event {\n  /**\n   * @param {SnapEventType} type Type.\n   * @param {Object} options Options.\n   * @param {import(\"../coordinate.js\").Coordinate} options.vertex The snapped vertex.\n   * @param {import(\"../coordinate.js\").Coordinate} options.vertexPixel The pixel of the snapped vertex.\n   * @param {import(\"../Feature.js\").default} options.feature The feature being snapped.\n   * @param {Array<import(\"../coordinate.js\").Coordinate>|null} options.segment Segment, or `null` if snapped to a vertex.\n   */\n  constructor(type, options) {\n    super(type);\n    /**\n     * The Map coordinate of the snapped point.\n     * @type {import(\"../coordinate.js\").Coordinate}\n     * @api\n     */\n    this.vertex = options.vertex;\n    /**\n     * The Map pixel of the snapped point.\n     * @type {Array<number>&Array<number>}\n     * @api\n     */\n    this.vertexPixel = options.vertexPixel;\n    /**\n     * The feature closest to the snapped point.\n     * @type {import(\"../Feature.js\").default<import(\"../geom/Geometry.js\").default>}\n     * @api\n     */\n    this.feature = options.feature;\n    /**\n     * The segment closest to the snapped point, if snapped to a segment.\n     * @type {Array<import(\"../coordinate.js\").Coordinate>|null}\n     * @api\n     */\n    this.segment = options.segment;\n  }\n}\n","/**\n * @module ol/interaction/Snap\n */\nimport CollectionEventType from '../CollectionEventType.js';\nimport {\n  closestOnCircle,\n  closestOnSegment,\n  squaredDistance,\n} from '../coordinate.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport EventType from '../events/EventType.js';\nimport {SnapEvent, SnapEventType} from '../events/SnapEvent.js';\nimport {\n  boundingExtent,\n  buffer,\n  createEmpty,\n  intersects as intersectsExtent,\n} from '../extent.js';\nimport {FALSE, TRUE} from '../functions.js';\nimport {fromCircle} from '../geom/Polygon.js';\nimport {getIntersectionPoint} from '../geom/flat/segments.js';\nimport {clear} from '../obj.js';\nimport {\n  fromUserCoordinate,\n  getUserProjection,\n  toUserCoordinate,\n  toUserExtent,\n} from '../proj.js';\nimport VectorEventType from '../source/VectorEventType.js';\nimport RBush from '../structs/RBush.js';\nimport {getUid} from '../util.js';\nimport PointerInteraction from './Pointer.js';\n\n/**\n * @typedef {Array<import(\"../coordinate.js\").Coordinate>} Segment\n * An array of two coordinates representing a line segment, or an array of one\n * coordinate representing a point.\n */\n\n/**\n * @typedef {Object} SegmentData\n * @property {import(\"../Feature.js\").default} feature Feature.\n * @property {import(\"../Feature.js\").default} [intersectionFeature] Feature which intersects.\n * @property {Segment} segment Segment.\n */\n\n/**\n * @template {import(\"../geom/Geometry.js\").default} [GeometryType=import(\"../geom/Geometry.js\").default]\n * @typedef {(geometry: GeometryType, projection?: import(\"../proj/Projection.js\").default) => Array<Segment>} Segmenter\n * A function taking a {@link module:ol/geom/Geometry~Geometry} as argument and returning an array of {@link Segment}s.\n */\n\n/**\n * Each segmenter specified here will override the default segmenter for the\n * corresponding geometry type. To exclude all geometries of a specific geometry type from being snapped to,\n * set the segmenter to `null`.\n * @typedef {Object} Segmenters\n * @property {Segmenter<import(\"../geom/Point.js\").default>|null} [Point] Point segmenter.\n * @property {Segmenter<import(\"../geom/LineString.js\").default>|null} [LineString] LineString segmenter.\n * @property {Segmenter<import(\"../geom/Polygon.js\").default>|null} [Polygon] Polygon segmenter.\n * @property {Segmenter<import(\"../geom/Circle.js\").default>|null} [Circle] Circle segmenter.\n * @property {Segmenter<import(\"../geom/GeometryCollection.js\").default>|null} [GeometryCollection] GeometryCollection segmenter.\n * @property {Segmenter<import(\"../geom/MultiPoint.js\").default>|null} [MultiPoint] MultiPoint segmenter.\n * @property {Segmenter<import(\"../geom/MultiLineString.js\").default>|null} [MultiLineString] MultiLineString segmenter.\n * @property {Segmenter<import(\"../geom/MultiPolygon.js\").default>|null} [MultiPolygon] MultiPolygon segmenter.\n */\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../Collection.js\").default<import(\"../Feature.js\").default>} [features] Snap to these features. Either this option or source should be provided.\n * @property {import(\"../source/Vector.js\").default} [source] Snap to features from this source. Either this option or features should be provided\n * @property {boolean} [edge=true] Snap to edges.\n * @property {boolean} [vertex=true] Snap to vertices.\n * @property {boolean} [intersection=false] Snap to intersections between segments.\n * @property {number} [pixelTolerance=10] Pixel tolerance for considering the pointer close enough to a segment or\n * vertex for snapping.\n * @property {Segmenters} [segmenters] Custom segmenters by {@link module:ol/geom/Geometry~Type}. By default, the\n * following segmenters are used:\n *   - `Point`: A one-dimensional segment (e.g. `[[10, 20]]`) representing the point.\n *   - `LineString`: One two-dimensional segment (e.g. `[[10, 20], [30, 40]]`) for each segment of the linestring.\n *   - `Polygon`: One two-dimensional segment for each segment of the exterior ring and the interior rings.\n *   - `Circle`: One two-dimensional segment for each segment of a regular polygon with 32 points representing the circle circumference.\n *   - `GeometryCollection`: All segments of the contained geometries.\n *   - `MultiPoint`: One one-dimensional segment for each point.\n *   - `MultiLineString`: One two-dimensional segment for each segment of the linestrings.\n *   - `MultiPolygon`: One two-dimensional segment for each segment of the polygons.\n */\n\n/**\n * Information about the last snapped state.\n * @typedef {Object} SnappedInfo\n * @property {import(\"../coordinate.js\").Coordinate|null} vertex - The snapped vertex.\n * @property {import(\"../pixel.js\").Pixel|null} vertexPixel - The pixel of the snapped vertex.\n * @property {import(\"../Feature.js\").default|null} feature - The feature being snapped.\n * @property {Segment|null} segment - Segment, or `null` if snapped to a vertex.\n */\n\n/***\n * @type {Object<string, Segmenter>}\n */\nconst GEOMETRY_SEGMENTERS = {\n  /**\n   * @param {import(\"../geom/Circle.js\").default} geometry Geometry.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {Array<Segment>} Segments\n   */\n  Circle(geometry, projection) {\n    let circleGeometry = geometry;\n    const userProjection = getUserProjection();\n    if (userProjection) {\n      circleGeometry = circleGeometry\n        .clone()\n        .transform(userProjection, projection);\n    }\n    const polygon = fromCircle(circleGeometry);\n    if (userProjection) {\n      polygon.transform(projection, userProjection);\n    }\n    return GEOMETRY_SEGMENTERS.Polygon(polygon);\n  },\n\n  /**\n   * @param {import(\"../geom/GeometryCollection.js\").default} geometry Geometry.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {Array<Segment>} Segments\n   */\n  GeometryCollection(geometry, projection) {\n    /** @type {Array<Array<Segment>>} */\n    const segments = [];\n    const geometries = geometry.getGeometriesArray();\n    for (let i = 0; i < geometries.length; ++i) {\n      const segmenter = this[geometries[i].getType()];\n      if (segmenter) {\n        segments.push(segmenter(geometries[i], projection));\n      }\n    }\n    return segments.flat();\n  },\n\n  /**\n   * @param {import(\"../geom/LineString.js\").default} geometry Geometry.\n   * @return {Array<Segment>} Segments\n   */\n  LineString(geometry) {\n    /** @type {Array<Segment>} */\n    const segments = [];\n    const coordinates = geometry.getFlatCoordinates();\n    const stride = geometry.getStride();\n    for (let i = 0, ii = coordinates.length - stride; i < ii; i += stride) {\n      segments.push([\n        coordinates.slice(i, i + 2),\n        coordinates.slice(i + stride, i + stride + 2),\n      ]);\n    }\n    return segments;\n  },\n\n  /**\n   * @param {import(\"../geom/MultiLineString.js\").default} geometry Geometry.\n   * @return {Array<Segment>} Segments\n   */\n  MultiLineString(geometry) {\n    /** @type {Array<Segment>} */\n    const segments = [];\n    const coordinates = geometry.getFlatCoordinates();\n    const stride = geometry.getStride();\n    const ends = geometry.getEnds();\n    let offset = 0;\n    for (let i = 0, ii = ends.length; i < ii; ++i) {\n      const end = ends[i];\n      for (let j = offset, jj = end - stride; j < jj; j += stride) {\n        segments.push([\n          coordinates.slice(j, j + 2),\n          coordinates.slice(j + stride, j + stride + 2),\n        ]);\n      }\n      offset = end;\n    }\n    return segments;\n  },\n\n  /**\n   * @param {import(\"../geom/MultiPoint.js\").default} geometry Geometry.\n   * @return {Array<Segment>} Segments\n   */\n  MultiPoint(geometry) {\n    /** @type {Array<Segment>} */\n    const segments = [];\n    const coordinates = geometry.getFlatCoordinates();\n    const stride = geometry.getStride();\n    for (let i = 0, ii = coordinates.length; i < ii; i += stride) {\n      segments.push([coordinates.slice(i, i + 2)]);\n    }\n    return segments;\n  },\n\n  /**\n   * @param {import(\"../geom/MultiPolygon.js\").default} geometry Geometry.\n   * @return {Array<Segment>} Segments\n   */\n  MultiPolygon(geometry) {\n    /** @type {Array<Segment>} */\n    const segments = [];\n    const coordinates = geometry.getFlatCoordinates();\n    const stride = geometry.getStride();\n    const endss = geometry.getEndss();\n    let offset = 0;\n    for (let i = 0, ii = endss.length; i < ii; ++i) {\n      const ends = endss[i];\n      for (let j = 0, jj = ends.length; j < jj; ++j) {\n        const end = ends[j];\n        for (let k = offset, kk = end - stride; k < kk; k += stride) {\n          segments.push([\n            coordinates.slice(k, k + 2),\n            coordinates.slice(k + stride, k + stride + 2),\n          ]);\n        }\n        offset = end;\n      }\n    }\n    return segments;\n  },\n\n  /**\n   * @param {import(\"../geom/Point.js\").default} geometry Geometry.\n   * @return {Array<Segment>} Segments\n   */\n  Point(geometry) {\n    return [[geometry.getFlatCoordinates().slice(0, 2)]];\n  },\n\n  /**\n   * @param {import(\"../geom/Polygon.js\").default} geometry Geometry.\n   * @return {Array<Segment>} Segments\n   */\n  Polygon(geometry) {\n    /** @type {Array<Segment>} */\n    const segments = [];\n    const coordinates = geometry.getFlatCoordinates();\n    const stride = geometry.getStride();\n    const ends = geometry.getEnds();\n    let offset = 0;\n    for (let i = 0, ii = ends.length; i < ii; ++i) {\n      const end = ends[i];\n      for (let j = offset, jj = end - stride; j < jj; j += stride) {\n        segments.push([\n          coordinates.slice(j, j + 2),\n          coordinates.slice(j + stride, j + stride + 2),\n        ]);\n      }\n      offset = end;\n    }\n    return segments;\n  },\n};\n\n/**\n * @param  {import(\"../source/Vector.js\").VectorSourceEvent|import(\"../Collection.js\").CollectionEvent<import(\"../Feature.js\").default>} evt Event.\n * @return {import(\"../Feature.js\").default|null} Feature.\n */\nfunction getFeatureFromEvent(evt) {\n  if (\n    /** @type {import(\"../source/Vector.js\").VectorSourceEvent} */ (evt).feature\n  ) {\n    return /** @type {import(\"../source/Vector.js\").VectorSourceEvent} */ (evt)\n      .feature;\n  }\n  if (\n    /** @type {import(\"../Collection.js\").CollectionEvent<import(\"../Feature.js\").default>} */ (\n      evt\n    ).element\n  ) {\n    return /** @type {import(\"../Collection.js\").CollectionEvent<import(\"../Feature.js\").default>} */ (\n      evt\n    ).element;\n  }\n  return null;\n}\n\nconst tempSegment = [];\n/** @type {Array<import('../extent.js').Extent>} */\nconst tempExtents = [];\n/** @type {Array<SegmentData>} */\nconst tempSegmentData = [];\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types|\n *     'change:active', import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<'snap'|'unsnap', SnapEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"../ObjectEventType.js\").Types|\n *     'change:active'|'snap'|'unsnap', Return>} SnapOnSignature\n */\n\n/**\n * @classdesc\n * Handles snapping of vector features while modifying or drawing them.  The\n * features can come from a {@link module:ol/source/Vector~VectorSource} or {@link module:ol/Collection~Collection}\n * Any interaction object that allows the user to interact\n * with the features using the mouse can benefit from the snapping, as long\n * as it is added before.\n *\n * The snap interaction modifies map browser event `coordinate` and `pixel`\n * properties to force the snap to occur to any interaction that uses them.\n *\n * Example:\n *\n *     import Snap from 'ol/interaction/Snap.js';\n *\n *     const snap = new Snap({\n *       source: source\n *     });\n *\n *     map.addInteraction(snap);\n *\n * @fires SnapEvent\n * @api\n */\nclass Snap extends PointerInteraction {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super({\n      handleDownEvent: TRUE,\n      stopDown: FALSE,\n    });\n\n    /***\n     * @type {SnapOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {SnapOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {SnapOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @type {import(\"../source/Vector.js\").default|null}\n     * @private\n     */\n    this.source_ = options.source ? options.source : null;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.vertex_ = options.vertex !== undefined ? options.vertex : true;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.edge_ = options.edge !== undefined ? options.edge : true;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.intersection_ =\n      options.intersection !== undefined ? options.intersection : false;\n\n    /**\n     * @type {import(\"../Collection.js\").default<import(\"../Feature.js\").default>|null}\n     * @private\n     */\n    this.features_ = options.features ? options.features : null;\n\n    /**\n     * @type {Array<import(\"../events.js\").EventsKey>}\n     * @private\n     */\n    this.featuresListenerKeys_ = [];\n\n    /**\n     * @type {Object<string, import(\"../events.js\").EventsKey>}\n     * @private\n     */\n    this.featureChangeListenerKeys_ = {};\n\n    /**\n     * Extents are preserved so indexed segment can be quickly removed\n     * when its feature geometry changes\n     * @type {Object<string, import(\"../extent.js\").Extent>}\n     * @private\n     */\n    this.indexedFeaturesExtents_ = {};\n\n    /**\n     * If a feature geometry changes while a pointer drag|move event occurs, the\n     * feature doesn't get updated right away.  It will be at the next 'pointerup'\n     * event fired.\n     * @type {!Object<string, import(\"../Feature.js\").default>}\n     * @private\n     */\n    this.pendingFeatures_ = {};\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.pixelTolerance_ =\n      options.pixelTolerance !== undefined ? options.pixelTolerance : 10;\n\n    /**\n     * Segment RTree for each layer\n     * @type {import(\"../structs/RBush.js\").default<SegmentData>}\n     * @private\n     */\n    this.rBush_ = new RBush();\n\n    /**\n     * Holds information about the last snapped state.\n     * @type {SnappedInfo|null}\n     * @private\n     */\n    this.snapped_ = null;\n\n    /**\n     * @type {Object<string, Segmenter>}\n     * @private\n     */\n    this.segmenters_ = Object.assign(\n      {},\n      GEOMETRY_SEGMENTERS,\n      options.segmenters,\n    );\n  }\n\n  /**\n   * Add a feature to the collection of features that we may snap to.\n   * @param {import(\"../Feature.js\").default} feature Feature.\n   * @param {boolean} [register] Whether to listen to the feature change or not\n   *     Defaults to `true`.\n   * @api\n   */\n  addFeature(feature, register) {\n    register = register !== undefined ? register : true;\n    const feature_uid = getUid(feature);\n    const geometry = feature.getGeometry();\n    if (geometry) {\n      const segmenter = this.segmenters_[geometry.getType()];\n      if (segmenter) {\n        this.indexedFeaturesExtents_[feature_uid] =\n          geometry.getExtent(createEmpty());\n        const segments = segmenter.call(\n          this.segmenters_,\n          geometry,\n          this.getMap().getView().getProjection(),\n        );\n        let segmentCount = segments.length;\n        for (let i = 0; i < segmentCount; ++i) {\n          const segment = segments[i];\n          tempExtents[i] = boundingExtent(segment);\n          tempSegmentData[i] = {\n            feature: feature,\n            segment: segment,\n          };\n        }\n\n        if (this.intersection_) {\n          for (let j = 0, jj = segments.length; j < jj; ++j) {\n            const segment = segments[j];\n            if (segment.length === 1) {\n              continue;\n            }\n            const extent = tempExtents[j];\n            // Calculate intersections with own segments excluding self and\n            // neighbors\n            for (let k = 0, kk = j - 1; k < kk; ++k) {\n              const otherSegment = segments[k];\n              if (\n                otherSegment.length === 1 ||\n                !intersectsExtent(extent, tempExtents[k])\n              ) {\n                continue;\n              }\n              const intersection = getIntersectionPoint(segment, otherSegment);\n              if (!intersection) {\n                continue;\n              }\n              const intersectionSegment = [intersection];\n              tempExtents[segmentCount] = boundingExtent(intersectionSegment);\n              tempSegmentData[segmentCount++] = {\n                feature,\n                intersectionFeature: feature,\n                segment: intersectionSegment,\n              };\n            }\n            // Calculate intersections with existing segments\n            const otherSegments = this.rBush_.getInExtent(tempExtents[j]);\n            for (let k = 0, kk = otherSegments.length; k < kk; ++k) {\n              const otherSegment = otherSegments[k].segment;\n              if (otherSegment.length === 1) {\n                continue;\n              }\n              const intersection = getIntersectionPoint(segment, otherSegment);\n              if (!intersection) {\n                continue;\n              }\n              const intersectionSegment = [intersection];\n              tempExtents[segmentCount] = boundingExtent(intersectionSegment);\n              tempSegmentData[segmentCount++] = {\n                feature,\n                intersectionFeature: otherSegments[k].feature,\n                segment: intersectionSegment,\n              };\n            }\n          }\n        }\n\n        if (segmentCount === 1) {\n          this.rBush_.insert(tempExtents[0], tempSegmentData[0]);\n        } else {\n          tempExtents.length = segmentCount;\n          tempSegmentData.length = segmentCount;\n          this.rBush_.load(tempExtents, tempSegmentData);\n        }\n      }\n    }\n\n    if (register) {\n      if (this.featureChangeListenerKeys_[feature_uid]) {\n        unlistenByKey(this.featureChangeListenerKeys_[feature_uid]);\n      }\n      this.featureChangeListenerKeys_[feature_uid] = listen(\n        feature,\n        EventType.CHANGE,\n        this.handleFeatureChange_,\n        this,\n      );\n    }\n  }\n\n  /**\n   * @return {import(\"../Collection.js\").default<import(\"../Feature.js\").default>|Array<import(\"../Feature.js\").default>} Features.\n   * @private\n   */\n  getFeatures_() {\n    /** @type {import(\"../Collection.js\").default<import(\"../Feature.js\").default>|Array<import(\"../Feature.js\").default>} */\n    let features;\n    if (this.features_) {\n      features = this.features_;\n    } else if (this.source_) {\n      features = this.source_.getFeatures();\n    }\n    return features;\n  }\n\n  /**\n   * Checks if two snap data sets are equal.\n   * Compares the segment and the feature.\n   *\n   * @param {SnappedInfo} data1 The first snap data set.\n   * @param {SnappedInfo} data2 The second snap data set.\n   * @return {boolean} `true` if the data sets are equal, otherwise `false`.\n   * @private\n   */\n  areSnapDataEqual_(data1, data2) {\n    return data1.segment === data2.segment && data1.feature === data2.feature;\n  }\n\n  /**\n   * @param {import(\"../MapBrowserEvent.js\").default} evt Map browser event.\n   * @return {boolean} `false` to stop event propagation.\n   * @api\n   * @override\n   */\n  handleEvent(evt) {\n    const result = this.snapTo(evt.pixel, evt.coordinate, evt.map);\n\n    if (result) {\n      evt.coordinate = result.vertex.slice(0, 2);\n      evt.pixel = result.vertexPixel;\n\n      // Dispatch UNSNAP event if already snapped\n      if (this.snapped_ && !this.areSnapDataEqual_(this.snapped_, result)) {\n        this.dispatchEvent(new SnapEvent(SnapEventType.UNSNAP, this.snapped_));\n      }\n\n      this.snapped_ = {\n        vertex: evt.coordinate,\n        vertexPixel: evt.pixel,\n        feature: result.feature,\n        segment: result.segment,\n      };\n      this.dispatchEvent(new SnapEvent(SnapEventType.SNAP, this.snapped_));\n    } else if (this.snapped_) {\n      // Dispatch UNSNAP event if no longer snapped\n      this.dispatchEvent(new SnapEvent(SnapEventType.UNSNAP, this.snapped_));\n      this.snapped_ = null;\n    }\n\n    return super.handleEvent(evt);\n  }\n\n  /**\n   * @param {import(\"../source/Vector.js\").VectorSourceEvent|import(\"../Collection.js\").CollectionEvent<import(\"../Feature.js\").default>} evt Event.\n   * @private\n   */\n  handleFeatureAdd_(evt) {\n    const feature = getFeatureFromEvent(evt);\n    if (feature) {\n      this.addFeature(feature);\n    }\n  }\n\n  /**\n   * @param {import(\"../source/Vector.js\").VectorSourceEvent|import(\"../Collection.js\").CollectionEvent<import(\"../Feature.js\").default>} evt Event.\n   * @private\n   */\n  handleFeatureRemove_(evt) {\n    const feature = getFeatureFromEvent(evt);\n    if (feature) {\n      this.removeFeature(feature);\n      delete this.pendingFeatures_[getUid(feature)];\n    }\n  }\n\n  /**\n   * @param {import(\"../events/Event.js\").default} evt Event.\n   * @private\n   */\n  handleFeatureChange_(evt) {\n    const feature = /** @type {import(\"../Feature.js\").default} */ (evt.target);\n    if (this.handlingDownUpSequence) {\n      this.pendingFeatures_[getUid(feature)] = feature;\n    } else {\n      this.updateFeature_(feature);\n    }\n  }\n\n  /**\n   * Handle pointer up events.\n   * @param {import(\"../MapBrowserEvent.js\").default} evt Event.\n   * @return {boolean} If the event was consumed.\n   * @override\n   */\n  handleUpEvent(evt) {\n    const featuresToUpdate = Object.values(this.pendingFeatures_);\n    if (featuresToUpdate.length) {\n      for (const feature of featuresToUpdate) {\n        this.updateFeature_(feature);\n      }\n      clear(this.pendingFeatures_);\n    }\n    return false;\n  }\n\n  /**\n   * Remove a feature from the collection of features that we may snap to.\n   * @param {import(\"../Feature.js\").default} feature Feature\n   * @param {boolean} [unlisten] Whether to unlisten to the feature change\n   *     or not. Defaults to `true`.\n   * @api\n   */\n  removeFeature(feature, unlisten) {\n    const unregister = unlisten !== undefined ? unlisten : true;\n    const feature_uid = getUid(feature);\n    const extent = this.indexedFeaturesExtents_[feature_uid];\n    if (extent) {\n      const rBush = this.rBush_;\n      rBush.getInExtent(extent).forEach((node) => {\n        if (feature === node.feature || feature === node.intersectionFeature) {\n          rBush.remove(node);\n        }\n      });\n    }\n\n    if (unregister) {\n      unlistenByKey(this.featureChangeListenerKeys_[feature_uid]);\n      delete this.featureChangeListenerKeys_[feature_uid];\n    }\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} map Map.\n   * @override\n   */\n  setMap(map) {\n    const currentMap = this.getMap();\n    const keys = this.featuresListenerKeys_;\n    let features = this.getFeatures_();\n    if (!Array.isArray(features)) {\n      features = features.getArray();\n    }\n\n    if (currentMap) {\n      keys.forEach(unlistenByKey);\n      keys.length = 0;\n      this.rBush_.clear();\n      Object.values(this.featureChangeListenerKeys_).forEach(unlistenByKey);\n      this.featureChangeListenerKeys_ = {};\n    }\n    super.setMap(map);\n\n    if (map) {\n      if (this.features_) {\n        keys.push(\n          listen(\n            this.features_,\n            CollectionEventType.ADD,\n            this.handleFeatureAdd_,\n            this,\n          ),\n          listen(\n            this.features_,\n            CollectionEventType.REMOVE,\n            this.handleFeatureRemove_,\n            this,\n          ),\n        );\n      } else if (this.source_) {\n        keys.push(\n          listen(\n            this.source_,\n            VectorEventType.ADDFEATURE,\n            this.handleFeatureAdd_,\n            this,\n          ),\n          listen(\n            this.source_,\n            VectorEventType.REMOVEFEATURE,\n            this.handleFeatureRemove_,\n            this,\n          ),\n        );\n      }\n      for (const feature of features) {\n        this.addFeature(feature);\n      }\n    }\n  }\n\n  /**\n   * @param {import(\"../pixel.js\").Pixel} pixel Pixel\n   * @param {import(\"../coordinate.js\").Coordinate} pixelCoordinate Coordinate\n   * @param {import(\"../Map.js\").default} map Map.\n   * @return {SnappedInfo|null} Snap result\n   */\n  snapTo(pixel, pixelCoordinate, map) {\n    const projection = map.getView().getProjection();\n    const projectedCoordinate = fromUserCoordinate(pixelCoordinate, projection);\n\n    const box = toUserExtent(\n      buffer(\n        boundingExtent([projectedCoordinate]),\n        map.getView().getResolution() * this.pixelTolerance_,\n      ),\n      projection,\n    );\n\n    const segments = this.rBush_.getInExtent(box);\n    const segmentsLength = segments.length;\n    if (segmentsLength === 0) {\n      return null;\n    }\n\n    let closestVertex;\n    let minSquaredDistance = Infinity;\n    let closestFeature;\n    let closestSegment = null;\n\n    const squaredPixelTolerance = this.pixelTolerance_ * this.pixelTolerance_;\n    const getResult = () => {\n      if (!closestVertex) {\n        return null;\n      }\n      const vertexPixel = map.getPixelFromCoordinate(closestVertex);\n      const squaredPixelDistance = squaredDistance(pixel, vertexPixel);\n      if (squaredPixelDistance > squaredPixelTolerance) {\n        return null;\n      }\n      return {\n        vertex: closestVertex,\n        vertexPixel: [Math.round(vertexPixel[0]), Math.round(vertexPixel[1])],\n        feature: closestFeature,\n        segment: closestSegment,\n      };\n    };\n\n    if (this.vertex_ || this.intersection_) {\n      for (let i = 0; i < segmentsLength; ++i) {\n        const segmentData = segments[i];\n        if (segmentData.feature.getGeometry().getType() !== 'Circle') {\n          for (const vertex of segmentData.segment) {\n            const tempVertexCoord = fromUserCoordinate(vertex, projection);\n            const delta = squaredDistance(projectedCoordinate, tempVertexCoord);\n            if (\n              delta < minSquaredDistance &&\n              ((this.intersection_ && segmentData.intersectionFeature) ||\n                (this.vertex_ && !segmentData.intersectionFeature))\n            ) {\n              closestVertex = vertex;\n              minSquaredDistance = delta;\n              closestFeature = segmentData.feature;\n            }\n          }\n        }\n      }\n      const result = getResult();\n      if (result) {\n        return result;\n      }\n    }\n\n    if (this.edge_) {\n      for (let i = 0; i < segmentsLength; ++i) {\n        let vertex = null;\n        const segmentData = segments[i];\n        if (segmentData.feature.getGeometry().getType() === 'Circle') {\n          let circleGeometry = segmentData.feature.getGeometry();\n          const userProjection = getUserProjection();\n          if (userProjection) {\n            circleGeometry = circleGeometry\n              .clone()\n              .transform(userProjection, projection);\n          }\n          vertex = closestOnCircle(\n            projectedCoordinate,\n            /** @type {import(\"../geom/Circle.js\").default} */ (circleGeometry),\n          );\n        } else {\n          const [segmentStart, segmentEnd] = segmentData.segment;\n          // points have only one coordinate\n          if (segmentEnd) {\n            tempSegment[0] = fromUserCoordinate(segmentStart, projection);\n            tempSegment[1] = fromUserCoordinate(segmentEnd, projection);\n            vertex = closestOnSegment(projectedCoordinate, tempSegment);\n          }\n        }\n        if (vertex) {\n          const delta = squaredDistance(projectedCoordinate, vertex);\n          if (delta < minSquaredDistance) {\n            closestVertex = toUserCoordinate(vertex, projection);\n            closestSegment =\n              segmentData.feature.getGeometry().getType() === 'Circle'\n                ? null\n                : segmentData.segment;\n            minSquaredDistance = delta;\n            closestFeature = segmentData.feature;\n          }\n        }\n      }\n\n      const result = getResult();\n      if (result) {\n        return result;\n      }\n    }\n\n    return null;\n  }\n\n  /**\n   * @param {import(\"../Feature.js\").default} feature Feature\n   * @private\n   */\n  updateFeature_(feature) {\n    this.removeFeature(feature, false);\n    this.addFeature(feature, false);\n  }\n}\n\nexport default Snap;\n","/**\n * @module ol/interaction/Translate\n */\nimport Collection from '../Collection.js';\nimport Feature from '../Feature.js';\nimport Event from '../events/Event.js';\nimport {always} from '../events/condition.js';\nimport {TRUE} from '../functions.js';\nimport {fromUserCoordinate, getUserProjection} from '../proj.js';\nimport PointerInteraction from './Pointer.js';\nimport InteractionProperty from './Property.js';\n\n/**\n * @enum {string}\n */\nconst TranslateEventType = {\n  /**\n   * Triggered upon feature translation start.\n   * @event TranslateEvent#translatestart\n   * @api\n   */\n  TRANSLATESTART: 'translatestart',\n  /**\n   * Triggered upon feature translation.\n   * @event TranslateEvent#translating\n   * @api\n   */\n  TRANSLATING: 'translating',\n  /**\n   * Triggered upon feature translation end.\n   * @event TranslateEvent#translateend\n   * @api\n   */\n  TRANSLATEEND: 'translateend',\n};\n\n/**\n * A function that takes a {@link module:ol/Feature~Feature} or\n * {@link module:ol/render/Feature~RenderFeature} and a\n * {@link module:ol/layer/Layer~Layer} and returns `true` if the feature may be\n * translated or `false` otherwise.\n * @typedef {function(Feature, import(\"../layer/Layer.js\").default<import(\"../source/Source.js\").default>):boolean} FilterFunction\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.\n * Default is {@link module:ol/events/condition.always}.\n * @property {Collection<Feature>} [features] Features contained in this collection will be able to be translated together.\n * @property {Array<import(\"../layer/Layer.js\").default>|function(import(\"../layer/Layer.js\").default<import(\"../source/Source.js\").default>): boolean} [layers] A list of layers from which features should be\n * translated. Alternatively, a filter function can be provided. The\n * function will be called for each layer in the map and should return\n * `true` for layers that you want to be translatable. If the option is\n * absent, all visible layers will be considered translatable.\n * Not used if `features` is provided.\n * @property {FilterFunction} [filter] A function\n * that takes a {@link module:ol/Feature~Feature} and an\n * {@link module:ol/layer/Layer~Layer} and returns `true` if the feature may be\n * translated or `false` otherwise. Not used if `features` is provided.\n * @property {number} [hitTolerance=0] Hit-detection tolerance. Pixels inside the radius around the given position\n * will be checked for features.\n */\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/interaction/Translate~Translate} instances\n * are instances of this type.\n */\nexport class TranslateEvent extends Event {\n  /**\n   * @param {TranslateEventType} type Type.\n   * @param {Collection<Feature>} features The features translated.\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate The event coordinate.\n   * @param {import(\"../coordinate.js\").Coordinate} startCoordinate The original coordinates before.translation started\n   * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n   */\n  constructor(type, features, coordinate, startCoordinate, mapBrowserEvent) {\n    super(type);\n\n    /**\n     * The features being translated.\n     * @type {Collection<Feature>}\n     * @api\n     */\n    this.features = features;\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     * The coordinate of the start position before translation started.\n     * @const\n     * @type {import(\"../coordinate.js\").Coordinate}\n     * @api\n     */\n    this.startCoordinate = startCoordinate;\n\n    /**\n     * Associated {@link module:ol/MapBrowserEvent~MapBrowserEvent}.\n     * @type {import(\"../MapBrowserEvent.js\").default}\n     * @api\n     */\n    this.mapBrowserEvent = mapBrowserEvent;\n  }\n}\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types|\n *     'change:active', import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").OnSignature<'translateend'|'translatestart'|'translating', TranslateEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"../ObjectEventType.js\").Types|\n *     'change:active'|'translateend'|'translatestart'|'translating', Return>} TranslateOnSignature\n */\n\n/**\n * @classdesc\n * Interaction for translating (moving) features.\n * If you want to translate multiple features in a single action (for example,\n * the collection used by a select interaction), construct the interaction with\n * the `features` option.\n *\n * @fires TranslateEvent\n * @api\n */\nclass Translate extends PointerInteraction {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super(/** @type {import(\"./Pointer.js\").Options} */ (options));\n\n    /***\n     * @type {TranslateOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {TranslateOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {TranslateOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * The last position we translated to.\n     * @type {import(\"../coordinate.js\").Coordinate}\n     * @private\n     */\n    this.lastCoordinate_ = null;\n\n    /**\n     * The start position before translation started.\n     * @type {import(\"../coordinate.js\").Coordinate}\n     * @private\n     */\n    this.startCoordinate_ = null;\n\n    /**\n     * @type {Collection<Feature>|null}\n     * @private\n     */\n    this.features_ = options.features !== undefined ? options.features : null;\n\n    /** @type {function(import(\"../layer/Layer.js\").default<import(\"../source/Source.js\").default>): boolean} */\n    let layerFilter;\n    if (options.layers && !this.features_) {\n      if (typeof options.layers === 'function') {\n        layerFilter = options.layers;\n      } else {\n        const layers = options.layers;\n        layerFilter = function (layer) {\n          return layers.includes(layer);\n        };\n      }\n    } else {\n      layerFilter = TRUE;\n    }\n\n    /**\n     * @private\n     * @type {function(import(\"../layer/Layer.js\").default<import(\"../source/Source.js\").default>): boolean}\n     */\n    this.layerFilter_ = layerFilter;\n\n    /**\n     * @private\n     * @type {FilterFunction}\n     */\n    this.filter_ = options.filter && !this.features_ ? options.filter : TRUE;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.hitTolerance_ = options.hitTolerance ? options.hitTolerance : 0;\n\n    /**\n     * @private\n     * @type {import(\"../events/condition.js\").Condition}\n     */\n    this.condition_ = options.condition ? options.condition : always;\n\n    /**\n     * @type {Feature}\n     * @private\n     */\n    this.lastFeature_ = null;\n\n    this.addChangeListener(\n      InteractionProperty.ACTIVE,\n      this.handleActiveChanged_,\n    );\n  }\n\n  /**\n   * Handle pointer down events.\n   * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n   * @return {boolean} If the event was consumed.\n   * @override\n   */\n  handleDownEvent(event) {\n    if (!event.originalEvent || !this.condition_(event)) {\n      return false;\n    }\n    this.lastFeature_ = this.featuresAtPixel_(event.pixel, event.map);\n    if (!this.lastCoordinate_ && this.lastFeature_) {\n      this.startCoordinate_ = event.coordinate;\n      this.lastCoordinate_ = event.coordinate;\n      this.handleMoveEvent(event);\n\n      const features = this.features_ || new Collection([this.lastFeature_]);\n\n      this.dispatchEvent(\n        new TranslateEvent(\n          TranslateEventType.TRANSLATESTART,\n          features,\n          event.coordinate,\n          this.startCoordinate_,\n          event,\n        ),\n      );\n      return true;\n    }\n    return false;\n  }\n\n  /**\n   * Handle pointer up events.\n   * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n   * @return {boolean} If the event was consumed.\n   * @override\n   */\n  handleUpEvent(event) {\n    if (this.lastCoordinate_) {\n      this.lastCoordinate_ = null;\n      this.handleMoveEvent(event);\n\n      const features = this.features_ || new Collection([this.lastFeature_]);\n\n      this.dispatchEvent(\n        new TranslateEvent(\n          TranslateEventType.TRANSLATEEND,\n          features,\n          event.coordinate,\n          this.startCoordinate_,\n          event,\n        ),\n      );\n      // cleanup\n      this.startCoordinate_ = null;\n      return true;\n    }\n    return false;\n  }\n\n  /**\n   * Handle pointer drag events.\n   * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n   * @override\n   */\n  handleDragEvent(event) {\n    if (this.lastCoordinate_) {\n      const newCoordinate = event.coordinate;\n      const projection = event.map.getView().getProjection();\n\n      const newViewCoordinate = fromUserCoordinate(newCoordinate, projection);\n      const lastViewCoordinate = fromUserCoordinate(\n        this.lastCoordinate_,\n        projection,\n      );\n      const deltaX = newViewCoordinate[0] - lastViewCoordinate[0];\n      const deltaY = newViewCoordinate[1] - lastViewCoordinate[1];\n\n      const features = this.features_ || new Collection([this.lastFeature_]);\n      const userProjection = getUserProjection();\n\n      features.forEach(function (feature) {\n        const geom = feature.getGeometry();\n        if (userProjection) {\n          geom.transform(userProjection, projection);\n          geom.translate(deltaX, deltaY);\n          geom.transform(projection, userProjection);\n        } else {\n          geom.translate(deltaX, deltaY);\n        }\n        feature.setGeometry(geom);\n      });\n\n      this.lastCoordinate_ = newCoordinate;\n\n      this.dispatchEvent(\n        new TranslateEvent(\n          TranslateEventType.TRANSLATING,\n          features,\n          newCoordinate,\n          this.startCoordinate_,\n          event,\n        ),\n      );\n    }\n  }\n\n  /**\n   * Handle pointer move events.\n   * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n   * @override\n   */\n  handleMoveEvent(event) {\n    const elem = event.map.getViewport();\n\n    // Change the cursor to grab/grabbing if hovering any of the features managed\n    // by the interaction\n    if (this.featuresAtPixel_(event.pixel, event.map)) {\n      elem.classList.remove(this.lastCoordinate_ ? 'ol-grab' : 'ol-grabbing');\n      elem.classList.add(this.lastCoordinate_ ? 'ol-grabbing' : 'ol-grab');\n    } else {\n      elem.classList.remove('ol-grab', 'ol-grabbing');\n    }\n  }\n\n  /**\n   * Tests to see if the given coordinates intersects any of our selected\n   * features.\n   * @param {import(\"../pixel.js\").Pixel} pixel Pixel coordinate to test for intersection.\n   * @param {import(\"../Map.js\").default} map Map to test the intersection on.\n   * @return {Feature} Returns the feature found at the specified pixel\n   * coordinates.\n   * @private\n   */\n  featuresAtPixel_(pixel, map) {\n    return map.forEachFeatureAtPixel(\n      pixel,\n      (feature, layer) => {\n        if (!(feature instanceof Feature) || !this.filter_(feature, layer)) {\n          return undefined;\n        }\n        if (this.features_ && !this.features_.getArray().includes(feature)) {\n          return undefined;\n        }\n        return feature;\n      },\n      {\n        layerFilter: this.layerFilter_,\n        hitTolerance: this.hitTolerance_,\n      },\n    );\n  }\n\n  /**\n   * Returns the Hit-detection tolerance.\n   * @return {number} Hit tolerance in pixels.\n   * @api\n   */\n  getHitTolerance() {\n    return this.hitTolerance_;\n  }\n\n  /**\n   * Hit-detection tolerance. Pixels inside the radius around the given position\n   * will be checked for features.\n   * @param {number} hitTolerance Hit tolerance in pixels.\n   * @api\n   */\n  setHitTolerance(hitTolerance) {\n    this.hitTolerance_ = hitTolerance;\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} map Map.\n   * @override\n   */\n  setMap(map) {\n    const oldMap = this.getMap();\n    super.setMap(map);\n    this.updateState_(oldMap);\n  }\n\n  /**\n   * @private\n   */\n  handleActiveChanged_() {\n    this.updateState_(null);\n  }\n\n  /**\n   * @param {import(\"../Map.js\").default} oldMap Old map.\n   * @private\n   */\n  updateState_(oldMap) {\n    let map = this.getMap();\n    const active = this.getActive();\n    if (!map || !active) {\n      map = map || oldMap;\n      if (map) {\n        const elem = map.getViewport();\n        elem.classList.remove('ol-grab', 'ol-grabbing');\n      }\n    }\n  }\n}\n\nexport default Translate;\n","/**\n * @module ol/geom/flat/flip\n */\n\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {Array<number>} [dest] Destination.\n * @param {number} [destOffset] Destination offset.\n * @return {Array<number>} Flat coordinates.\n */\nexport function flipXY(flatCoordinates, offset, end, stride, dest, destOffset) {\n  if (dest !== undefined) {\n    dest = dest;\n    destOffset = destOffset !== undefined ? destOffset : 0;\n  } else {\n    dest = [];\n    destOffset = 0;\n  }\n  let j = offset;\n  while (j < end) {\n    const x = flatCoordinates[j++];\n    dest[destOffset++] = flatCoordinates[j++];\n    dest[destOffset++] = x;\n    for (let k = 2; k < stride; ++k) {\n      dest[destOffset++] = flatCoordinates[j++];\n    }\n  }\n  dest.length = destOffset;\n  return dest;\n}\n","/**\n * @module ol/format/Feature\n */\nimport Feature from '../Feature.js';\nimport GeometryCollection from '../geom/GeometryCollection.js';\nimport LineString from '../geom/LineString.js';\nimport MultiLineString from '../geom/MultiLineString.js';\nimport MultiPoint from '../geom/MultiPoint.js';\nimport MultiPolygon from '../geom/MultiPolygon.js';\nimport Point from '../geom/Point.js';\nimport Polygon from '../geom/Polygon.js';\nimport {\n  linearRingsAreOriented,\n  linearRingssAreOriented,\n  orientLinearRings,\n  orientLinearRingsArray,\n} from '../geom/flat/orient.js';\nimport {\n  equivalent as equivalentProjection,\n  get as getProjection,\n  getTransform,\n  transformExtent,\n} from '../proj.js';\nimport RenderFeature from '../render/Feature.js';\nimport {abstract} from '../util.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<number>} flatCoordinates Flat coordinates.\n * @property {Array<number>|Array<Array<number>>} [ends] Ends or endss.\n * @property {import('../geom/Geometry.js').GeometryLayout} [layout] Layout.\n */\n\n/**\n * @typedef {Array<GeometryObject>} 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<string, *>} [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<FeatureType>}\n     */\n    this.featureClass = /** @type {FeatureToFeatureClass<FeatureType>} */ (\n      Feature\n    );\n\n    /**\n     * A list media types supported by the format in descending order of preference.\n     * @type {Array<string>}\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<FeatureType>} 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<FeatureType>} 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<Feature>} 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<number>} coordinates Coordinates.\n     * @return {Array<number>} 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<RenderFeature>} 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 || 'XY', object.ends),\n    false,\n    options,\n  );\n}\n","/**\n * @module ol/format/XMLFeature\n */\nimport {extend} from '../array.js';\nimport FeatureFormat from '../format/Feature.js';\nimport {abstract} from '../util.js';\nimport {getXMLSerializer, isDocument, parse} from '../xml.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 XML feature formats.\n *\n * @abstract\n */\nclass XMLFeature extends FeatureFormat {\n  constructor() {\n    super();\n\n    /**\n     * @type {XMLSerializer}\n     * @private\n     */\n    this.xmlSerializer_ = getXMLSerializer();\n  }\n\n  /**\n   * @return {import(\"./Feature.js\").Type} Format.\n   * @override\n   */\n  getType() {\n    return 'xml';\n  }\n\n  /**\n   * Read a single feature.\n   *\n   * @param {Document|Element|Object|string} source Source.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @return {import(\"../Feature.js\").default} Feature.\n   * @api\n   * @override\n   */\n  readFeature(source, options) {\n    if (!source) {\n      return null;\n    }\n    if (typeof source === 'string') {\n      const doc = parse(source);\n      return this.readFeatureFromDocument(doc, options);\n    }\n    if (isDocument(source)) {\n      return this.readFeatureFromDocument(\n        /** @type {Document} */ (source),\n        options,\n      );\n    }\n    return this.readFeatureFromNode(/** @type {Element} */ (source), options);\n  }\n\n  /**\n   * @param {Document} doc Document.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @return {import(\"../Feature.js\").default} Feature.\n   */\n  readFeatureFromDocument(doc, options) {\n    const features = this.readFeaturesFromDocument(doc, options);\n    if (features.length > 0) {\n      return features[0];\n    }\n    return null;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @return {import(\"../Feature.js\").default} Feature.\n   */\n  readFeatureFromNode(node, options) {\n    return null; // not implemented\n  }\n\n  /**\n   * Read all features from a feature collection.\n   *\n   * @param {Document|Element|Object|string} source Source.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @return {Array<import(\"../Feature.js\").default>} Features.\n   * @api\n   * @override\n   */\n  readFeatures(source, options) {\n    if (!source) {\n      return [];\n    }\n    if (typeof source === 'string') {\n      const doc = parse(source);\n      return this.readFeaturesFromDocument(doc, options);\n    }\n    if (isDocument(source)) {\n      return this.readFeaturesFromDocument(\n        /** @type {Document} */ (source),\n        options,\n      );\n    }\n    return this.readFeaturesFromNode(/** @type {Element} */ (source), options);\n  }\n\n  /**\n   * @param {Document} doc Document.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @protected\n   * @return {Array<import(\"../Feature.js\").default>} Features.\n   */\n  readFeaturesFromDocument(doc, options) {\n    /** @type {Array<import(\"../Feature.js\").default>} */\n    const features = [];\n    for (let n = doc.firstChild; n; n = n.nextSibling) {\n      if (n.nodeType == Node.ELEMENT_NODE) {\n        extend(\n          features,\n          this.readFeaturesFromNode(/** @type {Element} */ (n), options),\n        );\n      }\n    }\n    return features;\n  }\n\n  /**\n   * @abstract\n   * @param {Element} node Node.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @protected\n   * @return {Array<import(\"../Feature.js\").default>} Features.\n   */\n  readFeaturesFromNode(node, options) {\n    return abstract();\n  }\n\n  /**\n   * Read a single geometry from a source.\n   *\n   * @param {Document|Element|Object|string} source Source.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @return {import(\"../geom/Geometry.js\").default} Geometry.\n   * @override\n   */\n  readGeometry(source, options) {\n    if (!source) {\n      return null;\n    }\n    if (typeof source === 'string') {\n      const doc = parse(source);\n      return this.readGeometryFromDocument(doc, options);\n    }\n    if (isDocument(source)) {\n      return this.readGeometryFromDocument(\n        /** @type {Document} */ (source),\n        options,\n      );\n    }\n    return this.readGeometryFromNode(/** @type {Element} */ (source), options);\n  }\n\n  /**\n   * @param {Document} doc Document.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @protected\n   * @return {import(\"../geom/Geometry.js\").default} Geometry.\n   */\n  readGeometryFromDocument(doc, options) {\n    return null; // not implemented\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @protected\n   * @return {import(\"../geom/Geometry.js\").default} Geometry.\n   */\n  readGeometryFromNode(node, options) {\n    return null; // not implemented\n  }\n\n  /**\n   * Read the projection from the source.\n   *\n   * @param {Document|Element|Object|string} source Source.\n   * @return {import(\"../proj/Projection.js\").default} Projection.\n   * @api\n   * @override\n   */\n  readProjection(source) {\n    if (!source) {\n      return null;\n    }\n    if (typeof source === 'string') {\n      const doc = parse(source);\n      return this.readProjectionFromDocument(doc);\n    }\n    if (isDocument(source)) {\n      return this.readProjectionFromDocument(/** @type {Document} */ (source));\n    }\n    return this.readProjectionFromNode(/** @type {Element} */ (source));\n  }\n\n  /**\n   * @param {Document} doc Document.\n   * @protected\n   * @return {import(\"../proj/Projection.js\").default} Projection.\n   */\n  readProjectionFromDocument(doc) {\n    return this.dataProjection;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @protected\n   * @return {import(\"../proj/Projection.js\").default} Projection.\n   */\n  readProjectionFromNode(node) {\n    return this.dataProjection;\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   * @override\n   */\n  writeFeature(feature, options) {\n    const node = this.writeFeatureNode(feature, options);\n    return this.xmlSerializer_.serializeToString(node);\n  }\n\n  /**\n   * @param {import(\"../Feature.js\").default} feature Feature.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Options.\n   * @protected\n   * @return {Node} Node.\n   */\n  writeFeatureNode(feature, options) {\n    return null; // not implemented\n  }\n\n  /**\n   * Encode an array of features as string.\n   *\n   * @param {Array<import(\"../Feature.js\").default>} features Features.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n   * @return {string} Result.\n   * @api\n   * @override\n   */\n  writeFeatures(features, options) {\n    const node = this.writeFeaturesNode(features, options);\n    return this.xmlSerializer_.serializeToString(node);\n  }\n\n  /**\n   * @param {Array<import(\"../Feature.js\").default>} features Features.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Options.\n   * @return {Node} Node.\n   */\n  writeFeaturesNode(features, options) {\n    return null; // not implemented\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   * @override\n   */\n  writeGeometry(geometry, options) {\n    const node = this.writeGeometryNode(geometry, options);\n    return this.xmlSerializer_.serializeToString(node);\n  }\n\n  /**\n   * @param {import(\"../geom/Geometry.js\").default} geometry Geometry.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Options.\n   * @return {Node} Node.\n   */\n  writeGeometryNode(geometry, options) {\n    return null; // not implemented\n  }\n}\n\nexport default XMLFeature;\n","/**\n * @module ol/format/xsd\n */\nimport {padNumber} from '../string.js';\nimport {getAllTextContent, getDocument} from '../xml.js';\n\n/**\n * @param {Node} node Node.\n * @return {boolean|undefined} Boolean.\n */\nexport function readBoolean(node) {\n  const s = getAllTextContent(node, false);\n  return readBooleanString(s);\n}\n\n/**\n * @param {string} string String.\n * @return {boolean|undefined} Boolean.\n */\nexport function readBooleanString(string) {\n  const m = /^\\s*(true|1)|(false|0)\\s*$/.exec(string);\n  if (m) {\n    return m[1] !== undefined || false;\n  }\n  return undefined;\n}\n\n/**\n * @param {Node} node Node.\n * @return {number|undefined} DateTime in seconds.\n */\nexport function readDateTime(node) {\n  const s = getAllTextContent(node, false);\n  const dateTime = Date.parse(s);\n  return isNaN(dateTime) ? undefined : dateTime / 1000;\n}\n\n/**\n * @param {Node} node Node.\n * @return {number|undefined} Decimal.\n */\nexport function readDecimal(node) {\n  const s = getAllTextContent(node, false);\n  return readDecimalString(s);\n}\n\n/**\n * @param {string} string String.\n * @return {number|undefined} Decimal.\n */\nexport function readDecimalString(string) {\n  // FIXME check spec\n  const m = /^\\s*([+\\-]?\\d*\\.?\\d+(?:e[+\\-]?\\d+)?)\\s*$/i.exec(string);\n  if (m) {\n    return parseFloat(m[1]);\n  }\n  return undefined;\n}\n\n/**\n * @param {Node} node Node.\n * @return {number|undefined} Non negative integer.\n */\nexport function readPositiveInteger(node) {\n  const s = getAllTextContent(node, false);\n  return readNonNegativeIntegerString(s);\n}\n\n/**\n * @param {string} string String.\n * @return {number|undefined} Non negative integer.\n */\nexport function readNonNegativeIntegerString(string) {\n  const m = /^\\s*(\\d+)\\s*$/.exec(string);\n  if (m) {\n    return parseInt(m[1], 10);\n  }\n  return undefined;\n}\n\n/**\n * @param {Node} node Node.\n * @return {string|undefined} String.\n */\nexport function readString(node) {\n  return getAllTextContent(node, false).trim();\n}\n\n/**\n * @param {Node} node Node to append a TextNode with the boolean to.\n * @param {boolean} bool Boolean.\n */\nexport function writeBooleanTextNode(node, bool) {\n  writeStringTextNode(node, bool ? '1' : '0');\n}\n\n/**\n * @param {Node} node Node to append a CDATA Section with the string to.\n * @param {string} string String.\n */\nexport function writeCDATASection(node, string) {\n  node.appendChild(getDocument().createCDATASection(string));\n}\n\n/**\n * @param {Node} node Node to append a TextNode with the dateTime to.\n * @param {number} dateTime DateTime in seconds.\n */\nexport function writeDateTimeTextNode(node, dateTime) {\n  const date = new Date(dateTime * 1000);\n  const string =\n    date.getUTCFullYear() +\n    '-' +\n    padNumber(date.getUTCMonth() + 1, 2) +\n    '-' +\n    padNumber(date.getUTCDate(), 2) +\n    'T' +\n    padNumber(date.getUTCHours(), 2) +\n    ':' +\n    padNumber(date.getUTCMinutes(), 2) +\n    ':' +\n    padNumber(date.getUTCSeconds(), 2) +\n    'Z';\n  node.appendChild(getDocument().createTextNode(string));\n}\n\n/**\n * @param {Node} node Node to append a TextNode with the decimal to.\n * @param {number} decimal Decimal.\n */\nexport function writeDecimalTextNode(node, decimal) {\n  const string = decimal.toPrecision();\n  node.appendChild(getDocument().createTextNode(string));\n}\n\n/**\n * @param {Node} node Node to append a TextNode with the decimal to.\n * @param {number} nonNegativeInteger Non negative integer.\n */\nexport function writeNonNegativeIntegerTextNode(node, nonNegativeInteger) {\n  const string = nonNegativeInteger.toString();\n  node.appendChild(getDocument().createTextNode(string));\n}\n\nconst whiteSpaceStart = /^\\s/;\nconst whiteSpaceEnd = /\\s$/;\nconst cdataCharacters = /(\\n|\\t|\\r|<|&| {2})/;\n\n/**\n * @param {Node} node Node to append a TextNode with the string to.\n * @param {string} string String.\n */\nexport function writeStringTextNode(node, string) {\n  if (\n    typeof string === 'string' &&\n    (whiteSpaceStart.test(string) ||\n      whiteSpaceEnd.test(string) ||\n      cdataCharacters.test(string))\n  ) {\n    string.split(']]>').forEach((part, i, a) => {\n      if (i < a.length - 1) {\n        part += ']]';\n      }\n      if (i > 0) {\n        part = '>' + part;\n      }\n      writeCDATASection(node, part);\n    });\n  } else {\n    node.appendChild(getDocument().createTextNode(string));\n  }\n}\n","/**\n * @module ol/format/GPX\n */\nimport Feature from '../Feature.js';\nimport LineString from '../geom/LineString.js';\nimport MultiLineString from '../geom/MultiLineString.js';\nimport Point from '../geom/Point.js';\nimport {get as getProjection} from '../proj.js';\nimport {\n  OBJECT_PROPERTY_NODE_FACTORY,\n  XML_SCHEMA_INSTANCE_URI,\n  createElementNS,\n  isDocument,\n  makeArrayPusher,\n  makeArraySerializer,\n  makeChildAppender,\n  makeObjectPropertySetter,\n  makeSequence,\n  makeSimpleNodeFactory,\n  makeStructureNS,\n  parse,\n  parseNode,\n  pushParseAndPop,\n  pushSerializeAndPop,\n} from '../xml.js';\nimport {transformGeometryWithOptions} from './Feature.js';\nimport XMLFeature from './XMLFeature.js';\nimport {\n  readDateTime,\n  readDecimal,\n  readPositiveInteger,\n  readString,\n  writeDateTimeTextNode,\n  writeDecimalTextNode,\n  writeNonNegativeIntegerTextNode,\n  writeStringTextNode,\n} from './xsd.js';\n\n/**\n * @const\n * @type {Array<null|string>}\n */\nconst NAMESPACE_URIS = [\n  null,\n  'http://www.topografix.com/GPX/1/0',\n  'http://www.topografix.com/GPX/1/1',\n];\n\n/**\n * @const\n * @type {string}\n */\nconst SCHEMA_LOCATION =\n  'http://www.topografix.com/GPX/1/1 ' +\n  'http://www.topografix.com/GPX/1/1/gpx.xsd';\n\n/**\n * @const\n * @type {Object<string, function(Node, Array<*>): (Feature|undefined)>}\n */\nconst FEATURE_READER = {\n  'rte': readRte,\n  'trk': readTrk,\n  'wpt': readWpt,\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst GPX_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'rte': makeArrayPusher(readRte),\n  'trk': makeArrayPusher(readTrk),\n  'wpt': makeArrayPusher(readWpt),\n});\n\n/**\n * @typedef {Object} GPXLink\n * @property {string} [text] text\n * @property {string} [type] type\n */\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst LINK_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'text': makeObjectPropertySetter(readString, 'linkText'),\n  'type': makeObjectPropertySetter(readString, 'linkType'),\n});\n\n/**\n * @typedef {Object} GPXAuthor\n * @property {string} [name] name\n * @property {string} [email] email\n * @property {GPXLink} [link] link\n */\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst AUTHOR_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'name': makeObjectPropertySetter(readString),\n  'email': parseEmail,\n  'link': parseLink,\n});\n\n/**\n * @typedef {Object} GPXMetadata\n * @property {string} [name] name\n * @property {string} [desc] desc\n * @property {GPXAuthor} [author] author\n * @property {GPXLink} [link] link\n * @property {number} [time] time\n * @property {string} [keywords] keywords\n * @property {Array<number>} [bounds] bounds\n * @property {Object} [extensions] extensions\n *\n */\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst METADATA_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'name': makeObjectPropertySetter(readString),\n  'desc': makeObjectPropertySetter(readString),\n  'author': makeObjectPropertySetter(readAuthor),\n  'copyright': makeObjectPropertySetter(readCopyright),\n  'link': parseLink,\n  'time': makeObjectPropertySetter(readDateTime),\n  'keywords': makeObjectPropertySetter(readString),\n  'bounds': parseBounds,\n  'extensions': parseExtensions,\n});\n\n/**\n * @typedef {Object} GPXCopyright\n * @property {string} [author] author\n * @property {number} [year] year\n * @property {string} [license] license\n */\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst COPYRIGHT_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'year': makeObjectPropertySetter(readPositiveInteger),\n  'license': makeObjectPropertySetter(readString),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst GPX_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'rte': makeChildAppender(writeRte),\n  'trk': makeChildAppender(writeTrk),\n  'wpt': makeChildAppender(writeWpt),\n});\n\n/**\n * @typedef {Object} Options\n * @property {function(Feature, Node):void} [readExtensions] Callback function\n * to process `extensions` nodes. To prevent memory leaks, this callback function must\n * not store any references to the node. Note that the `extensions`\n * node is not allowed in GPX 1.0. Moreover, only `extensions`\n * nodes from `wpt`, `rte` and `trk` can be processed, as those are\n * directly mapped to a feature.\n */\n\n/**\n * @typedef {Object} LayoutOptions\n * @property {boolean} [hasZ] HasZ.\n * @property {boolean} [hasM] HasM.\n */\n\n/**\n * @typedef {function(Feature, Node): void} ReadExtensions\n */\n\n/**\n * @classdesc\n * Feature format for reading and writing data in the GPX format.\n *\n * Note that {@link module:ol/format/GPX~GPX#readFeature} only reads the first\n * feature of the source.\n *\n * When reading, routes (`<rte>`) are converted into LineString geometries, and\n * tracks (`<trk>`) into MultiLineString. Any properties on route and track\n * waypoints are ignored.\n *\n * When writing, LineString geometries are output as routes (`<rte>`), and\n * MultiLineString as tracks (`<trk>`).\n *\n * @api\n */\nclass GPX extends XMLFeature {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    super();\n\n    options = options ? options : {};\n\n    /**\n     * @type {import(\"../proj/Projection.js\").default}\n     */\n    this.dataProjection = getProjection('EPSG:4326');\n\n    /**\n     * @type {ReadExtensions|undefined}\n     * @private\n     */\n    this.readExtensions_ = options.readExtensions;\n  }\n\n  /**\n   * @param {Array<Feature>} features List of features.\n   * @private\n   */\n  handleReadExtensions_(features) {\n    if (!features) {\n      features = [];\n    }\n    for (let i = 0, ii = features.length; i < ii; ++i) {\n      const feature = features[i];\n      if (this.readExtensions_) {\n        const extensionsNode = feature.get('extensionsNode_') || null;\n        this.readExtensions_(feature, extensionsNode);\n      }\n      feature.set('extensionsNode_', undefined);\n    }\n  }\n\n  /**\n   * Reads a GPX file's metadata tag, reading among other things:\n   *   - the name and description of this GPX\n   *   - its author\n   *   - the copyright associated with this GPX file\n   *\n   * Will return null if no metadata tag is present (or no valid source is given).\n   *\n   * @param {Document|Element|Object|string} source Source.\n   * @return {GPXMetadata | null} Metadata\n   * @api\n   */\n  readMetadata(source) {\n    if (!source) {\n      return null;\n    }\n    if (typeof source === 'string') {\n      return this.readMetadataFromDocument(parse(source));\n    }\n    if (isDocument(source)) {\n      return this.readMetadataFromDocument(/** @type {Document} */ (source));\n    }\n    return this.readMetadataFromNode(source);\n  }\n\n  /**\n   * @param {Document} doc Document.\n   * @return {GPXMetadata | null} Metadata\n   */\n  readMetadataFromDocument(doc) {\n    for (let n = /** @type {Node} */ (doc.firstChild); n; n = n.nextSibling) {\n      if (n.nodeType === Node.ELEMENT_NODE) {\n        const metadata = this.readMetadataFromNode(/** @type {Element} */ (n));\n        if (metadata) {\n          return metadata;\n        }\n      }\n    }\n    return null;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @return {Object} Metadata\n   */\n  readMetadataFromNode(node) {\n    if (!NAMESPACE_URIS.includes(node.namespaceURI)) {\n      return null;\n    }\n    for (let n = node.firstElementChild; n; n = n.nextElementSibling) {\n      if (\n        NAMESPACE_URIS.includes(n.namespaceURI) &&\n        n.localName === 'metadata'\n      ) {\n        return pushParseAndPop({}, METADATA_PARSERS, n, []);\n      }\n    }\n    return null;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @return {import(\"../Feature.js\").default} Feature.\n   * @override\n   */\n  readFeatureFromNode(node, options) {\n    if (!NAMESPACE_URIS.includes(node.namespaceURI)) {\n      return null;\n    }\n    const featureReader = FEATURE_READER[node.localName];\n    if (!featureReader) {\n      return null;\n    }\n    const feature = featureReader(node, [this.getReadOptions(node, options)]);\n    if (!feature) {\n      return null;\n    }\n    this.handleReadExtensions_([feature]);\n    return feature;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @return {Array<import(\"../Feature.js\").default>} Features.\n   * @override\n   */\n  readFeaturesFromNode(node, options) {\n    if (!NAMESPACE_URIS.includes(node.namespaceURI)) {\n      return [];\n    }\n    if (node.localName == 'gpx') {\n      /** @type {Array<Feature>} */\n      const features = pushParseAndPop([], GPX_PARSERS, node, [\n        this.getReadOptions(node, options),\n      ]);\n      if (features) {\n        this.handleReadExtensions_(features);\n        return features;\n      }\n      return [];\n    }\n    return [];\n  }\n\n  /**\n   * Encode an array of features in the GPX format as an XML node.\n   * LineString geometries are output as routes (`<rte>`), and MultiLineString\n   * as tracks (`<trk>`).\n   *\n   * @param {Array<Feature>} features Features.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Options.\n   * @return {Node} Node.\n   * @api\n   * @override\n   */\n  writeFeaturesNode(features, options) {\n    options = this.adaptOptions(options);\n    //FIXME Serialize metadata\n    const gpx = createElementNS('http://www.topografix.com/GPX/1/1', 'gpx');\n    const xmlnsUri = 'http://www.w3.org/2000/xmlns/';\n    gpx.setAttributeNS(xmlnsUri, 'xmlns:xsi', XML_SCHEMA_INSTANCE_URI);\n    gpx.setAttributeNS(\n      XML_SCHEMA_INSTANCE_URI,\n      'xsi:schemaLocation',\n      SCHEMA_LOCATION,\n    );\n    gpx.setAttribute('version', '1.1');\n    gpx.setAttribute('creator', 'OpenLayers');\n\n    pushSerializeAndPop(\n      /** @type {import(\"../xml.js\").NodeStackItem} */\n      ({node: gpx}),\n      GPX_SERIALIZERS,\n      GPX_NODE_FACTORY,\n      features,\n      [options],\n    );\n    return gpx;\n  }\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst RTE_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'name': makeObjectPropertySetter(readString),\n  'cmt': makeObjectPropertySetter(readString),\n  'desc': makeObjectPropertySetter(readString),\n  'src': makeObjectPropertySetter(readString),\n  'link': parseLink,\n  'number': makeObjectPropertySetter(readPositiveInteger),\n  'extensions': parseExtensions,\n  'type': makeObjectPropertySetter(readString),\n  'rtept': parseRtePt,\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst RTEPT_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'ele': makeObjectPropertySetter(readDecimal),\n  'time': makeObjectPropertySetter(readDateTime),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst TRK_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'name': makeObjectPropertySetter(readString),\n  'cmt': makeObjectPropertySetter(readString),\n  'desc': makeObjectPropertySetter(readString),\n  'src': makeObjectPropertySetter(readString),\n  'link': parseLink,\n  'number': makeObjectPropertySetter(readPositiveInteger),\n  'type': makeObjectPropertySetter(readString),\n  'extensions': parseExtensions,\n  'trkseg': parseTrkSeg,\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst TRKSEG_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'trkpt': parseTrkPt,\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst TRKPT_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'ele': makeObjectPropertySetter(readDecimal),\n  'time': makeObjectPropertySetter(readDateTime),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst WPT_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'ele': makeObjectPropertySetter(readDecimal),\n  'time': makeObjectPropertySetter(readDateTime),\n  'magvar': makeObjectPropertySetter(readDecimal),\n  'geoidheight': makeObjectPropertySetter(readDecimal),\n  'name': makeObjectPropertySetter(readString),\n  'cmt': makeObjectPropertySetter(readString),\n  'desc': makeObjectPropertySetter(readString),\n  'src': makeObjectPropertySetter(readString),\n  'link': parseLink,\n  'sym': makeObjectPropertySetter(readString),\n  'type': makeObjectPropertySetter(readString),\n  'fix': makeObjectPropertySetter(readString),\n  'sat': makeObjectPropertySetter(readPositiveInteger),\n  'hdop': makeObjectPropertySetter(readDecimal),\n  'vdop': makeObjectPropertySetter(readDecimal),\n  'pdop': makeObjectPropertySetter(readDecimal),\n  'ageofdgpsdata': makeObjectPropertySetter(readDecimal),\n  'dgpsid': makeObjectPropertySetter(readPositiveInteger),\n  'extensions': parseExtensions,\n});\n\n/**\n * @const\n * @type {Array<string>}\n */\nconst LINK_SEQUENCE = ['text', 'type'];\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst LINK_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'text': makeChildAppender(writeStringTextNode),\n  'type': makeChildAppender(writeStringTextNode),\n});\n\n/**\n * @const\n * @type {Object<string, Array<string>>}\n */\n// @ts-ignore\nconst RTE_SEQUENCE = makeStructureNS(NAMESPACE_URIS, [\n  'name',\n  'cmt',\n  'desc',\n  'src',\n  'link',\n  'number',\n  'type',\n  'rtept',\n]);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst RTE_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'name': makeChildAppender(writeStringTextNode),\n  'cmt': makeChildAppender(writeStringTextNode),\n  'desc': makeChildAppender(writeStringTextNode),\n  'src': makeChildAppender(writeStringTextNode),\n  'link': makeChildAppender(writeLink),\n  'number': makeChildAppender(writeNonNegativeIntegerTextNode),\n  'type': makeChildAppender(writeStringTextNode),\n  'rtept': makeArraySerializer(makeChildAppender(writeWptType)),\n});\n\n/**\n * @const\n * @type {Object<string, Array<string>>}\n */\n// @ts-ignore\nconst RTEPT_TYPE_SEQUENCE = makeStructureNS(NAMESPACE_URIS, ['ele', 'time']);\n\n/**\n * @const\n * @type {Object<string, Array<string>>}\n */\n// @ts-ignore\nconst TRK_SEQUENCE = makeStructureNS(NAMESPACE_URIS, [\n  'name',\n  'cmt',\n  'desc',\n  'src',\n  'link',\n  'number',\n  'type',\n  'trkseg',\n]);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst TRK_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'name': makeChildAppender(writeStringTextNode),\n  'cmt': makeChildAppender(writeStringTextNode),\n  'desc': makeChildAppender(writeStringTextNode),\n  'src': makeChildAppender(writeStringTextNode),\n  'link': makeChildAppender(writeLink),\n  'number': makeChildAppender(writeNonNegativeIntegerTextNode),\n  'type': makeChildAppender(writeStringTextNode),\n  'trkseg': makeArraySerializer(makeChildAppender(writeTrkSeg)),\n});\n\n/**\n * @const\n * @type {function(*, Array<*>, string=): (Node|undefined)}\n */\nconst TRKSEG_NODE_FACTORY = makeSimpleNodeFactory('trkpt');\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst TRKSEG_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'trkpt': makeChildAppender(writeWptType),\n});\n\n/**\n * @const\n * @type {Object<string, Array<string>>}\n */\n// @ts-ignore\nconst WPT_TYPE_SEQUENCE = makeStructureNS(NAMESPACE_URIS, [\n  'ele',\n  'time',\n  'magvar',\n  'geoidheight',\n  'name',\n  'cmt',\n  'desc',\n  'src',\n  'link',\n  'sym',\n  'type',\n  'fix',\n  'sat',\n  'hdop',\n  'vdop',\n  'pdop',\n  'ageofdgpsdata',\n  'dgpsid',\n]);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst WPT_TYPE_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'ele': makeChildAppender(writeDecimalTextNode),\n  'time': makeChildAppender(writeDateTimeTextNode),\n  'magvar': makeChildAppender(writeDecimalTextNode),\n  'geoidheight': makeChildAppender(writeDecimalTextNode),\n  'name': makeChildAppender(writeStringTextNode),\n  'cmt': makeChildAppender(writeStringTextNode),\n  'desc': makeChildAppender(writeStringTextNode),\n  'src': makeChildAppender(writeStringTextNode),\n  'link': makeChildAppender(writeLink),\n  'sym': makeChildAppender(writeStringTextNode),\n  'type': makeChildAppender(writeStringTextNode),\n  'fix': makeChildAppender(writeStringTextNode),\n  'sat': makeChildAppender(writeNonNegativeIntegerTextNode),\n  'hdop': makeChildAppender(writeDecimalTextNode),\n  'vdop': makeChildAppender(writeDecimalTextNode),\n  'pdop': makeChildAppender(writeDecimalTextNode),\n  'ageofdgpsdata': makeChildAppender(writeDecimalTextNode),\n  'dgpsid': makeChildAppender(writeNonNegativeIntegerTextNode),\n});\n\n/**\n * @const\n * @type {Object<string, string>}\n */\nconst GEOMETRY_TYPE_TO_NODENAME = {\n  'Point': 'wpt',\n  'LineString': 'rte',\n  'MultiLineString': 'trk',\n};\n\n/**\n * @param {*} value Value.\n * @param {Array<*>} objectStack Object stack.\n * @param {string} [nodeName] Node name.\n * @return {Node|undefined} Node.\n */\nfunction GPX_NODE_FACTORY(value, objectStack, nodeName) {\n  const geometry = /** @type {Feature} */ (value).getGeometry();\n  if (geometry) {\n    const nodeName = GEOMETRY_TYPE_TO_NODENAME[geometry.getType()];\n    if (nodeName) {\n      const parentNode = objectStack[objectStack.length - 1].node;\n      return createElementNS(parentNode.namespaceURI, nodeName);\n    }\n  }\n}\n\n/**\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {LayoutOptions} layoutOptions Layout options.\n * @param {Element} node Node.\n * @param {!Object} values Values.\n * @return {Array<number>} Flat coordinates.\n */\nfunction appendCoordinate(flatCoordinates, layoutOptions, node, values) {\n  flatCoordinates.push(\n    parseFloat(node.getAttribute('lon')),\n    parseFloat(node.getAttribute('lat')),\n  );\n  if ('ele' in values) {\n    flatCoordinates.push(/** @type {number} */ (values['ele']));\n    delete values['ele'];\n    layoutOptions.hasZ = true;\n  } else {\n    flatCoordinates.push(0);\n  }\n  if ('time' in values) {\n    flatCoordinates.push(/** @type {number} */ (values['time']));\n    delete values['time'];\n    layoutOptions.hasM = true;\n  } else {\n    flatCoordinates.push(0);\n  }\n  return flatCoordinates;\n}\n\n/**\n * Choose GeometryLayout based on flags in layoutOptions and adjust flatCoordinates\n * and ends arrays by shrinking them accordingly (removing unused zero entries).\n *\n * @param {LayoutOptions} layoutOptions Layout options.\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {Array<number>} [ends] Ends.\n * @return {import(\"../geom/Geometry.js\").GeometryLayout} Layout.\n */\nfunction applyLayoutOptions(layoutOptions, flatCoordinates, ends) {\n  /** @type {import(\"../geom/Geometry.js\").GeometryLayout} */\n  let layout = 'XY';\n  let stride = 2;\n  if (layoutOptions.hasZ && layoutOptions.hasM) {\n    layout = 'XYZM';\n    stride = 4;\n  } else if (layoutOptions.hasZ) {\n    layout = 'XYZ';\n    stride = 3;\n  } else if (layoutOptions.hasM) {\n    layout = 'XYM';\n    stride = 3;\n  }\n  if (stride !== 4) {\n    for (let i = 0, ii = flatCoordinates.length / 4; i < ii; i++) {\n      flatCoordinates[i * stride] = flatCoordinates[i * 4];\n      flatCoordinates[i * stride + 1] = flatCoordinates[i * 4 + 1];\n      if (layoutOptions.hasZ) {\n        flatCoordinates[i * stride + 2] = flatCoordinates[i * 4 + 2];\n      }\n      if (layoutOptions.hasM) {\n        flatCoordinates[i * stride + 2] = flatCoordinates[i * 4 + 3];\n      }\n    }\n    flatCoordinates.length = (flatCoordinates.length / 4) * stride;\n    if (ends) {\n      for (let i = 0, ii = ends.length; i < ii; i++) {\n        ends[i] = (ends[i] / 4) * stride;\n      }\n    }\n  }\n  return layout;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<any>} objectStack Object stack.\n * @return {GPXAuthor | undefined} Person object.\n */\nfunction readAuthor(node, objectStack) {\n  const values = pushParseAndPop({}, AUTHOR_PARSERS, node, objectStack);\n  if (values) {\n    return values;\n  }\n  return undefined;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<any>} objectStack Object stack.\n * @return {GPXCopyright | undefined} Person object.\n */\nfunction readCopyright(node, objectStack) {\n  const values = pushParseAndPop({}, COPYRIGHT_PARSERS, node, objectStack);\n  if (values) {\n    const author = node.getAttribute('author');\n    if (author !== null) {\n      values['author'] = author;\n    }\n    return values;\n  }\n  return undefined;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction parseBounds(node, objectStack) {\n  const values = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const minlat = node.getAttribute('minlat');\n  const minlon = node.getAttribute('minlon');\n  const maxlat = node.getAttribute('maxlat');\n  const maxlon = node.getAttribute('maxlon');\n  if (\n    minlon !== null &&\n    minlat !== null &&\n    maxlon !== null &&\n    maxlat !== null\n  ) {\n    values['bounds'] = [\n      [parseFloat(minlon), parseFloat(minlat)],\n      [parseFloat(maxlon), parseFloat(maxlat)],\n    ];\n  }\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction parseEmail(node, objectStack) {\n  const values = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const id = node.getAttribute('id');\n  const domain = node.getAttribute('domain');\n  if (id !== null && domain !== null) {\n    values['email'] = `${id}@${domain}`;\n  }\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction parseLink(node, objectStack) {\n  const values = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const href = node.getAttribute('href');\n  if (href !== null) {\n    values['link'] = href;\n  }\n  parseNode(LINK_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Node} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction parseExtensions(node, objectStack) {\n  const values = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  values['extensionsNode_'] = node;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction parseRtePt(node, objectStack) {\n  const values = pushParseAndPop({}, RTEPT_PARSERS, node, objectStack);\n  if (values) {\n    const rteValues = /** @type {!Object} */ (\n      objectStack[objectStack.length - 1]\n    );\n    const flatCoordinates = /** @type {Array<number>} */ (\n      rteValues['flatCoordinates']\n    );\n    const layoutOptions = /** @type {LayoutOptions} */ (\n      rteValues['layoutOptions']\n    );\n    appendCoordinate(flatCoordinates, layoutOptions, node, values);\n  }\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction parseTrkPt(node, objectStack) {\n  const values = pushParseAndPop({}, TRKPT_PARSERS, node, objectStack);\n  if (values) {\n    const trkValues = /** @type {!Object} */ (\n      objectStack[objectStack.length - 1]\n    );\n    const flatCoordinates = /** @type {Array<number>} */ (\n      trkValues['flatCoordinates']\n    );\n    const layoutOptions = /** @type {LayoutOptions} */ (\n      trkValues['layoutOptions']\n    );\n    appendCoordinate(flatCoordinates, layoutOptions, node, values);\n  }\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction parseTrkSeg(node, objectStack) {\n  const values = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  parseNode(TRKSEG_PARSERS, node, objectStack);\n  const flatCoordinates =\n    /** @type {Array<number>} */\n    (values['flatCoordinates']);\n  const ends = /** @type {Array<number>} */ (values['ends']);\n  ends.push(flatCoordinates.length);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Feature|undefined} Track.\n */\nfunction readRte(node, objectStack) {\n  const options = /** @type {import(\"./Feature.js\").ReadOptions} */ (\n    objectStack[0]\n  );\n  const values = pushParseAndPop(\n    {\n      'flatCoordinates': [],\n      'layoutOptions': {},\n    },\n    RTE_PARSERS,\n    node,\n    objectStack,\n  );\n  if (!values) {\n    return undefined;\n  }\n  const flatCoordinates =\n    /** @type {Array<number>} */\n    (values['flatCoordinates']);\n  delete values['flatCoordinates'];\n  const layoutOptions = /** @type {LayoutOptions} */ (values['layoutOptions']);\n  delete values['layoutOptions'];\n  const layout = applyLayoutOptions(layoutOptions, flatCoordinates);\n  const geometry = new LineString(flatCoordinates, layout);\n  transformGeometryWithOptions(geometry, false, options);\n  const feature = new Feature(geometry);\n  feature.setProperties(values, true);\n  return feature;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Feature|undefined} Track.\n */\nfunction readTrk(node, objectStack) {\n  const options = /** @type {import(\"./Feature.js\").ReadOptions} */ (\n    objectStack[0]\n  );\n  const values = pushParseAndPop(\n    {\n      'flatCoordinates': [],\n      'ends': [],\n      'layoutOptions': {},\n    },\n    TRK_PARSERS,\n    node,\n    objectStack,\n  );\n  if (!values) {\n    return undefined;\n  }\n  const flatCoordinates =\n    /** @type {Array<number>} */\n    (values['flatCoordinates']);\n  delete values['flatCoordinates'];\n  const ends = /** @type {Array<number>} */ (values['ends']);\n  delete values['ends'];\n  const layoutOptions = /** @type {LayoutOptions} */ (values['layoutOptions']);\n  delete values['layoutOptions'];\n  const layout = applyLayoutOptions(layoutOptions, flatCoordinates, ends);\n  const geometry = new MultiLineString(flatCoordinates, layout, ends);\n  transformGeometryWithOptions(geometry, false, options);\n  const feature = new Feature(geometry);\n  feature.setProperties(values, true);\n  return feature;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Feature|undefined} Waypoint.\n */\nfunction readWpt(node, objectStack) {\n  const options = /** @type {import(\"./Feature.js\").ReadOptions} */ (\n    objectStack[0]\n  );\n  const values = pushParseAndPop({}, WPT_PARSERS, node, objectStack);\n  if (!values) {\n    return undefined;\n  }\n  const layoutOptions = /** @type {LayoutOptions} */ ({});\n  const coordinates = appendCoordinate([], layoutOptions, node, values);\n  const layout = applyLayoutOptions(layoutOptions, coordinates);\n  const geometry = new Point(coordinates, layout);\n  transformGeometryWithOptions(geometry, false, options);\n  const feature = new Feature(geometry);\n  feature.setProperties(values, true);\n  return feature;\n}\n\n/**\n * @param {Element} node Node.\n * @param {string} value Value for the link's `href` attribute.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeLink(node, value, objectStack) {\n  node.setAttribute('href', value);\n  const context = objectStack[objectStack.length - 1];\n  const properties = context['properties'];\n  const link = [properties['linkText'], properties['linkType']];\n  pushSerializeAndPop(\n    /** @type {import(\"../xml.js\").NodeStackItem} */ ({node: node}),\n    LINK_SERIALIZERS,\n    OBJECT_PROPERTY_NODE_FACTORY,\n    link,\n    objectStack,\n    LINK_SEQUENCE,\n  );\n}\n\n/**\n * @param {Element} node Node.\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writeWptType(node, coordinate, objectStack) {\n  const context = objectStack[objectStack.length - 1];\n  const parentNode = context.node;\n  const namespaceURI = parentNode.namespaceURI;\n  const properties = context['properties'];\n  //FIXME Projection handling\n  node.setAttributeNS(null, 'lat', String(coordinate[1]));\n  node.setAttributeNS(null, 'lon', String(coordinate[0]));\n  const geometryLayout = context['geometryLayout'];\n  switch (geometryLayout) {\n    case 'XYZM':\n      if (coordinate[3] !== 0) {\n        properties['time'] = coordinate[3];\n      }\n    // fall through\n    case 'XYZ':\n      if (coordinate[2] !== 0) {\n        properties['ele'] = coordinate[2];\n      }\n      break;\n    case 'XYM':\n      if (coordinate[2] !== 0) {\n        properties['time'] = coordinate[2];\n      }\n      break;\n    default:\n    // pass\n  }\n  const orderedKeys =\n    node.nodeName == 'rtept'\n      ? RTEPT_TYPE_SEQUENCE[namespaceURI]\n      : WPT_TYPE_SEQUENCE[namespaceURI];\n  const values = makeSequence(properties, orderedKeys);\n  pushSerializeAndPop(\n    /** @type {import(\"../xml.js\").NodeStackItem} */\n    ({node: node, 'properties': properties}),\n    WPT_TYPE_SERIALIZERS,\n    OBJECT_PROPERTY_NODE_FACTORY,\n    values,\n    objectStack,\n    orderedKeys,\n  );\n}\n\n/**\n * @param {Node} node Node.\n * @param {Feature} feature Feature.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writeRte(node, feature, objectStack) {\n  const options = /** @type {import(\"./Feature.js\").WriteOptions} */ (\n    objectStack[0]\n  );\n  const properties = feature.getProperties();\n  const context = {node: node};\n  context['properties'] = properties;\n  const geometry = feature.getGeometry();\n  if (geometry.getType() == 'LineString') {\n    const lineString = /** @type {LineString} */ (\n      transformGeometryWithOptions(geometry, true, options)\n    );\n    context['geometryLayout'] = lineString.getLayout();\n    properties['rtept'] = lineString.getCoordinates();\n  }\n  const parentNode = objectStack[objectStack.length - 1].node;\n  const orderedKeys = RTE_SEQUENCE[parentNode.namespaceURI];\n  const values = makeSequence(properties, orderedKeys);\n  pushSerializeAndPop(\n    context,\n    RTE_SERIALIZERS,\n    OBJECT_PROPERTY_NODE_FACTORY,\n    values,\n    objectStack,\n    orderedKeys,\n  );\n}\n\n/**\n * @param {Element} node Node.\n * @param {Feature} feature Feature.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writeTrk(node, feature, objectStack) {\n  const options = /** @type {import(\"./Feature.js\").WriteOptions} */ (\n    objectStack[0]\n  );\n  const properties = feature.getProperties();\n  /** @type {import(\"../xml.js\").NodeStackItem} */\n  const context = {node: node};\n  context['properties'] = properties;\n  const geometry = feature.getGeometry();\n  if (geometry.getType() == 'MultiLineString') {\n    const multiLineString = /** @type {MultiLineString} */ (\n      transformGeometryWithOptions(geometry, true, options)\n    );\n    properties['trkseg'] = multiLineString.getLineStrings();\n  }\n  const parentNode = objectStack[objectStack.length - 1].node;\n  const orderedKeys = TRK_SEQUENCE[parentNode.namespaceURI];\n  const values = makeSequence(properties, orderedKeys);\n  pushSerializeAndPop(\n    context,\n    TRK_SERIALIZERS,\n    OBJECT_PROPERTY_NODE_FACTORY,\n    values,\n    objectStack,\n    orderedKeys,\n  );\n}\n\n/**\n * @param {Element} node Node.\n * @param {LineString} lineString LineString.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writeTrkSeg(node, lineString, objectStack) {\n  /** @type {import(\"../xml.js\").NodeStackItem} */\n  const context = {node: node};\n  context['geometryLayout'] = lineString.getLayout();\n  context['properties'] = {};\n  pushSerializeAndPop(\n    context,\n    TRKSEG_SERIALIZERS,\n    TRKSEG_NODE_FACTORY,\n    lineString.getCoordinates(),\n    objectStack,\n  );\n}\n\n/**\n * @param {Element} node Node.\n * @param {Feature} feature Feature.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writeWpt(node, feature, objectStack) {\n  const options = /** @type {import(\"./Feature.js\").WriteOptions} */ (\n    objectStack[0]\n  );\n  const context = objectStack[objectStack.length - 1];\n  context['properties'] = feature.getProperties();\n  const geometry = feature.getGeometry();\n  if (geometry.getType() == 'Point') {\n    const point = /** @type {Point} */ (\n      transformGeometryWithOptions(geometry, true, options)\n    );\n    context['geometryLayout'] = point.getLayout();\n    writeWptType(node, point.getCoordinates(), objectStack);\n  }\n}\n\nexport default GPX;\n","/**\n * @module ol/format/JSONFeature\n */\nimport {abstract} from '../util.js';\nimport FeatureFormat from './Feature.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<FeatureType>}\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<FeatureType>} 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<FeatureType>} 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<FeatureType>} 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<FeatureType>} 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<import(\"../Feature.js\").default>} 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<import(\"../Feature.js\").default>} 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 {getLayoutForStride} from '../geom/SimpleGeometry.js';\nimport {\n  deflateCoordinatesArray,\n  deflateMultiCoordinatesArray,\n} from '../geom/flat/deflate.js';\nimport {isEmpty} from '../obj.js';\nimport {get as getProjection} from '../proj.js';\nimport RenderFeature from '../render/Feature.js';\nimport {\n  createGeometry,\n  createRenderFeature,\n  transformGeometryWithOptions,\n} from './Feature.js';\nimport JSONFeature from './JSONFeature.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<FeatureType>} [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<FeatureType>}\n * @api\n */\nclass GeoJSON extends JSONFeature {\n  /**\n   * @param {Options<FeatureType>} [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<FeatureType>} 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<FeatureType>} */ (\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<FeatureType>} */ (feature);\n  }\n\n  /**\n   * @param {Object} object Object.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @protected\n   * @return {Array<FeatureType>} 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<FeatureType>} */ (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<import(\"../Feature.js\").default>} 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/format/TextFeature\n */\nimport FeatureFormat from '../format/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 text feature formats.\n *\n * @abstract\n */\nclass TextFeature extends FeatureFormat {\n  constructor() {\n    super();\n  }\n\n  /**\n   * @return {import(\"./Feature.js\").Type} Format.\n   * @override\n   */\n  getType() {\n    return 'text';\n  }\n\n  /**\n   * Read the feature from the source.\n   *\n   * @param {Document|Element|Object|string} source Source.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @return {import(\"../Feature.js\").default} Feature.\n   * @api\n   * @override\n   */\n  readFeature(source, options) {\n    return this.readFeatureFromText(\n      getText(source),\n      this.adaptOptions(options),\n    );\n  }\n\n  /**\n   * @abstract\n   * @param {string} text Text.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @protected\n   * @return {import(\"../Feature.js\").default} Feature.\n   */\n  readFeatureFromText(text, options) {\n    return abstract();\n  }\n\n  /**\n   * Read the features from the source.\n   *\n   * @param {Document|Element|Object|string} source Source.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @return {Array<import(\"../Feature.js\").default>} Features.\n   * @api\n   * @override\n   */\n  readFeatures(source, options) {\n    return this.readFeaturesFromText(\n      getText(source),\n      this.adaptOptions(options),\n    );\n  }\n\n  /**\n   * @abstract\n   * @param {string} text Text.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @protected\n   * @return {Array<import(\"../Feature.js\").default>} Features.\n   */\n  readFeaturesFromText(text, options) {\n    return abstract();\n  }\n\n  /**\n   * Read the geometry from the source.\n   *\n   * @param {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.readGeometryFromText(\n      getText(source),\n      this.adaptOptions(options),\n    );\n  }\n\n  /**\n   * @abstract\n   * @param {string} text Text.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @protected\n   * @return {import(\"../geom/Geometry.js\").default} Geometry.\n   */\n  readGeometryFromText(text, options) {\n    return abstract();\n  }\n\n  /**\n   * Read the projection from the source.\n   *\n   * @param {Document|Element|Object|string} source Source.\n   * @return {import(\"../proj/Projection.js\").default|undefined} Projection.\n   * @api\n   * @override\n   */\n  readProjection(source) {\n    return this.readProjectionFromText(getText(source));\n  }\n\n  /**\n   * @param {string} text Text.\n   * @protected\n   * @return {import(\"../proj/Projection.js\").default|undefined} Projection.\n   */\n  readProjectionFromText(text) {\n    return this.dataProjection;\n  }\n\n  /**\n   * Encode a feature as a 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 this.writeFeatureText(feature, this.adaptOptions(options));\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../Feature.js\").default} feature Features.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n   * @protected\n   * @return {string} Text.\n   */\n  writeFeatureText(feature, options) {\n    return abstract();\n  }\n\n  /**\n   * Encode an array of features as string.\n   *\n   * @param {Array<import(\"../Feature.js\").default>} 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 this.writeFeaturesText(features, this.adaptOptions(options));\n  }\n\n  /**\n   * @abstract\n   * @param {Array<import(\"../Feature.js\").default>} features Features.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n   * @protected\n   * @return {string} Text.\n   */\n  writeFeaturesText(features, options) {\n    return abstract();\n  }\n\n  /**\n   * Write a single geometry.\n   *\n   * @param {import(\"../geom/Geometry.js\").default} geometry Geometry.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n   * @return {string} Geometry.\n   * @api\n   * @override\n   */\n  writeGeometry(geometry, options) {\n    return this.writeGeometryText(geometry, this.adaptOptions(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   * @protected\n   * @return {string} Text.\n   */\n  writeGeometryText(geometry, options) {\n    return abstract();\n  }\n}\n\n/**\n * @param {Document|Element|Object|string} source Source.\n * @return {string} Text.\n */\nfunction getText(source) {\n  if (typeof source === 'string') {\n    return source;\n  }\n  return '';\n}\n\nexport default TextFeature;\n","/**\n * @module ol/format/IGC\n */\nimport Feature from '../Feature.js';\nimport LineString from '../geom/LineString.js';\nimport {get as getProjection} from '../proj.js';\nimport {transformGeometryWithOptions} from './Feature.js';\nimport TextFeature from './TextFeature.js';\n\n/**\n * @typedef {'barometric' | 'gps' | 'none'} IGCZ\n * IGC altitude/z. One of 'barometric', 'gps', 'none'.\n */\n\n/**\n * @const\n * @type {RegExp}\n */\nconst B_RECORD_RE =\n  /^B(\\d{2})(\\d{2})(\\d{2})(\\d{2})(\\d{5})([NS])(\\d{3})(\\d{5})([EW])([AV])(\\d{5})(\\d{5})/;\n\n/**\n * @const\n * @type {RegExp}\n */\nconst H_RECORD_RE = /^H.([A-Z]{3}).*?:(.*)/;\n\n/**\n * @const\n * @type {RegExp}\n */\nconst HFDTE_RECORD_RE = /^HFDTE(\\d{2})(\\d{2})(\\d{2})/;\n\n/**\n * @const\n * @type {RegExp}\n */\nconst HFDTEDATE_RECORD_RE = /^HFDTEDATE:(\\d{2})(\\d{2})(\\d{2}),(\\d{2})/;\n\n/**\n * A regular expression matching the newline characters `\\r\\n`, `\\r` and `\\n`.\n *\n * @const\n * @type {RegExp}\n */\nconst NEWLINE_RE = /\\r\\n|\\r|\\n/;\n\n/**\n * @typedef {Object} Options\n * @property {IGCZ} [altitudeMode='none'] Altitude mode. Possible\n * values are `'barometric'`, `'gps'`, and `'none'`.\n */\n\n/**\n * @classdesc\n * Feature format for `*.igc` flight recording files.\n *\n * As IGC sources contain a single feature,\n * {@link module:ol/format/IGC~IGC#readFeatures} will return the feature in an\n * array\n *\n * @api\n */\nclass IGC extends TextFeature {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    super();\n\n    options = options ? options : {};\n\n    /**\n     * @type {import(\"../proj/Projection.js\").default}\n     */\n    this.dataProjection = getProjection('EPSG:4326');\n\n    /**\n     * @private\n     * @type {IGCZ}\n     */\n    this.altitudeMode_ = options.altitudeMode ? options.altitudeMode : 'none';\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.lad_ = false;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.lod_ = false;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.ladStart_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.ladStop_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.lodStart_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.lodStop_ = 0;\n  }\n\n  /**\n   * @protected\n   * @param {string} text Text.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @return {import(\"../Feature.js\").default} Feature.\n   * @override\n   */\n  readFeatureFromText(text, options) {\n    const altitudeMode = this.altitudeMode_;\n    const lines = text.split(NEWLINE_RE);\n    /** @type {Object<string, string>} */\n    const properties = {};\n    const flatCoordinates = [];\n    let year = 2000;\n    let month = 0;\n    let day = 1;\n    let lastDateTime = -1;\n    let i, ii;\n    for (i = 0, ii = lines.length; i < ii; ++i) {\n      const line = lines[i];\n      let m;\n      if (line.charAt(0) == 'B') {\n        m = B_RECORD_RE.exec(line);\n        if (m) {\n          const hour = parseInt(m[1], 10);\n          const minute = parseInt(m[2], 10);\n          const second = parseInt(m[3], 10);\n          let y = parseInt(m[4], 10) + parseInt(m[5], 10) / 60000;\n          if (this.lad_) {\n            y +=\n              parseInt(line.slice(this.ladStart_, this.ladStop_), 10) /\n              60000 /\n              10 ** (this.ladStop_ - this.ladStart_);\n          }\n          if (m[6] == 'S') {\n            y = -y;\n          }\n          let x = parseInt(m[7], 10) + parseInt(m[8], 10) / 60000;\n          if (this.lod_) {\n            x +=\n              parseInt(line.slice(this.lodStart_, this.lodStop_), 10) /\n              60000 /\n              10 ** (this.lodStop_ - this.lodStart_);\n          }\n          if (m[9] == 'W') {\n            x = -x;\n          }\n          flatCoordinates.push(x, y);\n          if (altitudeMode != 'none') {\n            let z;\n            if (altitudeMode == 'gps') {\n              z = parseInt(m[11], 10);\n            } else if (altitudeMode == 'barometric') {\n              z = parseInt(m[12], 10);\n            } else {\n              z = 0;\n            }\n            flatCoordinates.push(z);\n          }\n          let dateTime = Date.UTC(year, month, day, hour, minute, second);\n          // Detect UTC midnight wrap around.\n          if (dateTime < lastDateTime) {\n            dateTime = Date.UTC(year, month, day + 1, hour, minute, second);\n          }\n          flatCoordinates.push(dateTime / 1000);\n          lastDateTime = dateTime;\n        }\n      } else if (line.charAt(0) == 'H') {\n        m = HFDTEDATE_RECORD_RE.exec(line);\n        if (m) {\n          day = parseInt(m[1], 10);\n          month = parseInt(m[2], 10) - 1;\n          year = 2000 + parseInt(m[3], 10);\n        } else {\n          m = HFDTE_RECORD_RE.exec(line);\n          if (m) {\n            day = parseInt(m[1], 10);\n            month = parseInt(m[2], 10) - 1;\n            year = 2000 + parseInt(m[3], 10);\n          } else {\n            m = H_RECORD_RE.exec(line);\n            if (m) {\n              properties[m[1]] = m[2].trim();\n            }\n          }\n        }\n      } else if (line.charAt(0) == 'I') {\n        const numberAdds = parseInt(line.slice(1, 3), 10);\n        for (let i = 0; i < numberAdds; i++) {\n          const addCode = line.slice(7 + i * 7, 10 + i * 7);\n          if (addCode === 'LAD' || addCode === 'LOD') {\n            // in IGC format, columns are numbered from 1\n            const addStart = parseInt(line.slice(3 + i * 7, 5 + i * 7), 10) - 1;\n            const addStop = parseInt(line.slice(5 + i * 7, 7 + i * 7), 10);\n            if (addCode === 'LAD') {\n              this.lad_ = true;\n              this.ladStart_ = addStart;\n              this.ladStop_ = addStop;\n            } else if (addCode === 'LOD') {\n              this.lod_ = true;\n              this.lodStart_ = addStart;\n              this.lodStop_ = addStop;\n            }\n          }\n        }\n      }\n    }\n    if (flatCoordinates.length === 0) {\n      return null;\n    }\n    const layout = altitudeMode == 'none' ? 'XYM' : 'XYZM';\n    const lineString = new LineString(flatCoordinates, layout);\n    const feature = new Feature(\n      transformGeometryWithOptions(lineString, false, options),\n    );\n    feature.setProperties(properties, true);\n    return feature;\n  }\n\n  /**\n   * @param {string} text Text.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @protected\n   * @return {Array<Feature>} Features.\n   * @override\n   */\n  readFeaturesFromText(text, options) {\n    const feature = this.readFeatureFromText(text, options);\n    if (feature) {\n      return [feature];\n    }\n    return [];\n  }\n}\n\nexport default IGC;\n","/**\n * @module ol/format/KML\n */\nimport Feature from '../Feature.js';\nimport ImageState from '../ImageState.js';\nimport {extend} from '../array.js';\nimport {asArray} from '../color.js';\nimport GeometryCollection from '../geom/GeometryCollection.js';\nimport LineString from '../geom/LineString.js';\nimport MultiLineString from '../geom/MultiLineString.js';\nimport MultiPoint from '../geom/MultiPoint.js';\nimport MultiPolygon from '../geom/MultiPolygon.js';\nimport Point from '../geom/Point.js';\nimport Polygon from '../geom/Polygon.js';\nimport {toRadians} from '../math.js';\nimport {get as getProjection} from '../proj.js';\nimport Fill from '../style/Fill.js';\nimport Icon from '../style/Icon.js';\nimport Stroke from '../style/Stroke.js';\nimport Style from '../style/Style.js';\nimport Text from '../style/Text.js';\nimport {\n  OBJECT_PROPERTY_NODE_FACTORY,\n  XML_SCHEMA_INSTANCE_URI,\n  createElementNS,\n  getAllTextContent,\n  isDocument,\n  makeArrayExtender,\n  makeArrayPusher,\n  makeChildAppender,\n  makeObjectPropertySetter,\n  makeReplacer,\n  makeSequence,\n  makeSimpleNodeFactory,\n  makeStructureNS,\n  parse,\n  parseNode,\n  pushParseAndPop,\n  pushSerializeAndPop,\n} from '../xml.js';\nimport {transformGeometryWithOptions} from './Feature.js';\nimport XMLFeature from './XMLFeature.js';\nimport {\n  readBoolean,\n  readDecimal,\n  readString,\n  writeBooleanTextNode,\n  writeDecimalTextNode,\n  writeStringTextNode,\n} from './xsd.js';\n\n/**\n * @typedef {Object} Vec2\n * @property {number} x X coordinate.\n * @property {import(\"../style/Icon.js\").IconAnchorUnits} xunits Units of x.\n * @property {number} y Y coordinate.\n * @property {import(\"../style/Icon.js\").IconAnchorUnits} yunits Units of Y.\n * @property {import(\"../style/Icon.js\").IconOrigin} [origin] Origin.\n */\n\n/**\n * @typedef {Object} GxTrackObject\n * @property {Array<Array<number>>} coordinates Coordinates.\n * @property {Array<number>} whens Whens.\n */\n\n/**\n * @const\n * @type {Array<string>}\n */\nconst GX_NAMESPACE_URIS = ['http://www.google.com/kml/ext/2.2'];\n\n/**\n * @const\n * @type {Array<null|string>}\n */\nconst NAMESPACE_URIS = [\n  null,\n  'http://earth.google.com/kml/2.0',\n  'http://earth.google.com/kml/2.1',\n  'http://earth.google.com/kml/2.2',\n  'http://www.opengis.net/kml/2.2',\n];\n\n/**\n * @const\n * @type {string}\n */\nconst SCHEMA_LOCATION =\n  'http://www.opengis.net/kml/2.2 ' +\n  'https://developers.google.com/kml/schema/kml22gx.xsd';\n\n/**\n * @type {Object<string, import(\"../style/Icon.js\").IconAnchorUnits>}\n */\nconst ICON_ANCHOR_UNITS_MAP = {\n  'fraction': 'fraction',\n  'pixels': 'pixels',\n  'insetPixels': 'pixels',\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst PLACEMARK_PARSERS = makeStructureNS(\n  NAMESPACE_URIS,\n  {\n    'ExtendedData': extendedDataParser,\n    'Region': regionParser,\n    'MultiGeometry': makeObjectPropertySetter(readMultiGeometry, 'geometry'),\n    'LineString': makeObjectPropertySetter(readLineString, 'geometry'),\n    'LinearRing': makeObjectPropertySetter(readLinearRing, 'geometry'),\n    'Point': makeObjectPropertySetter(readPoint, 'geometry'),\n    'Polygon': makeObjectPropertySetter(readPolygon, 'geometry'),\n    'Style': makeObjectPropertySetter(readStyle),\n    'StyleMap': placemarkStyleMapParser,\n    'address': makeObjectPropertySetter(readString),\n    'description': makeObjectPropertySetter(readString),\n    'name': makeObjectPropertySetter(readString),\n    'open': makeObjectPropertySetter(readBoolean),\n    'phoneNumber': makeObjectPropertySetter(readString),\n    'styleUrl': makeObjectPropertySetter(readStyleURL),\n    'visibility': makeObjectPropertySetter(readBoolean),\n  },\n  makeStructureNS(GX_NAMESPACE_URIS, {\n    'MultiTrack': makeObjectPropertySetter(readGxMultiTrack, 'geometry'),\n    'Track': makeObjectPropertySetter(readGxTrack, 'geometry'),\n  }),\n);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst NETWORK_LINK_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'ExtendedData': extendedDataParser,\n  'Region': regionParser,\n  'Link': linkParser,\n  'address': makeObjectPropertySetter(readString),\n  'description': makeObjectPropertySetter(readString),\n  'name': makeObjectPropertySetter(readString),\n  'open': makeObjectPropertySetter(readBoolean),\n  'phoneNumber': makeObjectPropertySetter(readString),\n  'visibility': makeObjectPropertySetter(readBoolean),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst LINK_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'href': makeObjectPropertySetter(readURI),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst CAMERA_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  Altitude: makeObjectPropertySetter(readDecimal),\n  Longitude: makeObjectPropertySetter(readDecimal),\n  Latitude: makeObjectPropertySetter(readDecimal),\n  Tilt: makeObjectPropertySetter(readDecimal),\n  AltitudeMode: makeObjectPropertySetter(readString),\n  Heading: makeObjectPropertySetter(readDecimal),\n  Roll: makeObjectPropertySetter(readDecimal),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst REGION_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'LatLonAltBox': latLonAltBoxParser,\n  'Lod': lodParser,\n});\n\n/**\n * @const\n * @type {Object<string, Array<string>>}\n */\n// @ts-ignore\nconst KML_SEQUENCE = makeStructureNS(NAMESPACE_URIS, ['Document', 'Placemark']);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst KML_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'Document': makeChildAppender(writeDocument),\n  'Placemark': makeChildAppender(writePlacemark),\n});\n\n/**\n * @type {import(\"../color.js\").Color}\n */\nlet DEFAULT_COLOR;\n\n/**\n * @type {Fill|null}\n */\nlet DEFAULT_FILL_STYLE = null;\n\n/**\n * Get the default fill style (or null if not yet set).\n * @return {Fill|null} The default fill style.\n */\nexport function getDefaultFillStyle() {\n  return DEFAULT_FILL_STYLE;\n}\n\n/**\n * @type {import(\"../size.js\").Size}\n */\nlet DEFAULT_IMAGE_STYLE_ANCHOR;\n\n/**\n * @type {import(\"../style/Icon.js\").IconAnchorUnits}\n */\nlet DEFAULT_IMAGE_STYLE_ANCHOR_X_UNITS;\n\n/**\n * @type {import(\"../style/Icon.js\").IconAnchorUnits}\n */\nlet DEFAULT_IMAGE_STYLE_ANCHOR_Y_UNITS;\n\n/**\n * @type {import(\"../size.js\").Size}\n */\nlet DEFAULT_IMAGE_STYLE_SIZE;\n\n/**\n * @type {string}\n */\nlet DEFAULT_IMAGE_STYLE_SRC;\n\n/**\n * @type {import(\"../style/Image.js\").default|null}\n */\nlet DEFAULT_IMAGE_STYLE = null;\n\n/**\n * Get the default image style (or null if not yet set).\n * @return {import(\"../style/Image.js\").default|null} The default image style.\n */\nexport function getDefaultImageStyle() {\n  return DEFAULT_IMAGE_STYLE;\n}\n\n/**\n * @type {string}\n */\nlet DEFAULT_NO_IMAGE_STYLE;\n\n/**\n * @type {Stroke|null}\n */\nlet DEFAULT_STROKE_STYLE = null;\n\n/**\n * Get the default stroke style (or null if not yet set).\n * @return {Stroke|null} The default stroke style.\n */\nexport function getDefaultStrokeStyle() {\n  return DEFAULT_STROKE_STYLE;\n}\n\n/**\n * @type {Stroke}\n */\nlet DEFAULT_TEXT_STROKE_STYLE;\n\n/**\n * @type {Text|null}\n */\nlet DEFAULT_TEXT_STYLE = null;\n\n/**\n * Get the default text style (or null if not yet set).\n * @return {Text|null} The default text style.\n */\nexport function getDefaultTextStyle() {\n  return DEFAULT_TEXT_STYLE;\n}\n\n/**\n * @type {Style|null}\n */\nlet DEFAULT_STYLE = null;\n\n/**\n * Get the default style (or null if not yet set).\n * @return {Style|null} The default style.\n */\nexport function getDefaultStyle() {\n  return DEFAULT_STYLE;\n}\n\n/**\n * @type {Array<Style>|null}\n */\nlet DEFAULT_STYLE_ARRAY = null;\n\n/**\n * Get the default style array (or null if not yet set).\n * @return {Array<Style>|null} The default style.\n */\nexport function getDefaultStyleArray() {\n  return DEFAULT_STYLE_ARRAY;\n}\n\n/**\n * Function that returns the scale needed to normalize an icon image to 32 pixels.\n * @param {import(\"../size.js\").Size} size Image size.\n * @return {number} Scale.\n */\nfunction scaleForSize(size) {\n  return 32 / Math.min(size[0], size[1]);\n}\n\nfunction createStyleDefaults() {\n  DEFAULT_COLOR = [255, 255, 255, 1];\n\n  DEFAULT_FILL_STYLE = new Fill({\n    color: DEFAULT_COLOR,\n  });\n\n  DEFAULT_IMAGE_STYLE_ANCHOR = [20, 2];\n\n  DEFAULT_IMAGE_STYLE_ANCHOR_X_UNITS = 'pixels';\n\n  DEFAULT_IMAGE_STYLE_ANCHOR_Y_UNITS = 'pixels';\n\n  DEFAULT_IMAGE_STYLE_SIZE = [64, 64];\n\n  DEFAULT_IMAGE_STYLE_SRC =\n    'https://maps.google.com/mapfiles/kml/pushpin/ylw-pushpin.png';\n\n  DEFAULT_IMAGE_STYLE = new Icon({\n    anchor: DEFAULT_IMAGE_STYLE_ANCHOR,\n    anchorOrigin: 'bottom-left',\n    anchorXUnits: DEFAULT_IMAGE_STYLE_ANCHOR_X_UNITS,\n    anchorYUnits: DEFAULT_IMAGE_STYLE_ANCHOR_Y_UNITS,\n    crossOrigin: 'anonymous',\n    rotation: 0,\n    scale: scaleForSize(DEFAULT_IMAGE_STYLE_SIZE),\n    size: DEFAULT_IMAGE_STYLE_SIZE,\n    src: DEFAULT_IMAGE_STYLE_SRC,\n  });\n\n  DEFAULT_NO_IMAGE_STYLE = 'NO_IMAGE';\n\n  DEFAULT_STROKE_STYLE = new Stroke({\n    color: DEFAULT_COLOR,\n    width: 1,\n  });\n\n  DEFAULT_TEXT_STROKE_STYLE = new Stroke({\n    color: [51, 51, 51, 1],\n    width: 2,\n  });\n\n  DEFAULT_TEXT_STYLE = new Text({\n    font: 'bold 16px Helvetica',\n    fill: DEFAULT_FILL_STYLE,\n    stroke: DEFAULT_TEXT_STROKE_STYLE,\n    scale: 0.8,\n  });\n\n  DEFAULT_STYLE = new Style({\n    fill: DEFAULT_FILL_STYLE,\n    image: DEFAULT_IMAGE_STYLE,\n    text: DEFAULT_TEXT_STYLE,\n    stroke: DEFAULT_STROKE_STYLE,\n    zIndex: 0,\n  });\n\n  DEFAULT_STYLE_ARRAY = [DEFAULT_STYLE];\n}\n\n/**\n * @type {HTMLTextAreaElement}\n */\nlet TEXTAREA;\n\n/**\n * A function that takes a url `{string}` and returns a url `{string}`.\n * Might be used to change an icon path or to substitute a\n * data url obtained from a KMZ array buffer.\n *\n * @typedef {function(string):string} IconUrlFunction\n * @api\n */\n\n/**\n * Function that returns a url unchanged.\n * @param {string} href Input url.\n * @return {string} Output url.\n */\nfunction defaultIconUrlFunction(href) {\n  return href;\n}\n\n/**\n * @typedef {Object} Options\n * @property {boolean} [extractStyles=true] Extract styles from the KML.\n * @property {boolean} [showPointNames=true] Show names as labels for placemarks which contain points.\n * @property {Array<Style>} [defaultStyle] Default style. The\n * default default style is the same as Google Earth.\n * @property {boolean} [writeStyles=true] Write styles into KML.\n * @property {null|string} [crossOrigin='anonymous'] The `crossOrigin` attribute for loaded images. Note that you must provide a\n * `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for loaded images.\n * @property {IconUrlFunction} [iconUrlFunction] Function that takes a url string and returns a url string.\n * Might be used to change an icon path or to substitute a data url obtained from a KMZ array buffer.\n */\n\n/**\n * @classdesc\n * Feature format for reading and writing data in the KML format.\n *\n * {@link module:ol/format/KML~KML#readFeature} will read the first feature from\n * a KML source.\n *\n * MultiGeometries are converted into GeometryCollections if they are a mix of\n * geometry types, and into MultiPoint/MultiLineString/MultiPolygon if they are\n * all of the same type.\n *\n * @api\n */\nclass KML extends XMLFeature {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    super();\n\n    options = options ? options : {};\n\n    if (!DEFAULT_STYLE_ARRAY) {\n      createStyleDefaults();\n    }\n\n    /**\n     * @type {import(\"../proj/Projection.js\").default}\n     */\n    this.dataProjection = getProjection('EPSG:4326');\n\n    /**\n     * @private\n     * @type {Array<Style>}\n     */\n    this.defaultStyle_ = options.defaultStyle\n      ? options.defaultStyle\n      : DEFAULT_STYLE_ARRAY;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.extractStyles_ =\n      options.extractStyles !== undefined ? options.extractStyles : true;\n\n    /**\n     * @type {boolean}\n     */\n    this.writeStyles_ =\n      options.writeStyles !== undefined ? options.writeStyles : true;\n\n    /**\n     * @private\n     * @type {!Object<string, (Array<Style>|string)>}\n     */\n    this.sharedStyles_ = {};\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.showPointNames_ =\n      options.showPointNames !== undefined ? options.showPointNames : true;\n\n    /**\n     * @type {null|string}\n     */\n    this.crossOrigin_ =\n      options.crossOrigin !== undefined ? options.crossOrigin : 'anonymous';\n\n    /**\n     * @type {ReferrerPolicy}\n     */\n    this.referrerPolicy_ = options.referrerPolicy;\n\n    /**\n     * @type {IconUrlFunction}\n     */\n    this.iconUrlFunction_ = options.iconUrlFunction\n      ? options.iconUrlFunction\n      : defaultIconUrlFunction;\n\n    this.supportedMediaTypes = ['application/vnd.google-earth.kml+xml'];\n  }\n\n  /**\n   * @param {Node} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @private\n   * @return {Array<Feature>|undefined} Features.\n   */\n  readDocumentOrFolder_(node, objectStack) {\n    // FIXME use scope somehow\n    const parsersNS = makeStructureNS(NAMESPACE_URIS, {\n      'Document': makeArrayExtender(this.readDocumentOrFolder_, this),\n      'Folder': makeArrayExtender(this.readDocumentOrFolder_, this),\n      'Placemark': makeArrayPusher(this.readPlacemark_, this),\n      'Style': this.readSharedStyle_.bind(this),\n      'StyleMap': this.readSharedStyleMap_.bind(this),\n    });\n    /** @type {Array<Feature>} */\n    // @ts-ignore\n    const features = pushParseAndPop([], parsersNS, node, objectStack, this);\n    if (features) {\n      return features;\n    }\n    return undefined;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @private\n   * @return {Feature|undefined} Feature.\n   */\n  readPlacemark_(node, objectStack) {\n    const object = pushParseAndPop(\n      {'geometry': null},\n      PLACEMARK_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    if (!object) {\n      return undefined;\n    }\n    const feature = new Feature();\n    const id = node.getAttribute('id');\n    if (id !== null) {\n      feature.setId(id);\n    }\n    const options = /** @type {import(\"./Feature.js\").ReadOptions} */ (\n      objectStack[0]\n    );\n\n    const geometry = object['geometry'];\n    if (geometry) {\n      transformGeometryWithOptions(geometry, false, options);\n    }\n    feature.setGeometry(geometry);\n    delete object['geometry'];\n\n    if (this.extractStyles_) {\n      const style = object['Style'];\n      const styleUrl = object['styleUrl'];\n      const styleFunction = createFeatureStyleFunction(\n        style,\n        styleUrl,\n        this.defaultStyle_,\n        this.sharedStyles_,\n        this.showPointNames_,\n      );\n      feature.setStyle(styleFunction);\n    }\n    delete object['Style'];\n    // we do not remove the styleUrl property from the object, so it\n    // gets stored on feature when setProperties is called\n\n    feature.setProperties(object, true);\n\n    return feature;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @private\n   */\n  readSharedStyle_(node, objectStack) {\n    const id = node.getAttribute('id');\n    if (id !== null) {\n      const style = readStyle.call(this, node, objectStack);\n      if (style) {\n        let styleUri;\n        let baseURI = node.baseURI;\n        if (!baseURI || baseURI == 'about:blank') {\n          baseURI = window.location.href;\n        }\n        if (baseURI) {\n          const url = new URL('#' + id, baseURI);\n          styleUri = url.href;\n        } else {\n          styleUri = '#' + id;\n        }\n        this.sharedStyles_[styleUri] = style;\n      }\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @private\n   */\n  readSharedStyleMap_(node, objectStack) {\n    const id = node.getAttribute('id');\n    if (id === null) {\n      return;\n    }\n    const styleMapValue = readStyleMapValue.call(this, node, objectStack);\n    if (!styleMapValue) {\n      return;\n    }\n    let styleUri;\n    let baseURI = node.baseURI;\n    if (!baseURI || baseURI == 'about:blank') {\n      baseURI = window.location.href;\n    }\n    if (baseURI) {\n      const url = new URL('#' + id, baseURI);\n      styleUri = url.href;\n    } else {\n      styleUri = '#' + id;\n    }\n    this.sharedStyles_[styleUri] = styleMapValue;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @return {import(\"../Feature.js\").default} Feature.\n   * @override\n   */\n  readFeatureFromNode(node, options) {\n    if (!NAMESPACE_URIS.includes(node.namespaceURI)) {\n      return null;\n    }\n    const feature = this.readPlacemark_(node, [\n      this.getReadOptions(node, options),\n    ]);\n    if (feature) {\n      return feature;\n    }\n    return null;\n  }\n\n  /**\n   * @protected\n   * @param {Element} node Node.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @return {Array<import(\"../Feature.js\").default>} Features.\n   * @override\n   */\n  readFeaturesFromNode(node, options) {\n    if (!NAMESPACE_URIS.includes(node.namespaceURI)) {\n      return [];\n    }\n    let features;\n    const localName = node.localName;\n    if (localName == 'Document' || localName == 'Folder') {\n      features = this.readDocumentOrFolder_(node, [\n        this.getReadOptions(node, options),\n      ]);\n      if (features) {\n        return features;\n      }\n      return [];\n    }\n    if (localName == 'Placemark') {\n      const feature = this.readPlacemark_(node, [\n        this.getReadOptions(node, options),\n      ]);\n      if (feature) {\n        return [feature];\n      }\n      return [];\n    }\n    if (localName == 'kml') {\n      features = [];\n      for (let n = node.firstElementChild; n; n = n.nextElementSibling) {\n        const fs = this.readFeaturesFromNode(n, options);\n        if (fs) {\n          extend(features, fs);\n        }\n      }\n      return features;\n    }\n    return [];\n  }\n\n  /**\n   * Read the name of the KML.\n   *\n   * @param {Document|Element|string} source Source.\n   * @return {string|undefined} Name.\n   * @api\n   */\n  readName(source) {\n    if (!source) {\n      return undefined;\n    }\n    if (typeof source === 'string') {\n      const doc = parse(source);\n      return this.readNameFromDocument(doc);\n    }\n    if (isDocument(source)) {\n      return this.readNameFromDocument(/** @type {Document} */ (source));\n    }\n    return this.readNameFromNode(/** @type {Element} */ (source));\n  }\n\n  /**\n   * @param {Document} doc Document.\n   * @return {string|undefined} Name.\n   */\n  readNameFromDocument(doc) {\n    for (let n = /** @type {Node} */ (doc.firstChild); n; n = n.nextSibling) {\n      if (n.nodeType == Node.ELEMENT_NODE) {\n        const name = this.readNameFromNode(/** @type {Element} */ (n));\n        if (name) {\n          return name;\n        }\n      }\n    }\n    return undefined;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @return {string|undefined} Name.\n   */\n  readNameFromNode(node) {\n    for (let n = node.firstElementChild; n; n = n.nextElementSibling) {\n      if (NAMESPACE_URIS.includes(n.namespaceURI) && n.localName == 'name') {\n        return readString(n);\n      }\n    }\n    for (let n = node.firstElementChild; n; n = n.nextElementSibling) {\n      const localName = n.localName;\n      if (\n        NAMESPACE_URIS.includes(n.namespaceURI) &&\n        (localName == 'Document' ||\n          localName == 'Folder' ||\n          localName == 'Placemark' ||\n          localName == 'kml')\n      ) {\n        const name = this.readNameFromNode(n);\n        if (name) {\n          return name;\n        }\n      }\n    }\n    return undefined;\n  }\n\n  /**\n   * Read the network links of the KML.\n   *\n   * @param {Document|Element|string} source Source.\n   * @return {Array<Object>} Network links.\n   * @api\n   */\n  readNetworkLinks(source) {\n    const networkLinks = [];\n    if (typeof source === 'string') {\n      const doc = parse(source);\n      extend(networkLinks, this.readNetworkLinksFromDocument(doc));\n    } else if (isDocument(source)) {\n      extend(\n        networkLinks,\n        this.readNetworkLinksFromDocument(/** @type {Document} */ (source)),\n      );\n    } else {\n      extend(\n        networkLinks,\n        this.readNetworkLinksFromNode(/** @type {Element} */ (source)),\n      );\n    }\n    return networkLinks;\n  }\n\n  /**\n   * @param {Document} doc Document.\n   * @return {Array<Object>} Network links.\n   */\n  readNetworkLinksFromDocument(doc) {\n    const networkLinks = [];\n    for (let n = /** @type {Node} */ (doc.firstChild); n; n = n.nextSibling) {\n      if (n.nodeType == Node.ELEMENT_NODE) {\n        extend(\n          networkLinks,\n          this.readNetworkLinksFromNode(/** @type {Element} */ (n)),\n        );\n      }\n    }\n    return networkLinks;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @return {Array<Object>} Network links.\n   */\n  readNetworkLinksFromNode(node) {\n    const networkLinks = [];\n    for (let n = node.firstElementChild; n; n = n.nextElementSibling) {\n      if (\n        NAMESPACE_URIS.includes(n.namespaceURI) &&\n        n.localName == 'NetworkLink'\n      ) {\n        const obj = pushParseAndPop({}, NETWORK_LINK_PARSERS, n, []);\n        networkLinks.push(obj);\n      }\n    }\n    for (let n = node.firstElementChild; n; n = n.nextElementSibling) {\n      const localName = n.localName;\n      if (\n        NAMESPACE_URIS.includes(n.namespaceURI) &&\n        (localName == 'Document' || localName == 'Folder' || localName == 'kml')\n      ) {\n        extend(networkLinks, this.readNetworkLinksFromNode(n));\n      }\n    }\n    return networkLinks;\n  }\n\n  /**\n   * Read the regions of the KML.\n   *\n   * @param {Document|Element|string} source Source.\n   * @return {Array<Object>} Regions.\n   * @api\n   */\n  readRegion(source) {\n    const regions = [];\n    if (typeof source === 'string') {\n      const doc = parse(source);\n      extend(regions, this.readRegionFromDocument(doc));\n    } else if (isDocument(source)) {\n      extend(\n        regions,\n        this.readRegionFromDocument(/** @type {Document} */ (source)),\n      );\n    } else {\n      extend(regions, this.readRegionFromNode(/** @type {Element} */ (source)));\n    }\n    return regions;\n  }\n\n  /**\n   * @param {Document} doc Document.\n   * @return {Array<Object>} Region.\n   */\n  readRegionFromDocument(doc) {\n    const regions = [];\n    for (let n = /** @type {Node} */ (doc.firstChild); n; n = n.nextSibling) {\n      if (n.nodeType == Node.ELEMENT_NODE) {\n        extend(regions, this.readRegionFromNode(/** @type {Element} */ (n)));\n      }\n    }\n    return regions;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @return {Array<Object>} Region.\n   * @api\n   */\n  readRegionFromNode(node) {\n    const regions = [];\n    for (let n = node.firstElementChild; n; n = n.nextElementSibling) {\n      if (NAMESPACE_URIS.includes(n.namespaceURI) && n.localName == 'Region') {\n        const obj = pushParseAndPop({}, REGION_PARSERS, n, []);\n        regions.push(obj);\n      }\n    }\n    for (let n = node.firstElementChild; n; n = n.nextElementSibling) {\n      const localName = n.localName;\n      if (\n        NAMESPACE_URIS.includes(n.namespaceURI) &&\n        (localName == 'Document' || localName == 'Folder' || localName == 'kml')\n      ) {\n        extend(regions, this.readRegionFromNode(n));\n      }\n    }\n    return regions;\n  }\n\n  /**\n   * @typedef {Object} KMLCamera Specifies the observer's viewpoint and associated view parameters.\n   * @property {number} [Latitude] Latitude of the camera.\n   * @property {number} [Longitude] Longitude of the camera.\n   * @property {number} [Altitude] Altitude of the camera.\n   * @property {string} [AltitudeMode] Floor-related altitude mode.\n   * @property {number} [Heading] Horizontal camera rotation.\n   * @property {number} [Tilt] Lateral camera rotation.\n   * @property {number} [Roll] Vertical camera rotation.\n   */\n\n  /**\n   * Read the cameras of the KML.\n   *\n   * @param {Document|Element|string} source Source.\n   * @return {Array<KMLCamera>} Cameras.\n   * @api\n   */\n  readCamera(source) {\n    const cameras = [];\n    if (typeof source === 'string') {\n      const doc = parse(source);\n      extend(cameras, this.readCameraFromDocument(doc));\n    } else if (isDocument(source)) {\n      extend(\n        cameras,\n        this.readCameraFromDocument(/** @type {Document} */ (source)),\n      );\n    } else {\n      extend(cameras, this.readCameraFromNode(/** @type {Element} */ (source)));\n    }\n    return cameras;\n  }\n\n  /**\n   * @param {Document} doc Document.\n   * @return {Array<KMLCamera>} Cameras.\n   */\n  readCameraFromDocument(doc) {\n    const cameras = [];\n    for (let n = /** @type {Node} */ (doc.firstChild); n; n = n.nextSibling) {\n      if (n.nodeType === Node.ELEMENT_NODE) {\n        extend(cameras, this.readCameraFromNode(/** @type {Element} */ (n)));\n      }\n    }\n    return cameras;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @return {Array<KMLCamera>} Cameras.\n   * @api\n   */\n  readCameraFromNode(node) {\n    const cameras = [];\n    for (let n = node.firstElementChild; n; n = n.nextElementSibling) {\n      if (NAMESPACE_URIS.includes(n.namespaceURI) && n.localName === 'Camera') {\n        const obj = pushParseAndPop({}, CAMERA_PARSERS, n, []);\n        cameras.push(obj);\n      }\n    }\n    for (let n = node.firstElementChild; n; n = n.nextElementSibling) {\n      const localName = n.localName;\n      if (\n        NAMESPACE_URIS.includes(n.namespaceURI) &&\n        (localName === 'Document' ||\n          localName === 'Folder' ||\n          localName === 'Placemark' ||\n          localName === 'kml')\n      ) {\n        extend(cameras, this.readCameraFromNode(n));\n      }\n    }\n    return cameras;\n  }\n\n  /**\n   * Encode an array of features in the KML format as an XML node. GeometryCollections,\n   * MultiPoints, MultiLineStrings, and MultiPolygons are output as MultiGeometries.\n   *\n   * @param {Array<Feature>} features Features.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Options.\n   * @return {Node} Node.\n   * @api\n   * @override\n   */\n  writeFeaturesNode(features, options) {\n    options = this.adaptOptions(options);\n    const kml = createElementNS(NAMESPACE_URIS[4], 'kml');\n    const xmlnsUri = 'http://www.w3.org/2000/xmlns/';\n    kml.setAttributeNS(xmlnsUri, 'xmlns:gx', GX_NAMESPACE_URIS[0]);\n    kml.setAttributeNS(xmlnsUri, 'xmlns:xsi', XML_SCHEMA_INSTANCE_URI);\n    kml.setAttributeNS(\n      XML_SCHEMA_INSTANCE_URI,\n      'xsi:schemaLocation',\n      SCHEMA_LOCATION,\n    );\n\n    const /** @type {import(\"../xml.js\").NodeStackItem} */ context = {\n        node: kml,\n      };\n    /** @type {!Object<string, (Array<Feature>|Feature|undefined)>} */\n    const properties = {};\n    if (features.length > 1) {\n      properties['Document'] = features;\n    } else if (features.length == 1) {\n      properties['Placemark'] = features[0];\n    }\n    const orderedKeys = KML_SEQUENCE[kml.namespaceURI];\n    const values = makeSequence(properties, orderedKeys);\n    pushSerializeAndPop(\n      context,\n      KML_SERIALIZERS,\n      OBJECT_PROPERTY_NODE_FACTORY,\n      values,\n      [options],\n      orderedKeys,\n      this,\n    );\n    return kml;\n  }\n}\n\n/**\n * @param {Style|undefined} foundStyle Style.\n * @param {string} name Name.\n * @return {Style} style Style.\n */\nfunction createNameStyleFunction(foundStyle, name) {\n  const textOffset = [0, 0];\n  /** @type {CanvasTextAlign} */\n  let textAlign = 'start';\n  const imageStyle = foundStyle.getImage();\n  if (imageStyle) {\n    const imageSize = imageStyle.getSize();\n    if (imageSize && imageSize.length == 2) {\n      const imageScale = imageStyle.getScaleArray();\n      const anchor = imageStyle.getAnchor();\n      // Offset the label to be centered to the right of the icon,\n      // if there is one.\n      textOffset[0] = imageScale[0] * (imageSize[0] - anchor[0]);\n      textOffset[1] = imageScale[1] * (imageSize[1] / 2 - anchor[1]);\n      textAlign = 'left';\n    }\n  }\n  let textStyle = foundStyle.getText();\n  if (textStyle) {\n    // clone the text style, customizing it with name, alignments and offset.\n    // Note that kml does not support many text options that OpenLayers does (rotation, textBaseline).\n    textStyle = textStyle.clone();\n    textStyle.setFont(textStyle.getFont() || DEFAULT_TEXT_STYLE.getFont());\n    textStyle.setScale(textStyle.getScale() || DEFAULT_TEXT_STYLE.getScale());\n    textStyle.setFill(textStyle.getFill() || DEFAULT_TEXT_STYLE.getFill());\n    textStyle.setStroke(textStyle.getStroke() || DEFAULT_TEXT_STROKE_STYLE);\n  } else {\n    textStyle = DEFAULT_TEXT_STYLE.clone();\n  }\n  textStyle.setText(name);\n  textStyle.setOffsetX(textOffset[0]);\n  textStyle.setOffsetY(textOffset[1]);\n  textStyle.setTextAlign(textAlign);\n\n  const nameStyle = new Style({\n    image: imageStyle,\n    text: textStyle,\n  });\n  return nameStyle;\n}\n\n/**\n * @param {Array<Style>|undefined} style Style.\n * @param {string} styleUrl Style URL.\n * @param {Array<Style>} defaultStyle Default style.\n * @param {!Object<string, (Array<Style>|string)>} sharedStyles Shared styles.\n * @param {boolean|undefined} showPointNames true to show names for point placemarks.\n * @return {import(\"../style/Style.js\").StyleFunction} Feature style function.\n */\nfunction createFeatureStyleFunction(\n  style,\n  styleUrl,\n  defaultStyle,\n  sharedStyles,\n  showPointNames,\n) {\n  return (\n    /**\n     * @param {Feature} feature feature.\n     * @param {number} resolution Resolution.\n     * @return {Array<Style>|Style} Style.\n     */\n    function (feature, resolution) {\n      let drawName = showPointNames;\n      let name = '';\n      let multiGeometryPoints = [];\n      if (drawName) {\n        const geometry = feature.getGeometry();\n        if (geometry) {\n          if (geometry instanceof GeometryCollection) {\n            multiGeometryPoints = geometry\n              .getGeometriesArrayRecursive()\n              .filter(function (geometry) {\n                const type = geometry.getType();\n                return type === 'Point' || type === 'MultiPoint';\n              });\n            drawName = multiGeometryPoints.length > 0;\n          } else {\n            const type = geometry.getType();\n            drawName = type === 'Point' || type === 'MultiPoint';\n          }\n        }\n      }\n\n      if (drawName) {\n        name = /** @type {string} */ (feature.get('name'));\n        drawName = drawName && !!name;\n        // convert any html character codes\n        if (drawName && /&[^&]+;/.test(name)) {\n          if (!TEXTAREA) {\n            TEXTAREA = document.createElement('textarea');\n          }\n          TEXTAREA.innerHTML = name;\n          name = TEXTAREA.value;\n        }\n      }\n\n      let featureStyle = defaultStyle;\n      if (style) {\n        featureStyle = style;\n      } else if (styleUrl) {\n        featureStyle = findStyle(styleUrl, defaultStyle, sharedStyles);\n      }\n      if (drawName) {\n        const nameStyle = createNameStyleFunction(featureStyle[0], name);\n        if (multiGeometryPoints.length > 0) {\n          // in multigeometries restrict the name style to points and create a\n          // style without image or text for geometries requiring fill or stroke\n          // including any polygon specific style if there is one\n          nameStyle.setGeometry(new GeometryCollection(multiGeometryPoints));\n          const baseStyle = new Style({\n            geometry: featureStyle[0].getGeometry(),\n            image: null,\n            fill: featureStyle[0].getFill(),\n            stroke: featureStyle[0].getStroke(),\n            text: null,\n          });\n          return [nameStyle, baseStyle].concat(featureStyle.slice(1));\n        }\n        return nameStyle;\n      }\n      return featureStyle;\n    }\n  );\n}\n\n/**\n * @param {Array<Style>|string|undefined} styleValue Style value.\n * @param {Array<Style>} defaultStyle Default style.\n * @param {!Object<string, (Array<Style>|string)>} sharedStyles\n * Shared styles.\n * @return {Array<Style>} Style.\n */\nfunction findStyle(styleValue, defaultStyle, sharedStyles) {\n  if (Array.isArray(styleValue)) {\n    return styleValue;\n  }\n  if (typeof styleValue === 'string') {\n    return findStyle(sharedStyles[styleValue], defaultStyle, sharedStyles);\n  }\n  return defaultStyle;\n}\n\n/**\n * @param {Node} node Node.\n * @return {import(\"../color.js\").Color|undefined} Color.\n */\nfunction readColor(node) {\n  const s = getAllTextContent(node, false);\n  // The KML specification states that colors should not include a leading `#`\n  // but we tolerate them.\n  const m = /^\\s*#?\\s*([0-9A-Fa-f]{8})\\s*$/.exec(s);\n  if (m) {\n    const hexColor = m[1];\n    return [\n      parseInt(hexColor.substr(6, 2), 16),\n      parseInt(hexColor.substr(4, 2), 16),\n      parseInt(hexColor.substr(2, 2), 16),\n      parseInt(hexColor.substr(0, 2), 16) / 255,\n    ];\n  }\n  return undefined;\n}\n\n/**\n * @param {Node} node Node.\n * @return {Array<number>|undefined} Flat coordinates.\n */\nexport function readFlatCoordinates(node) {\n  let s = getAllTextContent(node, false);\n  const flatCoordinates = [];\n  // The KML specification states that coordinate tuples should not include\n  // spaces, but we tolerate them.\n  s = s.replace(/\\s*,\\s*/g, ',');\n  const re =\n    /^\\s*([+\\-]?\\d*\\.?\\d+(?:e[+\\-]?\\d+)?),([+\\-]?\\d*\\.?\\d+(?:e[+\\-]?\\d+)?)(?:\\s+|,|$)(?:([+\\-]?\\d*\\.?\\d+(?:e[+\\-]?\\d+)?)(?:\\s+|$))?\\s*/i;\n  let m;\n  while ((m = re.exec(s))) {\n    const x = parseFloat(m[1]);\n    const y = parseFloat(m[2]);\n    const z = m[3] ? parseFloat(m[3]) : 0;\n    flatCoordinates.push(x, y, z);\n    s = s.substr(m[0].length);\n  }\n  if (s !== '') {\n    return undefined;\n  }\n  return flatCoordinates;\n}\n\n/**\n * @param {Node} node Node.\n * @return {string} URI.\n */\nfunction readURI(node) {\n  const s = getAllTextContent(node, false).trim();\n  let baseURI = node.baseURI;\n  if (!baseURI || baseURI == 'about:blank') {\n    baseURI = window.location.href;\n  }\n  if (baseURI) {\n    const url = new URL(s, baseURI);\n    return url.href;\n  }\n  return s;\n}\n\n/**\n * @param {Node} node Node.\n * @return {string} URI.\n */\nfunction readStyleURL(node) {\n  // KML files in the wild occasionally forget the leading\n  // `#` on styleUrlsdefined in the same document.\n  const s = getAllTextContent(node, false)\n    .trim()\n    .replace(/^(?!.*#)/, '#');\n  let baseURI = node.baseURI;\n  if (!baseURI || baseURI == 'about:blank') {\n    baseURI = window.location.href;\n  }\n  if (baseURI) {\n    const url = new URL(s, baseURI);\n    return url.href;\n  }\n  return s;\n}\n\n/**\n * @param {Element} node Node.\n * @return {Vec2} Vec2.\n */\nfunction readVec2(node) {\n  const xunits = node.getAttribute('xunits');\n  const yunits = node.getAttribute('yunits');\n  /** @type {import('../style/Icon.js').IconOrigin} */\n  let origin;\n  if (xunits !== 'insetPixels') {\n    if (yunits !== 'insetPixels') {\n      origin = 'bottom-left';\n    } else {\n      origin = 'top-left';\n    }\n  } else {\n    if (yunits !== 'insetPixels') {\n      origin = 'bottom-right';\n    } else {\n      origin = 'top-right';\n    }\n  }\n  return {\n    x: parseFloat(node.getAttribute('x')),\n    xunits: ICON_ANCHOR_UNITS_MAP[xunits],\n    y: parseFloat(node.getAttribute('y')),\n    yunits: ICON_ANCHOR_UNITS_MAP[yunits],\n    origin: origin,\n  };\n}\n\n/**\n * @param {Node} node Node.\n * @return {number|undefined} Scale.\n */\nfunction readScale(node) {\n  return readDecimal(node);\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst STYLE_MAP_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Pair': pairDataParser,\n});\n\n/**\n * @this {KML}\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Array<Style>|string|undefined} StyleMap.\n */\nfunction readStyleMapValue(node, objectStack) {\n  return pushParseAndPop(undefined, STYLE_MAP_PARSERS, node, objectStack, this);\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst ICON_STYLE_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Icon': makeObjectPropertySetter(readIcon),\n  'color': makeObjectPropertySetter(readColor),\n  'heading': makeObjectPropertySetter(readDecimal),\n  'hotSpot': makeObjectPropertySetter(readVec2),\n  'scale': makeObjectPropertySetter(readScale),\n});\n\n/**\n * @this {KML}\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction iconStyleParser(node, objectStack) {\n  // FIXME refreshMode\n  // FIXME refreshInterval\n  // FIXME viewRefreshTime\n  // FIXME viewBoundScale\n  // FIXME viewFormat\n  // FIXME httpQuery\n  const object = pushParseAndPop({}, ICON_STYLE_PARSERS, node, objectStack);\n  if (!object) {\n    return;\n  }\n  const styleObject = /** @type {Object} */ (\n    objectStack[objectStack.length - 1]\n  );\n  const IconObject = 'Icon' in object ? object['Icon'] : {};\n  const drawIcon = !('Icon' in object) || Object.keys(IconObject).length > 0;\n  let src;\n  const href = /** @type {string|undefined} */ (IconObject['href']);\n  if (href) {\n    src = href;\n  } else if (drawIcon) {\n    src = DEFAULT_IMAGE_STYLE_SRC;\n  }\n  let anchor, anchorXUnits, anchorYUnits;\n  /** @type {import('../style/Icon.js').IconOrigin|undefined} */\n  let anchorOrigin = 'bottom-left';\n  const hotSpot = /** @type {Vec2|undefined} */ (object['hotSpot']);\n  if (hotSpot) {\n    anchor = [hotSpot.x, hotSpot.y];\n    anchorXUnits = hotSpot.xunits;\n    anchorYUnits = hotSpot.yunits;\n    anchorOrigin = hotSpot.origin;\n  } else if (/^https?:\\/\\/maps\\.(?:google|gstatic)\\.com\\//.test(src)) {\n    // Google hotspots from https://kml4earth.appspot.com/icons.html#notes\n    if (src.includes('pushpin')) {\n      anchor = DEFAULT_IMAGE_STYLE_ANCHOR;\n      anchorXUnits = DEFAULT_IMAGE_STYLE_ANCHOR_X_UNITS;\n      anchorYUnits = DEFAULT_IMAGE_STYLE_ANCHOR_Y_UNITS;\n    } else if (src.includes('arrow-reverse')) {\n      anchor = [54, 42];\n      anchorXUnits = DEFAULT_IMAGE_STYLE_ANCHOR_X_UNITS;\n      anchorYUnits = DEFAULT_IMAGE_STYLE_ANCHOR_Y_UNITS;\n    } else if (src.includes('paddle')) {\n      anchor = [32, 1];\n      anchorXUnits = DEFAULT_IMAGE_STYLE_ANCHOR_X_UNITS;\n      anchorYUnits = DEFAULT_IMAGE_STYLE_ANCHOR_Y_UNITS;\n    }\n  }\n\n  let offset;\n  const x = /** @type {number|undefined} */ (IconObject['x']);\n  const y = /** @type {number|undefined} */ (IconObject['y']);\n  if (x !== undefined && y !== undefined) {\n    offset = [x, y];\n  }\n\n  let size;\n  const w = /** @type {number|undefined} */ (IconObject['w']);\n  const h = /** @type {number|undefined} */ (IconObject['h']);\n  if (w !== undefined && h !== undefined) {\n    size = [w, h];\n  }\n\n  let rotation;\n  const heading = /** @type {number} */ (object['heading']);\n  if (heading !== undefined) {\n    rotation = toRadians(heading);\n  }\n\n  const scale = /** @type {number|undefined} */ (object['scale']);\n\n  const color = /** @type {Array<number>|undefined} */ (object['color']);\n\n  if (drawIcon) {\n    if (src == DEFAULT_IMAGE_STYLE_SRC) {\n      size = DEFAULT_IMAGE_STYLE_SIZE;\n    }\n\n    const imageStyle = new Icon({\n      anchor: anchor,\n      anchorOrigin: anchorOrigin,\n      anchorXUnits: anchorXUnits,\n      anchorYUnits: anchorYUnits,\n      crossOrigin: this.crossOrigin_,\n      referrerPolicy: this.referrerPolicy_,\n      offset: offset,\n      offsetOrigin: 'bottom-left',\n      rotation: rotation,\n      scale: scale,\n      size: size,\n      src: this.iconUrlFunction_(src),\n      color: color,\n    });\n\n    const imageScale = imageStyle.getScaleArray()[0];\n    const imageSize = imageStyle.getSize();\n    if (imageSize === null) {\n      const imageState = imageStyle.getImageState();\n      if (imageState === ImageState.IDLE || imageState === ImageState.LOADING) {\n        const listener = function () {\n          const imageState = imageStyle.getImageState();\n          if (\n            !(\n              imageState === ImageState.IDLE ||\n              imageState === ImageState.LOADING\n            )\n          ) {\n            const imageSize = imageStyle.getSize();\n            if (imageSize && imageSize.length == 2) {\n              const resizeScale = scaleForSize(imageSize);\n              imageStyle.setScale(imageScale * resizeScale);\n            }\n            imageStyle.unlistenImageChange(listener);\n          }\n        };\n        imageStyle.listenImageChange(listener);\n        if (imageState === ImageState.IDLE) {\n          imageStyle.load();\n        }\n      }\n    } else if (imageSize.length == 2) {\n      const resizeScale = scaleForSize(imageSize);\n      imageStyle.setScale(imageScale * resizeScale);\n    }\n    styleObject['imageStyle'] = imageStyle;\n  } else {\n    // handle the case when we explicitly want to draw no icon.\n    styleObject['imageStyle'] = DEFAULT_NO_IMAGE_STYLE;\n  }\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst LABEL_STYLE_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'color': makeObjectPropertySetter(readColor),\n  'scale': makeObjectPropertySetter(readScale),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction labelStyleParser(node, objectStack) {\n  // FIXME colorMode\n  const object = pushParseAndPop({}, LABEL_STYLE_PARSERS, node, objectStack);\n  if (!object) {\n    return;\n  }\n  const styleObject = objectStack[objectStack.length - 1];\n  const textStyle = new Text({\n    fill: new Fill({\n      color:\n        /** @type {import(\"../color.js\").Color} */\n        ('color' in object ? object['color'] : DEFAULT_COLOR),\n    }),\n    scale: /** @type {number|undefined} */ (object['scale']),\n  });\n  styleObject['textStyle'] = textStyle;\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst LINE_STYLE_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'color': makeObjectPropertySetter(readColor),\n  'width': makeObjectPropertySetter(readDecimal),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction lineStyleParser(node, objectStack) {\n  // FIXME colorMode\n  // FIXME gx:outerColor\n  // FIXME gx:outerWidth\n  // FIXME gx:physicalWidth\n  // FIXME gx:labelVisibility\n  const object = pushParseAndPop({}, LINE_STYLE_PARSERS, node, objectStack);\n  if (!object) {\n    return;\n  }\n  const styleObject = objectStack[objectStack.length - 1];\n  const strokeStyle = new Stroke({\n    color:\n      /** @type {import(\"../color.js\").Color} */\n      ('color' in object ? object['color'] : DEFAULT_COLOR),\n    width: /** @type {number} */ ('width' in object ? object['width'] : 1),\n  });\n  styleObject['strokeStyle'] = strokeStyle;\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst POLY_STYLE_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'color': makeObjectPropertySetter(readColor),\n  'fill': makeObjectPropertySetter(readBoolean),\n  'outline': makeObjectPropertySetter(readBoolean),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction polyStyleParser(node, objectStack) {\n  // FIXME colorMode\n  const object = pushParseAndPop({}, POLY_STYLE_PARSERS, node, objectStack);\n  if (!object) {\n    return;\n  }\n  const styleObject = objectStack[objectStack.length - 1];\n  const fillStyle = new Fill({\n    color:\n      /** @type {import(\"../color.js\").Color} */\n      ('color' in object ? object['color'] : DEFAULT_COLOR),\n  });\n  styleObject['fillStyle'] = fillStyle;\n  const fill = /** @type {boolean|undefined} */ (object['fill']);\n  if (fill !== undefined) {\n    styleObject['fill'] = fill;\n  }\n  const outline = /** @type {boolean|undefined} */ (object['outline']);\n  if (outline !== undefined) {\n    styleObject['outline'] = outline;\n  }\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst FLAT_LINEAR_RING_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'coordinates': makeReplacer(readFlatCoordinates),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Array<number>} LinearRing flat coordinates.\n */\nfunction readFlatLinearRing(node, objectStack) {\n  return pushParseAndPop(null, FLAT_LINEAR_RING_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Node} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction gxCoordParser(node, objectStack) {\n  const gxTrackObject =\n    /** @type {GxTrackObject} */\n    (objectStack[objectStack.length - 1]);\n  const coordinates = gxTrackObject.coordinates;\n  const s = getAllTextContent(node, false);\n  const re =\n    /^\\s*([+\\-]?\\d+(?:\\.\\d*)?(?:e[+\\-]?\\d*)?)\\s+([+\\-]?\\d+(?:\\.\\d*)?(?:e[+\\-]?\\d*)?)\\s+([+\\-]?\\d+(?:\\.\\d*)?(?:e[+\\-]?\\d*)?)\\s*$/i;\n  const m = re.exec(s);\n  if (m) {\n    const x = parseFloat(m[1]);\n    const y = parseFloat(m[2]);\n    const z = parseFloat(m[3]);\n    coordinates.push([x, y, z]);\n  } else {\n    coordinates.push([]);\n  }\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst GX_MULTITRACK_GEOMETRY_PARSERS = makeStructureNS(GX_NAMESPACE_URIS, {\n  'Track': makeArrayPusher(readGxTrack),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {MultiLineString|undefined} MultiLineString.\n */\nfunction readGxMultiTrack(node, objectStack) {\n  const lineStrings = pushParseAndPop(\n    [],\n    GX_MULTITRACK_GEOMETRY_PARSERS,\n    node,\n    objectStack,\n  );\n  if (!lineStrings) {\n    return undefined;\n  }\n  return new MultiLineString(lineStrings);\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst GX_TRACK_PARSERS = makeStructureNS(\n  NAMESPACE_URIS,\n  {\n    'when': whenParser,\n  },\n  makeStructureNS(GX_NAMESPACE_URIS, {\n    'coord': gxCoordParser,\n  }),\n);\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {LineString|undefined} LineString.\n */\nfunction readGxTrack(node, objectStack) {\n  const gxTrackObject = pushParseAndPop(\n    /** @type {GxTrackObject} */ ({\n      coordinates: [],\n      whens: [],\n    }),\n    GX_TRACK_PARSERS,\n    node,\n    objectStack,\n  );\n  if (!gxTrackObject) {\n    return undefined;\n  }\n  const flatCoordinates = [];\n  const coordinates = gxTrackObject.coordinates;\n  const whens = gxTrackObject.whens;\n  for (\n    let i = 0, ii = Math.min(coordinates.length, whens.length);\n    i < ii;\n    ++i\n  ) {\n    if (coordinates[i].length == 3) {\n      flatCoordinates.push(\n        coordinates[i][0],\n        coordinates[i][1],\n        coordinates[i][2],\n        whens[i],\n      );\n    }\n  }\n  return new LineString(flatCoordinates, 'XYZM');\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst ICON_PARSERS = makeStructureNS(\n  NAMESPACE_URIS,\n  {\n    'href': makeObjectPropertySetter(readURI),\n  },\n  makeStructureNS(GX_NAMESPACE_URIS, {\n    'x': makeObjectPropertySetter(readDecimal),\n    'y': makeObjectPropertySetter(readDecimal),\n    'w': makeObjectPropertySetter(readDecimal),\n    'h': makeObjectPropertySetter(readDecimal),\n  }),\n);\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object} Icon object.\n */\nfunction readIcon(node, objectStack) {\n  const iconObject = pushParseAndPop({}, ICON_PARSERS, node, objectStack);\n  if (iconObject) {\n    return iconObject;\n  }\n  return null;\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst GEOMETRY_FLAT_COORDINATES_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'coordinates': makeReplacer(readFlatCoordinates),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Array<number>} Flat coordinates.\n */\nfunction readFlatCoordinatesFromNode(node, objectStack) {\n  return pushParseAndPop(\n    null,\n    GEOMETRY_FLAT_COORDINATES_PARSERS,\n    node,\n    objectStack,\n  );\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst EXTRUDE_AND_ALTITUDE_MODE_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'extrude': makeObjectPropertySetter(readBoolean),\n  'tessellate': makeObjectPropertySetter(readBoolean),\n  'altitudeMode': makeObjectPropertySetter(readString),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {LineString|undefined} LineString.\n */\nfunction readLineString(node, objectStack) {\n  const properties = pushParseAndPop(\n    {},\n    EXTRUDE_AND_ALTITUDE_MODE_PARSERS,\n    node,\n    objectStack,\n  );\n  const flatCoordinates = readFlatCoordinatesFromNode(node, objectStack);\n  if (flatCoordinates) {\n    const lineString = new LineString(flatCoordinates, 'XYZ');\n    lineString.setProperties(properties, true);\n    return lineString;\n  }\n  return undefined;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Polygon|undefined} Polygon.\n */\nfunction readLinearRing(node, objectStack) {\n  const properties = pushParseAndPop(\n    {},\n    EXTRUDE_AND_ALTITUDE_MODE_PARSERS,\n    node,\n    objectStack,\n  );\n  const flatCoordinates = readFlatCoordinatesFromNode(node, objectStack);\n  if (flatCoordinates) {\n    const polygon = new Polygon(flatCoordinates, 'XYZ', [\n      flatCoordinates.length,\n    ]);\n    polygon.setProperties(properties, true);\n    return polygon;\n  }\n  return undefined;\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst MULTI_GEOMETRY_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'LineString': makeArrayPusher(readLineString),\n  'LinearRing': makeArrayPusher(readLinearRing),\n  'MultiGeometry': makeArrayPusher(readMultiGeometry),\n  'Point': makeArrayPusher(readPoint),\n  'Polygon': makeArrayPusher(readPolygon),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {import(\"../geom/Geometry.js\").default} Geometry.\n */\nfunction readMultiGeometry(node, objectStack) {\n  const geometries = pushParseAndPop(\n    [],\n    MULTI_GEOMETRY_PARSERS,\n    node,\n    objectStack,\n  );\n  if (!geometries) {\n    return null;\n  }\n  if (geometries.length === 0) {\n    return new GeometryCollection(geometries);\n  }\n  let multiGeometry;\n  let homogeneous = true;\n  const type = geometries[0].getType();\n  let geometry;\n  for (let i = 1, ii = geometries.length; i < ii; ++i) {\n    geometry = geometries[i];\n    if (geometry.getType() != type) {\n      homogeneous = false;\n      break;\n    }\n  }\n  if (homogeneous) {\n    let layout;\n    let flatCoordinates;\n    if (type == 'Point') {\n      const point = geometries[0];\n      layout = point.getLayout();\n      flatCoordinates = point.getFlatCoordinates();\n      for (let i = 1, ii = geometries.length; i < ii; ++i) {\n        geometry = geometries[i];\n        extend(flatCoordinates, geometry.getFlatCoordinates());\n      }\n      multiGeometry = new MultiPoint(flatCoordinates, layout);\n      setCommonGeometryProperties(multiGeometry, geometries);\n    } else if (type == 'LineString') {\n      multiGeometry = new MultiLineString(geometries);\n      setCommonGeometryProperties(multiGeometry, geometries);\n    } else if (type == 'Polygon') {\n      multiGeometry = new MultiPolygon(geometries);\n      setCommonGeometryProperties(multiGeometry, geometries);\n    } else if (type == 'GeometryCollection' || type.startsWith('Multi')) {\n      multiGeometry = new GeometryCollection(geometries);\n    } else {\n      throw new Error('Unknown geometry type found');\n    }\n  } else {\n    multiGeometry = new GeometryCollection(geometries);\n  }\n  return /** @type {import(\"../geom/Geometry.js\").default} */ (multiGeometry);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Point|undefined} Point.\n */\nfunction readPoint(node, objectStack) {\n  const properties = pushParseAndPop(\n    {},\n    EXTRUDE_AND_ALTITUDE_MODE_PARSERS,\n    node,\n    objectStack,\n  );\n  const flatCoordinates = readFlatCoordinatesFromNode(node, objectStack);\n  if (flatCoordinates) {\n    const point = new Point(flatCoordinates, 'XYZ');\n    point.setProperties(properties, true);\n    return point;\n  }\n  return undefined;\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst FLAT_LINEAR_RINGS_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'innerBoundaryIs': innerBoundaryIsParser,\n  'outerBoundaryIs': outerBoundaryIsParser,\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Polygon|undefined} Polygon.\n */\nfunction readPolygon(node, objectStack) {\n  const properties = pushParseAndPop(\n    /** @type {Object<string,*>} */ ({}),\n    EXTRUDE_AND_ALTITUDE_MODE_PARSERS,\n    node,\n    objectStack,\n  );\n  const flatLinearRings = pushParseAndPop(\n    [null],\n    FLAT_LINEAR_RINGS_PARSERS,\n    node,\n    objectStack,\n  );\n  if (flatLinearRings && flatLinearRings[0]) {\n    const flatCoordinates = flatLinearRings[0];\n    const ends = [flatCoordinates.length];\n    for (let i = 1, ii = flatLinearRings.length; i < ii; ++i) {\n      extend(flatCoordinates, flatLinearRings[i]);\n      ends.push(flatCoordinates.length);\n    }\n    const polygon = new Polygon(flatCoordinates, 'XYZ', ends);\n    polygon.setProperties(properties, true);\n    return polygon;\n  }\n  return undefined;\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst STYLE_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'IconStyle': iconStyleParser,\n  'LabelStyle': labelStyleParser,\n  'LineStyle': lineStyleParser,\n  'PolyStyle': polyStyleParser,\n});\n\n/**\n * @this {KML}\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Array<Style>} Style.\n */\nfunction readStyle(node, objectStack) {\n  const styleObject = pushParseAndPop(\n    {},\n    STYLE_PARSERS,\n    node,\n    objectStack,\n    this,\n  );\n  if (!styleObject) {\n    return null;\n  }\n  let fillStyle =\n    /** @type {Fill} */\n    (\n      'fillStyle' in styleObject ? styleObject['fillStyle'] : DEFAULT_FILL_STYLE\n    );\n  const fill = /** @type {boolean|undefined} */ (styleObject['fill']);\n  if (fill !== undefined && !fill) {\n    fillStyle = null;\n  }\n  let imageStyle;\n  if ('imageStyle' in styleObject) {\n    if (styleObject['imageStyle'] != DEFAULT_NO_IMAGE_STYLE) {\n      imageStyle = /** @type {import(\"../style/Image.js\").default} */ (\n        styleObject['imageStyle']\n      );\n    }\n  } else {\n    imageStyle = DEFAULT_IMAGE_STYLE;\n  }\n  const textStyle =\n    /** @type {Text} */\n    (\n      'textStyle' in styleObject ? styleObject['textStyle'] : DEFAULT_TEXT_STYLE\n    );\n  const strokeStyle =\n    /** @type {Stroke} */\n    (\n      'strokeStyle' in styleObject\n        ? styleObject['strokeStyle']\n        : DEFAULT_STROKE_STYLE\n    );\n  const outline = /** @type {boolean|undefined} */ (styleObject['outline']);\n  if (outline !== undefined && !outline) {\n    // if the polystyle specifies no outline two styles are needed,\n    // one for non-polygon geometries where linestrings require a stroke\n    // and one for polygons where there should be no stroke\n    return [\n      new Style({\n        geometry: function (feature) {\n          const geometry = feature.getGeometry();\n          const type = geometry.getType();\n          if (type === 'GeometryCollection') {\n            const collection =\n              /** @type {import(\"../geom/GeometryCollection.js\").default} */ (\n                geometry\n              );\n            return new GeometryCollection(\n              collection\n                .getGeometriesArrayRecursive()\n                .filter(function (geometry) {\n                  const type = geometry.getType();\n                  return type !== 'Polygon' && type !== 'MultiPolygon';\n                }),\n            );\n          }\n          if (type !== 'Polygon' && type !== 'MultiPolygon') {\n            return geometry;\n          }\n        },\n        fill: fillStyle,\n        image: imageStyle,\n        stroke: strokeStyle,\n        text: textStyle,\n        zIndex: undefined, // FIXME\n      }),\n      new Style({\n        geometry: function (feature) {\n          const geometry = feature.getGeometry();\n          const type = geometry.getType();\n          if (type === 'GeometryCollection') {\n            const collection =\n              /** @type {import(\"../geom/GeometryCollection.js\").default} */ (\n                geometry\n              );\n            return new GeometryCollection(\n              collection\n                .getGeometriesArrayRecursive()\n                .filter(function (geometry) {\n                  const type = geometry.getType();\n                  return type === 'Polygon' || type === 'MultiPolygon';\n                }),\n            );\n          }\n          if (type === 'Polygon' || type === 'MultiPolygon') {\n            return geometry;\n          }\n        },\n        fill: fillStyle,\n        stroke: null,\n        zIndex: undefined, // FIXME\n      }),\n    ];\n  }\n  return [\n    new Style({\n      fill: fillStyle,\n      image: imageStyle,\n      stroke: strokeStyle,\n      text: textStyle,\n      zIndex: undefined, // FIXME\n    }),\n  ];\n}\n\n/**\n * Reads an array of geometries and creates arrays for common geometry\n * properties. Then sets them to the multi geometry.\n * @param {MultiPoint|MultiLineString|MultiPolygon} multiGeometry A multi-geometry.\n * @param {Array<import(\"../geom/Geometry.js\").default>} geometries List of geometries.\n */\nfunction setCommonGeometryProperties(multiGeometry, geometries) {\n  const ii = geometries.length;\n  const extrudes = new Array(geometries.length);\n  const tessellates = new Array(geometries.length);\n  const altitudeModes = new Array(geometries.length);\n  let hasExtrude, hasTessellate, hasAltitudeMode;\n  hasExtrude = false;\n  hasTessellate = false;\n  hasAltitudeMode = false;\n  for (let i = 0; i < ii; ++i) {\n    const geometry = geometries[i];\n    extrudes[i] = geometry.get('extrude');\n    tessellates[i] = geometry.get('tessellate');\n    altitudeModes[i] = geometry.get('altitudeMode');\n    hasExtrude = hasExtrude || extrudes[i] !== undefined;\n    hasTessellate = hasTessellate || tessellates[i] !== undefined;\n    hasAltitudeMode = hasAltitudeMode || altitudeModes[i];\n  }\n  if (hasExtrude) {\n    multiGeometry.set('extrude', extrudes);\n  }\n  if (hasTessellate) {\n    multiGeometry.set('tessellate', tessellates);\n  }\n  if (hasAltitudeMode) {\n    multiGeometry.set('altitudeMode', altitudeModes);\n  }\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst DATA_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'displayName': makeObjectPropertySetter(readString),\n  'value': makeObjectPropertySetter(readString),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction dataParser(node, objectStack) {\n  const name = node.getAttribute('name');\n  parseNode(DATA_PARSERS, node, objectStack);\n  const featureObject = /** @type {Object} */ (\n    objectStack[objectStack.length - 1]\n  );\n  if (name && featureObject.displayName) {\n    featureObject[name] = {\n      value: featureObject.value,\n      displayName: featureObject.displayName,\n      toString: function () {\n        return featureObject.value;\n      },\n    };\n  } else if (name !== null) {\n    featureObject[name] = featureObject.value;\n  } else if (featureObject.displayName !== null) {\n    featureObject[featureObject.displayName] = featureObject.value;\n  }\n  delete featureObject['value'];\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst EXTENDED_DATA_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Data': dataParser,\n  'SchemaData': schemaDataParser,\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction extendedDataParser(node, objectStack) {\n  parseNode(EXTENDED_DATA_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction regionParser(node, objectStack) {\n  parseNode(REGION_PARSERS, node, objectStack);\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst PAIR_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Style': makeObjectPropertySetter(readStyle),\n  'key': makeObjectPropertySetter(readString),\n  'styleUrl': makeObjectPropertySetter(readStyleURL),\n});\n\n/**\n * @this {KML}\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction pairDataParser(node, objectStack) {\n  const pairObject = pushParseAndPop({}, PAIR_PARSERS, node, objectStack, this);\n  if (!pairObject) {\n    return;\n  }\n  const key = /** @type {string|undefined} */ (pairObject['key']);\n  if (key && key == 'normal') {\n    const styleUrl = /** @type {string|undefined} */ (pairObject['styleUrl']);\n    if (styleUrl) {\n      objectStack[objectStack.length - 1] = styleUrl;\n    }\n    const style = /** @type {Style} */ (pairObject['Style']);\n    if (style) {\n      objectStack[objectStack.length - 1] = style;\n    }\n  }\n}\n\n/**\n * @this {KML}\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction placemarkStyleMapParser(node, objectStack) {\n  const styleMapValue = readStyleMapValue.call(this, node, objectStack);\n  if (!styleMapValue) {\n    return;\n  }\n  const placemarkObject = objectStack[objectStack.length - 1];\n  if (Array.isArray(styleMapValue)) {\n    placemarkObject['Style'] = styleMapValue;\n  } else if (typeof styleMapValue === 'string') {\n    placemarkObject['styleUrl'] = styleMapValue;\n  } else {\n    throw new Error('`styleMapValue` has an unknown type');\n  }\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst SCHEMA_DATA_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'SimpleData': simpleDataParser,\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction schemaDataParser(node, objectStack) {\n  parseNode(SCHEMA_DATA_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction simpleDataParser(node, objectStack) {\n  const name = node.getAttribute('name');\n  if (name !== null) {\n    const data = readString(node);\n    const featureObject = /** @type {Object} */ (\n      objectStack[objectStack.length - 1]\n    );\n    featureObject[name] = data;\n  }\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst LAT_LON_ALT_BOX_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'altitudeMode': makeObjectPropertySetter(readString),\n  'minAltitude': makeObjectPropertySetter(readDecimal),\n  'maxAltitude': makeObjectPropertySetter(readDecimal),\n  'north': makeObjectPropertySetter(readDecimal),\n  'south': makeObjectPropertySetter(readDecimal),\n  'east': makeObjectPropertySetter(readDecimal),\n  'west': makeObjectPropertySetter(readDecimal),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction latLonAltBoxParser(node, objectStack) {\n  const object = pushParseAndPop(\n    {},\n    LAT_LON_ALT_BOX_PARSERS,\n    node,\n    objectStack,\n  );\n  if (!object) {\n    return;\n  }\n  const regionObject = /** @type {Object} */ (\n    objectStack[objectStack.length - 1]\n  );\n  const extent = [\n    parseFloat(object['west']),\n    parseFloat(object['south']),\n    parseFloat(object['east']),\n    parseFloat(object['north']),\n  ];\n  regionObject['extent'] = extent;\n  regionObject['altitudeMode'] = object['altitudeMode'];\n  regionObject['minAltitude'] = parseFloat(object['minAltitude']);\n  regionObject['maxAltitude'] = parseFloat(object['maxAltitude']);\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst LOD_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'minLodPixels': makeObjectPropertySetter(readDecimal),\n  'maxLodPixels': makeObjectPropertySetter(readDecimal),\n  'minFadeExtent': makeObjectPropertySetter(readDecimal),\n  'maxFadeExtent': makeObjectPropertySetter(readDecimal),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction lodParser(node, objectStack) {\n  const object = pushParseAndPop({}, LOD_PARSERS, node, objectStack);\n  if (!object) {\n    return;\n  }\n  const lodObject = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  lodObject['minLodPixels'] = parseFloat(object['minLodPixels']);\n  lodObject['maxLodPixels'] = parseFloat(object['maxLodPixels']);\n  lodObject['minFadeExtent'] = parseFloat(object['minFadeExtent']);\n  lodObject['maxFadeExtent'] = parseFloat(object['maxFadeExtent']);\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst INNER_BOUNDARY_IS_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  // KML spec only allows one LinearRing  per innerBoundaryIs, but Google Earth\n  // allows multiple, so we parse multiple here too.\n  'LinearRing': makeArrayPusher(readFlatLinearRing),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction innerBoundaryIsParser(node, objectStack) {\n  const innerBoundaryFlatLinearRings = pushParseAndPop(\n    /** @type {Array<Array<number>>} */ ([]),\n    INNER_BOUNDARY_IS_PARSERS,\n    node,\n    objectStack,\n  );\n  if (innerBoundaryFlatLinearRings.length > 0) {\n    const flatLinearRings =\n      /** @type {Array<Array<number>>} */\n      (objectStack[objectStack.length - 1]);\n    flatLinearRings.push(...innerBoundaryFlatLinearRings);\n  }\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst OUTER_BOUNDARY_IS_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'LinearRing': makeReplacer(readFlatLinearRing),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction outerBoundaryIsParser(node, objectStack) {\n  /** @type {Array<number>|undefined} */\n  const flatLinearRing = pushParseAndPop(\n    undefined,\n    OUTER_BOUNDARY_IS_PARSERS,\n    node,\n    objectStack,\n  );\n  if (flatLinearRing) {\n    const flatLinearRings =\n      /** @type {Array<Array<number>>} */\n      (objectStack[objectStack.length - 1]);\n    flatLinearRings[0] = flatLinearRing;\n  }\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction linkParser(node, objectStack) {\n  parseNode(LINK_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Node} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction whenParser(node, objectStack) {\n  const gxTrackObject =\n    /** @type {GxTrackObject} */\n    (objectStack[objectStack.length - 1]);\n  const whens = gxTrackObject.whens;\n  const s = getAllTextContent(node, false);\n  const when = Date.parse(s);\n  whens.push(isNaN(when) ? 0 : when);\n}\n\n/**\n * @param {Node} node Node to append a TextNode with the color to.\n * @param {import(\"../color.js\").Color|string} color Color.\n */\nfunction writeColorTextNode(node, color) {\n  const rgba = asArray(color);\n  const opacity = rgba.length == 4 ? rgba[3] : 1;\n  /** @type {Array<string|number>} */\n  const abgr = [opacity * 255, rgba[2], rgba[1], rgba[0]];\n  for (let i = 0; i < 4; ++i) {\n    const hex = Math.floor(/** @type {number} */ (abgr[i])).toString(16);\n    abgr[i] = hex.length == 1 ? '0' + hex : hex;\n  }\n  writeStringTextNode(node, abgr.join(''));\n}\n\n/**\n * @param {Node} node Node to append a TextNode with the coordinates to.\n * @param {Array<number>} coordinates Coordinates.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writeCoordinatesTextNode(node, coordinates, objectStack) {\n  const context = objectStack[objectStack.length - 1];\n\n  const layout = context['layout'];\n  const stride = context['stride'];\n\n  let dimension;\n  if (layout == 'XY' || layout == 'XYM') {\n    dimension = 2;\n  } else if (layout == 'XYZ' || layout == 'XYZM') {\n    dimension = 3;\n  } else {\n    throw new Error('Invalid geometry layout');\n  }\n\n  const ii = coordinates.length;\n  let text = '';\n  if (ii > 0) {\n    text += coordinates[0];\n    for (let d = 1; d < dimension; ++d) {\n      text += ',' + coordinates[d];\n    }\n    for (let i = stride; i < ii; i += stride) {\n      text += ' ' + coordinates[i];\n      for (let d = 1; d < dimension; ++d) {\n        text += ',' + coordinates[i + d];\n      }\n    }\n  }\n  writeStringTextNode(node, text);\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst EXTENDEDDATA_NODE_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'Data': makeChildAppender(writeDataNode),\n  'value': makeChildAppender(writeDataNodeValue),\n  'displayName': makeChildAppender(writeDataNodeName),\n});\n\n/**\n * @param {Element} node Node.\n * @param {{name: *, value: *}} pair Name value pair.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writeDataNode(node, pair, objectStack) {\n  node.setAttribute('name', pair.name);\n  const /** @type {import(\"../xml.js\").NodeStackItem} */ context = {node: node};\n  const value = pair.value;\n\n  if (typeof value == 'object') {\n    if (value !== null && value.displayName) {\n      pushSerializeAndPop(\n        context,\n        EXTENDEDDATA_NODE_SERIALIZERS,\n        OBJECT_PROPERTY_NODE_FACTORY,\n        [value.displayName],\n        objectStack,\n        ['displayName'],\n      );\n    }\n\n    if (value !== null && value.value) {\n      pushSerializeAndPop(\n        context,\n        EXTENDEDDATA_NODE_SERIALIZERS,\n        OBJECT_PROPERTY_NODE_FACTORY,\n        [value.value],\n        objectStack,\n        ['value'],\n      );\n    }\n  } else {\n    pushSerializeAndPop(\n      context,\n      EXTENDEDDATA_NODE_SERIALIZERS,\n      OBJECT_PROPERTY_NODE_FACTORY,\n      [value],\n      objectStack,\n      ['value'],\n    );\n  }\n}\n\n/**\n * @param {Node} node Node to append a TextNode with the name to.\n * @param {string} name DisplayName.\n */\nfunction writeDataNodeName(node, name) {\n  writeStringTextNode(node, name);\n}\n\n/**\n * @param {Node} node Node to append a CDATA Section with the value to.\n * @param {string} value Value.\n */\nfunction writeDataNodeValue(node, value) {\n  writeStringTextNode(node, value);\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst DOCUMENT_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'Placemark': makeChildAppender(writePlacemark),\n});\n\n/**\n * @const\n * @param {*} value Value.\n * @param {Array<*>} objectStack Object stack.\n * @param {string} [nodeName] Node name.\n * @return {Node|undefined} Node.\n */\nconst DOCUMENT_NODE_FACTORY = function (value, objectStack, nodeName) {\n  const parentNode = objectStack[objectStack.length - 1].node;\n  return createElementNS(parentNode.namespaceURI, 'Placemark');\n};\n\n/**\n * @param {Element} node Node.\n * @param {Array<Feature>} features Features.\n * @param {Array<*>} objectStack Object stack.\n * @this {KML}\n */\nfunction writeDocument(node, features, objectStack) {\n  const /** @type {import(\"../xml.js\").NodeStackItem} */ context = {node: node};\n  pushSerializeAndPop(\n    context,\n    DOCUMENT_SERIALIZERS,\n    DOCUMENT_NODE_FACTORY,\n    features,\n    objectStack,\n    undefined,\n    this,\n  );\n}\n\n/**\n * A factory for creating Data nodes.\n * @const\n * @type {function(*, Array<*>): (Node|undefined)}\n */\nconst DATA_NODE_FACTORY = makeSimpleNodeFactory('Data');\n\n/**\n * @param {Element} node Node.\n * @param {{names: Array<string>, values: (Array<*>)}} namesAndValues Names and values.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writeExtendedData(node, namesAndValues, objectStack) {\n  const /** @type {import(\"../xml.js\").NodeStackItem} */ context = {node: node};\n  const names = namesAndValues.names;\n  const values = namesAndValues.values;\n  const length = names.length;\n\n  for (let i = 0; i < length; i++) {\n    pushSerializeAndPop(\n      context,\n      EXTENDEDDATA_NODE_SERIALIZERS,\n      DATA_NODE_FACTORY,\n      [{name: names[i], value: values[i]}],\n      objectStack,\n    );\n  }\n}\n\n/**\n * @const\n * @type {Object<string, Array<string>>}\n */\n// @ts-ignore\nconst ICON_SEQUENCE = makeStructureNS(\n  NAMESPACE_URIS,\n  ['href'],\n  makeStructureNS(GX_NAMESPACE_URIS, ['x', 'y', 'w', 'h']),\n);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst ICON_SERIALIZERS = makeStructureNS(\n  NAMESPACE_URIS,\n  {\n    'href': makeChildAppender(writeStringTextNode),\n  },\n  makeStructureNS(GX_NAMESPACE_URIS, {\n    'x': makeChildAppender(writeDecimalTextNode),\n    'y': makeChildAppender(writeDecimalTextNode),\n    'w': makeChildAppender(writeDecimalTextNode),\n    'h': makeChildAppender(writeDecimalTextNode),\n  }),\n);\n\n/**\n * @const\n * @param {*} value Value.\n * @param {Array<*>} objectStack Object stack.\n * @param {string} [nodeName] Node name.\n * @return {Node|undefined} Node.\n */\nconst GX_NODE_FACTORY = function (value, objectStack, nodeName) {\n  return createElementNS(GX_NAMESPACE_URIS[0], 'gx:' + nodeName);\n};\n\n/**\n * @param {Element} node Node.\n * @param {Object} icon Icon object.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writeIcon(node, icon, objectStack) {\n  const /** @type {import(\"../xml.js\").NodeStackItem} */ context = {node: node};\n  const parentNode = objectStack[objectStack.length - 1].node;\n  let orderedKeys = ICON_SEQUENCE[parentNode.namespaceURI];\n  let values = makeSequence(icon, orderedKeys);\n  pushSerializeAndPop(\n    context,\n    ICON_SERIALIZERS,\n    OBJECT_PROPERTY_NODE_FACTORY,\n    values,\n    objectStack,\n    orderedKeys,\n  );\n  orderedKeys = ICON_SEQUENCE[GX_NAMESPACE_URIS[0]];\n  values = makeSequence(icon, orderedKeys);\n  pushSerializeAndPop(\n    context,\n    ICON_SERIALIZERS,\n    GX_NODE_FACTORY,\n    values,\n    objectStack,\n    orderedKeys,\n  );\n}\n\n/**\n * @const\n * @type {Object<string, Array<string>>}\n */\n// @ts-ignore\nconst ICON_STYLE_SEQUENCE = makeStructureNS(NAMESPACE_URIS, [\n  'scale',\n  'heading',\n  'Icon',\n  'color',\n  'hotSpot',\n]);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst ICON_STYLE_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'Icon': makeChildAppender(writeIcon),\n  'color': makeChildAppender(writeColorTextNode),\n  'heading': makeChildAppender(writeDecimalTextNode),\n  'hotSpot': makeChildAppender(writeVec2),\n  'scale': makeChildAppender(writeScaleTextNode),\n});\n\n/**\n * @param {Element} node Node.\n * @param {import(\"../style/Icon.js\").default} style Icon style.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writeIconStyle(node, style, objectStack) {\n  const /** @type {import(\"../xml.js\").NodeStackItem} */ context = {node: node};\n  const /** @type {Object<string, any>} */ properties = {};\n  const src = style.getSrc();\n  const size = style.getSize();\n  const iconImageSize = style.getImageSize();\n  const iconProperties = {\n    'href': src,\n  };\n\n  if (size) {\n    iconProperties['w'] = size[0];\n    iconProperties['h'] = size[1];\n    const anchor = style.getAnchor(); // top-left\n    const origin = style.getOrigin(); // top-left\n\n    if (origin && iconImageSize && origin[0] !== 0 && origin[1] !== size[1]) {\n      iconProperties['x'] = origin[0];\n      iconProperties['y'] = iconImageSize[1] - (origin[1] + size[1]);\n    }\n\n    if (anchor && (anchor[0] !== size[0] / 2 || anchor[1] !== size[1] / 2)) {\n      const /** @type {Vec2} */ hotSpot = {\n          x: anchor[0],\n          xunits: 'pixels',\n          y: size[1] - anchor[1],\n          yunits: 'pixels',\n        };\n      properties['hotSpot'] = hotSpot;\n    }\n  }\n\n  properties['Icon'] = iconProperties;\n\n  let scale = style.getScaleArray()[0];\n  let imageSize = size;\n  if (imageSize === null) {\n    imageSize = DEFAULT_IMAGE_STYLE_SIZE;\n  }\n  if (imageSize.length == 2) {\n    const resizeScale = scaleForSize(imageSize);\n    scale = scale / resizeScale;\n  }\n  if (scale !== 1) {\n    properties['scale'] = scale;\n  }\n\n  const rotation = style.getRotation();\n  if (rotation !== 0) {\n    properties['heading'] = rotation; // 0-360\n  }\n\n  const color = style.getColor();\n  if (color) {\n    properties['color'] = color;\n  }\n\n  const parentNode = objectStack[objectStack.length - 1].node;\n  const orderedKeys = ICON_STYLE_SEQUENCE[parentNode.namespaceURI];\n  const values = makeSequence(properties, orderedKeys);\n  pushSerializeAndPop(\n    context,\n    ICON_STYLE_SERIALIZERS,\n    OBJECT_PROPERTY_NODE_FACTORY,\n    values,\n    objectStack,\n    orderedKeys,\n  );\n}\n\n/**\n * @const\n * @type {Object<string, Array<string>>}\n */\n// @ts-ignore\nconst LABEL_STYLE_SEQUENCE = makeStructureNS(NAMESPACE_URIS, [\n  'color',\n  'scale',\n]);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst LABEL_STYLE_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'color': makeChildAppender(writeColorTextNode),\n  'scale': makeChildAppender(writeScaleTextNode),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Text} style style.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writeLabelStyle(node, style, objectStack) {\n  const /** @type {import(\"../xml.js\").NodeStackItem} */ context = {node: node};\n  const properties = {};\n  const fill = style.getFill();\n  if (fill) {\n    properties['color'] = fill.getColor();\n  }\n  const scale = style.getScale();\n  if (scale && scale !== 1) {\n    properties['scale'] = scale;\n  }\n  const parentNode = objectStack[objectStack.length - 1].node;\n  const orderedKeys = LABEL_STYLE_SEQUENCE[parentNode.namespaceURI];\n  const values = makeSequence(properties, orderedKeys);\n  pushSerializeAndPop(\n    context,\n    LABEL_STYLE_SERIALIZERS,\n    OBJECT_PROPERTY_NODE_FACTORY,\n    values,\n    objectStack,\n    orderedKeys,\n  );\n}\n\n/**\n * @const\n * @type {Object<string, Array<string>>}\n */\n// @ts-ignore\nconst LINE_STYLE_SEQUENCE = makeStructureNS(NAMESPACE_URIS, ['color', 'width']);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst LINE_STYLE_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'color': makeChildAppender(writeColorTextNode),\n  'width': makeChildAppender(writeDecimalTextNode),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Stroke} style style.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writeLineStyle(node, style, objectStack) {\n  const /** @type {import(\"../xml.js\").NodeStackItem} */ context = {node: node};\n  const properties = {\n    'color': style.getColor(),\n    'width': Number(style.getWidth()) || 1,\n  };\n  const parentNode = objectStack[objectStack.length - 1].node;\n  const orderedKeys = LINE_STYLE_SEQUENCE[parentNode.namespaceURI];\n  const values = makeSequence(properties, orderedKeys);\n  pushSerializeAndPop(\n    context,\n    LINE_STYLE_SERIALIZERS,\n    OBJECT_PROPERTY_NODE_FACTORY,\n    values,\n    objectStack,\n    orderedKeys,\n  );\n}\n\n/**\n * @const\n * @type {Object<string, string>}\n */\nconst GEOMETRY_TYPE_TO_NODENAME = {\n  'Point': 'Point',\n  'LineString': 'LineString',\n  'LinearRing': 'LinearRing',\n  'Polygon': 'Polygon',\n  'MultiPoint': 'MultiGeometry',\n  'MultiLineString': 'MultiGeometry',\n  'MultiPolygon': 'MultiGeometry',\n  'GeometryCollection': 'MultiGeometry',\n};\n\n/**\n * @const\n * @param {*} value Value.\n * @param {Array<*>} objectStack Object stack.\n * @param {string} [nodeName] Node name.\n * @return {Node|undefined} Node.\n */\nconst GEOMETRY_NODE_FACTORY = function (value, objectStack, nodeName) {\n  if (value) {\n    const parentNode = objectStack[objectStack.length - 1].node;\n    return createElementNS(\n      parentNode.namespaceURI,\n      GEOMETRY_TYPE_TO_NODENAME[\n        /** @type {import(\"../geom/Geometry.js\").default} */ (value).getType()\n      ],\n    );\n  }\n};\n\n/**\n * A factory for creating Point nodes.\n * @const\n * @type {function(*, Array<*>, string=): (Node|undefined)}\n */\nconst POINT_NODE_FACTORY = makeSimpleNodeFactory('Point');\n\n/**\n * A factory for creating LineString nodes.\n * @const\n * @type {function(*, Array<*>, string=): (Node|undefined)}\n */\nconst LINE_STRING_NODE_FACTORY = makeSimpleNodeFactory('LineString');\n\n/**\n * A factory for creating LinearRing nodes.\n * @const\n * @type {function(*, Array<*>, string=): (Node|undefined)}\n */\nconst LINEAR_RING_NODE_FACTORY = makeSimpleNodeFactory('LinearRing');\n\n/**\n * A factory for creating Polygon nodes.\n * @const\n * @type {function(*, Array<*>, string=): (Node|undefined)}\n */\nconst POLYGON_NODE_FACTORY = makeSimpleNodeFactory('Polygon');\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst MULTI_GEOMETRY_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'LineString': makeChildAppender(writePrimitiveGeometry),\n  'Point': makeChildAppender(writePrimitiveGeometry),\n  'Polygon': makeChildAppender(writePolygon),\n  'GeometryCollection': makeChildAppender(writeMultiGeometry),\n});\n\n/**\n * @param {Element} node Node.\n * @param {import(\"../geom/Geometry.js\").default} geometry Geometry.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writeMultiGeometry(node, geometry, objectStack) {\n  /** @type {import(\"../xml.js\").NodeStackItem} */\n  const context = {node: node};\n  const type = geometry.getType();\n  /** @type {Array<import(\"../geom/Geometry.js\").default>} */\n  let geometries = [];\n  /** @type {function(*, Array<*>, string=): (Node|undefined)} */\n  let factory;\n  if (type === 'GeometryCollection') {\n    /** @type {GeometryCollection} */ (geometry)\n      .getGeometriesArrayRecursive()\n      .forEach(function (geometry) {\n        const type = geometry.getType();\n        if (type === 'MultiPoint') {\n          geometries = geometries.concat(\n            /** @type {MultiPoint} */ (geometry).getPoints(),\n          );\n        } else if (type === 'MultiLineString') {\n          geometries = geometries.concat(\n            /** @type {MultiLineString} */ (geometry).getLineStrings(),\n          );\n        } else if (type === 'MultiPolygon') {\n          geometries = geometries.concat(\n            /** @type {MultiPolygon} */ (geometry).getPolygons(),\n          );\n        } else if (\n          type === 'Point' ||\n          type === 'LineString' ||\n          type === 'Polygon'\n        ) {\n          geometries.push(geometry);\n        } else {\n          throw new Error('Unknown geometry type');\n        }\n      });\n    factory = GEOMETRY_NODE_FACTORY;\n  } else if (type === 'MultiPoint') {\n    geometries = /** @type {MultiPoint} */ (geometry).getPoints();\n    factory = POINT_NODE_FACTORY;\n  } else if (type === 'MultiLineString') {\n    geometries = /** @type {MultiLineString} */ (geometry).getLineStrings();\n    factory = LINE_STRING_NODE_FACTORY;\n  } else if (type === 'MultiPolygon') {\n    geometries = /** @type {MultiPolygon} */ (geometry).getPolygons();\n    factory = POLYGON_NODE_FACTORY;\n  } else {\n    throw new Error('Unknown geometry type');\n  }\n  pushSerializeAndPop(\n    context,\n    MULTI_GEOMETRY_SERIALIZERS,\n    factory,\n    geometries,\n    objectStack,\n  );\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst BOUNDARY_IS_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'LinearRing': makeChildAppender(writePrimitiveGeometry),\n});\n\n/**\n * @param {Element} node Node.\n * @param {import(\"../geom/LinearRing.js\").default} linearRing Linear ring.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writeBoundaryIs(node, linearRing, objectStack) {\n  const /** @type {import(\"../xml.js\").NodeStackItem} */ context = {node: node};\n  pushSerializeAndPop(\n    context,\n    BOUNDARY_IS_SERIALIZERS,\n    LINEAR_RING_NODE_FACTORY,\n    [linearRing],\n    objectStack,\n  );\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst PLACEMARK_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'ExtendedData': makeChildAppender(writeExtendedData),\n  'MultiGeometry': makeChildAppender(writeMultiGeometry),\n  'LineString': makeChildAppender(writePrimitiveGeometry),\n  'LinearRing': makeChildAppender(writePrimitiveGeometry),\n  'Point': makeChildAppender(writePrimitiveGeometry),\n  'Polygon': makeChildAppender(writePolygon),\n  'Style': makeChildAppender(writeStyle),\n  'address': makeChildAppender(writeStringTextNode),\n  'description': makeChildAppender(writeStringTextNode),\n  'name': makeChildAppender(writeStringTextNode),\n  'open': makeChildAppender(writeBooleanTextNode),\n  'phoneNumber': makeChildAppender(writeStringTextNode),\n  'styleUrl': makeChildAppender(writeStringTextNode),\n  'visibility': makeChildAppender(writeBooleanTextNode),\n});\n\n/**\n * @const\n * @type {Object<string, Array<string>>}\n */\n// @ts-ignore\nconst PLACEMARK_SEQUENCE = makeStructureNS(NAMESPACE_URIS, [\n  'name',\n  'open',\n  'visibility',\n  'address',\n  'phoneNumber',\n  'description',\n  'styleUrl',\n  'Style',\n]);\n\n/**\n * A factory for creating ExtendedData nodes.\n * @const\n * @type {function(*, Array<*>): (Node|undefined)}\n */\nconst EXTENDEDDATA_NODE_FACTORY = makeSimpleNodeFactory('ExtendedData');\n\n/**\n * FIXME currently we do serialize arbitrary/custom feature properties\n * (ExtendedData).\n * @param {Element} node Node.\n * @param {Feature} feature Feature.\n * @param {Array<*>} objectStack Object stack.\n * @this {KML}\n */\nfunction writePlacemark(node, feature, objectStack) {\n  const /** @type {import(\"../xml.js\").NodeStackItem} */ context = {node: node};\n\n  // set id\n  if (feature.getId()) {\n    node.setAttribute('id', /** @type {string} */ (feature.getId()));\n  }\n\n  // serialize properties (properties unknown to KML are not serialized)\n  const properties = feature.getProperties();\n\n  // don't export these to ExtendedData\n  const filter = {\n    'address': 1,\n    'description': 1,\n    'name': 1,\n    'open': 1,\n    'phoneNumber': 1,\n    'styleUrl': 1,\n    'visibility': 1,\n  };\n  filter[feature.getGeometryName()] = 1;\n  const keys = Object.keys(properties || {})\n    .sort()\n    .filter(function (v) {\n      return !filter[v];\n    });\n\n  const styleFunction = feature.getStyleFunction();\n  if (styleFunction) {\n    // FIXME the styles returned by the style function are supposed to be\n    // resolution-independent here\n    const styles = styleFunction(feature, 0);\n    if (styles) {\n      const styleArray = Array.isArray(styles) ? styles : [styles];\n      let pointStyles = styleArray;\n      if (feature.getGeometry()) {\n        pointStyles = styleArray.filter(function (style) {\n          const geometry = style.getGeometryFunction()(feature);\n          if (geometry) {\n            const type = geometry.getType();\n            if (type === 'GeometryCollection') {\n              return /** @type {GeometryCollection} */ (geometry)\n                .getGeometriesArrayRecursive()\n                .filter(function (geometry) {\n                  const type = geometry.getType();\n                  return type === 'Point' || type === 'MultiPoint';\n                }).length;\n            }\n            return type === 'Point' || type === 'MultiPoint';\n          }\n        });\n        ('Point');\n      }\n      if (this.writeStyles_) {\n        let lineStyles = styleArray;\n        let polyStyles = styleArray;\n        if (feature.getGeometry()) {\n          lineStyles = styleArray.filter(function (style) {\n            const geometry = style.getGeometryFunction()(feature);\n            if (geometry) {\n              const type = geometry.getType();\n              if (type === 'GeometryCollection') {\n                return /** @type {GeometryCollection} */ (geometry)\n                  .getGeometriesArrayRecursive()\n                  .filter(function (geometry) {\n                    const type = geometry.getType();\n                    return type === 'LineString' || type === 'MultiLineString';\n                  }).length;\n              }\n              return type === 'LineString' || type === 'MultiLineString';\n            }\n          });\n          polyStyles = styleArray.filter(function (style) {\n            const geometry = style.getGeometryFunction()(feature);\n            if (geometry) {\n              const type = geometry.getType();\n              if (type === 'GeometryCollection') {\n                return /** @type {GeometryCollection} */ (geometry)\n                  .getGeometriesArrayRecursive()\n                  .filter(function (geometry) {\n                    const type = geometry.getType();\n                    return type === 'Polygon' || type === 'MultiPolygon';\n                  }).length;\n              }\n              return type === 'Polygon' || type === 'MultiPolygon';\n            }\n          });\n        }\n        properties['Style'] = {\n          pointStyles: pointStyles,\n          lineStyles: lineStyles,\n          polyStyles: polyStyles,\n        };\n      }\n      if (pointStyles.length && properties['name'] === undefined) {\n        const textStyle = pointStyles[0].getText();\n        if (textStyle) {\n          properties['name'] = textStyle.getText();\n        }\n      }\n    }\n  }\n  const parentNode = objectStack[objectStack.length - 1].node;\n  const orderedKeys = PLACEMARK_SEQUENCE[parentNode.namespaceURI];\n  const values = makeSequence(properties, orderedKeys);\n  pushSerializeAndPop(\n    context,\n    PLACEMARK_SERIALIZERS,\n    OBJECT_PROPERTY_NODE_FACTORY,\n    values,\n    objectStack,\n    orderedKeys,\n  );\n\n  if (keys.length > 0) {\n    const sequence = makeSequence(properties, keys);\n    const namesAndValues = {names: keys, values: sequence};\n    pushSerializeAndPop(\n      context,\n      PLACEMARK_SERIALIZERS,\n      EXTENDEDDATA_NODE_FACTORY,\n      [namesAndValues],\n      objectStack,\n    );\n  }\n\n  // serialize geometry\n  const options = /** @type {import(\"./Feature.js\").WriteOptions} */ (\n    objectStack[0]\n  );\n  let geometry = feature.getGeometry();\n  if (geometry) {\n    geometry = transformGeometryWithOptions(geometry, true, options);\n  }\n  pushSerializeAndPop(\n    context,\n    PLACEMARK_SERIALIZERS,\n    GEOMETRY_NODE_FACTORY,\n    [geometry],\n    objectStack,\n  );\n}\n\n/**\n * @const\n * @type {Object<string, Array<string>>}\n */\n// @ts-ignore\nconst PRIMITIVE_GEOMETRY_SEQUENCE = makeStructureNS(NAMESPACE_URIS, [\n  'extrude',\n  'tessellate',\n  'altitudeMode',\n  'coordinates',\n]);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst PRIMITIVE_GEOMETRY_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'extrude': makeChildAppender(writeBooleanTextNode),\n  'tessellate': makeChildAppender(writeBooleanTextNode),\n  'altitudeMode': makeChildAppender(writeStringTextNode),\n  'coordinates': makeChildAppender(writeCoordinatesTextNode),\n});\n\n/**\n * @param {Element} node Node.\n * @param {import(\"../geom/SimpleGeometry.js\").default} geometry Geometry.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writePrimitiveGeometry(node, geometry, objectStack) {\n  const flatCoordinates = geometry.getFlatCoordinates();\n  const /** @type {import(\"../xml.js\").NodeStackItem} */ context = {node: node};\n  context['layout'] = geometry.getLayout();\n  context['stride'] = geometry.getStride();\n\n  // serialize properties (properties unknown to KML are not serialized)\n  const properties = geometry.getProperties();\n  properties.coordinates = flatCoordinates;\n\n  const parentNode = objectStack[objectStack.length - 1].node;\n  const orderedKeys = PRIMITIVE_GEOMETRY_SEQUENCE[parentNode.namespaceURI];\n  const values = makeSequence(properties, orderedKeys);\n  pushSerializeAndPop(\n    context,\n    PRIMITIVE_GEOMETRY_SERIALIZERS,\n    OBJECT_PROPERTY_NODE_FACTORY,\n    values,\n    objectStack,\n    orderedKeys,\n  );\n}\n\n/**\n * @const\n * @type {Object<string, Array<string>>}\n */\n// @ts-ignore\nconst POLY_STYLE_SEQUENCE = makeStructureNS(NAMESPACE_URIS, [\n  'color',\n  'fill',\n  'outline',\n]);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst POLYGON_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'outerBoundaryIs': makeChildAppender(writeBoundaryIs),\n  'innerBoundaryIs': makeChildAppender(writeBoundaryIs),\n});\n\n/**\n * A factory for creating innerBoundaryIs nodes.\n * @const\n * @type {function(*, Array<*>, string=): (Node|undefined)}\n */\nconst INNER_BOUNDARY_NODE_FACTORY = makeSimpleNodeFactory('innerBoundaryIs');\n\n/**\n * A factory for creating outerBoundaryIs nodes.\n * @const\n * @type {function(*, Array<*>, string=): (Node|undefined)}\n */\nconst OUTER_BOUNDARY_NODE_FACTORY = makeSimpleNodeFactory('outerBoundaryIs');\n\n/**\n * @param {Element} node Node.\n * @param {Polygon} polygon Polygon.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writePolygon(node, polygon, objectStack) {\n  const linearRings = polygon.getLinearRings();\n  const outerRing = linearRings.shift();\n  const /** @type {import(\"../xml.js\").NodeStackItem} */ context = {node: node};\n  // inner rings\n  pushSerializeAndPop(\n    context,\n    POLYGON_SERIALIZERS,\n    INNER_BOUNDARY_NODE_FACTORY,\n    linearRings,\n    objectStack,\n  );\n  // outer ring\n  pushSerializeAndPop(\n    context,\n    POLYGON_SERIALIZERS,\n    OUTER_BOUNDARY_NODE_FACTORY,\n    [outerRing],\n    objectStack,\n  );\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst POLY_STYLE_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'color': makeChildAppender(writeColorTextNode),\n  'fill': makeChildAppender(writeBooleanTextNode),\n  'outline': makeChildAppender(writeBooleanTextNode),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Style} style Style.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writePolyStyle(node, style, objectStack) {\n  const /** @type {import(\"../xml.js\").NodeStackItem} */ context = {node: node};\n  const fill = style.getFill();\n  const stroke = style.getStroke();\n  const properties = {\n    'color': fill ? fill.getColor() : undefined,\n    'fill': fill ? undefined : false,\n    'outline': stroke ? undefined : false,\n  };\n  const parentNode = objectStack[objectStack.length - 1].node;\n  const orderedKeys = POLY_STYLE_SEQUENCE[parentNode.namespaceURI];\n  const values = makeSequence(properties, orderedKeys);\n  pushSerializeAndPop(\n    context,\n    POLY_STYLE_SERIALIZERS,\n    OBJECT_PROPERTY_NODE_FACTORY,\n    values,\n    objectStack,\n    orderedKeys,\n  );\n}\n\n/**\n * @param {Node} node Node to append a TextNode with the scale to.\n * @param {number|undefined} scale Scale.\n */\nfunction writeScaleTextNode(node, scale) {\n  // the Math is to remove any excess decimals created by float arithmetic\n  writeDecimalTextNode(node, Math.round(scale * 1e6) / 1e6);\n}\n\n/**\n * @const\n * @type {Object<string, Array<string>>}\n */\n// @ts-ignore\nconst STYLE_SEQUENCE = makeStructureNS(NAMESPACE_URIS, [\n  'IconStyle',\n  'LabelStyle',\n  'LineStyle',\n  'PolyStyle',\n]);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\n// @ts-ignore\nconst STYLE_SERIALIZERS = makeStructureNS(NAMESPACE_URIS, {\n  'IconStyle': makeChildAppender(writeIconStyle),\n  'LabelStyle': makeChildAppender(writeLabelStyle),\n  'LineStyle': makeChildAppender(writeLineStyle),\n  'PolyStyle': makeChildAppender(writePolyStyle),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Object<string, Array<Style>>} styles Styles.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction writeStyle(node, styles, objectStack) {\n  const /** @type {import(\"../xml.js\").NodeStackItem} */ context = {node: node};\n  const properties = {};\n  if (styles.pointStyles.length) {\n    const textStyle = styles.pointStyles[0].getText();\n    if (textStyle) {\n      properties['LabelStyle'] = textStyle;\n    }\n    const imageStyle = styles.pointStyles[0].getImage();\n    if (\n      imageStyle &&\n      typeof (/** @type {?} */ (imageStyle).getSrc) === 'function'\n    ) {\n      properties['IconStyle'] = imageStyle;\n    }\n  }\n  if (styles.lineStyles.length) {\n    const strokeStyle = styles.lineStyles[0].getStroke();\n    if (strokeStyle) {\n      properties['LineStyle'] = strokeStyle;\n    }\n  }\n  if (styles.polyStyles.length) {\n    const strokeStyle = styles.polyStyles[0].getStroke();\n    if (strokeStyle && !properties['LineStyle']) {\n      properties['LineStyle'] = strokeStyle;\n    }\n    properties['PolyStyle'] = styles.polyStyles[0];\n  }\n  const parentNode = objectStack[objectStack.length - 1].node;\n  const orderedKeys = STYLE_SEQUENCE[parentNode.namespaceURI];\n  const values = makeSequence(properties, orderedKeys);\n  pushSerializeAndPop(\n    context,\n    STYLE_SERIALIZERS,\n    OBJECT_PROPERTY_NODE_FACTORY,\n    values,\n    objectStack,\n    orderedKeys,\n  );\n}\n\n/**\n * @param {Element} node Node to append a TextNode with the Vec2 to.\n * @param {Vec2} vec2 Vec2.\n */\nfunction writeVec2(node, vec2) {\n  node.setAttribute('x', String(vec2.x));\n  node.setAttribute('y', String(vec2.y));\n  node.setAttribute('xunits', vec2.xunits);\n  node.setAttribute('yunits', vec2.yunits);\n}\n\nexport default KML;\n","\nconst SHIFT_LEFT_32 = (1 << 16) * (1 << 16);\nconst SHIFT_RIGHT_32 = 1 / SHIFT_LEFT_32;\n\n// Threshold chosen based on both benchmarking and knowledge about browser string\n// data structures (which currently switch structure types at 12 bytes or more)\nconst TEXT_DECODER_MIN_LENGTH = 12;\nconst utf8TextDecoder = typeof TextDecoder === 'undefined' ? null : new TextDecoder('utf-8');\n\nconst PBF_VARINT  = 0; // varint: int32, int64, uint32, uint64, sint32, sint64, bool, enum\nconst PBF_FIXED64 = 1; // 64-bit: double, fixed64, sfixed64\nconst PBF_BYTES   = 2; // length-delimited: string, bytes, embedded messages, packed repeated fields\nconst PBF_FIXED32 = 5; // 32-bit: float, fixed32, sfixed32\n\nexport default class Pbf {\n    /**\n     * @param {Uint8Array | ArrayBuffer} [buf]\n     */\n    constructor(buf = new Uint8Array(16)) {\n        this.buf = ArrayBuffer.isView(buf) ? buf : new Uint8Array(buf);\n        this.dataView = new DataView(this.buf.buffer);\n        this.pos = 0;\n        this.type = 0;\n        this.length = this.buf.length;\n    }\n\n    // === READING =================================================================\n\n    /**\n     * @template T\n     * @param {(tag: number, result: T, pbf: Pbf) => void} readField\n     * @param {T} result\n     * @param {number} [end]\n     */\n    readFields(readField, result, end = this.length) {\n        while (this.pos < end) {\n            const val = this.readVarint(),\n                tag = val >> 3,\n                startPos = this.pos;\n\n            this.type = val & 0x7;\n            readField(tag, result, this);\n\n            if (this.pos === startPos) this.skip(val);\n        }\n        return result;\n    }\n\n    /**\n     * @template T\n     * @param {(tag: number, result: T, pbf: Pbf) => void} readField\n     * @param {T} result\n     */\n    readMessage(readField, result) {\n        return this.readFields(readField, result, this.readVarint() + this.pos);\n    }\n\n    readFixed32() {\n        const val = this.dataView.getUint32(this.pos, true);\n        this.pos += 4;\n        return val;\n    }\n\n    readSFixed32() {\n        const val = this.dataView.getInt32(this.pos, true);\n        this.pos += 4;\n        return val;\n    }\n\n    // 64-bit int handling is based on github.com/dpw/node-buffer-more-ints (MIT-licensed)\n\n    readFixed64() {\n        const val = this.dataView.getUint32(this.pos, true) + this.dataView.getUint32(this.pos + 4, true) * SHIFT_LEFT_32;\n        this.pos += 8;\n        return val;\n    }\n\n    readSFixed64() {\n        const val = this.dataView.getUint32(this.pos, true) + this.dataView.getInt32(this.pos + 4, true) * SHIFT_LEFT_32;\n        this.pos += 8;\n        return val;\n    }\n\n    readFloat() {\n        const val = this.dataView.getFloat32(this.pos, true);\n        this.pos += 4;\n        return val;\n    }\n\n    readDouble() {\n        const val = this.dataView.getFloat64(this.pos, true);\n        this.pos += 8;\n        return val;\n    }\n\n    /**\n     * @param {boolean} [isSigned]\n     */\n    readVarint(isSigned) {\n        const buf = this.buf;\n        let val, b;\n\n        b = buf[this.pos++]; val  =  b & 0x7f;        if (b < 0x80) return val;\n        b = buf[this.pos++]; val |= (b & 0x7f) << 7;  if (b < 0x80) return val;\n        b = buf[this.pos++]; val |= (b & 0x7f) << 14; if (b < 0x80) return val;\n        b = buf[this.pos++]; val |= (b & 0x7f) << 21; if (b < 0x80) return val;\n        b = buf[this.pos];   val |= (b & 0x0f) << 28;\n\n        return readVarintRemainder(val, isSigned, this);\n    }\n\n    readVarint64() { // for compatibility with v2.0.1\n        return this.readVarint(true);\n    }\n\n    readSVarint() {\n        const num = this.readVarint();\n        return num % 2 === 1 ? (num + 1) / -2 : num / 2; // zigzag encoding\n    }\n\n    readBoolean() {\n        return Boolean(this.readVarint());\n    }\n\n    readString() {\n        const end = this.readVarint() + this.pos;\n        const pos = this.pos;\n        this.pos = end;\n\n        if (end - pos >= TEXT_DECODER_MIN_LENGTH && utf8TextDecoder) {\n            // longer strings are fast with the built-in browser TextDecoder API\n            return utf8TextDecoder.decode(this.buf.subarray(pos, end));\n        }\n        // short strings are fast with our custom implementation\n        return readUtf8(this.buf, pos, end);\n    }\n\n    readBytes() {\n        const end = this.readVarint() + this.pos,\n            buffer = this.buf.subarray(this.pos, end);\n        this.pos = end;\n        return buffer;\n    }\n\n    // verbose for performance reasons; doesn't affect gzipped size\n\n    /**\n     * @param {number[]} [arr]\n     * @param {boolean} [isSigned]\n     */\n    readPackedVarint(arr = [], isSigned) {\n        const end = this.readPackedEnd();\n        while (this.pos < end) arr.push(this.readVarint(isSigned));\n        return arr;\n    }\n    /** @param {number[]} [arr] */\n    readPackedSVarint(arr = []) {\n        const end = this.readPackedEnd();\n        while (this.pos < end) arr.push(this.readSVarint());\n        return arr;\n    }\n    /** @param {boolean[]} [arr] */\n    readPackedBoolean(arr = []) {\n        const end = this.readPackedEnd();\n        while (this.pos < end) arr.push(this.readBoolean());\n        return arr;\n    }\n    /** @param {number[]} [arr] */\n    readPackedFloat(arr = []) {\n        const end = this.readPackedEnd();\n        while (this.pos < end) arr.push(this.readFloat());\n        return arr;\n    }\n    /** @param {number[]} [arr] */\n    readPackedDouble(arr = []) {\n        const end = this.readPackedEnd();\n        while (this.pos < end) arr.push(this.readDouble());\n        return arr;\n    }\n    /** @param {number[]} [arr] */\n    readPackedFixed32(arr = []) {\n        const end = this.readPackedEnd();\n        while (this.pos < end) arr.push(this.readFixed32());\n        return arr;\n    }\n    /** @param {number[]} [arr] */\n    readPackedSFixed32(arr = []) {\n        const end = this.readPackedEnd();\n        while (this.pos < end) arr.push(this.readSFixed32());\n        return arr;\n    }\n    /** @param {number[]} [arr] */\n    readPackedFixed64(arr = []) {\n        const end = this.readPackedEnd();\n        while (this.pos < end) arr.push(this.readFixed64());\n        return arr;\n    }\n    /** @param {number[]} [arr] */\n    readPackedSFixed64(arr = []) {\n        const end = this.readPackedEnd();\n        while (this.pos < end) arr.push(this.readSFixed64());\n        return arr;\n    }\n    readPackedEnd() {\n        return this.type === PBF_BYTES ? this.readVarint() + this.pos : this.pos + 1;\n    }\n\n    /** @param {number} val */\n    skip(val) {\n        const type = val & 0x7;\n        if (type === PBF_VARINT) while (this.buf[this.pos++] > 0x7f) {}\n        else if (type === PBF_BYTES) this.pos = this.readVarint() + this.pos;\n        else if (type === PBF_FIXED32) this.pos += 4;\n        else if (type === PBF_FIXED64) this.pos += 8;\n        else throw new Error(`Unimplemented type: ${type}`);\n    }\n\n    // === WRITING =================================================================\n\n    /**\n     * @param {number} tag\n     * @param {number} type\n     */\n    writeTag(tag, type) {\n        this.writeVarint((tag << 3) | type);\n    }\n\n    /** @param {number} min */\n    realloc(min) {\n        let length = this.length || 16;\n\n        while (length < this.pos + min) length *= 2;\n\n        if (length !== this.length) {\n            const buf = new Uint8Array(length);\n            buf.set(this.buf);\n            this.buf = buf;\n            this.dataView = new DataView(buf.buffer);\n            this.length = length;\n        }\n    }\n\n    finish() {\n        this.length = this.pos;\n        this.pos = 0;\n        return this.buf.subarray(0, this.length);\n    }\n\n    /** @param {number} val */\n    writeFixed32(val) {\n        this.realloc(4);\n        this.dataView.setInt32(this.pos, val, true);\n        this.pos += 4;\n    }\n\n    /** @param {number} val */\n    writeSFixed32(val) {\n        this.realloc(4);\n        this.dataView.setInt32(this.pos, val, true);\n        this.pos += 4;\n    }\n\n    /** @param {number} val */\n    writeFixed64(val) {\n        this.realloc(8);\n        this.dataView.setInt32(this.pos, val & -1, true);\n        this.dataView.setInt32(this.pos + 4, Math.floor(val * SHIFT_RIGHT_32), true);\n        this.pos += 8;\n    }\n\n    /** @param {number} val */\n    writeSFixed64(val) {\n        this.realloc(8);\n        this.dataView.setInt32(this.pos, val & -1, true);\n        this.dataView.setInt32(this.pos + 4, Math.floor(val * SHIFT_RIGHT_32), true);\n        this.pos += 8;\n    }\n\n    /** @param {number} val */\n    writeVarint(val) {\n        val = +val || 0;\n\n        if (val > 0xfffffff || val < 0) {\n            writeBigVarint(val, this);\n            return;\n        }\n\n        this.realloc(4);\n\n        this.buf[this.pos++] =           val & 0x7f  | (val > 0x7f ? 0x80 : 0); if (val <= 0x7f) return;\n        this.buf[this.pos++] = ((val >>>= 7) & 0x7f) | (val > 0x7f ? 0x80 : 0); if (val <= 0x7f) return;\n        this.buf[this.pos++] = ((val >>>= 7) & 0x7f) | (val > 0x7f ? 0x80 : 0); if (val <= 0x7f) return;\n        this.buf[this.pos++] =   (val >>> 7) & 0x7f;\n    }\n\n    /** @param {number} val */\n    writeSVarint(val) {\n        this.writeVarint(val < 0 ? -val * 2 - 1 : val * 2);\n    }\n\n    /** @param {boolean} val */\n    writeBoolean(val) {\n        this.writeVarint(+val);\n    }\n\n    /** @param {string} str */\n    writeString(str) {\n        str = String(str);\n        this.realloc(str.length * 4);\n\n        this.pos++; // reserve 1 byte for short string length\n\n        const startPos = this.pos;\n        // write the string directly to the buffer and see how much was written\n        this.pos = writeUtf8(this.buf, str, this.pos);\n        const len = this.pos - startPos;\n\n        if (len >= 0x80) makeRoomForExtraLength(startPos, len, this);\n\n        // finally, write the message length in the reserved place and restore the position\n        this.pos = startPos - 1;\n        this.writeVarint(len);\n        this.pos += len;\n    }\n\n    /** @param {number} val */\n    writeFloat(val) {\n        this.realloc(4);\n        this.dataView.setFloat32(this.pos, val, true);\n        this.pos += 4;\n    }\n\n    /** @param {number} val */\n    writeDouble(val) {\n        this.realloc(8);\n        this.dataView.setFloat64(this.pos, val, true);\n        this.pos += 8;\n    }\n\n    /** @param {Uint8Array} buffer */\n    writeBytes(buffer) {\n        const len = buffer.length;\n        this.writeVarint(len);\n        this.realloc(len);\n        for (let i = 0; i < len; i++) this.buf[this.pos++] = buffer[i];\n    }\n\n    /**\n     * @template T\n     * @param {(obj: T, pbf: Pbf) => void} fn\n     * @param {T} obj\n     */\n    writeRawMessage(fn, obj) {\n        this.pos++; // reserve 1 byte for short message length\n\n        // write the message directly to the buffer and see how much was written\n        const startPos = this.pos;\n        fn(obj, this);\n        const len = this.pos - startPos;\n\n        if (len >= 0x80) makeRoomForExtraLength(startPos, len, this);\n\n        // finally, write the message length in the reserved place and restore the position\n        this.pos = startPos - 1;\n        this.writeVarint(len);\n        this.pos += len;\n    }\n\n    /**\n     * @template T\n     * @param {number} tag\n     * @param {(obj: T, pbf: Pbf) => void} fn\n     * @param {T} obj\n     */\n    writeMessage(tag, fn, obj) {\n        this.writeTag(tag, PBF_BYTES);\n        this.writeRawMessage(fn, obj);\n    }\n\n    /**\n     * @param {number} tag\n     * @param {number[]} arr\n     */\n    writePackedVarint(tag, arr) {\n        if (arr.length) this.writeMessage(tag, writePackedVarint, arr);\n    }\n    /**\n     * @param {number} tag\n     * @param {number[]} arr\n     */\n    writePackedSVarint(tag, arr) {\n        if (arr.length) this.writeMessage(tag, writePackedSVarint, arr);\n    }\n    /**\n     * @param {number} tag\n     * @param {boolean[]} arr\n     */\n    writePackedBoolean(tag, arr) {\n        if (arr.length) this.writeMessage(tag, writePackedBoolean, arr);\n    }\n    /**\n     * @param {number} tag\n     * @param {number[]} arr\n     */\n    writePackedFloat(tag, arr) {\n        if (arr.length) this.writeMessage(tag, writePackedFloat, arr);\n    }\n    /**\n     * @param {number} tag\n     * @param {number[]} arr\n     */\n    writePackedDouble(tag, arr) {\n        if (arr.length) this.writeMessage(tag, writePackedDouble, arr);\n    }\n    /**\n     * @param {number} tag\n     * @param {number[]} arr\n     */\n    writePackedFixed32(tag, arr) {\n        if (arr.length) this.writeMessage(tag, writePackedFixed32, arr);\n    }\n    /**\n     * @param {number} tag\n     * @param {number[]} arr\n     */\n    writePackedSFixed32(tag, arr) {\n        if (arr.length) this.writeMessage(tag, writePackedSFixed32, arr);\n    }\n    /**\n     * @param {number} tag\n     * @param {number[]} arr\n     */\n    writePackedFixed64(tag, arr) {\n        if (arr.length) this.writeMessage(tag, writePackedFixed64, arr);\n    }\n    /**\n     * @param {number} tag\n     * @param {number[]} arr\n     */\n    writePackedSFixed64(tag, arr) {\n        if (arr.length) this.writeMessage(tag, writePackedSFixed64, arr);\n    }\n\n    /**\n     * @param {number} tag\n     * @param {Uint8Array} buffer\n     */\n    writeBytesField(tag, buffer) {\n        this.writeTag(tag, PBF_BYTES);\n        this.writeBytes(buffer);\n    }\n    /**\n     * @param {number} tag\n     * @param {number} val\n     */\n    writeFixed32Field(tag, val) {\n        this.writeTag(tag, PBF_FIXED32);\n        this.writeFixed32(val);\n    }\n    /**\n     * @param {number} tag\n     * @param {number} val\n     */\n    writeSFixed32Field(tag, val) {\n        this.writeTag(tag, PBF_FIXED32);\n        this.writeSFixed32(val);\n    }\n    /**\n     * @param {number} tag\n     * @param {number} val\n     */\n    writeFixed64Field(tag, val) {\n        this.writeTag(tag, PBF_FIXED64);\n        this.writeFixed64(val);\n    }\n    /**\n     * @param {number} tag\n     * @param {number} val\n     */\n    writeSFixed64Field(tag, val) {\n        this.writeTag(tag, PBF_FIXED64);\n        this.writeSFixed64(val);\n    }\n    /**\n     * @param {number} tag\n     * @param {number} val\n     */\n    writeVarintField(tag, val) {\n        this.writeTag(tag, PBF_VARINT);\n        this.writeVarint(val);\n    }\n    /**\n     * @param {number} tag\n     * @param {number} val\n     */\n    writeSVarintField(tag, val) {\n        this.writeTag(tag, PBF_VARINT);\n        this.writeSVarint(val);\n    }\n    /**\n     * @param {number} tag\n     * @param {string} str\n     */\n    writeStringField(tag, str) {\n        this.writeTag(tag, PBF_BYTES);\n        this.writeString(str);\n    }\n    /**\n     * @param {number} tag\n     * @param {number} val\n     */\n    writeFloatField(tag, val) {\n        this.writeTag(tag, PBF_FIXED32);\n        this.writeFloat(val);\n    }\n    /**\n     * @param {number} tag\n     * @param {number} val\n     */\n    writeDoubleField(tag, val) {\n        this.writeTag(tag, PBF_FIXED64);\n        this.writeDouble(val);\n    }\n    /**\n     * @param {number} tag\n     * @param {boolean} val\n     */\n    writeBooleanField(tag, val) {\n        this.writeVarintField(tag, +val);\n    }\n};\n\n/**\n * @param {number} l\n * @param {boolean | undefined} s\n * @param {Pbf} p\n */\nfunction readVarintRemainder(l, s, p) {\n    const buf = p.buf;\n    let h, b;\n\n    b = buf[p.pos++]; h  = (b & 0x70) >> 4;  if (b < 0x80) return toNum(l, h, s);\n    b = buf[p.pos++]; h |= (b & 0x7f) << 3;  if (b < 0x80) return toNum(l, h, s);\n    b = buf[p.pos++]; h |= (b & 0x7f) << 10; if (b < 0x80) return toNum(l, h, s);\n    b = buf[p.pos++]; h |= (b & 0x7f) << 17; if (b < 0x80) return toNum(l, h, s);\n    b = buf[p.pos++]; h |= (b & 0x7f) << 24; if (b < 0x80) return toNum(l, h, s);\n    b = buf[p.pos++]; h |= (b & 0x01) << 31; if (b < 0x80) return toNum(l, h, s);\n\n    throw new Error('Expected varint not more than 10 bytes');\n}\n\n/**\n * @param {number} low\n * @param {number} high\n * @param {boolean} [isSigned]\n */\nfunction toNum(low, high, isSigned) {\n    return isSigned ? high * 0x100000000 + (low >>> 0) : ((high >>> 0) * 0x100000000) + (low >>> 0);\n}\n\n/**\n * @param {number} val\n * @param {Pbf} pbf\n */\nfunction writeBigVarint(val, pbf) {\n    let low, high;\n\n    if (val >= 0) {\n        low  = (val % 0x100000000) | 0;\n        high = (val / 0x100000000) | 0;\n    } else {\n        low  = ~(-val % 0x100000000);\n        high = ~(-val / 0x100000000);\n\n        if (low ^ 0xffffffff) {\n            low = (low + 1) | 0;\n        } else {\n            low = 0;\n            high = (high + 1) | 0;\n        }\n    }\n\n    if (val >= 0x10000000000000000 || val < -0x10000000000000000) {\n        throw new Error('Given varint doesn\\'t fit into 10 bytes');\n    }\n\n    pbf.realloc(10);\n\n    writeBigVarintLow(low, high, pbf);\n    writeBigVarintHigh(high, pbf);\n}\n\n/**\n * @param {number} high\n * @param {number} low\n * @param {Pbf} pbf\n */\nfunction writeBigVarintLow(low, high, pbf) {\n    pbf.buf[pbf.pos++] = low & 0x7f | 0x80; low >>>= 7;\n    pbf.buf[pbf.pos++] = low & 0x7f | 0x80; low >>>= 7;\n    pbf.buf[pbf.pos++] = low & 0x7f | 0x80; low >>>= 7;\n    pbf.buf[pbf.pos++] = low & 0x7f | 0x80; low >>>= 7;\n    pbf.buf[pbf.pos]   = low & 0x7f;\n}\n\n/**\n * @param {number} high\n * @param {Pbf} pbf\n */\nfunction writeBigVarintHigh(high, pbf) {\n    const lsb = (high & 0x07) << 4;\n\n    pbf.buf[pbf.pos++] |= lsb         | ((high >>>= 3) ? 0x80 : 0); if (!high) return;\n    pbf.buf[pbf.pos++]  = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) return;\n    pbf.buf[pbf.pos++]  = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) return;\n    pbf.buf[pbf.pos++]  = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) return;\n    pbf.buf[pbf.pos++]  = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) return;\n    pbf.buf[pbf.pos++]  = high & 0x7f;\n}\n\n/**\n * @param {number} startPos\n * @param {number} len\n * @param {Pbf} pbf\n */\nfunction makeRoomForExtraLength(startPos, len, pbf) {\n    const extraLen =\n        len <= 0x3fff ? 1 :\n        len <= 0x1fffff ? 2 :\n        len <= 0xfffffff ? 3 : Math.floor(Math.log(len) / (Math.LN2 * 7));\n\n    // if 1 byte isn't enough for encoding message length, shift the data to the right\n    pbf.realloc(extraLen);\n    for (let i = pbf.pos - 1; i >= startPos; i--) pbf.buf[i + extraLen] = pbf.buf[i];\n}\n\n/**\n * @param {number[]} arr\n * @param {Pbf} pbf\n */\nfunction writePackedVarint(arr, pbf) {\n    for (let i = 0; i < arr.length; i++) pbf.writeVarint(arr[i]);\n}\n/**\n * @param {number[]} arr\n * @param {Pbf} pbf\n */\nfunction writePackedSVarint(arr, pbf) {\n    for (let i = 0; i < arr.length; i++) pbf.writeSVarint(arr[i]);\n}\n/**\n * @param {number[]} arr\n * @param {Pbf} pbf\n */\nfunction writePackedFloat(arr, pbf) {\n    for (let i = 0; i < arr.length; i++) pbf.writeFloat(arr[i]);\n}\n/**\n * @param {number[]} arr\n * @param {Pbf} pbf\n */\nfunction writePackedDouble(arr, pbf) {\n    for (let i = 0; i < arr.length; i++) pbf.writeDouble(arr[i]);\n}\n/**\n * @param {boolean[]} arr\n * @param {Pbf} pbf\n */\nfunction writePackedBoolean(arr, pbf) {\n    for (let i = 0; i < arr.length; i++) pbf.writeBoolean(arr[i]);\n}\n/**\n * @param {number[]} arr\n * @param {Pbf} pbf\n */\nfunction writePackedFixed32(arr, pbf) {\n    for (let i = 0; i < arr.length; i++) pbf.writeFixed32(arr[i]);\n}\n/**\n * @param {number[]} arr\n * @param {Pbf} pbf\n */\nfunction writePackedSFixed32(arr, pbf) {\n    for (let i = 0; i < arr.length; i++) pbf.writeSFixed32(arr[i]);\n}\n/**\n * @param {number[]} arr\n * @param {Pbf} pbf\n */\nfunction writePackedFixed64(arr, pbf) {\n    for (let i = 0; i < arr.length; i++) pbf.writeFixed64(arr[i]);\n}\n/**\n * @param {number[]} arr\n * @param {Pbf} pbf\n */\nfunction writePackedSFixed64(arr, pbf) {\n    for (let i = 0; i < arr.length; i++) pbf.writeSFixed64(arr[i]);\n}\n\n// Buffer code below from https://github.com/feross/buffer, MIT-licensed\n\n/**\n * @param {Uint8Array} buf\n * @param {number} pos\n * @param {number} end\n */\nfunction readUtf8(buf, pos, end) {\n    let str = '';\n    let i = pos;\n\n    while (i < end) {\n        const b0 = buf[i];\n        let c = null; // codepoint\n        let bytesPerSequence =\n            b0 > 0xEF ? 4 :\n            b0 > 0xDF ? 3 :\n            b0 > 0xBF ? 2 : 1;\n\n        if (i + bytesPerSequence > end) break;\n\n        let b1, b2, b3;\n\n        if (bytesPerSequence === 1) {\n            if (b0 < 0x80) {\n                c = b0;\n            }\n        } else if (bytesPerSequence === 2) {\n            b1 = buf[i + 1];\n            if ((b1 & 0xC0) === 0x80) {\n                c = (b0 & 0x1F) << 0x6 | (b1 & 0x3F);\n                if (c <= 0x7F) {\n                    c = null;\n                }\n            }\n        } else if (bytesPerSequence === 3) {\n            b1 = buf[i + 1];\n            b2 = buf[i + 2];\n            if ((b1 & 0xC0) === 0x80 && (b2 & 0xC0) === 0x80) {\n                c = (b0 & 0xF) << 0xC | (b1 & 0x3F) << 0x6 | (b2 & 0x3F);\n                if (c <= 0x7FF || (c >= 0xD800 && c <= 0xDFFF)) {\n                    c = null;\n                }\n            }\n        } else if (bytesPerSequence === 4) {\n            b1 = buf[i + 1];\n            b2 = buf[i + 2];\n            b3 = buf[i + 3];\n            if ((b1 & 0xC0) === 0x80 && (b2 & 0xC0) === 0x80 && (b3 & 0xC0) === 0x80) {\n                c = (b0 & 0xF) << 0x12 | (b1 & 0x3F) << 0xC | (b2 & 0x3F) << 0x6 | (b3 & 0x3F);\n                if (c <= 0xFFFF || c >= 0x110000) {\n                    c = null;\n                }\n            }\n        }\n\n        if (c === null) {\n            c = 0xFFFD;\n            bytesPerSequence = 1;\n\n        } else if (c > 0xFFFF) {\n            c -= 0x10000;\n            str += String.fromCharCode(c >>> 10 & 0x3FF | 0xD800);\n            c = 0xDC00 | c & 0x3FF;\n        }\n\n        str += String.fromCharCode(c);\n        i += bytesPerSequence;\n    }\n\n    return str;\n}\n\n/**\n * @param {Uint8Array} buf\n * @param {string} str\n * @param {number} pos\n */\nfunction writeUtf8(buf, str, pos) {\n    for (let i = 0, c, lead; i < str.length; i++) {\n        c = str.charCodeAt(i); // code point\n\n        if (c > 0xD7FF && c < 0xE000) {\n            if (lead) {\n                if (c < 0xDC00) {\n                    buf[pos++] = 0xEF;\n                    buf[pos++] = 0xBF;\n                    buf[pos++] = 0xBD;\n                    lead = c;\n                    continue;\n                } else {\n                    c = lead - 0xD800 << 10 | c - 0xDC00 | 0x10000;\n                    lead = null;\n                }\n            } else {\n                if (c > 0xDBFF || (i + 1 === str.length)) {\n                    buf[pos++] = 0xEF;\n                    buf[pos++] = 0xBF;\n                    buf[pos++] = 0xBD;\n                } else {\n                    lead = c;\n                }\n                continue;\n            }\n        } else if (lead) {\n            buf[pos++] = 0xEF;\n            buf[pos++] = 0xBF;\n            buf[pos++] = 0xBD;\n            lead = null;\n        }\n\n        if (c < 0x80) {\n            buf[pos++] = c;\n        } else {\n            if (c < 0x800) {\n                buf[pos++] = c >> 0x6 | 0xC0;\n            } else {\n                if (c < 0x10000) {\n                    buf[pos++] = c >> 0xC | 0xE0;\n                } else {\n                    buf[pos++] = c >> 0x12 | 0xF0;\n                    buf[pos++] = c >> 0xC & 0x3F | 0x80;\n                }\n                buf[pos++] = c >> 0x6 & 0x3F | 0x80;\n            }\n            buf[pos++] = c & 0x3F | 0x80;\n        }\n    }\n    return pos;\n}\n","/**\n * @module ol/format/MVT\n */\n//FIXME Implement projection handling\n\nimport PBF from 'pbf';\nimport LineString from '../geom/LineString.js';\nimport MultiLineString from '../geom/MultiLineString.js';\nimport MultiPoint from '../geom/MultiPoint.js';\nimport MultiPolygon from '../geom/MultiPolygon.js';\nimport Point from '../geom/Point.js';\nimport Polygon from '../geom/Polygon.js';\nimport {inflateEnds} from '../geom/flat/orient.js';\nimport {get} from '../proj.js';\nimport Projection from '../proj/Projection.js';\nimport RenderFeature from '../render/Feature.js';\nimport FeatureFormat, {transformGeometryWithOptions} from './Feature.js';\n\n/**\n * @template {import(\"../Feature.js\").FeatureLike} [FeatureType=import(\"../render/Feature.js\").default]\n * @typedef {Object} Options\n * @property {import('./Feature.js').FeatureToFeatureClass<FeatureType>} [featureClass] Class for features returned by\n * {@link module:ol/format/MVT~MVT#readFeatures}. Set to {@link module:ol/Feature~Feature} to get full editing and geometry\n * support at the cost of decreased rendering performance. The default is\n * {@link module:ol/render/Feature~RenderFeature}, which is optimized for rendering and hit detection.\n * @property {string} [geometryName='geometry'] Geometry name to use when creating features.\n * @property {string} [layerName='layer'] Name of the feature attribute that holds the layer name.\n * @property {Array<string>} [layers] Layers to read features from. If not provided, features will be read from all\n * @property {string} [idProperty] Optional property that will be assigned as the feature id and removed from the properties.\n * layers.\n */\n\n/**\n * @classdesc\n * Feature format for reading data in the Mapbox MVT format.\n *\n * @template {import('../Feature.js').FeatureLike} [FeatureType=RenderFeature]\n * @extends {FeatureFormat<FeatureType>}\n * @api\n */\nclass MVT extends FeatureFormat {\n  /**\n   * @param {Options<FeatureType>} [options] Options.\n   */\n  constructor(options) {\n    super();\n\n    options = options ? options : {};\n\n    /**\n     * @type {Projection}\n     */\n    this.dataProjection = new Projection({\n      code: '',\n      units: 'tile-pixels',\n    });\n\n    this.featureClass = options.featureClass\n      ? options.featureClass\n      : /** @type {import('./Feature.js').FeatureToFeatureClass<FeatureType>} */ (\n          RenderFeature\n        );\n\n    /**\n     * @private\n     * @type {string|undefined}\n     */\n    this.geometryName_ = options.geometryName;\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.layerName_ = options.layerName ? options.layerName : 'layer';\n\n    /**\n     * @private\n     * @type {Array<string>|null}\n     */\n    this.layers_ = options.layers ? options.layers : null;\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.idProperty_ = options.idProperty;\n\n    this.supportedMediaTypes = [\n      'application/vnd.mapbox-vector-tile',\n      'application/x-protobuf',\n    ];\n  }\n\n  /**\n   * Read the raw geometry from the pbf offset stored in a raw feature's geometry\n   * property.\n   * @param {PBF} pbf PBF.\n   * @param {Object} feature Raw feature.\n   * @param {Array<number>} flatCoordinates Array to store flat coordinates in.\n   * @param {Array<number>} ends Array to store ends in.\n   * @private\n   */\n  readRawGeometry_(pbf, feature, flatCoordinates, ends) {\n    pbf.pos = feature.geometry;\n\n    const end = pbf.readVarint() + pbf.pos;\n    let cmd = 1;\n    let length = 0;\n    let x = 0;\n    let y = 0;\n    let coordsLen = 0;\n    let currentEnd = 0;\n\n    while (pbf.pos < end) {\n      if (!length) {\n        const cmdLen = pbf.readVarint();\n        cmd = cmdLen & 0x7;\n        length = cmdLen >> 3;\n      }\n\n      length--;\n\n      if (cmd === 1 || cmd === 2) {\n        x += pbf.readSVarint();\n        y += pbf.readSVarint();\n\n        if (cmd === 1) {\n          // moveTo\n          if (coordsLen > currentEnd) {\n            ends.push(coordsLen);\n            currentEnd = coordsLen;\n          }\n        }\n\n        flatCoordinates.push(x, y);\n        coordsLen += 2;\n      } else if (cmd === 7) {\n        if (coordsLen > currentEnd) {\n          // close polygon\n          flatCoordinates.push(\n            flatCoordinates[currentEnd],\n            flatCoordinates[currentEnd + 1],\n          );\n          coordsLen += 2;\n        }\n      } else {\n        throw new Error('Invalid command found in the PBF');\n      }\n    }\n\n    if (coordsLen > currentEnd) {\n      ends.push(coordsLen);\n      currentEnd = coordsLen;\n    }\n  }\n\n  /**\n   * @private\n   * @param {PBF} pbf PBF\n   * @param {Object} rawFeature Raw Mapbox feature.\n   * @param {import(\"./Feature.js\").ReadOptions} options Read options.\n   * @return {FeatureType|null} Feature.\n   */\n  createFeature_(pbf, rawFeature, options) {\n    const type = rawFeature.type;\n    if (type === 0) {\n      return null;\n    }\n\n    let feature;\n    const values = rawFeature.properties;\n\n    let id;\n    if (!this.idProperty_) {\n      id = rawFeature.id;\n    } else {\n      id = values[this.idProperty_];\n      delete values[this.idProperty_];\n    }\n\n    values[this.layerName_] = rawFeature.layer.name;\n\n    const flatCoordinates = /** @type {Array<number>} */ ([]);\n    const ends = /** @type {Array<number>} */ ([]);\n    this.readRawGeometry_(pbf, rawFeature, flatCoordinates, ends);\n\n    const geometryType = getGeometryType(type, ends.length);\n\n    if (this.featureClass === RenderFeature) {\n      feature =\n        new /** @type {import('./Feature.js').FeatureToFeatureClass<RenderFeature>} */ (\n          this.featureClass\n        )(geometryType, flatCoordinates, ends, 2, values, id);\n      feature.transform(options.dataProjection);\n    } else {\n      let geom;\n      if (geometryType == 'Polygon') {\n        const endss = inflateEnds(flatCoordinates, ends);\n        geom =\n          endss.length > 1\n            ? new MultiPolygon(flatCoordinates, 'XY', endss)\n            : new Polygon(flatCoordinates, 'XY', ends);\n      } else {\n        geom =\n          geometryType === 'Point'\n            ? new Point(flatCoordinates, 'XY')\n            : geometryType === 'LineString'\n              ? new LineString(flatCoordinates, 'XY')\n              : geometryType === 'MultiPoint'\n                ? new MultiPoint(flatCoordinates, 'XY')\n                : geometryType === 'MultiLineString'\n                  ? new MultiLineString(flatCoordinates, 'XY', ends)\n                  : null;\n      }\n      const ctor = /** @type {typeof import(\"../Feature.js\").default} */ (\n        this.featureClass\n      );\n      feature = new ctor();\n      if (this.geometryName_) {\n        feature.setGeometryName(this.geometryName_);\n      }\n      const geometry = transformGeometryWithOptions(geom, false, options);\n      feature.setGeometry(geometry);\n      if (id !== undefined) {\n        feature.setId(id);\n      }\n      feature.setProperties(values, true);\n    }\n\n    return /** @type {FeatureType} */ (feature);\n  }\n\n  /**\n   * @return {import(\"./Feature.js\").Type} Format.\n   * @override\n   */\n  getType() {\n    return 'arraybuffer';\n  }\n\n  /**\n   * Read all features.\n   *\n   * @param {ArrayBuffer} source Source.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @return {Array<FeatureType>} Features.\n   * @api\n   * @override\n   */\n  readFeatures(source, options) {\n    const layers = this.layers_;\n    options = this.adaptOptions(options);\n    const dataProjection = get(options.dataProjection);\n    dataProjection.setWorldExtent(options.extent);\n    options.dataProjection = dataProjection;\n\n    const pbf = new PBF(/** @type {ArrayBuffer} */ (source));\n    const pbfLayers = pbf.readFields(layersPBFReader, {});\n    const features = [];\n    for (const name in pbfLayers) {\n      if (layers && !layers.includes(name)) {\n        continue;\n      }\n      const pbfLayer = pbfLayers[name];\n\n      const extent = pbfLayer ? [0, 0, pbfLayer.extent, pbfLayer.extent] : null;\n      dataProjection.setExtent(extent);\n\n      for (let i = 0, ii = pbfLayer.length; i < ii; ++i) {\n        const rawFeature = readRawFeature(pbf, pbfLayer, i);\n        const feature = this.createFeature_(pbf, rawFeature, options);\n        if (feature !== null) {\n          features.push(feature);\n        }\n      }\n    }\n\n    return /** @type {Array<FeatureType>} */ (features);\n  }\n\n  /**\n   * Read the projection from the source.\n   *\n   * @param {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.dataProjection;\n  }\n\n  /**\n   * Sets the layers that features will be read from.\n   * @param {Array<string>} layers Layers.\n   * @api\n   */\n  setLayers(layers) {\n    this.layers_ = layers;\n  }\n}\n\n/**\n * Reader callback for parsing layers.\n * @param {number} tag The tag.\n * @param {Object} layers The layers object.\n * @param {PBF} pbf The PBF.\n */\nfunction layersPBFReader(tag, layers, pbf) {\n  if (tag === 3) {\n    const layer = {\n      keys: [],\n      values: [],\n      features: [],\n    };\n    const end = pbf.readVarint() + pbf.pos;\n    pbf.readFields(layerPBFReader, layer, end);\n    layer.length = layer.features.length;\n    if (layer.length) {\n      layers[layer.name] = layer;\n    }\n  }\n}\n\n/**\n * Reader callback for parsing layer.\n * @param {number} tag The tag.\n * @param {Object} layer The layer object.\n * @param {PBF} pbf The PBF.\n */\nfunction layerPBFReader(tag, layer, pbf) {\n  if (tag === 15) {\n    layer.version = pbf.readVarint();\n  } else if (tag === 1) {\n    layer.name = pbf.readString();\n  } else if (tag === 5) {\n    layer.extent = pbf.readVarint();\n  } else if (tag === 2) {\n    layer.features.push(pbf.pos);\n  } else if (tag === 3) {\n    layer.keys.push(pbf.readString());\n  } else if (tag === 4) {\n    let value = null;\n    const end = pbf.readVarint() + pbf.pos;\n    while (pbf.pos < end) {\n      tag = pbf.readVarint() >> 3;\n      value =\n        tag === 1\n          ? pbf.readString()\n          : tag === 2\n            ? pbf.readFloat()\n            : tag === 3\n              ? pbf.readDouble()\n              : tag === 4\n                ? pbf.readVarint64()\n                : tag === 5\n                  ? pbf.readVarint()\n                  : tag === 6\n                    ? pbf.readSVarint()\n                    : tag === 7\n                      ? pbf.readBoolean()\n                      : null;\n    }\n    layer.values.push(value);\n  }\n}\n\n/**\n * Reader callback for parsing feature.\n * @param {number} tag The tag.\n * @param {Object} feature The feature object.\n * @param {PBF} pbf The PBF.\n */\nfunction featurePBFReader(tag, feature, pbf) {\n  if (tag == 1) {\n    feature.id = pbf.readVarint();\n  } else if (tag == 2) {\n    const end = pbf.readVarint() + pbf.pos;\n    while (pbf.pos < end) {\n      const key = feature.layer.keys[pbf.readVarint()];\n      const value = feature.layer.values[pbf.readVarint()];\n      feature.properties[key] = value;\n    }\n  } else if (tag == 3) {\n    feature.type = pbf.readVarint();\n  } else if (tag == 4) {\n    feature.geometry = pbf.pos;\n  }\n}\n\n/**\n * Read a raw feature from the pbf offset stored at index `i` in the raw layer.\n * @param {PBF} pbf PBF.\n * @param {Object} layer Raw layer.\n * @param {number} i Index of the feature in the raw layer's `features` array.\n * @return {Object} Raw feature.\n */\nfunction readRawFeature(pbf, layer, i) {\n  pbf.pos = layer.features[i];\n  const end = pbf.readVarint() + pbf.pos;\n\n  const feature = {\n    layer: layer,\n    type: 0,\n    properties: {},\n  };\n  pbf.readFields(featurePBFReader, feature, end);\n  return feature;\n}\n\n/**\n * @param {number} type The raw feature's geometry type\n * @param {number} numEnds Number of ends of the flat coordinates of the\n * geometry.\n * @return {import(\"../render/Feature.js\").Type} The geometry type.\n */\nfunction getGeometryType(type, numEnds) {\n  /** @type {import(\"../render/Feature.js\").Type} */\n  let geometryType;\n  if (type === 1) {\n    geometryType = numEnds === 1 ? 'Point' : 'MultiPoint';\n  } else if (type === 2) {\n    geometryType = numEnds === 1 ? 'LineString' : 'MultiLineString';\n  } else if (type === 3) {\n    geometryType = 'Polygon';\n    // MultiPolygon not relevant for rendering - winding order determines\n    // outer rings of polygons.\n  }\n  return geometryType;\n}\n\nexport default MVT;\n","/**\n * @module ol/format/OSMXML\n */\n// FIXME add typedef for stack state objects\nimport Feature from '../Feature.js';\nimport {extend} from '../array.js';\nimport LineString from '../geom/LineString.js';\nimport Point from '../geom/Point.js';\nimport Polygon from '../geom/Polygon.js';\nimport {isEmpty} from '../obj.js';\nimport {get as getProjection} from '../proj.js';\nimport {makeStructureNS, pushParseAndPop} from '../xml.js';\nimport {transformGeometryWithOptions} from './Feature.js';\nimport XMLFeature from './XMLFeature.js';\n\n/**\n * @const\n * @type {Array<null>}\n */\nconst NAMESPACE_URIS = [null];\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst WAY_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'nd': readNd,\n  'tag': readTag,\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'node': readNode,\n  'way': readWay,\n});\n\n/**\n * @classdesc\n * Feature format for reading data in the\n * [OSMXML format](https://wiki.openstreetmap.org/wiki/OSM_XML).\n *\n * @api\n */\nclass OSMXML extends XMLFeature {\n  constructor() {\n    super();\n\n    /**\n     * @type {import(\"../proj/Projection.js\").default}\n     */\n    this.dataProjection = getProjection('EPSG:4326');\n  }\n\n  /**\n   * @protected\n   * @param {Element} node Node.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @return {Array<import(\"../Feature.js\").default>} Features.\n   * @override\n   */\n  readFeaturesFromNode(node, options) {\n    options = this.getReadOptions(node, options);\n    if (node.localName == 'osm') {\n      const state = pushParseAndPop(\n        {\n          nodes: {},\n          ways: [],\n          features: [],\n        },\n        PARSERS,\n        node,\n        [options],\n      );\n      // parse nodes in ways\n      for (let j = 0; j < state.ways.length; j++) {\n        const values = /** @type {Object} */ (state.ways[j]);\n        /** @type {Array<number>} */\n        const flatCoordinates = values.flatCoordinates;\n        if (!flatCoordinates.length) {\n          for (let i = 0, ii = values.ndrefs.length; i < ii; i++) {\n            const point = state.nodes[values.ndrefs[i]];\n            extend(flatCoordinates, point);\n          }\n        }\n        let geometry;\n        if (values.ndrefs[0] == values.ndrefs[values.ndrefs.length - 1]) {\n          // closed way\n          geometry = new Polygon(flatCoordinates, 'XY', [\n            flatCoordinates.length,\n          ]);\n        } else {\n          geometry = new LineString(flatCoordinates, 'XY');\n        }\n        transformGeometryWithOptions(geometry, false, options);\n        const feature = new Feature(geometry);\n        if (values.id !== undefined) {\n          feature.setId(values.id);\n        }\n        feature.setProperties(values.tags, true);\n        state.features.push(feature);\n      }\n      if (state.features) {\n        return state.features;\n      }\n    }\n    return [];\n  }\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst NODE_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'tag': readTag,\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction readNode(node, objectStack) {\n  const options = /** @type {import(\"./Feature.js\").ReadOptions} */ (\n    objectStack[0]\n  );\n  const state = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const id = node.getAttribute('id');\n  /** @type {import(\"../coordinate.js\").Coordinate} */\n  const coordinates = [\n    parseFloat(node.getAttribute('lon')),\n    parseFloat(node.getAttribute('lat')),\n  ];\n  state.nodes[id] = coordinates;\n\n  const values = pushParseAndPop(\n    {\n      tags: {},\n    },\n    NODE_PARSERS,\n    node,\n    objectStack,\n  );\n  if (!isEmpty(values.tags)) {\n    const geometry = new Point(coordinates);\n    transformGeometryWithOptions(geometry, false, options);\n    const feature = new Feature(geometry);\n    if (id !== undefined) {\n      feature.setId(id);\n    }\n    feature.setProperties(values.tags, true);\n    state.features.push(feature);\n  }\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction readWay(node, objectStack) {\n  const id = node.getAttribute('id');\n  const values = pushParseAndPop(\n    {\n      id: id,\n      ndrefs: [],\n      flatCoordinates: [],\n      tags: {},\n    },\n    WAY_PARSERS,\n    node,\n    objectStack,\n  );\n  const state = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  state.ways.push(values);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction readNd(node, objectStack) {\n  const values = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  values.ndrefs.push(node.getAttribute('ref'));\n  if (node.hasAttribute('lon') && node.hasAttribute('lat')) {\n    values.flatCoordinates.push(parseFloat(node.getAttribute('lon')));\n    values.flatCoordinates.push(parseFloat(node.getAttribute('lat')));\n  }\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction readTag(node, objectStack) {\n  const values = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  values.tags[node.getAttribute('k')] = node.getAttribute('v');\n}\n\nexport default OSMXML;\n","/**\n * @module ol/format/XML\n */\nimport {abstract} from '../util.js';\nimport {isDocument, parse} from '../xml.js';\n\n/**\n * @classdesc\n * Generic format for reading non-feature XML data\n *\n * @abstract\n */\nclass XML {\n  /**\n   * Read the source document.\n   *\n   * @param {Document|Element|string} source The XML source.\n   * @return {Object|null} An object representing the source.\n   * @api\n   */\n  read(source) {\n    if (!source) {\n      return null;\n    }\n    if (typeof source === 'string') {\n      const doc = parse(source);\n      return this.readFromDocument(doc);\n    }\n    if (isDocument(source)) {\n      return this.readFromDocument(/** @type {Document} */ (source));\n    }\n    return this.readFromNode(/** @type {Element} */ (source));\n  }\n\n  /**\n   * @param {Document} doc Document.\n   * @return {Object|null} Object\n   */\n  readFromDocument(doc) {\n    for (let n = doc.firstChild; n; n = n.nextSibling) {\n      if (n.nodeType == Node.ELEMENT_NODE) {\n        return this.readFromNode(/** @type {Element} */ (n));\n      }\n    }\n    return null;\n  }\n\n  /**\n   * @abstract\n   * @param {Element} node Node.\n   * @return {Object|null} Object\n   */\n  readFromNode(node) {\n    abstract();\n  }\n}\n\nexport default XML;\n","/**\n * @module ol/format/xlink\n */\n\n/**\n * @const\n * @type {string}\n */\nconst NAMESPACE_URI = 'http://www.w3.org/1999/xlink';\n\n/**\n * @param {Element} node Node.\n * @return {string|null} href.\n */\nexport function readHref(node) {\n  return node.getAttributeNS(NAMESPACE_URI, 'href');\n}\n","/**\n * @module ol/format/OWS\n */\nimport {\n  makeObjectPropertyPusher,\n  makeObjectPropertySetter,\n  makeStructureNS,\n  pushParseAndPop,\n} from '../xml.js';\nimport XML from './XML.js';\nimport {readHref} from './xlink.js';\nimport {readString} from './xsd.js';\n\n/**\n * @const\n * @type {Array<null|string>}\n */\nconst NAMESPACE_URIS = [null, 'http://www.opengis.net/ows/1.1'];\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'ServiceIdentification': makeObjectPropertySetter(readServiceIdentification),\n  'ServiceProvider': makeObjectPropertySetter(readServiceProvider),\n  'OperationsMetadata': makeObjectPropertySetter(readOperationsMetadata),\n});\n\nclass OWS extends XML {\n  constructor() {\n    super();\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @return {Object|null} Object\n   * @override\n   */\n  readFromNode(node) {\n    const owsObject = pushParseAndPop({}, PARSERS, node, []);\n    return owsObject ? owsObject : null;\n  }\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst ADDRESS_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'DeliveryPoint': makeObjectPropertySetter(readString),\n  'City': makeObjectPropertySetter(readString),\n  'AdministrativeArea': makeObjectPropertySetter(readString),\n  'PostalCode': makeObjectPropertySetter(readString),\n  'Country': makeObjectPropertySetter(readString),\n  'ElectronicMailAddress': makeObjectPropertySetter(readString),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst ALLOWED_VALUES_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Value': makeObjectPropertyPusher(readValue),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst CONSTRAINT_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'AllowedValues': makeObjectPropertySetter(readAllowedValues),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst CONTACT_INFO_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Phone': makeObjectPropertySetter(readPhone),\n  'Address': makeObjectPropertySetter(readAddress),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst DCP_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'HTTP': makeObjectPropertySetter(readHttp),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst HTTP_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Get': makeObjectPropertyPusher(readGet),\n  'Post': undefined, // TODO\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst OPERATION_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'DCP': makeObjectPropertySetter(readDcp),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst OPERATIONS_METADATA_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Operation': readOperation,\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst PHONE_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Voice': makeObjectPropertySetter(readString),\n  'Facsimile': makeObjectPropertySetter(readString),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst REQUEST_METHOD_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Constraint': makeObjectPropertyPusher(readConstraint),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst SERVICE_CONTACT_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'IndividualName': makeObjectPropertySetter(readString),\n  'PositionName': makeObjectPropertySetter(readString),\n  'ContactInfo': makeObjectPropertySetter(readContactInfo),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst SERVICE_IDENTIFICATION_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Abstract': makeObjectPropertySetter(readString),\n  'AccessConstraints': makeObjectPropertySetter(readString),\n  'Fees': makeObjectPropertySetter(readString),\n  'Title': makeObjectPropertySetter(readString),\n  'ServiceTypeVersion': makeObjectPropertySetter(readString),\n  'ServiceType': makeObjectPropertySetter(readString),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst SERVICE_PROVIDER_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'ProviderName': makeObjectPropertySetter(readString),\n  'ProviderSite': makeObjectPropertySetter(readHref),\n  'ServiceContact': makeObjectPropertySetter(readServiceContact),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} The address.\n */\nfunction readAddress(node, objectStack) {\n  return pushParseAndPop({}, ADDRESS_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} The values.\n */\nfunction readAllowedValues(node, objectStack) {\n  return pushParseAndPop({}, ALLOWED_VALUES_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} The constraint.\n */\nfunction readConstraint(node, objectStack) {\n  const name = node.getAttribute('name');\n  if (!name) {\n    return undefined;\n  }\n  return pushParseAndPop({'name': name}, CONSTRAINT_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} The contact info.\n */\nfunction readContactInfo(node, objectStack) {\n  return pushParseAndPop({}, CONTACT_INFO_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} The DCP.\n */\nfunction readDcp(node, objectStack) {\n  return pushParseAndPop({}, DCP_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} The GET object.\n */\nfunction readGet(node, objectStack) {\n  const href = readHref(node);\n  if (!href) {\n    return undefined;\n  }\n  return pushParseAndPop(\n    {'href': href},\n    REQUEST_METHOD_PARSERS,\n    node,\n    objectStack,\n  );\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} The HTTP object.\n */\nfunction readHttp(node, objectStack) {\n  return pushParseAndPop({}, HTTP_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} The operation.\n */\nfunction readOperation(node, objectStack) {\n  const name = node.getAttribute('name');\n  const value = pushParseAndPop({}, OPERATION_PARSERS, node, objectStack);\n  if (!value) {\n    return undefined;\n  }\n  const object = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  object[name] = value;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} The operations metadata.\n */\nfunction readOperationsMetadata(node, objectStack) {\n  return pushParseAndPop({}, OPERATIONS_METADATA_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} The phone.\n */\nfunction readPhone(node, objectStack) {\n  return pushParseAndPop({}, PHONE_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} The service identification.\n */\nfunction readServiceIdentification(node, objectStack) {\n  return pushParseAndPop({}, SERVICE_IDENTIFICATION_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} The service contact.\n */\nfunction readServiceContact(node, objectStack) {\n  return pushParseAndPop({}, SERVICE_CONTACT_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} The service provider.\n */\nfunction readServiceProvider(node, objectStack) {\n  return pushParseAndPop({}, SERVICE_PROVIDER_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Node} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {string|undefined} The value.\n */\nfunction readValue(node, objectStack) {\n  return readString(node);\n}\n\nexport default OWS;\n","/**\n * @module ol/format/Polyline\n */\nimport Feature from '../Feature.js';\nimport LineString from '../geom/LineString.js';\nimport {getStrideForLayout} from '../geom/SimpleGeometry.js';\nimport {flipXY} from '../geom/flat/flip.js';\nimport {get as getProjection} from '../proj.js';\nimport {transformGeometryWithOptions} from './Feature.js';\nimport TextFeature from './TextFeature.js';\n\n/**\n * @typedef {Object} Options\n * @property {number} [factor=1e5] The factor by which the coordinates values will be scaled.\n * @property {import(\"../geom/Geometry.js\").GeometryLayout} [geometryLayout='XY'] Layout of the\n * feature geometries created by the format reader.\n */\n\n/**\n * @classdesc\n * Feature format for reading and writing data in the Encoded\n * Polyline Algorithm Format.\n *\n * When reading features, the coordinates are assumed to be in two dimensions\n * and in [latitude, longitude] order.\n *\n * As Polyline sources contain a single feature,\n * {@link module:ol/format/Polyline~Polyline#readFeatures} will return the\n * feature in an array.\n *\n * @api\n */\nclass Polyline extends TextFeature {\n  /**\n   * @param {Options} [options] Optional configuration object.\n   */\n  constructor(options) {\n    super();\n\n    options = options ? options : {};\n\n    /**\n     * @type {import(\"../proj/Projection.js\").default}\n     */\n    this.dataProjection = getProjection('EPSG:4326');\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.factor_ = options.factor ? options.factor : 1e5;\n\n    /**\n     * @private\n     * @type {import(\"../geom/Geometry.js\").GeometryLayout}\n     */\n    this.geometryLayout_ = options.geometryLayout\n      ? options.geometryLayout\n      : 'XY';\n  }\n\n  /**\n   * @protected\n   * @param {string} text Text.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @return {import(\"../Feature.js\").default} Feature.\n   * @override\n   */\n  readFeatureFromText(text, options) {\n    const geometry = this.readGeometryFromText(text, options);\n    return new Feature(geometry);\n  }\n\n  /**\n   * @param {string} text Text.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @protected\n   * @return {Array<Feature>} Features.\n   * @override\n   */\n  readFeaturesFromText(text, options) {\n    const feature = this.readFeatureFromText(text, options);\n    return [feature];\n  }\n\n  /**\n   * @param {string} text Text.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @protected\n   * @return {import(\"../geom/Geometry.js\").default} Geometry.\n   * @override\n   */\n  readGeometryFromText(text, options) {\n    const stride = getStrideForLayout(this.geometryLayout_);\n    const flatCoordinates = decodeDeltas(text, stride, this.factor_);\n    flipXY(flatCoordinates, 0, flatCoordinates.length, stride, flatCoordinates);\n    const lineString = new LineString(flatCoordinates, this.geometryLayout_);\n\n    return transformGeometryWithOptions(\n      lineString,\n      false,\n      this.adaptOptions(options),\n    );\n  }\n\n  /**\n   * @param {import(\"../Feature.js\").default<LineString>} feature Features.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n   * @protected\n   * @return {string} Text.\n   * @override\n   */\n  writeFeatureText(feature, options) {\n    const geometry = feature.getGeometry();\n    if (geometry) {\n      return this.writeGeometryText(geometry, options);\n    }\n    throw new Error('Expected `feature` to have a geometry');\n  }\n\n  /**\n   * @param {Array<import(\"../Feature.js\").default<LineString>>} features Features.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n   * @protected\n   * @return {string} Text.\n   * @override\n   */\n  writeFeaturesText(features, options) {\n    return this.writeFeatureText(features[0], options);\n  }\n\n  /**\n   * @param {LineString} geometry Geometry.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n   * @protected\n   * @return {string} Text.\n   * @override\n   */\n  writeGeometryText(geometry, options) {\n    geometry = /** @type {LineString} */ (\n      transformGeometryWithOptions(geometry, true, this.adaptOptions(options))\n    );\n    const flatCoordinates = geometry.getFlatCoordinates();\n    const stride = geometry.getStride();\n    flipXY(flatCoordinates, 0, flatCoordinates.length, stride, flatCoordinates);\n    return encodeDeltas(flatCoordinates, stride, this.factor_);\n  }\n}\n\n/**\n * Encode a list of n-dimensional points and return an encoded string\n *\n * Attention: This function will modify the passed array!\n *\n * @param {Array<number>} numbers A list of n-dimensional points.\n * @param {number} stride The number of dimension of the points in the list.\n * @param {number} [factor] The factor by which the numbers will be\n *     multiplied. The remaining decimal places will get rounded away.\n *     Default is `1e5`.\n * @return {string} The encoded string.\n * @api\n * @deprecated\n */\nexport function encodeDeltas(numbers, stride, factor) {\n  factor = factor ? factor : 1e5;\n\n  const lastNumbers = new Array(stride).fill(0);\n\n  for (let i = 0, ii = numbers.length; i < ii; ) {\n    for (let d = 0; d < stride; ++d, ++i) {\n      const value = numbers[i] * factor;\n      const num = value < 0 ? Math.ceil(value - 0.5) : Math.round(value);\n      const delta = num - lastNumbers[d];\n      lastNumbers[d] = num;\n\n      numbers[i] = delta;\n    }\n  }\n\n  return encodeSignedIntegers(numbers);\n}\n\n/**\n * Decode a list of n-dimensional points from an encoded string\n *\n * @param {string} encoded An encoded string.\n * @param {number} stride The number of dimension of the points in the\n *     encoded string.\n * @param {number} [factor] The factor by which the resulting numbers will\n *     be divided. Default is `1e5`.\n * @return {Array<number>} A list of n-dimensional points.\n * @api\n * @deprecated\n */\nexport function decodeDeltas(encoded, stride, factor) {\n  factor = factor ? factor : 1e5;\n\n  /** @type {Array<number>} */\n  const lastNumbers = new Array(stride).fill(0);\n  const numbers = decodeSignedIntegers(encoded);\n\n  for (let i = 0, ii = numbers.length; i < ii; ) {\n    for (let d = 0; d < stride; ++d, ++i) {\n      lastNumbers[d] += numbers[i];\n      numbers[i] = lastNumbers[d] / factor;\n    }\n  }\n\n  return numbers;\n}\n\n/**\n * Encode a list of floating point numbers and return an encoded string\n *\n * Attention: This function will modify the passed array!\n *\n * @param {Array<number>} numbers A list of floating point numbers.\n * @param {number} [factor] The factor by which the numbers will be\n *     multiplied. The remaining decimal places will get rounded away.\n *     Default is `1e5`.\n * @return {string} The encoded string.\n * @deprecated\n * @api\n */\nexport function encodeFloats(numbers, factor) {\n  factor = factor ? factor : 1e5;\n  for (let i = 0, ii = numbers.length; i < ii; ++i) {\n    numbers[i] = Math.round(numbers[i] * factor);\n  }\n\n  return encodeSignedIntegers(numbers);\n}\n\n/**\n * Decode a list of floating point numbers from an encoded string\n *\n * @param {string} encoded An encoded string.\n * @param {number} [factor] The factor by which the result will be divided.\n *     Default is `1e5`.\n * @return {Array<number>} A list of floating point numbers.\n * @deprecated\n * @api\n */\nexport function decodeFloats(encoded, factor) {\n  factor = factor ? factor : 1e5;\n  const numbers = decodeSignedIntegers(encoded);\n  for (let i = 0, ii = numbers.length; i < ii; ++i) {\n    numbers[i] /= factor;\n  }\n  return numbers;\n}\n\n/**\n * Encode a list of signed integers and return an encoded string\n *\n * Attention: This function will modify the passed array!\n *\n * @param {Array<number>} numbers A list of signed integers.\n * @return {string} The encoded string.\n */\nexport function encodeSignedIntegers(numbers) {\n  for (let i = 0, ii = numbers.length; i < ii; ++i) {\n    const num = numbers[i];\n    numbers[i] = num < 0 ? ~(num << 1) : num << 1;\n  }\n  return encodeUnsignedIntegers(numbers);\n}\n\n/**\n * Decode a list of signed integers from an encoded string\n *\n * @param {string} encoded An encoded string.\n * @return {Array<number>} A list of signed integers.\n */\nexport function decodeSignedIntegers(encoded) {\n  const numbers = decodeUnsignedIntegers(encoded);\n  for (let i = 0, ii = numbers.length; i < ii; ++i) {\n    const num = numbers[i];\n    numbers[i] = num & 1 ? ~(num >> 1) : num >> 1;\n  }\n  return numbers;\n}\n\n/**\n * Encode a list of unsigned integers and return an encoded string\n *\n * @param {Array<number>} numbers A list of unsigned integers.\n * @return {string} The encoded string.\n */\nexport function encodeUnsignedIntegers(numbers) {\n  let encoded = '';\n  for (let i = 0, ii = numbers.length; i < ii; ++i) {\n    encoded += encodeUnsignedInteger(numbers[i]);\n  }\n  return encoded;\n}\n\n/**\n * Decode a list of unsigned integers from an encoded string\n *\n * @param {string} encoded An encoded string.\n * @return {Array<number>} A list of unsigned integers.\n */\nexport function decodeUnsignedIntegers(encoded) {\n  const numbers = [];\n  let current = 0;\n  let shift = 0;\n  for (let i = 0, ii = encoded.length; i < ii; ++i) {\n    const b = encoded.charCodeAt(i) - 63;\n    current |= (b & 0x1f) << shift;\n    if (b < 0x20) {\n      numbers.push(current);\n      current = 0;\n      shift = 0;\n    } else {\n      shift += 5;\n    }\n  }\n  return numbers;\n}\n\n/**\n * Encode one single unsigned integer and return an encoded string\n *\n * @param {number} num Unsigned integer that should be encoded.\n * @return {string} The encoded string.\n */\nexport function encodeUnsignedInteger(num) {\n  let value,\n    encoded = '';\n  while (num >= 0x20) {\n    value = (0x20 | (num & 0x1f)) + 63;\n    encoded += String.fromCharCode(value);\n    num >>= 5;\n  }\n  value = num + 63;\n  encoded += String.fromCharCode(value);\n  return encoded;\n}\n\nexport default Polyline;\n","/**\n * @module ol/format/TopoJSON\n */\nimport Feature from '../Feature.js';\nimport LineString from '../geom/LineString.js';\nimport MultiLineString from '../geom/MultiLineString.js';\nimport MultiPoint from '../geom/MultiPoint.js';\nimport MultiPolygon from '../geom/MultiPolygon.js';\nimport Point from '../geom/Point.js';\nimport Polygon from '../geom/Polygon.js';\nimport {get as getProjection} from '../proj.js';\nimport {transformGeometryWithOptions} from './Feature.js';\nimport JSONFeature from './JSONFeature.js';\n\n/**\n * @typedef {import(\"topojson-specification\").Topology} TopoJSONTopology\n * @typedef {import(\"topojson-specification\").GeometryCollection} TopoJSONGeometryCollection\n * @typedef {import(\"topojson-specification\").GeometryObject} TopoJSONGeometry\n * @typedef {import(\"topojson-specification\").Point} TopoJSONPoint\n * @typedef {import(\"topojson-specification\").MultiPoint} TopoJSONMultiPoint\n * @typedef {import(\"topojson-specification\").LineString} TopoJSONLineString\n * @typedef {import(\"topojson-specification\").MultiLineString} TopoJSONMultiLineString\n * @typedef {import(\"topojson-specification\").Polygon} TopoJSONPolygon\n * @typedef {import(\"topojson-specification\").MultiPolygon} TopoJSONMultiPolygon\n */\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../proj.js\").ProjectionLike} [dataProjection='EPSG:4326'] Default data projection.\n * @property {string} [layerName] Set the name of the TopoJSON topology\n * `objects`'s children as feature property with the specified name. This means\n * that when set to `'layer'`, a topology like\n * ```\n * {\n *   \"type\": \"Topology\",\n *   \"objects\": {\n *     \"example\": {\n *       \"type\": \"GeometryCollection\",\n *       \"geometries\": []\n *     }\n *   }\n * }\n * ```\n * will result in features that have a property `'layer'` set to `'example'`.\n * When not set, no property will be added to features.\n * @property {Array<string>} [layers] Names of the TopoJSON topology's\n * `objects`'s children to read features from.  If not provided, features will\n * be read from all children.\n */\n\n/**\n * @classdesc\n * Feature format for reading data in the TopoJSON format.\n *\n * @api\n */\nclass TopoJSON extends JSONFeature {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    super();\n\n    options = options ? options : {};\n\n    /**\n     * @private\n     * @type {string|undefined}\n     */\n    this.layerName_ = options.layerName;\n\n    /**\n     * @private\n     * @type {?Array<string>}\n     */\n    this.layers_ = options.layers ? options.layers : null;\n\n    /**\n     * @type {import(\"../proj/Projection.js\").default}\n     */\n    this.dataProjection = getProjection(\n      options.dataProjection ? options.dataProjection : 'EPSG:4326',\n    );\n  }\n\n  /**\n   * @param {Object} object Object.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @protected\n   * @return {Array<Feature>} Features.\n   * @override\n   */\n  readFeaturesFromObject(object, options) {\n    if (object.type == 'Topology') {\n      const topoJSONTopology = /** @type {TopoJSONTopology} */ (object);\n      let transform,\n        scale = null,\n        translate = null;\n      if (topoJSONTopology['transform']) {\n        transform = topoJSONTopology['transform'];\n        scale = transform['scale'];\n        translate = transform['translate'];\n      }\n      const arcs = topoJSONTopology['arcs'];\n      if (transform) {\n        transformArcs(arcs, scale, translate);\n      }\n      /** @type {Array<Feature>} */\n      const features = [];\n      const topoJSONFeatures = topoJSONTopology['objects'];\n      const property = this.layerName_;\n      let feature;\n      for (const objectName in topoJSONFeatures) {\n        if (this.layers_ && !this.layers_.includes(objectName)) {\n          continue;\n        }\n        if (topoJSONFeatures[objectName].type === 'GeometryCollection') {\n          feature = /** @type {TopoJSONGeometryCollection} */ (\n            topoJSONFeatures[objectName]\n          );\n          features.push.apply(\n            features,\n            readFeaturesFromGeometryCollection(\n              feature,\n              arcs,\n              scale,\n              translate,\n              property,\n              objectName,\n              options,\n            ),\n          );\n        } else {\n          feature = /** @type {TopoJSONGeometry} */ (\n            topoJSONFeatures[objectName]\n          );\n          features.push(\n            readFeatureFromGeometry(\n              feature,\n              arcs,\n              scale,\n              translate,\n              property,\n              objectName,\n              options,\n            ),\n          );\n        }\n      }\n      return features;\n    }\n    return [];\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    return this.dataProjection;\n  }\n}\n\n/**\n * @const\n * @type {Object<string, function(TopoJSONGeometry, Array, ...Array=): import(\"../geom/Geometry.js\").default>}\n */\nconst GEOMETRY_READERS = {\n  'Point': readPointGeometry,\n  'LineString': readLineStringGeometry,\n  'Polygon': readPolygonGeometry,\n  'MultiPoint': readMultiPointGeometry,\n  'MultiLineString': readMultiLineStringGeometry,\n  'MultiPolygon': readMultiPolygonGeometry,\n};\n\n/**\n * Concatenate arcs into a coordinate array.\n * @param {Array<number>} indices Indices of arcs to concatenate.  Negative\n *     values indicate arcs need to be reversed.\n * @param {Array<Array<import(\"../coordinate.js\").Coordinate>>} arcs Array of arcs (already\n *     transformed).\n * @return {Array<import(\"../coordinate.js\").Coordinate>} Coordinates array.\n */\nfunction concatenateArcs(indices, arcs) {\n  /** @type {Array<import(\"../coordinate.js\").Coordinate>} */\n  const coordinates = [];\n  let index;\n  for (let i = 0, ii = indices.length; i < ii; ++i) {\n    index = indices[i];\n    if (i > 0) {\n      // splicing together arcs, discard last point\n      coordinates.pop();\n    }\n    if (index >= 0) {\n      // forward arc\n      const arc = arcs[index];\n      for (let j = 0, jj = arc.length; j < jj; ++j) {\n        coordinates.push(arc[j].slice(0));\n      }\n    } else {\n      // reverse arc\n      const arc = arcs[~index];\n      for (let j = arc.length - 1; j >= 0; --j) {\n        coordinates.push(arc[j].slice(0));\n      }\n    }\n  }\n  return coordinates;\n}\n\n/**\n * Create a point from a TopoJSON geometry object.\n *\n * @param {TopoJSONPoint} object TopoJSON object.\n * @param {Array<number>} scale Scale for each dimension.\n * @param {Array<number>} translate Translation for each dimension.\n * @return {Point} Geometry.\n */\nfunction readPointGeometry(object, scale, translate) {\n  const coordinates = object['coordinates'];\n  if (scale && translate) {\n    transformVertex(coordinates, scale, translate);\n  }\n  return new Point(coordinates);\n}\n\n/**\n * Create a multi-point from a TopoJSON geometry object.\n *\n * @param {TopoJSONMultiPoint} object TopoJSON object.\n * @param {Array<number>} scale Scale for each dimension.\n * @param {Array<number>} translate Translation for each dimension.\n * @return {MultiPoint} Geometry.\n */\nfunction readMultiPointGeometry(object, scale, translate) {\n  const coordinates = object['coordinates'];\n  if (scale && translate) {\n    for (let i = 0, ii = coordinates.length; i < ii; ++i) {\n      transformVertex(coordinates[i], scale, translate);\n    }\n  }\n  return new MultiPoint(coordinates);\n}\n\n/**\n * Create a linestring from a TopoJSON geometry object.\n *\n * @param {TopoJSONLineString} object TopoJSON object.\n * @param {Array<Array<import(\"../coordinate.js\").Coordinate>>} arcs Array of arcs.\n * @return {LineString} Geometry.\n */\nfunction readLineStringGeometry(object, arcs) {\n  const coordinates = concatenateArcs(object['arcs'], arcs);\n  return new LineString(coordinates);\n}\n\n/**\n * Create a multi-linestring from a TopoJSON geometry object.\n *\n * @param {TopoJSONMultiLineString} object TopoJSON object.\n * @param {Array<Array<import(\"../coordinate.js\").Coordinate>>} arcs Array of arcs.\n * @return {MultiLineString} Geometry.\n */\nfunction readMultiLineStringGeometry(object, arcs) {\n  const coordinates = [];\n  for (let i = 0, ii = object['arcs'].length; i < ii; ++i) {\n    coordinates[i] = concatenateArcs(object['arcs'][i], arcs);\n  }\n  return new MultiLineString(coordinates);\n}\n\n/**\n * Create a polygon from a TopoJSON geometry object.\n *\n * @param {TopoJSONPolygon} object TopoJSON object.\n * @param {Array<Array<import(\"../coordinate.js\").Coordinate>>} arcs Array of arcs.\n * @return {Polygon} Geometry.\n */\nfunction readPolygonGeometry(object, arcs) {\n  const coordinates = [];\n  for (let i = 0, ii = object['arcs'].length; i < ii; ++i) {\n    coordinates[i] = concatenateArcs(object['arcs'][i], arcs);\n  }\n  return new Polygon(coordinates);\n}\n\n/**\n * Create a multi-polygon from a TopoJSON geometry object.\n *\n * @param {TopoJSONMultiPolygon} object TopoJSON object.\n * @param {Array<Array<import(\"../coordinate.js\").Coordinate>>} arcs Array of arcs.\n * @return {MultiPolygon} Geometry.\n */\nfunction readMultiPolygonGeometry(object, arcs) {\n  const coordinates = [];\n  for (let i = 0, ii = object['arcs'].length; i < ii; ++i) {\n    // for each polygon\n    const polyArray = object['arcs'][i];\n    const ringCoords = [];\n    for (let j = 0, jj = polyArray.length; j < jj; ++j) {\n      // for each ring\n      ringCoords[j] = concatenateArcs(polyArray[j], arcs);\n    }\n    coordinates[i] = ringCoords;\n  }\n  return new MultiPolygon(coordinates);\n}\n\n/**\n * Create features from a TopoJSON GeometryCollection object.\n *\n * @param {TopoJSONGeometryCollection} collection TopoJSON Geometry\n *     object.\n * @param {Array<Array<import(\"../coordinate.js\").Coordinate>>} arcs Array of arcs.\n * @param {Array<number>} scale Scale for each dimension.\n * @param {Array<number>} translate Translation for each dimension.\n * @param {string|undefined} property Property to set the `GeometryCollection`'s parent\n *     object to.\n * @param {string} name Name of the `Topology`'s child object.\n * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n * @return {Array<Feature>} Array of features.\n */\nfunction readFeaturesFromGeometryCollection(\n  collection,\n  arcs,\n  scale,\n  translate,\n  property,\n  name,\n  options,\n) {\n  const geometries = collection['geometries'];\n  const features = [];\n  for (let i = 0, ii = geometries.length; i < ii; ++i) {\n    features[i] = readFeatureFromGeometry(\n      geometries[i],\n      arcs,\n      scale,\n      translate,\n      property,\n      name,\n      options,\n    );\n  }\n  return features;\n}\n\n/**\n * Create a feature from a TopoJSON geometry object.\n *\n * @param {TopoJSONGeometry} object TopoJSON geometry object.\n * @param {Array<Array<import(\"../coordinate.js\").Coordinate>>} arcs Array of arcs.\n * @param {Array<number>} scale Scale for each dimension.\n * @param {Array<number>} translate Translation for each dimension.\n * @param {string|undefined} property Property to set the `GeometryCollection`'s parent\n *     object to.\n * @param {string} name Name of the `Topology`'s child object.\n * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n * @return {Feature} Feature.\n */\nfunction readFeatureFromGeometry(\n  object,\n  arcs,\n  scale,\n  translate,\n  property,\n  name,\n  options,\n) {\n  let geometry = null;\n  const type = object.type;\n  if (type) {\n    const geometryReader = GEOMETRY_READERS[type];\n    if (type === 'Point' || type === 'MultiPoint') {\n      geometry = geometryReader(object, scale, translate);\n    } else {\n      geometry = geometryReader(object, arcs);\n    }\n    geometry = transformGeometryWithOptions(geometry, false, options);\n  }\n  const feature = new Feature({geometry: geometry});\n  if (object.id !== undefined) {\n    feature.setId(object.id);\n  }\n  let properties = object.properties;\n  if (property) {\n    if (!properties) {\n      properties = {};\n    }\n    properties[property] = name;\n  }\n  if (properties) {\n    feature.setProperties(properties, true);\n  }\n  return feature;\n}\n\n/**\n * Apply a linear transform to array of arcs.  The provided array of arcs is\n * modified in place.\n *\n * @param {Array<Array<import(\"../coordinate.js\").Coordinate>>} arcs Array of arcs.\n * @param {Array<number>} scale Scale for each dimension.\n * @param {Array<number>} translate Translation for each dimension.\n */\nfunction transformArcs(arcs, scale, translate) {\n  for (let i = 0, ii = arcs.length; i < ii; ++i) {\n    transformArc(arcs[i], scale, translate);\n  }\n}\n\n/**\n * Apply a linear transform to an arc.  The provided arc is modified in place.\n *\n * @param {Array<import(\"../coordinate.js\").Coordinate>} arc Arc.\n * @param {Array<number>} scale Scale for each dimension.\n * @param {Array<number>} translate Translation for each dimension.\n */\nfunction transformArc(arc, scale, translate) {\n  let x = 0;\n  let y = 0;\n  for (let i = 0, ii = arc.length; i < ii; ++i) {\n    const vertex = arc[i];\n    x += vertex[0];\n    y += vertex[1];\n    vertex[0] = x;\n    vertex[1] = y;\n    transformVertex(vertex, scale, translate);\n  }\n}\n\n/**\n * Apply a linear transform to a vertex.  The provided vertex is modified in\n * place.\n *\n * @param {import(\"../coordinate.js\").Coordinate} vertex Vertex.\n * @param {Array<number>} scale Scale for each dimension.\n * @param {Array<number>} translate Translation for each dimension.\n */\nfunction transformVertex(vertex, scale, translate) {\n  vertex[0] = vertex[0] * scale[0] + translate[0];\n  vertex[1] = vertex[1] * scale[1] + translate[1];\n}\n\nexport default TopoJSON;\n","/**\n * @module ol/format/GMLBase\n */\n// FIXME Envelopes should not be treated as geometries! readEnvelope_ is part\n// of GEOMETRY_PARSERS_ and methods using GEOMETRY_PARSERS_ do not expect\n// envelopes/extents, only geometries!\nimport Feature from '../Feature.js';\nimport {extend} from '../array.js';\nimport Geometry from '../geom/Geometry.js';\nimport LineString from '../geom/LineString.js';\nimport LinearRing from '../geom/LinearRing.js';\nimport MultiLineString from '../geom/MultiLineString.js';\nimport MultiPoint from '../geom/MultiPoint.js';\nimport MultiPolygon from '../geom/MultiPolygon.js';\nimport Point from '../geom/Point.js';\nimport Polygon from '../geom/Polygon.js';\nimport {get as getProjection} from '../proj.js';\nimport {\n  getAllTextContent,\n  getAttributeNS,\n  makeArrayPusher,\n  makeReplacer,\n  parseNode,\n  pushParseAndPop,\n} from '../xml.js';\nimport {\n  transformExtentWithOptions,\n  transformGeometryWithOptions,\n} from './Feature.js';\nimport XMLFeature from './XMLFeature.js';\n\n/**\n * @const\n * @type {string}\n */\nexport const GMLNS = 'http://www.opengis.net/gml';\n\n/**\n * A regular expression that matches if a string only contains whitespace\n * characters. It will e.g. match `''`, `' '`, `'\\n'` etc.\n *\n * @const\n * @type {RegExp}\n */\nconst ONLY_WHITESPACE_RE = /^\\s*$/;\n\n/**\n * @typedef {Object} Options\n * @property {Object<string, string>|string} [featureNS] Feature\n * namespace. If not defined will be derived from GML. If multiple\n * feature types have been configured which come from different feature\n * namespaces, this will be an object with the keys being the prefixes used\n * in the entries of featureType array. The values of the object will be the\n * feature namespaces themselves. So for instance there might be a featureType\n * item `topp:states` in the `featureType` array and then there will be a key\n * `topp` in the featureNS object with value `http://www.openplans.org/topp`.\n * @property {Array<string>|string} [featureType] Feature type(s) to parse.\n * If multiple feature types need to be configured\n * which come from different feature namespaces, `featureNS` will be an object\n * with the keys being the prefixes used in the entries of featureType array.\n * The values of the object will be the feature namespaces themselves.\n * So for instance there might be a featureType item `topp:states` and then\n * there will be a key named `topp` in the featureNS object with value\n * `http://www.openplans.org/topp`.\n * @property {string} [srsName] srsName to use when writing geometries.\n * @property {boolean} [surface=false] Write gml:Surface instead of gml:Polygon\n * elements. This also affects the elements in multi-part geometries.\n * @property {boolean} [curve=false] Write gml:Curve instead of gml:LineString\n * elements. This also affects the elements in multi-part geometries.\n * @property {boolean} [multiCurve=true] Write gml:MultiCurve instead of gml:MultiLineString.\n * Since the latter is deprecated in GML 3.\n * @property {boolean} [multiSurface=true] Write gml:multiSurface instead of\n * gml:MultiPolygon. Since the latter is deprecated in GML 3.\n * @property {string} [schemaLocation] Optional schemaLocation to use when\n * writing out the GML, this will override the default provided.\n * @property {boolean} [hasZ=false] If coordinates have a Z value.\n */\n\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * Feature base format for reading and writing data in the GML format.\n * This class cannot be instantiated, it contains only base content that\n * is shared with versioned format classes GML2 and GML3.\n *\n * @abstract\n * @api\n */\nclass GMLBase extends XMLFeature {\n  /**\n   * @param {Options} [options] Optional configuration object.\n   */\n  constructor(options) {\n    super();\n\n    options = options ? options : {};\n\n    /**\n     * @protected\n     * @type {Array<string>|string|undefined}\n     */\n    this.featureType = options.featureType;\n\n    /**\n     * @protected\n     * @type {Object<string, string>|string|undefined}\n     */\n    this.featureNS = options.featureNS;\n\n    /**\n     * @protected\n     * @type {string|undefined}\n     */\n    this.srsName = options.srsName;\n\n    /**\n     * @protected\n     * @type {string}\n     */\n    this.schemaLocation = '';\n\n    /**\n     * @type {Object<string, Object<string, Object>>}\n     */\n    this.FEATURE_COLLECTION_PARSERS = {};\n    this.FEATURE_COLLECTION_PARSERS[this.namespace] = {\n      'featureMember': makeArrayPusher(this.readFeaturesInternal),\n      'featureMembers': makeReplacer(this.readFeaturesInternal),\n    };\n\n    this.supportedMediaTypes = ['application/gml+xml'];\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Array<Feature> | undefined} Features.\n   */\n  readFeaturesInternal(node, objectStack) {\n    const localName = node.localName;\n    let features = null;\n    if (localName == 'FeatureCollection') {\n      features = pushParseAndPop(\n        [],\n        this.FEATURE_COLLECTION_PARSERS,\n        node,\n        objectStack,\n        this,\n      );\n    } else if (\n      localName == 'featureMembers' ||\n      localName == 'featureMember' ||\n      localName == 'member'\n    ) {\n      const context = objectStack[0];\n      let featureType = context['featureType'];\n      let featureNS = context['featureNS'];\n      const prefix = 'p';\n      const defaultPrefix = 'p0';\n      if (!featureType && node.childNodes) {\n        (featureType = []), (featureNS = {});\n        for (let i = 0, ii = node.childNodes.length; i < ii; ++i) {\n          const child = /** @type {Element} */ (node.childNodes[i]);\n          if (child.nodeType === 1) {\n            const ft = child.nodeName.split(':').pop();\n            if (!featureType.includes(ft)) {\n              let key = '';\n              let count = 0;\n              const uri = child.namespaceURI;\n              for (const candidate in featureNS) {\n                if (featureNS[candidate] === uri) {\n                  key = candidate;\n                  break;\n                }\n                ++count;\n              }\n              if (!key) {\n                key = prefix + count;\n                featureNS[key] = uri;\n              }\n              featureType.push(key + ':' + ft);\n            }\n          }\n        }\n        if (localName != 'featureMember') {\n          // recheck featureType for each featureMember\n          context['featureType'] = featureType;\n          context['featureNS'] = featureNS;\n        }\n      }\n      if (typeof featureNS === 'string') {\n        const ns = featureNS;\n        featureNS = {};\n        featureNS[defaultPrefix] = ns;\n      }\n      /** @type {Object<string, Object<string, import(\"../xml.js\").Parser>>} */\n      const parsersNS = {};\n      const featureTypes = Array.isArray(featureType)\n        ? featureType\n        : [featureType];\n      for (const p in featureNS) {\n        /** @type {Object<string, import(\"../xml.js\").Parser>} */\n        const parsers = {};\n        for (let i = 0, ii = featureTypes.length; i < ii; ++i) {\n          const featurePrefix = featureTypes[i].includes(':')\n            ? featureTypes[i].split(':')[0]\n            : defaultPrefix;\n          if (featurePrefix === p) {\n            parsers[featureTypes[i].split(':').pop()] =\n              localName == 'featureMembers'\n                ? makeArrayPusher(this.readFeatureElement, this)\n                : makeReplacer(this.readFeatureElement, this);\n          }\n        }\n        parsersNS[featureNS[p]] = parsers;\n      }\n      if (localName == 'featureMember' || localName == 'member') {\n        features = pushParseAndPop(undefined, parsersNS, node, objectStack);\n      } else {\n        features = pushParseAndPop([], parsersNS, node, objectStack);\n      }\n    }\n    if (features === null) {\n      features = [];\n    }\n    return features;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {import(\"../geom/Geometry.js\").default|import(\"../extent.js\").Extent|undefined} Geometry.\n   */\n  readGeometryOrExtent(node, objectStack) {\n    const context = /** @type {Object} */ (objectStack[0]);\n    context['srsName'] = node.firstElementChild.getAttribute('srsName');\n    context['srsDimension'] =\n      node.firstElementChild.getAttribute('srsDimension');\n    return pushParseAndPop(\n      null,\n      this.GEOMETRY_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {import(\"../extent.js\").Extent|undefined} Geometry.\n   */\n  readExtentElement(node, objectStack) {\n    const context = /** @type {Object} */ (objectStack[0]);\n    const extent = /** @type {import(\"../extent.js\").Extent} */ (\n      this.readGeometryOrExtent(node, objectStack)\n    );\n    return extent ? transformExtentWithOptions(extent, context) : undefined;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {import(\"../geom/Geometry.js\").default|undefined} Geometry.\n   */\n  readGeometryElement(node, objectStack) {\n    const context = /** @type {Object} */ (objectStack[0]);\n    const geometry = /** @type {import(\"../geom/Geometry.js\").default} */ (\n      this.readGeometryOrExtent(node, objectStack)\n    );\n    return geometry\n      ? transformGeometryWithOptions(geometry, false, context)\n      : undefined;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @param {boolean} asFeature whether result should be wrapped as a feature.\n   * @return {Feature|Object} Feature\n   */\n  readFeatureElementInternal(node, objectStack, asFeature) {\n    let geometryName;\n    const values = {};\n    for (let n = node.firstElementChild; n; n = n.nextElementSibling) {\n      let value;\n      const localName = n.localName;\n      // first, check if it is simple attribute\n      if (\n        n.childNodes.length === 0 ||\n        (n.childNodes.length === 1 &&\n          (n.firstChild.nodeType === 3 || n.firstChild.nodeType === 4))\n      ) {\n        value = getAllTextContent(n, false);\n        if (ONLY_WHITESPACE_RE.test(value)) {\n          value = undefined;\n        }\n      } else {\n        if (asFeature) {\n          //if feature, try it as a geometry or extent\n          value =\n            localName === 'boundedBy'\n              ? this.readExtentElement(n, objectStack)\n              : this.readGeometryElement(n, objectStack);\n        }\n        if (!value) {\n          //if not a geometry or not a feature, treat it as a complex attribute\n          value = this.readFeatureElementInternal(n, objectStack, false);\n        } else if (localName !== 'boundedBy') {\n          // boundedBy is an extent and must not be considered as a geometry\n          geometryName = localName;\n        }\n      }\n\n      const len = n.attributes.length;\n      if (len > 0 && !(value instanceof Geometry)) {\n        value = {_content_: value};\n        for (let i = 0; i < len; i++) {\n          const attName = n.attributes[i].name;\n          value[attName] = n.attributes[i].value;\n        }\n      }\n\n      if (values[localName]) {\n        if (!(values[localName] instanceof Array)) {\n          values[localName] = [values[localName]];\n        }\n        values[localName].push(value);\n      } else {\n        values[localName] = value;\n      }\n    }\n    if (!asFeature) {\n      return values;\n    }\n    const feature = new Feature(values);\n    if (geometryName) {\n      feature.setGeometryName(geometryName);\n    }\n    const fid =\n      node.getAttribute('fid') || getAttributeNS(node, this.namespace, 'id');\n    if (fid) {\n      feature.setId(fid);\n    }\n    return feature;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Feature} Feature.\n   */\n  readFeatureElement(node, objectStack) {\n    return this.readFeatureElementInternal(node, objectStack, true);\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Point|undefined} Point.\n   */\n  readPoint(node, objectStack) {\n    const flatCoordinates = this.readFlatCoordinatesFromNode(node, objectStack);\n    if (flatCoordinates) {\n      return new Point(flatCoordinates, 'XYZ');\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {MultiPoint|undefined} MultiPoint.\n   */\n  readMultiPoint(node, objectStack) {\n    /** @type {Array<Array<number>>} */\n    const coordinates = pushParseAndPop(\n      [],\n      this.MULTIPOINT_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    if (coordinates) {\n      return new MultiPoint(coordinates);\n    }\n    return undefined;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {MultiLineString|undefined} MultiLineString.\n   */\n  readMultiLineString(node, objectStack) {\n    /** @type {Array<LineString>} */\n    const lineStrings = pushParseAndPop(\n      [],\n      this.MULTILINESTRING_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    if (lineStrings) {\n      return new MultiLineString(lineStrings);\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {MultiPolygon|undefined} MultiPolygon.\n   */\n  readMultiPolygon(node, objectStack) {\n    /** @type {Array<Polygon>} */\n    const polygons = pushParseAndPop(\n      [],\n      this.MULTIPOLYGON_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    if (polygons) {\n      return new MultiPolygon(polygons);\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   */\n  pointMemberParser(node, objectStack) {\n    parseNode(this.POINTMEMBER_PARSERS, node, objectStack, this);\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   */\n  lineStringMemberParser(node, objectStack) {\n    parseNode(this.LINESTRINGMEMBER_PARSERS, node, objectStack, this);\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   */\n  polygonMemberParser(node, objectStack) {\n    parseNode(this.POLYGONMEMBER_PARSERS, node, objectStack, this);\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {LineString|undefined} LineString.\n   */\n  readLineString(node, objectStack) {\n    const flatCoordinates = this.readFlatCoordinatesFromNode(node, objectStack);\n    if (flatCoordinates) {\n      const lineString = new LineString(flatCoordinates, 'XYZ');\n      return lineString;\n    }\n    return undefined;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Array<number>|undefined} LinearRing flat coordinates.\n   */\n  readFlatLinearRing(node, objectStack) {\n    const ring = pushParseAndPop(\n      null,\n      this.GEOMETRY_FLAT_COORDINATES_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    if (ring) {\n      return ring;\n    }\n    return undefined;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {LinearRing|undefined} LinearRing.\n   */\n  readLinearRing(node, objectStack) {\n    const flatCoordinates = this.readFlatCoordinatesFromNode(node, objectStack);\n    if (flatCoordinates) {\n      return new LinearRing(flatCoordinates, 'XYZ');\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Polygon|undefined} Polygon.\n   */\n  readPolygon(node, objectStack) {\n    /** @type {Array<Array<number>>} */\n    const flatLinearRings = pushParseAndPop(\n      [null],\n      this.FLAT_LINEAR_RINGS_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    if (flatLinearRings && flatLinearRings[0]) {\n      const flatCoordinates = flatLinearRings[0];\n      const ends = [flatCoordinates.length];\n      let i, ii;\n      for (i = 1, ii = flatLinearRings.length; i < ii; ++i) {\n        extend(flatCoordinates, flatLinearRings[i]);\n        ends.push(flatCoordinates.length);\n      }\n      return new Polygon(flatCoordinates, 'XYZ', ends);\n    }\n    return undefined;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Array<number>} Flat coordinates.\n   */\n  readFlatCoordinatesFromNode(node, objectStack) {\n    return pushParseAndPop(\n      null,\n      this.GEOMETRY_FLAT_COORDINATES_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @protected\n   * @return {import(\"../geom/Geometry.js\").default} Geometry.\n   * @override\n   */\n  readGeometryFromNode(node, options) {\n    const geometry = this.readGeometryElement(node, [\n      this.getReadOptions(node, options ? options : {}),\n    ]);\n    return geometry ? geometry : null;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @return {Array<import(\"../Feature.js\").default>} Features.\n   * @override\n   */\n  readFeaturesFromNode(node, options) {\n    const internalOptions = {\n      featureType: this.featureType,\n      featureNS: this.featureNS,\n    };\n    if (internalOptions) {\n      Object.assign(internalOptions, this.getReadOptions(node, options));\n    }\n    const features = this.readFeaturesInternal(node, [internalOptions]);\n    return features || [];\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @return {import(\"../proj/Projection.js\").default} Projection.\n   * @override\n   */\n  readProjectionFromNode(node) {\n    return getProjection(\n      this.srsName\n        ? this.srsName\n        : node.firstElementChild.getAttribute('srsName'),\n    );\n  }\n}\n\nGMLBase.prototype.namespace = GMLNS;\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGMLBase.prototype.FLAT_LINEAR_RINGS_PARSERS = {\n  'http://www.opengis.net/gml': {},\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGMLBase.prototype.GEOMETRY_FLAT_COORDINATES_PARSERS = {\n  'http://www.opengis.net/gml': {},\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGMLBase.prototype.GEOMETRY_PARSERS = {\n  'http://www.opengis.net/gml': {},\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGMLBase.prototype.MULTIPOINT_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'pointMember': makeArrayPusher(GMLBase.prototype.pointMemberParser),\n    'pointMembers': makeArrayPusher(GMLBase.prototype.pointMemberParser),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGMLBase.prototype.MULTILINESTRING_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'lineStringMember': makeArrayPusher(\n      GMLBase.prototype.lineStringMemberParser,\n    ),\n    'lineStringMembers': makeArrayPusher(\n      GMLBase.prototype.lineStringMemberParser,\n    ),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGMLBase.prototype.MULTIPOLYGON_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'polygonMember': makeArrayPusher(GMLBase.prototype.polygonMemberParser),\n    'polygonMembers': makeArrayPusher(GMLBase.prototype.polygonMemberParser),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGMLBase.prototype.POINTMEMBER_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'Point': makeArrayPusher(GMLBase.prototype.readFlatCoordinatesFromNode),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGMLBase.prototype.LINESTRINGMEMBER_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'LineString': makeArrayPusher(GMLBase.prototype.readLineString),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGMLBase.prototype.POLYGONMEMBER_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'Polygon': makeArrayPusher(GMLBase.prototype.readPolygon),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGMLBase.prototype.RING_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'LinearRing': makeReplacer(GMLBase.prototype.readFlatLinearRing),\n  },\n};\n\nexport default GMLBase;\n","/**\n * @module ol/format/GML2\n */\nimport {createOrUpdate} from '../extent.js';\nimport {get as getProjection} from '../proj.js';\nimport {\n  OBJECT_PROPERTY_NODE_FACTORY,\n  createElementNS,\n  getAllTextContent,\n  makeArrayPusher,\n  makeChildAppender,\n  makeReplacer,\n  makeSimpleNodeFactory,\n  pushParseAndPop,\n  pushSerializeAndPop,\n} from '../xml.js';\nimport {\n  transformExtentWithOptions,\n  transformGeometryWithOptions,\n} from './Feature.js';\nimport GMLBase, {GMLNS} from './GMLBase.js';\nimport {writeStringTextNode} from './xsd.js';\n\n/**\n * @const\n * @type {string}\n */\nconst schemaLocation =\n  GMLNS + ' http://schemas.opengis.net/gml/2.1.2/feature.xsd';\n\n/**\n * @const\n * @type {Object<string, string>}\n */\nconst MULTIGEOMETRY_TO_MEMBER_NODENAME = {\n  'MultiLineString': 'lineStringMember',\n  'MultiCurve': 'curveMember',\n  'MultiPolygon': 'polygonMember',\n  'MultiSurface': 'surfaceMember',\n};\n\n/**\n * @classdesc\n * Feature format for reading and writing data in the GML format,\n * version 2.1.2.\n *\n * @api\n */\nclass GML2 extends GMLBase {\n  /**\n   * @param {import(\"./GMLBase.js\").Options} [options] Optional configuration object.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super(options);\n\n    this.FEATURE_COLLECTION_PARSERS[GMLNS]['featureMember'] = makeArrayPusher(\n      this.readFeaturesInternal,\n    );\n\n    /**\n     * @type {string}\n     */\n    this.schemaLocation = options.schemaLocation\n      ? options.schemaLocation\n      : schemaLocation;\n  }\n\n  /**\n   * @param {Node} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Array<number>|undefined} Flat coordinates.\n   */\n  readFlatCoordinates(node, objectStack) {\n    const s = getAllTextContent(node, false).replace(/^\\s*|\\s*$/g, '');\n    const context = /** @type {import(\"../xml.js\").NodeStackItem} */ (\n      objectStack[0]\n    );\n    const containerSrs = context['srsName'];\n    let axisOrientation = 'enu';\n    if (containerSrs) {\n      const proj = getProjection(containerSrs);\n      if (proj) {\n        axisOrientation = proj.getAxisOrientation();\n      }\n    }\n    const coordsGroups = s.trim().split(/\\s+/);\n    const flatCoordinates = [];\n    for (let i = 0, ii = coordsGroups.length; i < ii; i++) {\n      const coords = coordsGroups[i].split(/,+/);\n      const x = parseFloat(coords[0]);\n      const y = parseFloat(coords[1]);\n      const z = coords.length === 3 ? parseFloat(coords[2]) : 0;\n      if (axisOrientation.startsWith('en')) {\n        flatCoordinates.push(x, y, z);\n      } else {\n        flatCoordinates.push(y, x, z);\n      }\n    }\n    return flatCoordinates;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {import(\"../extent.js\").Extent|undefined} Envelope.\n   */\n  readBox(node, objectStack) {\n    /** @type {Array<number>} */\n    const flatCoordinates = pushParseAndPop(\n      [null],\n      this.BOX_PARSERS_,\n      node,\n      objectStack,\n      this,\n    );\n    return createOrUpdate(\n      flatCoordinates[1][0],\n      flatCoordinates[1][1],\n      flatCoordinates[1][3],\n      flatCoordinates[1][4],\n    );\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   */\n  innerBoundaryIsParser(node, objectStack) {\n    /** @type {Array<number>|undefined} */\n    const flatLinearRing = pushParseAndPop(\n      undefined,\n      this.RING_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    if (flatLinearRing) {\n      const flatLinearRings =\n        /** @type {Array<Array<number>>} */\n        (objectStack[objectStack.length - 1]);\n      flatLinearRings.push(flatLinearRing);\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   */\n  outerBoundaryIsParser(node, objectStack) {\n    /** @type {Array<number>|undefined} */\n    const flatLinearRing = pushParseAndPop(\n      undefined,\n      this.RING_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    if (flatLinearRing) {\n      const flatLinearRings =\n        /** @type {Array<Array<number>>} */\n        (objectStack[objectStack.length - 1]);\n      flatLinearRings[0] = flatLinearRing;\n    }\n  }\n\n  /**\n   * @const\n   * @param {*} value Value.\n   * @param {Array<*>} objectStack Object stack.\n   * @param {string} [nodeName] Node name.\n   * @return {Element|undefined} Node.\n   * @private\n   */\n  GEOMETRY_NODE_FACTORY_(value, objectStack, nodeName) {\n    const context = objectStack[objectStack.length - 1];\n    const multiSurface = context['multiSurface'];\n    const surface = context['surface'];\n    const multiCurve = context['multiCurve'];\n    if (!Array.isArray(value)) {\n      nodeName = /** @type {import(\"../geom/Geometry.js\").default} */ (\n        value\n      ).getType();\n      if (nodeName === 'MultiPolygon' && multiSurface === true) {\n        nodeName = 'MultiSurface';\n      } else if (nodeName === 'Polygon' && surface === true) {\n        nodeName = 'Surface';\n      } else if (nodeName === 'MultiLineString' && multiCurve === true) {\n        nodeName = 'MultiCurve';\n      }\n    } else {\n      nodeName = 'Envelope';\n    }\n    return createElementNS('http://www.opengis.net/gml', nodeName);\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../Feature.js\").default} feature Feature.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeFeatureElement(node, feature, objectStack) {\n    const fid = feature.getId();\n    if (fid) {\n      node.setAttribute('fid', /** @type {string} */ (fid));\n    }\n    const context = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n    const featureNS = context['featureNS'];\n    const geometryName = feature.getGeometryName();\n    if (!context.serializers) {\n      context.serializers = {};\n      context.serializers[featureNS] = {};\n    }\n    const keys = [];\n    const values = [];\n    if (feature.hasProperties()) {\n      const properties = feature.getProperties();\n      for (const key in properties) {\n        const value = properties[key];\n        if (value !== null && value !== undefined) {\n          keys.push(key);\n          values.push(value);\n          if (\n            key == geometryName ||\n            typeof (/** @type {?} */ (value).getSimplifiedGeometry) ===\n              'function'\n          ) {\n            if (!(key in context.serializers[featureNS])) {\n              context.serializers[featureNS][key] = makeChildAppender(\n                this.writeGeometryElement,\n                this,\n              );\n            }\n          } else {\n            if (!(key in context.serializers[featureNS])) {\n              context.serializers[featureNS][key] =\n                makeChildAppender(writeStringTextNode);\n            }\n          }\n        }\n      }\n    }\n    const item = Object.assign({}, context);\n    item.node = node;\n    pushSerializeAndPop(\n      /** @type {import(\"../xml.js\").NodeStackItem} */\n      (item),\n      context.serializers,\n      makeSimpleNodeFactory(undefined, featureNS),\n      values,\n      objectStack,\n      keys,\n    );\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/LineString.js\").default} geometry LineString geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeCurveOrLineString(node, geometry, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const srsName = context['srsName'];\n    if (node.nodeName !== 'LineStringSegment' && srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    if (\n      node.nodeName === 'LineString' ||\n      node.nodeName === 'LineStringSegment'\n    ) {\n      const coordinates = this.createCoordinatesNode_(node.namespaceURI);\n      node.appendChild(coordinates);\n      this.writeCoordinates_(coordinates, geometry, objectStack);\n    } else if (node.nodeName === 'Curve') {\n      const segments = createElementNS(node.namespaceURI, 'segments');\n      node.appendChild(segments);\n      this.writeCurveSegments_(segments, geometry, objectStack);\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/LineString.js\").default} line LineString geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeLineStringOrCurveMember(node, line, objectStack) {\n    const child = this.GEOMETRY_NODE_FACTORY_(line, objectStack);\n    if (child) {\n      node.appendChild(child);\n      this.writeCurveOrLineString(child, line, objectStack);\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/MultiLineString.js\").default} geometry MultiLineString geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeMultiCurveOrLineString(node, geometry, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const hasZ = context['hasZ'];\n    const srsName = context['srsName'];\n    const curve = context['curve'];\n    if (srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    const lines = geometry.getLineStrings();\n    pushSerializeAndPop(\n      {node: node, hasZ: hasZ, srsName: srsName, curve: curve},\n      this.LINESTRINGORCURVEMEMBER_SERIALIZERS,\n      this.MULTIGEOMETRY_MEMBER_NODE_FACTORY_,\n      lines,\n      objectStack,\n      undefined,\n      this,\n    );\n  }\n\n  /**\n   * @param {Node} node Node.\n   * @param {import(\"../geom/Geometry.js\").default|import(\"../extent.js\").Extent} geometry Geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeGeometryElement(node, geometry, objectStack) {\n    const context = /** @type {import(\"./Feature.js\").WriteOptions} */ (\n      objectStack[objectStack.length - 1]\n    );\n    const item = Object.assign({}, context);\n    item['node'] = node;\n    let value;\n    if (Array.isArray(geometry)) {\n      value = transformExtentWithOptions(\n        /** @type {import(\"../extent.js\").Extent} */ (geometry),\n        context,\n      );\n    } else {\n      value = transformGeometryWithOptions(\n        /** @type {import(\"../geom/Geometry.js\").default} */ (geometry),\n        true,\n        context,\n      );\n    }\n    pushSerializeAndPop(\n      /** @type {import(\"../xml.js\").NodeStackItem} */\n      (item),\n      this.GEOMETRY_SERIALIZERS,\n      this.GEOMETRY_NODE_FACTORY_,\n      [value],\n      objectStack,\n      undefined,\n      this,\n    );\n  }\n\n  /**\n   * @param {string} namespaceURI XML namespace.\n   * @return {Element} coordinates node.\n   * @private\n   */\n  createCoordinatesNode_(namespaceURI) {\n    const coordinates = createElementNS(namespaceURI, 'coordinates');\n    coordinates.setAttribute('decimal', '.');\n    coordinates.setAttribute('cs', ',');\n    coordinates.setAttribute('ts', ' ');\n\n    return coordinates;\n  }\n\n  /**\n   * @param {Node} node Node.\n   * @param {import(\"../geom/LineString.js\").default|import(\"../geom/LinearRing.js\").default} value Geometry.\n   * @param {Array<*>} objectStack Node stack.\n   * @private\n   */\n  writeCoordinates_(node, value, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const hasZ = context['hasZ'];\n    const srsName = context['srsName'];\n    // only 2d for simple features profile\n    const points = value.getCoordinates();\n    const len = points.length;\n    const parts = new Array(len);\n    for (let i = 0; i < len; ++i) {\n      const point = points[i];\n      parts[i] = this.getCoords_(point, srsName, hasZ);\n    }\n    writeStringTextNode(node, parts.join(' '));\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/LineString.js\").default} line LineString geometry.\n   * @param {Array<*>} objectStack Node stack.\n   * @private\n   */\n  writeCurveSegments_(node, line, objectStack) {\n    const child = createElementNS(node.namespaceURI, 'LineStringSegment');\n    node.appendChild(child);\n    this.writeCurveOrLineString(child, line, objectStack);\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/Polygon.js\").default} geometry Polygon geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeSurfaceOrPolygon(node, geometry, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const hasZ = context['hasZ'];\n    const srsName = context['srsName'];\n    if (node.nodeName !== 'PolygonPatch' && srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    if (node.nodeName === 'Polygon' || node.nodeName === 'PolygonPatch') {\n      const rings = geometry.getLinearRings();\n      pushSerializeAndPop(\n        {node: node, hasZ: hasZ, srsName: srsName},\n        this.RING_SERIALIZERS,\n        this.RING_NODE_FACTORY_,\n        rings,\n        objectStack,\n        undefined,\n        this,\n      );\n    } else if (node.nodeName === 'Surface') {\n      const patches = createElementNS(node.namespaceURI, 'patches');\n      node.appendChild(patches);\n      this.writeSurfacePatches_(patches, geometry, objectStack);\n    }\n  }\n\n  /**\n   * @param {*} value Value.\n   * @param {Array<*>} objectStack Object stack.\n   * @param {string} [nodeName] Node name.\n   * @return {Node} Node.\n   * @private\n   */\n  RING_NODE_FACTORY_(value, objectStack, nodeName) {\n    const context = objectStack[objectStack.length - 1];\n    const parentNode = context.node;\n    const exteriorWritten = context['exteriorWritten'];\n    if (exteriorWritten === undefined) {\n      context['exteriorWritten'] = true;\n    }\n    return createElementNS(\n      parentNode.namespaceURI,\n      exteriorWritten !== undefined ? 'innerBoundaryIs' : 'outerBoundaryIs',\n    );\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/Polygon.js\").default} polygon Polygon geometry.\n   * @param {Array<*>} objectStack Node stack.\n   * @private\n   */\n  writeSurfacePatches_(node, polygon, objectStack) {\n    const child = createElementNS(node.namespaceURI, 'PolygonPatch');\n    node.appendChild(child);\n    this.writeSurfaceOrPolygon(child, polygon, objectStack);\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/LinearRing.js\").default} ring LinearRing geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeRing(node, ring, objectStack) {\n    const linearRing = createElementNS(node.namespaceURI, 'LinearRing');\n    node.appendChild(linearRing);\n    this.writeLinearRing(linearRing, ring, objectStack);\n  }\n\n  /**\n   * @param {Array<number>} point Point geometry.\n   * @param {string} [srsName] Optional srsName\n   * @param {boolean} [hasZ] whether the geometry has a Z coordinate (is 3D) or not.\n   * @return {string} The coords string.\n   * @private\n   */\n  getCoords_(point, srsName, hasZ) {\n    const axisOrientation = srsName\n      ? getProjection(srsName).getAxisOrientation()\n      : 'enu';\n    let coords = axisOrientation.startsWith('en')\n      ? point[0] + ',' + point[1]\n      : point[1] + ',' + point[0];\n    if (hasZ) {\n      // For newly created points, Z can be undefined.\n      const z = point[2] || 0;\n      coords += ',' + z;\n    }\n\n    return coords;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/Point.js\").default} geometry Point geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writePoint(node, geometry, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const hasZ = context['hasZ'];\n    const srsName = context['srsName'];\n    if (srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    const coordinates = this.createCoordinatesNode_(node.namespaceURI);\n    node.appendChild(coordinates);\n    const point = geometry.getCoordinates();\n    const coord = this.getCoords_(point, srsName, hasZ);\n    writeStringTextNode(coordinates, coord);\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/MultiPoint.js\").default} geometry MultiPoint geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeMultiPoint(node, geometry, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const hasZ = context['hasZ'];\n    const srsName = context['srsName'];\n    if (srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    const points = geometry.getPoints();\n    pushSerializeAndPop(\n      {node: node, hasZ: hasZ, srsName: srsName},\n      this.POINTMEMBER_SERIALIZERS,\n      makeSimpleNodeFactory('pointMember'),\n      points,\n      objectStack,\n      undefined,\n      this,\n    );\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/Point.js\").default} point Point geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writePointMember(node, point, objectStack) {\n    const child = createElementNS(node.namespaceURI, 'Point');\n    node.appendChild(child);\n    this.writePoint(child, point, objectStack);\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/LinearRing.js\").default} geometry LinearRing geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeLinearRing(node, geometry, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const srsName = context['srsName'];\n    if (srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    const coordinates = this.createCoordinatesNode_(node.namespaceURI);\n    node.appendChild(coordinates);\n    this.writeCoordinates_(coordinates, geometry, objectStack);\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/MultiPolygon.js\").default} geometry MultiPolygon geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeMultiSurfaceOrPolygon(node, geometry, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const hasZ = context['hasZ'];\n    const srsName = context['srsName'];\n    const surface = context['surface'];\n    if (srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    const polygons = geometry.getPolygons();\n    pushSerializeAndPop(\n      {node: node, hasZ: hasZ, srsName: srsName, surface: surface},\n      this.SURFACEORPOLYGONMEMBER_SERIALIZERS,\n      this.MULTIGEOMETRY_MEMBER_NODE_FACTORY_,\n      polygons,\n      objectStack,\n      undefined,\n      this,\n    );\n  }\n\n  /**\n   * @param {Node} node Node.\n   * @param {import(\"../geom/Polygon.js\").default} polygon Polygon geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeSurfaceOrPolygonMember(node, polygon, objectStack) {\n    const child = this.GEOMETRY_NODE_FACTORY_(polygon, objectStack);\n    if (child) {\n      node.appendChild(child);\n      this.writeSurfaceOrPolygon(child, polygon, objectStack);\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeEnvelope(node, extent, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const srsName = context['srsName'];\n    if (srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    const keys = ['lowerCorner', 'upperCorner'];\n    const values = [extent[0] + ' ' + extent[1], extent[2] + ' ' + extent[3]];\n    pushSerializeAndPop(\n      /** @type {import(\"../xml.js\").NodeStackItem} */\n      ({node: node}),\n      this.ENVELOPE_SERIALIZERS,\n      OBJECT_PROPERTY_NODE_FACTORY,\n      values,\n      objectStack,\n      keys,\n      this,\n    );\n  }\n\n  /**\n   * @const\n   * @param {*} value Value.\n   * @param {Array<*>} objectStack Object stack.\n   * @param {string} [nodeName] Node name.\n   * @return {Node|undefined} Node.\n   * @private\n   */\n  MULTIGEOMETRY_MEMBER_NODE_FACTORY_(value, objectStack, nodeName) {\n    const parentNode = objectStack[objectStack.length - 1].node;\n    return createElementNS(\n      'http://www.opengis.net/gml',\n      MULTIGEOMETRY_TO_MEMBER_NODENAME[parentNode.nodeName],\n    );\n  }\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML2.prototype.GEOMETRY_FLAT_COORDINATES_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'coordinates': makeReplacer(GML2.prototype.readFlatCoordinates),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML2.prototype.FLAT_LINEAR_RINGS_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'innerBoundaryIs': GML2.prototype.innerBoundaryIsParser,\n    'outerBoundaryIs': GML2.prototype.outerBoundaryIsParser,\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML2.prototype.BOX_PARSERS_ = {\n  'http://www.opengis.net/gml': {\n    'coordinates': makeArrayPusher(GML2.prototype.readFlatCoordinates),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML2.prototype.GEOMETRY_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'Point': makeReplacer(GMLBase.prototype.readPoint),\n    'MultiPoint': makeReplacer(GMLBase.prototype.readMultiPoint),\n    'LineString': makeReplacer(GMLBase.prototype.readLineString),\n    'MultiLineString': makeReplacer(GMLBase.prototype.readMultiLineString),\n    'LinearRing': makeReplacer(GMLBase.prototype.readLinearRing),\n    'Polygon': makeReplacer(GMLBase.prototype.readPolygon),\n    'MultiPolygon': makeReplacer(GMLBase.prototype.readMultiPolygon),\n    'Box': makeReplacer(GML2.prototype.readBox),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML2.prototype.GEOMETRY_SERIALIZERS = {\n  'http://www.opengis.net/gml': {\n    'Curve': makeChildAppender(GML2.prototype.writeCurveOrLineString),\n    'MultiCurve': makeChildAppender(GML2.prototype.writeMultiCurveOrLineString),\n    'Point': makeChildAppender(GML2.prototype.writePoint),\n    'MultiPoint': makeChildAppender(GML2.prototype.writeMultiPoint),\n    'LineString': makeChildAppender(GML2.prototype.writeCurveOrLineString),\n    'MultiLineString': makeChildAppender(\n      GML2.prototype.writeMultiCurveOrLineString,\n    ),\n    'LinearRing': makeChildAppender(GML2.prototype.writeLinearRing),\n    'Polygon': makeChildAppender(GML2.prototype.writeSurfaceOrPolygon),\n    'MultiPolygon': makeChildAppender(\n      GML2.prototype.writeMultiSurfaceOrPolygon,\n    ),\n    'Surface': makeChildAppender(GML2.prototype.writeSurfaceOrPolygon),\n    'MultiSurface': makeChildAppender(\n      GML2.prototype.writeMultiSurfaceOrPolygon,\n    ),\n    'Envelope': makeChildAppender(GML2.prototype.writeEnvelope),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML2.prototype.LINESTRINGORCURVEMEMBER_SERIALIZERS = {\n  'http://www.opengis.net/gml': {\n    'lineStringMember': makeChildAppender(\n      GML2.prototype.writeLineStringOrCurveMember,\n    ),\n    'curveMember': makeChildAppender(\n      GML2.prototype.writeLineStringOrCurveMember,\n    ),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML2.prototype.RING_SERIALIZERS = {\n  'http://www.opengis.net/gml': {\n    'outerBoundaryIs': makeChildAppender(GML2.prototype.writeRing),\n    'innerBoundaryIs': makeChildAppender(GML2.prototype.writeRing),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML2.prototype.POINTMEMBER_SERIALIZERS = {\n  'http://www.opengis.net/gml': {\n    'pointMember': makeChildAppender(GML2.prototype.writePointMember),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML2.prototype.SURFACEORPOLYGONMEMBER_SERIALIZERS = {\n  'http://www.opengis.net/gml': {\n    'surfaceMember': makeChildAppender(\n      GML2.prototype.writeSurfaceOrPolygonMember,\n    ),\n    'polygonMember': makeChildAppender(\n      GML2.prototype.writeSurfaceOrPolygonMember,\n    ),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML2.prototype.ENVELOPE_SERIALIZERS = {\n  'http://www.opengis.net/gml': {\n    'lowerCorner': makeChildAppender(writeStringTextNode),\n    'upperCorner': makeChildAppender(writeStringTextNode),\n  },\n};\n\nexport default GML2;\n","/**\n * @module ol/format/GML3\n */\nimport {extend} from '../array.js';\nimport {createOrUpdate} from '../extent.js';\nimport LineString from '../geom/LineString.js';\nimport MultiLineString from '../geom/MultiLineString.js';\nimport MultiPolygon from '../geom/MultiPolygon.js';\nimport Polygon from '../geom/Polygon.js';\nimport {get as getProjection} from '../proj.js';\nimport {\n  OBJECT_PROPERTY_NODE_FACTORY,\n  XML_SCHEMA_INSTANCE_URI,\n  createElementNS,\n  getAllTextContent,\n  makeArrayExtender,\n  makeArrayPusher,\n  makeChildAppender,\n  makeReplacer,\n  makeSimpleNodeFactory,\n  parseNode,\n  pushParseAndPop,\n  pushSerializeAndPop,\n} from '../xml.js';\nimport {\n  transformExtentWithOptions,\n  transformGeometryWithOptions,\n} from './Feature.js';\nimport GML2 from './GML2.js';\nimport GMLBase, {GMLNS} from './GMLBase.js';\nimport {readNonNegativeIntegerString, writeStringTextNode} from './xsd.js';\n\n/**\n * @const\n * @type {string}\n * @private\n */\nconst schemaLocation =\n  GMLNS +\n  ' http://schemas.opengis.net/gml/3.1.1/profiles/gmlsfProfile/' +\n  '1.0.0/gmlsf.xsd';\n\n/**\n * @const\n * @type {Object<string, string>}\n */\nconst MULTIGEOMETRY_TO_MEMBER_NODENAME = {\n  'MultiLineString': 'lineStringMember',\n  'MultiCurve': 'curveMember',\n  'MultiPolygon': 'polygonMember',\n  'MultiSurface': 'surfaceMember',\n};\n\n/**\n * @classdesc\n * Feature format for reading and writing data in the GML format\n * version 3.1.1.\n * Currently only supports GML 3.1.1 Simple Features profile.\n *\n * @api\n */\nclass GML3 extends GMLBase {\n  /**\n   * @param {import(\"./GMLBase.js\").Options} [options] Optional configuration object.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super(options);\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.surface_ = options.surface !== undefined ? options.surface : false;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.curve_ = options.curve !== undefined ? options.curve : false;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.multiCurve_ =\n      options.multiCurve !== undefined ? options.multiCurve : true;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.multiSurface_ =\n      options.multiSurface !== undefined ? options.multiSurface : true;\n\n    /**\n     * @type {string}\n     */\n    this.schemaLocation = options.schemaLocation\n      ? options.schemaLocation\n      : schemaLocation;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.hasZ = options.hasZ !== undefined ? options.hasZ : false;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {MultiLineString|undefined} MultiLineString.\n   */\n  readMultiCurve(node, objectStack) {\n    /** @type {Array<LineString>} */\n    const lineStrings = pushParseAndPop(\n      [],\n      this.MULTICURVE_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    if (lineStrings) {\n      const multiLineString = new MultiLineString(lineStrings);\n      return multiLineString;\n    }\n    return undefined;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Array<number>|undefined} Polygon.\n   */\n  readFlatCurveRing(node, objectStack) {\n    /** @type {Array<LineString>} */\n    const lineStrings = pushParseAndPop(\n      [],\n      this.MULTICURVE_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    const flatCoordinates = [];\n    for (let i = 0, ii = lineStrings.length; i < ii; ++i) {\n      extend(flatCoordinates, lineStrings[i].getFlatCoordinates());\n    }\n    return flatCoordinates;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {MultiPolygon|undefined} MultiPolygon.\n   */\n  readMultiSurface(node, objectStack) {\n    /** @type {Array<Polygon>} */\n    const polygons = pushParseAndPop(\n      [],\n      this.MULTISURFACE_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    if (polygons) {\n      return new MultiPolygon(polygons);\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   */\n  curveMemberParser(node, objectStack) {\n    parseNode(this.CURVEMEMBER_PARSERS, node, objectStack, this);\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   */\n  surfaceMemberParser(node, objectStack) {\n    parseNode(this.SURFACEMEMBER_PARSERS, node, objectStack, this);\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Array<(Array<number>)>|undefined} flat coordinates.\n   */\n  readPatch(node, objectStack) {\n    return pushParseAndPop(\n      [null],\n      this.PATCHES_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Array<number>|undefined} flat coordinates.\n   */\n  readSegment(node, objectStack) {\n    return pushParseAndPop([], this.SEGMENTS_PARSERS, node, objectStack, this);\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Array<(Array<number>)>|undefined} flat coordinates.\n   */\n  readPolygonPatch(node, objectStack) {\n    return pushParseAndPop(\n      [null],\n      this.FLAT_LINEAR_RINGS_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Array<number>|undefined} flat coordinates.\n   */\n  readLineStringSegment(node, objectStack) {\n    return pushParseAndPop(\n      [null],\n      this.GEOMETRY_FLAT_COORDINATES_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   */\n  interiorParser(node, objectStack) {\n    /** @type {Array<number>|undefined} */\n    const flatLinearRing = pushParseAndPop(\n      undefined,\n      this.RING_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    if (flatLinearRing) {\n      const flatLinearRings =\n        /** @type {Array<Array<number>>} */\n        (objectStack[objectStack.length - 1]);\n      flatLinearRings.push(flatLinearRing);\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   */\n  exteriorParser(node, objectStack) {\n    /** @type {Array<number>|undefined} */\n    const flatLinearRing = pushParseAndPop(\n      undefined,\n      this.RING_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    if (flatLinearRing) {\n      const flatLinearRings =\n        /** @type {Array<Array<number>>} */\n        (objectStack[objectStack.length - 1]);\n      flatLinearRings[0] = flatLinearRing;\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Polygon|undefined} Polygon.\n   */\n  readSurface(node, objectStack) {\n    /** @type {Array<Array<number>>} */\n    const flatLinearRings = pushParseAndPop(\n      [null],\n      this.SURFACE_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    if (flatLinearRings && flatLinearRings[0]) {\n      const flatCoordinates = flatLinearRings[0];\n      const ends = [flatCoordinates.length];\n      let i, ii;\n      for (i = 1, ii = flatLinearRings.length; i < ii; ++i) {\n        extend(flatCoordinates, flatLinearRings[i]);\n        ends.push(flatCoordinates.length);\n      }\n      return new Polygon(flatCoordinates, 'XYZ', ends);\n    }\n    return undefined;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {LineString|undefined} LineString.\n   */\n  readCurve(node, objectStack) {\n    /** @type {Array<number>} */\n    const flatCoordinates = pushParseAndPop(\n      [null],\n      this.CURVE_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    if (flatCoordinates) {\n      const lineString = new LineString(flatCoordinates, 'XYZ');\n      return lineString;\n    }\n    return undefined;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {import(\"../extent.js\").Extent|undefined} Envelope.\n   */\n  readEnvelope(node, objectStack) {\n    /** @type {Array<number>} */\n    const flatCoordinates = pushParseAndPop(\n      [null],\n      this.ENVELOPE_PARSERS,\n      node,\n      objectStack,\n      this,\n    );\n    return createOrUpdate(\n      flatCoordinates[1][0],\n      flatCoordinates[1][1],\n      flatCoordinates[2][0],\n      flatCoordinates[2][1],\n    );\n  }\n\n  /**\n   * @param {Node} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Array<number>|undefined} Flat coordinates.\n   */\n  readFlatPos(node, objectStack) {\n    let s = getAllTextContent(node, false);\n    const re = /^\\s*([+\\-]?\\d*\\.?\\d+(?:[eE][+\\-]?\\d+)?)\\s*/;\n    /** @type {Array<number>} */\n    const flatCoordinates = [];\n    let m;\n    while ((m = re.exec(s))) {\n      flatCoordinates.push(parseFloat(m[1]));\n      s = s.substr(m[0].length);\n    }\n    if (s !== '') {\n      return undefined;\n    }\n    const context = objectStack[0];\n    const containerSrs = context['srsName'];\n    const axisOrientation = containerSrs\n      ? getProjection(containerSrs).getAxisOrientation()\n      : 'enu';\n    if (axisOrientation === 'neu') {\n      for (let i = 0, ii = flatCoordinates.length; i < ii; i += 3) {\n        const y = flatCoordinates[i];\n        const x = flatCoordinates[i + 1];\n        flatCoordinates[i] = x;\n        flatCoordinates[i + 1] = y;\n      }\n    }\n    const len = flatCoordinates.length;\n    if (len == 2) {\n      flatCoordinates.push(0);\n    }\n    if (len === 0) {\n      return undefined;\n    }\n    return flatCoordinates;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Array<number>|undefined} Flat coordinates.\n   */\n  readFlatPosList(node, objectStack) {\n    const s = getAllTextContent(node, false).replace(/^\\s*|\\s*$/g, '');\n    const context = objectStack[0];\n    const containerSrs = context['srsName'];\n    const contextDimension = context['srsDimension'];\n    const axisOrientation = containerSrs\n      ? getProjection(containerSrs).getAxisOrientation()\n      : 'enu';\n    const coords = s.split(/\\s+/);\n    // The \"dimension\" attribute is from the GML 3.0.1 spec.\n    let dim = 2;\n    if (node.getAttribute('srsDimension')) {\n      dim = readNonNegativeIntegerString(node.getAttribute('srsDimension'));\n    } else if (node.getAttribute('dimension')) {\n      dim = readNonNegativeIntegerString(node.getAttribute('dimension'));\n    } else if (\n      /** @type {Element} */ (node.parentNode).getAttribute('srsDimension')\n    ) {\n      dim = readNonNegativeIntegerString(\n        /** @type {Element} */ (node.parentNode).getAttribute('srsDimension'),\n      );\n    } else if (contextDimension) {\n      dim = readNonNegativeIntegerString(contextDimension);\n    }\n    const asXYZ = axisOrientation.startsWith('en');\n    let x, y, z;\n    const flatCoordinates = [];\n    for (let i = 0, ii = coords.length; i < ii; i += dim) {\n      x = parseFloat(coords[i]);\n      y = parseFloat(coords[i + 1]);\n      z = dim === 3 ? parseFloat(coords[i + 2]) : 0;\n      if (asXYZ) {\n        flatCoordinates.push(x, y, z);\n      } else {\n        flatCoordinates.push(y, x, z);\n      }\n    }\n    return flatCoordinates;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/Point.js\").default} value Point geometry.\n   * @param {Array<*>} objectStack Node stack.\n   * @private\n   */\n  writePos_(node, value, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const hasZ = context['hasZ'];\n    const srsDimension = hasZ ? '3' : '2';\n    node.setAttribute('srsDimension', srsDimension);\n    const srsName = context['srsName'];\n    const axisOrientation = srsName\n      ? getProjection(srsName).getAxisOrientation()\n      : 'enu';\n    const point = value.getCoordinates();\n    // only 2d for simple features profile\n    let coords = axisOrientation.startsWith('en')\n      ? point[0] + ' ' + point[1]\n      : point[1] + ' ' + point[0];\n    if (hasZ) {\n      // For newly created points, Z can be undefined.\n      const z = point[2] || 0;\n      coords += ' ' + z;\n    }\n    writeStringTextNode(node, coords);\n  }\n\n  /**\n   * @param {Array<number>} point Point geometry.\n   * @param {string} [srsName] Optional srsName\n   * @param {boolean} [hasZ] whether the geometry has a Z coordinate (is 3D) or not.\n   * @return {string} The coords string.\n   * @private\n   */\n  getCoords_(point, srsName, hasZ) {\n    const axisOrientation = srsName\n      ? getProjection(srsName).getAxisOrientation()\n      : 'enu';\n    let coords = axisOrientation.startsWith('en')\n      ? point[0] + ' ' + point[1]\n      : point[1] + ' ' + point[0];\n    if (hasZ) {\n      // For newly created points, Z can be undefined.\n      const z = point[2] || 0;\n      coords += ' ' + z;\n    }\n\n    return coords;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {LineString|import(\"../geom/LinearRing.js\").default} value Geometry.\n   * @param {Array<*>} objectStack Node stack.\n   * @private\n   */\n  writePosList_(node, value, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const hasZ = context['hasZ'];\n    const srsDimension = hasZ ? '3' : '2';\n    node.setAttribute('srsDimension', srsDimension);\n    const srsName = context['srsName'];\n    // only 2d for simple features profile\n    const points = value.getCoordinates();\n    const len = points.length;\n    const parts = new Array(len);\n    let point;\n    for (let i = 0; i < len; ++i) {\n      point = points[i];\n      parts[i] = this.getCoords_(point, srsName, hasZ);\n    }\n    writeStringTextNode(node, parts.join(' '));\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/Point.js\").default} geometry Point geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writePoint(node, geometry, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const srsName = context['srsName'];\n    if (srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    const pos = createElementNS(node.namespaceURI, 'pos');\n    node.appendChild(pos);\n    this.writePos_(pos, geometry, objectStack);\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeEnvelope(node, extent, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const srsName = context['srsName'];\n    if (srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    const keys = ['lowerCorner', 'upperCorner'];\n    const values = [extent[0] + ' ' + extent[1], extent[2] + ' ' + extent[3]];\n    pushSerializeAndPop(\n      /** @type {import(\"../xml.js\").NodeStackItem} */\n      ({node: node}),\n      this.ENVELOPE_SERIALIZERS,\n      OBJECT_PROPERTY_NODE_FACTORY,\n      values,\n      objectStack,\n      keys,\n      this,\n    );\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/LinearRing.js\").default} geometry LinearRing geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeLinearRing(node, geometry, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const srsName = context['srsName'];\n    if (srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    const posList = createElementNS(node.namespaceURI, 'posList');\n    node.appendChild(posList);\n    this.writePosList_(posList, geometry, objectStack);\n  }\n\n  /**\n   * @param {*} value Value.\n   * @param {Array<*>} objectStack Object stack.\n   * @param {string} [nodeName] Node name.\n   * @return {Node} Node.\n   * @private\n   */\n  RING_NODE_FACTORY_(value, objectStack, nodeName) {\n    const context = objectStack[objectStack.length - 1];\n    const parentNode = context.node;\n    const exteriorWritten = context['exteriorWritten'];\n    if (exteriorWritten === undefined) {\n      context['exteriorWritten'] = true;\n    }\n    return createElementNS(\n      parentNode.namespaceURI,\n      exteriorWritten !== undefined ? 'interior' : 'exterior',\n    );\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Polygon} geometry Polygon geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeSurfaceOrPolygon(node, geometry, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const hasZ = context['hasZ'];\n    const srsName = context['srsName'];\n    if (node.nodeName !== 'PolygonPatch' && srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    if (node.nodeName === 'Polygon' || node.nodeName === 'PolygonPatch') {\n      const rings = geometry.getLinearRings();\n      pushSerializeAndPop(\n        {node: node, hasZ: hasZ, srsName: srsName},\n        this.RING_SERIALIZERS,\n        this.RING_NODE_FACTORY_,\n        rings,\n        objectStack,\n        undefined,\n        this,\n      );\n    } else if (node.nodeName === 'Surface') {\n      const patches = createElementNS(node.namespaceURI, 'patches');\n      node.appendChild(patches);\n      this.writeSurfacePatches_(patches, geometry, objectStack);\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {LineString} geometry LineString geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeCurveOrLineString(node, geometry, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const srsName = context['srsName'];\n    if (node.nodeName !== 'LineStringSegment' && srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    if (\n      node.nodeName === 'LineString' ||\n      node.nodeName === 'LineStringSegment'\n    ) {\n      const posList = createElementNS(node.namespaceURI, 'posList');\n      node.appendChild(posList);\n      this.writePosList_(posList, geometry, objectStack);\n    } else if (node.nodeName === 'Curve') {\n      const segments = createElementNS(node.namespaceURI, 'segments');\n      node.appendChild(segments);\n      this.writeCurveSegments_(segments, geometry, objectStack);\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {MultiPolygon} geometry MultiPolygon geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeMultiSurfaceOrPolygon(node, geometry, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const hasZ = context['hasZ'];\n    const srsName = context['srsName'];\n    const surface = context['surface'];\n    if (srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    const polygons = geometry.getPolygons();\n    pushSerializeAndPop(\n      {node: node, hasZ: hasZ, srsName: srsName, surface: surface},\n      this.SURFACEORPOLYGONMEMBER_SERIALIZERS,\n      this.MULTIGEOMETRY_MEMBER_NODE_FACTORY_,\n      polygons,\n      objectStack,\n      undefined,\n      this,\n    );\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/MultiPoint.js\").default} geometry MultiPoint geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeMultiPoint(node, geometry, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const srsName = context['srsName'];\n    const hasZ = context['hasZ'];\n    if (srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    const points = geometry.getPoints();\n    pushSerializeAndPop(\n      {node: node, hasZ: hasZ, srsName: srsName},\n      this.POINTMEMBER_SERIALIZERS,\n      makeSimpleNodeFactory('pointMember'),\n      points,\n      objectStack,\n      undefined,\n      this,\n    );\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {MultiLineString} geometry MultiLineString geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeMultiCurveOrLineString(node, geometry, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    const hasZ = context['hasZ'];\n    const srsName = context['srsName'];\n    const curve = context['curve'];\n    if (srsName) {\n      node.setAttribute('srsName', srsName);\n    }\n    const lines = geometry.getLineStrings();\n    pushSerializeAndPop(\n      {node: node, hasZ: hasZ, srsName: srsName, curve: curve},\n      this.LINESTRINGORCURVEMEMBER_SERIALIZERS,\n      this.MULTIGEOMETRY_MEMBER_NODE_FACTORY_,\n      lines,\n      objectStack,\n      undefined,\n      this,\n    );\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/LinearRing.js\").default} ring LinearRing geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeRing(node, ring, objectStack) {\n    const linearRing = createElementNS(node.namespaceURI, 'LinearRing');\n    node.appendChild(linearRing);\n    this.writeLinearRing(linearRing, ring, objectStack);\n  }\n\n  /**\n   * @param {Node} node Node.\n   * @param {Polygon} polygon Polygon geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeSurfaceOrPolygonMember(node, polygon, objectStack) {\n    const child = this.GEOMETRY_NODE_FACTORY_(polygon, objectStack);\n    if (child) {\n      node.appendChild(child);\n      this.writeSurfaceOrPolygon(child, polygon, objectStack);\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../geom/Point.js\").default} point Point geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writePointMember(node, point, objectStack) {\n    const child = createElementNS(node.namespaceURI, 'Point');\n    node.appendChild(child);\n    this.writePoint(child, point, objectStack);\n  }\n\n  /**\n   * @param {Node} node Node.\n   * @param {LineString} line LineString geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeLineStringOrCurveMember(node, line, objectStack) {\n    const child = this.GEOMETRY_NODE_FACTORY_(line, objectStack);\n    if (child) {\n      node.appendChild(child);\n      this.writeCurveOrLineString(child, line, objectStack);\n    }\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Polygon} polygon Polygon geometry.\n   * @param {Array<*>} objectStack Node stack.\n   * @private\n   */\n  writeSurfacePatches_(node, polygon, objectStack) {\n    const child = createElementNS(node.namespaceURI, 'PolygonPatch');\n    node.appendChild(child);\n    this.writeSurfaceOrPolygon(child, polygon, objectStack);\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {LineString} line LineString geometry.\n   * @param {Array<*>} objectStack Node stack.\n   * @private\n   */\n  writeCurveSegments_(node, line, objectStack) {\n    const child = createElementNS(node.namespaceURI, 'LineStringSegment');\n    node.appendChild(child);\n    this.writeCurveOrLineString(child, line, objectStack);\n  }\n\n  /**\n   * @param {Node} node Node.\n   * @param {import(\"../geom/Geometry.js\").default|import(\"../extent.js\").Extent} geometry Geometry.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeGeometryElement(node, geometry, objectStack) {\n    const context = /** @type {import(\"./Feature.js\").WriteOptions} */ (\n      objectStack[objectStack.length - 1]\n    );\n    const item = Object.assign({}, context);\n    item['node'] = node;\n    let value;\n    if (Array.isArray(geometry)) {\n      value = transformExtentWithOptions(\n        /** @type {import(\"../extent.js\").Extent} */ (geometry),\n        context,\n      );\n    } else {\n      value = transformGeometryWithOptions(\n        /** @type {import(\"../geom/Geometry.js\").default} */ (geometry),\n        true,\n        context,\n      );\n    }\n    pushSerializeAndPop(\n      /** @type {import(\"../xml.js\").NodeStackItem} */\n      (item),\n      this.GEOMETRY_SERIALIZERS,\n      this.GEOMETRY_NODE_FACTORY_,\n      [value],\n      objectStack,\n      undefined,\n      this,\n    );\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {import(\"../Feature.js\").default} feature Feature.\n   * @param {Array<*>} objectStack Node stack.\n   */\n  writeFeatureElement(node, feature, objectStack) {\n    const fid = feature.getId();\n    if (fid) {\n      node.setAttribute('fid', /** @type {string} */ (fid));\n    }\n    const context = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n    const featureNS = context['featureNS'];\n    const geometryName = feature.getGeometryName();\n    if (!context.serializers) {\n      context.serializers = {};\n      context.serializers[featureNS] = {};\n    }\n    const keys = [];\n    const values = [];\n    if (feature.hasProperties()) {\n      const properties = feature.getProperties();\n      for (const key in properties) {\n        const value = properties[key];\n        if (value !== null && value !== undefined) {\n          keys.push(key);\n          values.push(value);\n          if (\n            key == geometryName ||\n            typeof (/** @type {?} */ (value).getSimplifiedGeometry) ===\n              'function'\n          ) {\n            if (!(key in context.serializers[featureNS])) {\n              context.serializers[featureNS][key] = makeChildAppender(\n                this.writeGeometryElement,\n                this,\n              );\n            }\n          } else {\n            if (!(key in context.serializers[featureNS])) {\n              context.serializers[featureNS][key] =\n                makeChildAppender(writeStringTextNode);\n            }\n          }\n        }\n      }\n    }\n    const item = Object.assign({}, context);\n    item.node = node;\n    pushSerializeAndPop(\n      /** @type {import(\"../xml.js\").NodeStackItem} */\n      (item),\n      context.serializers,\n      makeSimpleNodeFactory(undefined, featureNS),\n      values,\n      objectStack,\n      keys,\n    );\n  }\n\n  /**\n   * @param {Node} node Node.\n   * @param {Array<import(\"../Feature.js\").default>} features Features.\n   * @param {Array<*>} objectStack Node stack.\n   * @private\n   */\n  writeFeatureMembers_(node, features, objectStack) {\n    const context = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n    const featureType = context['featureType'];\n    const featureNS = context['featureNS'];\n    /** @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>} */\n    const serializers = {};\n    serializers[featureNS] = {};\n    serializers[featureNS][featureType] = makeChildAppender(\n      this.writeFeatureElement,\n      this,\n    );\n    const item = Object.assign({}, context);\n    item.node = node;\n    pushSerializeAndPop(\n      /** @type {import(\"../xml.js\").NodeStackItem} */\n      (item),\n      serializers,\n      makeSimpleNodeFactory(featureType, featureNS),\n      features,\n      objectStack,\n    );\n  }\n\n  /**\n   * @const\n   * @param {*} value Value.\n   * @param {Array<*>} objectStack Object stack.\n   * @param {string} [nodeName] Node name.\n   * @return {Node|undefined} Node.\n   * @private\n   */\n  MULTIGEOMETRY_MEMBER_NODE_FACTORY_(value, objectStack, nodeName) {\n    const parentNode = objectStack[objectStack.length - 1].node;\n    return createElementNS(\n      this.namespace,\n      MULTIGEOMETRY_TO_MEMBER_NODENAME[parentNode.nodeName],\n    );\n  }\n\n  /**\n   * @const\n   * @param {*} value Value.\n   * @param {Array<*>} objectStack Object stack.\n   * @param {string} [nodeName] Node name.\n   * @return {Element|undefined} Node.\n   * @private\n   */\n  GEOMETRY_NODE_FACTORY_(value, objectStack, nodeName) {\n    const context = objectStack[objectStack.length - 1];\n    const multiSurface = context['multiSurface'];\n    const surface = context['surface'];\n    const curve = context['curve'];\n    const multiCurve = context['multiCurve'];\n    if (!Array.isArray(value)) {\n      nodeName = /** @type {import(\"../geom/Geometry.js\").default} */ (\n        value\n      ).getType();\n      if (nodeName === 'MultiPolygon' && multiSurface === true) {\n        nodeName = 'MultiSurface';\n      } else if (nodeName === 'Polygon' && surface === true) {\n        nodeName = 'Surface';\n      } else if (nodeName === 'LineString' && curve === true) {\n        nodeName = 'Curve';\n      } else if (nodeName === 'MultiLineString' && multiCurve === true) {\n        nodeName = 'MultiCurve';\n      }\n    } else {\n      nodeName = 'Envelope';\n    }\n    return createElementNS(this.namespace, nodeName);\n  }\n\n  /**\n   * Encode a geometry in GML 3.1.1 Simple Features.\n   *\n   * @param {import(\"../geom/Geometry.js\").default} geometry Geometry.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Options.\n   * @return {Node} Node.\n   * @api\n   * @override\n   */\n  writeGeometryNode(geometry, options) {\n    options = this.adaptOptions(options);\n    const geom = createElementNS(this.namespace, 'geom');\n    const context = {\n      node: geom,\n      hasZ: this.hasZ,\n      srsName: this.srsName,\n      curve: this.curve_,\n      surface: this.surface_,\n      multiSurface: this.multiSurface_,\n      multiCurve: this.multiCurve_,\n    };\n    if (options) {\n      Object.assign(context, options);\n    }\n    this.writeGeometryElement(geom, geometry, [context]);\n    return geom;\n  }\n\n  /**\n   * Encode an array of features in the GML 3.1.1 format as an XML node.\n   *\n   * @param {Array<import(\"../Feature.js\").default>} features Features.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Options.\n   * @return {Element} Node.\n   * @api\n   * @override\n   */\n  writeFeaturesNode(features, options) {\n    options = this.adaptOptions(options);\n    const node = createElementNS(this.namespace, 'featureMembers');\n    node.setAttributeNS(\n      XML_SCHEMA_INSTANCE_URI,\n      'xsi:schemaLocation',\n      this.schemaLocation,\n    );\n    const context = {\n      srsName: this.srsName,\n      hasZ: this.hasZ,\n      curve: this.curve_,\n      surface: this.surface_,\n      multiSurface: this.multiSurface_,\n      multiCurve: this.multiCurve_,\n      featureNS: this.featureNS,\n      featureType: this.featureType,\n    };\n    if (options) {\n      Object.assign(context, options);\n    }\n    this.writeFeatureMembers_(node, features, [context]);\n    return node;\n  }\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML3.prototype.GEOMETRY_FLAT_COORDINATES_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'pos': makeReplacer(GML3.prototype.readFlatPos),\n    'posList': makeReplacer(GML3.prototype.readFlatPosList),\n    'coordinates': makeReplacer(GML2.prototype.readFlatCoordinates),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML3.prototype.FLAT_LINEAR_RINGS_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'interior': GML3.prototype.interiorParser,\n    'exterior': GML3.prototype.exteriorParser,\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML3.prototype.GEOMETRY_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'Point': makeReplacer(GMLBase.prototype.readPoint),\n    'MultiPoint': makeReplacer(GMLBase.prototype.readMultiPoint),\n    'LineString': makeReplacer(GMLBase.prototype.readLineString),\n    'MultiLineString': makeReplacer(GMLBase.prototype.readMultiLineString),\n    'LinearRing': makeReplacer(GMLBase.prototype.readLinearRing),\n    'Polygon': makeReplacer(GMLBase.prototype.readPolygon),\n    'MultiPolygon': makeReplacer(GMLBase.prototype.readMultiPolygon),\n    'Surface': makeReplacer(GML3.prototype.readSurface),\n    'MultiSurface': makeReplacer(GML3.prototype.readMultiSurface),\n    'Curve': makeReplacer(GML3.prototype.readCurve),\n    'MultiCurve': makeReplacer(GML3.prototype.readMultiCurve),\n    'Envelope': makeReplacer(GML3.prototype.readEnvelope),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML3.prototype.MULTICURVE_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'curveMember': makeArrayPusher(GML3.prototype.curveMemberParser),\n    'curveMembers': makeArrayPusher(GML3.prototype.curveMemberParser),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML3.prototype.MULTISURFACE_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'surfaceMember': makeArrayPusher(GML3.prototype.surfaceMemberParser),\n    'surfaceMembers': makeArrayPusher(GML3.prototype.surfaceMemberParser),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML3.prototype.CURVEMEMBER_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'LineString': makeArrayPusher(GMLBase.prototype.readLineString),\n    'Curve': makeArrayPusher(GML3.prototype.readCurve),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML3.prototype.SURFACEMEMBER_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'Polygon': makeArrayPusher(GMLBase.prototype.readPolygon),\n    'Surface': makeArrayPusher(GML3.prototype.readSurface),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML3.prototype.SURFACE_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'patches': makeReplacer(GML3.prototype.readPatch),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML3.prototype.CURVE_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'segments': makeReplacer(GML3.prototype.readSegment),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML3.prototype.ENVELOPE_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'lowerCorner': makeArrayPusher(GML3.prototype.readFlatPosList),\n    'upperCorner': makeArrayPusher(GML3.prototype.readFlatPosList),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML3.prototype.PATCHES_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'PolygonPatch': makeReplacer(GML3.prototype.readPolygonPatch),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML3.prototype.SEGMENTS_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'LineStringSegment': makeArrayExtender(\n      GML3.prototype.readLineStringSegment,\n    ),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGMLBase.prototype.RING_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'LinearRing': makeReplacer(GMLBase.prototype.readFlatLinearRing),\n    'Ring': makeReplacer(GML3.prototype.readFlatCurveRing),\n  },\n};\n\n/**\n * Encode an array of features in GML 3.1.1 Simple Features.\n *\n * @function\n * @param {Array<import(\"../Feature.js\").default>} features Features.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Options.\n * @return {string} Result.\n * @api\n */\nGML3.prototype.writeFeatures;\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML3.prototype.RING_SERIALIZERS = {\n  'http://www.opengis.net/gml': {\n    'exterior': makeChildAppender(GML3.prototype.writeRing),\n    'interior': makeChildAppender(GML3.prototype.writeRing),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML3.prototype.ENVELOPE_SERIALIZERS = {\n  'http://www.opengis.net/gml': {\n    'lowerCorner': makeChildAppender(writeStringTextNode),\n    'upperCorner': makeChildAppender(writeStringTextNode),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML3.prototype.SURFACEORPOLYGONMEMBER_SERIALIZERS = {\n  'http://www.opengis.net/gml': {\n    'surfaceMember': makeChildAppender(\n      GML3.prototype.writeSurfaceOrPolygonMember,\n    ),\n    'polygonMember': makeChildAppender(\n      GML3.prototype.writeSurfaceOrPolygonMember,\n    ),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML3.prototype.POINTMEMBER_SERIALIZERS = {\n  'http://www.opengis.net/gml': {\n    'pointMember': makeChildAppender(GML3.prototype.writePointMember),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML3.prototype.LINESTRINGORCURVEMEMBER_SERIALIZERS = {\n  'http://www.opengis.net/gml': {\n    'lineStringMember': makeChildAppender(\n      GML3.prototype.writeLineStringOrCurveMember,\n    ),\n    'curveMember': makeChildAppender(\n      GML3.prototype.writeLineStringOrCurveMember,\n    ),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML3.prototype.GEOMETRY_SERIALIZERS = {\n  'http://www.opengis.net/gml': {\n    'Curve': makeChildAppender(GML3.prototype.writeCurveOrLineString),\n    'MultiCurve': makeChildAppender(GML3.prototype.writeMultiCurveOrLineString),\n    'Point': makeChildAppender(GML3.prototype.writePoint),\n    'MultiPoint': makeChildAppender(GML3.prototype.writeMultiPoint),\n    'LineString': makeChildAppender(GML3.prototype.writeCurveOrLineString),\n    'MultiLineString': makeChildAppender(\n      GML3.prototype.writeMultiCurveOrLineString,\n    ),\n    'LinearRing': makeChildAppender(GML3.prototype.writeLinearRing),\n    'Polygon': makeChildAppender(GML3.prototype.writeSurfaceOrPolygon),\n    'MultiPolygon': makeChildAppender(\n      GML3.prototype.writeMultiSurfaceOrPolygon,\n    ),\n    'Surface': makeChildAppender(GML3.prototype.writeSurfaceOrPolygon),\n    'MultiSurface': makeChildAppender(\n      GML3.prototype.writeMultiSurfaceOrPolygon,\n    ),\n    'Envelope': makeChildAppender(GML3.prototype.writeEnvelope),\n  },\n};\n\nexport default GML3;\n","/**\n * @module ol/format/GML32\n */\nimport {writeStringTextNode} from '../format/xsd.js';\nimport {\n  makeArrayExtender,\n  makeArrayPusher,\n  makeChildAppender,\n  makeReplacer,\n} from '../xml.js';\nimport GML2 from './GML2.js';\nimport GML3 from './GML3.js';\nimport GMLBase from './GMLBase.js';\n\n/**\n * @classdesc Feature format for reading and writing data in the GML format\n *            version 3.2.1.\n * @api\n */\nclass GML32 extends GML3 {\n  /**\n   * @param {import(\"./GMLBase.js\").Options} [options] Optional configuration object.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super(options);\n\n    /**\n     * @type {string}\n     */\n    this.schemaLocation = options.schemaLocation\n      ? options.schemaLocation\n      : this.namespace + ' http://schemas.opengis.net/gml/3.2.1/gml.xsd';\n  }\n\n  /**\n   * @param {Node} node Node.\n   * @param {import(\"../geom/Geometry.js\").default|import(\"../extent.js\").Extent} geometry Geometry.\n   * @param {Array<*>} objectStack Node stack.\n   * @override\n   */\n  writeGeometryElement(node, geometry, objectStack) {\n    const context = objectStack[objectStack.length - 1];\n    objectStack[objectStack.length - 1] = Object.assign(\n      {multiCurve: true, multiSurface: true},\n      context,\n    );\n    super.writeGeometryElement(node, geometry, objectStack);\n  }\n}\n\nGML32.prototype.namespace = 'http://www.opengis.net/gml/3.2';\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.GEOMETRY_FLAT_COORDINATES_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'pos': makeReplacer(GML3.prototype.readFlatPos),\n    'posList': makeReplacer(GML3.prototype.readFlatPosList),\n    'coordinates': makeReplacer(GML2.prototype.readFlatCoordinates),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.FLAT_LINEAR_RINGS_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'interior': GML3.prototype.interiorParser,\n    'exterior': GML3.prototype.exteriorParser,\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.GEOMETRY_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'Point': makeReplacer(GMLBase.prototype.readPoint),\n    'MultiPoint': makeReplacer(GMLBase.prototype.readMultiPoint),\n    'LineString': makeReplacer(GMLBase.prototype.readLineString),\n    'MultiLineString': makeReplacer(GMLBase.prototype.readMultiLineString),\n    'LinearRing': makeReplacer(GMLBase.prototype.readLinearRing),\n    'Polygon': makeReplacer(GMLBase.prototype.readPolygon),\n    'MultiPolygon': makeReplacer(GMLBase.prototype.readMultiPolygon),\n    'Surface': makeReplacer(GML32.prototype.readSurface),\n    'MultiSurface': makeReplacer(GML3.prototype.readMultiSurface),\n    'Curve': makeReplacer(GML32.prototype.readCurve),\n    'MultiCurve': makeReplacer(GML3.prototype.readMultiCurve),\n    'Envelope': makeReplacer(GML32.prototype.readEnvelope),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.MULTICURVE_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'curveMember': makeArrayPusher(GML3.prototype.curveMemberParser),\n    'curveMembers': makeArrayPusher(GML3.prototype.curveMemberParser),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.MULTISURFACE_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'surfaceMember': makeArrayPusher(GML3.prototype.surfaceMemberParser),\n    'surfaceMembers': makeArrayPusher(GML3.prototype.surfaceMemberParser),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.CURVEMEMBER_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'LineString': makeArrayPusher(GMLBase.prototype.readLineString),\n    'Curve': makeArrayPusher(GML3.prototype.readCurve),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.SURFACEMEMBER_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'Polygon': makeArrayPusher(GMLBase.prototype.readPolygon),\n    'Surface': makeArrayPusher(GML3.prototype.readSurface),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.SURFACE_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'patches': makeReplacer(GML3.prototype.readPatch),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.CURVE_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'segments': makeReplacer(GML3.prototype.readSegment),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.ENVELOPE_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'lowerCorner': makeArrayPusher(GML3.prototype.readFlatPosList),\n    'upperCorner': makeArrayPusher(GML3.prototype.readFlatPosList),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.PATCHES_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'PolygonPatch': makeReplacer(GML3.prototype.readPolygonPatch),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.SEGMENTS_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'LineStringSegment': makeArrayExtender(\n      GML3.prototype.readLineStringSegment,\n    ),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.MULTIPOINT_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'pointMember': makeArrayPusher(GMLBase.prototype.pointMemberParser),\n    'pointMembers': makeArrayPusher(GMLBase.prototype.pointMemberParser),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.MULTILINESTRING_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'lineStringMember': makeArrayPusher(\n      GMLBase.prototype.lineStringMemberParser,\n    ),\n    'lineStringMembers': makeArrayPusher(\n      GMLBase.prototype.lineStringMemberParser,\n    ),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.MULTIPOLYGON_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'polygonMember': makeArrayPusher(GMLBase.prototype.polygonMemberParser),\n    'polygonMembers': makeArrayPusher(GMLBase.prototype.polygonMemberParser),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.POINTMEMBER_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'Point': makeArrayPusher(GMLBase.prototype.readFlatCoordinatesFromNode),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.LINESTRINGMEMBER_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'LineString': makeArrayPusher(GMLBase.prototype.readLineString),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.POLYGONMEMBER_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'Polygon': makeArrayPusher(GMLBase.prototype.readPolygon),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nGML32.prototype.RING_PARSERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'LinearRing': makeReplacer(GMLBase.prototype.readFlatLinearRing),\n    'Ring': makeReplacer(GML32.prototype.readFlatCurveRing),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML32.prototype.RING_SERIALIZERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'exterior': makeChildAppender(GML3.prototype.writeRing),\n    'interior': makeChildAppender(GML3.prototype.writeRing),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML32.prototype.ENVELOPE_SERIALIZERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'lowerCorner': makeChildAppender(writeStringTextNode),\n    'upperCorner': makeChildAppender(writeStringTextNode),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML32.prototype.SURFACEORPOLYGONMEMBER_SERIALIZERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'surfaceMember': makeChildAppender(\n      GML3.prototype.writeSurfaceOrPolygonMember,\n    ),\n    'polygonMember': makeChildAppender(\n      GML3.prototype.writeSurfaceOrPolygonMember,\n    ),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML32.prototype.POINTMEMBER_SERIALIZERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'pointMember': makeChildAppender(GML3.prototype.writePointMember),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML32.prototype.LINESTRINGORCURVEMEMBER_SERIALIZERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'lineStringMember': makeChildAppender(\n      GML3.prototype.writeLineStringOrCurveMember,\n    ),\n    'curveMember': makeChildAppender(\n      GML3.prototype.writeLineStringOrCurveMember,\n    ),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nGML32.prototype.GEOMETRY_SERIALIZERS = {\n  'http://www.opengis.net/gml/3.2': {\n    'Curve': makeChildAppender(GML3.prototype.writeCurveOrLineString),\n    'MultiCurve': makeChildAppender(GML3.prototype.writeMultiCurveOrLineString),\n    'Point': makeChildAppender(GML32.prototype.writePoint),\n    'MultiPoint': makeChildAppender(GML3.prototype.writeMultiPoint),\n    'LineString': makeChildAppender(GML3.prototype.writeCurveOrLineString),\n    'MultiLineString': makeChildAppender(\n      GML3.prototype.writeMultiCurveOrLineString,\n    ),\n    'LinearRing': makeChildAppender(GML3.prototype.writeLinearRing),\n    'Polygon': makeChildAppender(GML3.prototype.writeSurfaceOrPolygon),\n    'MultiPolygon': makeChildAppender(\n      GML3.prototype.writeMultiSurfaceOrPolygon,\n    ),\n    'Surface': makeChildAppender(GML3.prototype.writeSurfaceOrPolygon),\n    'MultiSurface': makeChildAppender(\n      GML3.prototype.writeMultiSurfaceOrPolygon,\n    ),\n    'Envelope': makeChildAppender(GML3.prototype.writeEnvelope),\n  },\n};\n\nexport default GML32;\n","/**\n * @module ol/format/filter/Filter\n */\n\n/**\n * @classdesc\n * Abstract class; normally only used for creating subclasses and not instantiated in apps.\n * Base class for WFS GetFeature filters.\n *\n * @abstract\n */\nclass Filter {\n  /**\n   * @param {!string} tagName The XML tag name for this filter.\n   */\n  constructor(tagName) {\n    /**\n     * @private\n     * @type {!string}\n     */\n    this.tagName_ = tagName;\n  }\n\n  /**\n   * The XML tag name for a filter.\n   * @return {!string} Name.\n   */\n  getTagName() {\n    return this.tagName_;\n  }\n}\n\nexport default Filter;\n","/**\n * @module ol/format/filter/LogicalNary\n */\nimport {assert} from '../../asserts.js';\nimport Filter from './Filter.js';\n\n/**\n * @classdesc\n * Abstract class; normally only used for creating subclasses and not instantiated in apps.\n * Base class for WFS GetFeature n-ary logical filters.\n *\n * @abstract\n */\nclass LogicalNary extends Filter {\n  /**\n   * @param {!string} tagName The XML tag name for this filter.\n   * @param {Array<import(\"./Filter.js\").default>} conditions Conditions.\n   */\n  constructor(tagName, conditions) {\n    super(tagName);\n\n    /**\n     * @type {Array<import(\"./Filter.js\").default>}\n     */\n    this.conditions = conditions;\n    assert(this.conditions.length >= 2, 'At least 2 conditions are required');\n  }\n}\n\nexport default LogicalNary;\n","/**\n * @module ol/format/filter/And\n */\nimport LogicalNary from './LogicalNary.js';\n\n/**\n * @classdesc\n * Represents a logical `<And>` operator between two or more filter conditions.\n *\n * @abstract\n */\nclass And extends LogicalNary {\n  /**\n   * @param {...import(\"./Filter.js\").default} conditions Conditions.\n   */\n  constructor(conditions) {\n    super('And', Array.prototype.slice.call(arguments));\n  }\n}\n\nexport default And;\n","/**\n * @module ol/format/filter/Bbox\n */\nimport Filter from './Filter.js';\n\n/**\n * @classdesc\n * Represents a `<BBOX>` operator to test whether a geometry-valued property\n * intersects a fixed bounding box\n *\n * @api\n */\nclass Bbox extends Filter {\n  /**\n   * @param {!string} geometryName Geometry name to use.\n   * @param {!import(\"../../extent.js\").Extent} extent Extent.\n   * @param {string} [srsName] SRS name. No srsName attribute will be set\n   * on geometries when this is not provided.\n   */\n  constructor(geometryName, extent, srsName) {\n    super('BBOX');\n\n    /**\n     * @type {!string}\n     */\n    this.geometryName = geometryName;\n\n    /**\n     * @type {import(\"../../extent.js\").Extent}\n     */\n    this.extent = extent;\n    if (extent.length !== 4) {\n      throw new Error(\n        'Expected an extent with four values ([minX, minY, maxX, maxY])',\n      );\n    }\n\n    /**\n     * @type {string|undefined}\n     */\n    this.srsName = srsName;\n  }\n}\n\nexport default Bbox;\n","/**\n * @module ol/format/WFS\n */\nimport {assert} from '../asserts.js';\nimport {get as getProjection} from '../proj.js';\nimport {\n  XML_SCHEMA_INSTANCE_URI,\n  createElementNS,\n  isDocument,\n  makeArrayPusher,\n  makeChildAppender,\n  makeObjectPropertySetter,\n  makeSimpleNodeFactory,\n  parse,\n  parseNode,\n  pushParseAndPop,\n  pushSerializeAndPop,\n} from '../xml.js';\nimport GML2 from './GML2.js';\nimport GML3 from './GML3.js';\nimport GML32 from './GML32.js';\nimport GMLBase, {GMLNS} from './GMLBase.js';\nimport XMLFeature from './XMLFeature.js';\nimport {and as andFilterFn, bbox as bboxFilterFn} from './filter.js';\nimport {\n  readNonNegativeIntegerString,\n  readPositiveInteger,\n  writeStringTextNode,\n} from './xsd.js';\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nconst FEATURE_COLLECTION_PARSERS = {\n  'http://www.opengis.net/gml': {\n    'boundedBy': makeObjectPropertySetter(\n      GMLBase.prototype.readExtentElement,\n      'bounds',\n    ),\n  },\n  'http://www.opengis.net/wfs/2.0': {\n    'member': makeArrayPusher(GMLBase.prototype.readFeaturesInternal),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nconst TRANSACTION_SUMMARY_PARSERS = {\n  'http://www.opengis.net/wfs': {\n    'totalInserted': makeObjectPropertySetter(readPositiveInteger),\n    'totalUpdated': makeObjectPropertySetter(readPositiveInteger),\n    'totalDeleted': makeObjectPropertySetter(readPositiveInteger),\n  },\n  'http://www.opengis.net/wfs/2.0': {\n    'totalInserted': makeObjectPropertySetter(readPositiveInteger),\n    'totalUpdated': makeObjectPropertySetter(readPositiveInteger),\n    'totalDeleted': makeObjectPropertySetter(readPositiveInteger),\n  },\n};\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nconst TRANSACTION_RESPONSE_PARSERS = {\n  'http://www.opengis.net/wfs': {\n    'TransactionSummary': makeObjectPropertySetter(\n      readTransactionSummary,\n      'transactionSummary',\n    ),\n    'InsertResults': makeObjectPropertySetter(readInsertResults, 'insertIds'),\n  },\n  'http://www.opengis.net/wfs/2.0': {\n    'TransactionSummary': makeObjectPropertySetter(\n      readTransactionSummary,\n      'transactionSummary',\n    ),\n    'InsertResults': makeObjectPropertySetter(readInsertResults, 'insertIds'),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nconst QUERY_SERIALIZERS = {\n  'http://www.opengis.net/wfs': {\n    'PropertyName': makeChildAppender(writeStringTextNode),\n  },\n  'http://www.opengis.net/wfs/2.0': {\n    'PropertyName': makeChildAppender(writeStringTextNode),\n  },\n};\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nconst TRANSACTION_SERIALIZERS = {\n  'http://www.opengis.net/wfs': {\n    'Insert': makeChildAppender(writeFeature),\n    'Update': makeChildAppender(writeUpdate),\n    'Delete': makeChildAppender(writeDelete),\n    'Property': makeChildAppender(writeProperty),\n    'Native': makeChildAppender(writeNative),\n  },\n  'http://www.opengis.net/wfs/2.0': {\n    'Insert': makeChildAppender(writeFeature),\n    'Update': makeChildAppender(writeUpdate),\n    'Delete': makeChildAppender(writeDelete),\n    'Property': makeChildAppender(writeProperty),\n    'Native': makeChildAppender(writeNative),\n  },\n};\n\n/**\n * @typedef {Object} Options\n * @property {Object<string, string>|string} [featureNS] The namespace URI used for features.\n * @property {Array<string>|string} [featureType] The feature type to parse. Only used for read operations.\n * @property {GMLBase} [gmlFormat] The GML format to use to parse the response.\n * Default is `ol/format/GML2` for WFS 1.0.0, `ol/format/GML3` for WFS 1.1.0 and `ol/format/GML32` for WFS 2.0.0.\n * @property {string} [schemaLocation] Optional schemaLocation to use for serialization, this will override the default.\n * @property {string} [version='1.1.0'] WFS version to use. Can be either `1.0.0`, `1.1.0` or `2.0.0`.\n */\n\n/**\n * @typedef {Object} WriteGetFeatureOptions\n * @property {string} featureNS The namespace URI used for features.\n * @property {string} featurePrefix The prefix for the feature namespace.\n * @property {Array<string|FeatureType>} featureTypes The feature type names or FeatureType objects to\n * define a unique bbox filter per feature type name (in this case, options `bbox` and `geometryName` are\n * ignored.).\n * @property {string} [srsName] SRS name. No srsName attribute will be set on\n * geometries when this is not provided.\n * @property {string} [handle] Handle.\n * @property {string} [outputFormat] Output format.\n * @property {number} [maxFeatures] Maximum number of features to fetch.\n * @property {string} [geometryName] Geometry name to use in a BBOX filter.\n * @property {Array<string>} [propertyNames] Optional list of property names to serialize.\n * @property {string} [viewParams] viewParams GeoServer vendor parameter.\n * @property {number} [startIndex] Start index to use for WFS paging. This is a\n * WFS 2.0 feature backported to WFS 1.1.0 by some Web Feature Services.\n * @property {number} [count] Number of features to retrieve when paging. This is a\n * WFS 2.0 feature backported to WFS 1.1.0 by some Web Feature Services. Please note that some\n * Web Feature Services have repurposed `maxfeatures` instead.\n * @property {import(\"../extent.js\").Extent} [bbox] Extent to use for the BBOX filter. The `geometryName`\n * option must be set.\n * @property {import(\"./filter/Filter.js\").default} [filter] Filter condition. See\n * {@link module:ol/format/filter} for more information.\n * @property {string} [resultType] Indicates what response should be returned,\n * e.g. `hits` only includes the `numberOfFeatures` attribute in the response and no features.\n */\n\n/**\n * @typedef {Object} FeatureType\n * @property {!string} name The feature type name.\n * @property {!import(\"../extent.js\").Extent} bbox Extent to use for the BBOX filter.\n * @property {!string} geometryName Geometry name to use in the BBOX filter.\n */\n\n/**\n * @typedef {Object} WriteTransactionOptions\n * @property {string} featureNS The namespace URI used for features.\n * @property {string} featurePrefix The prefix for the feature namespace.\n * @property {string} featureType The feature type name.\n * @property {string} [srsName] SRS name. No srsName attribute will be set on\n * geometries when this is not provided.\n * @property {string} [handle] Handle.\n * @property {boolean} [hasZ] Must be set to true if the transaction is for\n * a 3D layer. This will allow the Z coordinate to be included in the transaction.\n * @property {Array<Object>} nativeElements Native elements. Currently not supported.\n * @property {import(\"./GMLBase.js\").Options} [gmlOptions] GML options for the WFS transaction writer.\n * @property {string} [version='1.1.0'] WFS version to use for the transaction. Can be either `1.0.0`, `1.1.0` or `2.0.0`.\n */\n\n/**\n * Number of features; bounds/extent.\n * @typedef {Object} FeatureCollectionMetadata\n * @property {number} numberOfFeatures NumberOfFeatures.\n * @property {import(\"../extent.js\").Extent} bounds Bounds.\n */\n\n/**\n * @typedef {Object} TransactionSummary\n * @property {number} totalDeleted TotalDeleted.\n * @property {number} totalInserted TotalInserted.\n * @property {number} totalUpdated TotalUpdated.\n */\n\n/**\n * Total deleted; total inserted; total updated; array of insert ids.\n * @typedef {Object} TransactionResponse\n * @property {TransactionSummary} transactionSummary Transaction summary.\n * @property {Array<string>} insertIds InsertIds.\n */\n\n/**\n * @type {string}\n */\nconst FEATURE_PREFIX = 'feature';\n\n/**\n * @type {string}\n */\nconst XMLNS = 'http://www.w3.org/2000/xmlns/';\n\n/**\n * @type {Object<string, string>}\n */\nconst OGCNS = {\n  '2.0.0': 'http://www.opengis.net/ogc/1.1',\n  '1.1.0': 'http://www.opengis.net/ogc',\n  '1.0.0': 'http://www.opengis.net/ogc',\n};\n\n/**\n * @type {Object<string, string>}\n */\nconst WFSNS = {\n  '2.0.0': 'http://www.opengis.net/wfs/2.0',\n  '1.1.0': 'http://www.opengis.net/wfs',\n  '1.0.0': 'http://www.opengis.net/wfs',\n};\n\n/**\n * @type {Object<string, string>}\n */\nconst FESNS = {\n  '2.0.0': 'http://www.opengis.net/fes/2.0',\n  '1.1.0': 'http://www.opengis.net/fes',\n  '1.0.0': 'http://www.opengis.net/fes',\n};\n\n/**\n * @type {Object<string, string>}\n */\nconst SCHEMA_LOCATIONS = {\n  '2.0.0':\n    'http://www.opengis.net/wfs/2.0 http://schemas.opengis.net/wfs/2.0/wfs.xsd',\n  '1.1.0':\n    'http://www.opengis.net/wfs http://schemas.opengis.net/wfs/1.1.0/wfs.xsd',\n  '1.0.0':\n    'http://www.opengis.net/wfs http://schemas.opengis.net/wfs/1.0.0/wfs.xsd',\n};\n\n/**\n * @type {Object<string, object>}\n */\nconst GML_FORMATS = {\n  '2.0.0': GML32,\n  '1.1.0': GML3,\n  '1.0.0': GML2,\n};\n\n/**\n * @const\n * @type {string}\n */\nconst DEFAULT_VERSION = '1.1.0';\n\n/**\n * @classdesc\n * Feature format for reading and writing data in the WFS format.\n * By default, supports WFS version 1.1.0. You can pass a GML format\n * as option to override the default.\n * Also see {@link module:ol/format/GMLBase~GMLBase} which is used by this format.\n *\n * @api\n */\nclass WFS extends XMLFeature {\n  /**\n   * @param {Options} [options] Optional configuration object.\n   */\n  constructor(options) {\n    super();\n\n    options = options ? options : {};\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.version_ = options.version ? options.version : DEFAULT_VERSION;\n\n    /**\n     * @private\n     * @type {Array<string>|string|undefined}\n     */\n    this.featureType_ = options.featureType;\n\n    /**\n     * @private\n     * @type {Object<string, string>|string|undefined}\n     */\n    this.featureNS_ = options.featureNS;\n\n    /**\n     * @private\n     * @type {GMLBase}\n     */\n    this.gmlFormat_ = options.gmlFormat\n      ? options.gmlFormat\n      : new GML_FORMATS[this.version_]();\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.schemaLocation_ = options.schemaLocation\n      ? options.schemaLocation\n      : SCHEMA_LOCATIONS[this.version_];\n  }\n\n  /**\n   * @return {Array<string>|string|undefined} featureType\n   */\n  getFeatureType() {\n    return this.featureType_;\n  }\n\n  /**\n   * @param {Array<string>|string|undefined} featureType Feature type(s) to parse.\n   */\n  setFeatureType(featureType) {\n    this.featureType_ = featureType;\n  }\n\n  /**\n   * @protected\n   * @param {Element} node Node.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @return {Array<import(\"../Feature.js\").default>} Features.\n   * @override\n   */\n  readFeaturesFromNode(node, options) {\n    /** @type {import(\"../xml.js\").NodeStackItem} */\n    const context = {\n      node,\n    };\n    Object.assign(context, {\n      'featureType': this.featureType_,\n      'featureNS': this.featureNS_,\n    });\n\n    Object.assign(context, this.getReadOptions(node, options ? options : {}));\n    const objectStack = [context];\n    let featuresNS;\n    if (this.version_ === '2.0.0') {\n      featuresNS = FEATURE_COLLECTION_PARSERS;\n    } else {\n      featuresNS = this.gmlFormat_.FEATURE_COLLECTION_PARSERS;\n    }\n    let features = pushParseAndPop(\n      [],\n      featuresNS,\n      node,\n      objectStack,\n      this.gmlFormat_,\n    );\n    if (!features) {\n      features = [];\n    }\n    return features;\n  }\n\n  /**\n   * Read transaction response of the source.\n   *\n   * @param {Document|Element|Object|string} source Source.\n   * @return {TransactionResponse|undefined} Transaction response.\n   * @api\n   */\n  readTransactionResponse(source) {\n    if (!source) {\n      return undefined;\n    }\n    if (typeof source === 'string') {\n      const doc = parse(source);\n      return this.readTransactionResponseFromDocument(doc);\n    }\n    if (isDocument(source)) {\n      return this.readTransactionResponseFromDocument(\n        /** @type {Document} */ (source),\n      );\n    }\n    return this.readTransactionResponseFromNode(\n      /** @type {Element} */ (source),\n    );\n  }\n\n  /**\n   * Read feature collection metadata of the source.\n   *\n   * @param {Document|Element|Object|string} source Source.\n   * @return {FeatureCollectionMetadata|undefined}\n   *     FeatureCollection metadata.\n   * @api\n   */\n  readFeatureCollectionMetadata(source) {\n    if (!source) {\n      return undefined;\n    }\n    if (typeof source === 'string') {\n      const doc = parse(source);\n      return this.readFeatureCollectionMetadataFromDocument(doc);\n    }\n    if (isDocument(source)) {\n      return this.readFeatureCollectionMetadataFromDocument(\n        /** @type {Document} */ (source),\n      );\n    }\n    return this.readFeatureCollectionMetadataFromNode(\n      /** @type {Element} */ (source),\n    );\n  }\n\n  /**\n   * @param {Document} doc Document.\n   * @return {FeatureCollectionMetadata|undefined}\n   *     FeatureCollection metadata.\n   */\n  readFeatureCollectionMetadataFromDocument(doc) {\n    for (let n = /** @type {Node} */ (doc.firstChild); n; n = n.nextSibling) {\n      if (n.nodeType == Node.ELEMENT_NODE) {\n        return this.readFeatureCollectionMetadataFromNode(\n          /** @type {Element} */ (n),\n        );\n      }\n    }\n    return undefined;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @return {FeatureCollectionMetadata|undefined}\n   *     FeatureCollection metadata.\n   */\n  readFeatureCollectionMetadataFromNode(node) {\n    const result = {};\n    const value = readNonNegativeIntegerString(\n      node.getAttribute('numberOfFeatures'),\n    );\n    result['numberOfFeatures'] = value;\n    return pushParseAndPop(\n      /** @type {FeatureCollectionMetadata} */ (result),\n      FEATURE_COLLECTION_PARSERS,\n      node,\n      [],\n      this.gmlFormat_,\n    );\n  }\n\n  /**\n   * @param {Document} doc Document.\n   * @return {TransactionResponse|undefined} Transaction response.\n   */\n  readTransactionResponseFromDocument(doc) {\n    for (let n = /** @type {Node} */ (doc.firstChild); n; n = n.nextSibling) {\n      if (n.nodeType == Node.ELEMENT_NODE) {\n        return this.readTransactionResponseFromNode(/** @type {Element} */ (n));\n      }\n    }\n    return undefined;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @return {TransactionResponse|undefined} Transaction response.\n   */\n  readTransactionResponseFromNode(node) {\n    return pushParseAndPop(\n      /** @type {TransactionResponse} */ ({}),\n      TRANSACTION_RESPONSE_PARSERS,\n      node,\n      [],\n    );\n  }\n\n  /**\n   * Encode format as WFS `GetFeature` and return the Node.\n   *\n   * @param {WriteGetFeatureOptions} options Options.\n   * @return {Node} Result.\n   * @api\n   */\n  writeGetFeature(options) {\n    const node = createElementNS(WFSNS[this.version_], 'GetFeature');\n    node.setAttribute('service', 'WFS');\n    node.setAttribute('version', this.version_);\n    if (options.handle) {\n      node.setAttribute('handle', options.handle);\n    }\n    if (options.outputFormat) {\n      node.setAttribute('outputFormat', options.outputFormat);\n    }\n    if (options.maxFeatures !== undefined) {\n      node.setAttribute('maxFeatures', String(options.maxFeatures));\n    }\n    if (options.resultType) {\n      node.setAttribute('resultType', options.resultType);\n    }\n    if (options.startIndex !== undefined) {\n      node.setAttribute('startIndex', String(options.startIndex));\n    }\n    if (options.count !== undefined) {\n      node.setAttribute('count', String(options.count));\n    }\n    if (options.viewParams !== undefined) {\n      node.setAttribute('viewParams', options.viewParams);\n    }\n    node.setAttributeNS(\n      XML_SCHEMA_INSTANCE_URI,\n      'xsi:schemaLocation',\n      this.schemaLocation_,\n    );\n    /** @type {import(\"../xml.js\").NodeStackItem} */\n    const context = {\n      node,\n    };\n    Object.assign(context, {\n      'version': this.version_,\n      'srsName': options.srsName,\n      'featureNS': options.featureNS ? options.featureNS : this.featureNS_,\n      'featurePrefix': options.featurePrefix,\n      'propertyNames': options.propertyNames ? options.propertyNames : [],\n    });\n    assert(\n      Array.isArray(options.featureTypes),\n      '`options.featureTypes` must be an Array',\n    );\n    if (typeof options.featureTypes[0] === 'string') {\n      let filter = options.filter;\n      if (options.bbox) {\n        assert(\n          options.geometryName,\n          '`options.geometryName` must also be provided when `options.bbox` is set',\n        );\n        filter = this.combineBboxAndFilter(\n          options.geometryName,\n          options.bbox,\n          options.srsName,\n          filter,\n        );\n      }\n      Object.assign(context, {\n        'geometryName': options.geometryName,\n        'filter': filter,\n      });\n      writeGetFeature(\n        node,\n        /** @type {!Array<string>} */ (options.featureTypes),\n        [context],\n      );\n    } else {\n      // Write one query node per element in featuresType.\n      options.featureTypes.forEach((/** @type {FeatureType} */ featureType) => {\n        const completeFilter = this.combineBboxAndFilter(\n          featureType.geometryName,\n          featureType.bbox,\n          options.srsName,\n          options.filter,\n        );\n        Object.assign(context, {\n          'geometryName': featureType.geometryName,\n          'filter': completeFilter,\n        });\n        writeGetFeature(node, [featureType.name], [context]);\n      });\n    }\n    return node;\n  }\n\n  /**\n   * Create a bbox filter and combine it with another optional filter.\n   *\n   * @param {!string} geometryName Geometry name to use.\n   * @param {!import(\"../extent.js\").Extent} extent Extent.\n   * @param {string} [srsName] SRS name. No srsName attribute will be\n   *    set on geometries when this is not provided.\n   * @param {import(\"./filter/Filter.js\").default} [filter] Filter condition.\n   * @return {import(\"./filter/Filter.js\").default} The filter.\n   */\n  combineBboxAndFilter(geometryName, extent, srsName, filter) {\n    const bboxFilter = bboxFilterFn(geometryName, extent, srsName);\n    if (filter) {\n      // if bbox and filter are both set, combine the two into a single filter\n      return andFilterFn(filter, bboxFilter);\n    }\n    return bboxFilter;\n  }\n\n  /**\n   * Encode format as WFS `Transaction` and return the Node.\n   *\n   * @param {Array<import(\"../Feature.js\").default>} inserts The features to insert.\n   * @param {Array<import(\"../Feature.js\").default>} updates The features to update.\n   * @param {Array<import(\"../Feature.js\").default>} deletes The features to delete.\n   * @param {WriteTransactionOptions} options Write options.\n   * @return {Node} Result.\n   * @api\n   */\n  writeTransaction(inserts, updates, deletes, options) {\n    const objectStack = [];\n    const version = options.version ? options.version : this.version_;\n    const node = createElementNS(WFSNS[version], 'Transaction');\n\n    node.setAttribute('service', 'WFS');\n    node.setAttribute('version', version);\n    let baseObj;\n    /** @type {import(\"../xml.js\").NodeStackItem} */\n    if (options) {\n      baseObj = options.gmlOptions ? options.gmlOptions : {};\n      if (options.handle) {\n        node.setAttribute('handle', options.handle);\n      }\n    }\n    node.setAttributeNS(\n      XML_SCHEMA_INSTANCE_URI,\n      'xsi:schemaLocation',\n      SCHEMA_LOCATIONS[version],\n    );\n\n    const request = createTransactionRequest(node, baseObj, version, options);\n    if (inserts) {\n      serializeTransactionRequest('Insert', inserts, objectStack, request);\n    }\n    if (updates) {\n      serializeTransactionRequest('Update', updates, objectStack, request);\n    }\n    if (deletes) {\n      serializeTransactionRequest('Delete', deletes, objectStack, request);\n    }\n    if (options.nativeElements) {\n      serializeTransactionRequest(\n        'Native',\n        options.nativeElements,\n        objectStack,\n        request,\n      );\n    }\n    return node;\n  }\n\n  /**\n   * @param {Document} doc Document.\n   * @return {import(\"../proj/Projection.js\").default} Projection.\n   * @override\n   */\n  readProjectionFromDocument(doc) {\n    for (let n = doc.firstChild; n; n = n.nextSibling) {\n      if (n.nodeType == Node.ELEMENT_NODE) {\n        return this.readProjectionFromNode(/** @type {Element} */ (n));\n      }\n    }\n    return null;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @return {import(\"../proj/Projection.js\").default} Projection.\n   * @override\n   */\n  readProjectionFromNode(node) {\n    if (node.firstElementChild && node.firstElementChild.firstElementChild) {\n      node = node.firstElementChild.firstElementChild;\n      for (let n = node.firstElementChild; n; n = n.nextElementSibling) {\n        if (\n          !(\n            n.childNodes.length === 0 ||\n            (n.childNodes.length === 1 && n.firstChild.nodeType === 3)\n          )\n        ) {\n          const objectStack = [{}];\n          this.gmlFormat_.readGeometryElement(n, objectStack);\n          return getProjection(objectStack.pop().srsName);\n        }\n      }\n    }\n\n    return null;\n  }\n}\n\n/**\n * @param {Element} node Node.\n * @param {*} baseObj Base object.\n * @param {string} version Version.\n * @param {WriteTransactionOptions} options Options.\n * @return {Object} Request object.\n */\nfunction createTransactionRequest(node, baseObj, version, options) {\n  const featurePrefix = options.featurePrefix\n    ? options.featurePrefix\n    : FEATURE_PREFIX;\n  let gmlVersion;\n  if (version === '1.0.0') {\n    gmlVersion = 2;\n  } else if (version === '1.1.0') {\n    gmlVersion = 3;\n  } else if (version === '2.0.0') {\n    gmlVersion = 3.2;\n  }\n  const obj = Object.assign(\n    {node},\n    {\n      version,\n      'featureNS': options.featureNS,\n      'featureType': options.featureType,\n      'featurePrefix': featurePrefix,\n      'gmlVersion': gmlVersion,\n      'hasZ': options.hasZ,\n      'srsName': options.srsName,\n    },\n    baseObj,\n  );\n  return obj;\n}\n\n/**\n * @param {string} type Request type.\n * @param {Array<import(\"../Feature.js\").default>} features Features.\n * @param {Array<*>} objectStack Object stack.\n * @param {Element} request Transaction Request.\n */\nfunction serializeTransactionRequest(type, features, objectStack, request) {\n  pushSerializeAndPop(\n    request,\n    TRANSACTION_SERIALIZERS,\n    makeSimpleNodeFactory(type),\n    features,\n    objectStack,\n  );\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Transaction Summary.\n */\nfunction readTransactionSummary(node, objectStack) {\n  return pushParseAndPop({}, TRANSACTION_SUMMARY_PARSERS, node, objectStack);\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nconst OGC_FID_PARSERS = {\n  'http://www.opengis.net/ogc': {\n    'FeatureId': makeArrayPusher(function (node, objectStack) {\n      return node.getAttribute('fid');\n    }),\n  },\n  'http://www.opengis.net/ogc/1.1': {\n    'FeatureId': makeArrayPusher(function (node, objectStack) {\n      return node.getAttribute('fid');\n    }),\n  },\n};\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n */\nfunction fidParser(node, objectStack) {\n  parseNode(OGC_FID_PARSERS, node, objectStack);\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\nconst INSERT_RESULTS_PARSERS = {\n  'http://www.opengis.net/wfs': {\n    'Feature': fidParser,\n  },\n  'http://www.opengis.net/wfs/2.0': {\n    'Feature': fidParser,\n  },\n};\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Array<string>|undefined} Insert results.\n */\nfunction readInsertResults(node, objectStack) {\n  return pushParseAndPop([], INSERT_RESULTS_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {import(\"../Feature.js\").default} feature Feature.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeFeature(node, feature, objectStack) {\n  const context = objectStack[objectStack.length - 1];\n  const featureType = context['featureType'];\n  const featureNS = context['featureNS'];\n  const gmlVersion = context['gmlVersion'];\n  const child = createElementNS(featureNS, featureType);\n  node.appendChild(child);\n  if (gmlVersion === 2) {\n    GML2.prototype.writeFeatureElement(child, feature, objectStack);\n  } else if (gmlVersion === 3) {\n    GML3.prototype.writeFeatureElement(child, feature, objectStack);\n  } else {\n    GML32.prototype.writeFeatureElement(child, feature, objectStack);\n  }\n}\n\n/**\n * @param {Node} node Node.\n * @param {number|string} fid Feature identifier.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeOgcFidFilter(node, fid, objectStack) {\n  const context = objectStack[objectStack.length - 1];\n  const version = context['version'];\n  const ns = OGCNS[version];\n  const filter = createElementNS(ns, 'Filter');\n  const child = createElementNS(ns, 'FeatureId');\n  filter.appendChild(child);\n  child.setAttribute('fid', /** @type {string} */ (fid));\n  node.appendChild(filter);\n}\n\n/**\n * @param {string|undefined} featurePrefix The prefix of the feature.\n * @param {string} featureType The type of the feature.\n * @return {string} The value of the typeName property.\n */\nfunction getTypeName(featurePrefix, featureType) {\n  featurePrefix = featurePrefix ? featurePrefix : FEATURE_PREFIX;\n  const prefix = featurePrefix + ':';\n  // The featureType already contains the prefix.\n  if (featureType.startsWith(prefix)) {\n    return featureType;\n  }\n  return prefix + featureType;\n}\n\n/**\n * @param {Element} node Node.\n * @param {import(\"../Feature.js\").default} feature Feature.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeDelete(node, feature, objectStack) {\n  const context = objectStack[objectStack.length - 1];\n  assert(feature.getId() !== undefined, 'Features must have an id set');\n  const featureType = context['featureType'];\n  const featurePrefix = context['featurePrefix'];\n  const featureNS = context['featureNS'];\n  const typeName = getTypeName(featurePrefix, featureType);\n  node.setAttribute('typeName', typeName);\n  node.setAttributeNS(XMLNS, 'xmlns:' + featurePrefix, featureNS);\n  const fid = feature.getId();\n  if (fid !== undefined) {\n    writeOgcFidFilter(node, fid, objectStack);\n  }\n}\n\n/**\n * @param {Element} node Node.\n * @param {import(\"../Feature.js\").default} feature Feature.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeUpdate(node, feature, objectStack) {\n  const context = objectStack[objectStack.length - 1];\n  assert(feature.getId() !== undefined, 'Features must have an id set');\n  const version = context['version'];\n  const featureType = context['featureType'];\n  const featurePrefix = context['featurePrefix'];\n  const featureNS = context['featureNS'];\n  const typeName = getTypeName(featurePrefix, featureType);\n  const geometryName = feature.getGeometryName();\n  node.setAttribute('typeName', typeName);\n  node.setAttributeNS(XMLNS, 'xmlns:' + featurePrefix, featureNS);\n  const fid = feature.getId();\n  if (fid !== undefined) {\n    const keys = feature.getKeys();\n    const values = [];\n    for (let i = 0, ii = keys.length; i < ii; i++) {\n      const value = feature.get(keys[i]);\n      if (value !== undefined) {\n        let name = keys[i];\n        if (\n          value &&\n          typeof (/** @type {?} */ (value).getSimplifiedGeometry) === 'function'\n        ) {\n          name = geometryName;\n        }\n        values.push({name: name, value: value});\n      }\n    }\n    pushSerializeAndPop(\n      /** @type {import(\"../xml.js\").NodeStackItem} */ ({\n        version,\n        'gmlVersion': context['gmlVersion'],\n        node,\n        'hasZ': context['hasZ'],\n        'srsName': context['srsName'],\n      }),\n      TRANSACTION_SERIALIZERS,\n      makeSimpleNodeFactory('Property'),\n      values,\n      objectStack,\n    );\n    writeOgcFidFilter(node, fid, objectStack);\n  }\n}\n\n/**\n * @param {Node} node Node.\n * @param {Object} pair Property name and value.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeProperty(node, pair, objectStack) {\n  const context = objectStack[objectStack.length - 1];\n  const version = context['version'];\n  const ns = WFSNS[version];\n  const tagName = version === '2.0.0' ? 'ValueReference' : 'Name';\n  const name = createElementNS(ns, tagName);\n  const gmlVersion = context['gmlVersion'];\n  node.appendChild(name);\n  writeStringTextNode(name, pair.name);\n  if (pair.value !== undefined && pair.value !== null) {\n    const value = createElementNS(ns, 'Value');\n    node.appendChild(value);\n    if (\n      pair.value &&\n      typeof (/** @type {?} */ (pair.value).getSimplifiedGeometry) ===\n        'function'\n    ) {\n      if (gmlVersion === 2) {\n        GML2.prototype.writeGeometryElement(value, pair.value, objectStack);\n      } else if (gmlVersion === 3) {\n        GML3.prototype.writeGeometryElement(value, pair.value, objectStack);\n      } else {\n        GML32.prototype.writeGeometryElement(value, pair.value, objectStack);\n      }\n    } else {\n      writeStringTextNode(value, pair.value);\n    }\n  }\n}\n\n/**\n * @param {Element} node Node.\n * @param {{vendorId: string, safeToIgnore: boolean, value: string}} nativeElement The native element.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeNative(node, nativeElement, objectStack) {\n  if (nativeElement.vendorId) {\n    node.setAttribute('vendorId', nativeElement.vendorId);\n  }\n  if (nativeElement.safeToIgnore !== undefined) {\n    node.setAttribute('safeToIgnore', String(nativeElement.safeToIgnore));\n  }\n  if (nativeElement.value !== undefined) {\n    writeStringTextNode(node, nativeElement.value);\n  }\n}\n\n/**\n * @type {Object<string, Object<string, import(\"../xml.js\").Serializer>>}\n */\nconst GETFEATURE_SERIALIZERS = {\n  'http://www.opengis.net/wfs': {\n    'Query': makeChildAppender(writeQuery),\n  },\n  'http://www.opengis.net/wfs/2.0': {\n    'Query': makeChildAppender(writeQuery),\n  },\n  'http://www.opengis.net/ogc': {\n    'During': makeChildAppender(writeDuringFilter),\n    'And': makeChildAppender(writeLogicalFilter),\n    'Or': makeChildAppender(writeLogicalFilter),\n    'Not': makeChildAppender(writeNotFilter),\n    'BBOX': makeChildAppender(writeBboxFilter),\n    'Contains': makeChildAppender(writeSpatialFilter),\n    'Intersects': makeChildAppender(writeSpatialFilter),\n    'Within': makeChildAppender(writeSpatialFilter),\n    'DWithin': makeChildAppender(writeDWithinFilter),\n    'PropertyIsEqualTo': makeChildAppender(writeComparisonFilter),\n    'PropertyIsNotEqualTo': makeChildAppender(writeComparisonFilter),\n    'PropertyIsLessThan': makeChildAppender(writeComparisonFilter),\n    'PropertyIsLessThanOrEqualTo': makeChildAppender(writeComparisonFilter),\n    'PropertyIsGreaterThan': makeChildAppender(writeComparisonFilter),\n    'PropertyIsGreaterThanOrEqualTo': makeChildAppender(writeComparisonFilter),\n    'PropertyIsNull': makeChildAppender(writeIsNullFilter),\n    'PropertyIsBetween': makeChildAppender(writeIsBetweenFilter),\n    'PropertyIsLike': makeChildAppender(writeIsLikeFilter),\n  },\n  'http://www.opengis.net/fes/2.0': {\n    'During': makeChildAppender(writeDuringFilter),\n    'And': makeChildAppender(writeLogicalFilter),\n    'Or': makeChildAppender(writeLogicalFilter),\n    'Not': makeChildAppender(writeNotFilter),\n    'BBOX': makeChildAppender(writeBboxFilter),\n    'Contains': makeChildAppender(writeSpatialFilter),\n    'Disjoint': makeChildAppender(writeSpatialFilter),\n    'Intersects': makeChildAppender(writeSpatialFilter),\n    'ResourceId': makeChildAppender(writeResourceIdFilter),\n    'Within': makeChildAppender(writeSpatialFilter),\n    'DWithin': makeChildAppender(writeDWithinFilter),\n    'PropertyIsEqualTo': makeChildAppender(writeComparisonFilter),\n    'PropertyIsNotEqualTo': makeChildAppender(writeComparisonFilter),\n    'PropertyIsLessThan': makeChildAppender(writeComparisonFilter),\n    'PropertyIsLessThanOrEqualTo': makeChildAppender(writeComparisonFilter),\n    'PropertyIsGreaterThan': makeChildAppender(writeComparisonFilter),\n    'PropertyIsGreaterThanOrEqualTo': makeChildAppender(writeComparisonFilter),\n    'PropertyIsNull': makeChildAppender(writeIsNullFilter),\n    'PropertyIsBetween': makeChildAppender(writeIsBetweenFilter),\n    'PropertyIsLike': makeChildAppender(writeIsLikeFilter),\n  },\n};\n\n/**\n * @param {Element} node Node.\n * @param {string} featureType Feature type.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeQuery(node, featureType, objectStack) {\n  const context = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const version = context['version'];\n  const featurePrefix = context['featurePrefix'];\n  const featureNS = context['featureNS'];\n  const propertyNames = context['propertyNames'];\n  const srsName = context['srsName'];\n  let typeName;\n  // If feature prefix is not defined, we must not use the default prefix.\n  if (featurePrefix) {\n    typeName = getTypeName(featurePrefix, featureType);\n  } else {\n    typeName = featureType;\n  }\n  let typeNameAttr;\n  if (version === '2.0.0') {\n    typeNameAttr = 'typeNames';\n  } else {\n    typeNameAttr = 'typeName';\n  }\n  node.setAttribute(typeNameAttr, typeName);\n  if (srsName) {\n    node.setAttribute('srsName', srsName);\n  }\n  if (featureNS) {\n    node.setAttributeNS(XMLNS, 'xmlns:' + featurePrefix, featureNS);\n  }\n  const item = /** @type {import(\"../xml.js\").NodeStackItem} */ (\n    Object.assign({}, context)\n  );\n  item.node = node;\n  pushSerializeAndPop(\n    item,\n    QUERY_SERIALIZERS,\n    makeSimpleNodeFactory('PropertyName'),\n    propertyNames,\n    objectStack,\n  );\n  const filter = context['filter'];\n  if (filter) {\n    const child = createElementNS(getFilterNS(version), 'Filter');\n    node.appendChild(child);\n    writeFilterCondition(child, filter, objectStack);\n  }\n}\n\n/**\n * @param {Element} node Node.\n * @param {import(\"./filter/Filter.js\").default} filter Filter.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeFilterCondition(node, filter, objectStack) {\n  const context = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  /** @type {import(\"../xml.js\").NodeStackItem} */\n  const item = {node};\n  Object.assign(item, {context});\n  pushSerializeAndPop(\n    item,\n    GETFEATURE_SERIALIZERS,\n    makeSimpleNodeFactory(filter.getTagName()),\n    [filter],\n    objectStack,\n  );\n}\n\n/**\n * @param {Node} node Node.\n * @param {import(\"./filter/Bbox.js\").default} filter Filter.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeBboxFilter(node, filter, objectStack) {\n  const parent = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const context = parent['context'];\n  const version = context['version'];\n  parent['srsName'] = filter.srsName;\n  const format = GML_FORMATS[version];\n\n  writePropertyName(version, node, filter.geometryName);\n  format.prototype.writeGeometryElement(node, filter.extent, objectStack);\n}\n\n/**\n * @param {Element} node Element.\n * @param {import(\"./filter/ResourceId.js\").default} filter Filter.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeResourceIdFilter(node, filter, objectStack) {\n  node.setAttribute('rid', /** @type {string} */ (filter.rid));\n}\n\n/**\n * @param {Node} node Node.\n * @param {import(\"./filter/Spatial.js\").default} filter Filter.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeSpatialFilter(node, filter, objectStack) {\n  const parent = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const context = parent['context'];\n  const version = context['version'];\n  parent['srsName'] = filter.srsName;\n  const format = GML_FORMATS[version];\n\n  writePropertyName(version, node, filter.geometryName);\n  format.prototype.writeGeometryElement(node, filter.geometry, objectStack);\n}\n\n/**\n * @param {Node} node Node.\n * @param {import(\"./filter/DWithin.js\").default} filter Filter.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeDWithinFilter(node, filter, objectStack) {\n  const parent = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const context = parent['context'];\n  const version = context['version'];\n  writeSpatialFilter(node, filter, objectStack);\n  const distance = createElementNS(getFilterNS(version), 'Distance');\n  writeStringTextNode(distance, filter.distance.toString());\n  if (version === '2.0.0') {\n    distance.setAttribute('uom', filter.unit);\n  } else {\n    distance.setAttribute('units', filter.unit);\n  }\n  node.appendChild(distance);\n}\n\n/**\n * @param {Node} node Node.\n * @param {import(\"./filter/During.js\").default} filter Filter.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeDuringFilter(node, filter, objectStack) {\n  const parent = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const context = parent['context'];\n  const version = context['version'];\n\n  writeExpression(FESNS[version], 'ValueReference', node, filter.propertyName);\n  const timePeriod = createElementNS(GMLNS, 'TimePeriod');\n\n  node.appendChild(timePeriod);\n\n  const begin = createElementNS(GMLNS, 'begin');\n  timePeriod.appendChild(begin);\n  writeTimeInstant(begin, filter.begin);\n\n  const end = createElementNS(GMLNS, 'end');\n  timePeriod.appendChild(end);\n  writeTimeInstant(end, filter.end);\n}\n\n/**\n * @param {Element} node Node.\n * @param {import(\"./filter/LogicalNary.js\").default} filter Filter.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeLogicalFilter(node, filter, objectStack) {\n  const parent = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const context = parent['context'];\n  /** @type {import(\"../xml.js\").NodeStackItem} */\n  const item = {node};\n  Object.assign(item, {context});\n  const conditions = filter.conditions;\n  for (let i = 0, ii = conditions.length; i < ii; ++i) {\n    const condition = conditions[i];\n    pushSerializeAndPop(\n      item,\n      GETFEATURE_SERIALIZERS,\n      makeSimpleNodeFactory(condition.getTagName()),\n      [condition],\n      objectStack,\n    );\n  }\n}\n\n/**\n * @param {Element} node Node.\n * @param {import(\"./filter/Not.js\").default} filter Filter.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeNotFilter(node, filter, objectStack) {\n  const parent = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const context = parent['context'];\n  /** @type {import(\"../xml.js\").NodeStackItem} */\n  const item = {node};\n  Object.assign(item, {context});\n  const condition = filter.condition;\n  pushSerializeAndPop(\n    item,\n    GETFEATURE_SERIALIZERS,\n    makeSimpleNodeFactory(condition.getTagName()),\n    [condition],\n    objectStack,\n  );\n}\n\n/**\n * @param {Element} node Node.\n * @param {import(\"./filter/ComparisonBinary.js\").default} filter Filter.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeComparisonFilter(node, filter, objectStack) {\n  const parent = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const context = parent['context'];\n  const version = context['version'];\n  if (filter.matchCase !== undefined) {\n    node.setAttribute('matchCase', filter.matchCase.toString());\n  }\n  writePropertyName(version, node, filter.propertyName);\n  writeLiteral(version, node, '' + filter.expression);\n}\n\n/**\n * @param {Node} node Node.\n * @param {import(\"./filter/IsNull.js\").default} filter Filter.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeIsNullFilter(node, filter, objectStack) {\n  const parent = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const context = parent['context'];\n  const version = context['version'];\n  writePropertyName(version, node, filter.propertyName);\n}\n\n/**\n * @param {Node} node Node.\n * @param {import(\"./filter/IsBetween.js\").default} filter Filter.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeIsBetweenFilter(node, filter, objectStack) {\n  const parent = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const context = parent['context'];\n  const version = context['version'];\n  const ns = getFilterNS(version);\n\n  writePropertyName(version, node, filter.propertyName);\n\n  const lowerBoundary = createElementNS(ns, 'LowerBoundary');\n  node.appendChild(lowerBoundary);\n  writeLiteral(version, lowerBoundary, '' + filter.lowerBoundary);\n\n  const upperBoundary = createElementNS(ns, 'UpperBoundary');\n  node.appendChild(upperBoundary);\n  writeLiteral(version, upperBoundary, '' + filter.upperBoundary);\n}\n\n/**\n * @param {Element} node Node.\n * @param {import(\"./filter/IsLike.js\").default} filter Filter.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeIsLikeFilter(node, filter, objectStack) {\n  const parent = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const context = parent['context'];\n  const version = context['version'];\n  node.setAttribute('wildCard', filter.wildCard);\n  node.setAttribute('singleChar', filter.singleChar);\n  node.setAttribute('escapeChar', filter.escapeChar);\n  if (filter.matchCase !== undefined) {\n    node.setAttribute('matchCase', filter.matchCase.toString());\n  }\n  writePropertyName(version, node, filter.propertyName);\n  writeLiteral(version, node, '' + filter.pattern);\n}\n\n/**\n * @param {string} ns Namespace.\n * @param {string} tagName Tag name.\n * @param {Node} node Node.\n * @param {string} value Value.\n */\nfunction writeExpression(ns, tagName, node, value) {\n  const property = createElementNS(ns, tagName);\n  writeStringTextNode(property, value);\n  node.appendChild(property);\n}\n\n/**\n * @param {string} version Version.\n * @param {Node} node Node.\n * @param {string} value PropertyName value.\n */\nfunction writeLiteral(version, node, value) {\n  writeExpression(getFilterNS(version), 'Literal', node, value);\n}\n\n/**\n * @param {string} version Version.\n * @param {Node} node Node.\n * @param {string} value PropertyName value.\n */\nfunction writePropertyName(version, node, value) {\n  if (version === '2.0.0') {\n    writeExpression(FESNS[version], 'ValueReference', node, value);\n  } else {\n    writeExpression(OGCNS[version], 'PropertyName', node, value);\n  }\n}\n\n/**\n * @param {Node} node Node.\n * @param {string} time PropertyName value.\n */\nfunction writeTimeInstant(node, time) {\n  const timeInstant = createElementNS(GMLNS, 'TimeInstant');\n  node.appendChild(timeInstant);\n\n  const timePosition = createElementNS(GMLNS, 'timePosition');\n  timeInstant.appendChild(timePosition);\n  writeStringTextNode(timePosition, time);\n}\n\n/**\n * Encode filter as WFS `Filter` and return the Node.\n *\n * @param {import(\"./filter/Filter.js\").default} filter Filter.\n * @param {string} version WFS version. If not provided defaults to '1.1.0'\n * @return {Node} Result.\n * @api\n */\nexport function writeFilter(filter, version) {\n  version = version || '1.1.0';\n  const child = createElementNS(getFilterNS(version), 'Filter');\n  const context = {\n    node: child,\n  };\n  Object.assign(context, {\n    'version': version,\n    'filter': filter,\n  });\n  writeFilterCondition(child, filter, [context]);\n  return child;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<string>} featureTypes Feature types.\n * @param {Array<*>} objectStack Node stack.\n */\nfunction writeGetFeature(node, featureTypes, objectStack) {\n  const context = /** @type {Object} */ (objectStack[objectStack.length - 1]);\n  const item = /** @type {import(\"../xml.js\").NodeStackItem} */ (\n    Object.assign({}, context)\n  );\n  item.node = node;\n  pushSerializeAndPop(\n    item,\n    GETFEATURE_SERIALIZERS,\n    makeSimpleNodeFactory('Query'),\n    featureTypes,\n    objectStack,\n  );\n}\n\nfunction getFilterNS(version) {\n  let ns;\n  if (version === '2.0.0') {\n    ns = FESNS[version];\n  } else {\n    ns = OGCNS[version];\n  }\n  return ns;\n}\n\nexport default WFS;\n","/**\n * @module ol/format/WMTSCapabilities\n */\nimport {boundingExtent} from '../extent.js';\nimport {\n  makeArrayPusher,\n  makeObjectPropertyPusher,\n  makeObjectPropertySetter,\n  makeStructureNS,\n  pushParseAndPop,\n} from '../xml.js';\nimport OWS from './OWS.js';\nimport XML from './XML.js';\nimport {readHref} from './xlink.js';\nimport {readDecimal, readPositiveInteger, readString} from './xsd.js';\n\n/**\n * @const\n * @type {Array<null|string>}\n */\nconst NAMESPACE_URIS = [null, 'http://www.opengis.net/wmts/1.0'];\n\n/**\n * @const\n * @type {Array<null|string>}\n */\nconst OWS_NAMESPACE_URIS = [null, 'http://www.opengis.net/ows/1.1'];\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Contents': makeObjectPropertySetter(readContents),\n});\n\n/**\n * @classdesc\n * Format for reading WMTS capabilities data.\n *\n * @api\n */\nclass WMTSCapabilities extends XML {\n  constructor() {\n    super();\n\n    /**\n     * @type {OWS}\n     * @private\n     */\n    this.owsParser_ = new OWS();\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @return {Object|null} Object\n   * @override\n   */\n  readFromNode(node) {\n    let version = node.getAttribute('version');\n    if (version) {\n      version = version.trim();\n    }\n    let WMTSCapabilityObject = this.owsParser_.readFromNode(node);\n    if (!WMTSCapabilityObject) {\n      return null;\n    }\n    WMTSCapabilityObject['version'] = version;\n    WMTSCapabilityObject = pushParseAndPop(\n      WMTSCapabilityObject,\n      PARSERS,\n      node,\n      [],\n    );\n    return WMTSCapabilityObject ? WMTSCapabilityObject : null;\n  }\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst CONTENTS_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Layer': makeObjectPropertyPusher(readLayer),\n  'TileMatrixSet': makeObjectPropertyPusher(readTileMatrixSet),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst LAYER_PARSERS = makeStructureNS(\n  NAMESPACE_URIS,\n  {\n    'Style': makeObjectPropertyPusher(readStyle),\n    'Format': makeObjectPropertyPusher(readString),\n    'TileMatrixSetLink': makeObjectPropertyPusher(readTileMatrixSetLink),\n    'Dimension': makeObjectPropertyPusher(readDimensions),\n    'ResourceURL': makeObjectPropertyPusher(readResourceUrl),\n  },\n  makeStructureNS(OWS_NAMESPACE_URIS, {\n    'Title': makeObjectPropertySetter(readString),\n    'Abstract': makeObjectPropertySetter(readString),\n    'WGS84BoundingBox': makeObjectPropertySetter(readBoundingBox),\n    'BoundingBox': makeObjectPropertyPusher(readBoundingBoxWithCrs),\n    'Identifier': makeObjectPropertySetter(readString),\n  }),\n);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst STYLE_PARSERS = makeStructureNS(\n  NAMESPACE_URIS,\n  {\n    'LegendURL': makeObjectPropertyPusher(readLegendUrl),\n  },\n  makeStructureNS(OWS_NAMESPACE_URIS, {\n    'Title': makeObjectPropertySetter(readString),\n    'Identifier': makeObjectPropertySetter(readString),\n  }),\n);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst TMS_LINKS_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'TileMatrixSet': makeObjectPropertySetter(readString),\n  'TileMatrixSetLimits': makeObjectPropertySetter(readTileMatrixLimitsList),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst TMS_LIMITS_LIST_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'TileMatrixLimits': makeArrayPusher(readTileMatrixLimits),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst TMS_LIMITS_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'TileMatrix': makeObjectPropertySetter(readString),\n  'MinTileRow': makeObjectPropertySetter(readPositiveInteger),\n  'MaxTileRow': makeObjectPropertySetter(readPositiveInteger),\n  'MinTileCol': makeObjectPropertySetter(readPositiveInteger),\n  'MaxTileCol': makeObjectPropertySetter(readPositiveInteger),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst DIMENSION_PARSERS = makeStructureNS(\n  NAMESPACE_URIS,\n  {\n    'Default': makeObjectPropertySetter(readString),\n    'Value': makeObjectPropertyPusher(readString),\n  },\n  makeStructureNS(OWS_NAMESPACE_URIS, {\n    'Identifier': makeObjectPropertySetter(readString),\n  }),\n);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst WGS84_BBOX_READERS = makeStructureNS(OWS_NAMESPACE_URIS, {\n  'LowerCorner': makeArrayPusher(readCoordinates),\n  'UpperCorner': makeArrayPusher(readCoordinates),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst TMS_PARSERS = makeStructureNS(\n  NAMESPACE_URIS,\n  {\n    'WellKnownScaleSet': makeObjectPropertySetter(readString),\n    'TileMatrix': makeObjectPropertyPusher(readTileMatrix),\n  },\n  makeStructureNS(OWS_NAMESPACE_URIS, {\n    'SupportedCRS': makeObjectPropertySetter(readString),\n    'Identifier': makeObjectPropertySetter(readString),\n    'BoundingBox': makeObjectPropertySetter(readBoundingBox),\n  }),\n);\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst TM_PARSERS = makeStructureNS(\n  NAMESPACE_URIS,\n  {\n    'TopLeftCorner': makeObjectPropertySetter(readCoordinates),\n    'ScaleDenominator': makeObjectPropertySetter(readDecimal),\n    'TileWidth': makeObjectPropertySetter(readPositiveInteger),\n    'TileHeight': makeObjectPropertySetter(readPositiveInteger),\n    'MatrixWidth': makeObjectPropertySetter(readPositiveInteger),\n    'MatrixHeight': makeObjectPropertySetter(readPositiveInteger),\n  },\n  makeStructureNS(OWS_NAMESPACE_URIS, {\n    'Identifier': makeObjectPropertySetter(readString),\n  }),\n);\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Attribution object.\n */\nfunction readContents(node, objectStack) {\n  return pushParseAndPop({}, CONTENTS_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Layers object.\n */\nfunction readLayer(node, objectStack) {\n  return pushParseAndPop({}, LAYER_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Tile Matrix Set object.\n */\nfunction readTileMatrixSet(node, objectStack) {\n  return pushParseAndPop({}, TMS_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Style object.\n */\nfunction readStyle(node, objectStack) {\n  const style = pushParseAndPop({}, STYLE_PARSERS, node, objectStack);\n  if (!style) {\n    return undefined;\n  }\n  const isDefault = node.getAttribute('isDefault') === 'true';\n  style['isDefault'] = isDefault;\n  return style;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Tile Matrix Set Link object.\n */\nfunction readTileMatrixSetLink(node, objectStack) {\n  return pushParseAndPop({}, TMS_LINKS_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Dimension object.\n */\nfunction readDimensions(node, objectStack) {\n  return pushParseAndPop({}, DIMENSION_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Resource URL object.\n */\nfunction readResourceUrl(node, objectStack) {\n  const format = node.getAttribute('format');\n  const template = node.getAttribute('template');\n  const resourceType = node.getAttribute('resourceType');\n  const resource = {};\n  if (format) {\n    resource['format'] = format;\n  }\n  if (template) {\n    resource['template'] = template;\n  }\n  if (resourceType) {\n    resource['resourceType'] = resourceType;\n  }\n  return resource;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} BBox object.\n */\nfunction readBoundingBox(node, objectStack) {\n  const coordinates = pushParseAndPop(\n    [],\n    WGS84_BBOX_READERS,\n    node,\n    objectStack,\n  );\n  if (coordinates.length != 2) {\n    return undefined;\n  }\n  return boundingExtent(coordinates);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} BBox object.\n */\nfunction readBoundingBoxWithCrs(node, objectStack) {\n  const crs = node.getAttribute('crs');\n  const coordinates = pushParseAndPop(\n    [],\n    WGS84_BBOX_READERS,\n    node,\n    objectStack,\n  );\n  if (coordinates.length != 2) {\n    return undefined;\n  }\n  return {extent: boundingExtent(coordinates), crs: crs};\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Legend object.\n */\nfunction readLegendUrl(node, objectStack) {\n  const legend = {};\n  legend['format'] = node.getAttribute('format');\n  legend['href'] = readHref(node);\n  return legend;\n}\n\n/**\n * @param {Node} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Coordinates object.\n */\nfunction readCoordinates(node, objectStack) {\n  const coordinates = readString(node).split(/\\s+/);\n  if (!coordinates || coordinates.length != 2) {\n    return undefined;\n  }\n  const x = +coordinates[0];\n  const y = +coordinates[1];\n  if (isNaN(x) || isNaN(y)) {\n    return undefined;\n  }\n  return [x, y];\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} TileMatrix object.\n */\nfunction readTileMatrix(node, objectStack) {\n  return pushParseAndPop({}, TM_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} TileMatrixSetLimits Object.\n */\nfunction readTileMatrixLimitsList(node, objectStack) {\n  return pushParseAndPop([], TMS_LIMITS_LIST_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} TileMatrixLimits Array.\n */\nfunction readTileMatrixLimits(node, objectStack) {\n  return pushParseAndPop({}, TMS_LIMITS_PARSERS, node, objectStack);\n}\n\nexport default WMTSCapabilities;\n","/**\n * @module ol/control/FullScreen\n */\nimport MapProperty from '../MapProperty.js';\nimport {CLASS_CONTROL, CLASS_UNSELECTABLE, CLASS_UNSUPPORTED} from '../css.js';\nimport {replaceNode} from '../dom.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport EventType from '../events/EventType.js';\nimport Control from './Control.js';\n\nconst events = ['fullscreenchange', 'webkitfullscreenchange'];\n\n/**\n * @enum {string}\n */\nconst FullScreenEventType = {\n  /**\n   * Triggered after the map entered fullscreen.\n   * @event FullScreenEventType#enterfullscreen\n   * @api\n   */\n  ENTERFULLSCREEN: 'enterfullscreen',\n\n  /**\n   * Triggered after the map leave fullscreen.\n   * @event FullScreenEventType#leavefullscreen\n   * @api\n   */\n  LEAVEFULLSCREEN: 'leavefullscreen',\n};\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes|\n *     'enterfullscreen'|'leavefullscreen', import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types, import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|\n *     'enterfullscreen'|'leavefullscreen'|import(\"../ObjectEventType.js\").Types, Return>} FullScreenOnSignature\n */\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-full-screen'] CSS class name.\n * @property {string|Text|HTMLElement} [label='\\u2922'] Text label to use for the button.\n * Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string|Text|HTMLElement} [labelActive='\\u00d7'] Text label to use for the\n * button when full-screen is active.\n * Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string} [activeClassName=className + '-true'] CSS class name for the button\n * when full-screen is active.\n * @property {string} [inactiveClassName=className + '-false'] CSS class name for the button\n * when full-screen is inactive.\n * @property {string} [tipLabel='Toggle full-screen'] Text label to use for the button tip.\n * @property {boolean} [keys=false] Full keyboard access.\n * @property {HTMLElement|string} [target] Specify a target if you want the\n * control to be rendered outside of the map's viewport.\n * @property {HTMLElement|string} [source] The element to be displayed\n * fullscreen. When not provided, the element containing the map viewport will\n * be displayed fullscreen.\n */\n\n/**\n * @classdesc\n * Provides a button that when clicked fills up the full screen with the map.\n * The full screen source element is by default the element containing the map viewport unless\n * overridden by providing the `source` option. In which case, the dom\n * element introduced using this parameter will be displayed in full screen.\n *\n * When in full screen mode, a close button is shown to exit full screen mode.\n * The [Fullscreen API](https://www.w3.org/TR/fullscreen/) is used to\n * toggle the map in full screen mode.\n *\n * @fires FullScreenEventType#enterfullscreen\n * @fires FullScreenEventType#leavefullscreen\n * @api\n */\nclass FullScreen extends Control {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super({\n      element: document.createElement('div'),\n      target: options.target,\n    });\n\n    /***\n     * @type {FullScreenOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {FullScreenOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {FullScreenOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.keys_ = options.keys !== undefined ? options.keys : false;\n\n    /**\n     * @private\n     * @type {HTMLElement|string|undefined}\n     */\n    this.source_ = options.source;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.isInFullscreen_ = false;\n\n    /**\n     * @private\n     */\n    this.boundHandleMapTargetChange_ = this.handleMapTargetChange_.bind(this);\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.cssClassName_ =\n      options.className !== undefined ? options.className : 'ol-full-screen';\n\n    /**\n     * @private\n     * @type {Array<import(\"../events.js\").EventsKey>}\n     */\n    this.documentListeners_ = [];\n\n    /**\n     * @private\n     * @type {Array<string>}\n     */\n    this.activeClassName_ =\n      options.activeClassName !== undefined\n        ? options.activeClassName.split(' ')\n        : [this.cssClassName_ + '-true'];\n\n    /**\n     * @private\n     * @type {Array<string>}\n     */\n    this.inactiveClassName_ =\n      options.inactiveClassName !== undefined\n        ? options.inactiveClassName.split(' ')\n        : [this.cssClassName_ + '-false'];\n\n    const label = options.label !== undefined ? options.label : '\\u2922';\n\n    /**\n     * @private\n     * @type {Text|HTMLElement}\n     */\n    this.labelNode_ =\n      typeof label === 'string' ? document.createTextNode(label) : label;\n\n    const labelActive =\n      options.labelActive !== undefined ? options.labelActive : '\\u00d7';\n\n    /**\n     * @private\n     * @type {Text|HTMLElement}\n     */\n    this.labelActiveNode_ =\n      typeof labelActive === 'string'\n        ? document.createTextNode(labelActive)\n        : labelActive;\n\n    const tipLabel = options.tipLabel ? options.tipLabel : 'Toggle full-screen';\n\n    /**\n     * @private\n     * @type {HTMLElement}\n     */\n    this.button_ = document.createElement('button');\n    this.button_.title = tipLabel;\n    this.button_.setAttribute('type', 'button');\n    this.button_.appendChild(this.labelNode_);\n    this.button_.addEventListener(\n      EventType.CLICK,\n      this.handleClick_.bind(this),\n      false,\n    );\n    this.setClassName_(this.button_, this.isInFullscreen_);\n\n    this.element.className = `${this.cssClassName_} ${CLASS_UNSELECTABLE} ${CLASS_CONTROL}`;\n    this.element.appendChild(this.button_);\n  }\n\n  /**\n   * @param {MouseEvent} event The event to handle\n   * @private\n   */\n  handleClick_(event) {\n    event.preventDefault();\n    this.handleFullScreen_();\n  }\n\n  /**\n   * @private\n   */\n  handleFullScreen_() {\n    const map = this.getMap();\n    if (!map) {\n      return;\n    }\n    const doc = map.getOwnerDocument();\n    if (!isFullScreenSupported(doc)) {\n      return;\n    }\n    if (isFullScreen(doc)) {\n      exitFullScreen(doc);\n    } else {\n      let element;\n      if (this.source_) {\n        element =\n          typeof this.source_ === 'string'\n            ? doc.getElementById(this.source_)\n            : this.source_;\n      } else {\n        element = map.getTargetElement();\n      }\n      if (this.keys_) {\n        requestFullScreenWithKeys(element);\n      } else {\n        requestFullScreen(element);\n      }\n    }\n  }\n\n  /**\n   * @private\n   */\n  handleFullScreenChange_() {\n    const map = this.getMap();\n    if (!map) {\n      return;\n    }\n    const wasInFullscreen = this.isInFullscreen_;\n    this.isInFullscreen_ = isFullScreen(map.getOwnerDocument());\n    if (wasInFullscreen !== this.isInFullscreen_) {\n      this.setClassName_(this.button_, this.isInFullscreen_);\n      if (this.isInFullscreen_) {\n        replaceNode(this.labelActiveNode_, this.labelNode_);\n        this.dispatchEvent(FullScreenEventType.ENTERFULLSCREEN);\n      } else {\n        replaceNode(this.labelNode_, this.labelActiveNode_);\n        this.dispatchEvent(FullScreenEventType.LEAVEFULLSCREEN);\n      }\n      map.updateSize();\n    }\n  }\n\n  /**\n   * @param {HTMLElement} element Target element\n   * @param {boolean} fullscreen True if fullscreen class name should be active\n   * @private\n   */\n  setClassName_(element, fullscreen) {\n    if (fullscreen) {\n      element.classList.remove(...this.inactiveClassName_);\n      element.classList.add(...this.activeClassName_);\n    } else {\n      element.classList.remove(...this.activeClassName_);\n      element.classList.add(...this.inactiveClassName_);\n    }\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   * @override\n   */\n  setMap(map) {\n    const oldMap = this.getMap();\n    if (oldMap) {\n      oldMap.removeChangeListener(\n        MapProperty.TARGET,\n        this.boundHandleMapTargetChange_,\n      );\n    }\n\n    super.setMap(map);\n\n    this.handleMapTargetChange_();\n    if (map) {\n      map.addChangeListener(\n        MapProperty.TARGET,\n        this.boundHandleMapTargetChange_,\n      );\n    }\n  }\n\n  /**\n   * @private\n   */\n  handleMapTargetChange_() {\n    const listeners = this.documentListeners_;\n    for (let i = 0, ii = listeners.length; i < ii; ++i) {\n      unlistenByKey(listeners[i]);\n    }\n    listeners.length = 0;\n\n    const map = this.getMap();\n    if (map) {\n      const doc = map.getOwnerDocument();\n      if (isFullScreenSupported(doc)) {\n        this.element.classList.remove(CLASS_UNSUPPORTED);\n      } else {\n        this.element.classList.add(CLASS_UNSUPPORTED);\n      }\n\n      for (let i = 0, ii = events.length; i < ii; ++i) {\n        listeners.push(\n          listen(doc, events[i], this.handleFullScreenChange_, this),\n        );\n      }\n      this.handleFullScreenChange_();\n    }\n  }\n}\n\n/**\n * @param {Document} doc The root document to check.\n * @return {boolean} Fullscreen is supported by the current platform.\n */\nfunction isFullScreenSupported(doc) {\n  const body = doc.body;\n  return !!(\n    body['webkitRequestFullscreen'] ||\n    (body.requestFullscreen && doc.fullscreenEnabled)\n  );\n}\n\n/**\n * @param {Document} doc The root document to check.\n * @return {boolean} Element is currently in fullscreen.\n */\nfunction isFullScreen(doc) {\n  return !!(doc['webkitIsFullScreen'] || doc.fullscreenElement);\n}\n\n/**\n * Request to fullscreen an element.\n * @param {HTMLElement} element Element to request fullscreen\n */\nfunction requestFullScreen(element) {\n  if (element.requestFullscreen) {\n    element.requestFullscreen();\n  } else if (element['webkitRequestFullscreen']) {\n    element['webkitRequestFullscreen']();\n  }\n}\n\n/**\n * Request to fullscreen an element with keyboard input.\n * @param {HTMLElement} element Element to request fullscreen\n */\nfunction requestFullScreenWithKeys(element) {\n  if (element['webkitRequestFullscreen']) {\n    element['webkitRequestFullscreen']();\n  } else {\n    requestFullScreen(element);\n  }\n}\n\n/**\n * Exit fullscreen.\n * @param {Document} doc The document to exit fullscren from\n */\nfunction exitFullScreen(doc) {\n  if (doc.exitFullscreen) {\n    doc.exitFullscreen();\n  } else if (doc['webkitExitFullscreen']) {\n    doc['webkitExitFullscreen']();\n  }\n}\n\nexport default FullScreen;\n","/**\n * @module ol/control/MousePosition\n */\n\nimport {wrapX} from '../coordinate.js';\nimport {listen} from '../events.js';\nimport EventType from '../pointer/EventType.js';\nimport {\n  get as getProjection,\n  getTransformFromProjections,\n  getUserProjection,\n  identityTransform,\n} from '../proj.js';\nimport Control from './Control.js';\n\n/**\n * @type {string}\n */\nconst PROJECTION = 'projection';\n\n/**\n * @type {string}\n */\nconst COORDINATE_FORMAT = 'coordinateFormat';\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types|\n *     'change:coordinateFormat'|'change:projection', import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"../ObjectEventType.js\").Types|\n *     'change:coordinateFormat'|'change:projection', Return>} MousePositionOnSignature\n */\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-mouse-position'] CSS class name.\n * @property {import(\"../coordinate.js\").CoordinateFormat} [coordinateFormat] Coordinate format.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is the view projection.\n * @property {function(import(\"../MapEvent.js\").default):void} [render] Function called when the\n * control should be re-rendered. This is called in a `requestAnimationFrame`\n * callback.\n * @property {HTMLElement|string} [target] Specify a target if you want the\n * control to be rendered outside of the map's viewport.\n * @property {string} [placeholder] Markup to show when the mouse position is not\n * available (e.g. when the pointer leaves the map viewport).  By default, a non-breaking space is rendered\n * initially and the last position is retained when the mouse leaves the viewport.\n * When a string is provided (e.g. `'no position'` or `''` for an empty string) it is used as a\n * placeholder.\n * @property {boolean} [wrapX=true] Wrap the world horizontally on the projection's antimeridian, if it\n * is a global projection.\n */\n\n/**\n * @classdesc\n * A control to show the 2D coordinates of the mouse cursor. By default, these\n * are in the view projection, but can be in any supported projection.\n * By default the control is shown in the top right corner of the map, but this\n * can be changed by using the css selector `.ol-mouse-position`.\n *\n * On touch devices, which usually do not have a mouse cursor, the coordinates\n * of the currently touched position are shown.\n *\n * @api\n */\nclass MousePosition extends Control {\n  /**\n   * @param {Options} [options] Mouse position options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    const element = document.createElement('div');\n    element.className =\n      options.className !== undefined ? options.className : 'ol-mouse-position';\n\n    super({\n      element: element,\n      render: options.render,\n      target: options.target,\n    });\n\n    /***\n     * @type {MousePositionOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {MousePositionOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {MousePositionOnSignature<void>}\n     */\n    this.un;\n\n    this.addChangeListener(PROJECTION, this.handleProjectionChanged_);\n\n    if (options.coordinateFormat) {\n      this.setCoordinateFormat(options.coordinateFormat);\n    }\n    if (options.projection) {\n      this.setProjection(options.projection);\n    }\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.renderOnMouseOut_ = options.placeholder !== undefined;\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.placeholder_ = this.renderOnMouseOut_ ? options.placeholder : '&#160;';\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.renderedHTML_ = element.innerHTML;\n\n    /**\n     * @private\n     * @type {?import(\"../proj/Projection.js\").default}\n     */\n    this.mapProjection_ = null;\n\n    /**\n     * @private\n     * @type {?import(\"../proj.js\").TransformFunction}\n     */\n    this.transform_ = null;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.wrapX_ = options.wrapX === false ? false : true;\n  }\n\n  /**\n   * @private\n   */\n  handleProjectionChanged_() {\n    this.transform_ = null;\n  }\n\n  /**\n   * Return the coordinate format type used to render the current position or\n   * undefined.\n   * @return {import(\"../coordinate.js\").CoordinateFormat|undefined} The format to render the current\n   *     position in.\n   * @observable\n   * @api\n   */\n  getCoordinateFormat() {\n    return /** @type {import(\"../coordinate.js\").CoordinateFormat|undefined} */ (\n      this.get(COORDINATE_FORMAT)\n    );\n  }\n\n  /**\n   * Return the projection that is used to report the mouse position.\n   * @return {import(\"../proj/Projection.js\").default|undefined} The projection to report mouse\n   *     position in.\n   * @observable\n   * @api\n   */\n  getProjection() {\n    return /** @type {import(\"../proj/Projection.js\").default|undefined} */ (\n      this.get(PROJECTION)\n    );\n  }\n\n  /**\n   * @param {MouseEvent} event Browser event.\n   * @protected\n   */\n  handleMouseMove(event) {\n    const map = this.getMap();\n    this.updateHTML_(map.getEventPixel(event));\n  }\n\n  /**\n   * @param {Event} event Browser event.\n   * @protected\n   */\n  handleMouseOut(event) {\n    this.updateHTML_(null);\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   * @override\n   */\n  setMap(map) {\n    super.setMap(map);\n    if (map) {\n      const viewport = map.getViewport();\n      this.listenerKeys.push(\n        listen(viewport, EventType.POINTERMOVE, this.handleMouseMove, this),\n      );\n      if (this.renderOnMouseOut_) {\n        this.listenerKeys.push(\n          listen(viewport, EventType.POINTEROUT, this.handleMouseOut, this),\n        );\n      }\n      this.updateHTML_(null);\n    }\n  }\n\n  /**\n   * Set the coordinate format type used to render the current position.\n   * @param {import(\"../coordinate.js\").CoordinateFormat} format The format to render the current\n   *     position in.\n   * @observable\n   * @api\n   */\n  setCoordinateFormat(format) {\n    this.set(COORDINATE_FORMAT, format);\n  }\n\n  /**\n   * Set the projection that is used to report the mouse position.\n   * @param {import(\"../proj.js\").ProjectionLike} projection The projection to report mouse\n   *     position in.\n   * @observable\n   * @api\n   */\n  setProjection(projection) {\n    this.set(PROJECTION, getProjection(projection));\n  }\n\n  /**\n   * @param {?import(\"../pixel.js\").Pixel} pixel Pixel.\n   * @private\n   */\n  updateHTML_(pixel) {\n    let html = this.placeholder_;\n    if (pixel && this.mapProjection_) {\n      if (!this.transform_) {\n        const projection = this.getProjection();\n        if (projection) {\n          this.transform_ = getTransformFromProjections(\n            this.mapProjection_,\n            projection,\n          );\n        } else {\n          this.transform_ = identityTransform;\n        }\n      }\n      const map = this.getMap();\n      const coordinate = map.getCoordinateFromPixelInternal(pixel);\n      if (coordinate) {\n        const userProjection = getUserProjection();\n        if (userProjection) {\n          this.transform_ = getTransformFromProjections(\n            this.mapProjection_,\n            userProjection,\n          );\n        }\n        this.transform_(coordinate, coordinate);\n        if (this.wrapX_) {\n          const projection =\n            userProjection || this.getProjection() || this.mapProjection_;\n          wrapX(coordinate, projection);\n        }\n        const coordinateFormat = this.getCoordinateFormat();\n        if (coordinateFormat) {\n          html = coordinateFormat(coordinate);\n        } else {\n          html = coordinate.toString();\n        }\n      }\n    }\n    if (!this.renderedHTML_ || html !== this.renderedHTML_) {\n      this.element.innerHTML = html;\n      this.renderedHTML_ = html;\n    }\n  }\n\n  /**\n   * Update the projection. Rendering of the coordinates is done in\n   * `handleMouseMove` and `handleMouseUp`.\n   * @param {import(\"../MapEvent.js\").default} mapEvent Map event.\n   * @override\n   */\n  render(mapEvent) {\n    const frameState = mapEvent.frameState;\n    if (!frameState) {\n      this.mapProjection_ = null;\n    } else {\n      if (this.mapProjection_ != frameState.viewState.projection) {\n        this.mapProjection_ = frameState.viewState.projection;\n        this.transform_ = null;\n      }\n    }\n  }\n}\n\nexport default MousePosition;\n","/**\n * @module ol/control/OverviewMap\n */\nimport Collection from '../Collection.js';\nimport Map from '../Map.js';\nimport MapEventType from '../MapEventType.js';\nimport MapProperty from '../MapProperty.js';\nimport ObjectEventType from '../ObjectEventType.js';\nimport Overlay from '../Overlay.js';\nimport View from '../View.js';\nimport ViewProperty from '../ViewProperty.js';\nimport {CLASS_COLLAPSED, CLASS_CONTROL, CLASS_UNSELECTABLE} from '../css.js';\nimport {replaceNode} from '../dom.js';\nimport {listen, listenOnce} from '../events.js';\nimport EventType from '../events/EventType.js';\nimport {\n  containsExtent,\n  equals as equalsExtent,\n  getBottomRight,\n  getTopLeft,\n  scaleFromCenter,\n} from '../extent.js';\nimport {fromExtent as polygonFromExtent} from '../geom/Polygon.js';\nimport Control from './Control.js';\n\n/**\n * Maximum width and/or height extent ratio that determines when the overview\n * map should be zoomed out.\n * @type {number}\n */\nconst MAX_RATIO = 0.75;\n\n/**\n * Minimum width and/or height extent ratio that determines when the overview\n * map should be zoomed in.\n * @type {number}\n */\nconst MIN_RATIO = 0.1;\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-overviewmap'] CSS class name.\n * @property {boolean} [collapsed=true] Whether the control should start collapsed or not (expanded).\n * @property {string|HTMLElement} [collapseLabel='‹'] Text label to use for the\n * expanded overviewmap button. Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {boolean} [collapsible=true] Whether the control can be collapsed or not.\n * @property {string|HTMLElement} [label='›'] Text label to use for the collapsed\n * overviewmap button. Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {Array<import(\"../layer/Base.js\").default>|import(\"../Collection.js\").default<import(\"../layer/Base.js\").default>} [layers]\n * Layers for the overview map.\n * @property {function(import(\"../MapEvent.js\").default):void} [render] Function called when the control\n * should be re-rendered. This is called in a `requestAnimationFrame` callback.\n * @property {boolean} [rotateWithView=false] Whether the control view should rotate with the main map view.\n * @property {HTMLElement|string} [target] Specify a target if you want the control\n * to be rendered outside of the map's viewport.\n * @property {string} [tipLabel='Overview map'] Text label to use for the button tip.\n * @property {View} [view] Custom view for the overview map (should use same projection as main map). If not provided,\n * a default view with the same projection as the main map will be used.\n */\n\n/**\n * Create a new control with a map acting as an overview map for another\n * defined map.\n *\n * @api\n */\nclass OverviewMap extends Control {\n  /**\n   * @param {Options} [options] OverviewMap 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     */\n    this.boundHandleRotationChanged_ = this.handleRotationChanged_.bind(this);\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.collapsed_ =\n      options.collapsed !== undefined ? options.collapsed : true;\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    /**\n     * @private\n     * @type {boolean}\n     */\n    this.rotateWithView_ =\n      options.rotateWithView !== undefined ? options.rotateWithView : false;\n\n    /**\n     * @private\n     * @type {import(\"../extent.js\").Extent|undefined}\n     */\n    this.viewExtent_ = undefined;\n\n    const className =\n      options.className !== undefined ? options.className : 'ol-overviewmap';\n\n    const tipLabel =\n      options.tipLabel !== undefined ? options.tipLabel : 'Overview map';\n\n    const collapseLabel =\n      options.collapseLabel !== undefined ? options.collapseLabel : '\\u2039';\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    } else {\n      this.collapseLabel_ = collapseLabel;\n    }\n\n    const label = options.label !== undefined ? options.label : '\\u203A';\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    } else {\n      this.label_ = label;\n    }\n\n    const activeLabel =\n      this.collapsible_ && !this.collapsed_ ? this.collapseLabel_ : this.label_;\n    const button = document.createElement('button');\n    button.setAttribute('type', 'button');\n    button.title = tipLabel;\n    button.appendChild(activeLabel);\n\n    button.addEventListener(\n      EventType.CLICK,\n      this.handleClick_.bind(this),\n      false,\n    );\n\n    /**\n     * @type {HTMLElement}\n     * @private\n     */\n    this.ovmapDiv_ = document.createElement('div');\n    this.ovmapDiv_.className = 'ol-overviewmap-map';\n\n    /**\n     * Explicitly given view to be used instead of a view derived from the main map.\n     * @type {View}\n     * @private\n     */\n    this.view_ = options.view;\n\n    const ovmap = new Map({\n      view: options.view,\n      controls: new Collection(),\n      interactions: new Collection(),\n    });\n\n    /**\n     * @type {Map}\n     * @private\n     */\n    this.ovmap_ = ovmap;\n\n    if (options.layers) {\n      options.layers.forEach(function (layer) {\n        ovmap.addLayer(layer);\n      });\n    }\n\n    const box = document.createElement('div');\n    box.className = 'ol-overviewmap-box';\n    box.style.boxSizing = 'border-box';\n\n    /**\n     * @type {import(\"../Overlay.js\").default}\n     * @private\n     */\n    this.boxOverlay_ = new Overlay({\n      position: [0, 0],\n      positioning: 'center-center',\n      element: box,\n    });\n    this.ovmap_.addOverlay(this.boxOverlay_);\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.ovmapDiv_);\n    element.appendChild(button);\n\n    /* Interactive map */\n\n    const overlay = this.boxOverlay_;\n    const overlayBox = this.boxOverlay_.getElement();\n\n    /* Functions definition */\n\n    const computeDesiredMousePosition = (mousePosition) => {\n      return {\n        clientX: mousePosition.clientX,\n        clientY: mousePosition.clientY,\n      };\n    };\n\n    const move = function (event) {\n      const position = /** @type {?} */ (computeDesiredMousePosition(event));\n      const coordinates = ovmap.getEventCoordinate(\n        /** @type {MouseEvent} */ (position),\n      );\n\n      overlay.setPosition(coordinates);\n    };\n\n    const endMoving = (event) => {\n      const coordinates = ovmap.getEventCoordinateInternal(event);\n\n      const map = this.getMap();\n\n      map.getView().setCenterInternal(coordinates);\n\n      const ownerDocument = map.getOwnerDocument();\n      ownerDocument.removeEventListener('pointermove', move);\n      ownerDocument.removeEventListener('pointerup', endMoving);\n    };\n\n    /* Binding */\n\n    this.ovmapDiv_.addEventListener('pointerdown', (event) => {\n      const ownerDocument = this.getMap().getOwnerDocument();\n      if (event.target === overlayBox) {\n        ownerDocument.addEventListener('pointermove', move);\n      }\n      ownerDocument.addEventListener('pointerup', endMoving);\n    });\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   * @override\n   */\n  setMap(map) {\n    const oldMap = this.getMap();\n    if (map === oldMap) {\n      return;\n    }\n    if (oldMap) {\n      const oldView = oldMap.getView();\n      if (oldView) {\n        this.unbindView_(oldView);\n      }\n      this.ovmap_.setTarget(null);\n    }\n    super.setMap(map);\n\n    if (map) {\n      this.ovmap_.setTarget(this.ovmapDiv_);\n      this.listenerKeys.push(\n        listen(\n          map,\n          ObjectEventType.PROPERTYCHANGE,\n          this.handleMapPropertyChange_,\n          this,\n        ),\n      );\n\n      const view = map.getView();\n      if (view) {\n        this.bindView_(view);\n      }\n\n      if (!this.ovmap_.isRendered()) {\n        this.updateBoxAfterOvmapIsRendered_();\n      }\n    }\n  }\n\n  /**\n   * Handle map property changes.  This only deals with changes to the map's view.\n   * @param {import(\"../Object.js\").ObjectEvent} event The propertychange event.\n   * @private\n   */\n  handleMapPropertyChange_(event) {\n    if (event.key === MapProperty.VIEW) {\n      const oldView = /** @type {import(\"../View.js\").default} */ (\n        event.oldValue\n      );\n      if (oldView) {\n        this.unbindView_(oldView);\n      }\n      const newView = this.getMap().getView();\n      this.bindView_(newView);\n    } else if (\n      !this.ovmap_.isRendered() &&\n      (event.key === MapProperty.TARGET || event.key === MapProperty.SIZE)\n    ) {\n      this.ovmap_.updateSize();\n    }\n  }\n\n  /**\n   * Register listeners for view property changes.\n   * @param {import(\"../View.js\").default} view The view.\n   * @private\n   */\n  bindView_(view) {\n    if (!this.view_) {\n      // Unless an explicit view definition was given, derive default from whatever main map uses.\n      const newView = new View({\n        projection: view.getProjection(),\n      });\n      this.ovmap_.setView(newView);\n    }\n\n    view.addChangeListener(\n      ViewProperty.ROTATION,\n      this.boundHandleRotationChanged_,\n    );\n    // Sync once with the new view\n    this.handleRotationChanged_();\n\n    if (view.isDef()) {\n      this.ovmap_.updateSize();\n      this.resetExtent_();\n    }\n  }\n\n  /**\n   * Unregister listeners for view property changes.\n   * @param {import(\"../View.js\").default} view The view.\n   * @private\n   */\n  unbindView_(view) {\n    view.removeChangeListener(\n      ViewProperty.ROTATION,\n      this.boundHandleRotationChanged_,\n    );\n  }\n\n  /**\n   * Handle rotation changes to the main map.\n   * @private\n   */\n  handleRotationChanged_() {\n    if (this.rotateWithView_) {\n      this.ovmap_.getView().setRotation(this.getMap().getView().getRotation());\n    }\n  }\n\n  /**\n   * Reset the overview map extent if the box size (width or\n   * height) is less than the size of the overview map size times minRatio\n   * or is greater than the size of the overview size times maxRatio.\n   *\n   * If the map extent was not reset, the box size can fits in the defined\n   * ratio sizes. This method then checks if is contained inside the overview\n   * map current extent. If not, recenter the overview map to the current\n   * main map center location.\n   * @private\n   */\n  validateExtent_() {\n    const map = this.getMap();\n    const ovmap = this.ovmap_;\n\n    if (!map.isRendered() || !ovmap.isRendered()) {\n      return;\n    }\n\n    const mapSize = /** @type {import(\"../size.js\").Size} */ (map.getSize());\n\n    const view = map.getView();\n    const extent = view.calculateExtentInternal(mapSize);\n\n    if (this.viewExtent_ && equalsExtent(extent, this.viewExtent_)) {\n      // repeats of the same extent may indicate constraint conflicts leading to an endless cycle\n      return;\n    }\n    this.viewExtent_ = extent;\n\n    const ovmapSize = /** @type {import(\"../size.js\").Size} */ (\n      ovmap.getSize()\n    );\n\n    const ovview = ovmap.getView();\n    const ovextent = ovview.calculateExtentInternal(ovmapSize);\n\n    const topLeftPixel = ovmap.getPixelFromCoordinateInternal(\n      getTopLeft(extent),\n    );\n    const bottomRightPixel = ovmap.getPixelFromCoordinateInternal(\n      getBottomRight(extent),\n    );\n\n    const boxWidth = Math.abs(topLeftPixel[0] - bottomRightPixel[0]);\n    const boxHeight = Math.abs(topLeftPixel[1] - bottomRightPixel[1]);\n\n    const ovmapWidth = ovmapSize[0];\n    const ovmapHeight = ovmapSize[1];\n\n    if (\n      boxWidth < ovmapWidth * MIN_RATIO ||\n      boxHeight < ovmapHeight * MIN_RATIO ||\n      boxWidth > ovmapWidth * MAX_RATIO ||\n      boxHeight > ovmapHeight * MAX_RATIO\n    ) {\n      this.resetExtent_();\n    } else if (!containsExtent(ovextent, extent)) {\n      this.recenter_();\n    }\n  }\n\n  /**\n   * Reset the overview map extent to half calculated min and max ratio times\n   * the extent of the main map.\n   * @private\n   */\n  resetExtent_() {\n    if (MAX_RATIO === 0 || MIN_RATIO === 0) {\n      return;\n    }\n\n    const map = this.getMap();\n    const ovmap = this.ovmap_;\n\n    const mapSize = /** @type {import(\"../size.js\").Size} */ (map.getSize());\n\n    const view = map.getView();\n    const extent = view.calculateExtentInternal(mapSize);\n\n    const ovview = ovmap.getView();\n\n    // get how many times the current map overview could hold different\n    // box sizes using the min and max ratio, pick the step in the middle used\n    // to calculate the extent from the main map to set it to the overview map,\n    const steps = Math.log(MAX_RATIO / MIN_RATIO) / Math.LN2;\n    const ratio = 1 / (Math.pow(2, steps / 2) * MIN_RATIO);\n    scaleFromCenter(extent, ratio);\n    ovview.fitInternal(polygonFromExtent(extent));\n  }\n\n  /**\n   * Set the center of the overview map to the map center without changing its\n   * resolution.\n   * @private\n   */\n  recenter_() {\n    const map = this.getMap();\n    const ovmap = this.ovmap_;\n\n    const view = map.getView();\n\n    const ovview = ovmap.getView();\n\n    ovview.setCenterInternal(view.getCenterInternal());\n  }\n\n  /**\n   * Update the box using the main map extent\n   * @private\n   */\n  updateBox_() {\n    const map = this.getMap();\n    const ovmap = this.ovmap_;\n\n    if (!map.isRendered() || !ovmap.isRendered()) {\n      return;\n    }\n\n    const mapSize = /** @type {import(\"../size.js\").Size} */ (map.getSize());\n\n    const view = map.getView();\n\n    const ovview = ovmap.getView();\n\n    const rotation = this.rotateWithView_ ? 0 : -view.getRotation();\n\n    const overlay = this.boxOverlay_;\n    const box = this.boxOverlay_.getElement();\n    const center = view.getCenter();\n    const resolution = view.getResolution();\n    const ovresolution = ovview.getResolution();\n    const width = (mapSize[0] * resolution) / ovresolution;\n    const height = (mapSize[1] * resolution) / ovresolution;\n\n    // set position using center coordinates\n    overlay.setPosition(center);\n\n    // set box size calculated from map extent size and overview map resolution\n    if (box) {\n      box.style.width = width + 'px';\n      box.style.height = height + 'px';\n      const transform = 'rotate(' + rotation + 'rad)';\n      box.style.transform = transform;\n    }\n  }\n\n  /**\n   * @private\n   */\n  updateBoxAfterOvmapIsRendered_() {\n    if (this.ovmapPostrenderKey_) {\n      return;\n    }\n    this.ovmapPostrenderKey_ = listenOnce(\n      this.ovmap_,\n      MapEventType.POSTRENDER,\n      (event) => {\n        delete this.ovmapPostrenderKey_;\n        this.updateBox_();\n      },\n    );\n  }\n\n  /**\n   * @param {MouseEvent} event The event to handle\n   * @private\n   */\n  handleClick_(event) {\n    event.preventDefault();\n    this.handleToggle_();\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\n    // manage overview map if it had not been rendered before and control\n    // is expanded\n    const ovmap = this.ovmap_;\n    if (!this.collapsed_) {\n      if (ovmap.isRendered()) {\n        this.viewExtent_ = undefined;\n        ovmap.render();\n        return;\n      }\n      ovmap.updateSize();\n      this.resetExtent_();\n      this.updateBoxAfterOvmapIsRendered_();\n    }\n  }\n\n  /**\n   * Return `true` if the overview map 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 overview map 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 (!collapsible && this.collapsed_) {\n      this.handleToggle_();\n    }\n  }\n\n  /**\n   * Collapse or expand the overview map according to the passed parameter. Will\n   * not do anything if the overview map 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    if (!this.collapsible_ || this.collapsed_ === collapsed) {\n      return;\n    }\n    this.handleToggle_();\n  }\n\n  /**\n   * Determine if the overview map is collapsed.\n   * @return {boolean} The overview map is collapsed.\n   * @api\n   */\n  getCollapsed() {\n    return this.collapsed_;\n  }\n\n  /**\n   * Return `true` if the overview map view can rotate, `false` otherwise.\n   * @return {boolean} True if the control view can rotate.\n   * @api\n   */\n  getRotateWithView() {\n    return this.rotateWithView_;\n  }\n\n  /**\n   * Set whether the overview map view should rotate with the main map view.\n   * @param {boolean} rotateWithView True if the control view should rotate.\n   * @api\n   */\n  setRotateWithView(rotateWithView) {\n    if (this.rotateWithView_ === rotateWithView) {\n      return;\n    }\n    this.rotateWithView_ = rotateWithView;\n    if (this.getMap().getView().getRotation() !== 0) {\n      if (this.rotateWithView_) {\n        this.handleRotationChanged_();\n      } else {\n        this.ovmap_.getView().setRotation(0);\n      }\n      this.viewExtent_ = undefined;\n      this.validateExtent_();\n      this.updateBox_();\n    }\n  }\n\n  /**\n   * Return the overview map.\n   * @return {import(\"../Map.js\").default} Overview map.\n   * @api\n   */\n  getOverviewMap() {\n    return this.ovmap_;\n  }\n\n  /**\n   * Update the overview map element.\n   * @param {import(\"../MapEvent.js\").default} mapEvent Map event.\n   * @override\n   */\n  render(mapEvent) {\n    this.validateExtent_();\n    this.updateBox_();\n  }\n}\n\nexport default OverviewMap;\n","/**\n * @module ol/control/ScaleLine\n */\nimport {CLASS_UNSELECTABLE} from '../css.js';\nimport {METERS_PER_UNIT, getPointResolution} from '../proj.js';\nimport Control from './Control.js';\n\n/**\n * @type {string}\n */\nconst UNITS_PROP = 'units';\n\n/**\n * @typedef {'degrees' | 'imperial' | 'nautical' | 'metric' | 'us'} Units\n * Units for the scale line.\n */\n\n/**\n * @const\n * @type {Array<number>}\n */\nconst LEADING_DIGITS = [1, 2, 5];\n\n/**\n * @const\n * @type {number}\n */\nconst DEFAULT_DPI = 25.4 / 0.28;\n\n/***\n * @template Return\n * @typedef {import(\"../Observable.js\").OnSignature<import(\"../Observable.js\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable.js\").OnSignature<import(\"../ObjectEventType.js\").Types|\n *     'change:units', import(\"../Object.js\").ObjectEvent, Return> &\n *   import(\"../Observable.js\").CombinedOnSignature<import(\"../Observable.js\").EventTypes|import(\"../ObjectEventType.js\").Types\n *     |'change:units', Return>} ScaleLineOnSignature\n */\n\n/**\n * @typedef {Object} Options\n * @property {string} [className] CSS class name. The default is `ol-scale-bar` when configured with\n * `bar: true`. Otherwise the default is `ol-scale-line`.\n * @property {number} [minWidth=64] Minimum width in pixels at the OGC default dpi. The width will be\n * adjusted to match the dpi used.\n * @property {number} [maxWidth] Maximum width in pixels at the OGC default dpi. The width will be\n * adjusted to match the dpi used.\n * @property {function(import(\"../MapEvent.js\").default):void} [render] Function called when the control\n * should be re-rendered. This is called in a `requestAnimationFrame` callback.\n * @property {HTMLElement|string} [target] Specify a target if you want the control\n * to be rendered outside of the map's viewport.\n * @property {Units} [units='metric'] Units.\n * @property {boolean} [bar=false] Render scalebars instead of a line.\n * @property {number} [steps=4] Number of steps the scalebar should use. Use even numbers\n * for best results. Only applies when `bar` is `true`.\n * @property {boolean} [text=false] Render the text scale above of the scalebar. Only applies\n * when `bar` is `true`.\n * @property {number|undefined} [dpi=undefined] dpi of output device such as printer. Only applies\n * when `bar` is `true`. If undefined the OGC default screen pixel size of 0.28mm will be assumed.\n */\n\n/**\n * @classdesc\n * A control displaying rough y-axis distances, calculated for the center of the\n * viewport. For conformal projections (e.g. EPSG:3857, the default view\n * projection in OpenLayers), the scale is valid for all directions.\n * No scale line will be shown when the y-axis distance of a pixel at the\n * viewport center cannot be calculated in the view projection.\n * By default the scale line will show in the bottom left portion of the map,\n * but this can be changed by using the css selector `.ol-scale-line`.\n * When specifying `bar` as `true`, a scalebar will be rendered instead\n * of a scaleline.\n * For cartesian measurements of the scaleline, you need to set the\n * `getPointResolution` method of your projection to simply return the input\n * value, e.g. `projection.setGetPointResolution(r => r);`\n *\n * @api\n */\nclass ScaleLine extends Control {\n  /**\n   * @param {Options} [options] Scale line options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    const element = document.createElement('div');\n    element.style.pointerEvents = 'none';\n\n    super({\n      element: element,\n      render: options.render,\n      target: options.target,\n    });\n\n    /***\n     * @type {ScaleLineOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {ScaleLineOnSignature<import(\"../events.js\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {ScaleLineOnSignature<void>}\n     */\n    this.un;\n\n    const className =\n      options.className !== undefined\n        ? options.className\n        : options.bar\n          ? 'ol-scale-bar'\n          : 'ol-scale-line';\n\n    /**\n     * @private\n     * @type {HTMLElement}\n     */\n    this.innerElement_ = document.createElement('div');\n    this.innerElement_.className = className + '-inner';\n\n    this.element.className = className + ' ' + CLASS_UNSELECTABLE;\n    this.element.appendChild(this.innerElement_);\n\n    /**\n     * @private\n     * @type {?import(\"../View.js\").State}\n     */\n    this.viewState_ = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.minWidth_ = options.minWidth !== undefined ? options.minWidth : 64;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.maxWidth_ = options.maxWidth;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.renderedVisible_ = false;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.renderedWidth_ = undefined;\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.renderedHTML_ = '';\n\n    this.addChangeListener(UNITS_PROP, this.handleUnitsChanged_);\n\n    this.setUnits(options.units || 'metric');\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.scaleBar_ = options.bar || false;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.scaleBarSteps_ = options.steps || 4;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.scaleBarText_ = options.text || false;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.dpi_ = options.dpi || undefined;\n  }\n\n  /**\n   * Return the units to use in the scale line.\n   * @return {Units} The units\n   * to use in the scale line.\n   * @observable\n   * @api\n   */\n  getUnits() {\n    return this.get(UNITS_PROP);\n  }\n\n  /**\n   * @private\n   */\n  handleUnitsChanged_() {\n    this.updateElement_();\n  }\n\n  /**\n   * Set the units to use in the scale line.\n   * @param {Units} units The units to use in the scale line.\n   * @observable\n   * @api\n   */\n  setUnits(units) {\n    this.set(UNITS_PROP, units);\n  }\n\n  /**\n   * Specify the dpi of output device such as printer.\n   * @param {number|undefined} dpi The dpi of output device.\n   * @api\n   */\n  setDpi(dpi) {\n    this.dpi_ = dpi;\n  }\n\n  /**\n   * @private\n   */\n  updateElement_() {\n    const viewState = this.viewState_;\n\n    if (!viewState) {\n      if (this.renderedVisible_) {\n        this.element.style.display = 'none';\n        this.renderedVisible_ = false;\n      }\n      return;\n    }\n\n    const center = viewState.center;\n    const projection = viewState.projection;\n    const units = this.getUnits();\n    const pointResolutionUnits = units == 'degrees' ? 'degrees' : 'm';\n    let pointResolution = getPointResolution(\n      projection,\n      viewState.resolution,\n      center,\n      pointResolutionUnits,\n    );\n\n    const minWidth =\n      (this.minWidth_ * (this.dpi_ || DEFAULT_DPI)) / DEFAULT_DPI;\n\n    const maxWidth =\n      this.maxWidth_ !== undefined\n        ? (this.maxWidth_ * (this.dpi_ || DEFAULT_DPI)) / DEFAULT_DPI\n        : undefined;\n\n    let nominalCount = minWidth * pointResolution;\n    let suffix = '';\n    if (units == 'degrees') {\n      const metersPerDegree = METERS_PER_UNIT.degrees;\n      nominalCount *= metersPerDegree;\n      if (nominalCount < metersPerDegree / 60) {\n        suffix = '\\u2033'; // seconds\n        pointResolution *= 3600;\n      } else if (nominalCount < metersPerDegree) {\n        suffix = '\\u2032'; // minutes\n        pointResolution *= 60;\n      } else {\n        suffix = '\\u00b0'; // degrees\n      }\n    } else if (units == 'imperial') {\n      if (nominalCount < 0.9144) {\n        suffix = 'in';\n        pointResolution /= 0.0254;\n      } else if (nominalCount < 1609.344) {\n        suffix = 'ft';\n        pointResolution /= 0.3048;\n      } else {\n        suffix = 'mi';\n        pointResolution /= 1609.344;\n      }\n    } else if (units == 'nautical') {\n      pointResolution /= 1852;\n      suffix = 'NM';\n    } else if (units == 'metric') {\n      if (nominalCount < 1e-6) {\n        suffix = 'nm';\n        pointResolution *= 1e9;\n      } else if (nominalCount < 0.001) {\n        suffix = 'μm';\n        pointResolution *= 1000000;\n      } else if (nominalCount < 1) {\n        suffix = 'mm';\n        pointResolution *= 1000;\n      } else if (nominalCount < 1000) {\n        suffix = 'm';\n      } else {\n        suffix = 'km';\n        pointResolution /= 1000;\n      }\n    } else if (units == 'us') {\n      if (nominalCount < 0.9144) {\n        suffix = 'in';\n        pointResolution *= 39.37;\n      } else if (nominalCount < 1609.344) {\n        suffix = 'ft';\n        pointResolution /= 0.30480061;\n      } else {\n        suffix = 'mi';\n        pointResolution /= 1609.3472;\n      }\n    } else {\n      throw new Error('Invalid units');\n    }\n\n    let i = 3 * Math.floor(Math.log(minWidth * pointResolution) / Math.log(10));\n    let count, width, decimalCount;\n    let previousCount = 0;\n    let previousWidth, previousDecimalCount;\n    while (true) {\n      decimalCount = Math.floor(i / 3);\n      const decimal = Math.pow(10, decimalCount);\n      count = LEADING_DIGITS[((i % 3) + 3) % 3] * decimal;\n      width = Math.round(count / pointResolution);\n      if (isNaN(width)) {\n        this.element.style.display = 'none';\n        this.renderedVisible_ = false;\n        return;\n      }\n      if (maxWidth !== undefined && width >= maxWidth) {\n        count = previousCount;\n        width = previousWidth;\n        decimalCount = previousDecimalCount;\n        break;\n      } else if (width >= minWidth) {\n        break;\n      }\n      previousCount = count;\n      previousWidth = width;\n      previousDecimalCount = decimalCount;\n      ++i;\n    }\n    const html = this.scaleBar_\n      ? this.createScaleBar(width, count, suffix)\n      : count.toFixed(decimalCount < 0 ? -decimalCount : 0) + ' ' + suffix;\n\n    if (this.renderedHTML_ != html) {\n      this.innerElement_.innerHTML = html;\n      this.renderedHTML_ = html;\n    }\n\n    if (this.renderedWidth_ != width) {\n      this.innerElement_.style.width = width + 'px';\n      this.renderedWidth_ = width;\n    }\n\n    if (!this.renderedVisible_) {\n      this.element.style.display = '';\n      this.renderedVisible_ = true;\n    }\n  }\n\n  /**\n   * @private\n   * @param {number} width The current width of the scalebar.\n   * @param {number} scale The current scale.\n   * @param {string} suffix The suffix to append to the scale text.\n   * @return {string} The stringified HTML of the scalebar.\n   */\n  createScaleBar(width, scale, suffix) {\n    const resolutionScale = this.getScaleForResolution();\n    const mapScale =\n      resolutionScale < 1\n        ? Math.round(1 / resolutionScale).toLocaleString() + ' : 1'\n        : '1 : ' + Math.round(resolutionScale).toLocaleString();\n    const steps = this.scaleBarSteps_;\n    const stepWidth = width / steps;\n    const scaleSteps = [this.createMarker('absolute')];\n    for (let i = 0; i < steps; ++i) {\n      const cls =\n        i % 2 === 0 ? 'ol-scale-singlebar-odd' : 'ol-scale-singlebar-even';\n      scaleSteps.push(\n        '<div>' +\n          '<div ' +\n          `class=\"ol-scale-singlebar ${cls}\" ` +\n          `style=\"width: ${stepWidth}px;\"` +\n          '>' +\n          '</div>' +\n          this.createMarker('relative') +\n          // render text every second step, except when only 2 steps\n          (i % 2 === 0 || steps === 2\n            ? this.createStepText(i, width, false, scale, suffix)\n            : '') +\n          '</div>',\n      );\n    }\n    // render text at the end\n    scaleSteps.push(this.createStepText(steps, width, true, scale, suffix));\n\n    const scaleBarText = this.scaleBarText_\n      ? `<div class=\"ol-scale-text\" style=\"width: ${width}px;\">` +\n        mapScale +\n        '</div>'\n      : '';\n    return scaleBarText + scaleSteps.join('');\n  }\n\n  /**\n   * Creates a marker at given position\n   * @param {'absolute'|'relative'} position The position, absolute or relative\n   * @return {string} The stringified div containing the marker\n   */\n  createMarker(position) {\n    const top = position === 'absolute' ? 3 : -10;\n    return (\n      '<div ' +\n      'class=\"ol-scale-step-marker\" ' +\n      `style=\"position: ${position}; top: ${top}px;\"` +\n      '></div>'\n    );\n  }\n\n  /**\n   * Creates the label for a marker marker at given position\n   * @param {number} i The iterator\n   * @param {number} width The width the scalebar will currently use\n   * @param {boolean} isLast Flag indicating if we add the last step text\n   * @param {number} scale The current scale for the whole scalebar\n   * @param {string} suffix The suffix for the scale\n   * @return {string} The stringified div containing the step text\n   */\n  createStepText(i, width, isLast, scale, suffix) {\n    const length =\n      i === 0 ? 0 : Math.round((scale / this.scaleBarSteps_) * i * 100) / 100;\n    const lengthString = length + (i === 0 ? '' : ' ' + suffix);\n    const margin = i === 0 ? -3 : (width / this.scaleBarSteps_) * -1;\n    const minWidth = i === 0 ? 0 : (width / this.scaleBarSteps_) * 2;\n    return (\n      '<div ' +\n      'class=\"ol-scale-step-text\" ' +\n      'style=\"' +\n      `margin-left: ${margin}px;` +\n      `text-align: ${i === 0 ? 'left' : 'center'};` +\n      `min-width: ${minWidth}px;` +\n      `left: ${isLast ? width + 'px' : 'unset'};` +\n      '\">' +\n      lengthString +\n      '</div>'\n    );\n  }\n\n  /**\n   * Returns the appropriate scale for the given resolution and units.\n   * @return {number} The appropriate scale.\n   */\n  getScaleForResolution() {\n    const resolution = getPointResolution(\n      this.viewState_.projection,\n      this.viewState_.resolution,\n      this.viewState_.center,\n      'm',\n    );\n    const dpi = this.dpi_ || DEFAULT_DPI;\n    const inchesPerMeter = 1000 / 25.4;\n    return resolution * inchesPerMeter * dpi;\n  }\n\n  /**\n   * Update the scale line 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      this.viewState_ = null;\n    } else {\n      this.viewState_ = frameState.viewState;\n    }\n    this.updateElement_();\n  }\n}\n\nexport default ScaleLine;\n","/**\n * @module ol/control/ZoomSlider\n */\n\nimport {CLASS_CONTROL, CLASS_UNSELECTABLE} from '../css.js';\nimport {easeOut} from '../easing.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport {stopPropagation} from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport {clamp} from '../math.js';\nimport PointerEventType from '../pointer/EventType.js';\nimport Control from './Control.js';\n\n/**\n * The enum for available directions.\n *\n * @enum {number}\n */\nconst Direction = {\n  VERTICAL: 0,\n  HORIZONTAL: 1,\n};\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-zoomslider'] CSS class name.\n * @property {number} [duration=200] Animation duration in milliseconds.\n * @property {function(import(\"../MapEvent.js\").default):void} [render] Function called when the control\n * should be re-rendered. This is called in a `requestAnimationFrame` callback.\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 slider type of control for zooming.\n *\n * Example:\n *\n *     map.addControl(new ZoomSlider());\n *\n * @api\n */\nclass ZoomSlider extends Control {\n  /**\n   * @param {Options} [options] Zoom slider options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super({\n      target: options.target,\n      element: document.createElement('div'),\n      render: options.render,\n    });\n\n    /**\n     * @type {!Array<import(\"../events.js\").EventsKey>}\n     * @private\n     */\n    this.dragListenerKeys_ = [];\n\n    /**\n     * Will hold the current resolution of the view.\n     *\n     * @type {number|undefined}\n     * @private\n     */\n    this.currentResolution_ = undefined;\n\n    /**\n     * The direction of the slider. Will be determined from actual display of the\n     * container and defaults to Direction.VERTICAL.\n     *\n     * @type {Direction}\n     * @private\n     */\n    this.direction_ = Direction.VERTICAL;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.dragging_;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.heightLimit_ = 0;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.widthLimit_ = 0;\n\n    /**\n     * @type {number|undefined}\n     * @private\n     */\n    this.startX_;\n\n    /**\n     * @type {number|undefined}\n     * @private\n     */\n    this.startY_;\n\n    /**\n     * The calculated thumb size (border box plus margins).  Set when initSlider_\n     * is called.\n     * @type {import(\"../size.js\").Size}\n     * @private\n     */\n    this.thumbSize_ = null;\n\n    /**\n     * Whether the slider is initialized.\n     * @type {boolean}\n     * @private\n     */\n    this.sliderInitialized_ = false;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.duration_ = options.duration !== undefined ? options.duration : 200;\n\n    const className =\n      options.className !== undefined ? options.className : 'ol-zoomslider';\n    const thumbElement = document.createElement('button');\n    thumbElement.setAttribute('type', 'button');\n    thumbElement.className = className + '-thumb ' + CLASS_UNSELECTABLE;\n    const containerElement = this.element;\n    containerElement.className =\n      className + ' ' + CLASS_UNSELECTABLE + ' ' + CLASS_CONTROL;\n    containerElement.appendChild(thumbElement);\n\n    containerElement.addEventListener(\n      PointerEventType.POINTERDOWN,\n      this.handleDraggerStart_.bind(this),\n      false,\n    );\n    containerElement.addEventListener(\n      PointerEventType.POINTERMOVE,\n      this.handleDraggerDrag_.bind(this),\n      false,\n    );\n    containerElement.addEventListener(\n      PointerEventType.POINTERUP,\n      this.handleDraggerEnd_.bind(this),\n      false,\n    );\n\n    containerElement.addEventListener(\n      EventType.CLICK,\n      this.handleContainerClick_.bind(this),\n      false,\n    );\n    thumbElement.addEventListener(EventType.CLICK, stopPropagation, false);\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   * @override\n   */\n  setMap(map) {\n    super.setMap(map);\n    if (map) {\n      map.render();\n    }\n  }\n\n  /**\n   * Initializes the slider element. This will determine and set this controls\n   * direction_ and also constrain the dragging of the thumb to always be within\n   * the bounds of the container.\n   *\n   * @return {boolean} Initialization successful\n   * @private\n   */\n  initSlider_() {\n    const container = this.element;\n    let containerWidth = container.offsetWidth;\n    let containerHeight = container.offsetHeight;\n    if (containerWidth === 0 && containerHeight === 0) {\n      return (this.sliderInitialized_ = false);\n    }\n\n    const containerStyle = getComputedStyle(container);\n    containerWidth -=\n      parseFloat(containerStyle['paddingRight']) +\n      parseFloat(containerStyle['paddingLeft']);\n    containerHeight -=\n      parseFloat(containerStyle['paddingTop']) +\n      parseFloat(containerStyle['paddingBottom']);\n    const thumb = /** @type {HTMLElement} */ (container.firstElementChild);\n    const thumbStyle = getComputedStyle(thumb);\n    const thumbWidth =\n      thumb.offsetWidth +\n      parseFloat(thumbStyle['marginRight']) +\n      parseFloat(thumbStyle['marginLeft']);\n    const thumbHeight =\n      thumb.offsetHeight +\n      parseFloat(thumbStyle['marginTop']) +\n      parseFloat(thumbStyle['marginBottom']);\n    this.thumbSize_ = [thumbWidth, thumbHeight];\n\n    if (containerWidth > containerHeight) {\n      this.direction_ = Direction.HORIZONTAL;\n      this.widthLimit_ = containerWidth - thumbWidth;\n    } else {\n      this.direction_ = Direction.VERTICAL;\n      this.heightLimit_ = containerHeight - thumbHeight;\n    }\n    return (this.sliderInitialized_ = true);\n  }\n\n  /**\n   * @param {PointerEvent} event The browser event to handle.\n   * @private\n   */\n  handleContainerClick_(event) {\n    const view = this.getMap().getView();\n\n    const relativePosition = this.getRelativePosition_(\n      event.offsetX - this.thumbSize_[0] / 2,\n      event.offsetY - this.thumbSize_[1] / 2,\n    );\n\n    const resolution = this.getResolutionForPosition_(relativePosition);\n    const zoom = view.getConstrainedZoom(view.getZoomForResolution(resolution));\n\n    view.animateInternal({\n      zoom: zoom,\n      duration: this.duration_,\n      easing: easeOut,\n    });\n  }\n\n  /**\n   * Handle dragger start events.\n   * @param {PointerEvent} event The drag event.\n   * @private\n   */\n  handleDraggerStart_(event) {\n    if (!this.dragging_ && event.target === this.element.firstElementChild) {\n      const element = /** @type {HTMLElement} */ (\n        this.element.firstElementChild\n      );\n      this.getMap().getView().beginInteraction();\n      this.startX_ = event.clientX - parseFloat(element.style.left);\n      this.startY_ = event.clientY - parseFloat(element.style.top);\n      this.dragging_ = true;\n\n      if (this.dragListenerKeys_.length === 0) {\n        const drag = this.handleDraggerDrag_;\n        const end = this.handleDraggerEnd_;\n        const doc = this.getMap().getOwnerDocument();\n        this.dragListenerKeys_.push(\n          listen(doc, PointerEventType.POINTERMOVE, drag, this),\n          listen(doc, PointerEventType.POINTERUP, end, this),\n        );\n      }\n    }\n  }\n\n  /**\n   * Handle dragger drag events.\n   *\n   * @param {PointerEvent} event The drag event.\n   * @private\n   */\n  handleDraggerDrag_(event) {\n    if (this.dragging_) {\n      const deltaX = event.clientX - this.startX_;\n      const deltaY = event.clientY - this.startY_;\n      const relativePosition = this.getRelativePosition_(deltaX, deltaY);\n      this.currentResolution_ =\n        this.getResolutionForPosition_(relativePosition);\n      this.getMap().getView().setResolution(this.currentResolution_);\n    }\n  }\n\n  /**\n   * Handle dragger end events.\n   * @param {PointerEvent} event The drag event.\n   * @private\n   */\n  handleDraggerEnd_(event) {\n    if (this.dragging_) {\n      const view = this.getMap().getView();\n      view.endInteraction();\n\n      this.dragging_ = false;\n      this.startX_ = undefined;\n      this.startY_ = undefined;\n      this.dragListenerKeys_.forEach(unlistenByKey);\n      this.dragListenerKeys_.length = 0;\n    }\n  }\n\n  /**\n   * Positions the thumb inside its container according to the given resolution.\n   *\n   * @param {number} res The res.\n   * @private\n   */\n  setThumbPosition_(res) {\n    const position = this.getPositionForResolution_(res);\n    const thumb = /** @type {HTMLElement} */ (this.element.firstElementChild);\n\n    if (this.direction_ == Direction.HORIZONTAL) {\n      thumb.style.left = this.widthLimit_ * position + 'px';\n    } else {\n      thumb.style.top = this.heightLimit_ * position + 'px';\n    }\n  }\n\n  /**\n   * Calculates the relative position of the thumb given x and y offsets.  The\n   * relative position scales from 0 to 1.  The x and y offsets are assumed to be\n   * in pixel units within the dragger limits.\n   *\n   * @param {number} x Pixel position relative to the left of the slider.\n   * @param {number} y Pixel position relative to the top of the slider.\n   * @return {number} The relative position of the thumb.\n   * @private\n   */\n  getRelativePosition_(x, y) {\n    let amount;\n    if (this.direction_ === Direction.HORIZONTAL) {\n      amount = x / this.widthLimit_;\n    } else {\n      amount = y / this.heightLimit_;\n    }\n    return clamp(amount, 0, 1);\n  }\n\n  /**\n   * Calculates the corresponding resolution of the thumb given its relative\n   * position (where 0 is the minimum and 1 is the maximum).\n   *\n   * @param {number} position The relative position of the thumb.\n   * @return {number} The corresponding resolution.\n   * @private\n   */\n  getResolutionForPosition_(position) {\n    const fn = this.getMap().getView().getResolutionForValueFunction();\n    return fn(1 - position);\n  }\n\n  /**\n   * Determines the relative position of the slider for the given resolution.  A\n   * relative position of 0 corresponds to the minimum view resolution.  A\n   * relative position of 1 corresponds to the maximum view resolution.\n   *\n   * @param {number} res The resolution.\n   * @return {number} The relative position value (between 0 and 1).\n   * @private\n   */\n  getPositionForResolution_(res) {\n    const fn = this.getMap().getView().getValueForResolutionFunction();\n    return clamp(1 - fn(res), 0, 1);\n  }\n\n  /**\n   * Update the zoomslider element.\n   * @param {import(\"../MapEvent.js\").default} mapEvent Map event.\n   * @override\n   */\n  render(mapEvent) {\n    if (!mapEvent.frameState) {\n      return;\n    }\n    if (!this.sliderInitialized_ && !this.initSlider_()) {\n      return;\n    }\n    const res = mapEvent.frameState.viewState.resolution;\n    this.currentResolution_ = res;\n    this.setThumbPosition_(res);\n  }\n}\n\nexport default ZoomSlider;\n","import {CollectionEvent as _ol_Collection$CollectionEvent} from '../../ol/Collection.js';\nimport $ol$Collection from '../../ol/Collection.js';\nimport {asImageLike as _ol_DataTile$asImageLike} from '../../ol/DataTile.js';\nimport {asArrayLike as _ol_DataTile$asArrayLike} from '../../ol/DataTile.js';\nimport {disposedError as _ol_DataTile$disposedError} from '../../ol/DataTile.js';\nimport {toArray as _ol_DataTile$toArray} from '../../ol/DataTile.js';\nimport $ol$DataTile from '../../ol/DataTile.js';\nimport $ol$Disposable from '../../ol/Disposable.js';\nimport $ol$Feature from '../../ol/Feature.js';\nimport {createStyleFunction as _ol_Feature$createStyleFunction} from '../../ol/Feature.js';\nimport {GeolocationError as _ol_Geolocation$GeolocationError} from '../../ol/Geolocation.js';\nimport $ol$Geolocation from '../../ol/Geolocation.js';\nimport $ol$Image from '../../ol/Image.js';\nimport {listenImage as _ol_Image$listenImage} from '../../ol/Image.js';\nimport {load as _ol_Image$load} from '../../ol/Image.js';\nimport {decodeFallback as _ol_Image$decodeFallback} from '../../ol/Image.js';\nimport {decode as _ol_Image$decode} from '../../ol/Image.js';\nimport $ol$ImageCanvas from '../../ol/ImageCanvas.js';\nimport $ol$ImageTile from '../../ol/ImageTile.js';\nimport $ol$Kinetic from '../../ol/Kinetic.js';\nimport $ol$Map from '../../ol/Map.js';\nimport $ol$MapBrowserEvent from '../../ol/MapBrowserEvent.js';\nimport $ol$MapBrowserEventHandler from '../../ol/MapBrowserEventHandler.js';\nimport $ol$MapEvent from '../../ol/MapEvent.js';\nimport {ObjectEvent as _ol_Object$ObjectEvent} from '../../ol/Object.js';\nimport $ol$Object from '../../ol/Object.js';\nimport $ol$Observable from '../../ol/Observable.js';\nimport {unByKey as _ol_Observable$unByKey} from '../../ol/Observable.js';\nimport $ol$Overlay from '../../ol/Overlay.js';\nimport $ol$Tile from '../../ol/Tile.js';\nimport $ol$TileQueue from '../../ol/TileQueue.js';\nimport {getTilePriority as _ol_TileQueue$getTilePriority} from '../../ol/TileQueue.js';\nimport $ol$TileRange from '../../ol/TileRange.js';\nimport {createOrUpdate as _ol_TileRange$createOrUpdate} from '../../ol/TileRange.js';\nimport $ol$VectorRenderTile from '../../ol/VectorRenderTile.js';\nimport $ol$View from '../../ol/View.js';\nimport {createCenterConstraint as _ol_View$createCenterConstraint} from '../../ol/View.js';\nimport {createResolutionConstraint as _ol_View$createResolutionConstraint} from '../../ol/View.js';\nimport {createRotationConstraint as _ol_View$createRotationConstraint} from '../../ol/View.js';\nimport {isNoopAnimation as _ol_View$isNoopAnimation} from '../../ol/View.js';\nimport {withHigherResolutions as _ol_View$withHigherResolutions} from '../../ol/View.js';\nimport {withLowerResolutions as _ol_View$withLowerResolutions} from '../../ol/View.js';\nimport {withExtentCenter as _ol_View$withExtentCenter} from '../../ol/View.js';\nimport {withZoom as _ol_View$withZoom} from '../../ol/View.js';\nimport {getView as _ol_View$getView} from '../../ol/View.js';\nimport {binarySearch as _ol_array$binarySearch} from '../../ol/array.js';\nimport {ascending as _ol_array$ascending} from '../../ol/array.js';\nimport {descending as _ol_array$descending} from '../../ol/array.js';\nimport {linearFindNearest as _ol_array$linearFindNearest} from '../../ol/array.js';\nimport {reverseSubArray as _ol_array$reverseSubArray} from '../../ol/array.js';\nimport {extend as _ol_array$extend} from '../../ol/array.js';\nimport {remove as _ol_array$remove} from '../../ol/array.js';\nimport {equals as _ol_array$equals} from '../../ol/array.js';\nimport {stableSort as _ol_array$stableSort} from '../../ol/array.js';\nimport {isSorted as _ol_array$isSorted} from '../../ol/array.js';\nimport {assert as _ol_asserts$assert} from '../../ol/asserts.js';\nimport {createExtent as _ol_centerconstraint$createExtent} from '../../ol/centerconstraint.js';\nimport {none as _ol_centerconstraint$none} from '../../ol/centerconstraint.js';\nimport {NO_COLOR as _ol_color$NO_COLOR} from '../../ol/color.js';\nimport {asString as _ol_color$asString} from '../../ol/color.js';\nimport {withAlpha as _ol_color$withAlpha} from '../../ol/color.js';\nimport {rgbaToLcha as _ol_color$rgbaToLcha} from '../../ol/color.js';\nimport {lchaToRgba as _ol_color$lchaToRgba} from '../../ol/color.js';\nimport {fromString as _ol_color$fromString} from '../../ol/color.js';\nimport {asArray as _ol_color$asArray} from '../../ol/color.js';\nimport {toString as _ol_color$toString} from '../../ol/color.js';\nimport {isStringColor as _ol_color$isStringColor} from '../../ol/color.js';\nimport {asColorLike as _ol_colorlike$asColorLike} from '../../ol/colorlike.js';\nimport {setLevel as _ol_console$setLevel} from '../../ol/console.js';\nimport {log as _ol_console$log} from '../../ol/console.js';\nimport {warn as _ol_console$warn} from '../../ol/console.js';\nimport {error as _ol_console$error} from '../../ol/console.js';\nimport {add as _ol_coordinate$add} from '../../ol/coordinate.js';\nimport {closestOnCircle as _ol_coordinate$closestOnCircle} from '../../ol/coordinate.js';\nimport {closestOnSegment as _ol_coordinate$closestOnSegment} from '../../ol/coordinate.js';\nimport {createStringXY as _ol_coordinate$createStringXY} from '../../ol/coordinate.js';\nimport {degreesToStringHDMS as _ol_coordinate$degreesToStringHDMS} from '../../ol/coordinate.js';\nimport {format as _ol_coordinate$format} from '../../ol/coordinate.js';\nimport {equals as _ol_coordinate$equals} from '../../ol/coordinate.js';\nimport {rotate as _ol_coordinate$rotate} from '../../ol/coordinate.js';\nimport {scale as _ol_coordinate$scale} from '../../ol/coordinate.js';\nimport {squaredDistance as _ol_coordinate$squaredDistance} from '../../ol/coordinate.js';\nimport {distance as _ol_coordinate$distance} from '../../ol/coordinate.js';\nimport {squaredDistanceToSegment as _ol_coordinate$squaredDistanceToSegment} from '../../ol/coordinate.js';\nimport {toStringHDMS as _ol_coordinate$toStringHDMS} from '../../ol/coordinate.js';\nimport {toStringXY as _ol_coordinate$toStringXY} from '../../ol/coordinate.js';\nimport {wrapX as _ol_coordinate$wrapX} from '../../ol/coordinate.js';\nimport {getWorldsAway as _ol_coordinate$getWorldsAway} from '../../ol/coordinate.js';\nimport {angleBetween as _ol_coordinate$angleBetween} from '../../ol/coordinate.js';\nimport {CLASS_HIDDEN as _ol_css$CLASS_HIDDEN} from '../../ol/css.js';\nimport {CLASS_SELECTABLE as _ol_css$CLASS_SELECTABLE} from '../../ol/css.js';\nimport {CLASS_UNSELECTABLE as _ol_css$CLASS_UNSELECTABLE} from '../../ol/css.js';\nimport {CLASS_UNSUPPORTED as _ol_css$CLASS_UNSUPPORTED} from '../../ol/css.js';\nimport {CLASS_CONTROL as _ol_css$CLASS_CONTROL} from '../../ol/css.js';\nimport {CLASS_COLLAPSED as _ol_css$CLASS_COLLAPSED} from '../../ol/css.js';\nimport {fontWeights as _ol_css$fontWeights} from '../../ol/css.js';\nimport {getFontParameters as _ol_css$getFontParameters} from '../../ol/css.js';\nimport {createCanvasContext2D as _ol_dom$createCanvasContext2D} from '../../ol/dom.js';\nimport {getSharedCanvasContext2D as _ol_dom$getSharedCanvasContext2D} from '../../ol/dom.js';\nimport {releaseCanvas as _ol_dom$releaseCanvas} from '../../ol/dom.js';\nimport {outerWidth as _ol_dom$outerWidth} from '../../ol/dom.js';\nimport {outerHeight as _ol_dom$outerHeight} from '../../ol/dom.js';\nimport {replaceNode as _ol_dom$replaceNode} from '../../ol/dom.js';\nimport {removeChildren as _ol_dom$removeChildren} from '../../ol/dom.js';\nimport {replaceChildren as _ol_dom$replaceChildren} from '../../ol/dom.js';\nimport {createMockDiv as _ol_dom$createMockDiv} from '../../ol/dom.js';\nimport {isCanvas as _ol_dom$isCanvas} from '../../ol/dom.js';\nimport {easeIn as _ol_easing$easeIn} from '../../ol/easing.js';\nimport {easeOut as _ol_easing$easeOut} from '../../ol/easing.js';\nimport {inAndOut as _ol_easing$inAndOut} from '../../ol/easing.js';\nimport {linear as _ol_easing$linear} from '../../ol/easing.js';\nimport {upAndDown as _ol_easing$upAndDown} from '../../ol/easing.js';\nimport {listen as _ol_events$listen} from '../../ol/events.js';\nimport {listenOnce as _ol_events$listenOnce} from '../../ol/events.js';\nimport {unlistenByKey as _ol_events$unlistenByKey} from '../../ol/events.js';\nimport {boundingExtent as _ol_extent$boundingExtent} from '../../ol/extent.js';\nimport {buffer as _ol_extent$buffer} from '../../ol/extent.js';\nimport {clone as _ol_extent$clone} from '../../ol/extent.js';\nimport {closestSquaredDistanceXY as _ol_extent$closestSquaredDistanceXY} from '../../ol/extent.js';\nimport {containsCoordinate as _ol_extent$containsCoordinate} from '../../ol/extent.js';\nimport {containsExtent as _ol_extent$containsExtent} from '../../ol/extent.js';\nimport {containsXY as _ol_extent$containsXY} from '../../ol/extent.js';\nimport {coordinateRelationship as _ol_extent$coordinateRelationship} from '../../ol/extent.js';\nimport {createEmpty as _ol_extent$createEmpty} from '../../ol/extent.js';\nimport {createOrUpdate as _ol_extent$createOrUpdate} from '../../ol/extent.js';\nimport {createOrUpdateEmpty as _ol_extent$createOrUpdateEmpty} from '../../ol/extent.js';\nimport {createOrUpdateFromCoordinate as _ol_extent$createOrUpdateFromCoordinate} from '../../ol/extent.js';\nimport {createOrUpdateFromCoordinates as _ol_extent$createOrUpdateFromCoordinates} from '../../ol/extent.js';\nimport {createOrUpdateFromFlatCoordinates as _ol_extent$createOrUpdateFromFlatCoordinates} from '../../ol/extent.js';\nimport {createOrUpdateFromRings as _ol_extent$createOrUpdateFromRings} from '../../ol/extent.js';\nimport {equals as _ol_extent$equals} from '../../ol/extent.js';\nimport {approximatelyEquals as _ol_extent$approximatelyEquals} from '../../ol/extent.js';\nimport {extend as _ol_extent$extend} from '../../ol/extent.js';\nimport {extendCoordinate as _ol_extent$extendCoordinate} from '../../ol/extent.js';\nimport {extendCoordinates as _ol_extent$extendCoordinates} from '../../ol/extent.js';\nimport {extendFlatCoordinates as _ol_extent$extendFlatCoordinates} from '../../ol/extent.js';\nimport {extendRings as _ol_extent$extendRings} from '../../ol/extent.js';\nimport {extendXY as _ol_extent$extendXY} from '../../ol/extent.js';\nimport {forEachCorner as _ol_extent$forEachCorner} from '../../ol/extent.js';\nimport {getArea as _ol_extent$getArea} from '../../ol/extent.js';\nimport {getBottomLeft as _ol_extent$getBottomLeft} from '../../ol/extent.js';\nimport {getBottomRight as _ol_extent$getBottomRight} from '../../ol/extent.js';\nimport {getCenter as _ol_extent$getCenter} from '../../ol/extent.js';\nimport {getCorner as _ol_extent$getCorner} from '../../ol/extent.js';\nimport {getEnlargedArea as _ol_extent$getEnlargedArea} from '../../ol/extent.js';\nimport {getForViewAndSize as _ol_extent$getForViewAndSize} from '../../ol/extent.js';\nimport {getRotatedViewport as _ol_extent$getRotatedViewport} from '../../ol/extent.js';\nimport {getHeight as _ol_extent$getHeight} from '../../ol/extent.js';\nimport {getIntersectionArea as _ol_extent$getIntersectionArea} from '../../ol/extent.js';\nimport {getIntersection as _ol_extent$getIntersection} from '../../ol/extent.js';\nimport {getMargin as _ol_extent$getMargin} from '../../ol/extent.js';\nimport {getSize as _ol_extent$getSize} from '../../ol/extent.js';\nimport {getTopLeft as _ol_extent$getTopLeft} from '../../ol/extent.js';\nimport {getTopRight as _ol_extent$getTopRight} from '../../ol/extent.js';\nimport {getWidth as _ol_extent$getWidth} from '../../ol/extent.js';\nimport {intersects as _ol_extent$intersects} from '../../ol/extent.js';\nimport {isEmpty as _ol_extent$isEmpty} from '../../ol/extent.js';\nimport {returnOrUpdate as _ol_extent$returnOrUpdate} from '../../ol/extent.js';\nimport {scaleFromCenter as _ol_extent$scaleFromCenter} from '../../ol/extent.js';\nimport {intersectsSegment as _ol_extent$intersectsSegment} from '../../ol/extent.js';\nimport {applyTransform as _ol_extent$applyTransform} from '../../ol/extent.js';\nimport {wrapX as _ol_extent$wrapX} from '../../ol/extent.js';\nimport {wrapAndSliceX as _ol_extent$wrapAndSliceX} from '../../ol/extent.js';\nimport {loadFeaturesXhr as _ol_featureloader$loadFeaturesXhr} from '../../ol/featureloader.js';\nimport {xhr as _ol_featureloader$xhr} from '../../ol/featureloader.js';\nimport {setWithCredentials as _ol_featureloader$setWithCredentials} from '../../ol/featureloader.js';\nimport {TRUE as _ol_functions$TRUE} from '../../ol/functions.js';\nimport {FALSE as _ol_functions$FALSE} from '../../ol/functions.js';\nimport {VOID as _ol_functions$VOID} from '../../ol/functions.js';\nimport {memoizeOne as _ol_functions$memoizeOne} from '../../ol/functions.js';\nimport {toPromise as _ol_functions$toPromise} from '../../ol/functions.js';\nimport {SAFARI as _ol_has$SAFARI} from '../../ol/has.js';\nimport {SAFARI_BUG_237906 as _ol_has$SAFARI_BUG_237906} from '../../ol/has.js';\nimport {WEBKIT as _ol_has$WEBKIT} from '../../ol/has.js';\nimport {MAC as _ol_has$MAC} from '../../ol/has.js';\nimport {DEVICE_PIXEL_RATIO as _ol_has$DEVICE_PIXEL_RATIO} from '../../ol/has.js';\nimport {WORKER_OFFSCREEN_CANVAS as _ol_has$WORKER_OFFSCREEN_CANVAS} from '../../ol/has.js';\nimport {IMAGE_DECODE as _ol_has$IMAGE_DECODE} from '../../ol/has.js';\nimport {CREATE_IMAGE_BITMAP as _ol_has$CREATE_IMAGE_BITMAP} from '../../ol/has.js';\nimport {PASSIVE_EVENT_LISTENERS as _ol_has$PASSIVE_EVENT_LISTENERS} from '../../ol/has.js';\nimport {all as _ol_loadingstrategy$all} from '../../ol/loadingstrategy.js';\nimport {bbox as _ol_loadingstrategy$bbox} from '../../ol/loadingstrategy.js';\nimport {tile as _ol_loadingstrategy$tile} from '../../ol/loadingstrategy.js';\nimport {clamp as _ol_math$clamp} from '../../ol/math.js';\nimport {squaredSegmentDistance as _ol_math$squaredSegmentDistance} from '../../ol/math.js';\nimport {squaredDistance as _ol_math$squaredDistance} from '../../ol/math.js';\nimport {solveLinearSystem as _ol_math$solveLinearSystem} from '../../ol/math.js';\nimport {toDegrees as _ol_math$toDegrees} from '../../ol/math.js';\nimport {toRadians as _ol_math$toRadians} from '../../ol/math.js';\nimport {modulo as _ol_math$modulo} from '../../ol/math.js';\nimport {lerp as _ol_math$lerp} from '../../ol/math.js';\nimport {toFixed as _ol_math$toFixed} from '../../ol/math.js';\nimport {round as _ol_math$round} from '../../ol/math.js';\nimport {floor as _ol_math$floor} from '../../ol/math.js';\nimport {ceil as _ol_math$ceil} from '../../ol/math.js';\nimport {wrap as _ol_math$wrap} from '../../ol/math.js';\nimport {jsonp as _ol_net$jsonp} from '../../ol/net.js';\nimport {ResponseError as _ol_net$ResponseError} from '../../ol/net.js';\nimport {ClientError as _ol_net$ClientError} from '../../ol/net.js';\nimport {getJSON as _ol_net$getJSON} from '../../ol/net.js';\nimport {resolveUrl as _ol_net$resolveUrl} from '../../ol/net.js';\nimport {overrideXHR as _ol_net$overrideXHR} from '../../ol/net.js';\nimport {restoreXHR as _ol_net$restoreXHR} from '../../ol/net.js';\nimport {clear as _ol_obj$clear} from '../../ol/obj.js';\nimport {isEmpty as _ol_obj$isEmpty} from '../../ol/obj.js';\nimport {disableCoordinateWarning as _ol_proj$disableCoordinateWarning} from '../../ol/proj.js';\nimport {cloneTransform as _ol_proj$cloneTransform} from '../../ol/proj.js';\nimport {identityTransform as _ol_proj$identityTransform} from '../../ol/proj.js';\nimport {addProjection as _ol_proj$addProjection} from '../../ol/proj.js';\nimport {addProjections as _ol_proj$addProjections} from '../../ol/proj.js';\nimport {get as _ol_proj$get} from '../../ol/proj.js';\nimport {getPointResolution as _ol_proj$getPointResolution} from '../../ol/proj.js';\nimport {addEquivalentProjections as _ol_proj$addEquivalentProjections} from '../../ol/proj.js';\nimport {addEquivalentTransforms as _ol_proj$addEquivalentTransforms} from '../../ol/proj.js';\nimport {clearAllProjections as _ol_proj$clearAllProjections} from '../../ol/proj.js';\nimport {createProjection as _ol_proj$createProjection} from '../../ol/proj.js';\nimport {createTransformFromCoordinateTransform as _ol_proj$createTransformFromCoordinateTransform} from '../../ol/proj.js';\nimport {addCoordinateTransforms as _ol_proj$addCoordinateTransforms} from '../../ol/proj.js';\nimport {fromLonLat as _ol_proj$fromLonLat} from '../../ol/proj.js';\nimport {toLonLat as _ol_proj$toLonLat} from '../../ol/proj.js';\nimport {equivalent as _ol_proj$equivalent} from '../../ol/proj.js';\nimport {getTransformFromProjections as _ol_proj$getTransformFromProjections} from '../../ol/proj.js';\nimport {getTransform as _ol_proj$getTransform} from '../../ol/proj.js';\nimport {transform as _ol_proj$transform} from '../../ol/proj.js';\nimport {transformExtent as _ol_proj$transformExtent} from '../../ol/proj.js';\nimport {transformWithProjections as _ol_proj$transformWithProjections} from '../../ol/proj.js';\nimport {setUserProjection as _ol_proj$setUserProjection} from '../../ol/proj.js';\nimport {clearUserProjection as _ol_proj$clearUserProjection} from '../../ol/proj.js';\nimport {getUserProjection as _ol_proj$getUserProjection} from '../../ol/proj.js';\nimport {useGeographic as _ol_proj$useGeographic} from '../../ol/proj.js';\nimport {toUserCoordinate as _ol_proj$toUserCoordinate} from '../../ol/proj.js';\nimport {fromUserCoordinate as _ol_proj$fromUserCoordinate} from '../../ol/proj.js';\nimport {toUserExtent as _ol_proj$toUserExtent} from '../../ol/proj.js';\nimport {fromUserExtent as _ol_proj$fromUserExtent} from '../../ol/proj.js';\nimport {toUserResolution as _ol_proj$toUserResolution} from '../../ol/proj.js';\nimport {fromUserResolution as _ol_proj$fromUserResolution} from '../../ol/proj.js';\nimport {createSafeCoordinateTransform as _ol_proj$createSafeCoordinateTransform} from '../../ol/proj.js';\nimport {addCommon as _ol_proj$addCommon} from '../../ol/proj.js';\nimport {toContext as _ol_render$toContext} from '../../ol/render.js';\nimport {getVectorContext as _ol_render$getVectorContext} from '../../ol/render.js';\nimport {getRenderPixel as _ol_render$getRenderPixel} from '../../ol/render.js';\nimport {canvasPool as _ol_reproj$canvasPool} from '../../ol/reproj.js';\nimport {calculateSourceResolution as _ol_reproj$calculateSourceResolution} from '../../ol/reproj.js';\nimport {calculateSourceExtentResolution as _ol_reproj$calculateSourceExtentResolution} from '../../ol/reproj.js';\nimport {render as _ol_reproj$render} from '../../ol/reproj.js';\nimport {fromResolutionLike as _ol_resolution$fromResolutionLike} from '../../ol/resolution.js';\nimport {createSnapToResolutions as _ol_resolutionconstraint$createSnapToResolutions} from '../../ol/resolutionconstraint.js';\nimport {createSnapToPower as _ol_resolutionconstraint$createSnapToPower} from '../../ol/resolutionconstraint.js';\nimport {createMinMaxResolution as _ol_resolutionconstraint$createMinMaxResolution} from '../../ol/resolutionconstraint.js';\nimport {disable as _ol_rotationconstraint$disable} from '../../ol/rotationconstraint.js';\nimport {none as _ol_rotationconstraint$none} from '../../ol/rotationconstraint.js';\nimport {createSnapToN as _ol_rotationconstraint$createSnapToN} from '../../ol/rotationconstraint.js';\nimport {createSnapToZero as _ol_rotationconstraint$createSnapToZero} from '../../ol/rotationconstraint.js';\nimport {buffer as _ol_size$buffer} from '../../ol/size.js';\nimport {hasArea as _ol_size$hasArea} from '../../ol/size.js';\nimport {scale as _ol_size$scale} from '../../ol/size.js';\nimport {toSize as _ol_size$toSize} from '../../ol/size.js';\nimport {sourcesFromTileGrid as _ol_source$sourcesFromTileGrid} from '../../ol/source.js';\nimport {DEFAULT_RADIUS as _ol_sphere$DEFAULT_RADIUS} from '../../ol/sphere.js';\nimport {getDistance as _ol_sphere$getDistance} from '../../ol/sphere.js';\nimport {getLength as _ol_sphere$getLength} from '../../ol/sphere.js';\nimport {getArea as _ol_sphere$getArea} from '../../ol/sphere.js';\nimport {offset as _ol_sphere$offset} from '../../ol/sphere.js';\nimport {padNumber as _ol_string$padNumber} from '../../ol/string.js';\nimport {compareVersions as _ol_string$compareVersions} from '../../ol/string.js';\nimport {createOrUpdate as _ol_tilecoord$createOrUpdate} from '../../ol/tilecoord.js';\nimport {getKeyZXY as _ol_tilecoord$getKeyZXY} from '../../ol/tilecoord.js';\nimport {getKey as _ol_tilecoord$getKey} from '../../ol/tilecoord.js';\nimport {getCacheKeyForTileKey as _ol_tilecoord$getCacheKeyForTileKey} from '../../ol/tilecoord.js';\nimport {getCacheKey as _ol_tilecoord$getCacheKey} from '../../ol/tilecoord.js';\nimport {fromKey as _ol_tilecoord$fromKey} from '../../ol/tilecoord.js';\nimport {hash as _ol_tilecoord$hash} from '../../ol/tilecoord.js';\nimport {hashZXY as _ol_tilecoord$hashZXY} from '../../ol/tilecoord.js';\nimport {withinExtentAndZ as _ol_tilecoord$withinExtentAndZ} from '../../ol/tilecoord.js';\nimport {getForProjection as _ol_tilegrid$getForProjection} from '../../ol/tilegrid.js';\nimport {wrapX as _ol_tilegrid$wrapX} from '../../ol/tilegrid.js';\nimport {createForExtent as _ol_tilegrid$createForExtent} from '../../ol/tilegrid.js';\nimport {createXYZ as _ol_tilegrid$createXYZ} from '../../ol/tilegrid.js';\nimport {createForProjection as _ol_tilegrid$createForProjection} from '../../ol/tilegrid.js';\nimport {extentFromProjection as _ol_tilegrid$extentFromProjection} from '../../ol/tilegrid.js';\nimport {createFromTemplate as _ol_tileurlfunction$createFromTemplate} from '../../ol/tileurlfunction.js';\nimport {createFromTemplates as _ol_tileurlfunction$createFromTemplates} from '../../ol/tileurlfunction.js';\nimport {createFromTileUrlFunctions as _ol_tileurlfunction$createFromTileUrlFunctions} from '../../ol/tileurlfunction.js';\nimport {nullTileUrlFunction as _ol_tileurlfunction$nullTileUrlFunction} from '../../ol/tileurlfunction.js';\nimport {create as _ol_transform$create} from '../../ol/transform.js';\nimport {reset as _ol_transform$reset} from '../../ol/transform.js';\nimport {multiply as _ol_transform$multiply} from '../../ol/transform.js';\nimport {set as _ol_transform$set} from '../../ol/transform.js';\nimport {setFromArray as _ol_transform$setFromArray} from '../../ol/transform.js';\nimport {apply as _ol_transform$apply} from '../../ol/transform.js';\nimport {rotate as _ol_transform$rotate} from '../../ol/transform.js';\nimport {scale as _ol_transform$scale} from '../../ol/transform.js';\nimport {makeScale as _ol_transform$makeScale} from '../../ol/transform.js';\nimport {translate as _ol_transform$translate} from '../../ol/transform.js';\nimport {compose as _ol_transform$compose} from '../../ol/transform.js';\nimport {composeCssTransform as _ol_transform$composeCssTransform} from '../../ol/transform.js';\nimport {invert as _ol_transform$invert} from '../../ol/transform.js';\nimport {makeInverse as _ol_transform$makeInverse} from '../../ol/transform.js';\nimport {determinant as _ol_transform$determinant} from '../../ol/transform.js';\nimport {toString as _ol_transform$toString} from '../../ol/transform.js';\nimport {fromString as _ol_transform$fromString} from '../../ol/transform.js';\nimport {equivalent as _ol_transform$equivalent} from '../../ol/transform.js';\nimport {appendParams as _ol_uri$appendParams} from '../../ol/uri.js';\nimport {renderXYZTemplate as _ol_uri$renderXYZTemplate} from '../../ol/uri.js';\nimport {pickUrl as _ol_uri$pickUrl} from '../../ol/uri.js';\nimport {expandUrl as _ol_uri$expandUrl} from '../../ol/uri.js';\nimport {abstract as _ol_util$abstract} from '../../ol/util.js';\nimport {getUid as _ol_util$getUid} from '../../ol/util.js';\nimport {VERSION as _ol_util$VERSION} from '../../ol/util.js';\nimport {XML_SCHEMA_INSTANCE_URI as _ol_xml$XML_SCHEMA_INSTANCE_URI} from '../../ol/xml.js';\nimport {createElementNS as _ol_xml$createElementNS} from '../../ol/xml.js';\nimport {getAllTextContent as _ol_xml$getAllTextContent} from '../../ol/xml.js';\nimport {getAllTextContent_ as _ol_xml$getAllTextContent_} from '../../ol/xml.js';\nimport {isDocument as _ol_xml$isDocument} from '../../ol/xml.js';\nimport {getAttributeNS as _ol_xml$getAttributeNS} from '../../ol/xml.js';\nimport {parse as _ol_xml$parse} from '../../ol/xml.js';\nimport {makeArrayExtender as _ol_xml$makeArrayExtender} from '../../ol/xml.js';\nimport {makeArrayPusher as _ol_xml$makeArrayPusher} from '../../ol/xml.js';\nimport {makeReplacer as _ol_xml$makeReplacer} from '../../ol/xml.js';\nimport {makeObjectPropertyPusher as _ol_xml$makeObjectPropertyPusher} from '../../ol/xml.js';\nimport {makeObjectPropertySetter as _ol_xml$makeObjectPropertySetter} from '../../ol/xml.js';\nimport {makeChildAppender as _ol_xml$makeChildAppender} from '../../ol/xml.js';\nimport {makeArraySerializer as _ol_xml$makeArraySerializer} from '../../ol/xml.js';\nimport {makeSimpleNodeFactory as _ol_xml$makeSimpleNodeFactory} from '../../ol/xml.js';\nimport {OBJECT_PROPERTY_NODE_FACTORY as _ol_xml$OBJECT_PROPERTY_NODE_FACTORY} from '../../ol/xml.js';\nimport {makeSequence as _ol_xml$makeSequence} from '../../ol/xml.js';\nimport {makeStructureNS as _ol_xml$makeStructureNS} from '../../ol/xml.js';\nimport {parseNode as _ol_xml$parseNode} from '../../ol/xml.js';\nimport {pushParseAndPop as _ol_xml$pushParseAndPop} from '../../ol/xml.js';\nimport {serialize as _ol_xml$serialize} from '../../ol/xml.js';\nimport {pushSerializeAndPop as _ol_xml$pushSerializeAndPop} from '../../ol/xml.js';\nimport {registerXMLSerializer as _ol_xml$registerXMLSerializer} from '../../ol/xml.js';\nimport {getXMLSerializer as _ol_xml$getXMLSerializer} from '../../ol/xml.js';\nimport {registerDocument as _ol_xml$registerDocument} from '../../ol/xml.js';\nimport {getDocument as _ol_xml$getDocument} from '../../ol/xml.js';\nimport {create as _ol_vec_mat4$create} from '../../ol/vec/mat4.js';\nimport {fromTransform as _ol_vec_mat4$fromTransform} from '../../ol/vec/mat4.js';\nimport {orthographic as _ol_vec_mat4$orthographic} from '../../ol/vec/mat4.js';\nimport {scale as _ol_vec_mat4$scale} from '../../ol/vec/mat4.js';\nimport {translate as _ol_vec_mat4$translate} from '../../ol/vec/mat4.js';\nimport {translation as _ol_vec_mat4$translation} from '../../ol/vec/mat4.js';\nimport $ol$tilegrid$TileGrid from '../../ol/tilegrid/TileGrid.js';\nimport $ol$tilegrid$WMTS from '../../ol/tilegrid/WMTS.js';\nimport {createFromCapabilitiesMatrixSet as _ol_tilegrid_WMTS$createFromCapabilitiesMatrixSet} from '../../ol/tilegrid/WMTS.js';\nimport {DEFAULT_MAX_ZOOM as _ol_tilegrid_common$DEFAULT_MAX_ZOOM} from '../../ol/tilegrid/common.js';\nimport {DEFAULT_TILE_SIZE as _ol_tilegrid_common$DEFAULT_TILE_SIZE} from '../../ol/tilegrid/common.js';\nimport $ol$style$Circle from '../../ol/style/Circle.js';\nimport $ol$style$Fill from '../../ol/style/Fill.js';\nimport $ol$style$Icon from '../../ol/style/Icon.js';\nimport $ol$style$IconImage from '../../ol/style/IconImage.js';\nimport {get as _ol_style_IconImage$get} from '../../ol/style/IconImage.js';\nimport $ol$style$IconImageCache from '../../ol/style/IconImageCache.js';\nimport {getCacheKey as _ol_style_IconImageCache$getCacheKey} from '../../ol/style/IconImageCache.js';\nimport {shared as _ol_style_IconImageCache$shared} from '../../ol/style/IconImageCache.js';\nimport $ol$style$Image from '../../ol/style/Image.js';\nimport $ol$style$RegularShape from '../../ol/style/RegularShape.js';\nimport $ol$style$Stroke from '../../ol/style/Stroke.js';\nimport $ol$style$Style from '../../ol/style/Style.js';\nimport {toFunction as _ol_style_Style$toFunction} from '../../ol/style/Style.js';\nimport {createDefaultStyle as _ol_style_Style$createDefaultStyle} from '../../ol/style/Style.js';\nimport {createEditingStyle as _ol_style_Style$createEditingStyle} from '../../ol/style/Style.js';\nimport $ol$style$Text from '../../ol/style/Text.js';\nimport {createDefaultStyle as _ol_style_flat$createDefaultStyle} from '../../ol/style/flat.js';\nimport $ol$structs$LRUCache from '../../ol/structs/LRUCache.js';\nimport {DROP as _ol_structs_PriorityQueue$DROP} from '../../ol/structs/PriorityQueue.js';\nimport $ol$structs$PriorityQueue from '../../ol/structs/PriorityQueue.js';\nimport $ol$structs$RBush from '../../ol/structs/RBush.js';\nimport {quadKey as _ol_source_BingMaps$quadKey} from '../../ol/source/BingMaps.js';\nimport $ol$source$BingMaps from '../../ol/source/BingMaps.js';\nimport $ol$source$Cluster from '../../ol/source/Cluster.js';\nimport $ol$source$DataTile from '../../ol/source/DataTile.js';\nimport $ol$source$Google from '../../ol/source/Google.js';\nimport {ImageSourceEvent as _ol_source_Image$ImageSourceEvent} from '../../ol/source/Image.js';\nimport $ol$source$Image from '../../ol/source/Image.js';\nimport {defaultImageLoadFunction as _ol_source_Image$defaultImageLoadFunction} from '../../ol/source/Image.js';\nimport {getRequestExtent as _ol_source_Image$getRequestExtent} from '../../ol/source/Image.js';\nimport $ol$source$ImageArcGISRest from '../../ol/source/ImageArcGISRest.js';\nimport $ol$source$ImageCanvas from '../../ol/source/ImageCanvas.js';\nimport $ol$source$ImageStatic from '../../ol/source/ImageStatic.js';\nimport $ol$source$ImageTile from '../../ol/source/ImageTile.js';\nimport $ol$source$ImageWMS from '../../ol/source/ImageWMS.js';\nimport {ATTRIBUTION as _ol_source_OSM$ATTRIBUTION} from '../../ol/source/OSM.js';\nimport $ol$source$OSM from '../../ol/source/OSM.js';\nimport {Processor as _ol_source_Raster$Processor} from '../../ol/source/Raster.js';\nimport {RasterSourceEvent as _ol_source_Raster$RasterSourceEvent} from '../../ol/source/Raster.js';\nimport $ol$source$Raster from '../../ol/source/Raster.js';\nimport $ol$source$Source from '../../ol/source/Source.js';\nimport $ol$source$StadiaMaps from '../../ol/source/StadiaMaps.js';\nimport $ol$source$Tile from '../../ol/source/Tile.js';\nimport {TileSourceEvent as _ol_source_Tile$TileSourceEvent} from '../../ol/source/Tile.js';\nimport $ol$source$TileArcGISRest from '../../ol/source/TileArcGISRest.js';\nimport $ol$source$TileDebug from '../../ol/source/TileDebug.js';\nimport $ol$source$TileImage from '../../ol/source/TileImage.js';\nimport {defaultTileLoadFunction as _ol_source_TileImage$defaultTileLoadFunction} from '../../ol/source/TileImage.js';\nimport $ol$source$TileJSON from '../../ol/source/TileJSON.js';\nimport $ol$source$TileWMS from '../../ol/source/TileWMS.js';\nimport {CustomTile as _ol_source_UTFGrid$CustomTile} from '../../ol/source/UTFGrid.js';\nimport $ol$source$UTFGrid from '../../ol/source/UTFGrid.js';\nimport $ol$source$UrlTile from '../../ol/source/UrlTile.js';\nimport {VectorSourceEvent as _ol_source_Vector$VectorSourceEvent} from '../../ol/source/Vector.js';\nimport $ol$source$Vector from '../../ol/source/Vector.js';\nimport $ol$source$WMTS from '../../ol/source/WMTS.js';\nimport {optionsFromCapabilities as _ol_source_WMTS$optionsFromCapabilities} from '../../ol/source/WMTS.js';\nimport $ol$source$XYZ from '../../ol/source/XYZ.js';\nimport {getRequestUrl as _ol_source_arcgisRest$getRequestUrl} from '../../ol/source/arcgisRest.js';\nimport {createLoader as _ol_source_arcgisRest$createLoader} from '../../ol/source/arcgisRest.js';\nimport {DEFAULT_WMS_VERSION as _ol_source_common$DEFAULT_WMS_VERSION} from '../../ol/source/common.js';\nimport {DECIMALS as _ol_source_common$DECIMALS} from '../../ol/source/common.js';\nimport {createLoader as _ol_source_mapserver$createLoader} from '../../ol/source/mapserver.js';\nimport {appendCollectionsQueryParam as _ol_source_ogcTileUtil$appendCollectionsQueryParam} from '../../ol/source/ogcTileUtil.js';\nimport {getMapTileUrlTemplate as _ol_source_ogcTileUtil$getMapTileUrlTemplate} from '../../ol/source/ogcTileUtil.js';\nimport {getVectorTileUrlTemplate as _ol_source_ogcTileUtil$getVectorTileUrlTemplate} from '../../ol/source/ogcTileUtil.js';\nimport {parseTileMatrixSet as _ol_source_ogcTileUtil$parseTileMatrixSet} from '../../ol/source/ogcTileUtil.js';\nimport {getTileSetInfo as _ol_source_ogcTileUtil$getTileSetInfo} from '../../ol/source/ogcTileUtil.js';\nimport {createLoader as _ol_source_static$createLoader} from '../../ol/source/static.js';\nimport {DEFAULT_VERSION as _ol_source_wms$DEFAULT_VERSION} from '../../ol/source/wms.js';\nimport {getRequestUrl as _ol_source_wms$getRequestUrl} from '../../ol/source/wms.js';\nimport {getImageSrc as _ol_source_wms$getImageSrc} from '../../ol/source/wms.js';\nimport {getRequestParams as _ol_source_wms$getRequestParams} from '../../ol/source/wms.js';\nimport {createLoader as _ol_source_wms$createLoader} from '../../ol/source/wms.js';\nimport {getFeatureInfoUrl as _ol_source_wms$getFeatureInfoUrl} from '../../ol/source/wms.js';\nimport {getLegendUrl as _ol_source_wms$getLegendUrl} from '../../ol/source/wms.js';\nimport $ol$reproj$DataTile from '../../ol/reproj/DataTile.js';\nimport $ol$reproj$Image from '../../ol/reproj/Image.js';\nimport $ol$reproj$Tile from '../../ol/reproj/Tile.js';\nimport $ol$reproj$Triangulation from '../../ol/reproj/Triangulation.js';\nimport {ERROR_THRESHOLD as _ol_reproj_common$ERROR_THRESHOLD} from '../../ol/reproj/common.js';\nimport {createCanvasContextWebGL as _ol_reproj_glreproj$createCanvasContextWebGL} from '../../ol/reproj/glreproj.js';\nimport {releaseGLCanvas as _ol_reproj_glreproj$releaseGLCanvas} from '../../ol/reproj/glreproj.js';\nimport {canvasGLPool as _ol_reproj_glreproj$canvasGLPool} from '../../ol/reproj/glreproj.js';\nimport {render as _ol_reproj_glreproj$render} from '../../ol/reproj/glreproj.js';\nimport $ol$renderer$Composite from '../../ol/renderer/Composite.js';\nimport $ol$renderer$Layer from '../../ol/renderer/Layer.js';\nimport $ol$renderer$Map from '../../ol/renderer/Map.js';\nimport {defaultOrder as _ol_renderer_vector$defaultOrder} from '../../ol/renderer/vector.js';\nimport {getSquaredTolerance as _ol_renderer_vector$getSquaredTolerance} from '../../ol/renderer/vector.js';\nimport {getTolerance as _ol_renderer_vector$getTolerance} from '../../ol/renderer/vector.js';\nimport {renderFeature as _ol_renderer_vector$renderFeature} from '../../ol/renderer/vector.js';\nimport $ol$renderer$canvas$ImageLayer from '../../ol/renderer/canvas/ImageLayer.js';\nimport {canvasPool as _ol_renderer_canvas_Layer$canvasPool} from '../../ol/renderer/canvas/Layer.js';\nimport $ol$renderer$canvas$Layer from '../../ol/renderer/canvas/Layer.js';\nimport $ol$renderer$canvas$TileLayer from '../../ol/renderer/canvas/TileLayer.js';\nimport $ol$renderer$canvas$VectorImageLayer from '../../ol/renderer/canvas/VectorImageLayer.js';\nimport $ol$renderer$canvas$VectorLayer from '../../ol/renderer/canvas/VectorLayer.js';\nimport $ol$render$Box from '../../ol/render/Box.js';\nimport $ol$render$Event from '../../ol/render/Event.js';\nimport $ol$render$Feature from '../../ol/render/Feature.js';\nimport {toGeometry as _ol_render_Feature$toGeometry} from '../../ol/render/Feature.js';\nimport {toFeature as _ol_render_Feature$toFeature} from '../../ol/render/Feature.js';\nimport $ol$render$VectorContext from '../../ol/render/VectorContext.js';\nimport {defaultFont as _ol_render_canvas$defaultFont} from '../../ol/render/canvas.js';\nimport {defaultFillStyle as _ol_render_canvas$defaultFillStyle} from '../../ol/render/canvas.js';\nimport {defaultLineCap as _ol_render_canvas$defaultLineCap} from '../../ol/render/canvas.js';\nimport {defaultLineDash as _ol_render_canvas$defaultLineDash} from '../../ol/render/canvas.js';\nimport {defaultLineDashOffset as _ol_render_canvas$defaultLineDashOffset} from '../../ol/render/canvas.js';\nimport {defaultLineJoin as _ol_render_canvas$defaultLineJoin} from '../../ol/render/canvas.js';\nimport {defaultMiterLimit as _ol_render_canvas$defaultMiterLimit} from '../../ol/render/canvas.js';\nimport {defaultStrokeOffset as _ol_render_canvas$defaultStrokeOffset} from '../../ol/render/canvas.js';\nimport {defaultStrokeStyle as _ol_render_canvas$defaultStrokeStyle} from '../../ol/render/canvas.js';\nimport {defaultTextAlign as _ol_render_canvas$defaultTextAlign} from '../../ol/render/canvas.js';\nimport {defaultTextBaseline as _ol_render_canvas$defaultTextBaseline} from '../../ol/render/canvas.js';\nimport {defaultPadding as _ol_render_canvas$defaultPadding} from '../../ol/render/canvas.js';\nimport {defaultLineWidth as _ol_render_canvas$defaultLineWidth} from '../../ol/render/canvas.js';\nimport {checkedFonts as _ol_render_canvas$checkedFonts} from '../../ol/render/canvas.js';\nimport {textHeights as _ol_render_canvas$textHeights} from '../../ol/render/canvas.js';\nimport {registerFont as _ol_render_canvas$registerFont} from '../../ol/render/canvas.js';\nimport {measureTextHeight as _ol_render_canvas$measureTextHeight} from '../../ol/render/canvas.js';\nimport {measureTextWidth as _ol_render_canvas$measureTextWidth} from '../../ol/render/canvas.js';\nimport {measureAndCacheTextWidth as _ol_render_canvas$measureAndCacheTextWidth} from '../../ol/render/canvas.js';\nimport {getTextDimensions as _ol_render_canvas$getTextDimensions} from '../../ol/render/canvas.js';\nimport {rotateAtOffset as _ol_render_canvas$rotateAtOffset} from '../../ol/render/canvas.js';\nimport {drawImageOrLabel as _ol_render_canvas$drawImageOrLabel} from '../../ol/render/canvas.js';\nimport $ol$render$canvas$Builder from '../../ol/render/canvas/Builder.js';\nimport $ol$render$canvas$BuilderGroup from '../../ol/render/canvas/BuilderGroup.js';\nimport $ol$render$canvas$Executor from '../../ol/render/canvas/Executor.js';\nimport {ALL as _ol_render_canvas_ExecutorGroup$ALL} from '../../ol/render/canvas/ExecutorGroup.js';\nimport {DECLUTTER as _ol_render_canvas_ExecutorGroup$DECLUTTER} from '../../ol/render/canvas/ExecutorGroup.js';\nimport {NON_DECLUTTER as _ol_render_canvas_ExecutorGroup$NON_DECLUTTER} from '../../ol/render/canvas/ExecutorGroup.js';\nimport $ol$render$canvas$ExecutorGroup from '../../ol/render/canvas/ExecutorGroup.js';\nimport {getPixelIndexArray as _ol_render_canvas_ExecutorGroup$getPixelIndexArray} from '../../ol/render/canvas/ExecutorGroup.js';\nimport $ol$render$canvas$ImageBuilder from '../../ol/render/canvas/ImageBuilder.js';\nimport $ol$render$canvas$Immediate from '../../ol/render/canvas/Immediate.js';\nimport {fillInstruction as _ol_render_canvas_Instruction$fillInstruction} from '../../ol/render/canvas/Instruction.js';\nimport {strokeInstruction as _ol_render_canvas_Instruction$strokeInstruction} from '../../ol/render/canvas/Instruction.js';\nimport {beginPathInstruction as _ol_render_canvas_Instruction$beginPathInstruction} from '../../ol/render/canvas/Instruction.js';\nimport {closePathInstruction as _ol_render_canvas_Instruction$closePathInstruction} from '../../ol/render/canvas/Instruction.js';\nimport $ol$render$canvas$LineStringBuilder from '../../ol/render/canvas/LineStringBuilder.js';\nimport $ol$render$canvas$PolygonBuilder from '../../ol/render/canvas/PolygonBuilder.js';\nimport {TEXT_ALIGN as _ol_render_canvas_TextBuilder$TEXT_ALIGN} from '../../ol/render/canvas/TextBuilder.js';\nimport $ol$render$canvas$TextBuilder from '../../ol/render/canvas/TextBuilder.js';\nimport $ol$render$canvas$ZIndexContext from '../../ol/render/canvas/ZIndexContext.js';\nimport {HIT_DETECT_RESOLUTION as _ol_render_canvas_hitdetect$HIT_DETECT_RESOLUTION} from '../../ol/render/canvas/hitdetect.js';\nimport {createHitDetectionImageData as _ol_render_canvas_hitdetect$createHitDetectionImageData} from '../../ol/render/canvas/hitdetect.js';\nimport {hitDetect as _ol_render_canvas_hitdetect$hitDetect} from '../../ol/render/canvas/hitdetect.js';\nimport {rulesToStyleFunction as _ol_render_canvas_style$rulesToStyleFunction} from '../../ol/render/canvas/style.js';\nimport {flatStylesToStyleFunction as _ol_render_canvas_style$flatStylesToStyleFunction} from '../../ol/render/canvas/style.js';\nimport {buildRuleSet as _ol_render_canvas_style$buildRuleSet} from '../../ol/render/canvas/style.js';\nimport {buildStyle as _ol_render_canvas_style$buildStyle} from '../../ol/render/canvas/style.js';\nimport $ol$proj$Projection from '../../ol/proj/Projection.js';\nimport {fromCode as _ol_proj_Units$fromCode} from '../../ol/proj/Units.js';\nimport {METERS_PER_UNIT as _ol_proj_Units$METERS_PER_UNIT} from '../../ol/proj/Units.js';\nimport {RADIUS as _ol_proj_epsg3857$RADIUS} from '../../ol/proj/epsg3857.js';\nimport {HALF_SIZE as _ol_proj_epsg3857$HALF_SIZE} from '../../ol/proj/epsg3857.js';\nimport {EXTENT as _ol_proj_epsg3857$EXTENT} from '../../ol/proj/epsg3857.js';\nimport {WORLD_EXTENT as _ol_proj_epsg3857$WORLD_EXTENT} from '../../ol/proj/epsg3857.js';\nimport {MAX_SAFE_Y as _ol_proj_epsg3857$MAX_SAFE_Y} from '../../ol/proj/epsg3857.js';\nimport {PROJECTIONS as _ol_proj_epsg3857$PROJECTIONS} from '../../ol/proj/epsg3857.js';\nimport {fromEPSG4326 as _ol_proj_epsg3857$fromEPSG4326} from '../../ol/proj/epsg3857.js';\nimport {toEPSG4326 as _ol_proj_epsg3857$toEPSG4326} from '../../ol/proj/epsg3857.js';\nimport {RADIUS as _ol_proj_epsg4326$RADIUS} from '../../ol/proj/epsg4326.js';\nimport {EXTENT as _ol_proj_epsg4326$EXTENT} from '../../ol/proj/epsg4326.js';\nimport {METERS_PER_UNIT as _ol_proj_epsg4326$METERS_PER_UNIT} from '../../ol/proj/epsg4326.js';\nimport {PROJECTIONS as _ol_proj_epsg4326$PROJECTIONS} from '../../ol/proj/epsg4326.js';\nimport {isRegistered as _ol_proj_proj4$isRegistered} from '../../ol/proj/proj4.js';\nimport {unregister as _ol_proj_proj4$unregister} from '../../ol/proj/proj4.js';\nimport {register as _ol_proj_proj4$register} from '../../ol/proj/proj4.js';\nimport {setProjectionCodeLookup as _ol_proj_proj4$setProjectionCodeLookup} from '../../ol/proj/proj4.js';\nimport {getProjectionCodeLookup as _ol_proj_proj4$getProjectionCodeLookup} from '../../ol/proj/proj4.js';\nimport {fromProjectionCode as _ol_proj_proj4$fromProjectionCode} from '../../ol/proj/proj4.js';\nimport {setEPSGLookup as _ol_proj_proj4$setEPSGLookup} from '../../ol/proj/proj4.js';\nimport {getEPSGLookup as _ol_proj_proj4$getEPSGLookup} from '../../ol/proj/proj4.js';\nimport {fromEPSGCode as _ol_proj_proj4$fromEPSGCode} from '../../ol/proj/proj4.js';\nimport {epsgLookupMapTiler as _ol_proj_proj4$epsgLookupMapTiler} from '../../ol/proj/proj4.js';\nimport {clear as _ol_proj_projections$clear} from '../../ol/proj/projections.js';\nimport {get as _ol_proj_projections$get} from '../../ol/proj/projections.js';\nimport {add as _ol_proj_projections$add} from '../../ol/proj/projections.js';\nimport {clear as _ol_proj_transforms$clear} from '../../ol/proj/transforms.js';\nimport {add as _ol_proj_transforms$add} from '../../ol/proj/transforms.js';\nimport {remove as _ol_proj_transforms$remove} from '../../ol/proj/transforms.js';\nimport {get as _ol_proj_transforms$get} from '../../ol/proj/transforms.js';\nimport {zoneFromCode as _ol_proj_utm$zoneFromCode} from '../../ol/proj/utm.js';\nimport {makeProjection as _ol_proj_utm$makeProjection} from '../../ol/proj/utm.js';\nimport {makeTransforms as _ol_proj_utm$makeTransforms} from '../../ol/proj/utm.js';\nimport $ol$layer$Base from '../../ol/layer/Base.js';\nimport $ol$layer$BaseImage from '../../ol/layer/BaseImage.js';\nimport $ol$layer$BaseTile from '../../ol/layer/BaseTile.js';\nimport $ol$layer$BaseVector from '../../ol/layer/BaseVector.js';\nimport $ol$layer$Graticule from '../../ol/layer/Graticule.js';\nimport {GroupEvent as _ol_layer_Group$GroupEvent} from '../../ol/layer/Group.js';\nimport $ol$layer$Group from '../../ol/layer/Group.js';\nimport $ol$layer$Heatmap from '../../ol/layer/Heatmap.js';\nimport $ol$layer$Image from '../../ol/layer/Image.js';\nimport $ol$layer$Layer from '../../ol/layer/Layer.js';\nimport {inView as _ol_layer_Layer$inView} from '../../ol/layer/Layer.js';\nimport $ol$layer$Tile from '../../ol/layer/Tile.js';\nimport $ol$layer$Vector from '../../ol/layer/Vector.js';\nimport $ol$layer$VectorImage from '../../ol/layer/VectorImage.js';\nimport $ol$interaction$DblClickDragZoom from '../../ol/interaction/DblClickDragZoom.js';\nimport $ol$interaction$DoubleClickZoom from '../../ol/interaction/DoubleClickZoom.js';\nimport {DragAndDropEvent as _ol_interaction_DragAndDrop$DragAndDropEvent} from '../../ol/interaction/DragAndDrop.js';\nimport $ol$interaction$DragAndDrop from '../../ol/interaction/DragAndDrop.js';\nimport {DragBoxEvent as _ol_interaction_DragBox$DragBoxEvent} from '../../ol/interaction/DragBox.js';\nimport $ol$interaction$DragBox from '../../ol/interaction/DragBox.js';\nimport $ol$interaction$DragPan from '../../ol/interaction/DragPan.js';\nimport $ol$interaction$DragRotate from '../../ol/interaction/DragRotate.js';\nimport $ol$interaction$DragRotateAndZoom from '../../ol/interaction/DragRotateAndZoom.js';\nimport $ol$interaction$DragZoom from '../../ol/interaction/DragZoom.js';\nimport {DrawEvent as _ol_interaction_Draw$DrawEvent} from '../../ol/interaction/Draw.js';\nimport $ol$interaction$Draw from '../../ol/interaction/Draw.js';\nimport {createRegularPolygon as _ol_interaction_Draw$createRegularPolygon} from '../../ol/interaction/Draw.js';\nimport {createBox as _ol_interaction_Draw$createBox} from '../../ol/interaction/Draw.js';\nimport {ExtentEvent as _ol_interaction_Extent$ExtentEvent} from '../../ol/interaction/Extent.js';\nimport $ol$interaction$Extent from '../../ol/interaction/Extent.js';\nimport $ol$interaction$Interaction from '../../ol/interaction/Interaction.js';\nimport {pan as _ol_interaction_Interaction$pan} from '../../ol/interaction/Interaction.js';\nimport {zoomByDelta as _ol_interaction_Interaction$zoomByDelta} from '../../ol/interaction/Interaction.js';\nimport $ol$interaction$KeyboardPan from '../../ol/interaction/KeyboardPan.js';\nimport $ol$interaction$KeyboardZoom from '../../ol/interaction/KeyboardZoom.js';\nimport $ol$interaction$Link from '../../ol/interaction/Link.js';\nimport {ModifyEvent as _ol_interaction_Modify$ModifyEvent} from '../../ol/interaction/Modify.js';\nimport $ol$interaction$Modify from '../../ol/interaction/Modify.js';\nimport $ol$interaction$MouseWheelZoom from '../../ol/interaction/MouseWheelZoom.js';\nimport $ol$interaction$PinchRotate from '../../ol/interaction/PinchRotate.js';\nimport $ol$interaction$PinchZoom from '../../ol/interaction/PinchZoom.js';\nimport $ol$interaction$Pointer from '../../ol/interaction/Pointer.js';\nimport {centroid as _ol_interaction_Pointer$centroid} from '../../ol/interaction/Pointer.js';\nimport {SelectEvent as _ol_interaction_Select$SelectEvent} from '../../ol/interaction/Select.js';\nimport $ol$interaction$Select from '../../ol/interaction/Select.js';\nimport $ol$interaction$Snap from '../../ol/interaction/Snap.js';\nimport {TranslateEvent as _ol_interaction_Translate$TranslateEvent} from '../../ol/interaction/Translate.js';\nimport $ol$interaction$Translate from '../../ol/interaction/Translate.js';\nimport {defaults as _ol_interaction_defaults$defaults} from '../../ol/interaction/defaults.js';\nimport $ol$geom$Circle from '../../ol/geom/Circle.js';\nimport $ol$geom$Geometry from '../../ol/geom/Geometry.js';\nimport $ol$geom$GeometryCollection from '../../ol/geom/GeometryCollection.js';\nimport $ol$geom$LineString from '../../ol/geom/LineString.js';\nimport $ol$geom$LinearRing from '../../ol/geom/LinearRing.js';\nimport $ol$geom$MultiLineString from '../../ol/geom/MultiLineString.js';\nimport $ol$geom$MultiPoint from '../../ol/geom/MultiPoint.js';\nimport $ol$geom$MultiPolygon from '../../ol/geom/MultiPolygon.js';\nimport $ol$geom$Point from '../../ol/geom/Point.js';\nimport $ol$geom$Polygon from '../../ol/geom/Polygon.js';\nimport {circular as _ol_geom_Polygon$circular} from '../../ol/geom/Polygon.js';\nimport {fromExtent as _ol_geom_Polygon$fromExtent} from '../../ol/geom/Polygon.js';\nimport {fromCircle as _ol_geom_Polygon$fromCircle} from '../../ol/geom/Polygon.js';\nimport {makeRegular as _ol_geom_Polygon$makeRegular} from '../../ol/geom/Polygon.js';\nimport $ol$geom$SimpleGeometry from '../../ol/geom/SimpleGeometry.js';\nimport {getLayoutForStride as _ol_geom_SimpleGeometry$getLayoutForStride} from '../../ol/geom/SimpleGeometry.js';\nimport {getStrideForLayout as _ol_geom_SimpleGeometry$getStrideForLayout} from '../../ol/geom/SimpleGeometry.js';\nimport {transformGeom2D as _ol_geom_SimpleGeometry$transformGeom2D} from '../../ol/geom/SimpleGeometry.js';\nimport {linearRing as _ol_geom_flat_area$linearRing} from '../../ol/geom/flat/area.js';\nimport {linearRings as _ol_geom_flat_area$linearRings} from '../../ol/geom/flat/area.js';\nimport {linearRingss as _ol_geom_flat_area$linearRingss} from '../../ol/geom/flat/area.js';\nimport {linearRingss as _ol_geom_flat_center$linearRingss} from '../../ol/geom/flat/center.js';\nimport {maxSquaredDelta as _ol_geom_flat_closest$maxSquaredDelta} from '../../ol/geom/flat/closest.js';\nimport {arrayMaxSquaredDelta as _ol_geom_flat_closest$arrayMaxSquaredDelta} from '../../ol/geom/flat/closest.js';\nimport {multiArrayMaxSquaredDelta as _ol_geom_flat_closest$multiArrayMaxSquaredDelta} from '../../ol/geom/flat/closest.js';\nimport {assignClosestPoint as _ol_geom_flat_closest$assignClosestPoint} from '../../ol/geom/flat/closest.js';\nimport {assignClosestArrayPoint as _ol_geom_flat_closest$assignClosestArrayPoint} from '../../ol/geom/flat/closest.js';\nimport {assignClosestMultiArrayPoint as _ol_geom_flat_closest$assignClosestMultiArrayPoint} from '../../ol/geom/flat/closest.js';\nimport {linearRingContainsExtent as _ol_geom_flat_contains$linearRingContainsExtent} from '../../ol/geom/flat/contains.js';\nimport {linearRingContainsXY as _ol_geom_flat_contains$linearRingContainsXY} from '../../ol/geom/flat/contains.js';\nimport {linearRingsContainsXY as _ol_geom_flat_contains$linearRingsContainsXY} from '../../ol/geom/flat/contains.js';\nimport {linearRingssContainsXY as _ol_geom_flat_contains$linearRingssContainsXY} from '../../ol/geom/flat/contains.js';\nimport {deflateCoordinate as _ol_geom_flat_deflate$deflateCoordinate} from '../../ol/geom/flat/deflate.js';\nimport {deflateCoordinates as _ol_geom_flat_deflate$deflateCoordinates} from '../../ol/geom/flat/deflate.js';\nimport {deflateCoordinatesArray as _ol_geom_flat_deflate$deflateCoordinatesArray} from '../../ol/geom/flat/deflate.js';\nimport {deflateMultiCoordinatesArray as _ol_geom_flat_deflate$deflateMultiCoordinatesArray} from '../../ol/geom/flat/deflate.js';\nimport {flipXY as _ol_geom_flat_flip$flipXY} from '../../ol/geom/flat/flip.js';\nimport {greatCircleArc as _ol_geom_flat_geodesic$greatCircleArc} from '../../ol/geom/flat/geodesic.js';\nimport {meridian as _ol_geom_flat_geodesic$meridian} from '../../ol/geom/flat/geodesic.js';\nimport {parallel as _ol_geom_flat_geodesic$parallel} from '../../ol/geom/flat/geodesic.js';\nimport {inflateCoordinates as _ol_geom_flat_inflate$inflateCoordinates} from '../../ol/geom/flat/inflate.js';\nimport {inflateCoordinatesArray as _ol_geom_flat_inflate$inflateCoordinatesArray} from '../../ol/geom/flat/inflate.js';\nimport {inflateMultiCoordinatesArray as _ol_geom_flat_inflate$inflateMultiCoordinatesArray} from '../../ol/geom/flat/inflate.js';\nimport {getInteriorPointOfArray as _ol_geom_flat_interiorpoint$getInteriorPointOfArray} from '../../ol/geom/flat/interiorpoint.js';\nimport {getInteriorPointsOfMultiArray as _ol_geom_flat_interiorpoint$getInteriorPointsOfMultiArray} from '../../ol/geom/flat/interiorpoint.js';\nimport {interpolatePoint as _ol_geom_flat_interpolate$interpolatePoint} from '../../ol/geom/flat/interpolate.js';\nimport {lineStringCoordinateAtM as _ol_geom_flat_interpolate$lineStringCoordinateAtM} from '../../ol/geom/flat/interpolate.js';\nimport {lineStringsCoordinateAtM as _ol_geom_flat_interpolate$lineStringsCoordinateAtM} from '../../ol/geom/flat/interpolate.js';\nimport {intersectsLineString as _ol_geom_flat_intersectsextent$intersectsLineString} from '../../ol/geom/flat/intersectsextent.js';\nimport {intersectsLineStringArray as _ol_geom_flat_intersectsextent$intersectsLineStringArray} from '../../ol/geom/flat/intersectsextent.js';\nimport {intersectsLinearRing as _ol_geom_flat_intersectsextent$intersectsLinearRing} from '../../ol/geom/flat/intersectsextent.js';\nimport {intersectsLinearRingArray as _ol_geom_flat_intersectsextent$intersectsLinearRingArray} from '../../ol/geom/flat/intersectsextent.js';\nimport {intersectsLinearRingMultiArray as _ol_geom_flat_intersectsextent$intersectsLinearRingMultiArray} from '../../ol/geom/flat/intersectsextent.js';\nimport {lineStringLength as _ol_geom_flat_length$lineStringLength} from '../../ol/geom/flat/length.js';\nimport {linearRingLength as _ol_geom_flat_length$linearRingLength} from '../../ol/geom/flat/length.js';\nimport {linearRingIsClockwise as _ol_geom_flat_orient$linearRingIsClockwise} from '../../ol/geom/flat/orient.js';\nimport {linearRingsAreOriented as _ol_geom_flat_orient$linearRingsAreOriented} from '../../ol/geom/flat/orient.js';\nimport {linearRingssAreOriented as _ol_geom_flat_orient$linearRingssAreOriented} from '../../ol/geom/flat/orient.js';\nimport {orientLinearRings as _ol_geom_flat_orient$orientLinearRings} from '../../ol/geom/flat/orient.js';\nimport {orientLinearRingsArray as _ol_geom_flat_orient$orientLinearRingsArray} from '../../ol/geom/flat/orient.js';\nimport {inflateEnds as _ol_geom_flat_orient$inflateEnds} from '../../ol/geom/flat/orient.js';\nimport {coordinates as _ol_geom_flat_reverse$coordinates} from '../../ol/geom/flat/reverse.js';\nimport {forEach as _ol_geom_flat_segments$forEach} from '../../ol/geom/flat/segments.js';\nimport {getIntersectionPoint as _ol_geom_flat_segments$getIntersectionPoint} from '../../ol/geom/flat/segments.js';\nimport {simplifyLineString as _ol_geom_flat_simplify$simplifyLineString} from '../../ol/geom/flat/simplify.js';\nimport {douglasPeucker as _ol_geom_flat_simplify$douglasPeucker} from '../../ol/geom/flat/simplify.js';\nimport {douglasPeuckerArray as _ol_geom_flat_simplify$douglasPeuckerArray} from '../../ol/geom/flat/simplify.js';\nimport {douglasPeuckerMultiArray as _ol_geom_flat_simplify$douglasPeuckerMultiArray} from '../../ol/geom/flat/simplify.js';\nimport {radialDistance as _ol_geom_flat_simplify$radialDistance} from '../../ol/geom/flat/simplify.js';\nimport {snap as _ol_geom_flat_simplify$snap} from '../../ol/geom/flat/simplify.js';\nimport {quantize as _ol_geom_flat_simplify$quantize} from '../../ol/geom/flat/simplify.js';\nimport {quantizeArray as _ol_geom_flat_simplify$quantizeArray} from '../../ol/geom/flat/simplify.js';\nimport {quantizeMultiArray as _ol_geom_flat_simplify$quantizeMultiArray} from '../../ol/geom/flat/simplify.js';\nimport {matchingChunk as _ol_geom_flat_straightchunk$matchingChunk} from '../../ol/geom/flat/straightchunk.js';\nimport {drawTextOnPath as _ol_geom_flat_textpath$drawTextOnPath} from '../../ol/geom/flat/textpath.js';\nimport {lineStringIsClosed as _ol_geom_flat_topology$lineStringIsClosed} from '../../ol/geom/flat/topology.js';\nimport {transform2D as _ol_geom_flat_transform$transform2D} from '../../ol/geom/flat/transform.js';\nimport {rotate as _ol_geom_flat_transform$rotate} from '../../ol/geom/flat/transform.js';\nimport {scale as _ol_geom_flat_transform$scale} from '../../ol/geom/flat/transform.js';\nimport {translate as _ol_geom_flat_transform$translate} from '../../ol/geom/flat/transform.js';\nimport $ol$format$Feature from '../../ol/format/Feature.js';\nimport {transformGeometryWithOptions as _ol_format_Feature$transformGeometryWithOptions} from '../../ol/format/Feature.js';\nimport {transformExtentWithOptions as _ol_format_Feature$transformExtentWithOptions} from '../../ol/format/Feature.js';\nimport {createRenderFeature as _ol_format_Feature$createRenderFeature} from '../../ol/format/Feature.js';\nimport {createGeometry as _ol_format_Feature$createGeometry} from '../../ol/format/Feature.js';\nimport $ol$format$GPX from '../../ol/format/GPX.js';\nimport $ol$format$GeoJSON from '../../ol/format/GeoJSON.js';\nimport $ol$format$IGC from '../../ol/format/IGC.js';\nimport $ol$format$JSONFeature from '../../ol/format/JSONFeature.js';\nimport {getDefaultFillStyle as _ol_format_KML$getDefaultFillStyle} from '../../ol/format/KML.js';\nimport {getDefaultImageStyle as _ol_format_KML$getDefaultImageStyle} from '../../ol/format/KML.js';\nimport {getDefaultStrokeStyle as _ol_format_KML$getDefaultStrokeStyle} from '../../ol/format/KML.js';\nimport {getDefaultTextStyle as _ol_format_KML$getDefaultTextStyle} from '../../ol/format/KML.js';\nimport {getDefaultStyle as _ol_format_KML$getDefaultStyle} from '../../ol/format/KML.js';\nimport {getDefaultStyleArray as _ol_format_KML$getDefaultStyleArray} from '../../ol/format/KML.js';\nimport $ol$format$KML from '../../ol/format/KML.js';\nimport {readFlatCoordinates as _ol_format_KML$readFlatCoordinates} from '../../ol/format/KML.js';\nimport $ol$format$MVT from '../../ol/format/MVT.js';\nimport $ol$format$OSMXML from '../../ol/format/OSMXML.js';\nimport $ol$format$OWS from '../../ol/format/OWS.js';\nimport $ol$format$Polyline from '../../ol/format/Polyline.js';\nimport {encodeDeltas as _ol_format_Polyline$encodeDeltas} from '../../ol/format/Polyline.js';\nimport {decodeDeltas as _ol_format_Polyline$decodeDeltas} from '../../ol/format/Polyline.js';\nimport {encodeFloats as _ol_format_Polyline$encodeFloats} from '../../ol/format/Polyline.js';\nimport {decodeFloats as _ol_format_Polyline$decodeFloats} from '../../ol/format/Polyline.js';\nimport {encodeSignedIntegers as _ol_format_Polyline$encodeSignedIntegers} from '../../ol/format/Polyline.js';\nimport {decodeSignedIntegers as _ol_format_Polyline$decodeSignedIntegers} from '../../ol/format/Polyline.js';\nimport {encodeUnsignedIntegers as _ol_format_Polyline$encodeUnsignedIntegers} from '../../ol/format/Polyline.js';\nimport {decodeUnsignedIntegers as _ol_format_Polyline$decodeUnsignedIntegers} from '../../ol/format/Polyline.js';\nimport {encodeUnsignedInteger as _ol_format_Polyline$encodeUnsignedInteger} from '../../ol/format/Polyline.js';\nimport $ol$format$TextFeature from '../../ol/format/TextFeature.js';\nimport $ol$format$TopoJSON from '../../ol/format/TopoJSON.js';\nimport $ol$format$WFS from '../../ol/format/WFS.js';\nimport {writeFilter as _ol_format_WFS$writeFilter} from '../../ol/format/WFS.js';\nimport $ol$format$WMSGetFeatureInfo from '../../ol/format/WMSGetFeatureInfo.js';\nimport $ol$format$WMTSCapabilities from '../../ol/format/WMTSCapabilities.js';\nimport {readHref as _ol_format_xlink$readHref} from '../../ol/format/xlink.js';\nimport {readBoolean as _ol_format_xsd$readBoolean} from '../../ol/format/xsd.js';\nimport {readBooleanString as _ol_format_xsd$readBooleanString} from '../../ol/format/xsd.js';\nimport {readDateTime as _ol_format_xsd$readDateTime} from '../../ol/format/xsd.js';\nimport {readDecimal as _ol_format_xsd$readDecimal} from '../../ol/format/xsd.js';\nimport {readDecimalString as _ol_format_xsd$readDecimalString} from '../../ol/format/xsd.js';\nimport {readPositiveInteger as _ol_format_xsd$readPositiveInteger} from '../../ol/format/xsd.js';\nimport {readNonNegativeIntegerString as _ol_format_xsd$readNonNegativeIntegerString} from '../../ol/format/xsd.js';\nimport {readString as _ol_format_xsd$readString} from '../../ol/format/xsd.js';\nimport {writeBooleanTextNode as _ol_format_xsd$writeBooleanTextNode} from '../../ol/format/xsd.js';\nimport {writeCDATASection as _ol_format_xsd$writeCDATASection} from '../../ol/format/xsd.js';\nimport {writeDateTimeTextNode as _ol_format_xsd$writeDateTimeTextNode} from '../../ol/format/xsd.js';\nimport {writeDecimalTextNode as _ol_format_xsd$writeDecimalTextNode} from '../../ol/format/xsd.js';\nimport {writeNonNegativeIntegerTextNode as _ol_format_xsd$writeNonNegativeIntegerTextNode} from '../../ol/format/xsd.js';\nimport {writeStringTextNode as _ol_format_xsd$writeStringTextNode} from '../../ol/format/xsd.js';\nimport {newEvaluationContext as _ol_expr_cpu$newEvaluationContext} from '../../ol/expr/cpu.js';\nimport {buildExpression as _ol_expr_cpu$buildExpression} from '../../ol/expr/cpu.js';\nimport {NoneType as _ol_expr_expression$NoneType} from '../../ol/expr/expression.js';\nimport {BooleanType as _ol_expr_expression$BooleanType} from '../../ol/expr/expression.js';\nimport {NumberType as _ol_expr_expression$NumberType} from '../../ol/expr/expression.js';\nimport {StringType as _ol_expr_expression$StringType} from '../../ol/expr/expression.js';\nimport {ColorType as _ol_expr_expression$ColorType} from '../../ol/expr/expression.js';\nimport {NumberArrayType as _ol_expr_expression$NumberArrayType} from '../../ol/expr/expression.js';\nimport {SizeType as _ol_expr_expression$SizeType} from '../../ol/expr/expression.js';\nimport {AnyType as _ol_expr_expression$AnyType} from '../../ol/expr/expression.js';\nimport {typeName as _ol_expr_expression$typeName} from '../../ol/expr/expression.js';\nimport {includesType as _ol_expr_expression$includesType} from '../../ol/expr/expression.js';\nimport {overlapsType as _ol_expr_expression$overlapsType} from '../../ol/expr/expression.js';\nimport {isType as _ol_expr_expression$isType} from '../../ol/expr/expression.js';\nimport {LiteralExpression as _ol_expr_expression$LiteralExpression} from '../../ol/expr/expression.js';\nimport {CallExpression as _ol_expr_expression$CallExpression} from '../../ol/expr/expression.js';\nimport {newParsingContext as _ol_expr_expression$newParsingContext} from '../../ol/expr/expression.js';\nimport {parse as _ol_expr_expression$parse} from '../../ol/expr/expression.js';\nimport {Ops as _ol_expr_expression$Ops} from '../../ol/expr/expression.js';\nimport {computeGeometryType as _ol_expr_expression$computeGeometryType} from '../../ol/expr/expression.js';\nimport {numberToGlsl as _ol_expr_gpu$numberToGlsl} from '../../ol/expr/gpu.js';\nimport {arrayToGlsl as _ol_expr_gpu$arrayToGlsl} from '../../ol/expr/gpu.js';\nimport {colorToGlsl as _ol_expr_gpu$colorToGlsl} from '../../ol/expr/gpu.js';\nimport {sizeToGlsl as _ol_expr_gpu$sizeToGlsl} from '../../ol/expr/gpu.js';\nimport {getStringNumberEquivalent as _ol_expr_gpu$getStringNumberEquivalent} from '../../ol/expr/gpu.js';\nimport {stringToGlsl as _ol_expr_gpu$stringToGlsl} from '../../ol/expr/gpu.js';\nimport {uniformNameForVariable as _ol_expr_gpu$uniformNameForVariable} from '../../ol/expr/gpu.js';\nimport {newCompilationContext as _ol_expr_gpu$newCompilationContext} from '../../ol/expr/gpu.js';\nimport {PALETTE_TEXTURE_ARRAY as _ol_expr_gpu$PALETTE_TEXTURE_ARRAY} from '../../ol/expr/gpu.js';\nimport {FEATURE_ID_PROPERTY_NAME as _ol_expr_gpu$FEATURE_ID_PROPERTY_NAME} from '../../ol/expr/gpu.js';\nimport {GEOMETRY_TYPE_PROPERTY_NAME as _ol_expr_gpu$GEOMETRY_TYPE_PROPERTY_NAME} from '../../ol/expr/gpu.js';\nimport {UNDEFINED_PROP_VALUE as _ol_expr_gpu$UNDEFINED_PROP_VALUE} from '../../ol/expr/gpu.js';\nimport {buildExpression as _ol_expr_gpu$buildExpression} from '../../ol/expr/gpu.js';\nimport $ol$events$Event from '../../ol/events/Event.js';\nimport {stopPropagation as _ol_events_Event$stopPropagation} from '../../ol/events/Event.js';\nimport {preventDefault as _ol_events_Event$preventDefault} from '../../ol/events/Event.js';\nimport {SnapEvent as _ol_events_SnapEvent$SnapEvent} from '../../ol/events/SnapEvent.js';\nimport $ol$events$Target from '../../ol/events/Target.js';\nimport {all as _ol_events_condition$all} from '../../ol/events/condition.js';\nimport {altKeyOnly as _ol_events_condition$altKeyOnly} from '../../ol/events/condition.js';\nimport {altShiftKeysOnly as _ol_events_condition$altShiftKeysOnly} from '../../ol/events/condition.js';\nimport {focus as _ol_events_condition$focus} from '../../ol/events/condition.js';\nimport {focusWithTabindex as _ol_events_condition$focusWithTabindex} from '../../ol/events/condition.js';\nimport {always as _ol_events_condition$always} from '../../ol/events/condition.js';\nimport {click as _ol_events_condition$click} from '../../ol/events/condition.js';\nimport {mouseActionButton as _ol_events_condition$mouseActionButton} from '../../ol/events/condition.js';\nimport {never as _ol_events_condition$never} from '../../ol/events/condition.js';\nimport {pointerMove as _ol_events_condition$pointerMove} from '../../ol/events/condition.js';\nimport {singleClick as _ol_events_condition$singleClick} from '../../ol/events/condition.js';\nimport {doubleClick as _ol_events_condition$doubleClick} from '../../ol/events/condition.js';\nimport {noModifierKeys as _ol_events_condition$noModifierKeys} from '../../ol/events/condition.js';\nimport {platformModifierKeyOnly as _ol_events_condition$platformModifierKeyOnly} from '../../ol/events/condition.js';\nimport {platformModifierKey as _ol_events_condition$platformModifierKey} from '../../ol/events/condition.js';\nimport {shiftKeyOnly as _ol_events_condition$shiftKeyOnly} from '../../ol/events/condition.js';\nimport {targetNotEditable as _ol_events_condition$targetNotEditable} from '../../ol/events/condition.js';\nimport {mouseOnly as _ol_events_condition$mouseOnly} from '../../ol/events/condition.js';\nimport {touchOnly as _ol_events_condition$touchOnly} from '../../ol/events/condition.js';\nimport {penOnly as _ol_events_condition$penOnly} from '../../ol/events/condition.js';\nimport {primaryAction as _ol_events_condition$primaryAction} from '../../ol/events/condition.js';\nimport $ol$control$Attribution from '../../ol/control/Attribution.js';\nimport $ol$control$Control from '../../ol/control/Control.js';\nimport $ol$control$FullScreen from '../../ol/control/FullScreen.js';\nimport $ol$control$MousePosition from '../../ol/control/MousePosition.js';\nimport $ol$control$OverviewMap from '../../ol/control/OverviewMap.js';\nimport $ol$control$Rotate from '../../ol/control/Rotate.js';\nimport $ol$control$ScaleLine from '../../ol/control/ScaleLine.js';\nimport $ol$control$Zoom from '../../ol/control/Zoom.js';\nimport $ol$control$ZoomSlider from '../../ol/control/ZoomSlider.js';\nimport $ol$control$ZoomToExtent from '../../ol/control/ZoomToExtent.js';\nimport {defaults as _ol_control_defaults$defaults} from '../../ol/control/defaults.js';\n\nvar ol = {};\nol.Collection = $ol$Collection;\nol.Collection.CollectionEvent = _ol_Collection$CollectionEvent;\nol.DataTile = $ol$DataTile;\nol.DataTile.asArrayLike = _ol_DataTile$asArrayLike;\nol.DataTile.asImageLike = _ol_DataTile$asImageLike;\nol.DataTile.disposedError = _ol_DataTile$disposedError;\nol.DataTile.toArray = _ol_DataTile$toArray;\nol.Disposable = $ol$Disposable;\nol.Feature = $ol$Feature;\nol.Feature.createStyleFunction = _ol_Feature$createStyleFunction;\nol.Geolocation = $ol$Geolocation;\nol.Geolocation.GeolocationError = _ol_Geolocation$GeolocationError;\nol.Image = $ol$Image;\nol.Image.decode = _ol_Image$decode;\nol.Image.decodeFallback = _ol_Image$decodeFallback;\nol.Image.listenImage = _ol_Image$listenImage;\nol.Image.load = _ol_Image$load;\nol.ImageCanvas = $ol$ImageCanvas;\nol.ImageTile = $ol$ImageTile;\nol.Kinetic = $ol$Kinetic;\nol.Map = $ol$Map;\nol.MapBrowserEvent = $ol$MapBrowserEvent;\nol.MapBrowserEventHandler = $ol$MapBrowserEventHandler;\nol.MapEvent = $ol$MapEvent;\nol.Object = $ol$Object;\nol.Object.ObjectEvent = _ol_Object$ObjectEvent;\nol.Observable = $ol$Observable;\nol.Observable.unByKey = _ol_Observable$unByKey;\nol.Overlay = $ol$Overlay;\nol.Tile = $ol$Tile;\nol.TileQueue = $ol$TileQueue;\nol.TileQueue.getTilePriority = _ol_TileQueue$getTilePriority;\nol.TileRange = $ol$TileRange;\nol.TileRange.createOrUpdate = _ol_TileRange$createOrUpdate;\nol.VectorRenderTile = $ol$VectorRenderTile;\nol.View = $ol$View;\nol.View.createCenterConstraint = _ol_View$createCenterConstraint;\nol.View.createResolutionConstraint = _ol_View$createResolutionConstraint;\nol.View.createRotationConstraint = _ol_View$createRotationConstraint;\nol.View.getView = _ol_View$getView;\nol.View.isNoopAnimation = _ol_View$isNoopAnimation;\nol.View.withExtentCenter = _ol_View$withExtentCenter;\nol.View.withHigherResolutions = _ol_View$withHigherResolutions;\nol.View.withLowerResolutions = _ol_View$withLowerResolutions;\nol.View.withZoom = _ol_View$withZoom;\nol.array = {};\nol.array.ascending = _ol_array$ascending;\nol.array.binarySearch = _ol_array$binarySearch;\nol.array.descending = _ol_array$descending;\nol.array.equals = _ol_array$equals;\nol.array.extend = _ol_array$extend;\nol.array.isSorted = _ol_array$isSorted;\nol.array.linearFindNearest = _ol_array$linearFindNearest;\nol.array.remove = _ol_array$remove;\nol.array.reverseSubArray = _ol_array$reverseSubArray;\nol.array.stableSort = _ol_array$stableSort;\nol.asserts = {};\nol.asserts.assert = _ol_asserts$assert;\nol.centerconstraint = {};\nol.centerconstraint.createExtent = _ol_centerconstraint$createExtent;\nol.centerconstraint.none = _ol_centerconstraint$none;\nol.color = {};\nol.color.NO_COLOR = _ol_color$NO_COLOR;\nol.color.asArray = _ol_color$asArray;\nol.color.asString = _ol_color$asString;\nol.color.fromString = _ol_color$fromString;\nol.color.isStringColor = _ol_color$isStringColor;\nol.color.lchaToRgba = _ol_color$lchaToRgba;\nol.color.rgbaToLcha = _ol_color$rgbaToLcha;\nol.color.toString = _ol_color$toString;\nol.color.withAlpha = _ol_color$withAlpha;\nol.colorlike = {};\nol.colorlike.asColorLike = _ol_colorlike$asColorLike;\nol.console = {};\nol.console.error = _ol_console$error;\nol.console.log = _ol_console$log;\nol.console.setLevel = _ol_console$setLevel;\nol.console.warn = _ol_console$warn;\nol.control = {};\nol.control.Attribution = $ol$control$Attribution;\nol.control.Control = $ol$control$Control;\nol.control.FullScreen = $ol$control$FullScreen;\nol.control.MousePosition = $ol$control$MousePosition;\nol.control.OverviewMap = $ol$control$OverviewMap;\nol.control.Rotate = $ol$control$Rotate;\nol.control.ScaleLine = $ol$control$ScaleLine;\nol.control.Zoom = $ol$control$Zoom;\nol.control.ZoomSlider = $ol$control$ZoomSlider;\nol.control.ZoomToExtent = $ol$control$ZoomToExtent;\nol.control.defaults = {};\nol.control.defaults.defaults = _ol_control_defaults$defaults;\nol.coordinate = {};\nol.coordinate.add = _ol_coordinate$add;\nol.coordinate.angleBetween = _ol_coordinate$angleBetween;\nol.coordinate.closestOnCircle = _ol_coordinate$closestOnCircle;\nol.coordinate.closestOnSegment = _ol_coordinate$closestOnSegment;\nol.coordinate.createStringXY = _ol_coordinate$createStringXY;\nol.coordinate.degreesToStringHDMS = _ol_coordinate$degreesToStringHDMS;\nol.coordinate.distance = _ol_coordinate$distance;\nol.coordinate.equals = _ol_coordinate$equals;\nol.coordinate.format = _ol_coordinate$format;\nol.coordinate.getWorldsAway = _ol_coordinate$getWorldsAway;\nol.coordinate.rotate = _ol_coordinate$rotate;\nol.coordinate.scale = _ol_coordinate$scale;\nol.coordinate.squaredDistance = _ol_coordinate$squaredDistance;\nol.coordinate.squaredDistanceToSegment = _ol_coordinate$squaredDistanceToSegment;\nol.coordinate.toStringHDMS = _ol_coordinate$toStringHDMS;\nol.coordinate.toStringXY = _ol_coordinate$toStringXY;\nol.coordinate.wrapX = _ol_coordinate$wrapX;\nol.css = {};\nol.css.CLASS_COLLAPSED = _ol_css$CLASS_COLLAPSED;\nol.css.CLASS_CONTROL = _ol_css$CLASS_CONTROL;\nol.css.CLASS_HIDDEN = _ol_css$CLASS_HIDDEN;\nol.css.CLASS_SELECTABLE = _ol_css$CLASS_SELECTABLE;\nol.css.CLASS_UNSELECTABLE = _ol_css$CLASS_UNSELECTABLE;\nol.css.CLASS_UNSUPPORTED = _ol_css$CLASS_UNSUPPORTED;\nol.css.fontWeights = _ol_css$fontWeights;\nol.css.getFontParameters = _ol_css$getFontParameters;\nol.dom = {};\nol.dom.createCanvasContext2D = _ol_dom$createCanvasContext2D;\nol.dom.createMockDiv = _ol_dom$createMockDiv;\nol.dom.getSharedCanvasContext2D = _ol_dom$getSharedCanvasContext2D;\nol.dom.isCanvas = _ol_dom$isCanvas;\nol.dom.outerHeight = _ol_dom$outerHeight;\nol.dom.outerWidth = _ol_dom$outerWidth;\nol.dom.releaseCanvas = _ol_dom$releaseCanvas;\nol.dom.removeChildren = _ol_dom$removeChildren;\nol.dom.replaceChildren = _ol_dom$replaceChildren;\nol.dom.replaceNode = _ol_dom$replaceNode;\nol.easing = {};\nol.easing.easeIn = _ol_easing$easeIn;\nol.easing.easeOut = _ol_easing$easeOut;\nol.easing.inAndOut = _ol_easing$inAndOut;\nol.easing.linear = _ol_easing$linear;\nol.easing.upAndDown = _ol_easing$upAndDown;\nol.events = {};\nol.events.Event = $ol$events$Event;\nol.events.Event.preventDefault = _ol_events_Event$preventDefault;\nol.events.Event.stopPropagation = _ol_events_Event$stopPropagation;\nol.events.SnapEvent = {};\nol.events.SnapEvent.SnapEvent = _ol_events_SnapEvent$SnapEvent;\nol.events.Target = $ol$events$Target;\nol.events.condition = {};\nol.events.condition.all = _ol_events_condition$all;\nol.events.condition.altKeyOnly = _ol_events_condition$altKeyOnly;\nol.events.condition.altShiftKeysOnly = _ol_events_condition$altShiftKeysOnly;\nol.events.condition.always = _ol_events_condition$always;\nol.events.condition.click = _ol_events_condition$click;\nol.events.condition.doubleClick = _ol_events_condition$doubleClick;\nol.events.condition.focus = _ol_events_condition$focus;\nol.events.condition.focusWithTabindex = _ol_events_condition$focusWithTabindex;\nol.events.condition.mouseActionButton = _ol_events_condition$mouseActionButton;\nol.events.condition.mouseOnly = _ol_events_condition$mouseOnly;\nol.events.condition.never = _ol_events_condition$never;\nol.events.condition.noModifierKeys = _ol_events_condition$noModifierKeys;\nol.events.condition.penOnly = _ol_events_condition$penOnly;\nol.events.condition.platformModifierKey = _ol_events_condition$platformModifierKey;\nol.events.condition.platformModifierKeyOnly = _ol_events_condition$platformModifierKeyOnly;\nol.events.condition.pointerMove = _ol_events_condition$pointerMove;\nol.events.condition.primaryAction = _ol_events_condition$primaryAction;\nol.events.condition.shiftKeyOnly = _ol_events_condition$shiftKeyOnly;\nol.events.condition.singleClick = _ol_events_condition$singleClick;\nol.events.condition.targetNotEditable = _ol_events_condition$targetNotEditable;\nol.events.condition.touchOnly = _ol_events_condition$touchOnly;\nol.events.listen = _ol_events$listen;\nol.events.listenOnce = _ol_events$listenOnce;\nol.events.unlistenByKey = _ol_events$unlistenByKey;\nol.expr = {};\nol.expr.cpu = {};\nol.expr.cpu.buildExpression = _ol_expr_cpu$buildExpression;\nol.expr.cpu.newEvaluationContext = _ol_expr_cpu$newEvaluationContext;\nol.expr.expression = {};\nol.expr.expression.AnyType = _ol_expr_expression$AnyType;\nol.expr.expression.BooleanType = _ol_expr_expression$BooleanType;\nol.expr.expression.CallExpression = _ol_expr_expression$CallExpression;\nol.expr.expression.ColorType = _ol_expr_expression$ColorType;\nol.expr.expression.LiteralExpression = _ol_expr_expression$LiteralExpression;\nol.expr.expression.NoneType = _ol_expr_expression$NoneType;\nol.expr.expression.NumberArrayType = _ol_expr_expression$NumberArrayType;\nol.expr.expression.NumberType = _ol_expr_expression$NumberType;\nol.expr.expression.Ops = _ol_expr_expression$Ops;\nol.expr.expression.SizeType = _ol_expr_expression$SizeType;\nol.expr.expression.StringType = _ol_expr_expression$StringType;\nol.expr.expression.computeGeometryType = _ol_expr_expression$computeGeometryType;\nol.expr.expression.includesType = _ol_expr_expression$includesType;\nol.expr.expression.isType = _ol_expr_expression$isType;\nol.expr.expression.newParsingContext = _ol_expr_expression$newParsingContext;\nol.expr.expression.overlapsType = _ol_expr_expression$overlapsType;\nol.expr.expression.parse = _ol_expr_expression$parse;\nol.expr.expression.typeName = _ol_expr_expression$typeName;\nol.expr.gpu = {};\nol.expr.gpu.FEATURE_ID_PROPERTY_NAME = _ol_expr_gpu$FEATURE_ID_PROPERTY_NAME;\nol.expr.gpu.GEOMETRY_TYPE_PROPERTY_NAME = _ol_expr_gpu$GEOMETRY_TYPE_PROPERTY_NAME;\nol.expr.gpu.PALETTE_TEXTURE_ARRAY = _ol_expr_gpu$PALETTE_TEXTURE_ARRAY;\nol.expr.gpu.UNDEFINED_PROP_VALUE = _ol_expr_gpu$UNDEFINED_PROP_VALUE;\nol.expr.gpu.arrayToGlsl = _ol_expr_gpu$arrayToGlsl;\nol.expr.gpu.buildExpression = _ol_expr_gpu$buildExpression;\nol.expr.gpu.colorToGlsl = _ol_expr_gpu$colorToGlsl;\nol.expr.gpu.getStringNumberEquivalent = _ol_expr_gpu$getStringNumberEquivalent;\nol.expr.gpu.newCompilationContext = _ol_expr_gpu$newCompilationContext;\nol.expr.gpu.numberToGlsl = _ol_expr_gpu$numberToGlsl;\nol.expr.gpu.sizeToGlsl = _ol_expr_gpu$sizeToGlsl;\nol.expr.gpu.stringToGlsl = _ol_expr_gpu$stringToGlsl;\nol.expr.gpu.uniformNameForVariable = _ol_expr_gpu$uniformNameForVariable;\nol.extent = {};\nol.extent.applyTransform = _ol_extent$applyTransform;\nol.extent.approximatelyEquals = _ol_extent$approximatelyEquals;\nol.extent.boundingExtent = _ol_extent$boundingExtent;\nol.extent.buffer = _ol_extent$buffer;\nol.extent.clone = _ol_extent$clone;\nol.extent.closestSquaredDistanceXY = _ol_extent$closestSquaredDistanceXY;\nol.extent.containsCoordinate = _ol_extent$containsCoordinate;\nol.extent.containsExtent = _ol_extent$containsExtent;\nol.extent.containsXY = _ol_extent$containsXY;\nol.extent.coordinateRelationship = _ol_extent$coordinateRelationship;\nol.extent.createEmpty = _ol_extent$createEmpty;\nol.extent.createOrUpdate = _ol_extent$createOrUpdate;\nol.extent.createOrUpdateEmpty = _ol_extent$createOrUpdateEmpty;\nol.extent.createOrUpdateFromCoordinate = _ol_extent$createOrUpdateFromCoordinate;\nol.extent.createOrUpdateFromCoordinates = _ol_extent$createOrUpdateFromCoordinates;\nol.extent.createOrUpdateFromFlatCoordinates = _ol_extent$createOrUpdateFromFlatCoordinates;\nol.extent.createOrUpdateFromRings = _ol_extent$createOrUpdateFromRings;\nol.extent.equals = _ol_extent$equals;\nol.extent.extend = _ol_extent$extend;\nol.extent.extendCoordinate = _ol_extent$extendCoordinate;\nol.extent.extendCoordinates = _ol_extent$extendCoordinates;\nol.extent.extendFlatCoordinates = _ol_extent$extendFlatCoordinates;\nol.extent.extendRings = _ol_extent$extendRings;\nol.extent.extendXY = _ol_extent$extendXY;\nol.extent.forEachCorner = _ol_extent$forEachCorner;\nol.extent.getArea = _ol_extent$getArea;\nol.extent.getBottomLeft = _ol_extent$getBottomLeft;\nol.extent.getBottomRight = _ol_extent$getBottomRight;\nol.extent.getCenter = _ol_extent$getCenter;\nol.extent.getCorner = _ol_extent$getCorner;\nol.extent.getEnlargedArea = _ol_extent$getEnlargedArea;\nol.extent.getForViewAndSize = _ol_extent$getForViewAndSize;\nol.extent.getHeight = _ol_extent$getHeight;\nol.extent.getIntersection = _ol_extent$getIntersection;\nol.extent.getIntersectionArea = _ol_extent$getIntersectionArea;\nol.extent.getMargin = _ol_extent$getMargin;\nol.extent.getRotatedViewport = _ol_extent$getRotatedViewport;\nol.extent.getSize = _ol_extent$getSize;\nol.extent.getTopLeft = _ol_extent$getTopLeft;\nol.extent.getTopRight = _ol_extent$getTopRight;\nol.extent.getWidth = _ol_extent$getWidth;\nol.extent.intersects = _ol_extent$intersects;\nol.extent.intersectsSegment = _ol_extent$intersectsSegment;\nol.extent.isEmpty = _ol_extent$isEmpty;\nol.extent.returnOrUpdate = _ol_extent$returnOrUpdate;\nol.extent.scaleFromCenter = _ol_extent$scaleFromCenter;\nol.extent.wrapAndSliceX = _ol_extent$wrapAndSliceX;\nol.extent.wrapX = _ol_extent$wrapX;\nol.featureloader = {};\nol.featureloader.loadFeaturesXhr = _ol_featureloader$loadFeaturesXhr;\nol.featureloader.setWithCredentials = _ol_featureloader$setWithCredentials;\nol.featureloader.xhr = _ol_featureloader$xhr;\nol.format = {};\nol.format.Feature = $ol$format$Feature;\nol.format.Feature.createGeometry = _ol_format_Feature$createGeometry;\nol.format.Feature.createRenderFeature = _ol_format_Feature$createRenderFeature;\nol.format.Feature.transformExtentWithOptions = _ol_format_Feature$transformExtentWithOptions;\nol.format.Feature.transformGeometryWithOptions = _ol_format_Feature$transformGeometryWithOptions;\nol.format.GPX = $ol$format$GPX;\nol.format.GeoJSON = $ol$format$GeoJSON;\nol.format.IGC = $ol$format$IGC;\nol.format.JSONFeature = $ol$format$JSONFeature;\nol.format.KML = $ol$format$KML;\nol.format.KML.getDefaultFillStyle = _ol_format_KML$getDefaultFillStyle;\nol.format.KML.getDefaultImageStyle = _ol_format_KML$getDefaultImageStyle;\nol.format.KML.getDefaultStrokeStyle = _ol_format_KML$getDefaultStrokeStyle;\nol.format.KML.getDefaultStyle = _ol_format_KML$getDefaultStyle;\nol.format.KML.getDefaultStyleArray = _ol_format_KML$getDefaultStyleArray;\nol.format.KML.getDefaultTextStyle = _ol_format_KML$getDefaultTextStyle;\nol.format.KML.readFlatCoordinates = _ol_format_KML$readFlatCoordinates;\nol.format.MVT = $ol$format$MVT;\nol.format.OSMXML = $ol$format$OSMXML;\nol.format.OWS = $ol$format$OWS;\nol.format.Polyline = $ol$format$Polyline;\nol.format.Polyline.decodeDeltas = _ol_format_Polyline$decodeDeltas;\nol.format.Polyline.decodeFloats = _ol_format_Polyline$decodeFloats;\nol.format.Polyline.decodeSignedIntegers = _ol_format_Polyline$decodeSignedIntegers;\nol.format.Polyline.decodeUnsignedIntegers = _ol_format_Polyline$decodeUnsignedIntegers;\nol.format.Polyline.encodeDeltas = _ol_format_Polyline$encodeDeltas;\nol.format.Polyline.encodeFloats = _ol_format_Polyline$encodeFloats;\nol.format.Polyline.encodeSignedIntegers = _ol_format_Polyline$encodeSignedIntegers;\nol.format.Polyline.encodeUnsignedInteger = _ol_format_Polyline$encodeUnsignedInteger;\nol.format.Polyline.encodeUnsignedIntegers = _ol_format_Polyline$encodeUnsignedIntegers;\nol.format.TextFeature = $ol$format$TextFeature;\nol.format.TopoJSON = $ol$format$TopoJSON;\nol.format.WFS = $ol$format$WFS;\nol.format.WFS.writeFilter = _ol_format_WFS$writeFilter;\nol.format.WMSGetFeatureInfo = $ol$format$WMSGetFeatureInfo;\nol.format.WMTSCapabilities = $ol$format$WMTSCapabilities;\nol.format.xlink = {};\nol.format.xlink.readHref = _ol_format_xlink$readHref;\nol.format.xsd = {};\nol.format.xsd.readBoolean = _ol_format_xsd$readBoolean;\nol.format.xsd.readBooleanString = _ol_format_xsd$readBooleanString;\nol.format.xsd.readDateTime = _ol_format_xsd$readDateTime;\nol.format.xsd.readDecimal = _ol_format_xsd$readDecimal;\nol.format.xsd.readDecimalString = _ol_format_xsd$readDecimalString;\nol.format.xsd.readNonNegativeIntegerString = _ol_format_xsd$readNonNegativeIntegerString;\nol.format.xsd.readPositiveInteger = _ol_format_xsd$readPositiveInteger;\nol.format.xsd.readString = _ol_format_xsd$readString;\nol.format.xsd.writeBooleanTextNode = _ol_format_xsd$writeBooleanTextNode;\nol.format.xsd.writeCDATASection = _ol_format_xsd$writeCDATASection;\nol.format.xsd.writeDateTimeTextNode = _ol_format_xsd$writeDateTimeTextNode;\nol.format.xsd.writeDecimalTextNode = _ol_format_xsd$writeDecimalTextNode;\nol.format.xsd.writeNonNegativeIntegerTextNode = _ol_format_xsd$writeNonNegativeIntegerTextNode;\nol.format.xsd.writeStringTextNode = _ol_format_xsd$writeStringTextNode;\nol.functions = {};\nol.functions.FALSE = _ol_functions$FALSE;\nol.functions.TRUE = _ol_functions$TRUE;\nol.functions.VOID = _ol_functions$VOID;\nol.functions.memoizeOne = _ol_functions$memoizeOne;\nol.functions.toPromise = _ol_functions$toPromise;\nol.geom = {};\nol.geom.Circle = $ol$geom$Circle;\nol.geom.Geometry = $ol$geom$Geometry;\nol.geom.GeometryCollection = $ol$geom$GeometryCollection;\nol.geom.LineString = $ol$geom$LineString;\nol.geom.LinearRing = $ol$geom$LinearRing;\nol.geom.MultiLineString = $ol$geom$MultiLineString;\nol.geom.MultiPoint = $ol$geom$MultiPoint;\nol.geom.MultiPolygon = $ol$geom$MultiPolygon;\nol.geom.Point = $ol$geom$Point;\nol.geom.Polygon = $ol$geom$Polygon;\nol.geom.Polygon.circular = _ol_geom_Polygon$circular;\nol.geom.Polygon.fromCircle = _ol_geom_Polygon$fromCircle;\nol.geom.Polygon.fromExtent = _ol_geom_Polygon$fromExtent;\nol.geom.Polygon.makeRegular = _ol_geom_Polygon$makeRegular;\nol.geom.SimpleGeometry = $ol$geom$SimpleGeometry;\nol.geom.SimpleGeometry.getLayoutForStride = _ol_geom_SimpleGeometry$getLayoutForStride;\nol.geom.SimpleGeometry.getStrideForLayout = _ol_geom_SimpleGeometry$getStrideForLayout;\nol.geom.SimpleGeometry.transformGeom2D = _ol_geom_SimpleGeometry$transformGeom2D;\nol.geom.flat = {};\nol.geom.flat.area = {};\nol.geom.flat.area.linearRing = _ol_geom_flat_area$linearRing;\nol.geom.flat.area.linearRings = _ol_geom_flat_area$linearRings;\nol.geom.flat.area.linearRingss = _ol_geom_flat_area$linearRingss;\nol.geom.flat.center = {};\nol.geom.flat.center.linearRingss = _ol_geom_flat_center$linearRingss;\nol.geom.flat.closest = {};\nol.geom.flat.closest.arrayMaxSquaredDelta = _ol_geom_flat_closest$arrayMaxSquaredDelta;\nol.geom.flat.closest.assignClosestArrayPoint = _ol_geom_flat_closest$assignClosestArrayPoint;\nol.geom.flat.closest.assignClosestMultiArrayPoint = _ol_geom_flat_closest$assignClosestMultiArrayPoint;\nol.geom.flat.closest.assignClosestPoint = _ol_geom_flat_closest$assignClosestPoint;\nol.geom.flat.closest.maxSquaredDelta = _ol_geom_flat_closest$maxSquaredDelta;\nol.geom.flat.closest.multiArrayMaxSquaredDelta = _ol_geom_flat_closest$multiArrayMaxSquaredDelta;\nol.geom.flat.contains = {};\nol.geom.flat.contains.linearRingContainsExtent = _ol_geom_flat_contains$linearRingContainsExtent;\nol.geom.flat.contains.linearRingContainsXY = _ol_geom_flat_contains$linearRingContainsXY;\nol.geom.flat.contains.linearRingsContainsXY = _ol_geom_flat_contains$linearRingsContainsXY;\nol.geom.flat.contains.linearRingssContainsXY = _ol_geom_flat_contains$linearRingssContainsXY;\nol.geom.flat.deflate = {};\nol.geom.flat.deflate.deflateCoordinate = _ol_geom_flat_deflate$deflateCoordinate;\nol.geom.flat.deflate.deflateCoordinates = _ol_geom_flat_deflate$deflateCoordinates;\nol.geom.flat.deflate.deflateCoordinatesArray = _ol_geom_flat_deflate$deflateCoordinatesArray;\nol.geom.flat.deflate.deflateMultiCoordinatesArray = _ol_geom_flat_deflate$deflateMultiCoordinatesArray;\nol.geom.flat.flip = {};\nol.geom.flat.flip.flipXY = _ol_geom_flat_flip$flipXY;\nol.geom.flat.geodesic = {};\nol.geom.flat.geodesic.greatCircleArc = _ol_geom_flat_geodesic$greatCircleArc;\nol.geom.flat.geodesic.meridian = _ol_geom_flat_geodesic$meridian;\nol.geom.flat.geodesic.parallel = _ol_geom_flat_geodesic$parallel;\nol.geom.flat.inflate = {};\nol.geom.flat.inflate.inflateCoordinates = _ol_geom_flat_inflate$inflateCoordinates;\nol.geom.flat.inflate.inflateCoordinatesArray = _ol_geom_flat_inflate$inflateCoordinatesArray;\nol.geom.flat.inflate.inflateMultiCoordinatesArray = _ol_geom_flat_inflate$inflateMultiCoordinatesArray;\nol.geom.flat.interiorpoint = {};\nol.geom.flat.interiorpoint.getInteriorPointOfArray = _ol_geom_flat_interiorpoint$getInteriorPointOfArray;\nol.geom.flat.interiorpoint.getInteriorPointsOfMultiArray = _ol_geom_flat_interiorpoint$getInteriorPointsOfMultiArray;\nol.geom.flat.interpolate = {};\nol.geom.flat.interpolate.interpolatePoint = _ol_geom_flat_interpolate$interpolatePoint;\nol.geom.flat.interpolate.lineStringCoordinateAtM = _ol_geom_flat_interpolate$lineStringCoordinateAtM;\nol.geom.flat.interpolate.lineStringsCoordinateAtM = _ol_geom_flat_interpolate$lineStringsCoordinateAtM;\nol.geom.flat.intersectsextent = {};\nol.geom.flat.intersectsextent.intersectsLineString = _ol_geom_flat_intersectsextent$intersectsLineString;\nol.geom.flat.intersectsextent.intersectsLineStringArray = _ol_geom_flat_intersectsextent$intersectsLineStringArray;\nol.geom.flat.intersectsextent.intersectsLinearRing = _ol_geom_flat_intersectsextent$intersectsLinearRing;\nol.geom.flat.intersectsextent.intersectsLinearRingArray = _ol_geom_flat_intersectsextent$intersectsLinearRingArray;\nol.geom.flat.intersectsextent.intersectsLinearRingMultiArray = _ol_geom_flat_intersectsextent$intersectsLinearRingMultiArray;\nol.geom.flat.length = {};\nol.geom.flat.length.lineStringLength = _ol_geom_flat_length$lineStringLength;\nol.geom.flat.length.linearRingLength = _ol_geom_flat_length$linearRingLength;\nol.geom.flat.orient = {};\nol.geom.flat.orient.inflateEnds = _ol_geom_flat_orient$inflateEnds;\nol.geom.flat.orient.linearRingIsClockwise = _ol_geom_flat_orient$linearRingIsClockwise;\nol.geom.flat.orient.linearRingsAreOriented = _ol_geom_flat_orient$linearRingsAreOriented;\nol.geom.flat.orient.linearRingssAreOriented = _ol_geom_flat_orient$linearRingssAreOriented;\nol.geom.flat.orient.orientLinearRings = _ol_geom_flat_orient$orientLinearRings;\nol.geom.flat.orient.orientLinearRingsArray = _ol_geom_flat_orient$orientLinearRingsArray;\nol.geom.flat.reverse = {};\nol.geom.flat.reverse.coordinates = _ol_geom_flat_reverse$coordinates;\nol.geom.flat.segments = {};\nol.geom.flat.segments.forEach = _ol_geom_flat_segments$forEach;\nol.geom.flat.segments.getIntersectionPoint = _ol_geom_flat_segments$getIntersectionPoint;\nol.geom.flat.simplify = {};\nol.geom.flat.simplify.douglasPeucker = _ol_geom_flat_simplify$douglasPeucker;\nol.geom.flat.simplify.douglasPeuckerArray = _ol_geom_flat_simplify$douglasPeuckerArray;\nol.geom.flat.simplify.douglasPeuckerMultiArray = _ol_geom_flat_simplify$douglasPeuckerMultiArray;\nol.geom.flat.simplify.quantize = _ol_geom_flat_simplify$quantize;\nol.geom.flat.simplify.quantizeArray = _ol_geom_flat_simplify$quantizeArray;\nol.geom.flat.simplify.quantizeMultiArray = _ol_geom_flat_simplify$quantizeMultiArray;\nol.geom.flat.simplify.radialDistance = _ol_geom_flat_simplify$radialDistance;\nol.geom.flat.simplify.simplifyLineString = _ol_geom_flat_simplify$simplifyLineString;\nol.geom.flat.simplify.snap = _ol_geom_flat_simplify$snap;\nol.geom.flat.straightchunk = {};\nol.geom.flat.straightchunk.matchingChunk = _ol_geom_flat_straightchunk$matchingChunk;\nol.geom.flat.textpath = {};\nol.geom.flat.textpath.drawTextOnPath = _ol_geom_flat_textpath$drawTextOnPath;\nol.geom.flat.topology = {};\nol.geom.flat.topology.lineStringIsClosed = _ol_geom_flat_topology$lineStringIsClosed;\nol.geom.flat.transform = {};\nol.geom.flat.transform.rotate = _ol_geom_flat_transform$rotate;\nol.geom.flat.transform.scale = _ol_geom_flat_transform$scale;\nol.geom.flat.transform.transform2D = _ol_geom_flat_transform$transform2D;\nol.geom.flat.transform.translate = _ol_geom_flat_transform$translate;\nol.has = {};\nol.has.CREATE_IMAGE_BITMAP = _ol_has$CREATE_IMAGE_BITMAP;\nol.has.DEVICE_PIXEL_RATIO = _ol_has$DEVICE_PIXEL_RATIO;\nol.has.IMAGE_DECODE = _ol_has$IMAGE_DECODE;\nol.has.MAC = _ol_has$MAC;\nol.has.PASSIVE_EVENT_LISTENERS = _ol_has$PASSIVE_EVENT_LISTENERS;\nol.has.SAFARI = _ol_has$SAFARI;\nol.has.SAFARI_BUG_237906 = _ol_has$SAFARI_BUG_237906;\nol.has.WEBKIT = _ol_has$WEBKIT;\nol.has.WORKER_OFFSCREEN_CANVAS = _ol_has$WORKER_OFFSCREEN_CANVAS;\nol.interaction = {};\nol.interaction.DblClickDragZoom = $ol$interaction$DblClickDragZoom;\nol.interaction.DoubleClickZoom = $ol$interaction$DoubleClickZoom;\nol.interaction.DragAndDrop = $ol$interaction$DragAndDrop;\nol.interaction.DragAndDrop.DragAndDropEvent = _ol_interaction_DragAndDrop$DragAndDropEvent;\nol.interaction.DragBox = $ol$interaction$DragBox;\nol.interaction.DragBox.DragBoxEvent = _ol_interaction_DragBox$DragBoxEvent;\nol.interaction.DragPan = $ol$interaction$DragPan;\nol.interaction.DragRotate = $ol$interaction$DragRotate;\nol.interaction.DragRotateAndZoom = $ol$interaction$DragRotateAndZoom;\nol.interaction.DragZoom = $ol$interaction$DragZoom;\nol.interaction.Draw = $ol$interaction$Draw;\nol.interaction.Draw.DrawEvent = _ol_interaction_Draw$DrawEvent;\nol.interaction.Draw.createBox = _ol_interaction_Draw$createBox;\nol.interaction.Draw.createRegularPolygon = _ol_interaction_Draw$createRegularPolygon;\nol.interaction.Extent = $ol$interaction$Extent;\nol.interaction.Extent.ExtentEvent = _ol_interaction_Extent$ExtentEvent;\nol.interaction.Interaction = $ol$interaction$Interaction;\nol.interaction.Interaction.pan = _ol_interaction_Interaction$pan;\nol.interaction.Interaction.zoomByDelta = _ol_interaction_Interaction$zoomByDelta;\nol.interaction.KeyboardPan = $ol$interaction$KeyboardPan;\nol.interaction.KeyboardZoom = $ol$interaction$KeyboardZoom;\nol.interaction.Link = $ol$interaction$Link;\nol.interaction.Modify = $ol$interaction$Modify;\nol.interaction.Modify.ModifyEvent = _ol_interaction_Modify$ModifyEvent;\nol.interaction.MouseWheelZoom = $ol$interaction$MouseWheelZoom;\nol.interaction.PinchRotate = $ol$interaction$PinchRotate;\nol.interaction.PinchZoom = $ol$interaction$PinchZoom;\nol.interaction.Pointer = $ol$interaction$Pointer;\nol.interaction.Pointer.centroid = _ol_interaction_Pointer$centroid;\nol.interaction.Select = $ol$interaction$Select;\nol.interaction.Select.SelectEvent = _ol_interaction_Select$SelectEvent;\nol.interaction.Snap = $ol$interaction$Snap;\nol.interaction.Translate = $ol$interaction$Translate;\nol.interaction.Translate.TranslateEvent = _ol_interaction_Translate$TranslateEvent;\nol.interaction.defaults = {};\nol.interaction.defaults.defaults = _ol_interaction_defaults$defaults;\nol.layer = {};\nol.layer.Base = $ol$layer$Base;\nol.layer.BaseImage = $ol$layer$BaseImage;\nol.layer.BaseTile = $ol$layer$BaseTile;\nol.layer.BaseVector = $ol$layer$BaseVector;\nol.layer.Graticule = $ol$layer$Graticule;\nol.layer.Group = $ol$layer$Group;\nol.layer.Group.GroupEvent = _ol_layer_Group$GroupEvent;\nol.layer.Heatmap = $ol$layer$Heatmap;\nol.layer.Image = $ol$layer$Image;\nol.layer.Layer = $ol$layer$Layer;\nol.layer.Layer.inView = _ol_layer_Layer$inView;\nol.layer.Tile = $ol$layer$Tile;\nol.layer.Vector = $ol$layer$Vector;\nol.layer.VectorImage = $ol$layer$VectorImage;\nol.loadingstrategy = {};\nol.loadingstrategy.all = _ol_loadingstrategy$all;\nol.loadingstrategy.bbox = _ol_loadingstrategy$bbox;\nol.loadingstrategy.tile = _ol_loadingstrategy$tile;\nol.math = {};\nol.math.ceil = _ol_math$ceil;\nol.math.clamp = _ol_math$clamp;\nol.math.floor = _ol_math$floor;\nol.math.lerp = _ol_math$lerp;\nol.math.modulo = _ol_math$modulo;\nol.math.round = _ol_math$round;\nol.math.solveLinearSystem = _ol_math$solveLinearSystem;\nol.math.squaredDistance = _ol_math$squaredDistance;\nol.math.squaredSegmentDistance = _ol_math$squaredSegmentDistance;\nol.math.toDegrees = _ol_math$toDegrees;\nol.math.toFixed = _ol_math$toFixed;\nol.math.toRadians = _ol_math$toRadians;\nol.math.wrap = _ol_math$wrap;\nol.net = {};\nol.net.ClientError = _ol_net$ClientError;\nol.net.ResponseError = _ol_net$ResponseError;\nol.net.getJSON = _ol_net$getJSON;\nol.net.jsonp = _ol_net$jsonp;\nol.net.overrideXHR = _ol_net$overrideXHR;\nol.net.resolveUrl = _ol_net$resolveUrl;\nol.net.restoreXHR = _ol_net$restoreXHR;\nol.obj = {};\nol.obj.clear = _ol_obj$clear;\nol.obj.isEmpty = _ol_obj$isEmpty;\nol.proj = {};\nol.proj.Projection = $ol$proj$Projection;\nol.proj.Units = {};\nol.proj.Units.METERS_PER_UNIT = _ol_proj_Units$METERS_PER_UNIT;\nol.proj.Units.fromCode = _ol_proj_Units$fromCode;\nol.proj.addCommon = _ol_proj$addCommon;\nol.proj.addCoordinateTransforms = _ol_proj$addCoordinateTransforms;\nol.proj.addEquivalentProjections = _ol_proj$addEquivalentProjections;\nol.proj.addEquivalentTransforms = _ol_proj$addEquivalentTransforms;\nol.proj.addProjection = _ol_proj$addProjection;\nol.proj.addProjections = _ol_proj$addProjections;\nol.proj.clearAllProjections = _ol_proj$clearAllProjections;\nol.proj.clearUserProjection = _ol_proj$clearUserProjection;\nol.proj.cloneTransform = _ol_proj$cloneTransform;\nol.proj.createProjection = _ol_proj$createProjection;\nol.proj.createSafeCoordinateTransform = _ol_proj$createSafeCoordinateTransform;\nol.proj.createTransformFromCoordinateTransform = _ol_proj$createTransformFromCoordinateTransform;\nol.proj.disableCoordinateWarning = _ol_proj$disableCoordinateWarning;\nol.proj.epsg3857 = {};\nol.proj.epsg3857.EXTENT = _ol_proj_epsg3857$EXTENT;\nol.proj.epsg3857.HALF_SIZE = _ol_proj_epsg3857$HALF_SIZE;\nol.proj.epsg3857.MAX_SAFE_Y = _ol_proj_epsg3857$MAX_SAFE_Y;\nol.proj.epsg3857.PROJECTIONS = _ol_proj_epsg3857$PROJECTIONS;\nol.proj.epsg3857.RADIUS = _ol_proj_epsg3857$RADIUS;\nol.proj.epsg3857.WORLD_EXTENT = _ol_proj_epsg3857$WORLD_EXTENT;\nol.proj.epsg3857.fromEPSG4326 = _ol_proj_epsg3857$fromEPSG4326;\nol.proj.epsg3857.toEPSG4326 = _ol_proj_epsg3857$toEPSG4326;\nol.proj.epsg4326 = {};\nol.proj.epsg4326.EXTENT = _ol_proj_epsg4326$EXTENT;\nol.proj.epsg4326.METERS_PER_UNIT = _ol_proj_epsg4326$METERS_PER_UNIT;\nol.proj.epsg4326.PROJECTIONS = _ol_proj_epsg4326$PROJECTIONS;\nol.proj.epsg4326.RADIUS = _ol_proj_epsg4326$RADIUS;\nol.proj.equivalent = _ol_proj$equivalent;\nol.proj.fromLonLat = _ol_proj$fromLonLat;\nol.proj.fromUserCoordinate = _ol_proj$fromUserCoordinate;\nol.proj.fromUserExtent = _ol_proj$fromUserExtent;\nol.proj.fromUserResolution = _ol_proj$fromUserResolution;\nol.proj.get = _ol_proj$get;\nol.proj.getPointResolution = _ol_proj$getPointResolution;\nol.proj.getTransform = _ol_proj$getTransform;\nol.proj.getTransformFromProjections = _ol_proj$getTransformFromProjections;\nol.proj.getUserProjection = _ol_proj$getUserProjection;\nol.proj.identityTransform = _ol_proj$identityTransform;\nol.proj.proj4 = {};\nol.proj.proj4.epsgLookupMapTiler = _ol_proj_proj4$epsgLookupMapTiler;\nol.proj.proj4.fromEPSGCode = _ol_proj_proj4$fromEPSGCode;\nol.proj.proj4.fromProjectionCode = _ol_proj_proj4$fromProjectionCode;\nol.proj.proj4.getEPSGLookup = _ol_proj_proj4$getEPSGLookup;\nol.proj.proj4.getProjectionCodeLookup = _ol_proj_proj4$getProjectionCodeLookup;\nol.proj.proj4.isRegistered = _ol_proj_proj4$isRegistered;\nol.proj.proj4.register = _ol_proj_proj4$register;\nol.proj.proj4.setEPSGLookup = _ol_proj_proj4$setEPSGLookup;\nol.proj.proj4.setProjectionCodeLookup = _ol_proj_proj4$setProjectionCodeLookup;\nol.proj.proj4.unregister = _ol_proj_proj4$unregister;\nol.proj.projections = {};\nol.proj.projections.add = _ol_proj_projections$add;\nol.proj.projections.clear = _ol_proj_projections$clear;\nol.proj.projections.get = _ol_proj_projections$get;\nol.proj.setUserProjection = _ol_proj$setUserProjection;\nol.proj.toLonLat = _ol_proj$toLonLat;\nol.proj.toUserCoordinate = _ol_proj$toUserCoordinate;\nol.proj.toUserExtent = _ol_proj$toUserExtent;\nol.proj.toUserResolution = _ol_proj$toUserResolution;\nol.proj.transform = _ol_proj$transform;\nol.proj.transformExtent = _ol_proj$transformExtent;\nol.proj.transformWithProjections = _ol_proj$transformWithProjections;\nol.proj.transforms = {};\nol.proj.transforms.add = _ol_proj_transforms$add;\nol.proj.transforms.clear = _ol_proj_transforms$clear;\nol.proj.transforms.get = _ol_proj_transforms$get;\nol.proj.transforms.remove = _ol_proj_transforms$remove;\nol.proj.useGeographic = _ol_proj$useGeographic;\nol.proj.utm = {};\nol.proj.utm.makeProjection = _ol_proj_utm$makeProjection;\nol.proj.utm.makeTransforms = _ol_proj_utm$makeTransforms;\nol.proj.utm.zoneFromCode = _ol_proj_utm$zoneFromCode;\nol.render = {};\nol.render.Box = $ol$render$Box;\nol.render.Event = $ol$render$Event;\nol.render.Feature = $ol$render$Feature;\nol.render.Feature.toFeature = _ol_render_Feature$toFeature;\nol.render.Feature.toGeometry = _ol_render_Feature$toGeometry;\nol.render.VectorContext = $ol$render$VectorContext;\nol.render.canvas = {};\nol.render.canvas.Builder = $ol$render$canvas$Builder;\nol.render.canvas.BuilderGroup = $ol$render$canvas$BuilderGroup;\nol.render.canvas.Executor = $ol$render$canvas$Executor;\nol.render.canvas.ExecutorGroup = $ol$render$canvas$ExecutorGroup;\nol.render.canvas.ExecutorGroup.ALL = _ol_render_canvas_ExecutorGroup$ALL;\nol.render.canvas.ExecutorGroup.DECLUTTER = _ol_render_canvas_ExecutorGroup$DECLUTTER;\nol.render.canvas.ExecutorGroup.NON_DECLUTTER = _ol_render_canvas_ExecutorGroup$NON_DECLUTTER;\nol.render.canvas.ExecutorGroup.getPixelIndexArray = _ol_render_canvas_ExecutorGroup$getPixelIndexArray;\nol.render.canvas.ImageBuilder = $ol$render$canvas$ImageBuilder;\nol.render.canvas.Immediate = $ol$render$canvas$Immediate;\nol.render.canvas.Instruction = {};\nol.render.canvas.Instruction.beginPathInstruction = _ol_render_canvas_Instruction$beginPathInstruction;\nol.render.canvas.Instruction.closePathInstruction = _ol_render_canvas_Instruction$closePathInstruction;\nol.render.canvas.Instruction.fillInstruction = _ol_render_canvas_Instruction$fillInstruction;\nol.render.canvas.Instruction.strokeInstruction = _ol_render_canvas_Instruction$strokeInstruction;\nol.render.canvas.LineStringBuilder = $ol$render$canvas$LineStringBuilder;\nol.render.canvas.PolygonBuilder = $ol$render$canvas$PolygonBuilder;\nol.render.canvas.TextBuilder = $ol$render$canvas$TextBuilder;\nol.render.canvas.TextBuilder.TEXT_ALIGN = _ol_render_canvas_TextBuilder$TEXT_ALIGN;\nol.render.canvas.ZIndexContext = $ol$render$canvas$ZIndexContext;\nol.render.canvas.checkedFonts = _ol_render_canvas$checkedFonts;\nol.render.canvas.defaultFillStyle = _ol_render_canvas$defaultFillStyle;\nol.render.canvas.defaultFont = _ol_render_canvas$defaultFont;\nol.render.canvas.defaultLineCap = _ol_render_canvas$defaultLineCap;\nol.render.canvas.defaultLineDash = _ol_render_canvas$defaultLineDash;\nol.render.canvas.defaultLineDashOffset = _ol_render_canvas$defaultLineDashOffset;\nol.render.canvas.defaultLineJoin = _ol_render_canvas$defaultLineJoin;\nol.render.canvas.defaultLineWidth = _ol_render_canvas$defaultLineWidth;\nol.render.canvas.defaultMiterLimit = _ol_render_canvas$defaultMiterLimit;\nol.render.canvas.defaultPadding = _ol_render_canvas$defaultPadding;\nol.render.canvas.defaultStrokeOffset = _ol_render_canvas$defaultStrokeOffset;\nol.render.canvas.defaultStrokeStyle = _ol_render_canvas$defaultStrokeStyle;\nol.render.canvas.defaultTextAlign = _ol_render_canvas$defaultTextAlign;\nol.render.canvas.defaultTextBaseline = _ol_render_canvas$defaultTextBaseline;\nol.render.canvas.drawImageOrLabel = _ol_render_canvas$drawImageOrLabel;\nol.render.canvas.getTextDimensions = _ol_render_canvas$getTextDimensions;\nol.render.canvas.hitdetect = {};\nol.render.canvas.hitdetect.HIT_DETECT_RESOLUTION = _ol_render_canvas_hitdetect$HIT_DETECT_RESOLUTION;\nol.render.canvas.hitdetect.createHitDetectionImageData = _ol_render_canvas_hitdetect$createHitDetectionImageData;\nol.render.canvas.hitdetect.hitDetect = _ol_render_canvas_hitdetect$hitDetect;\nol.render.canvas.measureAndCacheTextWidth = _ol_render_canvas$measureAndCacheTextWidth;\nol.render.canvas.measureTextHeight = _ol_render_canvas$measureTextHeight;\nol.render.canvas.measureTextWidth = _ol_render_canvas$measureTextWidth;\nol.render.canvas.registerFont = _ol_render_canvas$registerFont;\nol.render.canvas.rotateAtOffset = _ol_render_canvas$rotateAtOffset;\nol.render.canvas.style = {};\nol.render.canvas.style.buildRuleSet = _ol_render_canvas_style$buildRuleSet;\nol.render.canvas.style.buildStyle = _ol_render_canvas_style$buildStyle;\nol.render.canvas.style.flatStylesToStyleFunction = _ol_render_canvas_style$flatStylesToStyleFunction;\nol.render.canvas.style.rulesToStyleFunction = _ol_render_canvas_style$rulesToStyleFunction;\nol.render.canvas.textHeights = _ol_render_canvas$textHeights;\nol.render.getRenderPixel = _ol_render$getRenderPixel;\nol.render.getVectorContext = _ol_render$getVectorContext;\nol.render.toContext = _ol_render$toContext;\nol.renderer = {};\nol.renderer.Composite = $ol$renderer$Composite;\nol.renderer.Layer = $ol$renderer$Layer;\nol.renderer.Map = $ol$renderer$Map;\nol.renderer.canvas = {};\nol.renderer.canvas.ImageLayer = $ol$renderer$canvas$ImageLayer;\nol.renderer.canvas.Layer = $ol$renderer$canvas$Layer;\nol.renderer.canvas.Layer.canvasPool = _ol_renderer_canvas_Layer$canvasPool;\nol.renderer.canvas.TileLayer = $ol$renderer$canvas$TileLayer;\nol.renderer.canvas.VectorImageLayer = $ol$renderer$canvas$VectorImageLayer;\nol.renderer.canvas.VectorLayer = $ol$renderer$canvas$VectorLayer;\nol.renderer.vector = {};\nol.renderer.vector.defaultOrder = _ol_renderer_vector$defaultOrder;\nol.renderer.vector.getSquaredTolerance = _ol_renderer_vector$getSquaredTolerance;\nol.renderer.vector.getTolerance = _ol_renderer_vector$getTolerance;\nol.renderer.vector.renderFeature = _ol_renderer_vector$renderFeature;\nol.reproj = {};\nol.reproj.DataTile = $ol$reproj$DataTile;\nol.reproj.Image = $ol$reproj$Image;\nol.reproj.Tile = $ol$reproj$Tile;\nol.reproj.Triangulation = $ol$reproj$Triangulation;\nol.reproj.calculateSourceExtentResolution = _ol_reproj$calculateSourceExtentResolution;\nol.reproj.calculateSourceResolution = _ol_reproj$calculateSourceResolution;\nol.reproj.canvasPool = _ol_reproj$canvasPool;\nol.reproj.common = {};\nol.reproj.common.ERROR_THRESHOLD = _ol_reproj_common$ERROR_THRESHOLD;\nol.reproj.glreproj = {};\nol.reproj.glreproj.canvasGLPool = _ol_reproj_glreproj$canvasGLPool;\nol.reproj.glreproj.createCanvasContextWebGL = _ol_reproj_glreproj$createCanvasContextWebGL;\nol.reproj.glreproj.releaseGLCanvas = _ol_reproj_glreproj$releaseGLCanvas;\nol.reproj.glreproj.render = _ol_reproj_glreproj$render;\nol.reproj.render = _ol_reproj$render;\nol.resolution = {};\nol.resolution.fromResolutionLike = _ol_resolution$fromResolutionLike;\nol.resolutionconstraint = {};\nol.resolutionconstraint.createMinMaxResolution = _ol_resolutionconstraint$createMinMaxResolution;\nol.resolutionconstraint.createSnapToPower = _ol_resolutionconstraint$createSnapToPower;\nol.resolutionconstraint.createSnapToResolutions = _ol_resolutionconstraint$createSnapToResolutions;\nol.rotationconstraint = {};\nol.rotationconstraint.createSnapToN = _ol_rotationconstraint$createSnapToN;\nol.rotationconstraint.createSnapToZero = _ol_rotationconstraint$createSnapToZero;\nol.rotationconstraint.disable = _ol_rotationconstraint$disable;\nol.rotationconstraint.none = _ol_rotationconstraint$none;\nol.size = {};\nol.size.buffer = _ol_size$buffer;\nol.size.hasArea = _ol_size$hasArea;\nol.size.scale = _ol_size$scale;\nol.size.toSize = _ol_size$toSize;\nol.source = {};\nol.source.BingMaps = $ol$source$BingMaps;\nol.source.BingMaps.quadKey = _ol_source_BingMaps$quadKey;\nol.source.Cluster = $ol$source$Cluster;\nol.source.DataTile = $ol$source$DataTile;\nol.source.Google = $ol$source$Google;\nol.source.Image = $ol$source$Image;\nol.source.Image.ImageSourceEvent = _ol_source_Image$ImageSourceEvent;\nol.source.Image.defaultImageLoadFunction = _ol_source_Image$defaultImageLoadFunction;\nol.source.Image.getRequestExtent = _ol_source_Image$getRequestExtent;\nol.source.ImageArcGISRest = $ol$source$ImageArcGISRest;\nol.source.ImageCanvas = $ol$source$ImageCanvas;\nol.source.ImageStatic = $ol$source$ImageStatic;\nol.source.ImageTile = $ol$source$ImageTile;\nol.source.ImageWMS = $ol$source$ImageWMS;\nol.source.OSM = $ol$source$OSM;\nol.source.OSM.ATTRIBUTION = _ol_source_OSM$ATTRIBUTION;\nol.source.Raster = $ol$source$Raster;\nol.source.Raster.Processor = _ol_source_Raster$Processor;\nol.source.Raster.RasterSourceEvent = _ol_source_Raster$RasterSourceEvent;\nol.source.Source = $ol$source$Source;\nol.source.StadiaMaps = $ol$source$StadiaMaps;\nol.source.Tile = $ol$source$Tile;\nol.source.Tile.TileSourceEvent = _ol_source_Tile$TileSourceEvent;\nol.source.TileArcGISRest = $ol$source$TileArcGISRest;\nol.source.TileDebug = $ol$source$TileDebug;\nol.source.TileImage = $ol$source$TileImage;\nol.source.TileImage.defaultTileLoadFunction = _ol_source_TileImage$defaultTileLoadFunction;\nol.source.TileJSON = $ol$source$TileJSON;\nol.source.TileWMS = $ol$source$TileWMS;\nol.source.UTFGrid = $ol$source$UTFGrid;\nol.source.UTFGrid.CustomTile = _ol_source_UTFGrid$CustomTile;\nol.source.UrlTile = $ol$source$UrlTile;\nol.source.Vector = $ol$source$Vector;\nol.source.Vector.VectorSourceEvent = _ol_source_Vector$VectorSourceEvent;\nol.source.WMTS = $ol$source$WMTS;\nol.source.WMTS.optionsFromCapabilities = _ol_source_WMTS$optionsFromCapabilities;\nol.source.XYZ = $ol$source$XYZ;\nol.source.arcgisRest = {};\nol.source.arcgisRest.createLoader = _ol_source_arcgisRest$createLoader;\nol.source.arcgisRest.getRequestUrl = _ol_source_arcgisRest$getRequestUrl;\nol.source.common = {};\nol.source.common.DECIMALS = _ol_source_common$DECIMALS;\nol.source.common.DEFAULT_WMS_VERSION = _ol_source_common$DEFAULT_WMS_VERSION;\nol.source.mapserver = {};\nol.source.mapserver.createLoader = _ol_source_mapserver$createLoader;\nol.source.ogcTileUtil = {};\nol.source.ogcTileUtil.appendCollectionsQueryParam = _ol_source_ogcTileUtil$appendCollectionsQueryParam;\nol.source.ogcTileUtil.getMapTileUrlTemplate = _ol_source_ogcTileUtil$getMapTileUrlTemplate;\nol.source.ogcTileUtil.getTileSetInfo = _ol_source_ogcTileUtil$getTileSetInfo;\nol.source.ogcTileUtil.getVectorTileUrlTemplate = _ol_source_ogcTileUtil$getVectorTileUrlTemplate;\nol.source.ogcTileUtil.parseTileMatrixSet = _ol_source_ogcTileUtil$parseTileMatrixSet;\nol.source.sourcesFromTileGrid = _ol_source$sourcesFromTileGrid;\nol.source.static = {};\nol.source.static.createLoader = _ol_source_static$createLoader;\nol.source.wms = {};\nol.source.wms.DEFAULT_VERSION = _ol_source_wms$DEFAULT_VERSION;\nol.source.wms.createLoader = _ol_source_wms$createLoader;\nol.source.wms.getFeatureInfoUrl = _ol_source_wms$getFeatureInfoUrl;\nol.source.wms.getImageSrc = _ol_source_wms$getImageSrc;\nol.source.wms.getLegendUrl = _ol_source_wms$getLegendUrl;\nol.source.wms.getRequestParams = _ol_source_wms$getRequestParams;\nol.source.wms.getRequestUrl = _ol_source_wms$getRequestUrl;\nol.sphere = {};\nol.sphere.DEFAULT_RADIUS = _ol_sphere$DEFAULT_RADIUS;\nol.sphere.getArea = _ol_sphere$getArea;\nol.sphere.getDistance = _ol_sphere$getDistance;\nol.sphere.getLength = _ol_sphere$getLength;\nol.sphere.offset = _ol_sphere$offset;\nol.string = {};\nol.string.compareVersions = _ol_string$compareVersions;\nol.string.padNumber = _ol_string$padNumber;\nol.structs = {};\nol.structs.LRUCache = $ol$structs$LRUCache;\nol.structs.PriorityQueue = $ol$structs$PriorityQueue;\nol.structs.PriorityQueue.DROP = _ol_structs_PriorityQueue$DROP;\nol.structs.RBush = $ol$structs$RBush;\nol.style = {};\nol.style.Circle = $ol$style$Circle;\nol.style.Fill = $ol$style$Fill;\nol.style.Icon = $ol$style$Icon;\nol.style.IconImage = $ol$style$IconImage;\nol.style.IconImage.get = _ol_style_IconImage$get;\nol.style.IconImageCache = $ol$style$IconImageCache;\nol.style.IconImageCache.getCacheKey = _ol_style_IconImageCache$getCacheKey;\nol.style.IconImageCache.shared = _ol_style_IconImageCache$shared;\nol.style.Image = $ol$style$Image;\nol.style.RegularShape = $ol$style$RegularShape;\nol.style.Stroke = $ol$style$Stroke;\nol.style.Style = $ol$style$Style;\nol.style.Style.createDefaultStyle = _ol_style_Style$createDefaultStyle;\nol.style.Style.createEditingStyle = _ol_style_Style$createEditingStyle;\nol.style.Style.toFunction = _ol_style_Style$toFunction;\nol.style.Text = $ol$style$Text;\nol.style.flat = {};\nol.style.flat.createDefaultStyle = _ol_style_flat$createDefaultStyle;\nol.tilecoord = {};\nol.tilecoord.createOrUpdate = _ol_tilecoord$createOrUpdate;\nol.tilecoord.fromKey = _ol_tilecoord$fromKey;\nol.tilecoord.getCacheKey = _ol_tilecoord$getCacheKey;\nol.tilecoord.getCacheKeyForTileKey = _ol_tilecoord$getCacheKeyForTileKey;\nol.tilecoord.getKey = _ol_tilecoord$getKey;\nol.tilecoord.getKeyZXY = _ol_tilecoord$getKeyZXY;\nol.tilecoord.hash = _ol_tilecoord$hash;\nol.tilecoord.hashZXY = _ol_tilecoord$hashZXY;\nol.tilecoord.withinExtentAndZ = _ol_tilecoord$withinExtentAndZ;\nol.tilegrid = {};\nol.tilegrid.TileGrid = $ol$tilegrid$TileGrid;\nol.tilegrid.WMTS = $ol$tilegrid$WMTS;\nol.tilegrid.WMTS.createFromCapabilitiesMatrixSet = _ol_tilegrid_WMTS$createFromCapabilitiesMatrixSet;\nol.tilegrid.common = {};\nol.tilegrid.common.DEFAULT_MAX_ZOOM = _ol_tilegrid_common$DEFAULT_MAX_ZOOM;\nol.tilegrid.common.DEFAULT_TILE_SIZE = _ol_tilegrid_common$DEFAULT_TILE_SIZE;\nol.tilegrid.createForExtent = _ol_tilegrid$createForExtent;\nol.tilegrid.createForProjection = _ol_tilegrid$createForProjection;\nol.tilegrid.createXYZ = _ol_tilegrid$createXYZ;\nol.tilegrid.extentFromProjection = _ol_tilegrid$extentFromProjection;\nol.tilegrid.getForProjection = _ol_tilegrid$getForProjection;\nol.tilegrid.wrapX = _ol_tilegrid$wrapX;\nol.tileurlfunction = {};\nol.tileurlfunction.createFromTemplate = _ol_tileurlfunction$createFromTemplate;\nol.tileurlfunction.createFromTemplates = _ol_tileurlfunction$createFromTemplates;\nol.tileurlfunction.createFromTileUrlFunctions = _ol_tileurlfunction$createFromTileUrlFunctions;\nol.tileurlfunction.nullTileUrlFunction = _ol_tileurlfunction$nullTileUrlFunction;\nol.transform = {};\nol.transform.apply = _ol_transform$apply;\nol.transform.compose = _ol_transform$compose;\nol.transform.composeCssTransform = _ol_transform$composeCssTransform;\nol.transform.create = _ol_transform$create;\nol.transform.determinant = _ol_transform$determinant;\nol.transform.equivalent = _ol_transform$equivalent;\nol.transform.fromString = _ol_transform$fromString;\nol.transform.invert = _ol_transform$invert;\nol.transform.makeInverse = _ol_transform$makeInverse;\nol.transform.makeScale = _ol_transform$makeScale;\nol.transform.multiply = _ol_transform$multiply;\nol.transform.reset = _ol_transform$reset;\nol.transform.rotate = _ol_transform$rotate;\nol.transform.scale = _ol_transform$scale;\nol.transform.set = _ol_transform$set;\nol.transform.setFromArray = _ol_transform$setFromArray;\nol.transform.toString = _ol_transform$toString;\nol.transform.translate = _ol_transform$translate;\nol.uri = {};\nol.uri.appendParams = _ol_uri$appendParams;\nol.uri.expandUrl = _ol_uri$expandUrl;\nol.uri.pickUrl = _ol_uri$pickUrl;\nol.uri.renderXYZTemplate = _ol_uri$renderXYZTemplate;\nol.util = {};\nol.util.VERSION = _ol_util$VERSION;\nol.util.abstract = _ol_util$abstract;\nol.util.getUid = _ol_util$getUid;\nol.vec = {};\nol.vec.mat4 = {};\nol.vec.mat4.create = _ol_vec_mat4$create;\nol.vec.mat4.fromTransform = _ol_vec_mat4$fromTransform;\nol.vec.mat4.orthographic = _ol_vec_mat4$orthographic;\nol.vec.mat4.scale = _ol_vec_mat4$scale;\nol.vec.mat4.translate = _ol_vec_mat4$translate;\nol.vec.mat4.translation = _ol_vec_mat4$translation;\nol.xml = {};\nol.xml.OBJECT_PROPERTY_NODE_FACTORY = _ol_xml$OBJECT_PROPERTY_NODE_FACTORY;\nol.xml.XML_SCHEMA_INSTANCE_URI = _ol_xml$XML_SCHEMA_INSTANCE_URI;\nol.xml.createElementNS = _ol_xml$createElementNS;\nol.xml.getAllTextContent = _ol_xml$getAllTextContent;\nol.xml.getAllTextContent_ = _ol_xml$getAllTextContent_;\nol.xml.getAttributeNS = _ol_xml$getAttributeNS;\nol.xml.getDocument = _ol_xml$getDocument;\nol.xml.getXMLSerializer = _ol_xml$getXMLSerializer;\nol.xml.isDocument = _ol_xml$isDocument;\nol.xml.makeArrayExtender = _ol_xml$makeArrayExtender;\nol.xml.makeArrayPusher = _ol_xml$makeArrayPusher;\nol.xml.makeArraySerializer = _ol_xml$makeArraySerializer;\nol.xml.makeChildAppender = _ol_xml$makeChildAppender;\nol.xml.makeObjectPropertyPusher = _ol_xml$makeObjectPropertyPusher;\nol.xml.makeObjectPropertySetter = _ol_xml$makeObjectPropertySetter;\nol.xml.makeReplacer = _ol_xml$makeReplacer;\nol.xml.makeSequence = _ol_xml$makeSequence;\nol.xml.makeSimpleNodeFactory = _ol_xml$makeSimpleNodeFactory;\nol.xml.makeStructureNS = _ol_xml$makeStructureNS;\nol.xml.parse = _ol_xml$parse;\nol.xml.parseNode = _ol_xml$parseNode;\nol.xml.pushParseAndPop = _ol_xml$pushParseAndPop;\nol.xml.pushSerializeAndPop = _ol_xml$pushSerializeAndPop;\nol.xml.registerDocument = _ol_xml$registerDocument;\nol.xml.registerXMLSerializer = _ol_xml$registerXMLSerializer;\nol.xml.serialize = _ol_xml$serialize;\n\nol.VERSION = ol.util.VERSION;\n\nol.getUid = ol.util.getUid;\n\nexport default ol;","/**\n * @module ol/control/ZoomToExtent\n */\nimport {CLASS_CONTROL, CLASS_UNSELECTABLE} from '../css.js';\nimport EventType from '../events/EventType.js';\nimport {fromExtent as polygonFromExtent} from '../geom/Polygon.js';\nimport {fromUserExtent} from '../proj.js';\nimport Control from './Control.js';\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-zoom-extent'] Class name.\n * @property {HTMLElement|string} [target] Specify a target if you want the control\n * to be rendered outside of the map's viewport.\n * @property {string|HTMLElement} [label='E'] Text label to use for the button.\n * Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string} [tipLabel='Fit to extent'] Text label to use for the button tip.\n * @property {import(\"../extent.js\").Extent} [extent] The extent to zoom to. If undefined the validity\n * extent of the view projection is used.\n * @property {import(\"../View.js\").FitOptions} [fitOptions] Options to pass to the view when fitting\n * the extent (e.g. `padding`, `duration`, `minResolution`, `maxZoom`, `easing`, `callback`).\n */\n\n/**\n * @classdesc\n * A button control which, when pressed, changes the map view to a specific\n * extent. To style this control use the css selector `.ol-zoom-extent`.\n *\n * @api\n */\nclass ZoomToExtent extends Control {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super({\n      element: document.createElement('div'),\n      target: options.target,\n    });\n\n    /**\n     * @type {?import(\"../extent.js\").Extent|null}\n     * @protected\n     */\n    this.extent = options.extent ? options.extent : null;\n\n    /**\n     * @type {import(\"../View.js\").FitOptions}\n     * @protected\n     */\n    this.fitOptions = options.fitOptions || {};\n\n    const className =\n      options.className !== undefined ? options.className : 'ol-zoom-extent';\n\n    const label = options.label !== undefined ? options.label : 'E';\n    const tipLabel =\n      options.tipLabel !== undefined ? options.tipLabel : 'Fit to extent';\n    const button = document.createElement('button');\n    button.setAttribute('type', 'button');\n    button.title = tipLabel;\n    button.appendChild(\n      typeof label === 'string' ? document.createTextNode(label) : label,\n    );\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  /**\n   * @param {MouseEvent} event The event to handle\n   * @private\n   */\n  handleClick_(event) {\n    event.preventDefault();\n    this.handleZoomToExtent();\n  }\n\n  /**\n   * @protected\n   */\n  handleZoomToExtent() {\n    const map = this.getMap();\n    const view = map.getView();\n    const extent = !this.extent\n      ? view.getProjection().getExtent()\n      : fromUserExtent(this.extent, view.getProjection());\n\n    view.fitInternal(polygonFromExtent(extent), this.fitOptions);\n  }\n}\n\nexport default ZoomToExtent;\n","/**\n * @module ol/format/filter\n */\nimport And from './filter/And.js';\nimport Bbox from './filter/Bbox.js';\nimport Contains from './filter/Contains.js';\nimport DWithin from './filter/DWithin.js';\nimport Disjoint from './filter/Disjoint.js';\nimport During from './filter/During.js';\nimport EqualTo from './filter/EqualTo.js';\nimport GreaterThan from './filter/GreaterThan.js';\nimport GreaterThanOrEqualTo from './filter/GreaterThanOrEqualTo.js';\nimport Intersects from './filter/Intersects.js';\nimport IsBetween from './filter/IsBetween.js';\nimport IsLike from './filter/IsLike.js';\nimport IsNull from './filter/IsNull.js';\nimport LessThan from './filter/LessThan.js';\nimport LessThanOrEqualTo from './filter/LessThanOrEqualTo.js';\nimport Not from './filter/Not.js';\nimport NotEqualTo from './filter/NotEqualTo.js';\nimport Or from './filter/Or.js';\nimport ResourceId from './filter/ResourceId.js';\nimport Within from './filter/Within.js';\n\n/**\n * Create a logical `<And>` operator between two or more filter conditions.\n *\n * @param {...import(\"./filter/Filter.js\").default} conditions Filter conditions.\n * @return {!And} `<And>` operator.\n * @api\n */\nexport function and(conditions) {\n  const params = [null].concat(Array.prototype.slice.call(arguments));\n  return new (Function.prototype.bind.apply(And, params))();\n}\n\n/**\n * Create a logical `<Or>` operator between two or more filter conditions.\n *\n * @param {...import(\"./filter/Filter.js\").default} conditions Filter conditions.\n * @return {!Or} `<Or>` operator.\n * @api\n */\nexport function or(conditions) {\n  const params = [null].concat(Array.prototype.slice.call(arguments));\n  return new (Function.prototype.bind.apply(Or, params))();\n}\n\n/**\n * Represents a logical `<Not>` operator for a filter condition.\n *\n * @param {!import(\"./filter/Filter.js\").default} condition Filter condition.\n * @return {!Not} `<Not>` operator.\n * @api\n */\nexport function not(condition) {\n  return new Not(condition);\n}\n\n/**\n * Create a `<BBOX>` operator to test whether a geometry-valued property\n * intersects a fixed bounding box\n *\n * @param {!string} geometryName Geometry name to use.\n * @param {!import(\"../extent.js\").Extent} extent Extent.\n * @param {string} [srsName] SRS name. No srsName attribute will be\n *    set on geometries when this is not provided.\n * @return {!Bbox} `<BBOX>` operator.\n * @api\n */\nexport function bbox(geometryName, extent, srsName) {\n  return new Bbox(geometryName, extent, srsName);\n}\n\n/**\n * Create a `<Contains>` operator to test whether a geometry-valued property\n * contains a given geometry.\n *\n * @param {!string} geometryName Geometry name to use.\n * @param {!import(\"../geom/Geometry.js\").default} geometry Geometry.\n * @param {string} [srsName] SRS name. No srsName attribute will be\n *    set on geometries when this is not provided.\n * @return {!Contains} `<Contains>` operator.\n * @api\n */\nexport function contains(geometryName, geometry, srsName) {\n  return new Contains(geometryName, geometry, srsName);\n}\n\n/**\n * Create a `<Intersects>` operator to test whether a geometry-valued property\n * intersects a given geometry.\n *\n * @param {!string} geometryName Geometry name to use.\n * @param {!import(\"../geom/Geometry.js\").default} geometry Geometry.\n * @param {string} [srsName] SRS name. No srsName attribute will be\n *    set on geometries when this is not provided.\n * @return {!Intersects} `<Intersects>` operator.\n * @api\n */\nexport function intersects(geometryName, geometry, srsName) {\n  return new Intersects(geometryName, geometry, srsName);\n}\n\n/**\n * Create a `<Disjoint>` operator to test whether a geometry-valued property\n * is disjoint to a given geometry.\n *\n * @param {!string} geometryName Geometry name to use.\n * @param {!import(\"../geom/Geometry.js\").default} geometry Geometry.\n * @param {string} [srsName] SRS name. No srsName attribute will be\n *    set on geometries when this is not provided.\n * @return {!Disjoint} `<Disjoint>` operator.\n * @api\n */\nexport function disjoint(geometryName, geometry, srsName) {\n  return new Disjoint(geometryName, geometry, srsName);\n}\n\n/**\n * Create a `<Within>` operator to test whether a geometry-valued property\n * is within a given geometry.\n *\n * @param {!string} geometryName Geometry name to use.\n * @param {!import(\"../geom/Geometry.js\").default} geometry Geometry.\n * @param {string} [srsName] SRS name. No srsName attribute will be\n *    set on geometries when this is not provided.\n * @return {!Within} `<Within>` operator.\n * @api\n */\nexport function within(geometryName, geometry, srsName) {\n  return new Within(geometryName, geometry, srsName);\n}\n\n/**\n * Create a `<DWithin>` operator to test whether a geometry-valued property\n * is within a distance to a given geometry.\n *\n * @param {!string} geometryName Geometry name to use.\n * @param {!import(\"../geom/Geometry.js\").default} geometry Geometry.\n * @param {!number} distance Distance.\n * @param {!string} unit Unit.\n * @param {string} [srsName] SRS name. No srsName attribute will be\n *    set on geometries when this is not provided.\n * @return {!DWithin} `<DWithin>` operator.\n * @api\n */\nexport function dwithin(geometryName, geometry, distance, unit, srsName) {\n  return new DWithin(geometryName, geometry, distance, unit, srsName);\n}\n\n/**\n * Creates a `<PropertyIsEqualTo>` comparison operator.\n *\n * @param {!string} propertyName Name of the context property to compare.\n * @param {!(string|number)} expression The value to compare.\n * @param {boolean} [matchCase] Case-sensitive?\n * @return {!EqualTo} `<PropertyIsEqualTo>` operator.\n * @api\n */\nexport function equalTo(propertyName, expression, matchCase) {\n  return new EqualTo(propertyName, expression, matchCase);\n}\n\n/**\n * Creates a `<PropertyIsNotEqualTo>` comparison operator.\n *\n * @param {!string} propertyName Name of the context property to compare.\n * @param {!(string|number)} expression The value to compare.\n * @param {boolean} [matchCase] Case-sensitive?\n * @return {!NotEqualTo} `<PropertyIsNotEqualTo>` operator.\n * @api\n */\nexport function notEqualTo(propertyName, expression, matchCase) {\n  return new NotEqualTo(propertyName, expression, matchCase);\n}\n\n/**\n * Creates a `<PropertyIsLessThan>` comparison operator.\n *\n * @param {!string} propertyName Name of the context property to compare.\n * @param {!number} expression The value to compare.\n * @return {!LessThan} `<PropertyIsLessThan>` operator.\n * @api\n */\nexport function lessThan(propertyName, expression) {\n  return new LessThan(propertyName, expression);\n}\n\n/**\n * Creates a `<PropertyIsLessThanOrEqualTo>` comparison operator.\n *\n * @param {!string} propertyName Name of the context property to compare.\n * @param {!number} expression The value to compare.\n * @return {!LessThanOrEqualTo} `<PropertyIsLessThanOrEqualTo>` operator.\n * @api\n */\nexport function lessThanOrEqualTo(propertyName, expression) {\n  return new LessThanOrEqualTo(propertyName, expression);\n}\n\n/**\n * Creates a `<PropertyIsGreaterThan>` comparison operator.\n *\n * @param {!string} propertyName Name of the context property to compare.\n * @param {!number} expression The value to compare.\n * @return {!GreaterThan} `<PropertyIsGreaterThan>` operator.\n * @api\n */\nexport function greaterThan(propertyName, expression) {\n  return new GreaterThan(propertyName, expression);\n}\n\n/**\n * Creates a `<PropertyIsGreaterThanOrEqualTo>` comparison operator.\n *\n * @param {!string} propertyName Name of the context property to compare.\n * @param {!number} expression The value to compare.\n * @return {!GreaterThanOrEqualTo} `<PropertyIsGreaterThanOrEqualTo>` operator.\n * @api\n */\nexport function greaterThanOrEqualTo(propertyName, expression) {\n  return new GreaterThanOrEqualTo(propertyName, expression);\n}\n\n/**\n * Creates a `<PropertyIsNull>` comparison operator to test whether a property value\n * is null.\n *\n * @param {!string} propertyName Name of the context property to compare.\n * @return {!IsNull} `<PropertyIsNull>` operator.\n * @api\n */\nexport function isNull(propertyName) {\n  return new IsNull(propertyName);\n}\n\n/**\n * Creates a `<PropertyIsBetween>` comparison operator to test whether an expression\n * value lies within a range given by a lower and upper bound (inclusive).\n *\n * @param {!string} propertyName Name of the context property to compare.\n * @param {!number} lowerBoundary The lower bound of the range.\n * @param {!number} upperBoundary The upper bound of the range.\n * @return {!IsBetween} `<PropertyIsBetween>` operator.\n * @api\n */\nexport function between(propertyName, lowerBoundary, upperBoundary) {\n  return new IsBetween(propertyName, lowerBoundary, upperBoundary);\n}\n\n/**\n * Represents a `<PropertyIsLike>` comparison operator that matches a string property\n * value against a text pattern.\n *\n * @param {!string} propertyName Name of the context property to compare.\n * @param {!string} pattern Text pattern.\n * @param {string} [wildCard] Pattern character which matches any sequence of\n *    zero or more string characters. Default is '*'.\n * @param {string} [singleChar] pattern character which matches any single\n *    string character. Default is '.'.\n * @param {string} [escapeChar] Escape character which can be used to escape\n *    the pattern characters. Default is '!'.\n * @param {boolean} [matchCase] Case-sensitive?\n * @return {!IsLike} `<PropertyIsLike>` operator.\n * @api\n */\nexport function like(\n  propertyName,\n  pattern,\n  wildCard,\n  singleChar,\n  escapeChar,\n  matchCase,\n) {\n  return new IsLike(\n    propertyName,\n    pattern,\n    wildCard,\n    singleChar,\n    escapeChar,\n    matchCase,\n  );\n}\n\n/**\n * Create a `<During>` temporal operator.\n *\n * @param {!string} propertyName Name of the context property to compare.\n * @param {!string} begin The begin date in ISO-8601 format.\n * @param {!string} end The end date in ISO-8601 format.\n * @return {!During} `<During>` operator.\n * @api\n */\nexport function during(propertyName, begin, end) {\n  return new During(propertyName, begin, end);\n}\n\nexport function resourceId(rid) {\n  return new ResourceId(rid);\n}\n","/**\n * @module ol/format/WMSGetFeatureInfo\n */\nimport {extend} from '../array.js';\nimport {makeArrayPusher, makeStructureNS, pushParseAndPop} from '../xml.js';\nimport GML2 from './GML2.js';\nimport XMLFeature from './XMLFeature.js';\n\n/**\n * @typedef {Object} Options\n * @property {Array<string>} [layers] If set, only features of the given layers will be returned by the format when read.\n */\n\n/**\n * @const\n * @type {string}\n */\nconst featureIdentifier = '_feature';\n\n/**\n * @const\n * @type {string}\n */\nconst layerIdentifier = '_layer';\n\n/**\n * @classdesc\n * Format for reading WMSGetFeatureInfo format. It uses\n * {@link module:ol/format/GML2~GML2} to read features.\n *\n * @api\n */\nclass WMSGetFeatureInfo extends XMLFeature {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    super();\n\n    options = options ? options : {};\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.featureNS_ = 'http://mapserver.gis.umn.edu/mapserver';\n\n    /**\n     * @private\n     * @type {GML2}\n     */\n    this.gmlFormat_ = new GML2();\n\n    /**\n     * @private\n     * @type {Array<string>|null}\n     */\n    this.layers_ = options.layers ? options.layers : null;\n  }\n\n  /**\n   * @return {Array<string>|null} layers\n   */\n  getLayers() {\n    return this.layers_;\n  }\n\n  /**\n   * @param {Array<string>|null} layers Layers to parse.\n   */\n  setLayers(layers) {\n    this.layers_ = layers;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @param {Array<*>} objectStack Object stack.\n   * @return {Array<import(\"../Feature.js\").default>} Features.\n   * @private\n   */\n  readFeatures_(node, objectStack) {\n    node.setAttribute('namespaceURI', this.featureNS_);\n    const localName = node.localName;\n    /** @type {Array<import(\"../Feature.js\").default>} */\n    let features = [];\n    if (node.childNodes.length === 0) {\n      return features;\n    }\n    if (localName == 'msGMLOutput') {\n      for (let i = 0, ii = node.childNodes.length; i < ii; i++) {\n        const layer = node.childNodes[i];\n        if (layer.nodeType !== Node.ELEMENT_NODE) {\n          continue;\n        }\n\n        const layerElement = /** @type {Element} */ (layer);\n        const context = objectStack[0];\n\n        const toRemove = layerIdentifier;\n        const layerName = layerElement.localName.replace(toRemove, '');\n\n        if (this.layers_ && !this.layers_.includes(layerName)) {\n          continue;\n        }\n\n        const featureType = layerName + featureIdentifier;\n\n        context['featureType'] = featureType;\n        context['featureNS'] = this.featureNS_;\n\n        /** @type {Object<string, import(\"../xml.js\").Parser>} */\n        const parsers = {};\n        parsers[featureType] = makeArrayPusher(\n          this.gmlFormat_.readFeatureElement,\n          this.gmlFormat_,\n        );\n        const parsersNS = makeStructureNS(\n          [context['featureNS'], null],\n          parsers,\n        );\n        layerElement.setAttribute('namespaceURI', this.featureNS_);\n        const layerFeatures = pushParseAndPop(\n          [],\n          // @ts-ignore\n          parsersNS,\n          layerElement,\n          objectStack,\n          this.gmlFormat_,\n        );\n        if (layerFeatures) {\n          extend(features, layerFeatures);\n        }\n      }\n    }\n    if (localName == 'FeatureCollection') {\n      const gmlFeatures = pushParseAndPop(\n        [],\n        this.gmlFormat_.FEATURE_COLLECTION_PARSERS,\n        node,\n        [{}],\n        this.gmlFormat_,\n      );\n      if (gmlFeatures) {\n        features = gmlFeatures;\n      }\n    }\n    return features;\n  }\n\n  /**\n   * @protected\n   * @param {Element} node Node.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Options.\n   * @return {Array<import(\"../Feature.js\").default>} Features.\n   * @override\n   */\n  readFeaturesFromNode(node, options) {\n    const internalOptions = {};\n    if (options) {\n      Object.assign(internalOptions, this.getReadOptions(node, options));\n    }\n    return this.readFeatures_(node, [internalOptions]);\n  }\n}\n\nexport default WMSGetFeatureInfo;\n","/**\n * @module ol/geom/flat/topology\n */\nimport {linearRing as linearRingArea} from './area.js';\n\n/**\n * Check if the linestring is a boundary.\n * @param {Array<number>} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @return {boolean} The linestring is a boundary.\n */\nexport function lineStringIsClosed(flatCoordinates, offset, end, stride) {\n  const lastCoord = end - stride;\n  if (\n    flatCoordinates[offset] === flatCoordinates[lastCoord] &&\n    flatCoordinates[offset + 1] === flatCoordinates[lastCoord + 1] &&\n    (end - offset) / stride > 3\n  ) {\n    return !!linearRingArea(flatCoordinates, offset, end, stride);\n  }\n  return false;\n}\n","/**\n * @module ol/interaction/DblClickDragZoom\n */\nimport MapBrowserEventType from '../MapBrowserEventType.js';\nimport Interaction from './Interaction.js';\n\n/**\n * @typedef {Object} Options\n * @property {number} [duration=400] Animation duration in milliseconds. *\n * @property {number} [delta=1] The zoom delta applied on move of one pixel. *\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 * Allows the user to zoom the map by double tap/click then drag up/down\n * with one finger/left mouse.\n * @api\n */\nclass DblClickDragZoom extends Interaction {\n  /**\n   * @param {Options} [opt_options] Options.\n   */\n  constructor(opt_options) {\n    const options = opt_options ? opt_options : {};\n\n    super(\n      /** @type {import(\"./Interaction.js\").InteractionOptions} */ (options),\n    );\n\n    if (options.stopDown) {\n      this.stopDown = options.stopDown;\n    }\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.scaleDeltaByPixel_ = options.delta ? options.delta : 0.01;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.duration_ = options.duration !== undefined ? options.duration : 250;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.handlingDownUpSequence_ = false;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.handlingDoubleDownSequence_ = false;\n\n    /**\n     * @type {ReturnType<typeof setTimeout>}\n     * @private\n     */\n    this.doubleTapTimeoutId_ = undefined;\n\n    /**\n     * @type {!Object<string, PointerEvent>}\n     * @private\n     */\n    this.trackedPointers_ = {};\n\n    /**\n     * @type {PointerEvent|null}\n     * @private\n     */\n    this.down_ = null;\n\n    /**\n     * @type {Array<PointerEvent>}\n     * @protected\n     */\n    this.targetPointers = [];\n  }\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<PointerEvent>} 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_ = handledUp;\n      }\n    } else {\n      if (mapBrowserEvent.type == MapBrowserEventType.POINTERDOWN) {\n        if (this.handlingDoubleDownSequence_) {\n          this.handlingDoubleDownSequence_ = false;\n          const handled = this.handleDownEvent(mapBrowserEvent);\n          this.handlingDownUpSequence_ = handled;\n          stopEvent = this.stopDown(handled);\n        } else {\n          stopEvent = this.stopDown(false);\n          this.waitForDblTap_();\n        }\n      }\n    }\n    return !stopEvent;\n  }\n\n  /**\n   * Handle pointer drag events.\n   * @param {import(\"../MapBrowserEvent.js\").default<PointerEvent>} mapBrowserEvent Event.\n   */\n  handleDragEvent(mapBrowserEvent) {\n    let scaleDelta = 1.0;\n\n    const touch0 = this.targetPointers[0];\n    const touch1 = this.down_;\n    const distance = touch0.clientY - touch1.clientY;\n\n    if (this.lastDistance_ !== undefined) {\n      scaleDelta =\n        1 - (this.lastDistance_ - distance) * this.scaleDeltaByPixel_;\n    }\n    this.lastDistance_ = distance;\n\n    if (scaleDelta != 1.0) {\n      this.lastScaleDelta_ = scaleDelta;\n    }\n\n    // scale, bypass the resolution constraint\n    const map = mapBrowserEvent.map;\n    const view = map.getView();\n    map.render();\n    view.adjustResolutionInternal(scaleDelta);\n  }\n\n  /**\n   * Handle pointer down events.\n   * @param {import(\"../MapBrowserEvent.js\").default<PointerEvent>} mapBrowserEvent Event.\n   * @return {boolean} If the event was consumed.\n   */\n  handleDownEvent(mapBrowserEvent) {\n    if (this.targetPointers.length == 1) {\n      const map = mapBrowserEvent.map;\n      this.anchor_ = null;\n      this.lastDistance_ = undefined;\n      this.lastScaleDelta_ = 1;\n      this.down_ = mapBrowserEvent.originalEvent;\n      if (!this.handlingDownUpSequence_) {\n        map.getView().beginInteraction();\n      }\n      return true;\n    }\n    return false;\n  }\n\n  /**\n   * Handle pointer up events zooming out.\n   * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n   * @return {boolean} If the event was consumed.\n   */\n  handleUpEvent(mapBrowserEvent) {\n    if (this.targetPointers.length == 0) {\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      this.handlingDownUpSequence_ = false;\n      this.handlingDoubleDownSequence_ = false;\n      return false;\n    }\n    return true;\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<PointerEvent>} mapBrowserEvent Event.\n   * @private\n   */\n  updateTrackedPointers_(mapBrowserEvent) {\n    if (isPointerDraggingEvent(mapBrowserEvent)) {\n      const event = mapBrowserEvent.originalEvent;\n\n      const id = event.pointerId.toString();\n      if (mapBrowserEvent.type == MapBrowserEventType.POINTERUP) {\n        delete this.trackedPointers_[id];\n      } else if (mapBrowserEvent.type == MapBrowserEventType.POINTERDOWN) {\n        this.trackedPointers_[id] = event;\n      } else if (id in this.trackedPointers_) {\n        // update only when there was a pointerdown event for this pointer\n        this.trackedPointers_[id] = event;\n      }\n      this.targetPointers = Object.values(this.trackedPointers_);\n    }\n  }\n\n  /**\n   * Wait the second double finger tap.\n   * @private\n   */\n  waitForDblTap_() {\n    if (this.doubleTapTimeoutId_ !== undefined) {\n      // double-click\n      clearTimeout(this.doubleTapTimeoutId_);\n      this.doubleTapTimeoutId_ = undefined;\n    } else {\n      this.handlingDoubleDownSequence_ = true;\n      this.doubleTapTimeoutId_ = setTimeout(\n        this.endInteraction_.bind(this),\n        250,\n      );\n    }\n  }\n\n  /**\n   * @private\n   */\n  endInteraction_() {\n    this.handlingDoubleDownSequence_ = false;\n    this.doubleTapTimeoutId_ = undefined;\n  }\n}\n\n/**\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} Whether the event is a pointerdown, pointerdrag\n *     or pointerup event.\n */\nfunction isPointerDraggingEvent(mapBrowserEvent) {\n  const type = mapBrowserEvent.type;\n  return (\n    type === MapBrowserEventType.POINTERDOWN ||\n    type === MapBrowserEventType.POINTERDRAG ||\n    type === MapBrowserEventType.POINTERUP\n  );\n}\n\nexport default DblClickDragZoom;\n","/**\n * @module ol/interaction/DragRotateAndZoom\n */\nimport {mouseOnly, shiftKeyOnly} from '../events/condition.js';\nimport PointerInteraction from './Pointer.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.\n * Default is {@link module:ol/events/condition.shiftKeyOnly}.\n * @property {number} [duration=400] Animation duration in milliseconds.\n */\n\n/**\n * @classdesc\n * Allows the user to zoom and rotate the map by clicking and dragging\n * on the map.  By default, this interaction is limited to when the shift\n * key is held down.\n *\n * This interaction is only supported for mouse devices.\n *\n * And this interaction is not included in the default interactions.\n * @api\n */\nclass DragRotateAndZoom extends PointerInteraction {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super(/** @type {import(\"./Pointer.js\").Options} */ (options));\n\n    /**\n     * @private\n     * @type {import(\"../events/condition.js\").Condition}\n     */\n    this.condition_ = options.condition ? options.condition : shiftKeyOnly;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.lastAngle_ = undefined;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.lastMagnitude_ = undefined;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.lastScaleDelta_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.duration_ = options.duration !== undefined ? options.duration : 400;\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 size = map.getSize();\n    const offset = mapBrowserEvent.pixel;\n    const deltaX = offset[0] - size[0] / 2;\n    const deltaY = size[1] / 2 - offset[1];\n    const theta = Math.atan2(deltaY, deltaX);\n    const magnitude = Math.sqrt(deltaX * deltaX + deltaY * deltaY);\n    const view = map.getView();\n    if (this.lastAngle_ !== undefined) {\n      const angleDelta = this.lastAngle_ - theta;\n      view.adjustRotationInternal(angleDelta);\n    }\n    this.lastAngle_ = theta;\n    if (this.lastMagnitude_ !== undefined) {\n      view.adjustResolutionInternal(this.lastMagnitude_ / magnitude);\n    }\n    if (this.lastMagnitude_ !== undefined) {\n      this.lastScaleDelta_ = this.lastMagnitude_ / magnitude;\n    }\n    this.lastMagnitude_ = magnitude;\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    const direction = this.lastScaleDelta_ > 1 ? 1 : -1;\n    view.endInteraction(this.duration_, direction);\n    this.lastScaleDelta_ = 0;\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 (this.condition_(mapBrowserEvent)) {\n      mapBrowserEvent.map.getView().beginInteraction();\n      this.lastAngle_ = undefined;\n      this.lastMagnitude_ = undefined;\n      return true;\n    }\n    return false;\n  }\n}\n\nexport default DragRotateAndZoom;\n","/**\n * @module ol/layer/VectorImage\n */\nimport CanvasVectorImageLayerRenderer from '../renderer/canvas/VectorImageLayer.js';\nimport BaseVectorLayer from './BaseVector.js';\n\n/**\n * @template {import(\"../source/Vector.js\").default<FeatureType>} [VectorSourceType=import(\"../source/Vector.js\").default<*>]\n * @template {import('../Feature.js').FeatureLike} [FeatureType=import(\"./BaseVector.js\").ExtractedFeatureType<VectorSourceType>]\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} [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 {import(\"../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 viewport extent used by the\n * renderer when getting features from the vector source for the rendering or hit-detection.\n * Recommended value: the size of the largest symbol, line width or label.\n * @property {VectorSourceType} [source] Source.\n * @property {import(\"../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()]{@link import(\"../Map.js\").default#addLayer}.\n * @property {boolean|string|number} [declutter=false] Declutter images and text on this layer. Any truthy value will enable\n * decluttering. The priority is defined by the `zIndex` of the style and the render order of features. Higher z-index means higher\n * priority. Within the same z-index, a feature rendered before another has higher priority. Items will\n * not be decluttered against or together with items on other layers with the same `declutter` value. If\n * that is needed, use {@link import(\"../layer/Vector.js\").default} instead.\n * @property {import(\"../style/Style.js\").StyleLike|import(\"../style/flat.js\").FlatStyleLike|null} [style] Layer style. When set to `null`, only\n * features that have their own style will be rendered. See {@link module:ol/style/Style~Style} for the default style\n * which will be used if this is not set.\n * @property {import(\"./Base.js\").BackgroundColor} [background] Background color for the layer. If not specified, no background\n * will be rendered.\n * @property {number} [imageRatio=1] Ratio by which the rendered extent should be larger than the\n * viewport extent. A larger ratio avoids cut images during panning, but will cause a decrease in performance.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n\n/**\n * @classdesc\n * Vector data is rendered client-side, to an image. This layer type provides great performance\n * during panning and zooming, but point symbols and texts are always rotated with the view and\n * pixels are scaled during zoom animations. For more accurate rendering of vector data, use\n * {@link module:ol/layer/Vector~VectorLayer} instead.\n *\n * Note that any property set in the options is set as a {@link module:ol/Object~BaseObject}\n * property on the layer object; for example, setting `title: 'My Title'` in the\n * options means that `title` is observable, and has get/set accessors.\n *\n * @template {import(\"../source/Vector.js\").default<FeatureType>} [VectorSourceType=import(\"../source/Vector.js\").default<*>]\n * @template {import('../Feature.js').FeatureLike} [FeatureType=import(\"./BaseVector.js\").ExtractedFeatureType<VectorSourceType>]\n * @extends {BaseVectorLayer<FeatureType, VectorSourceType, CanvasVectorImageLayerRenderer>}\n * @api\n */\nclass VectorImageLayer extends BaseVectorLayer {\n  /**\n   * @param {Options<VectorSourceType, FeatureType>} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    const baseOptions = Object.assign({}, options);\n    delete baseOptions.imageRatio;\n    super(baseOptions);\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.imageRatio_ =\n      options.imageRatio !== undefined ? options.imageRatio : 1;\n  }\n\n  /**\n   * @return {number} Ratio between rendered extent size and viewport extent size.\n   */\n  getImageRatio() {\n    return this.imageRatio_;\n  }\n\n  /**\n   * @override\n   */\n  createRenderer() {\n    return new CanvasVectorImageLayerRenderer(this);\n  }\n}\n\nexport default VectorImageLayer;\n","/**\n * @module ol/source/Cluster\n */\n\nimport Feature from '../Feature.js';\nimport {assert} from '../asserts.js';\nimport {add as addCoordinate, scale as scaleCoordinate} from '../coordinate.js';\nimport EventType from '../events/EventType.js';\nimport {\n  buffer,\n  createEmpty,\n  createOrUpdateFromCoordinate,\n  getCenter,\n} from '../extent.js';\nimport Point from '../geom/Point.js';\nimport {getUid} from '../util.js';\nimport VectorSource from './Vector.js';\n\n/**\n * @template {import(\"../Feature.js\").FeatureLike} [FeatureType=import(\"../Feature.js\").FeatureLike]\n * @typedef {(feature: FeatureType) => (Point|null)} GeometryFunction\n */\n\n/**\n * @template {import(\"../Feature.js\").FeatureLike} [FeatureType=import(\"../Feature.js\").default]\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {number} [distance=20] Distance in pixels within which features will\n * be clustered together.\n * @property {number} [minDistance=0] Minimum distance in pixels between clusters.\n * Will be capped at the configured distance.\n * By default no minimum distance is guaranteed. This config can be used to avoid\n * overlapping icons. As a tradoff, the cluster feature's position will no longer be\n * the center of all its features.\n * @property {GeometryFunction<FeatureType>} [geometryFunction]\n * Function that takes a {@link module:ol/Feature~Feature} as argument and returns a\n * {@link module:ol/geom/Point~Point} as cluster calculation point for the feature. When a\n * feature should not be considered for clustering, the function should return\n * `null`. The default, which works when the underlying source contains point\n * features only, is\n * ```js\n * function(feature) {\n *   return feature.getGeometry();\n * }\n * ```\n * See {@link module:ol/geom/Polygon~Polygon#getInteriorPoint} for a way to get a cluster\n * calculation point for polygons.\n * @property {function(Point, Array<FeatureType>):Feature} [createCluster]\n * Function that takes the cluster's center {@link module:ol/geom/Point~Point} and an array\n * of {@link module:ol/Feature~Feature} included in this cluster. Must return a\n * {@link module:ol/Feature~Feature} that will be used to render. Default implementation is:\n * ```js\n * function(point, features) {\n *   return new Feature({\n *     geometry: point,\n *     features: features\n *   });\n * }\n * ```\n * @property {VectorSource<FeatureType>} [source=null] Source.\n * @property {boolean} [wrapX=true] Whether to wrap the world horizontally.\n */\n\n/**\n * @classdesc\n * Layer source to cluster vector data. Works out of the box with point\n * geometries. For other geometry types, or if not all geometries should be\n * considered for clustering, a custom `geometryFunction` can be defined.\n *\n * If the instance is disposed without also disposing the underlying\n * source `setSource(null)` has to be called to remove the listener reference\n * from the wrapped source.\n * @api\n * @template {import('../Feature.js').FeatureLike} [FeatureType=import('../Feature.js').default]\n * @extends {VectorSource<Feature<import(\"../geom/Geometry.js\").default>>}\n */\nclass Cluster extends VectorSource {\n  /**\n   * @param {Options<FeatureType>} [options] Cluster options.\n   */\n  constructor(options) {\n    options = options || {};\n    super({\n      attributions: options.attributions,\n      wrapX: options.wrapX,\n    });\n\n    /**\n     * @type {number|undefined}\n     * @protected\n     */\n    this.resolution = undefined;\n\n    /**\n     * @type {number}\n     * @protected\n     */\n    this.distance = options.distance !== undefined ? options.distance : 20;\n\n    /**\n     * @type {number}\n     * @protected\n     */\n    this.minDistance = options.minDistance || 0;\n\n    /**\n     * @type {number}\n     * @protected\n     */\n    this.interpolationRatio = 0;\n\n    /**\n     * @type {Array<Feature>}\n     * @protected\n     */\n    this.features = [];\n\n    /**\n     * @type {GeometryFunction<import(\"../Feature.js\").FeatureLike>}\n     * @protected\n     */\n    this.geometryFunction =\n      options.geometryFunction ||\n      function (feature) {\n        const geometry = /** @type {Point} */ (feature.getGeometry());\n        assert(\n          !geometry || geometry.getType() === 'Point',\n          'The default `geometryFunction` can only handle `Point` or null geometries',\n        );\n        return geometry;\n      };\n\n    /**\n     * @type {function(Point, Array<FeatureType>):Feature}\n     * @private\n     */\n    this.createCustomCluster_ = options.createCluster;\n\n    /**\n     * @type {VectorSource<FeatureType>|null}\n     * @protected\n     */\n    this.source = null;\n\n    /**\n     * @private\n     */\n    this.boundRefresh_ = this.refresh.bind(this);\n\n    this.updateDistance(this.distance, this.minDistance);\n    this.setSource(options.source || null);\n  }\n\n  /**\n   * Remove all features from the source.\n   * @param {boolean} [fast] Skip dispatching of {@link module:ol/source/VectorEventType~VectorEventType#removefeature} events.\n   * @api\n   * @override\n   */\n  clear(fast) {\n    this.features.length = 0;\n    super.clear(fast);\n  }\n\n  /**\n   * Get the distance in pixels between clusters.\n   * @return {number} Distance.\n   * @api\n   */\n  getDistance() {\n    return this.distance;\n  }\n\n  /**\n   * Get a reference to the wrapped source.\n   * @return {VectorSource<FeatureType>|null} Source.\n   * @api\n   */\n  getSource() {\n    return this.source;\n  }\n\n  /**\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} resolution Resolution.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @override\n   */\n  loadFeatures(extent, resolution, projection) {\n    this.source?.loadFeatures(extent, resolution, projection);\n    if (resolution !== this.resolution) {\n      this.resolution = resolution;\n      this.refresh();\n    }\n  }\n\n  /**\n   * Set the distance within which features will be clusterd together.\n   * @param {number} distance The distance in pixels.\n   * @api\n   */\n  setDistance(distance) {\n    this.updateDistance(distance, this.minDistance);\n  }\n\n  /**\n   * Set the minimum distance between clusters. Will be capped at the\n   * configured distance.\n   * @param {number} minDistance The minimum distance in pixels.\n   * @api\n   */\n  setMinDistance(minDistance) {\n    this.updateDistance(this.distance, minDistance);\n  }\n\n  /**\n   * The configured minimum distance between clusters.\n   * @return {number} The minimum distance in pixels.\n   * @api\n   */\n  getMinDistance() {\n    return this.minDistance;\n  }\n\n  /**\n   * Replace the wrapped source.\n   * @param {VectorSource<FeatureType>|null} source The new source for this instance.\n   * @api\n   */\n  setSource(source) {\n    if (this.source) {\n      this.source.removeEventListener(EventType.CHANGE, this.boundRefresh_);\n    }\n    this.source = source;\n    if (source) {\n      source.addEventListener(EventType.CHANGE, this.boundRefresh_);\n    }\n    this.refresh();\n  }\n\n  /**\n   * Handle the source changing.\n   * @override\n   */\n  refresh() {\n    this.clear();\n    this.cluster();\n    this.addFeatures(this.features);\n  }\n\n  /**\n   * Update the distances and refresh the source if necessary.\n   * @param {number} distance The new distance.\n   * @param {number} minDistance The new minimum distance.\n   */\n  updateDistance(distance, minDistance) {\n    const ratio =\n      distance === 0 ? 0 : Math.min(minDistance, distance) / distance;\n    const changed =\n      distance !== this.distance || this.interpolationRatio !== ratio;\n    this.distance = distance;\n    this.minDistance = minDistance;\n    this.interpolationRatio = ratio;\n    if (changed) {\n      this.refresh();\n    }\n  }\n\n  /**\n   * @protected\n   */\n  cluster() {\n    if (this.resolution === undefined || !this.source) {\n      return;\n    }\n    const extent = createEmpty();\n    const mapDistance = this.distance * this.resolution;\n    const features = this.source.getFeatures();\n\n    /** @type {Object<string, true>} */\n    const clustered = {};\n\n    for (let i = 0, ii = features.length; i < ii; i++) {\n      const feature = features[i];\n      if (!(getUid(feature) in clustered)) {\n        const geometry = this.geometryFunction(feature);\n        if (geometry) {\n          const coordinates = geometry.getCoordinates();\n          createOrUpdateFromCoordinate(coordinates, extent);\n          buffer(extent, mapDistance, extent);\n\n          const neighbors = this.source\n            .getFeaturesInExtent(extent)\n            .filter(function (neighbor) {\n              const uid = getUid(neighbor);\n              if (uid in clustered) {\n                return false;\n              }\n              clustered[uid] = true;\n              return true;\n            });\n          this.features.push(this.createCluster(neighbors, extent));\n        }\n      }\n    }\n  }\n\n  /**\n   * @param {Array<FeatureType>} features Features\n   * @param {import(\"../extent.js\").Extent} extent The searched extent for these features.\n   * @return {Feature} The cluster feature.\n   * @protected\n   */\n  createCluster(features, extent) {\n    const centroid = [0, 0];\n    for (let i = features.length - 1; i >= 0; --i) {\n      const geometry = this.geometryFunction(features[i]);\n      if (geometry) {\n        addCoordinate(centroid, geometry.getCoordinates());\n      } else {\n        features.splice(i, 1);\n      }\n    }\n    scaleCoordinate(centroid, 1 / features.length);\n    const searchCenter = getCenter(extent);\n    const ratio = this.interpolationRatio;\n    const geometry = new Point([\n      centroid[0] * (1 - ratio) + searchCenter[0] * ratio,\n      centroid[1] * (1 - ratio) + searchCenter[1] * ratio,\n    ]);\n    if (this.createCustomCluster_) {\n      return this.createCustomCluster_(geometry, features);\n    }\n    return new Feature({\n      geometry,\n      features,\n    });\n  }\n}\n\nexport default Cluster;\n","/**\n * @module ol/source/Google\n */\n\nimport ViewHint from '../ViewHint.js';\nimport {getBottomLeft, getTopRight} from '../extent.js';\nimport {toLonLat} from '../proj.js';\nimport {createXYZ, extentFromProjection} from '../tilegrid.js';\nimport TileImage from './TileImage.js';\n\nconst maxZoom = 22;\n\n/**\n * @typedef {Object} Options\n * @property {string} key Google Map Tiles API key. Get yours at https://developers.google.com/maps/documentation/tile/get-api-key.\n * @property {string} [mapType='roadmap'] The type of [base map](https://developers.google.com/maps/documentation/tile/session_tokens#required_fields).\n * @property {string} [language='en-US'] An [IETF language tag](https://en.wikipedia.org/wiki/IETF_language_tag) for information displayed on the tiles.\n * @property {string} [region='US'] A [Common Locale Data Repository](https://cldr.unicode.org/) (CLDR) region identifier that represents the user location.\n * @property {string} [imageFormat] The image format used for the map tiles (e.g. `'jpeg'`, or `'png'`).\n * @property {string} [scale] Scale for map elements (`'scaleFactor1x'`, `'scaleFactor2x'`, or `'scaleFactor4x'`).\n * @property {boolean} [highDpi=false] Use high-resolution tiles.\n * @property {Array<string>} [layerTypes] The layer types added to the map (e.g. `'layerRoadmap'`, `'layerStreetview'`, or `'layerTraffic'`).\n * @property {boolean} [overlay=false] Display only the `layerTypes` and not the underlying `mapType` (only works if `layerTypes` is provided).\n * @property {Array<Object>} [styles] [Custom styles](https://developers.google.com/maps/documentation/tile/style-reference) applied to the map.\n * @property {boolean} [attributionsCollapsible=true] Allow the attributions to be collapsed.\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * linear interpolation is used when resampling.  Set to false to use the nearest neighbor instead.\n * @property {number} [cacheSize] Initial tile cache size. Will auto-grow to hold at least the number of tiles in the viewport.\n * @property {number} [reprojectionErrorThreshold=0.5] Maximum allowed reprojection error (in pixels).\n * Higher values can increase reprojection performance, but decrease precision.\n * @property {import(\"../Tile.js\").LoadFunction} [tileLoadFunction] Optional function to load a tile given a URL. The default is\n * ```js\n * function(imageTile, src) {\n *   imageTile.getImage().src = src;\n * };\n * ```\n * @property {Array<string>} [apiOptions] An array of values specifying additional options to apply.\n * @property {boolean} [wrapX=true] Wrap the world horizontally.\n * @property {number} [transition] Duration of the opacity transition for rendering.\n * To disable the opacity transition, pass `transition: 0`.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n * @property {string} [url='https://tile.googleapis.com/'] The Google Tile server URL.\n */\n\n/**\n * @typedef {Object} SessionTokenRequest\n * @property {string} mapType The map type.\n * @property {string} language The language.\n * @property {string} region The region.\n * @property {string} [imageFormat] The image format.\n * @property {string} [scale] The scale.\n * @property {boolean} [highDpi] Use high resolution tiles.\n * @property {Array<string>} [layerTypes] The layer types.\n * @property {boolean} [overlay] The overlay.\n * @property {Array<Object>} [styles] The styles.\n * @property {Array<string>} [apiOptions] An array of values specifying additional options to apply.\n */\n\n/**\n * @typedef {Object} SessionTokenResponse\n * @property {string} session The session token.\n * @property {string} expiry The session token expiry (seconds since the epoch as a string).\n * @property {number} tileWidth The tile width.\n * @property {number} tileHeight The tile height.\n * @property {string} imageFormat The image format.\n */\n\n/**\n * @classdesc\n * A tile layer source that renders tiles from the Google [Map Tiles API](https://developers.google.com/maps/documentation/tile/overview).\n * The constructor takes options that are passed to the request to create a session token.  Refer to the\n * [documentation](https://developers.google.com/maps/documentation/tile/session_tokens#required_fields)\n * for additional details.\n * @api\n */\nclass Google extends TileImage {\n  /**\n   * @param {Options} options Google Maps options.\n   */\n  constructor(options) {\n    const highDpi = !!options.highDpi;\n\n    super({\n      attributionsCollapsible: options.attributionsCollapsible,\n      cacheSize: options.cacheSize,\n      crossOrigin: 'anonymous',\n      interpolate: options.interpolate,\n      projection: 'EPSG:3857',\n      reprojectionErrorThreshold: options.reprojectionErrorThreshold,\n      state: 'loading',\n      tileLoadFunction: options.tileLoadFunction,\n      tilePixelRatio: highDpi ? 2 : 1,\n      wrapX: options.wrapX !== undefined ? options.wrapX : true,\n      transition: options.transition,\n      zDirection: options.zDirection,\n    });\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.apiKey_ = options.key;\n\n    /**\n     * @type {Error|null}\n     * @private\n     */\n    this.error_ = null;\n\n    /**\n     * @type {SessionTokenRequest}\n     */\n    const sessionTokenRequest = {\n      mapType: options.mapType || 'roadmap',\n      language: options.language || 'en-US',\n      region: options.region || 'US',\n    };\n    if (options.imageFormat) {\n      sessionTokenRequest.imageFormat = options.imageFormat;\n    }\n    if (options.scale) {\n      sessionTokenRequest.scale = options.scale;\n    }\n    if (highDpi) {\n      sessionTokenRequest.highDpi = true;\n    }\n    if (options.layerTypes) {\n      sessionTokenRequest.layerTypes = options.layerTypes;\n    }\n    if (options.styles) {\n      sessionTokenRequest.styles = options.styles;\n    }\n    if (options.overlay === true) {\n      sessionTokenRequest.overlay = true;\n    }\n    if (options.apiOptions) {\n      sessionTokenRequest.apiOptions = options.apiOptions;\n    }\n\n    /**\n     * @type {SessionTokenRequest}\n     * @private\n     */\n    this.sessionTokenRequest_ = sessionTokenRequest;\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.sessionTokenValue_;\n\n    /**\n     * @type {ReturnType<typeof setTimeout>}\n     * @private\n     */\n    this.sessionRefreshId_;\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.previousViewportAttribution_;\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.previousViewportExtent_;\n\n    const baseUrl = options.url || 'https://tile.googleapis.com/';\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.createSessionUrl_ = baseUrl + 'v1/createSession';\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.tileUrl_ = baseUrl + 'v1/2dtiles';\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.attributionUrl_ = baseUrl + 'tile/v1/viewport';\n\n    this.createSession_();\n  }\n\n  /**\n   * @return {Error|null} A source loading error. When the source state is `error`, use this function\n   * to get more information about the error. To debug a faulty configuration, you may want to use\n   * a listener like\n   * ```js\n   * source.on('change', () => {\n   *   if (source.getState() === 'error') {\n   *     console.error(source.getError());\n   *   }\n   * });\n   * ```\n   */\n  getError() {\n    return this.error_;\n  }\n\n  /**\n   * Exposed here so it can be overridden in the tests.\n   * @param {string} url The URL.\n   * @param {RequestInit} config The config.\n   * @return {Promise<Response>} A promise that resolves with the response.\n   */\n  fetchSessionToken(url, config) {\n    return fetch(url, config);\n  }\n\n  /**\n   * Get or renew a session token for use with tile requests.\n   * @private\n   */\n  async createSession_() {\n    const url = this.createSessionUrl_ + '?key=' + this.apiKey_;\n    const config = {\n      method: 'POST',\n      headers: {\n        'Content-Type': 'application/json',\n      },\n      body: JSON.stringify(this.sessionTokenRequest_),\n    };\n\n    const response = await this.fetchSessionToken(url, config);\n    if (!response.ok) {\n      try {\n        const body = await response.json();\n        this.error_ = new Error(body.error.message);\n      } catch {\n        this.error_ = new Error('Error fetching session token');\n      }\n      this.setState('error');\n      return;\n    }\n\n    /**\n     * @type {SessionTokenResponse}\n     */\n    const sessionTokenResponse = await response.json();\n\n    const tilePixelRatio = this.getTilePixelRatio(1);\n    const tileSize = [\n      sessionTokenResponse.tileWidth / tilePixelRatio,\n      sessionTokenResponse.tileHeight / tilePixelRatio,\n    ];\n\n    this.tileGrid = createXYZ({\n      extent: extentFromProjection(this.getProjection()),\n      maxZoom: maxZoom,\n      tileSize: tileSize,\n    });\n\n    const session = sessionTokenResponse.session;\n    this.sessionTokenValue_ = session;\n    const key = this.apiKey_;\n    const tileUrl = this.tileUrl_;\n    this.tileUrlFunction = function (tileCoord, pixelRatio, projection) {\n      const z = tileCoord[0];\n      const x = tileCoord[1];\n      const y = tileCoord[2];\n      const url = `${tileUrl}/${z}/${x}/${y}?session=${session}&key=${key}`;\n      return url;\n    };\n\n    const expiry = parseInt(sessionTokenResponse.expiry, 10) * 1000;\n    const timeout = Math.max(expiry - Date.now() - 60 * 1000, 1);\n    this.sessionRefreshId_ = setTimeout(() => this.createSession_(), timeout);\n\n    this.setAttributions(this.fetchAttributions_.bind(this));\n    // even if the state is already ready, we want the change event\n    this.setState('ready');\n  }\n\n  /**\n   * @param {import('../Map.js').FrameState} frameState The frame state.\n   * @return {Promise<string>} The attributions.\n   * @private\n   */\n  async fetchAttributions_(frameState) {\n    if (\n      frameState.viewHints[ViewHint.ANIMATING] ||\n      frameState.viewHints[ViewHint.INTERACTING] ||\n      frameState.animate\n    ) {\n      return this.previousViewportAttribution_;\n    }\n    const [west, south] = toLonLat(\n      getBottomLeft(frameState.extent),\n      frameState.viewState.projection,\n    );\n    const [east, north] = toLonLat(\n      getTopRight(frameState.extent),\n      frameState.viewState.projection,\n    );\n    const tileGrid = this.getTileGrid();\n    const zoom = tileGrid.getZForResolution(\n      frameState.viewState.resolution,\n      this.zDirection,\n    );\n    const viewportExtent = `zoom=${zoom}&north=${north}&south=${south}&east=${east}&west=${west}`;\n    // check if the extent or zoom has actually changed to avoid unnecessary requests\n    if (this.previousViewportExtent_ == viewportExtent) {\n      return this.previousViewportAttribution_;\n    }\n    this.previousViewportExtent_ = viewportExtent;\n    const session = this.sessionTokenValue_;\n    const key = this.apiKey_;\n    const attributionUrl = this.attributionUrl_;\n    const url = `${attributionUrl}?session=${session}&key=${key}&${viewportExtent}`;\n    this.previousViewportAttribution_ = await fetch(url)\n      .then((response) => response.json())\n      .then((json) => json.copyright);\n\n    return this.previousViewportAttribution_;\n  }\n\n  /**\n   * @override\n   */\n  disposeInternal() {\n    clearTimeout(this.sessionRefreshId_);\n    super.disposeInternal();\n  }\n}\n\nexport default Google;\n","/**\n * @module ol/source/ImageArcGISRest\n */\n\nimport {decode} from '../Image.js';\nimport ImageSource, {defaultImageLoadFunction} from './Image.js';\nimport {createLoader} from './arcgisRest.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images.  Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for loaded images.\n * @property {boolean} [hidpi=true] Use the `ol/Map#pixelRatio` value when requesting the image from\n * the remote server.\n * @property {import(\"../Image.js\").LoadFunction} [imageLoadFunction] Optional function to load an image given\n * a URL.\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * linear interpolation is used when resampling.  Set to false to use the nearest neighbor instead.\n * @property {Object<string,*>} [params] ArcGIS Rest parameters. This field is optional. Service\n * defaults will be used for any fields not specified. `FORMAT` is `PNG32` by default. `F` is\n * `IMAGE` by default. `TRANSPARENT` is `true` by default.  `BBOX`, `SIZE`, `BBOXSR`, and `IMAGESR`\n * will be set dynamically. Set `LAYERS` to override the default service layer visibility. See\n * https://developers.arcgis.com/rest/services-reference/export-map.htm\n * for further reference.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is the view projection.\n * The projection code must contain a numeric end portion separated by :\n * or the entire code must form a valid ArcGIS SpatialReference definition.\n * @property {number} [ratio=1.5] Ratio. `1` means image requests are the size of the map viewport,\n * `2` means twice the size of the map viewport, and so on.\n * @property {Array<number>} [resolutions] Resolutions. If specified, requests will be made for\n * these resolutions only.\n * @property {string} [url] ArcGIS Rest service URL for a Map Service or Image Service. The url\n * should include /MapServer or /ImageServer.\n */\n\n/**\n * @classdesc\n * Source for data from ArcGIS Rest services providing single, untiled images.\n * Useful when underlying map service has labels.\n *\n * If underlying map service is not using labels,\n * take advantage of ol image caching and use\n * {@link module:ol/source/TileArcGISRest~TileArcGISRest} data source.\n *\n * @fires module:ol/source/Image.ImageSourceEvent\n * @api\n */\nclass ImageArcGISRest extends ImageSource {\n  /**\n   * @param {Options} [options] Image ArcGIS Rest Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super({\n      attributions: options.attributions,\n      interpolate: options.interpolate,\n      projection: options.projection,\n      resolutions: options.resolutions,\n    });\n\n    /**\n     * @private\n     * @type {?string}\n     */\n    this.crossOrigin_ =\n      options.crossOrigin !== undefined ? options.crossOrigin : null;\n\n    /**\n     * @private\n     * @type {ReferrerPolicy}\n     */\n    this.referrerPolicy_ = options.referrerPolicy;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.hidpi_ = options.hidpi !== undefined ? options.hidpi : true;\n\n    /**\n     * @private\n     * @type {string|undefined}\n     */\n    this.url_ = options.url;\n\n    /**\n     * @private\n     * @type {import(\"../Image.js\").LoadFunction}\n     */\n    this.imageLoadFunction_ =\n      options.imageLoadFunction !== undefined\n        ? options.imageLoadFunction\n        : defaultImageLoadFunction;\n\n    /**\n     * @private\n     * @type {!Object}\n     */\n    this.params_ = Object.assign({}, options.params);\n\n    /**\n     * @private\n     * @type {import(\"../size.js\").Size}\n     */\n    this.imageSize_ = [0, 0];\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.renderedRevision_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.ratio_ = options.ratio !== undefined ? options.ratio : 1.5;\n\n    /**\n     * @private\n     * @type {import(\"../proj/Projection.js\").default}\n     */\n    this.loaderProjection_ = null;\n  }\n\n  /**\n   * Get the user-provided params, i.e. those passed to the constructor through\n   * the \"params\" option, and possibly updated using the updateParams method.\n   * @return {Object} Params.\n   * @api\n   */\n  getParams() {\n    return this.params_;\n  }\n\n  /**\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {import(\"../Image.js\").default} Single image.\n   * @override\n   */\n  getImageInternal(extent, resolution, pixelRatio, projection) {\n    if (this.url_ === undefined) {\n      return null;\n    }\n    if (!this.loader || this.loaderProjection_ !== projection) {\n      // Lazily create loader to pick up the view projection and to allow `params` updates\n      this.loaderProjection_ = projection;\n      this.loader = createLoader({\n        crossOrigin: this.crossOrigin_,\n        referrerPolicy: this.referrerPolicy_,\n        params: this.params_,\n        projection: projection,\n        hidpi: this.hidpi_,\n        url: this.url_,\n        ratio: this.ratio_,\n        load: (image, src) => {\n          this.image.setImage(image);\n          this.imageLoadFunction_(this.image, src);\n          return decode(image);\n        },\n      });\n    }\n\n    return super.getImageInternal(extent, resolution, pixelRatio, projection);\n  }\n\n  /**\n   * Return the image load function of the source.\n   * @return {import(\"../Image.js\").LoadFunction} The image load function.\n   * @api\n   */\n  getImageLoadFunction() {\n    return this.imageLoadFunction_;\n  }\n\n  /**\n   * Return the URL used for this ArcGIS source.\n   * @return {string|undefined} URL.\n   * @api\n   */\n  getUrl() {\n    return this.url_;\n  }\n\n  /**\n   * Set the image load function of the source.\n   * @param {import(\"../Image.js\").LoadFunction} imageLoadFunction Image load function.\n   * @api\n   */\n  setImageLoadFunction(imageLoadFunction) {\n    this.imageLoadFunction_ = imageLoadFunction;\n    this.changed();\n  }\n\n  /**\n   * Set the URL to use for requests.\n   * @param {string|undefined} url URL.\n   * @api\n   */\n  setUrl(url) {\n    if (url != this.url_) {\n      this.url_ = url;\n      this.loader = null;\n      this.changed();\n    }\n  }\n\n  /**\n   * Set the user-provided params.\n   * @param {Object} params Params.\n   * @api\n   */\n  setParams(params) {\n    this.params_ = Object.assign({}, params);\n    this.changed();\n  }\n\n  /**\n   * Update the user-provided params.\n   * @param {Object} params Params.\n   * @api\n   */\n  updateParams(params) {\n    Object.assign(this.params_, params);\n    this.changed();\n  }\n\n  /**\n   * @override\n   */\n  changed() {\n    this.image = null;\n    super.changed();\n  }\n}\n\nexport default ImageArcGISRest;\n","/**\n * @module ol/source/ImageCanvas\n */\n\nimport ImageCanvas from '../ImageCanvas.js';\nimport {\n  containsExtent,\n  getHeight,\n  getWidth,\n  scaleFromCenter,\n} from '../extent.js';\nimport ImageSource from './Image.js';\n\n/**\n * A function returning the canvas element (`{HTMLCanvasElement}`)\n * used by the source as an image. The arguments passed to the function are:\n * {@link module:ol/extent~Extent} the image extent, `{number}` the image resolution,\n * `{number}` the pixel ratio of the map, {@link module:ol/size~Size} the image size,\n * and {@link module:ol/proj/Projection~Projection} the image projection. The canvas returned by\n * this function is cached by the source. The this keyword inside the function\n * references the {@link module:ol/source/ImageCanvas~ImageCanvasSource}.\n *\n * @typedef {function(this:import(\"../ImageCanvas.js\").default, import(\"../extent.js\").Extent, number,\n *     number, import(\"../size.js\").Size, import(\"../proj/Projection.js\").default): HTMLCanvasElement} FunctionType\n */\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {FunctionType} [canvasFunction] Canvas function.\n * The function returning the canvas element used by the source\n * as an image. The arguments passed to the function are: {@link import(\"../extent.js\").Extent} the\n * image extent, `{number}` the image resolution, `{number}` the pixel ratio of the map,\n * {@link import(\"../size.js\").Size} the image size, and {@link import(\"../proj/Projection.js\").default} the image\n * projection. The canvas returned by this function is cached by the source. If\n * the value returned by the function is later changed then\n * `changed` should be called on the source for the source to\n * invalidate the current cached image. See: {@link module:ol/Observable~Observable#changed}\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * linear interpolation is used when resampling.  Set to false to use the nearest neighbor instead.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is the view projection.\n * @property {number} [ratio=1.5] Ratio. 1 means canvases are the size of the map viewport, 2 means twice the\n * width and height of the map viewport, and so on. Must be `1` or higher.\n * @property {Array<number>} [resolutions] Resolutions.\n * If specified, new canvases will be created for these resolutions\n * @property {import(\"./Source.js\").State} [state] Source state.\n */\n\n/**\n * @classdesc\n * Base class for image sources where a canvas element is the image.\n * @api\n */\nclass ImageCanvasSource extends ImageSource {\n  /**\n   * @param {Options} [options] ImageCanvas options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super({\n      attributions: options.attributions,\n      interpolate: options.interpolate,\n      projection: options.projection,\n      resolutions: options.resolutions,\n      state: options.state,\n    });\n\n    /**\n     * @private\n     * @type {FunctionType}\n     */\n    this.canvasFunction_ = options.canvasFunction;\n\n    /**\n     * @private\n     * @type {import(\"../ImageCanvas.js\").default}\n     */\n    this.canvas_ = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.renderedRevision_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.ratio_ = options.ratio !== undefined ? options.ratio : 1.5;\n  }\n\n  /**\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {import(\"../ImageCanvas.js\").default} Single image.\n   * @override\n   */\n  getImageInternal(extent, resolution, pixelRatio, projection) {\n    resolution = this.findNearestResolution(resolution);\n\n    let canvas = this.canvas_;\n    if (\n      canvas &&\n      this.renderedRevision_ == this.getRevision() &&\n      canvas.getResolution() == resolution &&\n      canvas.getPixelRatio() == pixelRatio &&\n      containsExtent(canvas.getExtent(), extent)\n    ) {\n      return canvas;\n    }\n\n    extent = extent.slice();\n    scaleFromCenter(extent, this.ratio_);\n    const width = getWidth(extent) / resolution;\n    const height = getHeight(extent) / resolution;\n    const size = [width * pixelRatio, height * pixelRatio];\n\n    const canvasElement = this.canvasFunction_.call(\n      this,\n      extent,\n      resolution,\n      pixelRatio,\n      size,\n      projection,\n    );\n    if (canvasElement) {\n      canvas = new ImageCanvas(extent, resolution, pixelRatio, canvasElement);\n    }\n    this.canvas_ = canvas;\n    this.renderedRevision_ = this.getRevision();\n\n    return canvas;\n  }\n}\n\nexport default ImageCanvasSource;\n","/**\n * @module ol/source/ImageStatic\n */\n\nimport ImageWrapper, {decode} from '../Image.js';\nimport EventType from '../events/EventType.js';\nimport {intersects} from '../extent.js';\nimport {get as getProjection} from '../proj.js';\nimport ImageSource, {defaultImageLoadFunction} from './Image.js';\nimport {createLoader} from './static.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images.  Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for loaded images.\n * @property {import(\"../extent.js\").Extent} imageExtent Extent of the image in map coordinates.\n * This is the [left, bottom, right, top] map coordinates of your image.\n * @property {import(\"../Image.js\").LoadFunction} [imageLoadFunction] Optional function to load an image given a URL.\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * linear interpolation is used when resampling.  Set to false to use the nearest neighbor instead.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is the view projection.\n * @property {string} url Image URL.\n */\n\n/**\n * @classdesc\n * A layer source for displaying a single, static image.\n * @api\n */\nclass Static extends ImageSource {\n  /**\n   * @param {Options} options ImageStatic options.\n   */\n  constructor(options) {\n    const crossOrigin =\n      options.crossOrigin !== undefined ? options.crossOrigin : null;\n\n    const /** @type {import(\"../Image.js\").LoadFunction} */ imageLoadFunction =\n        options.imageLoadFunction !== undefined\n          ? options.imageLoadFunction\n          : defaultImageLoadFunction;\n\n    super({\n      attributions: options.attributions,\n      interpolate: options.interpolate,\n      projection: getProjection(options.projection),\n    });\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.url_ = options.url;\n\n    /**\n     * @private\n     * @type {import(\"../extent.js\").Extent}\n     */\n    this.imageExtent_ = options.imageExtent;\n\n    /**\n     * @private\n     * @type {import(\"../Image.js\").default}\n     */\n    this.image = null;\n\n    this.image = new ImageWrapper(\n      this.imageExtent_,\n      undefined,\n      1,\n      createLoader({\n        url: options.url,\n        imageExtent: options.imageExtent,\n        crossOrigin,\n        referrerPolicy: options.referrerPolicy,\n        load: (image, src) => {\n          this.image.setImage(image);\n          imageLoadFunction(this.image, src);\n          return decode(image);\n        },\n      }),\n    );\n\n    this.image.addEventListener(\n      EventType.CHANGE,\n      this.handleImageChange.bind(this),\n    );\n  }\n\n  /**\n   * Returns the image extent\n   * @return {import(\"../extent.js\").Extent} image extent.\n   * @api\n   */\n  getImageExtent() {\n    return this.imageExtent_;\n  }\n\n  /**\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {import(\"../Image.js\").default} Single image.\n   * @override\n   */\n  getImageInternal(extent, resolution, pixelRatio, projection) {\n    if (intersects(extent, this.image.getExtent())) {\n      return this.image;\n    }\n    return null;\n  }\n\n  /**\n   * Return the URL used for this image source.\n   * @return {string} URL.\n   * @api\n   */\n  getUrl() {\n    return this.url_;\n  }\n}\n\nexport default Static;\n","/**\n * @module ol/source/ImageWMS\n */\n\nimport {decode} from '../Image.js';\nimport {get as getProjection, transform} from '../proj.js';\nimport {calculateSourceResolution} from '../reproj.js';\nimport ImageSource, {defaultImageLoadFunction} from './Image.js';\nimport {createLoader, getFeatureInfoUrl, getLegendUrl} from './wms.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images.  Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for loaded images.\n * @property {boolean} [hidpi=true] Use the `ol/Map#pixelRatio` value when requesting\n * the image from the remote server.\n * @property {import(\"./wms.js\").ServerType} [serverType] The type of\n * the remote WMS server: `mapserver`, `geoserver`, `carmentaserver`, or `qgis`.\n * Only needed if `hidpi` is `true`.\n * @property {import(\"../Image.js\").LoadFunction} [imageLoadFunction] Optional function to load an image given a URL.\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * linear interpolation is used when resampling.  Set to false to use the nearest neighbor instead.\n * @property {Object<string,*>} [params] WMS request parameters.\n * At least a `LAYERS` param is required. `STYLES` is\n * `''` by default. `VERSION` is `1.3.0` by default. `WIDTH`, `HEIGHT`, `BBOX`\n * and `CRS` (`SRS` for WMS version < 1.3.0) will be set dynamically.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is the view projection.\n * @property {number} [ratio=1.5] Ratio. `1` means image requests are the size of the map viewport, `2` means\n * twice the width and height of the map viewport, and so on. Must be `1` or higher.\n * @property {Array<number>} [resolutions] Resolutions.\n * If specified, requests will be made for these resolutions only.\n * @property {string} [url] WMS service URL.\n */\n\n/**\n * @classdesc\n * Source for WMS servers providing single, untiled images.\n *\n * @fires module:ol/source/Image.ImageSourceEvent\n * @api\n */\nclass ImageWMS extends ImageSource {\n  /**\n   * @param {Options} [options] ImageWMS options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super({\n      attributions: options.attributions,\n      interpolate: options.interpolate,\n      projection: options.projection,\n      resolutions: options.resolutions,\n    });\n\n    /**\n     * @private\n     * @type {?string}\n     */\n    this.crossOrigin_ =\n      options.crossOrigin !== undefined ? options.crossOrigin : null;\n\n    /**\n     * @private\n     * @type {ReferrerPolicy}\n     */\n    this.referrerPolicy_ = options.referrerPolicy;\n\n    /**\n     * @private\n     * @type {string|undefined}\n     */\n    this.url_ = options.url;\n\n    /**\n     * @private\n     * @type {import(\"../Image.js\").LoadFunction}\n     */\n    this.imageLoadFunction_ =\n      options.imageLoadFunction !== undefined\n        ? options.imageLoadFunction\n        : defaultImageLoadFunction;\n\n    /**\n     * @private\n     * @type {!Object}\n     */\n    this.params_ = Object.assign({}, options.params);\n\n    /**\n     * @private\n     * @type {import(\"./wms.js\").ServerType}\n     */\n    this.serverType_ = options.serverType;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.hidpi_ = options.hidpi !== undefined ? options.hidpi : true;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.renderedRevision_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.ratio_ = options.ratio !== undefined ? options.ratio : 1.5;\n\n    /**\n     * @private\n     * @type {import(\"../proj/Projection.js\").default}\n     */\n    this.loaderProjection_ = null;\n  }\n\n  /**\n   * Return the GetFeatureInfo URL for the passed coordinate, resolution, and\n   * projection. Return `undefined` if the GetFeatureInfo URL cannot be\n   * constructed.\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @param {number} resolution Resolution.\n   * @param {import(\"../proj.js\").ProjectionLike} projection Projection.\n   * @param {!Object} params GetFeatureInfo params. `INFO_FORMAT` at least should\n   *     be provided. If `QUERY_LAYERS` is not provided then the layers specified\n   *     in the `LAYERS` parameter will be used. `VERSION` should not be\n   *     specified here.\n   * @return {string|undefined} GetFeatureInfo URL.\n   * @api\n   */\n  getFeatureInfoUrl(coordinate, resolution, projection, params) {\n    const projectionObj = getProjection(projection);\n    const sourceProjectionObj = this.getProjection();\n\n    if (sourceProjectionObj && sourceProjectionObj !== projectionObj) {\n      resolution = calculateSourceResolution(\n        sourceProjectionObj,\n        projectionObj,\n        coordinate,\n        resolution,\n      );\n      coordinate = transform(coordinate, projectionObj, sourceProjectionObj);\n    }\n\n    const options = {\n      url: this.url_,\n      params: {\n        ...this.params_,\n        ...params,\n      },\n      projection: sourceProjectionObj || projectionObj,\n    };\n    return getFeatureInfoUrl(options, coordinate, resolution);\n  }\n\n  /**\n   * Return the GetLegendGraphic URL, optionally optimized for the passed\n   * resolution and possibly including any passed specific parameters. Returns\n   * `undefined` if the GetLegendGraphic URL cannot be constructed.\n   *\n   * @param {number} [resolution] Resolution. If set to undefined, `SCALE`\n   *     will not be calculated and included in URL.\n   * @param {Object} [params] GetLegendGraphic params. If `LAYER` is set, the\n   *     request is generated for this wms layer, else it will try to use the\n   *     configured wms layer. Default `FORMAT` is `image/png`.\n   *     `VERSION` should not be specified here.\n   * @return {string|undefined} GetLegendGraphic URL.\n   * @api\n   */\n  getLegendUrl(resolution, params) {\n    return getLegendUrl(\n      {\n        url: this.url_,\n        params: {\n          ...this.params_,\n          ...params,\n        },\n      },\n      resolution,\n    );\n  }\n\n  /**\n   * Get the user-provided params, i.e. those passed to the constructor through\n   * the \"params\" option, and possibly updated using the updateParams method.\n   * @return {Object} Params.\n   * @api\n   */\n  getParams() {\n    return this.params_;\n  }\n\n  /**\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} resolution Resolution.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {import(\"../Image.js\").default} Single image.\n   * @override\n   */\n  getImageInternal(extent, resolution, pixelRatio, projection) {\n    if (this.url_ === undefined) {\n      return null;\n    }\n    if (!this.loader || this.loaderProjection_ !== projection) {\n      // Lazily create loader to pick up the view projection and to allow `params` updates\n      this.loaderProjection_ = projection;\n      this.loader = createLoader({\n        crossOrigin: this.crossOrigin_,\n        referrerPolicy: this.referrerPolicy_,\n        params: this.params_,\n        projection: projection,\n        serverType: this.serverType_,\n        hidpi: this.hidpi_,\n        url: this.url_,\n        ratio: this.ratio_,\n        load: (image, src) => {\n          this.image.setImage(image);\n          this.imageLoadFunction_(this.image, src);\n          return decode(image);\n        },\n      });\n    }\n\n    return super.getImageInternal(extent, resolution, pixelRatio, projection);\n  }\n\n  /**\n   * Return the image load function of the source.\n   * @return {import(\"../Image.js\").LoadFunction} The image load function.\n   * @api\n   */\n  getImageLoadFunction() {\n    return this.imageLoadFunction_;\n  }\n\n  /**\n   * Return the URL used for this WMS source.\n   * @return {string|undefined} URL.\n   * @api\n   */\n  getUrl() {\n    return this.url_;\n  }\n\n  /**\n   * Set the image load function of the source.\n   * @param {import(\"../Image.js\").LoadFunction} imageLoadFunction Image load function.\n   * @api\n   */\n  setImageLoadFunction(imageLoadFunction) {\n    this.imageLoadFunction_ = imageLoadFunction;\n    this.changed();\n  }\n\n  /**\n   * Set the URL to use for requests.\n   * @param {string|undefined} url URL.\n   * @api\n   */\n  setUrl(url) {\n    if (url != this.url_) {\n      this.url_ = url;\n      this.loader = null;\n      this.changed();\n    }\n  }\n\n  /**\n   * Set the user-provided params.\n   * @param {Object} params Params.\n   * @api\n   */\n  setParams(params) {\n    this.params_ = Object.assign({}, params);\n    // Reset loader to pick up new params\n    this.loader = null;\n    this.changed();\n  }\n\n  /**\n   * Update the user-provided params.\n   * @param {Object} params Params.\n   * @api\n   */\n  updateParams(params) {\n    Object.assign(this.params_, params);\n    this.changed();\n  }\n\n  /**\n   * @override\n   */\n  changed() {\n    this.image = null;\n    super.changed();\n  }\n}\n\nexport default ImageWMS;\n","/**\n * @module ol/source/TileArcGISRest\n */\n\nimport {createEmpty} from '../extent.js';\nimport {modulo} from '../math.js';\nimport {scale as scaleSize, toSize} from '../size.js';\nimport {hash as tileCoordHash} from '../tilecoord.js';\nimport TileImage from './TileImage.js';\nimport {getRequestUrl} from './arcgisRest.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {number} [cacheSize] Deprecated.  Use the cacheSize option on the layer instead.\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images.  Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for loaded images.\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * linear interpolation is used when resampling.  Set to false to use the nearest neighbor instead.\n * @property {Object<string,*>} [params] ArcGIS Rest parameters. This field is optional. Service defaults will be\n * used for any fields not specified. `FORMAT` is `PNG32` by default. `F` is `IMAGE` by\n * default. `TRANSPARENT` is `true` by default.  `BBOX`, `SIZE`, `BBOXSR`,\n * and `IMAGESR` will be set dynamically. Set `LAYERS` to\n * override the default service layer visibility. See\n * https://developers.arcgis.com/rest/services-reference/export-map.htm\n * for further reference.\n * @property {boolean} [hidpi=true] Use the `ol/Map#pixelRatio` value when requesting\n * the image from the remote server.\n * @property {import(\"../tilegrid/TileGrid.js\").default} [tileGrid] Tile grid. Base this on the resolutions,\n * tilesize and extent supported by the server.\n * If this is not defined, a default grid will be used: if there is a projection\n * extent, the grid will be based on that; if not, a grid based on a global\n * extent with origin at 0,0 will be used.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is the view projection.\n * The projection code must contain a numeric end portion separated by :\n * or the entire code must form a valid ArcGIS SpatialReference definition.\n * @property {number} [reprojectionErrorThreshold=0.5] Maximum allowed reprojection error (in pixels).\n * Higher values can increase reprojection performance, but decrease precision.\n * @property {import(\"../Tile.js\").LoadFunction} [tileLoadFunction] Optional function to load a tile given a URL.\n * The default is\n * ```js\n * function(imageTile, src) {\n *   imageTile.getImage().src = src;\n * };\n * ```\n * @property {string} [url] ArcGIS Rest service URL for a Map Service or Image Service. The\n * url should include /MapServer or /ImageServer.\n * @property {boolean} [wrapX=true] Whether to wrap the world horizontally.\n * @property {number} [transition] Duration of the opacity transition for rendering.  To disable the opacity\n * transition, pass `transition: 0`.\n * @property {Array<string>} [urls] ArcGIS Rest service urls. Use this instead of `url` when the ArcGIS\n * Service supports multiple urls for export requests.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n */\n\n/**\n * @classdesc\n * Layer source for tile data from ArcGIS Rest services. Map and Image\n * Services are supported.\n *\n * For cached ArcGIS services, better performance is available using the\n * {@link module:ol/source/XYZ~XYZ} data source.\n * @api\n */\nclass TileArcGISRest extends TileImage {\n  /**\n   * @param {Options} [options] Tile ArcGIS Rest options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super({\n      attributions: options.attributions,\n      cacheSize: options.cacheSize,\n      crossOrigin: options.crossOrigin,\n      referrerPolicy: options.referrerPolicy,\n      interpolate: options.interpolate,\n      projection: options.projection,\n      reprojectionErrorThreshold: options.reprojectionErrorThreshold,\n      tileGrid: options.tileGrid,\n      tileLoadFunction: options.tileLoadFunction,\n      url: options.url,\n      urls: options.urls,\n      wrapX: options.wrapX !== undefined ? options.wrapX : true,\n      transition: options.transition,\n      zDirection: options.zDirection,\n    });\n\n    /**\n     * @private\n     * @type {!Object}\n     */\n    this.params_ = Object.assign({}, options.params);\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.hidpi_ = options.hidpi !== undefined ? options.hidpi : true;\n\n    /**\n     * @private\n     * @type {import(\"../extent.js\").Extent}\n     */\n    this.tmpExtent_ = createEmpty();\n\n    this.setKey(this.getKeyForParams_());\n  }\n\n  /**\n   * @private\n   * @return {string} The key for the current params.\n   */\n  getKeyForParams_() {\n    let i = 0;\n    const res = [];\n    for (const key in this.params_) {\n      res[i++] = key + '-' + this.params_[key];\n    }\n    return res.join('/');\n  }\n\n  /**\n   * Get the user-provided params, i.e. those passed to the constructor through\n   * the \"params\" option, and possibly updated using the updateParams method.\n   * @return {Object} Params.\n   * @api\n   */\n  getParams() {\n    return this.params_;\n  }\n\n  /**\n   * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n   * @param {import(\"../size.js\").Size} tileSize Tile size.\n   * @param {import(\"../extent.js\").Extent} tileExtent Tile extent.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @param {Object} params Params.\n   * @return {string|undefined} Request URL.\n   * @private\n   */\n  getRequestUrl_(\n    tileCoord,\n    tileSize,\n    tileExtent,\n    pixelRatio,\n    projection,\n    params,\n  ) {\n    const urls = this.urls;\n    if (!urls) {\n      return undefined;\n    }\n    let url;\n    if (urls.length == 1) {\n      url = urls[0];\n    } else {\n      const index = modulo(tileCoordHash(tileCoord), urls.length);\n      url = urls[index];\n    }\n\n    return getRequestUrl(\n      url,\n      tileExtent,\n      (\n        this.tileGrid || this.getTileGridForProjection(projection)\n      ).getResolution(tileCoord[0]),\n      pixelRatio,\n      projection,\n      params,\n    );\n  }\n\n  /**\n   * Get the tile pixel ratio for this source.\n   * @param {number} pixelRatio Pixel ratio.\n   * @return {number} Tile pixel ratio.\n   * @override\n   */\n  getTilePixelRatio(pixelRatio) {\n    return this.hidpi_ ? pixelRatio : 1;\n  }\n\n  /**\n   * Set the user-provided params.\n   * @param {Object} params Params.\n   * @api\n   */\n  setParams(params) {\n    this.params_ = Object.assign({}, params);\n    this.setKey(this.getKeyForParams_());\n  }\n\n  /**\n   * Update the user-provided params.\n   * @param {Object} params Params.\n   * @api\n   */\n  updateParams(params) {\n    Object.assign(this.params_, params);\n    this.setKey(this.getKeyForParams_());\n  }\n\n  /**\n   * @param {import(\"../tilecoord.js\").TileCoord} tileCoord The tile coordinate\n   * @param {number} pixelRatio The pixel ratio\n   * @param {import(\"../proj/Projection.js\").default} projection The projection\n   * @return {string|undefined} The tile URL\n   * @override\n   */\n  tileUrlFunction(tileCoord, pixelRatio, projection) {\n    let tileGrid = this.getTileGrid();\n    if (!tileGrid) {\n      tileGrid = this.getTileGridForProjection(projection);\n    }\n\n    if (tileGrid.getResolutions().length <= tileCoord[0]) {\n      return undefined;\n    }\n\n    if (pixelRatio != 1 && !this.hidpi_) {\n      pixelRatio = 1;\n    }\n\n    const tileExtent = tileGrid.getTileCoordExtent(tileCoord, this.tmpExtent_);\n    let tileSize = toSize(tileGrid.getTileSize(tileCoord[0]), this.tmpSize);\n\n    if (pixelRatio != 1) {\n      tileSize = scaleSize(tileSize, pixelRatio, this.tmpSize);\n    }\n\n    // Apply default params and override with user specified values.\n    const baseParams = {\n      'F': 'image',\n      'FORMAT': 'PNG32',\n      'TRANSPARENT': true,\n    };\n    Object.assign(baseParams, this.params_);\n\n    return this.getRequestUrl_(\n      tileCoord,\n      tileSize,\n      tileExtent,\n      pixelRatio,\n      projection,\n      baseParams,\n    );\n  }\n}\n\nexport default TileArcGISRest;\n","/**\n * @module ol/source/TileDebug\n */\n\nimport {createCanvasContext2D} from '../dom.js';\nimport EventType from '../events/EventType.js';\nimport {get as getProjection} from '../proj.js';\nimport {toSize} from '../size.js';\nimport {renderXYZTemplate} from '../uri.js';\nimport DataTile from './DataTile.js';\nimport ImageTile from './ImageTile.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../proj.js\").ProjectionLike} [projection='EPSG:3857'] Optional projection.\n * @property {import(\"../tilegrid/TileGrid.js\").default} [tileGrid] Tile grid.\n * @property {boolean} [wrapX=true] Whether to wrap the world horizontally.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Set to `1` when debugging `VectorTile` sources with a default configuration.\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n * @property {import(\"./Tile.js\").default} [source] Tile source.\n * This allows `projection`, `tileGrid`, `wrapX` and `zDirection` to be copied from another source.\n * If both `source` and individual options are specified the individual options will have precedence.\n * @property {string} [template='z:{z} x:{x} y:{y}'] Template for labeling the tiles.\n * Should include `{x}`, `{y}` or `{-y}`, and `{z}` placeholders.\n * @property {string} [color='grey'] CSS color to fill text and stroke grid lines of each tile.\n */\n\n/**\n * @classdesc\n * A pseudo tile source, which does not fetch tiles from a server, but renders\n * a grid outline for the tile grid/projection along with the coordinates for\n * each tile. See examples/canvas-tiles for an example.\n * @api\n */\nclass TileDebug extends ImageTile {\n  /**\n   * @param {Options} [options] Debug tile options.\n   */\n  constructor(options) {\n    /**\n     * @type {Options}\n     */\n    options = options || {};\n    const template = options.template || 'z:{z} x:{x} y:{y}';\n    const source = options.source;\n    const color = options.color || 'grey';\n\n    super({\n      transition: 0,\n      wrapX:\n        options.wrapX !== undefined\n          ? options.wrapX\n          : source !== undefined\n            ? source.getWrapX()\n            : undefined,\n    });\n\n    const setReady = () => {\n      this.projection =\n        options.projection !== undefined\n          ? getProjection(options.projection)\n          : source !== undefined\n            ? source.getProjection()\n            : this.projection;\n      this.tileGrid =\n        options.tileGrid !== undefined\n          ? options.tileGrid\n          : source !== undefined\n            ? source.getTileGrid()\n            : this.tileGrid;\n      this.zDirection =\n        options.zDirection !== undefined\n          ? options.zDirection\n          : source !== undefined\n            ? source.zDirection\n            : this.zDirection;\n\n      if (source instanceof DataTile) {\n        this.transformMatrix = source.transformMatrix?.slice() || null;\n      }\n\n      const tileGrid = this.tileGrid;\n      if (tileGrid) {\n        this.setTileSizes(\n          tileGrid\n            .getResolutions()\n            .map((r, i) =>\n              toSize(tileGrid.getTileSize(i)).map((s) =>\n                Math.max(Math.floor(s), 1),\n              ),\n            ),\n        );\n      }\n\n      this.setLoader((z, x, y, loaderOptions) => {\n        const text = renderXYZTemplate(template, z, x, y, loaderOptions.maxY);\n        const [width, height] = this.getTileSize(z);\n        const context = createCanvasContext2D(width, height);\n\n        context.strokeStyle = color;\n        context.strokeRect(0.5, 0.5, width + 0.5, height + 0.5);\n\n        context.fillStyle = color;\n        context.strokeStyle = 'white';\n        context.textAlign = 'center';\n        context.textBaseline = 'middle';\n        context.font = '24px sans-serif';\n        context.lineWidth = 4;\n        context.strokeText(text, width / 2, height / 2, width);\n        context.fillText(text, width / 2, height / 2, width);\n        // make the loader aysnc, so it behaves like other sources that fetch data from a remote server\n        return Promise.resolve(context.canvas);\n      });\n      this.setState('ready');\n    };\n\n    if (source === undefined || source.getState() === 'ready') {\n      setReady();\n    } else {\n      const handler = () => {\n        if (source.getState() === 'ready') {\n          source.removeEventListener(EventType.CHANGE, handler);\n          setReady();\n        }\n      };\n      source.addEventListener(EventType.CHANGE, handler);\n    }\n  }\n}\n\nexport default TileDebug;\n","/**\n * @module ol/source/TileJSON\n */\n// FIXME check order of async callbacks\n\n/**\n * See https://mapbox.com/developers/api/.\n */\n\nimport {applyTransform, intersects} from '../extent.js';\nimport {jsonp as requestJSONP} from '../net.js';\nimport {get as getProjection, getTransformFromProjections} from '../proj.js';\nimport {createXYZ, extentFromProjection} from '../tilegrid.js';\nimport {createFromTemplates} from '../tileurlfunction.js';\nimport TileImage from './TileImage.js';\n\n/**\n * @typedef {Object} Config\n * @property {string} [name] The name.\n * @property {string} [description] The description.\n * @property {string} [version] The version.\n * @property {string} [attribution] The attribution.\n * @property {string} [template] The template.\n * @property {string} [legend] The legend.\n * @property {string} [scheme] The scheme.\n * @property {Array<string>} tiles The tile URL templates.\n * @property {Array<string>} [grids] Optional grids.\n * @property {number} [minzoom] Minimum zoom level.\n * @property {number} [maxzoom] Maximum zoom level.\n * @property {Array<number>} [bounds] Optional bounds.\n * @property {Array<number>} [center] Optional center.\n */\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {number} [cacheSize] Deprecated.  Use the cacheSize option on the layer instead.\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images.  Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * linear interpolation is used when resampling.  Set to false to use the nearest neighbor instead.\n * @property {boolean} [jsonp=false] Use JSONP with callback to load the TileJSON.\n * Useful when the server does not support CORS..\n * @property {number} [reprojectionErrorThreshold=0.5] Maximum allowed reprojection error (in pixels).\n * Higher values can increase reprojection performance, but decrease precision.\n * @property {Config} [tileJSON] TileJSON configuration for this source.\n * If not provided, `url` must be configured.\n * @property {import(\"../Tile.js\").LoadFunction} [tileLoadFunction] Optional function to load a tile given a URL. The default is\n * ```js\n * function(imageTile, src) {\n *   imageTile.getImage().src = src;\n * };\n * ```\n * @property {number|import(\"../size.js\").Size} [tileSize=[256, 256]] The tile size used by the tile service.\n * Note: `tileSize` and other non-standard TileJSON properties are currently ignored.\n * @property {string} [url] URL to the TileJSON file. If not provided, `tileJSON` must be configured.\n * @property {boolean} [wrapX=true] Whether to wrap the world horizontally.\n * @property {number} [transition] Duration of the opacity transition for rendering.\n * To disable the opacity transition, pass `transition: 0`.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n */\n\n/**\n * @classdesc\n * Layer source for tile data in TileJSON format.\n * @api\n */\nclass TileJSON extends TileImage {\n  /**\n   * @param {Options} options TileJSON options.\n   */\n  constructor(options) {\n    super({\n      attributions: options.attributions,\n      cacheSize: options.cacheSize,\n      crossOrigin: options.crossOrigin,\n      interpolate: options.interpolate,\n      projection: getProjection('EPSG:3857'),\n      reprojectionErrorThreshold: options.reprojectionErrorThreshold,\n      state: 'loading',\n      tileLoadFunction: options.tileLoadFunction,\n      wrapX: options.wrapX !== undefined ? options.wrapX : true,\n      transition: options.transition,\n      zDirection: options.zDirection,\n    });\n\n    /**\n     * @type {Config}\n     * @private\n     */\n    this.tileJSON_ = null;\n\n    /**\n     * @type {number|import(\"../size.js\").Size}\n     * @private\n     */\n    this.tileSize_ = options.tileSize;\n\n    if (options.url) {\n      if (options.jsonp) {\n        requestJSONP(\n          options.url,\n          this.handleTileJSONResponse.bind(this),\n          this.handleTileJSONError.bind(this),\n        );\n      } else {\n        const client = new XMLHttpRequest();\n        client.addEventListener('load', this.onXHRLoad_.bind(this));\n        client.addEventListener('error', this.onXHRError_.bind(this));\n        client.open('GET', options.url);\n        client.send();\n      }\n    } else if (options.tileJSON) {\n      this.handleTileJSONResponse(options.tileJSON);\n    } else {\n      throw new Error('Either `url` or `tileJSON` options must be provided');\n    }\n  }\n\n  /**\n   * @private\n   * @param {Event} event The load event.\n   */\n  onXHRLoad_(event) {\n    const client = /** @type {XMLHttpRequest} */ (event.target);\n    // status will be 0 for file:// urls\n    if (!client.status || (client.status >= 200 && client.status < 300)) {\n      let response;\n      try {\n        response = /** @type {Config} */ (JSON.parse(client.responseText));\n      } catch {\n        this.handleTileJSONError();\n        return;\n      }\n      this.handleTileJSONResponse(response);\n    } else {\n      this.handleTileJSONError();\n    }\n  }\n\n  /**\n   * @private\n   * @param {Event} event The error event.\n   */\n  onXHRError_(event) {\n    this.handleTileJSONError();\n  }\n\n  /**\n   * @return {Config} The tilejson object.\n   * @api\n   */\n  getTileJSON() {\n    return this.tileJSON_;\n  }\n\n  /**\n   * @protected\n   * @param {Config} tileJSON Tile JSON.\n   */\n  handleTileJSONResponse(tileJSON) {\n    const epsg4326Projection = getProjection('EPSG:4326');\n\n    const sourceProjection = this.getProjection();\n    let extent;\n    if (tileJSON['bounds'] !== undefined) {\n      const transform = getTransformFromProjections(\n        epsg4326Projection,\n        sourceProjection,\n      );\n      extent = applyTransform(tileJSON['bounds'], transform);\n    }\n\n    const gridExtent = extentFromProjection(sourceProjection);\n    const minZoom = tileJSON['minzoom'] || 0;\n    const maxZoom = tileJSON['maxzoom'] || 22;\n    const tileGrid = createXYZ({\n      extent: gridExtent,\n      maxZoom: maxZoom,\n      minZoom: minZoom,\n      tileSize: this.tileSize_,\n    });\n    this.tileGrid = tileGrid;\n\n    this.tileUrlFunction = createFromTemplates(tileJSON['tiles'], tileGrid);\n\n    if (tileJSON['attribution'] && !this.getAttributions()) {\n      const attributionExtent = extent !== undefined ? extent : gridExtent;\n      this.setAttributions(function (frameState) {\n        if (intersects(attributionExtent, frameState.extent)) {\n          return [tileJSON['attribution']];\n        }\n        return null;\n      });\n    }\n    this.tileJSON_ = tileJSON;\n    this.setState('ready');\n  }\n\n  /**\n   * @protected\n   */\n  handleTileJSONError() {\n    this.setState('error');\n  }\n}\n\nexport default TileJSON;\n","/**\n * @module ol/source/TileWMS\n */\n\nimport {buffer, createEmpty} from '../extent.js';\nimport {modulo} from '../math.js';\nimport {get as getProjection, transform} from '../proj.js';\nimport {calculateSourceResolution} from '../reproj.js';\nimport {compareVersions} from '../string.js';\nimport {hash as tileCoordHash} from '../tilecoord.js';\nimport {appendParams} from '../uri.js';\nimport TileImage from './TileImage.js';\nimport {DEFAULT_VERSION, getImageSrc, getRequestParams} from './wms.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.\n * @property {number} [cacheSize] Deprecated.  Use the cacheSize option on the layer instead.\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images.  Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * linear interpolation is used when resampling.  Set to false to use the nearest neighbor instead.\n * @property {Object<string,*>} params WMS request parameters.\n * At least a `LAYERS` param is required. `STYLES` is\n * `''` by default. `VERSION` is `1.3.0` by default. `WIDTH`, `HEIGHT`, `BBOX`\n * and `CRS` (`SRS` for WMS version < 1.3.0) will be set dynamically.\n * @property {number} [gutter=0]\n * The size in pixels of the gutter around image tiles to ignore. By setting\n * this property to a non-zero value, images will be requested that are wider\n * and taller than the tile size by a value of `2 x gutter`.\n * Using a non-zero value allows artifacts of rendering at tile edges to be\n * ignored. If you control the WMS service it is recommended to address\n * \"artifacts at tile edges\" issues by properly configuring the WMS service. For\n * example, MapServer has a `tile_map_edge_buffer` configuration parameter for\n * this. See https://mapserver.org/output/tile_mode.html.\n * @property {boolean} [hidpi=true] Use the `ol/Map#pixelRatio` value when requesting\n * the image from the remote server.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is the view projection.\n * @property {number} [reprojectionErrorThreshold=0.5] Maximum allowed reprojection error (in pixels).\n * Higher values can increase reprojection performance, but decrease precision.\n * @property {typeof import(\"../ImageTile.js\").default} [tileClass] Class used to instantiate image tiles.\n * Default is {@link module:ol/ImageTile~ImageTile}.\n * @property {import(\"../tilegrid/TileGrid.js\").default} [tileGrid] Tile grid. Base this on the resolutions,\n * tilesize and extent supported by the server.\n * If this is not defined, a default grid will be used: if there is a projection\n * extent, the grid will be based on that; if not, a grid based on a global\n * extent with origin at 0,0 will be used.\n * @property {import(\"./wms.js\").ServerType} [serverType] The type of\n * the remote WMS server: `mapserver`, `geoserver`, `carmentaserver`, or `qgis`.\n * Only needed if `hidpi` is `true`.\n * @property {import(\"../Tile.js\").LoadFunction} [tileLoadFunction] Optional function to load a tile given a URL. The default is\n * ```js\n * function(imageTile, src) {\n *   imageTile.getImage().src = src;\n * };\n * ```\n * @property {string} [url] WMS service URL.\n * @property {Array<string>} [urls] WMS service urls.\n * Use this instead of `url` when the WMS supports multiple urls for GetMap requests.\n * @property {boolean} [wrapX=true] Whether to wrap the world horizontally.\n * When set to `false`, only one world\n * will be rendered. When `true`, tiles will be requested for one world only,\n * but they will be wrapped horizontally to render multiple worlds.\n * @property {number} [transition] Duration of the opacity transition for rendering.\n * To disable the opacity transition, pass `transition: 0`.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n */\n\n/**\n * @classdesc\n * Layer source for tile data from WMS servers.\n * @api\n */\nclass TileWMS extends TileImage {\n  /**\n   * @param {Options} [options] Tile WMS options.\n   */\n  constructor(options) {\n    options = options ? options : /** @type {Options} */ ({});\n\n    const params = Object.assign({}, options.params);\n\n    super({\n      attributions: options.attributions,\n      attributionsCollapsible: options.attributionsCollapsible,\n      cacheSize: options.cacheSize,\n      crossOrigin: options.crossOrigin,\n      interpolate: options.interpolate,\n      projection: options.projection,\n      reprojectionErrorThreshold: options.reprojectionErrorThreshold,\n      tileClass: options.tileClass,\n      tileGrid: options.tileGrid,\n      tileLoadFunction: options.tileLoadFunction,\n      url: options.url,\n      urls: options.urls,\n      wrapX: options.wrapX !== undefined ? options.wrapX : true,\n      transition: options.transition,\n      zDirection: options.zDirection,\n    });\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.gutter_ = options.gutter !== undefined ? options.gutter : 0;\n\n    /**\n     * @private\n     * @type {!Object}\n     */\n    this.params_ = params;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.v13_ = true;\n\n    /**\n     * @private\n     * @type {import(\"./wms.js\").ServerType}\n     */\n    this.serverType_ = options.serverType;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.hidpi_ = options.hidpi !== undefined ? options.hidpi : true;\n\n    /**\n     * @private\n     * @type {import(\"../extent.js\").Extent}\n     */\n    this.tmpExtent_ = createEmpty();\n\n    this.updateV13_();\n    this.setKey(this.getKeyForParams_());\n  }\n\n  /**\n   * Return the GetFeatureInfo URL for the passed coordinate, resolution, and\n   * projection. Return `undefined` if the GetFeatureInfo URL cannot be\n   * constructed.\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @param {number} resolution Resolution.\n   * @param {import(\"../proj.js\").ProjectionLike} projection Projection.\n   * @param {!Object} params GetFeatureInfo params. `INFO_FORMAT` at least should\n   *     be provided. If `QUERY_LAYERS` is not provided then the layers specified\n   *     in the `LAYERS` parameter will be used. `VERSION` should not be\n   *     specified here.\n   * @return {string|undefined} GetFeatureInfo URL.\n   * @api\n   */\n  getFeatureInfoUrl(coordinate, resolution, projection, params) {\n    const projectionObj = getProjection(projection);\n    const sourceProjectionObj = this.getProjection() || projectionObj;\n\n    let tileGrid = this.getTileGrid();\n    if (!tileGrid) {\n      tileGrid = this.getTileGridForProjection(sourceProjectionObj);\n    }\n\n    const sourceProjCoord = transform(\n      coordinate,\n      projectionObj,\n      sourceProjectionObj,\n    );\n    const sourceResolution = calculateSourceResolution(\n      sourceProjectionObj,\n      projectionObj,\n      coordinate,\n      resolution,\n    );\n\n    const z = tileGrid.getZForResolution(sourceResolution, this.zDirection);\n    const tileResolution = tileGrid.getResolution(z);\n    const tileCoord = tileGrid.getTileCoordForCoordAndZ(sourceProjCoord, z);\n\n    if (tileGrid.getResolutions().length <= tileCoord[0]) {\n      return undefined;\n    }\n\n    let tileExtent = tileGrid.getTileCoordExtent(tileCoord, this.tmpExtent_);\n\n    const gutter = this.gutter_;\n    if (gutter !== 0) {\n      tileExtent = buffer(tileExtent, tileResolution * gutter, tileExtent);\n    }\n\n    const baseParams = {\n      'QUERY_LAYERS': this.params_['LAYERS'],\n    };\n    Object.assign(\n      baseParams,\n      getRequestParams(this.params_, 'GetFeatureInfo'),\n      params,\n    );\n\n    const x = Math.floor((sourceProjCoord[0] - tileExtent[0]) / tileResolution);\n    const y = Math.floor((tileExtent[3] - sourceProjCoord[1]) / tileResolution);\n\n    baseParams[this.v13_ ? 'I' : 'X'] = x;\n    baseParams[this.v13_ ? 'J' : 'Y'] = y;\n\n    return this.getRequestUrl_(\n      tileCoord,\n      tileExtent,\n      1,\n      sourceProjectionObj || projectionObj,\n      baseParams,\n    );\n  }\n\n  /**\n   * Return the GetLegendGraphic URL, optionally optimized for the passed\n   * resolution and possibly including any passed specific parameters. Returns\n   * `undefined` if the GetLegendGraphic URL cannot be constructed.\n   *\n   * @param {number} [resolution] Resolution. If set to undefined, `SCALE`\n   *     will not be calculated and included in URL.\n   * @param {Object} [params] GetLegendGraphic params. If `LAYER` is set, the\n   *     request is generated for this wms layer, else it will try to use the\n   *     configured wms layer. Default `FORMAT` is `image/png`.\n   *     `VERSION` should not be specified here.\n   * @return {string|undefined} GetLegendGraphic URL.\n   * @api\n   */\n  getLegendUrl(resolution, params) {\n    if (this.urls[0] === undefined) {\n      return undefined;\n    }\n\n    const baseParams = {\n      'SERVICE': 'WMS',\n      'VERSION': DEFAULT_VERSION,\n      'REQUEST': 'GetLegendGraphic',\n      'FORMAT': 'image/png',\n    };\n\n    if (params === undefined || params['LAYER'] === undefined) {\n      const layers = this.params_.LAYERS;\n      const isSingleLayer = !Array.isArray(layers) || layers.length === 1;\n      if (!isSingleLayer) {\n        return undefined;\n      }\n      baseParams['LAYER'] = layers;\n    }\n\n    if (resolution !== undefined) {\n      const mpu = this.getProjection()\n        ? this.getProjection().getMetersPerUnit()\n        : 1;\n      const pixelSize = 0.00028;\n      baseParams['SCALE'] = (resolution * mpu) / pixelSize;\n    }\n\n    Object.assign(baseParams, params);\n\n    return appendParams(/** @type {string} */ (this.urls[0]), baseParams);\n  }\n\n  /**\n   * @return {number} Gutter.\n   * @override\n   */\n  getGutter() {\n    return this.gutter_;\n  }\n\n  /**\n   * Get the user-provided params, i.e. those passed to the constructor through\n   * the \"params\" option, and possibly updated using the updateParams method.\n   * @return {Object} Params.\n   * @api\n   */\n  getParams() {\n    return this.params_;\n  }\n\n  /**\n   * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n   * @param {import(\"../extent.js\").Extent} tileExtent Tile extent.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @param {Object} params Params.\n   * @return {string|undefined} Request URL.\n   * @private\n   */\n  getRequestUrl_(tileCoord, tileExtent, pixelRatio, projection, params) {\n    const urls = this.urls;\n    if (!urls) {\n      return undefined;\n    }\n    let url;\n    if (urls.length == 1) {\n      url = urls[0];\n    } else {\n      const index = modulo(tileCoordHash(tileCoord), urls.length);\n      url = urls[index];\n    }\n\n    return getImageSrc(\n      tileExtent,\n      (\n        this.tileGrid || this.getTileGridForProjection(projection)\n      ).getResolution(tileCoord[0]),\n      pixelRatio,\n      projection,\n      url,\n      params,\n      this.serverType_,\n    );\n  }\n\n  /**\n   * Get the tile pixel ratio for this source.\n   * @param {number} pixelRatio Pixel ratio.\n   * @return {number} Tile pixel ratio.\n   * @override\n   */\n  getTilePixelRatio(pixelRatio) {\n    return !this.hidpi_ || this.serverType_ === undefined ? 1 : pixelRatio;\n  }\n\n  /**\n   * @private\n   * @return {string} The key for the current params.\n   */\n  getKeyForParams_() {\n    let i = 0;\n    const res = [];\n    for (const key in this.params_) {\n      res[i++] = key + '-' + this.params_[key];\n    }\n    return res.join('/');\n  }\n\n  /**\n   * @param {Object} params New URL paremeters.\n   * @private\n   */\n  setParams_(params) {\n    this.params_ = params;\n    this.updateV13_();\n    this.setKey(this.getKeyForParams_());\n  }\n\n  /**\n   * Set the URL parameters passed to the WMS source.\n   * @param {Object} params New URL paremeters.\n   * @api\n   */\n  setParams(params) {\n    this.setParams_(Object.assign({}, params));\n  }\n\n  /**\n   * Update the URL parameters. This method can be used to update a subset of the WMS\n   * parameters. Call `setParams` to set all of the parameters.\n   * @param {Object} params Updated URL parameters.\n   * @api\n   */\n  updateParams(params) {\n    this.setParams_(Object.assign(this.params_, params));\n  }\n\n  /**\n   * @private\n   */\n  updateV13_() {\n    const version = this.params_['VERSION'] || DEFAULT_VERSION;\n    this.v13_ = compareVersions(version, '1.3') >= 0;\n  }\n\n  /**\n   * @param {import(\"../tilecoord.js\").TileCoord} tileCoord The tile coordinate\n   * @param {number} pixelRatio The pixel ratio\n   * @param {import(\"../proj/Projection.js\").default} projection The projection\n   * @return {string|undefined} The tile URL\n   * @override\n   */\n  tileUrlFunction(tileCoord, pixelRatio, projection) {\n    let tileGrid = this.getTileGrid();\n    if (!tileGrid) {\n      tileGrid = this.getTileGridForProjection(projection);\n    }\n\n    if (tileGrid.getResolutions().length <= tileCoord[0]) {\n      return undefined;\n    }\n\n    if (pixelRatio != 1 && (!this.hidpi_ || this.serverType_ === undefined)) {\n      pixelRatio = 1;\n    }\n\n    const tileResolution = tileGrid.getResolution(tileCoord[0]);\n    let tileExtent = tileGrid.getTileCoordExtent(tileCoord, this.tmpExtent_);\n\n    const gutter = this.gutter_;\n    if (gutter !== 0) {\n      tileExtent = buffer(tileExtent, tileResolution * gutter, tileExtent);\n    }\n\n    const baseParams = Object.assign(\n      {},\n      getRequestParams(this.params_, 'GetMap'),\n    );\n\n    return this.getRequestUrl_(\n      tileCoord,\n      tileExtent,\n      pixelRatio,\n      projection,\n      baseParams,\n    );\n  }\n}\n\nexport default TileWMS;\n","/**\n * @module ol/source/WMTS\n */\n\nimport {containsExtent} from '../extent.js';\nimport {equivalent, get as getProjection, transformExtent} from '../proj.js';\nimport {createFromCapabilitiesMatrixSet} from '../tilegrid/WMTS.js';\nimport {createFromTileUrlFunctions} from '../tileurlfunction.js';\nimport {appendParams, expandUrl} from '../uri.js';\nimport TileImage from './TileImage.js';\n\n/**\n * Request encoding. One of 'KVP', 'REST'.\n * @typedef {'KVP' | 'REST'} RequestEncoding\n */\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.\n * @property {number} [cacheSize] Deprecated.  Use the cacheSize option on the layer instead.\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images.  Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for loaded images.\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * linear interpolation is used when resampling.  Set to false to use the nearest neighbor instead.\n * @property {import(\"../tilegrid/WMTS.js\").default} tileGrid Tile grid.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is the view projection.\n * @property {number} [reprojectionErrorThreshold=0.5] Maximum allowed reprojection error (in pixels).\n * Higher values can increase reprojection performance, but decrease precision.\n * @property {RequestEncoding} [requestEncoding='KVP'] Request encoding.\n * @property {string} layer Layer name as advertised in the WMTS capabilities.\n * @property {string} style Style name as advertised in the WMTS capabilities.\n * @property {typeof import(\"../ImageTile.js\").default} [tileClass]  Class used to instantiate image tiles. Default is {@link module:ol/ImageTile~ImageTile}.\n * @property {number} [tilePixelRatio=1] The pixel ratio used by the tile service.\n * For example, if the tile service advertizes 256px by 256px tiles but actually sends 512px\n * by 512px images (for retina/hidpi devices) then `tilePixelRatio`\n * should be set to `2`.\n * @property {string} [format='image/jpeg'] Image format. Only used when `requestEncoding` is `'KVP'`.\n * @property {string} [version='1.0.0'] WMTS version.\n * @property {string} matrixSet Matrix set.\n * @property {!Object} [dimensions] Additional \"dimensions\" for tile requests.\n * This is an object with properties named like the advertised WMTS dimensions.\n * @property {string} [url]  A URL for the service.\n * For the RESTful request encoding, this is a URL\n * template.  For KVP encoding, it is normal URL. A `{?-?}` template pattern,\n * for example `subdomain{a-f}.domain.com`, may be used instead of defining\n * each one separately in the `urls` option.\n * @property {import(\"../Tile.js\").LoadFunction} [tileLoadFunction] Optional function to load a tile given a URL. The default is\n * ```js\n * function(imageTile, src) {\n *   imageTile.getImage().src = src;\n * };\n * ```\n * @property {Array<string>} [urls] An array of URLs.\n * Requests will be distributed among the URLs in this array.\n * @property {boolean} [wrapX=false] Whether to wrap the world horizontally.\n * @property {number} [transition] Duration of the opacity transition for rendering.\n * To disable the opacity transition, pass `transition: 0`.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=0]\n * Choose whether to use tiles with a higher or lower zoom level when between integer\n * zoom levels. See {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution}.\n */\n\n/**\n * @classdesc\n * Layer source for tile data from WMTS servers.\n * @api\n */\nclass WMTS extends TileImage {\n  /**\n   * @param {Options} options WMTS options.\n   */\n  constructor(options) {\n    // TODO: add support for TileMatrixLimits\n\n    const requestEncoding =\n      options.requestEncoding !== undefined ? options.requestEncoding : 'KVP';\n\n    // FIXME: should we create a default tileGrid?\n    // we could issue a getCapabilities xhr to retrieve missing configuration\n    const tileGrid = options.tileGrid;\n\n    let urls = options.urls;\n    if (urls === undefined && options.url !== undefined) {\n      urls = expandUrl(options.url);\n    }\n\n    super({\n      attributions: options.attributions,\n      attributionsCollapsible: options.attributionsCollapsible,\n      cacheSize: options.cacheSize,\n      crossOrigin: options.crossOrigin,\n      referrerPolicy: options.referrerPolicy,\n      interpolate: options.interpolate,\n      projection: options.projection,\n      reprojectionErrorThreshold: options.reprojectionErrorThreshold,\n      tileClass: options.tileClass,\n      tileGrid: tileGrid,\n      tileLoadFunction: options.tileLoadFunction,\n      tilePixelRatio: options.tilePixelRatio,\n      urls: urls,\n      wrapX: options.wrapX !== undefined ? options.wrapX : false,\n      transition: options.transition,\n      zDirection: options.zDirection,\n    });\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.version_ = options.version !== undefined ? options.version : '1.0.0';\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.format_ = options.format !== undefined ? options.format : 'image/jpeg';\n\n    /**\n     * @private\n     * @type {!Object}\n     */\n    this.dimensions_ =\n      options.dimensions !== undefined ? options.dimensions : {};\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.layer_ = options.layer;\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.matrixSet_ = options.matrixSet;\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.style_ = options.style;\n\n    // FIXME: should we guess this requestEncoding from options.url(s)\n    //        structure? that would mean KVP only if a template is not provided.\n\n    /**\n     * @private\n     * @type {RequestEncoding}\n     */\n    this.requestEncoding_ = requestEncoding;\n\n    this.setKey(this.getKeyForDimensions_());\n\n    if (urls && urls.length > 0) {\n      this.tileUrlFunction = createFromTileUrlFunctions(\n        urls.map(this.createFromWMTSTemplate.bind(this)),\n      );\n    }\n  }\n\n  /**\n   * Set the URLs to use for requests.\n   * URLs may contain OGC conform URL Template Variables: {TileMatrix}, {TileRow}, {TileCol}.\n   * @param {Array<string>} urls URLs.\n   * @override\n   */\n  setUrls(urls) {\n    this.urls = urls;\n    const key = urls.join('\\n');\n    this.setTileUrlFunction(\n      createFromTileUrlFunctions(\n        urls.map(this.createFromWMTSTemplate.bind(this)),\n      ),\n      key,\n    );\n  }\n\n  /**\n   * Get the dimensions, i.e. those passed to the constructor through the\n   * \"dimensions\" option, and possibly updated using the updateDimensions\n   * method.\n   * @return {!Object} Dimensions.\n   * @api\n   */\n  getDimensions() {\n    return this.dimensions_;\n  }\n\n  /**\n   * Return the image format of the WMTS source.\n   * @return {string} Format.\n   * @api\n   */\n  getFormat() {\n    return this.format_;\n  }\n\n  /**\n   * Return the layer of the WMTS source.\n   * @return {string} Layer.\n   * @api\n   */\n  getLayer() {\n    return this.layer_;\n  }\n\n  /**\n   * Return the matrix set of the WMTS source.\n   * @return {string} MatrixSet.\n   * @api\n   */\n  getMatrixSet() {\n    return this.matrixSet_;\n  }\n\n  /**\n   * Return the request encoding, either \"KVP\" or \"REST\".\n   * @return {RequestEncoding} Request encoding.\n   * @api\n   */\n  getRequestEncoding() {\n    return this.requestEncoding_;\n  }\n\n  /**\n   * Return the style of the WMTS source.\n   * @return {string} Style.\n   * @api\n   */\n  getStyle() {\n    return this.style_;\n  }\n\n  /**\n   * Return the version of the WMTS source.\n   * @return {string} Version.\n   * @api\n   */\n  getVersion() {\n    return this.version_;\n  }\n\n  /**\n   * @private\n   * @return {string} The key for the current dimensions.\n   */\n  getKeyForDimensions_() {\n    const res = this.urls ? this.urls.slice(0) : [];\n    for (const key in this.dimensions_) {\n      res.push(key + '-' + this.dimensions_[key]);\n    }\n    return res.join('/');\n  }\n\n  /**\n   * Update the dimensions.\n   * @param {Object} dimensions Dimensions.\n   * @api\n   */\n  updateDimensions(dimensions) {\n    Object.assign(this.dimensions_, dimensions);\n    this.setKey(this.getKeyForDimensions_());\n  }\n\n  /**\n   * @param {string} template Template.\n   * @return {import(\"../Tile.js\").UrlFunction} Tile URL function.\n   */\n  createFromWMTSTemplate(template) {\n    const requestEncoding = this.requestEncoding_;\n\n    // context property names are lower case to allow for a case insensitive\n    // replacement as some services use different naming conventions\n    const context = {\n      'layer': this.layer_,\n      'style': this.style_,\n      'tilematrixset': this.matrixSet_,\n    };\n\n    if (requestEncoding == 'KVP') {\n      Object.assign(context, {\n        'Service': 'WMTS',\n        'Request': 'GetTile',\n        'Version': this.version_,\n        'Format': this.format_,\n      });\n    }\n\n    // TODO: we may want to create our own appendParams function so that params\n    // order conforms to wmts spec guidance, and so that we can avoid to escape\n    // special template params\n\n    template =\n      requestEncoding == 'KVP'\n        ? appendParams(template, context)\n        : template.replace(/\\{(\\w+?)\\}/g, function (m, p) {\n            return p.toLowerCase() in context ? context[p.toLowerCase()] : m;\n          });\n\n    const tileGrid = /** @type {import(\"../tilegrid/WMTS.js\").default} */ (\n      this.tileGrid\n    );\n    const dimensions = this.dimensions_;\n\n    return (\n      /**\n       * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n       * @param {number} pixelRatio Pixel ratio.\n       * @param {import(\"../proj/Projection.js\").default} projection Projection.\n       * @return {string|undefined} Tile URL.\n       */\n      function (tileCoord, pixelRatio, projection) {\n        if (!tileCoord) {\n          return undefined;\n        }\n        const localContext = {\n          'TileMatrix': tileGrid.getMatrixId(tileCoord[0]),\n          'TileCol': tileCoord[1],\n          'TileRow': tileCoord[2],\n        };\n        Object.assign(localContext, dimensions);\n        let url = template;\n        if (requestEncoding == 'KVP') {\n          url = appendParams(url, localContext);\n        } else {\n          url = url.replace(/\\{(\\w+?)\\}/g, function (m, p) {\n            return encodeURIComponent(localContext[p]);\n          });\n        }\n        return url;\n      }\n    );\n  }\n}\n\nexport default WMTS;\n\n/**\n * Generate source options from a capabilities object.\n * @param {Object} wmtsCap An object representing the capabilities document.\n * @param {!Object} config Configuration properties for the layer.  Defaults for\n *                  the layer will apply if not provided.\n *\n * Required config properties:\n *  - layer - {string} The layer identifier.\n *\n * Optional config properties:\n *  - matrixSet - {string} The matrix set identifier, required if there is\n *       more than one matrix set in the layer capabilities.\n *  - projection - {string} The desired CRS when no matrixSet is specified.\n *       eg: \"EPSG:3857\". If the desired projection is not available,\n *       an error is thrown.\n *  - requestEncoding - {string} url encoding format for the layer. Default is\n *       the first tile url format found in the GetCapabilities response.\n *  - style - {string} The name of the style\n *  - format - {string} Image format for the layer. Default is the first\n *       format returned in the GetCapabilities response.\n *  - crossOrigin - {string|null|undefined} Cross origin. Default is `undefined`.\n * @return {Options|null} WMTS source options object or `null` if the layer was not found.\n * @api\n */\nexport function optionsFromCapabilities(wmtsCap, config) {\n  const layers = wmtsCap['Contents']['Layer'];\n  const l = layers?.find(function (elt) {\n    return elt['Identifier'] == config['layer'];\n  });\n  if (!l) {\n    return null;\n  }\n  const tileMatrixSets = wmtsCap['Contents']['TileMatrixSet'];\n  let idx;\n  if (l['TileMatrixSetLink'].length > 1) {\n    if ('projection' in config) {\n      idx = l['TileMatrixSetLink'].findIndex(function (elt) {\n        const tileMatrixSet = tileMatrixSets.find(function (el) {\n          return el['Identifier'] == elt['TileMatrixSet'];\n        });\n        const supportedCRS = tileMatrixSet['SupportedCRS'];\n        const proj1 = getProjection(supportedCRS);\n        const proj2 = getProjection(config['projection']);\n        if (proj1 && proj2) {\n          return equivalent(proj1, proj2);\n        }\n        return supportedCRS == config['projection'];\n      });\n    } else {\n      idx = l['TileMatrixSetLink'].findIndex(function (elt) {\n        return elt['TileMatrixSet'] == config['matrixSet'];\n      });\n    }\n  } else {\n    idx = 0;\n  }\n  if (idx < 0) {\n    idx = 0;\n  }\n  const matrixSet =\n    /** @type {string} */\n    (l['TileMatrixSetLink'][idx]['TileMatrixSet']);\n  const matrixLimits =\n    /** @type {Array<Object>} */\n    (l['TileMatrixSetLink'][idx]['TileMatrixSetLimits']);\n\n  let format = /** @type {string} */ (l['Format'][0]);\n  if ('format' in config) {\n    format = config['format'];\n  }\n  idx = l['Style'].findIndex(function (elt) {\n    if ('style' in config) {\n      return elt['Title'] == config['style'];\n    }\n    return elt['isDefault'];\n  });\n  if (idx < 0) {\n    idx = 0;\n  }\n  const style = /** @type {string} */ (l['Style'][idx]['Identifier']);\n\n  const dimensions = {};\n  if ('Dimension' in l) {\n    l['Dimension'].forEach(function (elt, index, array) {\n      const key = elt['Identifier'];\n      let value = elt['Default'];\n      if (value === undefined) {\n        value = elt['Value'][0];\n      }\n      dimensions[key] = value;\n    });\n  }\n\n  const matrixSets = wmtsCap['Contents']['TileMatrixSet'];\n  const matrixSetObj = matrixSets.find(function (elt) {\n    return elt['Identifier'] == matrixSet;\n  });\n\n  let projection;\n  const code = matrixSetObj['SupportedCRS'];\n  if (code) {\n    projection = getProjection(code);\n  }\n  if ('projection' in config) {\n    const projConfig = getProjection(config['projection']);\n    if (projConfig) {\n      if (!projection || equivalent(projConfig, projection)) {\n        projection = projConfig;\n      }\n    }\n  }\n\n  let wrapX = false;\n  const switchXY = projection.getAxisOrientation().startsWith('ne');\n\n  let matrix = matrixSetObj.TileMatrix[0];\n\n  // create default matrixLimit\n  let selectedMatrixLimit = {\n    MinTileCol: 0,\n    MinTileRow: 0,\n    // subtract one to end up at tile top left\n    MaxTileCol: matrix.MatrixWidth - 1,\n    MaxTileRow: matrix.MatrixHeight - 1,\n  };\n\n  //in case of matrix limits, use matrix limits to calculate extent\n  if (matrixLimits) {\n    selectedMatrixLimit = matrixLimits[matrixLimits.length - 1];\n    const m = matrixSetObj.TileMatrix.find(\n      (tileMatrixValue) =>\n        tileMatrixValue.Identifier === selectedMatrixLimit.TileMatrix ||\n        matrixSetObj.Identifier + ':' + tileMatrixValue.Identifier ===\n          selectedMatrixLimit.TileMatrix,\n    );\n    if (m) {\n      matrix = m;\n    }\n  }\n\n  const layerExtent = l['BoundingBox']?.find(\n    (bbox) =>\n      getProjection(bbox.crs) &&\n      equivalent(getProjection(bbox.crs), projection),\n  );\n\n  const resolution =\n    (matrix.ScaleDenominator * 0.00028) / projection.getMetersPerUnit(); // WMTS 1.0.0: standardized rendering pixel size\n  const origin = switchXY\n    ? [matrix.TopLeftCorner[1], matrix.TopLeftCorner[0]]\n    : matrix.TopLeftCorner;\n  const tileSpanX = matrix.TileWidth * resolution;\n  const tileSpanY = matrix.TileHeight * resolution;\n  let matrixSetExtent = layerExtent?.extent ?? matrixSetObj['BoundingBox'];\n  if (matrixSetExtent && switchXY) {\n    matrixSetExtent = [\n      matrixSetExtent[1],\n      matrixSetExtent[0],\n      matrixSetExtent[3],\n      matrixSetExtent[2],\n    ];\n  }\n  let extent = [\n    origin[0] + tileSpanX * selectedMatrixLimit.MinTileCol,\n    // add one to get proper bottom/right coordinate\n    origin[1] - tileSpanY * (1 + selectedMatrixLimit.MaxTileRow),\n    origin[0] + tileSpanX * (1 + selectedMatrixLimit.MaxTileCol),\n    origin[1] - tileSpanY * selectedMatrixLimit.MinTileRow,\n  ];\n\n  if (\n    matrixSetExtent !== undefined &&\n    !containsExtent(matrixSetExtent, extent)\n  ) {\n    const wgs84BoundingBox = l['WGS84BoundingBox'];\n    const wgs84ProjectionExtent = getProjection('EPSG:4326').getExtent();\n    extent = matrixSetExtent;\n    if (wgs84BoundingBox) {\n      wrapX =\n        wgs84BoundingBox[0] === wgs84ProjectionExtent[0] &&\n        wgs84BoundingBox[2] === wgs84ProjectionExtent[2];\n    } else {\n      const wgs84MatrixSetExtent = transformExtent(\n        matrixSetExtent,\n        matrixSetObj['SupportedCRS'],\n        'EPSG:4326',\n      );\n      // Ignore slight deviation from the correct x limits\n      wrapX =\n        wgs84MatrixSetExtent[0] - 1e-10 <= wgs84ProjectionExtent[0] &&\n        wgs84MatrixSetExtent[2] + 1e-10 >= wgs84ProjectionExtent[2];\n    }\n  }\n\n  const tileGrid = createFromCapabilitiesMatrixSet(\n    matrixSetObj,\n    extent,\n    matrixLimits,\n  );\n\n  /** @type {!Array<string>} */\n  const urls = [];\n  let requestEncoding = config['requestEncoding'];\n  requestEncoding = requestEncoding !== undefined ? requestEncoding : '';\n\n  if (\n    'OperationsMetadata' in wmtsCap &&\n    'GetTile' in wmtsCap['OperationsMetadata']\n  ) {\n    const gets = wmtsCap['OperationsMetadata']['GetTile']['DCP']['HTTP']['Get'];\n\n    for (let i = 0, ii = gets.length; i < ii; ++i) {\n      if (gets[i]['Constraint']) {\n        const constraint = gets[i]['Constraint'].find(function (element) {\n          return element['name'] == 'GetEncoding';\n        });\n        const encodings = constraint['AllowedValues']['Value'];\n\n        if (requestEncoding === '') {\n          // requestEncoding not provided, use the first encoding from the list\n          requestEncoding = encodings[0];\n        }\n        if (requestEncoding === 'KVP') {\n          if (encodings.includes('KVP')) {\n            urls.push(/** @type {string} */ (gets[i]['href']));\n          }\n        } else {\n          break;\n        }\n      } else if (gets[i]['href']) {\n        requestEncoding = 'KVP';\n        urls.push(/** @type {string} */ (gets[i]['href']));\n      }\n    }\n  }\n  if (urls.length === 0) {\n    requestEncoding = 'REST';\n    l['ResourceURL'].forEach(function (element) {\n      if (element['resourceType'] === 'tile') {\n        format = element['format'];\n        urls.push(/** @type {string} */ (element['template']));\n      }\n    });\n  }\n\n  return {\n    urls: urls,\n    layer: config['layer'],\n    matrixSet: matrixSet,\n    format: format,\n    projection: projection,\n    requestEncoding: requestEncoding,\n    tileGrid: tileGrid,\n    style: style,\n    dimensions: dimensions,\n    wrapX: wrapX,\n    crossOrigin: config['crossOrigin'],\n  };\n}\n","/**\n * @module ol/source/mapserver\n */\n\nimport {decode} from '../Image.js';\nimport {getHeight, getWidth} from '../extent.js';\nimport {appendParams} from '../uri.js';\nimport {getRequestExtent} from './Image.js';\n\n/**\n * @typedef {Object} LoaderOptions\n * @property {string} url The MapServer url.\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images.  Note that\n * you must provide a `crossOrigin` value if you want to access pixel data with the Canvas renderer.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image for more detail.\n * @property {ReferrerPolicy} [referrerPolicy] The `referrerPolicy` property for loaded images.\n * the image from the remote server.\n * @property {number} [ratio=1] Ratio. `1` means image requests are the size of the map viewport, `2` means\n * twice the width and height of the map viewport, and so on. Must be `1` or higher.\n * @property {Object} [params] Additional query parameters.\n * @property {function(HTMLImageElement, string): Promise<import('../DataTile.js').ImageLike>} [load] Function\n * to perform loading of the image. Receives the created `HTMLImageElement` and the desired `src` as argument and\n * returns a promise resolving to the loaded or decoded image. Default is {@link module:ol/Image.decode}.\n */\n\n/**\n * @param {string} baseUrl The MapServer url.\n * @param {Object<string, string|number>} params Request parameters.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @param {import(\"../size.js\").Size} size Size.\n * @return {string} The MapServer map image request URL.\n */\nfunction getUrl(baseUrl, params, extent, size) {\n  const width = Math.round(size[0]);\n  const height = Math.round(size[1]);\n  const mapSize = `${width} ${height}`;\n  const mapExt = `${extent[0]} ${extent[1]} ${extent[2]} ${extent[3]}`;\n\n  const baseParams = {\n    mode: 'map',\n    map_imagetype: 'png',\n    mapext: mapExt,\n    imgext: mapExt,\n    map_size: mapSize,\n    imgx: width / 2,\n    imgy: height / 2,\n    imgxy: mapSize,\n  };\n  Object.assign(baseParams, params);\n  return appendParams(baseUrl, baseParams);\n}\n\n/**\n * Creates a loader for MapServer images generated using the CGI interface,\n * which predates OGC services. It is **strongly** recommended to configure\n * MapServer to use WMS, and use the WMS createLoader.\n * @param {LoaderOptions} options LoaderOptions Options.\n * @return {import('../Image.js').ImageObjectPromiseLoader} MapServer image.\n * @api\n */\nexport function createLoader(options) {\n  const load = options.load || decode;\n  const ratio = options.ratio ?? 1;\n  const crossOrigin = options.crossOrigin ?? null;\n\n  /** @type {import('../Image.js').ImageObjectPromiseLoader} */\n  return function (extent, resolution, pixelRatio) {\n    const image = new Image();\n    image.crossOrigin = crossOrigin;\n    if (options.referrerPolicy !== undefined) {\n      image.referrerPolicy = options.referrerPolicy;\n    }\n    extent = getRequestExtent(extent, resolution, pixelRatio, ratio);\n    const width = getWidth(extent) / resolution;\n    const height = getHeight(extent) / resolution;\n    const size = [width * pixelRatio, height * pixelRatio];\n    const src = getUrl(options.url, options.params, extent, size);\n    return load(image, src).then((image) => ({image, extent, pixelRatio}));\n  };\n}\n","/**\n * @module ol/source\n */\n\nimport {getIntersection} from './extent.js';\nimport LRUCache from './structs/LRUCache.js';\n\nexport {createLoader as createArcGISRestLoader} from './source/arcgisRest.js';\nexport {default as BingMaps} from './source/BingMaps.js';\nexport {default as CartoDB} from './source/CartoDB.js';\nexport {default as Cluster} from './source/Cluster.js';\nexport {default as DataTile} from './source/DataTile.js';\nexport {default as GeoTIFF} from './source/GeoTIFF.js';\nexport {default as Google} from './source/Google.js';\nexport {default as IIIF} from './source/IIIF.js';\nexport {default as Image} from './source/Image.js';\nexport {default as ImageArcGISRest} from './source/ImageArcGISRest.js';\nexport {default as ImageCanvas} from './source/ImageCanvas.js';\nexport {default as ImageMapGuide} from './source/ImageMapGuide.js';\nexport {default as ImageStatic} from './source/ImageStatic.js';\nexport {default as ImageTile} from './source/ImageTile.js';\nexport {default as ImageWMS} from './source/ImageWMS.js';\nexport {createLoader as createMapGuideLoader} from './source/mapguide.js';\nexport {default as OGCMapTile} from './source/OGCMapTile.js';\nexport {default as OGCVectorTile} from './source/OGCVectorTile.js';\nexport {default as OSM} from './source/OSM.js';\nexport {default as Raster} from './source/Raster.js';\nexport {default as Source} from './source/Source.js';\nexport {default as StadiaMaps} from './source/StadiaMaps.js';\nexport {createLoader as createStaticLoader} from './source/static.js';\nexport {default as Tile} from './source/Tile.js';\nexport {default as TileArcGISRest} from './source/TileArcGISRest.js';\nexport {default as TileDebug} from './source/TileDebug.js';\nexport {default as TileImage} from './source/TileImage.js';\nexport {default as TileJSON} from './source/TileJSON.js';\nexport {default as TileWMS} from './source/TileWMS.js';\nexport {default as UrlTile} from './source/UrlTile.js';\nexport {default as UTFGrid} from './source/UTFGrid.js';\nexport {default as Vector} from './source/Vector.js';\nexport {default as VectorTile} from './source/VectorTile.js';\nexport {createLoader as createWMSLoader} from './source/wms.js';\nexport {default as WMTS} from './source/WMTS.js';\nexport {default as XYZ} from './source/XYZ.js';\nexport {default as Zoomify} from './source/Zoomify.js';\n\n/**\n * Creates a sources function from a tile grid. This function can be used as value for the\n * `sources` property of the {@link module:ol/layer/Layer~Layer} subclasses that support it.\n * @param {import(\"./tilegrid/TileGrid.js\").default} tileGrid Tile grid.\n * @param {function(import(\"./tilecoord.js\").TileCoord): import(\"./source/Source.js\").default} factory Source factory.\n * This function takes a {@link module:ol/tilecoord~TileCoord} as argument and is expected to return a\n * {@link module:ol/source/Source~Source}. **Note**: The returned sources should have a tile grid with\n * a limited set of resolutions, matching the resolution range of a single zoom level of the pyramid\n * `tileGrid` that `sourcesFromTileGrid` was called with.\n * @return {function(import(\"./extent.js\").Extent, number): Array<import(\"./source/Source.js\").default>} Sources function.\n * @api\n */\nexport function sourcesFromTileGrid(tileGrid, factory) {\n  const sourceCache = new LRUCache(32);\n  const tileGridExtent = tileGrid.getExtent();\n  return function (extent, resolution) {\n    sourceCache.expireCache();\n    if (tileGridExtent) {\n      extent = getIntersection(tileGridExtent, extent);\n    }\n    const z = tileGrid.getZForResolution(resolution);\n    const wantedSources = [];\n    tileGrid.forEachTileCoord(extent, z, (tileCoord) => {\n      const key = tileCoord.toString();\n      if (!sourceCache.containsKey(key)) {\n        const source = factory(tileCoord);\n        sourceCache.set(key, source);\n      }\n      wantedSources.push(sourceCache.get(key));\n    });\n    return wantedSources;\n  };\n}\n"],"names":["CollectionEventType","ObjectEventType","clear","object","property","isEmpty","listen","target","type","listener","thisArg","once","originalListener","event","removeEventListener","call","this","bind","eventsKey","addEventListener","listenOnce","unlistenByKey","key","EventType","Disposable","constructor","disposed","dispose","disposeInternal","binarySearch","haystack","needle","comparator","mid","cmp","ascending","low","high","length","found","a","b","descending","linearFindNearest","arr","direction","n","i","candidate","reverseSubArray","begin","end","tmp","extend","data","extension","Array","isArray","equals","arr1","arr2","len1","isSorted","func","strict","compare","every","currentVal","index","res","TRUE","FALSE","VOID","memoizeOne","fn","lastResult","lastArgs","lastThis","nextArgs","prototype","slice","arguments","arrayEquals","apply","toPromise","getter","value","err","Promise","reject","resolve","promiseGetter","BaseEvent","propagationStopped","defaultPrevented","preventDefault","stopPropagation","evt","Target","super","eventTarget_","pendingRemovals_","dispatching_","listeners_","listeners","listenersForType","includes","push","dispatchEvent","isString","Event","dispatching","pendingRemovals","propagate","ii","handleEvent","pr","getListeners","undefined","hasListener","Object","keys","indexOf","splice","Observable","EventTarget","on","un","revision_","changed","getRevision","onInternal","len","onceInternal","ol_key","unInternal","unByKey","abstract","Error","uidCounter_","getUid","obj","ol_uid","String","ObjectEvent","oldValue","BaseObject","values","values_","setProperties","get","hasOwnProperty","getKeys","getProperties","assign","getPropertiesInternal","hasProperties","notify","eventType","addChangeListener","removeChangeListener","set","silent","applyProperties","source","unset","Property","CollectionEvent","element","Collection","array","options","unique_","unique","array_","assertUnique_","updateLength_","getLength","pop","forEach","f","getArray","item","insertAt","elem","removeAt","remove","prev","setAt","except","TileState","easeIn","t","Math","pow","easeOut","inAndOut","linear","Tile","tileCoord","state","transition_","transition","transitionStarts_","interpolate","release","setState","getKey","getTileCoord","getState","load","getAlpha","id","time","start","delta","inTransition","endTransition","ua","navigator","userAgent","toLowerCase","SAFARI","SAFARI_BUG_237906","test","WEBKIT","MAC","DEVICE_PIXEL_RATIO","devicePixelRatio","WORKER_OFFSCREEN_CANVAS","WorkerGlobalScope","OffscreenCanvas","self","IMAGE_DECODE","Image","decode","CREATE_IMAGE_BITMAP","createImageBitmap","PASSIVE_EVENT_LISTENERS","passive","defineProperty","window","createCanvasContext2D","width","height","canvasPool","settings","canvas","shift","style","document","createElement","getContext","sharedCanvasContext","getSharedCanvasContext2D","releaseCanvas","context","clearRect","outerWidth","offsetWidth","getComputedStyle","parseInt","marginLeft","marginRight","outerHeight","offsetHeight","marginTop","marginBottom","replaceNode","newNode","oldNode","parent","parentNode","replaceChild","removeChildren","node","lastChild","replaceChildren","children","oldChildren","childNodes","oldChild","newChild","insertBefore","removeChild","appendChild","createMockDiv","Proxy","referenceNode","prop","receiver","Reflect","isCanvas","HTMLCanvasElement","asImageLike","HTMLVideoElement","ImageBitmap","asArrayLike","Uint8Array","Uint8ClampedArray","Float32Array","DataView","disposedError","sharedContext","toArray","image","willReadFrequently","drawImage","getImageData","defaultSize","DataTile","loader_","loader","data_","error_","size_","size","controller_","controller","getSize","imageData","getData","getError","then","catch","error","abort","assert","assertion","errorMessage","Feature","geometryOrProperties","id_","geometryName_","style_","styleFunction_","geometryChangeKey_","handleGeometryChanged_","geometry","setGeometry","properties","clone","geometryName","setGeometryName","getGeometry","getStyle","setStyle","getId","getGeometryName","getStyleFunction","handleGeometryChange_","createStyleFunction","setId","name","styles","Relationship","boundingExtent","coordinates","extent","createEmpty","extendCoordinate","buffer","dest","closestSquaredDistanceXY","x","y","dx","dy","containsCoordinate","coordinate","containsXY","containsExtent","extent1","extent2","coordinateRelationship","minX","minY","maxX","maxY","relationship","Infinity","createOrUpdate","createOrUpdateEmpty","createOrUpdateFromCoordinate","createOrUpdateFromFlatCoordinates","flatCoordinates","offset","stride","extendFlatCoordinates","approximatelyEquals","tolerance","abs","extendCoordinates","extendXY","extendRings","rings","min","max","forEachCorner","callback","val","getBottomLeft","getBottomRight","getTopRight","getTopLeft","getArea","area","getWidth","getHeight","getCenter","getCorner","corner","getForViewAndSize","center","resolution","rotation","x0","y0","x1","y1","x2","y2","x3","y3","getRotatedViewport","cosRotation","cos","sinRotation","sin","xCos","xSin","yCos","ySin","getIntersection","intersection","intersects","returnOrUpdate","scaleFromCenter","deltaX","deltaY","intersectsSegment","startRel","endRel","startX","startY","endX","endY","slope","applyTransform","transformFn","stops","xs","ys","l","_boundingExtentXYs","wrapX","projection","projectionExtent","getExtent","canWrapX","worldWidth","floor","wrapAndSliceX","multiWorld","isFinite","clamp","squaredSegmentDistance","squaredDistance","solveLinearSystem","mat","maxRow","maxEl","r","absValue","j","coef","k","m","toDegrees","angleInRadians","PI","toRadians","angleInDegrees","modulo","lerp","toFixed","decimals","factor","round","ceil","wrap","range","DEFAULT_RADIUS","getDistance","c1","c2","radius","lat1","lat2","deltaLatBy2","deltaLonBy2","atan2","sqrt","getLengthInternal","getAreaInternal","distance","bearing","lon1","dByR","lat","asin","levels","info","warn","none","level","args","console","padNumber","number","precision","numberString","decimal","join","compareVersions","v1","v2","s1","split","s2","n1","n2","add","closestOnCircle","circle","getRadius","d","closestOnSegment","segment","along","degreesToStringHDMS","hemispheres","degrees","fractionDigits","normalizedDegrees","deg","sec","hdms","charAt","format","template","replace","coordinate1","coordinate2","rotate","angle","cosAngle","sinAngle","scale","coord1","coord2","squaredDistanceToSegment","toStringXY","worldsAway","getWorldsAway","sourceExtentWidth","angleBetween","p0","pA","pB","lenA","tangentA","orthoA","lenB","tangentB","acos","unitByCode","METERS_PER_UNIT","radians","ft","Projection","code_","code","units_","extent_","worldExtent_","worldExtent","axisOrientation_","axisOrientation","global_","global","canWrapX_","getPointResolutionFunc_","getPointResolution","defaultTileGrid_","metersPerUnit_","metersPerUnit","getCode","getUnits","getMetersPerUnit","getWorldExtent","getAxisOrientation","isGlobal","setGlobal","getDefaultTileGrid","setDefaultTileGrid","tileGrid","setExtent","setWorldExtent","setGetPointResolution","getPointResolutionFunc","RADIUS","HALF_SIZE","EXTENT","WORLD_EXTENT","MAX_SAFE_Y","log","tan","EPSG3857Projection","units","point","cosh","PROJECTIONS","fromEPSG4326","input","output","dimension","toEPSG4326","atan","exp","EPSG4326Projection","cache","transforms","destination","sourceCode","destinationCode","K0","E","E2","E3","E_P2","SQRT_E","_E","_E2","_E3","_E4","_E5","M1","M3","M4","P2","P3","P4","P5","R","toLonLat","easting","northing","zone","mu","north","pRad","pSin","pSin2","pCos","pTan","pTan2","pTan4","epSin","epSinSqrt","c","d2","d3","d4","d5","latitude","longitude","zoneToCentralLongitude","fromLonLat","latRad","latSin","latCos","latTan","latTan2","latTan4","lonRad","centralLonRad","a2","a3","a4","a5","a6","epsgRegExes","zoneFromCode","epsgId","re","match","makeTransformFunction","transformer","coord","makeProjection","makeTransforms","forward","inverse","transformFactories","makeUTMTransforms","projectionFactories","makeUTMProjection","showCoordinateWarning","disableCoordinateWarning","disable","cloneTransform","identityTransform","addProjection","addProj","addTransformFunc","addProjections","projections","projectionLike","getProj","pointResolution","projUnits","getTransformFromProjections","vertices","addEquivalentProjections","addEquivalentTransforms","projections1","projections2","forwardTransform","inverseTransform","projection1","projection2","createProjection","defaultCode","createTransformFromCoordinateTransform","coordTransform","pointLength","jj","addCoordinateTransforms","sourceProj","destProj","lonLat","transform","lon","equivalent","equalUnits","transformFunc","getTransformFunc","sourceTransforms","destinationTransforms","intermediateCode","composeTransformFuncs","fromSource","toDestination","t1","t2","dimensions","getTransform","transformExtent","userProjection","setUserProjection","getUserProjection","toUserCoordinate","sourceProjection","fromUserCoordinate","destProjection","toUserExtent","fromUserExtent","toUserResolution","sourceMetersPerUnit","userMetersPerUnit","fromUserResolution","destMetersPerUnit","createSafeCoordinateTransform","transformed","sourceExtent","addCommon","EPSG3857_PROJECTIONS","EPSG4326_PROJECTIONS","tmp_","create","multiply","transform1","transform2","a1","b1","d1","e1","f1","b2","e2","f2","e","setFromArray","translate","compose","dx1","dy1","sx","sy","dx2","dy2","makeInverse","det","determinant","matrixPrecision","toString","fromString","cssTransform","substring","map","parseFloat","cssTransform1","cssTransform2","mat1","mat2","transform2D","destinationStride","anchor","anchorX","anchorY","tmpTransform","tmpPoint","NaN","Geometry","extentRevision_","simplifiedGeometryMaxMinSquaredTolerance","simplifiedGeometryRevision","simplifyTransformedInternal","revision","squaredTolerance","getSimplifiedGeometry","simplifyTransformed","closestPointXY","closestPoint","minSquaredDistance","Number","MIN_VALUE","getClosestPoint","intersectsCoordinate","computeExtent","isNaN","simplify","getType","intersectsExtent","getProjection","inCoordinates","outCoordinates","pixelExtent","projectedExtent","composeTransform","projTransform","SimpleGeometry","layout","getCoordinates","getFirstCoordinate","getFlatCoordinates","getLastCoordinate","getLayout","simplifiedGeometry","getSimplifiedGeometryInternal","getStride","setFlatCoordinates","getStrideForLayout","setCoordinates","setLayout","nesting","getLayoutForStride","startsWith","transformGeom2D","simpleGeometry","linearRing","twiceArea","linearRings","ends","linearRingss","endss","assignClosest","offset1","offset2","maxSquaredDelta","squaredDelta","squaredDx","arrayMaxSquaredDelta","multiArrayMaxSquaredDelta","assignClosestPoint","maxDelta","isRing","assignClosestArrayPoint","assignClosestMultiArrayPoint","deflateCoordinate","deflateCoordinates","deflateCoordinatesArray","coordinatess","deflateMultiCoordinatesArray","coordinatesss","inflateCoordinates","inflateCoordinatesArray","inflateMultiCoordinatesArray","douglasPeucker","simplifiedFlatCoordinates","simplifiedOffset","markers","stack","last","first","maxSquaredDistance","douglasPeuckerArray","simplifiedEnds","radialDistance","snap","quantize","quantizeArray","quantizeMultiArray","simplifiedEndss","LinearRing","maxDelta_","maxDeltaRevision_","linearRingArea","Point","linearRingContainsExtent","linearRingContainsXY","wn","linearRingsContainsXY","linearRingssContainsXY","getInteriorPointOfArray","flatCenters","flatCentersOffset","intersections","rr","pointX","maxSegmentLength","sort","segmentLength","getInteriorPointsOfMultiArray","interiorPoints","ret","getIntersectionPoint","segment1","segment2","u","intersectsLineString","coordinatesExtent","forEachSegment","point1","point2","intersectsLineStringArray","intersectsLinearRing","intersectsLinearRingArray","intersectsLinearRingMultiArray","linearRingIsClockwise","edge","linearRingsAreOriented","right","isClockwise","linearRingssAreOriented","orientLinearRings","reverseCoordinates","orientLinearRingsArray","inflateEnds","startOrientation","prevEndIndex","orientation","Polygon","ends_","flatInteriorPointRevision_","flatInteriorPoint_","orientedRevision_","orientedFlatCoordinates_","appendLinearRing","polygon","getOrientedFlatCoordinates","linearRingsArea","getEnds","getFlatInteriorPoint","flatCenter","getInteriorPoint","getLinearRingCount","getLinearRing","getLinearRings","circular","sphereRadius","sphereOffset","fromExtent","fromCircle","sides","arrayLength","makeRegular","startAngle","GeolocationErrorType","GeolocationError","message","ImageState","ImageWrapper","pixelRatio","stateOrLoader","pixelRatio_","image_","getImage","getPixelRatio","getResolution","requestResolution","HTMLImageElement","finally","setImage","setResolution","listenImage","loadHandler","errorHandler","img","listening","decoding","loaded","listenerKeys","src","handleLoad","unlisten","handleError","decodeFallback","complete","ImageCanvas","canvas_","handleLoad_","ImageTile","imageAttributes","tileLoadFunction","crossOrigin_","crossOrigin","referrerPolicy_","referrerPolicy","src_","unlisten_","tileLoadFunction_","unlistenImage_","getCrossOrigin","getReferrerPolicy","handleImageError_","ctx","fillStyle","fillRect","getBlankImage","handleImageLoad_","naturalWidth","naturalHeight","Kinetic","decay","minVelocity","delay","decay_","minVelocity_","delay_","points_","angle_","initialVelocity_","update","Date","now","lastIndex","firstIndex","duration","getAngle","MapEvent","frameState","MapBrowserEvent","originalEvent","dragging","activePointers","pixel_","coordinate_","pixel","getEventPixel","getCoordinateFromPixel","MapBrowserEventType","SINGLECLICK","CLICK","DBLCLICK","POINTERDRAG","POINTERMOVE","POINTERDOWN","POINTERUP","POINTEROVER","POINTEROUT","POINTERENTER","POINTERLEAVE","POINTERCANCEL","PointerEventType","MapBrowserEventHandler","moveTolerance","map_","clickTimeoutId_","emulateClicks_","dragging_","dragListenerKeys_","moveTolerance_","down_","getViewport","activePointers_","trackedTouches_","element_","pointerdownListenerKey_","handlePointerDown_","originalPointerMoveEvent_","relayedListenerKey_","relayMoveEvent_","boundHandleTouchMove_","handleTouchMove_","emulateClick_","pointerEvent","newEvent","clearTimeout","setTimeout","updateActivePointers_","pointerId","handlePointerUp_","isMouseActionButton_","button","PointerEvent","writable","doc","getOwnerDocument","handlePointerMove_","getRootNode","isMoving_","cancelable","clientX","clientY","MapEventType","MapProperty","DROP","PriorityQueue","priorityFunction","keyFunction","priorityFunction_","keyFunction_","elements_","priorities_","queuedElements_","dequeue","elements","priorities","siftUp_","elementKey","enqueue","priority","siftDown_","getCount","getLeftChildIndex_","getRightChildIndex_","getParentIndex_","heapify_","isKeyQueued","isQueued","count","startIndex","lIndex","rIndex","smallerChildIndex","parentIndex","reprioritize","TileQueue","tilePriorityFunction","tileChangeCallback","boundHandleTileChange_","handleTileChange","tileChangeCallback_","tilesLoading_","tilesLoadingKeys_","added","getTilesLoading","tile","tileKey","loadMoreTiles","maxTotalLoading","maxNewLoads","newLoads","getTilePriority","tileSourceKey","tileCenter","tileResolution","wantedTiles","viewState","ViewHint","ViewProperty","CENTER","RESOLUTION","ROTATION","createExtent","onlyCenter","smooth","isMoving","centerShift","viewWidth","viewHeight","shiftX","shiftY","ratio","getViewportClampedResolution","maxExtent","viewportSize","showFullExtent","xResolution","yResolution","getSmoothClampedResolution","maxResolution","minResolution","result","createSnapToResolutions","resolutions","cappedMaxRes","capped","z","createSnapToPower","power","minZoomLevel","cappedZoomLevel","zoomLevel","createMinMaxResolution","createSnapToN","theta","createSnapToZero","DEFAULT_TILE_SIZE","View","hints_","animations_","updateAnimationKey_","projection_","viewportSize_","targetCenter_","targetResolution_","targetRotation_","nextCenter_","nextResolution_","nextRotation_","cancelAnchor_","applyOptions_","resolutionConstraintInfo","createResolutionConstraint","maxResolution_","minResolution_","zoomFactor_","zoomFactor","resolutions_","padding_","padding","minZoom_","minZoom","centerConstraint","createCenterConstraint","resolutionConstraint","constraint","rotationConstraint","createRotationConstraint","constraints_","setRotation","setCenterInternal","zoom","setZoom","oldPadding","getCenterInternal","newPadding","offsetX","offsetY","getUpdatedOptions_","newOptions","getZoom","getRotation","animate","var_args","isDef","getAnimating","resolveConstraints","animateInternal","animationCount","animationCallback","series","animation","easing","sourceCenter","targetCenter","sourceResolution","targetResolution","getResolutionForZoom","sourceRotation","targetRotation","isNoopAnimation","setHint","updateAnimations_","getInteracting","cancelAnimations","cancelAnimationFrame","more","seriesComplete","elapsed","fraction","progress","getViewportSize_","constrainedResolution","calculateCenterZoom","applyTargetState_","constrainedRotation","calculateCenterRotate","filter","Boolean","requestAnimationFrame","currentCenter","rotateCoordinate","addCoordinate","currentResolution","w","h","setViewportSize","getConstraints","getConstrainResolution","getHints","hints","calculateExtent","calculateExtentInternal","getViewportSizeMinusPadding_","getMaxResolution","getMinResolution","getMaxZoom","getZoomForResolution","setMaxZoom","maxZoom","getMinZoom","setMinZoom","setConstrainResolution","enabled","constrainResolution","getResolutions","getResolutionForExtent","getResolutionForExtentInternal","getResolutionForValueFunction","getConstrainedResolution","getValueForResolutionFunction","logPower","reducedSize","calculateCenterOn","nextCenter","nextResolution","nextRotation","getViewStateAndExtent","nearest","baseLevel","fit","geometryOrExtent","polygonFromExtent","fitInternal","rotatedExtentForGeometry","coords","minRotX","minRotY","maxRotX","maxRotY","rotX","rotY","rotatedExtent","centerRot","centerX","centerY","getConstrainedCenter","centerOn","position","centerOnInternal","calculateCenterShift","shiftedCenter","adjustCenter","deltaCoordinates","setCenter","adjustCenterInternal","adjustResolution","adjustResolutionInternal","newResolution","adjustZoom","adjustRotation","adjustRotationInternal","newRotation","hint","doNotCancelAnims","forceMoving","newCenter","resolutionDirection","beginInteraction","endInteraction","endInteractionInternal","getConstrainedZoom","targetZoom","targetRes","returnValue","smoothExtentConstraint","constrainOnlyCenter","centerNone","smoothResolutionConstraint","projExtent","defaultMaxResolution","defaultMinResolution","defaultMaxZoom","enableRotation","constrainRotation","rotationNone","coordinatesEqual","CLASS_HIDDEN","CLASS_SELECTABLE","CLASS_UNSELECTABLE","CLASS_UNSUPPORTED","CLASS_CONTROL","CLASS_COLLAPSED","fontRegEx","RegExp","fontRegExMatchIndex","fontWeights","normal","bold","getFontParameters","fontSpec","lineHeight","weight","variant","trim","families","family","Control","pointerEvents","target_","render","setTarget","getMap","setMap","getOverlayContainerStopEvent","mapEvent","getElementById","Attribution","ulElement_","collapsed_","collapsed","userCollapsed_","overrideCollapsible_","collapsible","collapsible_","attributions_","attributions","className","tipLabel","expandClassName","collapseLabel","collapseClassName","collapseLabel_","textContent","label","label_","activeLabel","toggleButton_","setAttribute","title","handleClick_","cssClasses","renderedAttributions_","renderedVisible_","collectSourceAttributions_","layers","getAllLayers","visibleAttributions","Set","flatMap","layer","getAttributions","some","getSource","getAttributionsCollapsible","setCollapsible","from","updateElement_","display","all","attribution","visible","innerHTML","handleToggle_","classList","toggle","getCollapsible","setCollapsed","getCollapsed","Rotate","compassClassName","callResetNorth_","resetNorth","duration_","autoHide_","autoHide","rotation_","resetNorth_","view","getView","contains","Zoom","zoomInClassName","zoomOutClassName","zoomInLabel","zoomOutLabel","zoomInTipLabel","zoomOutTipLabel","inElement","createTextNode","outElement","zoomByDelta_","currentZoom","newZoom","defaults","controls","zoomOptions","rotateOptions","attributionOptions","InteractionProperty","Interaction","setActive","getActive","mapBrowserEvent","active","pan","zoomByDelta","DoubleClickZoom","delta_","stopEvent","browserEvent","shiftKey","conditions","pass","altKeyOnly","altKey","metaKey","ctrlKey","altShiftKeysOnly","focus","targetElement","getTargetElement","rootNode","activeElement","ShadowRoot","host","focusWithTabindex","hasAttribute","always","mouseActionButton","never","singleClick","noModifierKeys","platformModifierKey","shiftKeyOnly","targetNotEditable","tagName","isContentEditable","mouseOnly","pointerType","primaryAction","isPrimary","PointerInteraction","handleDownEvent","handleDragEvent","handleMoveEvent","handleUpEvent","stopDown","handlingDownUpSequence","targetPointers","getPointerCount","updateTrackedPointers_","handledUp","handled","centroid","DragPan","kinetic_","kinetic","lastCentroid","lastPointersCount_","panning_","condition","condition_","onFocusOnly","noKinetic_","centroidFromPointers","scaleCoordinate","centerpx","getPixelFromCoordinateInternal","getCoordinateFromPixelInternal","DragRotate","lastAngle_","RenderBox","geometry_","startPixel_","endPixel_","render_","startPixel","endPixel","px","left","top","getOverlayContainer","setPixels","createOrUpdateGeometry","DragBoxEventType","DragBoxEvent","DragBox","box_","minArea_","minArea","onBoxEnd","boxEndCondition_","boxEndCondition","defaultBoxEndCondition","completeBox","DragZoom","out_","out","Key","KeyboardPan","defaultCondition_","pixelDelta_","pixelDelta","keyEvent","mapUnitsDelta","KeyboardZoom","MouseWheelZoom","totalDelta_","lastDelta_","timeout_","timeout","useAnchor_","useAnchor","constrainResolution_","lastAnchor_","startTime_","timeoutId_","mode_","trackpadEventGap_","trackpadTimeoutId_","deltaPerZoom_","ctrlKeyPressed_","ctrlKeyListenerKeys_","endInteraction_","wheelEvent","isPinchToZoom","deltaMode","WheelEvent","DOM_DELTA_LINE","DOM_DELTA_PAGE","timeLeft","handleWheelZoom_","setMouseAnchor","PinchRotate","pointerOptions","anchor_","rotating_","rotationDelta_","threshold_","threshold","rotationDelta","touch0","touch1","PinchZoom","lastDistance_","lastScaleDelta_","scaleDelta","interactions","altShiftDragRotate","doubleClickZoom","zoomDelta","zoomDuration","dragPan","pinchRotate","pinchZoom","keyboard","mouseWheelZoom","shiftDragZoom","LayerProperty","BaseLayer","background_","background","opacity","zIndex","className_","state_","getBackground","getClassName","getLayerState","managed","getZIndex","getOpacity","getVisible","getLayersArray","getLayerStatesArray","states","getSourceState","setBackground","setMaxResolution","setMinResolution","setOpacity","setVisible","setZIndex","zindex","GroupEventType","GroupEvent","LayerGroup","baseOptions","layersListenerKeys_","listenerKeys_","handleLayersChanged_","setLayers","handleLayerChange_","getLayers","handleLayersAdd_","handleLayersRemove_","layersArray","registerLayerListeners_","handleLayerGroupAdd_","handleLayerGroupRemove_","collectionEvent","collection","currentLayers","pos","ownLayerState","defaultZIndex","layerState","RenderEventType","Layer","mapPrecomposeKey_","mapRenderKey_","sourceChangeKey_","renderer_","sourceReady_","rendered","handleSourcePropertyChange_","setSource","getRenderSource","handleSourceChange_","getFeatures","isVisible","getMapInternal","layerStatesArray","getLayerGroup","find","layerExtent","inView","layerRenderer","getRenderer","prepareFrame","renderFrame","unrender","getDeclutter","renderDeclutter","renderDeferred","setMapInternal","handlePrecompose_","renderEvent","arrayLayerState","createRenderer","hasRenderer","clearRenderer","quickselect","defaultCompare","s","sd","swap","RBush$1","maxEntries","_maxEntries","_minEntries","_all","search","bbox","toBBox","nodesToSearch","child","childBBox","leaf","collides","insert","_build","_splitRoot","tmpNode","_insert","createNode","equalsFn","path","indexes","goingUp","findItem","_condense","compareMinX","compareMinY","toJSON","fromJSON","items","N","M","calcBBox","N2","N1","multiSelect","right2","right3","_chooseSubtree","targetNode","minEnlargement","bboxArea","enlargement","isNode","insertPath","_split","_adjustParentBBoxes","_chooseSplitAxis","splitIndex","_chooseSplitIndex","minOverlap","bbox1","distBBox","bbox2","overlap","intersectionArea","compareNodeMinX","compareNodeMinY","_allDistMargin","leftBBox","rightBBox","margin","bboxMargin","siblings","p","destNode","NO_COLOR","colorParseContext","rgbModernRegEx","rgbLegacyAbsoluteRegEx","rgbLegacyPercentageRegEx","hexRegEx","toColorComponent","divider","endsWith","throwInvalidColor","color","parseRgba","rgb","alpha","rgbDivider","hex","step","colorFromHex","colorComponent","desynchronized","invalidCheckFillStyle","colorString","colorFromImage","asString","cacheSize","withAlpha","v","rgbaToLcha","g","q","lchaToRgba","asArray","hasArea","toSize","numTypes","BooleanType","NumberType","StringType","ColorType","NumberArrayType","SizeType","AnyType","typeNames","namedTypes","typeName","names","namedType","includesType","broad","specific","isType","expected","LiteralExpression","isSpecific","CallExpression","operator","newParsingContext","variables","featureId","geometryType","mCoordinate","mapState","parse","encoded","expectedType","colorFromString","returnType","parser","parsers","parseCallExpression","Ops","Get","Var","Concat","GeometryType","LineMetric","Any","All","Not","Resolution","Time","Equal","NotEqual","GreaterThan","GreaterThanOrEqualTo","LessThan","LessThanOrEqualTo","Multiply","Divide","Add","Subtract","Clamp","Mod","Pow","Abs","Floor","Ceil","Round","Sin","Cos","Atan","Sqrt","Match","Between","Interpolate","Coalesce","Case","In","Color","Id","Band","Palette","ToString","Has","createCallExpressionParser","hasArgsCount","withGetArgs","withNoArgs","withArgsOfType","usesMapState","withArgsOfReturnType","hasEvenArgs","argsCount","inputType","fallback","interpolationType","base","JSON","stringify","interpolation","stop","operation","argCount","needleType","arg","colors","parsedColors","minArgs","maxArgs","expression","argType","validators","parsed","computeGeometryType","getGeometries","newEvaluationContext","buildExpression","compileExpression","colorValue","compileAssertionExpression","nameExpression","hasOwn","compileAccessorExpression","concat","op","compileLogicalExpression","compileComparisonExpression","compileNumericExpression","compileCaseExpression","compileMatchExpression","previousInput","previousOutput","isColor","interpolateColor","interpolateNumber","compileInterpolateExpression","compileConvertExpression","input1","output1","input2","output2","rgba1","rgba2","lcha1","lcha2","deltaHue","IconImageCache","cache_","patternCache_","cacheSize_","maxCacheSize_","canExpireCache","expire","iconImage","getCacheKey","getPattern","pattern","getImageState","ready","createPattern","setSize","maxCacheSize","shared","taintedTestContext","IconImage","imageState","hitDetectionImage_","color_","imageState_","tainted_","ready_","initializeImage_","isTainted_","dispatchChangeEvent_","replaceColor_","getHitDetectionImage","getSrc","globalCompositeOperation","onChange","iconImageCache","asColorLike","iconCache","cacheKey","canvasPattern","patternCanvasContext","getIconImage","asCanvasPattern","defaultFont","defaultFillStyle","defaultLineCap","defaultLineDash","defaultLineJoin","defaultMiterLimit","defaultStrokeStyle","defaultTextAlign","defaultTextBaseline","defaultPadding","checkedFonts","measureFont","measureContext","textHeights","genericFontFamilies","getFontKey","registerFont","retries","fontFaceSet","async","isAvailable","fontFaces","font","checkFamily","checkWeight","check","done","checkedFontsProperties","fonts","currentRetries","needCheck","has","measureTextHeight","measureElement","metrics","measureText","actualBoundingBoxAscent","actualBoundingBoxDescent","minHeight","maxHeight","border","body","text","measureTextWidth","measureAndCacheTextWidth","reduce","curr","getTextDimensions","baseStyle","chunks","widths","heights","lineWidths","lineWidth","currentWidth","currentHeight","drawImageOrLabel","labelOrImage","originX","originY","save","globalAlpha","contextInstructions","executeLabelInstructions","restore","ImageStyle","opacity_","rotateWithView_","rotateWithView","scale_","scaleArray_","displacement_","displacement","declutterMode_","declutterMode","getScale","getRotateWithView","getDisplacement","getDeclutterMode","getScaleArray","getAnchor","getImageSize","getOrigin","setDisplacement","setRotateWithView","setScale","listenImageChange","unlistenImageChange","RegularShape","hitDetectionCanvas_","fill_","fill","origin_","points","radius2_","radius2","stroke_","stroke","renderOptions_","loading","getFill","getPoints","getRadius2","getStroke","setFill","createHitDetectionCanvas_","fillKey","renderOptions","draw_","imageBitmap","setRadius","setRadius2","setStroke","calculateLineJoinSize_","lineJoin","strokeWidth","miterLimit","r1","r2","miterRatio","bevelAdd","aa","dd","innerMiterRatio","innerLength","createRenderOptions","strokeStyle","lineCap","lineDash","lineDashOffset","getColor","getLineDash","getLineDashOffset","getLineJoin","getLineCap","getMiterLimit","maxRadius","createPath_","setLineDash","drawHitDetectionCanvas_","arc","angle0","radiusC","lineTo","closePath","CircleStyle","Fill","patternImage_","setColor","patternImage","CanvasPattern","CanvasGradient","calculateScale","wantedWidth","wantedHeight","Icon","normalizedAnchor_","anchorOrigin_","anchorOrigin","anchorXUnits_","anchorXUnits","anchorYUnits_","anchorYUnits","iconImage_","offset_","offsetOrigin_","offsetOrigin","initialOptions_","onload","imageSize","setAnchor","nextColor","iconImageSize","setSrc","Stroke","lineCap_","lineDash_","lineDashOffset_","lineJoin_","miterLimit_","width_","getOffset","setLineCap","setLineDashOffset","setLineJoin","setMiterLimit","setOffset","setWidth","Style","geometryFunction_","defaultGeometryFunction","renderer","hitDetectionRenderer_","hitDetectionRenderer","text_","zIndex_","getText","setRenderer","setHitDetectionRenderer","getHitDetectionRenderer","getGeometryFunction","setText","feature","toFunction","styleFunction","defaultStyles","createDefaultStyle","createEditingStyle","white","blue","Text","font_","keepUpright_","keepUpright","textAlign_","textAlign","justify_","justify","repeat_","repeat","textBaseline_","textBaseline","maxAngle_","maxAngle","placement_","placement","overflow_","overflow","offsetX_","offsetY_","backgroundFill_","backgroundFill","backgroundStroke_","backgroundStroke","getFont","getPlacement","getRepeat","getMaxAngle","getOverflow","getKeepUpright","getTextAlign","getJustify","getTextBaseline","getOffsetX","getOffsetY","getBackgroundFill","getBackgroundStroke","getPadding","setOverflow","setFont","setMaxAngle","setOffsetX","setOffsetY","setPlacement","setRepeat","setKeepUpright","setTextAlign","setJustify","setTextBaseline","setBackgroundFill","setBackgroundStroke","setPadding","rulesToStyleFunction","rules","parsingContext","evaluator","buildRuleSet","evaluationContext","flatStylesToStyleFunction","flatStyles","evaluators","buildStyle","nonNullCount","compiledRules","rule","styleLength","someMatched","filterEvaluator","else","styleEvaluator","flatStyle","evaluateFill","buildFill","evaluateStroke","buildStroke","evaluateText","prefix","evaluateValue","stringEvaluator","evaluateBackgroundFill","evaluateBackgroundStroke","evaluateFont","evaluateMaxAngle","numberEvaluator","evaluateOffsetX","evaluateOffsetY","evaluateOverflow","booleanEvaluator","evaluatePlacement","evaluateRepeat","evaluateScale","sizeLikeEvaluator","evaluateRotateWithView","evaluateRotation","evaluateAlign","evaluateJustify","evaluateBaseline","evaluateKeepUpright","evaluatePadding","numberArrayEvaluator","optionalDeclutterMode","buildText","evaluateImage","srcName","requireString","evaluateAnchor","coordinateEvaluator","evaluateOpacity","evaluateDisplacement","optionalIconOrigin","optionalIconAnchorUnits","getExpressionValue","evaluateColor","colorLikeEvaluator","requireColorLike","optionalString","requireNumberArray","optionalNumberArray","optionalNumber","optionalSize","iconOptions","icon","initialColor","buildIcon","pointsName","radiusName","requireNumber","evaluateRadius","initialRadius","radius2Name","evaluateRadius2","initialRadius2","shape","buildShape","Circle","buildCircle","buildImage","evaluateZIndex","empty","srcEvaluator","offsetEvaluator","sizeEvaluator","patternSizeEvaluator","colorEvaluator","patternEvaluator","evaluateWidth","evaluateLineCap","evaluateLineJoin","evaluateLineDash","evaluateLineDashOffset","evaluateMiterLimit","evaluateOffset","requireSize","requireSizeLike","BaseVectorLayer","renderBuffer","updateWhileAnimating","updateWhileInteracting","declutter_","declutter","renderBuffer_","updateWhileAnimating_","updateWhileInteracting_","getRenderBuffer","getRenderOrder","getUpdateWhileAnimating","getUpdateWhileInteracting","declutterGroup","RBush","setRenderOrder","renderOrder","styleLike","toStyleLike","toStyleFunction","setDeclutter","RenderEvent","inversePixelTransform","MapRenderer","dispatchRenderEvent","calculateMatrices2D","coordinateToPixelTransform","pixelToCoordinateTransform","forEachFeatureAtCoordinate","hitTolerance","checkWrapped","layerFilter","thisArg2","translatedCoordinate","offsets","layerStates","numLayers","matches","tmpCoord","getWrapX","order","distanceSq","hasFeatureAtCoordinate","scheduleExpireIconCache","postRenderFunctions","expireIconCache","CompositeMapRenderer","fontChangeListenerKey_","redrawText","container","firstChild","children_","renderedLayerStates","previousElement","layerIndex","sourceState","mapCanvas","mapContext","firstElementChild","backgroundColor","removeLayerMapProperty","setLayerMapProperty","optionsInternal","keyboardEventTarget","layerGroup","overlays","createOptionsInternal","renderComplete_","loaded_","boundHandleBrowserEvent_","handleBrowserEvent","maxTilesLoading_","maxTilesLoading","postRenderTimeoutHandle_","animationDelayKey_","animationDelay_","coordinateToPixelTransform_","pixelToCoordinateTransform_","frameIndex_","frameState_","previousExtent_","viewPropertyListenerKey_","viewChangeListenerKey_","layerGroupPropertyListenerKeys_","viewport_","overlayContainer_","overlayContainerStopEvent_","mapBrowserEventHandler_","keyboardEventTarget_","targetChangeHandlerKeys_","targetElement_","resizeObserver_","ResizeObserver","updateSize","defaultControls","defaultInteractions","overlays_","overlayIdIndex_","postRenderFunctions_","tileQueue_","handleTileChange_","handleLayerGroupChanged_","handleViewChanged_","handleSizeChanged_","handleTargetChanged_","viewOptions","setView","addOverlayInternal_","control","interaction","addControl","getControls","addInteraction","getInteractions","addLayer","handleLayerAdd_","addOverlay","overlay","getOverlays","disconnect","forEachFeatureAtPixel","getFeaturesAtPixel","features","addLayersFrom","hasFeatureAtPixel","getEventCoordinate","getEventCoordinateInternal","viewportPosition","getBoundingClientRect","scaleX","scaleY","eventPosition","changedTouches","getTarget","getOverlayById","group","getLoadingOrNotReady","getPixelFromCoordinate","viewCoordinate","setPixelRatio","ownerDocument","handleMapBrowserEvent","currentDoc","documentElement","interactionsArray","handlePostRender","tileQueue","viewHints","animatingOrInteracting","lowOnFrameBudget","unobserve","targetRoot","HTMLElement","observe","handleViewPropertyChanged_","updateViewportSize_","handleLayerRemove_","isRendered","renderFrame_","renderSync","handleFontsChanged","removeControl","removeInteraction","removeLayer","removeOverlay","previousFrameState","usedTiles","mapId","renderTargets","nextExtent","equalsExtent","setLayerGroup","oldLayerGroup","computedStyle","getClientRects","oldSize","Overlay","insertFirst","autoPan","transform_","mapPostrenderListenerKey","handleElementChanged","handleMapChanged","handleOffsetChanged","handlePositionChanged","handlePositioningChanged","setElement","setPositioning","positioning","setPosition","getElement","getPosition","getPositioning","updatePixelPosition","performAutoPan","panIntoView","panIntoViewOptions","mapRect","getRect","overlayRect","myMargin","offsetLeft","offsetRight","offsetTop","offsetBottom","centerPx","newCenterPx","panOptions","box","pageXOffset","pageYOffset","mapSize","updateRenderedPosition","posX","posY","getOptions","TileRange","containsTileRange","tileRange","originalXHR","withCredentials","loadFeaturesXhr","url","success","failure","xhr","XMLHttpRequest","open","responseType","status","responseText","responseXML","readFeatures","featureProjection","readProjection","onerror","send","dataProjection","addFeatures","jsonp","errback","callbackParam","script","cleanup","timer","head","ResponseError","response","ClientError","client","getJSON","setRequestHeader","resolveUrl","URL","href","offsetLineString","isClosedRing","secondPointX","secondPointY","secondToLastPointX","secondToLastPointY","prevX","prevY","nextX","nextY","offsetLineVertex","nx","ny","hypot","tx","ty","joinAngle","removeOffsetCycles","p1x","p1y","p2x","p2y","p3x","p3y","p4x","p4y","ix","iy","VectorContext","drawCustom","drawGeometry","drawCircle","circleGeometry","drawFeature","drawGeometryCollection","geometryCollectionGeometry","drawLineString","lineStringGeometry","drawMultiLineString","multiLineStringGeometry","drawMultiPoint","multiPointGeometry","drawMultiPolygon","multiPolygonGeometry","drawPoint","pointGeometry","drawPolygon","polygonGeometry","drawText","setFillStrokeStyle","setImageStyle","imageStyle","declutterImageWithText","setTextStyle","textStyle","CanvasImmediateRenderer","viewRotation","userTransform","context_","transformRotation_","viewRotation_","squaredTolerance_","userTransform_","contextFillState_","contextStrokeState_","contextTextState_","fillState_","strokeState_","imageAnchorX_","imageAnchorY_","imageHeight_","imageOpacity_","imageOriginX_","imageOriginY_","imageRotateWithView_","imageRotation_","imageScale_","imageWidth_","textOffsetX_","textOffsetY_","textRotateWithView_","textRotation_","textScale_","textFillState_","textStrokeState_","textState_","pixelCoordinates_","tmpLocalTransform_","drawImages_","pixelCoordinates","localTransform","drawText_","setContextFillState_","setContextStrokeState_","setContextTextState_","strokeText","fillText","moveToLineTo_","close","strokeOffset","moveTo","drawRings_","beginPath","setTransform","geometries","getGeometriesArray","flatMidpoint","getFlatMidpoint","geometryExtent","flatMidpoints","getFlatMidpoints","flatInteriorPoint","getEndss","flatInteriorPoints","getFlatInteriorPoints","fillState","contextFillState","strokeState","contextStrokeState","textState","contextTextState","fillStyleColor","strokeStyleColor","strokeStyleLineCap","strokeStyleLineDash","strokeStyleLineDashOffset","strokeStyleLineJoin","strokeStyleWidth","strokeStyleMiterLimit","imagePixelRatio","imageAnchor","imageOrigin","imageScale","textFillStyle","textFillStyleColor","textStrokeStyle","textStrokeStyleColor","textStrokeStyleLineCap","textStrokeStyleLineDash","textStrokeStyleLineDashOffset","textStrokeStyleLineJoin","textStrokeStyleWidth","textStrokeStyleMiterLimit","textFont","textOffsetX","textOffsetY","textRotateWithView","textRotation","textScale","textText","textTextAlign","textTextBaseline","acc","GEOMETRY_RENDERERS","builderGroup","hasText","imageReplay","getBuilder","textReplay","LineString","lineStringReplay","polygonReplay","MultiPoint","hasImage","MultiLineString","MultiPolygon","GeometryCollection","replayGroup","declutterBuilderGroup","geometryRenderer","circleReplay","defaultOrder","feature1","feature2","getSquaredTolerance","getTolerance","renderFeature","loadingPromises","renderGeometry","renderFeatureInternal","getVectorContext","CanvasRenderingContext2D","canvasPixelRatio","multiplyTransform","brokenDiagonalRendering_","drawTestTriangle","u1","u2","clip","verifyBrokenDiagonalRendering","calculateSourceResolution","targetProj","targetMetersPerUnit","compensationFactor","calculateSourceExtentResolution","targetExtent","triangulation","sources","gutter","renderEdges","drawSingle","clipExtent","imageSmoothingEnabled","pixelRound","sourceDataExtent","stitchContext","stitchScale","inverseScale","xPos","yPos","rect","srcWidth","srcHeight","targetTopLeft","getTriangles","triangle","u0","v0","sourceNumericalShiftX","sourceNumericalShiftY","affineCoefs","isBrokenDiagonalRendering","steps","ud","vd","fromResolutionLike","LRUCache","highWaterMark","count_","entries_","oldest_","newest_","deleteOldest","entry","expireCache","keep","containsKey","value_","key_","newer","older","getValues","peekLast","peekLastKey","peekFirstKey","peek","getKeyZXY","sourceKey","hash","hashZXY","withinExtentAndZ","getFullTileRange","appendParams","uri","params","keyParams","encodeURIComponent","qs","zRegEx","xRegEx","yRegEx","dashYRegEx","renderXYZTemplate","pickUrl","urls","expandUrl","exec","startCharCode","charCodeAt","stopCharCode","charCode","fromCharCode","Triangulation","maxSourceExtent","errorThreshold","destinationResolution","sourceMatrix","sourceProj_","targetProj_","transformInvCache","transformInv","applyMatrix","transformInv_","maxSourceExtent_","errorThresholdSquared_","triangles_","wrapsXInSource_","canWrapXInSource_","sourceWorldWidth_","targetWorldWidth_","destinationTopLeft","destinationTopRight","destinationBottomRight","destinationBottomLeft","sourceTopLeft","sourceTopRight","sourceBottomRight","sourceBottomLeft","maxSubdivision","log2","addQuad_","leftBound","newTriangle","addTriangle_","aSrc","bSrc","cSrc","dSrc","sourceQuadExtent","sourceCoverageX","sourceWorldWidth","wrapsX","needsSubdivision","isNotFinite","centerSrc","bc","bcSrc","da","daSrc","ab","abSrc","cd","cdSrc","calculateSourceExtent","ERROR_THRESHOLD","ReprojImage","getImageFunction","maxTargetExtent","limitedTargetExtent","sourceImage","sourcePixelRatio","triangulation_","targetExtent_","sourceImage_","sourcePixelRatio_","interpolate_","sourceListenerKey_","unlistenSource_","reproject_","renderReprojected","Source","adaptAttributions","attributionsCollapsible_","attributionsCollapsible","wrapX_","viewResolver","viewRejector","viewPromise_","getInterpolate","refresh","setAttributions","attributionLike","ImageSourceEventType","ImageSourceEvent","ImageSource","reprojectedImage_","reprojectedRevision_","wantedExtent_","wantedResolution_","static_","wantedProjection_","setResolutions","findNearestResolution","getImageInternal","requestExtent","getRequestExtent","handleImageChange","defaultImageLoadFunction","imageResolution","getRequestUrl","baseUrl","srid","createLoader","hidpi","F","FORMAT","TRANSPARENT","tmpTileCoord","TileGrid","origins","origin","origins_","tileSizes_","tileSizes","tileSize_","tileSize","fullTileRanges_","tmpSize_","tmpExtent_","sizes","restrictedTileRange","getTileRangeForExtentAndZ","calculateTileRanges_","forEachTileCoord","forEachTileCoordParentTileRange","tempTileRange","tempExtent","tileCoordExtent","getTileCoordExtent","createOrUpdateTileRange","getOrigins","getTileCoordChildTileRange","getTileRangeForTileCoordAndZ","tileCoordZ","tileCoordX","tileCoordY","getTileCoordForXYAndZ_","getTileCoordCenter","getTileSize","getTileCoordForCoordAndResolution","opt_tileCoord","getTileCoordForXYAndResolution_","reverseIntersectionPolicy","getZForResolution","createOrUpdateTileCoord","getTileCoordForCoordAndZ","getTileCoordResolution","opt_direction","tileCoordIntersectsViewport","viewport","fullTileRanges","WMTSTileGrid","matrixIds_","matrixIds","getMatrixId","getMatrixIds","createFromCapabilitiesMatrixSet","matrixSet","matrixLimits","matrixIdsPropName","identifierPropName","scaleDenominatorPropName","topLeftCornerPropName","switchOriginXY","elt","matrixAvailable","elt_ml","tileWidth","tileHeight","getForProjection","createForProjection","extentFromProjection","createForExtent","resolutionsFromExtent","createXYZ","xyzOptions","gridOptions","half","createFromTemplate","createFromTemplates","templates","tileUrlFunctions","createFromTileUrlFunctions","tileCoordHash","nullTileUrlFunction","ReprojTile","sourceTileGrid","targetTileGrid","wrappedTileCoord","getTileFunction","renderEdges_","gutter_","sourceTileGrid_","targetTileGrid_","wrappedTileCoord_","sourceTiles_","sourcesListenerKeys_","sourceZ_","clipExtent_","sourceProjExtent","errorThresholdInPixels","sourceRange","srcX","srcY","getTile","sourceTile","leftToLoad","sourceListenKey","unlistenSources_","TileSource","tilePixelRatio_","tilePixelRatio","tmpSize","tileOptions","zDirection","getGutterForProjection","setKey","getTileGridForProjection","tileCache","getTileGrid","getTilePixelRatio","getTilePixelSize","scaleSize","getTileCoordForTileUrlFunction","gridProjection","TileSourceEvent","TileEventType","UrlTile","generateTileUrlFunction_","tileUrlFunction","setUrls","setUrl","tileLoadingKeys_","getTileLoadFunction","getTileUrlFunction","getPrototypeOf","getUrls","uid","tileState","setTileLoadFunction","setTileUrlFunction","TileImage","defaultTileLoadFunction","tileClass","tileGridForProjection","reprojectionErrorThreshold_","reprojectionErrorThreshold","renderReprojectionEdges_","getGutter","thisProj","projKey","createTile_","urlTileCoord","tileUrl","getTileInternal","setRenderReprojectionEdges","setTileGridForProjection","tilegrid","proj","imageTile","mode","credentials","fetch","ok","blob","quadKey","digits","mask","XYZ","interpolatePoint","o","cumulativeLengths","lineStringCoordinateAtM","extrapolate","lo","hi","m0","lineStringsCoordinateAtM","lineStringLength","flatMidpoint_","flatMidpointRevision_","appendCoordinate","lineString","getCoordinateAtM","getCoordinateAt","lineStrings","appendLineString","multiLineString","getLineString","getLineStrings","midpoints","appendPoint","multiPoint","getPoint","endss_","flatInteriorPointsRevision_","flatInteriorPoints_","polygons","thisEndss","appendPolygon","newEndss","multiPolygon","linearRingssArea","linearRingssCenter","getInteriorPoints","getPolygon","prevEnds","getPolygons","lastEnds","RenderFeature","type_","flatCoordinates_","flatMidpoints_","properties_","stride_","simplifiedGeometry_","midpoint","enableSimplifyTransformed","toGeometry","rbush_","RBush_","items_","extents","getAll","getInExtent","forEach_","forEachInExtent","rbush","VectorEventType","VectorSourceEvent","VectorSource","format_","overlaps_","overlaps","url_","strategy_","strategy","allStrategy","useSpatialIndex","featuresRtree_","loadedExtentsRtree_","nullGeometryFeatures_","idIndex_","uidIndex_","featureChangeKeys_","featuresCollection_","addFeaturesInternal","bindFeaturesCollection_","addFeature","addFeatureInternal","featureKey","addToIndex_","setupChangeEvents_","handleFeatureChange_","valid","indexedFeature","newFeatures","geometryFeatures","modifyingCollection","removeFeature","fast","removeFeatureInternal","clearEvent","forEachFeature","forEachFeatureAtCoordinateDirect","forEachFeatureInExtent","forEachFeatureIntersectingExtent","getFeaturesCollection","getFeaturesAtCoordinate","getFeaturesInExtent","anExtent","getClosestFeatureToCoordinate","closestFeature","previousMinSquaredDistance","minDistance","getFeatureById","getFeatureByUid","getFormat","getOverlaps","getUrl","sid","removeFromIdIndex_","hasFeature","loadFeatures","loadedExtentsRtree","extentsToLoad","extentToLoad","disableCallbacks","removeLoadedExtent","removeFeatures","removed","featureChangeKeys","idString","setLoader","setOverlaps","fromTransform","mat4","orthographic","bottom","near","far","lr","bt","nf","a00","a01","a02","a03","a10","a11","a12","a13","a20","a21","a22","a23","translation","Canvas","gl","gl_","program_","createProgram","positionLocation","getAttribLocation","texcoordLocation","matrixLocation","getUniformLocation","textureMatrixLocation","textureLocation","positionBuffer","createBuffer","bindBuffer","ARRAY_BUFFER","positions","bufferData","STATIC_DRAW","texcoordBuffer","texcoords","tex","texWidth","texHeight","dstX","dstY","dstWidth","dstHeight","bindTexture","TEXTURE_2D","useProgram","enableVertexAttribArray","vertexAttribPointer","FLOAT","matrix","mat4.orthographic","mat4.translate","mat4.scale","uniformMatrix4fv","texMatrix","mat4.translation","uniform1i","drawArrays","TRIANGLES","createShader","shader","shaderSource","compileShader","getShaderParameter","COMPILE_STATUS","getShaderInfoLog","fragmentSource","vertexSource","program","vertexShader","VERTEX_SHADER","fragmentShader","FRAGMENT_SHADER","attachShader","linkProgram","getProgramParameter","LINK_STATUS","getProgramInfoLog","createCanvasContextWebGL","releaseGLCanvas","COLOR_BUFFER_BIT","DEPTH_BUFFER_BIT","STENCIL_BUFFER_BIT","canvasGLPool","height_","dataType","resultFrameBuffer","resultTexture","createTexture","texParameteri","TEXTURE_WRAP_S","CLAMP_TO_EDGE","TEXTURE_WRAP_T","TEXTURE_MIN_FILTER","LINEAR","TEXTURE_MAG_FILTER","NEAREST","texImage2D","RGBA","createFramebuffer","bindFramebuffer","FRAMEBUFFER","framebufferTexture2D","COLOR_ATTACHMENT0","framebuffer","texture","stitchTexture","stitchWidth","stitchHeight","maxTexSize","getParameter","MAX_TEXTURE_SIZE","largeSide","scaleFactor","stitchWidthFixed","stitchHeightFixed","fb","webGLCanvas","WebGLCanvas","enable","SCISSOR_TEST","scissor","deleteFramebuffer","getUVs","triProgram","su0","sv0","su1","sv1","su2","sv2","edgeProgram","burnval","burnvalLocation","uniform4fv","lines","LINES","ReprojDataTile","reprojData_","reprojError_","reprojSize_","sourceTileGridExtent","transformMatrix","dataSources","imageLike","tileData","arrayData","pixelSize","isFloat","pixelCount","DataType","tileDataR","bytesPerElement","BYTES_PER_ELEMENT","bytesPerPixel","bytesPerRow","byteLength","bandCount","targetWidth","targetHeight","outWidth","outHeight","dataR","premultipliedAlpha","antialias","willInterpolate","textureType","getExtension","UNSIGNED_BYTE","reproj","dataSource","dataS","rows","cols","readPixels","flipY","ImageData","putImageData","DataTileSource","nodataBandIndex","tileGridForProjection_","setTileSizes","getReprojTile_","reprojTilePixelRatio","textureSize","sourceLoader","AbortController","loaderOptions","signal","requestZ","requestX","requestY","sourceResolutions","targetFinestRes","registered","register","proj4","projCodes","defs","getCachedProjection","def","projName","axis","to_meter","code1","proj1","code2","proj2","projLookup","authority","num","fromProjectionCode","epsgLookup","imageExtent","resolutionX","resolutionY","loadError","loadImage","makeLoaderFromTemplates","makeLoaderFromUrlLike","keyCount","keyFromUrlLike","ImageTileSource","DEFAULT_VERSION","GETFEATUREINFO_IMAGE_SIZE","v13","getImageSrc","serverType","REQUEST","dpi","getRequestParams","request","SERVICE","VERSION","STYLES","getFeatureInfoUrl","projectionObj","baseParams","QUERY_LAYERS","INFO_FORMAT","getLegendUrl","mpu","knownMapMediaTypes","knownVectorMediaTypes","appendCollectionsQueryParam","tileUrlTemplate","collections","pathname","logError","encodedCollections","searchParams","append","decodeURIComponent","getMapTileUrlTemplate","links","mediaType","fallbackUrlTemplate","link","rel","getVectorTileUrlTemplate","supportedMediaTypes","hrefLookup","supportedMediaType","parseTileMatrixSet","sourceInfo","tileMatrixSet","tileMatrixSetLimits","crs","orderedAxes","backwards","matrices","tileMatrices","cellSize","matrixLookup","limitLookup","limit","tileMatrix","pointOfOrigin","matrixWidth","matrixHeight","tileMapWidth","minTileCol","maxTileCol","tileMapHeight","cornerOfOrigin","minTileRow","maxTileRow","intersectExtents","grid","urlTemplate","urlFunction","upsideDown","localContext","tileCol","tileRow","ATTRIBUTION","ZIndexContext","instructions_","push_","pushMethodArgs_","instructions","pushFunction","draw","instructionsAtIndex","instructionAtIndex","LayerRenderer","boundHandleImageChange_","handleImageChange_","layer_","staleKeys_","maxStaleKeys","getStaleKeys","prependStaleKey","unshift","getLayer","renderIfReadyAndVisible","pixelContext","CanvasLayerRenderer","renderedResolution","tempTransform","pixelTransform","deferredContext_","containerReused","col","row","useContainer","layerClassName","transformOrigin","clipUnrotated","topLeft","topRight","bottomRight","bottomLeft","inverted","prepareContainer","canvasTransform","toTransformString","dispatchRenderEvent_","preRender","postRender","renderDeferredInternal","getRenderContext","getRenderTransform","CanvasImageLayerRenderer","imageLayer","renderedSourceRevision_","viewResolution","imageSource","renderedExtent","imageMapWidth","imageMapHeight","imageResolutionX","imageResolutionY","viewCenter","clipped","dw","dh","BaseImageLayer","ImageLayer","addTileToLookup","tilesByZ","existing","removeTileFromLookup","delete","getRenderExtent","gridExtent","CanvasTileLayerRenderer","tileLayer","extentChanged","renderComplete","renderedExtent_","renderedPixelRatio","renderedProjection","renderedTiles","renderedSourceKey_","tempTileRange_","tempTileCoord_","createTileCoord","tileCache_","sourceTileCache_","getTileCache","getSourceTileCache","getOrCreateTile","tileSource","tileOrigin","sourceRevision","enqueueTilesForNextExtent","enqueueTiles","initialZ","preload","minZ","tileQueueKey","findStaleTile_","staleKeys","findAltTiles_","altZ","covered","frameExtent","canvasExtent","getPreload","targetZ","renderExtent","parentZ","canvasScale","zs","currentClip","clips","clipZs","currentZ","currentTilePixelSize","currentScale","originTileCoord","originTileExtent","tileGutter","xIndex","yIndex","contextSaved","drawTile","updateUsedTiles","postRenderFunction","tilesCount","updateCacheSize","tileCount","getTileImage","alphaChanged","TileProperty","BaseTileLayer","useInterimTilesOnError","setPreload","setUseInterimTilesOnError","getCacheSize","getUseInterimTilesOnError","TileLayer","createMinion","buffers","meta","imageOps","numBuffers","numBytes","images","arrays","pixels","createWorker","config","onMessage","lib","worker","Worker","Blob","Buffer","createObjectURL","Processor","threads","imageOps_","workers","onWorkerMessage_","minion","terminated","postMessage","terminate","createFauxWorker","workers_","queue_","maxQueueLength_","queue","running_","dataLookup_","job_","process","inputs","enqueue_","dispatch_","job","slices","resolveJob_","RasterEventType","RasterSourceEvent","RasterSource","processor_","operationType_","operationType","threads_","layers_","createLayer","createLayers","useResolutions_","processSources_","requestedFrameState_","renderedImageCanvas_","renderedRevision_","iMax","sourceOrLayer","sourceAttributions","setOperation","updateFrameState_","allSourcesReady_","imageDatas","onWorkerComplete_","layerOrSource","LayerConfig","stamen_terrain","stamen_terrain_background","stamen_terrain_labels","stamen_terrain_lines","stamen_toner_background","stamen_toner","stamen_toner_labels","stamen_toner_lines","stamen_toner_lite","stamen_toner_dark","stamen_toner_blacklite","stamen_watercolor","alidade_smooth","alidade_smooth_dark","alidade_satellite","outdoors","osm_bright","ProviderConfig","retina","CustomTile","preemptive","preemptive_","grid_","keys_","jsonp_","xRelative","yRelative","forDataAtCoordinate","loadInternal_","handleError_","json","requestJSONP","onXHRLoad_","onXHRError_","XML_SCHEMA_INSTANCE_URI","createElementNS","namespaceURI","qualifiedName","getDocument","getAllTextContent","normalizeWhitespace","getAllTextContent_","accumulator","nodeType","Node","CDATA_SECTION_NODE","TEXT_NODE","nodeValue","nextSibling","isDocument","getAttributeNS","xml","DOMParser","parseFromString","makeArrayExtender","valueReader","objectStack","makeArrayPusher","makeReplacer","makeObjectPropertyPusher","localName","makeObjectPropertySetter","makeChildAppender","nodeWriter","makeArraySerializer","serializersNS","nodeFactory","serializers","makeSimpleNodeFactory","serialize","fixedNodeName","fixedNamespaceURI","newNodeName","nodeName","OBJECT_PROPERTY_NODE_FACTORY","makeSequence","orderedKeys","sequence","makeStructureNS","namespaceURIs","structure","structureNS","parseNode","parsersNS","nextElementSibling","pushParseAndPop","pushSerializeAndPop","xmlSerializer_","document_","getXMLSerializer","XMLSerializer","implementation","createDocument","Instruction","fillInstruction","strokeInstruction","beginPathInstruction","closePathInstruction","CanvasBuilder","maxLineWidth","beginGeometryInstruction1_","beginGeometryInstruction2_","bufferedMaxExtent_","tmpCoordinate_","hitDetectionInstructions","applyPixelRatio","dashArray","dash","appendFlatPointCoordinates","getBufferedMaxExtent","myEnd","appendFlatLineCoordinates","closed","skipFirst","lastXCoord","lastYCoord","nextCoord","lastRel","nextRel","skipped","drawCustomCoordinates_","builderEnds","builderEnd","beginGeometry","builderBegin","builderEndss","myEnds","CanvasInstruction","endGeometry","finish","reverseHitDetectionInstructions","reverse","instruction","fillStyleToState","fillPatternScale","strokeStyleToState","strokeStyleOffset","createFill","applyStroke","createStroke","updateFillStyle","currentFillStyle","updateStrokeStyle","currentStrokeStyle","currentLineCap","currentLineDash","currentLineDashOffset","currentLineJoin","currentLineWidth","currentMiterLimit","currentStrokeOffset","endGeometryInstruction","CanvasImageBuilder","imagePixelRatio_","anchorX_","anchorY_","originX_","originY_","declutterImageWithText_","myBegin","filteredFlatCoordinates","sharedData","CanvasLineStringBuilder","drawFlatCoordinates_","lastStroke","CanvasPolygonBuilder","drawFlatCoordinatess_","numEnds","handleStrokeOffset_","setFillStrokeStyles_","circleInstruction","drawGeometryCallback","lineChunk","chunkLength","cursor","chunkM","currentChunk","missing","matchingChunk","m12","m23","x12","y12","x23","y23","chunkStart","chunkEnd","TEXT_ALIGN","middle","hanging","alphabetic","ideographic","CanvasTextBuilder","labels_","textKeepUpright_","fillStates","strokeStates","textStates","textKey_","fillKey_","strokeKey_","geometryWidths","beg","saveTextStates_","p1","p2","p3","hitDetectionBackgroundFill","flatOffset","oo","cc","chunk","chunkBegin","drawChars_","strokeKey","textKey","baseline","textKeepUpright","BATCH_CONSTRUCTORS","PolygonBuilder","Default","Builder","ImageBuilder","LineStringBuilder","TextBuilder","BuilderGroup","tolerance_","maxExtent_","resolution_","buildersByZIndex_","builderInstructions","zKey","builders","builderKey","builderInstruction","builderType","zIndexKey","replays","replay","Constructor","drawTextOnPath","startM","segmentM","advance","beginX","beginY","startOffset","startLength","endM","flat","singleSegment","previousAngle","iStart","charLength","chars","tmpExtent","p4","getDeclutterBox","replayImageOrLabelArgs","declutterBox","rtlRegEx","horizontalTextAlign","align","createTextChunks","line","richTextToPlainText","part","Executor","deferredRendering","alignAndScaleFill_","coordinateCache_","renderedTransform_","widths_","zIndexContext_","getZIndexContext","createLabel","renderWidth","leftRight","strokeInstructions","fillInstructions","previousFont","lineOffset","widthHeightIndex","lineWidthIndex","fillStrokeArgs","replayTextBackground_","setStrokeStyle_","calculateImageOrLabelDimensions_","sheetWidth","sheetHeight","snapToPixel","fillStroke","boxW","boxH","boxX","boxY","drawImageX","drawImageY","drawImageW","drawImageH","replayImageOrLabel_","scaledCanvasSize","imageOrLabel","strokePadding","alignAndScale","repeatSize","drawLabelWithPointPlacement_","execute_","featureCallback","hitExtent","declutterTree","zIndexContext","transformSetFromArray","offsetCoords","lineOffsetPx","roundX","roundY","pendingFill","pendingStroke","coordinateCache","viewRotationFromTransform","batchSize","currentGeometry","labelWithAnchor","backgroundFillInstruction","backgroundStrokeInstruction","widthIndex","imageArgs","imageDeclutterMode","imageDeclutterBox","renderImage","renderText","imageDeclutter","measurePixelRatio","pixelRatioScale","cachedWidths","pathLength","textLength","parts","drawChars","lineCoords","lineStart","lineEnd","execute","executeHitDetection","ALL","DECLUTTER","NON_DECLUTTER","canvasReadsBenchmarked","ExecutorGroup","allInstructions","executorsByZIndex_","hitDetectionContext_","hitDetectionTransform_","renderedContext_","deferredZIndexContexts_","createExecutors_","flatClipCoords","getClipCoords","executors","instructionByZindex","hasExecutors","candidates","declutteredFeatures","bestResult","measure","performance","measures","benchmarkCanvasReads","contextSize","newContext","getPixelIndexArray","idx","executor","targetContext","builderTypes","maxBuilderTypes","requireClip","getDeferredZIndexContexts","getRenderedContext","deferredZIndexContexts","circlePixelIndexArrayCache","maxDistanceSq","distances","pixelIndex","HIT_DETECT_RESOLUTION","createHitDetectionImageData","userExtent","featureCount","indexFactor","featuresByZIndex","featureStyleFunction","padStart","originalStyle","imgSize","imgContext","byGeometryType","getGeometriesArrayRecursive","zIndexKeys","geomAndStyle","kk","hitDetect","resultFeatures","CanvasVectorLayerRenderer","vectorLayer","boundHandleStyleImageChange_","handleStyleImageChange_","animatingOrInteracting_","hitDetectionImageData_","extendX_","renderedFeatures_","renderedResolution_","wrappedRenderedExtent_","renderedRotation_","renderedCenter_","renderedProjection_","renderedPixelRatio_","renderedRenderOrder_","renderedFrameDeclutter_","replayGroup_","replayGroupChanged","clipping","targetContext_","renderWorlds","executorGroup","declutterable","vectorSource","endWorld","world","setDrawContext_","resetDrawContext_","getSquaredRenderTolerance","lastIndexOf","animating","interacting","frameStateExtent","vectorLayerRevision","vectorLayerRenderBuffer","vectorLayerRenderOrder","defaultRenderOrder","loadExtents","projMinX","projMaxX","wrapCoordinateX","loadExtent","wrapExtentX","CanvasBuilderGroup","getRenderTolerance","dirty","replayGroupInstructions","CanvasVectorImageLayerRenderer","vectorRenderer_","layerImageRatio_","getImageRatio","coordinateToVectorPixelTransform_","renderedPixelToCoordinateTransform_","vectorPixel","vectorRenderer","imageLayerState","imageFrameState","geoA","geoB","geoStack","fractionStack","fractions","geoM","fracA","fracB","fracM","maxIterations","meridian","frac","parallel","lon2","VectorLayer","DEFAULT_STROKE_STYLE","INTERVALS","ELEMENT_ARRAY_BUFFER","DYNAMIC_DRAW","CONTEXT_IDS","BufferUsage","WebGLArrayBuffer","usage","usage_","ofSize","getArrayClassForType","fromArray","fromArrayBuffer","setArray","ArrayType","getUsage","Uint32Array","ContextEventType","WebGLPostProcessingPass","webGlContext","scaleRatio_","scaleRatio","renderTargetTexture_","renderTargetTextureSize_","frameBuffer_","depthBuffer_","createRenderbuffer","renderTargetProgram_","renderTargetVerticesBuffer_","renderTargetAttribLocation_","renderTargetUniformLocation_","renderTargetOpacityLocation_","renderTargetTextureLocation_","uniforms_","uniforms","location","getRenderTargetTexture","getGL","init","drawingBufferWidth","drawingBufferHeight","getFrameBuffer","bindRenderbuffer","RENDERBUFFER","getDepthBuffer","internalFormat","renderbufferStorage","DEPTH_COMPONENT16","framebufferRenderbuffer","DEPTH_ATTACHMENT","nextPass","preCompose","postCompose","activeTexture","TEXTURE0","canvasId","attributes","getContextAttributes","preserveDrawingBuffer","clearColor","clearDepth","DEPTH_TEST","BLEND","blendFunc","ONE","ONE_MINUS_SRC_ALPHA","uniform2f","uniform1f","applyUniforms","textureSlot","uniform","uniform3f","uniform4f","DefaultUniform","PROJECTION_MATRIX","INVERT_PROJECTION_MATRIX","TIME","ZOOM","VIEWPORT_SIZE_PX","PIXEL_RATIO","HIT_DETECTION","AttributeType","canvasCache","getSharedCanvasCacheKey","uniqueCanvasCacheKeyCount","getOrCreateContext","cacheItem","users","WebGLHelper","boundHandleWebGLContextLost_","handleWebGLContextLost","boundHandleWebGLContextRestored_","handleWebGLContextRestored","canvasCacheKey_","canvasCacheKey","getUniqueCanvasCacheKey","bufferCache_","extensionCache_","currentProgram_","needsToBeRecreated_","offsetRotateMatrix_","offsetScaleMatrix_","tmpMat4_","uniformLocationsByProgram_","attribLocationsByProgram_","setUniforms","postProcessPasses_","postProcesses","shaderCompileErrors_","maxAttributeCount_","MAX_VERTEX_ATTRIBS","addUniforms","canvasCacheKeyMatches","getInstancedRenderingExtension_","ext","bufferKey","bufferCache","webGlBuffer","flushBufferData","deleteBuffer","buf","loseContext","prepareDraw","disableAlphaBlend","enableDepth","getCanvas","depthRange","ZERO","depthFunc","LEQUAL","bindFrameBuffer","frameBuffer","bindInitialFrameBuffer","slot","uniformName","bindAttribute","attributeName","getAttributeLocation","prepareDrawToRenderTarget","renderTarget","getFramebuffer","getDepthbuffer","getTexture","drawElements","elementType","UNSIGNED_INT","numItems","offsetInBytes","drawElementsInstanced","instanceCount","drawElementsInstancedANGLE","vertexAttribDivisorANGLE","finalizeDraw","applyFrameState","setUniformFloatValue","setUniformFloatVec2","applyHitDetectionUniform","loc","WebGLTexture","prevValue","imageReady","setUniformMatrixValue","disableAllAttributes_","getProgram","fragmentShaderSource","vertexShaderSource","deleteShader","programUid","makeProjectionTransform","uniform2fv","setUniformFloatVec4","disableVertexAttribArray","enableAttributeArray_","attribName","instanced","enableAttributes_","attr","getByteSizeFromType","computeAttributesStride","enableAttributes","enableAttributesInstanced","needsToBeRecreated","Uint16Array","WebGLLayerRenderer","inversePixelTransform_","postProcesses_","helper","onMapChanged_","clearCache","removeHelper","dispatchPreComposeEvent","dispatchPostComposeEvent","reset","incrementGroup","groupNumber","afterHelperCreated","prepareFrameInternal","Uniforms","PaletteTexture","texture_","deleteTexture","numberToGlsl","arrayToGlsl","colorToGlsl","sizeToGlsl","stringToFloatMap","stringToFloatCounter","getStringNumberEquivalent","string","stringToGlsl","uniformNameForVariable","variableName","newCompilationContext","functions","GET_BAND_VALUE_FUNC","PALETTE_TEXTURE_ARRAY","FEATURE_ID_PROPERTY_NAME","GEOMETRY_TYPE_PROPERTY_NAME","UNDEFINED_PROP_VALUE","compilationContext","compile","createCompiler","compilers","propName","varName","compiledArgs","firstValue","secondValue","exponent","stop1","stop2","funcName","computeOperatorFunctionName","tests","band","xOffset","yOffset","ifBlocks","colorIndex","bandIndex","numColors","palette","paletteTextures","paletteName","paletteTexture","compiler","expressionToGlsl","packColor","getGlslSizeFromType","getGlslTypeFromType","applyContextToBuilder","builder","variable","glslType","addUniform","addAttribute","functionName","addVertexShaderFunction","addFragmentShaderFunction","generateUniformsFromContext","generateAttributesFromContext","getLowPart","float","getHighPart","fround","COMMON_HEADER","DEFAULT_STYLE","ShaderBuilder","attributes_","hasSymbol_","symbolSizeExpression_","symbolRotationExpression_","symbolOffsetExpression_","symbolColorExpression_","texCoordExpression_","fragmentDiscardExpression_","shapeDiscardExpression_","symbolRotateWithView_","hasStroke_","strokeWidthExpression_","strokeColorExpression_","strokeOffsetExpression_","strokeCapExpression_","strokeJoinExpression_","strokeMiterLimitExpression_","strokeDistanceFieldExpression_","strokePatternLengthExpression_","hasFill_","fillColorExpression_","fillPatternSizeExpression_","vertexShaderFunctions_","fragmentShaderFunctions_","varyingExpression","varyingType","varyingName","setSymbolSizeExpression","getSymbolSizeExpression","setSymbolRotationExpression","setSymbolOffsetExpression","getSymbolOffsetExpression","setSymbolColorExpression","getSymbolColorExpression","setTextureCoordinateExpression","setFragmentDiscardExpression","getFragmentDiscardExpression","setShapeDiscardExpression","getShapeDiscardExpression","setSymbolRotateWithView","setStrokeWidthExpression","setStrokeColorExpression","getStrokeColorExpression","setStrokeOffsetExpression","setStrokeCapExpression","setStrokeJoinExpression","setStrokeMiterLimitExpression","setStrokeDistanceFieldExpression","setStrokePatternLengthExpression","getStrokePatternLengthExpression","setFillColorExpression","getFillColorExpression","setFillPatternSizeExpression","getFillPatternSizeExpression","getSymbolVertexShader","attribute","getSymbolFragmentShader","getStrokeVertexShader","getStrokeFragmentShader","getFillVertexShader","getFillFragmentShader","MixedGeometryBatch","globalCounter_","refToFeature_","Map","uidToRef_","freeGlobalRef_","polygonBatch","entries","geometriesCount","verticesCount","ringsCount","pointBatch","lineStringBatch","projectionTransform","addGeometry_","clearFeatureEntryInPointBatch_","featureUid","flatCoordss","clearFeatureEntryInLineStringBatch_","clearFeatureEntryInPolygonBatch_","multiPolygonGeom","addCoordinates_","multiLineGeom","multiPointGeom","polygonGeom","pointGeom","lineGeom","flatCoords","multiPolygonEndss","polygonEnds","prevPolygonEnds","endIndex","multiLineEnds","multiPolygonEnds","addRefToEntry_","ringsVerticesCounts","ringsVerticesCount","ind","getFlatCoordinatesXY","getFlatCoordinatesXYM","currentRef","ref","removeRef_","changeFeature","getFeatureFromRef","featureFilter","filtered","WebGLWorkerMessageType","pushCustomAttributesInRenderInstructions","renderInstructions","customAttributes","batchEntry","currentIndex","getCustomAttributesSize","computeHash","parseCommonSymbolProperties","vertContext","getColorFromDistanceField","distanceField","fillColor","strokeColor","parseImageProperties","textureId","parseImageOffsetProperties","sampleSize","offsetExpression","parseLiteralStyle","sizeExpression","fullsize","shiftPx","offsetPx","parseIconProperties","currentPoint","numPoints","shapeField","colorExpression","parseShapeProperties","parseCircleProperties","sampleSizeExpression","spacingExpression","startOffsetExpression","textureName","tintExpression","dashPattern","dashFunctionName","dashLengthsParamsDef","totalLengthDef","currentDashOffset","distanceExpression","dashLengthsCalls","patternLength","parseStrokeProperties","specifiedSizeExpression","parseFillProperties","filterContext","parsedFilter","defineSpecialInput","contextPropName","glslPropName","attrSize","tmpColor","WEBGL_WORKER","getWebGLWorker","createWebGLWorker","workerMessageCounter","Attributes","VectorStyleRenderer","enableHitDetection","helper_","hitDetectionEnabled_","styleShaders","shaders","previousFilters","ruleStyles","currentFilter","convertStyleToShaders","customAttributes_","radix","divide","colorEncodeIdAndPack","styleShader","renderPasses_","renderPass","customAttributesDesc","fillRenderPass","attributesDesc","instancedAttributesDesc","instancePrimitiveVertexCount","strokeRenderPass","symbolRenderPass","setHelper","generateBuffers","geometryBatch","generateRenderInstructions_","polygonBuffers","lineStringBuffers","pointBuffers","generateBuffersForType_","polygonInstructions","lineStringInstructions","pointInstructions","invertVerticesTransform","makeInverseTransform","batch","totalInstructionsCount","renderIndex","generatePolygonRenderInstructions","generateLineStringRenderInstructions","tmpCoords","generatePointRenderInstructions","messageId","messageType","renderInstructionsTransform","customAttributesSize","handleMessage","received","indicesBuffer","vertexAttributesBuffer","instanceAttributesBuffer","preRenderCallback","renderInternal_","subRenderPass","renderCount","usesInstancedRendering","instanceAttributesStride","tmpArray4","WebGLRenderTarget","framebuffer_","depthbuffer_","dataCacheDirty_","updateSize_","clearCachedData","readAll","readPixel","VectorUniforms","PATTERN_ORIGIN_X_DOUBLE","PATTERN_ORIGIN_Y_DOUBLE","PATTERN_SCALE_RATIO_DOUBLE","tmpCoords2","tmpMat4","RENDER_EXTENT","GLOBAL_ALPHA","WebGLVectorLayerRenderer","disableHitDetection","hitRenderTarget_","sourceRevision_","currentTransform_","currentFrameStateTransform_","styleVariables_","styleRenderer_","buffers_","batch_","initialFeaturesAdded_","sourceListenKeys_","addInitialFeatures_","handleSourceFeatureAdded_","handleSourceFeatureChanged_","handleSourceFeatureDelete_","handleSourceFeatureClear_","createRenderers_","applyUniforms_","batchInvertTransform","worldToViewTransform","geometryInvertTransform","setFromTransform","mat4FromTransform","applyVectorUniforms","startWorld","getWorldParameters","viewNotMoving","sourceChanged","BaseVector","disposeBuffers","forHitDetection","translateTransform","mult","colorDecodeId","disposeBuffersOfType","typeBuffers","DEFAULT_GRADIENT","DragAndDropEventType","DragAndDropEvent","file","setCenterAndRadius","getRadiusSquared_","geometries_","changeEventsKeys_","listenGeometriesChange_","unlistenGeometriesChange_","geometryCollection","cloneGeometries","geometriesArray","simplifiedGeometries","simplified","setGeometries","setGeometriesArray","getCoordinate","interpolateCoordinate","sharedUpdateInfo","closestTargetDistance","getTraceTargetUpdate","traceState","snapTolerance","newTargetIndex","newEndIndex","targetIndex","targets","minSegmentDistance","coordinateIndex","getPointSegmentRelationship","ring","newTarget","considerBothDirections","newCoordinate","startCoord","forwardDistance","getCumulativeSquaredDistance","reverseDistance","getTraceTargets","appendGeometryTraceTargets","appendTraceTarget","polys","getSquaredDistance","lowIndex","highIndex","lowWholeIndex","highWholeIndex","sharedRel","py","DrawEventType","DrawEvent","getDefaultStyleFunction","ExtentEventType","ExtentEvent","getDefaultExtentStyleFunction","getDefaultPointerStyleFunction","getPointHandler","fixedPoint","getEdgeHandler","fixedP1","fixedP2","readNumber","writeNumber","to5","differentNumber","tempSegment","ModifyEventType","getCoordinatesArray","depth","coordinatesArray","ModifyEvent","compareIndexes","projectedDistanceToSegmentDataSquared","pointCoordinates","segmentData","distanceToCenterSquared","squaredCoordinateDistance","distanceToCircumference","closestOnSegmentData","SelectEventType","SelectEvent","selected","deselected","originalFeatureStyles","Select","boundAddFeature_","addFeature_","boundRemoveFeature_","removeFeature_","addCondition_","addCondition","removeCondition_","removeCondition","toggleCondition_","toggleCondition","multi_","multi","filter_","hitTolerance_","features_","layerFilter_","featureLayerAssociation_","addFeatureLayerAssociation_","getHitTolerance","setHitTolerance","restorePreviousStyle_","applySelectedStyle_","findLayerOfFeature_","removeFeatureLayerAssociation_","selectFeature","deselectFeature","toggleFeature","clearSelection","SnapEventType","SnapEvent","vertex","vertexPixel","GEOMETRY_SEGMENTERS","segments","segmenter","getFeatureFromEvent","tempExtents","tempSegmentData","TranslateEventType","TranslateEvent","startCoordinate","flipXY","destOffset","FeatureFormat","defaultFeatureProjection","featureClass","getReadOptions","adaptOptions","readFeature","readGeometry","writeFeature","writeFeatures","writeGeometry","transformGeometryWithOptions","write","equivalentProjection","fromProjection","toProjection","transformExtentWithOptions","GeometryConstructor","createRenderFeature","orientFlatCoordinates","createGeometry","XMLFeature","readFeatureFromDocument","readFeatureFromNode","readFeaturesFromDocument","readFeaturesFromNode","ELEMENT_NODE","readGeometryFromDocument","readGeometryFromNode","readProjectionFromDocument","readProjectionFromNode","writeFeatureNode","serializeToString","writeFeaturesNode","writeGeometryNode","readBoolean","readBooleanString","readDateTime","dateTime","readDecimal","readDecimalString","readPositiveInteger","readNonNegativeIntegerString","readString","writeBooleanTextNode","bool","writeStringTextNode","writeCDATASection","createCDATASection","writeDateTimeTextNode","date","getUTCFullYear","getUTCMonth","getUTCDate","getUTCHours","getUTCMinutes","getUTCSeconds","writeDecimalTextNode","toPrecision","writeNonNegativeIntegerTextNode","nonNegativeInteger","whiteSpaceStart","whiteSpaceEnd","cdataCharacters","NAMESPACE_URIS","FEATURE_READER","rte","readRte","trk","readTrk","wpt","readWpt","GPX_PARSERS","LINK_PARSERS","AUTHOR_PARSERS","email","getAttribute","domain","parseLink","METADATA_PARSERS","desc","author","copyright","COPYRIGHT_PARSERS","keywords","bounds","minlat","minlon","maxlat","maxlon","extensions","parseExtensions","year","license","GPX_SERIALIZERS","RTE_SEQUENCE","RTE_SERIALIZERS","TRK_SEQUENCE","TRK_SERIALIZERS","writeWptType","RTE_PARSERS","cmt","rtept","RTEPT_PARSERS","rteValues","ele","TRK_PARSERS","trkseg","TRKSEG_PARSERS","trkpt","TRKPT_PARSERS","trkValues","WPT_PARSERS","magvar","geoidheight","sym","fix","sat","hdop","vdop","pdop","ageofdgpsdata","dgpsid","LINK_SEQUENCE","LINK_SERIALIZERS","writeLink","RTEPT_TYPE_SEQUENCE","TRKSEG_SERIALIZERS","TRKSEG_NODE_FACTORY","WPT_TYPE_SEQUENCE","WPT_TYPE_SERIALIZERS","GEOMETRY_TYPE_TO_NODENAME","GPX_NODE_FACTORY","layoutOptions","hasZ","hasM","applyLayoutOptions","setAttributeNS","JSONFeature","readFeatureFromObject","getObject","readFeaturesFromObject","readGeometryFromObject","readProjectionFromObject","writeFeatureObject","writeFeaturesObject","writeGeometryObject","readGeometryInternal","readPointGeometry","readLineStringGeometry","readPolygonGeometry","readMultiPointGeometry","readMultiLineStringGeometry","readMultiPolygonGeometry","readGeometryCollectionGeometry","geoJSON","writePointGeometry","writeLineStringGeometry","rightHanded","writePolygonGeometry","writeMultiPointGeometry","writeMultiLineStringGeometry","writeMultiPolygonGeometry","writeGeometryCollectionGeometry","TextFeature","readFeatureFromText","readFeaturesFromText","readGeometryFromText","readProjectionFromText","writeFeatureText","writeFeaturesText","writeGeometryText","B_RECORD_RE","H_RECORD_RE","HFDTE_RECORD_RE","HFDTEDATE_RECORD_RE","NEWLINE_RE","GX_NAMESPACE_URIS","ICON_ANCHOR_UNITS_MAP","insetPixels","PLACEMARK_PARSERS","ExtendedData","extendedDataParser","Region","regionParser","MultiGeometry","readMultiGeometry","readLineString","readLinearRing","readPoint","readPolygon","readStyle","StyleMap","styleMapValue","readStyleMapValue","placemarkObject","address","description","phoneNumber","styleUrl","readStyleURL","visibility","MultiTrack","GX_MULTITRACK_GEOMETRY_PARSERS","Track","readGxTrack","NETWORK_LINK_PARSERS","Link","readURI","CAMERA_PARSERS","Altitude","Longitude","Latitude","Tilt","AltitudeMode","Heading","Roll","REGION_PARSERS","LatLonAltBox","LAT_LON_ALT_BOX_PARSERS","regionObject","Lod","LOD_PARSERS","lodObject","KML_SEQUENCE","KML_SERIALIZERS","Document","DOCUMENT_SERIALIZERS","DOCUMENT_NODE_FACTORY","Placemark","writePlacemark","DEFAULT_COLOR","DEFAULT_IMAGE_STYLE_ANCHOR","DEFAULT_IMAGE_STYLE_ANCHOR_X_UNITS","DEFAULT_IMAGE_STYLE_ANCHOR_Y_UNITS","DEFAULT_IMAGE_STYLE_SIZE","DEFAULT_IMAGE_STYLE_SRC","DEFAULT_FILL_STYLE","DEFAULT_NO_IMAGE_STYLE","DEFAULT_IMAGE_STYLE","DEFAULT_TEXT_STROKE_STYLE","DEFAULT_TEXT_STYLE","TEXTAREA","DEFAULT_STYLE_ARRAY","scaleForSize","defaultIconUrlFunction","findStyle","styleValue","defaultStyle","sharedStyles","readColor","hexColor","substr","readFlatCoordinates","baseURI","readScale","STYLE_MAP_PARSERS","Pair","pairObject","PAIR_PARSERS","ICON_STYLE_PARSERS","iconObject","ICON_PARSERS","heading","hotSpot","xunits","yunits","LABEL_STYLE_PARSERS","LINE_STYLE_PARSERS","POLY_STYLE_PARSERS","outline","FLAT_LINEAR_RING_PARSERS","readFlatLinearRing","GX_TRACK_PARSERS","when","whens","gxTrackObject","GEOMETRY_FLAT_COORDINATES_PARSERS","readFlatCoordinatesFromNode","EXTRUDE_AND_ALTITUDE_MODE_PARSERS","extrude","tessellate","altitudeMode","MULTI_GEOMETRY_PARSERS","multiGeometry","homogeneous","setCommonGeometryProperties","FLAT_LINEAR_RINGS_PARSERS","innerBoundaryIs","innerBoundaryFlatLinearRings","INNER_BOUNDARY_IS_PARSERS","outerBoundaryIs","flatLinearRing","OUTER_BOUNDARY_IS_PARSERS","flatLinearRings","STYLE_PARSERS","IconStyle","styleObject","IconObject","drawIcon","iconUrlFunction_","resizeScale","LabelStyle","LineStyle","PolyStyle","extrudes","tessellates","altitudeModes","hasExtrude","hasTessellate","hasAltitudeMode","DATA_PARSERS","displayName","EXTENDED_DATA_PARSERS","Data","featureObject","SchemaData","SCHEMA_DATA_PARSERS","SimpleData","minAltitude","maxAltitude","south","east","west","minLodPixels","maxLodPixels","minFadeExtent","maxFadeExtent","writeColorTextNode","rgba","abgr","EXTENDEDDATA_NODE_SERIALIZERS","pair","DATA_NODE_FACTORY","ICON_SEQUENCE","ICON_SERIALIZERS","GX_NODE_FACTORY","ICON_STYLE_SEQUENCE","ICON_STYLE_SERIALIZERS","vec2","writeScaleTextNode","LABEL_STYLE_SEQUENCE","LABEL_STYLE_SERIALIZERS","LINE_STYLE_SEQUENCE","LINE_STYLE_SERIALIZERS","GEOMETRY_NODE_FACTORY","POINT_NODE_FACTORY","LINE_STRING_NODE_FACTORY","LINEAR_RING_NODE_FACTORY","POLYGON_NODE_FACTORY","MULTI_GEOMETRY_SERIALIZERS","writePrimitiveGeometry","writePolygon","writeMultiGeometry","factory","BOUNDARY_IS_SERIALIZERS","writeBoundaryIs","PLACEMARK_SERIALIZERS","namesAndValues","pointStyles","lineStyles","polyStyles","STYLE_SEQUENCE","STYLE_SERIALIZERS","PLACEMARK_SEQUENCE","EXTENDEDDATA_NODE_FACTORY","styleArray","writeStyles_","PRIMITIVE_GEOMETRY_SEQUENCE","PRIMITIVE_GEOMETRY_SERIALIZERS","POLY_STYLE_SEQUENCE","POLYGON_SERIALIZERS","INNER_BOUNDARY_NODE_FACTORY","OUTER_BOUNDARY_NODE_FACTORY","outerRing","POLY_STYLE_SERIALIZERS","iconProperties","SHIFT_LEFT_32","SHIFT_RIGHT_32","utf8TextDecoder","TextDecoder","Pbf","ArrayBuffer","isView","dataView","readFields","readField","readVarint","tag","startPos","skip","readMessage","readFixed32","getUint32","readSFixed32","getInt32","readFixed64","readSFixed64","readFloat","getFloat32","readDouble","getFloat64","isSigned","toNum","readVarintRemainder","readVarint64","readSVarint","subarray","str","b0","b3","bytesPerSequence","readUtf8","readBytes","readPackedVarint","readPackedEnd","readPackedSVarint","readPackedBoolean","readPackedFloat","readPackedDouble","readPackedFixed32","readPackedSFixed32","readPackedFixed64","readPackedSFixed64","writeTag","writeVarint","realloc","writeFixed32","setInt32","writeSFixed32","writeFixed64","writeSFixed64","pbf","writeBigVarintLow","lsb","writeBigVarintHigh","writeBigVarint","writeSVarint","writeBoolean","writeString","lead","writeUtf8","makeRoomForExtraLength","writeFloat","setFloat32","writeDouble","setFloat64","writeBytes","writeRawMessage","writeMessage","writePackedVarint","writePackedSVarint","writePackedBoolean","writePackedFloat","writePackedDouble","writePackedFixed32","writePackedSFixed32","writePackedFixed64","writePackedSFixed64","writeBytesField","writeFixed32Field","writeSFixed32Field","writeFixed64Field","writeSFixed64Field","writeVarintField","writeSVarintField","writeStringField","writeFloatField","writeDoubleField","writeBooleanField","extraLen","LN2","layersPBFReader","layerPBFReader","version","featurePBFReader","readRawFeature","WAY_PARSERS","nd","ndrefs","readTag","PARSERS","nodes","tags","NODE_PARSERS","way","ways","XML","read","readFromDocument","readFromNode","readHref","ServiceIdentification","SERVICE_IDENTIFICATION_PARSERS","ServiceProvider","SERVICE_PROVIDER_PARSERS","OperationsMetadata","OPERATIONS_METADATA_PARSERS","OWS","owsObject","ADDRESS_PARSERS","DeliveryPoint","City","AdministrativeArea","PostalCode","Country","ElectronicMailAddress","ALLOWED_VALUES_PARSERS","Value","CONSTRAINT_PARSERS","AllowedValues","CONTACT_INFO_PARSERS","Phone","PHONE_PARSERS","Address","DCP_PARSERS","HTTP","HTTP_PARSERS","REQUEST_METHOD_PARSERS","Post","OPERATION_PARSERS","DCP","Operation","Voice","Facsimile","Constraint","SERVICE_CONTACT_PARSERS","IndividualName","PositionName","ContactInfo","Abstract","AccessConstraints","Fees","Title","ServiceTypeVersion","ServiceType","ProviderName","ProviderSite","ServiceContact","encodeDeltas","numbers","lastNumbers","encodeSignedIntegers","decodeDeltas","decodeSignedIntegers","encodeUnsignedIntegers","decodeUnsignedIntegers","encodeUnsignedInteger","current","GEOMETRY_READERS","transformVertex","arcs","concatenateArcs","polyArray","ringCoords","indices","readFeaturesFromGeometryCollection","readFeatureFromGeometry","geometryReader","transformArc","GMLNS","ONLY_WHITESPACE_RE","GMLBase","featureType","featureNS","srsName","schemaLocation","FEATURE_COLLECTION_PARSERS","namespace","featureMember","readFeaturesInternal","featureMembers","defaultPrefix","ns","featureTypes","readFeatureElement","readGeometryOrExtent","GEOMETRY_PARSERS","readExtentElement","readGeometryElement","readFeatureElementInternal","asFeature","_content_","fid","readMultiPoint","MULTIPOINT_PARSERS","readMultiLineString","MULTILINESTRING_PARSERS","readMultiPolygon","MULTIPOLYGON_PARSERS","pointMemberParser","POINTMEMBER_PARSERS","lineStringMemberParser","LINESTRINGMEMBER_PARSERS","polygonMemberParser","POLYGONMEMBER_PARSERS","internalOptions","pointMember","pointMembers","lineStringMember","lineStringMembers","polygonMember","polygonMembers","RING_PARSERS","MULTIGEOMETRY_TO_MEMBER_NODENAME","MultiCurve","MultiSurface","GML2","containerSrs","coordsGroups","readBox","BOX_PARSERS_","innerBoundaryIsParser","outerBoundaryIsParser","GEOMETRY_NODE_FACTORY_","multiSurface","surface","multiCurve","writeFeatureElement","writeGeometryElement","writeCurveOrLineString","createCoordinatesNode_","writeCoordinates_","writeCurveSegments_","writeLineStringOrCurveMember","writeMultiCurveOrLineString","curve","LINESTRINGORCURVEMEMBER_SERIALIZERS","MULTIGEOMETRY_MEMBER_NODE_FACTORY_","GEOMETRY_SERIALIZERS","getCoords_","writeSurfaceOrPolygon","RING_SERIALIZERS","RING_NODE_FACTORY_","patches","writeSurfacePatches_","exteriorWritten","writeRing","writeLinearRing","writePoint","writeMultiPoint","POINTMEMBER_SERIALIZERS","writePointMember","writeMultiSurfaceOrPolygon","SURFACEORPOLYGONMEMBER_SERIALIZERS","writeSurfaceOrPolygonMember","writeEnvelope","ENVELOPE_SERIALIZERS","Box","Curve","Surface","Envelope","curveMember","surfaceMember","lowerCorner","upperCorner","GML3","surface_","curve_","multiCurve_","multiSurface_","readMultiCurve","MULTICURVE_PARSERS","readFlatCurveRing","readMultiSurface","MULTISURFACE_PARSERS","curveMemberParser","CURVEMEMBER_PARSERS","surfaceMemberParser","SURFACEMEMBER_PARSERS","readPatch","PATCHES_PARSERS","readSegment","SEGMENTS_PARSERS","readPolygonPatch","readLineStringSegment","interiorParser","exteriorParser","readSurface","SURFACE_PARSERS","readCurve","CURVE_PARSERS","readEnvelope","ENVELOPE_PARSERS","readFlatPos","readFlatPosList","contextDimension","dim","asXYZ","writePos_","srsDimension","writePosList_","posList","writeFeatureMembers_","geom","interior","exterior","curveMembers","surfaceMembers","PolygonPatch","LineStringSegment","Ring","GML32","Filter","tagName_","getTagName","LogicalNary","And","Bbox","boundedBy","member","TRANSACTION_SUMMARY_PARSERS","totalInserted","totalUpdated","totalDeleted","TRANSACTION_RESPONSE_PARSERS","TransactionSummary","readTransactionSummary","InsertResults","readInsertResults","QUERY_SERIALIZERS","PropertyName","TRANSACTION_SERIALIZERS","Insert","Update","writeUpdate","Delete","writeDelete","writeProperty","Native","writeNative","FEATURE_PREFIX","XMLNS","OGCNS","WFSNS","FESNS","SCHEMA_LOCATIONS","GML_FORMATS","serializeTransactionRequest","OGC_FID_PARSERS","FeatureId","fidParser","INSERT_RESULTS_PARSERS","gmlVersion","writeOgcFidFilter","getTypeName","featurePrefix","nativeElement","vendorId","safeToIgnore","GETFEATURE_SERIALIZERS","Query","writeQuery","During","writeDuringFilter","writeLogicalFilter","Or","writeNotFilter","BBOX","writeBboxFilter","Contains","writeSpatialFilter","Intersects","Within","DWithin","writeDWithinFilter","PropertyIsEqualTo","writeComparisonFilter","PropertyIsNotEqualTo","PropertyIsLessThan","PropertyIsLessThanOrEqualTo","PropertyIsGreaterThan","PropertyIsGreaterThanOrEqualTo","PropertyIsNull","writeIsNullFilter","PropertyIsBetween","writeIsBetweenFilter","PropertyIsLike","writeIsLikeFilter","Disjoint","ResourceId","propertyNames","typeNameAttr","getFilterNS","writeFilterCondition","writePropertyName","unit","writeExpression","propertyName","timePeriod","writeTimeInstant","matchCase","writeLiteral","lowerBoundary","upperBoundary","wildCard","singleChar","escapeChar","timeInstant","timePosition","writeGetFeature","OWS_NAMESPACE_URIS","Contents","CONTENTS_PARSERS","LAYER_PARSERS","TileMatrixSet","TMS_PARSERS","isDefault","Format","TileMatrixSetLink","TMS_LINKS_PARSERS","Dimension","DIMENSION_PARSERS","ResourceURL","resourceType","resource","WGS84BoundingBox","readBoundingBox","BoundingBox","WGS84_BBOX_READERS","Identifier","LegendURL","legend","TileMatrixSetLimits","TMS_LIMITS_LIST_PARSERS","TileMatrixLimits","TMS_LIMITS_PARSERS","TileMatrix","MinTileRow","MaxTileRow","MinTileCol","MaxTileCol","LowerCorner","readCoordinates","UpperCorner","WellKnownScaleSet","TM_PARSERS","SupportedCRS","TopLeftCorner","ScaleDenominator","TileWidth","TileHeight","MatrixWidth","MatrixHeight","events","FullScreenEventType","isFullScreenSupported","requestFullscreen","fullscreenEnabled","isFullScreen","fullscreenElement","requestFullScreen","PROJECTION","COORDINATE_FORMAT","MAX_RATIO","MIN_RATIO","UNITS_PROP","LEADING_DIGITS","DEFAULT_DPI","Direction","ol","$ol$Collection","_ol_Collection$CollectionEvent","$ol$DataTile","_ol_DataTile$asArrayLike","_ol_DataTile$asImageLike","_ol_DataTile$disposedError","_ol_DataTile$toArray","$ol$Disposable","$ol$Feature","_ol_Feature$createStyleFunction","Geolocation","position_","watchId_","handleProjectionChanged_","handleTrackingChanged_","setProjection","trackingOptions","setTrackingOptions","setTracking","tracking","getTracking","geolocation","watchPosition","positionChange_","positionError_","getTrackingOptions","clearWatch","accuracy","altitude","altitudeAccuracy","projectedPosition","speed","circularPolygon","getAccuracy","getAccuracyGeometry","getAltitude","getAltitudeAccuracy","getHeading","getSpeed","_ol_Geolocation$GeolocationError","$ol$Image","_ol_Image$decode","_ol_Image$decodeFallback","_ol_Image$listenImage","_ol_Image$load","$ol$ImageCanvas","$ol$ImageTile","$ol$Kinetic","$ol$Map","$ol$MapBrowserEvent","$ol$MapBrowserEventHandler","$ol$MapEvent","$ol$Object","_ol_Object$ObjectEvent","$ol$Observable","_ol_Observable$unByKey","$ol$Overlay","$ol$Tile","$ol$TileQueue","_ol_TileQueue$getTilePriority","$ol$TileRange","_ol_TileRange$createOrUpdate","VectorRenderTile","getSourceTiles","removeSourceTiles","executorGroups","loadingSourceTiles","hitDetectionImageData","replayState_","sourceTiles","errorTileKeys","wantedResolution","removeSourceTiles_","hasContext","getReplayState","renderedRenderOrder","renderedRevision","renderedTileResolution","renderedTileRevision","renderedTileZ","$ol$View","_ol_View$createCenterConstraint","_ol_View$createResolutionConstraint","_ol_View$createRotationConstraint","_ol_View$isNoopAnimation","withExtentCenter","withHigherResolutions","highest","withLowerResolutions","lowest","withZoom","_ol_array$ascending","_ol_array$binarySearch","_ol_array$descending","_ol_array$equals","_ol_array$extend","_ol_array$isSorted","_ol_array$linearFindNearest","_ol_array$reverseSubArray","stableSort","compareFnc","asserts","_ol_asserts$assert","centerconstraint","_ol_centerconstraint$createExtent","_ol_centerconstraint$none","_ol_color$NO_COLOR","_ol_color$asArray","_ol_color$asString","_ol_color$fromString","isStringColor","_ol_color$lchaToRgba","_ol_color$rgbaToLcha","_ol_color$toString","_ol_color$withAlpha","colorlike","_ol_colorlike$asColorLike","_ol_console$error","setLevel","_ol_console$warn","$ol$control$Attribution","$ol$control$Control","FullScreen","source_","isInFullscreen_","boundHandleMapTargetChange_","handleMapTargetChange_","cssClassName_","documentListeners_","activeClassName_","activeClassName","inactiveClassName_","inactiveClassName","labelNode_","labelActive","labelActiveNode_","button_","setClassName_","handleFullScreen_","exitFullscreen","exitFullScreen","requestFullScreenWithKeys","handleFullScreenChange_","wasInFullscreen","fullscreen","oldMap","MousePosition","coordinateFormat","setCoordinateFormat","renderOnMouseOut_","placeholder","placeholder_","renderedHTML_","mapProjection_","getCoordinateFormat","handleMouseMove","updateHTML_","handleMouseOut","html","OverviewMap","boundHandleRotationChanged_","handleRotationChanged_","viewExtent_","ovmapDiv_","view_","ovmap","ovmap_","boxSizing","boxOverlay_","overlayBox","move","mousePosition","endMoving","oldView","unbindView_","handleMapPropertyChange_","bindView_","updateBoxAfterOvmapIsRendered_","newView","resetExtent_","validateExtent_","ovmapSize","ovextent","topLeftPixel","bottomRightPixel","boxWidth","boxHeight","ovmapWidth","ovmapHeight","recenter_","ovview","updateBox_","ovresolution","ovmapPostrenderKey_","getOverviewMap","$ol$control$Rotate","ScaleLine","bar","innerElement_","viewState_","minWidth_","minWidth","maxWidth_","maxWidth","renderedWidth_","handleUnitsChanged_","setUnits","scaleBar_","scaleBarSteps_","scaleBarText_","dpi_","setDpi","pointResolutionUnits","nominalCount","suffix","metersPerDegree","decimalCount","previousWidth","previousDecimalCount","previousCount","createScaleBar","resolutionScale","getScaleForResolution","mapScale","toLocaleString","stepWidth","scaleSteps","createMarker","cls","createStepText","isLast","lengthString","$ol$control$Zoom","ZoomSlider","currentResolution_","direction_","heightLimit_","widthLimit_","startX_","startY_","thumbSize_","sliderInitialized_","thumbElement","containerElement","handleDraggerStart_","handleDraggerDrag_","handleDraggerEnd_","handleContainerClick_","initSlider_","containerWidth","containerHeight","containerStyle","thumb","thumbStyle","thumbWidth","thumbHeight","relativePosition","getRelativePosition_","getResolutionForPosition_","drag","setThumbPosition_","getPositionForResolution_","amount","ZoomToExtent","fitOptions","handleZoomToExtent","_ol_control_defaults$defaults","_ol_coordinate$add","_ol_coordinate$angleBetween","_ol_coordinate$closestOnCircle","_ol_coordinate$closestOnSegment","createStringXY","_ol_coordinate$degreesToStringHDMS","_ol_coordinate$distance","_ol_coordinate$equals","_ol_coordinate$format","_ol_coordinate$getWorldsAway","_ol_coordinate$rotate","_ol_coordinate$scale","_ol_coordinate$squaredDistance","_ol_coordinate$squaredDistanceToSegment","toStringHDMS","_ol_coordinate$toStringXY","_ol_coordinate$wrapX","css","_ol_css$CLASS_COLLAPSED","_ol_css$CLASS_CONTROL","_ol_css$CLASS_HIDDEN","_ol_css$CLASS_SELECTABLE","_ol_css$CLASS_UNSELECTABLE","_ol_css$CLASS_UNSUPPORTED","_ol_css$fontWeights","_ol_css$getFontParameters","dom","_ol_dom$createCanvasContext2D","_ol_dom$createMockDiv","_ol_dom$getSharedCanvasContext2D","_ol_dom$isCanvas","_ol_dom$outerHeight","_ol_dom$outerWidth","_ol_dom$releaseCanvas","_ol_dom$removeChildren","_ol_dom$replaceChildren","_ol_dom$replaceNode","_ol_easing$easeIn","_ol_easing$easeOut","_ol_easing$inAndOut","_ol_easing$linear","upAndDown","$ol$events$Event","_ol_events_Event$stopPropagation","_ol_events_SnapEvent$SnapEvent","$ol$events$Target","_ol_events_condition$all","_ol_events_condition$altKeyOnly","_ol_events_condition$altShiftKeysOnly","_ol_events_condition$always","click","doubleClick","_ol_events_condition$focus","_ol_events_condition$focusWithTabindex","_ol_events_condition$mouseActionButton","_ol_events_condition$mouseOnly","_ol_events_condition$never","_ol_events_condition$noModifierKeys","penOnly","pointerEvt","_ol_events_condition$platformModifierKey","platformModifierKeyOnly","pointerMove","_ol_events_condition$primaryAction","_ol_events_condition$shiftKeyOnly","_ol_events_condition$singleClick","_ol_events_condition$targetNotEditable","touchOnly","_ol_events$listen","_ol_events$listenOnce","_ol_events$unlistenByKey","expr","cpu","_ol_expr_cpu$buildExpression","_ol_expr_cpu$newEvaluationContext","_ol_expr_expression$AnyType","_ol_expr_expression$BooleanType","_ol_expr_expression$CallExpression","_ol_expr_expression$ColorType","_ol_expr_expression$LiteralExpression","NoneType","_ol_expr_expression$NumberArrayType","_ol_expr_expression$NumberType","_ol_expr_expression$Ops","_ol_expr_expression$SizeType","_ol_expr_expression$StringType","_ol_expr_expression$computeGeometryType","_ol_expr_expression$includesType","_ol_expr_expression$isType","_ol_expr_expression$newParsingContext","overlapsType","oneType","otherType","_ol_expr_expression$parse","_ol_expr_expression$typeName","gpu","_ol_expr_gpu$FEATURE_ID_PROPERTY_NAME","_ol_expr_gpu$GEOMETRY_TYPE_PROPERTY_NAME","_ol_expr_gpu$PALETTE_TEXTURE_ARRAY","_ol_expr_gpu$UNDEFINED_PROP_VALUE","_ol_expr_gpu$arrayToGlsl","_ol_expr_gpu$buildExpression","_ol_expr_gpu$colorToGlsl","_ol_expr_gpu$getStringNumberEquivalent","_ol_expr_gpu$newCompilationContext","_ol_expr_gpu$numberToGlsl","_ol_expr_gpu$sizeToGlsl","_ol_expr_gpu$stringToGlsl","_ol_expr_gpu$uniformNameForVariable","_ol_extent$applyTransform","_ol_extent$approximatelyEquals","_ol_extent$boundingExtent","_ol_extent$buffer","_ol_extent$clone","_ol_extent$closestSquaredDistanceXY","_ol_extent$containsCoordinate","_ol_extent$containsExtent","_ol_extent$containsXY","_ol_extent$coordinateRelationship","_ol_extent$createEmpty","_ol_extent$createOrUpdate","_ol_extent$createOrUpdateEmpty","_ol_extent$createOrUpdateFromCoordinate","createOrUpdateFromCoordinates","_ol_extent$createOrUpdateFromFlatCoordinates","createOrUpdateFromRings","_ol_extent$equals","_ol_extent$extend","_ol_extent$extendCoordinate","_ol_extent$extendCoordinates","_ol_extent$extendFlatCoordinates","_ol_extent$extendRings","_ol_extent$extendXY","_ol_extent$forEachCorner","_ol_extent$getArea","_ol_extent$getBottomLeft","_ol_extent$getBottomRight","_ol_extent$getCenter","_ol_extent$getCorner","getEnlargedArea","_ol_extent$getForViewAndSize","_ol_extent$getHeight","_ol_extent$getIntersection","getIntersectionArea","getMargin","_ol_extent$getRotatedViewport","_ol_extent$getTopLeft","_ol_extent$getTopRight","_ol_extent$getWidth","_ol_extent$intersects","_ol_extent$intersectsSegment","_ol_extent$isEmpty","_ol_extent$returnOrUpdate","_ol_extent$scaleFromCenter","_ol_extent$wrapAndSliceX","_ol_extent$wrapX","featureloader","_ol_featureloader$loadFeaturesXhr","setWithCredentials","xhrWithCredentials","_ol_featureloader$xhr","$ol$format$Feature","_ol_format_Feature$createGeometry","_ol_format_Feature$createRenderFeature","_ol_format_Feature$transformExtentWithOptions","_ol_format_Feature$transformGeometryWithOptions","GPX","readExtensions_","readExtensions","handleReadExtensions_","extensionsNode","readMetadata","readMetadataFromDocument","readMetadataFromNode","metadata","featureReader","gpx","GeoJSON","extractGeometryName_","extractGeometryName","geoJSONFeature","geoJSONFeatures","geometryObject","objects","IGC","altitudeMode_","lad_","lod_","ladStart_","ladStop_","lodStart_","lodStop_","month","day","lastDateTime","hour","minute","second","UTC","numberAdds","addCode","addStart","addStop","$ol$format$JSONFeature","KML","defaultStyle_","extractStyles_","extractStyles","writeStyles","sharedStyles_","showPointNames_","showPointNames","iconUrlFunction","readDocumentOrFolder_","Folder","readPlacemark_","readSharedStyle_","readSharedStyleMap_","drawName","multiGeometryPoints","featureStyle","nameStyle","foundStyle","textOffset","createNameStyleFunction","createFeatureStyleFunction","styleUri","fs","readName","readNameFromDocument","readNameFromNode","readNetworkLinks","networkLinks","readNetworkLinksFromDocument","readNetworkLinksFromNode","readRegion","regions","readRegionFromDocument","readRegionFromNode","readCamera","cameras","readCameraFromDocument","readCameraFromNode","kml","xmlnsUri","getDefaultFillStyle","getDefaultImageStyle","getDefaultStrokeStyle","getDefaultStyle","getDefaultStyleArray","getDefaultTextStyle","_ol_format_KML$readFlatCoordinates","MVT","layerName_","layerName","idProperty_","idProperty","readRawGeometry_","cmd","coordsLen","currentEnd","cmdLen","createFeature_","rawFeature","getGeometryType","ctor","PBF","pbfLayers","pbfLayer","OSMXML","$ol$format$OWS","Polyline","factor_","geometryLayout_","geometryLayout","_ol_format_Polyline$decodeDeltas","decodeFloats","_ol_format_Polyline$decodeSignedIntegers","_ol_format_Polyline$decodeUnsignedIntegers","_ol_format_Polyline$encodeDeltas","encodeFloats","_ol_format_Polyline$encodeSignedIntegers","_ol_format_Polyline$encodeUnsignedInteger","_ol_format_Polyline$encodeUnsignedIntegers","$ol$format$TextFeature","TopoJSON","topoJSONTopology","transformArcs","topoJSONFeatures","objectName","WFS","version_","featureType_","featureNS_","gmlFormat_","gmlFormat","schemaLocation_","getFeatureType","setFeatureType","featuresNS","readTransactionResponse","readTransactionResponseFromDocument","readTransactionResponseFromNode","readFeatureCollectionMetadata","readFeatureCollectionMetadataFromDocument","readFeatureCollectionMetadataFromNode","handle","outputFormat","maxFeatures","resultType","viewParams","combineBboxAndFilter","completeFilter","bboxFilter","bboxFilterFn","Function","andFilterFn","writeTransaction","inserts","updates","deletes","baseObj","gmlOptions","createTransactionRequest","nativeElements","writeFilter","WMSGetFeatureInfo","readFeatures_","layerElement","toRemove","layerFeatures","gmlFeatures","WMTSCapabilities","owsParser_","WMTSCapabilityObject","xlink","_ol_format_xlink$readHref","xsd","_ol_format_xsd$readBoolean","_ol_format_xsd$readBooleanString","_ol_format_xsd$readDateTime","_ol_format_xsd$readDecimal","_ol_format_xsd$readDecimalString","_ol_format_xsd$readNonNegativeIntegerString","_ol_format_xsd$readPositiveInteger","_ol_format_xsd$readString","_ol_format_xsd$writeBooleanTextNode","_ol_format_xsd$writeCDATASection","_ol_format_xsd$writeDateTimeTextNode","_ol_format_xsd$writeDecimalTextNode","_ol_format_xsd$writeNonNegativeIntegerTextNode","_ol_format_xsd$writeStringTextNode","_ol_functions$FALSE","_ol_functions$TRUE","_ol_functions$VOID","_ol_functions$memoizeOne","_ol_functions$toPromise","$ol$geom$Circle","$ol$geom$Geometry","$ol$geom$GeometryCollection","$ol$geom$LineString","$ol$geom$LinearRing","$ol$geom$MultiLineString","$ol$geom$MultiPoint","$ol$geom$MultiPolygon","$ol$geom$Point","$ol$geom$Polygon","_ol_geom_Polygon$circular","_ol_geom_Polygon$fromCircle","_ol_geom_Polygon$fromExtent","_ol_geom_Polygon$makeRegular","$ol$geom$SimpleGeometry","_ol_geom_SimpleGeometry$getLayoutForStride","_ol_geom_SimpleGeometry$getStrideForLayout","_ol_geom_SimpleGeometry$transformGeom2D","_ol_geom_flat_area$linearRing","_ol_geom_flat_area$linearRings","_ol_geom_flat_area$linearRingss","_ol_geom_flat_center$linearRingss","closest","_ol_geom_flat_closest$arrayMaxSquaredDelta","_ol_geom_flat_closest$assignClosestArrayPoint","_ol_geom_flat_closest$assignClosestMultiArrayPoint","_ol_geom_flat_closest$assignClosestPoint","_ol_geom_flat_closest$maxSquaredDelta","_ol_geom_flat_closest$multiArrayMaxSquaredDelta","_ol_geom_flat_contains$linearRingContainsExtent","_ol_geom_flat_contains$linearRingContainsXY","_ol_geom_flat_contains$linearRingsContainsXY","_ol_geom_flat_contains$linearRingssContainsXY","deflate","_ol_geom_flat_deflate$deflateCoordinate","_ol_geom_flat_deflate$deflateCoordinates","_ol_geom_flat_deflate$deflateCoordinatesArray","_ol_geom_flat_deflate$deflateMultiCoordinatesArray","flip","_ol_geom_flat_flip$flipXY","geodesic","greatCircleArc","geoProjection","cosLat1","sinLat1","cosLat2","sinLat2","cosDeltaLon","sinDeltaLon","D","cosD","sinD","_ol_geom_flat_geodesic$meridian","_ol_geom_flat_geodesic$parallel","inflate","_ol_geom_flat_inflate$inflateCoordinates","_ol_geom_flat_inflate$inflateCoordinatesArray","_ol_geom_flat_inflate$inflateMultiCoordinatesArray","interiorpoint","_ol_geom_flat_interiorpoint$getInteriorPointOfArray","_ol_geom_flat_interiorpoint$getInteriorPointsOfMultiArray","_ol_geom_flat_interpolate$interpolatePoint","_ol_geom_flat_interpolate$lineStringCoordinateAtM","_ol_geom_flat_interpolate$lineStringsCoordinateAtM","intersectsextent","_ol_geom_flat_intersectsextent$intersectsLineString","_ol_geom_flat_intersectsextent$intersectsLineStringArray","_ol_geom_flat_intersectsextent$intersectsLinearRing","_ol_geom_flat_intersectsextent$intersectsLinearRingArray","_ol_geom_flat_intersectsextent$intersectsLinearRingMultiArray","_ol_geom_flat_length$lineStringLength","linearRingLength","perimeter","orient","_ol_geom_flat_orient$inflateEnds","_ol_geom_flat_orient$linearRingIsClockwise","_ol_geom_flat_orient$linearRingsAreOriented","_ol_geom_flat_orient$linearRingssAreOriented","_ol_geom_flat_orient$orientLinearRings","_ol_geom_flat_orient$orientLinearRingsArray","_ol_geom_flat_reverse$coordinates","_ol_geom_flat_segments$forEach","_ol_geom_flat_segments$getIntersectionPoint","_ol_geom_flat_simplify$douglasPeucker","_ol_geom_flat_simplify$douglasPeuckerArray","douglasPeuckerMultiArray","_ol_geom_flat_simplify$quantize","_ol_geom_flat_simplify$quantizeArray","_ol_geom_flat_simplify$quantizeMultiArray","_ol_geom_flat_simplify$radialDistance","simplifyLineString","highQuality","_ol_geom_flat_simplify$snap","straightchunk","_ol_geom_flat_straightchunk$matchingChunk","textpath","_ol_geom_flat_textpath$drawTextOnPath","topology","lineStringIsClosed","lastCoord","_ol_geom_flat_transform$rotate","_ol_geom_flat_transform$scale","_ol_geom_flat_transform$transform2D","_ol_geom_flat_transform$translate","_ol_has$CREATE_IMAGE_BITMAP","_ol_has$DEVICE_PIXEL_RATIO","_ol_has$IMAGE_DECODE","_ol_has$MAC","_ol_has$PASSIVE_EVENT_LISTENERS","_ol_has$SAFARI","_ol_has$SAFARI_BUG_237906","_ol_has$WEBKIT","_ol_has$WORKER_OFFSCREEN_CANVAS","DblClickDragZoom","opt_options","scaleDeltaByPixel_","handlingDownUpSequence_","handlingDoubleDownSequence_","doubleTapTimeoutId_","trackedPointers_","waitForDblTap_","isPointerDraggingEvent","$ol$interaction$DoubleClickZoom","DragAndDrop","readAsBuffer_","formats_","formatConstructors","dropListenKeys_","handleResult_","formats","tryReadFeatures_","registerListeners_","dropArea","handleDrop","handleStop","unregisterListeners_","files","dataTransfer","reader","FileReader","readAsArrayBuffer","readAsText","dropEffect","_ol_interaction_DragAndDrop$DragAndDropEvent","$ol$interaction$DragBox","_ol_interaction_DragBox$DragBoxEvent","$ol$interaction$DragPan","$ol$interaction$DragRotate","DragRotateAndZoom","lastMagnitude_","magnitude","angleDelta","$ol$interaction$DragZoom","Draw","options_","shouldHandle_","downPx_","downTimeout_","lastDragTime_","pointerType_","freehand_","snapTolerance_","getMode","stopClick_","stopClick","ignoreNextUpEvent_","minPoints_","minPoints","maxPoints_","maxPoints","finishCondition_","finishCondition","geometryFunction","squaredLength","dragVertexDelay_","dragVertexDelay","finishCoordinate_","sketchFeature_","sketchPoint_","sketchCoords_","sketchLine_","sketchLineCoords_","squaredClickTolerance_","clickTolerance","overlay_","freehandCondition_","freehand","freehandCondition","traceCondition_","setTrace","trace","traceState_","traceSource_","traceSource","updateState_","setFreehand","getOverlay","getFreehand","addToDrawing_","startDrawing_","deactivateTrace_","toggleTraceState_","addOrRemoveTracedCoordinates_","previouslyForward","addTracedCoordinates_","removeTracedCoordinates_","fromIndex","toIndex","removeLastPoints_","appendCoordinates","updateTrace_","updatedTraceTarget","oldTarget","tracing","startingToDraw","finishDrawing","atFinish_","abortDrawing","downPx","clickPx","modifyDrawing_","createOrUpdateSketchPoint_","at","potentiallyDone","potentiallyFinishCoordinates","sketchCoords","finishCoordinate","finishPixel","updateSketchFeatures_","createOrUpdateCustomSketchLine_","sketchLineGeom","removeLastPoint","sketchFeature","abortDrawing_","newDrawing","ending","sketchFeatures","overlaySource","_ol_interaction_Draw$DrawEvent","createBox","boxCoordinates","createRegularPolygon","internalAngle","Extent","createCondition_","createCondition","drag_","pointerHandler_","pixelTolerance_","pixelTolerance","snappedToVertex_","extentFeature_","vertexFeature_","extentOverlay_","boxStyle","vertexOverlay_","pointerStyle","snapToVertex_","pixelCoordinate","sortByDistance","getExtentInternal","getSegments","closestSegment","coordinateDistance","pixel1","pixel2","squaredDist1","squaredDist2","dist","draggable","updatePointerFeature_","noVertexFeature_","createOrUpdateExtentFeature_","extentFeature","createIfNotExists","vertexFeature","getOpposingPoint","x_","y_","getDragHandler","_ol_interaction_Extent$ExtentEvent","$ol$interaction$Interaction","_ol_interaction_Interaction$pan","_ol_interaction_Interaction$zoomByDelta","$ol$interaction$KeyboardPan","$ol$interaction$KeyboardZoom","animationOptions","animationOptions_","params_","replace_","prefix_","initial_","trackedCallbacks_","trackedValues_","getParamName_","get_","set_","delete_","updateUrl_","handleChangeLayerGroup_","history","replaceState","updateView","viewProperties","layersParam","track","updateHistory_","visibilities","pushState","Modify","handleSourceAdd_","handleSourceRemove_","handleExternalCollectionAdd_","handleExternalCollectionRemove_","defaultDeleteCondition_","deleteCondition_","deleteCondition","insertVertexCondition_","insertVertexCondition","vertexSegments_","lastCoordinate_","ignoreNextSingleClick_","featuresBeingModified_","rBush_","changingFeature_","dragSegments_","SEGMENT_WRITERS_","writePointGeometry_","writeLineStringGeometry_","writePolygonGeometry_","writeMultiPointGeometry_","writeMultiLineStringGeometry_","writeMultiPolygonGeometry_","writeCircleGeometry_","writeGeometryCollectionGeometry_","traceSegments_","hitDetection_","filterFunctionWasSupplied_","coordinatesEqual_","sharedVerticesEqual","hitDetection","lastPointerEvent_","snapToPointer_","snapToPointer","writer","handlePointerAtPixel_","willModifyFeatures_","itemIndex","removeFeatureSegmentData_","rBush","nodesToRemove","nodeToRemove","externalAddFeatureHandler_","externalRemoveFeatureHandler_","centerSegmentData","circumferenceSegmentData","featureSegments","createOrUpdateVertexFeature_","removePoint","findInsertVerticesAndUpdateDragSegments_","insertVertices","vertexExtent","segmentDataMatches","componentSegments","segmentDataMatch","closestVertex","traceSegment","getTraceCandidates_","removeIndex","newCoordinates","insertIndex","updateGeometry_","dragSegment","mRing","mTargetIndex","setGeometryCoordinates_","startTraceCoord","insertVertex_","hitPointGeometry","bufferExtent","vertexSegments","geometryUid","rTree","updateSegmentIndices_","newSegmentData","newSegmentData2","updatePointer_","canRemovePoint","removeVertex_","dragSegments","segmentsByFeature","component","newIndex","deleted","canInsertPoint","insertPoint","_ol_interaction_Modify$ModifyEvent","$ol$interaction$MouseWheelZoom","$ol$interaction$PinchRotate","$ol$interaction$PinchZoom","Pointer","$ol$interaction$Pointer","_ol_interaction_Pointer$centroid","$ol$interaction$Select","_ol_interaction_Select$SelectEvent","Snap","vertex_","edge_","intersection_","featuresListenerKeys_","featureChangeListenerKeys_","indexedFeaturesExtents_","pendingFeatures_","snapped_","segmenters_","segmenters","feature_uid","segmentCount","otherSegment","intersectionSegment","intersectionFeature","otherSegments","getFeatures_","areSnapDataEqual_","data1","data2","snapTo","handleFeatureAdd_","handleFeatureRemove_","updateFeature_","featuresToUpdate","unregister","currentMap","projectedCoordinate","segmentsLength","squaredPixelTolerance","getResult","segmentStart","segmentEnd","Translate","startCoordinate_","lastFeature_","handleActiveChanged_","featuresAtPixel_","newViewCoordinate","lastViewCoordinate","_ol_interaction_Translate$TranslateEvent","_ol_interaction_defaults$defaults","Base","$ol$layer$Base","BaseImage","$ol$layer$BaseImage","BaseTile","$ol$layer$BaseTile","$ol$layer$BaseVector","Graticule","maxLines","targetSize","showLabels","lonLabelFormatter","latLabelFormatter","lonLabelPosition","latLabelPosition","lonLabelStyle","latLabelStyle","intervals","maxLat_","maxLon_","minLat_","minLon_","maxX_","maxY_","minX_","minY_","targetSize_","maxLines_","meridians_","parallels_","strokeStyle_","fromLonLatTransform_","toLonLatTransform_","projectionCenterLonLat_","bottomLeft_","bottomRight_","topLeft_","topRight_","meridiansLabels_","parallelsLabels_","lonLabelFormatter_","latLabelFormatter_","lonLabelPosition_","latLabelPosition_","lonLabelStyleBase_","lonLabelStyle_","latLabelStyleBase_","latLabelStyle_","drawLabels_","intervals_","loaderFunction","strategyFunction","featurePool_","lineStyle_","loadedExtent_","realWorldExtent","updateProjectionInfo_","createGraticule_","featuresColl","poolIndex","addMeridian_","minLat","maxLat","getMeridian_","addParallel_","minLon","maxLon","getParallel_","rotationCenter","rotationExtent","unrotatedWidth","unrotatedHeight","labelsAtStart","vectorContext","textPoint","getMeridianPoint_","getParallelPoint_","interval","getInterval_","validCenterP","centerLonLat","centerLon","centerLat","cnt","validExtentP","validExtent","clampedLat","clampedBottom","clampedTop","getMeridians","clampedLeft","clampedRight","getParallels","epsg4326Projection","toLonLatTransform","lonLatCoordinates","worldExtentP","Group","$ol$layer$Group","_ol_layer_Group$GroupEvent","Heatmap","gradient","blur","gradient_","handleGradientChanged_","setGradient","setBlur","weight_","getBlur","getGradient","createLinearGradient","addColorStop","createGradient","previousValue","setFilter","setWeight","filterParsingContext","filterCompiled","radiusCompiled","blurCompiled","blurRadiusUniforms","weightAttribute","weightExpression","weightFunction","weightValue","blurSlopeExpr","u_gradientTexture","u_opacity","updateStyleVariables","$ol$layer$Image","$ol$layer$Layer","_ol_layer_Layer$inView","$ol$layer$Tile","Vector","$ol$layer$Vector","VectorImage","imageRatio","imageRatio_","loadingstrategy","_ol_loadingstrategy$all","math","_ol_math$ceil","_ol_math$clamp","_ol_math$floor","_ol_math$lerp","_ol_math$modulo","_ol_math$round","_ol_math$solveLinearSystem","_ol_math$squaredDistance","_ol_math$squaredSegmentDistance","_ol_math$toDegrees","_ol_math$toFixed","_ol_math$toRadians","_ol_math$wrap","net","_ol_net$ClientError","_ol_net$ResponseError","_ol_net$getJSON","_ol_net$jsonp","overrideXHR","globalThis","_ol_net$resolveUrl","restoreXHR","_ol_obj$clear","_ol_obj$isEmpty","$ol$proj$Projection","Units","_ol_proj_Units$METERS_PER_UNIT","fromCode","_ol_proj$addCommon","_ol_proj$addCoordinateTransforms","_ol_proj$addEquivalentProjections","_ol_proj$addEquivalentTransforms","_ol_proj$addProjection","_ol_proj$addProjections","clearAllProjections","clearProj","clearTransformFuncs","clearUserProjection","_ol_proj$cloneTransform","_ol_proj$createProjection","_ol_proj$createSafeCoordinateTransform","_ol_proj$createTransformFromCoordinateTransform","_ol_proj$disableCoordinateWarning","epsg3857","_ol_proj_epsg3857$EXTENT","_ol_proj_epsg3857$HALF_SIZE","_ol_proj_epsg3857$MAX_SAFE_Y","_ol_proj_epsg3857$PROJECTIONS","_ol_proj_epsg3857$RADIUS","_ol_proj_epsg3857$WORLD_EXTENT","_ol_proj_epsg3857$fromEPSG4326","_ol_proj_epsg3857$toEPSG4326","epsg4326","_ol_proj_epsg4326$EXTENT","_ol_proj_epsg4326$METERS_PER_UNIT","_ol_proj_epsg4326$PROJECTIONS","_ol_proj_epsg4326$RADIUS","_ol_proj$equivalent","_ol_proj$fromUserCoordinate","_ol_proj$fromUserExtent","_ol_proj$fromUserResolution","_ol_proj$get","_ol_proj$getPointResolution","_ol_proj$getTransform","_ol_proj$getTransformFromProjections","_ol_proj$getUserProjection","_ol_proj$identityTransform","epsgLookupMapTiler","results","defaultTransform","fromEPSGCode","_ol_proj_proj4$fromProjectionCode","getEPSGLookup","getProjectionCodeLookup","isRegistered","_ol_proj_proj4$register","setEPSGLookup","setProjectionCodeLookup","_ol_proj_projections$add","_ol_proj_projections$clear","_ol_proj_projections$get","_ol_proj$setUserProjection","_ol_proj$toLonLat","_ol_proj$toUserCoordinate","_ol_proj$toUserExtent","_ol_proj$toUserResolution","_ol_proj$transform","_ol_proj$transformExtent","transformWithProjections","destinationProjection","_ol_proj_transforms$add","_ol_proj_transforms$clear","_ol_proj_transforms$get","useGeographic","utm","_ol_proj_utm$makeProjection","_ol_proj_utm$makeTransforms","_ol_proj_utm$zoneFromCode","$ol$render$Box","$ol$render$Event","$ol$render$Feature","toFeature","_ol_render_Feature$toGeometry","$ol$render$VectorContext","$ol$render$canvas$Builder","$ol$render$canvas$BuilderGroup","$ol$render$canvas$Executor","$ol$render$canvas$ExecutorGroup","_ol_render_canvas_ExecutorGroup$ALL","_ol_render_canvas_ExecutorGroup$DECLUTTER","_ol_render_canvas_ExecutorGroup$NON_DECLUTTER","_ol_render_canvas_ExecutorGroup$getPixelIndexArray","$ol$render$canvas$ImageBuilder","Immediate","$ol$render$canvas$Immediate","_ol_render_canvas_Instruction$beginPathInstruction","_ol_render_canvas_Instruction$closePathInstruction","_ol_render_canvas_Instruction$fillInstruction","_ol_render_canvas_Instruction$strokeInstruction","$ol$render$canvas$LineStringBuilder","$ol$render$canvas$PolygonBuilder","$ol$render$canvas$TextBuilder","_ol_render_canvas_TextBuilder$TEXT_ALIGN","$ol$render$canvas$ZIndexContext","_ol_render_canvas$checkedFonts","_ol_render_canvas$defaultFillStyle","_ol_render_canvas$defaultFont","_ol_render_canvas$defaultLineCap","_ol_render_canvas$defaultLineDash","defaultLineDashOffset","_ol_render_canvas$defaultLineJoin","defaultLineWidth","_ol_render_canvas$defaultMiterLimit","_ol_render_canvas$defaultPadding","defaultStrokeOffset","_ol_render_canvas$defaultStrokeStyle","_ol_render_canvas$defaultTextAlign","_ol_render_canvas$defaultTextBaseline","_ol_render_canvas$drawImageOrLabel","_ol_render_canvas$getTextDimensions","hitdetect","_ol_render_canvas_hitdetect$HIT_DETECT_RESOLUTION","_ol_render_canvas_hitdetect$createHitDetectionImageData","_ol_render_canvas_hitdetect$hitDetect","_ol_render_canvas$measureAndCacheTextWidth","_ol_render_canvas$measureTextHeight","_ol_render_canvas$measureTextWidth","_ol_render_canvas$registerFont","rotateAtOffset","_ol_render_canvas_style$buildRuleSet","_ol_render_canvas_style$buildStyle","_ol_render_canvas_style$flatStylesToStyleFunction","_ol_render_canvas_style$rulesToStyleFunction","_ol_render_canvas$textHeights","getRenderPixel","_ol_render$getVectorContext","toContext","scaleTransform","Composite","$ol$renderer$Composite","$ol$renderer$Layer","$ol$renderer$Map","$ol$renderer$canvas$ImageLayer","$ol$renderer$canvas$Layer","_ol_renderer_canvas_Layer$canvasPool","$ol$renderer$canvas$TileLayer","VectorImageLayer","$ol$renderer$canvas$VectorImageLayer","$ol$renderer$canvas$VectorLayer","vector","_ol_renderer_vector$defaultOrder","_ol_renderer_vector$getSquaredTolerance","_ol_renderer_vector$getTolerance","_ol_renderer_vector$renderFeature","$ol$reproj$DataTile","$ol$reproj$Image","$ol$reproj$Tile","$ol$reproj$Triangulation","_ol_reproj$calculateSourceExtentResolution","_ol_reproj$calculateSourceResolution","_ol_reproj$canvasPool","common","_ol_reproj_common$ERROR_THRESHOLD","glreproj","_ol_reproj_glreproj$canvasGLPool","_ol_reproj_glreproj$createCanvasContextWebGL","_ol_reproj_glreproj$releaseGLCanvas","_ol_reproj_glreproj$render","_ol_reproj$render","_ol_resolution$fromResolutionLike","resolutionconstraint","_ol_resolutionconstraint$createMinMaxResolution","_ol_resolutionconstraint$createSnapToPower","_ol_resolutionconstraint$createSnapToResolutions","rotationconstraint","_ol_rotationconstraint$createSnapToN","_ol_rotationconstraint$createSnapToZero","_ol_rotationconstraint$disable","_ol_rotationconstraint$none","_ol_size$hasArea","_ol_size$scale","_ol_size$toSize","BingMaps","hidpi_","culture_","culture","maxZoom_","apiKey_","imagerySet_","imagerySet","placeholderTiles_","placeholderTiles","handleImageryMetadataResponse","getApiKey","getImagerySet","statusCode","statusDescription","authenticationResultCode","resourceSets","resources","zoomMax","imageWidth","imageHeight","zoomMin","imageUrlSubdomains","subdomain","quadKeyTileCoord","imageUrl","imageryProviders","imageryProvider","intersecting","coverageAreas","coverageArea","_ol_source_BingMaps$quadKey","Cluster","interpolationRatio","createCustomCluster_","createCluster","boundRefresh_","updateDistance","setDistance","setMinDistance","getMinDistance","cluster","mapDistance","clustered","neighbors","neighbor","searchCenter","$ol$source$DataTile","Google","highDpi","sessionTokenRequest","mapType","language","region","imageFormat","layerTypes","apiOptions","sessionTokenRequest_","sessionTokenValue_","sessionRefreshId_","previousViewportAttribution_","previousViewportExtent_","createSessionUrl_","tileUrl_","attributionUrl_","createSession_","fetchSessionToken","method","headers","sessionTokenResponse","session","expiry","fetchAttributions_","viewportExtent","$ol$source$Image","_ol_source_Image$ImageSourceEvent","_ol_source_Image$defaultImageLoadFunction","_ol_source_Image$getRequestExtent","ImageArcGISRest","imageLoadFunction_","imageLoadFunction","imageSize_","ratio_","loaderProjection_","getParams","getImageLoadFunction","setImageLoadFunction","setParams","updateParams","canvasFunction_","canvasFunction","canvasElement","ImageStatic","imageExtent_","getImageExtent","$ol$source$ImageTile","ImageWMS","serverType_","sourceProjectionObj","OSM","_ol_source_OSM$ATTRIBUTION","Raster","$ol$source$Raster","_ol_source_Raster$Processor","_ol_source_Raster$RasterSourceEvent","$ol$source$Source","StadiaMaps","provider","providerConfig","layerConfig","query","apiKey","OSM_ATTRIBUTION","$ol$source$Tile","_ol_source_Tile$TileSourceEvent","TileArcGISRest","getKeyForParams_","getRequestUrl_","tileExtent","TileDebug","setReady","strokeRect","handler","$ol$source$TileImage","_ol_source_TileImage$defaultTileLoadFunction","TileJSON","tileJSON_","handleTileJSONResponse","handleTileJSONError","tileJSON","getTileJSON","attributionExtent","TileWMS","v13_","updateV13_","sourceProjCoord","LAYERS","setParams_","UTFGrid","tileUrlFunction_","template_","getTemplate","forDataAtCoordinateAndResolution","grids","_ol_source_UTFGrid$CustomTile","$ol$source$UrlTile","$ol$source$Vector","_ol_source_Vector$VectorSourceEvent","WMTS","requestEncoding","dimensions_","matrixSet_","requestEncoding_","getKeyForDimensions_","createFromWMTSTemplate","getDimensions","getMatrixSet","getRequestEncoding","getVersion","updateDimensions","tilematrixset","Service","Request","Version","TileCol","TileRow","optionsFromCapabilities","wmtsCap","tileMatrixSets","findIndex","supportedCRS","el","matrixSetObj","projConfig","switchXY","selectedMatrixLimit","tileMatrixValue","tileSpanX","tileSpanY","matrixSetExtent","wgs84BoundingBox","wgs84ProjectionExtent","wgs84MatrixSetExtent","gets","encodings","$ol$source$XYZ","arcgisRest","_ol_source_arcgisRest$createLoader","_ol_source_arcgisRest$getRequestUrl","DECIMALS","DEFAULT_WMS_VERSION","mapserver","mapExt","map_imagetype","mapext","imgext","map_size","imgx","imgy","imgxy","ogcTileUtil","_ol_source_ogcTileUtil$appendCollectionsQueryParam","_ol_source_ogcTileUtil$getMapTileUrlTemplate","getTileSetInfo","tileSet","tileMatrixSetLink","tileMatrixSetDefinition","parseTileSetMetadata","_ol_source_ogcTileUtil$getVectorTileUrlTemplate","_ol_source_ogcTileUtil$parseTileMatrixSet","sourcesFromTileGrid","sourceCache","tileGridExtent","wantedSources","static","_ol_source_static$createLoader","wms","_ol_source_wms$DEFAULT_VERSION","_ol_source_wms$createLoader","_ol_source_wms$getFeatureInfoUrl","_ol_source_wms$getImageSrc","_ol_source_wms$getLegendUrl","_ol_source_wms$getRequestParams","_ol_source_wms$getRequestUrl","sphere","_ol_sphere$DEFAULT_RADIUS","_ol_sphere$getDistance","_ol_sphere$offset","_ol_string$compareVersions","_ol_string$padNumber","structs","$ol$structs$LRUCache","$ol$structs$PriorityQueue","_ol_structs_PriorityQueue$DROP","$ol$structs$RBush","$ol$style$Circle","$ol$style$Fill","$ol$style$Icon","$ol$style$IconImage","_ol_style_IconImage$get","$ol$style$IconImageCache","_ol_style_IconImageCache$getCacheKey","_ol_style_IconImageCache$shared","$ol$style$Image","$ol$style$RegularShape","$ol$style$Stroke","$ol$style$Style","_ol_style_Style$createDefaultStyle","_ol_style_Style$createEditingStyle","_ol_style_Style$toFunction","$ol$style$Text","_ol_style_flat$createDefaultStyle","tilecoord","_ol_tilecoord$createOrUpdate","fromKey","_ol_tilecoord$getCacheKey","getCacheKeyForTileKey","_ol_tilecoord$getKeyZXY","_ol_tilecoord$hash","_ol_tilecoord$hashZXY","_ol_tilecoord$withinExtentAndZ","$ol$tilegrid$TileGrid","$ol$tilegrid$WMTS","_ol_tilegrid_WMTS$createFromCapabilitiesMatrixSet","DEFAULT_MAX_ZOOM","_ol_tilegrid_common$DEFAULT_TILE_SIZE","_ol_tilegrid$createForExtent","_ol_tilegrid$createForProjection","_ol_tilegrid$createXYZ","_ol_tilegrid$extentFromProjection","_ol_tilegrid$getForProjection","_ol_tilegrid$wrapX","tileurlfunction","_ol_tileurlfunction$createFromTemplate","_ol_tileurlfunction$createFromTemplates","_ol_tileurlfunction$createFromTileUrlFunctions","_ol_tileurlfunction$nullTileUrlFunction","_ol_transform$apply","_ol_transform$compose","composeCssTransform","_ol_transform$create","_ol_transform$determinant","_ol_transform$equivalent","_ol_transform$fromString","invert","_ol_transform$makeInverse","makeScale","_ol_transform$multiply","_ol_transform$scale","_ol_transform$set","_ol_transform$setFromArray","_ol_transform$toString","_ol_transform$translate","_ol_uri$appendParams","_ol_uri$expandUrl","_ol_uri$pickUrl","_ol_uri$renderXYZTemplate","util","_ol_util$abstract","_ol_util$getUid","vec","_ol_vec_mat4$create","_ol_vec_mat4$fromTransform","_ol_vec_mat4$orthographic","_ol_vec_mat4$scale","_ol_vec_mat4$translate","_ol_vec_mat4$translation","_ol_xml$OBJECT_PROPERTY_NODE_FACTORY","_ol_xml$XML_SCHEMA_INSTANCE_URI","_ol_xml$createElementNS","_ol_xml$getAllTextContent","_ol_xml$getAllTextContent_","_ol_xml$getAttributeNS","_ol_xml$getDocument","_ol_xml$getXMLSerializer","_ol_xml$isDocument","_ol_xml$makeArrayExtender","_ol_xml$makeArrayPusher","_ol_xml$makeArraySerializer","_ol_xml$makeChildAppender","_ol_xml$makeObjectPropertyPusher","_ol_xml$makeObjectPropertySetter","_ol_xml$makeReplacer","_ol_xml$makeSequence","_ol_xml$makeSimpleNodeFactory","_ol_xml$makeStructureNS","_ol_xml$parse","_ol_xml$parseNode","_ol_xml$pushParseAndPop","_ol_xml$pushSerializeAndPop","registerDocument","registerXMLSerializer","xmlSerializer","_ol_xml$serialize"],"mappings":"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","x_google_ignoreList":[105,106,264]}