{"version":3,"file":"ol.js","sources":["../ol/events/Event.js","../ol/ObjectEventType.js","../ol/Disposable.js","../ol/array.js","../ol/functions.js","../ol/obj.js","../ol/events/Target.js","../ol/events/EventType.js","../ol/events.js","../ol/Observable.js","../ol/util.js","../ol/Object.js","../ol/CollectionEventType.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/transform.js","../ol/extent/Relationship.js","../ol/extent.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/math.js","../ol/string.js","../ol/coordinate.js","../ol/sphere.js","../ol/console.js","../ol/proj.js","../ol/geom/flat/transform.js","../ol/geom/Geometry.js","../ol/geom/SimpleGeometry.js","../ol/geom/flat/closest.js","../ol/geom/flat/deflate.js","../ol/geom/flat/simplify.js","../ol/geom/flat/inflate.js","../ol/geom/flat/area.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","../../node_modules/color-space/rgb.js","../../node_modules/color-space/xyz.js","../../node_modules/color-space/luv.js","../../node_modules/color-space/lchuv.js","../../node_modules/color-name/index.js","../../node_modules/color-parse/index.js","../../node_modules/color-space/hsl.js","../../node_modules/color-rgba/index.js","../ol/color.js","../ol/style/IconImageCache.js","../ol/layer/Property.js","../ol/layer/Base.js","../ol/render/EventType.js","../ol/ViewHint.js","../ol/ViewProperty.js","../ol/tilegrid/common.js","../ol/centerconstraint.js","../ol/resolutionconstraint.js","../ol/rotationconstraint.js","../ol/View.js","../ol/layer/Layer.js","../ol/renderer/Map.js","../ol/render/Event.js","../ol/css.js","../ol/render/canvas.js","../ol/renderer/Composite.js","../ol/layer/Group.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/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/interaction/Pointer.js","../ol/events/condition.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/size.js","../ol/Map.js","../ol/Overlay.js","../ol/structs/LRUCache.js","../ol/tilecoord.js","../ol/TileCache.js","../ol/TileRange.js","../ol/VectorRenderTile.js","../ol/VectorTile.js","../ol/colorlike.js","../ol/featureloader.js","../ol/net.js","../ol/loadingstrategy.js","../ol/render/VectorContext.js","../ol/render/canvas/Immediate.js","../ol/renderer/vector.js","../ol/render.js","../ol/reproj.js","../ol/resolution.js","../ol/reproj/common.js","../ol/reproj/Triangulation.js","../ol/reproj/Tile.js","../ol/source/TileEventType.js","../ol/source/Source.js","../ol/tilegrid/TileGrid.js","../ol/tilegrid.js","../ol/source/Tile.js","../ol/tileurlfunction.js","../ol/source/UrlTile.js","../ol/source/TileImage.js","../ol/source/BingMaps.js","../ol/source/XYZ.js","../ol/source/CartoDB.js","../../node_modules/quickselect/index.js","../../node_modules/rbush/index.js","../ol/structs/RBush.js","../ol/geom/Circle.js","../ol/geom/GeometryCollection.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/source/VectorEventType.js","../ol/source/Vector.js","../ol/source/Cluster.js","../ol/reproj/DataTile.js","../ol/source/DataTile.js","../ol/source/GeoTIFF.js","../ol/source/Zoomify.js","../ol/format/IIIFInfo.js","../ol/source/IIIF.js","../ol/reproj/Image.js","../ol/source/common.js","../ol/source/Image.js","../ol/uri.js","../ol/source/arcgisRest.js","../ol/source/ImageArcGISRest.js","../ol/source/ImageCanvas.js","../ol/source/mapguide.js","../ol/source/ImageMapGuide.js","../ol/source/static.js","../ol/source/ImageStatic.js","../ol/source/wms.js","../ol/source/ImageWMS.js","../ol/source/ogcTileUtil.js","../ol/source/OGCMapTile.js","../ol/source/VectorTile.js","../ol/source/OGCVectorTile.js","../ol/source/OSM.js","../ol/layer/BaseImage.js","../ol/renderer/Layer.js","../ol/renderer/canvas/Layer.js","../ol/renderer/canvas/ImageLayer.js","../ol/layer/Image.js","../ol/layer/TileProperty.js","../ol/layer/BaseTile.js","../ol/renderer/canvas/TileLayer.js","../ol/layer/Tile.js","../ol/source/Raster.js","../ol/source/StadiaMaps.js","../ol/source/TileArcGISRest.js","../ol/source/TileDebug.js","../ol/source/TileJSON.js","../ol/source/TileWMS.js","../ol/source/UTFGrid.js","../ol/tilegrid/WMTS.js","../ol/source/WMTS.js","../ol/webgl.js","../ol/xml.js","../ol/webgl/BaseTileRepresentation.js","../ol/webgl/Buffer.js","../ol/webgl/ContextEventType.js","../ol/webgl/PostProcessingPass.js","../ol/vec/mat4.js","../ol/webgl/Helper.js","../ol/webgl/PaletteTexture.js","../ol/webgl/RenderTarget.js","../../node_modules/earcut/src/earcut.js","../ol/render/webgl/utils.js","../ol/expr/expression.js","../ol/webgl/TileTexture.js","../ol/renderer/webgl/Layer.js","../ol/renderer/webgl/TileLayerBase.js","../ol/renderer/webgl/TileLayer.js","../ol/expr/gpu.js","../ol/style/flat.js","../ol/webgl/ShaderBuilder.js","../ol/render/webgl/MixedGeometryBatch.js","../ol/webgl/TileGeometry.js","../ol/webgl/styleparser.js","../ol/style/Image.js","../ol/style/RegularShape.js","../ol/style/Circle.js","../ol/style/Fill.js","../ol/style/IconImage.js","../ol/style/Icon.js","../ol/style/Stroke.js","../ol/style/Style.js","../ol/style/Text.js","../ol/structs/LinkedList.js","../ol/expr/cpu.js","../ol/render/canvas/style.js","../ol/layer/BaseVector.js","../ol/render/webgl/constants.js","../ol/worker/webgl.js","../ol/renderer/webgl/worldUtil.js","../ol/renderer/webgl/PointsLayer.js","../ol/render/webgl/renderinstructions.js","../ol/render/webgl/VectorStyleRenderer.js","../ol/renderer/webgl/VectorLayer.js","../ol/renderer/webgl/VectorTileLayer.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/renderer/canvas/VectorTileLayer.js","../ol/proj/proj4.js","../ol/layer/Vector.js","../ol/geom/flat/geodesic.js","../ol/layer/Graticule.js","../ol/layer/Heatmap.js","../ol/layer/VectorImage.js","../ol/layer/VectorTile.js","../ol/layer/WebGLPoints.js","../ol/layer/WebGLTile.js","../ol/interaction/DblClickDragZoom.js","../ol/interaction/DragAndDrop.js","../ol/interaction/DragRotateAndZoom.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/JSONFeature.js","../ol/format/EsriJSON.js","../ol/format/XMLFeature.js","../ol/format/GMLBase.js","../ol/format/xsd.js","../ol/format/GML2.js","../ol/format/GML3.js","../ol/format/GML.js","../ol/format/GML32.js","../ol/format/GPX.js","../ol/format/GeoJSON.js","../ol/format/TextFeature.js","../ol/format/IGC.js","../ol/format/KML.js","../../node_modules/ieee754/index.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/filter/Filter.js","../ol/format/filter/LogicalNary.js","../ol/format/filter/And.js","../ol/format/filter/Bbox.js","../ol/format/filter/Spatial.js","../ol/format/filter/Contains.js","../ol/format/filter/DWithin.js","../ol/format/filter/Disjoint.js","../ol/format/filter/Comparison.js","../ol/format/filter/During.js","../ol/format/filter/ComparisonBinary.js","../ol/format/filter/EqualTo.js","../ol/format/filter/GreaterThan.js","../ol/format/filter/GreaterThanOrEqualTo.js","../ol/format/filter/Intersects.js","../ol/format/filter/IsBetween.js","../ol/format/filter/IsLike.js","../ol/format/filter/IsNull.js","../ol/format/filter/LessThan.js","../ol/format/filter/LessThanOrEqualTo.js","../ol/format/filter/Not.js","../ol/format/filter/NotEqualTo.js","../ol/format/filter/Or.js","../ol/format/filter/ResourceId.js","../ol/format/filter/Within.js","../ol/format/filter.js","../ol/format/WFS.js","../ol/format/WKB.js","../ol/format/WKT.js","../ol/format/WMSCapabilities.js","../ol/format/WMSGetFeatureInfo.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/control/ZoomToExtent.js","../index.js","../ol/geom/flat/topology.js","../ol/source.js"],"sourcesContent":["/**\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/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/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 */\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  let called = false;\n\n  /** @type {ReturnType} */\n  let lastResult;\n\n  /** @type {Array<any>} */\n  let lastArgs;\n\n  let lastThis;\n\n  return function () {\n    const nextArgs = Array.prototype.slice.call(arguments);\n    if (!called || this !== lastThis || !arrayEquals(nextArgs, lastArgs)) {\n      called = true;\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/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/Target\n */\nimport Disposable from '../Disposable.js';\nimport Event from './Event.js';\nimport {VOID} from '../functions.js';\nimport {clear} from '../obj.js';\n\n/**\n * @typedef {EventTarget|Target} EventTargetLike\n */\n\n/**\n * @classdesc\n * A simplified implementation of the W3C DOM Level 2 EventTarget interface.\n * See https://www.w3.org/TR/2000/REC-DOM-Level-2-Events-20001113/events.html#Events-EventTarget.\n *\n * There are two important simplifications compared to the specification:\n *\n * 1. The handling of `useCapture` in `addEventListener` and\n *    `removeEventListener`. There is no real capture model.\n * 2. The handling of `stopPropagation` and `preventDefault` on `dispatchEvent`.\n *    There is no event target hierarchy. When a listener calls\n *    `stopPropagation` or `preventDefault` on an event object, it means that no\n *    more listeners after this one will be called. Same as when the listener\n *    returns false.\n */\nclass Target extends Disposable {\n  /**\n   * @param {*} [target] Default event target for dispatched events.\n   */\n  constructor(target) {\n    super();\n\n    /**\n     * @private\n     * @type {*}\n     */\n    this.eventTarget_ = target;\n\n    /**\n     * @private\n     * @type {Object<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   */\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/events/EventType\n */\n\n/**\n * @enum {string}\n * @const\n */\nexport default {\n  /**\n   * Generic change event. Triggered when the revision counter is increased.\n   * @event module:ol/events/Event~BaseEvent#change\n   * @api\n   */\n  CHANGE: 'change',\n\n  /**\n   * Generic error event. Triggered when an error occurs.\n   * @event module:ol/events/Event~BaseEvent#error\n   * @api\n   */\n  ERROR: 'error',\n\n  BLUR: 'blur',\n  CLEAR: 'clear',\n  CONTEXTMENU: 'contextmenu',\n  CLICK: 'click',\n  DBLCLICK: 'dblclick',\n  DRAGENTER: 'dragenter',\n  DRAGOVER: 'dragover',\n  DROP: 'drop',\n  FOCUS: 'focus',\n  KEYDOWN: 'keydown',\n  KEYPRESS: 'keypress',\n  LOAD: 'load',\n  RESIZE: 'resize',\n  TOUCHMOVE: 'touchmove',\n  WHEEL: 'wheel',\n};\n","/**\n * @module ol/events\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 (thisArg && thisArg !== target) {\n    listener = listener.bind(thisArg);\n  }\n  if (once) {\n    const originalListener = listener;\n    listener = function () {\n      target.removeEventListener(type, listener);\n      originalListener.apply(this, arguments);\n    };\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/Observable\n */\nimport EventTarget from './events/Target.js';\nimport EventType from './events/EventType.js';\nimport {listen, listenOnce, unlistenByKey} from './events.js';\n\n/***\n * @template {string} Type\n * @template {Event|import(\"./events/Event.js\").default} EventClass\n * @template Return\n * @typedef {(type: Type, listener: (event: EventClass) => ?) => Return} OnSignature\n */\n\n/***\n * @template {string} Type\n * @template Return\n * @typedef {(type: Type[], listener: (event: Event|import(\"./events/Event\").default) => ?) => Return extends void ? void : Return[]} CombinedOnSignature\n */\n\n/**\n * @typedef {'change'|'error'} EventTypes\n */\n\n/***\n * @template Return\n * @typedef {OnSignature<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\").EventsKey>} */ (\n        this.onInternal\n      );\n\n    this.once =\n      /** @type {ObservableOnSignature<import(\"./events\").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\").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\").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\").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\").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\").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\").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 = '8.1.1-dev.1699341921517';\n","/**\n * @module ol/Object\n */\nimport Event from './events/Event.js';\nimport ObjectEventType from './ObjectEventType.js';\nimport Observable from './Observable.js';\nimport {getUid} from './util.js';\nimport {isEmpty} from './obj.js';\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/Object~BaseObject} instances are instances of this type.\n */\nexport class ObjectEvent extends Event {\n  /**\n   * @param {string} type The event type.\n   * @param {string} key The property name.\n   * @param {*} oldValue The old value for `key`.\n   */\n  constructor(type, key, oldValue) {\n    super(type);\n\n    /**\n     * The name of the property whose value is changing.\n     * @type {string}\n     * @api\n     */\n    this.key = key;\n\n    /**\n     * The old value. To get the new value use `e.target.get(e.key)` where\n     * `e` is the event object.\n     * @type {*}\n     * @api\n     */\n    this.oldValue = oldValue;\n  }\n}\n\n/***\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature<import(\"./Observable\").EventTypes, import(\"./events/Event.js\").default, Return> &\n *    import(\"./Observable\").OnSignature<import(\"./ObjectEventType\").Types, ObjectEvent, Return> &\n *    import(\"./Observable\").CombinedOnSignature<import(\"./Observable\").EventTypes|import(\"./ObjectEventType\").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 * @api\n */\nclass BaseObject extends Observable {\n  /**\n   * @param {Object<string, *>} [values] An object with key-value pairs.\n   */\n  constructor(values) {\n    super();\n\n    /***\n     * @type {ObjectOnSignature<import(\"./events\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {ObjectOnSignature<import(\"./events\").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 {Object<string, *>|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 {Object<string, *>} Object.\n   * @api\n   */\n  getProperties() {\n    return (this.values_ && Object.assign({}, this.values_)) || {};\n  }\n\n  /**\n   * Get an object of all property names and values.\n   * @return {Object<string, *>?} Object.\n   */\n  getPropertiesInternal() {\n    return this.values_;\n  }\n\n  /**\n   * @return {boolean} The object has properties.\n   */\n  hasProperties() {\n    return !!this.values_;\n  }\n\n  /**\n   * @param {string} key Key name.\n   * @param {*} oldValue Old value.\n   */\n  notify(key, oldValue) {\n    let eventType;\n    eventType = `change:${key}`;\n    if (this.hasListener(eventType)) {\n      this.dispatchEvent(new ObjectEvent(eventType, key, oldValue));\n    }\n    eventType = ObjectEventType.PROPERTYCHANGE;\n    if (this.hasListener(eventType)) {\n      this.dispatchEvent(new ObjectEvent(eventType, key, oldValue));\n    }\n  }\n\n  /**\n   * @param {string} key Key name.\n   * @param {import(\"./events.js\").Listener} listener Listener.\n   */\n  addChangeListener(key, listener) {\n    this.addEventListener(`change:${key}`, listener);\n  }\n\n  /**\n   * @param {string} key Key name.\n   * @param {import(\"./events.js\").Listener} listener Listener.\n   */\n  removeChangeListener(key, listener) {\n    this.removeEventListener(`change:${key}`, listener);\n  }\n\n  /**\n   * Sets a value.\n   * @param {string} key Key name.\n   * @param {*} value Value.\n   * @param {boolean} [silent] Update without triggering an event.\n   * @api\n   */\n  set(key, value, silent) {\n    const values = this.values_ || (this.values_ = {});\n    if (silent) {\n      values[key] = value;\n    } else {\n      const oldValue = values[key];\n      values[key] = value;\n      if (oldValue !== value) {\n        this.notify(key, oldValue);\n      }\n    }\n  }\n\n  /**\n   * Sets a collection of key-value pairs.  Note that this changes any existing\n   * properties and adds new ones (it does not remove any existing properties).\n   * @param {Object<string, *>} 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/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/Collection\n */\nimport BaseObject from './Object.js';\nimport CollectionEventType from './CollectionEventType.js';\nimport Event from './events/Event.js';\n\n/**\n * @enum {string}\n * @private\n */\nconst Property = {\n  LENGTH: 'length',\n};\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/Collection~Collection} instances are instances of this\n * type.\n * @template T\n */\nexport class CollectionEvent extends Event {\n  /**\n   * @param {import(\"./CollectionEventType.js\").default} type Type.\n   * @param {T} element Element.\n   * @param {number} index The index of the added or removed element.\n   */\n  constructor(type, element, index) {\n    super(type);\n\n    /**\n     * The element that is added to or removed from the collection.\n     * @type {T}\n     * @api\n     */\n    this.element = element;\n\n    /**\n     * The index of the added or removed element.\n     * @type {number}\n     * @api\n     */\n    this.index = index;\n  }\n}\n\n/***\n * @template T\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature<import(\"./Observable\").EventTypes, import(\"./events/Event.js\").default, Return> &\n *   import(\"./Observable\").OnSignature<import(\"./ObjectEventType\").Types|'change:length', import(\"./Object\").ObjectEvent, Return> &\n *   import(\"./Observable\").OnSignature<'add'|'remove', CollectionEvent<T>, Return> &\n *   import(\"./Observable\").CombinedOnSignature<import(\"./Observable\").EventTypes|import(\"./ObjectEventType\").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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {CollectionOnSignature<T, import(\"./events\").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 ? array : [];\n\n    if (this.unique_) {\n      for (let i = 0, ii = this.array_.length; i < ii; ++i) {\n        this.assertUnique_(this.array_[i], i);\n      }\n    }\n\n    this.updateLength_();\n  }\n\n  /**\n   * Remove all elements from the collection.\n   * @api\n   */\n  clear() {\n    while (this.getLength() > 0) {\n      this.pop();\n    }\n  }\n\n  /**\n   * Add elements to the collection.  This pushes each item in the provided array\n   * to the end of the collection.\n   * @param {!Array<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    if (this.unique_) {\n      this.assertUnique_(elem);\n    }\n    const n = this.getLength();\n    this.insertAt(n, elem);\n    return this.getLength();\n  }\n\n  /**\n   * Remove the first occurrence of an element from the collection.\n   * @param {T} elem Element.\n   * @return {T|undefined} The removed element or undefined if none found.\n   * @api\n   */\n  remove(elem) {\n    const arr = this.array_;\n    for (let i = 0, ii = arr.length; i < ii; ++i) {\n      if (arr[i] === elem) {\n        return this.removeAt(i);\n      }\n    }\n    return undefined;\n  }\n\n  /**\n   * Remove the element at the provided index and return it.\n   * Return `undefined` if the collection does not contain this index.\n   * @param {number} index Index.\n   * @return {T|undefined} Value.\n   * @api\n   */\n  removeAt(index) {\n    if (index < 0 || index >= this.getLength()) {\n      return undefined;\n    }\n    const prev = this.array_[index];\n    this.array_.splice(index, 1);\n    this.updateLength_();\n    this.dispatchEvent(\n      /** @type {CollectionEvent<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    for (let i = 0, ii = this.array_.length; i < ii; ++i) {\n      if (this.array_[i] === elem && i !== except) {\n        throw new Error('Duplicate item added to a unique collection');\n      }\n    }\n  }\n}\n\nexport default Collection;\n","/**\n * @module ol/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 EventTarget from './events/Target.js';\nimport EventType from './events/EventType.js';\nimport TileState from './TileState.js';\nimport {abstract} from './util.js';\nimport {easeIn} from './easing.js';\n\n/**\n * A function that takes an {@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 an {@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     * An \"interim\" tile for this tile. The interim tile may be used while this\n     * one is loading, for \"smooth\" transitions when changing params/dimensions\n     * on the source.\n     * @type {Tile|null}\n     */\n    this.interimTile = null;\n\n    /**\n     * A key assigned to the tile. This is used by the tile source to determine\n     * if this tile can effectively be used, or if a new tile should be created\n     * and this one be used as an interim tile for this new tile.\n     * @type {string}\n     */\n    this.key = '';\n\n    /**\n     * The duration for the opacity transition.\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     * @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    if (this.state === TileState.ERROR) {\n      // to remove the `change` listener on this tile in `ol/TileQueue#handleTileChange`\n      this.setState(TileState.EMPTY);\n    }\n  }\n\n  /**\n   * @return {string} Key.\n   */\n  getKey() {\n    return this.key + '/' + this.tileCoord;\n  }\n\n  /**\n   * Get the interim tile most suitable for rendering using the chain of interim\n   * tiles. This corresponds to the  most recent tile that has been loaded, if no\n   * such tile exists, the original tile is returned.\n   * @return {!Tile} Best tile for rendering.\n   */\n  getInterimTile() {\n    let tile = this.interimTile;\n    if (!tile) {\n      //empty chain\n      return this;\n    }\n\n    // find the first loaded tile and return it. Since the chain is sorted in\n    // decreasing order of creation time, there is no need to search the remainder\n    // of the list (all those tiles correspond to older requests and will be\n    // cleaned up by refreshInterimChain)\n    do {\n      if (tile.getState() == TileState.LOADED) {\n        // Show tile immediately instead of fading it in after loading, because\n        // the interim tile is in place already\n        this.transition_ = 0;\n        return tile;\n      }\n      tile = tile.interimTile;\n    } while (tile);\n\n    // we can not find a better tile\n    return this;\n  }\n\n  /**\n   * Goes through the chain of interim tiles and discards sections of the chain\n   * that are no longer relevant.\n   */\n  refreshInterimChain() {\n    let tile = this.interimTile;\n    if (!tile) {\n      return;\n    }\n\n    /** @type {Tile} */\n    let prev = this;\n    do {\n      if (tile.getState() == TileState.LOADED) {\n        //we have a loaded tile, we can discard the rest of the list\n        //we would could abort any LOADING tile request\n        //older than this tile (i.e. any LOADING tile following this entry in the chain)\n        tile.interimTile = null;\n        break;\n      }\n      if (tile.getState() == TileState.LOADING) {\n        //keep this LOADING tile any loaded tiles later in the chain are\n        //older than this tile, so we're still interested in the request\n        prev = tile;\n      } else if (tile.getState() == TileState.IDLE) {\n        //the head of the list is the most current tile, we don't need\n        //to start any other requests for this chain\n        prev.interimTile = tile.interimTile;\n      } else {\n        prev = tile;\n      }\n      tile = prev.interimTile;\n    } while (tile);\n  }\n\n  /**\n   * Get the tile coordinate for this tile.\n   * @return {import(\"./tilecoord.js\").TileCoord} The tile coordinate.\n   * @api\n   */\n  getTileCoord() {\n    return this.tileCoord;\n  }\n\n  /**\n   * @return {import(\"./TileState.js\").default} State.\n   */\n  getState() {\n    return this.state;\n  }\n\n  /**\n   * Sets the state of this tile. If you write your own {@link module:ol/Tile~LoadFunction tileLoadFunction} ,\n   * it is important to set the state correctly to {@link module:ol/TileState~ERROR}\n   * when the tile cannot be loaded. Otherwise the tile cannot be removed from\n   * the tile queue and will block other requests.\n   * @param {import(\"./TileState.js\").default} state State.\n   * @api\n   */\n  setState(state) {\n    if (this.state !== TileState.ERROR && this.state > state) {\n      throw new Error('Tile load sequence violation');\n    }\n    this.state = state;\n    this.changed();\n  }\n\n  /**\n   * Load the image or retry if loading previously failed.\n   * Loading is taken care of by the tile queue, and calling this method is\n   * only needed for preloading or for reloading in case of an error.\n   * @abstract\n   * @api\n   */\n  load() {\n    abstract();\n  }\n\n  /**\n   * Get the alpha value for rendering.\n   * @param {string} id An id for the renderer.\n   * @param {number} time The render frame time.\n   * @return {number} A number between 0 and 1.\n   */\n  getAlpha(id, time) {\n    if (!this.transition_) {\n      return 1;\n    }\n\n    let start = this.transitionStarts_[id];\n    if (!start) {\n      start = time;\n      this.transitionStarts_[id] = start;\n    } else if (start === -1) {\n      return 1;\n    }\n\n    const delta = time - start + 1000 / 60; // avoid rendering at 0\n    if (delta >= this.transition_) {\n      return 1;\n    }\n    return easeIn(delta / this.transition_);\n  }\n\n  /**\n   * Determine if a tile is in an alpha transition.  A tile is considered in\n   * transition if tile.getAlpha() has not yet been called or has been called\n   * and returned 1.\n   * @param {string} id An id for the renderer.\n   * @return {boolean} The tile is in transition.\n   */\n  inTransition(id) {\n    if (!this.transition_) {\n      return false;\n    }\n    return this.transitionStarts_[id] !== -1;\n  }\n\n  /**\n   * Mark a transition as complete.\n   * @param {string} id An id for the renderer.\n   */\n  endTransition(id) {\n    if (this.transition_) {\n      this.transitionStarts_[id] = -1;\n    }\n  }\n}\n\nexport default Tile;\n","/**\n * @module ol/has\n */\n\nconst ua =\n  typeof navigator !== 'undefined' && typeof navigator.userAgent !== 'undefined'\n    ? navigator.userAgent.toLowerCase()\n    : '';\n\n/**\n * User agent string says we are dealing with Firefox as browser.\n * @type {boolean}\n */\nexport const FIREFOX = ua.includes('firefox');\n\n/**\n * User agent string says we are dealing with Safari as browser.\n * @type {boolean}\n */\nexport const SAFARI = ua.includes('safari') && !ua.includes('chrom');\n\n/**\n * https://bugs.webkit.org/show_bug.cgi?id=237906\n * @type {boolean}\n */\nexport const SAFARI_BUG_237906 =\n  SAFARI &&\n  (ua.includes('version/15.4') ||\n    /cpu (os|iphone os) 15_4 like mac os x/.test(ua));\n\n/**\n * User agent string says we are dealing with a WebKit engine.\n * @type {boolean}\n */\nexport const WEBKIT = ua.includes('webkit') && !ua.includes('edge');\n\n/**\n * User agent string says we are dealing with a Mac as platform.\n * @type {boolean}\n */\nexport const MAC = ua.includes('macintosh');\n\n/**\n * The ratio between physical pixels and device-independent pixels\n * (dips) on the device (`window.devicePixelRatio`).\n * @const\n * @type {number}\n * @api\n */\nexport const DEVICE_PIXEL_RATIO =\n  typeof devicePixelRatio !== 'undefined' ? devicePixelRatio : 1;\n\n/**\n * The execution context is a worker with OffscreenCanvas available.\n * @const\n * @type {boolean}\n */\nexport const WORKER_OFFSCREEN_CANVAS =\n  typeof WorkerGlobalScope !== 'undefined' &&\n  typeof OffscreenCanvas !== 'undefined' &&\n  self instanceof WorkerGlobalScope; //eslint-disable-line\n\n/**\n * Image.prototype.decode() is supported.\n * @type {boolean}\n */\nexport const IMAGE_DECODE =\n  typeof Image !== 'undefined' && Image.prototype.decode;\n\n/**\n * createImageBitmap() is supported.\n * @type {boolean}\n */\nexport const CREATE_IMAGE_BITMAP = typeof createImageBitmap === 'function';\n\n/**\n * @type {boolean}\n */\nexport const PASSIVE_EVENT_LISTENERS = (function () {\n  let passive = false;\n  try {\n    const options = Object.defineProperty({}, 'passive', {\n      get: function () {\n        passive = true;\n      },\n    });\n\n    // @ts-ignore Ignore invalid event type '_'\n    window.addEventListener('_', null, options);\n    // @ts-ignore Ignore invalid event type '_'\n    window.removeEventListener('_', null, options);\n  } catch (error) {\n    // passive not supported\n  }\n  return passive;\n})();\n","import {WORKER_OFFSCREEN_CANVAS} from './has.js';\n\n/**\n * @module ol/dom\n */\n\n//FIXME Move this function to the canvas module\n/**\n * Create an html canvas element and returns its 2d context.\n * @param {number} [width] Canvas width.\n * @param {number} [height] Canvas height.\n * @param {Array<HTMLCanvasElement>} [canvasPool] Canvas pool to take existing canvas from.\n * @param {CanvasRenderingContext2DSettings} [settings] CanvasRenderingContext2DSettings\n * @return {CanvasRenderingContext2D} The context.\n */\nexport function createCanvasContext2D(width, height, canvasPool, settings) {\n  /** @type {HTMLCanvasElement|OffscreenCanvas} */\n  let canvas;\n  if (canvasPool && canvasPool.length) {\n    canvas = /** @type {HTMLCanvasElement} */ (canvasPool.shift());\n  } else if (WORKER_OFFSCREEN_CANVAS) {\n    canvas = new OffscreenCanvas(width || 300, height || 300);\n  } else {\n    canvas = document.createElement('canvas');\n  }\n  if (width) {\n    canvas.width = width;\n  }\n  if (height) {\n    canvas.height = height;\n  }\n  //FIXME Allow OffscreenCanvasRenderingContext2D as return type\n  return /** @type {CanvasRenderingContext2D} */ (\n    canvas.getContext('2d', settings)\n  );\n}\n\n/**\n * Releases canvas memory to avoid exceeding memory limits in Safari.\n * See https://pqina.nl/blog/total-canvas-memory-use-exceeds-the-maximum-limit/\n * @param {CanvasRenderingContext2D} context Context.\n */\nexport function releaseCanvas(context) {\n  const canvas = context.canvas;\n  canvas.width = 1;\n  canvas.height = 1;\n  context.clearRect(0, 0, 1, 1);\n}\n\n/**\n * Get the current computed width for the given element including margin,\n * padding and border.\n * Equivalent to jQuery's `$(el).outerWidth(true)`.\n * @param {!HTMLElement} element Element.\n * @return {number} The width.\n */\nexport function outerWidth(element) {\n  let width = element.offsetWidth;\n  const style = getComputedStyle(element);\n  width += parseInt(style.marginLeft, 10) + parseInt(style.marginRight, 10);\n\n  return width;\n}\n\n/**\n * Get the current computed height for the given element including margin,\n * padding and border.\n * Equivalent to jQuery's `$(el).outerHeight(true)`.\n * @param {!HTMLElement} element Element.\n * @return {number} The height.\n */\nexport function outerHeight(element) {\n  let height = element.offsetHeight;\n  const style = getComputedStyle(element);\n  height += parseInt(style.marginTop, 10) + parseInt(style.marginBottom, 10);\n\n  return height;\n}\n\n/**\n * @param {Node} newNode Node to replace old node\n * @param {Node} oldNode The node to be replaced\n */\nexport function replaceNode(newNode, oldNode) {\n  const parent = oldNode.parentNode;\n  if (parent) {\n    parent.replaceChild(newNode, oldNode);\n  }\n}\n\n/**\n * @param {Node} node The node to remove.\n * @return {Node|null} The node that was removed or null.\n */\nexport function removeNode(node) {\n  return node && node.parentNode ? node.parentNode.removeChild(node) : null;\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.removeChild(node.lastChild);\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 * @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|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 * @type {CanvasRenderingContext2D|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 * @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  /**\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 not yet loaded URI.\n   * @api\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\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 EventType from './events/EventType.js';\nimport {assert} from './asserts.js';\nimport {listen, unlistenByKey} from './events.js';\n\n/**\n * @typedef {typeof Feature|typeof import(\"./render/Feature.js\").default} FeatureClass\n */\n\n/**\n * @typedef {Feature|import(\"./render/Feature.js\").default} FeatureLike\n */\n\n/***\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature<import(\"./Observable\").EventTypes, import(\"./events/Event.js\").default, Return> &\n *   import(\"./Observable\").OnSignature<import(\"./ObjectEventType\").Types|'change:geometry', import(\"./Object\").ObjectEvent, Return> &\n *   import(\"./Observable\").CombinedOnSignature<import(\"./Observable\").EventTypes|import(\"./ObjectEventType\").Types\n *     |'change:geometry', Return>} FeatureOnSignature\n */\n\n/***\n * @template {import(\"./geom/Geometry.js\").default} [Geometry=import(\"./geom/Geometry.js\").default]\n * @typedef {Object<string, *> & { geometry?: Geometry }} ObjectWithGeometry\n */\n\n/**\n * @classdesc\n * A vector object for geographic features with a geometry and other\n * attribute properties, similar to the features in vector file formats like\n * GeoJSON.\n *\n * Features can be styled individually with `setStyle`; otherwise they use the\n * style of their vector layer.\n *\n * Note that attribute properties are set as {@link module:ol/Object~BaseObject} properties on\n * the feature object, so they are observable, and have get/set accessors.\n *\n * Typically, a feature has a single geometry property. You can set the\n * geometry using the `setGeometry` method and get it with `getGeometry`.\n * It is possible to store more than one geometry on a feature using attribute\n * properties. By default, the geometry used for rendering is identified by\n * the property name `geometry`. If you want to use another geometry property\n * for rendering, use the `setGeometryName` method to change the attribute\n * property associated with the geometry for the feature.  For example:\n *\n * ```js\n *\n * import Feature from 'ol/Feature.js';\n * import Polygon from 'ol/geom/Polygon.js';\n * import Point from 'ol/geom/Point.js';\n *\n * const feature = new Feature({\n *   geometry: new Polygon(polyCoords),\n *   labelPoint: new Point(labelCoords),\n *   name: 'My Polygon',\n * });\n *\n * // get the polygon geometry\n * const poly = feature.getGeometry();\n *\n * // Render the feature as a point using the coordinates from labelPoint\n * feature.setGeometryName('labelPoint');\n *\n * // get the point geometry\n * const point = feature.getGeometry();\n * ```\n *\n * @api\n * @template {import(\"./geom/Geometry.js\").default} [Geometry=import(\"./geom/Geometry.js\").default]\n */\nclass Feature extends BaseObject {\n  /**\n   * @param {Geometry|ObjectWithGeometry<Geometry>} [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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {FeatureOnSignature<import(\"./events\").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 {Object<string, *>} */\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>} */ (\n      new Feature(this.hasProperties() ? this.getProperties() : null)\n    );\n    clone.setGeometryName(this.getGeometryName());\n    const geometry = this.getGeometry();\n    if (geometry) {\n      clone.setGeometry(/** @type {Geometry} */ (geometry.clone()));\n    }\n    const style = this.getStyle();\n    if (style) {\n      clone.setStyle(style);\n    }\n    return clone;\n  }\n\n  /**\n   * Get the feature's default geometry.  A feature may have any number of named\n   * geometries.  The \"default\" geometry (the one that is rendered by default) is\n   * set when calling {@link module:ol/Feature~Feature#setGeometry}.\n   * @return {Geometry|undefined} The default geometry for the feature.\n   * @api\n   * @observable\n   */\n  getGeometry() {\n    return /** @type {Geometry|undefined} */ (this.get(this.geometryName_));\n  }\n\n  /**\n   * Get the feature identifier.  This is a stable identifier for the feature and\n   * is either set when reading data from a remote source or set explicitly by\n   * calling {@link module:ol/Feature~Feature#setId}.\n   * @return {number|string|undefined} Id.\n   * @api\n   */\n  getId() {\n    return this.id_;\n  }\n\n  /**\n   * Get the name of the feature's default geometry.  By default, the default\n   * geometry is named `geometry`.\n   * @return {string} Get the property name associated with the default geometry\n   *     for this feature.\n   * @api\n   */\n  getGeometryName() {\n    return this.geometryName_;\n  }\n\n  /**\n   * Get the feature's style. Will return what was provided to the\n   * {@link module:ol/Feature~Feature#setStyle} method.\n   * @return {import(\"./style/Style.js\").StyleLike|undefined} The feature style.\n   * @api\n   */\n  getStyle() {\n    return this.style_;\n  }\n\n  /**\n   * Get the feature's style function.\n   * @return {import(\"./style/Style.js\").StyleFunction|undefined} Return a function\n   * representing the current style of this feature.\n   * @api\n   */\n  getStyleFunction() {\n    return this.styleFunction_;\n  }\n\n  /**\n   * @private\n   */\n  handleGeometryChange_() {\n    this.changed();\n  }\n\n  /**\n   * @private\n   */\n  handleGeometryChanged_() {\n    if (this.geometryChangeKey_) {\n      unlistenByKey(this.geometryChangeKey_);\n      this.geometryChangeKey_ = null;\n    }\n    const geometry = this.getGeometry();\n    if (geometry) {\n      this.geometryChangeKey_ = listen(\n        geometry,\n        EventType.CHANGE,\n        this.handleGeometryChange_,\n        this\n      );\n    }\n    this.changed();\n  }\n\n  /**\n   * Set the default geometry for the feature.  This will update the property\n   * with the name returned by {@link module:ol/Feature~Feature#getGeometryName}.\n   * @param {Geometry|undefined} geometry The new geometry.\n   * @api\n   * @observable\n   */\n  setGeometry(geometry) {\n    this.set(this.geometryName_, geometry);\n  }\n\n  /**\n   * Set the style for the feature to override the layer style.  This can be a\n   * single style object, an array of styles, or a function that takes a\n   * resolution and returns an array of styles. To unset the feature style, call\n   * `setStyle()` without arguments or a falsey value.\n   * @param {import(\"./style/Style.js\").StyleLike} [style] Style for this feature.\n   * @api\n   * @fires module:ol/events/Event~BaseEvent#event:change\n   */\n  setStyle(style) {\n    this.style_ = style;\n    this.styleFunction_ = !style ? undefined : createStyleFunction(style);\n    this.changed();\n  }\n\n  /**\n   * Set the feature id.  The feature id is considered stable and may be used when\n   * requesting features or comparing identifiers returned from a remote source.\n   * The feature id can be used with the\n   * {@link module:ol/source/Vector~VectorSource#getFeatureById} method.\n   * @param {number|string|undefined} id The feature id.\n   * @api\n   * @fires module:ol/events/Event~BaseEvent#event:change\n   */\n  setId(id) {\n    this.id_ = id;\n    this.changed();\n  }\n\n  /**\n   * Set the property name to be used when getting the feature's default geometry.\n   * When calling {@link module:ol/Feature~Feature#getGeometry}, the value of the property with\n   * this name will be returned.\n   * @param {string} name The property name of the default geometry.\n   * @api\n   */\n  setGeometryName(name) {\n    this.removeChangeListener(this.geometryName_, this.handleGeometryChanged_);\n    this.geometryName_ = name;\n    this.addChangeListener(this.geometryName_, this.handleGeometryChanged_);\n    this.handleGeometryChanged_();\n  }\n}\n\n/**\n * Convert the provided object into a feature style function.  Functions passed\n * through unchanged.  Arrays of Style or single style objects wrapped\n * in a new feature style function.\n * @param {!import(\"./style/Style.js\").StyleFunction|!Array<import(\"./style/Style.js\").default>|!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/transform\n */\nimport {WORKER_OFFSCREEN_CANVAS} from './has.js';\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 {HTMLElement}\n * @private\n */\nlet transformStringDiv;\n\n/**\n * A rounded 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  if (WORKER_OFFSCREEN_CANVAS) {\n    return transformString;\n  }\n  const node =\n    transformStringDiv || (transformStringDiv = document.createElement('div'));\n  node.style.transform = transformString;\n  return node.style.transform;\n}\n","/**\n * @module ol/extent/Relationship\n */\n\n/**\n * Relationship to an extent.\n * @enum {number}\n */\nexport default {\n  UNKNOWN: 0,\n  INTERSECTING: 1,\n  ABOVE: 2,\n  RIGHT: 4,\n  BELOW: 8,\n  LEFT: 16,\n};\n","/**\n * @module ol/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 * @return {Array<Extent>} The extent within the real world extent.\n */\nexport function wrapAndSliceX(extent, projection) {\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) {\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/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 * @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 {function(number, import(\"../coordinate.js\").Coordinate):number} [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 * Projection definition class. One of these is created for each projection\n * supported in the application and stored in the {@link module:ol/proj} namespace.\n * You can use these in applications, but this is not required, as API params\n * and options use {@link module:ol/proj~ProjectionLike} which means the simple string\n * code will suffice.\n *\n * You can use {@link module:ol/proj.get} to retrieve the object for a particular\n * projection.\n *\n * The library includes definitions for `EPSG:4326` and `EPSG:3857`, together\n * with the following aliases:\n * * `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,\n *     http://www.opengis.net/gml/srs/epsg.xml#4326,\n *     urn:x-ogc:def:crs:EPSG:4326\n * * `EPSG:3857`: EPSG:102100, EPSG:102113, EPSG:900913,\n *     urn:ogc:def:crs:EPSG:6.18:3:3857,\n *     http://www.opengis.net/gml/srs/epsg.xml#3857\n *\n * If you use [proj4js](https://github.com/proj4js/proj4js), aliases can\n * be added using `proj4.defs()`. After all required projection definitions are\n * added, call the {@link module:ol/proj/proj4.register} function.\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 {function(number, import(\"../coordinate.js\").Coordinate):number|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 {function(number, import(\"../coordinate.js\").Coordinate):number|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 * @return {Array<number>} Output array of coordinate values.\n */\nexport function fromEPSG4326(input, output, dimension) {\n  const length = input.length;\n  dimension = dimension > 1 ? dimension : 2;\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 += dimension) {\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 * @return {Array<number>} Output array of coordinate values.\n */\nexport function toEPSG4326(input, output, dimension) {\n  const length = input.length;\n  dimension = dimension > 1 ? dimension : 2;\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 += dimension) {\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} 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|undefined} The transform function (if found).\n */\nexport function get(sourceCode, destinationCode) {\n  let transform;\n  if (sourceCode in transforms && destinationCode in transforms[sourceCode]) {\n    transform = transforms[sourceCode][destinationCode];\n  }\n  return transform;\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 * @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 {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 * @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/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://epsg.io/, and are a JS function, so can be loaded in a script\n * 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 Projection from './proj/Projection.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 {METERS_PER_UNIT} from './proj/Units.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 {applyTransform, getWidth} from './extent.js';\nimport {clamp, modulo} from './math.js';\nimport {equals, getWorldsAway} from './coordinate.js';\nimport {getDistance} from './sphere.js';\nimport {warn} from './console.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 * 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 * @typedef {function(Array<number>, Array<number>=, number=): Array<number>} TransformFunction\n * @api\n */\n\nexport {METERS_PER_UNIT};\n\nexport {Projection};\n\nlet showCoordinateWarning = true;\n\n/**\n * @param {boolean} [disable = true] 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  return typeof projectionLike === 'string'\n    ? getProj(/** @type {string} */ (projectionLike))\n    : /** @type {Projection} */ (projectionLike) || 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 === identityTransform && 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] Dimension.\n     * @return {Array<number>} Output.\n     */\n    function (input, output, dimension) {\n      const length = input.length;\n      dimension = dimension !== undefined ? dimension : 2;\n      output = output !== undefined ? output : new Array(length);\n      for (let i = 0; i < length; i += dimension) {\n        const point = coordTransform(input.slice(i, i + dimension));\n        const pointLength = point.length;\n        for (let j = 0, jj = dimension; 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} sourceProjection Source Projection object.\n * @param {Projection} destinationProjection Destination Projection\n *     object.\n * @return {TransformFunction} Transform function.\n */\nexport function getTransformFromProjections(\n  sourceProjection,\n  destinationProjection\n) {\n  const sourceCode = sourceProjection.getCode();\n  const destinationCode = destinationProjection.getCode();\n  let transformFunc = getTransformFunc(sourceCode, destinationCode);\n  if (!transformFunc) {\n    transformFunc = identityTransform;\n  }\n  return transformFunc;\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).\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  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/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 * @return {Array<number>} Transformed coordinates.\n */\nexport function transform2D(\n  flatCoordinates,\n  offset,\n  end,\n  stride,\n  transform,\n  dest\n) {\n  dest = dest ? dest : [];\n  let i = 0;\n  for (let j = offset; j < end; j += stride) {\n    const x = flatCoordinates[j];\n    const y = flatCoordinates[j + 1];\n    dest[i++] = transform[0] * x + transform[2] * y + transform[4];\n    dest[i++] = transform[1] * x + transform[3] * y + transform[5];\n  }\n  if (dest && dest.length != i) {\n    dest.length = i;\n  }\n  return dest;\n}\n\n/**\n * @param {Array<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 {abstract} from '../util.js';\nimport {\n  compose as composeTransform,\n  create as createTransform,\n} from '../transform.js';\nimport {\n  createEmpty,\n  createOrUpdateEmpty,\n  getHeight,\n  returnOrUpdate,\n} from '../extent.js';\nimport {get as getProjection, getTransform} from '../proj.js';\nimport {memoizeOne} from '../functions.js';\nimport {transform2D} from './flat/transform.js';\n\n/**\n * @typedef {'XY' | 'XYZ' | 'XYM' | 'XYZM'} GeometryLayout\n * The coordinate layout for geometries, indicating whether a 3rd or 4th z ('Z')\n * or measure ('M') coordinate is available.\n */\n\n/**\n * @typedef {'Point' | 'LineString' | 'LinearRing' | 'Polygon' | 'MultiPoint' | 'MultiLineString' | 'MultiPolygon' | 'GeometryCollection' | 'Circle'} Type\n * The geometry type.  One of `'Point'`, `'LineString'`, `'LinearRing'`,\n * `'Polygon'`, `'MultiPoint'`, `'MultiLineString'`, `'MultiPolygon'`,\n * `'GeometryCollection'`, or `'Circle'`.\n */\n\n/**\n * @type {import(\"../transform.js\").Transform}\n */\nconst tmpTransform = createTransform();\n\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * Base class for vector geometries.\n *\n * To get notified of changes to the geometry, register a listener for the\n * generic `change` event on your geometry instance.\n *\n * @abstract\n * @api\n */\nclass Geometry extends BaseObject {\n  constructor() {\n    super();\n\n    /**\n     * @private\n     * @type {import(\"../extent.js\").Extent}\n     */\n    this.extent_ = createEmpty();\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.extentRevision_ = -1;\n\n    /**\n     * @protected\n     * @type {number}\n     */\n    this.simplifiedGeometryMaxMinSquaredTolerance = 0;\n\n    /**\n     * @protected\n     * @type {number}\n     */\n    this.simplifiedGeometryRevision = 0;\n\n    /**\n     * Get a transformed and simplified version of the geometry.\n     * @abstract\n     * @param {number} revision The geometry revision.\n     * @param {number} squaredTolerance Squared tolerance.\n     * @param {import(\"../proj.js\").TransformFunction} [transform] Optional transform function.\n     * @return {Geometry} Simplified geometry.\n     */\n    this.simplifyTransformedInternal = memoizeOne(\n      (revision, squaredTolerance, transform) => {\n        if (!transform) {\n          return this.getSimplifiedGeometry(squaredTolerance);\n        }\n        const clone = this.clone();\n        clone.applyTransform(transform);\n        return clone.getSimplifiedGeometry(squaredTolerance);\n      }\n    );\n  }\n\n  /**\n   * Get a transformed and simplified version of the geometry.\n   * @abstract\n   * @param {number} squaredTolerance Squared tolerance.\n   * @param {import(\"../proj.js\").TransformFunction} [transform] Optional transform function.\n   * @return {Geometry} Simplified geometry.\n   */\n  simplifyTransformed(squaredTolerance, transform) {\n    return this.simplifyTransformedInternal(\n      this.getRevision(),\n      squaredTolerance,\n      transform\n    );\n  }\n\n  /**\n   * Make a complete copy of the geometry.\n   * @abstract\n   * @return {!Geometry} Clone.\n   */\n  clone() {\n    return abstract();\n  }\n\n  /**\n   * @abstract\n   * @param {number} x X.\n   * @param {number} y Y.\n   * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n   * @param {number} minSquaredDistance Minimum squared distance.\n   * @return {number} Minimum squared distance.\n   */\n  closestPointXY(x, y, closestPoint, minSquaredDistance) {\n    return abstract();\n  }\n\n  /**\n   * @param {number} x X.\n   * @param {number} y Y.\n   * @return {boolean} Contains (x, y).\n   */\n  containsXY(x, y) {\n    const coord = this.getClosestPoint([x, y]);\n    return coord[0] === x && coord[1] === y;\n  }\n\n  /**\n   * Return the closest point of the geometry to the passed point as\n   * {@link module:ol/coordinate~Coordinate coordinate}.\n   * @param {import(\"../coordinate.js\").Coordinate} point Point.\n   * @param {import(\"../coordinate.js\").Coordinate} [closestPoint] Closest point.\n   * @return {import(\"../coordinate.js\").Coordinate} Closest point.\n   * @api\n   */\n  getClosestPoint(point, closestPoint) {\n    closestPoint = closestPoint ? closestPoint : [NaN, NaN];\n    this.closestPointXY(point[0], point[1], closestPoint, Infinity);\n    return closestPoint;\n  }\n\n  /**\n   * Returns true if this geometry includes the specified coordinate. If the\n   * coordinate is on the boundary of the geometry, returns false.\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n   * @return {boolean} Contains coordinate.\n   * @api\n   */\n  intersectsCoordinate(coordinate) {\n    return this.containsXY(coordinate[0], coordinate[1]);\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @protected\n   * @return {import(\"../extent.js\").Extent} extent Extent.\n   */\n  computeExtent(extent) {\n    return abstract();\n  }\n\n  /**\n   * Get the extent of the geometry.\n   * @param {import(\"../extent.js\").Extent} [extent] Extent.\n   * @return {import(\"../extent.js\").Extent} extent Extent.\n   * @api\n   */\n  getExtent(extent) {\n    if (this.extentRevision_ != this.getRevision()) {\n      const extent = this.computeExtent(this.extent_);\n      if (isNaN(extent[0]) || isNaN(extent[1])) {\n        createOrUpdateEmpty(extent);\n      }\n      this.extentRevision_ = this.getRevision();\n    }\n    return returnOrUpdate(this.extent_, extent);\n  }\n\n  /**\n   * Rotate the geometry around a given coordinate. This modifies the geometry\n   * coordinates in place.\n   * @abstract\n   * @param {number} angle Rotation angle in radians.\n   * @param {import(\"../coordinate.js\").Coordinate} anchor The rotation center.\n   * @api\n   */\n  rotate(angle, anchor) {\n    abstract();\n  }\n\n  /**\n   * Scale the geometry (with an optional origin).  This modifies the geometry\n   * coordinates in place.\n   * @abstract\n   * @param {number} sx The scaling factor in the x-direction.\n   * @param {number} [sy] The scaling factor in the y-direction (defaults to sx).\n   * @param {import(\"../coordinate.js\").Coordinate} [anchor] The scale origin (defaults to the center\n   *     of the geometry extent).\n   * @api\n   */\n  scale(sx, sy, anchor) {\n    abstract();\n  }\n\n  /**\n   * Create a simplified version of this geometry.  For linestrings, this uses\n   * the [Douglas Peucker](https://en.wikipedia.org/wiki/Ramer-Douglas-Peucker_algorithm)\n   * algorithm.  For polygons, a quantization-based\n   * simplification is used to preserve topology.\n   * @param {number} tolerance The tolerance distance for simplification.\n   * @return {Geometry} A new, simplified version of the original geometry.\n   * @api\n   */\n  simplify(tolerance) {\n    return this.getSimplifiedGeometry(tolerance * tolerance);\n  }\n\n  /**\n   * Create a simplified version of this geometry using the Douglas Peucker\n   * algorithm.\n   * See https://en.wikipedia.org/wiki/Ramer-Douglas-Peucker_algorithm.\n   * @abstract\n   * @param {number} squaredTolerance Squared tolerance.\n   * @return {Geometry} Simplified geometry.\n   */\n  getSimplifiedGeometry(squaredTolerance) {\n    return abstract();\n  }\n\n  /**\n   * Get the type of this geometry.\n   * @abstract\n   * @return {Type} Geometry type.\n   */\n  getType() {\n    return abstract();\n  }\n\n  /**\n   * Apply a transform function to the coordinates of the geometry.\n   * The geometry is modified in place.\n   * If you do not want the geometry modified in place, first `clone()` it and\n   * then use this function on the clone.\n   * @abstract\n   * @param {import(\"../proj.js\").TransformFunction} transformFn Transform function.\n   * Called with a flat array of geometry coordinates.\n   */\n  applyTransform(transformFn) {\n    abstract();\n  }\n\n  /**\n   * Test if the geometry and the passed extent intersect.\n   * @abstract\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @return {boolean} `true` if the geometry and the extent intersect.\n   */\n  intersectsExtent(extent) {\n    return abstract();\n  }\n\n  /**\n   * Translate the geometry.  This modifies the geometry coordinates in place.  If\n   * instead you want a new geometry, first `clone()` this geometry.\n   * @abstract\n   * @param {number} deltaX Delta X.\n   * @param {number} deltaY Delta Y.\n   * @api\n   */\n  translate(deltaX, deltaY) {\n    abstract();\n  }\n\n  /**\n   * Transform each coordinate of the geometry from one coordinate reference\n   * system to another. The geometry is modified in place.\n   * For example, a line will be transformed to a line and a circle to a circle.\n   * If you do not want the geometry modified in place, first `clone()` it and\n   * then use this function on the clone.\n   *\n   * @param {import(\"../proj.js\").ProjectionLike} source The current projection.  Can be a\n   *     string identifier or a {@link module:ol/proj/Projection~Projection} object.\n   * @param {import(\"../proj.js\").ProjectionLike} destination The desired projection.  Can be a\n   *     string identifier or a {@link module:ol/proj/Projection~Projection} object.\n   * @return {Geometry} This geometry.  Note that original geometry is\n   *     modified in place.\n   * @api\n   */\n  transform(source, destination) {\n    /** @type {import(\"../proj/Projection.js\").default} */\n    const sourceProj = getProjection(source);\n    const transformFn =\n      sourceProj.getUnits() == 'tile-pixels'\n        ? function (inCoordinates, outCoordinates, stride) {\n            const pixelExtent = sourceProj.getExtent();\n            const projectedExtent = sourceProj.getWorldExtent();\n            const scale = getHeight(projectedExtent) / getHeight(pixelExtent);\n            composeTransform(\n              tmpTransform,\n              projectedExtent[0],\n              projectedExtent[3],\n              scale,\n              -scale,\n              0,\n              0,\n              0\n            );\n            transform2D(\n              inCoordinates,\n              0,\n              inCoordinates.length,\n              stride,\n              tmpTransform,\n              outCoordinates\n            );\n            return getTransform(sourceProj, destination)(\n              inCoordinates,\n              outCoordinates,\n              stride\n            );\n          }\n        : getTransform(sourceProj, destination);\n    this.applyTransform(transformFn);\n    return this;\n  }\n}\n\nexport default Geometry;\n","/**\n * @module ol/geom/SimpleGeometry\n */\nimport Geometry from './Geometry.js';\nimport {abstract} from '../util.js';\nimport {createOrUpdateFromFlatCoordinates, getCenter} from '../extent.js';\nimport {rotate, scale, transform2D, translate} from './flat/transform.js';\n\n/**\n * @classdesc\n * Abstract base class; only used for creating subclasses; do not instantiate\n * in apps, as cannot be rendered.\n *\n * @abstract\n * @api\n */\nclass SimpleGeometry extends Geometry {\n  constructor() {\n    super();\n\n    /**\n     * @protected\n     * @type {import(\"./Geometry.js\").GeometryLayout}\n     */\n    this.layout = 'XY';\n\n    /**\n     * @protected\n     * @type {number}\n     */\n    this.stride = 2;\n\n    /**\n     * @protected\n     * @type {Array<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   */\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   */\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   */\n  applyTransform(transformFn) {\n    if (this.flatCoordinates) {\n      transformFn(this.flatCoordinates, this.flatCoordinates, this.stride);\n      this.changed();\n    }\n  }\n\n  /**\n   * Rotate the geometry around a given coordinate. This modifies the geometry\n   * coordinates in place.\n   * @param {number} angle Rotation angle in counter-clockwise radians.\n   * @param {import(\"../coordinate.js\").Coordinate} anchor The rotation center.\n   * @api\n   */\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   */\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   */\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/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/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/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/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  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    twiceArea += y1 * x2 - x1 * y2;\n    x1 = x2;\n    y1 = y2;\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/LinearRing\n */\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {assignClosestPoint, maxSquaredDelta} from './flat/closest.js';\nimport {closestSquaredDistanceXY} from '../extent.js';\nimport {deflateCoordinates} from './flat/deflate.js';\nimport {douglasPeucker} from './flat/simplify.js';\nimport {inflateCoordinates} from './flat/inflate.js';\nimport {linearRing as linearRingArea} from './flat/area.js';\n\n/**\n * @classdesc\n * Linear ring geometry. Only used as part of polygon; cannot be rendered\n * on its own.\n *\n * @api\n */\nclass LinearRing extends SimpleGeometry {\n  /**\n   * @param {Array<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   */\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   */\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   */\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   */\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   */\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   */\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   */\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 SimpleGeometry from './SimpleGeometry.js';\nimport {containsXY, createOrUpdateFromCoordinate} from '../extent.js';\nimport {deflateCoordinate} from './flat/deflate.js';\nimport {squaredDistance as squaredDx} from '../math.js';\n\n/**\n * @classdesc\n * Point geometry.\n *\n * @api\n */\nclass Point extends SimpleGeometry {\n  /**\n   * @param {import(\"../coordinate.js\").Coordinate} coordinates Coordinates.\n   * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n   */\n  constructor(coordinates, layout) {\n    super();\n    this.setCoordinates(coordinates, layout);\n  }\n\n  /**\n   * Make a complete copy of the geometry.\n   * @return {!Point} Clone.\n   * @api\n   */\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   */\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   */\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   */\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   */\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   */\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   */\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://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 * @module ol/geom/flat/intersectsextent\n */\nimport {\n  containsExtent,\n  createEmpty,\n  extendFlatCoordinates,\n  intersects,\n  intersectsSegment,\n} from '../../extent.js';\nimport {forEach as forEachSegment} from './segments.js';\nimport {linearRingContainsExtent, linearRingContainsXY} from './contains.js';\n\n/**\n * @param {Array<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 intersectsLineString(\n  flatCoordinates,\n  offset,\n  end,\n  stride,\n  extent\n) {\n  const coordinatesExtent = extendFlatCoordinates(\n    createEmpty(),\n    flatCoordinates,\n    offset,\n    end,\n    stride\n  );\n  if (!intersects(extent, coordinatesExtent)) {\n    return false;\n  }\n  if (containsExtent(extent, coordinatesExtent)) {\n    return true;\n  }\n  if (coordinatesExtent[0] >= extent[0] && coordinatesExtent[2] <= extent[2]) {\n    return true;\n  }\n  if (coordinatesExtent[1] >= extent[1] && coordinatesExtent[3] <= extent[3]) {\n    return true;\n  }\n  return forEachSegment(\n    flatCoordinates,\n    offset,\n    end,\n    stride,\n    /**\n     * @param {import(\"../../coordinate.js\").Coordinate} point1 Start point.\n     * @param {import(\"../../coordinate.js\").Coordinate} point2 End point.\n     * @return {boolean} `true` if the segment and the extent intersect,\n     *     `false` otherwise.\n     */\n    function (point1, point2) {\n      return intersectsSegment(extent, point1, point2);\n    }\n  );\n}\n\n/**\n * @param {Array<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 LinearRing from './LinearRing.js';\nimport Point from './Point.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {arrayMaxSquaredDelta, assignClosestArrayPoint} from './flat/closest.js';\nimport {closestSquaredDistanceXY, getCenter, isEmpty} from '../extent.js';\nimport {deflateCoordinatesArray} from './flat/deflate.js';\nimport {extend} from '../array.js';\nimport {getInteriorPointOfArray} from './flat/interiorpoint.js';\nimport {inflateCoordinatesArray} from './flat/inflate.js';\nimport {intersectsLinearRingArray} from './flat/intersectsextent.js';\nimport {linearRingsAreOriented, orientLinearRings} from './flat/orient.js';\nimport {linearRings as linearRingsArea} from './flat/area.js';\nimport {linearRingsContainsXY} from './flat/contains.js';\nimport {modulo} from '../math.js';\nimport {quantizeArray} from './flat/simplify.js';\nimport {offset as sphereOffset} from '../sphere.js';\n\n/**\n * @classdesc\n * Polygon geometry.\n *\n * @api\n */\nclass Polygon extends SimpleGeometry {\n  /**\n   * @param {!Array<Array<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   */\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   */\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   */\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   */\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   */\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   */\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   */\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   */\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 BaseEvent from './events/Event.js';\nimport BaseObject from './Object.js';\nimport {circular as circularPolygon} from './geom/Polygon.js';\nimport {\n  get as getProjection,\n  getTransformFromProjections,\n  identityTransform,\n} from './proj.js';\nimport {toRadians} from './math.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\").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\").OnSignature<GeolocationObjectEventTypes, import(\"./Object\").ObjectEvent, Return> &\n *   import(\"./Observable\").OnSignature<'error', GeolocationError, Return> &\n *   import(\"./Observable\").CombinedOnSignature<import(\"./Observable\").EventTypes|GeolocationObjectEventTypes, Return> &\n *   import(\"./Observable\").OnSignature<import(\"./Observable\").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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {GeolocationOnSignature<import(\"./events\").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   */\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 EventTarget from './events/Target.js';\nimport EventType from './events/EventType.js';\nimport ImageState from './ImageState.js';\nimport {CREATE_IMAGE_BITMAP, IMAGE_DECODE} from './has.js';\nimport {listenOnce, unlistenByKey} from './events.js';\nimport {toPromise} from './functions.js';\n\n/**\n * A function that takes an {@link module:ol/Image~ImageWrapper} for the image and a\n * `{string}` for the src as arguments. It is supposed to make it so the\n * underlying image {@link module:ol/Image~ImageWrapper#getImage} is assigned the\n * content specified by the src. If not specified, the default is\n *\n *     function(image, src) {\n *       image.getImage().src = src;\n *     }\n *\n * Providing a custom `imageLoadFunction` can be useful to load images with\n * post requests or - in general - through XHR requests, where the src of the\n * image element would be set to a data URI when the content is loaded.\n *\n * @typedef {function(import(\"./Image.js\").default, string): void} LoadFunction\n * @api\n */\n\n/**\n * @typedef {Object} ImageObject\n * @property {import(\"./extent.js\").Extent} [extent] Extent, if different from the requested one.\n * @property {import(\"./resolution.js\").ResolutionLike} [resolution] Resolution, if different from the requested one.\n * When x and y resolution are different, use the array type (`[xResolution, yResolution]`).\n * @property {number} [pixelRatio] Pixel ratio, if different from the requested one.\n * @property {import('./DataTile.js').ImageLike} image Image.\n */\n\n/**\n * Loader function used for image sources. Receives extent, resolution and pixel ratio as arguments.\n * For images that cover any extent and resolution (static images), the loader function should not accept\n * any arguments. The function returns an {@link import(\"./DataTile.js\").ImageLike image}, an\n * {@link import(\"./Image.js\").ImageObject image object}, or a promise for the same.\n * For loaders that generate images, the promise should not resolve until the image is loaded.\n * If the returned image does not match the extent, resolution or pixel ratio passed to the loader,\n * it has to return an {@link import(\"./Image.js\").ImageObject image object} with the `image` and the\n * correct `extent`, `resolution` and `pixelRatio`.\n *\n * @typedef {function(import(\"./extent.js\").Extent, number, number, (function(HTMLImageElement, string): void)=): import(\"./DataTile.js\").ImageLike|ImageObject|Promise<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)=): import(\"./DataTile.js\").ImageLike|ImageObject|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|import(\"./Image.js\").Loader} stateOrLoader State.\n   */\n  constructor(extent, resolution, pixelRatio, stateOrLoader) {\n    super();\n\n    /**\n     * @protected\n     * @type {import(\"./extent.js\").Extent}\n     */\n    this.extent = extent;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.pixelRatio_ = pixelRatio;\n\n    /**\n     * @protected\n     * @type {number|Array<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 {import(\"./Image.js\").Loader}\n     */\n    this.loader = typeof stateOrLoader === 'function' ? stateOrLoader : null;\n  }\n\n  /**\n   * @protected\n   */\n  changed() {\n    this.dispatchEvent(EventType.CHANGE);\n  }\n\n  /**\n   * @return {import(\"./extent.js\").Extent} Extent.\n   */\n  getExtent() {\n    return this.extent;\n  }\n\n  /**\n   * @return {import('./DataTile.js').ImageLike} Image.\n   */\n  getImage() {\n    return this.image_;\n  }\n\n  /**\n   * @return {number} PixelRatio.\n   */\n  getPixelRatio() {\n    return this.pixelRatio_;\n  }\n\n  /**\n   * @return {number|Array<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(this.getExtent(), requestResolution, this.getPixelRatio())\n        )\n          .then((image) => {\n            if ('image' in image) {\n              this.image_ = image.image;\n            }\n            if ('extent' in image) {\n              this.extent = image.extent;\n            }\n            if ('resolution' in image) {\n              this.resolution = image.resolution;\n            }\n            if ('pixelRatio' in image) {\n              this.pixelRatio_ = image.pixelRatio;\n            }\n            if (\n              image instanceof HTMLImageElement ||\n              image instanceof ImageBitmap ||\n              image instanceof HTMLCanvasElement ||\n              image instanceof HTMLVideoElement\n            ) {\n              this.image_ = image;\n            }\n            this.state = ImageState.LOADED;\n          })\n          .catch((error) => {\n            this.state = ImageState.ERROR;\n            console.error(error); // eslint-disable-line no-console\n          })\n          .finally(() => this.changed());\n      }\n    }\n  }\n\n  /**\n   * @param {import('./DataTile.js').ImageLike} image The image.\n   */\n  setImage(image) {\n    this.image_ = image;\n  }\n\n  /**\n   * @param {number|Array<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 ImageState from './ImageState.js';\nimport ImageWrapper from './Image.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} 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}\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   */\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} Canvas element.\n   */\n  getImage() {\n    return this.canvas_;\n  }\n}\n\nexport default ImageCanvas;\n","/**\n * @module ol/ImageTile\n */\nimport Tile from './Tile.js';\nimport TileState from './TileState.js';\nimport {createCanvasContext2D} from './dom.js';\nimport {listenImage} from './Image.js';\n\nclass ImageTile extends Tile {\n  /**\n   * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n   * @param {import(\"./TileState.js\").default} state State.\n   * @param {string} src Image source URI.\n   * @param {?string} crossOrigin Cross origin.\n   * @param {import(\"./Tile.js\").LoadFunction} tileLoadFunction Tile load function.\n   * @param {import(\"./Tile.js\").Options} [options] Tile options.\n   */\n  constructor(tileCoord, state, src, crossOrigin, tileLoadFunction, options) {\n    super(tileCoord, state, options);\n\n    /**\n     * @private\n     * @type {?string}\n     */\n    this.crossOrigin_ = crossOrigin;\n\n    /**\n     * Image URI\n     *\n     * @private\n     * @type {string}\n     */\n    this.src_ = src;\n\n    this.key = src;\n\n    /**\n     * @private\n     * @type {HTMLImageElement|HTMLCanvasElement}\n     */\n    this.image_ = new Image();\n    if (crossOrigin !== null) {\n      this.image_.crossOrigin = crossOrigin;\n    }\n\n    /**\n     * @private\n     * @type {?function():void}\n     */\n    this.unlisten_ = null;\n\n    /**\n     * @private\n     * @type {import(\"./Tile.js\").LoadFunction}\n     */\n    this.tileLoadFunction_ = tileLoadFunction;\n  }\n\n  /**\n   * Get the HTML image element for this tile (may be a Canvas, Image, or Video).\n   * @return {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} Image.\n   * @api\n   */\n  getImage() {\n    return this.image_;\n  }\n\n  /**\n   * Sets an HTML image element for this tile (may be a Canvas or preloaded Image).\n   * @param {HTMLCanvasElement|HTMLImageElement} element Element.\n   */\n  setImage(element) {\n    this.image_ = element;\n    this.state = TileState.LOADED;\n    this.unlistenImage_();\n    this.changed();\n  }\n\n  /**\n   * Tracks loading or read errors.\n   *\n   * @private\n   */\n  handleImageError_() {\n    this.state = TileState.ERROR;\n    this.unlistenImage_();\n    this.image_ = getBlankImage();\n    this.changed();\n  }\n\n  /**\n   * Tracks successful image load.\n   *\n   * @private\n   */\n  handleImageLoad_() {\n    const image = /** @type {HTMLImageElement} */ (this.image_);\n    if (image.naturalWidth && image.naturalHeight) {\n      this.state = TileState.LOADED;\n    } else {\n      this.state = TileState.EMPTY;\n    }\n    this.unlistenImage_();\n    this.changed();\n  }\n\n  /**\n   * Load the image or retry if loading previously failed.\n   * Loading is taken care of by the tile queue, and calling this method is\n   * only needed for preloading or for reloading in case of an error.\n   *\n   * To retry loading tiles on failed requests, use a custom `tileLoadFunction`\n   * that checks for error status codes and reloads only when the status code is\n   * 408, 429, 500, 502, 503 and 504, and only when not too many retries have been\n   * made already:\n   *\n   * ```js\n   * const retryCodes = [408, 429, 500, 502, 503, 504];\n   * const retries = {};\n   * source.setTileLoadFunction((tile, src) => {\n   *   const image = tile.getImage();\n   *   fetch(src)\n   *     .then((response) => {\n   *       if (retryCodes.includes(response.status)) {\n   *         retries[src] = (retries[src] || 0) + 1;\n   *         if (retries[src] <= 3) {\n   *           setTimeout(() => tile.load(), retries[src] * 1000);\n   *         }\n   *         return Promise.reject();\n   *       }\n   *       return response.blob();\n   *     })\n   *     .then((blob) => {\n   *       const imageUrl = URL.createObjectURL(blob);\n   *       image.src = imageUrl;\n   *       setTimeout(() => URL.revokeObjectURL(imageUrl), 5000);\n   *     })\n   *     .catch(() => tile.setState(3)); // error\n   * });\n   * ```\n   *\n   * @api\n   */\n  load() {\n    if (this.state == TileState.ERROR) {\n      this.state = TileState.IDLE;\n      this.image_ = new Image();\n      if (this.crossOrigin_ !== null) {\n        this.image_.crossOrigin = this.crossOrigin_;\n      }\n    }\n    if (this.state == TileState.IDLE) {\n      this.state = TileState.LOADING;\n      this.changed();\n      this.tileLoadFunction_(this, this.src_);\n      this.unlisten_ = listenImage(\n        this.image_,\n        this.handleImageLoad_.bind(this),\n        this.handleImageError_.bind(this)\n      );\n    }\n  }\n\n  /**\n   * Discards event handlers which listen for load completion or errors.\n   *\n   * @private\n   */\n  unlistenImage_() {\n    if (this.unlisten_) {\n      this.unlisten_();\n      this.unlisten_ = null;\n    }\n  }\n}\n\n/**\n * Get a 1-pixel blank image.\n * @return {HTMLCanvasElement} Blank image.\n */\nfunction getBlankImage() {\n  const ctx = createCanvasContext2D(1, 1);\n  ctx.fillStyle = 'rgba(0,0,0,0)';\n  ctx.fillRect(0, 0, 1, 1);\n  return ctx.canvas;\n}\n\nexport default ImageTile;\n","/**\n * @module ol/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 * RGB space.\n *\n * @module  color-space/rgb\n */\n\nexport default {\n\tname: 'rgb',\n\tmin: [0,0,0],\n\tmax: [255,255,255],\n\tchannel: ['red', 'green', 'blue'],\n\talias: ['RGB']\n};\n","/**\n * CIE XYZ\n *\n * @module  color-space/xyz\n */\nimport rgb from './rgb.js';\n\nvar xyz = {\n\tname: 'xyz',\n\tmin: [0,0,0],\n\tchannel: ['X','Y','Z'],\n\talias: ['XYZ', 'ciexyz', 'cie1931']\n};\n\n\n/**\n * Whitepoint reference values with observer/illuminant\n *\n * http://en.wikipedia.org/wiki/Standard_illuminant\n */\nxyz.whitepoint = {\n\t//1931 2°\n\t2: {\n\t\t//incadescent\n\t\tA:[109.85, 100, 35.585],\n\t\t// B:[],\n\t\tC: [98.074, 100, 118.232],\n\t\tD50: [96.422, 100, 82.521],\n\t\tD55: [95.682, 100, 92.149],\n\t\t//daylight\n\t\tD65: [95.045592705167, 100, 108.9057750759878],\n\t\tD75: [94.972, 100, 122.638],\n\t\t//flourescent\n\t\t// F1: [],\n\t\tF2: [99.187, 100, 67.395],\n\t\t// F3: [],\n\t\t// F4: [],\n\t\t// F5: [],\n\t\t// F6:[],\n\t\tF7: [95.044, 100, 108.755],\n\t\t// F8: [],\n\t\t// F9: [],\n\t\t// F10: [],\n\t\tF11: [100.966, 100, 64.370],\n\t\t// F12: [],\n\t\tE: [100,100,100]\n\t},\n\n\t//1964  10°\n\t10: {\n\t\t//incadescent\n\t\tA:[111.144, 100, 35.200],\n\t\tC: [97.285, 100, 116.145],\n\t\tD50: [96.720, 100, 81.427],\n\t\tD55: [95.799, 100, 90.926],\n\t\t//daylight\n\t\tD65: [94.811, 100, 107.304],\n\t\tD75: [94.416, 100, 120.641],\n\t\t//flourescent\n\t\tF2: [103.280, 100, 69.026],\n\t\tF7: [95.792, 100, 107.687],\n\t\tF11: [103.866, 100, 65.627],\n\t\tE: [100,100,100]\n\t}\n};\n\n\n/**\n * Top values are the whitepoint’s top values, default are D65\n */\nxyz.max = xyz.whitepoint[2].D65;\n\n\n/**\n * Transform xyz to rgb\n *\n * @param {Array} xyz Array of xyz values\n *\n * @return {Array} RGB values\n */\nxyz.rgb = function (_xyz, white) {\n\t//FIXME: make sure we have to divide like this. Probably we have to replace matrix as well then\n\twhite = white || xyz.whitepoint[2].E;\n\n\tvar x = _xyz[0] / white[0],\n\t\ty = _xyz[1] / white[1],\n\t\tz = _xyz[2] / white[2],\n\t\tr, g, b;\n\n\t// assume sRGB\n\t// http://www.brucelindbloom.com/index.html?Eqn_RGB_XYZ_Matrix.html\n\tr = (x * 3.240969941904521) + (y * -1.537383177570093) + (z * -0.498610760293);\n\tg = (x * -0.96924363628087) + (y * 1.87596750150772) + (z * 0.041555057407175);\n\tb = (x * 0.055630079696993) + (y * -0.20397695888897) + (z * 1.056971514242878);\n\n\tr = r > 0.0031308 ? ((1.055 * Math.pow(r, 1.0 / 2.4)) - 0.055)\n\t\t: r = (r * 12.92);\n\n\tg = g > 0.0031308 ? ((1.055 * Math.pow(g, 1.0 / 2.4)) - 0.055)\n\t\t: g = (g * 12.92);\n\n\tb = b > 0.0031308 ? ((1.055 * Math.pow(b, 1.0 / 2.4)) - 0.055)\n\t\t: b = (b * 12.92);\n\n\tr = Math.min(Math.max(0, r), 1);\n\tg = Math.min(Math.max(0, g), 1);\n\tb = Math.min(Math.max(0, b), 1);\n\n\treturn [r * 255, g * 255, b * 255];\n}\n\n\n\n/**\n * RGB to XYZ\n *\n * @param {Array} rgb RGB channels\n *\n * @return {Array} XYZ channels\n */\nrgb.xyz = function(rgb, white) {\n\tvar r = rgb[0] / 255,\n\t\t\tg = rgb[1] / 255,\n\t\t\tb = rgb[2] / 255;\n\n\t// assume sRGB\n\tr = r > 0.04045 ? Math.pow(((r + 0.055) / 1.055), 2.4) : (r / 12.92);\n\tg = g > 0.04045 ? Math.pow(((g + 0.055) / 1.055), 2.4) : (g / 12.92);\n\tb = b > 0.04045 ? Math.pow(((b + 0.055) / 1.055), 2.4) : (b / 12.92);\n\n\tvar x = (r * 0.41239079926595) + (g * 0.35758433938387) + (b * 0.18048078840183);\n\tvar y = (r * 0.21263900587151) + (g * 0.71516867876775) + (b * 0.072192315360733);\n\tvar z = (r * 0.019330818715591) + (g * 0.11919477979462) + (b * 0.95053215224966);\n\n\twhite = white || xyz.whitepoint[2].E;\n\n\treturn [x * white[0], y * white[1], z * white[2]];\n};\n\n\n\nexport default xyz;\n","/**\n * CIE LUV (C'est la vie)\n *\n * @module color-space/luv\n */\n import xyz from './xyz.js';\n\nexport default {\n\tname: 'luv',\n\t//NOTE: luv has no rigidly defined limits\n\t//easyrgb fails to get proper coords\n\t//boronine states no rigid limits\n\t//colorMine refers this ones:\n\tmin: [0,-134,-140],\n\tmax: [100,224,122],\n\tchannel: ['lightness', 'u', 'v'],\n\talias: ['LUV', 'cieluv', 'cie1976'],\n\n\txyz: function(arg, i, o){\n\t\tvar _u, _v, l, u, v, x, y, z, xn, yn, zn, un, vn;\n\t\tl = arg[0], u = arg[1], v = arg[2];\n\n\t\tif (l === 0) return [0,0,0];\n\n\t\t//get constants\n\t\t//var e = 0.008856451679035631; //(6/29)^3\n\t\tvar k = 0.0011070564598794539; //(3/29)^3\n\n\t\t//get illuminant/observer\n\t\ti = i || 'D65';\n\t\to = o || 2;\n\n\t\txn = xyz.whitepoint[o][i][0];\n\t\tyn = xyz.whitepoint[o][i][1];\n\t\tzn = xyz.whitepoint[o][i][2];\n\n\t\tun = (4 * xn) / (xn + (15 * yn) + (3 * zn));\n\t\tvn = (9 * yn) / (xn + (15 * yn) + (3 * zn));\n\t\t// un = 0.19783000664283;\n\t\t// vn = 0.46831999493879;\n\n\n\t\t_u = u / (13 * l) + un || 0;\n\t\t_v = v / (13 * l) + vn || 0;\n\n\t\ty = l > 8 ? yn * Math.pow( (l + 16) / 116 , 3) : yn * l * k;\n\n\t\t//wikipedia method\n\t\tx = y * 9 * _u / (4 * _v) || 0;\n\t\tz = y * (12 - 3 * _u - 20 * _v) / (4 * _v) || 0;\n\n\t\t//boronine method\n\t\t//https://github.com/boronine/husl/blob/master/husl.coffee#L201\n\t\t// x = 0 - (9 * y * _u) / ((_u - 4) * _v - _u * _v);\n\t\t// z = (9 * y - (15 * _v * y) - (_v * x)) / (3 * _v);\n\n\t\treturn [x, y, z];\n\t}\n};\n\n// http://www.brucelindbloom.com/index.html?Equations.html\n// https://github.com/boronine/husl/blob/master/husl.coffee\n//i - illuminant\n//o - observer\nxyz.luv = function(arg, i, o) {\n\tvar _u, _v, l, u, v, x, y, z, xn, yn, zn, un, vn;\n\n\t//get constants\n\tvar e = 0.008856451679035631; //(6/29)^3\n\tvar k = 903.2962962962961; //(29/3)^3\n\n\t//get illuminant/observer coords\n\ti = i || 'D65';\n\to = o || 2;\n\n\txn = xyz.whitepoint[o][i][0];\n\tyn = xyz.whitepoint[o][i][1];\n\tzn = xyz.whitepoint[o][i][2];\n\n\tun = (4 * xn) / (xn + (15 * yn) + (3 * zn));\n\tvn = (9 * yn) / (xn + (15 * yn) + (3 * zn));\n\n\n\tx = arg[0], y = arg[1], z = arg[2];\n\n\n\t_u = (4 * x) / (x + (15 * y) + (3 * z)) || 0;\n\t_v = (9 * y) / (x + (15 * y) + (3 * z)) || 0;\n\n\tvar yr = y/yn;\n\n\tl = yr <= e ? k * yr : 116 * Math.pow(yr, 1/3) - 16;\n\n\tu = 13 * l * (_u - un);\n\tv = 13 * l * (_v - vn);\n\n\treturn [l, u, v];\n};\n","/**\n * Cylindrical CIE LUV\n *\n * @module color-space/lchuv\n */\nimport luv from './luv.js';\nimport xyz from './xyz.js';\n\n//cylindrical luv\nvar lchuv = {\n\tname: 'lchuv',\n\tchannel: ['lightness', 'chroma', 'hue'],\n\talias: ['LCHuv', 'cielchuv'],\n\tmin: [0,0,0],\n\tmax: [100,100,360],\n\n\tluv: function(luv){\n\t\tvar l = luv[0],\n\t\tc = luv[1],\n\t\th = luv[2],\n\t\tu, v, hr;\n\n\t\thr = h / 360 * 2 * Math.PI;\n\t\tu = c * Math.cos(hr);\n\t\tv = c * Math.sin(hr);\n\t\treturn [l, u, v];\n\t},\n\n\txyz: function(arg) {\n\t\treturn luv.xyz(lchuv.luv(arg));\n\t}\n};\n\nexport default lchuv;\n\nluv.lchuv = function(luv){\n\tvar l = luv[0], u = luv[1], v = luv[2];\n\n\tvar c = Math.sqrt(u*u + v*v);\n\tvar hr = Math.atan2(v,u);\n\tvar h = hr * 360 / 2 / Math.PI;\n\tif (h < 0) {\n\t\th += 360;\n\t}\n\n\treturn [l,c,h]\n};\n\nxyz.lchuv = function(arg){\n  return luv.lchuv(xyz.luv(arg));\n};\n","'use strict'\r\n\r\nmodule.exports = {\r\n\t\"aliceblue\": [240, 248, 255],\r\n\t\"antiquewhite\": [250, 235, 215],\r\n\t\"aqua\": [0, 255, 255],\r\n\t\"aquamarine\": [127, 255, 212],\r\n\t\"azure\": [240, 255, 255],\r\n\t\"beige\": [245, 245, 220],\r\n\t\"bisque\": [255, 228, 196],\r\n\t\"black\": [0, 0, 0],\r\n\t\"blanchedalmond\": [255, 235, 205],\r\n\t\"blue\": [0, 0, 255],\r\n\t\"blueviolet\": [138, 43, 226],\r\n\t\"brown\": [165, 42, 42],\r\n\t\"burlywood\": [222, 184, 135],\r\n\t\"cadetblue\": [95, 158, 160],\r\n\t\"chartreuse\": [127, 255, 0],\r\n\t\"chocolate\": [210, 105, 30],\r\n\t\"coral\": [255, 127, 80],\r\n\t\"cornflowerblue\": [100, 149, 237],\r\n\t\"cornsilk\": [255, 248, 220],\r\n\t\"crimson\": [220, 20, 60],\r\n\t\"cyan\": [0, 255, 255],\r\n\t\"darkblue\": [0, 0, 139],\r\n\t\"darkcyan\": [0, 139, 139],\r\n\t\"darkgoldenrod\": [184, 134, 11],\r\n\t\"darkgray\": [169, 169, 169],\r\n\t\"darkgreen\": [0, 100, 0],\r\n\t\"darkgrey\": [169, 169, 169],\r\n\t\"darkkhaki\": [189, 183, 107],\r\n\t\"darkmagenta\": [139, 0, 139],\r\n\t\"darkolivegreen\": [85, 107, 47],\r\n\t\"darkorange\": [255, 140, 0],\r\n\t\"darkorchid\": [153, 50, 204],\r\n\t\"darkred\": [139, 0, 0],\r\n\t\"darksalmon\": [233, 150, 122],\r\n\t\"darkseagreen\": [143, 188, 143],\r\n\t\"darkslateblue\": [72, 61, 139],\r\n\t\"darkslategray\": [47, 79, 79],\r\n\t\"darkslategrey\": [47, 79, 79],\r\n\t\"darkturquoise\": [0, 206, 209],\r\n\t\"darkviolet\": [148, 0, 211],\r\n\t\"deeppink\": [255, 20, 147],\r\n\t\"deepskyblue\": [0, 191, 255],\r\n\t\"dimgray\": [105, 105, 105],\r\n\t\"dimgrey\": [105, 105, 105],\r\n\t\"dodgerblue\": [30, 144, 255],\r\n\t\"firebrick\": [178, 34, 34],\r\n\t\"floralwhite\": [255, 250, 240],\r\n\t\"forestgreen\": [34, 139, 34],\r\n\t\"fuchsia\": [255, 0, 255],\r\n\t\"gainsboro\": [220, 220, 220],\r\n\t\"ghostwhite\": [248, 248, 255],\r\n\t\"gold\": [255, 215, 0],\r\n\t\"goldenrod\": [218, 165, 32],\r\n\t\"gray\": [128, 128, 128],\r\n\t\"green\": [0, 128, 0],\r\n\t\"greenyellow\": [173, 255, 47],\r\n\t\"grey\": [128, 128, 128],\r\n\t\"honeydew\": [240, 255, 240],\r\n\t\"hotpink\": [255, 105, 180],\r\n\t\"indianred\": [205, 92, 92],\r\n\t\"indigo\": [75, 0, 130],\r\n\t\"ivory\": [255, 255, 240],\r\n\t\"khaki\": [240, 230, 140],\r\n\t\"lavender\": [230, 230, 250],\r\n\t\"lavenderblush\": [255, 240, 245],\r\n\t\"lawngreen\": [124, 252, 0],\r\n\t\"lemonchiffon\": [255, 250, 205],\r\n\t\"lightblue\": [173, 216, 230],\r\n\t\"lightcoral\": [240, 128, 128],\r\n\t\"lightcyan\": [224, 255, 255],\r\n\t\"lightgoldenrodyellow\": [250, 250, 210],\r\n\t\"lightgray\": [211, 211, 211],\r\n\t\"lightgreen\": [144, 238, 144],\r\n\t\"lightgrey\": [211, 211, 211],\r\n\t\"lightpink\": [255, 182, 193],\r\n\t\"lightsalmon\": [255, 160, 122],\r\n\t\"lightseagreen\": [32, 178, 170],\r\n\t\"lightskyblue\": [135, 206, 250],\r\n\t\"lightslategray\": [119, 136, 153],\r\n\t\"lightslategrey\": [119, 136, 153],\r\n\t\"lightsteelblue\": [176, 196, 222],\r\n\t\"lightyellow\": [255, 255, 224],\r\n\t\"lime\": [0, 255, 0],\r\n\t\"limegreen\": [50, 205, 50],\r\n\t\"linen\": [250, 240, 230],\r\n\t\"magenta\": [255, 0, 255],\r\n\t\"maroon\": [128, 0, 0],\r\n\t\"mediumaquamarine\": [102, 205, 170],\r\n\t\"mediumblue\": [0, 0, 205],\r\n\t\"mediumorchid\": [186, 85, 211],\r\n\t\"mediumpurple\": [147, 112, 219],\r\n\t\"mediumseagreen\": [60, 179, 113],\r\n\t\"mediumslateblue\": [123, 104, 238],\r\n\t\"mediumspringgreen\": [0, 250, 154],\r\n\t\"mediumturquoise\": [72, 209, 204],\r\n\t\"mediumvioletred\": [199, 21, 133],\r\n\t\"midnightblue\": [25, 25, 112],\r\n\t\"mintcream\": [245, 255, 250],\r\n\t\"mistyrose\": [255, 228, 225],\r\n\t\"moccasin\": [255, 228, 181],\r\n\t\"navajowhite\": [255, 222, 173],\r\n\t\"navy\": [0, 0, 128],\r\n\t\"oldlace\": [253, 245, 230],\r\n\t\"olive\": [128, 128, 0],\r\n\t\"olivedrab\": [107, 142, 35],\r\n\t\"orange\": [255, 165, 0],\r\n\t\"orangered\": [255, 69, 0],\r\n\t\"orchid\": [218, 112, 214],\r\n\t\"palegoldenrod\": [238, 232, 170],\r\n\t\"palegreen\": [152, 251, 152],\r\n\t\"paleturquoise\": [175, 238, 238],\r\n\t\"palevioletred\": [219, 112, 147],\r\n\t\"papayawhip\": [255, 239, 213],\r\n\t\"peachpuff\": [255, 218, 185],\r\n\t\"peru\": [205, 133, 63],\r\n\t\"pink\": [255, 192, 203],\r\n\t\"plum\": [221, 160, 221],\r\n\t\"powderblue\": [176, 224, 230],\r\n\t\"purple\": [128, 0, 128],\r\n\t\"rebeccapurple\": [102, 51, 153],\r\n\t\"red\": [255, 0, 0],\r\n\t\"rosybrown\": [188, 143, 143],\r\n\t\"royalblue\": [65, 105, 225],\r\n\t\"saddlebrown\": [139, 69, 19],\r\n\t\"salmon\": [250, 128, 114],\r\n\t\"sandybrown\": [244, 164, 96],\r\n\t\"seagreen\": [46, 139, 87],\r\n\t\"seashell\": [255, 245, 238],\r\n\t\"sienna\": [160, 82, 45],\r\n\t\"silver\": [192, 192, 192],\r\n\t\"skyblue\": [135, 206, 235],\r\n\t\"slateblue\": [106, 90, 205],\r\n\t\"slategray\": [112, 128, 144],\r\n\t\"slategrey\": [112, 128, 144],\r\n\t\"snow\": [255, 250, 250],\r\n\t\"springgreen\": [0, 255, 127],\r\n\t\"steelblue\": [70, 130, 180],\r\n\t\"tan\": [210, 180, 140],\r\n\t\"teal\": [0, 128, 128],\r\n\t\"thistle\": [216, 191, 216],\r\n\t\"tomato\": [255, 99, 71],\r\n\t\"turquoise\": [64, 224, 208],\r\n\t\"violet\": [238, 130, 238],\r\n\t\"wheat\": [245, 222, 179],\r\n\t\"white\": [255, 255, 255],\r\n\t\"whitesmoke\": [245, 245, 245],\r\n\t\"yellow\": [255, 255, 0],\r\n\t\"yellowgreen\": [154, 205, 50]\r\n};\r\n","/**\n * @module color-parse\n */\nimport names from 'color-name'\n\nexport default parse\n\n/**\n * Base hues\n * http://dev.w3.org/csswg/css-color/#typedef-named-hue\n */\n//FIXME: use external hue detector\nvar baseHues = {\n\tred: 0,\n\torange: 60,\n\tyellow: 120,\n\tgreen: 180,\n\tblue: 240,\n\tpurple: 300\n}\n\n/**\n * Parse color from the string passed\n *\n * @return {Object} A space indicator `space`, an array `values` and `alpha`\n */\nfunction parse(cstr) {\n\tvar m, parts = [], alpha = 1, space\n\n\t//numeric case\n\tif (typeof cstr === 'number') {\n\t\treturn { space: 'rgb', values: [cstr >>> 16, (cstr & 0x00ff00) >>> 8, cstr & 0x0000ff], alpha: 1 }\n\t}\n\tif (typeof cstr === 'number') return { space: 'rgb', values: [cstr >>> 16, (cstr & 0x00ff00) >>> 8, cstr & 0x0000ff], alpha: 1 }\n\n\tcstr = String(cstr).toLowerCase();\n\n\t//keyword\n\tif (names[cstr]) {\n\t\tparts = names[cstr].slice()\n\t\tspace = 'rgb'\n\t}\n\n\t//reserved words\n\telse if (cstr === 'transparent') {\n\t\talpha = 0\n\t\tspace = 'rgb'\n\t\tparts = [0, 0, 0]\n\t}\n\n\t//hex\n\telse if (cstr[0] === '#') {\n\t\tvar base = cstr.slice(1)\n\t\tvar size = base.length\n\t\tvar isShort = size <= 4\n\t\talpha = 1\n\n\t\tif (isShort) {\n\t\t\tparts = [\n\t\t\t\tparseInt(base[0] + base[0], 16),\n\t\t\t\tparseInt(base[1] + base[1], 16),\n\t\t\t\tparseInt(base[2] + base[2], 16)\n\t\t\t]\n\t\t\tif (size === 4) {\n\t\t\t\talpha = parseInt(base[3] + base[3], 16) / 255\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tparts = [\n\t\t\t\tparseInt(base[0] + base[1], 16),\n\t\t\t\tparseInt(base[2] + base[3], 16),\n\t\t\t\tparseInt(base[4] + base[5], 16)\n\t\t\t]\n\t\t\tif (size === 8) {\n\t\t\t\talpha = parseInt(base[6] + base[7], 16) / 255\n\t\t\t}\n\t\t}\n\n\t\tif (!parts[0]) parts[0] = 0\n\t\tif (!parts[1]) parts[1] = 0\n\t\tif (!parts[2]) parts[2] = 0\n\n\t\tspace = 'rgb'\n\t}\n\n\t// color space\n\telse if (m = /^((?:rgba?|hs[lvb]a?|hwba?|cmyk?|xy[zy]|gray|lab|lchu?v?|[ly]uv|lms|oklch|oklab|color))\\s*\\(([^\\)]*)\\)/.exec(cstr)) {\n\t\tvar name = m[1]\n\t\tspace = name.replace(/a$/, '')\n\t\tvar dims = space === 'cmyk' ? 4 : space === 'gray' ? 1 : 3\n\t\tparts = m[2].trim().split(/\\s*[,\\/]\\s*|\\s+/)\n\n\t\t// color(srgb-linear x x x) -> srgb-linear(x x x)\n\t\tif (space === 'color') space = parts.shift()\n\n\t\tparts = parts.map(function (x, i) {\n\t\t\t//<percentage>\n\t\t\tif (x[x.length - 1] === '%') {\n\t\t\t\tx = parseFloat(x) / 100\n\t\t\t\t// alpha -> 0..1\n\t\t\t\tif (i === 3) return x\n\t\t\t\t// rgb -> 0..255\n\t\t\t\tif (space === 'rgb') return x * 255\n\t\t\t\t// hsl, hwb H -> 0..100\n\t\t\t\tif (space[0] === 'h') return x * 100\n\t\t\t\t// lch, lab L -> 0..100\n\t\t\t\tif (space[0] === 'l' && !i) return x * 100\n\t\t\t\t// lab A B -> -125..125\n\t\t\t\tif (space === 'lab') return x * 125\n\t\t\t\t// lch C -> 0..150, H -> 0..360\n\t\t\t\tif (space === 'lch') return i < 2 ? x * 150 : x * 360\n\t\t\t\t// oklch/oklab L -> 0..1\n\t\t\t\tif (space[0] === 'o' && !i) return x\n\t\t\t\t// oklab A B -> -0.4..0.4\n\t\t\t\tif (space === 'oklab') return x * 0.4\n\t\t\t\t// oklch C -> 0..0.4, H -> 0..360\n\t\t\t\tif (space === 'oklch') return i < 2 ? x * 0.4 : x * 360\n\t\t\t\t// color(xxx) -> 0..1\n\t\t\t\treturn x\n\t\t\t}\n\n\t\t\t//hue\n\t\t\tif (space[i] === 'h' || (i === 2 && space[space.length - 1] === 'h')) {\n\t\t\t\t//<base-hue>\n\t\t\t\tif (baseHues[x] !== undefined) return baseHues[x]\n\t\t\t\t//<deg>\n\t\t\t\tif (x.endsWith('deg')) return parseFloat(x)\n\t\t\t\t//<turn>\n\t\t\t\tif (x.endsWith('turn')) return parseFloat(x) * 360\n\t\t\t\tif (x.endsWith('grad')) return parseFloat(x) * 360 / 400\n\t\t\t\tif (x.endsWith('rad')) return parseFloat(x) * 180 / Math.PI\n\t\t\t}\n\t\t\tif (x === 'none') return 0\n\t\t\treturn parseFloat(x)\n\t\t});\n\n\t\talpha = parts.length > dims ? parts.pop() : 1\n\t}\n\n\t//named channels case\n\telse if (/[0-9](?:\\s|\\/|,)/.test(cstr)) {\n\t\tparts = cstr.match(/([0-9]+)/g).map(function (value) {\n\t\t\treturn parseFloat(value)\n\t\t})\n\n\t\tspace = cstr.match(/([a-z])/ig)?.join('')?.toLowerCase() || 'rgb'\n\t}\n\n\treturn {\n\t\tspace,\n\t\tvalues: parts,\n\t\talpha\n\t}\n}\n","/**\n * @module color-space/hsl\n */\nimport rgb from './rgb.js';\n\nexport default {\n\tname: 'hsl',\n\tmin: [0,0,0],\n\tmax: [360,100,100],\n\tchannel: ['hue', 'saturation', 'lightness'],\n\talias: ['HSL'],\n\n\trgb: function(hsl) {\n\t\tvar h = hsl[0]/360, s = hsl[1]/100, l = hsl[2]/100, t1, t2, t3, rgb, val, i=0;\n\n\t\tif (s === 0) return val = l * 255, [val, val, val];\n\n\t\tt2 = l < 0.5 ? l * (1 + s) : l + s - l * s;\n\t\tt1 = 2 * l - t2;\n\n\t\trgb = [0, 0, 0];\n\t\tfor (;i<3;) {\n\t\t\tt3 = h + 1 / 3 * - (i - 1);\n\t\t\tt3 < 0 ? t3++ : t3 > 1 && t3--;\n\t\t\tval = 6 * t3 < 1 ? t1 + (t2 - t1) * 6 * t3 :\n\t\t\t2 * t3 < 1 ? t2 :\n\t\t\t3 * t3 < 2 ?  t1 + (t2 - t1) * (2 / 3 - t3) * 6 :\n\t\t\tt1;\n\t\t\trgb[i++] = val * 255;\n\t\t}\n\n\t\treturn rgb;\n\t}\n};\n\n\n//extend rgb\nrgb.hsl = function(rgb) {\n\tvar r = rgb[0]/255,\n\t\t\tg = rgb[1]/255,\n\t\t\tb = rgb[2]/255,\n\t\t\tmin = Math.min(r, g, b),\n\t\t\tmax = Math.max(r, g, b),\n\t\t\tdelta = max - min,\n\t\t\th, s, l;\n\n\tif (max === min) {\n\t\th = 0;\n\t}\n\telse if (r === max) {\n\t\th = (g - b) / delta;\n\t}\n\telse if (g === max) {\n\t\th = 2 + (b - r) / delta;\n\t}\n\telse if (b === max) {\n\t\th = 4 + (r - g)/ delta;\n\t}\n\n\th = Math.min(h * 60, 360);\n\n\tif (h < 0) {\n\t\th += 360;\n\t}\n\n\tl = (min + max) / 2;\n\n\tif (max === min) {\n\t\ts = 0;\n\t}\n\telse if (l <= 0.5) {\n\t\ts = delta / (max + min);\n\t}\n\telse {\n\t\ts = delta / (2 - max - min);\n\t}\n\n\treturn [h, s * 100, l * 100];\n};\n","/** @module  color-rgba */\nimport parse from 'color-parse'\nimport rgb from 'color-space/rgb.js'\nimport hsl from 'color-space/hsl.js'\n\nexport default function rgba(color) {\n\t// template literals\n\tif (Array.isArray(color) && color.raw) color = String.raw(...arguments)\n\tif (color instanceof Number) color = +color\n\n\tvar values, i, l\n\n\t//attempt to parse non-array arguments\n\tvar parsed = parse(color)\n\n\tif (!parsed.space) return []\n\n\tconst min = parsed.space[0] === 'h' ? hsl.min : rgb.min\n\tconst max = parsed.space[0] === 'h' ? hsl.max : rgb.max\n\n\tvalues = Array(3)\n\tvalues[0] = Math.min(Math.max(parsed.values[0], min[0]), max[0])\n\tvalues[1] = Math.min(Math.max(parsed.values[1], min[1]), max[1])\n\tvalues[2] = Math.min(Math.max(parsed.values[2], min[2]), max[2])\n\n\tif (parsed.space[0] === 'h') {\n\t\tvalues = hsl.rgb(values)\n\t}\n\n\tvalues.push(Math.min(Math.max(parsed.alpha, 0), 1))\n\n\treturn values\n}\n","/**\n * @module ol/color\n */\nimport lchuv from 'color-space/lchuv.js';\nimport parseRgba from 'color-rgba';\nimport rgb from 'color-space/rgb.js';\nimport xyz from 'color-space/xyz.js';\nimport {clamp} from './math.js';\n\n/**\n * A color represented as a short array [red, green, blue, alpha].\n * red, green, and blue should be integers in the range 0..255 inclusive.\n * alpha should be a float in the range 0..1 inclusive. If no alpha value is\n * given then `1` will be used.\n * @typedef {Array<number>} Color\n * @api\n */\n\n/**\n * Return the color as an rgba string.\n * @param {Color|string} color Color.\n * @return {string} Rgba string.\n * @api\n */\nexport function asString(color) {\n  if (typeof color === 'string') {\n    return color;\n  }\n  return toString(color);\n}\n\n/**\n * @type {number}\n */\nconst MAX_CACHE_SIZE = 1024;\n\n/**\n * We maintain a small cache of parsed strings.  Whenever the cache grows too large,\n * we delete an arbitrary set of the entries.\n *\n * @type {Object<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/**\n * @param {Color} color RGBA color.\n * @return {Color} LCHuv color with alpha.\n */\nexport function rgbaToLcha(color) {\n  const output = xyz.lchuv(rgb.xyz(color));\n  output[3] = color[3];\n  return output;\n}\n\n/**\n * @param {Color} color LCHuv color with alpha.\n * @return {Color} RGBA color.\n */\nexport function lchaToRgba(color) {\n  const output = xyz.rgb(lchuv.xyz(color));\n  output[3] = color[3];\n  return output;\n}\n\n/**\n * @param {string} s String.\n * @return {Color} Color.\n */\nexport function fromString(s) {\n  if (cache.hasOwnProperty(s)) {\n    return cache[s];\n  }\n  if (cacheSize >= MAX_CACHE_SIZE) {\n    let i = 0;\n    for (const key in cache) {\n      if ((i++ & 3) === 0) {\n        delete cache[key];\n        --cacheSize;\n      }\n    }\n  }\n\n  const color = parseRgba(s);\n  if (color.length !== 4) {\n    throw new Error('Failed to parse \"' + s + '\" as color');\n  }\n  for (const c of color) {\n    if (isNaN(c)) {\n      throw new Error('Failed to parse \"' + s + '\" as color');\n    }\n  }\n  normalize(color);\n  cache[s] = color;\n  ++cacheSize;\n  return color;\n}\n\n/**\n * Return the color as an array. This function maintains a cache of calculated\n * arrays which means the result should not be modified.\n * @param {Color|string} color Color.\n * @return {Color} Color.\n * @api\n */\nexport function asArray(color) {\n  if (Array.isArray(color)) {\n    return color;\n  }\n  return fromString(color);\n}\n\n/**\n * Exported for the tests.\n * @param {Color} color Color.\n * @return {Color} Clamped color.\n */\nexport function normalize(color) {\n  color[0] = clamp((color[0] + 0.5) | 0, 0, 255);\n  color[1] = clamp((color[1] + 0.5) | 0, 0, 255);\n  color[2] = clamp((color[2] + 0.5) | 0, 0, 255);\n  color[3] = clamp(color[3], 0, 1);\n  return color;\n}\n\n/**\n * @param {Color} color Color.\n * @return {string} String.\n */\nexport function toString(color) {\n  let r = color[0];\n  if (r != (r | 0)) {\n    r = (r + 0.5) | 0;\n  }\n  let g = color[1];\n  if (g != (g | 0)) {\n    g = (g + 0.5) | 0;\n  }\n  let b = color[2];\n  if (b != (b | 0)) {\n    b = (b + 0.5) | 0;\n  }\n  const a = color[3] === undefined ? 1 : Math.round(color[3] * 100) / 100;\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/style/IconImageCache\n */\nimport {asString} from '../color.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 {number}\n     * @private\n     */\n    this.cacheSize_ = 0;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.maxCacheSize_ = 32;\n  }\n\n  /**\n   * FIXME empty description for jsdoc\n   */\n  clear() {\n    this.cache_ = {};\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          --this.cacheSize_;\n        }\n      }\n    }\n  }\n\n  /**\n   * @param {string} src Src.\n   * @param {?string} crossOrigin Cross origin.\n   * @param {import(\"../color.js\").Color} color Color.\n   * @return {import(\"./IconImage.js\").default} Icon image.\n   */\n  get(src, crossOrigin, color) {\n    const key = getKey(src, crossOrigin, color);\n    return key in this.cache_ ? this.cache_[key] : null;\n  }\n\n  /**\n   * @param {string} src Src.\n   * @param {?string} crossOrigin Cross origin.\n   * @param {import(\"../color.js\").Color} color Color.\n   * @param {import(\"./IconImage.js\").default} iconImage Icon image.\n   */\n  set(src, crossOrigin, color, iconImage) {\n    const key = getKey(src, crossOrigin, color);\n    this.cache_[key] = iconImage;\n    ++this.cacheSize_;\n  }\n\n  /**\n   * Set the cache size of the icon cache. Default is `32`. Change this value when\n   * your map uses more than 32 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 {?string} crossOrigin Cross origin.\n * @param {import(\"../color.js\").Color} color Color.\n * @return {string} Cache key.\n */\nfunction getKey(src, crossOrigin, color) {\n  const colorString = color ? asString(color) : 'null';\n  return crossOrigin + ':' + 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/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 LayerProperty from './Property.js';\nimport {abstract} from '../util.js';\nimport {assert} from '../asserts.js';\nimport {clamp} from '../math.js';\n\n/**\n * A css color, or a function called with a view resolution returning a css color.\n *\n * @typedef {string|function(number):string} BackgroundColor\n * @api\n */\n\n/**\n * @typedef {import(\"../ObjectEventType\").Types|'change:extent'|'change:maxResolution'|'change:maxZoom'|\n *    'change:minResolution'|'change:minZoom'|'change:opacity'|'change:visible'|'change:zIndex'} BaseLayerObjectEventTypes\n */\n\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<BaseLayerObjectEventTypes, import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|BaseLayerObjectEventTypes, Return>} BaseLayerOnSignature\n */\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-layer'] A CSS class name to set to the layer element.\n * @property {number} [opacity=1] Opacity (0, 1).\n * @property {boolean} [visible=true] Visibility.\n * @property {import(\"../extent.js\").Extent} [extent] The bounding extent for layer rendering.  The layer will not be\n * rendered outside of this extent.\n * @property {number | undefined} [zIndex] The z-index for layer rendering.  At rendering time, the layers\n * will be ordered, first by Z-index and then by position. When `undefined`, a `zIndex` of 0 is assumed\n * for layers that are added to the map's `layers` collection, or `Infinity` when the layer's `setMap()`\n * method was used.\n * @property {number} [minResolution] The minimum resolution (inclusive) at which this layer will be\n * visible.\n * @property {number} [maxResolution] The maximum resolution (exclusive) below which this layer will\n * be visible.\n * @property {number} [minZoom] The minimum view zoom level (exclusive) above which this layer will be\n * visible.\n * @property {number} [maxZoom] The maximum view zoom level (inclusive) at which this layer will\n * be visible.\n * @property {BackgroundColor} [background] Background color for the layer. If not specified, no background\n * will be rendered.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * Note that with {@link module:ol/layer/Base~BaseLayer} and all its subclasses, any property set in\n * the options is set as a {@link module:ol/Object~BaseObject} property on the layer object, so\n * is observable, and has get/set accessors.\n *\n * @api\n */\nclass BaseLayer extends BaseObject {\n  /**\n   * @param {Options} options Layer options.\n   */\n  constructor(options) {\n    super();\n\n    /***\n     * @type {BaseLayerOnSignature<import(\"../events\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {BaseLayerOnSignature<import(\"../events\").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 {Object<string, *>}\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   */\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/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/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/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/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 {clamp} from './math.js';\nimport {getHeight, getWidth} from './extent.js';\nimport {linearFindNearest} from './array.js';\n\n/**\n * @typedef {function((number|undefined), number, import(\"./size.js\").Size, boolean=): (number|undefined)} Type\n */\n\n/**\n * Returns a modified resolution taking into account the viewport size and maximum\n * allowed extent.\n * @param {number} resolution Resolution\n * @param {import(\"./extent.js\").Extent} maxExtent Maximum allowed extent.\n * @param {import(\"./size.js\").Size} viewportSize Viewport size.\n * @param {boolean} showFullExtent Whether to show the full extent.\n * @return {number} Capped resolution.\n */\nfunction getViewportClampedResolution(\n  resolution,\n  maxExtent,\n  viewportSize,\n  showFullExtent\n) {\n  const xResolution = getWidth(maxExtent) / viewportSize[0];\n  const yResolution = getHeight(maxExtent) / viewportSize[1];\n\n  if (showFullExtent) {\n    return Math.min(resolution, Math.max(xResolution, yResolution));\n  }\n  return Math.min(resolution, Math.min(xResolution, yResolution));\n}\n\n/**\n * Returns a modified resolution to be between maxResolution and minResolution while\n * still allowing the value to be slightly out of bounds.\n * Note: the computation is based on the logarithm function (ln):\n *  - at 1, ln(x) is 0\n *  - above 1, ln(x) keeps increasing but at a much slower pace than x\n * The final result is clamped to prevent getting too far away from bounds.\n * @param {number} resolution Resolution.\n * @param {number} maxResolution Max resolution.\n * @param {number} minResolution Min resolution.\n * @return {number} Smoothed resolution.\n */\nfunction getSmoothClampedResolution(resolution, maxResolution, minResolution) {\n  let result = Math.min(resolution, maxResolution);\n  const ratio = 50;\n\n  result *=\n    Math.log(1 + ratio * Math.max(0, resolution / maxResolution - 1)) / ratio +\n    1;\n  if (minResolution) {\n    result = Math.max(result, minResolution);\n    result /=\n      Math.log(1 + ratio * Math.max(0, minResolution / resolution - 1)) /\n        ratio +\n      1;\n  }\n  return clamp(result, minResolution / 2, maxResolution * 2);\n}\n\n/**\n * @param {Array<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/View\n */\nimport BaseObject from './Object.js';\nimport ViewHint from './ViewHint.js';\nimport ViewProperty from './ViewProperty.js';\nimport {DEFAULT_TILE_SIZE} from './tilegrid/common.js';\nimport {\n  METERS_PER_UNIT,\n  createProjection,\n  disableCoordinateWarning,\n  fromUserCoordinate,\n  fromUserExtent,\n  getUserProjection,\n  toUserCoordinate,\n  toUserExtent,\n} from './proj.js';\nimport {VOID} from './functions.js';\nimport {\n  add as addCoordinate,\n  equals as coordinatesEqual,\n  equals,\n  rotate as rotateCoordinate,\n} from './coordinate.js';\nimport {assert} from './asserts.js';\nimport {none as centerNone, createExtent} from './centerconstraint.js';\nimport {clamp, modulo} from './math.js';\nimport {\n  createMinMaxResolution,\n  createSnapToPower,\n  createSnapToResolutions,\n} from './resolutionconstraint.js';\nimport {\n  createSnapToN,\n  createSnapToZero,\n  disable,\n  none as rotationNone,\n} from './rotationconstraint.js';\nimport {easeOut, inAndOut} from './easing.js';\nimport {\n  getCenter,\n  getForViewAndSize,\n  getHeight,\n  getWidth,\n  isEmpty,\n} from './extent.js';\nimport {linearFindNearest} from './array.js';\nimport {fromExtent as polygonFromExtent} from './geom/Polygon.js';\n\n/**\n * An animation configuration\n *\n * @typedef {Object} Animation\n * @property {import(\"./coordinate.js\").Coordinate} [sourceCenter] Source center.\n * @property {import(\"./coordinate.js\").Coordinate} [targetCenter] Target center.\n * @property {number} [sourceResolution] Source resolution.\n * @property {number} [targetResolution] Target resolution.\n * @property {number} [sourceRotation] Source rotation.\n * @property {number} [targetRotation] Target rotation.\n * @property {import(\"./coordinate.js\").Coordinate} [anchor] Anchor.\n * @property {number} start Start.\n * @property {number} duration Duration.\n * @property {boolean} complete Complete.\n * @property {function(number):number} easing Easing.\n * @property {function(boolean):void} callback Callback.\n */\n\n/**\n * @typedef {Object} Constraints\n * @property {import(\"./centerconstraint.js\").Type} center Center.\n * @property {import(\"./resolutionconstraint.js\").Type} resolution Resolution.\n * @property {import(\"./rotationconstraint.js\").Type} rotation Rotation.\n */\n\n/**\n * @typedef {Object} FitOptions\n * @property {import(\"./size.js\").Size} [size] The size in pixels of the box to\n * fit the extent into. Defaults to the size of the map the view is associated with.\n * If no map or multiple maps are connected to the view, provide the desired box size\n * (e.g. `map.getSize()`).\n * @property {!Array<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\").Types|'change:center'|'change:resolution'|'change:rotation'} ViewObjectEventTypes\n */\n\n/***\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature<import(\"./Observable\").EventTypes, import(\"./events/Event.js\").default, Return> &\n *   import(\"./Observable\").OnSignature<ViewObjectEventTypes, import(\"./Object\").ObjectEvent, Return> &\n *   import(\"./Observable\").CombinedOnSignature<import(\"./Observable\").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 */\nclass View extends BaseObject {\n  /**\n   * @param {ViewOptions} [options] View options.\n   */\n  constructor(options) {\n    super();\n\n    /***\n     * @type {ViewOnSignature<import(\"./events\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {ViewOnSignature<import(\"./events\").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_) {\n      if (this.resolutions_.length <= 1) {\n        return 0;\n      }\n      const baseLevel = clamp(\n        Math.floor(zoom),\n        0,\n        this.resolutions_.length - 2\n      );\n      const zoomFactor =\n        this.resolutions_[baseLevel] / this.resolutions_[baseLevel + 1];\n      return (\n        this.resolutions_[baseLevel] /\n        Math.pow(zoomFactor, clamp(zoom - baseLevel, 0, 1))\n      );\n    }\n    return (\n      this.maxResolution_ / Math.pow(this.zoomFactor_, zoom - this.minZoom_)\n    );\n  }\n\n  /**\n   * Fit the given geometry or extent based on the given map size and border.\n   * The size is pixel dimensions of the box to fit the extent into.\n   * In most cases you will want to use the map size, that is `map.getSize()`.\n   * Takes care of the map angle.\n   * @param {import(\"./geom/SimpleGeometry.js\").default|import(\"./extent.js\").Extent} geometryOrExtent The geometry or\n   *     extent to fit the view to.\n   * @param {FitOptions} [options] Options.\n   * @api\n   */\n  fit(geometryOrExtent, options) {\n    /** @type {import(\"./geom/SimpleGeometry.js\").default} */\n    let geometry;\n    assert(\n      Array.isArray(geometryOrExtent) ||\n        typeof (/** @type {?} */ (geometryOrExtent).getSimplifiedGeometry) ===\n          'function',\n      'Invalid extent or geometry provided as `geometry`'\n    );\n    if (Array.isArray(geometryOrExtent)) {\n      assert(\n        !isEmpty(geometryOrExtent),\n        'Cannot fit empty extent provided as `geometry`'\n      );\n      const extent = fromUserExtent(geometryOrExtent, this.getProjection());\n      geometry = polygonFromExtent(extent);\n    } else if (geometryOrExtent.getType() === 'Circle') {\n      const extent = fromUserExtent(\n        geometryOrExtent.getExtent(),\n        this.getProjection()\n      );\n      geometry = polygonFromExtent(extent);\n      geometry.rotate(this.getRotation(), getCenter(extent));\n    } else {\n      const userProjection = getUserProjection();\n      if (userProjection) {\n        geometry = /** @type {import(\"./geom/SimpleGeometry.js\").default} */ (\n          geometryOrExtent\n            .clone()\n            .transform(userProjection, this.getProjection())\n        );\n      } else {\n        geometry = geometryOrExtent;\n      }\n    }\n\n    this.fitInternal(geometry, options);\n  }\n\n  /**\n   * Calculate rotated extent\n   * @param {import(\"./geom/SimpleGeometry.js\").default} geometry The geometry.\n   * @return {import(\"./extent\").Extent} The rotated extent for the geometry.\n   */\n  rotatedExtentForGeometry(geometry) {\n    const rotation = this.getRotation();\n    const cosAngle = Math.cos(rotation);\n    const sinAngle = Math.sin(-rotation);\n    const coords = geometry.getFlatCoordinates();\n    const stride = geometry.getStride();\n    let minRotX = +Infinity;\n    let minRotY = +Infinity;\n    let maxRotX = -Infinity;\n    let maxRotY = -Infinity;\n    for (let i = 0, ii = coords.length; i < ii; i += stride) {\n      const rotX = coords[i] * cosAngle - coords[i + 1] * sinAngle;\n      const rotY = coords[i] * sinAngle + coords[i + 1] * cosAngle;\n      minRotX = Math.min(minRotX, rotX);\n      minRotY = Math.min(minRotY, rotY);\n      maxRotX = Math.max(maxRotX, rotX);\n      maxRotY = Math.max(maxRotY, rotY);\n    }\n    return [minRotX, minRotY, maxRotX, maxRotY];\n  }\n\n  /**\n   * @param {import(\"./geom/SimpleGeometry.js\").default} geometry The geometry.\n   * @param {FitOptions} [options] Options.\n   */\n  fitInternal(geometry, options) {\n    options = options || {};\n    let size = options.size;\n    if (!size) {\n      size = this.getViewportSizeMinusPadding_();\n    }\n    const padding =\n      options.padding !== undefined ? options.padding : [0, 0, 0, 0];\n    const nearest = options.nearest !== undefined ? options.nearest : false;\n    let minResolution;\n    if (options.minResolution !== undefined) {\n      minResolution = options.minResolution;\n    } else if (options.maxZoom !== undefined) {\n      minResolution = this.getResolutionForZoom(options.maxZoom);\n    } else {\n      minResolution = 0;\n    }\n\n    const rotatedExtent = this.rotatedExtentForGeometry(geometry);\n\n    // calculate resolution\n    let resolution = this.getResolutionForExtentInternal(rotatedExtent, [\n      size[0] - padding[1] - padding[3],\n      size[1] - padding[0] - padding[2],\n    ]);\n    resolution = isNaN(resolution)\n      ? minResolution\n      : Math.max(resolution, minResolution);\n    resolution = this.getConstrainedResolution(resolution, nearest ? 0 : 1);\n\n    // calculate center\n    const rotation = this.getRotation();\n    const sinAngle = Math.sin(rotation);\n    const cosAngle = Math.cos(rotation);\n    const centerRot = getCenter(rotatedExtent);\n    centerRot[0] += ((padding[1] - padding[3]) / 2) * resolution;\n    centerRot[1] += ((padding[0] - padding[2]) / 2) * resolution;\n    const centerX = centerRot[0] * cosAngle - centerRot[1] * sinAngle;\n    const centerY = centerRot[1] * cosAngle + centerRot[0] * sinAngle;\n    const center = this.getConstrainedCenter([centerX, centerY], resolution);\n    const callback = options.callback ? options.callback : VOID;\n\n    if (options.duration !== undefined) {\n      this.animateInternal(\n        {\n          resolution: resolution,\n          center: center,\n          duration: options.duration,\n          easing: options.easing,\n        },\n        callback\n      );\n    } else {\n      this.targetResolution_ = resolution;\n      this.targetCenter_ = center;\n      this.applyTargetState_(false, true);\n      animationCallback(callback, true);\n    }\n  }\n\n  /**\n   * Center on coordinate and view position.\n   * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n   * @param {import(\"./size.js\").Size} size Box pixel size.\n   * @param {import(\"./pixel.js\").Pixel} position Position on the view to center on.\n   * @api\n   */\n  centerOn(coordinate, size, position) {\n    this.centerOnInternal(\n      fromUserCoordinate(coordinate, this.getProjection()),\n      size,\n      position\n    );\n  }\n\n  /**\n   * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n   * @param {import(\"./size.js\").Size} size Box pixel size.\n   * @param {import(\"./pixel.js\").Pixel} position Position on the view to center on.\n   */\n  centerOnInternal(coordinate, size, position) {\n    this.setCenterInternal(\n      calculateCenterOn(\n        coordinate,\n        size,\n        position,\n        this.getResolution(),\n        this.getRotation()\n      )\n    );\n  }\n\n  /**\n   * Calculates the shift between map and viewport center.\n   * @param {import(\"./coordinate.js\").Coordinate} center Center.\n   * @param {number} resolution Resolution.\n   * @param {number} rotation Rotation.\n   * @param {import(\"./size.js\").Size} size Size.\n   * @return {Array<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=0] Indicate which resolution should be used\n   * by a renderer if the view resolution does not match any resolution of the tile source.\n   * If 0, the nearest resolution will be used. If 1, the nearest lower resolution\n   * will be used. If -1, the nearest higher resolution will be used.\n   * @return {number|undefined} Valid zoom level.\n   */\n  getConstrainedZoom(targetZoom, direction) {\n    const targetRes = this.getResolutionForZoom(targetZoom);\n    return this.getZoomForResolution(\n      this.getConstrainedResolution(targetRes, direction)\n    );\n  }\n\n  /**\n   * Get a valid resolution according to the current view constraints.\n   * @param {number|undefined} targetResolution Target resolution.\n   * @param {number} [direction=0] Indicate which resolution should be used\n   * by a renderer if the view resolution does not match any resolution of the tile source.\n   * If 0, the nearest resolution will be used. If 1, the nearest lower resolution\n   * will be used. If -1, the nearest higher resolution will be used.\n   * @return {number|undefined} Valid resolution.\n   */\n  getConstrainedResolution(targetResolution, direction) {\n    direction = direction || 0;\n    const size = this.getViewportSize_(this.getRotation());\n\n    return this.constraints_.resolution(targetResolution, direction, size);\n  }\n}\n\n/**\n * @param {Function} callback Callback.\n * @param {*} returnValue Return value.\n */\nfunction animationCallback(callback, returnValue) {\n  setTimeout(function () {\n    callback(returnValue);\n  }, 0);\n}\n\n/**\n * @param {ViewOptions} options View options.\n * @return {import(\"./centerconstraint.js\").Type} The constraint.\n */\nexport function createCenterConstraint(options) {\n  if (options.extent !== undefined) {\n    const smooth =\n      options.smoothExtentConstraint !== undefined\n        ? options.smoothExtentConstraint\n        : true;\n    return createExtent(options.extent, options.constrainOnlyCenter, smooth);\n  }\n\n  const projection = createProjection(options.projection, 'EPSG:3857');\n  if (options.multiWorld !== true && projection.isGlobal()) {\n    const extent = projection.getExtent().slice();\n    extent[0] = -Infinity;\n    extent[2] = Infinity;\n    return createExtent(extent, false, false);\n  }\n\n  return centerNone;\n}\n\n/**\n * @param {ViewOptions} options View options.\n * @return {{constraint: import(\"./resolutionconstraint.js\").Type, maxResolution: number,\n *     minResolution: number, minZoom: number, zoomFactor: number}} The constraint.\n */\nexport function createResolutionConstraint(options) {\n  let resolutionConstraint;\n  let maxResolution;\n  let minResolution;\n\n  // TODO: move these to be ol constants\n  // see https://github.com/openlayers/openlayers/issues/2076\n  const defaultMaxZoom = 28;\n  const defaultZoomFactor = 2;\n\n  let minZoom =\n    options.minZoom !== undefined ? options.minZoom : DEFAULT_MIN_ZOOM;\n\n  let maxZoom =\n    options.maxZoom !== undefined ? options.maxZoom : defaultMaxZoom;\n\n  const zoomFactor =\n    options.zoomFactor !== undefined ? options.zoomFactor : defaultZoomFactor;\n\n  const multiWorld =\n    options.multiWorld !== undefined ? options.multiWorld : false;\n\n  const smooth =\n    options.smoothResolutionConstraint !== undefined\n      ? options.smoothResolutionConstraint\n      : true;\n\n  const showFullExtent =\n    options.showFullExtent !== undefined ? options.showFullExtent : false;\n\n  const projection = createProjection(options.projection, 'EPSG:3857');\n  const projExtent = projection.getExtent();\n  let constrainOnlyCenter = options.constrainOnlyCenter;\n  let extent = options.extent;\n  if (!multiWorld && !extent && projection.isGlobal()) {\n    constrainOnlyCenter = false;\n    extent = projExtent;\n  }\n\n  if (options.resolutions !== undefined) {\n    const resolutions = options.resolutions;\n    maxResolution = resolutions[minZoom];\n    minResolution =\n      resolutions[maxZoom] !== undefined\n        ? resolutions[maxZoom]\n        : resolutions[resolutions.length - 1];\n\n    if (options.constrainResolution) {\n      resolutionConstraint = createSnapToResolutions(\n        resolutions,\n        smooth,\n        !constrainOnlyCenter && extent,\n        showFullExtent\n      );\n    } else {\n      resolutionConstraint = createMinMaxResolution(\n        maxResolution,\n        minResolution,\n        smooth,\n        !constrainOnlyCenter && extent,\n        showFullExtent\n      );\n    }\n  } else {\n    // calculate the default min and max resolution\n    const size = !projExtent\n      ? // use an extent that can fit the whole world if need be\n        (360 * METERS_PER_UNIT.degrees) / projection.getMetersPerUnit()\n      : Math.max(getWidth(projExtent), getHeight(projExtent));\n\n    const defaultMaxResolution =\n      size / DEFAULT_TILE_SIZE / Math.pow(defaultZoomFactor, DEFAULT_MIN_ZOOM);\n\n    const defaultMinResolution =\n      defaultMaxResolution /\n      Math.pow(defaultZoomFactor, defaultMaxZoom - DEFAULT_MIN_ZOOM);\n\n    // user provided maxResolution takes precedence\n    maxResolution = options.maxResolution;\n    if (maxResolution !== undefined) {\n      minZoom = 0;\n    } else {\n      maxResolution = defaultMaxResolution / Math.pow(zoomFactor, minZoom);\n    }\n\n    // user provided minResolution takes precedence\n    minResolution = options.minResolution;\n    if (minResolution === undefined) {\n      if (options.maxZoom !== undefined) {\n        if (options.maxResolution !== undefined) {\n          minResolution = maxResolution / Math.pow(zoomFactor, maxZoom);\n        } else {\n          minResolution = defaultMaxResolution / Math.pow(zoomFactor, maxZoom);\n        }\n      } else {\n        minResolution = defaultMinResolution;\n      }\n    }\n\n    // given discrete zoom levels, minResolution may be different than provided\n    maxZoom =\n      minZoom +\n      Math.floor(\n        Math.log(maxResolution / minResolution) / Math.log(zoomFactor)\n      );\n    minResolution = maxResolution / Math.pow(zoomFactor, maxZoom - minZoom);\n\n    if (options.constrainResolution) {\n      resolutionConstraint = createSnapToPower(\n        zoomFactor,\n        maxResolution,\n        minResolution,\n        smooth,\n        !constrainOnlyCenter && extent,\n        showFullExtent\n      );\n    } else {\n      resolutionConstraint = createMinMaxResolution(\n        maxResolution,\n        minResolution,\n        smooth,\n        !constrainOnlyCenter && extent,\n        showFullExtent\n      );\n    }\n  }\n  return {\n    constraint: resolutionConstraint,\n    maxResolution: maxResolution,\n    minResolution: minResolution,\n    minZoom: minZoom,\n    zoomFactor: zoomFactor,\n  };\n}\n\n/**\n * @param {ViewOptions} options View options.\n * @return {import(\"./rotationconstraint.js\").Type} Rotation constraint.\n */\nexport function createRotationConstraint(options) {\n  const enableRotation =\n    options.enableRotation !== undefined ? options.enableRotation : true;\n  if (enableRotation) {\n    const constrainRotation = options.constrainRotation;\n    if (constrainRotation === undefined || constrainRotation === true) {\n      return createSnapToZero();\n    }\n    if (constrainRotation === false) {\n      return rotationNone;\n    }\n    if (typeof constrainRotation === 'number') {\n      return createSnapToN(constrainRotation);\n    }\n    return rotationNone;\n  }\n  return disable;\n}\n\n/**\n * Determine if an animation involves no view change.\n * @param {Animation} animation The animation.\n * @return {boolean} The animation involves no view change.\n */\nexport function isNoopAnimation(animation) {\n  if (animation.sourceCenter && animation.targetCenter) {\n    if (!coordinatesEqual(animation.sourceCenter, animation.targetCenter)) {\n      return false;\n    }\n  }\n  if (animation.sourceResolution !== animation.targetResolution) {\n    return false;\n  }\n  if (animation.sourceRotation !== animation.targetRotation) {\n    return false;\n  }\n  return true;\n}\n\n/**\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {import(\"./size.js\").Size} size Box pixel size.\n * @param {import(\"./pixel.js\").Pixel} position Position on the view to center on.\n * @param {number} resolution Resolution.\n * @param {number} rotation Rotation.\n * @return {import(\"./coordinate.js\").Coordinate} Shifted center.\n */\nfunction calculateCenterOn(coordinate, size, position, resolution, rotation) {\n  // calculate rotated position\n  const cosAngle = Math.cos(-rotation);\n  let sinAngle = Math.sin(-rotation);\n  let rotX = coordinate[0] * cosAngle - coordinate[1] * sinAngle;\n  let rotY = coordinate[1] * cosAngle + coordinate[0] * sinAngle;\n  rotX += (size[0] / 2 - position[0]) * resolution;\n  rotY += (position[1] - size[1] / 2) * resolution;\n\n  // go back to original angle\n  sinAngle = -sinAngle; // go back to original rotation\n  const centerX = rotX * cosAngle - rotY * sinAngle;\n  const centerY = rotY * cosAngle + rotX * sinAngle;\n\n  return [centerX, centerY];\n}\n\nexport default View;\n","/**\n * @module ol/layer/Layer\n */\nimport BaseLayer from './Base.js';\nimport EventType from '../events/EventType.js';\nimport LayerProperty from './Property.js';\nimport RenderEventType from '../render/EventType.js';\nimport View from '../View.js';\nimport {assert} from '../asserts.js';\nimport {intersects} from '../extent.js';\nimport {listen, unlistenByKey} from '../events.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\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"./Base\").BaseLayerObjectEventTypes|\n *     LayerEventType, import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../render/EventType\").LayerRenderEventTypes, import(\"../render/Event\").default, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"./Base\").BaseLayerObjectEventTypes|LayerEventType|\n *     import(\"../render/EventType\").LayerRenderEventTypes, Return>} LayerOnSignature\n */\n\n/**\n * @template {import(\"../source/Source.js\").default} [SourceType=import(\"../source/Source.js\").default]\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 {Object<string, *>} [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 | undefined} 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 * @api\n */\nclass Layer extends BaseLayer {\n  /**\n   * @param {Options<SourceType>} 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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {LayerOnSignature<import(\"../events\").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   */\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   */\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   */\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\").Pixel} pixel Pixel.\n   * @return {Promise<Array<import(\"../Feature\").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\").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    } 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    let getAttributions;\n    const source = this.getSource();\n    if (source) {\n      getAttributions = source.getAttributions();\n    }\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  /**\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        function (evt) {\n          const renderEvent =\n            /** @type {import(\"../render/Event.js\").default} */ (evt);\n          const layerStatesArray = renderEvent.frameState.layerStatesArray;\n          const layerState = this.getLayerState(false);\n          assert(\n            !layerStatesArray.some(function (arrayLayerState) {\n              return 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        this\n      );\n      this.mapRenderKey_ = listen(this, EventType.CHANGE, map.render, map);\n      this.changed();\n    }\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   * Clean up.\n   */\n  disposeInternal() {\n    if (this.renderer_) {\n      this.renderer_.dispose();\n      delete this.renderer_;\n    }\n\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 * @module ol/renderer/Map\n */\nimport Disposable from '../Disposable.js';\nimport {TRUE} from '../functions.js';\nimport {abstract} from '../util.js';\nimport {compose as composeTransform, makeInverse} from '../transform.js';\nimport {getWidth} from '../extent.js';\nimport {shared as iconImageCache} from '../style/IconImageCache.js';\nimport {inView} from '../layer/Layer.js';\nimport {wrapX} from '../coordinate.js';\n\n/**\n * @template T\n * @typedef HitMatch\n * @property {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @property {import(\"../layer/Layer.js\").default} layer Layer.\n * @property {import(\"../geom/SimpleGeometry.js\").default} geometry Geometry.\n * @property {number} distanceSq Squared distance.\n * @property {import(\"./vector.js\").FeatureCallback<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   */\n  flushDeclutterItems(frameState) {}\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/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|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|WebGLRenderingContext|undefined}\n     * @api\n     */\n    this.context = context;\n  }\n}\n\nexport default RenderEvent;\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-z]+?)\\\\s*$',\n  ].join(''),\n  'i'\n);\n/** @type {Array<'style'|'variant'|'weight'|'size'|'lineHeight'|'family'>} */\nconst fontRegExMatchIndex = [\n  'style',\n  'variant',\n  'weight',\n  'size',\n  'lineHeight',\n  'family',\n];\n\n/**\n * Get the list of font families from a font spec.  Note that this doesn't work\n * for font families that have commas in them.\n * @param {string} fontSpec The CSS font property.\n * @return {FontParameters|null} The font parameters (or null if the input spec is invalid).\n */\nexport const getFontParameters = function (fontSpec) {\n  const match = fontSpec.match(fontRegEx);\n  if (!match) {\n    return null;\n  }\n  const style = /** @type {FontParameters} */ ({\n    lineHeight: 'normal',\n    size: '1.2em',\n    style: 'normal',\n    weight: 'normal',\n    variant: 'normal',\n  });\n  for (let i = 0, ii = fontRegExMatchIndex.length; i < ii; ++i) {\n    const value = match[i + 1];\n    if (value !== undefined) {\n      style[fontRegExMatchIndex[i]] = value;\n    }\n  }\n  style.families = style.family.split(/,\\s?/);\n  return style;\n};\n","/**\n * @module ol/render/canvas\n */\nimport BaseObject from '../Object.js';\nimport {WORKER_OFFSCREEN_CANVAS} from '../has.js';\nimport {clear} from '../obj.js';\nimport {createCanvasContext2D} from '../dom.js';\nimport {getFontParameters} from '../css.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} [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 */\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 {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 {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}\n */\nlet measureContext = null;\n\n/**\n * @type {string}\n */\nlet measureFont;\n\n/**\n * @type {!Object<string, number>}\n */\nexport const textHeights = {};\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  const size = '32px ';\n  const referenceFonts = ['monospace', 'serif'];\n  const len = referenceFonts.length;\n  const text = 'wmytzilWMYTZIL@#/&?$%10\\uF013';\n  let interval, referenceWidth;\n\n  /**\n   * @param {string} fontStyle Css font-style\n   * @param {string} fontWeight Css font-weight\n   * @param {*} fontFamily Css font-family\n   * @return {boolean} Font with style and weight is available\n   */\n  function isAvailable(fontStyle, fontWeight, fontFamily) {\n    let available = true;\n    for (let i = 0; i < len; ++i) {\n      const referenceFont = referenceFonts[i];\n      referenceWidth = measureTextWidth(\n        fontStyle + ' ' + fontWeight + ' ' + size + referenceFont,\n        text\n      );\n      if (fontFamily != referenceFont) {\n        const width = measureTextWidth(\n          fontStyle +\n            ' ' +\n            fontWeight +\n            ' ' +\n            size +\n            fontFamily +\n            ',' +\n            referenceFont,\n          text\n        );\n        // If width and referenceWidth are the same, then the fallback was used\n        // instead of the font we wanted, so the font is not available.\n        available = available && width != referenceWidth;\n      }\n    }\n    if (available) {\n      return true;\n    }\n    return false;\n  }\n\n  function check() {\n    let done = true;\n    const fonts = checkedFonts.getKeys();\n    for (let i = 0, ii = fonts.length; i < ii; ++i) {\n      const font = fonts[i];\n      if (checkedFonts.get(font) < retries) {\n        if (isAvailable.apply(this, font.split('\\n'))) {\n          clear(textHeights);\n          // Make sure that loaded fonts are picked up by Safari\n          measureContext = null;\n          measureFont = undefined;\n          checkedFonts.set(font, retries);\n        } else {\n          checkedFonts.set(font, checkedFonts.get(font) + 1, true);\n          done = false;\n        }\n      }\n    }\n    if (done) {\n      clearInterval(interval);\n      interval = undefined;\n    }\n  }\n\n  return function (fontSpec) {\n    const font = getFontParameters(fontSpec);\n    if (!font) {\n      return;\n    }\n    const families = font.families;\n    for (let i = 0, ii = families.length; i < ii; ++i) {\n      const family = families[i];\n      const key = font.style + '\\n' + font.weight + '\\n' + family;\n      if (checkedFonts.get(key) === undefined) {\n        checkedFonts.set(key, retries, true);\n        if (!isAvailable(font.style, font.weight, family)) {\n          checkedFonts.set(key, 0, true);\n          if (interval === undefined) {\n            interval = setInterval(check, 32);\n          }\n        }\n      }\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      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} 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    context.globalAlpha *= opacity;\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} 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/renderer/Composite\n */\nimport MapRenderer from './Map.js';\nimport ObjectEventType from '../ObjectEventType.js';\nimport RenderEvent from '../render/Event.js';\nimport RenderEventType from '../render/EventType.js';\nimport {CLASS_UNSELECTABLE} from '../css.js';\nimport {checkedFonts} from '../render/canvas.js';\nimport {inView} from '../layer/Layer.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport {replaceChildren} from '../dom.js';\n\n/**\n * @classdesc\n * Canvas map renderer.\n * @api\n */\nclass CompositeMapRenderer extends MapRenderer {\n  /**\n   * @param {import(\"../Map.js\").default} map Map.\n   */\n  constructor(map) {\n    super(map);\n\n    /**\n     * @type {import(\"../events.js\").EventsKey}\n     */\n    this.fontChangeListenerKey_ = listen(\n      checkedFonts,\n      ObjectEventType.PROPERTYCHANGE,\n      map.redrawText.bind(map)\n    );\n\n    /**\n     * @private\n     * @type {HTMLDivElement}\n     */\n    this.element_ = document.createElement('div');\n    const style = this.element_.style;\n    style.position = 'absolute';\n    style.width = '100%';\n    style.height = '100%';\n    style.zIndex = '0';\n\n    this.element_.className = CLASS_UNSELECTABLE + ' ol-layers';\n\n    const container = map.getViewport();\n    container.insertBefore(this.element_, container.firstChild || null);\n\n    /**\n     * @private\n     * @type {Array<HTMLElement>}\n     */\n    this.children_ = [];\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.renderedVisible_ = true;\n\n    /**\n     * @type {Array<import(\"../layer/BaseVector.js\").default>}\n     */\n    this.declutterLayers_ = [];\n  }\n\n  /**\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    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  disposeInternal() {\n    unlistenByKey(this.fontChangeListenerKey_);\n    this.element_.parentNode.removeChild(this.element_);\n    super.disposeInternal();\n  }\n\n  /**\n   * Render.\n   * @param {?import(\"../Map.js\").FrameState} frameState Frame state.\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(function (a, b) {\n      return a.zIndex - b.zIndex;\n    });\n    const viewState = frameState.viewState;\n\n    this.children_.length = 0;\n\n    const declutterLayers = this.declutterLayers_;\n    declutterLayers.length = 0;\n\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      if ('getDeclutter' in layer) {\n        declutterLayers.push(\n          /** @type {import(\"../layer/BaseVector.js\").default} */ (layer)\n        );\n      }\n    }\n    this.flushDeclutterItems(frameState);\n\n    replaceChildren(this.element_, this.children_);\n\n    this.dispatchRenderEvent(RenderEventType.POSTCOMPOSE, frameState);\n\n    if (!this.renderedVisible_) {\n      this.element_.style.display = '';\n      this.renderedVisible_ = true;\n    }\n\n    this.scheduleExpireIconCache(frameState);\n  }\n\n  /**\n   * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n   */\n  flushDeclutterItems(frameState) {\n    const layers = this.declutterLayers_;\n    for (let i = layers.length - 1; i >= 0; --i) {\n      layers[i].renderDeclutter(frameState);\n    }\n    layers.length = 0;\n  }\n}\n\nexport default CompositeMapRenderer;\n","/**\n * @module ol/layer/Group\n */\nimport BaseLayer from './Base.js';\nimport Collection from '../Collection.js';\nimport CollectionEventType from '../CollectionEventType.js';\nimport Event from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport ObjectEventType from '../ObjectEventType.js';\nimport {assert} from '../asserts.js';\nimport {clear} from '../obj.js';\nimport {getIntersection} from '../extent.js';\nimport {getUid} from '../util.js';\nimport {listen, unlistenByKey} from '../events.js';\n\n/**\n * @typedef {'addlayer'|'removelayer'} EventType\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 {EventType} 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\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"./Base\").BaseLayerObjectEventTypes|\n *     'change:layers', import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"./Base\").BaseLayerObjectEventTypes|'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 * @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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {GroupOnSignature<import(\"../events\").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(layers, CollectionEventType.REMOVE, this.handleLayersRemove_, this)\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('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, 'addlayer', this.handleLayerGroupAdd_, this),\n        listen(layer, 'removelayer', this.handleLayerGroupRemove_, this)\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('addlayer', event.layer));\n  }\n\n  /**\n   * @param {GroupEvent} event The layer group event.\n   */\n  handleLayerGroupRemove_(event) {\n    this.dispatchEvent(new GroupEvent('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('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('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(new GroupEvent('removelayer', currentLayers[i]));\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   */\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   */\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   */\n  getSourceState() {\n    return 'ready';\n  }\n}\n\nexport default LayerGroup;\n","/**\n * @module ol/MapEvent\n */\nimport Event from './events/Event.js';\n\n/**\n * @classdesc\n * Events emitted as map events are instances of this type.\n * See {@link module:ol/Map~Map} for which events trigger a map event.\n */\nclass MapEvent extends Event {\n  /**\n   * @param {string} type Event type.\n   * @param {import(\"./Map.js\").default} map Map.\n   * @param {?import(\"./Map.js\").FrameState} [frameState] Frame state.\n   */\n  constructor(type, map, frameState) {\n    super(type);\n\n    /**\n     * The map where the event occurred.\n     * @type {import(\"./Map.js\").default}\n     * @api\n     */\n    this.map = map;\n\n    /**\n     * The frame state at the time of the event.\n     * @type {?import(\"./Map.js\").FrameState}\n     * @api\n     */\n    this.frameState = frameState !== undefined ? frameState : null;\n  }\n}\n\nexport default MapEvent;\n","/**\n * @module ol/MapBrowserEvent\n */\nimport MapEvent from './MapEvent.js';\n\n/**\n * @classdesc\n * Events emitted as map browser events are instances of this type.\n * See {@link module:ol/Map~Map} for which events trigger a map browser event.\n * @template {UIEvent} EVENT\n */\nclass MapBrowserEvent extends MapEvent {\n  /**\n   * @param {string} type Event type.\n   * @param {import(\"./Map.js\").default} map Map.\n   * @param {EVENT} originalEvent Original event.\n   * @param {boolean} [dragging] Is the map currently being dragged?\n   * @param {import(\"./Map.js\").FrameState} [frameState] Frame state.\n   * @param {Array<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     */\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     */\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   */\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   */\n  stopPropagation() {\n    super.stopPropagation();\n    if ('stopPropagation' in this.originalEvent) {\n      /** @type {UIEvent} */ (this.originalEvent).stopPropagation();\n    }\n  }\n}\n\nexport default MapBrowserEvent;\n","/**\n * @module ol/MapBrowserEventType\n */\nimport EventType from './events/EventType.js';\n\n/**\n * Constants for event names.\n * @enum {string}\n */\nexport default {\n  /**\n   * A true single click with no dragging and no double click. Note that this\n   * event is delayed by 250 ms to ensure that it is not a double click.\n   * @event module:ol/MapBrowserEvent~MapBrowserEvent#singleclick\n   * @api\n   */\n  SINGLECLICK: 'singleclick',\n\n  /**\n   * A click with no dragging. A double click will fire two of this.\n   * @event module:ol/MapBrowserEvent~MapBrowserEvent#click\n   * @api\n   */\n  CLICK: EventType.CLICK,\n\n  /**\n   * A true double click, with no dragging.\n   * @event module:ol/MapBrowserEvent~MapBrowserEvent#dblclick\n   * @api\n   */\n  DBLCLICK: EventType.DBLCLICK,\n\n  /**\n   * Triggered when a pointer is dragged.\n   * @event module:ol/MapBrowserEvent~MapBrowserEvent#pointerdrag\n   * @api\n   */\n  POINTERDRAG: 'pointerdrag',\n\n  /**\n   * Triggered when a pointer is moved. Note that on touch devices this is\n   * triggered when the map is panned, so is not the same as mousemove.\n   * @event module:ol/MapBrowserEvent~MapBrowserEvent#pointermove\n   * @api\n   */\n  POINTERMOVE: 'pointermove',\n\n  POINTERDOWN: 'pointerdown',\n  POINTERUP: 'pointerup',\n  POINTEROVER: 'pointerover',\n  POINTEROUT: 'pointerout',\n  POINTERENTER: 'pointerenter',\n  POINTERLEAVE: 'pointerleave',\n  POINTERCANCEL: 'pointercancel',\n};\n\n/***\n * @typedef {'singleclick'|'click'|'dblclick'|'pointerdrag'|'pointermove'} Types\n */\n","/**\n * @module ol/pointer/EventType\n */\n\n/**\n * Constants for event names.\n * @enum {string}\n */\nexport default {\n  POINTERMOVE: 'pointermove',\n  POINTERDOWN: 'pointerdown',\n  POINTERUP: 'pointerup',\n  POINTEROVER: 'pointerover',\n  POINTEROUT: 'pointerout',\n  POINTERENTER: 'pointerenter',\n  POINTERLEAVE: 'pointerleave',\n  POINTERCANCEL: 'pointercancel',\n};\n","/**\n * @module ol/MapBrowserEventHandler\n */\n\nimport EventType from './events/EventType.js';\nimport MapBrowserEvent from './MapBrowserEvent.js';\nimport MapBrowserEventType from './MapBrowserEventType.js';\nimport PointerEventType from './pointer/EventType.js';\nimport Target from './events/Target.js';\nimport {PASSIVE_EVENT_LISTENERS} from './has.js';\nimport {listen, unlistenByKey} from './events.js';\n\nclass MapBrowserEventHandler extends Target {\n  /**\n   * @param {import(\"./Map.js\").default} map The map with the viewport to listen to events on.\n   * @param {number} [moveTolerance] The minimal distance the pointer must travel to trigger a move.\n   */\n  constructor(map, moveTolerance) {\n    super(map);\n\n    /**\n     * This is the element that we will listen to the real events on.\n     * @type {import(\"./Map.js\").default}\n     * @private\n     */\n    this.map_ = map;\n\n    /**\n     * @type {ReturnType<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    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   */\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 EventType from './events/EventType.js';\nimport PriorityQueue, {DROP} from './structs/PriorityQueue.js';\nimport TileState from './TileState.js';\n\n/**\n * @typedef {function(import(\"./Tile.js\").default, string, import(\"./coordinate.js\").Coordinate, number): number} PriorityFunction\n */\n\nclass TileQueue extends PriorityQueue {\n  /**\n   * @param {PriorityFunction} tilePriorityFunction Tile priority function.\n   * @param {function(): ?} tileChangeCallback Function called on each tile change event.\n   */\n  constructor(tilePriorityFunction, tileChangeCallback) {\n    super(\n      /**\n       * @param {Array} element Element.\n       * @return {number} Priority.\n       */\n      function (element) {\n        return tilePriorityFunction.apply(null, element);\n      },\n      /**\n       * @param {Array} element Element.\n       * @return {string} Key.\n       */\n      function (element) {\n        return /** @type {import(\"./Tile.js\").default} */ (element[0]).getKey();\n      }\n    );\n\n    /** @private */\n    this.boundHandleTileChange_ = this.handleTileChange.bind(this);\n\n    /**\n     * @private\n     * @type {function(): ?}\n     */\n    this.tileChangeCallback_ = tileChangeCallback;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.tilesLoading_ = 0;\n\n    /**\n     * @private\n     * @type {!Object<string,boolean>}\n     */\n    this.tilesLoadingKeys_ = {};\n  }\n\n  /**\n   * @param {Array} element Element.\n   * @return {boolean} The element was added to the queue.\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    let state, tile, tileKey;\n    while (\n      this.tilesLoading_ < maxTotalLoading &&\n      newLoads < maxNewLoads &&\n      this.getCount() > 0\n    ) {\n      tile = /** @type {import(\"./Tile.js\").default} */ (this.dequeue()[0]);\n      tileKey = tile.getKey();\n      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/control/Control\n */\nimport BaseObject from '../Object.js';\nimport MapEventType from '../MapEventType.js';\nimport {VOID} from '../functions.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport {removeNode} from '../dom.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   */\n  disposeInternal() {\n    removeNode(this.element);\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      removeNode(this.element);\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_\n        ? this.target_\n        : map.getOverlayContainerStopEvent();\n      target.appendChild(this.element);\n      if (this.render !== VOID) {\n        this.listenerKeys.push(\n          listen(map, MapEventType.POSTRENDER, this.render, this)\n        );\n      }\n      map.render();\n    }\n  }\n\n  /**\n   * Renders the control.\n   * @param {import(\"../MapEvent.js\").default} mapEvent Map event.\n   * @api\n   */\n  render(mapEvent) {}\n\n  /**\n   * This function is used to set a target element for the control. It has no\n   * effect if it is called after the control has been added to the map (i.e.\n   * after `setMap` is called on the control). If no `target` is set in the\n   * options passed to the control constructor and if `setTarget` is not called\n   * then the control is added to the map's overlay container.\n   * @param {HTMLElement|string} target Target.\n   * @api\n   */\n  setTarget(target) {\n    this.target_ =\n      typeof target === 'string' ? document.getElementById(target) : target;\n  }\n}\n\nexport default Control;\n","/**\n * @module ol/control/Attribution\n */\nimport Control from './Control.js';\nimport EventType from '../events/EventType.js';\nimport {CLASS_COLLAPSED, CLASS_CONTROL, CLASS_UNSELECTABLE} from '../css.js';\nimport {equals} from '../array.js';\nimport {removeChildren, replaceNode} from '../dom.js';\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-attribution'] CSS class name.\n * @property {HTMLElement|string} [target] Specify a target if you\n * want the control to be rendered outside of the map's\n * viewport.\n * @property {boolean} [collapsible] Specify if attributions can\n * be collapsed. If not specified, sources control this behavior with their\n * `attributionsCollapsible` setting.\n * @property {boolean} [collapsed=true] Specify if attributions should\n * be collapsed at startup.\n * @property {string} [tipLabel='Attributions'] Text label to use for the button tip.\n * @property {string|HTMLElement} [label='i'] Text label to use for the\n * collapsed attributions button.\n * Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string} [expandClassName=className + '-expand'] CSS class name for the\n * collapsed attributions button.\n * @property {string|HTMLElement} [collapseLabel='›'] Text label to use\n * for the expanded attributions button.\n * Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string} [collapseClassName=className + '-collapse'] CSS class name for the\n * expanded attributions button.\n * @property {function(import(\"../MapEvent.js\").default):void} [render] Function called when\n * the control should be re-rendered. This is called in a `requestAnimationFrame`\n * callback.\n */\n\n/**\n * @classdesc\n * Control to show all the attributions associated with the layer sources\n * in the map. This control is one of the default controls included in maps.\n * By default it will show in the bottom right portion of the map, but this can\n * be changed by using a css selector for `.ol-attribution`.\n *\n * @api\n */\nclass Attribution extends Control {\n  /**\n   * @param {Options} [options] Attribution options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super({\n      element: document.createElement('div'),\n      render: options.render,\n      target: options.target,\n    });\n\n    /**\n     * @private\n     * @type {HTMLElement}\n     */\n    this.ulElement_ = document.createElement('ul');\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.collapsed_ =\n      options.collapsed !== undefined ? options.collapsed : true;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.userCollapsed_ = this.collapsed_;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.overrideCollapsible_ = options.collapsible !== undefined;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.collapsible_ =\n      options.collapsible !== undefined ? options.collapsible : true;\n\n    if (!this.collapsible_) {\n      this.collapsed_ = false;\n    }\n\n    const className =\n      options.className !== undefined ? options.className : 'ol-attribution';\n\n    const tipLabel =\n      options.tipLabel !== undefined ? options.tipLabel : 'Attributions';\n\n    const expandClassName =\n      options.expandClassName !== undefined\n        ? options.expandClassName\n        : className + '-expand';\n\n    const collapseLabel =\n      options.collapseLabel !== undefined ? options.collapseLabel : '\\u203A';\n\n    const collapseClassName =\n      options.collapseClassName !== undefined\n        ? options.collapseClassName\n        : className + '-collapse';\n\n    if (typeof collapseLabel === 'string') {\n      /**\n       * @private\n       * @type {HTMLElement}\n       */\n      this.collapseLabel_ = document.createElement('span');\n      this.collapseLabel_.textContent = collapseLabel;\n      this.collapseLabel_.className = collapseClassName;\n    } else {\n      this.collapseLabel_ = collapseLabel;\n    }\n\n    const label = options.label !== undefined ? options.label : 'i';\n\n    if (typeof label === 'string') {\n      /**\n       * @private\n       * @type {HTMLElement}\n       */\n      this.label_ = document.createElement('span');\n      this.label_.textContent = label;\n      this.label_.className = expandClassName;\n    } else {\n      this.label_ = label;\n    }\n\n    const activeLabel =\n      this.collapsible_ && !this.collapsed_ ? this.collapseLabel_ : this.label_;\n\n    /**\n     * @private\n     * @type {HTMLElement}\n     */\n    this.toggleButton_ = document.createElement('button');\n    this.toggleButton_.setAttribute('type', 'button');\n    this.toggleButton_.setAttribute('aria-expanded', String(!this.collapsed_));\n    this.toggleButton_.title = tipLabel;\n    this.toggleButton_.appendChild(activeLabel);\n\n    this.toggleButton_.addEventListener(\n      EventType.CLICK,\n      this.handleClick_.bind(this),\n      false\n    );\n\n    const cssClasses =\n      className +\n      ' ' +\n      CLASS_UNSELECTABLE +\n      ' ' +\n      CLASS_CONTROL +\n      (this.collapsed_ && this.collapsible_ ? ' ' + CLASS_COLLAPSED : '') +\n      (this.collapsible_ ? '' : ' ol-uncollapsible');\n    const element = this.element;\n    element.className = cssClasses;\n    element.appendChild(this.toggleButton_);\n    element.appendChild(this.ulElement_);\n\n    /**\n     * A list of currently rendered resolutions.\n     * @type {Array<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 visibleAttributions = Array.from(\n      new Set(\n        this.getMap()\n          .getAllLayers()\n          .flatMap((layer) => layer.getAttributions(frameState))\n      )\n    );\n\n    const collapsible = !this.getMap()\n      .getAllLayers()\n      .some(\n        (layer) =>\n          layer.getSource() &&\n          layer.getSource().getAttributionsCollapsible() === false\n      );\n    if (!this.overrideCollapsible_) {\n      this.setCollapsible(collapsible);\n    }\n    return visibleAttributions;\n  }\n\n  /**\n   * @private\n   * @param {?import(\"../Map.js\").FrameState} frameState Frame state.\n   */\n  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 = this.collectSourceAttributions_(frameState);\n\n    const visible = attributions.length > 0;\n    if (this.renderedVisible_ != visible) {\n      this.element.style.display = visible ? '' : 'none';\n      this.renderedVisible_ = visible;\n    }\n\n    if (equals(attributions, this.renderedAttributions_)) {\n      return;\n    }\n\n    removeChildren(this.ulElement_);\n\n    // append the attributions\n    for (let i = 0, ii = attributions.length; i < ii; ++i) {\n      const element = document.createElement('li');\n      element.innerHTML = attributions[i];\n      this.ulElement_.appendChild(element);\n    }\n\n    this.renderedAttributions_ = attributions;\n  }\n\n  /**\n   * @param {MouseEvent} event The event to handle\n   * @private\n   */\n  handleClick_(event) {\n    event.preventDefault();\n    this.handleToggle_();\n    this.userCollapsed_ = this.collapsed_;\n  }\n\n  /**\n   * @private\n   */\n  handleToggle_() {\n    this.element.classList.toggle(CLASS_COLLAPSED);\n    if (this.collapsed_) {\n      replaceNode(this.collapseLabel_, this.label_);\n    } else {\n      replaceNode(this.label_, this.collapseLabel_);\n    }\n    this.collapsed_ = !this.collapsed_;\n    this.toggleButton_.setAttribute('aria-expanded', String(!this.collapsed_));\n  }\n\n  /**\n   * Return `true` if the attribution is collapsible, `false` otherwise.\n   * @return {boolean} True if the widget is collapsible.\n   * @api\n   */\n  getCollapsible() {\n    return this.collapsible_;\n  }\n\n  /**\n   * Set whether the attribution should be collapsible.\n   * @param {boolean} collapsible True if the widget is collapsible.\n   * @api\n   */\n  setCollapsible(collapsible) {\n    if (this.collapsible_ === collapsible) {\n      return;\n    }\n    this.collapsible_ = collapsible;\n    this.element.classList.toggle('ol-uncollapsible');\n    if (this.userCollapsed_) {\n      this.handleToggle_();\n    }\n  }\n\n  /**\n   * Collapse or expand the attribution according to the passed parameter. Will\n   * not do anything if the attribution isn't collapsible or if the current\n   * collapsed state is already the one requested.\n   * @param {boolean} collapsed True if the widget is collapsed.\n   * @api\n   */\n  setCollapsed(collapsed) {\n    this.userCollapsed_ = collapsed;\n    if (!this.collapsible_ || this.collapsed_ === collapsed) {\n      return;\n    }\n    this.handleToggle_();\n  }\n\n  /**\n   * Return `true` when the attribution is currently collapsed or `false`\n   * otherwise.\n   * @return {boolean} True if the widget is collapsed.\n   * @api\n   */\n  getCollapsed() {\n    return this.collapsed_;\n  }\n\n  /**\n   * Update the attribution element.\n   * @param {import(\"../MapEvent.js\").default} mapEvent Map event.\n   * @override\n   */\n  render(mapEvent) {\n    this.updateElement_(mapEvent.frameState);\n  }\n}\n\nexport default Attribution;\n","/**\n * @module ol/control/Rotate\n */\nimport Control from './Control.js';\nimport EventType from '../events/EventType.js';\nimport {CLASS_CONTROL, CLASS_HIDDEN, CLASS_UNSELECTABLE} from '../css.js';\nimport {easeOut} from '../easing.js';\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-rotate'] CSS class name.\n * @property {string|HTMLElement} [label='⇧'] Text label to use for the rotate button.\n * Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string} [tipLabel='Reset rotation'] Text label to use for the rotate tip.\n * @property {string} [compassClassName='ol-compass'] CSS class name for the compass.\n * @property {number} [duration=250] Animation duration in milliseconds.\n * @property {boolean} [autoHide=true] Hide the control when rotation is 0.\n * @property {function(import(\"../MapEvent.js\").default):void} [render] Function called when the control should\n * be re-rendered. This is called in a `requestAnimationFrame` callback.\n * @property {function():void} [resetNorth] Function called when the control is clicked.\n * This will override the default `resetNorth`.\n * @property {HTMLElement|string} [target] Specify a target if you want the control to be\n * rendered outside of the map's viewport.\n */\n\n/**\n * @classdesc\n * A button control to reset rotation to 0.\n * To style this control use css selector `.ol-rotate`. A `.ol-hidden` css\n * selector is added to the button when the rotation is 0.\n *\n * @api\n */\nclass Rotate extends Control {\n  /**\n   * @param {Options} [options] Rotate options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super({\n      element: document.createElement('div'),\n      render: options.render,\n      target: options.target,\n    });\n\n    const className =\n      options.className !== undefined ? options.className : 'ol-rotate';\n\n    const label = options.label !== undefined ? options.label : '\\u21E7';\n\n    const compassClassName =\n      options.compassClassName !== undefined\n        ? options.compassClassName\n        : 'ol-compass';\n\n    /**\n     * @type {HTMLElement}\n     * @private\n     */\n    this.label_ = null;\n\n    if (typeof label === 'string') {\n      this.label_ = document.createElement('span');\n      this.label_.className = compassClassName;\n      this.label_.textContent = label;\n    } else {\n      this.label_ = label;\n      this.label_.classList.add(compassClassName);\n    }\n\n    const tipLabel = options.tipLabel ? options.tipLabel : 'Reset rotation';\n\n    const button = document.createElement('button');\n    button.className = className + '-reset';\n    button.setAttribute('type', 'button');\n    button.title = tipLabel;\n    button.appendChild(this.label_);\n\n    button.addEventListener(\n      EventType.CLICK,\n      this.handleClick_.bind(this),\n      false\n    );\n\n    const cssClasses =\n      className + ' ' + CLASS_UNSELECTABLE + ' ' + CLASS_CONTROL;\n    const element = this.element;\n    element.className = cssClasses;\n    element.appendChild(button);\n\n    this.callResetNorth_ = options.resetNorth ? options.resetNorth : undefined;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.duration_ = options.duration !== undefined ? options.duration : 250;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.autoHide_ = options.autoHide !== undefined ? options.autoHide : true;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.rotation_ = undefined;\n\n    if (this.autoHide_) {\n      this.element.classList.add(CLASS_HIDDEN);\n    }\n  }\n\n  /**\n   * @param {MouseEvent} event The event to handle\n   * @private\n   */\n  handleClick_(event) {\n    event.preventDefault();\n    if (this.callResetNorth_ !== undefined) {\n      this.callResetNorth_();\n    } else {\n      this.resetNorth_();\n    }\n  }\n\n  /**\n   * @private\n   */\n  resetNorth_() {\n    const map = this.getMap();\n    const view = map.getView();\n    if (!view) {\n      // the map does not have a view, so we can't act\n      // upon it\n      return;\n    }\n    const rotation = view.getRotation();\n    if (rotation !== undefined) {\n      if (this.duration_ > 0 && rotation % (2 * Math.PI) !== 0) {\n        view.animate({\n          rotation: 0,\n          duration: this.duration_,\n          easing: easeOut,\n        });\n      } else {\n        view.setRotation(0);\n      }\n    }\n  }\n\n  /**\n   * Update the rotate control element.\n   * @param {import(\"../MapEvent.js\").default} mapEvent Map event.\n   * @override\n   */\n  render(mapEvent) {\n    const frameState = mapEvent.frameState;\n    if (!frameState) {\n      return;\n    }\n    const rotation = frameState.viewState.rotation;\n    if (rotation != this.rotation_) {\n      const transform = 'rotate(' + rotation + 'rad)';\n      if (this.autoHide_) {\n        const contains = this.element.classList.contains(CLASS_HIDDEN);\n        if (!contains && rotation === 0) {\n          this.element.classList.add(CLASS_HIDDEN);\n        } else if (contains && rotation !== 0) {\n          this.element.classList.remove(CLASS_HIDDEN);\n        }\n      }\n      this.label_.style.transform = transform;\n    }\n    this.rotation_ = rotation;\n  }\n}\n\nexport default Rotate;\n","/**\n * @module ol/control/Zoom\n */\nimport Control from './Control.js';\nimport EventType from '../events/EventType.js';\nimport {CLASS_CONTROL, CLASS_UNSELECTABLE} from '../css.js';\nimport {easeOut} from '../easing.js';\n\n/**\n * @typedef {Object} Options\n * @property {number} [duration=250] Animation duration in milliseconds.\n * @property {string} [className='ol-zoom'] CSS class name.\n * @property {string} [zoomInClassName=className + '-in'] CSS class name for the zoom-in button.\n * @property {string} [zoomOutClassName=className + '-out'] CSS class name for the zoom-out button.\n * @property {string|HTMLElement} [zoomInLabel='+'] Text label to use for the zoom-in\n * button. Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string|HTMLElement} [zoomOutLabel='–'] Text label to use for the zoom-out button.\n * Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string} [zoomInTipLabel='Zoom in'] Text label to use for the button tip.\n * @property {string} [zoomOutTipLabel='Zoom out'] Text label to use for the button tip.\n * @property {number} [delta=1] The zoom delta applied on each click.\n * @property {HTMLElement|string} [target] Specify a target if you want the control to be\n * rendered outside of the map's viewport.\n */\n\n/**\n * @classdesc\n * A control with 2 buttons, one for zoom in and one for zoom out.\n * This control is one of the default controls of a map. To style this control\n * use css selectors `.ol-zoom-in` and `.ol-zoom-out`.\n *\n * @api\n */\nclass Zoom extends Control {\n  /**\n   * @param {Options} [options] Zoom options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super({\n      element: document.createElement('div'),\n      target: options.target,\n    });\n\n    const className =\n      options.className !== undefined ? options.className : 'ol-zoom';\n\n    const delta = options.delta !== undefined ? options.delta : 1;\n\n    const zoomInClassName =\n      options.zoomInClassName !== undefined\n        ? options.zoomInClassName\n        : className + '-in';\n\n    const zoomOutClassName =\n      options.zoomOutClassName !== undefined\n        ? options.zoomOutClassName\n        : className + '-out';\n\n    const zoomInLabel =\n      options.zoomInLabel !== undefined ? options.zoomInLabel : '+';\n    const zoomOutLabel =\n      options.zoomOutLabel !== undefined ? options.zoomOutLabel : '\\u2013';\n\n    const zoomInTipLabel =\n      options.zoomInTipLabel !== undefined ? options.zoomInTipLabel : 'Zoom in';\n    const zoomOutTipLabel =\n      options.zoomOutTipLabel !== undefined\n        ? options.zoomOutTipLabel\n        : 'Zoom out';\n\n    const inElement = document.createElement('button');\n    inElement.className = zoomInClassName;\n    inElement.setAttribute('type', 'button');\n    inElement.title = zoomInTipLabel;\n    inElement.appendChild(\n      typeof zoomInLabel === 'string'\n        ? document.createTextNode(zoomInLabel)\n        : zoomInLabel\n    );\n\n    inElement.addEventListener(\n      EventType.CLICK,\n      this.handleClick_.bind(this, delta),\n      false\n    );\n\n    const outElement = document.createElement('button');\n    outElement.className = zoomOutClassName;\n    outElement.setAttribute('type', 'button');\n    outElement.title = zoomOutTipLabel;\n    outElement.appendChild(\n      typeof zoomOutLabel === 'string'\n        ? document.createTextNode(zoomOutLabel)\n        : zoomOutLabel\n    );\n\n    outElement.addEventListener(\n      EventType.CLICK,\n      this.handleClick_.bind(this, -delta),\n      false\n    );\n\n    const cssClasses =\n      className + ' ' + CLASS_UNSELECTABLE + ' ' + CLASS_CONTROL;\n    const element = this.element;\n    element.className = cssClasses;\n    element.appendChild(inElement);\n    element.appendChild(outElement);\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.duration_ = options.duration !== undefined ? options.duration : 250;\n  }\n\n  /**\n   * @param {number} delta Zoom delta.\n   * @param {MouseEvent} event The event to handle\n   * @private\n   */\n  handleClick_(delta, event) {\n    event.preventDefault();\n    this.zoomByDelta_(delta);\n  }\n\n  /**\n   * @param {number} delta Zoom delta.\n   * @private\n   */\n  zoomByDelta_(delta) {\n    const map = this.getMap();\n    const view = map.getView();\n    if (!view) {\n      // the map does not have a view, so we can't act\n      // upon it\n      return;\n    }\n    const currentZoom = view.getZoom();\n    if (currentZoom !== undefined) {\n      const newZoom = view.getConstrainedZoom(currentZoom + delta);\n      if (this.duration_ > 0) {\n        if (view.getAnimating()) {\n          view.cancelAnimations();\n        }\n        view.animate({\n          zoom: newZoom,\n          duration: this.duration_,\n          easing: easeOut,\n        });\n      } else {\n        view.setZoom(newZoom);\n      }\n    }\n  }\n}\n\nexport default Zoom;\n","/**\n * @module ol/control/defaults\n */\nimport Attribution from './Attribution.js';\nimport Collection from '../Collection.js';\nimport Rotate from './Rotate.js';\nimport Zoom from './Zoom.js';\n\n/**\n * @typedef {Object} DefaultsOptions\n * @property {boolean} [attribution=true] Include\n * {@link module:ol/control/Attribution~Attribution}.\n * @property {import(\"./Attribution.js\").Options} [attributionOptions]\n * Options for {@link module:ol/control/Attribution~Attribution}.\n * @property {boolean} [rotate=true] Include\n * {@link module:ol/control/Rotate~Rotate}.\n * @property {import(\"./Rotate.js\").Options} [rotateOptions] Options\n * for {@link module:ol/control/Rotate~Rotate}.\n * @property {boolean} [zoom] Include {@link module:ol/control/Zoom~Zoom}.\n * @property {import(\"./Zoom.js\").Options} [zoomOptions] Options for\n * {@link module:ol/control/Zoom~Zoom}.\n */\n\n/**\n * Set of controls included in maps by default. Unless configured otherwise,\n * this returns a collection containing an instance of each of the following\n * controls:\n * * {@link module:ol/control/Zoom~Zoom}\n * * {@link module:ol/control/Rotate~Rotate}\n * * {@link module:ol/control/Attribution~Attribution}\n *\n * @param {DefaultsOptions} [options] Options for the default controls.\n * @return {Collection<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 InteractionProperty from './Property.js';\nimport {easeOut, linear} from '../easing.js';\n\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types|\n *     'change:active', import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {InteractionOnSignature<import(\"../events\").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 Interaction, {zoomByDelta} from './Interaction.js';\nimport MapBrowserEventType from '../MapBrowserEventType.js';\n\n/**\n * @typedef {Object} Options\n * @property {number} [duration=250] Animation duration in milliseconds.\n * @property {number} [delta=1] The zoom delta applied on each double click.\n */\n\n/**\n * @classdesc\n * Allows the user to zoom by double-clicking on the map.\n * @api\n */\nclass DoubleClickZoom extends Interaction {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    super();\n\n    options = options ? options : {};\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.delta_ = options.delta ? options.delta : 1;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.duration_ = options.duration !== undefined ? options.duration : 250;\n  }\n\n  /**\n   * Handles the {@link module:ol/MapBrowserEvent~MapBrowserEvent map browser event} (if it was a\n   * doubleclick) and eventually zooms the map.\n   * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n   * @return {boolean} `false` to stop event propagation.\n   */\n  handleEvent(mapBrowserEvent) {\n    let stopEvent = false;\n    if (mapBrowserEvent.type == MapBrowserEventType.DBLCLICK) {\n      const browserEvent = /** @type {MouseEvent} */ (\n        mapBrowserEvent.originalEvent\n      );\n      const map = mapBrowserEvent.map;\n      const anchor = mapBrowserEvent.coordinate;\n      const delta = browserEvent.shiftKey ? -this.delta_ : this.delta_;\n      const view = map.getView();\n      zoomByDelta(view, delta, anchor, this.duration_);\n      browserEvent.preventDefault();\n      stopEvent = true;\n    }\n    return !stopEvent;\n  }\n}\n\nexport default DoubleClickZoom;\n","/**\n * @module ol/interaction/Pointer\n */\nimport Interaction from './Interaction.js';\nimport MapBrowserEventType from '../MapBrowserEventType.js';\n\n/**\n * @typedef {Object} Options\n * @property {function(import(\"../MapBrowserEvent.js\").default):boolean} [handleDownEvent]\n * Function handling \"down\" events. If the function returns `true` then a drag\n * sequence is started.\n * @property {function(import(\"../MapBrowserEvent.js\").default):void} [handleDragEvent]\n * Function handling \"drag\" events. This function is called on \"move\" events\n * during a drag sequence.\n * @property {function(import(\"../MapBrowserEvent.js\").default):boolean} [handleEvent]\n * Method called by the map to notify the interaction that a browser event was\n * dispatched to the map. The function may return `false` to prevent the\n * propagation of the event to other interactions in the map's interactions\n * chain.\n * @property {function(import(\"../MapBrowserEvent.js\").default):void} [handleMoveEvent]\n * Function handling \"move\" events. This function is called on \"move\" events.\n * This functions is also called during a drag sequence, so during a drag\n * sequence both the `handleDragEvent` function and this function are called.\n * If `handleDownEvent` is defined and it returns true this function will not\n * be called during a drag sequence.\n * @property {function(import(\"../MapBrowserEvent.js\").default):boolean} [handleUpEvent]\n *  Function handling \"up\" events. If the function returns `false` then the\n * current drag sequence is stopped.\n * @property {function(boolean):boolean} [stopDown]\n * Should the down event be propagated to other interactions, or should be\n * stopped?\n */\n\n/**\n * @classdesc\n * Base class that calls user-defined functions on `down`, `move` and `up`\n * events. This class also manages \"drag sequences\".\n *\n * When the `handleDownEvent` user function returns `true` a drag sequence is\n * started. During a drag sequence the `handleDragEvent` user function is\n * called on `move` events. The drag sequence ends when the `handleUpEvent`\n * user function is called and returns `false`.\n * @api\n */\nclass PointerInteraction extends Interaction {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super(\n      /** @type {import(\"./Interaction.js\").InteractionOptions} */ (options)\n    );\n\n    if (options.handleDownEvent) {\n      this.handleDownEvent = options.handleDownEvent;\n    }\n\n    if (options.handleDragEvent) {\n      this.handleDragEvent = options.handleDragEvent;\n    }\n\n    if (options.handleMoveEvent) {\n      this.handleMoveEvent = options.handleMoveEvent;\n    }\n\n    if (options.handleUpEvent) {\n      this.handleUpEvent = options.handleUpEvent;\n    }\n\n    if (options.stopDown) {\n      this.stopDown = options.stopDown;\n    }\n\n    /**\n     * @type {boolean}\n     * @protected\n     */\n    this.handlingDownUpSequence = false;\n\n    /**\n     * @type {Array<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   */\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/events/condition\n */\nimport MapBrowserEventType from '../MapBrowserEventType.js';\nimport {FALSE, TRUE} from '../functions.js';\nimport {MAC, WEBKIT} from '../has.js';\nimport {assert} from '../asserts.js';\n\n/**\n * A function that takes an {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * `{boolean}`. If the condition is met, true should be returned.\n *\n * @typedef {function(this: ?, import(\"../MapBrowserEvent.js\").default): boolean} Condition\n */\n\n/**\n * Creates a condition function that passes when all provided conditions pass.\n * @param {...Condition} var_args Conditions to check.\n * @return {Condition} Condition function.\n */\nexport function all(var_args) {\n  const conditions = arguments;\n  /**\n   * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n   * @return {boolean} All conditions passed.\n   */\n  return function (event) {\n    let pass = true;\n    for (let i = 0, ii = conditions.length; i < ii; ++i) {\n      pass = pass && conditions[i](event);\n      if (!pass) {\n        break;\n      }\n    }\n    return pass;\n  };\n}\n\n/**\n * Return `true` if only the alt-key is pressed, `false` otherwise (e.g. when\n * additionally the shift-key is pressed).\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if only the alt key is pressed.\n * @api\n */\nexport const altKeyOnly = function (mapBrowserEvent) {\n  const originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (\n    mapBrowserEvent.originalEvent\n  );\n  return (\n    originalEvent.altKey &&\n    !(originalEvent.metaKey || originalEvent.ctrlKey) &&\n    !originalEvent.shiftKey\n  );\n};\n\n/**\n * Return `true` if only the alt-key and shift-key is pressed, `false` otherwise\n * (e.g. when additionally the platform-modifier-key is pressed).\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if only the alt and shift keys are pressed.\n * @api\n */\nexport const altShiftKeysOnly = function (mapBrowserEvent) {\n  const originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (\n    mapBrowserEvent.originalEvent\n  );\n  return (\n    originalEvent.altKey &&\n    !(originalEvent.metaKey || originalEvent.ctrlKey) &&\n    originalEvent.shiftKey\n  );\n};\n\n/**\n * Return `true` if the map has the focus. This condition requires a map target\n * element with a `tabindex` attribute, e.g. `<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 activeElement = event.map.getOwnerDocument().activeElement;\n  return targetElement.contains(activeElement);\n};\n\n/**\n * Return `true` if the map has the focus or no 'tabindex' attribute set.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} event Map browser event.\n * @return {boolean} The map container has the focus or no 'tabindex' attribute.\n */\nexport const focusWithTabindex = function (event) {\n  return event.map.getTargetElement().hasAttribute('tabindex')\n    ? focus(event)\n    : true;\n};\n\n/**\n * Return always true.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True.\n * @api\n */\nexport const always = TRUE;\n\n/**\n * Return `true` if the event is a `click` event, `false` otherwise.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event is a map `click` event.\n * @api\n */\nexport const click = function (mapBrowserEvent) {\n  return mapBrowserEvent.type == MapBrowserEventType.CLICK;\n};\n\n/**\n * Return `true` if the event has an \"action\"-producing mouse button.\n *\n * By definition, this includes left-click on windows/linux, and left-click\n * without the ctrl key on Macs.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} The result.\n */\nexport const mouseActionButton = function (mapBrowserEvent) {\n  const originalEvent = /** @type {MouseEvent} */ (\n    mapBrowserEvent.originalEvent\n  );\n  return originalEvent.button == 0 && !(WEBKIT && MAC && originalEvent.ctrlKey);\n};\n\n/**\n * Return always false.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} False.\n * @api\n */\nexport const never = FALSE;\n\n/**\n * Return `true` if the browser event is a `pointermove` event, `false`\n * otherwise.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the browser event is a `pointermove` event.\n * @api\n */\nexport const pointerMove = function (mapBrowserEvent) {\n  return mapBrowserEvent.type == 'pointermove';\n};\n\n/**\n * Return `true` if the event is a map `singleclick` event, `false` otherwise.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event is a map `singleclick` event.\n * @api\n */\nexport const singleClick = function (mapBrowserEvent) {\n  return mapBrowserEvent.type == MapBrowserEventType.SINGLECLICK;\n};\n\n/**\n * Return `true` if the event is a map `dblclick` event, `false` otherwise.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event is a map `dblclick` event.\n * @api\n */\nexport const doubleClick = function (mapBrowserEvent) {\n  return mapBrowserEvent.type == MapBrowserEventType.DBLCLICK;\n};\n\n/**\n * Return `true` if no modifier key (alt-, shift- or platform-modifier-key) is\n * pressed.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True only if there no modifier keys are pressed.\n * @api\n */\nexport const noModifierKeys = function (mapBrowserEvent) {\n  const originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (\n    mapBrowserEvent.originalEvent\n  );\n  return (\n    !originalEvent.altKey &&\n    !(originalEvent.metaKey || originalEvent.ctrlKey) &&\n    !originalEvent.shiftKey\n  );\n};\n\n/**\n * Return `true` if only the platform-modifier-key (the meta-key on Mac,\n * ctrl-key otherwise) is pressed, `false` otherwise (e.g. when additionally\n * the shift-key is pressed).\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if only the platform modifier key is pressed.\n * @api\n */\nexport const platformModifierKeyOnly = function (mapBrowserEvent) {\n  const originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (\n    mapBrowserEvent.originalEvent\n  );\n  return (\n    !originalEvent.altKey &&\n    (MAC ? originalEvent.metaKey : originalEvent.ctrlKey) &&\n    !originalEvent.shiftKey\n  );\n};\n\n/**\n * Return `true` if the platform-modifier-key (the meta-key on Mac,\n * ctrl-key otherwise) is pressed.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the platform modifier key is pressed.\n * @api\n */\nexport const platformModifierKey = function (mapBrowserEvent) {\n  const originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (\n    mapBrowserEvent.originalEvent\n  );\n  return MAC ? originalEvent.metaKey : originalEvent.ctrlKey;\n};\n\n/**\n * Return `true` if only the shift-key is pressed, `false` otherwise (e.g. when\n * additionally the alt-key is pressed).\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if only the shift key is pressed.\n * @api\n */\nexport const shiftKeyOnly = function (mapBrowserEvent) {\n  const originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (\n    mapBrowserEvent.originalEvent\n  );\n  return (\n    !originalEvent.altKey &&\n    !(originalEvent.metaKey || originalEvent.ctrlKey) &&\n    originalEvent.shiftKey\n  );\n};\n\n/**\n * Return `true` if the target element is not editable, i.e. not an `input`,\n * `select`, or `textarea` element and no `contenteditable` attribute is\n * set or inherited, `false` otherwise.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True only if the target element is not editable.\n * @api\n */\nexport const targetNotEditable = function (mapBrowserEvent) {\n  const originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (\n    mapBrowserEvent.originalEvent\n  );\n  const tagName = /** @type {Element} */ (originalEvent.target).tagName;\n  return (\n    tagName !== 'INPUT' &&\n    tagName !== 'SELECT' &&\n    tagName !== 'TEXTAREA' &&\n    // `isContentEditable` is only available on `HTMLElement`, but it may also be a\n    // different type like `SVGElement`.\n    // @ts-ignore\n    !originalEvent.target.isContentEditable\n  );\n};\n\n/**\n * Return `true` if the event originates from a mouse device.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event originates from a mouse device.\n * @api\n */\nexport const mouseOnly = function (mapBrowserEvent) {\n  const pointerEvent = /** @type {import(\"../MapBrowserEvent\").default} */ (\n    mapBrowserEvent\n  ).originalEvent;\n  assert(\n    pointerEvent !== undefined,\n    'mapBrowserEvent must originate from a pointer event'\n  );\n  // see https://www.w3.org/TR/pointerevents/#widl-PointerEvent-pointerType\n  return pointerEvent.pointerType == 'mouse';\n};\n\n/**\n * Return `true` if the event originates from a touchable device.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event originates from a touchable device.\n * @api\n */\nexport const touchOnly = function (mapBrowserEvent) {\n  const pointerEvt = /** @type {import(\"../MapBrowserEvent\").default} */ (\n    mapBrowserEvent\n  ).originalEvent;\n  assert(\n    pointerEvt !== undefined,\n    'mapBrowserEvent must originate from a pointer event'\n  );\n  // see https://www.w3.org/TR/pointerevents/#widl-PointerEvent-pointerType\n  return pointerEvt.pointerType === 'touch';\n};\n\n/**\n * Return `true` if the event originates from a digital pen.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event originates from a digital pen.\n * @api\n */\nexport const penOnly = function (mapBrowserEvent) {\n  const pointerEvt = /** @type {import(\"../MapBrowserEvent\").default} */ (\n    mapBrowserEvent\n  ).originalEvent;\n  assert(\n    pointerEvt !== undefined,\n    'mapBrowserEvent must originate from a pointer event'\n  );\n  // see https://www.w3.org/TR/pointerevents/#widl-PointerEvent-pointerType\n  return pointerEvt.pointerType === 'pen';\n};\n\n/**\n * Return `true` if the event originates from a primary pointer in\n * contact with the surface or if the left mouse button is pressed.\n * See https://www.w3.org/TR/pointerevents/#button-states.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event originates from a primary pointer.\n * @api\n */\nexport const primaryAction = function (mapBrowserEvent) {\n  const pointerEvent = /** @type {import(\"../MapBrowserEvent\").default} */ (\n    mapBrowserEvent\n  ).originalEvent;\n  assert(\n    pointerEvent !== undefined,\n    'mapBrowserEvent must originate from a pointer event'\n  );\n  return pointerEvent.isPrimary && pointerEvent.button === 0;\n};\n","/**\n * @module ol/interaction/DragPan\n */\nimport PointerInteraction, {\n  centroid as centroidFromPointers,\n} from './Pointer.js';\nimport {FALSE} from '../functions.js';\nimport {\n  all,\n  focusWithTabindex,\n  noModifierKeys,\n  primaryAction,\n} from '../events/condition.js';\nimport {easeOut} from '../easing.js';\nimport {\n  rotate as rotateCoordinate,\n  scale as scaleCoordinate,\n} from '../coordinate.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that takes an {@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     */\n    this.lastPointersCount_;\n\n    /**\n     * @type {boolean}\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   */\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   */\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   */\n  handleDownEvent(mapBrowserEvent) {\n    if (this.targetPointers.length > 0 && this.condition_(mapBrowserEvent)) {\n      const map = mapBrowserEvent.map;\n      const view = map.getView();\n      this.lastCentroid = null;\n      // stop any current animation\n      if (view.getAnimating()) {\n        view.cancelAnimations();\n      }\n      if (this.kinetic_) {\n        this.kinetic_.begin();\n      }\n      // No kinetic as soon as more than one pointer on the screen is\n      // detected. This is to prevent nasty pans after pinch.\n      this.noKinetic_ = this.targetPointers.length > 1;\n      return true;\n    }\n    return false;\n  }\n}\n\nexport default DragPan;\n","/**\n * @module ol/interaction/DragRotate\n */\nimport PointerInteraction from './Pointer.js';\nimport {FALSE} from '../functions.js';\nimport {\n  altShiftKeysOnly,\n  mouseActionButton,\n  mouseOnly,\n} from '../events/condition.js';\nimport {disable} from '../rotationconstraint.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that takes an\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 an {@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   */\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   */\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   */\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   */\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    const startPixel = this.startPixel_;\n    const endPixel = this.endPixel_;\n    const pixels = [\n      startPixel,\n      [startPixel[0], endPixel[1]],\n      endPixel,\n      [endPixel[0], startPixel[1]],\n    ];\n    const coordinates = pixels.map(\n      this.map_.getCoordinateFromPixelInternal,\n      this.map_\n    );\n    // close the polygon\n    coordinates[4] = coordinates[0].slice();\n    if (!this.geometry_) {\n      this.geometry_ = new Polygon([coordinates]);\n    } else {\n      this.geometry_.setCoordinates([coordinates]);\n    }\n  }\n\n  /**\n   * @return {import(\"../geom/Polygon.js\").default} Geometry.\n   */\n  getGeometry() {\n    return this.geometry_;\n  }\n}\n\nexport default RenderBox;\n","/**\n * @module ol/interaction/DragBox\n */\n// FIXME draw drag box\nimport Event from '../events/Event.js';\nimport PointerInteraction from './Pointer.js';\nimport RenderBox from '../render/Box.js';\nimport {mouseActionButton} from '../events/condition.js';\n\n/**\n * A function that takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and two\n * {@link module:ol/pixel~Pixel}s and returns a `{boolean}`. If the condition is met,\n * true should be returned.\n * @typedef {function(this: ?, import(\"../MapBrowserEvent.js\").default, import(\"../pixel.js\").Pixel, import(\"../pixel.js\").Pixel):boolean} EndCondition\n */\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-dragbox'] CSS class name for styling the box.\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that takes an {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a boolean\n * to indicate whether that event should be handled.\n * Default is {@link ol/events/condition~mouseActionButton}.\n * @property {number} [minArea=64] The minimum area of the box in pixel, this value is used by the default\n * `boxEndCondition` function.\n * @property {EndCondition} [boxEndCondition] A function that takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and two\n * {@link module:ol/pixel~Pixel}s to indicate whether a `boxend` event should be fired.\n * Default is `true` if the area of the box is bigger than the `minArea` option.\n * @property {function(this:DragBox, import(\"../MapBrowserEvent.js\").default):void} [onBoxEnd] Code to execute just\n * before `boxend` is fired.\n */\n\n/**\n * @enum {string}\n */\nconst DragBoxEventType = {\n  /**\n   * Triggered upon drag box start.\n   * @event DragBoxEvent#boxstart\n   * @api\n   */\n  BOXSTART: 'boxstart',\n\n  /**\n   * Triggered on drag when box is active.\n   * @event DragBoxEvent#boxdrag\n   * @api\n   */\n  BOXDRAG: 'boxdrag',\n\n  /**\n   * Triggered upon drag box end.\n   * @event DragBoxEvent#boxend\n   * @api\n   */\n  BOXEND: 'boxend',\n\n  /**\n   * Triggered upon drag box canceled.\n   * @event DragBoxEvent#boxcancel\n   * @api\n   */\n  BOXCANCEL: 'boxcancel',\n};\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/interaction/DragBox~DragBox} instances are instances of\n * this type.\n */\nexport class DragBoxEvent extends Event {\n  /**\n   * @param {string} type The event type.\n   * @param {import(\"../coordinate.js\").Coordinate} coordinate The event coordinate.\n   * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Originating event.\n   */\n  constructor(type, coordinate, mapBrowserEvent) {\n    super(type);\n\n    /**\n     * The coordinate of the drag event.\n     * @const\n     * @type {import(\"../coordinate.js\").Coordinate}\n     * @api\n     */\n    this.coordinate = coordinate;\n\n    /**\n     * @const\n     * @type {import(\"../MapBrowserEvent.js\").default}\n     * @api\n     */\n    this.mapBrowserEvent = mapBrowserEvent;\n  }\n}\n\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types|\n *     'change:active', import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").OnSignature<'boxcancel'|'boxdrag'|'boxend'|'boxstart', DragBoxEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").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 an {@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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {DragBoxOnSignature<import(\"../events\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {DragBoxOnSignature<void>}\n     */\n    this.un;\n\n    options = options ? options : {};\n\n    /**\n     * @type {import(\"../render/Box.js\").default}\n     * @private\n     */\n    this.box_ = new RenderBox(options.className || 'ol-dragbox');\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.minArea_ = options.minArea !== undefined ? options.minArea : 64;\n\n    if (options.onBoxEnd) {\n      this.onBoxEnd = options.onBoxEnd;\n    }\n\n    /**\n     * @type {import(\"../pixel.js\").Pixel}\n     * @private\n     */\n    this.startPixel_ = null;\n\n    /**\n     * @private\n     * @type {import(\"../events/condition.js\").Condition}\n     */\n    this.condition_ = options.condition ? options.condition : mouseActionButton;\n\n    /**\n     * @private\n     * @type {EndCondition}\n     */\n    this.boxEndCondition_ = options.boxEndCondition\n      ? options.boxEndCondition\n      : this.defaultBoxEndCondition;\n  }\n\n  /**\n   * The default condition for determining whether the boxend event\n   * should fire.\n   * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent The originating MapBrowserEvent\n   *     leading to the box end.\n   * @param {import(\"../pixel.js\").Pixel} startPixel The starting pixel of the box.\n   * @param {import(\"../pixel.js\").Pixel} endPixel The end pixel of the box.\n   * @return {boolean} Whether or not the boxend condition should be fired.\n   */\n  defaultBoxEndCondition(mapBrowserEvent, startPixel, endPixel) {\n    const width = endPixel[0] - startPixel[0];\n    const height = endPixel[1] - startPixel[1];\n    return width * width + height * height >= this.minArea_;\n  }\n\n  /**\n   * Returns geometry of last drawn box.\n   * @return {import(\"../geom/Polygon.js\").default} Geometry.\n   * @api\n   */\n  getGeometry() {\n    return this.box_.getGeometry();\n  }\n\n  /**\n   * Handle pointer drag events.\n   * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n   */\n  handleDragEvent(mapBrowserEvent) {\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   */\n  handleUpEvent(mapBrowserEvent) {\n    this.box_.setMap(null);\n\n    const completeBox = this.boxEndCondition_(\n      mapBrowserEvent,\n      this.startPixel_,\n      mapBrowserEvent.pixel\n    );\n    if (completeBox) {\n      this.onBoxEnd(mapBrowserEvent);\n    }\n    this.dispatchEvent(\n      new DragBoxEvent(\n        completeBox ? DragBoxEventType.BOXEND : DragBoxEventType.BOXCANCEL,\n        mapBrowserEvent.coordinate,\n        mapBrowserEvent\n      )\n    );\n    return false;\n  }\n\n  /**\n   * Handle pointer down events.\n   * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n   * @return {boolean} If the event was consumed.\n   */\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\nexport default DragBox;\n","/**\n * @module ol/interaction/DragZoom\n */\nimport DragBox from './DragBox.js';\nimport {easeOut} from '../easing.js';\nimport {shiftKeyOnly} from '../events/condition.js';\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-dragzoom'] CSS class name for styling the\n * box.\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes an {@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 an {@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   */\n  onBoxEnd(event) {\n    const map = this.getMap();\n    const view = /** @type {!import(\"../View.js\").default} */ (map.getView());\n    let geometry = this.getGeometry();\n\n    if (this.out_) {\n      const rotatedExtent = view.rotatedExtentForGeometry(geometry);\n      const resolution = view.getResolutionForExtentInternal(rotatedExtent);\n      const factor = view.getResolution() / resolution;\n      geometry = geometry.clone();\n      geometry.scale(factor * factor);\n    }\n\n    view.fitInternal(geometry, {\n      duration: this.duration_,\n      easing: easeOut,\n    });\n  }\n}\n\nexport default DragZoom;\n","/**\n * @module ol/events/Key\n */\n\n/**\n * @enum {string}\n * @const\n */\nexport default {\n  LEFT: 'ArrowLeft',\n  UP: 'ArrowUp',\n  RIGHT: 'ArrowRight',\n  DOWN: 'ArrowDown',\n};\n","/**\n * @module ol/interaction/KeyboardPan\n */\nimport EventType from '../events/EventType.js';\nimport Interaction, {pan} from './Interaction.js';\nimport Key from '../events/Key.js';\nimport {noModifierKeys, targetNotEditable} from '../events/condition.js';\nimport {rotate as rotateCoordinate} from '../coordinate.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes an {@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   */\n  handleEvent(mapBrowserEvent) {\n    let stopEvent = false;\n    if (mapBrowserEvent.type == EventType.KEYDOWN) {\n      const keyEvent = /** @type {KeyboardEvent} */ (\n        mapBrowserEvent.originalEvent\n      );\n      const key = keyEvent.key;\n      if (\n        this.condition_(mapBrowserEvent) &&\n        (key == Key.DOWN ||\n          key == Key.LEFT ||\n          key == Key.RIGHT ||\n          key == Key.UP)\n      ) {\n        const map = mapBrowserEvent.map;\n        const view = map.getView();\n        const mapUnitsDelta = view.getResolution() * this.pixelDelta_;\n        let deltaX = 0,\n          deltaY = 0;\n        if (key == Key.DOWN) {\n          deltaY = -mapUnitsDelta;\n        } else if (key == Key.LEFT) {\n          deltaX = -mapUnitsDelta;\n        } else if (key == Key.RIGHT) {\n          deltaX = mapUnitsDelta;\n        } else {\n          deltaY = mapUnitsDelta;\n        }\n        const delta = [deltaX, deltaY];\n        rotateCoordinate(delta, view.getRotation());\n        pan(view, delta, this.duration_);\n        keyEvent.preventDefault();\n        stopEvent = true;\n      }\n    }\n    return !stopEvent;\n  }\n}\n\nexport default KeyboardPan;\n","/**\n * @module ol/interaction/KeyboardZoom\n */\nimport EventType from '../events/EventType.js';\nimport Interaction, {zoomByDelta} from './Interaction.js';\nimport {platformModifierKey, targetNotEditable} from '../events/condition.js';\n\n/**\n * @typedef {Object} Options\n * @property {number} [duration=100] Animation duration in milliseconds.\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes an {@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   */\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 EventType from '../events/EventType.js';\nimport Interaction, {zoomByDelta} from './Interaction.js';\nimport {DEVICE_PIXEL_RATIO, FIREFOX} from '../has.js';\nimport {all, always, focusWithTabindex} from '../events/condition.js';\nimport {clamp} from '../math.js';\n\n/**\n * @typedef {'trackpad' | 'wheel'} Mode\n */\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes an {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * boolean to indicate whether that event should be handled. Default is\n * {@link module:ol/events/condition.always}.\n * @property {boolean} [onFocusOnly=false] When the map's target has a `tabindex` attribute set,\n * the interaction will only handle events when the map has the focus.\n * @property {number} [maxDelta=1] Maximum mouse wheel delta.\n * @property {number} [duration=250] Animation duration in milliseconds.\n * @property {number} [timeout=80] Mouse wheel timeout duration in milliseconds.\n * @property {boolean} [useAnchor=true] Enable zooming using the mouse's\n * location as the anchor. When set to `false`, zooming in and out will zoom to\n * the center of the screen instead of zooming on the mouse's location.\n * @property {boolean} [constrainResolution=false] If true, the mouse wheel zoom\n * event will always animate to the closest zoom level after an interaction;\n * false means intermediary zoom levels are allowed.\n */\n\n/**\n * @classdesc\n * Allows the user to zoom the map by scrolling the mouse wheel.\n * @api\n */\nclass MouseWheelZoom extends Interaction {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super(\n      /** @type {import(\"./Interaction.js\").InteractionOptions} */ (options)\n    );\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.totalDelta_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.lastDelta_ = 0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.maxDelta_ = options.maxDelta !== undefined ? options.maxDelta : 1;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.duration_ = options.duration !== undefined ? options.duration : 250;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.timeout_ = options.timeout !== undefined ? options.timeout : 80;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.useAnchor_ =\n      options.useAnchor !== undefined ? options.useAnchor : true;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.constrainResolution_ =\n      options.constrainResolution !== undefined\n        ? options.constrainResolution\n        : false;\n\n    const condition = options.condition ? options.condition : always;\n\n    /**\n     * @private\n     * @type {import(\"../events/condition.js\").Condition}\n     */\n    this.condition_ = options.onFocusOnly\n      ? all(focusWithTabindex, condition)\n      : condition;\n\n    /**\n     * @private\n     * @type {?import(\"../coordinate.js\").Coordinate}\n     */\n    this.lastAnchor_ = null;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.startTime_ = undefined;\n\n    /**\n     * @private\n     * @type {ReturnType<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  /**\n   * @private\n   */\n  endInteraction_() {\n    this.trackpadTimeoutId_ = undefined;\n    const map = this.getMap();\n    if (!map) {\n      return;\n    }\n    const view = map.getView();\n    view.endInteraction(\n      undefined,\n      this.lastDelta_ ? (this.lastDelta_ > 0 ? 1 : -1) : 0,\n      this.lastAnchor_\n    );\n  }\n\n  /**\n   * Handles the {@link module:ol/MapBrowserEvent~MapBrowserEvent map browser event} (if it was a mousewheel-event) and eventually\n   * zooms the map.\n   * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n   * @return {boolean} `false` to stop event propagation.\n   */\n  handleEvent(mapBrowserEvent) {\n    if (!this.condition_(mapBrowserEvent)) {\n      return true;\n    }\n    const type = mapBrowserEvent.type;\n    if (type !== EventType.WHEEL) {\n      return true;\n    }\n\n    const map = mapBrowserEvent.map;\n    const wheelEvent = /** @type {WheelEvent} */ (\n      mapBrowserEvent.originalEvent\n    );\n    wheelEvent.preventDefault();\n\n    if (this.useAnchor_) {\n      this.lastAnchor_ = mapBrowserEvent.coordinate;\n    }\n\n    // Delta normalisation inspired by\n    // https://github.com/mapbox/mapbox-gl-js/blob/001c7b9/js/ui/handler/scroll_zoom.js\n    let delta;\n    if (mapBrowserEvent.type == EventType.WHEEL) {\n      delta = wheelEvent.deltaY;\n      if (FIREFOX && wheelEvent.deltaMode === WheelEvent.DOM_DELTA_PIXEL) {\n        delta /= DEVICE_PIXEL_RATIO;\n      }\n      if (wheelEvent.deltaMode === WheelEvent.DOM_DELTA_LINE) {\n        delta *= 40;\n      }\n    }\n\n    if (delta === 0) {\n      return false;\n    }\n    this.lastDelta_ = delta;\n\n    const now = Date.now();\n\n    if (this.startTime_ === undefined) {\n      this.startTime_ = now;\n    }\n\n    if (!this.mode_ || now - this.startTime_ > this.trackpadEventGap_) {\n      this.mode_ = Math.abs(delta) < 4 ? 'trackpad' : 'wheel';\n    }\n\n    const view = map.getView();\n    if (\n      this.mode_ === 'trackpad' &&\n      !(view.getConstrainResolution() || this.constrainResolution_)\n    ) {\n      if (this.trackpadTimeoutId_) {\n        clearTimeout(this.trackpadTimeoutId_);\n      } else {\n        if (view.getAnimating()) {\n          view.cancelAnimations();\n        }\n        view.beginInteraction();\n      }\n      this.trackpadTimeoutId_ = setTimeout(\n        this.endInteraction_.bind(this),\n        this.timeout_\n      );\n      view.adjustZoom(-delta / this.deltaPerZoom_, this.lastAnchor_);\n      this.startTime_ = now;\n      return false;\n    }\n\n    this.totalDelta_ += delta;\n\n    const timeLeft = Math.max(this.timeout_ - (now - this.startTime_), 0);\n\n    clearTimeout(this.timeoutId_);\n    this.timeoutId_ = setTimeout(\n      this.handleWheelZoom_.bind(this, map),\n      timeLeft\n    );\n\n    return false;\n  }\n\n  /**\n   * @private\n   * @param {import(\"../Map.js\").default} map Map.\n   */\n  handleWheelZoom_(map) {\n    const view = map.getView();\n    if (view.getAnimating()) {\n      view.cancelAnimations();\n    }\n    let delta =\n      -clamp(\n        this.totalDelta_,\n        -this.maxDelta_ * this.deltaPerZoom_,\n        this.maxDelta_ * this.deltaPerZoom_\n      ) / this.deltaPerZoom_;\n    if (view.getConstrainResolution() || this.constrainResolution_) {\n      // view has a zoom constraint, zoom by 1\n      delta = delta ? (delta > 0 ? 1 : -1) : 0;\n    }\n    zoomByDelta(view, delta, this.lastAnchor_, this.duration_);\n\n    this.mode_ = undefined;\n    this.totalDelta_ = 0;\n    this.lastAnchor_ = null;\n    this.startTime_ = undefined;\n    this.timeoutId_ = undefined;\n  }\n\n  /**\n   * Enable or disable using the mouse's location as an anchor when zooming\n   * @param {boolean} useAnchor true to zoom to the mouse's location, false\n   * to zoom to the center of the map\n   * @api\n   */\n  setMouseAnchor(useAnchor) {\n    this.useAnchor_ = useAnchor;\n    if (!useAnchor) {\n      this.lastAnchor_ = null;\n    }\n  }\n}\n\nexport default MouseWheelZoom;\n","/**\n * @module ol/interaction/PinchRotate\n */\nimport PointerInteraction, {\n  centroid as centroidFromPointers,\n} from './Pointer.js';\nimport {FALSE} from '../functions.js';\nimport {disable} from '../rotationconstraint.js';\n\n/**\n * @typedef {Object} Options\n * @property {number} [duration=250] The duration of the animation in\n * milliseconds.\n * @property {number} [threshold=0.3] Minimal angle in radians to start a rotation.\n */\n\n/**\n * @classdesc\n * Allows the user to rotate the map by twisting with two fingers\n * on a touch screen.\n * @api\n */\nclass PinchRotate extends PointerInteraction {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    const pointerOptions = /** @type {import(\"./Pointer.js\").Options} */ (\n      options\n    );\n\n    if (!pointerOptions.stopDown) {\n      pointerOptions.stopDown = FALSE;\n    }\n\n    super(pointerOptions);\n\n    /**\n     * @private\n     * @type {import(\"../coordinate.js\").Coordinate}\n     */\n    this.anchor_ = null;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.lastAngle_ = undefined;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.rotating_ = false;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.rotationDelta_ = 0.0;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.threshold_ = options.threshold !== undefined ? options.threshold : 0.3;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.duration_ = options.duration !== undefined ? options.duration : 250;\n  }\n\n  /**\n   * Handle pointer drag events.\n   * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n   */\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   */\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   */\n  handleDownEvent(mapBrowserEvent) {\n    if (this.targetPointers.length >= 2) {\n      const map = mapBrowserEvent.map;\n      this.anchor_ = null;\n      this.lastAngle_ = undefined;\n      this.rotating_ = false;\n      this.rotationDelta_ = 0.0;\n      if (!this.handlingDownUpSequence) {\n        map.getView().beginInteraction();\n      }\n      return true;\n    }\n    return false;\n  }\n}\n\nexport default PinchRotate;\n","/**\n * @module ol/interaction/PinchZoom\n */\nimport PointerInteraction, {\n  centroid as centroidFromPointers,\n} from './Pointer.js';\nimport {FALSE} from '../functions.js';\n\n/**\n * @typedef {Object} Options\n * @property {number} [duration=400] Animation duration in milliseconds.\n */\n\n/**\n * @classdesc\n * Allows the user to zoom the map by pinching with two fingers\n * on a touch screen.\n * @api\n */\nclass PinchZoom extends PointerInteraction {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    const pointerOptions = /** @type {import(\"./Pointer.js\").Options} */ (\n      options\n    );\n\n    if (!pointerOptions.stopDown) {\n      pointerOptions.stopDown = FALSE;\n    }\n\n    super(pointerOptions);\n\n    /**\n     * @private\n     * @type {import(\"../coordinate.js\").Coordinate}\n     */\n    this.anchor_ = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.duration_ = options.duration !== undefined ? options.duration : 400;\n\n    /**\n     * @private\n     * @type {number|undefined}\n     */\n    this.lastDistance_ = undefined;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.lastScaleDelta_ = 1;\n  }\n\n  /**\n   * Handle pointer drag events.\n   * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n   */\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   */\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   */\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 DoubleClickZoom from './DoubleClickZoom.js';\nimport DragPan from './DragPan.js';\nimport DragRotate from './DragRotate.js';\nimport DragZoom from './DragZoom.js';\nimport KeyboardPan from './KeyboardPan.js';\nimport KeyboardZoom from './KeyboardZoom.js';\nimport Kinetic from '../Kinetic.js';\nimport MouseWheelZoom from './MouseWheelZoom.js';\nimport PinchRotate from './PinchRotate.js';\nimport PinchZoom from './PinchZoom.js';\n\n/**\n * @typedef {Object} DefaultsOptions\n * @property {boolean} [altShiftDragRotate=true] Whether Alt-Shift-drag rotate is\n * desired.\n * @property {boolean} [onFocusOnly=false] Interact only when the map has the\n * focus. This affects the `MouseWheelZoom` and `DragPan` interactions and is\n * useful when page scroll is desired for maps that do not have the browser's\n * focus.\n * @property {boolean} [doubleClickZoom=true] Whether double click zoom is\n * desired.\n * @property {boolean} [keyboard=true] Whether keyboard interaction is desired.\n * @property {boolean} [mouseWheelZoom=true] Whether mousewheel zoom is desired.\n * @property {boolean} [shiftDragZoom=true] Whether Shift-drag zoom is desired.\n * @property {boolean} [dragPan=true] Whether drag pan is desired.\n * @property {boolean} [pinchRotate=true] Whether pinch rotate is desired.\n * @property {boolean} [pinchZoom=true] Whether pinch zoom is desired.\n * @property {number} [zoomDelta] Zoom level delta when using keyboard or double click zoom.\n * @property {number} [zoomDuration] Duration of the zoom animation in\n * milliseconds.\n */\n\n/**\n * Set of interactions included in maps by default. Specific interactions can be\n * excluded by setting the appropriate option to false in the constructor\n * options, but the order of the interactions is fixed.  If you want to specify\n * a different order for interactions, you will need to create your own\n * {@link module:ol/interaction/Interaction~Interaction} instances and insert\n * them into a {@link module:ol/Collection~Collection} in the order you want\n * before creating your {@link module:ol/Map~Map} instance. Changing the order can\n * be of interest if the event propagation needs to be stopped at a point.\n * The default set of interactions, in sequence, is:\n * * {@link module:ol/interaction/DragRotate~DragRotate}\n * * {@link module:ol/interaction/DoubleClickZoom~DoubleClickZoom}\n * * {@link module:ol/interaction/DragPan~DragPan}\n * * {@link module:ol/interaction/PinchRotate~PinchRotate}\n * * {@link module:ol/interaction/PinchZoom~PinchZoom}\n * * {@link module:ol/interaction/KeyboardPan~KeyboardPan}\n * * {@link module:ol/interaction/KeyboardZoom~KeyboardZoom}\n * * {@link module:ol/interaction/MouseWheelZoom~MouseWheelZoom}\n * * {@link module:ol/interaction/DragZoom~DragZoom}\n *\n * @param {DefaultsOptions} [options] Defaults options.\n * @return {Collection<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/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/Map\n */\nimport BaseObject from './Object.js';\nimport Collection from './Collection.js';\nimport CollectionEventType from './CollectionEventType.js';\nimport CompositeMapRenderer from './renderer/Composite.js';\nimport EventType from './events/EventType.js';\nimport Layer from './layer/Layer.js';\nimport LayerGroup, {GroupEvent} from './layer/Group.js';\nimport MapBrowserEvent from './MapBrowserEvent.js';\nimport MapBrowserEventHandler from './MapBrowserEventHandler.js';\nimport MapBrowserEventType from './MapBrowserEventType.js';\nimport MapEvent from './MapEvent.js';\nimport MapEventType from './MapEventType.js';\nimport MapProperty from './MapProperty.js';\nimport ObjectEventType from './ObjectEventType.js';\nimport PointerEventType from './pointer/EventType.js';\nimport RenderEventType from './render/EventType.js';\nimport TileQueue, {getTilePriority} from './TileQueue.js';\nimport View from './View.js';\nimport ViewHint from './ViewHint.js';\nimport {DEVICE_PIXEL_RATIO, PASSIVE_EVENT_LISTENERS} from './has.js';\nimport {TRUE} from './functions.js';\nimport {\n  apply as applyTransform,\n  create as createTransform,\n} from './transform.js';\nimport {assert} from './asserts.js';\nimport {\n  clone,\n  createOrUpdateEmpty,\n  equals as equalsExtent,\n  getForViewAndSize,\n  isEmpty,\n} from './extent.js';\nimport {defaults as defaultControls} from './control/defaults.js';\nimport {defaults as defaultInteractions} from './interaction/defaults.js';\nimport {equals} from './array.js';\nimport {fromUserCoordinate, toUserCoordinate} from './proj.js';\nimport {getUid} from './util.js';\nimport {hasArea} from './size.js';\nimport {listen, unlistenByKey} from './events.js';\nimport {removeNode} from './dom.js';\nimport {warn} from './console.js';\n\n/**\n * State of the current frame. Only `pixelRatio`, `time` and `viewState` should\n * be used in applications.\n * @typedef {Object} FrameState\n * @property {number} pixelRatio The pixel ratio of the frame.\n * @property {number} time The time when rendering of the frame was requested.\n * @property {import(\"./View.js\").State} viewState The state of the current view.\n * @property {boolean} animate Animate.\n * @property {import(\"./transform.js\").Transform} coordinateToPixelTransform CoordinateToPixelTransform.\n * @property {import(\"rbush\").default} declutterTree DeclutterTree.\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\").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\").Types|'change:layergroup'|'change:size'|'change:target'|'change:view'} MapObjectEventTypes\n */\n\n/***\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature<import(\"./Observable\").EventTypes, import(\"./events/Event.js\").default, Return> &\n *    import(\"./Observable\").OnSignature<MapObjectEventTypes, import(\"./Object\").ObjectEvent, Return> &\n *    import(\"./Observable\").OnSignature<import(\"./MapBrowserEventType\").Types, import(\"./MapBrowserEvent\").default, Return> &\n *    import(\"./Observable\").OnSignature<import(\"./MapEventType\").Types, import(\"./MapEvent\").default, Return> &\n *    import(\"./Observable\").OnSignature<import(\"./render/EventType\").MapRenderEventTypes, import(\"./render/Event\").default, Return> &\n *    import(\"./Observable\").CombinedOnSignature<import(\"./Observable\").EventTypes|MapObjectEventTypes|\n *      import(\"./MapBrowserEventType\").Types|import(\"./MapEventType\").Types|\n *      import(\"./render/EventType\").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.\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.\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} [target] The container for the map, either the\n * element itself or the `id` of the element. If not specified at construction\n * time, {@link module:ol/Map~Map#setTarget} must be called for the map to be\n * rendered. If passed by element, the container can be in a secondary document.\n * **Note:** CSS `transform` support for the target element is limited to `scale`.\n * @property {View|Promise<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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {MapEventHandler<import(\"./events\").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|undefined}\n     */\n    this.renderComplete_;\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    this.viewport_ = document.createElement('div');\n    this.viewport_.className =\n      'ol-viewport' + ('ontouchstart' in window ? ' ol-touch' : '');\n    this.viewport_.style.position = 'relative';\n    this.viewport_.style.overflow = 'hidden';\n    this.viewport_.style.width = '100%';\n    this.viewport_.style.height = '100%';\n\n    /**\n     * @private\n     * @type {!HTMLElement}\n     */\n    this.overlayContainer_ = document.createElement('div');\n    this.overlayContainer_.style.position = 'absolute';\n    this.overlayContainer_.style.zIndex = '0';\n    this.overlayContainer_.style.width = '100%';\n    this.overlayContainer_.style.height = '100%';\n    this.overlayContainer_.style.pointerEvents = 'none';\n    this.overlayContainer_.className = 'ol-overlaycontainer';\n    this.viewport_.appendChild(this.overlayContainer_);\n\n    /**\n     * @private\n     * @type {!HTMLElement}\n     */\n    this.overlayContainerStopEvent_ = document.createElement('div');\n    this.overlayContainerStopEvent_.style.position = 'absolute';\n    this.overlayContainerStopEvent_.style.zIndex = '0';\n    this.overlayContainerStopEvent_.style.width = '100%';\n    this.overlayContainerStopEvent_.style.height = '100%';\n    this.overlayContainerStopEvent_.style.pointerEvents = 'none';\n    this.overlayContainerStopEvent_.className = 'ol-overlaycontainer-stopevent';\n    this.viewport_.appendChild(this.overlayContainerStopEvent_);\n\n    /**\n     * @private\n     * @type {MapBrowserEventHandler}\n     */\n    this.mapBrowserEventHandler_ = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.moveTolerance_ = options.moveTolerance;\n\n    /**\n     * @private\n     * @type {HTMLElement|Document}\n     */\n    this.keyboardEventTarget_ = optionsInternal.keyboardEventTarget;\n\n    /**\n     * @private\n     * @type {?Array<import(\"./events.js\").EventsKey>}\n     */\n    this.targetChangeHandlerKeys_ = null;\n\n    /**\n     * @private\n     * @type {HTMLElement|null}\n     */\n    this.targetElement_ = null;\n\n    /**\n     * @type {ResizeObserver}\n     */\n    this.resizeObserver_ = new ResizeObserver(() => this.updateSize());\n\n    /**\n     * @type {Collection<import(\"./control/Control.js\").default>}\n     * @protected\n     */\n    this.controls = optionsInternal.controls || defaultControls();\n\n    /**\n     * @type {Collection<import(\"./interaction/Interaction.js\").default>}\n     * @protected\n     */\n    this.interactions =\n      optionsInternal.interactions ||\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   */\n  disposeInternal() {\n    this.controls.clear();\n    this.interactions.clear();\n    this.overlays_.clear();\n    this.resizeObserver_.disconnect();\n    this.setTarget(null);\n    super.disposeInternal();\n  }\n\n  /**\n   * Detect features that intersect a pixel on the viewport, and execute a\n   * callback with each intersecting feature. Layers included in the detection can\n   * be configured through the `layerFilter` option in `options`.\n   * @param {import(\"./pixel.js\").Pixel} pixel Pixel.\n   * @param {function(import(\"./Feature.js\").FeatureLike, import(\"./layer/Layer.js\").default<import(\"./source/Source\").default>, import(\"./geom/SimpleGeometry.js\").default): T} callback Feature callback. The callback will be\n   *     called with two arguments. The first argument is one\n   *     {@link module:ol/Feature~Feature feature} or\n   *     {@link module:ol/render/Feature~RenderFeature render feature} at the pixel, the second is\n   *     the {@link module:ol/layer/Layer~Layer layer} of the feature and will be null for\n   *     unmanaged layers. To stop detection, callback functions can return a\n   *     truthy value.\n   * @param {AtPixelOptions} [options] Optional options.\n   * @return {T|undefined} Callback result, i.e. the return value of last\n   * callback execution, or the first truthy callback return value.\n   * @template T\n   * @api\n   */\n  forEachFeatureAtPixel(pixel, callback, options) {\n    if (!this.frameState_ || !this.renderer_) {\n      return;\n    }\n    const coordinate = this.getCoordinateFromPixelInternal(pixel);\n    options = options !== undefined ? options : {};\n    const hitTolerance =\n      options.hitTolerance !== undefined ? options.hitTolerance : 0;\n    const layerFilter =\n      options.layerFilter !== undefined ? options.layerFilter : TRUE;\n    const checkWrapped = options.checkWrapped !== false;\n    return this.renderer_.forEachFeatureAtCoordinate(\n      coordinate,\n      this.frameState_,\n      hitTolerance,\n      checkWrapped,\n      callback,\n      null,\n      layerFilter,\n      null\n    );\n  }\n\n  /**\n   * Get all features that intersect a pixel on the viewport.\n   * @param {import(\"./pixel.js\").Pixel} pixel Pixel.\n   * @param {AtPixelOptions} [options] Optional options.\n   * @return {Array<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   * @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} 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 map renderer.\n   * @return {import(\"./renderer/Map.js\").default|null} Renderer\n   */\n  getRenderer() {\n    return this.renderer_;\n  }\n\n  /**\n   * Get the size of this map.\n   * @return {import(\"./size.js\").Size|undefined} The size in pixels of the map in the DOM.\n   * @observable\n   * @api\n   */\n  getSize() {\n    return /** @type {import(\"./size.js\").Size|undefined} */ (\n      this.get(MapProperty.SIZE)\n    );\n  }\n\n  /**\n   * Get the view associated with this map. A view manages properties such as\n   * center and resolution.\n   * @return {View} The view that controls this map.\n   * @observable\n   * @api\n   */\n  getView() {\n    return /** @type {View} */ (this.get(MapProperty.VIEW));\n  }\n\n  /**\n   * Get the element that serves as the map viewport.\n   * @return {HTMLElement} Viewport.\n   * @api\n   */\n  getViewport() {\n    return this.viewport_;\n  }\n\n  /**\n   * Get the element that serves as the container for overlays.  Elements added to\n   * this container will let mousedown and touchstart events through to the map,\n   * so clicks and gestures on an overlay will trigger {@link module:ol/MapBrowserEvent~MapBrowserEvent}\n   * events.\n   * @return {!HTMLElement} The map's overlay container.\n   */\n  getOverlayContainer() {\n    return this.overlayContainer_;\n  }\n\n  /**\n   * Get the element that serves as a container for overlays that don't allow\n   * event propagation. Elements added to this container won't let mousedown and\n   * touchstart events through to the map, so clicks and gestures on an overlay\n   * don't trigger any {@link module:ol/MapBrowserEvent~MapBrowserEvent}.\n   * @return {!HTMLElement} The map's overlay container that stops events.\n   */\n  getOverlayContainerStopEvent() {\n    return this.overlayContainerStopEvent_;\n  }\n\n  /**\n   * @return {!Document} The document where the map is displayed.\n   */\n  getOwnerDocument() {\n    const targetElement = this.getTargetElement();\n    return targetElement ? targetElement.ownerDocument : document;\n  }\n\n  /**\n   * @param {import(\"./Tile.js\").default} tile Tile.\n   * @param {string} tileSourceKey Tile source key.\n   * @param {import(\"./coordinate.js\").Coordinate} tileCenter Tile center.\n   * @param {number} tileResolution Tile resolution.\n   * @return {number} Tile priority.\n   */\n  getTilePriority(tile, tileSourceKey, tileCenter, tileResolution) {\n    return getTilePriority(\n      this.frameState_,\n      tile,\n      tileSourceKey,\n      tileCenter,\n      tileResolution\n    );\n  }\n\n  /**\n   * @param {UIEvent} browserEvent Browser event.\n   * @param {string} [type] Type.\n   */\n  handleBrowserEvent(browserEvent, type) {\n    type = type || browserEvent.type;\n    const mapBrowserEvent = new MapBrowserEvent(type, this, browserEvent);\n    this.handleMapBrowserEvent(mapBrowserEvent);\n  }\n\n  /**\n   * @param {MapBrowserEvent} mapBrowserEvent The event to handle.\n   */\n  handleMapBrowserEvent(mapBrowserEvent) {\n    if (!this.frameState_) {\n      // With no view defined, we cannot translate pixels into geographical\n      // coordinates so interactions cannot be used.\n      return;\n    }\n    const originalEvent = /** @type {PointerEvent} */ (\n      mapBrowserEvent.originalEvent\n    );\n    const eventType = originalEvent.type;\n    if (\n      eventType === PointerEventType.POINTERDOWN ||\n      eventType === EventType.WHEEL ||\n      eventType === EventType.KEYDOWN\n    ) {\n      const doc = this.getOwnerDocument();\n      const rootNode = this.viewport_.getRootNode\n        ? this.viewport_.getRootNode()\n        : doc;\n      const target = /** @type {Node} */ (originalEvent.target);\n      if (\n        // Abort if the target is a child of the container for elements whose events are not meant\n        // to be handled by map interactions.\n        this.overlayContainerStopEvent_.contains(target) ||\n        // Abort if the event target is a child of the container that is no longer in the page.\n        // It's possible for the target to no longer be in the page if it has been removed in an\n        // event listener, this might happen in a Control that recreates it's content based on\n        // user interaction either manually or via a render in something like https://reactjs.org/\n        !(rootNode === doc ? doc.documentElement : rootNode).contains(target)\n      ) {\n        return;\n      }\n    }\n    mapBrowserEvent.frameState = this.frameState_;\n    if (this.dispatchEvent(mapBrowserEvent) !== false) {\n      const interactionsArray = this.getInteractions().getArray().slice();\n      for (let i = interactionsArray.length - 1; i >= 0; i--) {\n        const interaction = interactionsArray[i];\n        if (\n          interaction.getMap() !== this ||\n          !interaction.getActive() ||\n          !this.getTargetElement()\n        ) {\n          continue;\n        }\n        const cont = interaction.handleEvent(mapBrowserEvent);\n        if (!cont || mapBrowserEvent.propagationStopped) {\n          break;\n        }\n      }\n    }\n  }\n\n  /**\n   * @protected\n   */\n  handlePostRender() {\n    const frameState = this.frameState_;\n\n    // Manage the tile queue\n    // Image loads are expensive and a limited resource, so try to use them\n    // efficiently:\n    // * When the view is static we allow a large number of parallel tile loads\n    //   to complete the frame as quickly as possible.\n    // * When animating or interacting, image loads can cause janks, so we reduce\n    //   the maximum number of loads per frame and limit the number of parallel\n    //   tile loads to remain reactive to view changes and to reduce the chance of\n    //   loading tiles that will quickly disappear from view.\n    const tileQueue = this.tileQueue_;\n    if (!tileQueue.isEmpty()) {\n      let maxTotalLoading = this.maxTilesLoading_;\n      let maxNewLoads = maxTotalLoading;\n      if (frameState) {\n        const hints = frameState.viewHints;\n        if (hints[ViewHint.ANIMATING] || hints[ViewHint.INTERACTING]) {\n          const lowOnFrameBudget = Date.now() - frameState.time > 8;\n          maxTotalLoading = lowOnFrameBudget ? 0 : 8;\n          maxNewLoads = lowOnFrameBudget ? 0 : 2;\n        }\n      }\n      if (tileQueue.getTilesLoading() < maxTotalLoading) {\n        tileQueue.reprioritize(); // FIXME only call if view has changed\n        tileQueue.loadMoreTiles(maxTotalLoading, maxNewLoads);\n      }\n    }\n\n    if (frameState && this.renderer_ && !frameState.animate) {\n      if (this.renderComplete_ === true) {\n        if (this.hasListener(RenderEventType.RENDERCOMPLETE)) {\n          this.renderer_.dispatchRenderEvent(\n            RenderEventType.RENDERCOMPLETE,\n            frameState\n          );\n        }\n        if (this.loaded_ === false) {\n          this.loaded_ = true;\n          this.dispatchEvent(\n            new MapEvent(MapEventType.LOADEND, this, frameState)\n          );\n        }\n      } else if (this.loaded_ === true) {\n        this.loaded_ = false;\n        this.dispatchEvent(\n          new MapEvent(MapEventType.LOADSTART, this, frameState)\n        );\n      }\n    }\n\n    const postRenderFunctions = this.postRenderFunctions_;\n    for (let i = 0, ii = postRenderFunctions.length; i < ii; ++i) {\n      postRenderFunctions[i](this, frameState);\n    }\n    postRenderFunctions.length = 0;\n  }\n\n  /**\n   * @private\n   */\n  handleSizeChanged_() {\n    if (this.getView() && !this.getView().getAnimating()) {\n      this.getView().resolveConstraints(0);\n    }\n\n    this.render();\n  }\n\n  /**\n   * @private\n   */\n  handleTargetChanged_() {\n    if (this.mapBrowserEventHandler_) {\n      for (let i = 0, ii = this.targetChangeHandlerKeys_.length; i < ii; ++i) {\n        unlistenByKey(this.targetChangeHandlerKeys_[i]);\n      }\n      this.targetChangeHandlerKeys_ = null;\n      this.viewport_.removeEventListener(\n        EventType.CONTEXTMENU,\n        this.boundHandleBrowserEvent_\n      );\n      this.viewport_.removeEventListener(\n        EventType.WHEEL,\n        this.boundHandleBrowserEvent_\n      );\n      this.mapBrowserEventHandler_.dispose();\n      this.mapBrowserEventHandler_ = null;\n      removeNode(this.viewport_);\n    }\n\n    if (this.targetElement_) {\n      this.resizeObserver_.unobserve(this.targetElement_);\n      const rootNode = this.targetElement_.getRootNode();\n      if (rootNode instanceof ShadowRoot) {\n        this.resizeObserver_.unobserve(rootNode.host);\n      }\n      this.setSize(undefined);\n    }\n\n    // target may be undefined, null, a string or an Element.\n    // If it's a string we convert it to an Element before proceeding.\n    // If it's not now an Element we remove the viewport from the DOM.\n    // If it's an Element we append the viewport element to it.\n\n    const target = this.getTarget();\n    const targetElement =\n      typeof target === 'string' ? document.getElementById(target) : target;\n    this.targetElement_ = targetElement;\n    if (!targetElement) {\n      if (this.renderer_) {\n        clearTimeout(this.postRenderTimeoutHandle_);\n        this.postRenderTimeoutHandle_ = undefined;\n        this.postRenderFunctions_.length = 0;\n        this.renderer_.dispose();\n        this.renderer_ = null;\n      }\n      if (this.animationDelayKey_) {\n        cancelAnimationFrame(this.animationDelayKey_);\n        this.animationDelayKey_ = undefined;\n      }\n    } else {\n      targetElement.appendChild(this.viewport_);\n      if (!this.renderer_) {\n        this.renderer_ = new CompositeMapRenderer(this);\n      }\n\n      this.mapBrowserEventHandler_ = new MapBrowserEventHandler(\n        this,\n        this.moveTolerance_\n      );\n      for (const key in MapBrowserEventType) {\n        this.mapBrowserEventHandler_.addEventListener(\n          MapBrowserEventType[key],\n          this.handleMapBrowserEvent.bind(this)\n        );\n      }\n      this.viewport_.addEventListener(\n        EventType.CONTEXTMENU,\n        this.boundHandleBrowserEvent_,\n        false\n      );\n      this.viewport_.addEventListener(\n        EventType.WHEEL,\n        this.boundHandleBrowserEvent_,\n        PASSIVE_EVENT_LISTENERS ? {passive: false} : false\n      );\n\n      const keyboardEventTarget = !this.keyboardEventTarget_\n        ? targetElement\n        : this.keyboardEventTarget_;\n      this.targetChangeHandlerKeys_ = [\n        listen(\n          keyboardEventTarget,\n          EventType.KEYDOWN,\n          this.handleBrowserEvent,\n          this\n        ),\n        listen(\n          keyboardEventTarget,\n          EventType.KEYPRESS,\n          this.handleBrowserEvent,\n          this\n        ),\n      ];\n      const rootNode = targetElement.getRootNode();\n      if (rootNode instanceof ShadowRoot) {\n        this.resizeObserver_.observe(rootNode.host);\n      }\n      this.resizeObserver_.observe(targetElement);\n    }\n\n    this.updateSize();\n    // updateSize calls setSize, so no need to call this.render\n    // ourselves here.\n  }\n\n  /**\n   * @private\n   */\n  handleTileChange_() {\n    this.render();\n  }\n\n  /**\n   * @private\n   */\n  handleViewPropertyChanged_() {\n    this.render();\n  }\n\n  /**\n   * @private\n   */\n  handleViewChanged_() {\n    if (this.viewPropertyListenerKey_) {\n      unlistenByKey(this.viewPropertyListenerKey_);\n      this.viewPropertyListenerKey_ = null;\n    }\n    if (this.viewChangeListenerKey_) {\n      unlistenByKey(this.viewChangeListenerKey_);\n      this.viewChangeListenerKey_ = null;\n    }\n    const view = this.getView();\n    if (view) {\n      this.updateViewportSize_(this.getSize());\n\n      this.viewPropertyListenerKey_ = listen(\n        view,\n        ObjectEventType.PROPERTYCHANGE,\n        this.handleViewPropertyChanged_,\n        this\n      );\n      this.viewChangeListenerKey_ = listen(\n        view,\n        EventType.CHANGE,\n        this.handleViewPropertyChanged_,\n        this\n      );\n\n      view.resolveConstraints(0);\n    }\n    this.render();\n  }\n\n  /**\n   * @private\n   */\n  handleLayerGroupChanged_() {\n    if (this.layerGroupPropertyListenerKeys_) {\n      this.layerGroupPropertyListenerKeys_.forEach(unlistenByKey);\n      this.layerGroupPropertyListenerKeys_ = null;\n    }\n    const layerGroup = this.getLayerGroup();\n    if (layerGroup) {\n      this.handleLayerAdd_(new GroupEvent('addlayer', layerGroup));\n      this.layerGroupPropertyListenerKeys_ = [\n        listen(layerGroup, ObjectEventType.PROPERTYCHANGE, this.render, this),\n        listen(layerGroup, EventType.CHANGE, this.render, this),\n        listen(layerGroup, 'addlayer', this.handleLayerAdd_, this),\n        listen(layerGroup, 'removelayer', this.handleLayerRemove_, this),\n      ];\n    }\n    this.render();\n  }\n\n  /**\n   * @return {boolean} Is rendered.\n   */\n  isRendered() {\n    return !!this.frameState_;\n  }\n\n  /**\n   * @private\n   */\n  animationDelay_() {\n    this.animationDelayKey_ = undefined;\n    this.renderFrame_(Date.now());\n  }\n\n  /**\n   * Requests an immediate render in a synchronous manner.\n   * @api\n   */\n  renderSync() {\n    if (this.animationDelayKey_) {\n      cancelAnimationFrame(this.animationDelayKey_);\n    }\n    this.animationDelay_();\n  }\n\n  /**\n   * Redraws all text after new fonts have loaded\n   */\n  redrawText() {\n    const layerStates = this.getLayerGroup().getLayerStatesArray();\n    for (let i = 0, ii = layerStates.length; i < ii; ++i) {\n      const layer = layerStates[i].layer;\n      if (layer.hasRenderer()) {\n        layer.getRenderer().handleFontsChanged();\n      }\n    }\n  }\n\n  /**\n   * Request a map rendering (at the next animation frame).\n   * @api\n   */\n  render() {\n    if (this.renderer_ && this.animationDelayKey_ === undefined) {\n      this.animationDelayKey_ = requestAnimationFrame(this.animationDelay_);\n    }\n  }\n\n  /**\n   * This method is meant to be called in a layer's `prerender` listener. It causes all collected\n   * declutter items to be decluttered and rendered on the map immediately. This is useful for\n   * layers that need to appear entirely above the decluttered items of layers lower in the layer\n   * stack.\n   * @api\n   */\n  flushDeclutterItems() {\n    const frameState = this.frameState_;\n    if (!frameState) {\n      return;\n    }\n    this.renderer_.flushDeclutterItems(frameState);\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        declutterTree: 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        : undefined;\n\n    if (!this.postRenderTimeoutHandle_) {\n      this.postRenderTimeoutHandle_ = setTimeout(() => {\n        this.postRenderTimeoutHandle_ = undefined;\n        this.handlePostRender();\n      }, 0);\n    }\n  }\n\n  /**\n   * Sets the layergroup of this map.\n   * @param {LayerGroup} layerGroup A layer group containing the layers in this map.\n   * @observable\n   * @api\n   */\n  setLayerGroup(layerGroup) {\n    const oldLayerGroup = this.getLayerGroup();\n    if (oldLayerGroup) {\n      this.handleLayerRemove_(new GroupEvent('removelayer', oldLayerGroup));\n    }\n    this.set(MapProperty.LAYERGROUP, layerGroup);\n  }\n\n  /**\n   * Set the size of this map.\n   * @param {import(\"./size.js\").Size|undefined} size The size in pixels of the map in the DOM.\n   * @observable\n   * @api\n   */\n  setSize(size) {\n    this.set(MapProperty.SIZE, size);\n  }\n\n  /**\n   * Set the target element to render this map into.\n   * @param {HTMLElement|string} [target] The Element or id of the Element\n   *     that the map is rendered in.\n   * @observable\n   * @api\n   */\n  setTarget(target) {\n    this.set(MapProperty.TARGET, target);\n  }\n\n  /**\n   * Set the view for this map.\n   * @param {View|Promise<import(\"./View.js\").ViewOptions>} view The view that controls this map.\n   * It is also possible to pass a promise that resolves to options for constructing a view.  This\n   * alternative allows view properties to be resolved by sources or other components that load\n   * view-related metadata.\n   * @observable\n   * @api\n   */\n  setView(view) {\n    if (!view || view instanceof View) {\n      this.set(MapProperty.VIEW, view);\n      return;\n    }\n    this.set(MapProperty.VIEW, new View());\n\n    const map = this;\n    view.then(function (viewOptions) {\n      map.setView(new View(viewOptions));\n    });\n  }\n\n  /**\n   * Force a recalculation of the map viewport size.  This should be called when\n   * third-party code changes the size of the map viewport.\n   * @api\n   */\n  updateSize() {\n    const targetElement = this.getTargetElement();\n\n    let size = undefined;\n    if (targetElement) {\n      const computedStyle = getComputedStyle(targetElement);\n      const width =\n        targetElement.offsetWidth -\n        parseFloat(computedStyle['borderLeftWidth']) -\n        parseFloat(computedStyle['paddingLeft']) -\n        parseFloat(computedStyle['paddingRight']) -\n        parseFloat(computedStyle['borderRightWidth']);\n      const height =\n        targetElement.offsetHeight -\n        parseFloat(computedStyle['borderTopWidth']) -\n        parseFloat(computedStyle['paddingTop']) -\n        parseFloat(computedStyle['paddingBottom']) -\n        parseFloat(computedStyle['borderBottomWidth']);\n      if (!isNaN(width) && !isNaN(height)) {\n        size = [width, height];\n        if (\n          !hasArea(size) &&\n          !!(\n            targetElement.offsetWidth ||\n            targetElement.offsetHeight ||\n            targetElement.getClientRects().length\n          )\n        ) {\n          warn(\n            \"No map visible because the map container's width or height are 0.\"\n          );\n        }\n      }\n    }\n\n    const oldSize = this.getSize();\n    if (size && (!oldSize || !equals(size, oldSize))) {\n      this.setSize(size);\n      this.updateViewportSize_(size);\n    }\n  }\n\n  /**\n   * Recomputes the viewport size and save it on the view object (if any)\n   * @param {import(\"./size.js\").Size|undefined} size The size.\n   * @private\n   */\n  updateViewportSize_(size) {\n    const view = this.getView();\n    if (view) {\n      view.setViewportSize(size);\n    }\n  }\n}\n\n/**\n * @param {MapOptions} options Map options.\n * @return {MapOptionsInternal} Internal map options.\n */\nfunction createOptionsInternal(options) {\n  /**\n   * @type {HTMLElement|Document}\n   */\n  let keyboardEventTarget = null;\n  if (options.keyboardEventTarget !== undefined) {\n    keyboardEventTarget =\n      typeof options.keyboardEventTarget === 'string'\n        ? document.getElementById(options.keyboardEventTarget)\n        : options.keyboardEventTarget;\n  }\n\n  /**\n   * @type {Object<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\").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 BaseObject from './Object.js';\nimport MapEventType from './MapEventType.js';\nimport {CLASS_SELECTABLE} from './css.js';\nimport {containsExtent} from './extent.js';\nimport {listen, unlistenByKey} from './events.js';\nimport {outerHeight, outerWidth, removeChildren, removeNode} from './dom.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\").Types|'change:element'|'change:map'|'change:offset'|'change:position'|\n *   'change:positioning'} OverlayObjectEventTypes\n */\n\n/***\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature<import(\"./Observable\").EventTypes, import(\"./events/Event.js\").default, Return> &\n *   import(\"./Observable\").OnSignature<OverlayObjectEventTypes, import(\"./Object\").ObjectEvent, Return> &\n *   import(\"./Observable\").CombinedOnSignature<import(\"./Observable\").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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {OverlayOnSignature<import(\"./events\").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      removeNode(this.element);\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 = Math.round(pixel[0] + offset[0]) + 'px';\n    const y = Math.round(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/structs/LRUCache\n */\n\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  /**\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.\n   * @param {!Object<string, boolean>} [keep] Keys to keep. To be implemented by subclasses.\n   */\n  expireCache(keep) {\n    while (this.canExpireCache()) {\n      this.pop();\n    }\n  }\n\n  /**\n   * FIXME empty description for jsdoc\n   */\n  clear() {\n    this.count_ = 0;\n    this.entries_ = {};\n    this.oldest_ = null;\n    this.newest_ = null;\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\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 * 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 (tileCoord[1] << tileCoord[0]) + tileCoord[2];\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/TileCache\n */\nimport LRUCache from './structs/LRUCache.js';\nimport {fromKey, getKey} from './tilecoord.js';\n\nclass TileCache extends LRUCache {\n  clear() {\n    while (this.getCount() > 0) {\n      this.pop().release();\n    }\n    super.clear();\n  }\n\n  /**\n   * @param {!Object<string, boolean>} usedTiles Used tiles.\n   */\n  expireCache(usedTiles) {\n    while (this.canExpireCache()) {\n      const tile = this.peekLast();\n      if (tile.getKey() in usedTiles) {\n        break;\n      } else {\n        this.pop().release();\n      }\n    }\n  }\n\n  /**\n   * Prune all tiles from the cache that don't have the same z as the newest tile.\n   */\n  pruneExceptNewestZ() {\n    if (this.getCount() === 0) {\n      return;\n    }\n    const key = this.peekFirstKey();\n    const tileCoord = fromKey(key);\n    const z = tileCoord[0];\n    this.forEach((tile) => {\n      if (tile.tileCoord[0] !== z) {\n        this.remove(getKey(tile.tileCoord));\n        tile.release();\n      }\n    });\n  }\n}\n\nexport default TileCache;\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} renderedRevision RenderedRevision.\n * @property {number} renderedTileResolution RenderedTileResolution.\n * @property {number} renderedTileZ RenderedTileZ.\n */\n\n/**\n * @type {Array<HTMLCanvasElement>}\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\").default>} getSourceTiles Function\n   * to get source tiles for this tile.\n   */\n  constructor(tileCoord, state, urlTileCoord, getSourceTiles) {\n    super(tileCoord, state, {transition: 0});\n\n    /**\n     * @private\n     * @type {!Object<string, CanvasRenderingContext2D>}\n     */\n    this.context_ = {};\n\n    /**\n     * Executor groups by layer uid. Entries are read/written by the renderer.\n     * @type {Object<string, Array<import(\"./render/canvas/ExecutorGroup.js\").default>>}\n     */\n    this.executorGroups = {};\n\n    /**\n     * Executor groups for decluttering, by layer uid. Entries are read/written by the renderer.\n     * @type {Object<string, Array<import(\"./render/canvas/ExecutorGroup.js\").default>>}\n     */\n    this.declutterExecutorGroups = {};\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<number, 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 {import(\"./tilecoord.js\").TileCoord}\n     */\n    this.wrappedTileCoord = urlTileCoord;\n  }\n\n  /**\n   * @param {import(\"./layer/Layer.js\").default} layer Layer.\n   * @return {CanvasRenderingContext2D} The rendering context.\n   */\n  getContext(layer) {\n    const key = getUid(layer);\n    if (!(key in this.context_)) {\n      this.context_[key] = createCanvasContext2D(1, 1, canvasPool);\n    }\n    return this.context_[key];\n  }\n\n  /**\n   * @param {import(\"./layer/Layer.js\").default} layer Layer.\n   * @return {boolean} Tile has a rendering context for the given layer.\n   */\n  hasContext(layer) {\n    return getUid(layer) in this.context_;\n  }\n\n  /**\n   * Get the Canvas for this tile.\n   * @param {import(\"./layer/Layer.js\").default} layer Layer.\n   * @return {HTMLCanvasElement} Canvas.\n   */\n  getImage(layer) {\n    return this.hasContext(layer) ? this.getContext(layer).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        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   */\n  load() {\n    this.getSourceTiles();\n  }\n\n  /**\n   * Remove from the cache due to expiry\n   */\n  release() {\n    for (const key in this.context_) {\n      const context = this.context_[key];\n      releaseCanvas(context);\n      canvasPool.push(context.canvas);\n      delete this.context_[key];\n    }\n    super.release();\n  }\n}\n\nexport default VectorRenderTile;\n","/**\n * @module ol/VectorTile\n */\nimport Tile from './Tile.js';\nimport TileState from './TileState.js';\n\nclass VectorTile extends Tile {\n  /**\n   * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n   * @param {import(\"./TileState.js\").default} state State.\n   * @param {string} src Data source url.\n   * @param {import(\"./format/Feature.js\").default} format Feature format.\n   * @param {import(\"./Tile.js\").LoadFunction} tileLoadFunction Tile load function.\n   * @param {import(\"./Tile.js\").Options} [options] Tile options.\n   */\n  constructor(tileCoord, state, src, format, tileLoadFunction, options) {\n    super(tileCoord, state, options);\n\n    /**\n     * Extent of this tile; set by the source.\n     * @type {import(\"./extent.js\").Extent}\n     */\n    this.extent = null;\n\n    /**\n     * @private\n     * @type {import(\"./format/Feature.js\").default}\n     */\n    this.format_ = format;\n\n    /**\n     * @private\n     * @type {Array<import(\"./Feature.js\").FeatureLike>}\n     */\n    this.features_ = null;\n\n    /**\n     * @private\n     * @type {import(\"./featureloader.js\").FeatureLoader}\n     */\n    this.loader_;\n\n    /**\n     * Feature projection of this tile; set by the source.\n     * @type {import(\"./proj/Projection.js\").default}\n     */\n    this.projection = null;\n\n    /**\n     * Resolution of this tile; set by the source.\n     * @type {number}\n     */\n    this.resolution;\n\n    /**\n     * @private\n     * @type {import(\"./Tile.js\").LoadFunction}\n     */\n    this.tileLoadFunction_ = tileLoadFunction;\n\n    /**\n     * @private\n     * @type {string}\n     */\n    this.url_ = src;\n\n    this.key = src;\n  }\n\n  /**\n   * Get the feature format assigned for reading this tile's features.\n   * @return {import(\"./format/Feature.js\").default} Feature format.\n   * @api\n   */\n  getFormat() {\n    return this.format_;\n  }\n\n  /**\n   * Get the features for this tile. Geometries will be in the view projection.\n   * @return {Array<import(\"./Feature.js\").FeatureLike>} Features.\n   * @api\n   */\n  getFeatures() {\n    return this.features_;\n  }\n\n  /**\n   * Load not yet loaded URI.\n   */\n  load() {\n    if (this.state == TileState.IDLE) {\n      this.setState(TileState.LOADING);\n      this.tileLoadFunction_(this, this.url_);\n      if (this.loader_) {\n        this.loader_(this.extent, this.resolution, this.projection);\n      }\n    }\n  }\n\n  /**\n   * Handler for successful tile load.\n   * @param {Array<import(\"./Feature.js\").default>} features The loaded features.\n   * @param {import(\"./proj/Projection.js\").default} dataProjection Data projection.\n   */\n  onLoad(features, dataProjection) {\n    this.setFeatures(features);\n  }\n\n  /**\n   * Handler for tile load errors.\n   */\n  onError() {\n    this.setState(TileState.ERROR);\n  }\n\n  /**\n   * Function for use in an {@link module:ol/source/VectorTile~VectorTile}'s `tileLoadFunction`.\n   * Sets the features for the tile.\n   * @param {Array<import(\"./Feature.js\").FeatureLike>} features Features.\n   * @api\n   */\n  setFeatures(features) {\n    this.features_ = features;\n    this.setState(TileState.LOADED);\n  }\n\n  /**\n   * Set the feature loader for reading this tile's features.\n   * @param {import(\"./featureloader.js\").FeatureLoader} loader Feature loader.\n   * @api\n   */\n  setLoader(loader) {\n    this.loader_ = loader;\n  }\n}\n\nexport default VectorTile;\n","/**\n * @module ol/colorlike\n */\nimport {toString} from './color.js';\n\n/**\n * A type accepted by CanvasRenderingContext2D.fillStyle\n * or CanvasRenderingContext2D.strokeStyle.\n * Represents a color, pattern, or gradient. The origin for patterns and\n * 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} color Color.\n * @return {ColorLike} The color as an {@link ol/colorlike~ColorLike}.\n * @api\n */\nexport function asColorLike(color) {\n  if (Array.isArray(color)) {\n    return toString(color);\n  }\n  return color;\n}\n","/**\n * @module ol/featureloader\n */\nimport {VOID} from './functions.js';\n\n/**\n *\n * @type {boolean}\n * @private\n */\nlet withCredentials = false;\n\n/**\n * {@link module:ol/source/Vector~VectorSource} sources use a function of this type to\n * load features.\n *\n * This function takes up to 5 arguments. These are an {@link module:ol/extent~Extent} representing\n * the area to be loaded, a `{number}` representing the resolution (map units per pixel), an\n * {@link module:ol/proj/Projection~Projection} for the projection, an optional success callback that should get\n * the loaded features passed as an argument and an optional failure callback with no arguments. If\n * the callbacks are not used, the corresponding vector source will not fire `'featuresloadend'` and\n * `'featuresloaderror'` events. `this` within the function is bound to the\n * {@link module:ol/source/Vector~VectorSource} it's called from.\n *\n * The function is responsible for loading the features and adding them to the\n * source.\n * @typedef {function(this:(import(\"./source/Vector\").default|import(\"./VectorTile.js\").default),\n *           import(\"./extent.js\").Extent,\n *           number,\n *           import(\"./proj/Projection.js\").default,\n *           function(Array<import(\"./Feature.js\").default>): void=,\n *           function(): void=): void} FeatureLoader\n * @api\n */\n\n/**\n * {@link module:ol/source/Vector~VectorSource} sources use a function of this type to\n * get the url to load features from.\n *\n * This function takes an {@link module:ol/extent~Extent} representing the area\n * to be loaded, a `{number}` representing the resolution (map units per pixel)\n * and an {@link module:ol/proj/Projection~Projection} for the projection  as\n * arguments and returns a `{string}` representing the URL.\n * @typedef {function(import(\"./extent.js\").Extent, number, import(\"./proj/Projection.js\").default): string} FeatureUrlFunction\n * @api\n */\n\n/**\n * @param {string|FeatureUrlFunction} url Feature URL service.\n * @param {import(\"./format/Feature.js\").default} format Feature format.\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number} resolution Resolution.\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @param {function(Array<import(\"./Feature.js\").default>, 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      /** @type {Document|Node|Object|string|undefined} */\n      let source;\n      if (type == 'json') {\n        source = JSON.parse(xhr.responseText);\n      } else if (type == 'text') {\n        source = xhr.responseText;\n      } else if (type == 'xml') {\n        source = xhr.responseXML;\n        if (!source) {\n          source = new DOMParser().parseFromString(\n            xhr.responseText,\n            'application/xml'\n          );\n        }\n      } else if (type == 'arraybuffer') {\n        source = /** @type {ArrayBuffer} */ (xhr.response);\n      }\n      if (source) {\n        success(\n          /** @type {Array<import(\"./Feature.js\").default>} */\n          (\n            format.readFeatures(source, {\n              extent: extent,\n              featureProjection: projection,\n            })\n          ),\n          format.readProjection(source)\n        );\n      } else {\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 * @param {string|FeatureUrlFunction} url Feature URL service.\n * @param {import(\"./format/Feature.js\").default} format Feature format.\n * @return {FeatureLoader} The feature loader.\n * @api\n */\nexport function xhr(url, format) {\n  /**\n   * @param {import(\"./extent.js\").Extent} extent Extent.\n   * @param {number} resolution Resolution.\n   * @param {import(\"./proj/Projection.js\").default} projection Projection.\n   * @param {function(Array<import(\"./Feature.js\").default>): void} [success] Success\n   *      Function called when loading succeeded.\n   * @param {function(): void} [failure] Failure\n   *      Function called when loading failed.\n   */\n  return function (extent, resolution, projection, success, failure) {\n    const source = /** @type {import(\"./source/Vector\").default} */ (this);\n    loadFeaturesXhr(\n      url,\n      format,\n      extent,\n      resolution,\n      projection,\n      /**\n       * @param {Array<import(\"./Feature.js\").default>} features The loaded features.\n       * @param {import(\"./proj/Projection.js\").default} dataProjection Data\n       * projection.\n       */\n      function (features, dataProjection) {\n        source.addFeatures(features);\n        if (success !== undefined) {\n          success(features);\n        }\n      },\n      /* FIXME handle error */ failure ? failure : VOID\n    );\n  };\n}\n\n/**\n * Setter for the withCredentials configuration for the XHR.\n *\n * @param {boolean} xhrWithCredentials The value of withCredentials to set.\n * Compare https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/\n * @api\n */\nexport function setWithCredentials(xhrWithCredentials) {\n  withCredentials = xhrWithCredentials;\n}\n","/**\n * @module ol/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  global.XMLHttpRequest = xhr;\n}\n\nexport function restoreXHR() {\n  global.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","/**\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   */\n  drawCustom(geometry, feature, renderer, hitDetectionRenderer) {}\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   */\n  drawCircle(circleGeometry, feature) {}\n\n  /**\n   * @param {import(\"../Feature.js\").default} feature Feature.\n   * @param {import(\"../style/Style.js\").default} style Style.\n   */\n  drawFeature(feature, style) {}\n\n  /**\n   * @param {import(\"../geom/GeometryCollection.js\").default} geometryCollectionGeometry Geometry collection.\n   * @param {import(\"../Feature.js\").default} feature Feature.\n   */\n  drawGeometryCollection(geometryCollectionGeometry, feature) {}\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   */\n  drawLineString(lineStringGeometry, feature) {}\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   */\n  drawMultiLineString(multiLineStringGeometry, feature) {}\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   */\n  drawMultiPoint(multiPointGeometry, feature) {}\n\n  /**\n   * @param {import(\"../geom/MultiPolygon.js\").default} multiPolygonGeometry MultiPolygon geometry.\n   * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n   */\n  drawMultiPolygon(multiPolygonGeometry, feature) {}\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   */\n  drawPoint(pointGeometry, feature) {}\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   */\n  drawPolygon(polygonGeometry, feature) {}\n\n  /**\n   * @param {import(\"../geom/SimpleGeometry.js\").default|import(\"./Feature.js\").default} geometry Geometry.\n   * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n   */\n  drawText(geometry, feature) {}\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 VectorContext from '../VectorContext.js';\nimport {asColorLike} from '../../colorlike.js';\nimport {\n  compose as composeTransform,\n  create as createTransform,\n} from '../../transform.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';\nimport {equals} from '../../array.js';\nimport {intersects} from '../../extent.js';\nimport {toFixed} from '../../math.js';\nimport {transform2D} from '../../geom/flat/transform.js';\nimport {transformGeom2D} from '../../geom/SimpleGeometry.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} 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}\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   * @private\n   * @return {number} end End.\n   */\n  moveToLineTo_(flatCoordinates, offset, end, stride, close) {\n    const context = this.context_;\n    const pixelCoordinates = transform2D(\n      flatCoordinates,\n      offset,\n      end,\n      stride,\n      this.transform_,\n      this.pixelCoordinates_\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   * @private\n   * @return {number} End.\n   */\n  drawRings_(flatCoordinates, offset, ends, stride) {\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      );\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   */\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   */\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   */\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} */ (geometry)\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   */\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   */\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   */\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   */\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   */\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      );\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   */\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        );\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   */\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      );\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   */\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_(flatCoordinates, offset, ends, stride);\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   */\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      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      };\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   */\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   */\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\").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 {import(\"../render/canvas/BuilderGroup.js\").default} [declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderCircleGeometry(\n  builderGroup,\n  geometry,\n  style,\n  feature,\n  declutterBuilderGroup\n) {\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);\n  }\n  const textStyle = style.getText();\n  if (textStyle && textStyle.getText()) {\n    const textReplay = (declutterBuilderGroup || builderGroup).getBuilder(\n      style.getZIndex(),\n      'Text'\n    );\n    textReplay.setTextStyle(textStyle);\n    textReplay.drawText(geometry, feature);\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 {import(\"../render/canvas/BuilderGroup.js\").default} [declutterBuilderGroup] Builder for decluttering.\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  declutterBuilderGroup\n) {\n  let loading = false;\n  const imageStyle = style.getImage();\n  if (imageStyle) {\n    const imageState = imageStyle.getImageState();\n    if (imageState == ImageState.LOADED || imageState == ImageState.ERROR) {\n      imageStyle.unlistenImageChange(listener);\n    } else {\n      if (imageState == ImageState.IDLE) {\n        imageStyle.load();\n      }\n      imageStyle.listenImageChange(listener);\n      loading = true;\n    }\n  }\n  renderFeatureInternal(\n    replayGroup,\n    feature,\n    style,\n    squaredTolerance,\n    transform,\n    declutterBuilderGroup\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 {import(\"../render/canvas/BuilderGroup.js\").default} [declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderFeatureInternal(\n  replayGroup,\n  feature,\n  style,\n  squaredTolerance,\n  transform,\n  declutterBuilderGroup\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);\n  } else {\n    const geometryRenderer = GEOMETRY_RENDERERS[simplifiedGeometry.getType()];\n    geometryRenderer(\n      replayGroup,\n      simplifiedGeometry,\n      style,\n      feature,\n      declutterBuilderGroup\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 */\nfunction renderGeometry(replayGroup, geometry, style, feature) {\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);\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  );\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 */\nfunction renderGeometryCollectionGeometry(\n  replayGroup,\n  geometry,\n  style,\n  feature,\n  declutterBuilderGroup\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    );\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 {import(\"../render/canvas/BuilderGroup.js\").default} [declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderLineStringGeometry(\n  builderGroup,\n  geometry,\n  style,\n  feature,\n  declutterBuilderGroup\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);\n  }\n  const textStyle = style.getText();\n  if (textStyle && textStyle.getText()) {\n    const textReplay = (declutterBuilderGroup || builderGroup).getBuilder(\n      style.getZIndex(),\n      'Text'\n    );\n    textReplay.setTextStyle(textStyle);\n    textReplay.drawText(geometry, feature);\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 {import(\"../render/canvas/BuilderGroup.js\").default} [declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderMultiLineStringGeometry(\n  builderGroup,\n  geometry,\n  style,\n  feature,\n  declutterBuilderGroup\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);\n  }\n  const textStyle = style.getText();\n  if (textStyle && textStyle.getText()) {\n    const textReplay = (declutterBuilderGroup || builderGroup).getBuilder(\n      style.getZIndex(),\n      'Text'\n    );\n    textReplay.setTextStyle(textStyle);\n    textReplay.drawText(geometry, feature);\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 {import(\"../render/canvas/BuilderGroup.js\").default} [declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderMultiPolygonGeometry(\n  builderGroup,\n  geometry,\n  style,\n  feature,\n  declutterBuilderGroup\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);\n  }\n  const textStyle = style.getText();\n  if (textStyle && textStyle.getText()) {\n    const textReplay = (declutterBuilderGroup || builderGroup).getBuilder(\n      style.getZIndex(),\n      'Text'\n    );\n    textReplay.setTextStyle(textStyle);\n    textReplay.drawText(geometry, feature);\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 {import(\"../render/canvas/BuilderGroup.js\").default} [declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderPointGeometry(\n  builderGroup,\n  geometry,\n  style,\n  feature,\n  declutterBuilderGroup\n) {\n  const imageStyle = style.getImage();\n  const textStyle = style.getText();\n  /** @type {import(\"../render/canvas.js\").DeclutterImageWithText} */\n  let declutterImageWithText;\n  if (imageStyle) {\n    if (imageStyle.getImageState() != ImageState.LOADED) {\n      return;\n    }\n    let imageBuilderGroup = builderGroup;\n    if (declutterBuilderGroup) {\n      const declutterMode = imageStyle.getDeclutterMode();\n      if (declutterMode !== 'none') {\n        imageBuilderGroup = declutterBuilderGroup;\n        if (declutterMode === 'obstacle') {\n          // draw in non-declutter group:\n          const imageReplay = builderGroup.getBuilder(\n            style.getZIndex(),\n            'Image'\n          );\n          imageReplay.setImageStyle(imageStyle, declutterImageWithText);\n          imageReplay.drawPoint(geometry, feature);\n        } else if (textStyle && textStyle.getText()) {\n          declutterImageWithText = {};\n        }\n      }\n    }\n    const imageReplay = imageBuilderGroup.getBuilder(\n      style.getZIndex(),\n      'Image'\n    );\n    imageReplay.setImageStyle(imageStyle, declutterImageWithText);\n    imageReplay.drawPoint(geometry, feature);\n  }\n  if (textStyle && textStyle.getText()) {\n    let textBuilderGroup = builderGroup;\n    if (declutterBuilderGroup) {\n      textBuilderGroup = declutterBuilderGroup;\n    }\n    const textReplay = textBuilderGroup.getBuilder(style.getZIndex(), 'Text');\n    textReplay.setTextStyle(textStyle, declutterImageWithText);\n    textReplay.drawText(geometry, feature);\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 {import(\"../render/canvas/BuilderGroup.js\").default} [declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderMultiPointGeometry(\n  builderGroup,\n  geometry,\n  style,\n  feature,\n  declutterBuilderGroup\n) {\n  const imageStyle = style.getImage();\n  const textStyle = style.getText();\n  /** @type {import(\"../render/canvas.js\").DeclutterImageWithText} */\n  let declutterImageWithText;\n  if (imageStyle) {\n    if (imageStyle.getImageState() != ImageState.LOADED) {\n      return;\n    }\n    let imageBuilderGroup = builderGroup;\n    if (declutterBuilderGroup) {\n      const declutterMode = imageStyle.getDeclutterMode();\n      if (declutterMode !== 'none') {\n        imageBuilderGroup = declutterBuilderGroup;\n        if (declutterMode === 'obstacle') {\n          // draw in non-declutter group:\n          const imageReplay = builderGroup.getBuilder(\n            style.getZIndex(),\n            'Image'\n          );\n          imageReplay.setImageStyle(imageStyle, declutterImageWithText);\n          imageReplay.drawMultiPoint(geometry, feature);\n        } else if (textStyle && textStyle.getText()) {\n          declutterImageWithText = {};\n        }\n      }\n    }\n    const imageReplay = imageBuilderGroup.getBuilder(\n      style.getZIndex(),\n      'Image'\n    );\n    imageReplay.setImageStyle(imageStyle, declutterImageWithText);\n    imageReplay.drawMultiPoint(geometry, feature);\n  }\n  if (textStyle && textStyle.getText()) {\n    let textBuilderGroup = builderGroup;\n    if (declutterBuilderGroup) {\n      textBuilderGroup = declutterBuilderGroup;\n    }\n    const textReplay = textBuilderGroup.getBuilder(style.getZIndex(), 'Text');\n    textReplay.setTextStyle(textStyle, declutterImageWithText);\n    textReplay.drawText(geometry, feature);\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 {import(\"../render/canvas/BuilderGroup.js\").default} [declutterBuilderGroup] Builder for decluttering.\n */\nfunction renderPolygonGeometry(\n  builderGroup,\n  geometry,\n  style,\n  feature,\n  declutterBuilderGroup\n) {\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);\n  }\n  const textStyle = style.getText();\n  if (textStyle && textStyle.getText()) {\n    const textReplay = (declutterBuilderGroup || builderGroup).getBuilder(\n      style.getZIndex(),\n      'Text'\n    );\n    textReplay.setTextStyle(textStyle);\n    textReplay.drawText(geometry, feature);\n  }\n}\n","/**\n * @module ol/render\n */\nimport CanvasImmediateRenderer from './render/canvas/Immediate.js';\nimport {DEVICE_PIXEL_RATIO} from './has.js';\nimport {\n  apply as applyTransform,\n  create as createTransform,\n  multiply as multiplyTransform,\n  scale as scaleTransform,\n} from './transform.js';\nimport {getSquaredTolerance} from './renderer/vector.js';\nimport {getTransformFromProjections, getUserProjection} from './proj.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  return new CanvasImmediateRenderer(context, pixelRatio, extent, transform, 0);\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 {\n  containsCoordinate,\n  createEmpty,\n  extend,\n  forEachCorner,\n  getCenter,\n  getHeight,\n  getTopLeft,\n  getWidth,\n} from './extent.js';\nimport {createCanvasContext2D, releaseCanvas} from './dom.js';\nimport {getPointResolution, transform} from './proj.js';\nimport {solveLinearSystem} from './math.js';\n\nlet brokenDiagonalRendering_;\n\n/**\n * @type {Array<HTMLCanvasElement>}\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} 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('./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 * @return {HTMLCanvasElement} 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) {\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  if (!drawSingle || sources.length !== 1 || gutter !== 0) {\n    const canvasWidthInUnits = getWidth(sourceDataExtent);\n    const canvasHeightInUnits = getHeight(sourceDataExtent);\n    stitchContext = createCanvasContext2D(\n      Math.round((pixelRatio * canvasWidthInUnits) / sourceResolution),\n      Math.round((pixelRatio * canvasHeightInUnits) / sourceResolution),\n      canvasPool\n    );\n\n    if (!interpolate) {\n      stitchContext.imageSmoothingEnabled = false;\n    }\n\n    const stitchScale = pixelRatio / sourceResolution;\n\n    sources.forEach(function (src, i, arr) {\n      const xPos = src.extent[0] - sourceDataExtent[0];\n      const yPos = -(src.extent[3] - sourceDataExtent[3]);\n      const srcWidth = getWidth(src.extent);\n      const srcHeight = getHeight(src.extent);\n\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        stitchContext.drawImage(\n          src.image,\n          gutter,\n          gutter,\n          src.image.width - 2 * gutter,\n          src.image.height - 2 * gutter,\n          xPos * stitchScale,\n          yPos * stitchScale,\n          srcWidth * stitchScale,\n          srcHeight * stitchScale\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(\n        sourceResolution / pixelRatio,\n        -sourceResolution / pixelRatio\n      );\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/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/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 {getTransform} from '../proj.js';\nimport {modulo} from '../math.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   */\n  constructor(\n    sourceProj,\n    targetProj,\n    targetExtent,\n    maxSourceExtent,\n    errorThreshold,\n    destinationResolution\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 = 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/Tile\n */\nimport {ERROR_THRESHOLD} from './common.js';\n\nimport EventType from '../events/EventType.js';\nimport Tile from '../Tile.js';\nimport TileState from '../TileState.js';\nimport Triangulation from './Triangulation.js';\nimport {\n  calculateSourceExtentResolution,\n  canvasPool,\n  render as renderReprojected,\n} from '../reproj.js';\nimport {clamp} from '../math.js';\nimport {getArea, getIntersection} from '../extent.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport {releaseCanvas} from '../dom.js';\n\n/**\n * @typedef {function(number, number, number, number) : (import(\"../ImageTile.js\").default)} FunctionType\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}\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<import(\"../ImageTile.js\").default>}\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 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      const sourceRange = sourceTileGrid.getTileRangeForExtentAndZ(\n        sourceExtent,\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 tile = getTileFunction(this.sourceZ_, srcX, srcY, pixelRatio);\n          if (tile) {\n            this.sourceTiles_.push(tile);\n          }\n        }\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} Canvas.\n   */\n  getImage() {\n    return this.canvas_;\n  }\n\n  /**\n   * @private\n   */\n  reproject_() {\n    const sources = [];\n    this.sourceTiles_.forEach((tile) => {\n      if (tile && tile.getState() == TileState.LOADED) {\n        sources.push({\n          extent: this.sourceTileGrid_.getTileCoordExtent(tile.tileCoord),\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   */\n  load() {\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(\n            tile,\n            EventType.CHANGE,\n            function (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\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   */\n  release() {\n    if (this.canvas_) {\n      releaseCanvas(this.canvas_.getContext('2d'));\n      canvasPool.push(this.canvas_);\n      this.canvas_ = null;\n    }\n    super.release();\n  }\n}\n\nexport default ReprojTile;\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/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_ =\n      options.attributionsCollapsible !== undefined\n        ? options.attributionsCollapsible\n        : 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 `true`.\n     * @type {boolean}\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\").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 (Array.isArray(attributionLike)) {\n    return function (frameState) {\n      return attributionLike;\n    };\n  }\n\n  if (typeof attributionLike === 'function') {\n    return attributionLike;\n  }\n\n  return function (frameState) {\n    return [attributionLike];\n  };\n}\n\nexport default Source;\n","/**\n * @module ol/tilegrid/TileGrid\n */\nimport TileRange, {\n  createOrUpdate as createOrUpdateTileRange,\n} from '../TileRange.js';\nimport {DEFAULT_TILE_SIZE} from './common.js';\nimport {assert} from '../asserts.js';\nimport {ceil, clamp, floor} from '../math.js';\nimport {createOrUpdate, getTopLeft} from '../extent.js';\nimport {createOrUpdate as createOrUpdateTileCoord} from '../tilecoord.js';\nimport {intersectsLinearRing} from '../geom/flat/intersectsextent.js';\nimport {isSorted, linearFindNearest} from '../array.js';\nimport {toSize} from '../size.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 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\n */\nimport TileGrid from './tilegrid/TileGrid.js';\nimport {DEFAULT_MAX_ZOOM, DEFAULT_TILE_SIZE} from './tilegrid/common.js';\nimport {METERS_PER_UNIT, get as getProjection} from './proj.js';\nimport {\n  containsCoordinate,\n  createOrUpdate,\n  getCorner,\n  getHeight,\n  getWidth,\n} from './extent.js';\nimport {toSize} from './size.js';\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/source/Tile\n */\nimport Event from '../events/Event.js';\nimport Source from './Source.js';\nimport TileCache from '../TileCache.js';\nimport TileState from '../TileState.js';\nimport {abstract} from '../util.js';\nimport {assert} from '../asserts.js';\nimport {equivalent} from '../proj.js';\nimport {getKeyZXY, withinExtentAndZ} from '../tilecoord.js';\nimport {\n  getForProjection as getTileGridForProjection,\n  wrapX,\n} from '../tilegrid.js';\nimport {scale as scaleSize, toSize} from '../size.js';\n\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types, import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").OnSignature<import(\"./TileEventType\").TileSourceEventTypes, TileSourceEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").Types|\n *     import(\"./TileEventType\").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] CacheSize.\n * @property {boolean} [opaque=false] Whether the layer is opaque.\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 * @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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {TileSourceOnSignature<import(\"../events\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {TileSourceOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.opaque_ = options.opaque !== undefined ? options.opaque : false;\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     */\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(\"../TileCache.js\").default}\n     */\n    this.tileCache = new TileCache(options.cacheSize || 0);\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 || '';\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   * @return {boolean} Can expire cache.\n   */\n  canExpireCache() {\n    return this.tileCache.canExpireCache();\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @param {!Object<string, boolean>} usedTiles Used tiles.\n   */\n  expireCache(projection, usedTiles) {\n    const tileCache = this.getTileCacheForProjection(projection);\n    if (tileCache) {\n      tileCache.expireCache(usedTiles);\n    }\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @param {number} z Zoom level.\n   * @param {import(\"../TileRange.js\").default} tileRange Tile range.\n   * @param {function(import(\"../Tile.js\").default):(boolean|void)} callback Called with each\n   *     loaded tile.  If the callback returns `false`, the tile will not be\n   *     considered loaded.\n   * @return {boolean} The tile range is fully covered with loaded tiles.\n   */\n  forEachLoadedTile(projection, z, tileRange, callback) {\n    const tileCache = this.getTileCacheForProjection(projection);\n    if (!tileCache) {\n      return false;\n    }\n\n    let covered = true;\n    let tile, tileCoordKey, loaded;\n    for (let x = tileRange.minX; x <= tileRange.maxX; ++x) {\n      for (let y = tileRange.minY; y <= tileRange.maxY; ++y) {\n        tileCoordKey = getKeyZXY(z, x, y);\n        loaded = false;\n        if (tileCache.containsKey(tileCoordKey)) {\n          tile = /** @type {!import(\"../Tile.js\").default} */ (\n            tileCache.get(tileCoordKey)\n          );\n          loaded = tile.getState() === TileState.LOADED;\n          if (loaded) {\n            loaded = callback(tile) !== false;\n          }\n        }\n        if (!loaded) {\n          covered = false;\n        }\n      }\n    }\n    return covered;\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 {boolean} Opaque.\n   */\n  getOpaque(projection) {\n    return this.opaque_;\n  }\n\n  /**\n   * @param {import(\"../proj/Projection\").default} [projection] Projection.\n   * @return {Array<number>|null} Resolutions.\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   * @return {!import(\"../Tile.js\").default} Tile.\n   */\n  getTile(z, x, y, pixelRatio, projection) {\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   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {import(\"../TileCache.js\").default} Tile cache.\n   * @protected\n   */\n  getTileCacheForProjection(projection) {\n    const sourceProjection = this.getProjection();\n    assert(\n      sourceProjection === null || equivalent(sourceProjection, projection),\n      'A VectorTile source can only be rendered if it has a projection compatible with the view projection.'\n    );\n    return this.tileCache;\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    projection = projection !== undefined ? projection : this.getProjection();\n    const tileGrid = this.getTileGridForProjection(projection);\n    if (this.getWrapX() && projection.isGlobal()) {\n      tileCoord = wrapX(tileGrid, tileCoord, projection);\n    }\n    return withinExtentAndZ(tileCoord, tileGrid) ? tileCoord : null;\n  }\n\n  /**\n   * Remove all cached tiles from the source. The next render cycle will fetch new tiles.\n   * @api\n   */\n  clear() {\n    this.tileCache.clear();\n  }\n\n  refresh() {\n    this.clear();\n    super.refresh();\n  }\n\n  /**\n   * Increases the cache size if needed\n   * @param {number} tileCount Minimum number of tiles needed.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   */\n  updateCacheSize(tileCount, projection) {\n    const tileCache = this.getTileCacheForProjection(projection);\n    if (tileCount > tileCache.highWaterMark) {\n      tileCache.highWaterMark = tileCount;\n    }\n  }\n\n  /**\n   * Marks a tile coord as being used, without triggering a load.\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 {import(\"../proj/Projection.js\").default} projection Projection.\n   */\n  useTile(z, x, y, projection) {}\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/tileurlfunction\n */\nimport {modulo} from './math.js';\nimport {hash as tileCoordHash} from './tilecoord.js';\n\n/**\n * @param {string} template Template.\n * @param {import(\"./tilegrid/TileGrid.js\").default} tileGrid Tile grid.\n * @return {import(\"./Tile.js\").UrlFunction} Tile URL function.\n */\nexport function createFromTemplate(template, tileGrid) {\n  const zRegEx = /\\{z\\}/g;\n  const xRegEx = /\\{x\\}/g;\n  const yRegEx = /\\{y\\}/g;\n  const dashYRegEx = /\\{-y\\}/g;\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      return template\n        .replace(zRegEx, tileCoord[0].toString())\n        .replace(xRegEx, tileCoord[1].toString())\n        .replace(yRegEx, tileCoord[2].toString())\n        .replace(dashYRegEx, function () {\n          const z = tileCoord[0];\n          const range = tileGrid.getFullTileRange(z);\n          if (!range) {\n            throw new Error(\n              'The {-y} placeholder requires a tile grid with extent'\n            );\n          }\n          const y = range.getHeight() - tileCoord[2] - 1;\n          return y.toString();\n        });\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/**\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/source/UrlTile\n */\nimport TileEventType from './TileEventType.js';\nimport TileSource, {TileSourceEvent} from './Tile.js';\nimport TileState from '../TileState.js';\nimport {createFromTemplates, expandUrl} from '../tileurlfunction.js';\nimport {getKeyZXY} from '../tilecoord.js';\nimport {getUid} from '../util.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] Cache size.\n * @property {boolean} [opaque=false] Whether the layer is opaque.\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] TileUrlFunction.\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 * @classdesc\n * Base class for sources providing tiles divided into a tile grid over http.\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      opaque: options.opaque,\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   * 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   * 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   * 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   * 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.tileCache.clear();\n    this.tileLoadFunction = tileLoadFunction;\n    this.changed();\n  }\n\n  /**\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    this.tileCache.pruneExceptNewestZ();\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   * 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  /**\n   * Marks a tile coord as being used, without triggering a load.\n   * @param {number} z Tile coordinate z.\n   * @param {number} x Tile coordinate x.\n   * @param {number} y Tile coordinate y.\n   */\n  useTile(z, x, y) {\n    const tileCoordKey = getKeyZXY(z, x, y);\n    if (this.tileCache.containsKey(tileCoordKey)) {\n      this.tileCache.get(tileCoordKey);\n    }\n  }\n}\n\nexport default UrlTile;\n","/**\n * @module ol/source/TileImage\n */\nimport EventType from '../events/EventType.js';\nimport ImageTile from '../ImageTile.js';\nimport ReprojTile from '../reproj/Tile.js';\nimport TileCache from '../TileCache.js';\nimport TileState from '../TileState.js';\nimport UrlTile from './UrlTile.js';\nimport {equivalent, get as getProjection} from '../proj.js';\nimport {getKey, getKeyZXY} from '../tilecoord.js';\nimport {getForProjection as getTileGridForProjection} from '../tilegrid.js';\nimport {getUid} from '../util.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] Initial tile cache size. Will auto-grow to hold at least the number of tiles in the viewport.\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} [opaque=false] Whether the layer is opaque.\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] Optional function to get tile URL given a tile coordinate and the projection.\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 * @classdesc\n * Base class for sources providing images divided into a tile grid.\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      opaque: options.opaque,\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 {typeof ImageTile}\n     */\n    this.tileClass =\n      options.tileClass !== undefined ? options.tileClass : ImageTile;\n\n    /**\n     * @protected\n     * @type {!Object<string, TileCache>}\n     */\n    this.tileCacheForProjection = {};\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   * @return {boolean} Can expire cache.\n   */\n  canExpireCache() {\n    if (this.tileCache.canExpireCache()) {\n      return true;\n    }\n    for (const key in this.tileCacheForProjection) {\n      if (this.tileCacheForProjection[key].canExpireCache()) {\n        return true;\n      }\n    }\n\n    return false;\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @param {!Object<string, boolean>} usedTiles Used tiles.\n   */\n  expireCache(projection, usedTiles) {\n    const usedTileCache = this.getTileCacheForProjection(projection);\n\n    this.tileCache.expireCache(\n      this.tileCache == usedTileCache ? usedTiles : {}\n    );\n    for (const id in this.tileCacheForProjection) {\n      const tileCache = this.tileCacheForProjection[id];\n      tileCache.expireCache(tileCache == usedTileCache ? usedTiles : {});\n    }\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {number} Gutter.\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   */\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 {boolean} Opaque.\n   */\n  getOpaque(projection) {\n    if (\n      this.getProjection() &&\n      projection &&\n      !equivalent(this.getProjection(), projection)\n    ) {\n      return false;\n    }\n    return super.getOpaque(projection);\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    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 {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {import(\"../TileCache.js\").default} Tile cache.\n   */\n  getTileCacheForProjection(projection) {\n    const thisProj = this.getProjection();\n    if (!thisProj || equivalent(thisProj, projection)) {\n      return this.tileCache;\n    }\n    const projKey = getUid(projection);\n    if (!(projKey in this.tileCacheForProjection)) {\n      this.tileCacheForProjection[projKey] = new TileCache(\n        this.tileCache.highWaterMark\n      );\n    }\n    return this.tileCacheForProjection[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      this.crossOrigin,\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   * @return {!(ImageTile|ReprojTile)} Tile.\n   */\n  getTile(z, x, y, pixelRatio, projection) {\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 cache = this.getTileCacheForProjection(projection);\n    const tileCoord = [z, x, y];\n    let tile;\n    const tileCoordKey = getKey(tileCoord);\n    if (cache.containsKey(tileCoordKey)) {\n      tile = cache.get(tileCoordKey);\n    }\n    const key = this.getKey();\n    if (tile && tile.key == key) {\n      return tile;\n    }\n    const sourceTileGrid = this.getTileGridForProjection(sourceProjection);\n    const targetTileGrid = this.getTileGridForProjection(projection);\n    const wrappedTileCoord = this.getTileCoordForTileUrlFunction(\n      tileCoord,\n      projection\n    );\n    const newTile = 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),\n      this.reprojectionErrorThreshold_,\n      this.renderReprojectionEdges_,\n      this.tileOptions\n    );\n    newTile.key = key;\n\n    if (tile) {\n      newTile.interimTile = tile;\n      newTile.refreshInterimChain();\n      cache.replace(tileCoordKey, newTile);\n    } else {\n      cache.set(tileCoordKey, newTile);\n    }\n    return newTile;\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 {!ImageTile} Tile.\n   * @protected\n   */\n  getTileInternal(z, x, y, pixelRatio, projection) {\n    let tile = null;\n    const tileCoordKey = getKeyZXY(z, x, y);\n    const key = this.getKey();\n    if (!this.tileCache.containsKey(tileCoordKey)) {\n      tile = this.createTile_(z, x, y, pixelRatio, projection, key);\n      this.tileCache.set(tileCoordKey, tile);\n    } else {\n      tile = this.tileCache.get(tileCoordKey);\n      if (tile.key != key) {\n        // The source's params changed. If the tile has an interim tile and if we\n        // can use it then we use it. Otherwise we create a new tile.  In both\n        // cases we attempt to assign an interim tile to the new tile.\n        const interimTile = tile;\n        tile = this.createTile_(z, x, y, pixelRatio, projection, key);\n\n        //make the new tile the head of the list,\n        if (interimTile.getState() == TileState.IDLE) {\n          //the old tile hasn't begun loading yet, and is now outdated, so we can simply discard it\n          tile.interimTile = interimTile.interimTile;\n        } else {\n          tile.interimTile = interimTile;\n        }\n        tile.refreshInterimChain();\n        this.tileCache.replace(tileCoordKey, tile);\n      }\n    }\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    for (const id in this.tileCacheForProjection) {\n      this.tileCacheForProjection[id].clear();\n    }\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  clear() {\n    super.clear();\n    for (const id in this.tileCacheForProjection) {\n      this.tileCacheForProjection[id].clear();\n    }\n  }\n}\n\n/**\n * @param {ImageTile} imageTile Image tile.\n * @param {string} src Source.\n */\nfunction defaultTileLoadFunction(imageTile, src) {\n  /** @type {HTMLImageElement|HTMLVideoElement} */ (imageTile.getImage()).src =\n    src;\n}\n\nexport default TileImage;\n","/**\n * @module ol/source/BingMaps\n */\n\nimport TileImage from './TileImage.js';\nimport {applyTransform, intersects} from '../extent.js';\nimport {createFromTileUrlFunctions} from '../tileurlfunction.js';\nimport {createOrUpdate} from '../tilecoord.js';\nimport {createXYZ, extentFromProjection} from '../tilegrid.js';\nimport {get as getProjection, getTransformFromProjections} from '../proj.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] Initial tile cache size. Will auto-grow to hold at least the number of tiles in the viewport.\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 */\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      opaque: true,\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      '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 TileImage from './TileImage.js';\nimport {createXYZ, extentFromProjection} from '../tilegrid.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] Initial tile cache size. Will auto-grow to hold at least the number of tiles in the viewport.\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} [opaque=false] Whether the layer is opaque.\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] 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] Optional function to get\n * tile URL given a tile coordinate and the projection.\n * Required if `url` or `urls` are not provided.\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] An array of URL templates.\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      interpolate: options.interpolate,\n      opaque: options.opaque,\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   */\n  getGutter() {\n    return this.gutter_;\n  }\n}\n\nexport default XYZ;\n","/**\n * @module ol/source/CartoDB\n */\n\nimport XYZ from './XYZ.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {number} [cacheSize] Initial tile cache size. Will auto-grow to hold at least the number of tiles in the viewport.\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 {import(\"../proj.js\").ProjectionLike} [projection='EPSG:3857'] Projection.\n * @property {number} [maxZoom=18] Max zoom.\n * @property {number} [minZoom] Minimum zoom.\n * @property {boolean} [wrapX=true] Whether to wrap the world horizontally.\n * @property {Object} [config] If using anonymous maps, the CartoDB config to use. See\n * https://carto.com/developers/maps-api/guides/anonymous-maps/\n * for more detail.\n * If using named maps, a key-value lookup with the template parameters.\n * See https://carto.com/developers/maps-api/guides/named-maps/\n * for more detail.\n * @property {string} [map] If using named maps, this will be the name of the template to load.\n * See https://carto.com/developers/maps-api/guides/named-maps/\n * for more detail.\n * @property {string} [account] Username as used to access public Carto dashboard at https://{username}.carto.com/.\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 * @typedef {Object} CartoDBLayerInfo\n * @property {string} layergroupid The layer group ID\n * @property {{https: string}} cdn_url The CDN URL\n */\n\n/**\n * @classdesc\n * Layer source for the CartoDB Maps API.\n * @api\n */\nclass CartoDB extends XYZ {\n  /**\n   * @param {Options} options CartoDB options.\n   */\n  constructor(options) {\n    super({\n      attributions: options.attributions,\n      cacheSize: options.cacheSize,\n      crossOrigin: options.crossOrigin,\n      maxZoom: options.maxZoom !== undefined ? options.maxZoom : 18,\n      minZoom: options.minZoom,\n      projection: options.projection,\n      transition: options.transition,\n      wrapX: options.wrapX,\n      zDirection: options.zDirection,\n    });\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.account_ = options.account;\n\n    /**\n     * @type {string}\n     * @private\n     */\n    this.mapId_ = options.map || '';\n\n    /**\n     * @type {!Object}\n     * @private\n     */\n    this.config_ = options.config || {};\n\n    /**\n     * @type {!Object<string, CartoDBLayerInfo>}\n     * @private\n     */\n    this.templateCache_ = {};\n\n    this.initializeMap_();\n  }\n\n  /**\n   * Returns the current config.\n   * @return {!Object} The current configuration.\n   * @api\n   */\n  getConfig() {\n    return this.config_;\n  }\n\n  /**\n   * Updates the carto db config.\n   * @param {Object} config a key-value lookup. Values will replace current values\n   *     in the config.\n   * @api\n   */\n  updateConfig(config) {\n    Object.assign(this.config_, config);\n    this.initializeMap_();\n  }\n\n  /**\n   * Sets the CartoDB config\n   * @param {Object} config In the case of anonymous maps, a CartoDB configuration\n   *     object.\n   * If using named maps, a key-value lookup with the template parameters.\n   * @api\n   */\n  setConfig(config) {\n    this.config_ = config || {};\n    this.initializeMap_();\n  }\n\n  /**\n   * Issue a request to initialize the CartoDB map.\n   * @private\n   */\n  initializeMap_() {\n    const paramHash = JSON.stringify(this.config_);\n    if (this.templateCache_[paramHash]) {\n      this.applyTemplate_(this.templateCache_[paramHash]);\n      return;\n    }\n    let mapUrl = 'https://' + this.account_ + '.carto.com/api/v1/map';\n\n    if (this.mapId_) {\n      mapUrl += '/named/' + this.mapId_;\n    }\n\n    const client = new XMLHttpRequest();\n    client.addEventListener(\n      'load',\n      this.handleInitResponse_.bind(this, paramHash)\n    );\n    client.addEventListener('error', this.handleInitError_.bind(this));\n    client.open('POST', mapUrl);\n    client.setRequestHeader('Content-type', 'application/json');\n    client.send(JSON.stringify(this.config_));\n  }\n\n  /**\n   * Handle map initialization response.\n   * @param {string} paramHash a hash representing the parameter set that was used\n   *     for the request\n   * @param {Event} event Event.\n   * @private\n   */\n  handleInitResponse_(paramHash, 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 {CartoDBLayerInfo} */ (\n          JSON.parse(client.responseText)\n        );\n      } catch (err) {\n        this.setState('error');\n        return;\n      }\n      this.applyTemplate_(response);\n      this.templateCache_[paramHash] = response;\n      this.setState('ready');\n    } else {\n      this.setState('error');\n    }\n  }\n\n  /**\n   * @private\n   * @param {Event} event Event.\n   */\n  handleInitError_(event) {\n    this.setState('error');\n  }\n\n  /**\n   * Apply the new tile urls returned by carto db\n   * @param {CartoDBLayerInfo} data Result of carto db call.\n   * @private\n   */\n  applyTemplate_(data) {\n    const tilesUrl =\n      'https://' +\n      data.cdn_url.https +\n      '/' +\n      this.account_ +\n      '/api/v1/map/' +\n      data.layergroupid +\n      '/{z}/{x}/{y}.png';\n    this.setUrl(tilesUrl);\n  }\n}\n\nexport default CartoDB;\n","\nexport default function quickselect(arr, k, left, right, compare) {\n    quickselectStep(arr, k, left || 0, right || (arr.length - 1), compare || defaultCompare);\n}\n\nfunction quickselectStep(arr, k, left, right, compare) {\n\n    while (right > left) {\n        if (right - left > 600) {\n            var n = right - left + 1;\n            var m = k - left + 1;\n            var z = Math.log(n);\n            var s = 0.5 * Math.exp(2 * z / 3);\n            var sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);\n            var newLeft = Math.max(left, Math.floor(k - m * s / n + sd));\n            var newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));\n            quickselectStep(arr, k, newLeft, newRight, compare);\n        }\n\n        var t = arr[k];\n        var i = left;\n        var 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\nfunction swap(arr, i, j) {\n    var tmp = arr[i];\n    arr[i] = arr[j];\n    arr[j] = tmp;\n}\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/structs/RBush\n */\nimport RBush_ from 'rbush';\nimport {createOrUpdate, equals} from '../extent.js';\nimport {getUid} from '../util.js';\nimport {isEmpty} from '../obj.js';\n\n/**\n * @typedef {Object} Entry\n * @property {number} minX MinX.\n * @property {number} minY MinY.\n * @property {number} maxX MaxX.\n * @property {number} maxY MaxY.\n * @property {Object} [value] Value.\n */\n\n/**\n * @classdesc\n * Wrapper around the RBush by Vladimir Agafonkin.\n * See https://github.com/mourner/rbush.\n *\n * @template T\n */\nclass RBush {\n  /**\n   * @param {number} [maxEntries] Max entries.\n   */\n  constructor(maxEntries) {\n    /**\n     * @private\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>}\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} */\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} */\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 {Entry} */\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): *} callback Callback.\n   * @return {*} Callback return value.\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): *} callback Callback.\n   * @return {*} Callback return value.\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): *} callback Callback.\n   * @private\n   * @return {*} Callback return value.\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} 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/geom/Circle\n */\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {createOrUpdate, forEachCorner, intersects} from '../extent.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   */\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   */\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   */\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   */\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   */\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   */\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  getCoordinates() {\n    return null;\n  }\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   */\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 EventType from '../events/EventType.js';\nimport Geometry from './Geometry.js';\nimport {\n  closestSquaredDistanceXY,\n  createOrUpdateEmpty,\n  extend,\n  getCenter,\n} from '../extent.js';\nimport {listen, unlistenByKey} from '../events.js';\n\n/**\n * @classdesc\n * An array of {@link module:ol/geom/Geometry~Geometry} objects.\n *\n * @api\n */\nclass GeometryCollection extends Geometry {\n  /**\n   * @param {Array<Geometry>} [geometries] Geometries.\n   */\n  constructor(geometries) {\n    super();\n\n    /**\n     * @private\n     * @type {Array<Geometry>}\n     */\n    this.geometries_ = geometries ? geometries : null;\n\n    /**\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    if (!this.geometries_) {\n      return;\n    }\n    for (let i = 0, ii = this.geometries_.length; i < ii; ++i) {\n      this.changeEventsKeys_.push(\n        listen(this.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   */\n  clone() {\n    const geometryCollection = new GeometryCollection(null);\n    geometryCollection.setGeometries(this.geometries_);\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   */\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   */\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   */\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   */\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(null);\n      simplifiedGeometryCollection.setGeometriesArray(simplifiedGeometries);\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   */\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   */\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   */\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   */\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   */\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   */\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   */\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  const clonedGeometries = [];\n  for (let i = 0, ii = geometries.length; i < ii; ++i) {\n    clonedGeometries.push(geometries[i].clone());\n  }\n  return clonedGeometries;\n}\n\nexport default GeometryCollection;\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 SimpleGeometry from './SimpleGeometry.js';\nimport {assignClosestPoint, maxSquaredDelta} from './flat/closest.js';\nimport {closestSquaredDistanceXY} from '../extent.js';\nimport {deflateCoordinates} from './flat/deflate.js';\nimport {douglasPeucker} from './flat/simplify.js';\nimport {extend} from '../array.js';\nimport {forEach as forEachSegment} from './flat/segments.js';\nimport {inflateCoordinates} from './flat/inflate.js';\nimport {interpolatePoint, lineStringCoordinateAtM} from './flat/interpolate.js';\nimport {intersectsLineString} from './flat/intersectsextent.js';\nimport {lineStringLength} from './flat/length.js';\n\n/**\n * @classdesc\n * Linestring geometry.\n *\n * @api\n */\nclass LineString extends SimpleGeometry {\n  /**\n   * @param {Array<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   */\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   */\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   */\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   */\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   */\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   */\n  intersectsExtent(extent) {\n    return intersectsLineString(\n      this.flatCoordinates,\n      0,\n      this.flatCoordinates.length,\n      this.stride,\n      extent\n    );\n  }\n\n  /**\n   * Set the coordinates of the linestring.\n   * @param {!Array<import(\"../coordinate.js\").Coordinate>} coordinates Coordinates.\n   * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n   * @api\n   */\n  setCoordinates(coordinates, layout) {\n    this.setLayout(layout, coordinates, 1);\n    if (!this.flatCoordinates) {\n      this.flatCoordinates = [];\n    }\n    this.flatCoordinates.length = deflateCoordinates(\n      this.flatCoordinates,\n      0,\n      coordinates,\n      this.stride\n    );\n    this.changed();\n  }\n}\n\nexport default LineString;\n","/**\n * @module ol/geom/MultiLineString\n */\nimport LineString from './LineString.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {arrayMaxSquaredDelta, assignClosestArrayPoint} from './flat/closest.js';\nimport {closestSquaredDistanceXY} from '../extent.js';\nimport {deflateCoordinatesArray} from './flat/deflate.js';\nimport {douglasPeuckerArray} from './flat/simplify.js';\nimport {extend} from '../array.js';\nimport {inflateCoordinatesArray} from './flat/inflate.js';\nimport {\n  interpolatePoint,\n  lineStringsCoordinateAtM,\n} from './flat/interpolate.js';\nimport {intersectsLineStringArray} from './flat/intersectsextent.js';\n\n/**\n * @classdesc\n * Multi-linestring geometry.\n *\n * @api\n */\nclass MultiLineString extends SimpleGeometry {\n  /**\n   * @param {Array<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   */\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   */\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   */\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 {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   */\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   */\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   */\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   */\n  setCoordinates(coordinates, layout) {\n    this.setLayout(layout, coordinates, 2);\n    if (!this.flatCoordinates) {\n      this.flatCoordinates = [];\n    }\n    const ends = deflateCoordinatesArray(\n      this.flatCoordinates,\n      0,\n      coordinates,\n      this.stride,\n      this.ends_\n    );\n    this.flatCoordinates.length = ends.length === 0 ? 0 : ends[ends.length - 1];\n    this.changed();\n  }\n}\n\nexport default MultiLineString;\n","/**\n * @module ol/geom/MultiPoint\n */\nimport Point from './Point.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {closestSquaredDistanceXY, containsXY} from '../extent.js';\nimport {deflateCoordinates} from './flat/deflate.js';\nimport {extend} from '../array.js';\nimport {inflateCoordinates} from './flat/inflate.js';\nimport {squaredDistance as squaredDx} from '../math.js';\n\n/**\n * @classdesc\n * Multi-point geometry.\n *\n * @api\n */\nclass MultiPoint extends SimpleGeometry {\n  /**\n   * @param {Array<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   */\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   */\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   */\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   */\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   */\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   */\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 MultiPoint from './MultiPoint.js';\nimport Polygon from './Polygon.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {\n  assignClosestMultiArrayPoint,\n  multiArrayMaxSquaredDelta,\n} from './flat/closest.js';\nimport {closestSquaredDistanceXY} from '../extent.js';\nimport {deflateMultiCoordinatesArray} from './flat/deflate.js';\nimport {extend} from '../array.js';\nimport {getInteriorPointsOfMultiArray} from './flat/interiorpoint.js';\nimport {inflateMultiCoordinatesArray} from './flat/inflate.js';\nimport {intersectsLinearRingMultiArray} from './flat/intersectsextent.js';\nimport {\n  linearRingssAreOriented,\n  orientLinearRingsArray,\n} from './flat/orient.js';\nimport {linearRingss as linearRingssArea} from './flat/area.js';\nimport {linearRingss as linearRingssCenter} from './flat/center.js';\nimport {linearRingssContainsXY} from './flat/contains.js';\nimport {quantizeMultiArray} from './flat/simplify.js';\n\n/**\n * @classdesc\n * Multi-polygon geometry.\n *\n * @api\n */\nclass MultiPolygon extends SimpleGeometry {\n  /**\n   * @param {Array<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   */\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   */\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   */\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   */\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   */\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   */\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   */\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   */\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 {\n  LineString,\n  MultiLineString,\n  MultiPoint,\n  MultiPolygon,\n  Point,\n  Polygon,\n} from '../geom.js';\nimport {\n  compose as composeTransform,\n  create as createTransform,\n} from '../transform.js';\nimport {\n  createOrUpdateFromCoordinate,\n  createOrUpdateFromFlatCoordinates,\n  getCenter,\n  getHeight,\n} from '../extent.js';\nimport {\n  douglasPeucker,\n  douglasPeuckerArray,\n  quantizeArray,\n} from '../geom/flat/simplify.js';\nimport {extend} from '../array.js';\nimport {\n  getInteriorPointOfArray,\n  getInteriorPointsOfMultiArray,\n} from '../geom/flat/interiorpoint.js';\nimport {get as getProjection} from '../proj.js';\nimport {inflateEnds} from '../geom/flat/orient.js';\nimport {interpolatePoint} from '../geom/flat/interpolate.js';\nimport {linearRingss as linearRingssCenter} from '../geom/flat/center.js';\nimport {memoizeOne} from '../functions.js';\nimport {transform2D} from '../geom/flat/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>}\n     */\n    this.ends_ = ends;\n\n    /**\n     * @private\n     * @type {Object<string, *>}\n     */\n    this.properties_ = properties;\n\n    /**\n     * @type {number}\n     */\n    this.squaredTolerance_;\n\n    /**\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              2\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        /** @type {Array<number>} */ (this.ends_),\n        2,\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(this.flatCoordinates_, 0, ends, 2);\n      this.flatInteriorPoints_ = getInteriorPointsOfMultiArray(\n        this.flatCoordinates_,\n        0,\n        ends,\n        2,\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        2,\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(flatCoordinates, offset, end, 2, 0.5);\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        2,\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>} 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          2,\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 = /** @type {Array<number>} */ (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'] 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/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 Event from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport ObjectEventType from '../ObjectEventType.js';\nimport RBush from '../structs/RBush.js';\nimport RenderFeature from '../render/Feature.js';\nimport Source from './Source.js';\nimport VectorEventType from './VectorEventType.js';\nimport {TRUE, VOID} from '../functions.js';\nimport {all as allStrategy} from '../loadingstrategy.js';\nimport {assert} from '../asserts.js';\nimport {containsExtent, equals, wrapAndSliceX} from '../extent.js';\nimport {extend} from '../array.js';\nimport {getUid} from '../util.js';\nimport {isEmpty} from '../obj.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport {xhr} from '../featureloader.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} [FeatureClass=import(\"../Feature.js\").default]\n */\nexport class VectorSourceEvent extends Event {\n  /**\n   * @param {string} type Type.\n   * @param {FeatureClass} [feature] Feature.\n   * @param {Array<FeatureClass>} [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 {FeatureClass|undefined}\n     * @api\n     */\n    this.feature = feature;\n\n    /**\n     * The loaded features for the `FEATURESLOADED` event, `undefined` otherwise.\n     * @type {Array<FeatureClass>|undefined}\n     * @api\n     */\n    this.features = features;\n  }\n}\n\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types, import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").OnSignature<import(\"./VectorEventType\").VectorSourceEventTypes, VectorSourceEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").Types|\n *     import(\"./VectorEventType\").VectorSourceEventTypes, Return>} VectorSourceOnSignature\n */\n\n/**\n * @template {import(\"../Feature.js\").FeatureLike} [FeatureClass=import(\"../Feature.js\").default]\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {Array<FeatureClass>|Collection<FeatureClass>} [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} [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} [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 *   format: new GeoJSON(),\n *   loader: function(extent, resolution, projection, success, failure) {\n *      const proj = projection.getCode();\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&srsname=' + proj + '&' +\n *          'bbox=' + extent.join(',') + ',' + proj;\n *      const xhr = new XMLHttpRequest();\n *      xhr.open('GET', url);\n *      const onError = function() {\n *        vectorSource.removeLoadedExtent(extent);\n *        failure();\n *      }\n *      xhr.onerror = onError;\n *      xhr.onload = function() {\n *        if (xhr.status == 200) {\n *          const features = vectorSource.getFormat().readFeatures(xhr.responseText);\n *          vectorSource.addFeatures(features);\n *          success(features);\n *        } else {\n *          onError();\n *        }\n *      }\n *      xhr.send();\n *    },\n *    strategy: bbox,\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} [FeatureClass=import(\"../Feature.js\").default]\n */\nclass VectorSource extends Source {\n  /**\n   * @param {Options<FeatureClass>} [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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {VectorSourceOnSignature<import(\"../events\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {VectorSourceOnSignature<void>}\n     */\n    this.un;\n\n    /**\n     * @private\n     * @type {import(\"../featureloader.js\").FeatureLoader}\n     */\n    this.loader_ = VOID;\n\n    /**\n     * @private\n     * @type {import(\"../format/Feature.js\").default|undefined}\n     */\n    this.format_ = options.format;\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(\n        this.url_,\n        /** @type {import(\"../format/Feature.js\").default} */ (this.format_)\n      );\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<FeatureClass>}\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     * @type {number}\n     * @private\n     */\n    this.loadingExtentsCount_ = 0;\n\n    /**\n     * @private\n     * @type {!Object<string, FeatureClass>}\n     */\n    this.nullGeometryFeatures_ = {};\n\n    /**\n     * A lookup of features by id (the return from feature.getId()).\n     * @private\n     * @type {!Object<string, FeatureClass|Array<RenderFeature>>}\n     */\n    this.idIndex_ = {};\n\n    /**\n     * A lookup of features by uid (using getUid(feature)).\n     * @private\n     * @type {!Object<string, FeatureClass>}\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<FeatureClass>|null}\n     */\n    this.featuresCollection_ = null;\n\n    /** @type {Collection<FeatureClass>} */\n    let collection;\n    /** @type {Array<FeatureClass>} */\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 an {@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 {FeatureClass} 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 {FeatureClass} 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 {FeatureClass} 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 {FeatureClass} 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 {\n          if (!Array.isArray(indexedFeature)) {\n            this.idIndex_[id] = [indexedFeature, feature];\n          } else {\n            indexedFeature.push(feature);\n          }\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<FeatureClass>} 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<FeatureClass>} features Features.\n   * @protected\n   */\n  addFeaturesInternal(features) {\n    const extents = [];\n    /** @type {Array<FeatureClass>} */\n    const newFeatures = [];\n    /** @type Array<FeatureClass> */\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<FeatureClass>} collection Collection.\n   * @private\n   */\n  bindFeaturesCollection_(collection) {\n    let modifyingCollection = false;\n    this.addEventListener(\n      VectorEventType.ADDFEATURE,\n      /**\n       * @param {VectorSourceEvent<FeatureClass>} 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<FeatureClass>} 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<FeatureClass>} 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<FeatureClass>} 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        const removeAndIgnoreReturn = (feature) => {\n          this.removeFeatureInternal(feature);\n        };\n        this.featuresRtree_.forEach(removeAndIgnoreReturn);\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(FeatureClass): 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(FeatureClass): 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(FeatureClass): 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(FeatureClass): 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 {FeatureClass} 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 an {@link module:ol/Collection~Collection} as `features`.\n   * @return {Collection<FeatureClass>|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<FeatureClass>} 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<import(\"../Feature.js\").default>} Features.\n   * @api\n   */\n  getFeaturesAtCoordinate(coordinate) {\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<FeatureClass>} 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(FeatureClass):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 {FeatureClass} Closest feature.\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 {FeatureClass} 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 method is not available 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} Extent.\n   * @api\n   */\n  getExtent(extent) {\n    return this.featuresRtree_.getExtent(extent);\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 {FeatureClass|Array<RenderFeature>|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 ? feature : null;\n  }\n\n  /**\n   * Get a feature by its internal unique identifier (using `getUid`).\n   *\n   * @param {string} uid Feature identifier.\n   * @return {FeatureClass|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|undefined} 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 {FeatureClass} */ (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 {FeatureClass} 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.loadingExtentsCount_;\n        this.dispatchEvent(\n          new VectorSourceEvent(VectorEventType.FEATURESLOADSTART)\n        );\n        this.loader_.call(\n          this,\n          extentToLoad,\n          resolution,\n          projection,\n          (features) => {\n            --this.loadingExtentsCount_;\n            this.dispatchEvent(\n              new VectorSourceEvent(\n                VectorEventType.FEATURESLOADEND,\n                undefined,\n                features\n              )\n            );\n          },\n          () => {\n            --this.loadingExtentsCount_;\n            this.dispatchEvent(\n              new VectorSourceEvent(VectorEventType.FEATURESLOADERROR)\n            );\n          }\n        );\n        loadedExtentsRtree.insert(extentToLoad, {extent: extentToLoad.slice()});\n      }\n    }\n    this.loading =\n      this.loader_.length < 4 ? false : this.loadingExtentsCount_ > 0;\n  }\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    let obj;\n    loadedExtentsRtree.forEachInExtent(extent, function (object) {\n      if (equals(object.extent, extent)) {\n        obj = object;\n        return true;\n      }\n    });\n    if (obj) {\n      loadedExtentsRtree.remove(obj);\n    }\n  }\n\n  /**\n   * Remove a single feature 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 {FeatureClass} feature Feature to remove.\n   * @api\n   */\n  removeFeature(feature) {\n    if (!feature) {\n      return;\n    }\n    const featureKey = getUid(feature);\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    const result = this.removeFeatureInternal(feature);\n    if (result) {\n      this.changed();\n    }\n  }\n\n  /**\n   * Remove feature without firing a `change` event.\n   * @param {FeatureClass} feature Feature.\n   * @return {FeatureClass|undefined} The removed feature\n   *     (or undefined if the feature was not found).\n   * @protected\n   */\n  removeFeatureInternal(feature) {\n    const featureKey = getUid(feature);\n    const featureChangeKeys = this.featureChangeKeys_[featureKey];\n    if (!featureChangeKeys) {\n      return;\n    }\n    featureChangeKeys.forEach(unlistenByKey);\n    delete this.featureChangeKeys_[featureKey];\n    const id = feature.getId();\n    if (id !== undefined) {\n      delete this.idIndex_[id.toString()];\n    }\n    delete this.uidIndex_[featureKey];\n    this.dispatchEvent(\n      new VectorSourceEvent(VectorEventType.REMOVEFEATURE, feature)\n    );\n    return feature;\n  }\n\n  /**\n   * Remove a feature from the id index.  Called internally when the feature id\n   * may have changed.\n   * @param {FeatureClass} feature The feature.\n   * @return {boolean} Removed the feature from the index.\n   * @private\n   */\n  removeFromIdIndex_(feature) {\n    let removed = false;\n    for (const id in this.idIndex_) {\n      const indexedFeature = this.idIndex_[id];\n      if (\n        feature instanceof RenderFeature &&\n        Array.isArray(indexedFeature) &&\n        indexedFeature.includes(feature)\n      ) {\n        indexedFeature.splice(indexedFeature.indexOf(feature), 1);\n      } else if (this.idIndex_[id] === feature) {\n        delete this.idIndex_[id];\n        removed = true;\n        break;\n      }\n    }\n    return removed;\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\nexport default VectorSource;\n","/**\n * @module ol/source/Cluster\n */\n\nimport EventType from '../events/EventType.js';\nimport Feature from '../Feature.js';\nimport Point from '../geom/Point.js';\nimport VectorSource from './Vector.js';\nimport {add as addCoordinate, scale as scaleCoordinate} from '../coordinate.js';\nimport {assert} from '../asserts.js';\nimport {\n  buffer,\n  createEmpty,\n  createOrUpdateFromCoordinate,\n  getCenter,\n} from '../extent.js';\nimport {getUid} from '../util.js';\n\n/**\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 {function(Feature):Point} [geometryFunction]\n * Function that takes an {@link module:ol/Feature~Feature} as argument and returns an\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<Feature>):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} [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 */\nclass Cluster extends VectorSource {\n  /**\n   * @param {Options} options Cluster options.\n   */\n  constructor(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     * @param {Feature} feature Feature.\n     * @return {Point} Cluster calculation point.\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<Feature>):Feature}\n     * @private\n     */\n    this.createCustomCluster_ = options.createCluster;\n\n    /**\n     * @type {VectorSource|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   */\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|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   */\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|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   */\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<Feature>} 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/reproj/DataTile\n */\nimport {ERROR_THRESHOLD} from './common.js';\n\nimport DataTile, {asArrayLike, asImageLike, toArray} from '../DataTile.js';\nimport EventType from '../events/EventType.js';\nimport TileState from '../TileState.js';\nimport Triangulation from './Triangulation.js';\nimport {\n  calculateSourceExtentResolution,\n  canvasPool,\n  render as renderReprojected,\n} from '../reproj.js';\nimport {clamp} from '../math.js';\nimport {createCanvasContext2D, releaseCanvas} from '../dom.js';\nimport {getArea, getIntersection} from '../extent.js';\nimport {listen, unlistenByKey} from '../events.js';\n\n/**\n * @typedef {function(number, number, number, number) : import(\"../DataTile.js\").default} TileGetter\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 */\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 Uint8Array(4)),\n      interpolate: options.interpolate,\n      transition: options.transition,\n    });\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<DataTile>}\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 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    const sourceProj = options.sourceProj;\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 = 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    );\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      const sourceRange = this.sourceTileGrid_.getTileRangeForExtentAndZ(\n        sourceExtent,\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            this.sourceTiles_.push(tile);\n          }\n        }\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   */\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   */\n  getData() {\n    return this.reprojData_;\n  }\n\n  /**\n   * Get any loading error.\n   * @return {Error} Loading error.\n   */\n  getError() {\n    return this.reprojError_;\n  }\n\n  /**\n   * @private\n   */\n  reproject_() {\n    const dataSources = [];\n    this.sourceTiles_.forEach((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        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 : Uint8Array;\n      const tileDataR = new DataType(tileData.buffer);\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 packedLength = pixelCount * bandCount;\n      let packedData = tileDataR;\n      if (tileDataR.length !== packedLength) {\n        packedData = new DataType(packedLength);\n        let dataIndex = 0;\n        let rowOffset = 0;\n        const colCount = pixelSize[0] * bandCount;\n        for (let rowIndex = 0; rowIndex < pixelSize[1]; ++rowIndex) {\n          for (let colIndex = 0; colIndex < colCount; ++colIndex) {\n            packedData[dataIndex++] = tileDataR[rowOffset + colIndex];\n          }\n          rowOffset += bytesPerRow / bytesPerElement;\n        }\n      }\n      dataSources.push({\n        extent: this.sourceTileGrid_.getTileCoordExtent(tile.tileCoord),\n        data: new Uint8Array(packedData.buffer),\n        dataType: DataType,\n        bytesPerPixel: bytesPerPixel,\n        pixelSize: pixelSize,\n      });\n    });\n    this.sourceTiles_.length = 0;\n\n    if (dataSources.length === 0) {\n      this.state = TileState.ERROR;\n    } else {\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 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      let dataR, dataU;\n\n      const bytesPerPixel = dataSources[0].bytesPerPixel;\n\n      const reprojs = Math.ceil(bytesPerPixel / 3);\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          const buffer = dataSource.data;\n          const pixelSize = dataSource.pixelSize;\n          const width = pixelSize[0];\n          const height = pixelSize[1];\n          const context = createCanvasContext2D(width, height, canvasPool);\n          const imageData = context.createImageData(width, height);\n          const data = imageData.data;\n          let offset = reproj * 3;\n          for (let j = 0, len = data.length; j < len; j += 4) {\n            data[j] = buffer[offset];\n            data[j + 1] = buffer[offset + 1];\n            data[j + 2] = buffer[offset + 2];\n            data[j + 3] = 255;\n            offset += bytesPerPixel;\n          }\n          context.putImageData(imageData, 0, 0);\n          sources.push({\n            extent: dataSource.extent,\n            image: context.canvas,\n          });\n        }\n\n        const canvas = renderReprojected(\n          targetWidth,\n          targetHeight,\n          this.pixelRatio_,\n          sourceResolution,\n          this.sourceTileGrid_.getExtent(),\n          targetResolution,\n          targetExtent,\n          this.triangulation_,\n          sources,\n          this.gutter_,\n          false,\n          false\n        );\n\n        for (let i = 0, len = sources.length; i < len; ++i) {\n          const canvas = sources[i].image;\n          const context = canvas.getContext('2d');\n          releaseCanvas(context);\n          canvasPool.push(context.canvas);\n        }\n\n        const context = canvas.getContext('2d');\n        const imageData = context.getImageData(\n          0,\n          0,\n          canvas.width,\n          canvas.height\n        );\n\n        releaseCanvas(context);\n        canvasPool.push(canvas);\n\n        if (!dataR) {\n          dataU = new Uint8Array(\n            bytesPerPixel * imageData.width * imageData.height\n          );\n          dataR = new dataSources[0].dataType(dataU.buffer);\n        }\n\n        const data = imageData.data;\n        let offset = reproj * 3;\n        for (let i = 0, len = data.length; i < len; i += 4) {\n          if (data[i + 3] === 255) {\n            dataU[offset] = data[i];\n            dataU[offset + 1] = data[i + 1];\n            dataU[offset + 2] = data[i + 2];\n          } else {\n            dataU[offset] = 0;\n            dataU[offset + 1] = 0;\n            dataU[offset + 2] = 0;\n          }\n          offset += bytesPerPixel;\n        }\n      }\n\n      this.reprojData_ = dataR;\n      this.reprojSize_ = [\n        Math.round(targetWidth * this.pixelRatio_),\n        Math.round(targetHeight * this.pixelRatio_),\n      ];\n      this.state = TileState.LOADED;\n    }\n    this.changed();\n  }\n\n  /**\n   * Load not yet loaded URI.\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(\n        tile,\n        EventType.CHANGE,\n        function () {\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\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 EventType from '../events/EventType.js';\nimport ReprojDataTile from '../reproj/DataTile.js';\nimport TileCache from '../TileCache.js';\nimport TileEventType from './TileEventType.js';\nimport TileSource, {TileSourceEvent} from './Tile.js';\nimport TileState from '../TileState.js';\nimport {\n  createXYZ,\n  extentFromProjection,\n  getForProjection as getTileGridForProjection,\n} from '../tilegrid.js';\nimport {equivalent, get as getProjection} from '../proj.js';\nimport {getKeyZXY} from '../tilecoord.js';\nimport {getUid} from '../util.js';\nimport {toPromise} from '../functions.js';\nimport {toSize} from '../size.js';\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) : (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 {boolean} [opaque=false] Whether the layer is opaque.\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 */\n\n/**\n * @classdesc\n * A source for typed array data tiles.\n *\n * @fires import(\"./Tile.js\").TileSourceEvent\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      opaque: options.opaque,\n      state: options.state,\n      wrapX: options.wrapX,\n      transition: options.transition,\n      interpolate: options.interpolate,\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    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     * @private\n     * @type {!Object<string, import(\"../tilegrid/TileGrid.js\").default>}\n     */\n    this.tileGridForProjection_ = {};\n\n    /**\n     * @private\n     * @type {!Object<string, import(\"../TileCache.js\").default>}\n     */\n    this.tileCacheForProjection_ = {};\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   */\n  getGutterForProjection(projection) {\n    const thisProj = this.getProjection();\n    if (!thisProj || equivalent(thisProj, projection)) {\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   * @return {!DataTile} Tile.\n   */\n  getReprojTile_(z, x, y, targetProj, sourceProj) {\n    const cache = this.getTileCacheForProjection(targetProj);\n    const tileCoordKey = getKeyZXY(z, x, y);\n    if (cache.containsKey(tileCoordKey)) {\n      const tile = cache.get(tileCoordKey);\n      if (tile && tile.key == this.getKey()) {\n        return tile;\n      }\n    }\n\n    const tileGrid = this.getTileGrid();\n    const reprojTilePixelRatio = Math.max.apply(\n      null,\n      tileGrid.getResolutions().map((r, z) => {\n        const tileSize = toSize(tileGrid.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 sourceTileGrid = this.getTileGridForProjection(sourceProj);\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,\n        sourceTileGrid,\n        targetProj,\n        targetTileGrid,\n        tileCoord,\n        wrappedTileCoord,\n        pixelRatio: reprojTilePixelRatio,\n        gutter: this.getGutterForProjection(sourceProj),\n        getTileFunction: (z, x, y, pixelRatio) =>\n          this.getTile(z, x, y, pixelRatio, sourceProj),\n      },\n      this.tileOptions\n    );\n    const newTile = new ReprojDataTile(options);\n    newTile.key = this.getKey();\n    return newTile;\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 {!DataTile} Tile.\n   */\n  getTile(z, x, y, pixelRatio, projection) {\n    const sourceProjection = this.getProjection();\n    if (\n      sourceProjection &&\n      projection &&\n      !equivalent(sourceProjection, projection)\n    ) {\n      return this.getReprojTile_(z, x, y, projection, sourceProjection);\n    }\n\n    const size = this.getTileSize(z);\n    const tileCoordKey = getKeyZXY(z, x, y);\n    if (this.tileCache.containsKey(tileCoordKey)) {\n      return this.tileCache.get(tileCoordKey);\n    }\n\n    const sourceLoader = this.loader_;\n\n    function loader() {\n      return toPromise(function () {\n        return sourceLoader(z, x, y);\n      });\n    }\n\n    const options = Object.assign(\n      {\n        tileCoord: [z, x, y],\n        loader: loader,\n        size: size,\n      },\n      this.tileOptions\n    );\n\n    const tile = new DataTile(options);\n    tile.key = this.getKey();\n    tile.addEventListener(EventType.CHANGE, this.handleTileChange_);\n\n    this.tileCache.set(tileCoordKey, 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   */\n  getTileGridForProjection(projection) {\n    const thisProj = this.getProjection();\n    if (this.tileGrid && (!thisProj || equivalent(thisProj, projection))) {\n      return this.tileGrid;\n    }\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   * 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   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @return {import(\"../TileCache.js\").default} Tile cache.\n   */\n  getTileCacheForProjection(projection) {\n    const thisProj = this.getProjection();\n    if (!thisProj || equivalent(thisProj, projection)) {\n      return this.tileCache;\n    }\n\n    const projKey = getUid(projection);\n    if (!(projKey in this.tileCacheForProjection_)) {\n      this.tileCacheForProjection_[projKey] = new TileCache(0.1); // don't cache\n    }\n    return this.tileCacheForProjection_[projKey];\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @param {!Object<string, boolean>} usedTiles Used tiles.\n   */\n  expireCache(projection, usedTiles) {\n    const usedTileCache = this.getTileCacheForProjection(projection);\n\n    this.tileCache.expireCache(\n      this.tileCache == usedTileCache ? usedTiles : {}\n    );\n    for (const id in this.tileCacheForProjection_) {\n      const tileCache = this.tileCacheForProjection_[id];\n      tileCache.expireCache(tileCache == usedTileCache ? usedTiles : {});\n    }\n  }\n\n  clear() {\n    super.clear();\n    for (const id in this.tileCacheForProjection_) {\n      this.tileCacheForProjection_[id].clear();\n    }\n  }\n}\n\nexport default DataTileSource;\n","/**\n * @module ol/source/GeoTIFF\n */\nimport DataTile from './DataTile.js';\nimport TileGrid from '../tilegrid/TileGrid.js';\nimport {\n  Pool,\n  globals as geotiffGlobals,\n  fromBlob as tiffFromBlob,\n  fromUrl as tiffFromUrl,\n  fromUrls as tiffFromUrls,\n} from 'geotiff';\nimport {\n  Projection,\n  get as getCachedProjection,\n  toUserCoordinate,\n  toUserExtent,\n} from '../proj.js';\nimport {clamp} from '../math.js';\nimport {getCenter, getIntersection} from '../extent.js';\nimport {error as logError} from '../console.js';\nimport {fromCode as unitsFromCode} from '../proj/Units.js';\n\n/**\n * Determine if an image type is a mask.\n * See https://www.awaresystems.be/imaging/tiff/tifftags/newsubfiletype.html\n * @param {GeoTIFFImage} image The image.\n * @return {boolean} The image is a mask.\n */\nfunction isMask(image) {\n  const fileDirectory = image.fileDirectory;\n  const type = fileDirectory.NewSubfileType || 0;\n  return (type & 4) === 4;\n}\n\n/**\n * @param {true|false|'auto'} preference The convertToRGB option.\n * @param {GeoTIFFImage} image The image.\n * @return {boolean} Use the `image.readRGB()` method.\n */\nfunction readRGB(preference, image) {\n  if (!preference) {\n    return false;\n  }\n  if (preference === true) {\n    return true;\n  }\n  if (image.getSamplesPerPixel() !== 3) {\n    return false;\n  }\n  const interpretation = image.fileDirectory.PhotometricInterpretation;\n  const interpretations = geotiffGlobals.photometricInterpretations;\n  return (\n    interpretation === interpretations.CMYK ||\n    interpretation === interpretations.YCbCr ||\n    interpretation === interpretations.CIELab ||\n    interpretation === interpretations.ICCLab\n  );\n}\n\n/**\n * @typedef {Object} SourceInfo\n * @property {string} [url] URL for the source GeoTIFF.\n * @property {Array<string>} [overviews] List of any overview URLs, only applies if the url parameter is given.\n * @property {Blob} [blob] Blob containing the source GeoTIFF. `blob` and `url` are mutually exclusive.\n * @property {number} [min=0] The minimum source data value.  Rendered values are scaled from 0 to 1 based on\n * the configured min and max.  If not provided and raster statistics are available, those will be used instead.\n * If neither are available, the minimum for the data type will be used.  To disable this behavior, set\n * the `normalize` option to `false` in the constructor.\n * @property {number} [max] The maximum source data value.  Rendered values are scaled from 0 to 1 based on\n * the configured min and max.  If not provided and raster statistics are available, those will be used instead.\n * If neither are available, the maximum for the data type will be used.  To disable this behavior, set\n * the `normalize` option to `false` in the constructor.\n * @property {number} [nodata] Values to discard (overriding any nodata values in the metadata).\n * When provided, an additional alpha band will be added to the data.  Often the GeoTIFF metadata\n * will include information about nodata values, so you should only need to set this property if\n * you find that it is not already extracted from the metadata.\n * @property {Array<number>} [bands] Band numbers to be read from (where the first band is `1`). If not provided, all bands will\n * be read. For example, if a GeoTIFF has blue (1), green (2), red (3), and near-infrared (4) bands, and you only need the\n * near-infrared band, configure `bands: [4]`.\n */\n\n/**\n * @typedef {Object} GeoKeys\n * @property {number} GTModelTypeGeoKey Model type.\n * @property {number} GTRasterTypeGeoKey Raster type.\n * @property {number} GeogAngularUnitsGeoKey Angular units.\n * @property {number} GeogInvFlatteningGeoKey Inverse flattening.\n * @property {number} GeogSemiMajorAxisGeoKey Semi-major axis.\n * @property {number} GeographicTypeGeoKey Geographic coordinate system code.\n * @property {number} ProjLinearUnitsGeoKey Projected linear unit code.\n * @property {number} ProjectedCSTypeGeoKey Projected coordinate system code.\n */\n\n/**\n * @typedef {import(\"geotiff\").GeoTIFF} GeoTIFF\n */\n\n/**\n * @typedef {import(\"geotiff\").MultiGeoTIFF} MultiGeoTIFF\n */\n\n/**\n * @typedef {Object} GDALMetadata\n * @property {string} STATISTICS_MINIMUM The minimum value (as a string).\n * @property {string} STATISTICS_MAXIMUM The maximum value (as a string).\n */\n\nconst STATISTICS_MAXIMUM = 'STATISTICS_MAXIMUM';\nconst STATISTICS_MINIMUM = 'STATISTICS_MINIMUM';\n\nconst defaultTileSize = 256;\n\n/**\n * @typedef {import(\"geotiff\").GeoTIFFImage} GeoTIFFImage\n */\n\nlet workerPool;\nfunction getWorkerPool() {\n  if (!workerPool) {\n    workerPool = new Pool();\n  }\n  return workerPool;\n}\n\n/**\n * Get the bounding box of an image.  If the image does not have an affine transform,\n * the pixel bounds are returned.\n * @param {GeoTIFFImage} image The image.\n * @return {Array<number>} The image bounding box.\n */\nfunction getBoundingBox(image) {\n  try {\n    return image.getBoundingBox();\n  } catch (_) {\n    return [0, 0, image.getWidth(), image.getHeight()];\n  }\n}\n\n/**\n * Get the origin of an image.  If the image does not have an affine transform,\n * the top-left corner of the pixel bounds is returned.\n * @param {GeoTIFFImage} image The image.\n * @return {Array<number>} The image origin.\n */\nfunction getOrigin(image) {\n  try {\n    return image.getOrigin().slice(0, 2);\n  } catch (_) {\n    return [0, image.getHeight()];\n  }\n}\n\n/**\n * Get the resolution of an image.  If the image does not have an affine transform,\n * the width of the image is compared with the reference image.\n * @param {GeoTIFFImage} image The image.\n * @param {GeoTIFFImage} referenceImage The reference image.\n * @return {Array<number>} The map x and y units per pixel.\n */\nfunction getResolutions(image, referenceImage) {\n  try {\n    return image.getResolution(referenceImage);\n  } catch (_) {\n    return [\n      referenceImage.getWidth() / image.getWidth(),\n      referenceImage.getHeight() / image.getHeight(),\n    ];\n  }\n}\n\n/**\n * @param {GeoTIFFImage} image A GeoTIFF.\n * @return {import(\"../proj/Projection.js\").default} The image projection.\n */\nfunction getProjection(image) {\n  const geoKeys = image.geoKeys;\n  if (!geoKeys) {\n    return null;\n  }\n\n  if (\n    geoKeys.ProjectedCSTypeGeoKey &&\n    geoKeys.ProjectedCSTypeGeoKey !== 32767\n  ) {\n    const code = 'EPSG:' + geoKeys.ProjectedCSTypeGeoKey;\n    let projection = getCachedProjection(code);\n    if (!projection) {\n      const units = unitsFromCode(geoKeys.ProjLinearUnitsGeoKey);\n      if (units) {\n        projection = new Projection({\n          code: code,\n          units: units,\n        });\n      }\n    }\n    return projection;\n  }\n\n  if (geoKeys.GeographicTypeGeoKey && geoKeys.GeographicTypeGeoKey !== 32767) {\n    const code = 'EPSG:' + geoKeys.GeographicTypeGeoKey;\n    let projection = getCachedProjection(code);\n    if (!projection) {\n      const units = unitsFromCode(geoKeys.GeogAngularUnitsGeoKey);\n      if (units) {\n        projection = new Projection({\n          code: code,\n          units: units,\n        });\n      }\n    }\n    return projection;\n  }\n\n  return null;\n}\n\n/**\n * @param {GeoTIFF|MultiGeoTIFF} tiff A GeoTIFF.\n * @return {Promise<Array<GeoTIFFImage>>} Resolves to a list of images.\n */\nfunction getImagesForTIFF(tiff) {\n  return tiff.getImageCount().then(function (count) {\n    const requests = new Array(count);\n    for (let i = 0; i < count; ++i) {\n      requests[i] = tiff.getImage(i);\n    }\n    return Promise.all(requests);\n  });\n}\n\n/**\n * @param {SourceInfo} source The GeoTIFF source.\n * @param {Object} options Options for the GeoTIFF source.\n * @return {Promise<Array<GeoTIFFImage>>} Resolves to a list of images.\n */\nfunction getImagesForSource(source, options) {\n  let request;\n  if (source.blob) {\n    request = tiffFromBlob(source.blob);\n  } else if (source.overviews) {\n    request = tiffFromUrls(source.url, source.overviews, options);\n  } else {\n    request = tiffFromUrl(source.url, options);\n  }\n  return request.then(getImagesForTIFF);\n}\n\n/**\n * @param {number|Array<number>|Array<Array<number>>} expected Expected value.\n * @param {number|Array<number>|Array<Array<number>>} got Actual value.\n * @param {number} tolerance Accepted tolerance in fraction of expected between expected and got.\n * @param {string} message The error message.\n * @param {function(Error):void} rejector A function to be called with any error.\n */\nfunction assertEqual(expected, got, tolerance, message, rejector) {\n  if (Array.isArray(expected)) {\n    const length = expected.length;\n    if (!Array.isArray(got) || length != got.length) {\n      const error = new Error(message);\n      rejector(error);\n      throw error;\n    }\n    for (let i = 0; i < length; ++i) {\n      assertEqual(expected[i], got[i], tolerance, message, rejector);\n    }\n    return;\n  }\n\n  got = /** @type {number} */ (got);\n  if (Math.abs(expected - got) > tolerance * expected) {\n    throw new Error(message);\n  }\n}\n\n/**\n * @param {Array} array The data array.\n * @return {number} The minimum value.\n */\nfunction getMinForDataType(array) {\n  if (array instanceof Int8Array) {\n    return -128;\n  }\n  if (array instanceof Int16Array) {\n    return -32768;\n  }\n  if (array instanceof Int32Array) {\n    return -2147483648;\n  }\n  if (array instanceof Float32Array) {\n    return 1.2e-38;\n  }\n  return 0;\n}\n\n/**\n * @param {Array} array The data array.\n * @return {number} The maximum value.\n */\nfunction getMaxForDataType(array) {\n  if (array instanceof Int8Array) {\n    return 127;\n  }\n  if (array instanceof Uint8Array) {\n    return 255;\n  }\n  if (array instanceof Uint8ClampedArray) {\n    return 255;\n  }\n  if (array instanceof Int16Array) {\n    return 32767;\n  }\n  if (array instanceof Uint16Array) {\n    return 65535;\n  }\n  if (array instanceof Int32Array) {\n    return 2147483647;\n  }\n  if (array instanceof Uint32Array) {\n    return 4294967295;\n  }\n  if (array instanceof Float32Array) {\n    return 3.4e38;\n  }\n  return 255;\n}\n\n/**\n * @typedef {Object} GeoTIFFSourceOptions\n * @property {boolean} [forceXHR=false] Whether to force the usage of the browsers XMLHttpRequest API.\n * @property {Object<string, string>} [headers] additional key-value pairs of headers to be passed with each request. Key is the header name, value the header value.\n * @property {string} [credentials] How credentials shall be handled. See\n * https://developer.mozilla.org/en-US/docs/Web/API/fetch for reference and possible values\n * @property {number} [maxRanges] The maximum amount of ranges to request in a single multi-range request.\n * By default only a single range is used.\n * @property {boolean} [allowFullFile=false] Whether or not a full file is accepted when only a portion is\n * requested. Only use this when you know the source image to be small enough to fit in memory.\n * @property {number} [blockSize=65536] The block size to use.\n * @property {number} [cacheSize=100] The number of blocks that shall be held in a LRU cache.\n */\n\n/**\n * @typedef {Object} Options\n * @property {Array<SourceInfo>} sources List of information about GeoTIFF sources.\n * Multiple sources can be combined when their resolution sets are equal after applying a scale.\n * The list of sources defines a mapping between input bands as they are read from each GeoTIFF and\n * the output bands that are provided by data tiles. To control which bands to read from each GeoTIFF,\n * use the {@link import(\"./GeoTIFF.js\").SourceInfo bands} property. If, for example, you specify two\n * sources, one with 3 bands and {@link import(\"./GeoTIFF.js\").SourceInfo nodata} configured, and\n * another with 1 band, the resulting data tiles will have 5 bands: 3 from the first source, 1 alpha\n * band from the first source, and 1 band from the second source.\n * @property {GeoTIFFSourceOptions} [sourceOptions] Additional options to be passed to [geotiff.js](https://geotiffjs.github.io/geotiff.js/module-geotiff.html)'s `fromUrl` or `fromUrls` methods.\n * @property {true|false|'auto'} [convertToRGB=false] By default, bands from the sources are read as-is. When\n * reading GeoTIFFs with the purpose of displaying them as RGB images, setting this to `true` will\n * convert other color spaces (YCbCr, CMYK) to RGB.  Setting the option to `'auto'` will make it so CMYK, YCbCr,\n * CIELab, and ICCLab images will automatically be converted to RGB.\n * @property {boolean} [normalize=true] By default, the source data is normalized to values between\n * 0 and 1 with scaling factors based on the raster statistics or `min` and `max` properties of each source.\n * If instead you want to work with the raw values in a style expression, set this to `false`.  Setting this option\n * to `false` will make it so any `min` and `max` properties on sources are ignored.\n * @property {boolean} [opaque=false] Whether the layer is opaque.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Source projection.  If not provided, the GeoTIFF metadata\n * will be read for projection information.\n * @property {number} [transition=250] Duration of the opacity transition for rendering.\n * To disable the opacity transition, pass `transition: 0`.\n * @property {boolean} [wrapX=false] Render tiles beyond the tile grid extent.\n * @property {boolean} [interpolate=true] Use interpolated values when resampling.  By default,\n * the linear interpolation is used to resample the data.  If false, nearest neighbor is used.\n */\n\n/**\n * @classdesc\n * A source for working with GeoTIFF data.\n * **Note for users of the full build**: The `GeoTIFF` source requires the\n * [geotiff.js](https://github.com/geotiffjs/geotiff.js) library to be loaded as well.\n *\n * @api\n */\nclass GeoTIFFSource extends DataTile {\n  /**\n   * @param {Options} options Data tile options.\n   */\n  constructor(options) {\n    super({\n      state: 'loading',\n      tileGrid: null,\n      projection: options.projection || null,\n      opaque: options.opaque,\n      transition: options.transition,\n      interpolate: options.interpolate !== false,\n      wrapX: options.wrapX,\n    });\n\n    /**\n     * @type {Array<SourceInfo>}\n     * @private\n     */\n    this.sourceInfo_ = options.sources;\n\n    const numSources = this.sourceInfo_.length;\n\n    /**\n     * @type {Object}\n     * @private\n     */\n    this.sourceOptions_ = options.sourceOptions;\n\n    /**\n     * @type {Array<Array<GeoTIFFImage>>}\n     * @private\n     */\n    this.sourceImagery_ = new Array(numSources);\n\n    /**\n     * @type {Array<Array<GeoTIFFImage>>}\n     * @private\n     */\n    this.sourceMasks_ = new Array(numSources);\n\n    /**\n     * @type {Array<number>}\n     * @private\n     */\n    this.resolutionFactors_ = new Array(numSources);\n\n    /**\n     * @type {Array<number>}\n     * @private\n     */\n    this.samplesPerPixel_;\n\n    /**\n     * @type {Array<Array<number>>}\n     * @private\n     */\n    this.nodataValues_;\n\n    /**\n     * @type {Array<Array<GDALMetadata>>}\n     * @private\n     */\n    this.metadata_;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.normalize_ = options.normalize !== false;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.addAlpha_ = false;\n\n    /**\n     * @type {Error}\n     * @private\n     */\n    this.error_ = null;\n\n    /**\n     * @type {true|false|'auto'}\n     */\n    this.convertToRGB_ = options.convertToRGB || false;\n\n    this.setKey(this.sourceInfo_.map((source) => source.url).join(','));\n\n    const self = this;\n    const requests = new Array(numSources);\n    for (let i = 0; i < numSources; ++i) {\n      requests[i] = getImagesForSource(\n        this.sourceInfo_[i],\n        this.sourceOptions_\n      );\n    }\n    Promise.all(requests)\n      .then(function (sources) {\n        self.configure_(sources);\n      })\n      .catch(function (error) {\n        logError(error);\n        self.error_ = error;\n        self.setState('error');\n      });\n  }\n\n  /**\n   * @return {Error} 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   * geotiffSource.on('change', () => {\n   *   if (geotiffSource.getState() === 'error') {\n   *     console.error(geotiffSource.getError());\n   *   }\n   * });\n   * ```\n   */\n  getError() {\n    return this.error_;\n  }\n\n  /**\n   * Determine the projection of the images in this GeoTIFF.\n   * The default implementation looks at the ProjectedCSTypeGeoKey and the GeographicTypeGeoKey\n   * of each image in turn.\n   * You can override this method in a subclass to support more projections.\n   *\n   * @param {Array<Array<GeoTIFFImage>>} sources Each source is a list of images\n   * from a single GeoTIFF.\n   */\n  determineProjection(sources) {\n    const firstSource = sources[0];\n    for (let i = firstSource.length - 1; i >= 0; --i) {\n      const image = firstSource[i];\n      const projection = getProjection(image);\n      if (projection) {\n        this.projection = projection;\n        break;\n      }\n    }\n  }\n\n  /**\n   * Configure the tile grid based on images within the source GeoTIFFs.  Each GeoTIFF\n   * must have the same internal tiled structure.\n   * @param {Array<Array<GeoTIFFImage>>} sources Each source is a list of images\n   * from a single GeoTIFF.\n   * @private\n   */\n  configure_(sources) {\n    let extent;\n    let origin;\n    let commonRenderTileSizes;\n    let commonSourceTileSizes;\n    let resolutions;\n    const samplesPerPixel = new Array(sources.length);\n    const nodataValues = new Array(sources.length);\n    const metadata = new Array(sources.length);\n    let minZoom = 0;\n\n    const sourceCount = sources.length;\n    for (let sourceIndex = 0; sourceIndex < sourceCount; ++sourceIndex) {\n      const images = [];\n      const masks = [];\n      sources[sourceIndex].forEach((item) => {\n        if (isMask(item)) {\n          masks.push(item);\n        } else {\n          images.push(item);\n        }\n      });\n\n      const imageCount = images.length;\n      if (masks.length > 0 && masks.length !== imageCount) {\n        throw new Error(\n          `Expected one mask per image found ${masks.length} masks and ${imageCount} images`\n        );\n      }\n\n      let sourceExtent;\n      let sourceOrigin;\n      const sourceTileSizes = new Array(imageCount);\n      const renderTileSizes = new Array(imageCount);\n      const sourceResolutions = new Array(imageCount);\n\n      nodataValues[sourceIndex] = new Array(imageCount);\n      metadata[sourceIndex] = new Array(imageCount);\n\n      for (let imageIndex = 0; imageIndex < imageCount; ++imageIndex) {\n        const image = images[imageIndex];\n        const nodataValue = image.getGDALNoData();\n        metadata[sourceIndex][imageIndex] = image.getGDALMetadata(0);\n        nodataValues[sourceIndex][imageIndex] = nodataValue;\n\n        const wantedSamples = this.sourceInfo_[sourceIndex].bands;\n        samplesPerPixel[sourceIndex] = wantedSamples\n          ? wantedSamples.length\n          : image.getSamplesPerPixel();\n        const level = imageCount - (imageIndex + 1);\n\n        if (!sourceExtent) {\n          sourceExtent = getBoundingBox(image);\n        }\n\n        if (!sourceOrigin) {\n          sourceOrigin = getOrigin(image);\n        }\n\n        const imageResolutions = getResolutions(image, images[0]);\n        sourceResolutions[level] = imageResolutions[0];\n\n        const sourceTileSize = [image.getTileWidth(), image.getTileHeight()];\n\n        // request larger blocks for untiled layouts\n        if (\n          sourceTileSize[0] !== sourceTileSize[1] &&\n          sourceTileSize[1] < defaultTileSize\n        ) {\n          sourceTileSize[0] = defaultTileSize;\n          sourceTileSize[1] = defaultTileSize;\n        }\n\n        sourceTileSizes[level] = sourceTileSize;\n\n        const aspectRatio = imageResolutions[0] / Math.abs(imageResolutions[1]);\n        renderTileSizes[level] = [\n          sourceTileSize[0],\n          sourceTileSize[1] / aspectRatio,\n        ];\n      }\n\n      if (!extent) {\n        extent = sourceExtent;\n      } else {\n        getIntersection(extent, sourceExtent, extent);\n      }\n\n      if (!origin) {\n        origin = sourceOrigin;\n      } else {\n        const message = `Origin mismatch for source ${sourceIndex}, got [${sourceOrigin}] but expected [${origin}]`;\n        assertEqual(origin, sourceOrigin, 0, message, this.viewRejector);\n      }\n\n      if (!resolutions) {\n        resolutions = sourceResolutions;\n        this.resolutionFactors_[sourceIndex] = 1;\n      } else {\n        if (resolutions.length - minZoom > sourceResolutions.length) {\n          minZoom = resolutions.length - sourceResolutions.length;\n        }\n        const resolutionFactor =\n          resolutions[resolutions.length - 1] /\n          sourceResolutions[sourceResolutions.length - 1];\n        this.resolutionFactors_[sourceIndex] = resolutionFactor;\n        const scaledSourceResolutions = sourceResolutions.map(\n          (resolution) => (resolution *= resolutionFactor)\n        );\n        const message = `Resolution mismatch for source ${sourceIndex}, got [${scaledSourceResolutions}] but expected [${resolutions}]`;\n        assertEqual(\n          resolutions.slice(minZoom, resolutions.length),\n          scaledSourceResolutions,\n          0.02,\n          message,\n          this.viewRejector\n        );\n      }\n\n      if (!commonRenderTileSizes) {\n        commonRenderTileSizes = renderTileSizes;\n      } else {\n        assertEqual(\n          commonRenderTileSizes.slice(minZoom, commonRenderTileSizes.length),\n          renderTileSizes,\n          0.01,\n          `Tile size mismatch for source ${sourceIndex}`,\n          this.viewRejector\n        );\n      }\n\n      if (!commonSourceTileSizes) {\n        commonSourceTileSizes = sourceTileSizes;\n      } else {\n        assertEqual(\n          commonSourceTileSizes.slice(minZoom, commonSourceTileSizes.length),\n          sourceTileSizes,\n          0,\n          `Tile size mismatch for source ${sourceIndex}`,\n          this.viewRejector\n        );\n      }\n\n      this.sourceImagery_[sourceIndex] = images.reverse();\n      this.sourceMasks_[sourceIndex] = masks.reverse();\n    }\n\n    for (let i = 0, ii = this.sourceImagery_.length; i < ii; ++i) {\n      const sourceImagery = this.sourceImagery_[i];\n      while (sourceImagery.length < resolutions.length) {\n        sourceImagery.unshift(undefined);\n      }\n    }\n\n    if (!this.getProjection()) {\n      this.determineProjection(sources);\n    }\n\n    this.samplesPerPixel_ = samplesPerPixel;\n    this.nodataValues_ = nodataValues;\n    this.metadata_ = metadata;\n\n    // decide if we need to add an alpha band to handle nodata\n    outer: for (let sourceIndex = 0; sourceIndex < sourceCount; ++sourceIndex) {\n      // option 1: source is configured with a nodata value\n      if (this.sourceInfo_[sourceIndex].nodata !== undefined) {\n        this.addAlpha_ = true;\n        break;\n      }\n      if (this.sourceMasks_[sourceIndex].length) {\n        this.addAlpha_ = true;\n        break;\n      }\n\n      const values = nodataValues[sourceIndex];\n\n      // option 2: check image metadata for limited bands\n      const bands = this.sourceInfo_[sourceIndex].bands;\n      if (bands) {\n        for (let i = 0; i < bands.length; ++i) {\n          if (values[bands[i] - 1] !== null) {\n            this.addAlpha_ = true;\n            break outer;\n          }\n        }\n        continue;\n      }\n\n      // option 3: check image metadata for all bands\n      for (let imageIndex = 0; imageIndex < values.length; ++imageIndex) {\n        if (values[imageIndex] !== null) {\n          this.addAlpha_ = true;\n          break outer;\n        }\n      }\n    }\n\n    let bandCount = this.addAlpha_ ? 1 : 0;\n    for (let sourceIndex = 0; sourceIndex < sourceCount; ++sourceIndex) {\n      bandCount += samplesPerPixel[sourceIndex];\n    }\n    this.bandCount = bandCount;\n\n    const tileGrid = new TileGrid({\n      extent: extent,\n      minZoom: minZoom,\n      origin: origin,\n      resolutions: resolutions,\n      tileSizes: commonRenderTileSizes,\n    });\n\n    this.tileGrid = tileGrid;\n    this.setTileSizes(commonSourceTileSizes);\n\n    this.setLoader(this.loadTile_.bind(this));\n    this.setState('ready');\n\n    const zoom = 1;\n    if (resolutions.length === 2) {\n      resolutions = [resolutions[0], resolutions[1], resolutions[1] / 2];\n    } else if (resolutions.length === 1) {\n      resolutions = [resolutions[0] * 2, resolutions[0], resolutions[0] / 2];\n    }\n\n    this.viewResolver({\n      showFullExtent: true,\n      projection: this.projection,\n      resolutions: resolutions,\n      center: toUserCoordinate(getCenter(extent), this.projection),\n      extent: toUserExtent(extent, this.projection),\n      zoom: zoom,\n    });\n  }\n\n  /**\n   * @param {number} z The z tile index.\n   * @param {number} x The x tile index.\n   * @param {number} y The y tile index.\n   * @return {Promise} The composed tile data.\n   * @private\n   */\n  loadTile_(z, x, y) {\n    const sourceTileSize = this.getTileSize(z);\n    const sourceCount = this.sourceImagery_.length;\n    const requests = new Array(sourceCount * 2);\n    const nodataValues = this.nodataValues_;\n    const sourceInfo = this.sourceInfo_;\n    const pool = getWorkerPool();\n    for (let sourceIndex = 0; sourceIndex < sourceCount; ++sourceIndex) {\n      const source = sourceInfo[sourceIndex];\n      const resolutionFactor = this.resolutionFactors_[sourceIndex];\n      const pixelBounds = [\n        Math.round(x * (sourceTileSize[0] * resolutionFactor)),\n        Math.round(y * (sourceTileSize[1] * resolutionFactor)),\n        Math.round((x + 1) * (sourceTileSize[0] * resolutionFactor)),\n        Math.round((y + 1) * (sourceTileSize[1] * resolutionFactor)),\n      ];\n      const image = this.sourceImagery_[sourceIndex][z];\n      let samples;\n      if (source.bands) {\n        samples = source.bands.map(function (bandNumber) {\n          return bandNumber - 1;\n        });\n      }\n\n      /** @type {number|Array<number>} */\n      let fillValue;\n      if ('nodata' in source && source.nodata !== null) {\n        fillValue = source.nodata;\n      } else {\n        if (!samples) {\n          fillValue = nodataValues[sourceIndex];\n        } else {\n          fillValue = samples.map(function (sampleIndex) {\n            return nodataValues[sourceIndex][sampleIndex];\n          });\n        }\n      }\n\n      const readOptions = {\n        window: pixelBounds,\n        width: sourceTileSize[0],\n        height: sourceTileSize[1],\n        samples: samples,\n        fillValue: fillValue,\n        pool: pool,\n        interleave: false,\n      };\n      if (readRGB(this.convertToRGB_, image)) {\n        requests[sourceIndex] = image.readRGB(readOptions);\n      } else {\n        requests[sourceIndex] = image.readRasters(readOptions);\n      }\n\n      // requests after `sourceCount` are for mask data (if any)\n      const maskIndex = sourceCount + sourceIndex;\n      const mask = this.sourceMasks_[sourceIndex][z];\n      if (!mask) {\n        requests[maskIndex] = Promise.resolve(null);\n        continue;\n      }\n\n      requests[maskIndex] = mask.readRasters({\n        window: pixelBounds,\n        width: sourceTileSize[0],\n        height: sourceTileSize[1],\n        samples: [0],\n        pool: pool,\n        interleave: false,\n      });\n    }\n\n    return Promise.all(requests)\n      .then(this.composeTile_.bind(this, sourceTileSize))\n      .catch(function (error) {\n        logError(error);\n        throw error;\n      });\n  }\n\n  /**\n   * @param {import(\"../size.js\").Size} sourceTileSize The source tile size.\n   * @param {Array} sourceSamples The source samples.\n   * @return {import(\"../DataTile.js\").Data} The composed tile data.\n   * @private\n   */\n  composeTile_(sourceTileSize, sourceSamples) {\n    const metadata = this.metadata_;\n    const sourceInfo = this.sourceInfo_;\n    const sourceCount = this.sourceImagery_.length;\n    const bandCount = this.bandCount;\n    const samplesPerPixel = this.samplesPerPixel_;\n    const nodataValues = this.nodataValues_;\n    const normalize = this.normalize_;\n    const addAlpha = this.addAlpha_;\n\n    const pixelCount = sourceTileSize[0] * sourceTileSize[1];\n    const dataLength = pixelCount * bandCount;\n\n    /** @type {Uint8Array|Float32Array} */\n    let data;\n    if (normalize) {\n      data = new Uint8Array(dataLength);\n    } else {\n      data = new Float32Array(dataLength);\n    }\n\n    let dataIndex = 0;\n    for (let pixelIndex = 0; pixelIndex < pixelCount; ++pixelIndex) {\n      let transparent = addAlpha;\n      for (let sourceIndex = 0; sourceIndex < sourceCount; ++sourceIndex) {\n        const source = sourceInfo[sourceIndex];\n\n        let min = source.min;\n        let max = source.max;\n        let gain, bias;\n        if (normalize) {\n          const stats = metadata[sourceIndex][0];\n          if (min === undefined) {\n            if (stats && STATISTICS_MINIMUM in stats) {\n              min = parseFloat(stats[STATISTICS_MINIMUM]);\n            } else {\n              min = getMinForDataType(sourceSamples[sourceIndex][0]);\n            }\n          }\n          if (max === undefined) {\n            if (stats && STATISTICS_MAXIMUM in stats) {\n              max = parseFloat(stats[STATISTICS_MAXIMUM]);\n            } else {\n              max = getMaxForDataType(sourceSamples[sourceIndex][0]);\n            }\n          }\n\n          gain = 255 / (max - min);\n          bias = -min * gain;\n        }\n\n        for (\n          let sampleIndex = 0;\n          sampleIndex < samplesPerPixel[sourceIndex];\n          ++sampleIndex\n        ) {\n          const sourceValue =\n            sourceSamples[sourceIndex][sampleIndex][pixelIndex];\n\n          let value;\n          if (normalize) {\n            value = clamp(gain * sourceValue + bias, 0, 255);\n          } else {\n            value = sourceValue;\n          }\n\n          if (!addAlpha) {\n            data[dataIndex] = value;\n          } else {\n            let nodata = source.nodata;\n            if (nodata === undefined) {\n              let bandIndex;\n              if (source.bands) {\n                bandIndex = source.bands[sampleIndex] - 1;\n              } else {\n                bandIndex = sampleIndex;\n              }\n              nodata = nodataValues[sourceIndex][bandIndex];\n            }\n\n            const nodataIsNaN = isNaN(nodata);\n            if (\n              (!nodataIsNaN && sourceValue !== nodata) ||\n              (nodataIsNaN && !isNaN(sourceValue))\n            ) {\n              transparent = false;\n              data[dataIndex] = value;\n            }\n          }\n          dataIndex++;\n        }\n        if (!transparent) {\n          const maskIndex = sourceCount + sourceIndex;\n          const mask = sourceSamples[maskIndex];\n          if (mask && !mask[0][pixelIndex]) {\n            transparent = true;\n          }\n        }\n      }\n      if (addAlpha) {\n        if (!transparent) {\n          data[dataIndex] = 255;\n        }\n        dataIndex++;\n      }\n    }\n\n    return data;\n  }\n}\n\n/**\n * Get a promise for view properties based on the source.  Use the result of this function\n * as the `view` option in a map constructor.\n *\n *     const source = new GeoTIFF(options);\n *\n *     const map = new Map({\n *       target: 'map',\n *       layers: [\n *         new TileLayer({\n *           source: source,\n *         }),\n *       ],\n *       view: source.getView(),\n *     });\n *\n * @function\n * @return {Promise<import(\"../View.js\").ViewOptions>} A promise for view-related properties.\n * @api\n *\n */\nGeoTIFFSource.prototype.getView;\n\nexport default GeoTIFFSource;\n","/**\n * @module ol/source/Zoomify\n */\nimport {DEFAULT_TILE_SIZE} from '../tilegrid/common.js';\n\nimport ImageTile from '../ImageTile.js';\nimport TileGrid from '../tilegrid/TileGrid.js';\nimport TileImage from './TileImage.js';\nimport TileState from '../TileState.js';\nimport {createCanvasContext2D} from '../dom.js';\nimport {createFromTileUrlFunctions, expandUrl} from '../tileurlfunction.js';\nimport {getCenter} from '../extent.js';\nimport {toSize} from '../size.js';\n\n/**\n * @typedef {'default' | 'truncated'} TierSizeCalculation\n */\n\nexport class CustomTile extends ImageTile {\n  /**\n   * @param {import(\"../size.js\").Size} tileSize Full tile size.\n   * @param {import(\"../tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n   * @param {import(\"../TileState.js\").default} state State.\n   * @param {string} src Image source URI.\n   * @param {?string} crossOrigin Cross origin.\n   * @param {import(\"../Tile.js\").LoadFunction} tileLoadFunction Tile load function.\n   * @param {import(\"../Tile.js\").Options} [options] Tile options.\n   */\n  constructor(\n    tileSize,\n    tileCoord,\n    state,\n    src,\n    crossOrigin,\n    tileLoadFunction,\n    options\n  ) {\n    super(tileCoord, state, src, crossOrigin, tileLoadFunction, options);\n\n    /**\n     * @private\n     * @type {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement}\n     */\n    this.zoomifyImage_ = null;\n\n    /**\n     * @type {import(\"../size.js\").Size}\n     */\n    this.tileSize_ = tileSize;\n  }\n\n  /**\n   * Get the image element for this tile.\n   * @return {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} Image.\n   */\n  getImage() {\n    if (this.zoomifyImage_) {\n      return this.zoomifyImage_;\n    }\n    const image = super.getImage();\n    if (this.state == TileState.LOADED) {\n      const tileSize = this.tileSize_;\n      if (image.width == tileSize[0] && image.height == tileSize[1]) {\n        this.zoomifyImage_ = image;\n        return image;\n      }\n      const context = createCanvasContext2D(tileSize[0], tileSize[1]);\n      context.drawImage(image, 0, 0);\n      this.zoomifyImage_ = context.canvas;\n      return context.canvas;\n    }\n    return image;\n  }\n}\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {number} [cacheSize] Initial tile cache size. Will auto-grow to hold at least the number of tiles in the viewport.\n * @property {null|string} [crossOrigin] The `crossOrigin` attribute for loaded images.  Note that\n * you must provide a `crossOrigin` value  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 {import(\"../proj.js\").ProjectionLike} [projection] Projection.\n * @property {number} [tilePixelRatio] The pixel ratio used by the tile service. For example, if the tile service advertizes 256px by 256px tiles but actually sends 512px by 512px images (for retina/hidpi devices) then `tilePixelRatio` should be set to `2`\n * @property {number} [reprojectionErrorThreshold=0.5] Maximum allowed reprojection error (in pixels).\n * Higher values can increase reprojection performance, but decrease precision.\n * @property {string} url URL template or base URL of the Zoomify service.\n * A base URL is the fixed part\n * of the URL, excluding the tile group, z, x, and y folder structure, e.g.\n * `http://my.zoomify.info/IMAGE.TIF/`. A URL template must include\n * `{TileGroup}`, `{x}`, `{y}`, and `{z}` placeholders, e.g.\n * `http://my.zoomify.info/IMAGE.TIF/{TileGroup}/{z}-{x}-{y}.jpg`.\n * Internet Imaging Protocol (IIP) with JTL extension can be also used with\n * `{tileIndex}` and `{z}` placeholders, e.g.\n * `http://my.zoomify.info?FIF=IMAGE.TIF&JTL={z},{tileIndex}`.\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 {TierSizeCalculation} [tierSizeCalculation] Tier size calculation method: `default` or `truncated`.\n * @property {import(\"../size.js\").Size} size Size.\n * @property {import(\"../extent.js\").Extent} [extent] Extent for the TileGrid that is created.\n * Default sets the TileGrid in the\n * fourth quadrant, meaning extent is `[0, -height, width, 0]`. To change the\n * extent to the first quadrant (the default for OpenLayers 2) set the extent\n * as `[0, 0, width, height]`.\n * @property {number} [transition] Duration of the opacity transition for rendering.\n * To disable the opacity transition, pass `transition: 0`.\n * @property {number} [tileSize=256] Tile size. Same tile size is used for all zoom levels.\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 Zoomify format (both Zoomify and Internet\n * Imaging Protocol are supported).\n * @api\n */\nclass Zoomify extends TileImage {\n  /**\n   * @param {Options} options Options.\n   */\n  constructor(options) {\n    const size = options.size;\n    const tierSizeCalculation =\n      options.tierSizeCalculation !== undefined\n        ? options.tierSizeCalculation\n        : 'default';\n\n    const tilePixelRatio = options.tilePixelRatio || 1;\n    const imageWidth = size[0];\n    const imageHeight = size[1];\n    const tierSizeInTiles = [];\n    const tileSize = options.tileSize || DEFAULT_TILE_SIZE;\n    let tileSizeForTierSizeCalculation = tileSize * tilePixelRatio;\n\n    switch (tierSizeCalculation) {\n      case 'default':\n        while (\n          imageWidth > tileSizeForTierSizeCalculation ||\n          imageHeight > tileSizeForTierSizeCalculation\n        ) {\n          tierSizeInTiles.push([\n            Math.ceil(imageWidth / tileSizeForTierSizeCalculation),\n            Math.ceil(imageHeight / tileSizeForTierSizeCalculation),\n          ]);\n          tileSizeForTierSizeCalculation += tileSizeForTierSizeCalculation;\n        }\n        break;\n      case 'truncated':\n        let width = imageWidth;\n        let height = imageHeight;\n        while (\n          width > tileSizeForTierSizeCalculation ||\n          height > tileSizeForTierSizeCalculation\n        ) {\n          tierSizeInTiles.push([\n            Math.ceil(width / tileSizeForTierSizeCalculation),\n            Math.ceil(height / tileSizeForTierSizeCalculation),\n          ]);\n          width >>= 1;\n          height >>= 1;\n        }\n        break;\n      default:\n        throw new Error('Unknown `tierSizeCalculation` configured');\n    }\n\n    tierSizeInTiles.push([1, 1]);\n    tierSizeInTiles.reverse();\n\n    const resolutions = [tilePixelRatio];\n    const tileCountUpToTier = [0];\n    for (let i = 1, ii = tierSizeInTiles.length; i < ii; i++) {\n      resolutions.push(tilePixelRatio << i);\n      tileCountUpToTier.push(\n        tierSizeInTiles[i - 1][0] * tierSizeInTiles[i - 1][1] +\n          tileCountUpToTier[i - 1]\n      );\n    }\n    resolutions.reverse();\n\n    const tileGrid = new TileGrid({\n      tileSize: tileSize,\n      extent: options.extent || [0, -imageHeight, imageWidth, 0],\n      resolutions: resolutions,\n    });\n\n    let url = options.url;\n    if (url && !url.includes('{TileGroup}') && !url.includes('{tileIndex}')) {\n      url += '{TileGroup}/{z}-{x}-{y}.jpg';\n    }\n    const urls = expandUrl(url);\n\n    let tileWidth = tileSize * tilePixelRatio;\n\n    /**\n     * @param {string} template Template.\n     * @return {import(\"../Tile.js\").UrlFunction} Tile URL function.\n     */\n    function createFromTemplate(template) {\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 tileCoordZ = tileCoord[0];\n          const tileCoordX = tileCoord[1];\n          const tileCoordY = tileCoord[2];\n          const tileIndex =\n            tileCoordX + tileCoordY * tierSizeInTiles[tileCoordZ][0];\n          const tileGroup =\n            ((tileIndex + tileCountUpToTier[tileCoordZ]) / tileWidth) | 0;\n          const localContext = {\n            'z': tileCoordZ,\n            'x': tileCoordX,\n            'y': tileCoordY,\n            'tileIndex': tileIndex,\n            'TileGroup': 'TileGroup' + tileGroup,\n          };\n          return template.replace(/\\{(\\w+?)\\}/g, function (m, p) {\n            return localContext[p];\n          });\n        }\n      );\n    }\n\n    const tileUrlFunction = createFromTileUrlFunctions(\n      urls.map(createFromTemplate)\n    );\n\n    const ZoomifyTileClass = CustomTile.bind(\n      null,\n      toSize(tileSize * tilePixelRatio)\n    );\n\n    super({\n      attributions: options.attributions,\n      cacheSize: options.cacheSize,\n      crossOrigin: options.crossOrigin,\n      interpolate: options.interpolate,\n      projection: options.projection,\n      tilePixelRatio: tilePixelRatio,\n      reprojectionErrorThreshold: options.reprojectionErrorThreshold,\n      tileClass: ZoomifyTileClass,\n      tileGrid: tileGrid,\n      tileUrlFunction: tileUrlFunction,\n      transition: options.transition,\n    });\n\n    /**\n     * @type {number|import(\"../array.js\").NearestDirectionFunction}\n     */\n    this.zDirection = options.zDirection;\n\n    // Server retina tile detection (non-standard):\n    // Try loading the center tile for the highest resolution. If it is not\n    // available, we are dealing with retina tiles, and need to adjust the\n    // tile url calculation.\n    const tileUrl = tileGrid.getTileCoordForCoordAndResolution(\n      getCenter(tileGrid.getExtent()),\n      resolutions[resolutions.length - 1]\n    );\n    const testTileUrl = tileUrlFunction(tileUrl, 1, null);\n    const image = new Image();\n    image.addEventListener('error', () => {\n      tileWidth = tileSize;\n      this.changed();\n    });\n    image.src = testTileUrl;\n  }\n}\n\nexport default Zoomify;\n","/**\n * @module ol/format/IIIFInfo\n */\n\nimport {assert} from '../asserts.js';\n\n/**\n * @typedef {Object} PreferredOptions\n * @property {string} [format] Preferred image format. Will be used if the image information\n * indicates support for that format.\n * @property {string} [quality] IIIF image qualitiy.  Will be used if the image information\n * indicates support for that quality.\n */\n\n/**\n * @typedef {Object} SupportedFeatures\n * @property {Array<string>} [supports] Supported IIIF image size and region\n * calculation features.\n * @property {Array<string>} [formats] Supported image formats.\n * @property {Array<string>} [qualities] Supported IIIF image qualities.\n */\n\n/**\n * @typedef {Object} TileInfo\n * @property {Array<number>} scaleFactors Supported resolution scaling factors.\n * @property {number} width Tile width in pixels.\n * @property {number} [height] Tile height in pixels. Same as tile width if height is\n * not given.\n */\n\n/**\n * @typedef {Object} IiifProfile\n * @property {Array<string>} [formats] Supported image formats for the image service.\n * @property {Array<string>} [qualities] Supported IIIF image qualities.\n * @property {Array<string>} [supports] Supported features.\n * @property {number} [maxArea] Maximum area (pixels) available for this image service.\n * @property {number} [maxHeight] Maximum height.\n * @property {number} [maxWidth] Maximum width.\n */\n\n/**\n * @typedef {Object<string,string|number|Array<number|string|IiifProfile|Object<string, number>|TileInfo>>}\n *    ImageInformationResponse\n */\n\n/**\n * Enum representing the major IIIF Image API versions\n * @enum {string}\n */\nexport const Versions = {\n  VERSION1: 'version1',\n  VERSION2: 'version2',\n  VERSION3: 'version3',\n};\n\n/**\n * Supported image formats, qualities and supported region / size calculation features\n * for different image API versions and compliance levels\n * @const\n * @type {Object<string, Object<string, SupportedFeatures>>}\n */\nconst IIIF_PROFILE_VALUES = {};\nIIIF_PROFILE_VALUES[Versions.VERSION1] = {\n  'level0': {\n    supports: [],\n    formats: [],\n    qualities: ['native'],\n  },\n  'level1': {\n    supports: ['regionByPx', 'sizeByW', 'sizeByH', 'sizeByPct'],\n    formats: ['jpg'],\n    qualities: ['native'],\n  },\n  'level2': {\n    supports: [\n      'regionByPx',\n      'regionByPct',\n      'sizeByW',\n      'sizeByH',\n      'sizeByPct',\n      'sizeByConfinedWh',\n      'sizeByWh',\n    ],\n    formats: ['jpg', 'png'],\n    qualities: ['native', 'color', 'grey', 'bitonal'],\n  },\n};\nIIIF_PROFILE_VALUES[Versions.VERSION2] = {\n  'level0': {\n    supports: [],\n    formats: ['jpg'],\n    qualities: ['default'],\n  },\n  'level1': {\n    supports: ['regionByPx', 'sizeByW', 'sizeByH', 'sizeByPct'],\n    formats: ['jpg'],\n    qualities: ['default'],\n  },\n  'level2': {\n    supports: [\n      'regionByPx',\n      'regionByPct',\n      'sizeByW',\n      'sizeByH',\n      'sizeByPct',\n      'sizeByConfinedWh',\n      'sizeByDistortedWh',\n      'sizeByWh',\n    ],\n    formats: ['jpg', 'png'],\n    qualities: ['default', 'bitonal'],\n  },\n};\nIIIF_PROFILE_VALUES[Versions.VERSION3] = {\n  'level0': {\n    supports: [],\n    formats: ['jpg'],\n    qualities: ['default'],\n  },\n  'level1': {\n    supports: ['regionByPx', 'regionSquare', 'sizeByW', 'sizeByH', 'sizeByWh'],\n    formats: ['jpg'],\n    qualities: ['default'],\n  },\n  'level2': {\n    supports: [\n      'regionByPx',\n      'regionSquare',\n      'regionByPct',\n      'sizeByW',\n      'sizeByH',\n      'sizeByPct',\n      'sizeByConfinedWh',\n      'sizeByWh',\n    ],\n    formats: ['jpg', 'png'],\n    qualities: ['default'],\n  },\n};\nIIIF_PROFILE_VALUES['none'] = {\n  'none': {\n    supports: [],\n    formats: [],\n    qualities: [],\n  },\n};\n\nconst COMPLIANCE_VERSION1 =\n  /^https?:\\/\\/library\\.stanford\\.edu\\/iiif\\/image-api\\/(?:1\\.1\\/)?compliance\\.html#level[0-2]$/;\nconst COMPLIANCE_VERSION2 =\n  /^https?:\\/\\/iiif\\.io\\/api\\/image\\/2\\/level[0-2](?:\\.json)?$/;\nconst COMPLIANCE_VERSION3 =\n  /(^https?:\\/\\/iiif\\.io\\/api\\/image\\/3\\/level[0-2](?:\\.json)?$)|(^level[0-2]$)/;\n\nfunction generateVersion1Options(iiifInfo) {\n  let levelProfile = iiifInfo.getComplianceLevelSupportedFeatures();\n  // Version 1.0 and 1.1 do not require a profile.\n  if (levelProfile === undefined) {\n    levelProfile = IIIF_PROFILE_VALUES[Versions.VERSION1]['level0'];\n  }\n  return {\n    url:\n      iiifInfo.imageInfo['@id'] === undefined\n        ? undefined\n        : iiifInfo.imageInfo['@id'].replace(/\\/?(?:info\\.json)?$/g, ''),\n    supports: levelProfile.supports,\n    formats: [\n      ...levelProfile.formats,\n      iiifInfo.imageInfo.formats === undefined\n        ? []\n        : iiifInfo.imageInfo.formats,\n    ],\n    qualities: [\n      ...levelProfile.qualities,\n      iiifInfo.imageInfo.qualities === undefined\n        ? []\n        : iiifInfo.imageInfo.qualities,\n    ],\n    resolutions: iiifInfo.imageInfo.scale_factors,\n    tileSize:\n      iiifInfo.imageInfo.tile_width !== undefined\n        ? iiifInfo.imageInfo.tile_height !== undefined\n          ? [iiifInfo.imageInfo.tile_width, iiifInfo.imageInfo.tile_height]\n          : [iiifInfo.imageInfo.tile_width, iiifInfo.imageInfo.tile_width]\n        : iiifInfo.imageInfo.tile_height != undefined\n        ? [iiifInfo.imageInfo.tile_height, iiifInfo.imageInfo.tile_height]\n        : undefined,\n  };\n}\n\nfunction generateVersion2Options(iiifInfo) {\n  const levelProfile = iiifInfo.getComplianceLevelSupportedFeatures(),\n    additionalProfile =\n      Array.isArray(iiifInfo.imageInfo.profile) &&\n      iiifInfo.imageInfo.profile.length > 1,\n    profileSupports =\n      additionalProfile && iiifInfo.imageInfo.profile[1].supports\n        ? iiifInfo.imageInfo.profile[1].supports\n        : [],\n    profileFormats =\n      additionalProfile && iiifInfo.imageInfo.profile[1].formats\n        ? iiifInfo.imageInfo.profile[1].formats\n        : [],\n    profileQualities =\n      additionalProfile && iiifInfo.imageInfo.profile[1].qualities\n        ? iiifInfo.imageInfo.profile[1].qualities\n        : [];\n  return {\n    url: iiifInfo.imageInfo['@id'].replace(/\\/?(?:info\\.json)?$/g, ''),\n    sizes:\n      iiifInfo.imageInfo.sizes === undefined\n        ? undefined\n        : iiifInfo.imageInfo.sizes.map(function (size) {\n            return [size.width, size.height];\n          }),\n    tileSize:\n      iiifInfo.imageInfo.tiles === undefined\n        ? undefined\n        : [\n            iiifInfo.imageInfo.tiles.map(function (tile) {\n              return tile.width;\n            })[0],\n            iiifInfo.imageInfo.tiles.map(function (tile) {\n              return tile.height === undefined ? tile.width : tile.height;\n            })[0],\n          ],\n    resolutions:\n      iiifInfo.imageInfo.tiles === undefined\n        ? undefined\n        : iiifInfo.imageInfo.tiles.map(function (tile) {\n            return tile.scaleFactors;\n          })[0],\n    supports: [...levelProfile.supports, ...profileSupports],\n    formats: [...levelProfile.formats, ...profileFormats],\n    qualities: [...levelProfile.qualities, ...profileQualities],\n  };\n}\n\nfunction generateVersion3Options(iiifInfo) {\n  const levelProfile = iiifInfo.getComplianceLevelSupportedFeatures(),\n    formats =\n      iiifInfo.imageInfo.extraFormats === undefined\n        ? levelProfile.formats\n        : [...levelProfile.formats, ...iiifInfo.imageInfo.extraFormats],\n    preferredFormat =\n      iiifInfo.imageInfo.preferredFormats !== undefined &&\n      Array.isArray(iiifInfo.imageInfo.preferredFormats) &&\n      iiifInfo.imageInfo.preferredFormats.length > 0\n        ? iiifInfo.imageInfo.preferredFormats\n            .filter(function (format) {\n              return ['jpg', 'png', 'gif'].includes(format);\n            })\n            .reduce(function (acc, format) {\n              return acc === undefined && formats.includes(format)\n                ? format\n                : acc;\n            }, undefined)\n        : undefined;\n  return {\n    url: iiifInfo.imageInfo['id'],\n    sizes:\n      iiifInfo.imageInfo.sizes === undefined\n        ? undefined\n        : iiifInfo.imageInfo.sizes.map(function (size) {\n            return [size.width, size.height];\n          }),\n    tileSize:\n      iiifInfo.imageInfo.tiles === undefined\n        ? undefined\n        : [\n            iiifInfo.imageInfo.tiles.map(function (tile) {\n              return tile.width;\n            })[0],\n            iiifInfo.imageInfo.tiles.map(function (tile) {\n              return tile.height;\n            })[0],\n          ],\n    resolutions:\n      iiifInfo.imageInfo.tiles === undefined\n        ? undefined\n        : iiifInfo.imageInfo.tiles.map(function (tile) {\n            return tile.scaleFactors;\n          })[0],\n    supports:\n      iiifInfo.imageInfo.extraFeatures === undefined\n        ? levelProfile.supports\n        : [...levelProfile.supports, ...iiifInfo.imageInfo.extraFeatures],\n    formats: formats,\n    qualities:\n      iiifInfo.imageInfo.extraQualities === undefined\n        ? levelProfile.qualities\n        : [...levelProfile.qualities, ...iiifInfo.imageInfo.extraQualities],\n    preferredFormat: preferredFormat,\n  };\n}\n\nconst versionFunctions = {};\nversionFunctions[Versions.VERSION1] = generateVersion1Options;\nversionFunctions[Versions.VERSION2] = generateVersion2Options;\nversionFunctions[Versions.VERSION3] = generateVersion3Options;\n\n/**\n * @classdesc\n * Format for transforming IIIF Image API image information responses into\n * IIIF tile source ready options\n *\n * @api\n */\nclass IIIFInfo {\n  /**\n   * @param {string|ImageInformationResponse} imageInfo\n   * Deserialized image information JSON response object or JSON response as string\n   */\n  constructor(imageInfo) {\n    this.setImageInfo(imageInfo);\n  }\n\n  /**\n   * @param {string|ImageInformationResponse} imageInfo\n   * Deserialized image information JSON response object or JSON response as string\n   * @api\n   */\n  setImageInfo(imageInfo) {\n    if (typeof imageInfo == 'string') {\n      this.imageInfo = JSON.parse(imageInfo);\n    } else {\n      this.imageInfo = imageInfo;\n    }\n  }\n\n  /**\n   * @return {Versions|undefined} Major IIIF version.\n   * @api\n   */\n  getImageApiVersion() {\n    if (this.imageInfo === undefined) {\n      return undefined;\n    }\n    let context = this.imageInfo['@context'] || 'ol-no-context';\n    if (typeof context == 'string') {\n      context = [context];\n    }\n    for (let i = 0; i < context.length; i++) {\n      switch (context[i]) {\n        case 'http://library.stanford.edu/iiif/image-api/1.1/context.json':\n        case 'http://iiif.io/api/image/1/context.json':\n          return Versions.VERSION1;\n        case 'http://iiif.io/api/image/2/context.json':\n          return Versions.VERSION2;\n        case 'http://iiif.io/api/image/3/context.json':\n          return Versions.VERSION3;\n        case 'ol-no-context':\n          // Image API 1.0 has no '@context'\n          if (\n            this.getComplianceLevelEntryFromProfile(Versions.VERSION1) &&\n            this.imageInfo.identifier\n          ) {\n            return Versions.VERSION1;\n          }\n          break;\n        default:\n      }\n    }\n    assert(\n      false,\n      'Cannot determine IIIF Image API version from provided image information JSON'\n    );\n  }\n\n  /**\n   * @param {Versions} version Optional IIIF image API version\n   * @return {string|undefined} Compliance level as it appears in the IIIF image information\n   * response.\n   */\n  getComplianceLevelEntryFromProfile(version) {\n    if (this.imageInfo === undefined || this.imageInfo.profile === undefined) {\n      return undefined;\n    }\n    if (version === undefined) {\n      version = this.getImageApiVersion();\n    }\n    switch (version) {\n      case Versions.VERSION1:\n        if (COMPLIANCE_VERSION1.test(this.imageInfo.profile)) {\n          return this.imageInfo.profile;\n        }\n        break;\n      case Versions.VERSION3:\n        if (COMPLIANCE_VERSION3.test(this.imageInfo.profile)) {\n          return this.imageInfo.profile;\n        }\n        break;\n      case Versions.VERSION2:\n        if (\n          typeof this.imageInfo.profile === 'string' &&\n          COMPLIANCE_VERSION2.test(this.imageInfo.profile)\n        ) {\n          return this.imageInfo.profile;\n        }\n        if (\n          Array.isArray(this.imageInfo.profile) &&\n          this.imageInfo.profile.length > 0 &&\n          typeof this.imageInfo.profile[0] === 'string' &&\n          COMPLIANCE_VERSION2.test(this.imageInfo.profile[0])\n        ) {\n          return this.imageInfo.profile[0];\n        }\n        break;\n      default:\n    }\n    return undefined;\n  }\n\n  /**\n   * @param {Versions} version Optional IIIF image API version\n   * @return {string} Compliance level, on of 'level0', 'level1' or 'level2' or undefined\n   */\n  getComplianceLevelFromProfile(version) {\n    const complianceLevel = this.getComplianceLevelEntryFromProfile(version);\n    if (complianceLevel === undefined) {\n      return undefined;\n    }\n    const level = complianceLevel.match(/level[0-2](?:\\.json)?$/g);\n    return Array.isArray(level) ? level[0].replace('.json', '') : undefined;\n  }\n\n  /**\n   * @return {SupportedFeatures|undefined} Image formats, qualities and region / size calculation\n   * methods that are supported by the IIIF service.\n   */\n  getComplianceLevelSupportedFeatures() {\n    if (this.imageInfo === undefined) {\n      return undefined;\n    }\n    const version = this.getImageApiVersion();\n    const level = this.getComplianceLevelFromProfile(version);\n    if (level === undefined) {\n      return IIIF_PROFILE_VALUES['none']['none'];\n    }\n    return IIIF_PROFILE_VALUES[version][level];\n  }\n\n  /**\n   * @param {PreferredOptions} [preferredOptions] Optional options for preferred format and quality.\n   * @return {import(\"../source/IIIF.js\").Options|undefined} IIIF tile source ready constructor options.\n   * @api\n   */\n  getTileSourceOptions(preferredOptions) {\n    const options = preferredOptions || {},\n      version = this.getImageApiVersion();\n    if (version === undefined) {\n      return undefined;\n    }\n    const imageOptions =\n      version === undefined ? undefined : versionFunctions[version](this);\n    if (imageOptions === undefined) {\n      return undefined;\n    }\n    return {\n      url: imageOptions.url,\n      version: version,\n      size: [this.imageInfo.width, this.imageInfo.height],\n      sizes: imageOptions.sizes,\n      format:\n        options.format !== undefined &&\n        imageOptions.formats.includes(options.format)\n          ? options.format\n          : imageOptions.preferredFormat !== undefined\n          ? imageOptions.preferredFormat\n          : 'jpg',\n      supports: imageOptions.supports,\n      quality:\n        options.quality && imageOptions.qualities.includes(options.quality)\n          ? options.quality\n          : imageOptions.qualities.includes('native')\n          ? 'native'\n          : 'default',\n      resolutions: Array.isArray(imageOptions.resolutions)\n        ? imageOptions.resolutions.sort(function (a, b) {\n            return b - a;\n          })\n        : undefined,\n      tileSize: imageOptions.tileSize,\n    };\n  }\n}\n\nexport default IIIFInfo;\n","/**\n * @module ol/source/IIIF\n */\n\nimport TileGrid from '../tilegrid/TileGrid.js';\nimport TileImage from './TileImage.js';\nimport {CustomTile} from './Zoomify.js';\nimport {DEFAULT_TILE_SIZE} from '../tilegrid/common.js';\nimport {Versions} from '../format/IIIFInfo.js';\nimport {assert} from '../asserts.js';\nimport {getTopLeft} from '../extent.js';\nimport {toSize} from '../size.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] Size of the cache.\n * @property {null|string} [crossOrigin] The value for the crossOrigin option of the request.\n * @property {import(\"../extent.js\").Extent} [extent=[0, -height, width, 0]] The extent.\n * @property {string} [format='jpg'] Requested image format.\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.\n * @property {string} [quality] Requested IIIF image quality. Default is 'native'\n * for version 1, 'default' for versions 2 and 3.\n * @property {number} [reprojectionErrorThreshold=0.5] Maximum allowed reprojection error (in pixels).\n * Higher values can increase reprojection performance, but decrease precision.\n * @property {Array<number>} [resolutions] Supported resolutions as given in IIIF 'scaleFactors'\n * @property {import(\"../size.js\").Size} size Size of the image [width, height].\n * @property {Array<import(\"../size.js\").Size>} [sizes] Supported scaled image sizes.\n * Content of the IIIF info.json 'sizes' property, but as array of Size objects.\n * @property {import(\"./Source.js\").State} [state] Source state.\n * @property {Array<string>} [supports=[]] Supported IIIF region and size calculation\n * features.\n * @property {number} [tilePixelRatio] Tile pixel ratio.\n * @property {number|import(\"../size.js\").Size} [tileSize] Tile size.\n * Same tile size is used for all zoom levels. If tile size is a number,\n * a square tile is assumed. If the IIIF image service supports arbitrary\n * tiling (sizeByH, sizeByW, sizeByWh or sizeByPct as well as regionByPx or regionByPct\n * are supported), the default tilesize is 256.\n * @property {number} [transition] Transition.\n * @property {string} [url] Base URL of the IIIF Image service.\n * This should be the same as the IIIF Image ID.\n * @property {import(\"../format/IIIFInfo.js\").Versions} [version=Versions.VERSION2] Service's IIIF Image API version.\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\nfunction formatPercentage(percentage) {\n  return percentage.toLocaleString('en', {maximumFractionDigits: 10});\n}\n\n/**\n * @classdesc\n * Layer source for IIIF Image API services.\n * @api\n */\nclass IIIF extends TileImage {\n  /**\n   * @param {Options} [options] Tile source options. Use {@link import(\"../format/IIIFInfo.js\").IIIFInfo}\n   * to parse Image API service information responses into constructor options.\n   * @api\n   */\n  constructor(options) {\n    /**\n     * @type {Partial<Options>}\n     */\n    const partialOptions = options || {};\n\n    let baseUrl = partialOptions.url || '';\n    baseUrl =\n      baseUrl +\n      (baseUrl.lastIndexOf('/') === baseUrl.length - 1 || baseUrl === ''\n        ? ''\n        : '/');\n    const version = partialOptions.version || Versions.VERSION2;\n    const sizes = partialOptions.sizes || [];\n    const size = partialOptions.size;\n    assert(\n      size != undefined &&\n        Array.isArray(size) &&\n        size.length == 2 &&\n        !isNaN(size[0]) &&\n        size[0] > 0 &&\n        !isNaN(size[1]) &&\n        size[1] > 0,\n      'Missing or invalid `size`'\n    );\n    const width = size[0];\n    const height = size[1];\n    const tileSize = partialOptions.tileSize;\n    const tilePixelRatio = partialOptions.tilePixelRatio || 1;\n    const format = partialOptions.format || 'jpg';\n    const quality =\n      partialOptions.quality ||\n      (partialOptions.version == Versions.VERSION1 ? 'native' : 'default');\n    let resolutions = partialOptions.resolutions || [];\n    const supports = partialOptions.supports || [];\n    const extent = partialOptions.extent || [0, -height, width, 0];\n\n    const supportsListedSizes =\n      sizes != undefined && Array.isArray(sizes) && sizes.length > 0;\n    const supportsListedTiles =\n      tileSize !== undefined &&\n      ((typeof tileSize === 'number' &&\n        Number.isInteger(tileSize) &&\n        tileSize > 0) ||\n        (Array.isArray(tileSize) && tileSize.length > 0));\n    const supportsArbitraryTiling =\n      supports != undefined &&\n      Array.isArray(supports) &&\n      (supports.includes('regionByPx') || supports.includes('regionByPct')) &&\n      (supports.includes('sizeByWh') ||\n        supports.includes('sizeByH') ||\n        supports.includes('sizeByW') ||\n        supports.includes('sizeByPct'));\n\n    let tileWidth, tileHeight, maxZoom;\n\n    resolutions.sort(function (a, b) {\n      return b - a;\n    });\n\n    if (supportsListedTiles || supportsArbitraryTiling) {\n      if (tileSize != undefined) {\n        if (\n          typeof tileSize === 'number' &&\n          Number.isInteger(tileSize) &&\n          tileSize > 0\n        ) {\n          tileWidth = tileSize;\n          tileHeight = tileSize;\n        } else if (Array.isArray(tileSize) && tileSize.length > 0) {\n          if (\n            tileSize.length == 1 ||\n            (tileSize[1] == undefined && Number.isInteger(tileSize[0]))\n          ) {\n            tileWidth = tileSize[0];\n            tileHeight = tileSize[0];\n          }\n          if (tileSize.length == 2) {\n            if (\n              Number.isInteger(tileSize[0]) &&\n              Number.isInteger(tileSize[1])\n            ) {\n              tileWidth = tileSize[0];\n              tileHeight = tileSize[1];\n            } else if (\n              tileSize[0] == undefined &&\n              Number.isInteger(tileSize[1])\n            ) {\n              tileWidth = tileSize[1];\n              tileHeight = tileSize[1];\n            }\n          }\n        }\n      }\n      if (tileWidth === undefined || tileHeight === undefined) {\n        tileWidth = DEFAULT_TILE_SIZE;\n        tileHeight = DEFAULT_TILE_SIZE;\n      }\n      if (resolutions.length == 0) {\n        maxZoom = Math.max(\n          Math.ceil(Math.log(width / tileWidth) / Math.LN2),\n          Math.ceil(Math.log(height / tileHeight) / Math.LN2)\n        );\n        for (let i = maxZoom; i >= 0; i--) {\n          resolutions.push(Math.pow(2, i));\n        }\n      } else {\n        const maxScaleFactor = Math.max(...resolutions);\n        // TODO maxScaleFactor might not be a power to 2\n        maxZoom = Math.round(Math.log(maxScaleFactor) / Math.LN2);\n      }\n    } else {\n      // No tile support.\n      tileWidth = width;\n      tileHeight = height;\n      resolutions = [];\n      if (supportsListedSizes) {\n        /*\n         * 'sizes' provided. Use full region in different resolutions. Every\n         * resolution has only one tile.\n         */\n        sizes.sort(function (a, b) {\n          return a[0] - b[0];\n        });\n        maxZoom = -1;\n        const ignoredSizesIndex = [];\n        for (let i = 0; i < sizes.length; i++) {\n          const resolution = width / sizes[i][0];\n          if (\n            resolutions.length > 0 &&\n            resolutions[resolutions.length - 1] == resolution\n          ) {\n            ignoredSizesIndex.push(i);\n            continue;\n          }\n          resolutions.push(resolution);\n          maxZoom++;\n        }\n        if (ignoredSizesIndex.length > 0) {\n          for (let i = 0; i < ignoredSizesIndex.length; i++) {\n            sizes.splice(ignoredSizesIndex[i] - i, 1);\n          }\n        }\n      } else {\n        // No useful image information at all. Try pseudo tile with full image.\n        resolutions.push(1);\n        sizes.push([width, height]);\n        maxZoom = 0;\n      }\n    }\n\n    const tileGrid = new TileGrid({\n      tileSize: [tileWidth, tileHeight],\n      extent: extent,\n      origin: getTopLeft(extent),\n      resolutions: resolutions,\n    });\n\n    const tileUrlFunction = function (tileCoord, pixelRatio, projection) {\n      let regionParam, sizeParam;\n      const zoom = tileCoord[0];\n      if (zoom > maxZoom) {\n        return;\n      }\n      const tileX = tileCoord[1],\n        tileY = tileCoord[2],\n        scale = resolutions[zoom];\n      if (\n        tileX === undefined ||\n        tileY === undefined ||\n        scale === undefined ||\n        tileX < 0 ||\n        Math.ceil(width / scale / tileWidth) <= tileX ||\n        tileY < 0 ||\n        Math.ceil(height / scale / tileHeight) <= tileY\n      ) {\n        return;\n      }\n      if (supportsArbitraryTiling || supportsListedTiles) {\n        const regionX = tileX * tileWidth * scale,\n          regionY = tileY * tileHeight * scale;\n        let regionW = tileWidth * scale,\n          regionH = tileHeight * scale,\n          sizeW = tileWidth,\n          sizeH = tileHeight;\n        if (regionX + regionW > width) {\n          regionW = width - regionX;\n        }\n        if (regionY + regionH > height) {\n          regionH = height - regionY;\n        }\n        if (regionX + tileWidth * scale > width) {\n          sizeW = Math.floor((width - regionX + scale - 1) / scale);\n        }\n        if (regionY + tileHeight * scale > height) {\n          sizeH = Math.floor((height - regionY + scale - 1) / scale);\n        }\n        if (\n          regionX == 0 &&\n          regionW == width &&\n          regionY == 0 &&\n          regionH == height\n        ) {\n          // canonical full image region parameter is 'full', not 'x,y,w,h'\n          regionParam = 'full';\n        } else if (\n          !supportsArbitraryTiling ||\n          supports.includes('regionByPx')\n        ) {\n          regionParam = regionX + ',' + regionY + ',' + regionW + ',' + regionH;\n        } else if (supports.includes('regionByPct')) {\n          const pctX = formatPercentage((regionX / width) * 100),\n            pctY = formatPercentage((regionY / height) * 100),\n            pctW = formatPercentage((regionW / width) * 100),\n            pctH = formatPercentage((regionH / height) * 100);\n          regionParam = 'pct:' + pctX + ',' + pctY + ',' + pctW + ',' + pctH;\n        }\n        if (\n          version == Versions.VERSION3 &&\n          (!supportsArbitraryTiling || supports.includes('sizeByWh'))\n        ) {\n          sizeParam = sizeW + ',' + sizeH;\n        } else if (!supportsArbitraryTiling || supports.includes('sizeByW')) {\n          sizeParam = sizeW + ',';\n        } else if (supports.includes('sizeByH')) {\n          sizeParam = ',' + sizeH;\n        } else if (supports.includes('sizeByWh')) {\n          sizeParam = sizeW + ',' + sizeH;\n        } else if (supports.includes('sizeByPct')) {\n          sizeParam = 'pct:' + formatPercentage(100 / scale);\n        }\n      } else {\n        regionParam = 'full';\n        if (supportsListedSizes) {\n          const regionWidth = sizes[zoom][0],\n            regionHeight = sizes[zoom][1];\n          if (version == Versions.VERSION3) {\n            if (regionWidth == width && regionHeight == height) {\n              sizeParam = 'max';\n            } else {\n              sizeParam = regionWidth + ',' + regionHeight;\n            }\n          } else {\n            if (regionWidth == width) {\n              sizeParam = 'full';\n            } else {\n              sizeParam = regionWidth + ',';\n            }\n          }\n        } else {\n          sizeParam = version == Versions.VERSION3 ? 'max' : 'full';\n        }\n      }\n      return (\n        baseUrl + regionParam + '/' + sizeParam + '/0/' + quality + '.' + format\n      );\n    };\n\n    const IiifTileClass = CustomTile.bind(\n      null,\n      toSize(tileSize || 256).map(function (size) {\n        return size * tilePixelRatio;\n      })\n    );\n\n    super({\n      attributions: partialOptions.attributions,\n      attributionsCollapsible: partialOptions.attributionsCollapsible,\n      cacheSize: partialOptions.cacheSize,\n      crossOrigin: partialOptions.crossOrigin,\n      interpolate: partialOptions.interpolate,\n      projection: partialOptions.projection,\n      reprojectionErrorThreshold: partialOptions.reprojectionErrorThreshold,\n      state: partialOptions.state,\n      tileClass: IiifTileClass,\n      tileGrid: tileGrid,\n      tilePixelRatio: partialOptions.tilePixelRatio,\n      tileUrlFunction: tileUrlFunction,\n      transition: partialOptions.transition,\n    });\n\n    /**\n     * @type {number|import(\"../array.js\").NearestDirectionFunction}\n     */\n    this.zDirection = partialOptions.zDirection;\n  }\n}\n\nexport default IIIF;\n","/**\n * @module ol/reproj/Image\n */\nimport {ERROR_THRESHOLD} from './common.js';\n\nimport EventType from '../events/EventType.js';\nimport ImageState from '../ImageState.js';\nimport ImageWrapper from '../Image.js';\nimport Triangulation from './Triangulation.js';\nimport {\n  calculateSourceResolution,\n  render as renderReprojected,\n} from '../reproj.js';\nimport {fromResolutionLike} from '../resolution.js';\nimport {\n  getCenter,\n  getHeight,\n  getIntersection,\n  getWidth,\n  isEmpty,\n} from '../extent.js';\nimport {listen, unlistenByKey} from '../events.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}\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   */\n  disposeInternal() {\n    if (this.state == ImageState.LOADING) {\n      this.unlistenSource_();\n    }\n    super.disposeInternal();\n  }\n\n  /**\n   * @return {HTMLCanvasElement} Image.\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   */\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          function (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          this\n        );\n        this.sourceImage_.load();\n      }\n    }\n  }\n\n  /**\n   * @private\n   */\n  unlistenSource_() {\n    unlistenByKey(\n      /** @type {!import(\"../events.js\").EventsKey} */ (this.sourceListenerKey_)\n    );\n    this.sourceListenerKey_ = null;\n  }\n}\n\nexport default ReprojImage;\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 Event from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport ImageState from '../ImageState.js';\nimport ImageWrapper from '../Image.js';\nimport ReprojImage from '../reproj/Image.js';\nimport Source from './Source.js';\nimport {DECIMALS} from './common.js';\nimport {ceil} from '../math.js';\nimport {\n  containsExtent,\n  equals,\n  getCenter,\n  getForViewAndSize,\n  getHeight,\n  getWidth,\n} from '../extent.js';\nimport {equivalent} from '../proj.js';\nimport {fromResolutionLike} from '../resolution.js';\nimport {linearFindNearest} from '../array.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\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types, import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").OnSignature<ImageSourceEventTypes, ImageSourceEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {ImageSourceOnSignature<import(\"../events\").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   */\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/uri\n */\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","/**\n * @module ol/source/arcgisRest\n */\n\nimport {DECIMALS} from './common.js';\nimport {appendParams} from '../uri.js';\nimport {decode} from '../Image.js';\nimport {getHeight, getWidth} from '../extent.js';\nimport {get as getProjection} from '../proj.js';\nimport {getRequestExtent} from './Image.js';\nimport {round} from '../math.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  if (modifiedUrl == baseUrl) {\n    throw new Error('`options.featureTypes` should be an Array');\n  }\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 {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\n  /** @type {import('../Image.js').ImageObjectPromiseLoader} */\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, options.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    if (options.crossOrigin !== null) {\n      image.crossOrigin = options.crossOrigin;\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/source/ImageArcGISRest\n */\n\nimport ImageSource, {defaultImageLoadFunction} from './Image.js';\nimport {createLoader} from './arcgisRest.js';\nimport {decode} from '../Image.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 {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 {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_ = options.params || {};\n\n    /**\n     * @private\n     * @type {import(\"../Image.js\").default}\n     */\n    this.image_ = null;\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   */\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        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.image_ = null;\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.image_ = null;\n      this.changed();\n    }\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.image_ = null;\n    this.changed();\n  }\n}\n\nexport default ImageArcGISRest;\n","/**\n * @module ol/source/ImageCanvas\n */\n\nimport ImageCanvas from '../ImageCanvas.js';\nimport ImageSource from './Image.js';\nimport {\n  containsExtent,\n  getHeight,\n  getWidth,\n  scaleFromCenter,\n} from '../extent.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   */\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/mapguide\n */\n\nimport {appendParams} from '../uri.js';\nimport {decode} from '../Image.js';\nimport {getCenter, getHeight, getWidth} from '../extent.js';\nimport {getRequestExtent} from './Image.js';\n\n/**\n * @typedef {Object} LoaderOptions\n * @property {string} [url] The mapagent 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 {number} [displayDpi=96] The display resolution.\n * @property {number} [metersPerUnit=1] The meters-per-unit value.\n * @property {boolean} [hidpi=true] Use the `ol/Map#pixelRatio` value when requesting\n * the image from the remote server.\n * @property {boolean} [useOverlay] If `true`, will use `GETDYNAMICMAPOVERLAYIMAGE`.\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 {import(\"../extent.js\").Extent} extent The map extents.\n * @param {import(\"../size.js\").Size} size The viewport size.\n * @param {number} metersPerUnit The meters-per-unit value.\n * @param {number} dpi The display resolution.\n * @return {number} The computed map scale.\n */\nfunction getScale(extent, size, metersPerUnit, dpi) {\n  const mcsW = getWidth(extent);\n  const mcsH = getHeight(extent);\n  const devW = size[0];\n  const devH = size[1];\n  const mpp = 0.0254 / dpi;\n  if (devH * mcsW > devW * mcsH) {\n    return (mcsW * metersPerUnit) / (devW * mpp); // width limited\n  }\n  return (mcsH * metersPerUnit) / (devH * mpp); // height limited\n}\n\n/**\n * @param {string} baseUrl The mapagent 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 * @param {boolean} useOverlay If `true`, will use `GETDYNAMICMAPOVERLAYIMAGE`.\n * @param {number} metersPerUnit The meters-per-unit value.\n * @param {number} displayDpi The display resolution.\n * @return {string} The mapagent map image request URL.\n */\nfunction getUrl(\n  baseUrl,\n  params,\n  extent,\n  size,\n  useOverlay,\n  metersPerUnit,\n  displayDpi\n) {\n  const scale = getScale(extent, size, metersPerUnit, displayDpi);\n  const center = getCenter(extent);\n  const baseParams = {\n    'OPERATION': useOverlay ? 'GETDYNAMICMAPOVERLAYIMAGE' : 'GETMAPIMAGE',\n    'VERSION': '2.0.0',\n    'LOCALE': 'en',\n    'CLIENTAGENT': 'ol/source/ImageMapGuide source',\n    'CLIP': '1',\n    'SETDISPLAYDPI': displayDpi,\n    'SETDISPLAYWIDTH': Math.round(size[0]),\n    'SETDISPLAYHEIGHT': Math.round(size[1]),\n    'SETVIEWSCALE': scale,\n    'SETVIEWCENTERX': center[0],\n    'SETVIEWCENTERY': center[1],\n  };\n  Object.assign(baseParams, params);\n  return appendParams(baseUrl, baseParams);\n}\n\n/**\n * Creates a loader for MapGuide 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 || decode;\n\n  /** @type {import('../Image.js').ImageObjectPromiseLoader} */\n  return function (extent, resolution, pixelRatio) {\n    const image = new Image();\n    if (options.crossOrigin !== null) {\n      image.crossOrigin = options.crossOrigin;\n    }\n    extent = getRequestExtent(extent, resolution, pixelRatio, options.ratio);\n    const width = getWidth(extent) / resolution;\n    const height = getHeight(extent) / resolution;\n    const size = [width * pixelRatio, height * pixelRatio];\n    const src = getUrl(\n      options.url,\n      options.params,\n      extent,\n      size,\n      options.useOverlay,\n      options.metersPerUnit || 1,\n      options.displayDpi || 96\n    );\n    return load(image, src).then((image) => ({image, extent, pixelRatio}));\n  };\n}\n","/**\n * @module ol/source/ImageMapGuide\n */\n\nimport ImageSource, {defaultImageLoadFunction} from './Image.js';\nimport {createLoader} from './mapguide.js';\nimport {decode} from '../Image.js';\n\n/**\n * @typedef {Object} Options\n * @property {string} [url] The mapagent 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 {number} [displayDpi=96] The display resolution.\n * @property {number} [metersPerUnit=1] The meters-per-unit value.\n * @property {boolean} [hidpi=true] Use the `ol/Map#pixelRatio` value when requesting\n * the image from the remote server.\n * @property {boolean} [useOverlay] If `true`, will use `GETDYNAMICMAPOVERLAYIMAGE`.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. Default is the view projection.\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 {Array<number>} [resolutions] Resolutions.\n * If specified, requests will be made for these resolutions only.\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} [params] Additional parameters.\n */\n\n/**\n * @classdesc\n * Source for images from Mapguide servers\n *\n * @fires module:ol/source/Image.ImageSourceEvent\n * @api\n */\nclass ImageMapGuide extends ImageSource {\n  /**\n   * @param {Options} options ImageMapGuide options.\n   */\n  constructor(options) {\n    super({\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 {number}\n     */\n    this.displayDpi_ =\n      options.displayDpi !== undefined ? options.displayDpi : 96;\n\n    /**\n     * @private\n     * @type {!Object}\n     */\n    this.params_ = options.params || {};\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 {boolean}\n     */\n    this.hidpi_ = options.hidpi !== undefined ? options.hidpi : true;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.metersPerUnit_ =\n      options.metersPerUnit !== undefined ? options.metersPerUnit : 1;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.ratio_ = options.ratio !== undefined ? options.ratio : 1;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.useOverlay_ =\n      options.useOverlay !== undefined ? options.useOverlay : false;\n\n    /**\n     * @private\n     * @type {import(\"../Image.js\").default}\n     */\n    this.image_ = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.renderedRevision_ = 0;\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   */\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        params: this.params_,\n        hidpi: this.hidpi_,\n        metersPerUnit: this.metersPerUnit_,\n        url: this.url_,\n        useOverlay: this.useOverlay_,\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   * 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   * Set the image load function of the MapGuide source.\n   * @param {import(\"../Image.js\").LoadFunction} imageLoadFunction Image load function.\n   * @api\n   */\n  setImageLoadFunction(imageLoadFunction) {\n    this.image_ = null;\n    this.imageLoadFunction_ = imageLoadFunction;\n    this.changed();\n  }\n}\n\nexport default ImageMapGuide;\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 {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 image = new Image();\n  if (options.crossOrigin !== null) {\n    image.crossOrigin = options.crossOrigin;\n  }\n\n  return () =>\n    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 * @module ol/source/ImageStatic\n */\n\nimport EventType from '../events/EventType.js';\nimport ImageSource, {defaultImageLoadFunction} from './Image.js';\nimport ImageWrapper, {decode} from '../Image.js';\nimport {createLoader} from './static.js';\nimport {get as getProjection} from '../proj.js';\nimport {intersects} from '../extent.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 {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        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   */\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/wms\n */\n\nimport {DECIMALS} from './common.js';\nimport {appendParams} from '../uri.js';\nimport {compareVersions} from '../string.js';\nimport {decode} from '../Image.js';\nimport {floor, round} from '../math.js';\nimport {getForViewAndSize, getHeight, getWidth} from '../extent.js';\nimport {get as getProjection} from '../proj.js';\nimport {getRequestExtent} from './Image.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  let bbox;\n  const v13 = compareVersions(params['VERSION'], '1.3') >= 0;\n  params[v13 ? 'CRS' : 'SRS'] = projection.getCode();\n  if (v13 && axisOrientation.substr(0, 2) == 'ne') {\n    bbox = [extent[1], extent[0], extent[3], extent[2]];\n  } else {\n    bbox = extent;\n  }\n  params['BBOX'] = bbox.join(',');\n\n  return appendParams(/** @type {string} */ (baseUrl), params);\n}\n\n/**\n * @param {import(\"../extent\").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 {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\n  /**\n   * @type {import(\"../Image.js\").Loader}\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    if (options.crossOrigin !== null) {\n      image.crossOrigin = options.crossOrigin;\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 (options.params === undefined || options.params['LAYER'] === undefined) {\n    const layers = options.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 =\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  return appendParams(options.url, baseParams);\n}\n","/**\n * @module ol/source/ImageWMS\n */\n\nimport ImageSource, {defaultImageLoadFunction} from './Image.js';\nimport {calculateSourceResolution} from '../reproj.js';\nimport {createLoader, getFeatureInfoUrl, getLegendUrl} from './wms.js';\nimport {decode} from '../Image.js';\nimport {get as getProjection, transform} from '../proj.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 {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 {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_ = 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   */\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        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   * 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  changed() {\n    this.image = null;\n    super.changed();\n  }\n}\n\nexport default ImageWMS;\n","/**\n * @module ol/source/ogcTileUtil\n */\n\nimport TileGrid from '../tilegrid/TileGrid.js';\nimport {getJSON, resolveUrl} from '../net.js';\nimport {get as getProjection} from '../proj.js';\nimport {getIntersection as intersectExtents} from '../extent.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} crs The coordinate reference system.\n * @property {Array<TileMatrix>} tileMatrices Array of tile matrices.\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(\"../tilegrid/TileGrid.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 */\n\n/**\n * @param {Array<Link>} links Tileset links.\n * @param {string} [mediaType] The preferred media type.\n * @return {string} The tile URL template.\n */\nexport function getMapTileUrlTemplate(links, mediaType) {\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  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 * @return {string} The tile URL template.\n */\nexport function getVectorTileUrlTemplate(\n  links,\n  mediaType,\n  supportedMediaTypes\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  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 */\nfunction parseTileMatrixSet(\n  sourceInfo,\n  tileMatrixSet,\n  tileUrlTemplate,\n  tileMatrixSetLimits\n) {\n  let projection = sourceInfo.projection;\n  if (!projection) {\n    projection = getProjection(tileMatrixSet.crs);\n    if (!projection) {\n      throw new Error(`Unsupported CRS: ${tileMatrixSet.crs}`);\n    }\n  }\n  const backwards = projection.getAxisOrientation().substr(0, 2) !== 'en';\n\n  const matrices = tileMatrixSet.tileMatrices;\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      matrixIds.push(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: origins,\n    resolutions: resolutions,\n    sizes: sizes,\n    tileSizes: tileSizes,\n    extent: tileMatrixSetLimits ? extent : undefined,\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(localContext, context);\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    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    );\n  } else if (tileSet.dataType === 'vector') {\n    tileUrlTemplate = getVectorTileUrlTemplate(\n      tileSet.links,\n      sourceInfo.mediaType,\n      sourceInfo.supportedMediaTypes\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/OGCMapTile\n */\nimport TileImage from './TileImage.js';\nimport {getTileSetInfo} from './ogcTileUtil.js';\nimport {error as logError} from '../console.js';\n\n/**\n * @typedef {Object} Options\n * @property {string} url URL to the OGC Map Tileset endpoint.\n * @property {Object} [context] A lookup of values to use in the tile URL template.  The `{tileMatrix}`\n * (zoom level), `{tileRow}`, and `{tileCol}` variables in the URL will always be provided by the source.\n * @property {string} [mediaType] The content type for the tiles (e.g. \"image/png\").  If not provided,\n * the source will try to find a link with rel=\"item\" that uses a supported image type.\n * @property {import(\"../proj.js\").ProjectionLike} [projection] Projection. By default, the projection\n * will be derived from the `crs` of the `tileMatrixSet`.  You can override this by supplying\n * a projection to the constructor.\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {number} [cacheSize] Tile cache size. The default depends on the screen size. Will be ignored if too small.\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 {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(tile, src) {\n *   tile.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 */\n\n/**\n * @classdesc\n * Layer source for map tiles from an [OGC API - Tiles](https://ogcapi.ogc.org/tiles/) service that provides \"map\" type tiles.\n * The service must conform to at least the core (http://www.opengis.net/spec/ogcapi-tiles-1/1.0/conf/core)\n * and tileset (http://www.opengis.net/spec/ogcapi-tiles-1/1.0/conf/tileset) conformance classes.\n * @api\n */\nclass OGCMapTile extends TileImage {\n  /**\n   * @param {Options} options OGC map tile 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: options.projection,\n      reprojectionErrorThreshold: options.reprojectionErrorThreshold,\n      state: 'loading',\n      tileLoadFunction: options.tileLoadFunction,\n      wrapX: options.wrapX !== undefined ? options.wrapX : true,\n      transition: options.transition,\n    });\n\n    const sourceInfo = {\n      url: options.url,\n      projection: this.getProjection(),\n      mediaType: options.mediaType,\n      context: options.context || null,\n    };\n\n    getTileSetInfo(sourceInfo)\n      .then(this.handleTileSetInfo_.bind(this))\n      .catch(this.handleError_.bind(this));\n  }\n\n  /**\n   * @param {import(\"./ogcTileUtil.js\").TileSetInfo} tileSetInfo Tile set info.\n   * @private\n   */\n  handleTileSetInfo_(tileSetInfo) {\n    this.tileGrid = tileSetInfo.grid;\n    this.setTileUrlFunction(tileSetInfo.urlFunction, tileSetInfo.urlTemplate);\n    this.setState('ready');\n  }\n\n  /**\n   * @private\n   * @param {Error} error The error.\n   */\n  handleError_(error) {\n    logError(error);\n    this.setState('error');\n  }\n}\n\nexport default OGCMapTile;\n","/**\n * @module ol/source/VectorTile\n */\n\nimport EventType from '../events/EventType.js';\nimport Tile from '../VectorTile.js';\nimport TileCache from '../TileCache.js';\nimport TileGrid from '../tilegrid/TileGrid.js';\nimport TileState from '../TileState.js';\nimport UrlTile from './UrlTile.js';\nimport VectorRenderTile from '../VectorRenderTile.js';\nimport {DEFAULT_MAX_ZOOM} from '../tilegrid/common.js';\nimport {\n  buffer as bufferExtent,\n  getIntersection,\n  intersects,\n} from '../extent.js';\nimport {createXYZ, extentFromProjection} from '../tilegrid.js';\nimport {fromKey, getCacheKeyForTileKey, getKeyZXY} from '../tilecoord.js';\nimport {isEmpty} from '../obj.js';\nimport {loadFeaturesXhr} from '../featureloader.js';\nimport {toSize} from '../size.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] Initial tile cache size. Will auto-grow to hold at least twice the number of tiles in the viewport.\n * @property {import(\"../extent.js\").Extent} [extent] Extent.\n * @property {import(\"../format/Feature.js\").default} [format] Feature format for tiles. Used and required by the default.\n * @property {boolean} [overlaps=true] This source may have overlapping geometries. Setting this\n * 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 {import(\"../proj.js\").ProjectionLike} [projection='EPSG:3857'] Projection of the tile grid.\n * @property {import(\"./Source.js\").State} [state] Source state.\n * @property {typeof import(\"../VectorTile.js\").default} [tileClass] Class used to instantiate image tiles.\n * Default is {@link module:ol/VectorTile~VectorTile}.\n * @property {number} [maxZoom=22] Optional max zoom level. Not used if `tileGrid` is provided.\n * @property {number} [minZoom] Optional min zoom level. Not used if `tileGrid` is provided.\n * @property {number|import(\"../size.js\").Size} [tileSize=512] Optional tile size. 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]\n * Optional function to load a tile given a URL. Could look like this for pbf tiles:\n * ```js\n * function(tile, url) {\n *   tile.setLoader(function(extent, resolution, projection) {\n *     fetch(url).then(function(response) {\n *       response.arrayBuffer().then(function(data) {\n *         const format = tile.getFormat() // ol/format/MVT configured as source format\n *         const features = format.readFeatures(data, {\n *           extent: extent,\n *           featureProjection: projection\n *         });\n *         tile.setFeatures(features);\n *       });\n *     });\n *   });\n * }\n * ```\n * If you do not need extent, resolution and projection to get the features for a tile (e.g.\n * for GeoJSON tiles), your `tileLoadFunction` does not need a `setLoader()` call. Only make sure\n * to call `setFeatures()` on the tile:\n * ```js\n * const format = new GeoJSON({featureProjection: map.getView().getProjection()});\n * async function tileLoadFunction(tile, url) {\n *   const response = await fetch(url);\n *   const data = await response.json();\n *   tile.setFeatures(format.readFeatures(data));\n * }\n * ```\n * @property {import(\"../Tile.js\").UrlFunction} [tileUrlFunction] Optional function to get tile URL given a tile coordinate and the projection.\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 {number} [transition] A duration for tile opacity\n * transitions in milliseconds. A duration of 0 disables the opacity transition.\n * @property {Array<string>} [urls] An array of URL templates.\n * @property {boolean} [wrapX=true] Whether to wrap the world horizontally.\n * When set to `false`, only one world\n * will be rendered. When set to `true`, tiles will be wrapped horizontally to\n * render multiple worlds.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=1]\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 * Class for layer sources providing vector data divided into a tile grid, to be\n * used with {@link module:ol/layer/VectorTile~VectorTileLayer}. Although this source receives tiles\n * with vector features from the server, it is not meant for feature editing.\n * Features are optimized for rendering, their geometries are clipped at or near\n * tile boundaries and simplified for a view resolution. See\n * {@link module:ol/source/Vector~VectorSource} for vector sources that are suitable for feature\n * editing.\n *\n * @fires import(\"./Tile.js\").TileSourceEvent\n * @api\n */\nclass VectorTile extends UrlTile {\n  /**\n   * @param {!Options} options Vector tile options.\n   */\n  constructor(options) {\n    const projection = options.projection || 'EPSG:3857';\n\n    const extent = options.extent || extentFromProjection(projection);\n\n    const tileGrid =\n      options.tileGrid ||\n      createXYZ({\n        extent: extent,\n        maxResolution: options.maxResolution,\n        maxZoom: options.maxZoom !== undefined ? options.maxZoom : 22,\n        minZoom: options.minZoom,\n        tileSize: options.tileSize || 512,\n      });\n\n    super({\n      attributions: options.attributions,\n      attributionsCollapsible: options.attributionsCollapsible,\n      cacheSize: options.cacheSize,\n      interpolate: true,\n      opaque: false,\n      projection: projection,\n      state: options.state,\n      tileGrid: tileGrid,\n      tileLoadFunction: options.tileLoadFunction\n        ? options.tileLoadFunction\n        : defaultLoadFunction,\n      tileUrlFunction: options.tileUrlFunction,\n      url: options.url,\n      urls: options.urls,\n      wrapX: options.wrapX === undefined ? true : options.wrapX,\n      transition: options.transition,\n      zDirection: options.zDirection === undefined ? 1 : options.zDirection,\n    });\n\n    /**\n     * @private\n     * @type {import(\"../format/Feature.js\").default|null}\n     */\n    this.format_ = options.format ? options.format : null;\n\n    /**\n     * @private\n     * @type {TileCache}\n     */\n    this.sourceTileCache = new TileCache(this.tileCache.highWaterMark);\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.overlaps_ = options.overlaps == undefined ? true : options.overlaps;\n\n    /**\n     * @protected\n     * @type {typeof import(\"../VectorTile.js\").default}\n     */\n    this.tileClass = options.tileClass ? options.tileClass : Tile;\n\n    /**\n     * @private\n     * @type {Object<string, import(\"../tilegrid/TileGrid.js\").default>}\n     */\n    this.tileGrids_ = {};\n  }\n\n  /**\n   * Get features whose bounding box intersects the provided extent. Only features for cached\n   * tiles for the last rendered zoom level are available in the source. So this method is only\n   * suitable for requesting tiles for extents that are currently rendered.\n   *\n   * Features are returned in random tile order and as they are included in the tiles. This means\n   * they can be clipped, duplicated across tiles, and simplified to the render resolution.\n   *\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @return {Array<import(\"../Feature.js\").FeatureLike>} Features.\n   * @api\n   */\n  getFeaturesInExtent(extent) {\n    const features = [];\n    const tileCache = this.tileCache;\n    if (tileCache.getCount() === 0) {\n      return features;\n    }\n    const z = fromKey(tileCache.peekFirstKey())[0];\n    const tileGrid = this.tileGrid;\n    tileCache.forEach(function (tile) {\n      if (tile.tileCoord[0] !== z || tile.getState() !== TileState.LOADED) {\n        return;\n      }\n      const sourceTiles = tile.getSourceTiles();\n      for (let i = 0, ii = sourceTiles.length; i < ii; ++i) {\n        const sourceTile = sourceTiles[i];\n        const tileCoord = sourceTile.tileCoord;\n        if (intersects(extent, tileGrid.getTileCoordExtent(tileCoord))) {\n          const tileFeatures = sourceTile.getFeatures();\n          if (tileFeatures) {\n            for (let j = 0, jj = tileFeatures.length; j < jj; ++j) {\n              const candidate = tileFeatures[j];\n              const geometry = candidate.getGeometry();\n              if (intersects(extent, geometry.getExtent())) {\n                features.push(candidate);\n              }\n            }\n          }\n        }\n      }\n    });\n    return features;\n  }\n\n  /**\n   * @return {boolean} The source can have overlapping geometries.\n   */\n  getOverlaps() {\n    return this.overlaps_;\n  }\n\n  /**\n   * clear {@link module:ol/TileCache~TileCache} and delete all source tiles\n   * @api\n   */\n  clear() {\n    this.tileCache.clear();\n    this.sourceTileCache.clear();\n  }\n\n  /**\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   * @param {!Object<string, boolean>} usedTiles Used tiles.\n   */\n  expireCache(projection, usedTiles) {\n    const tileCache = this.getTileCacheForProjection(projection);\n    const usedSourceTiles = Object.keys(usedTiles).reduce((acc, key) => {\n      const cacheKey = getCacheKeyForTileKey(key);\n      const tile = tileCache.peek(cacheKey);\n      if (tile) {\n        const sourceTiles = tile.sourceTiles;\n        for (let i = 0, ii = sourceTiles.length; i < ii; ++i) {\n          acc[sourceTiles[i].getKey()] = true;\n        }\n      }\n      return acc;\n    }, {});\n    super.expireCache(projection, usedTiles);\n    this.sourceTileCache.expireCache(usedSourceTiles);\n  }\n\n  /**\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../proj/Projection\").default} projection Projection.\n   * @param {VectorRenderTile} tile Vector image tile.\n   * @return {Array<import(\"../VectorTile\").default>} Tile keys.\n   */\n  getSourceTiles(pixelRatio, projection, tile) {\n    if (tile.getState() === TileState.IDLE) {\n      tile.setState(TileState.LOADING);\n      const urlTileCoord = tile.wrappedTileCoord;\n      const tileGrid = this.getTileGridForProjection(projection);\n      const extent = tileGrid.getTileCoordExtent(urlTileCoord);\n      const z = urlTileCoord[0];\n      const resolution = tileGrid.getResolution(z);\n      // make extent 1 pixel smaller so we don't load tiles for < 0.5 pixel render space\n      bufferExtent(extent, -resolution, extent);\n      const sourceTileGrid = this.tileGrid;\n      const sourceExtent = sourceTileGrid.getExtent();\n      if (sourceExtent) {\n        getIntersection(extent, sourceExtent, extent);\n      }\n      const sourceZ = sourceTileGrid.getZForResolution(\n        resolution,\n        this.zDirection\n      );\n\n      sourceTileGrid.forEachTileCoord(extent, sourceZ, (sourceTileCoord) => {\n        const tileUrl = this.tileUrlFunction(\n          sourceTileCoord,\n          pixelRatio,\n          projection\n        );\n        const sourceTile = this.sourceTileCache.containsKey(tileUrl)\n          ? this.sourceTileCache.get(tileUrl)\n          : new this.tileClass(\n              sourceTileCoord,\n              tileUrl ? TileState.IDLE : TileState.EMPTY,\n              tileUrl,\n              this.format_,\n              this.tileLoadFunction\n            );\n        tile.sourceTiles.push(sourceTile);\n        const sourceTileState = sourceTile.getState();\n        if (sourceTileState < TileState.LOADED) {\n          const listenChange = (event) => {\n            this.handleTileChange(event);\n            const state = sourceTile.getState();\n            if (state === TileState.LOADED || state === TileState.ERROR) {\n              const sourceTileKey = sourceTile.getKey();\n              if (sourceTileKey in tile.errorTileKeys) {\n                if (sourceTile.getState() === TileState.LOADED) {\n                  delete tile.errorTileKeys[sourceTileKey];\n                }\n              } else {\n                tile.loadingSourceTiles--;\n              }\n              if (state === TileState.ERROR) {\n                tile.errorTileKeys[sourceTileKey] = true;\n              } else {\n                sourceTile.removeEventListener(EventType.CHANGE, listenChange);\n              }\n              if (tile.loadingSourceTiles === 0) {\n                tile.setState(\n                  isEmpty(tile.errorTileKeys)\n                    ? TileState.LOADED\n                    : TileState.ERROR\n                );\n              }\n            }\n          };\n          sourceTile.addEventListener(EventType.CHANGE, listenChange);\n          tile.loadingSourceTiles++;\n        }\n        if (sourceTileState === TileState.IDLE) {\n          sourceTile.extent =\n            sourceTileGrid.getTileCoordExtent(sourceTileCoord);\n          sourceTile.projection = projection;\n          sourceTile.resolution = sourceTileGrid.getResolution(\n            sourceTileCoord[0]\n          );\n          this.sourceTileCache.set(tileUrl, sourceTile);\n          sourceTile.load();\n        }\n      });\n      if (!tile.loadingSourceTiles) {\n        tile.setState(\n          tile.sourceTiles.some(\n            (sourceTile) => sourceTile.getState() === TileState.ERROR\n          )\n            ? TileState.ERROR\n            : TileState.LOADED\n        );\n      }\n    }\n\n    return tile.sourceTiles;\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 {!VectorRenderTile} Tile.\n   */\n  getTile(z, x, y, pixelRatio, projection) {\n    const coordKey = getKeyZXY(z, x, y);\n    const key = this.getKey();\n    let tile;\n    if (this.tileCache.containsKey(coordKey)) {\n      tile = this.tileCache.get(coordKey);\n      if (tile.key === key) {\n        return tile;\n      }\n    }\n    const tileCoord = [z, x, y];\n    let urlTileCoord = this.getTileCoordForTileUrlFunction(\n      tileCoord,\n      projection\n    );\n    const sourceExtent = this.getTileGrid().getExtent();\n    const tileGrid = this.getTileGridForProjection(projection);\n    if (urlTileCoord && sourceExtent) {\n      const tileExtent = tileGrid.getTileCoordExtent(urlTileCoord);\n      // make extent 1 pixel smaller so we don't load tiles for < 0.5 pixel render space\n      bufferExtent(tileExtent, -tileGrid.getResolution(z), tileExtent);\n      if (!intersects(sourceExtent, tileExtent)) {\n        urlTileCoord = null;\n      }\n    }\n    let empty = true;\n    if (urlTileCoord !== null) {\n      const sourceTileGrid = this.tileGrid;\n      const resolution = tileGrid.getResolution(z);\n      const sourceZ = sourceTileGrid.getZForResolution(resolution, 1);\n      // make extent 1 pixel smaller so we don't load tiles for < 0.5 pixel render space\n      const extent = tileGrid.getTileCoordExtent(urlTileCoord);\n      bufferExtent(extent, -resolution, extent);\n      sourceTileGrid.forEachTileCoord(extent, sourceZ, (sourceTileCoord) => {\n        empty =\n          empty &&\n          !this.tileUrlFunction(sourceTileCoord, pixelRatio, projection);\n      });\n    }\n    const newTile = new VectorRenderTile(\n      tileCoord,\n      empty ? TileState.EMPTY : TileState.IDLE,\n      urlTileCoord,\n      this.getSourceTiles.bind(this, pixelRatio, projection)\n    );\n\n    newTile.key = key;\n    if (tile) {\n      newTile.interimTile = tile;\n      newTile.refreshInterimChain();\n      this.tileCache.replace(coordKey, newTile);\n    } else {\n      this.tileCache.set(coordKey, newTile);\n    }\n    return newTile;\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    const code = projection.getCode();\n    let tileGrid = this.tileGrids_[code];\n    if (!tileGrid) {\n      // A tile grid that matches the tile size of the source tile grid is more\n      // likely to have 1:1 relationships between source tiles and rendered tiles.\n      const sourceTileGrid = this.tileGrid;\n      const resolutions = sourceTileGrid.getResolutions().slice();\n      const origins = resolutions.map(function (resolution, z) {\n        return sourceTileGrid.getOrigin(z);\n      });\n      const tileSizes = resolutions.map(function (resolution, z) {\n        return sourceTileGrid.getTileSize(z);\n      });\n      const length = DEFAULT_MAX_ZOOM + 1;\n      for (let z = resolutions.length; z < length; ++z) {\n        resolutions.push(resolutions[z - 1] / 2);\n        origins.push(origins[z - 1]);\n        tileSizes.push(tileSizes[z - 1]);\n      }\n      tileGrid = new TileGrid({\n        extent: sourceTileGrid.getExtent(),\n        origins: origins,\n        resolutions: resolutions,\n        tileSizes: tileSizes,\n      });\n      this.tileGrids_[code] = tileGrid;\n    }\n    return tileGrid;\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   */\n  getTilePixelRatio(pixelRatio) {\n    return pixelRatio;\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 tileSize = toSize(tileGrid.getTileSize(z), this.tmpSize);\n    return [\n      Math.round(tileSize[0] * pixelRatio),\n      Math.round(tileSize[1] * pixelRatio),\n    ];\n  }\n\n  /**\n   * Increases the cache size if needed\n   * @param {number} tileCount Minimum number of tiles needed.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection.\n   */\n  updateCacheSize(tileCount, projection) {\n    super.updateCacheSize(tileCount * 2, projection);\n    this.sourceTileCache.highWaterMark =\n      this.getTileCacheForProjection(projection).highWaterMark;\n  }\n}\n\nexport default VectorTile;\n\n/**\n * Sets the loader for a tile.\n * @param {import(\"../VectorTile.js\").default} tile Vector tile.\n * @param {string} url URL.\n */\nexport function defaultLoadFunction(tile, url) {\n  tile.setLoader(\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    function (extent, resolution, projection) {\n      loadFeaturesXhr(\n        url,\n        tile.getFormat(),\n        extent,\n        resolution,\n        projection,\n        tile.onLoad.bind(tile),\n        tile.onError.bind(tile)\n      );\n    }\n  );\n}\n","/**\n * @module ol/source/OGCVectorTile\n */\n\nimport VectorTileSource from './VectorTile.js';\nimport {getTileSetInfo} from './ogcTileUtil.js';\nimport {error as logError} from '../console.js';\n\n/**\n * @typedef {Object} Options\n * @property {string} url URL to the OGC Vector Tileset endpoint.\n * @property {Object} [context] A lookup of values to use in the tile URL template.  The `{tileMatrix}`\n * (zoom level), `{tileRow}`, and `{tileCol}` variables in the URL will always be provided by the source.\n * @property {import(\"../format/Feature.js\").default} format Feature parser for tiles.\n * @property {string} [mediaType] The content type for the tiles (e.g. \"application/vnd.mapbox-vector-tile\").  If not provided,\n * the source will try to find a link with rel=\"item\" that uses a vector type supported by the configured format.\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {boolean} [attributionsCollapsible=true] Attributions are collapsible.\n * @property {number} [cacheSize] Initial tile cache size. Will auto-grow to hold at least twice the number of tiles in the viewport.\n * @property {boolean} [overlaps=true] This source may have overlapping geometries. Setting this\n * 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 {import(\"../proj.js\").ProjectionLike} [projection='EPSG:3857'] Projection of the tile grid.\n * @property {typeof import(\"../VectorTile.js\").default} [tileClass] Class used to instantiate image tiles.\n * Default is {@link module:ol/VectorTile~VectorTile}.\n * @property {number} [transition] A duration for tile opacity\n * transitions in milliseconds. A duration of 0 disables the opacity transition.\n * @property {boolean} [wrapX=true] Whether to wrap the world horizontally.\n * When set to `false`, only one world\n * will be rendered. When set to `true`, tiles will be wrapped horizontally to\n * render multiple worlds.\n * @property {number|import(\"../array.js\").NearestDirectionFunction} [zDirection=1]\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 map tiles from an [OGC API - Tiles](https://ogcapi.ogc.org/tiles/) service that provides \"vector\" type tiles.\n * The service must conform to at least the core (http://www.opengis.net/spec/ogcapi-tiles-1/1.0/conf/core)\n * and tileset (http://www.opengis.net/spec/ogcapi-tiles-1/1.0/conf/tileset) conformance classes.\n *\n * Vector tile sets may come in a variety of formats (e.g. GeoJSON, MVT).  The `format` option is used to determine\n * which of the advertised media types is used.  If you need to force the use of a particular media type, you can\n * provide the `mediaType` option.\n * @api\n */\nclass OGCVectorTile extends VectorTileSource {\n  /**\n   * @param {Options} options OGC vector tile options.\n   */\n  constructor(options) {\n    super({\n      attributions: options.attributions,\n      attributionsCollapsible: options.attributionsCollapsible,\n      cacheSize: options.cacheSize,\n      format: options.format,\n      overlaps: options.overlaps,\n      projection: options.projection,\n      tileClass: options.tileClass,\n      transition: options.transition,\n      wrapX: options.wrapX,\n      zDirection: options.zDirection,\n      state: 'loading',\n    });\n\n    const sourceInfo = {\n      url: options.url,\n      projection: this.getProjection(),\n      mediaType: options.mediaType,\n      supportedMediaTypes: options.format.supportedMediaTypes,\n      context: options.context || null,\n    };\n\n    getTileSetInfo(sourceInfo)\n      .then(this.handleTileSetInfo_.bind(this))\n      .catch(this.handleError_.bind(this));\n  }\n\n  /**\n   * @param {import(\"./ogcTileUtil.js\").TileSetInfo} tileSetInfo Tile set info.\n   * @private\n   */\n  handleTileSetInfo_(tileSetInfo) {\n    this.tileGrid = tileSetInfo.grid;\n    this.setTileUrlFunction(tileSetInfo.urlFunction, tileSetInfo.urlTemplate);\n    this.setState('ready');\n  }\n\n  /**\n   * @private\n   * @param {Error} error The error.\n   */\n  handleError_(error) {\n    logError(error);\n    this.setState('error');\n  }\n}\n\nexport default OGCVectorTile;\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] Initial tile cache size. Will auto-grow to hold at least the number of tiles in the viewport.\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 {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 {boolean} [opaque=true] Whether the layer is opaque.\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 crossOrigin =\n      options.crossOrigin !== undefined ? options.crossOrigin : 'anonymous';\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: crossOrigin,\n      interpolate: options.interpolate,\n      maxZoom: options.maxZoom !== undefined ? options.maxZoom : 19,\n      opaque: options.opaque !== undefined ? options.opaque : true,\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/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 {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/renderer/Layer\n */\nimport EventType from '../events/EventType.js';\nimport ImageState from '../ImageState.js';\nimport Observable from '../Observable.js';\nimport {abstract} from '../util.js';\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     * @protected\n     * @type {LayerType}\n     */\n    this.layer_ = layer;\n\n    /**\n     * @type {import(\"../render/canvas/ExecutorGroup\").default}\n     */\n    this.declutterExecutorGroup = null;\n  }\n\n  /**\n   * Asynchronous layer level hit detection.\n   * @param {import(\"../pixel.js\").Pixel} pixel Pixel.\n   * @return {Promise<Array<import(\"../Feature\").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|null} The rendered element.\n   */\n  renderFrame(frameState, target) {\n    return abstract();\n  }\n\n  /**\n   * @param {Object<number, Object<string, import(\"../Tile.js\").default>>} tiles Lookup of loaded tiles by zoom level.\n   * @param {number} zoom Zoom level.\n   * @param {import(\"../Tile.js\").default} tile Tile.\n   * @return {boolean|void} If `false`, the tile will not be considered loaded.\n   */\n  loadedTileCallback(tiles, zoom, tile) {\n    if (!tiles[zoom]) {\n      tiles[zoom] = {};\n    }\n    tiles[zoom][tile.tileCoord.toString()] = tile;\n    return undefined;\n  }\n\n  /**\n   * Create a function that adds loaded tiles to the tile lookup.\n   * @param {import(\"../source/Tile.js\").default} source Tile source.\n   * @param {import(\"../proj/Projection.js\").default} projection Projection of the tiles.\n   * @param {Object<number, Object<string, import(\"../Tile.js\").default>>} tiles Lookup of loaded tiles by zoom level.\n   * @return {function(number, import(\"../TileRange.js\").default):boolean} A function that can be\n   *     called with a zoom level and a tile range to add loaded tiles to the lookup.\n   * @protected\n   */\n  createLoadedTileFinder(source, projection, tiles) {\n    return (\n      /**\n       * @param {number} zoom Zoom level.\n       * @param {import(\"../TileRange.js\").default} tileRange Tile range.\n       * @return {boolean} The tile range is fully loaded.\n       */\n      (zoom, tileRange) => {\n        const callback = this.loadedTileCallback.bind(this, tiles, zoom);\n        return source.forEachLoadedTile(projection, zoom, tileRange, callback);\n      }\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   * Clean up.\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 LayerRenderer from '../Layer.js';\nimport RenderEvent from '../../render/Event.js';\nimport RenderEventType from '../../render/EventType.js';\nimport {\n  apply as applyTransform,\n  compose as composeTransform,\n  create as createTransform,\n} from '../../transform.js';\nimport {asArray} from '../../color.js';\nimport {createCanvasContext2D} from '../../dom.js';\nimport {equals} from '../../array.js';\nimport {\n  getBottomLeft,\n  getBottomRight,\n  getTopLeft,\n  getTopRight,\n} from '../../extent.js';\n\n/**\n * @type {Array<HTMLCanvasElement>}\n */\nexport const canvasPool = [];\n\n/**\n * @type {CanvasRenderingContext2D}\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     * @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}\n     */\n    this.context = null;\n\n    /**\n     * @type {boolean}\n     */\n    this.containerReused = false;\n\n    /**\n     * @private\n     * @type {CanvasRenderingContext2D}\n     */\n    this.pixelContext_ = null;\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 (err) {\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.\n   * @param {string} [backgroundColor] Background color.\n   */\n  useContainer(target, transform, backgroundColor) {\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 (canvas instanceof HTMLCanvasElement) {\n        context = canvas.getContext('2d');\n      }\n    }\n    if (context && 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 = 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 = 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} 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(\"../../render/EventType.js\").default} type Event type.\n   * @param {CanvasRenderingContext2D} 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} context Context.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @protected\n   */\n  preRender(context, frameState) {\n    this.frameState = frameState;\n    this.dispatchRenderEvent_(RenderEventType.PRERENDER, context, frameState);\n  }\n\n  /**\n   * @param {CanvasRenderingContext2D} context 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  /**\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   */\n  disposeInternal() {\n    delete this.frameState;\n    super.disposeInternal();\n  }\n}\n\nexport default CanvasLayerRenderer;\n","/**\n * @module ol/renderer/canvas/ImageLayer\n */\nimport CanvasLayerRenderer from './Layer.js';\nimport ImageState from '../../ImageState.js';\nimport ViewHint from '../../ViewHint.js';\nimport {\n  apply as applyTransform,\n  compose as composeTransform,\n  makeInverse,\n  toString as toTransformString,\n} from '../../transform.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';\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  /**\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   */\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        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   */\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   */\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    const extent = frameState.extent;\n    const resolution = viewState.resolution;\n    const rotation = viewState.rotation;\n    // desired dimensions of the canvas in pixels\n    const width = Math.round((getWidth(extent) / resolution) * pixelRatio);\n    const height = Math.round((getHeight(extent) / resolution) * pixelRatio);\n\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\n    this.useContainer(target, canvasTransform, this.getBackground(frameState));\n\n    const context = this.context;\n    const canvas = context.canvas;\n\n    if (canvas.width != width || canvas.height != height) {\n      canvas.width = width;\n      canvas.height = height;\n    } else if (!this.containerReused) {\n      context.clearRect(0, 0, width, height);\n    }\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      let previousAlpha;\n      if (opacity !== 1) {\n        previousAlpha = context.globalAlpha;\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.globalAlpha = previousAlpha;\n      }\n    }\n    this.postRender(context, frameState);\n\n    if (clipped) {\n      context.restore();\n    }\n    context.imageSmoothingEnabled = true;\n\n    if (canvasTransform !== canvas.style.transform) {\n      canvas.style.transform = canvasTransform;\n    }\n\n    return this.container;\n  }\n}\n\nexport default CanvasImageLayerRenderer;\n","/**\n * @module ol/layer/Image\n */\nimport BaseImageLayer from './BaseImage.js';\nimport CanvasImageLayerRenderer from '../renderer/canvas/ImageLayer.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  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\").Pixel} pixel Pixel.\n   * @return {Uint8ClampedArray|Uint8Array|Float32Array|DataView|null} Pixel data.\n   * @api\n   */\n  getData(pixel) {\n    return super.getData(pixel);\n  }\n}\n\nexport default ImageLayer;\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\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"./Base\").BaseLayerObjectEventTypes|\n *     import(\"./Layer.js\").LayerEventType|'change:preload'|'change:useInterimTilesOnError', import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../render/EventType\").LayerRenderEventTypes, import(\"../render/Event\").default, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"./Base\").BaseLayerObjectEventTypes|\n *   import(\"./Layer.js\").LayerEventType|'change:preload'|'change:useInterimTilesOnError'|import(\"../render/EventType\").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 {boolean} [useInterimTilesOnError=true] Use interim tiles on error.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\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    delete baseOptions.preload;\n    delete baseOptions.useInterimTilesOnError;\n    super(baseOptions);\n\n    /***\n     * @type {BaseTileLayerOnSignature<import(\"../events\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {BaseTileLayerOnSignature<import(\"../events\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {BaseTileLayerOnSignature<void>}\n     */\n    this.un;\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 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   * 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   * 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\").Pixel} pixel Pixel.\n   * @return {Uint8ClampedArray|Uint8Array|Float32Array|DataView|null} Pixel data.\n   * @api\n   */\n  getData(pixel) {\n    return super.getData(pixel);\n  }\n}\n\nexport default BaseTileLayer;\n","/**\n * @module ol/renderer/canvas/TileLayer\n */\nimport CanvasLayerRenderer from './Layer.js';\nimport ImageTile from '../../ImageTile.js';\nimport ReprojTile from '../../reproj/Tile.js';\nimport TileRange from '../../TileRange.js';\nimport TileState from '../../TileState.js';\nimport {\n  apply as applyTransform,\n  compose as composeTransform,\n  makeInverse,\n  toString as toTransformString,\n} from '../../transform.js';\nimport {ascending} from '../../array.js';\nimport {\n  containsCoordinate,\n  createEmpty,\n  equals,\n  getHeight,\n  getIntersection,\n  getRotatedViewport,\n  getTopLeft,\n  getWidth,\n  intersects,\n} from '../../extent.js';\nimport {fromUserExtent} from '../../proj.js';\nimport {getUid} from '../../util.js';\nimport {toSize} from '../../size.js';\n\n/**\n * @classdesc\n * Canvas renderer for tile layers.\n * @api\n * @template {import(\"../../layer/Tile.js\").default<import(\"../../source/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   */\n  constructor(tileLayer) {\n    super(tileLayer);\n\n    /**\n     * Rendered extent has changed since the previous `renderFrame()` call\n     * @type {boolean}\n     */\n    this.extentChanged = true;\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}\n     */\n    this.renderedProjection = null;\n\n    /**\n     * @protected\n     * @type {number}\n     */\n    this.renderedRevision;\n\n    /**\n     * @protected\n     * @type {!Array<import(\"../../Tile.js\").default>}\n     */\n    this.renderedTiles = [];\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.newTiles_ = false;\n\n    /**\n     * @protected\n     * @type {import(\"../../extent.js\").Extent}\n     */\n    this.tmpExtent = createEmpty();\n\n    /**\n     * @private\n     * @type {import(\"../../TileRange.js\").default}\n     */\n    this.tmpTileRange_ = new TileRange(0, 0, 0, 0);\n  }\n\n  /**\n   * @protected\n   * @param {import(\"../../Tile.js\").default} tile Tile.\n   * @return {boolean} Tile is drawable.\n   */\n  isDrawableTile(tile) {\n    const tileLayer = this.getLayer();\n    const tileState = tile.getState();\n    const useInterimTilesOnError = tileLayer.getUseInterimTilesOnError();\n    return (\n      tileState == TileState.LOADED ||\n      tileState == TileState.EMPTY ||\n      (tileState == TileState.ERROR && !useInterimTilesOnError)\n    );\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} Tile.\n   */\n  getTile(z, x, y, frameState) {\n    const pixelRatio = frameState.pixelRatio;\n    const projection = frameState.viewState.projection;\n    const tileLayer = this.getLayer();\n    const tileSource = tileLayer.getSource();\n    let tile = tileSource.getTile(z, x, y, pixelRatio, projection);\n    if (tile.getState() == TileState.ERROR) {\n      if (tileLayer.getUseInterimTilesOnError() && tileLayer.getPreload() > 0) {\n        // Preloaded tiles for lower resolutions might have finished loading.\n        this.newTiles_ = true;\n      }\n    }\n    if (!this.isDrawableTile(tile)) {\n      tile = tile.getInterimTile();\n    }\n    return tile;\n  }\n\n  /**\n   * @param {import(\"../../pixel.js\").Pixel} pixel Pixel.\n   * @return {Uint8ClampedArray} Data at the pixel location.\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 pixelRatio = frameState.pixelRatio;\n    const projection = frameState.viewState.projection;\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 = source.getTile(\n        z,\n        tileCoord[1],\n        tileCoord[2],\n        pixelRatio,\n        projection\n      );\n      if (\n        !(tile instanceof ImageTile || tile instanceof ReprojTile) ||\n        (tile instanceof ReprojTile && tile.getState() === TileState.EMPTY)\n      ) {\n        return null;\n      }\n\n      if (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      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(tile.getImage(), col + gutter, row + gutter);\n    }\n\n    return null;\n  }\n\n  /**\n   * @param {Object<number, Object<string, import(\"../../Tile.js\").default>>} tiles Lookup of loaded tiles by zoom level.\n   * @param {number} zoom Zoom level.\n   * @param {import(\"../../Tile.js\").default} tile Tile.\n   * @return {boolean|void} If `false`, the tile will not be considered loaded.\n   */\n  loadedTileCallback(tiles, zoom, tile) {\n    if (this.isDrawableTile(tile)) {\n      return super.loadedTileCallback(tiles, zoom, tile);\n    }\n    return false;\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   */\n  prepareFrame(frameState) {\n    return !!this.getLayer().getSource();\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   */\n  renderFrame(frameState, target) {\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 rotation = viewState.rotation;\n    const pixelRatio = frameState.pixelRatio;\n\n    const tileLayer = this.getLayer();\n    const tileSource = tileLayer.getSource();\n    const sourceRevision = tileSource.getRevision();\n    const tileGrid = tileSource.getTileGridForProjection(projection);\n    const z = tileGrid.getZForResolution(viewResolution, tileSource.zDirection);\n    const tileResolution = tileGrid.getResolution(z);\n\n    let extent = frameState.extent;\n    const resolution = frameState.viewState.resolution;\n    const tilePixelRatio = tileSource.getTilePixelRatio(pixelRatio);\n    // desired dimensions of the canvas in pixels\n    const width = Math.round((getWidth(extent) / resolution) * pixelRatio);\n    const height = Math.round((getHeight(extent) / resolution) * pixelRatio);\n\n    const layerExtent =\n      layerState.extent && fromUserExtent(layerState.extent, projection);\n    if (layerExtent) {\n      extent = getIntersection(\n        extent,\n        fromUserExtent(layerState.extent, projection)\n      );\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    const tileRange = tileGrid.getTileRangeForExtentAndZ(extent, z);\n\n    /**\n     * @type {Object<number, Object<string, import(\"../../Tile.js\").default>>}\n     */\n    const tilesToDrawByZ = {};\n    tilesToDrawByZ[z] = {};\n\n    const findLoadedTiles = this.createLoadedTileFinder(\n      tileSource,\n      projection,\n      tilesToDrawByZ\n    );\n\n    const tmpExtent = this.tmpExtent;\n    const tmpTileRange = this.tmpTileRange_;\n    this.newTiles_ = false;\n    const viewport = rotation\n      ? getRotatedViewport(\n          viewState.center,\n          resolution,\n          rotation,\n          frameState.size\n        )\n      : undefined;\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 (this.isDrawableTile(tile)) {\n          const uid = getUid(this);\n          if (tile.getState() == TileState.LOADED) {\n            tilesToDrawByZ[z][tile.tileCoord.toString()] = tile;\n            let inTransition = tile.inTransition(uid);\n            if (inTransition && layerState.opacity !== 1) {\n              // Skipping transition when layer is not fully opaque avoids visual artifacts.\n              tile.endTransition(uid);\n              inTransition = false;\n            }\n            if (\n              !this.newTiles_ &&\n              (inTransition || !this.renderedTiles.includes(tile))\n            ) {\n              this.newTiles_ = true;\n            }\n          }\n          if (tile.getAlpha(uid, frameState.time) === 1) {\n            // don't look for alt tiles if alpha is 1\n            continue;\n          }\n        }\n\n        const childTileRange = tileGrid.getTileCoordChildTileRange(\n          tile.tileCoord,\n          tmpTileRange,\n          tmpExtent\n        );\n\n        let covered = false;\n        if (childTileRange) {\n          covered = findLoadedTiles(z + 1, childTileRange);\n        }\n        if (!covered) {\n          tileGrid.forEachTileCoordParentTileRange(\n            tile.tileCoord,\n            findLoadedTiles,\n            tmpTileRange,\n            tmpExtent\n          );\n        }\n      }\n    }\n\n    const canvasScale =\n      ((tileResolution / viewResolution) * pixelRatio) / tilePixelRatio;\n\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\n    const canvasTransform = toTransformString(this.pixelTransform);\n\n    this.useContainer(target, canvasTransform, this.getBackground(frameState));\n    const context = this.context;\n    const canvas = context.canvas;\n\n    makeInverse(this.inversePixelTransform, this.pixelTransform);\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 (canvas.width != width || canvas.height != height) {\n      canvas.width = width;\n      canvas.height = height;\n    } else if (!this.containerReused) {\n      context.clearRect(0, 0, width, height);\n    }\n\n    if (layerExtent) {\n      this.clipUnrotated(context, frameState, layerExtent);\n    }\n\n    if (!tileSource.getInterpolate()) {\n      context.imageSmoothingEnabled = false;\n    }\n\n    this.preRender(context, frameState);\n\n    this.renderedTiles.length = 0;\n    /** @type {Array<number>} */\n    let zs = Object.keys(tilesToDrawByZ).map(Number);\n    zs.sort(ascending);\n\n    let clips, clipZs, currentClip;\n    if (\n      layerState.opacity === 1 &&\n      (!this.containerReused ||\n        tileSource.getOpaque(frameState.viewState.projection))\n    ) {\n      zs = zs.reverse();\n    } else {\n      clips = [];\n      clipZs = [];\n    }\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      const tilesToDraw = tilesToDrawByZ[currentZ];\n      for (const tileCoordKey in tilesToDraw) {\n        const tile = /** @type {import(\"../../ImageTile.js\").default} */ (\n          tilesToDraw[tileCoordKey]\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 = z === currentZ;\n\n        const inTransition =\n          transition && tile.getAlpha(getUid(this), frameState.time) !== 1;\n        let contextSaved = false;\n        if (!inTransition) {\n          if (clips) {\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 (z !== currentZ && 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          } else {\n            context.clearRect(x, y, w, h);\n          }\n        }\n        this.drawTileImage(\n          tile,\n          frameState,\n          x,\n          y,\n          w,\n          h,\n          tileGutter,\n          transition\n        );\n        if (clips && !inTransition) {\n          if (contextSaved) {\n            context.restore();\n          }\n          this.renderedTiles.unshift(tile);\n        } else {\n          this.renderedTiles.push(tile);\n        }\n        this.updateUsedTiles(frameState.usedTiles, tileSource, tile);\n      }\n    }\n\n    this.renderedRevision = sourceRevision;\n    this.renderedResolution = tileResolution;\n    this.extentChanged =\n      !this.renderedExtent_ || !equals(this.renderedExtent_, canvasExtent);\n    this.renderedExtent_ = canvasExtent;\n    this.renderedPixelRatio = pixelRatio;\n    this.renderedProjection = projection;\n\n    this.manageTilePyramid(\n      frameState,\n      tileSource,\n      tileGrid,\n      pixelRatio,\n      projection,\n      extent,\n      z,\n      tileLayer.getPreload()\n    );\n    this.scheduleExpireCache(frameState, tileSource);\n\n    this.postRender(context, frameState);\n\n    if (layerState.extent) {\n      context.restore();\n    }\n    context.imageSmoothingEnabled = true;\n\n    if (canvasTransform !== canvas.style.transform) {\n      canvas.style.transform = canvasTransform;\n    }\n\n    return this.container;\n  }\n\n  /**\n   * @param {import(\"../../ImageTile.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   */\n  drawTileImage(tile, frameState, x, y, w, h, gutter, transition) {\n    const image = this.getTileImage(tile);\n    if (!image) {\n      return;\n    }\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 !== this.context.globalAlpha;\n    if (alphaChanged) {\n      this.context.save();\n      this.context.globalAlpha = alpha;\n    }\n    this.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      this.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} 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|HTMLImageElement|HTMLVideoElement} Image.\n   * @protected\n   */\n  getTileImage(tile) {\n    return tile.getImage();\n  }\n\n  /**\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @param {import(\"../../source/Tile.js\").default} tileSource Tile source.\n   * @protected\n   */\n  scheduleExpireCache(frameState, tileSource) {\n    if (tileSource.canExpireCache()) {\n      /**\n       * @param {import(\"../../source/Tile.js\").default} tileSource Tile source.\n       * @param {import(\"../../Map.js\").default} map Map.\n       * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n       */\n      const postRenderFunction = function (tileSource, map, frameState) {\n        const tileSourceKey = getUid(tileSource);\n        if (tileSourceKey in frameState.usedTiles) {\n          tileSource.expireCache(\n            frameState.viewState.projection,\n            frameState.usedTiles[tileSourceKey]\n          );\n        }\n      }.bind(null, tileSource);\n\n      frameState.postRenderFunctions.push(\n        /** @type {import(\"../../Map.js\").PostRenderFunction} */ (\n          postRenderFunction\n        )\n      );\n    }\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  /**\n   * Manage tile pyramid.\n   * This function performs a number of functions related to the tiles at the\n   * current zoom and lower zoom levels:\n   * - registers idle tiles in frameState.wantedTiles so that they are not\n   *   discarded by the tile queue\n   * - enqueues missing tiles\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @param {import(\"../../source/Tile.js\").default} tileSource Tile source.\n   * @param {import(\"../../tilegrid/TileGrid.js\").default} tileGrid Tile grid.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../../proj/Projection.js\").default} projection Projection.\n   * @param {import(\"../../extent.js\").Extent} extent Extent.\n   * @param {number} currentZ Current Z.\n   * @param {number} preload Load low resolution tiles up to `preload` levels.\n   * @param {function(import(\"../../Tile.js\").default):void} [tileCallback] Tile callback.\n   * @protected\n   */\n  manageTilePyramid(\n    frameState,\n    tileSource,\n    tileGrid,\n    pixelRatio,\n    projection,\n    extent,\n    currentZ,\n    preload,\n    tileCallback\n  ) {\n    const tileSourceKey = getUid(tileSource);\n    if (!(tileSourceKey in frameState.wantedTiles)) {\n      frameState.wantedTiles[tileSourceKey] = {};\n    }\n    const wantedTiles = frameState.wantedTiles[tileSourceKey];\n    const tileQueue = frameState.tileQueue;\n    const minZoom = tileGrid.getMinZoom();\n    const rotation = frameState.viewState.rotation;\n    const viewport = rotation\n      ? getRotatedViewport(\n          frameState.viewState.center,\n          frameState.viewState.resolution,\n          rotation,\n          frameState.size\n        )\n      : undefined;\n    let tileCount = 0;\n    let tile, tileRange, tileResolution, x, y, z;\n    for (z = minZoom; z <= currentZ; ++z) {\n      tileRange = tileGrid.getTileRangeForExtentAndZ(extent, z, tileRange);\n      tileResolution = tileGrid.getResolution(z);\n      for (x = tileRange.minX; x <= tileRange.maxX; ++x) {\n        for (y = tileRange.minY; y <= tileRange.maxY; ++y) {\n          if (\n            rotation &&\n            !tileGrid.tileCoordIntersectsViewport([z, x, y], viewport)\n          ) {\n            continue;\n          }\n          if (currentZ - z <= preload) {\n            ++tileCount;\n            tile = tileSource.getTile(z, x, y, pixelRatio, projection);\n            if (tile.getState() == TileState.IDLE) {\n              wantedTiles[tile.getKey()] = true;\n              if (!tileQueue.isKeyQueued(tile.getKey())) {\n                tileQueue.enqueue([\n                  tile,\n                  tileSourceKey,\n                  tileGrid.getTileCoordCenter(tile.tileCoord),\n                  tileResolution,\n                ]);\n              }\n            }\n            if (tileCallback !== undefined) {\n              tileCallback(tile);\n            }\n          } else {\n            tileSource.useTile(z, x, y, projection);\n          }\n        }\n      }\n    }\n    tileSource.updateCacheSize(tileCount, projection);\n  }\n}\n\nexport default CanvasTileLayerRenderer;\n","/**\n * @module ol/layer/Tile\n */\nimport BaseTileLayer from './BaseTile.js';\nimport CanvasTileLayerRenderer from '../renderer/canvas/TileLayer.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\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  createRenderer() {\n    return new CanvasTileLayerRenderer(this);\n  }\n}\n\nexport default TileLayer;\n","/**\n * @module ol/source/Raster\n */\nimport Disposable from '../Disposable.js';\nimport Event from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport ImageCanvas from '../ImageCanvas.js';\nimport ImageLayer from '../layer/Image.js';\nimport ImageSource from './Image.js';\nimport Source from './Source.js';\nimport TileLayer from '../layer/Tile.js';\nimport TileQueue from '../TileQueue.js';\nimport TileSource from './Tile.js';\nimport {createCanvasContext2D} from '../dom.js';\nimport {create as createTransform} from '../transform.js';\nimport {equals, getCenter, getHeight, getWidth} from '../extent.js';\nimport {getUid} from '../util.js';\n\nlet hasImageData = true;\ntry {\n  new ImageData(10, 10);\n} catch (_) {\n  hasImageData = false;\n}\n\n/** @type {CanvasRenderingContext2D} */\nlet context;\n\n/**\n * @param {Uint8ClampedArray} data Image data.\n * @param {number} width Number of columns.\n * @param {number} height Number of rows.\n * @return {ImageData} Image data.\n */\nexport function newImageData(data, width, height) {\n  if (hasImageData) {\n    return new ImageData(data, width, height);\n  }\n\n  if (!context) {\n    context = document.createElement('canvas').getContext('2d');\n  }\n  const imageData = context.createImageData(width, height);\n  imageData.data.set(data);\n  return imageData;\n}\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  let workerHasImageData = true;\n  try {\n    new ImageData(10, 10);\n  } catch (_) {\n    workerHasImageData = false;\n  }\n\n  function newWorkerImageData(data, width, height) {\n    if (workerHasImageData) {\n      return new ImageData(data, width, height);\n    }\n    return {data: data, width: width, height: height};\n  }\n\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] = newWorkerImageData(\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        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    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    this._workers = workers;\n\n    /**\n     * @type {Array<Job>}\n     * @private\n     */\n    this._queue = [];\n\n    this._maxQueueLength = config.queue || Infinity;\n    this._running = 0;\n\n    /**\n     * @type {Object<number, any>}\n     * @private\n     */\n    this._dataLookup = {};\n\n    /**\n     * @type {Job}\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      newImageData(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   */\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.  For vector data, use an VectorImage layer.\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\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types, import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").OnSignature<import(\"./Image.js\").ImageSourceEventTypes, import(\"./Image.js\").ImageSourceEvent, Return> &\n *   import(\"../Observable\").OnSignature<RasterSourceEventTypes, RasterSourceEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {RasterSourceOnSignature<import(\"../events\").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    /** @type {boolean} */\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     */\n    this.renderedRevision_;\n\n    /**\n     * @private\n     * @type {import(\"../Map.js\").FrameState}\n     */\n    this.frameState_ = {\n      animate: false,\n      coordinateToPixelTransform: createTransform(),\n      declutterTree: 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      const attributions = [];\n      for (\n        let index = 0, iMax = options.sources.length;\n        index < iMax;\n        ++index\n      ) {\n        const sourceOrLayer = options.sources[index];\n        const source =\n          sourceOrLayer instanceof Source\n            ? sourceOrLayer\n            : sourceOrLayer.getSource();\n        if (!source) {\n          continue;\n        }\n        const attributionGetter = source.getAttributions();\n        if (typeof attributionGetter === 'function') {\n          const sourceAttribution = attributionGetter(frameState);\n          attributions.push.apply(attributions, sourceAttribution);\n        }\n      }\n      return attributions.length !== 0 ? attributions : null;\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   */\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 = this.renderedImageCanvas_.getImage().getContext('2d');\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\").default} [projection] Projection.\n   * @return {Array<number>|null} Resolutions.\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  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}\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 XYZ from './XYZ.js';\nimport {ATTRIBUTION as OSM_ATTRIBUTION} from './OSM.js';\n\n/**\n * @const\n * @type string\n */\nconst STADIA_ATTRIBUTION =\n  '&copy; <a href=\"https://www.stadiamaps.com/\" target=\"_blank\">Stadia Maps</a>';\n\n/**\n * @const\n * @type string\n */\nconst OMT_ATTRIBUTION =\n  '&copy; <a href=\"https://openmaptiles.org/\" target=\"_blank\">OpenMapTiles</a>';\n\n/**\n * @const\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, opaque: boolean}>}\n */\nconst LayerConfig = {\n  'stamen_terrain': {\n    extension: 'png',\n    opaque: true,\n  },\n  'stamen_terrain_background': {\n    extension: 'png',\n    opaque: true,\n  },\n  'stamen_terrain_labels': {\n    extension: 'png',\n    opaque: false,\n  },\n  'stamen_terrain_lines': {\n    extension: 'png',\n    opaque: false,\n  },\n  'stamen_toner_background': {\n    extension: 'png',\n    opaque: true,\n  },\n  'stamen_toner': {\n    extension: 'png',\n    opaque: true,\n  },\n  'stamen_toner_labels': {\n    extension: 'png',\n    opaque: false,\n  },\n  'stamen_toner_lines': {\n    extension: 'png',\n    opaque: false,\n  },\n  'stamen_toner_lite': {\n    extension: 'png',\n    opaque: true,\n  },\n  'stamen_watercolor': {\n    extension: 'jpg',\n    opaque: true,\n  },\n  'alidade_smooth': {\n    extension: 'png',\n    opaque: true,\n  },\n  'alidade_smooth_dark': {\n    extension: 'png',\n    opaque: true,\n  },\n  'outdoors': {\n    extension: 'png',\n    opaque: true,\n  },\n  'osm_bright': {\n    extension: 'png',\n    opaque: true,\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_watercolor': {\n    minZoom: 1,\n    maxZoom: 18,\n    retina: false,\n  },\n};\n\n/**\n * @typedef {Object} Options\n * @property {number} [cacheSize] Initial tile cache size. Will auto-grow to hold at least the number of tiles in the viewport.\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      opaque: layerConfig.opaque,\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/TileArcGISRest\n */\n\nimport TileImage from './TileImage.js';\nimport {createEmpty} from '../extent.js';\nimport {getRequestUrl} from './arcgisRest.js';\nimport {modulo} from '../math.js';\nimport {scale as scaleSize, toSize} from '../size.js';\nimport {hash as tileCoordHash} from '../tilecoord.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"./Source.js\").AttributionLike} [attributions] Attributions.\n * @property {number} [cacheSize] Initial tile cache size. Will auto-grow to hold at least the number of tiles in the viewport.\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] 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      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_ = 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   */\n  getTilePixelRatio(pixelRatio) {\n    return this.hidpi_ ? pixelRatio : 1;\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 XYZ from './XYZ.js';\nimport {createCanvasContext2D} from '../dom.js';\nimport {toSize} from '../size.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 {string} [template='z:{z} x:{x} y:{y}'] Template for labeling the tiles.\n * Should include `{x}`, `{y}` or `{-y}`, and `{z}` placeholders.\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 XYZ {\n  /**\n   * @param {Options} [options] Debug tile options.\n   */\n  constructor(options) {\n    /**\n     * @type {Options}\n     */\n    options = options || {};\n\n    super({\n      opaque: false,\n      projection: options.projection,\n      tileGrid: options.tileGrid,\n      wrapX: options.wrapX !== undefined ? options.wrapX : true,\n      zDirection: options.zDirection,\n      url: options.template || 'z:{z} x:{x} y:{y}',\n      tileLoadFunction: (tile, text) => {\n        const z = tile.getTileCoord()[0];\n        const tileSize = toSize(this.tileGrid.getTileSize(z));\n        const context = createCanvasContext2D(tileSize[0], tileSize[1]);\n\n        context.strokeStyle = 'grey';\n        context.strokeRect(0.5, 0.5, tileSize[0] + 0.5, tileSize[1] + 0.5);\n\n        context.fillStyle = 'grey';\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, tileSize[0] / 2, tileSize[1] / 2, tileSize[0]);\n        context.fillText(text, tileSize[0] / 2, tileSize[1] / 2, tileSize[0]);\n\n        /** @type {import(\"../ImageTile.js\").default} */ (tile).setImage(\n          context.canvas\n        );\n      },\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 TileImage from './TileImage.js';\nimport {applyTransform, intersects} from '../extent.js';\nimport {createFromTemplates} from '../tileurlfunction.js';\nimport {createXYZ, extentFromProjection} from '../tilegrid.js';\nimport {get as getProjection, getTransformFromProjections} from '../proj.js';\nimport {jsonp as requestJSONP} from '../net.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] Initial tile cache size. Will auto-grow to hold at least the number of tiles in the viewport.\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 (err) {\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 TileImage from './TileImage.js';\nimport {DEFAULT_VERSION, getImageSrc, getRequestParams} from './wms.js';\nimport {appendParams} from '../uri.js';\nimport {buffer, createEmpty} from '../extent.js';\nimport {calculateSourceResolution} from '../reproj.js';\nimport {compareVersions} from '../string.js';\nimport {get as getProjection, transform} from '../proj.js';\nimport {modulo} from '../math.js';\nimport {hash as tileCoordHash} from '../tilecoord.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] Initial tile cache size. Will auto-grow to hold at least the number of tiles in the viewport.\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    const transparent = 'TRANSPARENT' in params ? params['TRANSPARENT'] : true;\n\n    super({\n      attributions: options.attributions,\n      attributionsCollapsible: options.attributionsCollapsible,\n      cacheSize: options.cacheSize,\n      crossOrigin: options.crossOrigin,\n      interpolate: options.interpolate,\n      opaque: !transparent,\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   */\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   */\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   * Update the user-provided params.\n   * @param {Object} params Params.\n   * @api\n   */\n  updateParams(params) {\n    Object.assign(this.params_, params);\n    this.updateV13_();\n    this.setKey(this.getKeyForParams_());\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/UTFGrid\n */\n\nimport EventType from '../events/EventType.js';\nimport Tile from '../Tile.js';\nimport TileSource from './Tile.js';\nimport TileState from '../TileState.js';\nimport {applyTransform, intersects} from '../extent.js';\nimport {createFromTemplates, nullTileUrlFunction} from '../tileurlfunction.js';\nimport {createXYZ, extentFromProjection} from '../tilegrid.js';\nimport {getKeyZXY} from '../tilecoord.js';\nimport {get as getProjection, getTransformFromProjections} from '../proj.js';\nimport {listenOnce} from '../events.js';\nimport {jsonp as requestJSONP} from '../net.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(\n        this,\n        EventType.CHANGE,\n        function (e) {\n          callback(this.getData(coordinate));\n        },\n        this\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   */\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 (err) {\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   */\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 {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      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    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 (err) {\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      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'] !== undefined) {\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   */\n  getTile(z, x, y, pixelRatio, projection) {\n    const tileCoordKey = getKeyZXY(z, x, y);\n    if (this.tileCache.containsKey(tileCoordKey)) {\n      return this.tileCache.get(tileCoordKey);\n    }\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 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(tileCoordKey, tile);\n    return tile;\n  }\n\n  /**\n   * Marks a tile coord as being used, without triggering a load.\n   * @param {number} z Tile coordinate z.\n   * @param {number} x Tile coordinate x.\n   * @param {number} y Tile coordinate y.\n   */\n  useTile(z, x, y) {\n    const tileCoordKey = getKeyZXY(z, x, y);\n    if (this.tileCache.containsKey(tileCoordKey)) {\n      this.tileCache.get(tileCoordKey);\n    }\n  }\n}\n\nexport default UTFGrid;\n","/**\n * @module ol/tilegrid/WMTS\n */\n\nimport TileGrid from './TileGrid.js';\nimport {get as getProjection} from '../proj.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().substr(0, 2) == '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/source/WMTS\n */\n\nimport TileImage from './TileImage.js';\nimport {appendParams} from '../uri.js';\nimport {containsExtent} from '../extent.js';\nimport {createFromCapabilitiesMatrixSet} from '../tilegrid/WMTS.js';\nimport {createFromTileUrlFunctions, expandUrl} from '../tileurlfunction.js';\nimport {equivalent, get as getProjection, transformExtent} from '../proj.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] Initial tile cache size. Will auto-grow to hold at least the number of tiles in the viewport.\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 {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      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   */\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 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().substr(0, 2) == '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 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 = 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/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/** 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 (e) {\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/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     */\n    function (node, objectStack) {\n      const value = valueReader.call(\n        thisArg !== undefined ? thisArg : this,\n        node,\n        objectStack\n      );\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     */\n    function (node, objectStack) {\n      const value = valueReader.call(\n        thisArg !== undefined ? thisArg : this,\n        node,\n        objectStack\n      );\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     */\n    function (node, objectStack) {\n      const value = valueReader.call(\n        thisArg !== undefined ? thisArg : this,\n        node,\n        objectStack\n      );\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     */\n    function (node, objectStack) {\n      const value = valueReader.call(\n        thisArg !== undefined ? thisArg : this,\n        node,\n        objectStack\n      );\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     */\n    function (node, objectStack) {\n      const value = valueReader.call(\n        thisArg !== undefined ? thisArg : this,\n        node,\n        objectStack\n      );\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 function (node, value, objectStack) {\n    nodeWriter.call(\n      thisArg !== undefined ? thisArg : this,\n      node,\n      value,\n      objectStack\n    );\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 * 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 !== undefined ? thisArg : this,\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/webgl/BaseTileRepresentation\n */\n\nimport EventTarget from '../events/Target.js';\nimport EventType from '../events/EventType.js';\nimport ImageTile from '../ImageTile.js';\nimport TileState from '../TileState.js';\nimport {abstract} from '../util.js';\n\n/**\n * @typedef {import(\"../Tile.js\").default} BaseTileType\n */\n\n/**\n * @template {BaseTileType} TileType\n * @typedef {Object} TileRepresentationOptions\n * @property {TileType} tile The tile.\n * @property {import(\"../tilegrid/TileGrid.js\").default} grid Tile grid.\n * @property {import(\"../webgl/Helper.js\").default} helper WebGL helper.\n * @property {number} [gutter=0] The size in pixels of the gutter around image tiles to ignore.\n */\n\n/**\n * @classdesc\n * Base class for representing a tile in a webgl context\n * @template {import(\"../Tile.js\").default} TileType\n * @abstract\n */\nclass BaseTileRepresentation extends EventTarget {\n  /**\n   * @param {TileRepresentationOptions<TileType>} options The tile representation options.\n   */\n  constructor(options) {\n    super();\n\n    /**\n     * @type {TileType}\n     */\n    this.tile;\n    this.handleTileChange_ = this.handleTileChange_.bind(this);\n\n    /**\n     * @type {number}\n     * @protected\n     */\n    this.gutter_ = options.gutter || 0;\n\n    /**\n     * @type {import(\"../webgl/Helper.js\").default}\n     * @protected\n     */\n    this.helper_ = options.helper;\n\n    this.loaded = false;\n    this.ready = false;\n  }\n\n  /**\n   * @param {TileType} tile Tile.\n   */\n  setTile(tile) {\n    if (tile !== this.tile) {\n      if (this.tile) {\n        this.tile.removeEventListener(EventType.CHANGE, this.handleTileChange_);\n      }\n      this.tile = tile;\n      this.loaded = tile.getState() === TileState.LOADED;\n      if (this.loaded) {\n        this.uploadTile();\n      } else {\n        if (tile instanceof ImageTile) {\n          const image = tile.getImage();\n          if (image instanceof Image && !image.crossOrigin) {\n            image.crossOrigin = 'anonymous';\n          }\n        }\n        tile.addEventListener(EventType.CHANGE, this.handleTileChange_);\n      }\n    }\n  }\n\n  /**\n   * @abstract\n   * @protected\n   */\n  uploadTile() {\n    abstract();\n  }\n\n  setReady() {\n    this.ready = true;\n    this.dispatchEvent(EventType.CHANGE);\n  }\n\n  handleTileChange_() {\n    if (this.tile.getState() === TileState.LOADED) {\n      this.loaded = true;\n      this.uploadTile();\n    }\n  }\n\n  disposeInternal() {\n    this.tile.removeEventListener(EventType.CHANGE, this.handleTileChange_);\n  }\n}\n\nexport default BaseTileRepresentation;\n","/**\n * @module ol/webgl/Buffer\n */\nimport {\n  ARRAY_BUFFER,\n  DYNAMIC_DRAW,\n  ELEMENT_ARRAY_BUFFER,\n  STATIC_DRAW,\n  STREAM_DRAW,\n} from '../webgl.js';\nimport {assert} from '../asserts.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 `DYNAMIC_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   * @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\").UniformValue>} [uniforms] Uniform definitions for the post process step\n */\n\n/**\n * @typedef {Object} UniformInternalDescription\n * @property {import(\"./Helper\").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    this.gl_ = options.webGlContext;\n    const gl = this.gl_;\n\n    this.scaleRatio_ = options.scaleRatio || 1;\n\n    this.renderTargetTexture_ = gl.createTexture();\n    this.renderTargetTextureSize_ = null;\n\n    this.frameBuffer_ = gl.createFramebuffer();\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    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    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    this.renderTargetAttribLocation_ = gl.getAttribLocation(\n      this.renderTargetProgram_,\n      'a_position'\n    );\n    this.renderTargetUniformLocation_ = gl.getUniformLocation(\n      this.renderTargetProgram_,\n      'u_screenSize'\n    );\n    this.renderTargetOpacityLocation_ = gl.getUniformLocation(\n      this.renderTargetProgram_,\n      'u_opacity'\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  /**\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/vec/mat4\n */\n\n/**\n * @return {Array<number>} \"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 {Array<number>} mat4 Flattened 4x4 matrix receiving the result.\n * @param {import(\"../transform.js\").Transform} transform Transformation matrix.\n * @return {Array<number>} \"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 * @module ol/webgl/Helper\n */\nimport ContextEventType from '../webgl/ContextEventType.js';\nimport Disposable from '../Disposable.js';\nimport WebGLPostProcessingPass from './PostProcessingPass.js';\nimport {\n  FLOAT,\n  UNSIGNED_BYTE,\n  UNSIGNED_INT,\n  UNSIGNED_SHORT,\n  getContext,\n} from '../webgl.js';\nimport {clear} from '../obj.js';\nimport {\n  compose as composeTransform,\n  create as createTransform,\n} from '../transform.js';\nimport {create, fromTransform} from '../vec/mat4.js';\nimport {getUid} from '../util.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  SCREEN_TO_WORLD_MATRIX: 'u_screenToWorldMatrix',\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} name Attribute name to use in shaders\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|import(\"../transform\").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  /**\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   * 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\").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\").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 gl = this.gl_;\n    const bufferKey = getUid(buf);\n    const bufferCacheEntry = this.bufferCache_[bufferKey];\n    if (bufferCacheEntry && !gl.isContextLost()) {\n      gl.deleteBuffer(bufferCacheEntry.webGlBuffer);\n    }\n    delete this.bufferCache_[bufferKey];\n  }\n\n  /**\n   * Clean up.\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   * 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   * 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   * 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      ) {\n        // create a texture & put data\n        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 (imageReady && uniform.prevValue !== value) {\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    const gl = this.gl_;\n    gl.useProgram(program);\n    this.currentProgram_ = program;\n    this.applyFrameState(frameState);\n    this.applyUniforms(frameState);\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\").Transform} transform Transform to update.\n   * @return {import(\"../transform\").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   * 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   * @private\n   */\n  enableAttributeArray_(attribName, size, type, stride, offset) {\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  }\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    const stride = computeAttributesStride(attributes);\n    let offset = 0;\n    for (let i = 0; i < attributes.length; i++) {\n      const attr = attributes[i];\n      this.enableAttributeArray_(\n        attr.name,\n        attr.size,\n        attr.type || FLOAT,\n        stride,\n        offset\n      );\n      offset += attr.size * getByteSizeFromType(attr.type);\n    }\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.\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} [data] Image data/object to bind to the texture\n   * @param {WebGLTexture} [texture] Existing texture to reuse\n   * @return {WebGLTexture} The generated texture\n   */\n  createTexture(size, data, texture) {\n    const gl = this.gl_;\n    texture = texture || gl.createTexture();\n\n    // set params & size\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    gl.bindTexture(gl.TEXTURE_2D, texture);\n    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    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    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/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\nexport default PaletteTexture;\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","'use strict';\n\nmodule.exports = earcut;\nmodule.exports.default = earcut;\n\nfunction earcut(data, holeIndices, dim) {\n\n    dim = dim || 2;\n\n    var hasHoles = holeIndices && holeIndices.length,\n        outerLen = hasHoles ? holeIndices[0] * dim : data.length,\n        outerNode = linkedList(data, 0, outerLen, dim, true),\n        triangles = [];\n\n    if (!outerNode || outerNode.next === outerNode.prev) return triangles;\n\n    var minX, minY, maxX, maxY, x, y, invSize;\n\n    if (hasHoles) outerNode = eliminateHoles(data, holeIndices, outerNode, dim);\n\n    // if the shape is not too simple, we'll use z-order curve hash later; calculate polygon bbox\n    if (data.length > 80 * dim) {\n        minX = maxX = data[0];\n        minY = maxY = data[1];\n\n        for (var i = dim; i < outerLen; i += dim) {\n            x = data[i];\n            y = data[i + 1];\n            if (x < minX) minX = x;\n            if (y < minY) minY = y;\n            if (x > maxX) maxX = x;\n            if (y > maxY) maxY = y;\n        }\n\n        // minX, minY and invSize are later used to transform coords into integers for z-order calculation\n        invSize = Math.max(maxX - minX, maxY - minY);\n        invSize = invSize !== 0 ? 32767 / invSize : 0;\n    }\n\n    earcutLinked(outerNode, triangles, dim, minX, minY, invSize, 0);\n\n    return triangles;\n}\n\n// create a circular doubly linked list from polygon points in the specified winding order\nfunction linkedList(data, start, end, dim, clockwise) {\n    var i, last;\n\n    if (clockwise === (signedArea(data, start, end, dim) > 0)) {\n        for (i = start; i < end; i += dim) last = insertNode(i, data[i], data[i + 1], last);\n    } else {\n        for (i = end - dim; i >= start; i -= dim) last = insertNode(i, data[i], data[i + 1], last);\n    }\n\n    if (last && equals(last, last.next)) {\n        removeNode(last);\n        last = last.next;\n    }\n\n    return last;\n}\n\n// eliminate colinear or duplicate points\nfunction filterPoints(start, end) {\n    if (!start) return start;\n    if (!end) end = start;\n\n    var p = start,\n        again;\n    do {\n        again = false;\n\n        if (!p.steiner && (equals(p, p.next) || area(p.prev, p, p.next) === 0)) {\n            removeNode(p);\n            p = end = p.prev;\n            if (p === p.next) break;\n            again = true;\n\n        } else {\n            p = p.next;\n        }\n    } while (again || p !== end);\n\n    return end;\n}\n\n// main ear slicing loop which triangulates a polygon (given as a linked list)\nfunction earcutLinked(ear, triangles, dim, minX, minY, invSize, pass) {\n    if (!ear) return;\n\n    // interlink polygon nodes in z-order\n    if (!pass && invSize) indexCurve(ear, minX, minY, invSize);\n\n    var stop = ear,\n        prev, next;\n\n    // iterate through ears, slicing them one by one\n    while (ear.prev !== ear.next) {\n        prev = ear.prev;\n        next = ear.next;\n\n        if (invSize ? isEarHashed(ear, minX, minY, invSize) : isEar(ear)) {\n            // cut off the triangle\n            triangles.push(prev.i / dim | 0);\n            triangles.push(ear.i / dim | 0);\n            triangles.push(next.i / dim | 0);\n\n            removeNode(ear);\n\n            // skipping the next vertex leads to less sliver triangles\n            ear = next.next;\n            stop = next.next;\n\n            continue;\n        }\n\n        ear = next;\n\n        // if we looped through the whole remaining polygon and can't find any more ears\n        if (ear === stop) {\n            // try filtering points and slicing again\n            if (!pass) {\n                earcutLinked(filterPoints(ear), triangles, dim, minX, minY, invSize, 1);\n\n            // if this didn't work, try curing all small self-intersections locally\n            } else if (pass === 1) {\n                ear = cureLocalIntersections(filterPoints(ear), triangles, dim);\n                earcutLinked(ear, triangles, dim, minX, minY, invSize, 2);\n\n            // as a last resort, try splitting the remaining polygon into two\n            } else if (pass === 2) {\n                splitEarcut(ear, triangles, dim, minX, minY, invSize);\n            }\n\n            break;\n        }\n    }\n}\n\n// check whether a polygon node forms a valid ear with adjacent nodes\nfunction isEar(ear) {\n    var a = ear.prev,\n        b = ear,\n        c = ear.next;\n\n    if (area(a, b, c) >= 0) return false; // reflex, can't be an ear\n\n    // now make sure we don't have other points inside the potential ear\n    var ax = a.x, bx = b.x, cx = c.x, ay = a.y, by = b.y, cy = c.y;\n\n    // triangle bbox; min & max are calculated like this for speed\n    var x0 = ax < bx ? (ax < cx ? ax : cx) : (bx < cx ? bx : cx),\n        y0 = ay < by ? (ay < cy ? ay : cy) : (by < cy ? by : cy),\n        x1 = ax > bx ? (ax > cx ? ax : cx) : (bx > cx ? bx : cx),\n        y1 = ay > by ? (ay > cy ? ay : cy) : (by > cy ? by : cy);\n\n    var p = c.next;\n    while (p !== a) {\n        if (p.x >= x0 && p.x <= x1 && p.y >= y0 && p.y <= y1 &&\n            pointInTriangle(ax, ay, bx, by, cx, cy, p.x, p.y) &&\n            area(p.prev, p, p.next) >= 0) return false;\n        p = p.next;\n    }\n\n    return true;\n}\n\nfunction isEarHashed(ear, minX, minY, invSize) {\n    var a = ear.prev,\n        b = ear,\n        c = ear.next;\n\n    if (area(a, b, c) >= 0) return false; // reflex, can't be an ear\n\n    var ax = a.x, bx = b.x, cx = c.x, ay = a.y, by = b.y, cy = c.y;\n\n    // triangle bbox; min & max are calculated like this for speed\n    var x0 = ax < bx ? (ax < cx ? ax : cx) : (bx < cx ? bx : cx),\n        y0 = ay < by ? (ay < cy ? ay : cy) : (by < cy ? by : cy),\n        x1 = ax > bx ? (ax > cx ? ax : cx) : (bx > cx ? bx : cx),\n        y1 = ay > by ? (ay > cy ? ay : cy) : (by > cy ? by : cy);\n\n    // z-order range for the current triangle bbox;\n    var minZ = zOrder(x0, y0, minX, minY, invSize),\n        maxZ = zOrder(x1, y1, minX, minY, invSize);\n\n    var p = ear.prevZ,\n        n = ear.nextZ;\n\n    // look for points inside the triangle in both directions\n    while (p && p.z >= minZ && n && n.z <= maxZ) {\n        if (p.x >= x0 && p.x <= x1 && p.y >= y0 && p.y <= y1 && p !== a && p !== c &&\n            pointInTriangle(ax, ay, bx, by, cx, cy, p.x, p.y) && area(p.prev, p, p.next) >= 0) return false;\n        p = p.prevZ;\n\n        if (n.x >= x0 && n.x <= x1 && n.y >= y0 && n.y <= y1 && n !== a && n !== c &&\n            pointInTriangle(ax, ay, bx, by, cx, cy, n.x, n.y) && area(n.prev, n, n.next) >= 0) return false;\n        n = n.nextZ;\n    }\n\n    // look for remaining points in decreasing z-order\n    while (p && p.z >= minZ) {\n        if (p.x >= x0 && p.x <= x1 && p.y >= y0 && p.y <= y1 && p !== a && p !== c &&\n            pointInTriangle(ax, ay, bx, by, cx, cy, p.x, p.y) && area(p.prev, p, p.next) >= 0) return false;\n        p = p.prevZ;\n    }\n\n    // look for remaining points in increasing z-order\n    while (n && n.z <= maxZ) {\n        if (n.x >= x0 && n.x <= x1 && n.y >= y0 && n.y <= y1 && n !== a && n !== c &&\n            pointInTriangle(ax, ay, bx, by, cx, cy, n.x, n.y) && area(n.prev, n, n.next) >= 0) return false;\n        n = n.nextZ;\n    }\n\n    return true;\n}\n\n// go through all polygon nodes and cure small local self-intersections\nfunction cureLocalIntersections(start, triangles, dim) {\n    var p = start;\n    do {\n        var a = p.prev,\n            b = p.next.next;\n\n        if (!equals(a, b) && intersects(a, p, p.next, b) && locallyInside(a, b) && locallyInside(b, a)) {\n\n            triangles.push(a.i / dim | 0);\n            triangles.push(p.i / dim | 0);\n            triangles.push(b.i / dim | 0);\n\n            // remove two nodes involved\n            removeNode(p);\n            removeNode(p.next);\n\n            p = start = b;\n        }\n        p = p.next;\n    } while (p !== start);\n\n    return filterPoints(p);\n}\n\n// try splitting polygon into two and triangulate them independently\nfunction splitEarcut(start, triangles, dim, minX, minY, invSize) {\n    // look for a valid diagonal that divides the polygon into two\n    var a = start;\n    do {\n        var b = a.next.next;\n        while (b !== a.prev) {\n            if (a.i !== b.i && isValidDiagonal(a, b)) {\n                // split the polygon in two by the diagonal\n                var c = splitPolygon(a, b);\n\n                // filter colinear points around the cuts\n                a = filterPoints(a, a.next);\n                c = filterPoints(c, c.next);\n\n                // run earcut on each half\n                earcutLinked(a, triangles, dim, minX, minY, invSize, 0);\n                earcutLinked(c, triangles, dim, minX, minY, invSize, 0);\n                return;\n            }\n            b = b.next;\n        }\n        a = a.next;\n    } while (a !== start);\n}\n\n// link every hole into the outer loop, producing a single-ring polygon without holes\nfunction eliminateHoles(data, holeIndices, outerNode, dim) {\n    var queue = [],\n        i, len, start, end, list;\n\n    for (i = 0, len = holeIndices.length; i < len; i++) {\n        start = holeIndices[i] * dim;\n        end = i < len - 1 ? holeIndices[i + 1] * dim : data.length;\n        list = linkedList(data, start, end, dim, false);\n        if (list === list.next) list.steiner = true;\n        queue.push(getLeftmost(list));\n    }\n\n    queue.sort(compareX);\n\n    // process holes from left to right\n    for (i = 0; i < queue.length; i++) {\n        outerNode = eliminateHole(queue[i], outerNode);\n    }\n\n    return outerNode;\n}\n\nfunction compareX(a, b) {\n    return a.x - b.x;\n}\n\n// find a bridge between vertices that connects hole with an outer ring and and link it\nfunction eliminateHole(hole, outerNode) {\n    var bridge = findHoleBridge(hole, outerNode);\n    if (!bridge) {\n        return outerNode;\n    }\n\n    var bridgeReverse = splitPolygon(bridge, hole);\n\n    // filter collinear points around the cuts\n    filterPoints(bridgeReverse, bridgeReverse.next);\n    return filterPoints(bridge, bridge.next);\n}\n\n// David Eberly's algorithm for finding a bridge between hole and outer polygon\nfunction findHoleBridge(hole, outerNode) {\n    var p = outerNode,\n        hx = hole.x,\n        hy = hole.y,\n        qx = -Infinity,\n        m;\n\n    // find a segment intersected by a ray from the hole's leftmost point to the left;\n    // segment's endpoint with lesser x will be potential connection point\n    do {\n        if (hy <= p.y && hy >= p.next.y && p.next.y !== p.y) {\n            var x = p.x + (hy - p.y) * (p.next.x - p.x) / (p.next.y - p.y);\n            if (x <= hx && x > qx) {\n                qx = x;\n                m = p.x < p.next.x ? p : p.next;\n                if (x === hx) return m; // hole touches outer segment; pick leftmost endpoint\n            }\n        }\n        p = p.next;\n    } while (p !== outerNode);\n\n    if (!m) return null;\n\n    // look for points inside the triangle of hole point, segment intersection and endpoint;\n    // if there are no points found, we have a valid connection;\n    // otherwise choose the point of the minimum angle with the ray as connection point\n\n    var stop = m,\n        mx = m.x,\n        my = m.y,\n        tanMin = Infinity,\n        tan;\n\n    p = m;\n\n    do {\n        if (hx >= p.x && p.x >= mx && hx !== p.x &&\n                pointInTriangle(hy < my ? hx : qx, hy, mx, my, hy < my ? qx : hx, hy, p.x, p.y)) {\n\n            tan = Math.abs(hy - p.y) / (hx - p.x); // tangential\n\n            if (locallyInside(p, hole) &&\n                (tan < tanMin || (tan === tanMin && (p.x > m.x || (p.x === m.x && sectorContainsSector(m, p)))))) {\n                m = p;\n                tanMin = tan;\n            }\n        }\n\n        p = p.next;\n    } while (p !== stop);\n\n    return m;\n}\n\n// whether sector in vertex m contains sector in vertex p in the same coordinates\nfunction sectorContainsSector(m, p) {\n    return area(m.prev, m, p.prev) < 0 && area(p.next, m, m.next) < 0;\n}\n\n// interlink polygon nodes in z-order\nfunction indexCurve(start, minX, minY, invSize) {\n    var p = start;\n    do {\n        if (p.z === 0) p.z = zOrder(p.x, p.y, minX, minY, invSize);\n        p.prevZ = p.prev;\n        p.nextZ = p.next;\n        p = p.next;\n    } while (p !== start);\n\n    p.prevZ.nextZ = null;\n    p.prevZ = null;\n\n    sortLinked(p);\n}\n\n// Simon Tatham's linked list merge sort algorithm\n// http://www.chiark.greenend.org.uk/~sgtatham/algorithms/listsort.html\nfunction sortLinked(list) {\n    var i, p, q, e, tail, numMerges, pSize, qSize,\n        inSize = 1;\n\n    do {\n        p = list;\n        list = null;\n        tail = null;\n        numMerges = 0;\n\n        while (p) {\n            numMerges++;\n            q = p;\n            pSize = 0;\n            for (i = 0; i < inSize; i++) {\n                pSize++;\n                q = q.nextZ;\n                if (!q) break;\n            }\n            qSize = inSize;\n\n            while (pSize > 0 || (qSize > 0 && q)) {\n\n                if (pSize !== 0 && (qSize === 0 || !q || p.z <= q.z)) {\n                    e = p;\n                    p = p.nextZ;\n                    pSize--;\n                } else {\n                    e = q;\n                    q = q.nextZ;\n                    qSize--;\n                }\n\n                if (tail) tail.nextZ = e;\n                else list = e;\n\n                e.prevZ = tail;\n                tail = e;\n            }\n\n            p = q;\n        }\n\n        tail.nextZ = null;\n        inSize *= 2;\n\n    } while (numMerges > 1);\n\n    return list;\n}\n\n// z-order of a point given coords and inverse of the longer side of data bbox\nfunction zOrder(x, y, minX, minY, invSize) {\n    // coords are transformed into non-negative 15-bit integer range\n    x = (x - minX) * invSize | 0;\n    y = (y - minY) * invSize | 0;\n\n    x = (x | (x << 8)) & 0x00FF00FF;\n    x = (x | (x << 4)) & 0x0F0F0F0F;\n    x = (x | (x << 2)) & 0x33333333;\n    x = (x | (x << 1)) & 0x55555555;\n\n    y = (y | (y << 8)) & 0x00FF00FF;\n    y = (y | (y << 4)) & 0x0F0F0F0F;\n    y = (y | (y << 2)) & 0x33333333;\n    y = (y | (y << 1)) & 0x55555555;\n\n    return x | (y << 1);\n}\n\n// find the leftmost node of a polygon ring\nfunction getLeftmost(start) {\n    var p = start,\n        leftmost = start;\n    do {\n        if (p.x < leftmost.x || (p.x === leftmost.x && p.y < leftmost.y)) leftmost = p;\n        p = p.next;\n    } while (p !== start);\n\n    return leftmost;\n}\n\n// check if a point lies within a convex triangle\nfunction pointInTriangle(ax, ay, bx, by, cx, cy, px, py) {\n    return (cx - px) * (ay - py) >= (ax - px) * (cy - py) &&\n           (ax - px) * (by - py) >= (bx - px) * (ay - py) &&\n           (bx - px) * (cy - py) >= (cx - px) * (by - py);\n}\n\n// check if a diagonal between two polygon nodes is valid (lies in polygon interior)\nfunction isValidDiagonal(a, b) {\n    return a.next.i !== b.i && a.prev.i !== b.i && !intersectsPolygon(a, b) && // dones't intersect other edges\n           (locallyInside(a, b) && locallyInside(b, a) && middleInside(a, b) && // locally visible\n            (area(a.prev, a, b.prev) || area(a, b.prev, b)) || // does not create opposite-facing sectors\n            equals(a, b) && area(a.prev, a, a.next) > 0 && area(b.prev, b, b.next) > 0); // special zero-length case\n}\n\n// signed area of a triangle\nfunction area(p, q, r) {\n    return (q.y - p.y) * (r.x - q.x) - (q.x - p.x) * (r.y - q.y);\n}\n\n// check if two points are equal\nfunction equals(p1, p2) {\n    return p1.x === p2.x && p1.y === p2.y;\n}\n\n// check if two segments intersect\nfunction intersects(p1, q1, p2, q2) {\n    var o1 = sign(area(p1, q1, p2));\n    var o2 = sign(area(p1, q1, q2));\n    var o3 = sign(area(p2, q2, p1));\n    var o4 = sign(area(p2, q2, q1));\n\n    if (o1 !== o2 && o3 !== o4) return true; // general case\n\n    if (o1 === 0 && onSegment(p1, p2, q1)) return true; // p1, q1 and p2 are collinear and p2 lies on p1q1\n    if (o2 === 0 && onSegment(p1, q2, q1)) return true; // p1, q1 and q2 are collinear and q2 lies on p1q1\n    if (o3 === 0 && onSegment(p2, p1, q2)) return true; // p2, q2 and p1 are collinear and p1 lies on p2q2\n    if (o4 === 0 && onSegment(p2, q1, q2)) return true; // p2, q2 and q1 are collinear and q1 lies on p2q2\n\n    return false;\n}\n\n// for collinear points p, q, r, check if point q lies on segment pr\nfunction onSegment(p, q, r) {\n    return q.x <= Math.max(p.x, r.x) && q.x >= Math.min(p.x, r.x) && q.y <= Math.max(p.y, r.y) && q.y >= Math.min(p.y, r.y);\n}\n\nfunction sign(num) {\n    return num > 0 ? 1 : num < 0 ? -1 : 0;\n}\n\n// check if a polygon diagonal intersects any polygon segments\nfunction intersectsPolygon(a, b) {\n    var p = a;\n    do {\n        if (p.i !== a.i && p.next.i !== a.i && p.i !== b.i && p.next.i !== b.i &&\n                intersects(p, p.next, a, b)) return true;\n        p = p.next;\n    } while (p !== a);\n\n    return false;\n}\n\n// check if a polygon diagonal is locally inside the polygon\nfunction locallyInside(a, b) {\n    return area(a.prev, a, a.next) < 0 ?\n        area(a, b, a.next) >= 0 && area(a, a.prev, b) >= 0 :\n        area(a, b, a.prev) < 0 || area(a, a.next, b) < 0;\n}\n\n// check if the middle point of a polygon diagonal is inside the polygon\nfunction middleInside(a, b) {\n    var p = a,\n        inside = false,\n        px = (a.x + b.x) / 2,\n        py = (a.y + b.y) / 2;\n    do {\n        if (((p.y > py) !== (p.next.y > py)) && p.next.y !== p.y &&\n                (px < (p.next.x - p.x) * (py - p.y) / (p.next.y - p.y) + p.x))\n            inside = !inside;\n        p = p.next;\n    } while (p !== a);\n\n    return inside;\n}\n\n// link two polygon vertices with a bridge; if the vertices belong to the same ring, it splits polygon into two;\n// if one belongs to the outer ring and another to a hole, it merges it into a single ring\nfunction splitPolygon(a, b) {\n    var a2 = new Node(a.i, a.x, a.y),\n        b2 = new Node(b.i, b.x, b.y),\n        an = a.next,\n        bp = b.prev;\n\n    a.next = b;\n    b.prev = a;\n\n    a2.next = an;\n    an.prev = a2;\n\n    b2.next = a2;\n    a2.prev = b2;\n\n    bp.next = b2;\n    b2.prev = bp;\n\n    return b2;\n}\n\n// create a node and optionally link it with previous one (in a circular doubly linked list)\nfunction insertNode(i, x, y, last) {\n    var p = new Node(i, x, y);\n\n    if (!last) {\n        p.prev = p;\n        p.next = p;\n\n    } else {\n        p.next = last.next;\n        p.prev = last;\n        last.next.prev = p;\n        last.next = p;\n    }\n    return p;\n}\n\nfunction removeNode(p) {\n    p.next.prev = p.prev;\n    p.prev.next = p.next;\n\n    if (p.prevZ) p.prevZ.nextZ = p.nextZ;\n    if (p.nextZ) p.nextZ.prevZ = p.prevZ;\n}\n\nfunction Node(i, x, y) {\n    // vertex index in coordinates array\n    this.i = i;\n\n    // vertex coordinates\n    this.x = x;\n    this.y = y;\n\n    // previous and next vertex nodes in a polygon ring\n    this.prev = null;\n    this.next = null;\n\n    // z-order curve value\n    this.z = 0;\n\n    // previous and next nodes in z-order\n    this.prevZ = null;\n    this.nextZ = null;\n\n    // indicates whether this is a steiner point\n    this.steiner = false;\n}\n\n// return a percentage difference between the polygon area and its triangulation area;\n// used to verify correctness of triangulation\nearcut.deviation = function (data, holeIndices, dim, triangles) {\n    var hasHoles = holeIndices && holeIndices.length;\n    var outerLen = hasHoles ? holeIndices[0] * dim : data.length;\n\n    var polygonArea = Math.abs(signedArea(data, 0, outerLen, dim));\n    if (hasHoles) {\n        for (var i = 0, len = holeIndices.length; i < len; i++) {\n            var start = holeIndices[i] * dim;\n            var end = i < len - 1 ? holeIndices[i + 1] * dim : data.length;\n            polygonArea -= Math.abs(signedArea(data, start, end, dim));\n        }\n    }\n\n    var trianglesArea = 0;\n    for (i = 0; i < triangles.length; i += 3) {\n        var a = triangles[i] * dim;\n        var b = triangles[i + 1] * dim;\n        var c = triangles[i + 2] * dim;\n        trianglesArea += Math.abs(\n            (data[a] - data[c]) * (data[b + 1] - data[a + 1]) -\n            (data[a] - data[b]) * (data[c + 1] - data[a + 1]));\n    }\n\n    return polygonArea === 0 && trianglesArea === 0 ? 0 :\n        Math.abs((trianglesArea - polygonArea) / polygonArea);\n};\n\nfunction signedArea(data, start, end, dim) {\n    var sum = 0;\n    for (var i = start, j = end - dim; i < end; i += dim) {\n        sum += (data[j] - data[i]) * (data[i + 1] + data[j + 1]);\n        j = i;\n    }\n    return sum;\n}\n\n// turn a polygon in a multi-dimensional array form (e.g. as in GeoJSON) into a form Earcut accepts\nearcut.flatten = function (data) {\n    var dim = data[0][0].length,\n        result = {vertices: [], holes: [], dimensions: dim},\n        holeIndex = 0;\n\n    for (var i = 0; i < data.length; i++) {\n        for (var j = 0; j < data[i].length; j++) {\n            for (var d = 0; d < dim; d++) result.vertices.push(data[i][j][d]);\n        }\n        if (i > 0) {\n            holeIndex += data[i - 1].length;\n            result.holes.push(holeIndex);\n        }\n    }\n    return result;\n};\n","/**\n * @module ol/render/webgl/utils\n */\nimport earcut from 'earcut';\nimport {apply as applyTransform} from '../../transform.js';\nimport {clamp} from '../../math.js';\n\nexport const LINESTRING_ANGLE_COSINE_CUTOFF = 0.985;\n\n/** @type {Array<number>} */\nconst tmpArray_ = [];\n\n/**\n * An object holding positions both in an index and a vertex buffer.\n * @typedef {Object} BufferPositions\n * @property {number} vertexPosition Position in the vertex buffer\n * @property {number} indexPosition Position in the index buffer\n */\nconst bufferPositions_ = {vertexPosition: 0, indexPosition: 0};\n\n/**\n * @param {Float32Array} buffer Buffer\n * @param {number} pos Position\n * @param {number} x X\n * @param {number} y Y\n * @param {number} index Index\n */\nfunction writePointVertex(buffer, pos, x, y, index) {\n  buffer[pos + 0] = x;\n  buffer[pos + 1] = y;\n  buffer[pos + 2] = index;\n}\n\n/**\n * Pushes a quad (two triangles) based on a point geometry\n * @param {Float32Array} instructions Array of render instructions for points.\n * @param {number} elementIndex Index from which render instructions will be read.\n * @param {Float32Array} vertexBuffer Buffer in the form of a typed array.\n * @param {Uint32Array} indexBuffer Buffer in the form of a typed array.\n * @param {number} customAttributesSize Amount of custom attributes for each element.\n * @param {BufferPositions} [bufferPositions] Buffer write positions; if not specified, positions will be set at 0.\n * @return {BufferPositions} New buffer positions where to write next\n * @property {number} vertexPosition New position in the vertex buffer where future writes should start.\n * @property {number} indexPosition New position in the index buffer where future writes should start.\n * @private\n */\nexport function writePointFeatureToBuffers(\n  instructions,\n  elementIndex,\n  vertexBuffer,\n  indexBuffer,\n  customAttributesSize,\n  bufferPositions\n) {\n  // This is for x, y and index\n  const baseVertexAttrsCount = 3;\n  const baseInstructionsCount = 2;\n  const stride = baseVertexAttrsCount + customAttributesSize;\n\n  const x = instructions[elementIndex + 0];\n  const y = instructions[elementIndex + 1];\n\n  // read custom numerical attributes on the feature\n  const customAttrs = tmpArray_;\n  customAttrs.length = customAttributesSize;\n  for (let i = 0; i < customAttrs.length; i++) {\n    customAttrs[i] = instructions[elementIndex + baseInstructionsCount + i];\n  }\n\n  let vPos = bufferPositions ? bufferPositions.vertexPosition : 0;\n  let iPos = bufferPositions ? bufferPositions.indexPosition : 0;\n  const baseIndex = vPos / stride;\n\n  // push vertices for each of the four quad corners (first standard then custom attributes)\n  writePointVertex(vertexBuffer, vPos, x, y, 0);\n  customAttrs.length &&\n    vertexBuffer.set(customAttrs, vPos + baseVertexAttrsCount);\n  vPos += stride;\n\n  writePointVertex(vertexBuffer, vPos, x, y, 1);\n  customAttrs.length &&\n    vertexBuffer.set(customAttrs, vPos + baseVertexAttrsCount);\n  vPos += stride;\n\n  writePointVertex(vertexBuffer, vPos, x, y, 2);\n  customAttrs.length &&\n    vertexBuffer.set(customAttrs, vPos + baseVertexAttrsCount);\n  vPos += stride;\n\n  writePointVertex(vertexBuffer, vPos, x, y, 3);\n  customAttrs.length &&\n    vertexBuffer.set(customAttrs, vPos + baseVertexAttrsCount);\n  vPos += stride;\n\n  indexBuffer[iPos++] = baseIndex;\n  indexBuffer[iPos++] = baseIndex + 1;\n  indexBuffer[iPos++] = baseIndex + 3;\n  indexBuffer[iPos++] = baseIndex + 1;\n  indexBuffer[iPos++] = baseIndex + 2;\n  indexBuffer[iPos++] = baseIndex + 3;\n\n  bufferPositions_.vertexPosition = vPos;\n  bufferPositions_.indexPosition = iPos;\n\n  return bufferPositions_;\n}\n\n/**\n * Pushes a single quad to form a line segment; also includes a computation for the join angles with previous and next\n * segment, in order to be able to offset the vertices correctly in the shader.\n * Join angles are between 0 and 2PI.\n * This also computes the length of the current segment and the sum of the join angle tangents in order\n * to store this information on each subsequent segment along the line. This is necessary to correctly render dashes\n * and symbols along the line.\n *\n *   pB (before)                          pA (after)\n *    X             negative             X\n *     \\             offset             /\n *      \\                              /\n *       \\   join              join   /\n *        \\ angle 0          angle 1 /\n *         \\←---                ←---/      positive\n *          \\   ←--          ←--   /        offset\n *           \\     ↑       ↓      /\n *            X────┴───────┴─────X\n *            p0                  p1\n *\n * @param {Float32Array} instructions Array of render instructions for lines.s\n * @param {number} segmentStartIndex Index of the segment start point from which render instructions will be read.\n * @param {number} segmentEndIndex Index of the segment end point from which render instructions will be read.\n * @param {number|null} beforeSegmentIndex Index of the point right before the segment (null if none, e.g this is a line start)\n * @param {number|null} afterSegmentIndex Index of the point right after the segment (null if none, e.g this is a line end)\n * @param {Array<number>} vertexArray Array containing vertices.\n * @param {Array<number>} indexArray Array containing indices.\n * @param {Array<number>} customAttributes Array of custom attributes value\n * @param {import('../../transform.js').Transform} toWorldTransform Transform matrix used to obtain world coordinates from instructions\n * @param {number} currentLength Cumulated length of segments processed so far\n * @param {number} currentAngleTangentSum Cumulated tangents of the join angles processed so far\n * @return {{length: number, angle: number}} Cumulated length with the newly processed segment (in world units), new sum of the join angle tangents\n * @private\n */\nexport function writeLineSegmentToBuffers(\n  instructions,\n  segmentStartIndex,\n  segmentEndIndex,\n  beforeSegmentIndex,\n  afterSegmentIndex,\n  vertexArray,\n  indexArray,\n  customAttributes,\n  toWorldTransform,\n  currentLength,\n  currentAngleTangentSum\n) {\n  // compute the stride to determine how many vertices were already pushed\n  const baseVertexAttrsCount = 8; // base attributes: x0, y0, x1, y1, angle0, angle1, distance, params\n  const stride = baseVertexAttrsCount + customAttributes.length;\n  const baseIndex = vertexArray.length / stride;\n\n  // The segment is composed of two positions called P0[x0, y0] and P1[x1, y1]\n  // Depending on whether there are points before and after the segment, its final shape\n  // will be different\n  const p0 = [\n    instructions[segmentStartIndex + 0],\n    instructions[segmentStartIndex + 1],\n  ];\n  const p1 = [instructions[segmentEndIndex], instructions[segmentEndIndex + 1]];\n\n  // to compute join angles we need to reproject coordinates back in world units\n  const p0world = applyTransform(toWorldTransform, [...p0]);\n  const p1world = applyTransform(toWorldTransform, [...p1]);\n\n  /**\n   * Compute the angle between p0pA and p0pB\n   * @param {import(\"../../coordinate.js\").Coordinate} p0 Point 0\n   * @param {import(\"../../coordinate.js\").Coordinate} pA Point A\n   * @param {import(\"../../coordinate.js\").Coordinate} pB Point B\n   * @return {number} a value in [0, 2PI]\n   */\n  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    const 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    const isClockwise = tangentB[0] * orthoA[0] + tangentB[1] * orthoA[1] > 0;\n    return !isClockwise ? Math.PI * 2 - angle : angle;\n  }\n\n  // a negative angle indicates a line cap\n  let angle0 = -1;\n  let angle1 = -1;\n  let newAngleTangentSum = currentAngleTangentSum;\n\n  const joinBefore = beforeSegmentIndex !== null;\n  const joinAfter = afterSegmentIndex !== null;\n\n  // add vertices and adapt offsets for P0 in case of join\n  if (joinBefore) {\n    // B for before\n    const pB = [\n      instructions[beforeSegmentIndex],\n      instructions[beforeSegmentIndex + 1],\n    ];\n    const pBworld = applyTransform(toWorldTransform, [...pB]);\n    angle0 = angleBetween(p0world, p1world, pBworld);\n\n    // only add to the sum if the angle isn't too close to 0 or 2PI\n    if (Math.cos(angle0) <= LINESTRING_ANGLE_COSINE_CUTOFF) {\n      newAngleTangentSum += Math.tan((angle0 - Math.PI) / 2);\n    }\n  }\n  // adapt offsets for P1 in case of join; add to angle sum\n  if (joinAfter) {\n    // A for after\n    const pA = [\n      instructions[afterSegmentIndex],\n      instructions[afterSegmentIndex + 1],\n    ];\n    const pAworld = applyTransform(toWorldTransform, [...pA]);\n    angle1 = angleBetween(p1world, p0world, pAworld);\n\n    // only add to the sum if the angle isn't too close to 0 or 2PI\n    if (Math.cos(angle1) <= LINESTRING_ANGLE_COSINE_CUTOFF) {\n      newAngleTangentSum += Math.tan((Math.PI - angle1) / 2);\n    }\n  }\n\n  /**\n   * @param {number} vertexIndex From 0 to 3, indicating position in the quad\n   * @param {number} angleSum Sum of the join angles encountered so far (used to compute distance offset\n   * @return {number} A float value containing both information\n   */\n  function computeParameters(vertexIndex, angleSum) {\n    if (angleSum === 0) {\n      return vertexIndex * 10000;\n    }\n    return Math.sign(angleSum) * (vertexIndex * 10000 + Math.abs(angleSum));\n  }\n\n  // add main segment triangles\n  vertexArray.push(\n    p0[0],\n    p0[1],\n    p1[0],\n    p1[1],\n    angle0,\n    angle1,\n    currentLength,\n    computeParameters(0, currentAngleTangentSum)\n  );\n  vertexArray.push(...customAttributes);\n\n  vertexArray.push(\n    p0[0],\n    p0[1],\n    p1[0],\n    p1[1],\n    angle0,\n    angle1,\n    currentLength,\n    computeParameters(1, currentAngleTangentSum)\n  );\n  vertexArray.push(...customAttributes);\n\n  vertexArray.push(\n    p0[0],\n    p0[1],\n    p1[0],\n    p1[1],\n    angle0,\n    angle1,\n    currentLength,\n    computeParameters(2, currentAngleTangentSum)\n  );\n  vertexArray.push(...customAttributes);\n\n  vertexArray.push(\n    p0[0],\n    p0[1],\n    p1[0],\n    p1[1],\n    angle0,\n    angle1,\n    currentLength,\n    computeParameters(3, currentAngleTangentSum)\n  );\n  vertexArray.push(...customAttributes);\n\n  indexArray.push(\n    baseIndex,\n    baseIndex + 1,\n    baseIndex + 2,\n    baseIndex + 1,\n    baseIndex + 3,\n    baseIndex + 2\n  );\n\n  return {\n    length:\n      currentLength +\n      Math.sqrt(\n        (p1world[0] - p0world[0]) * (p1world[0] - p0world[0]) +\n          (p1world[1] - p0world[1]) * (p1world[1] - p0world[1])\n      ),\n    angle: newAngleTangentSum,\n  };\n}\n\n/**\n * Pushes several triangles to form a polygon, including holes\n * @param {Float32Array} instructions Array of render instructions for lines.\n * @param {number} polygonStartIndex Index of the polygon start point from which render instructions will be read.\n * @param {Array<number>} vertexArray Array containing vertices.\n * @param {Array<number>} indexArray Array containing indices.\n * @param {number} customAttributesSize Amount of custom attributes for each element.\n * @return {number} Next polygon instructions index\n * @private\n */\nexport function writePolygonTrianglesToBuffers(\n  instructions,\n  polygonStartIndex,\n  vertexArray,\n  indexArray,\n  customAttributesSize\n) {\n  const instructionsPerVertex = 2; // x, y\n  const attributesPerVertex = 2 + customAttributesSize;\n  let instructionsIndex = polygonStartIndex;\n  const customAttributes = instructions.slice(\n    instructionsIndex,\n    instructionsIndex + customAttributesSize\n  );\n  instructionsIndex += customAttributesSize;\n  const ringsCount = instructions[instructionsIndex++];\n  let verticesCount = 0;\n  const holes = new Array(ringsCount - 1);\n  for (let i = 0; i < ringsCount; i++) {\n    verticesCount += instructions[instructionsIndex++];\n    if (i < ringsCount - 1) {\n      holes[i] = verticesCount;\n    }\n  }\n  const flatCoords = instructions.slice(\n    instructionsIndex,\n    instructionsIndex + verticesCount * instructionsPerVertex\n  );\n\n  // pushing to vertices and indices!! this is where the magic happens\n  const result = earcut(flatCoords, holes, instructionsPerVertex);\n  for (let i = 0; i < result.length; i++) {\n    indexArray.push(result[i] + vertexArray.length / attributesPerVertex);\n  }\n  for (let i = 0; i < flatCoords.length; i += 2) {\n    vertexArray.push(flatCoords[i], flatCoords[i + 1], ...customAttributes);\n  }\n\n  return instructionsIndex + verticesCount * instructionsPerVertex;\n}\n\n/**\n * Returns a texture of 1x1 pixel, white\n * @private\n * @return {ImageData} Image data.\n */\nexport function getBlankImageData() {\n  const canvas = document.createElement('canvas');\n  const image = canvas.getContext('2d').createImageData(1, 1);\n  image.data[0] = 255;\n  image.data[1] = 255;\n  image.data[2] = 255;\n  image.data[3] = 255;\n  return image;\n}\n\n/**\n * Generates a color array based on a numerical id\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>} Color array containing the encoded id\n */\nexport function colorEncodeId(id, array) {\n  array = array || [];\n  const radix = 256;\n  const divide = radix - 1;\n  array[0] = Math.floor(id / radix / radix / radix) / divide;\n  array[1] = (Math.floor(id / radix / radix) % radix) / divide;\n  array[2] = (Math.floor(id / radix) % radix) / divide;\n  array[3] = (id % radix) / divide;\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\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 * @module ol/expr/expression\n */\nimport {ascending} from '../array.js';\nimport {isStringColor} from '../color.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 * The following operators can be used:\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.\n *   * `['get', 'attributeName', typeHint]` fetches a feature property value, similar to `feature.get('attributeName')`\n *     A type hint can optionally be specified, in case the resulting expression contains a type ambiguity which\n *     will make it invalid. Type hints can be one of: 'string', 'color', 'number', 'boolean', 'number[]'\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\n *   * `['resolution']` returns the current resolution\n *   * `['time']` returns the time in seconds since the creation of the layer\n *   * `['var', 'varName']` fetches a value from the style variables; will throw an error if that variable is undefined\n *   * `['zoom']` returns the current zoom level\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 *\n * * Logical operators:\n *   * `['<', value1, value2]` returns `true` if `value1` is strictly lower than `value2`, or `false` otherwise.\n *   * `['<=', value1, value2]` returns `true` if `value1` is lower than or equals `value2`, or `false` otherwise.\n *   * `['>', value1, value2]` returns `true` if `value1` is strictly greater than `value2`, or `false` otherwise.\n *   * `['>=', value1, value2]` returns `true` if `value1` is greater than or equals `value2`, or `false` otherwise.\n *   * `['==', value1, value2]` returns `true` if `value1` equals `value2`, or `false` otherwise.\n *   * `['!=', value1, value2]` returns `true` if `value1` does not equal `value2`, or `false` otherwise.\n *   * `['!', value1]` returns `false` if `value1` is `true` or greater than `0`, or `true` otherwise.\n *   * `['all', value1, value2, ...]` returns `true` if all the inputs are `true`, `false` otherwise.\n *   * `['any', value1, value2, ...]` returns `true` if any of the inputs are `true`, `false` otherwise.\n *   * `['between', value1, value2, value3]` returns `true` if `value1` is contained between `value2` and `value3`\n *     (inclusively), or `false` otherwise.\n *   * `['in', needle, haystack]` returns `true` if `needle` is found in `haystack`, and\n *     `false` otherwise.\n *     This operator has the following limitations:\n *     * `haystack` has to be an array of numbers or strings (searching for a substring in a string is not supported yet)\n *     * Only literal arrays are supported as `haystack` for now; this means that `haystack` cannot be the result of an\n *     expression. If `haystack` is an array of strings, use the `literal` operator to disambiguate from an expression:\n *     `['literal', ['abc', 'def', 'ghi']]`\n *\n * * Conversion operators:\n *   * `['array', value1, ...valueN]` creates a numerical array from `number` values; please note that the amount of\n *     values can currently only be 2, 3 or 4.\n *   * `['color', red, green, blue, alpha]` creates a `color` value from `number` values; the `alpha` parameter is\n *     optional; if not specified, it will be set to 1.\n *     Note: `red`, `green` and `blue` 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).\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 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};\n\nconst namedTypes = Object.keys(typeNames).map(Number).sort(ascending);\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    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 {import(\"../style/flat.js\").FlatStyle|import(\"../style/webgl.js\").WebGLStyle} style The style being parsed\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    style: {},\n  };\n}\n\n/**\n * @param {string} typeHint Type hint\n * @return {number} Resulting value type (will be a single type)\n */\nfunction getTypeFromHint(typeHint) {\n  switch (typeHint) {\n    case 'string':\n      return StringType;\n    case 'color':\n      return ColorType;\n    case 'number':\n      return NumberType;\n    case 'boolean':\n      return BooleanType;\n    case 'number[]':\n      return NumberArrayType;\n    default:\n      throw new Error(`Unrecognized type hint: ${typeHint}`);\n  }\n}\n\n/**\n * @typedef {LiteralValue|Array} EncodedExpression\n */\n\n/**\n * @param {EncodedExpression} encoded The encoded expression.\n * @param {ParsingContext} context The parsing context.\n * @param {number} [typeHint] Optional type hint\n * @return {Expression} The parsed expression result.\n */\nexport function parse(encoded, context, typeHint) {\n  switch (typeof encoded) {\n    case 'boolean': {\n      return new LiteralExpression(BooleanType, encoded);\n    }\n    case 'number': {\n      return new LiteralExpression(NumberType, encoded);\n    }\n    case 'string': {\n      let type = StringType;\n      if (isStringColor(encoded)) {\n        type |= ColorType;\n      }\n      // apply the given type hint only if it won't result in an empty type\n      if (!isType(type & typeHint, NoneType)) {\n        type &= typeHint;\n      }\n      return new LiteralExpression(type, 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, context, typeHint);\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  let type = NumberArrayType;\n  if (encoded.length === 3 || encoded.length === 4) {\n    type |= ColorType;\n  }\n  if (typeHint) {\n    type &= typeHint;\n  }\n  return new LiteralExpression(type, 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  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  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};\n\n/**\n * @typedef {function(Array, ParsingContext, number):Expression} Parser\n * Third argument is a type hint\n */\n\n/**\n * @type {Object<string, Parser>}\n */\nconst parsers = {\n  [Ops.Get]: createParser(\n    ([_, typeHint]) => {\n      if (typeHint !== undefined) {\n        return getTypeFromHint(\n          /** @type {string} */ (\n            /** @type {LiteralExpression} */ (typeHint).value\n          )\n        );\n      }\n      return AnyType;\n    },\n    withArgsCount(1, 2),\n    withGetArgs\n  ),\n  [Ops.Var]: createParser(\n    ([firstArg]) => firstArg.type,\n    withArgsCount(1, 1),\n    withVarArgs\n  ),\n  [Ops.Id]: createParser(NumberType | StringType, withNoArgs, usesFeatureId),\n  [Ops.Concat]: createParser(\n    StringType,\n    withArgsCount(2, Infinity),\n    parseArgsOfType(AnyType)\n  ),\n  [Ops.GeometryType]: createParser(StringType, withNoArgs),\n  [Ops.Resolution]: createParser(NumberType, withNoArgs),\n  [Ops.Zoom]: createParser(NumberType, withNoArgs),\n  [Ops.Time]: createParser(NumberType, withNoArgs),\n  [Ops.Any]: createParser(\n    BooleanType,\n    withArgsCount(2, Infinity),\n    parseArgsOfType(BooleanType)\n  ),\n  [Ops.All]: createParser(\n    BooleanType,\n    withArgsCount(2, Infinity),\n    parseArgsOfType(BooleanType)\n  ),\n  [Ops.Not]: createParser(\n    BooleanType,\n    withArgsCount(1, 1),\n    parseArgsOfType(BooleanType)\n  ),\n  [Ops.Equal]: createParser(\n    BooleanType,\n    withArgsCount(2, 2),\n    parseArgsOfType(AnyType),\n    narrowArgsType\n  ),\n  [Ops.NotEqual]: createParser(\n    BooleanType,\n    withArgsCount(2, 2),\n    parseArgsOfType(AnyType),\n    narrowArgsType\n  ),\n  [Ops.GreaterThan]: createParser(\n    BooleanType,\n    withArgsCount(2, 2),\n    parseArgsOfType(AnyType),\n    narrowArgsType\n  ),\n  [Ops.GreaterThanOrEqualTo]: createParser(\n    BooleanType,\n    withArgsCount(2, 2),\n    parseArgsOfType(AnyType),\n    narrowArgsType\n  ),\n  [Ops.LessThan]: createParser(\n    BooleanType,\n    withArgsCount(2, 2),\n    parseArgsOfType(AnyType),\n    narrowArgsType\n  ),\n  [Ops.LessThanOrEqualTo]: createParser(\n    BooleanType,\n    withArgsCount(2, 2),\n    parseArgsOfType(AnyType),\n    narrowArgsType\n  ),\n  [Ops.Multiply]: createParser(\n    (parsedArgs) => {\n      let outputType = NumberType | ColorType;\n      for (let i = 0; i < parsedArgs.length; i++) {\n        outputType &= parsedArgs[i].type;\n      }\n      return outputType;\n    },\n    withArgsCount(2, Infinity),\n    parseArgsOfType(NumberType | ColorType),\n    narrowArgsType\n  ),\n  [Ops.Divide]: createParser(\n    NumberType,\n    withArgsCount(2, 2),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Add]: createParser(\n    NumberType,\n    withArgsCount(2, Infinity),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Subtract]: createParser(\n    NumberType,\n    withArgsCount(2, 2),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Clamp]: createParser(\n    NumberType,\n    withArgsCount(3, 3),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Mod]: createParser(\n    NumberType,\n    withArgsCount(2, 2),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Pow]: createParser(\n    NumberType,\n    withArgsCount(2, 2),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Abs]: createParser(\n    NumberType,\n    withArgsCount(1, 1),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Floor]: createParser(\n    NumberType,\n    withArgsCount(1, 1),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Ceil]: createParser(\n    NumberType,\n    withArgsCount(1, 1),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Round]: createParser(\n    NumberType,\n    withArgsCount(1, 1),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Sin]: createParser(\n    NumberType,\n    withArgsCount(1, 1),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Cos]: createParser(\n    NumberType,\n    withArgsCount(1, 1),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Atan]: createParser(\n    NumberType,\n    withArgsCount(1, 2),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Sqrt]: createParser(\n    NumberType,\n    withArgsCount(1, 1),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Match]: createParser(\n    (parsedArgs) => {\n      let type = AnyType;\n      for (let i = 2; i < parsedArgs.length; i += 2) {\n        type &= parsedArgs[i].type;\n      }\n      type &= parsedArgs[parsedArgs.length - 1].type;\n      return type;\n    },\n    withArgsCount(4, Infinity),\n    withEvenArgs,\n    parseMatchArgs\n  ),\n  [Ops.Between]: createParser(\n    BooleanType,\n    withArgsCount(3, 3),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Interpolate]: createParser(\n    (parsedArgs) => {\n      let type = ColorType | NumberType;\n      for (let i = 3; i < parsedArgs.length; i += 2) {\n        type &= parsedArgs[i].type;\n      }\n      return type;\n    },\n    withArgsCount(6, Infinity),\n    withEvenArgs,\n    parseInterpolateArgs\n  ),\n  [Ops.Case]: createParser(\n    (parsedArgs) => {\n      let type = AnyType;\n      for (let i = 1; i < parsedArgs.length; i += 2) {\n        type &= parsedArgs[i].type;\n      }\n      type &= parsedArgs[parsedArgs.length - 1].type;\n      return type;\n    },\n    withArgsCount(3, Infinity),\n    withOddArgs,\n    parseCaseArgs\n  ),\n  [Ops.In]: createParser(BooleanType, withArgsCount(2, 2), parseInArgs),\n  [Ops.Number]: createParser(\n    NumberType,\n    withArgsCount(1, Infinity),\n    parseArgsOfType(AnyType)\n  ),\n  [Ops.String]: createParser(\n    StringType,\n    withArgsCount(1, Infinity),\n    parseArgsOfType(AnyType)\n  ),\n  [Ops.Array]: createParser(\n    (parsedArgs) => {\n      return parsedArgs.length === 3 || parsedArgs.length === 4\n        ? NumberArrayType | ColorType\n        : NumberArrayType;\n    },\n    withArgsCount(1, Infinity),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Color]: createParser(\n    ColorType,\n    withArgsCount(3, 4),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Band]: createParser(\n    NumberType,\n    withArgsCount(1, 3),\n    parseArgsOfType(NumberType)\n  ),\n  [Ops.Palette]: createParser(ColorType, withArgsCount(2, 2), parsePaletteArgs),\n};\n\n/**\n * @typedef {function(Array<EncodedExpression>, ParsingContext, Array<Expression>, number?):Array<Expression>|void} ArgValidator\n * An argument validator applies various checks to an encoded expression arguments\n * Returns the parsed arguments if any.\n * Third argument is the array of parsed arguments from previous validators\n * Fourth argument is an optional type hint\n */\n\n/**\n * @type ArgValidator\n */\nfunction withGetArgs(encoded, context) {\n  const arg = parse(encoded[1], context);\n  if (!(arg instanceof LiteralExpression)) {\n    throw new Error('Expected a literal argument for get operation');\n  }\n  if (typeof arg.value !== 'string') {\n    throw new Error('Expected a string argument for get operation');\n  }\n  context.properties.add(arg.value);\n  if (encoded.length === 3) {\n    const hint = parse(encoded[2], context);\n    return [arg, hint];\n  }\n  return [arg];\n}\n\n/**\n * @type ArgValidator\n */\nfunction withVarArgs(encoded, context, parsedArgs, typeHint) {\n  const varName = encoded[1];\n  if (typeof varName !== 'string') {\n    throw new Error('Expected a string argument for var operation');\n  }\n  context.variables.add(varName);\n  if (\n    !('variables' in context.style) ||\n    context.style.variables[varName] === undefined\n  ) {\n    return [new LiteralExpression(AnyType, varName)];\n  }\n  const initialValue = context.style.variables[varName];\n  const arg = /** @type {LiteralExpression} */ (parse(initialValue, context));\n  arg.value = varName;\n  if (typeHint && !overlapsType(typeHint, arg.type)) {\n    throw new Error(\n      `The variable ${varName} has type ${typeName(\n        arg.type\n      )} but the following type was expected: ${typeName(typeHint)}`\n    );\n  }\n  return [arg];\n}\n\n/**\n * @type ArgValidator\n */\nfunction usesFeatureId(encoded, context) {\n  context.featureId = true;\n}\n\n/**\n * @type ArgValidator\n */\nfunction withNoArgs(encoded, 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 withArgsCount(minArgs, maxArgs) {\n  return function (encoded, 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 * @param {number} argType The argument type.\n * @return {ArgValidator} The argument validator\n */\nfunction parseArgsOfType(argType) {\n  return function (encoded, context) {\n    const operation = encoded[0];\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], context);\n      if (!overlapsType(argType, expression.type)) {\n        const gotType = typeName(argType);\n        const expectedType = typeName(expression.type);\n        throw new Error(\n          `Unexpected type for argument ${i} of ${operation} operation` +\n            `, got ${gotType} but expected ${expectedType}`\n        );\n      }\n      expression.type &= argType;\n      args[i] = expression;\n    }\n    return args;\n  };\n}\n\n/**\n * @type {ArgValidator}\n */\nfunction narrowArgsType(encoded, context, parsedArgs) {\n  const operation = encoded[0];\n  const argCount = encoded.length - 1;\n\n  // first pass to determine a narrowed down type\n  let sameType = AnyType;\n  for (let i = 0; i < parsedArgs.length; ++i) {\n    sameType &= parsedArgs[i].type;\n  }\n\n  if (sameType === NoneType) {\n    throw new Error(\n      `No common type could be found for arguments of ${operation} operation`\n    );\n  }\n\n  // re-parse args\n  const args = new Array(argCount);\n  for (let i = 0; i < argCount; ++i) {\n    args[i] = parse(encoded[i + 1], context, sameType);\n  }\n  return args;\n}\n\n/**\n * @type {ArgValidator}\n */\nfunction withOddArgs(encoded, context) {\n  const operation = encoded[0];\n  const argCount = encoded.length - 1;\n  if (argCount % 2 === 0) {\n    throw new Error(\n      `An odd amount of arguments was expected for operation ${operation}, got ${JSON.stringify(\n        argCount\n      )} instead`\n    );\n  }\n}\n\n/**\n * @type {ArgValidator}\n */\nfunction withEvenArgs(encoded, context) {\n  const operation = encoded[0];\n  const argCount = encoded.length - 1;\n  if (argCount % 2 === 1) {\n    throw new Error(\n      `An even amount of arguments was expected for operation ${operation}, got ${JSON.stringify(\n        argCount\n      )} instead`\n    );\n  }\n}\n\n/**\n * @type ArgValidator\n */\nfunction parseMatchArgs(encoded, context, parsedArgs, typeHint) {\n  const argsCount = encoded.length - 1;\n\n  const input = parse(encoded[1], context);\n  let inputType = input.type;\n  const fallback = parse(encoded[encoded.length - 1], context);\n  let outputType =\n    typeHint !== undefined ? typeHint & fallback.type : fallback.type;\n\n  // first parse args to figure out possible types\n  const args = new Array(argsCount - 2);\n  for (let i = 0; i < argsCount - 2; i += 2) {\n    const match = parse(encoded[i + 2], context);\n    const output = parse(encoded[i + 3], context);\n    inputType &= match.type;\n    outputType &= output.type;\n    args[i] = match;\n    args[i + 1] = output;\n  }\n\n  // check input and output types validity\n  const expectedInputType = StringType | NumberType | BooleanType;\n  if (!overlapsType(expectedInputType, inputType)) {\n    throw new Error(\n      `Expected an input of type ${typeName(\n        expectedInputType\n      )} for the interpolate operation` + `, got ${typeName(inputType)} instead`\n    );\n  }\n  if (isType(outputType, NoneType)) {\n    throw new Error(\n      `Could not find a common output type for the following match operation: ` +\n        JSON.stringify(encoded)\n    );\n  }\n\n  // parse again inputs and outputs with common type\n  for (let i = 0; i < argsCount - 2; i += 2) {\n    const match = parse(encoded[i + 2], context, inputType);\n    const output = parse(encoded[i + 3], context, outputType);\n    args[i] = match;\n    args[i + 1] = output;\n  }\n\n  return [\n    parse(encoded[1], context, inputType),\n    ...args,\n    parse(encoded[encoded.length - 1], context, outputType),\n  ];\n}\n\n/**\n * @type ArgValidator\n */\nfunction parseInterpolateArgs(encoded, context, parsedArgs, typeHint) {\n  const interpolationType = encoded[1];\n  let interpolation;\n  switch (interpolationType[0]) {\n    case 'linear':\n      interpolation = 1;\n      break;\n    case 'exponential':\n      interpolation = interpolationType[1];\n      if (typeof interpolation !== 'number') {\n        throw new Error(\n          `Expected a number base for exponential interpolation` +\n            `, got ${JSON.stringify(interpolation)} instead`\n        );\n      }\n      break;\n    default:\n      interpolation = null;\n  }\n  if (!interpolation) {\n    throw new Error(\n      `Invalid interpolation type: ${JSON.stringify(interpolationType)}`\n    );\n  }\n  interpolation = parse(interpolation, context);\n\n  // check input types\n  let input = parse(encoded[2], context);\n  if (!overlapsType(NumberType, input.type)) {\n    throw new Error(\n      `Expected an input of type number for the interpolate operation` +\n        `, got ${typeName(input.type)} instead`\n    );\n  }\n  input = parse(encoded[2], context, NumberType); // parse again with narrower output\n\n  const args = new Array(encoded.length - 3);\n  for (let i = 0; i < args.length; i += 2) {\n    let stop = parse(encoded[i + 3], context);\n    if (!overlapsType(NumberType, stop.type)) {\n      throw new Error(\n        `Expected all stop input values in the interpolate operation to be of type number` +\n          `, got ${typeName(stop.type)} at position ${i + 2} instead`\n      );\n    }\n    let output = parse(encoded[i + 4], context);\n    if (!overlapsType(NumberType | ColorType, output.type)) {\n      throw new Error(\n        `Expected all stop output values in the interpolate operation to be a number or color` +\n          `, got ${typeName(output.type)} at position ${i + 3} instead`\n      );\n    }\n    // parse again with narrower types\n    stop = parse(encoded[i + 3], context, NumberType);\n    output = parse(encoded[i + 4], context, NumberType | ColorType);\n    args[i] = stop;\n    args[i + 1] = output;\n  }\n\n  return [interpolation, input, ...args];\n}\n\n/**\n * @type ArgValidator\n */\nfunction parseCaseArgs(encoded, context, parsedArgs, typeHint) {\n  const fallback = parse(encoded[encoded.length - 1], context);\n  let outputType =\n    typeHint !== undefined ? typeHint & fallback.type : fallback.type;\n\n  // first parse args to figure out possible types\n  const args = new Array(encoded.length - 1);\n  for (let i = 0; i < args.length - 1; i += 2) {\n    const condition = parse(encoded[i + 1], context);\n    const output = parse(encoded[i + 2], context);\n    if (!overlapsType(BooleanType, condition.type)) {\n      throw new Error(\n        `Expected all conditions in the case operation to be of type boolean` +\n          `, got ${typeName(condition.type)} at position ${i} instead`\n      );\n    }\n    outputType &= output.type;\n    args[i] = condition;\n    args[i + 1] = output;\n  }\n\n  if (isType(outputType, NoneType)) {\n    throw new Error(\n      `Could not find a common output type for the following case operation: ` +\n        JSON.stringify(encoded)\n    );\n  }\n\n  // parse again args with common output type\n  for (let i = 0; i < args.length - 1; i += 2) {\n    args[i + 1] = parse(encoded[i + 2], context, outputType);\n  }\n  args[args.length - 1] = parse(\n    encoded[encoded.length - 1],\n    context,\n    outputType\n  );\n\n  return args;\n}\n\n/**\n * @type ArgValidator\n */\nfunction parseInArgs(encoded, context) {\n  /** @type {Array<number|string>} */\n  let haystack = /** @type {any} */ (encoded[2]);\n  if (!Array.isArray(haystack)) {\n    throw new Error(\n      `The \"in\" operator was provided a literal value which was not an array as second argument.`\n    );\n  }\n  if (typeof haystack[0] === 'string') {\n    if (haystack[0] !== 'literal') {\n      throw new Error(\n        `For the \"in\" operator, a string array should be wrapped in a \"literal\" operator to disambiguate from expressions.`\n      );\n    }\n    if (!Array.isArray(haystack[1])) {\n      throw new Error(\n        `The \"in\" operator was provided a literal value which was not an array as second argument.`\n      );\n    }\n    haystack = haystack[1];\n  }\n\n  let needleType = StringType | NumberType;\n  const args = new Array(haystack.length);\n  for (let i = 0; i < args.length; i++) {\n    const arg = parse(haystack[i], context);\n    needleType &= arg.type;\n    args[i] = arg;\n  }\n  if (isType(needleType, NoneType)) {\n    throw new Error(\n      `Could not find a common type for the following in operation: ` +\n        JSON.stringify(encoded)\n    );\n  }\n\n  const needle = parse(encoded[1], context, needleType);\n  return [needle, ...args];\n}\n\n/**\n * @type ArgValidator\n */\nfunction parsePaletteArgs(encoded, context) {\n  const index = parse(encoded[1], context, NumberType);\n  if (index.type !== NumberType) {\n    throw new Error(\n      `The first argument of palette must be an number, got ${typeName(\n        index.type\n      )} instead`\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    const color = parse(colors[i], context, ColorType);\n    if (!(color instanceof LiteralExpression)) {\n      throw new Error(\n        `The palette color at index ${i} must be a literal value`\n      );\n    }\n    if (!overlapsType(color.type, ColorType)) {\n      throw new Error(\n        `The palette color at index ${i} should be of type color, got ${typeName(\n          color.type\n        )} instead`\n      );\n    }\n    parsedColors[i] = color;\n  }\n  return [index, ...parsedColors];\n}\n\n/**\n * @param {number|function(Array<Expression>):number} returnType The return type of the operator; can be a fixed value or a callback taking the parsed\n * arguments\n * @param {Array<ArgValidator>} argValidators A chain of argument validators; the return value of the last validator\n * will be used as parsed arguments\n * @return {Parser} The parser.\n */\nfunction createParser(returnType, ...argValidators) {\n  return function (encoded, context, typeHint) {\n    const operator = encoded[0];\n    let parsedArgs = [];\n    for (let i = 0; i < argValidators.length; i++) {\n      parsedArgs =\n        argValidators[i](encoded, context, parsedArgs, typeHint) || parsedArgs;\n    }\n    let actualType =\n      typeof returnType === 'function' ? returnType(parsedArgs) : returnType;\n    if (typeHint !== undefined) {\n      if (!overlapsType(actualType, typeHint)) {\n        throw new Error(\n          `The following expression was expected to return ${typeName(\n            typeHint\n          )}, but returns ${typeName(actualType)} instead: ${JSON.stringify(\n            encoded\n          )}`\n        );\n      }\n      actualType &= typeHint;\n    }\n    if (actualType === NoneType) {\n      throw new Error(\n        `No matching type was found for the following expression: ${JSON.stringify(\n          encoded\n        )}`\n      );\n    }\n    return new CallExpression(actualType, operator, ...parsedArgs);\n  };\n}\n\n/**\n * @param {Array} encoded The encoded expression.\n * @param {ParsingContext} context The parsing context.\n * @param {number} [typeHint] Optional type hint\n * @return {Expression} The parsed expression.\n */\nfunction parseCallExpression(encoded, context, typeHint) {\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, context, typeHint);\n}\n","/**\n * @module ol/webgl/TileTexture\n */\n\nimport BaseTileRepresentation from './BaseTileRepresentation.js';\nimport DataTile, {asArrayLike, asImageLike} from '../DataTile.js';\nimport EventType from '../events/EventType.js';\nimport ImageTile from '../ImageTile.js';\nimport ReprojTile from '../reproj/Tile.js';\nimport WebGLArrayBuffer from './Buffer.js';\nimport {ARRAY_BUFFER, STATIC_DRAW} from '../webgl.js';\nimport {createCanvasContext2D} from '../dom.js';\nimport {toSize} from '../size.js';\n\n/**\n * @param {WebGLRenderingContext} gl The WebGL context.\n * @param {WebGLTexture} texture The texture.\n * @param {boolean} interpolate Interpolate when resampling.\n */\nfunction bindAndConfigure(gl, texture, interpolate) {\n  const resampleFilter = interpolate ? gl.LINEAR : gl.NEAREST;\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, resampleFilter);\n  gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, resampleFilter);\n}\n\n/**\n * @param {WebGLRenderingContext} gl The WebGL context.\n * @param {WebGLTexture} texture The texture.\n * @param {import(\"../DataTile.js\").ImageLike} image The image.\n * @param {boolean} interpolate Interpolate when resampling.\n */\nfunction uploadImageTexture(gl, texture, image, interpolate) {\n  bindAndConfigure(gl, texture, interpolate);\n\n  gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, image);\n}\n\n/**\n * @param {import(\"./Helper.js\").default} helper The WebGL helper.\n * @param {WebGLTexture} texture The texture.\n * @param {import(\"../DataTile.js\").ArrayLike} data The pixel data.\n * @param {import(\"../size.js\").Size} size The pixel size.\n * @param {number} bandCount The band count.\n * @param {boolean} interpolate Interpolate when resampling.\n */\nfunction uploadDataTexture(\n  helper,\n  texture,\n  data,\n  size,\n  bandCount,\n  interpolate\n) {\n  const gl = helper.getGL();\n  let textureType;\n  let canInterpolate;\n  if (data instanceof Float32Array) {\n    textureType = gl.FLOAT;\n    helper.getExtension('OES_texture_float');\n    const extension = helper.getExtension('OES_texture_float_linear');\n    canInterpolate = extension !== null;\n  } else {\n    textureType = gl.UNSIGNED_BYTE;\n    canInterpolate = true;\n  }\n  bindAndConfigure(gl, texture, interpolate && canInterpolate);\n\n  const bytesPerRow = data.byteLength / size[1];\n  let unpackAlignment = 1;\n  if (bytesPerRow % 8 === 0) {\n    unpackAlignment = 8;\n  } else if (bytesPerRow % 4 === 0) {\n    unpackAlignment = 4;\n  } else if (bytesPerRow % 2 === 0) {\n    unpackAlignment = 2;\n  }\n\n  let format;\n  switch (bandCount) {\n    case 1: {\n      format = gl.LUMINANCE;\n      break;\n    }\n    case 2: {\n      format = gl.LUMINANCE_ALPHA;\n      break;\n    }\n    case 3: {\n      format = gl.RGB;\n      break;\n    }\n    case 4: {\n      format = gl.RGBA;\n      break;\n    }\n    default: {\n      throw new Error(`Unsupported number of bands: ${bandCount}`);\n    }\n  }\n\n  const oldUnpackAlignment = gl.getParameter(gl.UNPACK_ALIGNMENT);\n  gl.pixelStorei(gl.UNPACK_ALIGNMENT, unpackAlignment);\n  gl.texImage2D(\n    gl.TEXTURE_2D,\n    0,\n    format,\n    size[0],\n    size[1],\n    0,\n    format,\n    textureType,\n    data\n  );\n  gl.pixelStorei(gl.UNPACK_ALIGNMENT, oldUnpackAlignment);\n}\n\n/**\n * @type {CanvasRenderingContext2D}\n */\nlet pixelContext = null;\n\nfunction createPixelContext() {\n  pixelContext = createCanvasContext2D(1, 1, undefined, {\n    willReadFrequently: true,\n  });\n}\n\n/**\n * @typedef {import(\"../DataTile.js\").default|ImageTile|ReprojTile} TileType\n */\n\n/**\n * @extends {BaseTileRepresentation<TileType>}\n */\nclass TileTexture extends BaseTileRepresentation {\n  /**\n   * @param {import(\"./BaseTileRepresentation.js\").TileRepresentationOptions<TileType>} options The tile texture options.\n   */\n  constructor(options) {\n    super(options);\n\n    /**\n     * @type {Array<WebGLTexture>}\n     */\n    this.textures = [];\n\n    /**\n     * @type {import(\"../size.js\").Size}\n     * @private\n     */\n    this.renderSize_ = toSize(\n      options.grid.getTileSize(options.tile.tileCoord[0])\n    );\n\n    /**\n     * @type {number}\n     */\n    this.bandCount = NaN;\n\n    const coords = new WebGLArrayBuffer(ARRAY_BUFFER, STATIC_DRAW);\n    coords.fromArray([\n      0, // P0\n      1,\n      1, // P1\n      1,\n      1, // P2\n      0,\n      0, // P3\n      0,\n    ]);\n    this.helper_.flushBufferData(coords);\n\n    /**\n     * @type {WebGLArrayBuffer}\n     */\n    this.coords = coords;\n\n    this.setTile(options.tile);\n  }\n\n  uploadTile() {\n    const helper = this.helper_;\n    const gl = helper.getGL();\n    const tile = this.tile;\n\n    this.textures.length = 0;\n\n    /**\n     * @type {import(\"../DataTile.js\").Data}\n     */\n    let data;\n\n    if (tile instanceof ImageTile || tile instanceof ReprojTile) {\n      data = tile.getImage();\n    } else {\n      data = tile.getData();\n    }\n\n    const image = asImageLike(data);\n    if (image) {\n      const texture = gl.createTexture();\n      this.textures.push(texture);\n      this.bandCount = 4;\n      uploadImageTexture(gl, texture, image, tile.interpolate);\n      this.setReady();\n      return;\n    }\n\n    data = asArrayLike(data);\n\n    const sourceTileSize = /** @type {DataTile} */ (tile).getSize();\n    const pixelSize = [\n      sourceTileSize[0] + 2 * this.gutter_,\n      sourceTileSize[1] + 2 * this.gutter_,\n    ];\n    const isFloat = data instanceof Float32Array;\n    const pixelCount = pixelSize[0] * pixelSize[1];\n    const DataType = isFloat ? Float32Array : Uint8Array;\n    const bytesPerElement = DataType.BYTES_PER_ELEMENT;\n    const bytesPerRow = data.byteLength / pixelSize[1];\n\n    this.bandCount = Math.floor(bytesPerRow / bytesPerElement / pixelSize[0]);\n    const textureCount = Math.ceil(this.bandCount / 4);\n\n    if (textureCount === 1) {\n      const texture = gl.createTexture();\n      this.textures.push(texture);\n      uploadDataTexture(\n        helper,\n        texture,\n        data,\n        pixelSize,\n        this.bandCount,\n        tile.interpolate\n      );\n      this.setReady();\n      return;\n    }\n\n    const textureDataArrays = new Array(textureCount);\n    for (let textureIndex = 0; textureIndex < textureCount; ++textureIndex) {\n      const texture = gl.createTexture();\n      this.textures.push(texture);\n\n      const bandCount =\n        textureIndex < textureCount - 1 ? 4 : ((this.bandCount - 1) % 4) + 1;\n      textureDataArrays[textureIndex] = new DataType(pixelCount * bandCount);\n    }\n\n    let dataIndex = 0;\n    let rowOffset = 0;\n    const colCount = pixelSize[0] * this.bandCount;\n    for (let rowIndex = 0; rowIndex < pixelSize[1]; ++rowIndex) {\n      for (let colIndex = 0; colIndex < colCount; ++colIndex) {\n        const dataValue = data[rowOffset + colIndex];\n\n        const pixelIndex = Math.floor(dataIndex / this.bandCount);\n        const bandIndex = colIndex % this.bandCount;\n        const textureIndex = Math.floor(bandIndex / 4);\n        const textureData = textureDataArrays[textureIndex];\n        const bandCount = textureData.length / pixelCount;\n        const textureBandIndex = bandIndex % 4;\n        textureData[pixelIndex * bandCount + textureBandIndex] = dataValue;\n\n        ++dataIndex;\n      }\n      rowOffset += bytesPerRow / bytesPerElement;\n    }\n\n    for (let textureIndex = 0; textureIndex < textureCount; ++textureIndex) {\n      const texture = this.textures[textureIndex];\n      const textureData = textureDataArrays[textureIndex];\n      const bandCount = textureData.length / pixelCount;\n      uploadDataTexture(\n        helper,\n        texture,\n        textureData,\n        pixelSize,\n        bandCount,\n        tile.interpolate\n      );\n    }\n\n    this.setReady();\n  }\n\n  disposeInternal() {\n    const gl = this.helper_.getGL();\n    this.helper_.deleteBuffer(this.coords);\n    for (let i = 0; i < this.textures.length; ++i) {\n      gl.deleteTexture(this.textures[i]);\n    }\n    this.tile.removeEventListener(EventType.CHANGE, this.handleTileChange_);\n  }\n\n  /**\n   * @param {import(\"../DataTile.js\").ImageLike} image The image.\n   * @param {number} renderCol The column index (in rendered tile space).\n   * @param {number} renderRow The row index (in rendered tile space).\n   * @return {Uint8ClampedArray|null} The data.\n   * @private\n   */\n  getImagePixelData_(image, renderCol, renderRow) {\n    const gutter = this.gutter_;\n    const renderWidth = this.renderSize_[0];\n    const renderHeight = this.renderSize_[1];\n\n    if (!pixelContext) {\n      createPixelContext();\n    }\n    pixelContext.clearRect(0, 0, 1, 1);\n\n    const sourceWidth = image.width;\n    const sourceHeight = image.height;\n\n    const sourceWidthWithoutGutter = sourceWidth - 2 * gutter;\n    const sourceHeightWithoutGutter = sourceHeight - 2 * gutter;\n\n    const sourceCol =\n      gutter + Math.floor(sourceWidthWithoutGutter * (renderCol / renderWidth));\n\n    const sourceRow =\n      gutter +\n      Math.floor(sourceHeightWithoutGutter * (renderRow / renderHeight));\n\n    let data;\n    try {\n      pixelContext.drawImage(image, sourceCol, sourceRow, 1, 1, 0, 0, 1, 1);\n      data = pixelContext.getImageData(0, 0, 1, 1).data;\n    } catch (err) {\n      pixelContext = null;\n      return null;\n    }\n    return data;\n  }\n\n  /**\n   * @param {import(\"../DataTile.js\").ArrayLike} data The data.\n   * @param {import(\"../size.js\").Size} sourceSize The size.\n   * @param {number} renderCol The column index (in rendered tile space).\n   * @param {number} renderRow The row index (in rendered tile space).\n   * @return {import(\"../DataTile.js\").ArrayLike|null} The data.\n   * @private\n   */\n  getArrayPixelData_(data, sourceSize, renderCol, renderRow) {\n    const gutter = this.gutter_;\n    const renderWidth = this.renderSize_[0];\n    const renderHeight = this.renderSize_[1];\n\n    const sourceWidthWithoutGutter = sourceSize[0];\n    const sourceHeightWithoutGutter = sourceSize[1];\n    const sourceWidth = sourceWidthWithoutGutter + 2 * gutter;\n    const sourceHeight = sourceHeightWithoutGutter + 2 * gutter;\n\n    const sourceCol =\n      gutter + Math.floor(sourceWidthWithoutGutter * (renderCol / renderWidth));\n\n    const sourceRow =\n      gutter +\n      Math.floor(sourceHeightWithoutGutter * (renderRow / renderHeight));\n\n    if (data instanceof DataView) {\n      const bytesPerPixel = data.byteLength / (sourceWidth * sourceHeight);\n      const offset = bytesPerPixel * (sourceRow * sourceWidth + sourceCol);\n      const buffer = data.buffer.slice(offset, offset + bytesPerPixel);\n      return new DataView(buffer);\n    }\n\n    const offset = this.bandCount * (sourceRow * sourceWidth + sourceCol);\n    return data.slice(offset, offset + this.bandCount);\n  }\n\n  /**\n   * Get data for a pixel.  If the tile is not loaded, null is returned.\n   * @param {number} renderCol The column index (in rendered tile space).\n   * @param {number} renderRow The row index (in rendered tile space).\n   * @return {import(\"../DataTile.js\").ArrayLike|null} The data.\n   */\n  getPixelData(renderCol, renderRow) {\n    if (!this.loaded) {\n      return null;\n    }\n\n    if (this.tile instanceof DataTile) {\n      const data = this.tile.getData();\n      const arrayData = asArrayLike(data);\n      if (arrayData) {\n        const sourceSize = this.tile.getSize();\n        return this.getArrayPixelData_(\n          arrayData,\n          sourceSize,\n          renderCol,\n          renderRow\n        );\n      }\n      return this.getImagePixelData_(asImageLike(data), renderCol, renderRow);\n    }\n\n    return this.getImagePixelData_(this.tile.getImage(), renderCol, renderRow);\n  }\n}\n\nexport default TileTexture;\n","/**\n * @module ol/renderer/webgl/Layer\n */\nimport LayerProperty from '../../layer/Property.js';\nimport LayerRenderer from '../Layer.js';\nimport RenderEvent from '../../render/Event.js';\nimport RenderEventType from '../../render/EventType.js';\nimport WebGLHelper from '../../webgl/Helper.js';\nimport {\n  compose as composeTransform,\n  create as createTransform,\n} from '../../transform.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\").UniformValue>} [uniforms] Uniform definitions for the post process step\n */\n\n/**\n * @typedef {Object} Options\n * @property {Object<string,import(\"../../webgl/Helper\").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     * @type {CanvasRenderingContext2D}\n     */\n    this.pixelContext_ = null;\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    layer.addChangeListener(LayerProperty.MAP, this.removeHelper.bind(this));\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   */\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   * Clean up.\n   */\n  disposeInternal() {\n    this.removeHelper();\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/TileLayerBase\n */\nimport LRUCache from '../../structs/LRUCache.js';\nimport ReprojDataTile from '../../reproj/DataTile.js';\nimport ReprojTile from '../../reproj/Tile.js';\nimport TileRange from '../../TileRange.js';\nimport TileState from '../../TileState.js';\nimport WebGLLayerRenderer from './Layer.js';\nimport {abstract, getUid} from '../../util.js';\nimport {create as createMat4} from '../../vec/mat4.js';\nimport {\n  createOrUpdate as createTileCoord,\n  getKey as getTileCoordKey,\n} from '../../tilecoord.js';\nimport {\n  create as createTransform,\n  reset as resetTransform,\n  rotate as rotateTransform,\n  scale as scaleTransform,\n  translate as translateTransform,\n} from '../../transform.js';\nimport {descending} from '../../array.js';\nimport {fromUserExtent} from '../../proj.js';\nimport {getIntersection, isEmpty} from '../../extent.js';\nimport {toSize} from '../../size.js';\n\nexport const Uniforms = {\n  TILE_TRANSFORM: 'u_tileTransform',\n  TRANSITION_ALPHA: 'u_transitionAlpha',\n  DEPTH: 'u_depth',\n  RENDER_EXTENT: 'u_renderExtent', // intersection of layer, source, and view extent\n  PATTERN_ORIGIN: 'u_patternOrigin',\n  RESOLUTION: 'u_resolution',\n  ZOOM: 'u_zoom',\n  GLOBAL_ALPHA: 'u_globalAlpha',\n  PROJECTION_MATRIX: 'u_projectionMatrix',\n  SCREEN_TO_WORLD_MATRIX: 'u_screenToWorldMatrix',\n};\n\n/**\n * @type {Object<string, boolean>}\n */\nconst empty = {};\n\n/**\n * Transform a zoom level into a depth value; zoom level zero has a depth value of 0.5, and increasing values\n * have a depth trending towards 0\n * @param {number} z A zoom level.\n * @return {number} A depth value.\n */\nfunction depthForZ(z) {\n  return 1 / (z + 2);\n}\n\n/**\n * @typedef {import(\"../../webgl/BaseTileRepresentation.js\").default<import(\"../../Tile.js\").default>} AbstractTileRepresentation\n */\n/**\n * @typedef {Object} TileRepresentationLookup\n * @property {Set<string>} tileIds The set of tile ids in the lookup.\n * @property {Object<number, Set<AbstractTileRepresentation>>} representationsByZ Tile representations by zoom level.\n */\n\n/**\n * @return {TileRepresentationLookup} A new tile representation lookup.\n */\nexport function newTileRepresentationLookup() {\n  return {tileIds: new Set(), representationsByZ: {}};\n}\n\n/**\n * Check if a tile is already in the tile representation lookup.\n * @param {TileRepresentationLookup} tileRepresentationLookup Lookup of tile representations by zoom level.\n * @param {import(\"../../Tile.js\").default} tile A tile.\n * @return {boolean} The tile is already in the lookup.\n */\nfunction lookupHasTile(tileRepresentationLookup, tile) {\n  return tileRepresentationLookup.tileIds.has(getUid(tile));\n}\n\n/**\n * Add a tile representation to the lookup.\n * @param {TileRepresentationLookup} tileRepresentationLookup Lookup of tile representations by zoom level.\n * @param {AbstractTileRepresentation} tileRepresentation A tile representation.\n * @param {number} z The zoom level.\n */\nfunction addTileRepresentationToLookup(\n  tileRepresentationLookup,\n  tileRepresentation,\n  z\n) {\n  const representationsByZ = tileRepresentationLookup.representationsByZ;\n  if (!(z in representationsByZ)) {\n    representationsByZ[z] = new Set();\n  }\n  representationsByZ[z].add(tileRepresentation);\n  tileRepresentationLookup.tileIds.add(getUid(tileRepresentation.tile));\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\nexport function getCacheKey(source, tileCoord) {\n  return `${source.getKey()},${getTileCoordKey(tileCoord)}`;\n}\n\n/**\n * @typedef {Object} Options\n * @property {Object<string, import(\"../../webgl/Helper\").UniformValue>} [uniforms] Additional uniforms\n * made available to shaders.\n * @property {number} [cacheSize=512] The tile representation cache size.\n * @property {Array<import('./Layer.js').PostProcessesOptions>} [postProcesses] Post-processes definitions.\n */\n\n/**\n * @typedef {import(\"../../layer/BaseTile.js\").default} BaseLayerType\n */\n\n/**\n * @classdesc\n * Base WebGL renderer for tile layers.\n * @template {BaseLayerType} LayerType\n * @template {import(\"../../Tile.js\").default} TileType\n * @template {import(\"../../webgl/BaseTileRepresentation.js\").default<TileType>} TileRepresentation\n * @extends {WebGLLayerRenderer<LayerType>}\n */\nclass WebGLBaseTileLayerRenderer extends WebGLLayerRenderer {\n  /**\n   * @param {LayerType} tileLayer Tile layer.\n   * @param {Options} options Options.\n   */\n  constructor(tileLayer, options) {\n    super(tileLayer, {\n      uniforms: options.uniforms,\n      postProcesses: options.postProcesses,\n    });\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     * This transform converts representation coordinates to screen coordinates.\n     * @type {import(\"../../transform.js\").Transform}\n     * @private\n     */\n    this.tileTransform_ = createTransform();\n\n    /**\n     * @type {Array<number>}\n     * @protected\n     */\n    this.tempMat4 = createMat4();\n\n    /**\n     * @type {import(\"../../TileRange.js\").default}\n     * @private\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    /**\n     * @type {import(\"../../size.js\").Size}\n     * @private\n     */\n    this.tempSize_ = [0, 0];\n\n    const cacheSize = options.cacheSize !== undefined ? options.cacheSize : 512;\n    /**\n     * @type {import(\"../../structs/LRUCache.js\").default<TileRepresentation>}\n     * @protected\n     */\n    this.tileRepresentationCache = new LRUCache(cacheSize);\n\n    /**\n     * @protected\n     * @type {import(\"../../Map.js\").FrameState|null}\n     */\n    this.frameState = null;\n\n    /**\n     * @private\n     * @type {import(\"../../proj/Projection.js\").default}\n     */\n    this.projection_ = undefined;\n  }\n\n  /**\n   * @param {Options} options Options.\n   */\n  reset(options) {\n    super.reset({\n      uniforms: options.uniforms,\n    });\n  }\n\n  /**\n   * @param {TileType} tile Tile.\n   * @return {boolean} Tile is drawable.\n   * @private\n   */\n  isDrawableTile_(tile) {\n    const tileLayer = this.getLayer();\n    const tileState = tile.getState();\n    const useInterimTilesOnError = tileLayer.getUseInterimTilesOnError();\n    return (\n      tileState == TileState.LOADED ||\n      tileState == TileState.EMPTY ||\n      (tileState == TileState.ERROR && !useInterimTilesOnError)\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   */\n  prepareFrameInternal(frameState) {\n    if (!this.projection_) {\n      this.projection_ = frameState.viewState.projection;\n    } else if (frameState.viewState.projection !== this.projection_) {\n      this.clearCache();\n      this.projection_ = frameState.viewState.projection;\n    }\n\n    const layer = this.getLayer();\n    const source = layer.getRenderSource();\n    if (!source) {\n      return false;\n    }\n\n    if (isEmpty(getRenderExtent(frameState, frameState.extent))) {\n      return false;\n    }\n    return source.getState() === 'ready';\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../../webgl/BaseTileRepresentation.js\").TileRepresentationOptions<TileType>} options tile representation options\n   * @return {TileRepresentation} A new tile representation\n   * @protected\n   */\n  createTileRepresentation(options) {\n    return abstract();\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 {TileRepresentationLookup} tileRepresentationLookup The zoom level.\n   * @param {number} preload Number of additional levels to load.\n   */\n  enqueueTiles(\n    frameState,\n    extent,\n    initialZ,\n    tileRepresentationLookup,\n    preload\n  ) {\n    const viewState = frameState.viewState;\n    const tileLayer = this.getLayer();\n    const tileSource = tileLayer.getRenderSource();\n    const tileGrid = tileSource.getTileGridForProjection(viewState.projection);\n    const gutter = tileSource.getGutterForProjection(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    const tileRepresentationCache = this.tileRepresentationCache;\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    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          const tileCoord = createTileCoord(z, x, y, this.tempTileCoord_);\n          const cacheKey = getCacheKey(tileSource, tileCoord);\n\n          /** @type {TileRepresentation} */\n          let tileRepresentation;\n\n          /** @type {TileType} */\n          let tile;\n\n          if (tileRepresentationCache.containsKey(cacheKey)) {\n            tileRepresentation = tileRepresentationCache.get(cacheKey);\n            tile = tileRepresentation.tile;\n          }\n          if (\n            !tileRepresentation ||\n            tileRepresentation.tile.key !== tileSource.getKey()\n          ) {\n            tile = tileSource.getTile(\n              z,\n              x,\n              y,\n              frameState.pixelRatio,\n              viewState.projection\n            );\n          }\n\n          if (lookupHasTile(tileRepresentationLookup, tile)) {\n            continue;\n          }\n\n          if (!tileRepresentation) {\n            tileRepresentation = this.createTileRepresentation({\n              tile: tile,\n              grid: tileGrid,\n              helper: this.helper,\n              gutter: gutter,\n            });\n            tileRepresentationCache.set(cacheKey, tileRepresentation);\n          } else {\n            if (this.isDrawableTile_(tile)) {\n              tileRepresentation.setTile(tile);\n            } else {\n              const interimTile = /** @type {TileType} */ (\n                tile.getInterimTile()\n              );\n              tileRepresentation.setTile(interimTile);\n            }\n          }\n\n          addTileRepresentationToLookup(\n            tileRepresentationLookup,\n            tileRepresentation,\n            z\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              frameState.tileQueue.enqueue([\n                tile,\n                tileSourceKey,\n                tileGrid.getTileCoordCenter(tileCoord),\n                tileResolution,\n              ]);\n            }\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @param {boolean} tilesWithAlpha True if at least one of the rendered tiles has alpha\n   * @protected\n   */\n  beforeTilesRender(frameState, tilesWithAlpha) {\n    this.helper.prepareDraw(this.frameState, !tilesWithAlpha, true);\n  }\n\n  /**\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @return {boolean} If returns false, tile mask rendering will be skipped\n   * @protected\n   */\n  beforeTilesMaskRender(frameState) {\n    return false;\n  }\n\n  /**\n   * @param {TileRepresentation} tileRepresentation Tile representation\n   * @param {import(\"../../transform.js\").Transform} tileTransform Tile transform\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state\n   * @param {import(\"../../extent.js\").Extent} renderExtent Render extent\n   * @param {number} tileResolution Tile resolution\n   * @param {import(\"../../size.js\").Size} tileSize Tile size\n   * @param {import(\"../../coordinate.js\").Coordinate} tileOrigin Tile origin\n   * @param {import(\"../../extent.js\").Extent} tileExtent tile Extent\n   * @param {number} depth Depth\n   * @param {number} gutter Gutter\n   * @param {number} alpha Alpha\n   * @protected\n   */\n  renderTile(\n    tileRepresentation,\n    tileTransform,\n    frameState,\n    renderExtent,\n    tileResolution,\n    tileSize,\n    tileOrigin,\n    tileExtent,\n    depth,\n    gutter,\n    alpha\n  ) {}\n\n  /**\n   * @param {TileRepresentation} tileRepresentation Tile representation\n   * @param {number} tileZ Tile Z\n   * @param {import(\"../../extent.js\").Extent} extent Render extent\n   * @param {number} depth Depth\n   * @protected\n   */\n  renderTileMask(tileRepresentation, tileZ, extent, depth) {}\n\n  drawTile_(\n    frameState,\n    tileRepresentation,\n    tileZ,\n    gutter,\n    extent,\n    alphaLookup,\n    tileGrid\n  ) {\n    if (!tileRepresentation.ready) {\n      return;\n    }\n    const tile = tileRepresentation.tile;\n    const tileCoord = tile.tileCoord;\n    const tileCoordKey = getTileCoordKey(tileCoord);\n    const alpha = tileCoordKey in alphaLookup ? alphaLookup[tileCoordKey] : 1;\n\n    const tileResolution = tileGrid.getResolution(tileZ);\n    const tileSize = toSize(tileGrid.getTileSize(tileZ), this.tempSize_);\n    const tileOrigin = tileGrid.getOrigin(tileZ);\n    const tileExtent = tileGrid.getTileCoordExtent(tileCoord);\n    // tiles with alpha are rendered last to allow blending\n    const depth = alpha < 1 ? -1 : depthForZ(tileZ);\n    if (alpha < 1) {\n      frameState.animate = true;\n    }\n\n    const viewState = frameState.viewState;\n    const centerX = viewState.center[0];\n    const centerY = viewState.center[1];\n\n    const tileWidthWithGutter = tileSize[0] + 2 * gutter;\n    const tileHeightWithGutter = tileSize[1] + 2 * gutter;\n\n    const aspectRatio = tileWidthWithGutter / tileHeightWithGutter;\n\n    const centerI = (centerX - tileOrigin[0]) / (tileSize[0] * tileResolution);\n    const centerJ = (tileOrigin[1] - centerY) / (tileSize[1] * tileResolution);\n\n    const tileScale = viewState.resolution / tileResolution;\n\n    const tileCenterI = tileCoord[1];\n    const tileCenterJ = tileCoord[2];\n\n    resetTransform(this.tileTransform_);\n    scaleTransform(\n      this.tileTransform_,\n      2 / ((frameState.size[0] * tileScale) / tileWidthWithGutter),\n      -2 / ((frameState.size[1] * tileScale) / tileWidthWithGutter)\n    );\n    rotateTransform(this.tileTransform_, viewState.rotation);\n    scaleTransform(this.tileTransform_, 1, 1 / aspectRatio);\n    translateTransform(\n      this.tileTransform_,\n      (tileSize[0] * (tileCenterI - centerI) - gutter) / tileWidthWithGutter,\n      (tileSize[1] * (tileCenterJ - centerJ) - gutter) / tileHeightWithGutter\n    );\n\n    this.renderTile(\n      /** @type {TileRepresentation} */ (tileRepresentation),\n      this.tileTransform_,\n      frameState,\n      extent,\n      tileResolution,\n      tileSize,\n      tileOrigin,\n      tileExtent,\n      depth,\n      gutter,\n      alpha\n    );\n  }\n\n  /**\n   * Render the layer.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @return {HTMLElement} The rendered element.\n   */\n  renderFrame(frameState) {\n    this.frameState = frameState;\n    this.renderComplete = true;\n    const gl = this.helper.getGL();\n    this.preRender(gl, frameState);\n\n    const viewState = frameState.viewState;\n    const tileLayer = this.getLayer();\n    const tileSource = tileLayer.getRenderSource();\n    const tileGrid = tileSource.getTileGridForProjection(viewState.projection);\n    const gutter = tileSource.getGutterForProjection(viewState.projection);\n    const extent = getRenderExtent(frameState, frameState.extent);\n    const z = tileGrid.getZForResolution(\n      viewState.resolution,\n      tileSource.zDirection\n    );\n\n    /**\n     * @type {TileRepresentationLookup}\n     */\n    const tileRepresentationLookup = newTileRepresentationLookup();\n\n    const preload = tileLayer.getPreload();\n    if (frameState.nextExtent) {\n      const targetZ = tileGrid.getZForResolution(\n        viewState.nextResolution,\n        tileSource.zDirection\n      );\n      const nextExtent = getRenderExtent(frameState, frameState.nextExtent);\n      this.enqueueTiles(\n        frameState,\n        nextExtent,\n        targetZ,\n        tileRepresentationLookup,\n        preload\n      );\n    }\n\n    this.enqueueTiles(frameState, extent, z, tileRepresentationLookup, 0);\n    if (preload > 0) {\n      setTimeout(() => {\n        this.enqueueTiles(\n          frameState,\n          extent,\n          z - 1,\n          tileRepresentationLookup,\n          preload - 1\n        );\n      }, 0);\n    }\n\n    /**\n     * A lookup of alpha values for tiles at the target rendering resolution\n     * for tiles that are in transition.  If a tile coord key is absent from\n     * this lookup, the tile should be rendered at alpha 1.\n     * @type {Object<string, number>}\n     */\n    const alphaLookup = {};\n\n    const uid = getUid(this);\n    const time = frameState.time;\n    let blend = false;\n\n    // look for cached tiles to use if a target tile is not ready\n    for (const tileRepresentation of tileRepresentationLookup\n      .representationsByZ[z]) {\n      const tile = tileRepresentation.tile;\n      if (\n        (tile instanceof ReprojTile || tile instanceof ReprojDataTile) &&\n        tile.getState() === TileState.EMPTY\n      ) {\n        continue;\n      }\n      const tileCoord = tile.tileCoord;\n\n      if (tileRepresentation.ready) {\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        blend = true;\n        const tileCoordKey = getTileCoordKey(tileCoord);\n        alphaLookup[tileCoordKey] = alpha;\n      }\n      this.renderComplete = false;\n\n      // first look for child tiles (at z + 1)\n      const coveredByChildren = this.findAltTiles_(\n        tileGrid,\n        tileCoord,\n        z + 1,\n        tileRepresentationLookup\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          tileRepresentationLookup\n        );\n\n        if (coveredByParent) {\n          break;\n        }\n      }\n    }\n\n    const representationsByZ = tileRepresentationLookup.representationsByZ;\n    const zs = Object.keys(representationsByZ).map(Number).sort(descending);\n\n    const renderTileMask = this.beforeTilesMaskRender(frameState);\n\n    if (renderTileMask) {\n      for (let j = 0, jj = zs.length; j < jj; ++j) {\n        const tileZ = zs[j];\n        for (const tileRepresentation of representationsByZ[tileZ]) {\n          const tileCoord = tileRepresentation.tile.tileCoord;\n          const tileCoordKey = getTileCoordKey(tileCoord);\n          // do not render the tile mask if alpha < 1\n          if (tileCoordKey in alphaLookup) {\n            continue;\n          }\n          const tileExtent = tileGrid.getTileCoordExtent(tileCoord);\n          this.renderTileMask(\n            /** @type {TileRepresentation} */ (tileRepresentation),\n            tileZ,\n            tileExtent,\n            depthForZ(tileZ)\n          );\n        }\n      }\n    }\n\n    this.beforeTilesRender(frameState, blend);\n\n    for (let j = 0, jj = zs.length; j < jj; ++j) {\n      const tileZ = zs[j];\n      for (const tileRepresentation of representationsByZ[tileZ]) {\n        const tileCoord = tileRepresentation.tile.tileCoord;\n        const tileCoordKey = getTileCoordKey(tileCoord);\n        if (tileCoordKey in alphaLookup) {\n          continue;\n        }\n\n        this.drawTile_(\n          frameState,\n          tileRepresentation,\n          tileZ,\n          gutter,\n          extent,\n          alphaLookup,\n          tileGrid\n        );\n      }\n    }\n\n    for (const tileRepresentation of representationsByZ[z]) {\n      const tileCoord = tileRepresentation.tile.tileCoord;\n      const tileCoordKey = getTileCoordKey(tileCoord);\n      if (tileCoordKey in alphaLookup) {\n        this.drawTile_(\n          frameState,\n          tileRepresentation,\n          z,\n          gutter,\n          extent,\n          alphaLookup,\n          tileGrid\n        );\n      }\n    }\n\n    this.helper.finalizeDraw(\n      frameState,\n      this.dispatchPreComposeEvent,\n      this.dispatchPostComposeEvent\n    );\n\n    const canvas = this.helper.getCanvas();\n\n    const tileRepresentationCache = this.tileRepresentationCache;\n    while (tileRepresentationCache.canExpireCache()) {\n      const tileRepresentation = tileRepresentationCache.pop();\n      tileRepresentation.dispose();\n    }\n\n    // TODO: let the renderers manage their own cache instead of managing the source cache\n    /**\n     * Here we unconditionally expire the source cache since the renderer maintains\n     * its own cache.\n     * @param {import(\"../../Map.js\").default} map Map.\n     * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n     */\n    const postRenderFunction = function (map, frameState) {\n      tileSource.updateCacheSize(0.1, frameState.viewState.projection);\n      tileSource.expireCache(frameState.viewState.projection, empty);\n    };\n\n    frameState.postRenderFunctions.push(postRenderFunction);\n\n    this.postRender(gl, frameState);\n    return canvas;\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 representation 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 {TileRepresentationLookup} tileRepresentationLookup Lookup of\n   * tile representations 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, tileRepresentationLookup) {\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 tileRepresentationCache = this.tileRepresentationCache;\n    const source = this.getLayer().getRenderSource();\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, [altZ, x, y]);\n        let loaded = false;\n        if (tileRepresentationCache.containsKey(cacheKey)) {\n          const tileRepresentation = tileRepresentationCache.get(cacheKey);\n          if (\n            tileRepresentation.ready &&\n            !lookupHasTile(tileRepresentationLookup, tileRepresentation.tile)\n          ) {\n            addTileRepresentationToLookup(\n              tileRepresentationLookup,\n              tileRepresentation,\n              altZ\n            );\n            loaded = true;\n          }\n        }\n        if (!loaded) {\n          covered = false;\n        }\n      }\n    }\n    return covered;\n  }\n\n  clearCache() {\n    const tileRepresentationCache = this.tileRepresentationCache;\n    tileRepresentationCache.forEach((tileRepresentation) =>\n      tileRepresentation.dispose()\n    );\n    tileRepresentationCache.clear();\n  }\n\n  removeHelper() {\n    if (this.helper) {\n      this.clearCache();\n    }\n\n    super.removeHelper();\n  }\n\n  /**\n   * Clean up.\n   */\n  disposeInternal() {\n    super.disposeInternal();\n    delete this.frameState;\n  }\n}\n\nexport default WebGLBaseTileLayerRenderer;\n","/**\n * @module ol/renderer/webgl/TileLayer\n */\nimport ReprojDataTile from '../../reproj/DataTile.js';\nimport ReprojTile from '../../reproj/Tile.js';\nimport TileState from '../../TileState.js';\nimport TileTexture from '../../webgl/TileTexture.js';\nimport WebGLArrayBuffer from '../../webgl/Buffer.js';\nimport WebGLBaseTileLayerRenderer, {\n  Uniforms as BaseUniforms,\n  getCacheKey,\n} from './TileLayerBase.js';\nimport {AttributeType} from '../../webgl/Helper.js';\nimport {ELEMENT_ARRAY_BUFFER, STATIC_DRAW} from '../../webgl.js';\nimport {apply as applyTransform} from '../../transform.js';\nimport {\n  boundingExtent,\n  containsCoordinate,\n  getIntersection,\n} from '../../extent.js';\nimport {fromUserExtent} from '../../proj.js';\nimport {fromTransform as mat4FromTransform} from '../../vec/mat4.js';\nimport {toSize} from '../../size.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  TEXTURE_ORIGIN_X: 'u_textureOriginX', // map x coordinate of left edge of texture\n  TEXTURE_ORIGIN_Y: 'u_textureOriginY', // map y coordinate of top edge of texture\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\").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 */\n\n/**\n * @typedef {import(\"../../layer/WebGLTile.js\").default} LayerType\n */\n/**\n * @typedef {import(\"../../webgl/TileTexture.js\").TileType} TileTextureType\n */\n/**\n * @typedef {import(\"../../webgl/TileTexture.js\").default} TileTextureRepresentation\n */\n\n/**\n * @classdesc\n * WebGL renderer for tile layers.\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   */\n  reset(options) {\n    super.reset(options);\n\n    this.vertexShader_ = options.vertexShader;\n    this.fragmentShader_ = options.fragmentShader;\n    this.paletteTextures_ = options.paletteTextures || [];\n    if (this.helper) {\n      this.program_ = this.helper.getProgram(\n        this.fragmentShader_,\n        this.vertexShader_\n      );\n    }\n  }\n\n  afterHelperCreated() {\n    this.program_ = this.helper.getProgram(\n      this.fragmentShader_,\n      this.vertexShader_\n    );\n    this.helper.flushBufferData(this.indices_);\n  }\n\n  createTileRepresentation(options) {\n    return new TileTexture(options);\n  }\n\n  beforeTilesRender(frameState, tilesWithAlpha) {\n    super.beforeTilesRender(frameState, tilesWithAlpha);\n    this.helper.useProgram(this.program_, frameState);\n  }\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.tempMat4, 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    this.helper.setUniformFloatVec4(Uniforms.RENDER_EXTENT, gutterExtent);\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    this.helper.setUniformFloatValue(\n      Uniforms.TEXTURE_ORIGIN_X,\n      tileOrigin[0] +\n        tileCenterI * tileSize[0] * tileResolution -\n        gutter * tileResolution\n    );\n    this.helper.setUniformFloatValue(\n      Uniforms.TEXTURE_ORIGIN_Y,\n      tileOrigin[1] -\n        tileCenterJ * tileSize[1] * tileResolution +\n        gutter * 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   */\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 (\n        (tile instanceof ReprojTile || tile instanceof ReprojDataTile) &&\n        tile.getState() === TileState.EMPTY\n      ) {\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   */\n  disposeInternal() {\n    const helper = this.helper;\n    if (helper) {\n      const gl = helper.getGL();\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/expr/gpu\n */\nimport PaletteTexture from '../webgl/PaletteTexture.js';\nimport {\n  BooleanType,\n  CallExpression,\n  ColorType,\n  NoneType,\n  NumberArrayType,\n  NumberType,\n  Ops,\n  StringType,\n  isType,\n  overlapsType,\n  parse,\n  typeName,\n} from './expression.js';\nimport {Uniforms} from '../renderer/webgl/TileLayer.js';\nimport {asArray} from '../color.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  // all components are premultiplied with alpha value\n  return arrayToGlsl([\n    (array[0] / 255) * alpha,\n    (array[1] / 255) * alpha,\n    (array[2] / 255) * alpha,\n    alpha,\n  ]);\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 * @property {function(import(\"../Feature.js\").FeatureLike): *} [evaluator] Function used for evaluating the value;\n */\n\n/**\n * @typedef {Object} CompilationContextVariable\n * @property {string} name Name\n * @property {number} type Resolved variable type\n * @property {function(Object): *} [evaluator] Function used for evaluating the value; argument is the style variables object\n */\n\n/**\n * @typedef {Object} CompilationContext\n * @property {boolean} [inFragmentShader] If false, means the expression output should be made for a vertex shader\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 {import(\"../style/webgl.js\").WebGLStyle} style Literal style.\n */\n\n/**\n * @return {CompilationContext} A new compilation context.\n */\nexport function newCompilationContext() {\n  return {\n    inFragmentShader: false,\n    variables: {},\n    properties: {},\n    functions: {},\n    bandCount: 0,\n    style: {},\n  };\n}\n\nconst GET_BAND_VALUE_FUNC = 'getBandValue';\n\nexport const PALETTE_TEXTURE_ARRAY = 'u_paletteTextures';\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, parsingContext, type);\n  if (isType(expression.type, NoneType)) {\n    throw new Error(`No matching type was found`);\n  }\n  if (!overlapsType(type, expression.type)) {\n    const expected = typeName(type);\n    const actual = typeName(expression.type);\n    throw new Error(\n      `Expected expression to be of type ${expected}, got ${actual}`\n    );\n  }\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    const prefix = context.inFragmentShader ? 'v_prop_' : 'a_prop_';\n    return prefix + propName;\n  },\n  [Ops.GeometryType]: (context, expression, type) => {\n    const propName = 'geometryType';\n    const computeType = (geometry) => {\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.substring(5);\n        case 'Circle':\n          return 'Polygon';\n        case 'GeometryCollection':\n          return computeType(geometry.getGeometries()[0]);\n        default:\n      }\n    };\n    const isExisting = propName in context.properties;\n    if (!isExisting) {\n      context.properties[propName] = {\n        name: propName,\n        type: StringType,\n        evaluator: (feature) => {\n          return computeType(feature.getGeometry());\n        },\n      };\n    }\n    const prefix = context.inFragmentShader ? 'v_prop_' : 'a_prop_';\n    return prefix + propName;\n  },\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    return uniformNameForVariable(varName);\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    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 `(${alpha} * vec4(${rgb.join(', ')}, 1.0))`;\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[\n        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.Concat\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  throw new Error(\n    `Unexpected expression ${expression.value} (expected type ${typeName(\n      returnType\n    )})`\n  );\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.\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} [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 *\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. Specify `'none'` to avoid hit detection on the fill.\n * @property {ColorExpression} [text-background-fill-color] The fill color.\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 {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 {import(\"../color.js\").Color|string} [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 {Array<number>} [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 {number} [icon-width] Width of the icon. If not specified, the actual image width will be used. Cannot be combined\n * with `scale`.\n * @property {number} [icon-height] Height of the icon. If not specified, the actual image height will be used. Cannot be combined\n * with `scale`.\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.\n * @property {import(\"../size.js\").Size} [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.\n * @property {\"declutter\"|\"obstacle\"|\"none\"|undefined} [icon-declutter-mode] Declutter mode\n * @property {NumberExpression} [z-index] The zIndex of the style.\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 {number} [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.\n * @property {ColorExpression} [shape-fill-color] The fill color.\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`.\n * @property {StringExpression} [shape-stroke-line-join='round'] Line join style: `bevel`, `round`, or `miter`.\n * @property {NumberArrayExpression} [shape-stroke-line-dash] Line dash pattern.\n * @property {NumberExpression} [shape-stroke-line-dash-offset=0] Line dash offset.\n * @property {NumberExpression} [shape-stroke-miter-limit=10] Miter limit.\n * @property {number} [shape-radius] Radius of a regular polygon.\n * @property {number} [shape-radius1] First radius of a star. Ignored if radius is set.\n * @property {number} [shape-radius2] Second radius of a star.\n * @property {number} [shape-angle=0] Shape's angle in radians. A value of 0 will have one of the shape's point facing up.\n * @property {NumberArrayExpression} [shape-displacement=[0,0]] Displacement of the shape\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.\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`, `shape-radius1` and `shape-radius2`.\n * @property {\"declutter\"|\"obstacle\"|\"none\"|undefined} [shape-declutter-mode] Declutter mode.\n * @property {NumberExpression} [z-index] The zIndex of the style.\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 {number} [circle-radius] Circle radius.\n * @property {ColorExpression} [circle-fill-color] The fill color.\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`.\n * @property {StringExpression} [circle-stroke-line-join='round'] Line join style: `bevel`, `round`, or `miter`.\n * @property {NumberArrayExpression} [circle-stroke-line-dash] Line dash pattern.\n * @property {NumberExpression} [circle-stroke-line-dash-offset=0] Line dash offset.\n * @property {NumberExpression} [circle-stroke-miter-limit=10] Miter limit.\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-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\n * (meaningful only when used in conjunction with a two dimensional scale).\n * @property {\"declutter\"|\"obstacle\"|\"none\"|undefined} [circle-declutter-mode] Declutter mode\n * @property {NumberExpression} [z-index] The zIndex of the style.\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 * Class for generating shaders from literal style objects\n * @module ol/webgl/ShaderBuilder\n */\nimport {LINESTRING_ANGLE_COSINE_CUTOFF} from '../render/webgl/utils.js';\nimport {colorToGlsl, numberToGlsl, stringToGlsl} from '../expr/gpu.js';\nimport {createDefaultStyle} from '../style/flat.js';\n\nexport const COMMON_HEADER = `#ifdef GL_FRAGMENT_PRECISION_HIGH\nprecision highp float;\n#else\nprecision mediump float;\n#endif\nuniform mat4 u_projectionMatrix;\nuniform mat4 u_screenToWorldMatrix;\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 vec2 u_patternOrigin;\nuniform float u_depth;\nuniform mediump int u_hitDetection;\n\nconst float PI = 3.141592653589793238;\nconst float TWO_PI = 2.0 * PI;\n\n// this used to produce an alpha-premultiplied color from a texture\nvec4 samplePremultiplied(sampler2D sampler, vec2 texCoord) {\n  vec4 color = texture2D(sampler, texCoord);\n  return vec4(color.rgb * color.a, color.a);\n}\n`;\n\nconst DEFAULT_STYLE = createDefaultStyle();\n\n/**\n * @typedef {Object} VaryingDescription\n * @property {string} name Varying name, as will be declared in the header.\n * @property {string} type Varying type, either `float`, `vec2`, `vec4`...\n * @property {string} expression Expression which will be assigned to the varying in the vertex shader, and\n * passed on to the fragment shader.\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 *   .addVarying('v_width', 'float', 'a_width')\n *   .addUniform('u_time')\n *   .setColorExpression('...')\n *   .setSymbolSizeExpression('...')\n *   .getSymbolFragmentShader();\n * ```\n */\nexport class ShaderBuilder {\n  constructor() {\n    /**\n     * Uniforms; these will be declared in the header (should include the type).\n     * @type {Array<string>}\n     * @private\n     */\n    this.uniforms_ = [];\n\n    /**\n     * Attributes; these will be declared in the header (should include the type).\n     * @type {Array<string>}\n     * @private\n     */\n    this.attributes_ = [];\n\n    /**\n     * Varyings with a name, a type and an expression.\n     * @type {Array<VaryingDescription>}\n     * @private\n     */\n    this.varyings_ = [];\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.discardExpression_ = 'false';\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     * @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     * @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\n   * @return {ShaderBuilder} the builder object\n   */\n  addUniform(name) {\n    this.uniforms_.push(name);\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   * @param {string} name Attribute name\n   * @return {ShaderBuilder} the builder object\n   */\n  addAttribute(name) {\n    this.attributes_.push(name);\n    return this;\n  }\n\n  /**\n   * Adds a varying defined in the vertex shader and accessible from the fragment shader.\n   * The type and expression of the varying have to be specified separately.\n   * @param {string} name Varying name\n   * @param {'float'|'vec2'|'vec3'|'vec4'} type Type\n   * @param {string} expression Expression used to assign a value to the varying.\n   * @return {ShaderBuilder} the builder object\n   */\n  addVarying(name, type, expression) {\n    this.varyings_.push({\n      name: name,\n      type: type,\n      expression: expression,\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.\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.discardExpression_ = expression;\n    return this;\n  }\n\n  /**\n   * @return {string} The current fragment discard expression\n   */\n  getFragmentDiscardExpression() {\n    return this.discardExpression_;\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   * @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  addVertexShaderFunction(code) {\n    if (this.vertexShaderFunctions_.includes(code)) {\n      return;\n    }\n    this.vertexShaderFunctions_.push(code);\n  }\n  addFragmentShaderFunction(code) {\n    if (this.fragmentShaderFunctions_.includes(code)) {\n      return;\n    }\n    this.fragmentShaderFunctions_.push(code);\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_\n  .map(function (uniform) {\n    return 'uniform ' + uniform + ';';\n  })\n  .join('\\n')}\nattribute vec2 a_position;\nattribute float a_index;\nattribute vec4 a_hitColor;\n${this.attributes_\n  .map(function (attribute) {\n    return 'attribute ' + attribute + ';';\n  })\n  .join('\\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${this.varyings_\n  .map(function (varying) {\n    return 'varying ' + varying.type + ' ' + varying.name + ';';\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;\n  if (a_index == 0.0) {\n    offsetPx -= halfSizePx;\n  } else if (a_index == 1.0) {\n    offsetPx += halfSizePx * vec2(1., -1.);\n  } else if (a_index == 2.0) {\n    offsetPx += halfSizePx;\n  } else {\n    offsetPx += halfSizePx * vec2(-1., 1.);\n  }\n  float angle = ${this.symbolRotationExpression_};\n  ${this.symbolRotateWithView_ ? 'angle += 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 = a_index == 0.0 || a_index == 3.0 ? texCoord.s : texCoord.p;\n  float v = a_index == 2.0 || a_index == 3.0 ? texCoord.t : texCoord.q;\n  v_texCoord = vec2(u, v);\n  v_hitColor = 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.varyings_\n  .map(function (varying) {\n    return '  ' + varying.name + ' = ' + varying.expression + ';';\n  })\n  .join('\\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_\n  .map(function (uniform) {\n    return 'uniform ' + uniform + ';';\n  })\n  .join('\\n')}\nvarying vec2 v_texCoord;\nvarying vec4 v_hitColor;\nvarying vec2 v_centerPx;\nvarying float v_angle;\nvarying vec2 v_quadSizePx;\n${this.varyings_\n  .map(function (varying) {\n    return 'varying ' + varying.type + ' ' + varying.name + ';';\n  })\n  .join('\\n')}\n${this.fragmentShaderFunctions_.join('\\n')}\n\nvoid main(void) {\n  if (${this.discardExpression_}) { 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  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_\n  .map(function (uniform) {\n    return 'uniform ' + uniform + ';';\n  })\n  .join('\\n')}\nattribute vec2 a_position;\nattribute float a_index;\nattribute vec2 a_segmentStart;\nattribute vec2 a_segmentEnd;\nattribute float a_parameters;\nattribute float a_distance;\nattribute vec2 a_joinAngles;\nattribute vec4 a_hitColor;\n${this.attributes_\n  .map(function (attribute) {\n    return 'attribute ' + attribute + ';';\n  })\n  .join('\\n')}\nvarying vec2 v_segmentStart;\nvarying vec2 v_segmentEnd;\nvarying float v_angleStart;\nvarying float v_angleEnd;\nvarying float v_width;\nvarying vec4 v_hitColor;\nvarying float v_distanceOffsetPx;\n${this.varyings_\n  .map(function (varying) {\n    return 'varying ' + varying.type + ' ' + varying.name + ';';\n  })\n  .join('\\n')}\n${this.vertexShaderFunctions_.join('\\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\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 vertexNumber = floor(abs(a_parameters) / 10000. + 0.5);\n  // we're reading the fractional part while keeping the sign (so -4.12 gives -0.12, 3.45 gives 0.45)\n  float angleTangentSum = fract(abs(a_parameters) / 10000.) * 10000. * sign(a_parameters);\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 = vertexNumber < 0.5 || (vertexNumber > 1.5 && vertexNumber < 2.5) ? 1.0 : -1.0;\n  float tangentDir = vertexNumber < 1.5 ? 1.0 : -1.0;\n  float angle = vertexNumber < 1.5 ? v_angleStart : v_angleEnd;\n  vec2 joinDirection;\n  vec2 positionPx = vertexNumber < 1.5 ? segmentStartPx : segmentEndPx;\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;\n  gl_Position = pxToScreen(positionPx);\n\n  v_segmentStart = segmentStartPx;\n  v_segmentEnd = segmentEndPx;\n  v_width = lineWidth;\n  v_hitColor = a_hitColor;\n  v_distanceOffsetPx = a_distance / u_resolution - (lineOffsetPx * angleTangentSum);\n${this.varyings_\n  .map(function (varying) {\n    return '  ' + varying.name + ' = ' + varying.expression + ';';\n  })\n  .join('\\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_\n  .map(function (uniform) {\n    return 'uniform ' + uniform + ';';\n  })\n  .join('\\n')}\nvarying vec2 v_segmentStart;\nvarying vec2 v_segmentEnd;\nvarying float v_angleStart;\nvarying float v_angleEnd;\nvarying float v_width;\nvarying vec4 v_hitColor;\nvarying float v_distanceOffsetPx;\n${this.varyings_\n  .map(function (varying) {\n    return 'varying ' + varying.type + ' ' + varying.name + ';';\n  })\n  .join('\\n')}\n${this.fragmentShaderFunctions_.join('\\n')}\n\nvec2 pxToWorld(vec2 pxPos) {\n  vec2 screenPos = 2.0 * pxPos / u_viewportSizePx - 1.0;\n  return (u_screenToWorldMatrix * vec4(screenPos, 0.0, 1.0)).xy;\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\nvoid main(void) {\n  vec2 currentPoint = gl_FragCoord.xy / u_pixelRatio;\n  #ifdef GL_FRAGMENT_PRECISION_HIGH\n  vec2 worldPos = pxToWorld(currentPoint);\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  #endif\n  if (${this.discardExpression_}) { discard; }\n\n  float segmentLength = length(v_segmentEnd - v_segmentStart);\n  vec2 segmentTangent = (v_segmentEnd - v_segmentStart) / segmentLength;\n  vec2 segmentNormal = vec2(-segmentTangent.y, segmentTangent.x);\n  vec2 startToPoint = currentPoint - v_segmentStart;\n  float currentLengthPx = max(0., min(dot(segmentTangent, startToPoint), segmentLength)) + v_distanceOffsetPx; \n  float currentRadiusPx = abs(dot(segmentNormal, startToPoint));\n  float currentRadiusRatio = dot(segmentNormal, startToPoint) * 2. / v_width;\n  vec4 color = ${this.strokeColorExpression_} * u_globalAlpha;\n  float capType = ${this.strokeCapExpression_};\n  float joinType = ${this.strokeJoinExpression_};\n  float segmentStartDistance = computeSegmentPointDistance(currentPoint, v_segmentStart, v_segmentEnd, v_width, v_angleStart, capType, joinType);\n  float segmentEndDistance = computeSegmentPointDistance(currentPoint, v_segmentEnd, v_segmentStart, v_width, v_angleEnd, capType, joinType);\n  float distance = max(\n    segmentDistanceField(currentPoint, v_segmentStart, v_segmentEnd, v_width),\n    max(segmentStartDistance, segmentEndDistance)\n  );\n  distance = max(distance, ${this.strokeDistanceFieldExpression_});\n  gl_FragColor = color * smoothstep(0., -1., distance);\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_\n  .map(function (uniform) {\n    return 'uniform ' + uniform + ';';\n  })\n  .join('\\n')}\nattribute vec2 a_position;\nattribute vec4 a_hitColor;\n${this.attributes_\n  .map(function (attribute) {\n    return 'attribute ' + attribute + ';';\n  })\n  .join('\\n')}\nvarying vec4 v_hitColor;\n${this.varyings_\n  .map(function (varying) {\n    return 'varying ' + varying.type + ' ' + varying.name + ';';\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 = a_hitColor;\n${this.varyings_\n  .map(function (varying) {\n    return '  ' + varying.name + ' = ' + varying.expression + ';';\n  })\n  .join('\\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_\n  .map(function (uniform) {\n    return 'uniform ' + uniform + ';';\n  })\n  .join('\\n')}\nvarying vec4 v_hitColor;\n${this.varyings_\n  .map(function (varying) {\n    return 'varying ' + varying.type + ' ' + varying.name + ';';\n  })\n  .join('\\n')}\n${this.fragmentShaderFunctions_.join('\\n')}\nvec2 pxToWorld(vec2 pxPos) {\n  vec2 screenPos = 2.0 * pxPos / u_viewportSizePx - 1.0;\n  return (u_screenToWorldMatrix * 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\nvoid main(void) {\n  vec2 pxPos = gl_FragCoord.xy / u_pixelRatio;\n  vec2 pxOrigin = worldToPx(u_patternOrigin);\n  #ifdef GL_FRAGMENT_PRECISION_HIGH\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  #endif\n  if (${this.discardExpression_}) { discard; }\n  gl_FragColor = ${this.fillColorExpression_} * u_globalAlpha;\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 RenderFeature from '../../render/Feature.js';\nimport {getUid} from '../../util.js';\nimport {inflateEnds} from '../../geom/flat/orient.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    this.globalCounter_ = 0;\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 returned 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 entry = this.pointBatch.entries[getUid(feature)];\n    if (!entry) {\n      return;\n    }\n    this.pointBatch.geometriesCount -= entry.flatCoordss.length;\n    delete this.pointBatch.entries[getUid(feature)];\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 entry = this.lineStringBatch.entries[getUid(feature)];\n    if (!entry) {\n      return;\n    }\n    this.lineStringBatch.verticesCount -= entry.verticesCount;\n    this.lineStringBatch.geometriesCount -= entry.flatCoordss.length;\n    delete this.lineStringBatch.entries[getUid(feature)];\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 entry = this.polygonBatch.entries[getUid(feature)];\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[getUid(feature)];\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        this.addCoordinates_(\n          type,\n          lineGeom.getFlatCoordinates(),\n          null,\n          feature,\n          getUid(feature),\n          lineGeom.getStride()\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   * @private\n   */\n  addCoordinates_(type, flatCoords, ends, feature, featureUid, stride) {\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          );\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          );\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          );\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            );\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          );\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          getFlatCoordinatesXY(flatCoords, stride)\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  returnRef_(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   */\n  changeFeature(feature) {\n    this.removeFeature(feature);\n    const geometry = feature.getGeometry();\n    if (!geometry) {\n      return;\n    }\n    this.addGeometry_(geometry, feature);\n  }\n\n  /**\n   * @param {Feature|RenderFeature} feature Feature\n   */\n  removeFeature(feature) {\n    let entry;\n    entry = this.clearFeatureEntryInPointBatch_(feature) || entry;\n    entry = this.clearFeatureEntryInPolygonBatch_(feature) || entry;\n    entry = this.clearFeatureEntryInLineStringBatch_(feature) || entry;\n    if (entry) {\n      this.returnRef_(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\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\nexport default MixedGeometryBatch;\n","/**\n * @module ol/webgl/TileGeometry\n */\n\nimport BaseTileRepresentation from './BaseTileRepresentation.js';\nimport MixedGeometryBatch from '../render/webgl/MixedGeometryBatch.js';\nimport WebGLArrayBuffer from './Buffer.js';\nimport {ARRAY_BUFFER, STATIC_DRAW} from '../webgl.js';\nimport {\n  create as createTransform,\n  translate as translateTransform,\n} from '../transform.js';\n\n/**\n * @typedef {import(\"../VectorRenderTile\").default} TileType\n */\n\n/**\n * @extends {BaseTileRepresentation<TileType>}\n */\nclass TileGeometry extends BaseTileRepresentation {\n  /**\n   * @param {import(\"./BaseTileRepresentation.js\").TileRepresentationOptions<TileType>} options The tile texture options.\n   * @param {Array<import(\"../render/webgl/VectorStyleRenderer.js\").default>} styleRenderers Array of vector style renderers\n   */\n  constructor(options, styleRenderers) {\n    super(options);\n\n    /**\n     * @private\n     */\n    this.batch_ = new MixedGeometryBatch();\n\n    /**\n     * @private\n     */\n    this.styleRenderers_ = styleRenderers;\n\n    /**\n     * @type {Array<import(\"../render/webgl/VectorStyleRenderer.js\").WebGLBuffers>}\n     */\n    this.buffers = [];\n\n    /**\n     * Each geometry tile also has a mask which consisted of a quad (two triangles); this mask is intended to\n     * be rendered to an offscreen buffer, and be used to correctly mask tiles according to their zoom level\n     * during rendering\n     */\n    this.maskVertices = new WebGLArrayBuffer(ARRAY_BUFFER, STATIC_DRAW);\n\n    this.setTile(options.tile);\n  }\n\n  /**\n   * @private\n   */\n  generateMaskBuffer_() {\n    const extent = this.tile.getSourceTiles()[0].extent;\n    this.maskVertices.fromArray([\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    this.helper_.flushBufferData(this.maskVertices);\n  }\n\n  uploadTile() {\n    this.generateMaskBuffer_();\n\n    this.batch_.clear();\n    const sourceTiles = this.tile.getSourceTiles();\n    const features = sourceTiles.reduce(\n      (accumulator, sourceTile) => accumulator.concat(sourceTile.getFeatures()),\n      []\n    );\n    this.batch_.addFeatures(features);\n\n    const tileOriginX = sourceTiles[0].extent[0];\n    const tileOriginY = sourceTiles[0].extent[1];\n    const transform = translateTransform(\n      createTransform(),\n      -tileOriginX,\n      -tileOriginY\n    );\n\n    const generatePromises = this.styleRenderers_.map((renderer, i) =>\n      renderer.generateBuffers(this.batch_, transform).then((buffers) => {\n        this.buffers[i] = buffers;\n      })\n    );\n    Promise.all(generatePromises).then(() => {\n      this.setReady();\n    });\n  }\n}\n\nexport default TileGeometry;\n","/**\n * Utilities for parsing literal style objects\n * @module ol/webgl/styleparser\n */\nimport {\n  BooleanType,\n  ColorType,\n  NumberArrayType,\n  NumberType,\n  StringType,\n  newParsingContext,\n} from '../expr/expression.js';\nimport {ShaderBuilder} from './ShaderBuilder.js';\nimport {\n  arrayToGlsl,\n  buildExpression,\n  getStringNumberEquivalent,\n  stringToGlsl,\n  uniformNameForVariable,\n} from '../expr/gpu.js';\nimport {asArray} from '../color.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 * @return {string} GLSL-compatible output\n */\nexport function expressionToGlsl(compilationContext, value, expectedType) {\n  const parsingContext = newParsingContext();\n  parsingContext.style = compilationContext.style;\n  return buildExpression(\n    value,\n    expectedType,\n    parsingContext,\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\nconst UNPACK_COLOR_FN = `vec4 unpackColor(vec2 packedColor) {\n  return fract(packedColor[1] / 256.0) * vec4(\n    fract(floor(packedColor[0] / 256.0) / 256.0),\n    fract(packedColor[0] / 256.0),\n    fract(floor(packedColor[1] / 256.0) / 256.0),\n    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 */\nfunction getGlslSizeFromType(type) {\n  if (type === ColorType) {\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 */\nfunction 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 * 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/webgl.js\").WebGLStyle} 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  let radius;\n  if (`${prefix}radius` in style && prefix !== 'icon-') {\n    radius = expressionToGlsl(\n      vertContext,\n      style[`${prefix}radius`],\n      NumberType\n    );\n  } else if (`${prefix}radius1` in style && prefix === 'shape-') {\n    radius = expressionToGlsl(\n      vertContext,\n      style[`${prefix}radius1`],\n      NumberType\n    );\n  }\n  if (radius !== undefined) {\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      NumberType | NumberArrayType\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} * ${shapeOpacity}`;\n  if (opacity !== null) {\n    result = `${result} * ${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/webgl.js\").WebGLStyle} style Style\n * @param {ShaderBuilder} builder Shader builder\n * @param {Object<string,import(\"../webgl/Helper\").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  let size;\n  image.crossOrigin =\n    style[`${prefix}cross-origin`] === undefined\n      ? 'anonymous'\n      : style[`${prefix}cross-origin`];\n  image.src = style[`${prefix}src`];\n\n  if (image.complete && image.width && image.height) {\n    size = arrayToGlsl([image.width, image.height]);\n  } else {\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(`vec2 u_texture${textureId}_size`);\n    size = `u_texture${textureId}_size`;\n  }\n  uniforms[`u_texture${textureId}`] = image;\n  builder.addUniform(`sampler2D u_texture${textureId}`);\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/webgl.js\").WebGLStyle} 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    NumberArrayType\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/webgl.js\").WebGLStyle} style Style\n * @param {ShaderBuilder} builder Shader builder\n * @param {Object<string,import(\"../webgl/Helper\").UniformValue>} uniforms Uniforms\n * @param {import(\"../expr/gpu.js\").CompilationContext} vertContext Vertex shader compilation context\n * @param {import(\"../expr/gpu.js\").CompilationContext} fragContext Fragment shader compilation context\n */\nfunction parseCircleProperties(\n  style,\n  builder,\n  uniforms,\n  vertContext,\n  fragContext\n) {\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  fragContext.functions[\n    'circleDistanceField'\n  ] = `float circleDistanceField(vec2 point, float radius) {\n  return length(point) - radius;\n}`;\n\n  parseCommonSymbolProperties(style, builder, vertContext, 'circle-');\n\n  // OPACITY\n  let opacity = null;\n  if ('circle-opacity' in style) {\n    opacity = expressionToGlsl(\n      fragContext,\n      style['circle-opacity'],\n      NumberType\n    );\n  }\n\n  // SCALE\n  let currentPoint = 'coordsPx';\n  if ('circle-scale' in style) {\n    const scale = expressionToGlsl(\n      fragContext,\n      style['circle-scale'],\n      NumberType | NumberArrayType\n    );\n    currentPoint = `coordsPx / ${scale}`;\n  }\n\n  // FILL COLOR\n  let fillColor = null;\n  if ('circle-fill-color' in style) {\n    fillColor = expressionToGlsl(\n      fragContext,\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      fragContext,\n      style['circle-stroke-color'],\n      ColorType\n    );\n  }\n\n  // RADIUS\n  let radius = expressionToGlsl(\n    fragContext,\n    style['circle-radius'],\n    NumberType\n  );\n\n  // STROKE WIDTH\n  let strokeWidth = null;\n  if ('circle-stroke-width' in style) {\n    strokeWidth = expressionToGlsl(\n      fragContext,\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/webgl.js\").WebGLStyle} style Style\n * @param {ShaderBuilder} builder Shader builder\n * @param {Object<string,import(\"../webgl/Helper\").UniformValue>} uniforms Uniforms\n * @param {import(\"../expr/gpu.js\").CompilationContext} vertContext Vertex shader compilation context\n * @param {import(\"../expr/gpu.js\").CompilationContext} fragContext Fragment shader compilation context\n */\nfunction parseShapeProperties(\n  style,\n  builder,\n  uniforms,\n  vertContext,\n  fragContext\n) {\n  fragContext.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 circle, positive outside, values in pixels)\n  // inspired by https://github.com/zranger1/PixelblazePatterns/blob/master/Toolkit/sdf2d.md#n-sided-regular-polygon\n  fragContext.functions[\n    'starDistanceField'\n  ] = `float starDistanceField(vec2 point, float numPoints, float radiusIn, float radiusOut, 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(-radiusOut, 0.);\n  vec2 edgeNormal = vec2(radiusIn * sin(alpha * 0.5), -radiusIn * cos(alpha * 0.5) + radiusOut);\n  return dot(normalize(edgeNormal), tipToPoint);\n}`;\n  fragContext.functions[\n    '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, vertContext, 'shape-');\n\n  // OPACITY\n  let opacity = null;\n  if ('shape-opacity' in style) {\n    opacity = expressionToGlsl(fragContext, style['shape-opacity'], NumberType);\n  }\n\n  // SCALE\n  let currentPoint = 'coordsPx';\n  if ('shape-scale' in style) {\n    const scale = expressionToGlsl(\n      fragContext,\n      style['shape-scale'],\n      NumberType | NumberArrayType\n    );\n    currentPoint = `coordsPx / ${scale}`;\n  }\n\n  // FILL COLOR\n  let fillColor = null;\n  if ('shape-fill-color' in style) {\n    fillColor = expressionToGlsl(\n      fragContext,\n      style['shape-fill-color'],\n      ColorType\n    );\n  }\n\n  // STROKE COLOR\n  let strokeColor = null;\n  if ('shape-stroke-color' in style) {\n    strokeColor = expressionToGlsl(\n      fragContext,\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      fragContext,\n      style['shape-stroke-width'],\n      NumberType\n    );\n  }\n\n  // SHAPE TYPE\n  const numPoints = expressionToGlsl(\n    fragContext,\n    style['shape-points'],\n    NumberType\n  );\n  let angle = '0.';\n  if ('shape-angle' in style) {\n    angle = expressionToGlsl(fragContext, style['shape-angle'], NumberType);\n  }\n  let shapeField;\n  if ('shape-radius' in style) {\n    let radius = expressionToGlsl(\n      fragContext,\n      style['shape-radius'],\n      NumberType\n    );\n    if (strokeWidth !== null) {\n      radius = `${radius} + ${strokeWidth} * 0.5`;\n    }\n    shapeField = `regularDistanceField(${currentPoint}, ${numPoints}, ${radius}, ${angle})`;\n  } else {\n    let radiusOuter = expressionToGlsl(\n      fragContext,\n      style['shape-radius1'],\n      NumberType\n    );\n    let radiusInner = expressionToGlsl(\n      fragContext,\n      style['shape-radius2'],\n      NumberType\n    );\n    if (strokeWidth !== null) {\n      radiusOuter = `${radiusOuter} + ${strokeWidth} * 0.5`;\n      radiusInner = `${radiusInner} + ${strokeWidth} * 0.5`;\n    }\n    shapeField = `starDistanceField(${currentPoint}, ${numPoints}, ${radiusInner}, ${radiusOuter}, ${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/webgl.js\").WebGLStyle} style Style\n * @param {ShaderBuilder} builder Shader builder\n * @param {Object<string,import(\"../webgl/Helper\").UniformValue>} uniforms Uniforms\n * @param {import(\"../expr/gpu.js\").CompilationContext} vertContext Vertex shader compilation context\n * @param {import(\"../expr/gpu.js\").CompilationContext} fragContext Fragment shader compilation context\n */\nfunction parseIconProperties(\n  style,\n  builder,\n  uniforms,\n  vertContext,\n  fragContext\n) {\n  // COLOR\n  let color = 'vec4(1.0)';\n  if ('icon-color' in style) {\n    color = expressionToGlsl(fragContext, style['icon-color'], ColorType);\n  }\n\n  // OPACITY\n  if ('icon-opacity' in style) {\n    color = `${color} * ${expressionToGlsl(\n      fragContext,\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} * samplePremultiplied(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        vertContext,\n        style['icon-width'],\n        NumberType\n      )}, ${expressionToGlsl(vertContext, 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      vertContext,\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      vertContext,\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, vertContext, 'icon-');\n\n  if ('icon-anchor' in style) {\n    const anchor = expressionToGlsl(\n      vertContext,\n      style['icon-anchor'],\n      NumberArrayType\n    );\n    let scale = `1.0`;\n    if (`icon-scale` in style) {\n      scale = expressionToGlsl(\n        vertContext,\n        style[`icon-scale`],\n        NumberType | NumberArrayType\n      );\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/webgl.js\").WebGLStyle} style Style\n * @param {ShaderBuilder} builder Shader Builder\n * @param {Object<string,import(\"../webgl/Helper\").UniformValue>} uniforms Uniforms\n * @param {import(\"../expr/gpu.js\").CompilationContext} vertContext Vertex shader compilation context\n * @param {import(\"../expr/gpu.js\").CompilationContext} fragContext Fragment shader compilation context\n */\nfunction parseStrokeProperties(\n  style,\n  builder,\n  uniforms,\n  vertContext,\n  fragContext\n) {\n  if ('stroke-color' in style) {\n    builder.setStrokeColorExpression(\n      expressionToGlsl(fragContext, 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        fragContext,\n        style[`stroke-pattern-size`],\n        NumberArrayType\n      );\n      offsetExpression = parseImageOffsetProperties(\n        style,\n        'stroke-pattern-',\n        fragContext,\n        sizeExpression,\n        sampleSizeExpression\n      );\n    }\n    let spacingExpression = '0.';\n    if ('stroke-pattern-spacing' in style) {\n      spacingExpression = expressionToGlsl(\n        fragContext,\n        style['stroke-pattern-spacing'],\n        NumberType\n      );\n    }\n    fragContext.functions[\n      'sampleStrokePattern'\n    ] = `vec4 sampleStrokePattern(sampler2D texture, vec2 textureSize, vec2 textureOffset, vec2 sampleSize, float spacingPx, float currentLengthPx, float currentRadiusRatio) {\n      float currentLengthScaled = currentLengthPx * sampleSize.y / v_width;\n      float spacingScaled = spacingPx * sampleSize.y / v_width;\n      float uCoordPx = mod(currentLengthScaled, (sampleSize.x + spacingScaled));\n      float vCoordPx = (currentRadiusRatio * 0.5 + 0.5) * sampleSize.y;\n      vec2 texCoord = (vec2(uCoordPx, vCoordPx) + textureOffset) / textureSize;\n      return uCoordPx > sampleSize.x ? vec4(0.) : samplePremultiplied(texture, texCoord);\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}, currentLengthPx, currentRadiusRatio)`\n    );\n  }\n\n  if ('stroke-width' in style) {\n    builder.setStrokeWidthExpression(\n      expressionToGlsl(vertContext, style['stroke-width'], NumberType)\n    );\n  }\n\n  if ('stroke-offset' in style) {\n    builder.setStrokeOffsetExpression(\n      expressionToGlsl(vertContext, style['stroke-offset'], NumberType)\n    );\n  }\n\n  if ('stroke-line-cap' in style) {\n    builder.setStrokeCapExpression(\n      expressionToGlsl(vertContext, style['stroke-line-cap'], StringType)\n    );\n  }\n\n  if ('stroke-line-join' in style) {\n    builder.setStrokeJoinExpression(\n      expressionToGlsl(vertContext, style['stroke-line-join'], StringType)\n    );\n  }\n\n  if ('stroke-miter-limit' in style) {\n    builder.setStrokeMiterLimitExpression(\n      expressionToGlsl(vertContext, style['stroke-miter-limit'], NumberType)\n    );\n  }\n\n  if ('stroke-line-dash' in style) {\n    fragContext.functions[\n      'getSingleDashDistance'\n    ] = `float getSingleDashDistance(float distance, float radius, float dashOffset, float dashLength, float dashLengthTotal, float capType) {\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 -= v_width * 0.5;\n  } else if (capType == ${stringToGlsl('round')}) {\n    distanceSegment = min(distanceSegment, sqrt(distanceSegment * distanceSegment + radius * radius) - v_width * 0.5);\n  }\n  return distanceSegment;\n}`;\n\n    let dashPattern = style['stroke-line-dash'].map((v) =>\n      expressionToGlsl(fragContext, 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        vertContext,\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 dashLengthsDef = dashPattern.map(\n      (v, i) => `float dashLength${i} = ${v};`\n    );\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)`;\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))`;\n    }\n\n    fragContext.functions[\n      dashFunctionName\n    ] = `float ${dashFunctionName}(float distance, float radius, float capType) {\n  ${dashLengthsDef.join('\\n  ')}\n  float totalDashLength = ${totalLengthDef};\n  return ${distanceExpression};\n}`;\n    builder.setStrokeDistanceFieldExpression(\n      `${dashFunctionName}(currentLengthPx + ${offsetExpression}, currentRadiusPx, capType)`\n    );\n  }\n}\n\n/**\n * @param {import(\"../style/webgl.js\").WebGLStyle} style Style\n * @param {ShaderBuilder} builder Shader Builder\n * @param {Object<string,import(\"../webgl/Helper\").UniformValue>} uniforms Uniforms\n * @param {import(\"../expr/gpu.js\").CompilationContext} vertContext Vertex shader compilation context\n * @param {import(\"../expr/gpu.js\").CompilationContext} fragContext Fragment shader compilation context\n */\nfunction parseFillProperties(\n  style,\n  builder,\n  uniforms,\n  vertContext,\n  fragContext\n) {\n  if ('fill-color' in style) {\n    builder.setFillColorExpression(\n      expressionToGlsl(fragContext, 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    let sampleSizeExpression = sizeExpression;\n    let offsetExpression = 'vec2(0.)';\n    if ('fill-pattern-offset' in style && 'fill-pattern-size' in style) {\n      sampleSizeExpression = expressionToGlsl(\n        fragContext,\n        style[`fill-pattern-size`],\n        NumberArrayType\n      );\n      offsetExpression = parseImageOffsetProperties(\n        style,\n        'fill-pattern-',\n        fragContext,\n        sizeExpression,\n        sampleSizeExpression\n      );\n    }\n    fragContext.functions[\n      'sampleFillPattern'\n    ] = `vec4 sampleFillPattern(sampler2D texture, vec2 textureSize, vec2 textureOffset, vec2 sampleSize, vec2 pxOrigin, vec2 pxPosition) {\n  float scaleRatio = pow(2., mod(u_zoom + 0.5, 1.) - 0.5);\n  vec2 samplePos = mod((pxPosition - pxOrigin) / scaleRatio, sampleSize);\n  samplePos.y = sampleSize.y - samplePos.y; // invert y axis so that images appear upright\n  return samplePremultiplied(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    builder.setFillColorExpression(\n      `${tintExpression} * sampleFillPattern(${textureName}, ${sizeExpression}, ${offsetExpression}, ${sampleSizeExpression}, pxOrigin, pxPos)`\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(\"../render/webgl/VectorStyleRenderer.js\").UniformDefinitions} uniforms Uniform definitions\n * @property {import(\"../render/webgl/VectorStyleRenderer.js\").AttributeDefinitions} attributes Attribute definitions\n */\n\n/**\n * Parses a {@link import(\"../style/webgl.js\").WebGLStyle} 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/webgl.js\").WebGLStyle} style Literal style.\n * @return {StyleParseResult} Result containing shader params, attributes and uniforms.\n */\nexport function parseLiteralStyle(style) {\n  /**\n   * @type {import(\"../expr/gpu.js\").CompilationContext}\n   */\n  const vertContext = {\n    inFragmentShader: false,\n    properties: {},\n    variables: {},\n    functions: {},\n    style,\n  };\n\n  /**\n   * @type {import(\"../expr/gpu.js\").CompilationContext}\n   */\n  const fragContext = {\n    inFragmentShader: true,\n    variables: vertContext.variables,\n    properties: {},\n    functions: {},\n    style,\n  };\n\n  const builder = new ShaderBuilder();\n\n  /** @type {Object<string,import(\"../webgl/Helper\").UniformValue>} */\n  const uniforms = {};\n\n  if ('icon-src' in style) {\n    parseIconProperties(style, builder, uniforms, vertContext, fragContext);\n  } else if ('shape-points' in style) {\n    parseShapeProperties(style, builder, uniforms, vertContext, fragContext);\n  } else if ('circle-radius' in style) {\n    parseCircleProperties(style, builder, uniforms, vertContext, fragContext);\n  }\n  parseStrokeProperties(style, builder, uniforms, vertContext, fragContext);\n  parseFillProperties(style, builder, uniforms, vertContext, fragContext);\n\n  if (style.filter) {\n    const parsedFilter = expressionToGlsl(\n      fragContext,\n      style.filter,\n      BooleanType\n    );\n    builder.setFragmentDiscardExpression(`!${parsedFilter}`);\n  }\n\n  // define one uniform per variable\n  Object.keys(fragContext.variables).forEach(function (varName) {\n    const variable = fragContext.variables[varName];\n    const uniformName = uniformNameForVariable(variable.name);\n    builder.addUniform(`${getGlslTypeFromType(variable.type)} ${uniformName}`);\n\n    let callback;\n    if (variable.type === StringType) {\n      callback = () =>\n        getStringNumberEquivalent(\n          /** @type {string} */ (style.variables[variable.name])\n        );\n    } else if (variable.type === ColorType) {\n      callback = () =>\n        packColor([\n          ...asArray(\n            /** @type {string|Array<number>} */ (\n              style.variables[variable.name]\n            ) || '#eee'\n          ),\n        ]);\n    } else if (variable.type === BooleanType) {\n      callback = () =>\n        /** @type {boolean} */ (style.variables[variable.name]) ? 1.0 : 0.0;\n    } else {\n      callback = () => /** @type {number} */ (style.variables[variable.name]);\n    }\n    uniforms[uniformName] = callback;\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  Object.keys(fragContext.properties).forEach(function (propName) {\n    const property = fragContext.properties[propName];\n    if (!vertContext.properties[propName]) {\n      vertContext.properties[propName] = property;\n    }\n    let type = getGlslTypeFromType(property.type);\n    let expression = `a_prop_${property.name}`;\n    if (property.type === ColorType) {\n      type = 'vec4';\n      expression = `unpackColor(${expression})`;\n      builder.addVertexShaderFunction(UNPACK_COLOR_FN);\n    }\n    builder.addVarying(`v_prop_${property.name}`, type, expression);\n  });\n\n  // for each feature attribute used in the vertex shader, define an attribute in the vertex shader.\n  Object.keys(vertContext.properties).forEach(function (propName) {\n    const property = vertContext.properties[propName];\n    builder.addAttribute(\n      `${getGlslTypeFromType(property.type)} a_prop_${property.name}`\n    );\n  });\n\n  const attributes = Object.keys(vertContext.properties).map(function (\n    propName\n  ) {\n    const property = vertContext.properties[propName];\n    let callback;\n    if (property.evaluator) {\n      callback = property.evaluator;\n    } else if (property.type === StringType) {\n      callback = (feature) =>\n        getStringNumberEquivalent(feature.get(property.name));\n    } else if (property.type === ColorType) {\n      callback = (feature) =>\n        packColor([...asArray(feature.get(property.name) || '#eee')]);\n    } else if (property.type === BooleanType) {\n      callback = (feature) => (feature.get(property.name) ? 1.0 : 0.0);\n    } else {\n      callback = (feature) => feature.get(property.name);\n    }\n\n    return {\n      name: property.name,\n      size: getGlslSizeFromType(property.type),\n      callback,\n    };\n  });\n\n  // add functions that were collected in the compilation contexts\n  for (const functionName in vertContext.functions) {\n    builder.addVertexShaderFunction(vertContext.functions[functionName]);\n  }\n  for (const functionName in fragContext.functions) {\n    builder.addFragmentShaderFunction(fragContext.functions[functionName]);\n  }\n\n  return {\n    builder: builder,\n    attributes: attributes.reduce(\n      (prev, curr) => ({\n        ...prev,\n        [curr.name]: {callback: curr.callback, size: curr.size},\n      }),\n      {}\n    ),\n    uniforms: uniforms,\n  };\n}\n","/**\n * @module ol/style/Image\n */\nimport {abstract} from '../util.js';\nimport {toSize} from '../size.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 {\"declutter\"|\"obstacle\"|\"none\"|undefined} declutterMode Declutter mode: `declutter`, `obstacle`, 'none */\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 {\"declutter\"|\"obstacle\"|\"none\"|undefined}\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 {\"declutter\"|\"obstacle\"|\"none\"|undefined} 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\nexport default ImageStyle;\n","/**\n * @module ol/style/RegularShape\n */\n\nimport ImageState from '../ImageState.js';\nimport ImageStyle from './Image.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';\n\n/**\n * Specify radius for regular polygons, or radius1 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} [radius1] First radius of a star. Ignored if radius is set.\n * @property {number} [radius2] Second radius of a star.\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`, `radius1` and `radius2`.\n * @property {\"declutter\"|\"obstacle\"|\"none\"|undefined} [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 `radius1` and\n * `radius2` are provided.\n * @api\n */\nclass RegularShape extends ImageStyle {\n  /**\n   * @param {Options} options Options.\n   */\n  constructor(options) {\n    /**\n     * @type {boolean}\n     */\n    const rotateWithView =\n      options.rotateWithView !== undefined ? options.rotateWithView : false;\n\n    super({\n      opacity: 1,\n      rotateWithView: rotateWithView,\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 {Object<number, HTMLCanvasElement>}\n     */\n    this.canvases_;\n\n    /**\n     * @private\n     * @type {HTMLCanvasElement|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_ =\n      options.radius !== undefined ? options.radius : options.radius1;\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    this.render();\n  }\n\n  /**\n   * Clones the style.\n   * @return {RegularShape} The cloned style.\n   * @api\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   */\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} Image element.\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} Image or Canvas element.\n   * @api\n   */\n  getImage(pixelRatio) {\n    let image = this.canvases_[pixelRatio];\n    if (!image) {\n      const renderOptions = this.renderOptions_;\n      const context = createCanvasContext2D(\n        renderOptions.size * pixelRatio,\n        renderOptions.size * pixelRatio\n      );\n      this.draw_(renderOptions, context, pixelRatio);\n\n      image = context.canvas;\n      this.canvases_[pixelRatio] = image;\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   */\n  getPixelRatio(pixelRatio) {\n    return pixelRatio;\n  }\n\n  /**\n   * @return {import(\"../size.js\").Size} Image size.\n   */\n  getImageSize() {\n    return this.size_;\n  }\n\n  /**\n   * @return {import(\"../ImageState.js\").default} Image state.\n   */\n  getImageState() {\n    return ImageState.LOADED;\n  }\n\n  /**\n   * Get the origin of the symbolizer.\n   * @return {Array<number>} Origin.\n   * @api\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   * 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   * Get the size of the symbolizer (in pixels).\n   * @return {import(\"../size.js\").Size} Size.\n   * @api\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   */\n  listenImageChange(listener) {}\n\n  /**\n   * Load not yet loaded URI.\n   */\n  load() {}\n\n  /**\n   * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\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.canvases_ = {};\n    this.hitDetectionCanvas_ = null;\n    this.size_ = [size, size];\n  }\n\n  /**\n   * @private\n   * @param {RenderOptions} renderOptions Render options.\n   * @param {CanvasRenderingContext2D} 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} 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} 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} 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\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 {\"declutter\"|\"obstacle\"|\"none\"|undefined} [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   */\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  /**\n   * Set the circle radius.\n   *\n   * @param {number} radius Circle radius.\n   * @api\n   */\n  setRadius(radius) {\n    this.radius_ = radius;\n    this.render();\n  }\n}\n\nexport default CircleStyle;\n","/**\n * @module ol/style/Fill\n */\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike|null} [color=null] 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 */\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(\"../color.js\").Color|import(\"../colorlike.js\").ColorLike|null}\n     */\n    this.color_ = options.color !== undefined ? options.color : null;\n  }\n\n  /**\n   * Clones the style. The color is not cloned if it is an {@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|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|null} color Color.\n   * @api\n   */\n  setColor(color) {\n    this.color_ = color;\n  }\n}\n\nexport default Fill;\n","/**\n * @module ol/style/IconImage\n */\n\nimport EventTarget from '../events/Target.js';\nimport EventType from '../events/EventType.js';\nimport ImageState from '../ImageState.js';\nimport {asString} from '../color.js';\nimport {createCanvasContext2D} from '../dom.js';\nimport {decodeFallback} from '../Image.js';\nimport {shared as iconImageCache} from './IconImageCache.js';\n\n/**\n * @type {CanvasRenderingContext2D}\n */\nlet taintedTestContext = null;\n\nclass IconImage extends EventTarget {\n  /**\n   * @param {HTMLImageElement|HTMLCanvasElement|ImageBitmap} image Image.\n   * @param {string|undefined} src Src.\n   * @param {?string} crossOrigin Cross origin.\n   * @param {import(\"../ImageState.js\").default} imageState Image state.\n   * @param {import(\"../color.js\").Color} color Color.\n   */\n  constructor(image, src, crossOrigin, imageState, color) {\n    super();\n\n    /**\n     * @private\n     * @type {HTMLImageElement|HTMLCanvasElement|ImageBitmap}\n     */\n    this.hitDetectionImage_ = null;\n\n    /**\n     * @private\n     * @type {HTMLImageElement|HTMLCanvasElement|ImageBitmap}\n     */\n    this.image_ = image;\n\n    /**\n     * @private\n     * @type {string|null}\n     */\n    this.crossOrigin_ = crossOrigin;\n\n    /**\n     * @private\n     * @type {Object<number, HTMLCanvasElement>}\n     */\n    this.canvas_ = {};\n\n    /**\n     * @private\n     * @type {import(\"../color.js\").Color}\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  /**\n   * @private\n   */\n  initializeImage_() {\n    this.image_ = new Image();\n    if (this.crossOrigin_ !== null) {\n      this.image_.crossOrigin = this.crossOrigin_;\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 (e) {\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|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 {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|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 (e) {\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 canvas = document.createElement('canvas');\n    canvas.width = Math.ceil(image.width * pixelRatio);\n    canvas.height = Math.ceil(image.height * pixelRatio);\n\n    const ctx = canvas.getContext('2d');\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/**\n * @param {HTMLImageElement|HTMLCanvasElement|ImageBitmap} image Image.\n * @param {string} cacheKey Src.\n * @param {?string} crossOrigin Cross origin.\n * @param {import(\"../ImageState.js\").default} imageState Image state.\n * @param {import(\"../color.js\").Color} color Color.\n * @return {IconImage} Icon image.\n */\nexport function get(image, cacheKey, crossOrigin, imageState, color) {\n  let iconImage =\n    cacheKey === undefined\n      ? undefined\n      : iconImageCache.get(cacheKey, crossOrigin, color);\n  if (!iconImage) {\n    iconImage = new IconImage(\n      image,\n      image instanceof HTMLImageElement ? image.src || undefined : cacheKey,\n      crossOrigin,\n      imageState,\n      color\n    );\n    iconImageCache.set(cacheKey, crossOrigin, color, iconImage);\n  }\n  return iconImage;\n}\n\nexport default IconImage;\n","/**\n * @module ol/style/Icon\n */\nimport EventType from '../events/EventType.js';\nimport ImageState from '../ImageState.js';\nimport ImageStyle from './Image.js';\nimport {asArray} from '../color.js';\nimport {assert} from '../asserts.js';\nimport {get as getIconImage} from './IconImage.js';\nimport {getUid} from '../util.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 {HTMLImageElement|HTMLCanvasElement|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 {\"declutter\"|\"obstacle\"|\"none\"|undefined} [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    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 (image instanceof HTMLImageElement) {\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      this.crossOrigin_,\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     * 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   */\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      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   */\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   * Get the image icon.\n   * @param {number} pixelRatio Pixel ratio.\n   * @return {HTMLImageElement|HTMLCanvasElement|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   */\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   */\n  getPixelRatio(pixelRatio) {\n    return this.iconImage_.getPixelRatio(pixelRatio);\n  }\n\n  /**\n   * @return {import(\"../size.js\").Size} Image size.\n   */\n  getImageSize() {\n    return this.iconImage_.getSize();\n  }\n\n  /**\n   * @return {import(\"../ImageState.js\").default} Image state.\n   */\n  getImageState() {\n    return this.iconImage_.getImageState();\n  }\n\n  /**\n   * @return {HTMLImageElement|HTMLCanvasElement|ImageBitmap} Image element.\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   */\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   * Get the size of the icon (in pixels).\n   * @return {import(\"../size.js\").Size} Image size.\n   * @api\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   */\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   */\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   */\n  load() {\n    this.iconImage_.load();\n  }\n\n  /**\n   * @param {function(import(\"../events/Event.js\").default): void} listener Listener function.\n   */\n  unlistenImageChange(listener) {\n    this.iconImage_.removeEventListener(EventType.CHANGE, listener);\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} [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.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      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 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 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 CircleStyle from './Circle.js';\nimport Fill from './Fill.js';\nimport Stroke from './Stroke.js';\nimport {assert} from '../asserts.js';\n\n/**\n * A function that takes an {@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 an {@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} 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 Fill from './Fill.js';\nimport {toSize} from '../size.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 {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 */\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 {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  /**\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      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: this.getFill() ? this.getFill().clone() : undefined,\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    });\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   * 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   * 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 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/structs/LinkedList\n */\n\n/**\n * @typedef {Object} Item\n * @property {Item} [prev] Previous.\n * @property {Item} [next] Next.\n * @property {?} data Data.\n */\n\n/**\n * @classdesc\n * Creates an empty linked list structure.\n */\nclass LinkedList {\n  /**\n   * @param {boolean} [circular] The last item is connected to the first one,\n   * and the first item to the last one. Default is true.\n   */\n  constructor(circular) {\n    /**\n     * @private\n     * @type {Item|undefined}\n     */\n    this.first_;\n\n    /**\n     * @private\n     * @type {Item|undefined}\n     */\n    this.last_;\n\n    /**\n     * @private\n     * @type {Item|undefined}\n     */\n    this.head_;\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.circular_ = circular === undefined ? true : circular;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.length_ = 0;\n  }\n\n  /**\n   * Inserts an item into the linked list right after the current one.\n   *\n   * @param {?} data Item data.\n   */\n  insertItem(data) {\n    /** @type {Item} */\n    const item = {\n      prev: undefined,\n      next: undefined,\n      data: data,\n    };\n\n    const head = this.head_;\n\n    //Initialize the list.\n    if (!head) {\n      this.first_ = item;\n      this.last_ = item;\n      if (this.circular_) {\n        item.next = item;\n        item.prev = item;\n      }\n    } else {\n      //Link the new item to the adjacent ones.\n      const next = head.next;\n      item.prev = head;\n      item.next = next;\n      head.next = item;\n      if (next) {\n        next.prev = item;\n      }\n\n      if (head === this.last_) {\n        this.last_ = item;\n      }\n    }\n    this.head_ = item;\n    this.length_++;\n  }\n\n  /**\n   * Removes the current item from the list. Sets the cursor to the next item,\n   * if possible.\n   */\n  removeItem() {\n    const head = this.head_;\n    if (head) {\n      const next = head.next;\n      const prev = head.prev;\n      if (next) {\n        next.prev = prev;\n      }\n      if (prev) {\n        prev.next = next;\n      }\n      this.head_ = next || prev;\n\n      if (this.first_ === this.last_) {\n        this.head_ = undefined;\n        this.first_ = undefined;\n        this.last_ = undefined;\n      } else if (this.first_ === head) {\n        this.first_ = this.head_;\n      } else if (this.last_ === head) {\n        this.last_ = prev ? this.head_.prev : this.head_;\n      }\n      this.length_--;\n    }\n  }\n\n  /**\n   * Sets the cursor to the first item, and returns the associated data.\n   *\n   * @return {?} Item data.\n   */\n  firstItem() {\n    this.head_ = this.first_;\n    if (this.head_) {\n      return this.head_.data;\n    }\n    return undefined;\n  }\n\n  /**\n   * Sets the cursor to the last item, and returns the associated data.\n   *\n   * @return {?} Item data.\n   */\n  lastItem() {\n    this.head_ = this.last_;\n    if (this.head_) {\n      return this.head_.data;\n    }\n    return undefined;\n  }\n\n  /**\n   * Sets the cursor to the next item, and returns the associated data.\n   *\n   * @return {?} Item data.\n   */\n  nextItem() {\n    if (this.head_ && this.head_.next) {\n      this.head_ = this.head_.next;\n      return this.head_.data;\n    }\n    return undefined;\n  }\n\n  /**\n   * Returns the next item's data without moving the cursor.\n   *\n   * @return {?} Item data.\n   */\n  getNextItem() {\n    if (this.head_ && this.head_.next) {\n      return this.head_.next.data;\n    }\n    return undefined;\n  }\n\n  /**\n   * Sets the cursor to the previous item, and returns the associated data.\n   *\n   * @return {?} Item data.\n   */\n  prevItem() {\n    if (this.head_ && this.head_.prev) {\n      this.head_ = this.head_.prev;\n      return this.head_.data;\n    }\n    return undefined;\n  }\n\n  /**\n   * Returns the previous item's data without moving the cursor.\n   *\n   * @return {?} Item data.\n   */\n  getPrevItem() {\n    if (this.head_ && this.head_.prev) {\n      return this.head_.prev.data;\n    }\n    return undefined;\n  }\n\n  /**\n   * Returns the current item's data.\n   *\n   * @return {?} Item data.\n   */\n  getCurrItem() {\n    if (this.head_) {\n      return this.head_.data;\n    }\n    return undefined;\n  }\n\n  /**\n   * Sets the first item of the list. This only works for circular lists, and sets\n   * the last item accordingly.\n   */\n  setFirstItem() {\n    if (this.circular_ && this.head_) {\n      this.first_ = this.head_;\n      this.last_ = this.head_.prev;\n    }\n  }\n\n  /**\n   * Concatenates two lists.\n   * @param {LinkedList} list List to merge into the current list.\n   */\n  concat(list) {\n    if (list.head_) {\n      if (this.head_) {\n        const end = this.head_.next;\n        this.head_.next = list.first_;\n        list.first_.prev = this.head_;\n        end.prev = list.last_;\n        list.last_.next = end;\n        this.length_ += list.length_;\n      } else {\n        this.head_ = list.head_;\n        this.first_ = list.first_;\n        this.last_ = list.last_;\n        this.length_ = list.length_;\n      }\n      list.head_ = undefined;\n      list.first_ = undefined;\n      list.last_ = undefined;\n      list.length_ = 0;\n    }\n  }\n\n  /**\n   * Returns the current length of the list.\n   *\n   * @return {number} Length.\n   */\n  getLength() {\n    return this.length_;\n  }\n}\n\nexport default LinkedList;\n","/**\n * @module ol/expr/cpu\n */\n\nimport {\n  ColorType,\n  LiteralExpression,\n  Ops,\n  overlapsType,\n  parse,\n  typeName,\n} from './expression.js';\nimport {\n  fromString,\n  lchaToRgba,\n  normalize,\n  rgbaToLcha,\n  withAlpha,\n} from '../color.js';\n\n/**\n * @fileoverview This module includes functions to build expressions for evaluation on the CPU.\n * Building is composed of two steps: parsing and compiling.  The parsing step takes an encoded\n * expression and returns an instance of one of the expression classes.  The compiling step takes\n * the expression instance and returns a function that can be evaluated in to return a literal\n * value.  The evaluator function should do as little allocation and work as possible.\n */\n\n/**\n * @typedef {Object} EvaluationContext\n * @property {Object} properties The values for properties used in 'get' expressions.\n * @property {Object} variables The values for variables used in 'var' expressions.\n * @property {number} resolution The map resolution.\n * @property {string|number|null} featureId The feature id.\n */\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  };\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>|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, context);\n  if (!overlapsType(type, expression.type)) {\n    const expected = typeName(type);\n    const actual = typeName(expression.type);\n    throw new Error(\n      `Expected expression to be of type ${expected}, got ${actual}`\n    );\n  }\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      return compileAssertionExpression(expression, context);\n    }\n    case Ops.Get:\n    case Ops.Var: {\n      return compileAccessorExpression(expression, context);\n    }\n    case Ops.Id: {\n      return (expression) => expression.featureId;\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.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.Match: {\n      return compileMatchExpression(expression, context);\n    }\n    case Ops.Interpolate: {\n      return compileInterpolateExpression(expression, context);\n    }\n    default: {\n      throw new Error(`Unsupported operator ${operator}`);\n    }\n    // TODO: unimplemented\n    // Ops.GeometryType\n    // Ops.Zoom\n    // Ops.Time\n    // Ops.Between\n    // Ops.Case\n    // Ops.In\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.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) => context.properties[name];\n    }\n    case Ops.Var: {\n      return (context) => context.variables[name];\n    }\n    default: {\n      throw new Error(`Unsupported accessor operator ${expression.operator}`);\n    }\n  }\n}\n\n/**\n * @param {import('./expression.js').CallExpression} expression The call expression.\n * @param {import('./expression.js').ParsingContext} context The parsing context.\n * @return {BooleanEvaluator} The evaluator function.\n */\nfunction compileComparisonExpression(expression, context) {\n  const op = expression.operator;\n  const left = compileExpression(expression.args[0], context);\n  const right = compileExpression(expression.args[1], context);\n  switch (op) {\n    case Ops.Equal: {\n      return (context) => left(context) === right(context);\n    }\n    case Ops.NotEqual: {\n      return (context) => left(context) !== right(context);\n    }\n    case Ops.LessThan: {\n      return (context) => left(context) < right(context);\n    }\n    case Ops.LessThanOrEqualTo: {\n      return (context) => left(context) <= right(context);\n    }\n    case Ops.GreaterThan: {\n      return (context) => left(context) > right(context);\n    }\n    case Ops.GreaterThanOrEqualTo: {\n      return (context) => left(context) >= right(context);\n    }\n    default: {\n      throw new Error(`Unsupported comparison operator ${op}`);\n    }\n  }\n}\n\n/**\n * @param {import('./expression.js').CallExpression} expression The call expression.\n * @param {import('./expression.js').ParsingContext} context The parsing context.\n * @return {BooleanEvaluator} The evaluator function.\n */\nfunction compileLogicalExpression(expression, context) {\n  const op = expression.operator;\n  const length = expression.args.length;\n\n  const args = new Array(length);\n  for (let i = 0; i < length; ++i) {\n    args[i] = compileExpression(expression.args[i], context);\n  }\n  switch (op) {\n    case Ops.Any: {\n      return (context) => {\n        for (let i = 0; i < length; ++i) {\n          if (args[i](context)) {\n            return true;\n          }\n        }\n        return false;\n      };\n    }\n    case Ops.All: {\n      return (context) => {\n        for (let i = 0; i < length; ++i) {\n          if (!args[i](context)) {\n            return false;\n          }\n        }\n        return true;\n      };\n    }\n    case Ops.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 compileMatchExpression(expression, context) {\n  const length = expression.args.length;\n  const args = new Array(length);\n  for (let i = 0; i < length; ++i) {\n    args[i] = compileExpression(expression.args[i], context);\n  }\n  return (context) => {\n    const value = args[0](context);\n    for (let i = 1; i < length; i += 2) {\n      if (value === args[i](context)) {\n        return args[i + 1](context);\n      }\n    }\n    return args[length - 1](context);\n  };\n}\n\n/**\n * @param {import('./expression.js').CallExpression} expression The call expression.\n * @param {import('./expression.js').ParsingContext} context The parsing context.\n * @return {ExpressionEvaluator} The evaluator function.\n */\nfunction compileInterpolateExpression(expression, context) {\n  const length = expression.args.length;\n  const args = new Array(length);\n  for (let i = 0; i < length; ++i) {\n    args[i] = compileExpression(expression.args[i], context);\n  }\n  return (context) => {\n    const base = args[0](context);\n    const value = args[1](context);\n\n    let previousInput;\n    let previousOutput;\n    for (let i = 2; i < length; i += 2) {\n      const input = args[i](context);\n      let output = args[i + 1](context);\n      const isColor = Array.isArray(output);\n      if (isColor) {\n        output = withAlpha(output);\n      }\n      if (input >= value) {\n        if (i === 2) {\n          return output;\n        }\n        if (isColor) {\n          return interpolateColor(\n            base,\n            value,\n            previousInput,\n            previousOutput,\n            input,\n            output\n          );\n        }\n        return interpolateNumber(\n          base,\n          value,\n          previousInput,\n          previousOutput,\n          input,\n          output\n        );\n      }\n      previousInput = input;\n      previousOutput = output;\n    }\n    return previousOutput;\n  };\n}\n\n/**\n * @param {number} base The base.\n * @param {number} value The value.\n * @param {number} input1 The first input value.\n * @param {number} output1 The first output value.\n * @param {number} input2 The second input value.\n * @param {number} output2 The second output value.\n * @return {number} The interpolated value.\n */\nfunction interpolateNumber(base, value, input1, output1, input2, output2) {\n  const delta = input2 - input1;\n  if (delta === 0) {\n    return output1;\n  }\n  const along = value - input1;\n  const factor =\n    base === 1\n      ? along / delta\n      : (Math.pow(base, along) - 1) / (Math.pow(base, delta) - 1);\n  return output1 + factor * (output2 - output1);\n}\n\n/**\n * @param {number} base The base.\n * @param {number} value The value.\n * @param {number} input1 The first input value.\n * @param {import('../color.js').Color} rgba1 The first output value.\n * @param {number} input2 The second input value.\n * @param {import('../color.js').Color} rgba2 The second output value.\n * @return {import('../color.js').Color} The interpolated color.\n */\nfunction interpolateColor(base, value, input1, rgba1, input2, rgba2) {\n  const delta = input2 - input1;\n  if (delta === 0) {\n    return rgba1;\n  }\n  const lcha1 = rgbaToLcha(rgba1);\n  const lcha2 = rgbaToLcha(rgba2);\n  let deltaHue = lcha2[2] - lcha1[2];\n  if (deltaHue > 180) {\n    deltaHue -= 360;\n  } else if (deltaHue < -180) {\n    deltaHue += 360;\n  }\n\n  const lcha = [\n    interpolateNumber(base, value, input1, lcha1[0], input2, lcha2[0]),\n    interpolateNumber(base, value, input1, lcha1[1], input2, lcha2[1]),\n    lcha1[2] + interpolateNumber(base, value, input1, 0, input2, deltaHue),\n    interpolateNumber(base, value, input1, rgba1[3], input2, rgba2[3]),\n  ];\n  return normalize(lchaToRgba(lcha));\n}\n","/**\n * @module ol/render/canvas/style\n */\n\nimport Circle from '../../style/Circle.js';\nimport Fill from '../../style/Fill.js';\nimport Icon from '../../style/Icon.js';\nimport RegularShape from '../../style/RegularShape.js';\nimport Stroke from '../../style/Stroke.js';\nimport Style from '../../style/Style.js';\nimport Text from '../../style/Text.js';\nimport {\n  BooleanType,\n  ColorType,\n  NumberArrayType,\n  NumberType,\n  StringType,\n  newParsingContext,\n} from '../../expr/expression.js';\nimport {buildExpression, newEvaluationContext} from '../../expr/cpu.js';\nimport {isEmpty} from '../../obj.js';\nimport {toSize} from '../../size.js';\n\n/**\n * @fileoverview This module includes functions to build styles for the canvas renderer.  Building\n * is composed of two steps: parsing and compiling.  The parsing step takes an encoded expression\n * and returns an instance of one of the expression classes.  The compiling step takes the\n * expression instance and returns a function that can be evaluated to return a literal value.  The\n * evaluator function should do as little allocation and work as possible.\n */\n\n/**\n * @typedef {import(\"../../style/flat.js\").FlatStyle} FlatStyle\n */\n\n/**\n * @typedef {import(\"../../expr/expression.js\").EncodedExpression} EncodedExpression\n */\n\n/**\n * @typedef {import(\"../../expr/expression.js\").ParsingContext} ParsingContext\n */\n\n/**\n * @typedef {import(\"../../expr/expression.js\").CallExpression} CallExpression\n */\n\n/**\n * @typedef {import(\"../../expr/cpu.js\").EvaluationContext} EvaluationContext\n */\n\n/**\n * @typedef {import(\"../../expr/cpu.js\").ExpressionEvaluator} ExpressionEvaluator\n */\n\n/**\n * @param {EvaluationContext} context The evaluation context.\n * @return {boolean} Always true.\n */\nfunction always(context) {\n  return true;\n}\n\n/**\n * This function adapts a rule evaluator to the existing style function interface.\n * After we have deprecated the style function, we can use the compiled rules directly\n * and pass a more complete evaluation context (variables, zoom, time, etc.).\n *\n * @param {Array<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    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  const evaluateColor = colorLikeEvaluator(\n    flatStyle,\n    prefix + 'fill-color',\n    context\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 === 'none') {\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 stroke = new Stroke();\n  return function (context) {\n    if (evaluateColor) {\n      const color = evaluateColor(context);\n      if (color === 'none') {\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    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 evaluatePadding = numberArrayEvaluator(\n    flatStyle,\n    prefix + 'padding',\n    context\n  );\n\n  const text = new Text({});\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    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 color = optionalColorLike(flatStyle, prefix + 'color');\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(flatStyle, prefix + 'declutter');\n\n  const icon = new Icon({\n    src,\n    anchorOrigin,\n    anchorXUnits,\n    anchorYUnits,\n    color,\n    crossOrigin,\n    offset,\n    offsetOrigin,\n    height,\n    width,\n    size,\n    declutterMode,\n  });\n\n  return function (context) {\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 points = requireNumber(flatStyle[pointsName], pointsName);\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 radius = optionalNumber(flatStyle, prefix + 'radius');\n  const radius1 = optionalNumber(flatStyle, prefix + 'radius1');\n  const radius2 = optionalNumber(flatStyle, prefix + 'radius2');\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,\n    radius1,\n    radius2,\n    angle,\n    declutterMode,\n  });\n\n  return function (context) {\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 * @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  if (!(name in flatStyle)) {\n    return undefined;\n  }\n  const evaluator = buildExpression(flatStyle[name], 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  if (!(name in flatStyle)) {\n    return null;\n  }\n  const evaluator = buildExpression(flatStyle[name], StringType, context);\n  return function (context) {\n    return requireString(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').BooleanEvaluator?} The expression evaluator.\n */\nfunction booleanEvaluator(flatStyle, name, context) {\n  if (!(name in flatStyle)) {\n    return null;\n  }\n  const evaluator = buildExpression(flatStyle[name], 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  if (!(name in flatStyle)) {\n    return null;\n  }\n  const evaluator = buildExpression(\n    flatStyle[name],\n    ColorType | StringType,\n    context\n  );\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  if (!(name in flatStyle)) {\n    return null;\n  }\n  const evaluator = buildExpression(flatStyle[name], 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  if (!(name in flatStyle)) {\n    return null;\n  }\n  const evaluator = buildExpression(flatStyle[name], 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').SizeLikeEvaluator?} The expression evaluator.\n */\nfunction sizeLikeEvaluator(flatStyle, name, context) {\n  if (!(name in flatStyle)) {\n    return null;\n  }\n  const evaluator = buildExpression(\n    flatStyle[name],\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 {\"declutter\"|\"obstacle\"|\"none\"|undefined} 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 {FlatStyle} flatStyle The flat style.\n * @param {string} property The symbolizer property.\n * @return {string|Array<number>|undefined} A string or an array of color values or undefined.\n */\nfunction optionalColorLike(flatStyle, property) {\n  const encoded = flatStyle[property];\n  if (encoded === undefined) {\n    return undefined;\n  }\n  return requireColorLike(encoded, property);\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 {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  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 * @module ol/layer/BaseVector\n */\nimport Layer from './Layer.js';\nimport RBush from 'rbush';\nimport Style, {\n  createDefaultStyle,\n  toFunction as toStyleFunction,\n} from '../style/Style.js';\nimport {\n  flatStylesToStyleFunction,\n  rulesToStyleFunction,\n} from '../render/canvas/style.js';\n\n/**\n * @template {import(\"../source/Vector.js\").default|import(\"../source/VectorTile.js\").default} 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} [declutter=false] Declutter images and text. Decluttering is applied to all\n * image and text styles of all Vector and VectorTile layers that have set this to `true`. The priority\n * is defined by the z-index of the layer, the `zIndex` of the style and the render order of features.\n * Higher z-index means higher priority. Within the same z-index, a feature rendered before another has\n * higher priority.\n *\n * As an optimization decluttered features from layers with the same `className` are rendered above\n * the fill and stroke styles of all of those layers regardless of z-index.  To opt out of this\n * behavior and place declutterd features with their own layer configure the layer with a `className`\n * other than `ol-layer`.\n * @property {import(\"../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(\"../source/Vector.js\").default|import(\"../source/VectorTile.js\").default} VectorSourceType\n * @template {import(\"../renderer/canvas/VectorLayer.js\").default|import(\"../renderer/canvas/VectorTileLayer.js\").default|import(\"../renderer/canvas/VectorImageLayer.js\").default|import(\"../renderer/webgl/PointsLayer.js\").default} RendererType\n * @extends {Layer<VectorSourceType, RendererType>}\n * @api\n */\nclass BaseVectorLayer extends Layer {\n  /**\n   * @param {Options<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 {boolean}\n     */\n    this.declutter_ =\n      options.declutter !== undefined ? options.declutter : false;\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}\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 {boolean} Declutter.\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\").FeatureLike>>} Promise that resolves with an array of features.\n   * @api\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 {function(import(\"../Feature.js\").default, import(\"../Feature.js\").default): number|null|undefined} Render\n   *     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|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   */\n  renderDeclutter(frameState) {\n    if (!frameState.declutterTree) {\n      frameState.declutterTree = new RBush(9);\n    }\n    /** @type {*} */ (this.getRenderer()).renderDeclutter(frameState);\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_ = toStyleLike(style);\n    this.styleFunction_ =\n      style === null ? undefined : toStyleFunction(this.style_);\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/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 {ArrayBuffer} renderInstructions render instructions raw binary buffer.\n * @property {number} [customAttributesSize] Amount of hit detection + custom attributes count in the render instructions.\n * @property {ArrayBuffer} [vertexBuffer] Vertices array raw binary buffer (sent by the worker).\n * @property {ArrayBuffer} [indexBuffer] Indices array raw binary buffer (sent by the worker).\n * @property {import(\"../../transform\").Transform} [renderInstructionsTransform] Transformation matrix used to project the instructions coordinates\n */\n","\n        export function create() {\n          const source = \"const e=\\\"GENERATE_POLYGON_BUFFERS\\\",t=\\\"GENERATE_POINT_BUFFERS\\\",n=\\\"GENERATE_LINE_STRING_BUFFERS\\\";function r(e,t){const n=t[0],r=t[1];return t[0]=e[0]*n+e[2]*r+e[4],t[1]=e[1]*n+e[3]*r+e[5],t}function x(e,t){const n=(r=t)[0]*r[3]-r[1]*r[2];var r;!function(e,t){if(!e)throw new Error(t)}(0!==n,\\\"Transformation matrix cannot be inverted\\\");const x=t[0],i=t[1],u=t[2],o=t[3],f=t[4],s=t[5];return e[0]=o/n,e[1]=-i/n,e[2]=-u/n,e[3]=x/n,e[4]=(u*s-o*f)/n,e[5]=-(x*s-i*f)/n,e}function i(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,\\\"default\\\")?e.default:e}new Array(6);var u={exports:{}};function o(e,t,n){n=n||2;var r,x,i,u,o,s,l,v=t&&t.length,h=v?t[0]*n:e.length,c=f(e,0,h,n,!0),g=[];if(!c||c.next===c.prev)return g;if(v&&(c=function(e,t,n,r){var x,i,u,o=[];for(x=0,i=t.length;x<i;x++)(u=f(e,t[x]*r,x<i-1?t[x+1]*r:e.length,r,!1))===u.next&&(u.steiner=!0),o.push(d(u));for(o.sort(p),x=0;x<o.length;x++)n=y(o[x],n);return n}(e,t,c,n)),e.length>80*n){r=i=e[0],x=u=e[1];for(var b=n;b<h;b+=n)(o=e[b])<r&&(r=o),(s=e[b+1])<x&&(x=s),o>i&&(i=o),s>u&&(u=s);l=0!==(l=Math.max(i-r,u-x))?32767/l:0}return a(c,g,n,r,x,l,0),g}function f(e,t,n,r,x){var i,u;if(x===O(e,t,n,r)>0)for(i=t;i<n;i+=r)u=P(i,e[i],e[i+1],u);else for(i=n-r;i>=t;i-=r)u=P(i,e[i],e[i+1],u);return u&&m(u,u.next)&&(B(u),u=u.next),u}function s(e,t){if(!e)return e;t||(t=e);var n,r=e;do{if(n=!1,r.steiner||!m(r,r.next)&&0!==w(r.prev,r,r.next))r=r.next;else{if(B(r),(r=t=r.prev)===r.next)break;n=!0}}while(n||r!==t);return t}function a(e,t,n,r,x,i,u){if(e){!u&&i&&function(e,t,n,r){var x=e;do{0===x.z&&(x.z=b(x.x,x.y,t,n,r)),x.prevZ=x.prev,x.nextZ=x.next,x=x.next}while(x!==e);x.prevZ.nextZ=null,x.prevZ=null,function(e){var t,n,r,x,i,u,o,f,s=1;do{for(n=e,e=null,i=null,u=0;n;){for(u++,r=n,o=0,t=0;t<s&&(o++,r=r.nextZ);t++);for(f=s;o>0||f>0&&r;)0!==o&&(0===f||!r||n.z<=r.z)?(x=n,n=n.nextZ,o--):(x=r,r=r.nextZ,f--),i?i.nextZ=x:e=x,x.prevZ=i,i=x;n=r}i.nextZ=null,s*=2}while(u>1)}(x)}(e,r,x,i);for(var o,f,p=e;e.prev!==e.next;)if(o=e.prev,f=e.next,i?v(e,r,x,i):l(e))t.push(o.i/n|0),t.push(e.i/n|0),t.push(f.i/n|0),B(e),e=f.next,p=f.next;else if((e=f)===p){u?1===u?a(e=h(s(e),t,n),t,n,r,x,i,2):2===u&&c(e,t,n,r,x,i):a(s(e),t,n,r,x,i,1);break}}}function l(e){var t=e.prev,n=e,r=e.next;if(w(t,n,r)>=0)return!1;for(var x=t.x,i=n.x,u=r.x,o=t.y,f=n.y,s=r.y,a=x<i?x<u?x:u:i<u?i:u,l=o<f?o<s?o:s:f<s?f:s,v=x>i?x>u?x:u:i>u?i:u,h=o>f?o>s?o:s:f>s?f:s,c=r.next;c!==t;){if(c.x>=a&&c.x<=v&&c.y>=l&&c.y<=h&&M(x,o,i,f,u,s,c.x,c.y)&&w(c.prev,c,c.next)>=0)return!1;c=c.next}return!0}function v(e,t,n,r){var x=e.prev,i=e,u=e.next;if(w(x,i,u)>=0)return!1;for(var o=x.x,f=i.x,s=u.x,a=x.y,l=i.y,v=u.y,h=o<f?o<s?o:s:f<s?f:s,c=a<l?a<v?a:v:l<v?l:v,p=o>f?o>s?o:s:f>s?f:s,y=a>l?a>v?a:v:l>v?l:v,g=b(h,c,t,n,r),d=b(p,y,t,n,r),Z=e.prevZ,m=e.nextZ;Z&&Z.z>=g&&m&&m.z<=d;){if(Z.x>=h&&Z.x<=p&&Z.y>=c&&Z.y<=y&&Z!==x&&Z!==u&&M(o,a,f,l,s,v,Z.x,Z.y)&&w(Z.prev,Z,Z.next)>=0)return!1;if(Z=Z.prevZ,m.x>=h&&m.x<=p&&m.y>=c&&m.y<=y&&m!==x&&m!==u&&M(o,a,f,l,s,v,m.x,m.y)&&w(m.prev,m,m.next)>=0)return!1;m=m.nextZ}for(;Z&&Z.z>=g;){if(Z.x>=h&&Z.x<=p&&Z.y>=c&&Z.y<=y&&Z!==x&&Z!==u&&M(o,a,f,l,s,v,Z.x,Z.y)&&w(Z.prev,Z,Z.next)>=0)return!1;Z=Z.prevZ}for(;m&&m.z<=d;){if(m.x>=h&&m.x<=p&&m.y>=c&&m.y<=y&&m!==x&&m!==u&&M(o,a,f,l,s,v,m.x,m.y)&&w(m.prev,m,m.next)>=0)return!1;m=m.nextZ}return!0}function h(e,t,n){var r=e;do{var x=r.prev,i=r.next.next;!m(x,i)&&A(x,r,r.next,i)&&z(x,i)&&z(i,x)&&(t.push(x.i/n|0),t.push(r.i/n|0),t.push(i.i/n|0),B(r),B(r.next),r=e=i),r=r.next}while(r!==e);return s(r)}function c(e,t,n,r,x,i){var u=e;do{for(var o=u.next.next;o!==u.prev;){if(u.i!==o.i&&Z(u,o)){var f=F(u,o);return u=s(u,u.next),f=s(f,f.next),a(u,t,n,r,x,i,0),void a(f,t,n,r,x,i,0)}o=o.next}u=u.next}while(u!==e)}function p(e,t){return e.x-t.x}function y(e,t){var n=function(e,t){var n,r=t,x=e.x,i=e.y,u=-1/0;do{if(i<=r.y&&i>=r.next.y&&r.next.y!==r.y){var o=r.x+(i-r.y)*(r.next.x-r.x)/(r.next.y-r.y);if(o<=x&&o>u&&(u=o,n=r.x<r.next.x?r:r.next,o===x))return n}r=r.next}while(r!==t);if(!n)return null;var f,s=n,a=n.x,l=n.y,v=1/0;r=n;do{x>=r.x&&r.x>=a&&x!==r.x&&M(i<l?x:u,i,a,l,i<l?u:x,i,r.x,r.y)&&(f=Math.abs(i-r.y)/(x-r.x),z(r,e)&&(f<v||f===v&&(r.x>n.x||r.x===n.x&&g(n,r)))&&(n=r,v=f)),r=r.next}while(r!==s);return n}(e,t);if(!n)return t;var r=F(n,e);return s(r,r.next),s(n,n.next)}function g(e,t){return w(e.prev,e,t.prev)<0&&w(t.next,e,e.next)<0}function b(e,t,n,r,x){return(e=1431655765&((e=858993459&((e=252645135&((e=16711935&((e=(e-n)*x|0)|e<<8))|e<<4))|e<<2))|e<<1))|(t=1431655765&((t=858993459&((t=252645135&((t=16711935&((t=(t-r)*x|0)|t<<8))|t<<4))|t<<2))|t<<1))<<1}function d(e){var t=e,n=e;do{(t.x<n.x||t.x===n.x&&t.y<n.y)&&(n=t),t=t.next}while(t!==e);return n}function M(e,t,n,r,x,i,u,o){return(x-u)*(t-o)>=(e-u)*(i-o)&&(e-u)*(r-o)>=(n-u)*(t-o)&&(n-u)*(i-o)>=(x-u)*(r-o)}function Z(e,t){return e.next.i!==t.i&&e.prev.i!==t.i&&!function(e,t){var n=e;do{if(n.i!==e.i&&n.next.i!==e.i&&n.i!==t.i&&n.next.i!==t.i&&A(n,n.next,e,t))return!0;n=n.next}while(n!==e);return!1}(e,t)&&(z(e,t)&&z(t,e)&&function(e,t){var n=e,r=!1,x=(e.x+t.x)/2,i=(e.y+t.y)/2;do{n.y>i!=n.next.y>i&&n.next.y!==n.y&&x<(n.next.x-n.x)*(i-n.y)/(n.next.y-n.y)+n.x&&(r=!r),n=n.next}while(n!==e);return r}(e,t)&&(w(e.prev,e,t.prev)||w(e,t.prev,t))||m(e,t)&&w(e.prev,e,e.next)>0&&w(t.prev,t,t.next)>0)}function w(e,t,n){return(t.y-e.y)*(n.x-t.x)-(t.x-e.x)*(n.y-t.y)}function m(e,t){return e.x===t.x&&e.y===t.y}function A(e,t,n,r){var x=I(w(e,t,n)),i=I(w(e,t,r)),u=I(w(n,r,e)),o=I(w(n,r,t));return x!==i&&u!==o||(!(0!==x||!E(e,n,t))||(!(0!==i||!E(e,r,t))||(!(0!==u||!E(n,e,r))||!(0!==o||!E(n,t,r)))))}function E(e,t,n){return t.x<=Math.max(e.x,n.x)&&t.x>=Math.min(e.x,n.x)&&t.y<=Math.max(e.y,n.y)&&t.y>=Math.min(e.y,n.y)}function I(e){return e>0?1:e<0?-1:0}function z(e,t){return w(e.prev,e,e.next)<0?w(e,t,e.next)>=0&&w(e,e.prev,t)>=0:w(e,t,e.prev)<0||w(e,e.next,t)<0}function F(e,t){var n=new _(e.i,e.x,e.y),r=new _(t.i,t.x,t.y),x=e.next,i=t.prev;return e.next=t,t.prev=e,n.next=x,x.prev=n,r.next=n,n.prev=r,i.next=r,r.prev=i,r}function P(e,t,n,r){var x=new _(e,t,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 B(e){e.next.prev=e.prev,e.prev.next=e.next,e.prevZ&&(e.prevZ.nextZ=e.nextZ),e.nextZ&&(e.nextZ.prevZ=e.prevZ)}function _(e,t,n){this.i=e,this.x=t,this.y=n,this.prev=null,this.next=null,this.z=0,this.prevZ=null,this.nextZ=null,this.steiner=!1}function O(e,t,n,r){for(var x=0,i=t,u=n-r;i<n;i+=r)x+=(e[u]-e[i])*(e[i+1]+e[u+1]),u=i;return x}u.exports=o,u.exports.default=o,o.deviation=function(e,t,n,r){var x=t&&t.length,i=x?t[0]*n:e.length,u=Math.abs(O(e,0,i,n));if(x)for(var o=0,f=t.length;o<f;o++){var s=t[o]*n,a=o<f-1?t[o+1]*n:e.length;u-=Math.abs(O(e,s,a,n))}var l=0;for(o=0;o<r.length;o+=3){var v=r[o]*n,h=r[o+1]*n,c=r[o+2]*n;l+=Math.abs((e[v]-e[c])*(e[h+1]-e[v+1])-(e[v]-e[h])*(e[c+1]-e[v+1]))}return 0===u&&0===l?0:Math.abs((l-u)/u)},o.flatten=function(e){for(var t=e[0][0].length,n={vertices:[],holes:[],dimensions:t},r=0,x=0;x<e.length;x++){for(var i=0;i<e[x].length;i++)for(var u=0;u<t;u++)n.vertices.push(e[x][i][u]);x>0&&(r+=e[x-1].length,n.holes.push(r))}return n};var N=i(u.exports);const R=[],S={vertexPosition:0,indexPosition:0};function T(e,t,n,r,x){e[t+0]=n,e[t+1]=r,e[t+2]=x}function U(e,t,n,r,x,i){const u=3+x,o=e[t+0],f=e[t+1],s=R;s.length=x;for(let n=0;n<s.length;n++)s[n]=e[t+2+n];let a=i?i.vertexPosition:0,l=i?i.indexPosition:0;const v=a/u;return T(n,a,o,f,0),s.length&&n.set(s,a+3),a+=u,T(n,a,o,f,1),s.length&&n.set(s,a+3),a+=u,T(n,a,o,f,2),s.length&&n.set(s,a+3),a+=u,T(n,a,o,f,3),s.length&&n.set(s,a+3),a+=u,r[l++]=v,r[l++]=v+1,r[l++]=v+3,r[l++]=v+1,r[l++]=v+2,r[l++]=v+3,S.vertexPosition=a,S.indexPosition=l,S}function k(e,t,n,x,i,u,o,f,s,a,l){const v=8+f.length,h=u.length/v,c=[e[t+0],e[t+1]],p=[e[n],e[n+1]],y=r(s,[...c]),g=r(s,[...p]);function b(e,t,n){const r=Math.sqrt((t[0]-e[0])*(t[0]-e[0])+(t[1]-e[1])*(t[1]-e[1])),x=[(t[0]-e[0])/r,(t[1]-e[1])/r],i=[-x[1],x[0]],u=Math.sqrt((n[0]-e[0])*(n[0]-e[0])+(n[1]-e[1])*(n[1]-e[1])),o=[(n[0]-e[0])/u,(n[1]-e[1])/u],f=0===r||0===u?0:Math.acos((s=o[0]*x[0]+o[1]*x[1],a=-1,l=1,Math.min(Math.max(s,a),l)));var s,a,l;return o[0]*i[0]+o[1]*i[1]>0?f:2*Math.PI-f}let d=-1,M=-1,Z=l;const w=null!==i;if(null!==x){d=b(y,g,r(s,[...[e[x],e[x+1]]])),Math.cos(d)<=.985&&(Z+=Math.tan((d-Math.PI)/2))}if(w){M=b(g,y,r(s,[...[e[i],e[i+1]]])),Math.cos(M)<=.985&&(Z+=Math.tan((Math.PI-M)/2))}function m(e,t){return 0===t?1e4*e:Math.sign(t)*(1e4*e+Math.abs(t))}return u.push(c[0],c[1],p[0],p[1],d,M,a,m(0,l)),u.push(...f),u.push(c[0],c[1],p[0],p[1],d,M,a,m(1,l)),u.push(...f),u.push(c[0],c[1],p[0],p[1],d,M,a,m(2,l)),u.push(...f),u.push(c[0],c[1],p[0],p[1],d,M,a,m(3,l)),u.push(...f),o.push(h,h+1,h+2,h+1,h+3,h+2),{length:a+Math.sqrt((g[0]-y[0])*(g[0]-y[0])+(g[1]-y[1])*(g[1]-y[1])),angle:Z}}function G(e,t,n,r,x){const i=2+x;let u=t;const o=e.slice(u,u+x);u+=x;const f=e[u++];let s=0;const a=new Array(f-1);for(let t=0;t<f;t++)s+=e[u++],t<f-1&&(a[t]=s);const l=e.slice(u,u+2*s),v=N(l,a,2);for(let e=0;e<v.length;e++)r.push(v[e]+n.length/i);for(let e=0;e<l.length;e+=2)n.push(l[e],l[e+1],...o);return u+2*s}const j=self;j.onmessage=r=>{const i=r.data;switch(i.type){case t:{const e=3,t=2,n=i.customAttributesSize,r=t+n,x=new Float32Array(i.renderInstructions),u=x.length/r,o=4*u*(n+e),f=new Uint32Array(6*u),s=new Float32Array(o);let a;for(let e=0;e<x.length;e+=r)a=U(x,e,s,f,n,a);const l=Object.assign({vertexBuffer:s.buffer,indexBuffer:f.buffer,renderInstructions:x.buffer},i);j.postMessage(l,[s.buffer,f.buffer,x.buffer]);break}case n:{const e=[],t=[],n=i.customAttributesSize,r=2,u=new Float32Array(i.renderInstructions);let o=0;const f=[1,0,0,1,0,0];let s,a;for(x(f,i.renderInstructionsTransform);o<u.length;){a=Array.from(u.slice(o,o+n)),o+=n,s=u[o++];const x=o,i=o+(s-1)*r,l=u[x]===u[i]&&u[x+1]===u[i+1];let v=0,h=0;for(let n=0;n<s-1;n++){let c=null;n>0?c=o+(n-1)*r:l&&(c=i-r);let p=null;n<s-2?p=o+(n+2)*r:l&&(p=x+r);const y=k(u,o+n*r,o+(n+1)*r,c,p,e,t,a,f,v,h);v=y.length,h=y.angle}o+=s*r}const l=Uint32Array.from(t),v=Float32Array.from(e),h=Object.assign({vertexBuffer:v.buffer,indexBuffer:l.buffer,renderInstructions:u.buffer},i);j.postMessage(h,[v.buffer,l.buffer,u.buffer]);break}case e:{const e=[],t=[],n=i.customAttributesSize,r=new Float32Array(i.renderInstructions);let x=0;for(;x<r.length;)x=G(r,x,e,t,n);const u=Uint32Array.from(t),o=Float32Array.from(e),f=Object.assign({vertexBuffer:o.buffer,indexBuffer:u.buffer,renderInstructions:r.buffer},i);j.postMessage(f,[o.buffer,u.buffer,r.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","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/renderer/webgl/PointsLayer\n */\nimport BaseVector from '../../layer/BaseVector.js';\nimport VectorEventType from '../../source/VectorEventType.js';\nimport ViewHint from '../../ViewHint.js';\nimport WebGLArrayBuffer from '../../webgl/Buffer.js';\nimport WebGLLayerRenderer from './Layer.js';\nimport WebGLRenderTarget from '../../webgl/RenderTarget.js';\nimport {ARRAY_BUFFER, DYNAMIC_DRAW, ELEMENT_ARRAY_BUFFER} from '../../webgl.js';\nimport {AttributeType, DefaultUniform} from '../../webgl/Helper.js';\nimport {WebGLWorkerMessageType} from '../../render/webgl/constants.js';\nimport {\n  apply as applyTransform,\n  create as createTransform,\n  makeInverse as makeInverseTransform,\n  multiply as multiplyTransform,\n  translate as translateTransform,\n} from '../../transform.js';\nimport {assert} from '../../asserts.js';\nimport {buffer, createEmpty, equals} from '../../extent.js';\nimport {colorDecodeId, colorEncodeId} from '../../render/webgl/utils.js';\nimport {create as createWebGLWorker} from '../../worker/webgl.js';\nimport {fromUserCoordinate, getUserProjection} from '../../proj.js';\nimport {getUid} from '../../util.js';\nimport {getWorldParameters} from './worldUtil.js';\nimport {listen, unlistenByKey} from '../../events.js';\n\n/**\n * @typedef {Object} CustomAttribute A description of a custom attribute to be passed on to the GPU, with a value different\n * for each feature.\n * @property {string} name Attribute name.\n * @property {function(import(\"../../Feature\").default, Object<string, *>):number} callback This callback computes the numerical value of the\n * attribute for a given feature (properties are available as 2nd arg for quicker access).\n */\n\n/**\n * @typedef {Object} FeatureCacheItem Object that holds a reference to a feature, its geometry and properties. Used to optimize\n * rebuildBuffers by accessing these objects quicker.\n * @property {import(\"../../Feature\").default} feature Feature\n * @property {Object<string, *>} properties Feature properties\n * @property {import(\"../../geom\").Geometry} geometry Feature geometry\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 {Array<CustomAttribute>} [attributes] These attributes will be read from the features in the source and then\n * passed to the GPU. The `name` property of each attribute will serve as its identifier:\n *  * In the vertex shader as an `attribute` by prefixing it with `a_`\n *  * In the fragment shader as a `varying` by prefixing it with `v_`\n * Please note that these can only be numerical values.\n * @property {string} vertexShader Vertex shader source, mandatory.\n * @property {string} fragmentShader Fragment shader source, mandatory.\n * @property {boolean} [hitDetectionEnabled] Whether shader is hit detection aware.\n * @property {Object<string,import(\"../../webgl/Helper\").UniformValue>} [uniforms] Uniform definitions for the post process steps\n * Please note that `u_texture` is reserved for the main texture slot and `u_opacity` is reserved for the layer opacity.\n * @property {Array<import(\"./Layer\").PostProcessesOptions>} [postProcesses] Post-processes definitions\n */\n\n/**\n * @classdesc\n * WebGL vector renderer optimized for points.\n * All features will be rendered as quads (two triangles forming a square). New data will be flushed to the GPU\n * every time the vector source changes.\n *\n * You need to provide vertex and fragment shaders for rendering. This can be done using\n * {@link module:ol/webgl/ShaderBuilder~ShaderBuilder} utilities. These shaders shall expect a `a_position` attribute\n * containing the screen-space projected center of the quad, as well as a `a_index` attribute\n * whose value (0, 1, 2 or 3) indicates which quad vertex is currently getting processed (see structure below).\n *\n * To include variable attributes in the shaders, you need to declare them using the `attributes` property of\n * the options object like so:\n * ```js\n * new WebGLPointsLayerRenderer(layer, {\n *   attributes: [\n *     {\n *       name: 'size',\n *       callback: function(feature) {\n *         // compute something with the feature\n *       }\n *     },\n *     {\n *       name: 'weight',\n *       callback: function(feature) {\n *         // compute something with the feature\n *       }\n *     },\n *   ],\n *   vertexShader:\n *     // shader using attribute a_weight and a_size\n *   fragmentShader:\n *     // shader using varying v_weight and v_size\n * ```\n *\n * To enable hit detection, you must as well provide dedicated shaders using the `hitVertexShader`\n * and `hitFragmentShader` properties. These shall expect the `a_hitColor` attribute to contain\n * the final color that will have to be output for hit detection to work.\n *\n * The following uniform is used for the main texture: `u_texture`.\n * The following uniform is used for the layer opacity: `u_opacity`.\n *\n * Please note that the main shader output should have premultiplied alpha, otherwise visual anomalies may occur.\n *\n * Points are rendered as quads with the following structure:\n *\n * ```\n *   (u0, v1)      (u1, v1)\n *  [3]----------[2]\n *   |`           |\n *   |  `         |\n *   |    `       |\n *   |      `     |\n *   |        `   |\n *   |          ` |\n *  [0]----------[1]\n *   (u0, v0)      (u1, v0)\n *  ```\n *\n * This uses {@link module:ol/webgl/Helper~WebGLHelper} internally.\n *\n * @api\n */\nclass WebGLPointsLayerRenderer 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 = options.uniforms || {};\n    const projectionMatrixTransform = createTransform();\n    uniforms[DefaultUniform.PROJECTION_MATRIX] = projectionMatrixTransform;\n\n    super(layer, {\n      uniforms: uniforms,\n      postProcesses: options.postProcesses,\n    });\n\n    this.sourceRevision_ = -1;\n\n    this.verticesBuffer_ = new WebGLArrayBuffer(ARRAY_BUFFER, DYNAMIC_DRAW);\n    this.indicesBuffer_ = new WebGLArrayBuffer(\n      ELEMENT_ARRAY_BUFFER,\n      DYNAMIC_DRAW\n    );\n\n    /**\n     * @private\n     */\n    this.vertexShader_ = options.vertexShader;\n\n    /**\n     * @private\n     */\n    this.fragmentShader_ = options.fragmentShader;\n\n    /**\n     * @type {WebGLProgram}\n     * @private\n     */\n    this.program_;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.hitDetectionEnabled_ = options.hitDetectionEnabled ?? true;\n\n    const customAttributes = options.attributes\n      ? options.attributes.map(function (attribute) {\n          return {\n            name: 'a_prop_' + attribute.name,\n            size: 1,\n            type: AttributeType.FLOAT,\n          };\n        })\n      : [];\n\n    /**\n     * A list of attributes used by the renderer. By default only the position and\n     * index of the vertex (0 to 3) are required.\n     * @type {Array<import('../../webgl/Helper.js').AttributeDescription>}\n     */\n    this.attributes = [\n      {\n        name: 'a_position',\n        size: 2,\n        type: AttributeType.FLOAT,\n      },\n      {\n        name: 'a_index',\n        size: 1,\n        type: AttributeType.FLOAT,\n      },\n    ];\n\n    if (this.hitDetectionEnabled_) {\n      this.attributes.push({\n        name: 'a_hitColor',\n        size: 4,\n        type: AttributeType.FLOAT,\n      });\n      this.attributes.push({\n        name: 'a_featureUid',\n        size: 1,\n        type: AttributeType.FLOAT,\n      });\n    }\n    this.attributes.push(...customAttributes);\n\n    this.customAttributes = options.attributes ? options.attributes : [];\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_ = projectionMatrixTransform;\n\n    /**\n     * This transform is updated when buffers are rebuilt and converts world space coordinates to screen space\n     * @type {import(\"../../transform.js\").Transform}\n     * @private\n     */\n    this.renderTransform_ = createTransform();\n\n    /**\n     * @type {import(\"../../transform.js\").Transform}\n     * @private\n     */\n    this.invertRenderTransform_ = createTransform();\n\n    /**\n     * @type {Float32Array}\n     * @private\n     */\n    this.renderInstructions_ = new Float32Array(0);\n\n    /**\n     * @type {WebGLRenderTarget}\n     * @private\n     */\n    this.hitRenderTarget_;\n\n    /**\n     * Keep track of latest message sent to worker\n     * @type {number}\n     * @private\n     */\n    this.lastSentId = 0;\n\n    /**\n     * @private\n     */\n    this.worker_ = createWebGLWorker();\n\n    this.worker_.addEventListener(\n      'message',\n      /**\n       * @param {*} event Event.\n       */\n      (event) => {\n        const received = event.data;\n        if (received.type === WebGLWorkerMessageType.GENERATE_POINT_BUFFERS) {\n          const projectionTransform = received.projectionTransform;\n          this.verticesBuffer_.fromArrayBuffer(received.vertexBuffer);\n          this.helper.flushBufferData(this.verticesBuffer_);\n          this.indicesBuffer_.fromArrayBuffer(received.indexBuffer);\n          this.helper.flushBufferData(this.indicesBuffer_);\n\n          this.renderTransform_ = projectionTransform;\n          makeInverseTransform(\n            this.invertRenderTransform_,\n            this.renderTransform_\n          );\n          this.renderInstructions_ = new Float32Array(\n            event.data.renderInstructions\n          );\n          if (received.id === this.lastSentId) {\n            this.ready = true;\n          }\n          this.getLayer().changed();\n        }\n      }\n    );\n\n    /**\n     * This object will be updated when the source changes. Key is uid.\n     * @type {Object<string, FeatureCacheItem>}\n     * @private\n     */\n    this.featureCache_ = {};\n\n    /**\n     * Amount of features in the cache.\n     * @type {number}\n     * @private\n     */\n    this.featureCount_ = 0;\n\n    const source = this.getLayer().getSource();\n    this.sourceListenKeys_ = [\n      listen(\n        source,\n        VectorEventType.ADDFEATURE,\n        this.handleSourceFeatureAdded_,\n        this\n      ),\n      listen(\n        source,\n        VectorEventType.CHANGEFEATURE,\n        this.handleSourceFeatureChanged_,\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    source.forEachFeature((feature) => {\n      this.featureCache_[getUid(feature)] = {\n        feature: feature,\n        properties: feature.getProperties(),\n        geometry: feature.getGeometry(),\n      };\n      this.featureCount_++;\n    });\n  }\n\n  afterHelperCreated() {\n    this.program_ = this.helper.getProgram(\n      this.fragmentShader_,\n      this.vertexShader_\n    );\n\n    if (this.hitDetectionEnabled_) {\n      this.hitRenderTarget_ = new WebGLRenderTarget(this.helper);\n    }\n  }\n\n  /**\n   * @param {import(\"../../source/Vector.js\").VectorSourceEvent} event Event.\n   * @private\n   */\n  handleSourceFeatureAdded_(event) {\n    const feature = event.feature;\n    this.featureCache_[getUid(feature)] = {\n      feature: feature,\n      properties: feature.getProperties(),\n      geometry: feature.getGeometry(),\n    };\n    this.featureCount_++;\n  }\n\n  /**\n   * @param {import(\"../../source/Vector.js\").VectorSourceEvent} event Event.\n   * @private\n   */\n  handleSourceFeatureChanged_(event) {\n    const feature = event.feature;\n    this.featureCache_[getUid(feature)] = {\n      feature: feature,\n      properties: feature.getProperties(),\n      geometry: feature.getGeometry(),\n    };\n  }\n\n  /**\n   * @param {import(\"../../source/Vector.js\").VectorSourceEvent} event Event.\n   * @private\n   */\n  handleSourceFeatureDelete_(event) {\n    const feature = event.feature;\n    delete this.featureCache_[getUid(feature)];\n    this.featureCount_--;\n  }\n\n  /**\n   * @private\n   */\n  handleSourceFeatureClear_() {\n    this.featureCache_ = {};\n    this.featureCount_ = 0;\n  }\n\n  /**\n   * Render the layer.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @return {HTMLElement} The rendered element.\n   */\n  renderFrame(frameState) {\n    const gl = this.helper.getGL();\n    this.preRender(gl, frameState);\n    const [startWorld, endWorld, worldWidth] = getWorldParameters(\n      frameState,\n      this.getLayer()\n    );\n\n    // draw the normal canvas\n    this.renderWorlds(frameState, false, startWorld, endWorld, worldWidth);\n    this.helper.finalizeDraw(\n      frameState,\n      this.dispatchPreComposeEvent,\n      this.dispatchPostComposeEvent\n    );\n\n    if (this.hitDetectionEnabled_) {\n      // draw the hit buffer\n      this.renderWorlds(frameState, true, startWorld, endWorld, worldWidth);\n      this.hitRenderTarget_.clearCachedData();\n    }\n\n    this.postRender(gl, frameState);\n\n    const canvas = this.helper.getCanvas();\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   */\n  prepareFrameInternal(frameState) {\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      vectorSource.loadFeatures(extent, resolution, projection);\n\n      this.rebuildBuffers_(frameState);\n      this.previousExtent_ = frameState.extent.slice();\n    }\n\n    this.helper.useProgram(this.program_, frameState);\n    this.helper.prepareDraw(frameState);\n\n    // write new data\n    this.helper.bindBuffer(this.verticesBuffer_);\n    this.helper.bindBuffer(this.indicesBuffer_);\n    this.helper.enableAttributes(this.attributes);\n\n    return true;\n  }\n\n  /**\n   * Rebuild internal webgl buffers based on current view extent; costly, should not be called too much\n   * @param {import(\"../../Map\").FrameState} frameState Frame state.\n   * @private\n   */\n  rebuildBuffers_(frameState) {\n    // saves the projection transform for the current frame state\n    const projectionTransform = createTransform();\n    this.helper.makeProjectionTransform(frameState, projectionTransform);\n\n    const userProjection = getUserProjection();\n\n    const baseInstructionLength = this.hitDetectionEnabled_ ? 7 : 2; // see below\n    const singleInstructionLength =\n      baseInstructionLength + this.customAttributes.length;\n    const totalSize = singleInstructionLength * this.featureCount_;\n    if (\n      !this.renderInstructions_ ||\n      this.renderInstructions_.length !== totalSize\n    ) {\n      this.renderInstructions_ = new Float32Array(totalSize);\n    }\n\n    // loop on features to fill the buffer\n    let featureCache, geometry;\n    const tmpCoords = [];\n    const tmpColor = [];\n    let idx = -1;\n    for (const featureUid in this.featureCache_) {\n      featureCache = this.featureCache_[featureUid];\n      geometry = /** @type {import(\"../../geom\").Point} */ (\n        featureCache.geometry\n      );\n      if (!geometry || geometry.getType() !== 'Point') {\n        continue;\n      }\n      if (userProjection) {\n        const userCoords = fromUserCoordinate(\n          geometry.getFlatCoordinates(),\n          frameState.viewState.projection\n        );\n        tmpCoords[0] = userCoords[0];\n        tmpCoords[1] = userCoords[1];\n      } else {\n        tmpCoords[0] = geometry.getFlatCoordinates()[0];\n        tmpCoords[1] = geometry.getFlatCoordinates()[1];\n      }\n      applyTransform(projectionTransform, tmpCoords);\n\n      this.renderInstructions_[++idx] = tmpCoords[0];\n      this.renderInstructions_[++idx] = tmpCoords[1];\n\n      // for hit detection, the feature uid is saved in the opacity value\n      // and the index of the opacity value is encoded in the color values\n      if (this.hitDetectionEnabled_) {\n        const hitColor = colorEncodeId(idx + 5, tmpColor);\n        this.renderInstructions_[++idx] = hitColor[0];\n        this.renderInstructions_[++idx] = hitColor[1];\n        this.renderInstructions_[++idx] = hitColor[2];\n        this.renderInstructions_[++idx] = hitColor[3];\n        this.renderInstructions_[++idx] = Number(featureUid);\n      }\n\n      // pushing custom attributes\n      for (let j = 0; j < this.customAttributes.length; j++) {\n        const value = this.customAttributes[j].callback(\n          featureCache.feature,\n          featureCache.properties\n        );\n        this.renderInstructions_[++idx] = value;\n      }\n    }\n\n    /** @type {import('../../render/webgl/constants.js').WebGLWorkerGenerateBuffersMessage} */\n    const message = {\n      id: ++this.lastSentId,\n      type: WebGLWorkerMessageType.GENERATE_POINT_BUFFERS,\n      renderInstructions: this.renderInstructions_.buffer,\n      customAttributesSize: singleInstructionLength - 2,\n    };\n    // additional properties will be sent back as-is by the worker\n    message['projectionTransform'] = projectionTransform;\n    this.ready = false;\n    this.worker_.postMessage(message, [this.renderInstructions_.buffer]);\n    this.renderInstructions_ = null;\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   */\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.renderInstructions_ || !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 index = colorDecodeId(color);\n    const opacity = this.renderInstructions_[index];\n    const uid = Math.floor(opacity).toString();\n\n    const source = this.getLayer().getSource();\n    const feature = source.getFeatureByUid(uid);\n    if (feature) {\n      return callback(feature, this.getLayer(), null);\n    }\n    return undefined;\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    this.helper.useProgram(this.program_, frameState);\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    this.helper.bindBuffer(this.verticesBuffer_);\n    this.helper.bindBuffer(this.indicesBuffer_);\n    this.helper.enableAttributes(this.attributes);\n\n    do {\n      this.helper.makeProjectionTransform(frameState, this.currentTransform_);\n      translateTransform(this.currentTransform_, world * worldWidth, 0);\n      multiplyTransform(this.currentTransform_, this.invertRenderTransform_);\n      this.helper.applyUniforms(frameState);\n      this.helper.applyHitDetectionUniform(forHitDetection);\n      const renderCount = this.indicesBuffer_.getSize();\n      this.helper.drawElements(0, renderCount);\n    } while (++world < endWorld);\n  }\n\n  /**\n   * Clean up.\n   */\n  disposeInternal() {\n    this.worker_.terminate();\n    this.layer_ = null;\n    this.sourceListenKeys_.forEach(function (key) {\n      unlistenByKey(key);\n    });\n    this.sourceListenKeys_ = null;\n    super.disposeInternal();\n  }\n}\n\nexport default WebGLPointsLayerRenderer;\n","/**\n * @module ol/render/webgl/renderinstructions\n */\nimport {apply as applyTransform} from '../../transform.js';\nimport {transform2D} from '../../geom/flat/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    renderInstructions[currentIndex + shift++] = value[0] ?? value;\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  // 2 instructions per vertex for position (x and y)\n  // + 1 instruction per line per custom attributes\n  // + 1 instruction per line (for vertices count)\n  const totalInstructionsCount =\n    2 * 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        2,\n        transform,\n        flatCoords\n      );\n      renderIndex += pushCustomAttributesInRenderInstructions(\n        renderInstructions,\n        customAttributes,\n        batchEntry,\n        renderIndex\n      );\n\n      // vertices count\n      renderInstructions[renderIndex++] = flatCoords.length / 2;\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/**\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 * @module ol/render/webgl/VectorStyleRenderer\n */\nimport WebGLArrayBuffer from '../../webgl/Buffer.js';\nimport {ARRAY_BUFFER, DYNAMIC_DRAW, ELEMENT_ARRAY_BUFFER} from '../../webgl.js';\nimport {AttributeType} from '../../webgl/Helper.js';\nimport {WebGLWorkerMessageType} from './constants.js';\nimport {colorEncodeId} from './utils.js';\nimport {\n  create as createTransform,\n  makeInverse as makeInverseTransform,\n} from '../../transform.js';\nimport {create as createWebGLWorker} from '../../worker/webgl.js';\nimport {\n  generateLineStringRenderInstructions,\n  generatePointRenderInstructions,\n  generatePolygonRenderInstructions,\n  getCustomAttributesSize,\n} from './renderinstructions.js';\nimport {parseLiteralStyle} from '../../webgl/styleparser.js';\n\nconst tmpColor = [];\nconst WEBGL_WORKER = createWebGLWorker();\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  INDEX: 'a_index',\n  SEGMENT_START: 'a_segmentStart',\n  SEGMENT_END: 'a_segmentEnd',\n  PARAMETERS: 'a_parameters',\n  JOIN_ANGLES: 'a_joinAngles',\n  DISTANCE: 'a_distance',\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\").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\").UniformValue>} UniformDefinitions\n */\n\n/**\n * @typedef {Object} WebGLBuffers\n * @property {Array<WebGLArrayBuffer>} polygonBuffers Array containing indices and vertices buffers for polygons\n * @property {Array<WebGLArrayBuffer>} lineStringBuffers Array containing indices and vertices buffers for line strings\n * @property {Array<WebGLArrayBuffer>} 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 {Object} StyleShaders\n * @property {import(\"../../webgl/ShaderBuilder.js\").ShaderBuilder} builder Shader builder with the appropriate presets.\n * @property {AttributeDefinitions} [attributes] Custom attributes made available in the vertex shaders.\n * Default shaders rely on the attributes in {@link Attributes}.\n * @property {UniformDefinitions} [uniforms] Additional uniforms usable in shaders.\n */\n\n/**\n * @typedef {import('../../style/webgl.js').WebGLStyle|StyleShaders} VectorStyle\n */\n\n/**\n * @classdesc This class is responsible for:\n * 1. generate WebGL buffers according to a provided style, using a MixedGeometryBatch as input\n * 2. rendering geometries contained in said buffers\n *\n * A layer renderer will typically maintain several of these in order to have several styles rendered separately.\n *\n * A VectorStyleRenderer instance can be created either from a literal style or from shaders using either\n * `VectorStyleRenderer.fromStyle` or `VectorStyleRenderer.fromShaders`. The shaders should not be provided explicitly\n * 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 {VectorStyle} styleOrShaders Literal style or custom shaders\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(styleOrShaders, helper, enableHitDetection) {\n    this.helper_ = helper;\n\n    this.hitDetectionEnabled_ = enableHitDetection;\n    let shaders = /** @type {StyleShaders} */ (styleOrShaders);\n    const isShaders = 'builder' in styleOrShaders;\n    if (!isShaders) {\n      const parseResult = parseLiteralStyle(\n        /** @type {import('../../style/webgl.js').WebGLStyle} */ (\n          styleOrShaders\n        )\n      );\n      shaders = {\n        builder: parseResult.builder,\n        attributes: parseResult.attributes,\n        uniforms: parseResult.uniforms,\n      };\n    }\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.hasFill_ = !!shaders.builder.getFillVertexShader();\n    if (this.hasFill_) {\n      this.fillVertexShader_ = shaders.builder.getFillVertexShader();\n      this.fillFragmentShader_ = shaders.builder.getFillFragmentShader();\n      this.fillProgram_ = this.helper_.getProgram(\n        this.fillFragmentShader_,\n        this.fillVertexShader_\n      );\n    }\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.hasStroke_ = !!shaders.builder.getStrokeVertexShader();\n    if (this.hasStroke_) {\n      this.strokeVertexShader_ = shaders.builder.getStrokeVertexShader();\n      this.strokeFragmentShader_ = shaders.builder.getStrokeFragmentShader();\n      this.strokeProgram_ = this.helper_.getProgram(\n        this.strokeFragmentShader_,\n        this.strokeVertexShader_\n      );\n    }\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.hasSymbol_ = !!shaders.builder.getSymbolVertexShader();\n    if (this.hasSymbol_) {\n      this.symbolVertexShader_ = shaders.builder.getSymbolVertexShader();\n      this.symbolFragmentShader_ = shaders.builder.getSymbolFragmentShader();\n      this.symbolProgram_ = this.helper_.getProgram(\n        this.symbolFragmentShader_,\n        this.symbolVertexShader_\n      );\n    }\n\n    const hitDetectionAttributes = this.hitDetectionEnabled_\n      ? {\n          hitColor: {\n            callback() {\n              return colorEncodeId(this.ref, tmpColor);\n            },\n            size: 4,\n          },\n        }\n      : {};\n\n    this.customAttributes_ = Object.assign(\n      {},\n      hitDetectionAttributes,\n      shaders.attributes\n    );\n    this.uniforms_ = shaders.uniforms;\n\n    const customAttributesDesc = Object.entries(this.customAttributes_).map(\n      ([name, value]) => ({\n        name: `a_prop_${name}`,\n        size: value.size || 1,\n        type: AttributeType.FLOAT,\n      })\n    );\n    /**\n     * @type {Array<import('../../webgl/Helper.js').AttributeDescription>}\n     * @private\n     */\n    this.polygonAttributesDesc_ = [\n      {\n        name: Attributes.POSITION,\n        size: 2,\n        type: AttributeType.FLOAT,\n      },\n      ...customAttributesDesc,\n    ];\n    /**\n     * @type {Array<import('../../webgl/Helper.js').AttributeDescription>}\n     * @private\n     */\n    this.lineStringAttributesDesc_ = [\n      {\n        name: Attributes.SEGMENT_START,\n        size: 2,\n        type: AttributeType.FLOAT,\n      },\n      {\n        name: Attributes.SEGMENT_END,\n        size: 2,\n        type: AttributeType.FLOAT,\n      },\n      {\n        name: Attributes.JOIN_ANGLES,\n        size: 2,\n        type: AttributeType.FLOAT,\n      },\n      {\n        name: Attributes.DISTANCE,\n        size: 1,\n        type: AttributeType.FLOAT,\n      },\n      {\n        name: Attributes.PARAMETERS,\n        size: 1,\n        type: AttributeType.FLOAT,\n      },\n      ...customAttributesDesc,\n    ];\n    /**\n     * @type {Array<import('../../webgl/Helper.js').AttributeDescription>}\n     * @private\n     */\n    this.pointAttributesDesc_ = [\n      {\n        name: Attributes.POSITION,\n        size: 2,\n        type: AttributeType.FLOAT,\n      },\n      {\n        name: Attributes.INDEX,\n        size: 1,\n        type: AttributeType.FLOAT,\n      },\n      ...customAttributesDesc,\n    ];\n\n    if (shaders.uniforms) {\n      this.helper_.addUniforms(shaders.uniforms);\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 {Promise<WebGLBuffers>} A promise resolving to WebGL buffers\n   */\n  async generateBuffers(geometryBatch, transform) {\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<Array<WebGLArrayBuffer>>|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    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 {*} 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 verticesBuffer = new WebGLArrayBuffer(\n          ARRAY_BUFFER,\n          DYNAMIC_DRAW\n        ).fromArrayBuffer(received.vertexBuffer);\n        const indicesBuffer = new WebGLArrayBuffer(\n          ELEMENT_ARRAY_BUFFER,\n          DYNAMIC_DRAW\n        ).fromArrayBuffer(received.indexBuffer);\n        this.helper_.flushBufferData(verticesBuffer);\n        this.helper_.flushBufferData(indicesBuffer);\n\n        resolve([indicesBuffer, verticesBuffer]);\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    this.hasFill_ &&\n      this.renderInternal_(\n        buffers.polygonBuffers[0],\n        buffers.polygonBuffers[1],\n        this.fillProgram_,\n        this.polygonAttributesDesc_,\n        frameState,\n        preRenderCallback\n      );\n    this.hasStroke_ &&\n      this.renderInternal_(\n        buffers.lineStringBuffers[0],\n        buffers.lineStringBuffers[1],\n        this.strokeProgram_,\n        this.lineStringAttributesDesc_,\n        frameState,\n        preRenderCallback\n      );\n    this.hasSymbol_ &&\n      this.renderInternal_(\n        buffers.pointBuffers[0],\n        buffers.pointBuffers[1],\n        this.symbolProgram_,\n        this.pointAttributesDesc_,\n        frameState,\n        preRenderCallback\n      );\n  }\n\n  /**\n   * @param {WebGLArrayBuffer} indicesBuffer Indices buffer\n   * @param {WebGLArrayBuffer} verticesBuffer Vertices buffer\n   * @param {WebGLProgram} program Program\n   * @param {Array<import('../../webgl/Helper.js').AttributeDescription>} attributes Attribute descriptions\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    verticesBuffer,\n    program,\n    attributes,\n    frameState,\n    preRenderCallback\n  ) {\n    const renderCount = indicesBuffer.getSize();\n    if (renderCount === 0) {\n      return;\n    }\n    this.helper_.useProgram(program, frameState);\n    this.helper_.bindBuffer(verticesBuffer);\n    this.helper_.bindBuffer(indicesBuffer);\n    this.helper_.enableAttributes(attributes);\n    preRenderCallback();\n    this.helper_.drawElements(0, renderCount);\n  }\n}\n\nexport default VectorStyleRenderer;\n","/**\n * @module ol/renderer/webgl/VectorLayer\n */\nimport BaseVector from '../../layer/BaseVector.js';\nimport MixedGeometryBatch from '../../render/webgl/MixedGeometryBatch.js';\nimport VectorEventType from '../../source/VectorEventType.js';\nimport VectorStyleRenderer from '../../render/webgl/VectorStyleRenderer.js';\nimport ViewHint from '../../ViewHint.js';\nimport WebGLLayerRenderer from './Layer.js';\nimport WebGLRenderTarget from '../../webgl/RenderTarget.js';\nimport {DefaultUniform} from '../../webgl/Helper.js';\nimport {\n  apply as applyTransform,\n  create as createTransform,\n  makeInverse as makeInverseTransform,\n  multiply as multiplyTransform,\n  setFromArray as setFromTransform,\n  translate as translateTransform,\n} from '../../transform.js';\nimport {assert} from '../../asserts.js';\nimport {buffer, createEmpty, equals} from '../../extent.js';\nimport {colorDecodeId} from '../../render/webgl/utils.js';\nimport {\n  create as createMat4,\n  fromTransform as mat4FromTransform,\n} from '../../vec/mat4.js';\nimport {\n  getTransformFromProjections,\n  getUserProjection,\n  toUserExtent,\n  toUserResolution,\n} from '../../proj.js';\nimport {getWorldParameters} from './worldUtil.js';\nimport {listen, unlistenByKey} from '../../events.js';\n\nexport const Uniforms = {\n  ...DefaultUniform,\n  RENDER_EXTENT: 'u_renderExtent', // intersection of layer, source, and view extent\n  PATTERN_ORIGIN: 'u_patternOrigin',\n  GLOBAL_ALPHA: 'u_globalAlpha',\n};\n\n/**\n * @typedef {import('../../render/webgl/VectorStyleRenderer.js').VectorStyle} VectorStyle\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 {VectorStyle|Array<VectorStyle>} style Vector style as literal style or shaders; can also accept an array of styles\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\").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.PATTERN_ORIGIN]: [0, 0],\n      [Uniforms.GLOBAL_ALPHA]: 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    this.sourceRevision_ = -1;\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    this.tmpCoords_ = [0, 0];\n    this.tmpTransform_ = createTransform();\n    this.tmpMat4_ = createMat4();\n\n    /**\n     * @type {import(\"../../transform.js\").Transform}\n     * @private\n     */\n    this.currentFrameStateTransform_ = createTransform();\n\n    /**\n     * @type {Array<VectorStyle>}\n     * @private\n     */\n    this.styles_ = [];\n\n    /**\n     * @type {Array<VectorStyleRenderer>}\n     * @private\n     */\n    this.styleRenderers_ = [];\n\n    /**\n     * @type {Array<import('../../render/webgl/VectorStyleRenderer.js').WebGLBuffers>}\n     * @private\n     */\n    this.buffers_ = [];\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        this\n      ),\n      listen(\n        source,\n        VectorEventType.CHANGEFEATURE,\n        this.handleSourceFeatureChanged_,\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.styles_ = Array.isArray(options.style)\n      ? options.style\n      : [options.style];\n  }\n\n  /**\n   * @private\n   */\n  createRenderers_() {\n    this.buffers_ = [];\n    this.styleRenderers_ = this.styles_.map(\n      (style) =>\n        new VectorStyleRenderer(style, this.helper, this.hitDetectionEnabled_)\n    );\n  }\n\n  reset(options) {\n    this.applyOptions_(options);\n    if (this.helper) {\n      this.createRenderers_();\n    }\n    super.reset(options);\n  }\n\n  afterHelperCreated() {\n    this.createRenderers_();\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(\"../../source/Vector.js\").VectorSourceEvent} event Event.\n   * @private\n   */\n  handleSourceFeatureChanged_(event) {\n    const feature = event.feature;\n    this.batch_.changeFeature(feature);\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   * @private\n   */\n  applyUniforms_(batchInvertTransform) {\n    // world to screen matrix\n    setFromTransform(this.tmpTransform_, this.currentFrameStateTransform_);\n    multiplyTransform(this.tmpTransform_, batchInvertTransform);\n    this.helper.setUniformMatrixValue(\n      Uniforms.PROJECTION_MATRIX,\n      mat4FromTransform(this.tmpMat4_, this.tmpTransform_)\n    );\n\n    // screen to world matrix\n    makeInverseTransform(this.tmpTransform_, this.tmpTransform_);\n    this.helper.setUniformMatrixValue(\n      Uniforms.SCREEN_TO_WORLD_MATRIX,\n      mat4FromTransform(this.tmpMat4_, this.tmpTransform_)\n    );\n\n    // pattern origin should always be [0, 0] in world coordinates\n    this.tmpCoords_[0] = 0;\n    this.tmpCoords_[1] = 0;\n    makeInverseTransform(this.tmpTransform_, batchInvertTransform);\n    applyTransform(this.tmpTransform_, this.tmpCoords_);\n    this.helper.setUniformFloatVec2(Uniforms.PATTERN_ORIGIN, this.tmpCoords_);\n  }\n\n  /**\n   * Render the layer.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   * @return {HTMLElement} The rendered element.\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(frameState);\n\n    const canvas = this.helper.getCanvas();\n    const layerState = frameState.layerStatesArray[frameState.layerIndex];\n    const opacity = layerState.opacity;\n    if (opacity !== parseFloat(canvas.style.opacity)) {\n      canvas.style.opacity = String(opacity);\n    }\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   */\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      const generatePromises = this.styleRenderers_.map((renderer, i) =>\n        renderer.generateBuffers(this.batch_, transform).then((buffers) => {\n          this.buffers_[i] = buffers;\n        })\n      );\n      Promise.all(generatePromises).then(() => {\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    this.currentFrameStateTransform_ = this.helper.makeProjectionTransform(\n      frameState,\n      this.currentFrameStateTransform_\n    );\n\n    do {\n      for (let i = 0, ii = this.styleRenderers_.length; i < ii; i++) {\n        const renderer = this.styleRenderers_[i];\n        const buffers = this.buffers_[i];\n        if (!buffers) {\n          continue;\n        }\n        renderer.render(buffers, frameState, () => {\n          this.applyUniforms_(buffers.invertVerticesTransform);\n          this.helper.applyHitDetectionUniform(forHitDetection);\n        });\n      }\n      translateTransform(this.currentFrameStateTransform_, worldWidth, 0);\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   */\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.styleRenderers_.length || !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   * Clean up.\n   */\n  disposeInternal() {\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\nexport default WebGLVectorLayerRenderer;\n","/**\n * @module ol/renderer/webgl/VectorTileLayer\n */\nimport EventType from '../../events/EventType.js';\nimport TileGeometry from '../../webgl/TileGeometry.js';\nimport VectorStyleRenderer from '../../render/webgl/VectorStyleRenderer.js';\nimport WebGLArrayBuffer from '../../webgl/Buffer.js';\nimport WebGLBaseTileLayerRenderer, {\n  Uniforms as BaseUniforms,\n} from './TileLayerBase.js';\nimport WebGLRenderTarget from '../../webgl/RenderTarget.js';\nimport {AttributeType} from '../../webgl/Helper.js';\nimport {ELEMENT_ARRAY_BUFFER, STATIC_DRAW} from '../../webgl.js';\nimport {ShaderBuilder} from '../../webgl/ShaderBuilder.js';\nimport {\n  create as createMat4,\n  fromTransform as mat4FromTransform,\n} from '../../vec/mat4.js';\nimport {\n  create as createTransform,\n  makeInverse as makeInverseTransform,\n  multiply as multiplyTransform,\n  setFromArray as setFromTransform,\n} from '../../transform.js';\nimport {getIntersection} from '../../extent.js';\nimport {parseLiteralStyle} from '../../webgl/styleparser.js';\n\nexport const Uniforms = {\n  ...BaseUniforms,\n  TILE_MASK_TEXTURE: 'u_depthMask',\n  TILE_ZOOM_LEVEL: 'u_tileZoomLevel',\n};\n\nexport const Attributes = {\n  POSITION: 'a_position',\n};\n\n/**\n * @typedef {import('../../render/webgl/VectorStyleRenderer.js').VectorStyle} VectorStyle\n */\n\n/**\n * @typedef {Object} Options\n * @property {VectorStyle|Array<VectorStyle>} style Vector style as literal style or shaders; can also accept an array of styles\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 {number} [cacheSize=512] The vector tile cache size.\n */\n\n/**\n * @typedef {import(\"../../layer/BaseTile.js\").default} LayerType\n */\n\n/**\n * @classdesc\n * WebGL renderer for vector tile layers. Experimental.\n * @extends {WebGLBaseTileLayerRenderer<LayerType>}\n */\nclass WebGLVectorTileLayerRenderer extends WebGLBaseTileLayerRenderer {\n  /**\n   * @param {LayerType} tileLayer Tile layer.\n   * @param {Options} options Options.\n   */\n  constructor(tileLayer, options) {\n    super(tileLayer, {\n      cacheSize: options.cacheSize,\n      uniforms: {\n        [Uniforms.PATTERN_ORIGIN]: [0, 0],\n      },\n    });\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.hitDetectionEnabled_ = !options.disableHitDetection;\n\n    /**\n     * @type {Array<VectorStyle>}\n     * @private\n     */\n    this.styles_ = [];\n\n    /**\n     * @type {Array<VectorStyleRenderer>}\n     * @private\n     */\n    this.styleRenderers_ = [];\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.currentFrameStateTransform_ = createTransform();\n\n    this.tmpTransform_ = createTransform();\n    this.tmpMat4_ = createMat4();\n\n    /**\n     * @type {WebGLRenderTarget}\n     * @private\n     */\n    this.tileMaskTarget_ = null;\n\n    /**\n     * @private\n     */\n    this.tileMaskIndices_ = new WebGLArrayBuffer(\n      ELEMENT_ARRAY_BUFFER,\n      STATIC_DRAW\n    );\n    this.tileMaskIndices_.fromArray([0, 1, 3, 1, 2, 3]);\n\n    /**\n     * @type {Array<import('../../webgl/Helper.js').AttributeDescription>}\n     * @private\n     */\n    this.tileMaskAttributes_ = [\n      {\n        name: Attributes.POSITION,\n        size: 2,\n        type: AttributeType.FLOAT,\n      },\n    ];\n\n    /**\n     * @type {WebGLProgram}\n     */\n    this.tileMaskProgram_;\n\n    this.applyOptions_(options);\n  }\n\n  /**\n   * @param {Options} options Options.\n   */\n  reset(options) {\n    super.reset(options);\n\n    this.applyOptions_(options);\n    if (this.helper) {\n      this.createRenderers_();\n      this.initTileMask_();\n    }\n  }\n\n  /**\n   * @param {Options} options Options.\n   * @private\n   */\n  applyOptions_(options) {\n    this.styles_ = Array.isArray(options.style)\n      ? options.style\n      : [options.style];\n  }\n\n  /**\n   * @private\n   */\n  createRenderers_() {\n    function addBuilderParams(builder) {\n      const exisitingDiscard = builder.getFragmentDiscardExpression();\n      const discardFromMask = `texture2D(${Uniforms.TILE_MASK_TEXTURE}, gl_FragCoord.xy / u_pixelRatio / u_viewportSizePx).r * 50. > ${Uniforms.TILE_ZOOM_LEVEL} + 0.5`;\n      builder.setFragmentDiscardExpression(\n        exisitingDiscard !== 'false'\n          ? `(${exisitingDiscard}) || (${discardFromMask})`\n          : discardFromMask\n      );\n      builder.addUniform(`sampler2D ${Uniforms.TILE_MASK_TEXTURE}`);\n      builder.addUniform(`float ${Uniforms.TILE_ZOOM_LEVEL}`);\n    }\n\n    this.styleRenderers_ = this.styles_.map((style) => {\n      const isShaders = 'builder' in style;\n      let shaders;\n      if (!isShaders) {\n        const parseResult = parseLiteralStyle(\n          /** @type {import('../../style/webgl.js').WebGLStyle} */ (style)\n        );\n        addBuilderParams(parseResult.builder);\n        shaders = {\n          builder: parseResult.builder,\n          attributes: parseResult.attributes,\n          uniforms: parseResult.uniforms,\n        };\n      } else {\n        addBuilderParams(\n          /** @type {import('../../render/webgl/VectorStyleRenderer.js').StyleShaders} */ (\n            style\n          ).builder\n        );\n        shaders = style;\n      }\n      return new VectorStyleRenderer(\n        shaders,\n        this.helper,\n        this.hitDetectionEnabled_\n      );\n    });\n  }\n\n  /**\n   * @private\n   */\n  initTileMask_() {\n    this.tileMaskTarget_ = new WebGLRenderTarget(this.helper);\n    const builder = new ShaderBuilder()\n      .setFillColorExpression(\n        `vec4(${Uniforms.TILE_ZOOM_LEVEL} / 50., 0., 0., 1.)`\n      )\n      .addUniform(`float ${Uniforms.TILE_ZOOM_LEVEL}`);\n    this.tileMaskProgram_ = this.helper.getProgram(\n      builder.getFillFragmentShader(),\n      builder.getFillVertexShader()\n    );\n    this.helper.flushBufferData(this.tileMaskIndices_);\n  }\n\n  afterHelperCreated() {\n    this.createRenderers_();\n    this.initTileMask_();\n  }\n\n  createTileRepresentation(options) {\n    const tileRep = new TileGeometry(options, this.styleRenderers_);\n    // redraw the layer when the tile is ready\n    const listener = () => {\n      if (tileRep.ready) {\n        this.getLayer().changed();\n        tileRep.removeEventListener(EventType.CHANGE, listener);\n      }\n    };\n    tileRep.addEventListener(EventType.CHANGE, listener);\n    return tileRep;\n  }\n\n  beforeTilesRender(frameState, tilesWithAlpha) {\n    super.beforeTilesRender(frameState, true); // always consider that tiles need alpha blending\n    this.helper.makeProjectionTransform(\n      frameState,\n      this.currentFrameStateTransform_\n    );\n    this.helper.bindTexture(\n      this.tileMaskTarget_.getTexture(),\n      0,\n      Uniforms.TILE_MASK_TEXTURE\n    );\n  }\n\n  beforeTilesMaskRender(frameState) {\n    this.helper.makeProjectionTransform(\n      frameState,\n      this.currentFrameStateTransform_\n    );\n    const pixelRatio = frameState.pixelRatio;\n    const size = frameState.size;\n    this.tileMaskTarget_.setSize([size[0] * pixelRatio, size[1] * pixelRatio]);\n    this.helper.prepareDrawToRenderTarget(\n      frameState,\n      this.tileMaskTarget_,\n      true,\n      true\n    );\n    this.helper.useProgram(this.tileMaskProgram_, frameState);\n    setFromTransform(this.tmpTransform_, this.currentFrameStateTransform_);\n    this.helper.setUniformMatrixValue(\n      Uniforms.PROJECTION_MATRIX,\n      mat4FromTransform(this.tmpMat4_, this.tmpTransform_)\n    );\n    makeInverseTransform(this.tmpTransform_, this.currentFrameStateTransform_);\n    this.helper.setUniformMatrixValue(\n      Uniforms.SCREEN_TO_WORLD_MATRIX,\n      mat4FromTransform(this.tmpMat4_, this.tmpTransform_)\n    );\n    return true;\n  }\n\n  renderTileMask(tileRepresentation, tileZ, extent, depth) {\n    if (!tileRepresentation.ready) {\n      return;\n    }\n    this.helper.setUniformFloatValue(Uniforms.DEPTH, depth);\n    this.helper.setUniformFloatValue(Uniforms.TILE_ZOOM_LEVEL, tileZ);\n    this.helper.setUniformFloatVec4(Uniforms.RENDER_EXTENT, extent);\n    this.helper.setUniformFloatValue(Uniforms.GLOBAL_ALPHA, 1);\n    this.helper.bindBuffer(\n      /** @type {TileGeometry} */ (tileRepresentation).maskVertices\n    );\n    this.helper.bindBuffer(this.tileMaskIndices_);\n    this.helper.enableAttributes(this.tileMaskAttributes_);\n    const renderCount = this.tileMaskIndices_.getSize();\n    this.helper.drawElements(0, renderCount);\n  }\n\n  /**\n   * @param {number} alpha Alpha value of the tile\n   * @param {import(\"../../extent.js\").Extent} renderExtent Which extent to restrict drawing to\n   * @param {import(\"../../transform.js\").Transform} batchInvertTransform Inverse of the transformation in which tile geometries are expressed\n   * @param {number} tileZ Tile zoom level\n   * @param {number} depth Depth of the tile\n   * @private\n   */\n  applyUniforms_(alpha, renderExtent, batchInvertTransform, tileZ, depth) {\n    // world to screen matrix\n    setFromTransform(this.tmpTransform_, this.currentFrameStateTransform_);\n    multiplyTransform(this.tmpTransform_, batchInvertTransform);\n    this.helper.setUniformMatrixValue(\n      Uniforms.PROJECTION_MATRIX,\n      mat4FromTransform(this.tmpMat4_, this.tmpTransform_)\n    );\n\n    // screen to world matrix\n    makeInverseTransform(this.tmpTransform_, this.currentFrameStateTransform_);\n    this.helper.setUniformMatrixValue(\n      Uniforms.SCREEN_TO_WORLD_MATRIX,\n      mat4FromTransform(this.tmpMat4_, this.tmpTransform_)\n    );\n\n    this.helper.setUniformFloatValue(Uniforms.GLOBAL_ALPHA, alpha);\n    this.helper.setUniformFloatValue(Uniforms.DEPTH, depth);\n    this.helper.setUniformFloatValue(Uniforms.TILE_ZOOM_LEVEL, tileZ);\n    this.helper.setUniformFloatVec4(Uniforms.RENDER_EXTENT, renderExtent);\n  }\n\n  renderTile(\n    tileRepresentation,\n    tileTransform,\n    frameState,\n    renderExtent,\n    tileResolution,\n    tileSize,\n    tileOrigin,\n    tileExtent,\n    depth,\n    gutter,\n    alpha\n  ) {\n    const gutterExtent = getIntersection(tileExtent, renderExtent, tileExtent);\n    const tileZ = tileRepresentation.tile.getTileCoord()[0];\n    for (let i = 0, ii = this.styleRenderers_.length; i < ii; i++) {\n      const renderer = this.styleRenderers_[i];\n      const buffers = tileRepresentation.buffers[i];\n      renderer.render(buffers, frameState, () => {\n        this.applyUniforms_(\n          alpha,\n          gutterExtent,\n          buffers.invertVerticesTransform,\n          tileZ,\n          depth\n        );\n      });\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\n  /**\n   * Clean up.\n   */\n  disposeInternal() {\n    super.disposeInternal();\n  }\n}\n\nexport default WebGLVectorTileLayerRenderer;\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 CanvasInstruction from './Instruction.js';\nimport Relationship from '../../extent/Relationship.js';\nimport VectorContext from '../VectorContext.js';\nimport {asColorLike} from '../../colorlike.js';\nimport {\n  buffer,\n  clone,\n  containsCoordinate,\n  coordinateRelationship,\n} from '../../extent.js';\nimport {\n  defaultFillStyle,\n  defaultLineCap,\n  defaultLineDash,\n  defaultLineDashOffset,\n  defaultLineJoin,\n  defaultLineWidth,\n  defaultMiterLimit,\n  defaultStrokeStyle,\n} from '../canvas.js';\nimport {equals, reverseSubArray} from '../../array.js';\nimport {\n  inflateCoordinates,\n  inflateCoordinatesArray,\n  inflateMultiCoordinatesArray,\n} from '../../geom/flat/inflate.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   */\n  drawCustom(geometry, feature, renderer, hitDetectionRenderer) {\n    this.beginGeometry(geometry, feature);\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        ]);\n        this.hitDetectionInstructions.push([\n          CanvasInstruction.CUSTOM,\n          builderBegin,\n          builderEndss,\n          geometry,\n          hitDetectionRenderer || renderer,\n          inflateMultiCoordinatesArray,\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        ]);\n        this.hitDetectionInstructions.push([\n          CanvasInstruction.CUSTOM,\n          builderBegin,\n          builderEnds,\n          geometry,\n          hitDetectionRenderer || renderer,\n          inflateCoordinatesArray,\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        ]);\n        this.hitDetectionInstructions.push([\n          CanvasInstruction.CUSTOM,\n          builderBegin,\n          builderEnd,\n          geometry,\n          hitDetectionRenderer || renderer,\n          inflateCoordinates,\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          ]);\n          this.hitDetectionInstructions.push([\n            CanvasInstruction.CUSTOM,\n            builderBegin,\n            builderEnd,\n            geometry,\n            hitDetectionRenderer || renderer,\n            inflateCoordinates,\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        ]);\n        this.hitDetectionInstructions.push([\n          CanvasInstruction.CUSTOM,\n          builderBegin,\n          builderEnd,\n          geometry,\n          hitDetectionRenderer || renderer,\n        ]);\n        break;\n      default:\n    }\n    this.endGeometry(feature);\n  }\n\n  /**\n   * @protected\n   * @param {import(\"../../geom/Geometry\").default|import(\"../Feature.js\").default} geometry The geometry.\n   * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n   */\n  beginGeometry(geometry, feature) {\n    this.beginGeometryInstruction1_ = [\n      CanvasInstruction.BEGIN_GEOMETRY,\n      feature,\n      0,\n      geometry,\n    ];\n    this.instructions.push(this.beginGeometryInstruction1_);\n    this.beginGeometryInstruction2_ = [\n      CanvasInstruction.BEGIN_GEOMETRY,\n      feature,\n      0,\n      geometry,\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(\"../../style/Stroke.js\").default} strokeStyle Stroke style.\n   */\n  setFillStrokeStyle(fillStyle, strokeStyle) {\n    const state = this.state;\n    if (fillStyle) {\n      const fillStyleColor = fillStyle.getColor();\n      state.fillStyle = asColorLike(\n        fillStyleColor ? fillStyleColor : defaultFillStyle\n      );\n    } else {\n      state.fillStyle = undefined;\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\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    }\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 it!\n      fillInstruction.push(true);\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      this.applyPixelRatio(state.lineDash),\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 (typeof fillStyle !== 'string' || state.currentFillStyle != fillStyle) {\n      if (fillStyle !== undefined) {\n        this.instructions.push(createFill.call(this, state));\n      }\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    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    ) {\n      if (strokeStyle !== undefined) {\n        applyStroke.call(this, state);\n      }\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    }\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 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 {\"declutter\"|\"obstacle\"|\"none\"|undefined}\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   */\n  drawPoint(pointGeometry, feature) {\n    if (!this.image_) {\n      return;\n    }\n    this.beginGeometry(pointGeometry, feature);\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   */\n  drawMultiPoint(multiPointGeometry, feature) {\n    if (!this.image_) {\n      return;\n    }\n    this.beginGeometry(multiPointGeometry, feature);\n    const flatCoordinates = multiPointGeometry.getFlatCoordinates();\n    const stride = multiPointGeometry.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   * @return {import(\"../canvas.js\").SerializableInstructions} the serializable instructions.\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   */\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 CanvasBuilder from './Builder.js';\nimport CanvasInstruction, {\n  beginPathInstruction,\n  strokeInstruction,\n} from './Instruction.js';\nimport {defaultLineDash, defaultLineDashOffset} from '../canvas.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   * @private\n   * @return {number} end.\n   */\n  drawFlatCoordinates_(flatCoordinates, offset, end, stride) {\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    const moveToLineToInstruction = [\n      CanvasInstruction.MOVE_TO_LINE_TO,\n      myBegin,\n      myEnd,\n    ];\n    this.instructions.push(moveToLineToInstruction);\n    this.hitDetectionInstructions.push(moveToLineToInstruction);\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   */\n  drawLineString(lineStringGeometry, feature) {\n    const state = this.state;\n    const strokeStyle = state.strokeStyle;\n    const lineWidth = state.lineWidth;\n    if (strokeStyle === undefined || lineWidth === undefined) {\n      return;\n    }\n    this.updateStrokeStyle(state, this.applyStroke);\n    this.beginGeometry(lineStringGeometry, feature);\n    this.hitDetectionInstructions.push(\n      [\n        CanvasInstruction.SET_STROKE_STYLE,\n        state.strokeStyle,\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    );\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   */\n  drawMultiLineString(multiLineStringGeometry, feature) {\n    const state = this.state;\n    const strokeStyle = state.strokeStyle;\n    const lineWidth = state.lineWidth;\n    if (strokeStyle === undefined || lineWidth === undefined) {\n      return;\n    }\n    this.updateStrokeStyle(state, this.applyStroke);\n    this.beginGeometry(multiLineStringGeometry, feature);\n    this.hitDetectionInstructions.push(\n      [\n        CanvasInstruction.SET_STROKE_STYLE,\n        state.strokeStyle,\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      );\n    }\n    this.hitDetectionInstructions.push(strokeInstruction);\n    this.endGeometry(feature);\n  }\n\n  /**\n   * @return {import(\"../canvas.js\").SerializableInstructions} the serializable instructions.\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   */\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 CanvasBuilder from './Builder.js';\nimport CanvasInstruction, {\n  beginPathInstruction,\n  closePathInstruction,\n  fillInstruction,\n  strokeInstruction,\n} from './Instruction.js';\nimport {\n  defaultFillStyle,\n  defaultLineDash,\n  defaultLineDashOffset,\n} from '../canvas.js';\nimport {snap} from '../../geom/flat/simplify.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   * @private\n   * @return {number} End.\n   */\n  drawFlatCoordinatess_(flatCoordinates, offset, ends, stride) {\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      const moveToLineToInstruction = [\n        CanvasInstruction.MOVE_TO_LINE_TO,\n        myBegin,\n        myEnd,\n      ];\n      this.instructions.push(moveToLineToInstruction);\n      this.hitDetectionInstructions.push(moveToLineToInstruction);\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   */\n  drawCircle(circleGeometry, feature) {\n    const state = this.state;\n    const fillStyle = state.fillStyle;\n    const strokeStyle = state.strokeStyle;\n    if (fillStyle === undefined && strokeStyle === undefined) {\n      return;\n    }\n    this.setFillStrokeStyles_();\n    this.beginGeometry(circleGeometry, feature);\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        state.strokeStyle,\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];\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   */\n  drawPolygon(polygonGeometry, feature) {\n    const state = this.state;\n    const fillStyle = state.fillStyle;\n    const strokeStyle = state.strokeStyle;\n    if (fillStyle === undefined && strokeStyle === undefined) {\n      return;\n    }\n    this.setFillStrokeStyles_();\n    this.beginGeometry(polygonGeometry, feature);\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        state.strokeStyle,\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    );\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   */\n  drawMultiPolygon(multiPolygonGeometry, feature) {\n    const state = this.state;\n    const fillStyle = state.fillStyle;\n    const strokeStyle = state.strokeStyle;\n    if (fillStyle === undefined && strokeStyle === undefined) {\n      return;\n    }\n    this.setFillStrokeStyles_();\n    this.beginGeometry(multiPolygonGeometry, feature);\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        state.strokeStyle,\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      );\n    }\n    this.endGeometry(feature);\n  }\n\n  /**\n   * @return {import(\"../canvas.js\").SerializableInstructions} the serializable instructions.\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    const fillStyle = state.fillStyle;\n    if (fillStyle !== undefined) {\n      this.updateFillStyle(state, this.createFill);\n    }\n    if (state.strokeStyle !== undefined) {\n      this.updateStrokeStyle(state, this.applyStroke);\n    }\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 CanvasBuilder from './Builder.js';\nimport CanvasInstruction from './Instruction.js';\nimport {asColorLike} from '../../colorlike.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 {getUid} from '../../util.js';\nimport {intersects} from '../../extent.js';\nimport {lineChunk} from '../../geom/flat/linechunk.js';\nimport {matchingChunk} from '../../geom/flat/straightchunk.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 {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     * 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   */\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   */\n  drawText(geometry, feature) {\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.getBufferedMaxExtent(), 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);\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      if (textState.backgroundFill || textState.backgroundStroke) {\n        this.setFillStrokeStyle(\n          textState.backgroundFill,\n          textState.backgroundStroke\n        );\n        if (textState.backgroundFill) {\n          this.updateFillStyle(this.state, this.createFill);\n        }\n        if (textState.backgroundStroke) {\n          this.updateStrokeStyle(this.state, this.applyStroke);\n          this.hitDetectionInstructions.push(this.createStroke(this.state));\n        }\n      }\n\n      this.beginGeometry(geometry, feature);\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        undefined,\n        this.declutterImageWithText_,\n        padding == defaultPadding\n          ? defaultPadding\n          : padding.map(function (p) {\n              return p * pixelRatio;\n            }),\n        !!textState.backgroundFill,\n        !!textState.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 currentFillStyle = this.state.fillStyle;\n      if (textState.backgroundFill) {\n        this.state.fillStyle = defaultFillStyle;\n        this.hitDetectionInstructions.push(this.createFill(this.state));\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        undefined,\n        this.declutterImageWithText_,\n        padding,\n        !!textState.backgroundFill,\n        !!textState.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      // Reset previous fill\n      if (textState.backgroundFill) {\n        this.state.fillStyle = currentFillStyle;\n        this.hitDetectionInstructions.push(this.createFill(this.state));\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    ]);\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    ]);\n  }\n\n  /**\n   * @param {import(\"../../style/Text.js\").default} textStyle Text style.\n   * @param {Object} [sharedData] Shared data.\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 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.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_ = fillState\n        ? typeof fillState.fillStyle == 'string'\n          ? fillState.fillStyle\n          : '|' + getUid(fillState.fillStyle)\n        : '';\n    }\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 * @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) {\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\n  let reverse;\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  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 CanvasInstruction from './Instruction.js';\nimport {TEXT_ALIGN} from './TextBuilder.js';\nimport {\n  apply as applyTransform,\n  compose as composeTransform,\n  create as createTransform,\n  setFromArray as transformSetFromArray,\n} from '../../transform.js';\nimport {createEmpty, createOrUpdate, intersects} from '../../extent.js';\nimport {\n  defaultPadding,\n  defaultTextAlign,\n  defaultTextBaseline,\n  drawImageOrLabel,\n  getTextDimensions,\n  measureAndCacheTextWidth,\n} from '../canvas.js';\nimport {drawTextOnPath} from '../../geom/flat/textpath.js';\nimport {equals} from '../../array.js';\nimport {lineStringLength} from '../../geom/flat/length.js';\nimport {transform2D} from '../../geom/flat/transform.js';\n\n/**\n * @typedef {Object} BBox\n * @property {number} minX Minimal x.\n * @property {number} minY Minimal y.\n * @property {number} maxX Maximal x.\n * @property {number} maxY Maximal y\n * @property {*} value Value.\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 {BBox} declutterBox DeclutterBox.\n * @property {import(\"../../transform.js\").Transform} canvasTransform CanvasTransform.\n */\n\n/**\n * @typedef {{0: CanvasRenderingContext2D, 1: number, 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): 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 {BBox} Declutter bbox.\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\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   */\n  constructor(resolution, pixelRatio, overlaps, instructions) {\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 {boolean}\n     */\n    this.alignFill_;\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  /**\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 textIsArray = Array.isArray(text);\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 = textIsArray\n      ? text\n      : 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.alignFill_ = /** @type {boolean} */ (fillInstruction[2]);\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 {number} contextScale Scale of the context.\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    contextScale,\n    imageOrLabel,\n    dimensions,\n    opacity,\n    fillInstruction,\n    strokeInstruction\n  ) {\n    const fillStroke = !!(fillInstruction || strokeInstruction);\n\n    const box = dimensions.declutterBox;\n    const canvas = context.canvas;\n    const strokePadding = strokeInstruction\n      ? (strokeInstruction[2] * dimensions.scale[0]) / 2\n      : 0;\n    const intersects =\n      box.minX - strokePadding <= canvas.width / contextScale &&\n      box.maxX + strokePadding >= 0 &&\n      box.minY - strokePadding <= canvas.height / contextScale &&\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} context Context.\n   */\n  fill_(context) {\n    if (this.alignFill_) {\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      context.rotate(this.viewRotation_);\n    }\n    context.fill();\n    if (this.alignFill_) {\n      context.restore();\n    }\n  }\n\n  /**\n   * @private\n   * @param {CanvasRenderingContext2D} context Context.\n   * @param {Array<*>} instruction Instruction.\n   */\n  setStrokeStyle_(context, instruction) {\n    context['strokeStyle'] =\n      /** @type {import(\"../../colorlike.js\").ColorLike} */ (instruction[1]);\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} context Context.\n   * @param {number} contextScale Scale of the context.\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} [declutterTree] Declutter tree.\n   * @return {T|undefined} Callback result.\n   * @template T\n   */\n  execute_(\n    context,\n    contextScale,\n    transform,\n    instructions,\n    snapToPixel,\n    featureCallback,\n    hitExtent,\n    declutterTree\n  ) {\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    let anchorX,\n      anchorY,\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    let lastFillInstruction = null;\n    let lastStrokeInstruction = null;\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          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          const x1 = pixelCoordinates[d];\n          const y1 = pixelCoordinates[d + 1];\n          const x2 = pixelCoordinates[d + 2];\n          const y2 = pixelCoordinates[d + 3];\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.length == 6 ? instruction[5] : undefined;\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          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          const declutterMode =\n            /** @type {\"declutter\"|\"obstacle\"|\"none\"|undefined} */ (\n              instruction[14]\n            );\n          const declutterImageWithText =\n            /** @type {import(\"../canvas.js\").DeclutterImageWithText} */ (\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, backgroundFill, backgroundStroke;\n          if (instruction.length > 17) {\n            padding = /** @type {Array<number>} */ (instruction[16]);\n            backgroundFill = /** @type {boolean} */ (instruction[17]);\n            backgroundStroke = /** @type {boolean} */ (instruction[18]);\n          } else {\n            padding = defaultPadding;\n            backgroundFill = false;\n            backgroundStroke = false;\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              backgroundFill || backgroundStroke,\n              feature\n            );\n            /** @type {ReplayImageOrLabelArgs} */\n            const args = [\n              context,\n              contextScale,\n              image,\n              dimensions,\n              opacity,\n              backgroundFill\n                ? /** @type {Array<*>} */ (lastFillInstruction)\n                : null,\n              backgroundStroke\n                ? /** @type {Array<*>} */ (lastStrokeInstruction)\n                : null,\n            ];\n            if (declutterTree) {\n              if (declutterMode === 'none') {\n                // not rendered in declutter group\n                continue;\n              } else if (declutterMode === 'obstacle') {\n                // will always be drawn, thus no collision detection, but insert as obstacle\n                declutterTree.insert(dimensions.declutterBox);\n                continue;\n              } else {\n                let imageArgs;\n                let 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;\n                    // Don't render anything for now, wait for the text.\n                    continue;\n                  }\n                  imageArgs = declutterImageWithText[index];\n                  delete declutterImageWithText[index];\n                  imageDeclutterBox = getDeclutterBox(imageArgs);\n                  if (declutterTree.collides(imageDeclutterBox)) {\n                    continue;\n                  }\n                }\n                if (declutterTree.collides(dimensions.declutterBox)) {\n                  continue;\n                }\n                if (imageArgs) {\n                  // We now have image and text for an image+text combination.\n                  declutterTree.insert(imageDeclutterBox);\n                  // Render the image before we render the text.\n                  this.replayImageOrLabel_.apply(this, imageArgs);\n                }\n                declutterTree.insert(dimensions.declutterBox);\n              }\n            }\n            this.replayImageOrLabel_.apply(this, args);\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} */ (instruction[11]);\n          textKey = /** @type {string} */ (instruction[12]);\n          const pixelRatioScale = [\n            /** @type {number} */ (instruction[13]),\n            /** @type {number} */ (instruction[13]),\n          ];\n\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            );\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                    declutterTree.collides(dimensions.declutterBox)\n                  ) {\n                    break drawChars;\n                  }\n                  replayImageOrLabelArgs.push([\n                    context,\n                    contextScale,\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                    declutterTree.collides(dimensions.declutterBox)\n                  ) {\n                    break drawChars;\n                  }\n                  replayImageOrLabelArgs.push([\n                    context,\n                    contextScale,\n                    label,\n                    dimensions,\n                    1,\n                    null,\n                    null,\n                  ]);\n                }\n              }\n              if (declutterTree) {\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(feature, currentGeometry);\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          x = pixelCoordinates[d];\n          y = pixelCoordinates[d + 1];\n          roundX = (x + 0.5) | 0;\n          roundY = (y + 0.5) | 0;\n          if (roundX !== prevX || roundY !== prevY) {\n            context.moveTo(x, y);\n            prevX = roundX;\n            prevY = roundY;\n          }\n          for (d += 2; d < dd; d += 2) {\n            x = pixelCoordinates[d];\n            y = pixelCoordinates[d + 1];\n            roundX = (x + 0.5) | 0;\n            roundY = (y + 0.5) | 0;\n            if (d == dd - 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          lastFillInstruction = instruction;\n          this.alignFill_ = instruction[2];\n\n          if (pendingFill) {\n            this.fill_(context);\n            pendingFill = 0;\n            if (pendingStroke) {\n              context.stroke();\n              pendingStroke = 0;\n            }\n          }\n\n          context.fillStyle =\n            /** @type {import(\"../../colorlike.js\").ColorLike} */ (\n              instruction[1]\n            );\n          ++i;\n          break;\n        case CanvasInstruction.SET_STROKE_STYLE:\n          lastStrokeInstruction = instruction;\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} context Context.\n   * @param {number} contextScale 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 text to integer pixels.\n   * @param {import(\"rbush\").default} [declutterTree] Declutter tree.\n   */\n  execute(\n    context,\n    contextScale,\n    transform,\n    viewRotation,\n    snapToPixel,\n    declutterTree\n  ) {\n    this.viewRotation_ = viewRotation;\n    this.execute_(\n      context,\n      contextScale,\n      transform,\n      this.instructions,\n      snapToPixel,\n      undefined,\n      undefined,\n      declutterTree\n    );\n  }\n\n  /**\n   * @param {CanvasRenderingContext2D} 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      1,\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 Executor from './Executor.js';\nimport {ascending} from '../../array.js';\nimport {buffer, createEmpty, extendCoordinate} from '../../extent.js';\nimport {\n  compose as composeTransform,\n  create as createTransform,\n} from '../../transform.js';\nimport {createCanvasContext2D} from '../../dom.js';\nimport {isEmpty} from '../../obj.js';\nimport {transform2D} from '../../geom/flat/transform.js';\n\n/**\n * @const\n * @type {Array<import(\"../canvas.js\").BuilderType>}\n */\nconst ORDER = ['Polygon', 'Circle', 'LineString', 'Image', 'Text', 'Default'];\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   */\n  constructor(\n    maxExtent,\n    resolution,\n    pixelRatio,\n    overlaps,\n    allInstructions,\n    renderBuffer\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<import(\"../canvas.js\").BuilderType, import(\"./Executor\").default>>}\n     */\n    this.executorsByZIndex_ = {};\n\n    /**\n     * @private\n     * @type {CanvasRenderingContext2D}\n     */\n    this.hitDetectionContext_ = null;\n\n    /**\n     * @private\n     * @type {import(\"../../transform.js\").Transform}\n     */\n    this.hitDetectionTransform_ = createTransform();\n\n    this.createExecutors_(allInstructions);\n  }\n\n  /**\n   * @param {CanvasRenderingContext2D} 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<import(\"../canvas.js\").BuilderType, import(\"../canvas.js\").SerializableInstructions>>} allInstructions The serializable instructions\n   */\n  createExecutors_(allInstructions) {\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        );\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    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        undefined,\n        {willReadFrequently: true}\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    /**\n     * @type {import(\"../../extent.js\").Extent}\n     */\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    let builderType;\n\n    /**\n     * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n     * @param {import(\"../../geom/SimpleGeometry.js\").default} geometry Geometry.\n     * @return {T|undefined} Callback result.\n     */\n    function featureCallback(feature, geometry) {\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            (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 = ORDER.length - 1; j >= 0; --j) {\n        builderType = ORDER[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} context Context.\n   * @param {number} contextScale 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~ORDER}\n   * @param {import(\"rbush\").default} [declutterTree] Declutter tree.\n   */\n  execute(\n    context,\n    contextScale,\n    transform,\n    viewRotation,\n    snapToPixel,\n    builderTypes,\n    declutterTree\n  ) {\n    /** @type {Array<number>} */\n    const zs = Object.keys(this.executorsByZIndex_).map(Number);\n    zs.sort(ascending);\n\n    // setup clipping so that the parts of over-simplified geometries are not\n    // visible outside the current extent when panning\n    if (this.maxExtent_) {\n      context.save();\n      this.clip(context, transform);\n    }\n\n    builderTypes = builderTypes ? builderTypes : ORDER;\n    let i, ii, j, jj, replays, replay;\n    if (declutterTree) {\n      zs.reverse();\n    }\n    for (i = 0, ii = zs.length; i < ii; ++i) {\n      const zIndexKey = zs[i].toString();\n      replays = this.executorsByZIndex_[zIndexKey];\n      for (j = 0, jj = builderTypes.length; j < jj; ++j) {\n        const builderType = builderTypes[j];\n        replay = replays[builderType];\n        if (replay !== undefined) {\n          replay.execute(\n            context,\n            contextScale,\n            transform,\n            viewRotation,\n            snapToPixel,\n            declutterTree\n          );\n        }\n      }\n    }\n\n    if (this.maxExtent_) {\n      context.restore();\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 CanvasImmediateRenderer from './Immediate.js';\nimport {Icon} from '../../style.js';\nimport {ascending} from '../../array.js';\nimport {clamp} from '../../math.js';\nimport {createCanvasContext2D} from '../../dom.js';\nimport {intersects} from '../../extent.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.\n * @param {number} resolution Resolution.\n * @param {number} rotation Rotation.\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) {\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  );\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(extent, 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\").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 CanvasBuilderGroup from '../../render/canvas/BuilderGroup.js';\nimport CanvasLayerRenderer, {canvasPool} from './Layer.js';\nimport ExecutorGroup from '../../render/canvas/ExecutorGroup.js';\nimport RenderEventType from '../../render/EventType.js';\nimport ViewHint from '../../ViewHint.js';\nimport {\n  HIT_DETECT_RESOLUTION,\n  createHitDetectionImageData,\n  hitDetect,\n} from '../../render/canvas/hitdetect.js';\nimport {\n  apply,\n  makeInverse,\n  makeScale,\n  toString as transformToString,\n} from '../../transform.js';\nimport {\n  buffer,\n  containsExtent,\n  createEmpty,\n  getWidth,\n  intersects as intersectsExtent,\n  wrapX as wrapExtentX,\n} from '../../extent.js';\nimport {createCanvasContext2D, releaseCanvas} from '../../dom.js';\nimport {\n  defaultOrder as defaultRenderOrder,\n  getTolerance as getRenderTolerance,\n  getSquaredTolerance as getSquaredRenderTolerance,\n  renderFeature,\n} from '../vector.js';\nimport {equals} from '../../array.js';\nimport {\n  fromUserExtent,\n  getTransformFromProjections,\n  getUserProjection,\n  toUserExtent,\n  toUserResolution,\n} from '../../proj.js';\nimport {getUid} from '../../util.js';\nimport {wrapX as wrapCoordinateX} from '../../coordinate.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     * @type {boolean}\n     */\n    this.animatingOrInteracting_;\n\n    /**\n     * @type {ImageData|null}\n     */\n    this.hitDetectionImageData_ = null;\n\n    /**\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\").Coordinate}\n     */\n    this.renderedCenter_ = null;\n\n    /**\n     * @private\n     * @type {import(\"../../proj/Projection\").default}\n     */\n    this.renderedProjection_ = null;\n\n    /**\n     * @private\n     * @type {function(import(\"../../Feature.js\").default, import(\"../../Feature.js\").default): number|null}\n     */\n    this.renderedRenderOrder_ = null;\n\n    /**\n     * @private\n     * @type {import(\"../../render/canvas/ExecutorGroup\").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     * @type {import(\"../../render/canvas/ExecutorGroup\").default}\n     */\n    this.declutterExecutorGroup = null;\n\n    /**\n     * Clipping to be performed by `renderFrame()`\n     * @type {boolean}\n     */\n    this.clipping = true;\n\n    /**\n     * @private\n     * @type {CanvasRenderingContext2D}\n     */\n    this.compositionContext_ = 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 {import(\"rbush\").default} [declutterTree] Declutter tree.\n   */\n  renderWorlds(executorGroup, frameState, declutterTree) {\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 pixelRatio = frameState.pixelRatio;\n    const viewHints = frameState.viewHints;\n    const snapToPixel = !(\n      viewHints[ViewHint.ANIMATING] || viewHints[ViewHint.INTERACTING]\n    );\n    const context = this.compositionContext_;\n    const width = Math.round(frameState.size[0] * pixelRatio);\n    const height = Math.round(frameState.size[1] * 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) + 1\n      : 1;\n    let world = multiWorld\n      ? Math.floor((extent[0] - projectionExtent[0]) / worldWidth)\n      : 0;\n    do {\n      const transform = this.getRenderTransform(\n        center,\n        resolution,\n        rotation,\n        pixelRatio,\n        width,\n        height,\n        world * worldWidth\n      );\n      executorGroup.execute(\n        context,\n        1,\n        transform,\n        rotation,\n        snapToPixel,\n        undefined,\n        declutterTree\n      );\n    } while (++world < endWorld);\n  }\n\n  setupCompositionContext_() {\n    if (this.opacity_ !== 1) {\n      const compositionContext = createCanvasContext2D(\n        this.context.canvas.width,\n        this.context.canvas.height,\n        canvasPool\n      );\n      this.compositionContext_ = compositionContext;\n    } else {\n      this.compositionContext_ = this.context;\n    }\n  }\n\n  releaseCompositionContext_() {\n    if (this.opacity_ !== 1) {\n      const alpha = this.context.globalAlpha;\n      this.context.globalAlpha = this.opacity_;\n      this.context.drawImage(this.compositionContext_.canvas, 0, 0);\n      this.context.globalAlpha = alpha;\n      releaseCanvas(this.compositionContext_);\n      canvasPool.push(this.compositionContext_.canvas);\n      this.compositionContext_ = 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.declutterExecutorGroup) {\n      this.setupCompositionContext_();\n      this.renderWorlds(\n        this.declutterExecutorGroup,\n        frameState,\n        frameState.declutterTree\n      );\n      this.releaseCompositionContext_();\n    }\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|null} The rendered element.\n   */\n  renderFrame(frameState, target) {\n    const pixelRatio = frameState.pixelRatio;\n    const layerState = frameState.layerStatesArray[frameState.layerIndex];\n\n    // set forward and inverse pixel transforms\n    makeScale(this.pixelTransform, 1 / pixelRatio, 1 / pixelRatio);\n    makeInverse(this.inversePixelTransform, this.pixelTransform);\n\n    const canvasTransform = transformToString(this.pixelTransform);\n\n    this.useContainer(target, canvasTransform, this.getBackground(frameState));\n    const context = this.context;\n    const canvas = context.canvas;\n\n    const replayGroup = this.replayGroup_;\n    const declutterExecutorGroup = this.declutterExecutorGroup;\n    let render =\n      (replayGroup && !replayGroup.isEmpty()) ||\n      (declutterExecutorGroup && !declutterExecutorGroup.isEmpty());\n    if (!render) {\n      const hasRenderListeners =\n        this.getLayer().hasListener(RenderEventType.PRERENDER) ||\n        this.getLayer().hasListener(RenderEventType.POSTRENDER);\n      if (!hasRenderListeners) {\n        return null;\n      }\n    }\n\n    // resize and clear\n    const width = Math.round(frameState.size[0] * pixelRatio);\n    const height = Math.round(frameState.size[1] * pixelRatio);\n    if (canvas.width != width || canvas.height != height) {\n      canvas.width = width;\n      canvas.height = height;\n      if (canvas.style.transform !== canvasTransform) {\n        canvas.style.transform = canvasTransform;\n      }\n    } else if (!this.containerReused) {\n      context.clearRect(0, 0, width, height);\n    }\n\n    this.preRender(context, frameState);\n\n    const viewState = frameState.viewState;\n    const projection = viewState.projection;\n\n    this.opacity_ = layerState.opacity;\n    this.setupCompositionContext_();\n\n    // clipped rendering if layer extent is set\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      clipped = render && !containsExtent(layerExtent, frameState.extent);\n      if (clipped) {\n        this.clipUnrotated(this.compositionContext_, frameState, layerExtent);\n      }\n    }\n\n    if (render) {\n      this.renderWorlds(replayGroup, frameState);\n    }\n\n    if (clipped) {\n      this.compositionContext_.restore();\n    }\n\n    this.releaseCompositionContext_();\n\n    this.postRender(context, frameState);\n\n    if (this.renderedRotation_ !== viewState.rotation) {\n      this.renderedRotation_ = viewState.rotation;\n      this.hitDetectionImageData_ = null;\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\").default>>} Promise\n   * that resolves with an array of features.\n   */\n  getFeatures(pixel) {\n    return new Promise((resolve) => {\n      if (!this.hitDetectionImageData_ && !this.animatingOrInteracting_) {\n        const size = [this.context.canvas.width, this.context.canvas.height];\n        apply(this.pixelTransform, size);\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\n        this.hitDetectionImageData_ = createHitDetectionImageData(\n          size,\n          transforms,\n          this.renderedFeatures_,\n          layer.getStyleFunction(),\n          extent,\n          resolution,\n          rotation\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   */\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    let result;\n    const executorGroups = [this.replayGroup_];\n    if (this.declutterExecutorGroup) {\n      executorGroups.push(this.declutterExecutorGroup);\n    }\n    executorGroups.some((executorGroup) => {\n      return (result = executorGroup.forEachFeatureAtCoordinate(\n        coordinate,\n        resolution,\n        rotation,\n        hitTolerance,\n        featureCallback,\n        executorGroup === this.declutterExecutorGroup &&\n          frameState.declutterTree\n          ? frameState.declutterTree.all().map((item) => item.value)\n          : null\n      ));\n    });\n\n    return result;\n  }\n\n  /**\n   * Perform action necessary to get the layer rendered after new fonts have loaded\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   */\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    if (\n      vectorSource.getWrapX() &&\n      projection.canWrapX() &&\n      !containsExtent(projectionExtent, frameState.extent)\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      extent[0] = projectionExtent[0] - gutter;\n      extent[2] = projectionExtent[2] + 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.renderedRevision_ == vectorLayerRevision &&\n      this.renderedRenderOrder_ == vectorLayerRenderOrder &&\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    let declutterBuilderGroup;\n    if (this.getLayer().getDeclutter()) {\n      declutterBuilderGroup = new CanvasBuilderGroup(\n        getRenderTolerance(resolution, pixelRatio),\n        extent,\n        resolution,\n        pixelRatio\n      );\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       */\n      (feature) => {\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            declutterBuilderGroup\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]);\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    );\n\n    if (declutterBuilderGroup) {\n      this.declutterExecutorGroup = new ExecutorGroup(\n        extent,\n        resolution,\n        pixelRatio,\n        vectorSource.getOverlaps(),\n        declutterBuilderGroup.finish(),\n        vectorLayer.getRenderBuffer()\n      );\n    }\n\n    this.renderedResolution_ = resolution;\n    this.renderedRevision_ = vectorLayerRevision;\n    this.renderedRenderOrder_ = vectorLayerRenderOrder;\n    this.renderedExtent_ = renderedExtent;\n    this.wrappedRenderedExtent_ = extent;\n    this.renderedCenter_ = center;\n    this.renderedProjection_ = projection;\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 {import(\"../../render/canvas/BuilderGroup.js\").default} [declutterBuilderGroup] Builder for decluttering.\n   * @return {boolean} `true` if an image is loading.\n   */\n  renderFeature(\n    feature,\n    squaredTolerance,\n    styles,\n    builderGroup,\n    transform,\n    declutterBuilderGroup\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            declutterBuilderGroup\n          ) || loading;\n      }\n    } else {\n      loading = renderFeature(\n        builderGroup,\n        feature,\n        styles,\n        squaredTolerance,\n        this.boundHandleStyleImageChange_,\n        transform,\n        declutterBuilderGroup\n      );\n    }\n    return loading;\n  }\n}\n\nexport default CanvasVectorLayerRenderer;\n","/**\n * @module ol/renderer/canvas/VectorImageLayer\n */\nimport CanvasImageLayerRenderer from './ImageLayer.js';\nimport CanvasVectorLayerRenderer from './VectorLayer.js';\nimport EventType from '../../events/EventType.js';\nimport ImageCanvas from '../../ImageCanvas.js';\nimport ImageState from '../../ImageState.js';\nimport RBush from 'rbush';\nimport ViewHint from '../../ViewHint.js';\nimport {apply, compose, create} from '../../transform.js';\nimport {fromResolutionLike} from '../../resolution.js';\nimport {getHeight, getWidth, isEmpty, scaleFromCenter} from '../../extent.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   */\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\").default>>} Promise that resolves with an array of features.\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   */\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   */\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          declutterTree: new RBush(9),\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        })\n      );\n      let emptyImage = true;\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            if (vectorRenderer.renderFrame(imageFrameState, null)) {\n              vectorRenderer.renderDeclutter(imageFrameState);\n              emptyImage = false;\n            }\n            callback();\n          }\n        }\n      );\n\n      image.addEventListener(EventType.CHANGE, () => {\n        if (image.getState() !== ImageState.LOADED) {\n          return;\n        }\n        this.image_ = emptyImage ? null : 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.image_;\n  }\n\n  /**\n   */\n  preRender() {}\n\n  /**\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   */\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/renderer/canvas/VectorTileLayer\n */\nimport CanvasBuilderGroup from '../../render/canvas/BuilderGroup.js';\nimport CanvasExecutorGroup from '../../render/canvas/ExecutorGroup.js';\nimport CanvasTileLayerRenderer from './TileLayer.js';\nimport TileState from '../../TileState.js';\nimport ViewHint from '../../ViewHint.js';\nimport {\n  HIT_DETECT_RESOLUTION,\n  createHitDetectionImageData,\n  hitDetect,\n} from '../../render/canvas/hitdetect.js';\nimport {\n  apply as applyTransform,\n  create as createTransform,\n  multiply,\n  reset as resetTransform,\n  scale,\n  scale as scaleTransform,\n  translate as translateTransform,\n} from '../../transform.js';\nimport {\n  boundingExtent,\n  buffer,\n  containsExtent,\n  equals,\n  getIntersection,\n  getTopLeft,\n  intersects,\n} from '../../extent.js';\nimport {\n  getSquaredTolerance as getSquaredRenderTolerance,\n  renderFeature,\n} from '../vector.js';\nimport {getUid} from '../../util.js';\nimport {toSize} from '../../size.js';\nimport {wrapX} from '../../coordinate.js';\n\n/**\n * @type {!Object<string, Array<import(\"../../render/canvas.js\").BuilderType>>}\n */\nconst IMAGE_REPLAYS = {\n  'image': ['Polygon', 'Circle', 'LineString', 'Image', 'Text'],\n  'hybrid': ['Polygon', 'LineString'],\n  'vector': [],\n};\n\n/**\n * @type {!Object<string, Array<import(\"../../render/canvas.js\").BuilderType>>}\n */\nconst VECTOR_REPLAYS = {\n  'hybrid': ['Image', 'Text', 'Default'],\n  'vector': ['Polygon', 'Circle', 'LineString', 'Image', 'Text', 'Default'],\n};\n\n/**\n * @classdesc\n * Canvas renderer for vector tile layers.\n * @api\n * @extends {CanvasTileLayerRenderer<import(\"../../layer/VectorTile.js\").default>}\n */\nclass CanvasVectorTileLayerRenderer extends CanvasTileLayerRenderer {\n  /**\n   * @param {import(\"../../layer/VectorTile.js\").default} layer VectorTile layer.\n   */\n  constructor(layer) {\n    super(layer);\n\n    /** @private */\n    this.boundHandleStyleImageChange_ = this.handleStyleImageChange_.bind(this);\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.renderedLayerRevision_;\n\n    /**\n     * @private\n     * @type {import(\"../../transform\").Transform}\n     */\n    this.renderedPixelToCoordinateTransform_ = null;\n\n    /**\n     * @private\n     * @type {number}\n     */\n    this.renderedRotation_;\n\n    /**\n     * @private\n     * @type {import(\"../../transform.js\").Transform}\n     */\n    this.tmpTransform_ = createTransform();\n  }\n\n  /**\n   * @param {import(\"../../VectorRenderTile.js\").default} tile Tile.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../../proj/Projection\").default} projection Projection.\n   * @return {boolean|undefined} Tile needs to be rendered.\n   */\n  prepareTile(tile, pixelRatio, projection) {\n    let render;\n    const state = tile.getState();\n    if (state === TileState.LOADED || state === TileState.ERROR) {\n      this.updateExecutorGroup_(tile, pixelRatio, projection);\n      if (this.tileImageNeedsRender_(tile)) {\n        render = true;\n      }\n    }\n    return render;\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} Tile.\n   */\n  getTile(z, x, y, frameState) {\n    const pixelRatio = frameState.pixelRatio;\n    const viewState = frameState.viewState;\n    const resolution = viewState.resolution;\n    const projection = viewState.projection;\n    const layer = this.getLayer();\n    const tile = layer.getSource().getTile(z, x, y, pixelRatio, projection);\n    const viewHints = frameState.viewHints;\n    const hifi = !(\n      viewHints[ViewHint.ANIMATING] || viewHints[ViewHint.INTERACTING]\n    );\n    if (hifi || !tile.wantedResolution) {\n      tile.wantedResolution = resolution;\n    }\n    const render = this.prepareTile(tile, pixelRatio, projection);\n    if (\n      render &&\n      (hifi || Date.now() - frameState.time < 8) &&\n      layer.getRenderMode() !== 'vector'\n    ) {\n      this.renderTileImage_(tile, frameState);\n    }\n    return super.getTile(z, x, y, frameState);\n  }\n\n  /**\n   * @param {import(\"../../VectorRenderTile.js\").default} tile Tile.\n   * @return {boolean} Tile is drawable.\n   */\n  isDrawableTile(tile) {\n    const layer = this.getLayer();\n    return (\n      super.isDrawableTile(tile) &&\n      (layer.getRenderMode() === 'vector'\n        ? getUid(layer) in tile.executorGroups\n        : tile.hasContext(layer))\n    );\n  }\n\n  /**\n   * @inheritDoc\n   */\n  getTileImage(tile) {\n    return tile.getImage(this.getLayer());\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   */\n  prepareFrame(frameState) {\n    const layerRevision = this.getLayer().getRevision();\n    if (this.renderedLayerRevision_ !== layerRevision) {\n      this.renderedLayerRevision_ = layerRevision;\n      this.renderedTiles.length = 0;\n    }\n    return super.prepareFrame(frameState);\n  }\n\n  /**\n   * @param {import(\"../../VectorRenderTile.js\").default} tile Tile.\n   * @param {number} pixelRatio Pixel ratio.\n   * @param {import(\"../../proj/Projection.js\").default} projection Projection.\n   * @private\n   */\n  updateExecutorGroup_(tile, pixelRatio, projection) {\n    const layer = /** @type {import(\"../../layer/VectorTile.js\").default} */ (\n      this.getLayer()\n    );\n    const revision = layer.getRevision();\n    const renderOrder = layer.getRenderOrder() || null;\n\n    const resolution = tile.wantedResolution;\n    const builderState = tile.getReplayState(layer);\n    if (\n      !builderState.dirty &&\n      builderState.renderedResolution === resolution &&\n      builderState.renderedRevision == revision &&\n      builderState.renderedRenderOrder == renderOrder\n    ) {\n      return;\n    }\n\n    const source = layer.getSource();\n    const declutter = layer.getDeclutter();\n    const sourceTileGrid = source.getTileGrid();\n    const tileGrid = source.getTileGridForProjection(projection);\n    const tileExtent = tileGrid.getTileCoordExtent(tile.wrappedTileCoord);\n\n    const sourceTiles = source.getSourceTiles(pixelRatio, projection, tile);\n    const layerUid = getUid(layer);\n    delete tile.hitDetectionImageData[layerUid];\n    tile.executorGroups[layerUid] = [];\n    if (declutter) {\n      tile.declutterExecutorGroups[layerUid] = [];\n    }\n    builderState.dirty = false;\n    for (let t = 0, tt = sourceTiles.length; t < tt; ++t) {\n      const sourceTile = sourceTiles[t];\n      if (sourceTile.getState() != TileState.LOADED) {\n        continue;\n      }\n      const sourceTileCoord = sourceTile.tileCoord;\n      const sourceTileExtent =\n        sourceTileGrid.getTileCoordExtent(sourceTileCoord);\n      const sharedExtent = getIntersection(tileExtent, sourceTileExtent);\n      const builderExtent = buffer(\n        sharedExtent,\n        layer.getRenderBuffer() * resolution,\n        this.tmpExtent\n      );\n      const bufferedExtent = equals(sourceTileExtent, sharedExtent)\n        ? null\n        : builderExtent;\n      const builderGroup = new CanvasBuilderGroup(\n        0,\n        builderExtent,\n        resolution,\n        pixelRatio\n      );\n      const declutterBuilderGroup = declutter\n        ? new CanvasBuilderGroup(0, sharedExtent, resolution, pixelRatio)\n        : undefined;\n      const squaredTolerance = getSquaredRenderTolerance(\n        resolution,\n        pixelRatio\n      );\n\n      /**\n       * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n       * @this {CanvasVectorTileLayerRenderer}\n       */\n      const render = function (feature) {\n        let styles;\n        const styleFunction =\n          feature.getStyleFunction() || layer.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            builderGroup,\n            declutterBuilderGroup\n          );\n          builderState.dirty = builderState.dirty || dirty;\n        }\n      };\n\n      const features = sourceTile.getFeatures();\n      if (renderOrder && renderOrder !== builderState.renderedRenderOrder) {\n        features.sort(renderOrder);\n      }\n      for (let i = 0, ii = features.length; i < ii; ++i) {\n        const feature = features[i];\n        if (\n          !bufferedExtent ||\n          intersects(bufferedExtent, feature.getGeometry().getExtent())\n        ) {\n          render.call(this, feature);\n        }\n      }\n      const executorGroupInstructions = builderGroup.finish();\n      // no need to clip when the render tile is covered by a single source tile\n      const replayExtent =\n        layer.getRenderMode() !== 'vector' &&\n        declutter &&\n        sourceTiles.length === 1\n          ? null\n          : sharedExtent;\n      const renderingReplayGroup = new CanvasExecutorGroup(\n        replayExtent,\n        resolution,\n        pixelRatio,\n        source.getOverlaps(),\n        executorGroupInstructions,\n        layer.getRenderBuffer()\n      );\n      tile.executorGroups[layerUid].push(renderingReplayGroup);\n      if (declutterBuilderGroup) {\n        const declutterExecutorGroup = new CanvasExecutorGroup(\n          null,\n          resolution,\n          pixelRatio,\n          source.getOverlaps(),\n          declutterBuilderGroup.finish(),\n          layer.getRenderBuffer()\n        );\n        tile.declutterExecutorGroups[layerUid].push(declutterExecutorGroup);\n      }\n    }\n    builderState.renderedRevision = revision;\n    builderState.renderedRenderOrder = renderOrder;\n    builderState.renderedResolution = resolution;\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   */\n  forEachFeatureAtCoordinate(\n    coordinate,\n    frameState,\n    hitTolerance,\n    callback,\n    matches\n  ) {\n    const resolution = frameState.viewState.resolution;\n    const rotation = frameState.viewState.rotation;\n    hitTolerance = hitTolerance == undefined ? 0 : hitTolerance;\n    const layer = this.getLayer();\n    const source = layer.getSource();\n    const tileGrid = source.getTileGridForProjection(\n      frameState.viewState.projection\n    );\n\n    const hitExtent = boundingExtent([coordinate]);\n    buffer(hitExtent, resolution * hitTolerance, hitExtent);\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      let key = feature.getId();\n      if (key === undefined) {\n        key = getUid(feature);\n      }\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 renderedTiles =\n      /** @type {Array<import(\"../../VectorRenderTile.js\").default>} */ (\n        this.renderedTiles\n      );\n\n    let found;\n    for (let i = 0, ii = renderedTiles.length; !found && i < ii; ++i) {\n      const tile = renderedTiles[i];\n      const tileExtent = tileGrid.getTileCoordExtent(tile.wrappedTileCoord);\n      if (!intersects(tileExtent, hitExtent)) {\n        continue;\n      }\n\n      const layerUid = getUid(layer);\n      const executorGroups = [tile.executorGroups[layerUid]];\n      const declutterExecutorGroups = tile.declutterExecutorGroups[layerUid];\n      if (declutterExecutorGroups) {\n        executorGroups.push(declutterExecutorGroups);\n      }\n      executorGroups.some((executorGroups) => {\n        const declutteredFeatures =\n          executorGroups === declutterExecutorGroups\n            ? frameState.declutterTree.all().map((item) => item.value)\n            : null;\n        for (let t = 0, tt = executorGroups.length; t < tt; ++t) {\n          const executorGroup = executorGroups[t];\n          found = executorGroup.forEachFeatureAtCoordinate(\n            coordinate,\n            resolution,\n            rotation,\n            hitTolerance,\n            featureCallback,\n            declutteredFeatures\n          );\n          if (found) {\n            return true;\n          }\n        }\n      });\n    }\n    return found;\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 an array of features.\n   */\n  getFeatures(pixel) {\n    return new Promise((resolve, reject) => {\n      const layer = this.getLayer();\n      const layerUid = getUid(layer);\n      const source = layer.getSource();\n      const projection = this.renderedProjection;\n      const projectionExtent = projection.getExtent();\n      const resolution = this.renderedResolution;\n      const tileGrid = source.getTileGridForProjection(projection);\n      const coordinate = applyTransform(\n        this.renderedPixelToCoordinateTransform_,\n        pixel.slice()\n      );\n      const tileCoord = tileGrid.getTileCoordForCoordAndResolution(\n        coordinate,\n        resolution\n      );\n      /** @type {import(\"../../VectorRenderTile.js\").default|undefined} */\n      let tile;\n      for (let i = 0, ii = this.renderedTiles.length; i < ii; ++i) {\n        if (\n          tileCoord.toString() === this.renderedTiles[i].tileCoord.toString()\n        ) {\n          tile = /** @type {import(\"../../VectorRenderTile.js\").default} */ (\n            this.renderedTiles[i]\n          );\n          if (tile.getState() === TileState.LOADED) {\n            const extent = tileGrid.getTileCoordExtent(tile.tileCoord);\n            if (\n              source.getWrapX() &&\n              projection.canWrapX() &&\n              !containsExtent(projectionExtent, extent)\n            ) {\n              wrapX(coordinate, projection);\n            }\n            break;\n          }\n          tile = undefined;\n        }\n      }\n      if (!tile || tile.loadingSourceTiles > 0) {\n        resolve([]);\n        return;\n      }\n      const extent = tileGrid.getTileCoordExtent(tile.wrappedTileCoord);\n      const corner = getTopLeft(extent);\n      const tilePixel = [\n        (coordinate[0] - corner[0]) / resolution,\n        (corner[1] - coordinate[1]) / resolution,\n      ];\n      /** @type {Array<import(\"../../Feature.js\").FeatureLike>} */\n      const features = tile\n        .getSourceTiles()\n        .reduce(function (accumulator, sourceTile) {\n          return accumulator.concat(sourceTile.getFeatures());\n        }, []);\n      /** @type {ImageData|undefined} */\n      let hitDetectionImageData = tile.hitDetectionImageData[layerUid];\n      if (!hitDetectionImageData) {\n        const tileSize = toSize(\n          tileGrid.getTileSize(\n            tileGrid.getZForResolution(resolution, source.zDirection)\n          )\n        );\n        const rotation = this.renderedRotation_;\n        const transforms = [\n          this.getRenderTransform(\n            tileGrid.getTileCoordCenter(tile.wrappedTileCoord),\n            resolution,\n            0,\n            HIT_DETECT_RESOLUTION,\n            tileSize[0] * HIT_DETECT_RESOLUTION,\n            tileSize[1] * HIT_DETECT_RESOLUTION,\n            0\n          ),\n        ];\n        hitDetectionImageData = createHitDetectionImageData(\n          tileSize,\n          transforms,\n          features,\n          layer.getStyleFunction(),\n          tileGrid.getTileCoordExtent(tile.wrappedTileCoord),\n          tile.getReplayState(layer).renderedResolution,\n          rotation\n        );\n        tile.hitDetectionImageData[layerUid] = hitDetectionImageData;\n      }\n      resolve(hitDetect(tilePixel, features, hitDetectionImageData));\n    });\n  }\n\n  /**\n   * Perform action necessary to get the layer rendered after new fonts have loaded\n   */\n  handleFontsChanged() {\n    const layer = this.getLayer();\n    if (layer.getVisible() && this.renderedLayerRevision_ !== undefined) {\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   * Render declutter items for this layer\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   */\n  renderDeclutter(frameState) {\n    const context = this.context;\n    const alpha = context.globalAlpha;\n    context.globalAlpha = this.getLayer().getOpacity();\n    const viewHints = frameState.viewHints;\n    const hifi = !(\n      viewHints[ViewHint.ANIMATING] || viewHints[ViewHint.INTERACTING]\n    );\n    const tiles =\n      /** @type {Array<import(\"../../VectorRenderTile.js\").default>} */ (\n        this.renderedTiles\n      );\n    for (let i = 0, ii = tiles.length; i < ii; ++i) {\n      const tile = tiles[i];\n      const declutterExecutorGroups =\n        tile.declutterExecutorGroups[getUid(this.getLayer())];\n      if (declutterExecutorGroups) {\n        for (let j = declutterExecutorGroups.length - 1; j >= 0; --j) {\n          declutterExecutorGroups[j].execute(\n            this.context,\n            1,\n            this.getTileRenderTransform(tile, frameState),\n            frameState.viewState.rotation,\n            hifi,\n            undefined,\n            frameState.declutterTree\n          );\n        }\n      }\n    }\n    context.globalAlpha = alpha;\n  }\n\n  getTileRenderTransform(tile, frameState) {\n    const pixelRatio = frameState.pixelRatio;\n    const viewState = frameState.viewState;\n    const center = viewState.center;\n    const resolution = viewState.resolution;\n    const rotation = viewState.rotation;\n    const size = frameState.size;\n    const width = Math.round(size[0] * pixelRatio);\n    const height = Math.round(size[1] * pixelRatio);\n\n    const source = this.getLayer().getSource();\n    const tileGrid = source.getTileGridForProjection(\n      frameState.viewState.projection\n    );\n    const tileCoord = tile.tileCoord;\n    const tileExtent = tileGrid.getTileCoordExtent(tile.wrappedTileCoord);\n    const worldOffset =\n      tileGrid.getTileCoordExtent(tileCoord, this.tmpExtent)[0] - tileExtent[0];\n    const transform = multiply(\n      scale(this.inversePixelTransform.slice(), 1 / pixelRatio, 1 / pixelRatio),\n      this.getRenderTransform(\n        center,\n        resolution,\n        rotation,\n        pixelRatio,\n        width,\n        height,\n        worldOffset\n      )\n    );\n    return transform;\n  }\n\n  /**\n   * Render the vectors for this layer.\n   * @param {CanvasRenderingContext2D} context Target context.\n   * @param {import(\"../../Map.js\").FrameState} frameState Frame state.\n   */\n  postRender(context, frameState) {\n    const viewHints = frameState.viewHints;\n    const hifi = !(\n      viewHints[ViewHint.ANIMATING] || viewHints[ViewHint.INTERACTING]\n    );\n\n    this.renderedPixelToCoordinateTransform_ =\n      frameState.pixelToCoordinateTransform.slice();\n    this.renderedRotation_ = frameState.viewState.rotation;\n\n    const layer = /** @type {import(\"../../layer/VectorTile.js\").default} */ (\n      this.getLayer()\n    );\n    const renderMode = layer.getRenderMode();\n    const alpha = context.globalAlpha;\n    context.globalAlpha = layer.getOpacity();\n    const replayTypes = VECTOR_REPLAYS[renderMode];\n    const viewState = frameState.viewState;\n    const rotation = viewState.rotation;\n    const tileSource = layer.getSource();\n    const tileGrid = tileSource.getTileGridForProjection(viewState.projection);\n    const z = tileGrid.getZForResolution(\n      viewState.resolution,\n      tileSource.zDirection\n    );\n\n    const tiles = this.renderedTiles;\n    const clips = [];\n    const clipZs = [];\n    let ready = true;\n    for (let i = tiles.length - 1; i >= 0; --i) {\n      const tile = /** @type {import(\"../../VectorRenderTile.js\").default} */ (\n        tiles[i]\n      );\n      ready = ready && !tile.getReplayState(layer).dirty;\n      const executorGroups = tile.executorGroups[getUid(layer)].filter(\n        (group) => group.hasExecutors(replayTypes)\n      );\n      if (executorGroups.length === 0) {\n        continue;\n      }\n      const transform = this.getTileRenderTransform(tile, frameState);\n      const currentZ = tile.tileCoord[0];\n      let contextSaved = false;\n      // Clip mask for regions in this tile that already filled by a higher z tile\n      const currentClip = executorGroups[0].getClipCoords(transform);\n      if (currentClip) {\n        for (let j = 0, jj = clips.length; j < jj; ++j) {\n          if (z !== currentZ && currentZ < clipZs[j]) {\n            const clip = clips[j];\n            if (\n              intersects(\n                [\n                  currentClip[0],\n                  currentClip[3],\n                  currentClip[4],\n                  currentClip[7],\n                ],\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      for (let t = 0, tt = executorGroups.length; t < tt; ++t) {\n        const executorGroup = executorGroups[t];\n        executorGroup.execute(\n          context,\n          1,\n          transform,\n          rotation,\n          hifi,\n          replayTypes\n        );\n      }\n      if (contextSaved) {\n        context.restore();\n      }\n    }\n    context.globalAlpha = alpha;\n    this.ready = ready;\n\n    super.postRender(context, frameState);\n  }\n\n  /**\n   * @param {import(\"../../Feature.js\").FeatureLike} feature Feature.\n   * @param {number} squaredTolerance Squared 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 Replay group.\n   * @param {import(\"../../render/canvas/BuilderGroup.js\").default} [declutterBuilderGroup] Builder group for decluttering.\n   * @return {boolean} `true` if an image is loading.\n   */\n  renderFeature(\n    feature,\n    squaredTolerance,\n    styles,\n    builderGroup,\n    declutterBuilderGroup\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            undefined,\n            declutterBuilderGroup\n          ) || loading;\n      }\n    } else {\n      loading = renderFeature(\n        builderGroup,\n        feature,\n        styles,\n        squaredTolerance,\n        this.boundHandleStyleImageChange_,\n        undefined,\n        declutterBuilderGroup\n      );\n    }\n    return loading;\n  }\n\n  /**\n   * @param {import(\"../../VectorRenderTile.js\").default} tile Tile.\n   * @return {boolean} A new tile image was rendered.\n   * @private\n   */\n  tileImageNeedsRender_(tile) {\n    const layer = /** @type {import(\"../../layer/VectorTile.js\").default} */ (\n      this.getLayer()\n    );\n    if (layer.getRenderMode() === 'vector') {\n      return false;\n    }\n    const replayState = tile.getReplayState(layer);\n    const revision = layer.getRevision();\n    const resolution = tile.wantedResolution;\n    return (\n      replayState.renderedTileResolution !== resolution ||\n      replayState.renderedTileRevision !== revision\n    );\n  }\n\n  /**\n   * @param {import(\"../../VectorRenderTile.js\").default} tile Tile.\n   * @param {import(\"../../Map\").FrameState} frameState Frame state.\n   * @private\n   */\n  renderTileImage_(tile, frameState) {\n    const layer = /** @type {import(\"../../layer/VectorTile.js\").default} */ (\n      this.getLayer()\n    );\n    const replayState = tile.getReplayState(layer);\n    const revision = layer.getRevision();\n    const executorGroups = tile.executorGroups[getUid(layer)];\n    replayState.renderedTileRevision = revision;\n\n    const tileCoord = tile.wrappedTileCoord;\n    const z = tileCoord[0];\n    const source = layer.getSource();\n    let pixelRatio = frameState.pixelRatio;\n    const viewState = frameState.viewState;\n    const projection = viewState.projection;\n    const tileGrid = source.getTileGridForProjection(projection);\n    const tileResolution = tileGrid.getResolution(tile.tileCoord[0]);\n    const renderPixelRatio =\n      (frameState.pixelRatio / tile.wantedResolution) * tileResolution;\n    const resolution = tileGrid.getResolution(z);\n    const context = tile.getContext(layer);\n\n    // Increase tile size when overzooming for low pixel ratio, to avoid blurry tiles\n    pixelRatio = Math.round(\n      Math.max(pixelRatio, renderPixelRatio / pixelRatio)\n    );\n    const size = source.getTilePixelSize(z, pixelRatio, projection);\n    context.canvas.width = size[0];\n    context.canvas.height = size[1];\n    const renderScale = pixelRatio / renderPixelRatio;\n    if (renderScale !== 1) {\n      const canvasTransform = resetTransform(this.tmpTransform_);\n      scaleTransform(canvasTransform, renderScale, renderScale);\n      context.setTransform.apply(context, canvasTransform);\n    }\n    const tileExtent = tileGrid.getTileCoordExtent(tileCoord, this.tmpExtent);\n    const pixelScale = renderPixelRatio / resolution;\n    const transform = resetTransform(this.tmpTransform_);\n    scaleTransform(transform, pixelScale, -pixelScale);\n    translateTransform(transform, -tileExtent[0], -tileExtent[3]);\n    for (let i = 0, ii = executorGroups.length; i < ii; ++i) {\n      const executorGroup = executorGroups[i];\n      executorGroup.execute(\n        context,\n        renderScale,\n        transform,\n        0,\n        true,\n        IMAGE_REPLAYS[layer.getRenderMode()]\n      );\n    }\n    replayState.renderedTileResolution = tile.wantedResolution;\n  }\n}\n\nexport default CanvasVectorTileLayerRenderer;\n","/**\n * @module ol/proj/proj4\n */\nimport Projection from './Projection.js';\nimport {\n  addCoordinateTransforms,\n  addEquivalentProjections,\n  addProjection,\n  createSafeCoordinateTransform,\n  get,\n} from '../proj.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 (!get(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 = get(code1);\n    for (j = 0; j < len; ++j) {\n      const code2 = projCodes[j];\n      const proj2 = get(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 {number} code The EPSG code.\n * @return {Promise<string>} The proj4 definition.\n */\nlet epsgLookup = async function (code) {\n  const response = await fetch(`https://epsg.io/${code}.proj4`);\n  if (!response.ok) {\n    throw new Error(`Unexpected response from epsg.io: ${response.status}`);\n  }\n  return response.text();\n};\n\n/**\n * Set the lookup function for getting proj4 definitions given an EPSG code.\n * By default, the {@link module:ol/proj/proj4.fromEPSGCode} function uses the\n * epsg.io website for proj4 definitions.  This can be changed by providing a\n * different lookup function.\n *\n * @param {function(number):Promise<string>} func The lookup function.\n * @api\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 */\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 epsg.io 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 {number|string} code The EPSG code (e.g. 4326 or 'EPSG:4326').\n * @return {Promise<Projection>} The projection.\n * @api\n */\nexport async function fromEPSGCode(code) {\n  if (typeof code === 'string') {\n    code = parseInt(code.split(':').pop(), 10);\n  }\n\n  const proj4 = registered;\n  if (!proj4) {\n    throw new Error('Proj4 must be registered first with register(proj4)');\n  }\n\n  const epsgCode = 'EPSG:' + code;\n  if (proj4.defs(epsgCode)) {\n    return get(epsgCode);\n  }\n\n  proj4.defs(epsgCode, await epsgLookup(code));\n  register(proj4);\n\n  return get(epsgCode);\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 */\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) => 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/layer/Vector\n */\nimport BaseVectorLayer from './BaseVector.js';\nimport CanvasVectorLayerRenderer from '../renderer/canvas/VectorLayer.js';\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} VectorSourceType\n * @extends {BaseVectorLayer<VectorSourceType, CanvasVectorLayerRenderer>}\n * @api\n */\nclass VectorLayer extends BaseVectorLayer {\n  /**\n   * @param {import(\"./BaseVector.js\").Options<VectorSourceType>} [options] Options.\n   */\n  constructor(options) {\n    super(options);\n  }\n\n  createRenderer() {\n    return new CanvasVectorLayerRenderer(this);\n  }\n}\n\nexport default VectorLayer;\n","/**\n * @module ol/geom/flat/geodesic\n */\nimport {get as getProjection, getTransform} from '../../proj.js';\nimport {squaredSegmentDistance, toDegrees, toRadians} from '../../math.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/Graticule\n */\nimport Collection from '../Collection.js';\nimport EventType from '../render/EventType.js';\nimport Feature from '../Feature.js';\nimport Fill from '../style/Fill.js';\nimport LineString from '../geom/LineString.js';\nimport Point from '../geom/Point.js';\nimport Stroke from '../style/Stroke.js';\nimport Style from '../style/Style.js';\nimport Text from '../style/Text.js';\nimport VectorLayer from './Vector.js';\nimport VectorSource from '../source/Vector.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 {clamp} from '../math.js';\nimport {degreesToStringHDMS} from '../coordinate.js';\nimport {\n  equivalent as equivalentProjection,\n  get as getProjection,\n  getTransform,\n} from '../proj.js';\nimport {getVectorContext} from '../render.js';\nimport {meridian, parallel} from '../geom/flat/geodesic.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\n * @extends {VectorLayer<import(\"../source/Vector.js\").default>}\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     */\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\").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\").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\").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/layer/Heatmap\n */\nimport BaseVector from './BaseVector.js';\nimport WebGLPointsLayerRenderer from '../renderer/webgl/PointsLayer.js';\nimport {ShaderBuilder} from '../webgl/ShaderBuilder.js';\nimport {clamp} from '../math.js';\nimport {createCanvasContext2D} from '../dom.js';\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 {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 {number} [radius=8] Radius size in pixels.\n * @property {number} [blur=15] Blur size in pixels.\n * @property {string|function(import(\"../Feature.js\").default):number} [weight='weight'] The feature\n * attribute to use for the weight 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(\"../source/Vector.js\").default} [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\n * @extends {BaseVector<import(\"../source/Vector.js\").default, WebGLPointsLayerRenderer>}\n * @api\n */\nclass Heatmap extends BaseVector {\n  /**\n   * @param {Options} [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     * @private\n     * @type {HTMLCanvasElement}\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    if (typeof weight === 'string') {\n      this.weightFunction_ = function (feature) {\n        return feature.get(weight);\n      };\n    } else {\n      this.weightFunction_ = weight;\n    }\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 {number} Blur size in pixels.\n   * @api\n   * @observable\n   */\n  getBlur() {\n    return /** @type {number} */ (this.get(Property.BLUR));\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 {number} Radius size in pixel.\n   * @api\n   * @observable\n   */\n  getRadius() {\n    return /** @type {number} */ (this.get(Property.RADIUS));\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 {number} blur Blur size in pixels.\n   * @api\n   * @observable\n   */\n  setBlur(blur) {\n    this.set(Property.BLUR, blur);\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 {number} radius Radius size in pixel.\n   * @api\n   * @observable\n   */\n  setRadius(radius) {\n    this.set(Property.RADIUS, radius);\n  }\n\n  createRenderer() {\n    const builder = new ShaderBuilder()\n      .addAttribute('float a_prop_weight')\n      .addVarying('v_prop_weight', 'float', 'a_prop_weight')\n      .addUniform('float u_size')\n      .addUniform('float u_blurSlope')\n      .setSymbolSizeExpression('vec2(u_size)')\n      .setSymbolColorExpression(\n        'vec4(smoothstep(0., 1., (1. - length(coordsPx * 2. / v_quadSizePx)) * u_blurSlope) * v_prop_weight)'\n      );\n\n    return new WebGLPointsLayerRenderer(this, {\n      className: this.getClassName(),\n      attributes: [\n        {\n          name: 'weight',\n          callback: (feature) => {\n            const weight = this.weightFunction_(feature);\n            return weight !== undefined ? clamp(weight, 0, 1) : 1;\n          },\n        },\n      ],\n      uniforms: {\n        u_size: () => {\n          return (this.get(Property.RADIUS) + this.get(Property.BLUR)) * 2;\n        },\n        u_blurSlope: () => {\n          return (\n            this.get(Property.RADIUS) / Math.max(1, this.get(Property.BLUR))\n          );\n        },\n      },\n      hitDetectionEnabled: true,\n      vertexShader: builder.getSymbolVertexShader(),\n      fragmentShader: builder.getSymbolFragmentShader(),\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  renderDeclutter() {}\n}\n\n/**\n * @param {Array<string>} colors A list of colored.\n * @return {HTMLCanvasElement} 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/layer/VectorImage\n */\nimport BaseVectorLayer from './BaseVector.js';\nimport CanvasVectorImageLayerRenderer from '../renderer/canvas/VectorImageLayer.js';\n\n/**\n * @template {import(\"../source/Vector.js\").default} 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} [declutter=false] Declutter images and text on this layer. The priority is defined\n * by the `zIndex` of the style and the render order of features. Higher z-index means higher priority.\n * Within the same z-index, a feature rendered before another has higher priority.\n * @property {import(\"../style/Style.js\").StyleLike|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 {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} VectorSourceType\n * @extends {BaseVectorLayer<VectorSourceType, CanvasVectorImageLayerRenderer>}\n * @api\n */\nclass VectorImageLayer extends BaseVectorLayer {\n  /**\n   * @param {Options<VectorSourceType>} [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  createRenderer() {\n    return new CanvasVectorImageLayerRenderer(this);\n  }\n}\n\nexport default VectorImageLayer;\n","/**\n * @module ol/layer/VectorTile\n */\nimport BaseVectorLayer from './BaseVector.js';\nimport CanvasVectorTileLayerRenderer from '../renderer/canvas/VectorTileLayer.js';\nimport TileProperty from './TileProperty.js';\nimport {assert} from '../asserts.js';\n\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"./Base\").BaseLayerObjectEventTypes|\n *     import(\"./Layer.js\").LayerEventType|'change:preload'|'change:useInterimTilesOnError', import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../render/EventType\").LayerRenderEventTypes, import(\"../render/Event\").default, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"./Base\").BaseLayerObjectEventTypes|\n *     import(\"./Layer.js\").LayerEventType|'change:preload'|'change:useInterimTilesOnError'|import(\"../render/EventType\").LayerRenderEventTypes, Return>} VectorTileLayerOnSignature\n */\n\n/**\n * @typedef {'hybrid' | 'vector'} VectorTileRenderType\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 {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 tile extent used by the\n * renderer when getting features from the vector tile for the rendering or hit-detection.\n * Recommended value: Vector tiles are usually generated with a buffer, so this value should match\n * the largest possible buffer of the used tiles. It should be at least the size of the largest\n * point symbol or line width.\n * @property {VectorTileRenderType} [renderMode='hybrid'] Render mode for vector tiles:\n *  * `'hybrid'`: Polygon and line elements are rendered as images, so pixels are scaled during zoom\n *    animations. Point symbols and texts are accurately rendered as vectors and can stay upright on\n *    rotated views.\n *  * `'vector'`: Everything is rendered as vectors. Use this mode for improved performance on vector\n *    tile layers with only a few rendered features (e.g. for highlighting a subset of features of\n *    another layer with the same source).\n * @property {import(\"../source/VectorTile.js\").default} [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} [declutter=false] Declutter images and text. Decluttering is applied to all\n * image and text styles of all Vector and VectorTile layers that have set this to `true`. The priority\n * is defined by the z-index of the layer, the `zIndex` of the style and the render order of features.\n * Higher z-index means higher priority. Within the same z-index, a feature rendered before another has\n * higher priority.\n *\n * As an optimization decluttered features from layers with the same `className` are rendered above\n * the fill and stroke styles of all of those layers regardless of z-index.  To opt out of this\n * behavior and place declutterd features with their own layer configure the layer with a `className`\n * other than `ol-layer`.\n * @property {import(\"../style/Style.js\").StyleLike|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|false} [background] Background color for the layer. If not specified, no\n * background will be rendered.\n * @property {boolean} [updateWhileAnimating=false] When set to `true`, feature batches will be\n * recreated during animations. This means that no vectors will be shown clipped, but the setting\n * will have a performance impact for large amounts of vector data. When set to `false`, batches\n * will be recreated when no animation is active.\n * @property {boolean} [updateWhileInteracting=false] When set to `true`, feature batches will be\n * recreated during interactions. See also `updateWhileAnimating`.\n * @property {number} [preload=0] Preload. Load low-resolution tiles up to `preload` levels. `0`\n * means no preloading.\n * @property {boolean} [useInterimTilesOnError=true] Use interim tiles on error.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n\n/**\n * @classdesc\n * Layer for vector tile 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 * @param {Options} [options] Options.\n * @extends {BaseVectorLayer<import(\"../source/VectorTile.js\").default, CanvasVectorTileLayerRenderer>}\n * @api\n */\nclass VectorTileLayer extends BaseVectorLayer {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    const baseOptions = /** @type {Object} */ (Object.assign({}, options));\n    delete baseOptions.preload;\n    delete baseOptions.useInterimTilesOnError;\n\n    super(\n      /** @type {import(\"./BaseVector.js\").Options<import(\"../source/VectorTile.js\").default>} */ (\n        baseOptions\n      )\n    );\n\n    /***\n     * @type {VectorTileLayerOnSignature<import(\"../events\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {VectorTileLayerOnSignature<import(\"../events\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {VectorTileLayerOnSignature<void>}\n     */\n    this.un;\n\n    const renderMode = options.renderMode || 'hybrid';\n    assert(\n      renderMode == 'hybrid' || renderMode == 'vector',\n      \"`renderMode` must be `'hybrid'` or `'vector'`\"\n    );\n\n    /**\n     * @private\n     * @type {VectorTileRenderType}\n     */\n    this.renderMode_ = renderMode;\n\n    this.setPreload(options.preload ? options.preload : 0);\n    this.setUseInterimTilesOnError(\n      options.useInterimTilesOnError !== undefined\n        ? options.useInterimTilesOnError\n        : true\n    );\n\n    /**\n     * @return {import(\"./Base.js\").BackgroundColor} Background color.\n     * @function\n     * @api\n     */\n    this.getBackground;\n\n    /**\n     * @param {import(\"./Base.js\").BackgroundColor} background Background color.\n     * @function\n     * @api\n     */\n    this.setBackground;\n  }\n\n  createRenderer() {\n    return new CanvasVectorTileLayerRenderer(this);\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\").FeatureLike>>} Promise that resolves with an array of features.\n   * @api\n   */\n  getFeatures(pixel) {\n    return super.getFeatures(pixel);\n  }\n\n  /**\n   * @return {VectorTileRenderType} The render mode.\n   */\n  getRenderMode() {\n    return this.renderMode_;\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   * 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   * 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   * 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\nexport default VectorTileLayer;\n","/**\n * @module ol/layer/WebGLPoints\n */\nimport Layer from './Layer.js';\nimport WebGLPointsLayerRenderer from '../renderer/webgl/PointsLayer.js';\nimport {parseLiteralStyle} from '../webgl/styleparser.js';\n\n/**\n * @template {import(\"../source/Vector.js\").default} VectorSourceType\n * @typedef {Object} Options\n * @property {import('../style/webgl.js').WebGLStyle} style Literal style to apply to the layer features.\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 {VectorSourceType} [source] Point source.\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 {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n\n/**\n * @classdesc\n * Layer optimized for rendering large point datasets. Takes a `style` property which\n * is a serializable JSON object describing how the layer should be rendered.\n *\n * Here are a few samples of literal style objects:\n * ```js\n * const style = {\n *   'circle-radius': 8,\n *   'circle-fill-color': '#33AAFF',\n *   'circle-opacity': 0.9\n * }\n * ```\n *\n * ```js\n * const style = {\n *   'icon-src': '../static/exclamation-mark.png',\n *   'icon-offset': [0, 12],\n *   'icon-width': 4,\n *   'icon-height': 8\n * }\n * ```\n *\n * **Important: a `WebGLPoints` layer must be manually disposed when removed, otherwise the underlying WebGL context\n * will not be garbage collected.**\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} VectorSourceType\n * @extends {Layer<VectorSourceType, WebGLPointsLayerRenderer>}\n * @fires import(\"../render/Event.js\").RenderEvent\n */\nclass WebGLPointsLayer extends Layer {\n  /**\n   * @param {Options<VectorSourceType>} options Options.\n   */\n  constructor(options) {\n    const baseOptions = Object.assign({}, options);\n\n    super(baseOptions);\n\n    /**\n     * @private\n     * @type {import('../webgl/styleparser.js').StyleParseResult}\n     */\n    this.parseResult_ = parseLiteralStyle(options.style);\n\n    /**\n     * @type {Object<string, (string|number|Array<number>|boolean)>}\n     * @private\n     */\n    this.styleVariables_ = options.style.variables || {};\n\n    /**\n     * @private\n     * @type {boolean}\n     */\n    this.hitDetectionDisabled_ = !!options.disableHitDetection;\n  }\n\n  createRenderer() {\n    const attributes = Object.keys(this.parseResult_.attributes).map(\n      (name) => ({\n        name,\n        ...this.parseResult_.attributes[name],\n      })\n    );\n    return new WebGLPointsLayerRenderer(this, {\n      vertexShader: this.parseResult_.builder.getSymbolVertexShader(),\n      fragmentShader: this.parseResult_.builder.getSymbolFragmentShader(),\n      hitDetectionEnabled: !this.hitDetectionDisabled_,\n      uniforms: this.parseResult_.uniforms,\n      attributes:\n        /** @type {Array<import('../renderer/webgl/PointsLayer.js').CustomAttribute>} */ (\n          attributes\n        ),\n    });\n  }\n\n  /**\n   * Update any variables used by the layer style and trigger a re-render.\n   * @param {Object<string, number>} variables Variables to update.\n   */\n  updateStyleVariables(variables) {\n    Object.assign(this.styleVariables_, variables);\n    this.changed();\n  }\n}\n\nexport default WebGLPointsLayer;\n","/**\n * @module ol/layer/WebGLTile\n */\nimport BaseTileLayer from './BaseTile.js';\nimport LayerProperty from '../layer/Property.js';\nimport WebGLTileLayerRenderer, {\n  Attributes,\n  Uniforms,\n} from '../renderer/webgl/TileLayer.js';\nimport {ColorType, NumberType} from '../expr/expression.js';\nimport {\n  PALETTE_TEXTURE_ARRAY,\n  getStringNumberEquivalent,\n  newCompilationContext,\n  uniformNameForVariable,\n} from '../expr/gpu.js';\nimport {expressionToGlsl} from '../webgl/styleparser.js';\n\n/**\n * @typedef {import(\"../source/DataTile.js\").default|import(\"../source/TileImage.js\").default} SourceType\n */\n\n/**\n * @typedef {Object} Style\n * Translates tile data to rendered pixels.\n *\n * @property {Object<string, (string|number)>} [variables] Style variables.  Each variable must hold a number or string.  These\n * variables can be used in the `color`, `brightness`, `contrast`, `exposure`, `saturation` and `gamma`\n * {@link import(\"../expr/expression.js\").ExpressionValue expressions}, using the `['var', 'varName']` operator.\n * To update style variables, use the {@link import(\"./WebGLTile.js\").default#updateStyleVariables} method.\n * @property {import(\"../expr/expression.js\").ExpressionValue} [color] An expression applied to color values.\n * @property {import(\"../expr/expression.js\").ExpressionValue} [brightness=0] Value used to decrease or increase\n * the layer brightness.  Values range from -1 to 1.\n * @property {import(\"../expr/expression.js\").ExpressionValue} [contrast=0] Value used to decrease or increase\n * the layer contrast.  Values range from -1 to 1.\n * @property {import(\"../expr/expression.js\").ExpressionValue} [exposure=0] Value used to decrease or increase\n * the layer exposure.  Values range from -1 to 1.\n * @property {import(\"../expr/expression.js\").ExpressionValue} [saturation=0] Value used to decrease or increase\n * the layer saturation.  Values range from -1 to 1.\n * @property {import(\"../expr/expression.js\").ExpressionValue} [gamma=1] Apply a gamma correction to the layer.\n * Values range from 0 to infinity.\n */\n\n/**\n * @typedef {Object} Options\n * @property {Style} [style] Style to apply to the layer.\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 {SourceType} [source] Source for this layer.\n * @property {Array<SourceType>|function(import(\"../extent.js\").Extent, number):Array<SourceType>} [sources] Array\n * of sources for this layer. Takes precedence over `source`. Can either be an array of sources, or a function that\n * expects an extent and a resolution (in view projection units per pixel) and returns an array of sources. See\n * {@link module:ol/source.sourcesFromTileGrid} for a helper function to generate sources that are organized in a\n * pyramid following the same pattern as a tile grid. **Note:** All sources must have the same band count and content.\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 module:ol/Map~Map#addLayer}.\n * @property {boolean} [useInterimTilesOnError=true] Use interim tiles on error.\n * @property {number} [cacheSize=512] The internal texture cache size.  This needs to be large enough to render\n * two zoom levels worth of tiles.\n * @property {Object<string, *>} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n\n/**\n * @typedef {Object} ParsedStyle\n * @property {string} vertexShader The vertex shader.\n * @property {string} fragmentShader The fragment shader.\n * @property {Object<string,import(\"../webgl/Helper.js\").UniformValue>} uniforms Uniform definitions.\n * @property {Array<import(\"../webgl/PaletteTexture.js\").default>} paletteTextures Palette textures.\n */\n\n/**\n * @param {Style} style The layer style.\n * @param {number} [bandCount] The number of bands.\n * @return {ParsedStyle} Shaders and uniforms generated from the style.\n */\nfunction parseStyle(style, bandCount) {\n  const vertexShader = `\n    attribute vec2 ${Attributes.TEXTURE_COORD};\n    uniform mat4 ${Uniforms.TILE_TRANSFORM};\n    uniform float ${Uniforms.TEXTURE_PIXEL_WIDTH};\n    uniform float ${Uniforms.TEXTURE_PIXEL_HEIGHT};\n    uniform float ${Uniforms.TEXTURE_RESOLUTION};\n    uniform float ${Uniforms.TEXTURE_ORIGIN_X};\n    uniform float ${Uniforms.TEXTURE_ORIGIN_Y};\n    uniform float ${Uniforms.DEPTH};\n\n    varying vec2 v_textureCoord;\n    varying vec2 v_mapCoord;\n\n    void main() {\n      v_textureCoord = ${Attributes.TEXTURE_COORD};\n      v_mapCoord = vec2(\n        ${Uniforms.TEXTURE_ORIGIN_X} + ${Uniforms.TEXTURE_RESOLUTION} * ${Uniforms.TEXTURE_PIXEL_WIDTH} * v_textureCoord[0],\n        ${Uniforms.TEXTURE_ORIGIN_Y} - ${Uniforms.TEXTURE_RESOLUTION} * ${Uniforms.TEXTURE_PIXEL_HEIGHT} * v_textureCoord[1]\n      );\n      gl_Position = ${Uniforms.TILE_TRANSFORM} * vec4(${Attributes.TEXTURE_COORD}, ${Uniforms.DEPTH}, 1.0);\n    }\n  `;\n\n  /**\n   * @type {import(\"../expr/gpu.js\").CompilationContext}\n   */\n  const context = {\n    ...newCompilationContext(),\n    inFragmentShader: true,\n    bandCount: bandCount,\n    style: style,\n  };\n\n  const pipeline = [];\n\n  if (style.color !== undefined) {\n    const color = expressionToGlsl(context, style.color, ColorType);\n    pipeline.push(`color = ${color};`);\n  }\n\n  if (style.contrast !== undefined) {\n    const contrast = expressionToGlsl(context, style.contrast, NumberType);\n    pipeline.push(\n      `color.rgb = clamp((${contrast} + 1.0) * color.rgb - (${contrast} / 2.0), vec3(0.0, 0.0, 0.0), vec3(1.0, 1.0, 1.0));`\n    );\n  }\n\n  if (style.exposure !== undefined) {\n    const exposure = expressionToGlsl(context, style.exposure, NumberType);\n    pipeline.push(\n      `color.rgb = clamp((${exposure} + 1.0) * color.rgb, vec3(0.0, 0.0, 0.0), vec3(1.0, 1.0, 1.0));`\n    );\n  }\n\n  if (style.saturation !== undefined) {\n    const saturation = expressionToGlsl(context, style.saturation, NumberType);\n    pipeline.push(`\n      float saturation = ${saturation} + 1.0;\n      float sr = (1.0 - saturation) * 0.2126;\n      float sg = (1.0 - saturation) * 0.7152;\n      float sb = (1.0 - saturation) * 0.0722;\n      mat3 saturationMatrix = mat3(\n        sr + saturation, sr, sr,\n        sg, sg + saturation, sg,\n        sb, sb, sb + saturation\n      );\n      color.rgb = clamp(saturationMatrix * color.rgb, vec3(0.0, 0.0, 0.0), vec3(1.0, 1.0, 1.0));\n    `);\n  }\n\n  if (style.gamma !== undefined) {\n    const gamma = expressionToGlsl(context, style.gamma, NumberType);\n    pipeline.push(`color.rgb = pow(color.rgb, vec3(1.0 / ${gamma}));`);\n  }\n\n  if (style.brightness !== undefined) {\n    const brightness = expressionToGlsl(context, style.brightness, NumberType);\n    pipeline.push(\n      `color.rgb = clamp(color.rgb + ${brightness}, vec3(0.0, 0.0, 0.0), vec3(1.0, 1.0, 1.0));`\n    );\n  }\n\n  /** @type {Object<string,import(\"../webgl/Helper\").UniformValue>} */\n  const uniforms = {};\n\n  const numVariables = Object.keys(context.variables).length;\n  if (numVariables > 1 && !style.variables) {\n    throw new Error(\n      `Missing variables in style (expected ${context.variables})`\n    );\n  }\n\n  for (let i = 0; i < numVariables; ++i) {\n    const variable = context.variables[Object.keys(context.variables)[i]];\n    if (!(variable.name in style.variables)) {\n      throw new Error(`Missing '${variable.name}' in style variables`);\n    }\n    const uniformName = uniformNameForVariable(variable.name);\n    uniforms[uniformName] = function () {\n      let value = style.variables[variable.name];\n      if (typeof value === 'string') {\n        value = getStringNumberEquivalent(value);\n      }\n      return value !== undefined ? value : -9999999; // to avoid matching with the first string literal\n    };\n  }\n\n  const uniformDeclarations = Object.keys(uniforms).map(function (name) {\n    return `uniform float ${name};`;\n  });\n\n  const textureCount = Math.ceil(bandCount / 4);\n  uniformDeclarations.push(\n    `uniform sampler2D ${Uniforms.TILE_TEXTURE_ARRAY}[${textureCount}];`\n  );\n\n  if (context.paletteTextures) {\n    uniformDeclarations.push(\n      `uniform sampler2D ${PALETTE_TEXTURE_ARRAY}[${context.paletteTextures.length}];`\n    );\n  }\n\n  const functionDefintions = Object.keys(context.functions).map(function (\n    name\n  ) {\n    return context.functions[name];\n  });\n\n  const fragmentShader = `\n    #ifdef GL_FRAGMENT_PRECISION_HIGH\n    precision highp float;\n    #else\n    precision mediump float;\n    #endif\n\n    varying vec2 v_textureCoord;\n    varying vec2 v_mapCoord;\n    uniform vec4 ${Uniforms.RENDER_EXTENT};\n    uniform float ${Uniforms.TRANSITION_ALPHA};\n    uniform float ${Uniforms.TEXTURE_PIXEL_WIDTH};\n    uniform float ${Uniforms.TEXTURE_PIXEL_HEIGHT};\n    uniform float ${Uniforms.RESOLUTION};\n    uniform float ${Uniforms.ZOOM};\n\n    ${uniformDeclarations.join('\\n')}\n\n    ${functionDefintions.join('\\n')}\n\n    void main() {\n      if (\n        v_mapCoord[0] < ${Uniforms.RENDER_EXTENT}[0] ||\n        v_mapCoord[1] < ${Uniforms.RENDER_EXTENT}[1] ||\n        v_mapCoord[0] > ${Uniforms.RENDER_EXTENT}[2] ||\n        v_mapCoord[1] > ${Uniforms.RENDER_EXTENT}[3]\n      ) {\n        discard;\n      }\n\n      vec4 color = texture2D(${\n        Uniforms.TILE_TEXTURE_ARRAY\n      }[0],  v_textureCoord);\n\n      ${pipeline.join('\\n')}\n\n      gl_FragColor = color;\n      gl_FragColor.rgb *= gl_FragColor.a;\n      gl_FragColor *= ${Uniforms.TRANSITION_ALPHA};\n    }`;\n\n  return {\n    vertexShader: vertexShader,\n    fragmentShader: fragmentShader,\n    uniforms: uniforms,\n    paletteTextures: context.paletteTextures,\n  };\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 * @extends BaseTileLayer<SourceType, WebGLTileLayerRenderer>\n * @fires import(\"../render/Event.js\").RenderEvent\n * @api\n */\nclass WebGLTileLayer extends BaseTileLayer {\n  /**\n   * @param {Options} options Tile layer options.\n   */\n  constructor(options) {\n    options = options ? Object.assign({}, options) : {};\n\n    const style = options.style || {};\n    delete options.style;\n\n    const cacheSize = options.cacheSize;\n    delete options.cacheSize;\n\n    super(options);\n\n    /**\n     * @type {Array<SourceType>|function(import(\"../extent.js\").Extent, number):Array<SourceType>}\n     * @private\n     */\n    this.sources_ = options.sources;\n\n    /**\n     * @type {SourceType|null}\n     * @private\n     */\n    this.renderedSource_ = null;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.renderedResolution_ = NaN;\n\n    /**\n     * @type {Style}\n     * @private\n     */\n    this.style_ = style;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.cacheSize_ = cacheSize;\n\n    /**\n     * @type {Object<string, (string|number)>}\n     * @private\n     */\n    this.styleVariables_ = this.style_.variables || {};\n\n    this.addChangeListener(LayerProperty.SOURCE, this.handleSourceUpdate_);\n  }\n\n  /**\n   * Gets the sources for this layer, for a given extent and resolution.\n   * @param {import(\"../extent.js\").Extent} extent Extent.\n   * @param {number} resolution Resolution.\n   * @return {Array<SourceType>} Sources.\n   */\n  getSources(extent, resolution) {\n    const source = this.getSource();\n    return this.sources_\n      ? typeof this.sources_ === 'function'\n        ? this.sources_(extent, resolution)\n        : this.sources_\n      : source\n      ? [source]\n      : [];\n  }\n\n  /**\n   * @return {SourceType} The source being rendered.\n   */\n  getRenderSource() {\n    return this.renderedSource_ || this.getSource();\n  }\n\n  /**\n   * @return {import(\"../source/Source.js\").State} Source state.\n   */\n  getSourceState() {\n    const source = this.getRenderSource();\n    return source ? source.getState() : 'undefined';\n  }\n\n  /**\n   * @private\n   */\n  handleSourceUpdate_() {\n    if (this.hasRenderer()) {\n      this.getRenderer().clearCache();\n    }\n    if (this.getSource()) {\n      this.setStyle(this.style_);\n    }\n  }\n\n  /**\n   * @private\n   * @return {number} The number of source bands.\n   */\n  getSourceBandCount_() {\n    const max = Number.MAX_SAFE_INTEGER;\n    const sources = this.getSources([-max, -max, max, max], max);\n    return sources && sources.length && 'bandCount' in sources[0]\n      ? sources[0].bandCount\n      : 4;\n  }\n\n  createRenderer() {\n    const parsedStyle = parseStyle(this.style_, this.getSourceBandCount_());\n\n    return new WebGLTileLayerRenderer(this, {\n      vertexShader: parsedStyle.vertexShader,\n      fragmentShader: parsedStyle.fragmentShader,\n      uniforms: parsedStyle.uniforms,\n      cacheSize: this.cacheSize_,\n      paletteTextures: parsedStyle.paletteTextures,\n    });\n  }\n\n  /**\n   * @param {import(\"../Map\").FrameState} frameState Frame state.\n   * @param {Array<SourceType>} sources Sources.\n   * @return {HTMLElement} Canvas.\n   */\n  renderSources(frameState, sources) {\n    const layerRenderer = this.getRenderer();\n    let canvas;\n    for (let i = 0, ii = sources.length; i < ii; ++i) {\n      this.renderedSource_ = sources[i];\n      if (layerRenderer.prepareFrame(frameState)) {\n        canvas = layerRenderer.renderFrame(frameState);\n      }\n    }\n    return canvas;\n  }\n\n  /**\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} The rendered element.\n   */\n  render(frameState, target) {\n    this.rendered = true;\n    const viewState = frameState.viewState;\n    const sources = this.getSources(frameState.extent, viewState.resolution);\n    let ready = true;\n    for (let i = 0, ii = sources.length; i < ii; ++i) {\n      const source = sources[i];\n      const sourceState = source.getState();\n      if (sourceState == 'loading') {\n        const onChange = () => {\n          if (source.getState() == 'ready') {\n            source.removeEventListener('change', onChange);\n            this.changed();\n          }\n        };\n        source.addEventListener('change', onChange);\n      }\n      ready = ready && sourceState == 'ready';\n    }\n    const canvas = this.renderSources(frameState, sources);\n    if (this.getRenderer().renderComplete && ready) {\n      // Fully rendered, done.\n      this.renderedResolution_ = viewState.resolution;\n      return canvas;\n    }\n    // Render sources from previously fully rendered frames\n    if (this.renderedResolution_ > 0.5 * viewState.resolution) {\n      const altSources = this.getSources(\n        frameState.extent,\n        this.renderedResolution_\n      ).filter((source) => !sources.includes(source));\n      if (altSources.length > 0) {\n        return this.renderSources(frameState, altSources);\n      }\n    }\n    return canvas;\n  }\n\n  /**\n   * Update the layer style.  The `updateStyleVariables` function is a more efficient\n   * way to update layer rendering.  In cases where the whole style needs to be updated,\n   * this method may be called instead.  Note that calling this method will also replace\n   * any previously set variables, so the new style also needs to include new variables,\n   * if needed.\n   * @param {Style} style The new style.\n   */\n  setStyle(style) {\n    this.styleVariables_ = style.variables || {};\n    this.style_ = style;\n    const parsedStyle = parseStyle(this.style_, this.getSourceBandCount_());\n    const renderer = this.getRenderer();\n    renderer.reset({\n      vertexShader: parsedStyle.vertexShader,\n      fragmentShader: parsedStyle.fragmentShader,\n      uniforms: parsedStyle.uniforms,\n      paletteTextures: parsedStyle.paletteTextures,\n    });\n    this.changed();\n  }\n\n  /**\n   * Update any variables used by the layer style and trigger a re-render.\n   * @param {Object<string, number>} variables Variables to update.\n   * @api\n   */\n  updateStyleVariables(variables) {\n    Object.assign(this.styleVariables_, variables);\n    this.changed();\n  }\n}\n\n/**\n * Clean up underlying WebGL resources.\n * @function\n * @api\n */\nWebGLTileLayer.prototype.dispose;\n\nexport default WebGLTileLayer;\n","/**\n * @module ol/interaction/DblClickDragZoom\n */\nimport Interaction from './Interaction.js';\nimport MapBrowserEventType from '../MapBrowserEventType.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 {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} mapBrowserEvent Map browser event.\n   * @return {boolean} `false` to stop event propagation.\n   * @api\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} mapBrowserEvent Event.\n   */\n  handleDragEvent(mapBrowserEvent) {\n    let scaleDelta = 1.0;\n\n    const touch0 = this.targetPointers[0];\n    const touch1 = this.down_.originalEvent;\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} 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;\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} 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/DragAndDrop\n */\n// FIXME should handle all geo-referenced data, not just vector data\n\nimport Event from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport Interaction from './Interaction.js';\nimport {TRUE} from '../functions.js';\nimport {get as getProjection, getUserProjection} from '../proj.js';\nimport {listen, unlistenByKey} from '../events.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\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types|\n *     'change:active', import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").OnSignature<'addfeatures', DragAndDropEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {DragAndDropOnSignature<import(\"../events\").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   */\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   */\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 (e) {\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/interaction/DragRotateAndZoom\n */\nimport PointerInteraction from './Pointer.js';\nimport {mouseOnly, shiftKeyOnly} from '../events/condition.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes an {@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   */\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   */\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   */\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/interaction/Draw\n */\nimport Circle from '../geom/Circle.js';\nimport Event from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport Feature from '../Feature.js';\nimport GeometryCollection from '../geom/GeometryCollection.js';\nimport InteractionProperty from './Property.js';\nimport LineString from '../geom/LineString.js';\nimport MapBrowserEvent from '../MapBrowserEvent.js';\nimport MapBrowserEventType from '../MapBrowserEventType.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 PointerInteraction from './Pointer.js';\nimport Polygon, {fromCircle, makeRegular} from '../geom/Polygon.js';\nimport VectorLayer from '../layer/Vector.js';\nimport VectorSource from '../source/Vector.js';\nimport {FALSE, TRUE} from '../functions.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 {clamp, squaredDistance, toFixed} from '../math.js';\nimport {createEditingStyle} from '../style/Style.js';\nimport {\n  distance,\n  squaredDistance as squaredCoordinateDistance,\n} from '../coordinate.js';\nimport {fromUserCoordinate, getUserProjection} from '../proj.js';\nimport {getStrideForLayout} from '../geom/SimpleGeometry.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 an {@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 an {@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 an {@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 * Coordinate type when drawing lines.\n * @typedef {Array<import(\"../coordinate.js\").Coordinate>} 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/**\n * @typedef {Object} TraceState\n * @property {boolean} active Tracing active.\n * @property {import(\"../pixel.js\").Pixel} [startPx] The initially clicked pixel location.\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} 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 * 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 * @param {import(\"../coordinate.js\").Coordinate} coordinate The coordinate.\n * @param {Array<Feature>} features The candidate features.\n * @return {Array<TraceTarget>} The trace targets.\n */\nfunction 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} 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 * @param {LineCoordType} coordinates The ring coordinates.\n * @param {number} index The index.  May be wrapped.\n * @return {import(\"../coordinate.js\").Coordinate} The coordinate.\n */\nfunction 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 * 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 * @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 * @typedef {Object} TraceTargetUpdateInfo\n * @property {number} index The new target index.\n * @property {number} endIndex The new segment end index.\n */\n\n/**\n * @type {TraceTargetUpdateInfo}\n */\nconst sharedUpdateInfo = {index: -1, endIndex: NaN};\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 */\nfunction getTraceTargetUpdate(coordinate, traceState, map, snapTolerance) {\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    if (distance(pixel, traceState.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  return sharedUpdateInfo;\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 * @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 */\nfunction 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/**\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 */\nfunction 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 * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types|\n *     'change:active', import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").OnSignature<'drawabort'|'drawend'|'drawstart', DrawEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {DrawOnSignature<import(\"../events\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {DrawOnSignature<void>}\n     */\n    this.un;\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     * 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 = function (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 = function (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   */\n  setMap(map) {\n    super.setMap(map);\n    this.updateState_();\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   * Handles the {@link module:ol/MapBrowserEvent~MapBrowserEvent map browser event} and may actually draw or finish the drawing.\n   * @param {import(\"../MapBrowserEvent.js\").default} event Map browser event.\n   * @return {boolean} `false` to stop event propagation.\n   * @api\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} event Event.\n   * @return {boolean} If the event was consumed.\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        startPx: event.pixel.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      if (distance(traceState.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 pointer up events.\n   * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n   * @return {boolean} If the event was consumed.\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      this.toggleTraceState_(event);\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\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} 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\").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   * @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      this.finishDrawing();\n    }\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   * @api\n   */\n  finishDrawing() {\n    const sketchFeature = this.abortDrawing_();\n    if (!sketchFeature) {\n      return;\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  }\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.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 Event from '../events/Event.js';\nimport Feature from '../Feature.js';\nimport MapBrowserEventType from '../MapBrowserEventType.js';\nimport Point from '../geom/Point.js';\nimport PointerInteraction from './Pointer.js';\nimport VectorLayer from '../layer/Vector.js';\nimport VectorSource from '../source/Vector.js';\nimport {always} from '../events/condition.js';\nimport {boundingExtent, getArea} from '../extent.js';\nimport {\n  closestOnSegment,\n  distance as coordinateDistance,\n  squaredDistance as squaredCoordinateDistance,\n  squaredDistanceToSegment,\n} from '../coordinate.js';\nimport {createEditingStyle} from '../style/Style.js';\nimport {fromExtent as polygonFromExtent} from '../geom/Polygon.js';\nimport {toUserExtent} from '../proj.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes an {@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(\"../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 * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types|\n *     'change:active', import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").OnSignature<'extentchanged', ExtentEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").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 * This interaction is only supported for mouse devices.\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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {ExtentOnSignature<import(\"../events\").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     * 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 {function (import(\"../coordinate.js\").Coordinate): import(\"../extent.js\").Extent|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   * @private\n   */\n  handlePointerMove_(mapBrowserEvent) {\n    const pixel = mapBrowserEvent.pixel;\n    const map = mapBrowserEvent.map;\n\n    let vertex = this.snapToVertex_(pixel, map);\n    if (!vertex) {\n      vertex = map.getCoordinateFromPixelInternal(pixel);\n    }\n    this.createOrUpdatePointerFeature_(vertex);\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   * @return {Feature} vertex as feature\n   * @private\n   */\n  createOrUpdatePointerFeature_(vertex) {\n    let vertexFeature = this.vertexFeature_;\n    if (!vertexFeature) {\n      vertexFeature = new Feature(new Point(vertex));\n      this.vertexFeature_ = vertexFeature;\n      this.vertexOverlay_.getSource().addFeature(vertexFeature);\n    } else {\n      const geometry = vertexFeature.getGeometry();\n      geometry.setCoordinates(vertex);\n    }\n    return vertexFeature;\n  }\n\n  /**\n   * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n   * @return {boolean} `false` to stop event propagation.\n   */\n  handleEvent(mapBrowserEvent) {\n    if (!mapBrowserEvent.originalEvent || !this.condition_(mapBrowserEvent)) {\n      return true;\n    }\n    //display pointer (if not dragging)\n    if (\n      mapBrowserEvent.type == MapBrowserEventType.POINTERMOVE &&\n      !this.handlingDownUpSequence\n    ) {\n      this.handlePointerMove_(mapBrowserEvent);\n    }\n    //call pointer to determine up/down/drag\n    super.handleEvent(mapBrowserEvent);\n    //return false to stop propagation\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   */\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\n    } else {\n      vertex = map.getCoordinateFromPixelInternal(pixel);\n      this.setExtent([vertex[0], vertex[1], vertex[0], vertex[1]]);\n      this.pointerHandler_ = getPointHandler(vertex);\n    }\n    return true; //event handled; start downup sequence\n  }\n\n  /**\n   * Handle pointer drag events.\n   * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n   */\n  handleDragEvent(mapBrowserEvent) {\n    if (this.pointerHandler_) {\n      const pixelCoordinate = mapBrowserEvent.coordinate;\n      this.setExtent(this.pointerHandler_(pixelCoordinate));\n      this.createOrUpdatePointerFeature_(pixelCoordinate);\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   */\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   */\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   */\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 {function (import(\"../coordinate.js\").Coordinate): import(\"../extent.js\").Extent|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 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 EventType from '../events/EventType.js';\nimport Interaction from './Interaction.js';\nimport MapEventType from '../MapEventType.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport {toFixed} from '../math.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    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   */\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) {\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) {\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 Event from '../events/Event.js';\nimport EventType from '../events/EventType.js';\nimport Feature from '../Feature.js';\nimport MapBrowserEventType from '../MapBrowserEventType.js';\nimport Point from '../geom/Point.js';\nimport PointerInteraction from './Pointer.js';\nimport RBush from '../structs/RBush.js';\nimport VectorEventType from '../source/VectorEventType.js';\nimport VectorLayer from '../layer/Vector.js';\nimport VectorSource from '../source/Vector.js';\nimport {\n  altKeyOnly,\n  always,\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 {\n  closestOnSegment,\n  distance as coordinateDistance,\n  equals as coordinatesEqual,\n  squaredDistance as squaredCoordinateDistance,\n  squaredDistanceToSegment,\n} from '../coordinate.js';\nimport {createEditingStyle} from '../style/Style.js';\nimport {equals} from '../array.js';\nimport {fromCircle} from '../geom/Polygon.js';\nimport {\n  fromUserCoordinate,\n  fromUserExtent,\n  getUserProjection,\n  toUserCoordinate,\n  toUserExtent,\n} from '../proj.js';\nimport {getUid} from '../util.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 * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes an {@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 an {@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 * @property {import(\"../events/condition.js\").Condition} [insertVertexCondition] A\n * function that takes an {@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 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\").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 {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 */\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\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types|\n *     'change:active', import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").OnSignature<'modifyend'|'modifystart', ModifyEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").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    /***\n     * @type {ModifyOnSignature<import(\"../events\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {ModifyOnSignature<import(\"../events\").EventsKey>}\n     */\n    this.once;\n\n    /***\n     * @type {ModifyOnSignature<void>}\n     */\n    this.un;\n\n    /** @private */\n    this.boundHandleFeatureChange_ = this.handleFeatureChange_.bind(this);\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(\"../pixel.js\").Pixel}\n     * @private\n     */\n    this.lastPixel_ = [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}\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 {boolean|import(\"../layer/BaseVector\").default}\n     */\n    this.hitDetection_ = null;\n\n    /** @type {Collection<Feature>} */\n    let features;\n    if (options.features) {\n      features = options.features;\n    } else if (options.source) {\n      this.source_ = options.source;\n      features = new Collection(this.source_.getFeatures());\n      this.source_.addEventListener(\n        VectorEventType.ADDFEATURE,\n        this.handleSourceAdd_.bind(this)\n      );\n      this.source_.addEventListener(\n        VectorEventType.REMOVEFEATURE,\n        this.handleSourceRemove_.bind(this)\n      );\n    }\n    if (!features) {\n      throw new Error(\n        'The modify interaction requires features, a source or a layer'\n      );\n    }\n    if (options.hitDetection) {\n      this.hitDetection_ = options.hitDetection;\n    }\n\n    /**\n     * @type {Collection<Feature>}\n     * @private\n     */\n    this.features_ = features;\n\n    this.features_.forEach(this.addFeature_.bind(this));\n    this.features_.addEventListener(\n      CollectionEventType.ADD,\n      this.handleFeatureAdd_.bind(this)\n    );\n    this.features_.addEventListener(\n      CollectionEventType.REMOVE,\n      this.handleFeatureRemove_.bind(this)\n    );\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     */\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   * @param {Feature} feature Feature.\n   * @private\n   */\n  addFeature_(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.lastPixel_, map);\n    }\n    feature.addEventListener(EventType.CHANGE, this.boundHandleFeatureChange_);\n  }\n\n  /**\n   * @param {import(\"../MapBrowserEvent.js\").default} evt Map browser event.\n   * @param {Array<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 segment = segments[i];\n        for (let s = 0, ss = segment.length; s < ss; ++s) {\n          const feature = segment[s].feature;\n          if (feature && !features.includes(feature)) {\n            this.featuresBeingModified_.push(feature);\n          }\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   * @param {Feature} feature Feature.\n   * @private\n   */\n  removeFeature_(feature) {\n    this.removeFeatureSegmentData_(feature);\n    // Remove the vertex feature if the collection of candidate features is empty.\n    if (this.vertexFeature_ && this.features_.getLength() === 0) {\n      this.overlay_.getSource().removeFeature(this.vertexFeature_);\n      this.vertexFeature_ = null;\n    }\n    feature.removeEventListener(\n      EventType.CHANGE,\n      this.boundHandleFeatureChange_\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   */\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   */\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    if (event.feature) {\n      this.features_.push(event.feature);\n    }\n  }\n\n  /**\n   * @param {import(\"../source/Vector.js\").VectorSourceEvent} event Event.\n   * @private\n   */\n  handleSourceRemove_(event) {\n    if (event.feature) {\n      this.features_.remove(event.feature);\n    }\n  }\n\n  /**\n   * @param {import(\"../Collection.js\").CollectionEvent<Feature>} evt Event.\n   * @private\n   */\n  handleFeatureAdd_(evt) {\n    this.addFeature_(evt.element);\n  }\n\n  /**\n   * @param {import(\"../events/Event.js\").default} evt Event.\n   * @private\n   */\n  handleFeatureChange_(evt) {\n    if (!this.changingFeature_) {\n      const feature = /** @type {Feature} */ (evt.target);\n      this.removeFeature_(feature);\n      this.addFeature_(feature);\n    }\n  }\n\n  /**\n   * @param {import(\"../Collection.js\").CollectionEvent<Feature>} evt Event.\n   * @private\n   */\n  handleFeatureRemove_(evt) {\n    this.removeFeature_(evt.element);\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   * @return {Feature} Vertex feature.\n   * @private\n   */\n  createOrUpdateVertexFeature_(coordinates, features, geometries) {\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    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   */\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   * Handle pointer drag events.\n   * @param {import(\"../MapBrowserEvent.js\").default} evt Event.\n   */\n  handleDragEvent(evt) {\n    this.ignoreNextSingleClick_ = false;\n    this.willModifyFeatures_(evt, this.dragSegments_);\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    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      const depth = segmentData.depth;\n      let coordinates;\n      const segment = segmentData.segment;\n      const index = dragSegment[1];\n\n      while (vertex.length < geometry.getStride()) {\n        vertex.push(segment[index][vertex.length]);\n      }\n\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          coordinates[depth[0]][segmentData.index + index] = vertex;\n          segment[index] = vertex;\n          break;\n        case 'MultiPolygon':\n          coordinates = geometry.getCoordinates();\n          coordinates[depth[1]][depth[0]][segmentData.index + index] = vertex;\n          segment[index] = vertex;\n          break;\n        case 'Circle':\n          segment[0] = vertex;\n          segment[1] = vertex;\n          if (segmentData.index === CIRCLE_CENTER_INDEX) {\n            this.changingFeature_ = true;\n            geometry.setCenter(vertex);\n            this.changingFeature_ = false;\n          } else {\n            // We're dragging the circle's circumference:\n            this.changingFeature_ = true;\n            const projection = evt.map.getView().getProjection();\n            let radius = coordinateDistance(\n              fromUserCoordinate(geometry.getCenter(), projection),\n              fromUserCoordinate(vertex, projection)\n            );\n            const userProjection = getUserProjection();\n            if (userProjection) {\n              const circleGeometry = geometry\n                .clone()\n                .transform(userProjection, projection);\n              circleGeometry.setRadius(radius);\n              radius = circleGeometry\n                .transform(projection, userProjection)\n                .getRadius();\n            }\n            geometry.setRadius(radius);\n            this.changingFeature_ = false;\n          }\n          break;\n        default:\n        // pass\n      }\n\n      if (coordinates) {\n        this.setGeometryCoordinates_(geometry, coordinates);\n      }\n    }\n    this.createOrUpdateVertexFeature_(vertex, features, geometries);\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   */\n  handleDownEvent(evt) {\n    if (!this.condition_(evt)) {\n      return false;\n    }\n    const pixelCoordinate = evt.coordinate;\n    this.handlePointerAtPixel_(evt.pixel, evt.map, pixelCoordinate);\n    this.dragSegments_.length = 0;\n    this.featuresBeingModified_ = null;\n    const vertexFeature = this.vertexFeature_;\n    if (vertexFeature) {\n      const projection = evt.map.getView().getProjection();\n      const insertVertices = [];\n      const vertex = 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            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          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          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 (\n                  segmentDataMatch.index !==\n                  coordinates[depth[0]].length - 2\n                ) {\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          this.insertVertexCondition_(evt)\n        ) {\n          insertVertices.push(segmentDataMatch);\n        }\n      }\n\n      if (insertVertices.length) {\n        this.willModifyFeatures_(evt, [insertVertices]);\n      }\n\n      for (let j = insertVertices.length - 1; j >= 0; --j) {\n        this.insertVertex_(insertVertices[j], vertex);\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   */\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        // Update a circle object in the R* bush:\n        const coordinates = geometry.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        let circleGeometry = geometry;\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.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.lastPixel_ = evt.pixel;\n    this.handlePointerAtPixel_(evt.pixel, evt.map, evt.coordinate);\n  }\n\n  /**\n   * @param {import(\"../pixel.js\").Pixel} pixel Pixel\n   * @param {import(\"../Map.js\").default} map Map.\n   * @param {import(\"../coordinate.js\").Coordinate} [coordinate] The pixel Coordinate.\n   * @private\n   */\n  handlePointerAtPixel_(pixel, map, coordinate) {\n    const pixelCoordinate = coordinate || map.getCoordinateFromPixel(pixel);\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          if (\n            feature instanceof Feature &&\n            this.features_.getArray().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          );\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          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          );\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              (coordinatesEqual(closestSegment[0], segment[0]) &&\n                coordinatesEqual(closestSegment[1], segment[1])) ||\n              (coordinatesEqual(closestSegment[0], segment[1]) &&\n                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   * @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;\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    this.ignoreNextSingleClick_ = true;\n  }\n\n  /**\n   * Removes the vertex currently being pointed.\n   * @return {boolean} True when a vertex was removed.\n   * @api\n   */\n  removePoint() {\n    if (\n      this.lastPointerEvent_ &&\n      this.lastPointerEvent_.type != MapBrowserEventType.POINTERDRAG\n    ) {\n      const evt = this.lastPointerEvent_;\n      this.willModifyFeatures_(evt, this.dragSegments_);\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   * @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/**\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 = /** @type {import(\"../geom/Circle.js\").default} */ (\n          circleGeometry.clone().transform(userProjection, projection)\n        );\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 = /** @type {import(\"../geom/Circle.js\").default} */ (\n        circleGeometry.clone().transform(userProjection, projection)\n      );\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 Event from '../events/Event.js';\nimport Feature from '../Feature.js';\nimport Interaction from './Interaction.js';\nimport VectorLayer from '../layer/Vector.js';\nimport {TRUE} from '../functions.js';\nimport {clear} from '../obj.js';\nimport {createEditingStyle} from '../style/Style.js';\nimport {extend} from '../array.js';\nimport {getUid} from '../util.js';\nimport {never, shiftKeyOnly, singleClick} from '../events/condition.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 an {@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\").default>):boolean} FilterFunction\n */\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [addCondition] A function\n * that takes an {@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 an {@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\").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 an {@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 an {@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 an {@link module:ol/Feature~Feature} and an\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\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types|\n *     'change:active', import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").OnSignature<'select', SelectEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {SelectOnSignature<import(\"../events\").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\").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\").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   */\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 = /** @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      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  }\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   * 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   */\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      clear(this.featureLayerAssociation_);\n      map.forEachFeatureAtPixel(\n        mapBrowserEvent.pixel,\n        /**\n         * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n         * @param {import(\"../layer/Layer.js\").default} layer Layer.\n         * @return {boolean|undefined} Continue to iterate over the features.\n         */\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      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          // feature is already selected\n          selected.splice(index, 1);\n        } else {\n          features.remove(feature);\n          deselected.push(feature);\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        /**\n         * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n         * @param {import(\"../layer/Layer.js\").default} layer Layer.\n         * @return {boolean|undefined} Continue to iterate over the features.\n         */\n        (feature, layer) => {\n          if (!(feature instanceof Feature) || !this.filter_(feature, layer)) {\n            return;\n          }\n          if ((add || toggle) && !features.getArray().includes(feature)) {\n            this.addFeatureLayerAssociation_(feature, layer);\n            selected.push(feature);\n          } else if (\n            (remove || toggle) &&\n            features.getArray().includes(feature)\n          ) {\n            deselected.push(feature);\n            this.removeFeatureLayerAssociation_(feature);\n          }\n          return !this.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\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   */\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}\n","/**\n * @module ol/interaction/Snap\n */\nimport CollectionEventType from '../CollectionEventType.js';\nimport EventType from '../events/EventType.js';\nimport PointerInteraction from './Pointer.js';\nimport RBush from '../structs/RBush.js';\nimport VectorEventType from '../source/VectorEventType.js';\nimport {FALSE, TRUE} from '../functions.js';\nimport {SnapEvent, SnapEventType} from '../events/SnapEvent.js';\nimport {boundingExtent, buffer, createEmpty} from '../extent.js';\nimport {\n  closestOnCircle,\n  closestOnSegment,\n  squaredDistance,\n} from '../coordinate.js';\nimport {fromCircle} from '../geom/Polygon.js';\nimport {\n  fromUserCoordinate,\n  getUserProjection,\n  toUserCoordinate,\n  toUserExtent,\n} from '../proj.js';\nimport {getUid} from '../util.js';\nimport {listen, unlistenByKey} from '../events.js';\n\n/**\n * @typedef {Object} Result\n * @property {import(\"../coordinate.js\").Coordinate|null} vertex Vertex.\n * @property {import(\"../pixel.js\").Pixel|null} vertexPixel VertexPixel.\n * @property {import(\"../Feature.js\").default|null} feature Feature.\n */\n\n/**\n * @typedef {Object} SegmentData\n * @property {import(\"../Feature.js\").default} feature Feature.\n * @property {Array<import(\"../coordinate.js\").Coordinate>} segment Segment.\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 {boolean} [edge=true] Snap to edges.\n * @property {boolean} [vertex=true] Snap to vertices.\n * @property {number} [pixelTolerance=10] Pixel tolerance for considering the pointer close enough to a segment or\n * vertex for snapping.\n * @property {import(\"../source/Vector.js\").default} [source] Snap to features from this source. Either this option or features should be provided\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\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types|\n *     'change:active', import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").OnSignature<'snap', SnapEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").Types|\n *     'change:active'|'snap', 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 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    const pointerOptions = /** @type {import(\"./Pointer.js\").Options} */ (\n      options\n    );\n\n    if (!pointerOptions.handleDownEvent) {\n      pointerOptions.handleDownEvent = TRUE;\n    }\n\n    if (!pointerOptions.stopDown) {\n      pointerOptions.stopDown = FALSE;\n    }\n\n    super(pointerOptions);\n\n    /***\n     * @type {SnapOnSignature<import(\"../events\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {SnapOnSignature<import(\"../events\").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     * @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     * @const\n     * @private\n     * @type {Object<string, function(Array<Array<import('../coordinate.js').Coordinate>>, import(\"../geom/Geometry.js\").default): void>}\n     */\n    this.GEOMETRY_SEGMENTERS_ = {\n      'Point': this.segmentPointGeometry_.bind(this),\n      'LineString': this.segmentLineStringGeometry_.bind(this),\n      'LinearRing': this.segmentLineStringGeometry_.bind(this),\n      'Polygon': this.segmentPolygonGeometry_.bind(this),\n      'MultiPoint': this.segmentMultiPointGeometry_.bind(this),\n      'MultiLineString': this.segmentMultiLineStringGeometry_.bind(this),\n      'MultiPolygon': this.segmentMultiPolygonGeometry_.bind(this),\n      'GeometryCollection': this.segmentGeometryCollectionGeometry_.bind(this),\n      'Circle': this.segmentCircleGeometry_.bind(this),\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.GEOMETRY_SEGMENTERS_[geometry.getType()];\n      if (segmenter) {\n        this.indexedFeaturesExtents_[feature_uid] = geometry.getExtent(\n          createEmpty()\n        );\n        const segments =\n          /** @type {Array<Array<import('../coordinate.js').Coordinate>>} */ ([]);\n        segmenter(segments, geometry);\n        if (segments.length === 1) {\n          this.rBush_.insert(boundingExtent(segments[0]), {\n            feature: feature,\n            segment: segments[0],\n          });\n        } else if (segments.length > 1) {\n          const extents = segments.map((s) => boundingExtent(s));\n          const segmentsData = segments.map((segment) => ({\n            feature: feature,\n            segment: segment,\n          }));\n          this.rBush_.load(extents, segmentsData);\n        }\n      }\n    }\n\n    if (register) {\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   * @param {import(\"../MapBrowserEvent.js\").default} evt Map browser event.\n   * @return {boolean} `false` to stop event propagation.\n   * @api\n   */\n  handleEvent(evt) {\n    const result = this.snapTo(evt.pixel, evt.coordinate, evt.map);\n    if (result) {\n      evt.coordinate = result.vertex.slice(0, 2);\n      evt.pixel = result.vertexPixel;\n      this.dispatchEvent(\n        new SnapEvent(SnapEventType.SNAP, {\n          vertex: evt.coordinate,\n          vertexPixel: evt.pixel,\n          feature: result.feature,\n        })\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    }\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      const uid = getUid(feature);\n      if (!(uid in this.pendingFeatures_)) {\n        this.pendingFeatures_[uid] = feature;\n      }\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   */\n  handleUpEvent(evt) {\n    const featuresToUpdate = Object.values(this.pendingFeatures_);\n    if (featuresToUpdate.length) {\n      featuresToUpdate.forEach(this.updateFeature_.bind(this));\n      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      const nodesToRemove = [];\n      rBush.forEachInExtent(extent, function (node) {\n        if (feature === node.feature) {\n          nodesToRemove.push(node);\n        }\n      });\n      for (let i = nodesToRemove.length - 1; i >= 0; --i) {\n        rBush.remove(nodesToRemove[i]);\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   */\n  setMap(map) {\n    const currentMap = this.getMap();\n    const keys = this.featuresListenerKeys_;\n    const features = /** @type {Array<import(\"../Feature.js\").default>} */ (\n      this.getFeatures_()\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      features.forEach((feature) => this.addFeature(feature));\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 {Result|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\n    const squaredPixelTolerance = this.pixelTolerance_ * this.pixelTolerance_;\n    const getResult = () => {\n      if (closestVertex) {\n        const vertexPixel = map.getPixelFromCoordinate(closestVertex);\n        const squaredPixelDistance = squaredDistance(pixel, vertexPixel);\n        if (squaredPixelDistance <= squaredPixelTolerance) {\n          return {\n            vertex: closestVertex,\n            vertexPixel: [\n              Math.round(vertexPixel[0]),\n              Math.round(vertexPixel[1]),\n            ],\n            feature: closestFeature,\n          };\n        }\n      }\n      return null;\n    };\n\n    if (this.vertex_) {\n      for (let i = 0; i < segmentsLength; ++i) {\n        const segmentData = segments[i];\n        if (segmentData.feature.getGeometry().getType() !== 'Circle') {\n          segmentData.segment.forEach((vertex) => {\n            const tempVertexCoord = fromUserCoordinate(vertex, projection);\n            const delta = squaredDistance(projectedCoordinate, tempVertexCoord);\n            if (delta < minSquaredDistance) {\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            minSquaredDistance = delta;\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  /**\n   * @param {Array<Array<import('../coordinate.js').Coordinate>>} segments Segments\n   * @param {import(\"../geom/Circle.js\").default} geometry Geometry.\n   * @private\n   */\n  segmentCircleGeometry_(segments, geometry) {\n    const projection = this.getMap().getView().getProjection();\n    let circleGeometry = geometry;\n    const userProjection = getUserProjection();\n    if (userProjection) {\n      circleGeometry = /** @type {import(\"../geom/Circle.js\").default} */ (\n        circleGeometry.clone().transform(userProjection, projection)\n      );\n    }\n    const polygon = fromCircle(circleGeometry);\n    if (userProjection) {\n      polygon.transform(projection, userProjection);\n    }\n    const coordinates = polygon.getCoordinates()[0];\n    for (let i = 0, ii = coordinates.length - 1; i < ii; ++i) {\n      segments.push(coordinates.slice(i, i + 2));\n    }\n  }\n\n  /**\n   * @param {Array<Array<import('../coordinate.js').Coordinate>>} segments Segments\n   * @param {import(\"../geom/GeometryCollection.js\").default} geometry Geometry.\n   * @private\n   */\n  segmentGeometryCollectionGeometry_(segments, geometry) {\n    const geometries = geometry.getGeometriesArray();\n    for (let i = 0; i < geometries.length; ++i) {\n      const segmenter = this.GEOMETRY_SEGMENTERS_[geometries[i].getType()];\n      if (segmenter) {\n        segmenter(segments, geometries[i]);\n      }\n    }\n  }\n\n  /**\n   * @param {Array<Array<import('../coordinate.js').Coordinate>>} segments Segments\n   * @param {import(\"../geom/LineString.js\").default} geometry Geometry.\n   * @private\n   */\n  segmentLineStringGeometry_(segments, geometry) {\n    const coordinates = geometry.getCoordinates();\n    for (let i = 0, ii = coordinates.length - 1; i < ii; ++i) {\n      segments.push(coordinates.slice(i, i + 2));\n    }\n  }\n\n  /**\n   * @param {Array<Array<import('../coordinate.js').Coordinate>>} segments Segments\n   * @param {import(\"../geom/MultiLineString.js\").default} geometry Geometry.\n   * @private\n   */\n  segmentMultiLineStringGeometry_(segments, 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        segments.push(coordinates.slice(i, i + 2));\n      }\n    }\n  }\n\n  /**\n   * @param {Array<Array<import('../coordinate.js').Coordinate>>} segments Segments\n   * @param {import(\"../geom/MultiPoint.js\").default} geometry Geometry.\n   * @private\n   */\n  segmentMultiPointGeometry_(segments, geometry) {\n    geometry.getCoordinates().forEach((point) => {\n      segments.push([point]);\n    });\n  }\n\n  /**\n   * @param {Array<Array<import('../coordinate.js').Coordinate>>} segments Segments\n   * @param {import(\"../geom/MultiPolygon.js\").default} geometry Geometry.\n   * @private\n   */\n  segmentMultiPolygonGeometry_(segments, 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          segments.push(coordinates.slice(i, i + 2));\n        }\n      }\n    }\n  }\n\n  /**\n   * @param {Array<Array<import('../coordinate.js').Coordinate>>} segments Segments\n   * @param {import(\"../geom/Point.js\").default} geometry Geometry.\n   * @private\n   */\n  segmentPointGeometry_(segments, geometry) {\n    segments.push([geometry.getCoordinates()]);\n  }\n\n  /**\n   * @param {Array<Array<import('../coordinate.js').Coordinate>>} segments Segments\n   * @param {import(\"../geom/Polygon.js\").default} geometry Geometry.\n   * @private\n   */\n  segmentPolygonGeometry_(segments, 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        segments.push(coordinates.slice(i, i + 2));\n      }\n    }\n  }\n}\n\nexport default Snap;\n","/**\n * @module ol/interaction/Translate\n */\nimport Collection from '../Collection.js';\nimport Event from '../events/Event.js';\nimport Feature from '../Feature.js';\nimport InteractionProperty from './Property.js';\nimport PointerInteraction from './Pointer.js';\nimport {TRUE} from '../functions.js';\nimport {always} from '../events/condition.js';\nimport {fromUserCoordinate, getUserProjection} from '../proj.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 an {@link module:ol/Feature~Feature} or\n * {@link module:ol/render/Feature~RenderFeature} and an\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\").default>):boolean} FilterFunction\n */\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes an {@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\").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 an {@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\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types|\n *     'change:active', import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").OnSignature<'translateend'|'translatestart'|'translating', TranslateEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {TranslateOnSignature<import(\"../events\").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\").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\").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   */\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   */\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   */\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   */\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   */\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 RenderFeature from '../render/Feature.js';\nimport {\n  GeometryCollection,\n  LineString,\n  MultiLineString,\n  MultiPoint,\n  MultiPolygon,\n  Point,\n  Polygon,\n} from '../geom.js';\nimport {abstract} from '../util.js';\nimport {\n  equivalent as equivalentProjection,\n  get as getProjection,\n  getTransform,\n  transformExtent,\n} from '../proj.js';\nimport {\n  linearRingsAreOriented,\n  linearRingssAreOriented,\n  orientLinearRings,\n  orientLinearRingsArray,\n} from '../geom/flat/orient.js';\n\n/**\n * @typedef {Object} ReadOptions\n * @property {import(\"../proj.js\").ProjectionLike} [dataProjection] Projection of the data we are reading.\n * If not provided, the projection will be derived from the data (where possible) or\n * the `dataProjection` of the format is assigned (where set). If the projection\n * can not be derived from the data and if no `dataProjection` is set for a format,\n * the features will not be reprojected.\n * @property {import(\"../extent.js\").Extent} [extent] Tile extent in map units of the tile being read.\n * This is only required when reading data with tile pixels as geometry units. When configured,\n * a `dataProjection` with `TILE_PIXELS` as `units` and the tile's pixel extent as `extent` needs to be\n * provided.\n * @property {import(\"../proj.js\").ProjectionLike} [featureProjection] Projection of the feature geometries\n * created by the format reader. If not provided, features will be returned in the\n * `dataProjection`.\n */\n\n/**\n * @typedef {Object} WriteOptions\n * @property {import(\"../proj.js\").ProjectionLike} [dataProjection] Projection of the data we are writing.\n * If not provided, the `dataProjection` of the format is assigned (where set).\n * If no `dataProjection` is set for a format, the features will be returned\n * in the `featureProjection`.\n * @property {import(\"../proj.js\").ProjectionLike} [featureProjection] Projection of the feature geometries\n * that will be serialized by the format writer. If not provided, geometries are assumed\n * to be in the `dataProjection` if that is set; in other words, they are not transformed.\n * @property {boolean} [rightHanded] When writing geometries, follow the right-hand\n * rule for linear ring orientation.  This means that polygons will have counter-clockwise\n * exterior rings and clockwise interior rings.  By default, coordinates are serialized\n * as they are provided at construction.  If `true`, the right-hand rule will\n * be applied.  If `false`, the left-hand rule will be applied (clockwise for\n * exterior and counter-clockwise for interior rings).  Note that not all\n * formats support this.  The GeoJSON format does use this property when writing\n * geometries.\n * @property {number} [decimals] Maximum number of decimal places for coordinates.\n * Coordinates are stored internally as floats, but floating-point arithmetic can create\n * coordinates with a large number of decimal places, not generally wanted on output.\n * Set a number here to round coordinates. Can also be used to ensure that\n * coordinates read in can be written back out with the same number of decimals.\n * Default is no rounding.\n */\n\n/**\n * @typedef {'arraybuffer' | 'json' | 'text' | 'xml'} Type\n */\n\n/**\n * @typedef {Object} SimpleGeometryObject\n * @property {import('../geom/Geometry.js').Type} type Type.\n * @property {Array<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 * @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 * @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 {import(\"../Feature.js\").FeatureClass}\n     */\n    this.featureClass = Feature;\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 {import(\"../Feature.js\").FeatureLike|Array<import(\"../render/Feature.js\").default>} 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<import(\"../Feature.js\").FeatureLike>} 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 {import(\"../Feature.js\").default} 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<import(\"../Feature.js\").default>} 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, object.ends),\n    false,\n    options\n  );\n}\n","/**\n * @module ol/format/JSONFeature\n */\nimport FeatureFormat from './Feature.js';\nimport {abstract} from '../util.js';\n\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * Base class for JSON feature formats.\n *\n * @abstract\n */\nclass JSONFeature extends FeatureFormat {\n  constructor() {\n    super();\n  }\n\n  /**\n   * @return {import(\"./Feature.js\").Type} Format.\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 {import(\"../Feature.js\").FeatureLike|Array<import(\"../render/Feature.js\").default>} Feature.\n   * @api\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<import(\"../Feature.js\").FeatureLike>} Features.\n   * @api\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 {import(\"../Feature.js\").default|import(\"../render/Feature.js\").default|Array<import(\"../render/Feature.js\").default>} 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<import(\"../Feature.js\").default|import(\"../render/Feature.js\").default>} 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   */\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   */\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   */\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   */\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   */\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/EsriJSON\n */\nimport Feature from '../Feature.js';\nimport JSONFeature from './JSONFeature.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 {containsExtent} from '../extent.js';\nimport {deflateCoordinates} from '../geom/flat/deflate.js';\nimport {get as getProjection} from '../proj.js';\nimport {isEmpty} from '../obj.js';\nimport {linearRingIsClockwise} from '../geom/flat/orient.js';\nimport {transformGeometryWithOptions} from './Feature.js';\n\n/**\n * @typedef {import(\"arcgis-rest-api\").Feature} EsriJSONFeature\n * @typedef {import(\"arcgis-rest-api\").FeatureSet} EsriJSONFeatureSet\n * @typedef {import(\"arcgis-rest-api\").Geometry} EsriJSONGeometry\n * @typedef {import(\"arcgis-rest-api\").Point} EsriJSONPoint\n * @typedef {import(\"arcgis-rest-api\").Polyline} EsriJSONPolyline\n * @typedef {import(\"arcgis-rest-api\").Polygon} EsriJSONPolygon\n * @typedef {import(\"arcgis-rest-api\").Multipoint} EsriJSONMultipoint\n * @typedef {import(\"arcgis-rest-api\").HasZM} EsriJSONHasZM\n * @typedef {import(\"arcgis-rest-api\").Position} EsriJSONPosition\n * @typedef {import(\"arcgis-rest-api\").SpatialReferenceWkid} EsriJSONSpatialReferenceWkid\n */\n\n/**\n * @typedef {Object} EsriJSONMultiPolygon\n * @property {Array<Array<Array<Array<number>>>>} rings Rings for the MultiPolygon.\n * @property {boolean} [hasM] If the polygon coordinates have an M value.\n * @property {boolean} [hasZ] If the polygon coordinates have a Z value.\n * @property {EsriJSONSpatialReferenceWkid} [spatialReference] The coordinate reference system.\n */\n\n/**\n * @const\n * @type {Object<import(\"../geom/Geometry.js\").Type, function(EsriJSONGeometry): 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 * @const\n * @type {Object<import(\"../geom/Geometry.js\").Type, function(import(\"../geom/Geometry.js\").default, import(\"./Feature.js\").WriteOptions=): (EsriJSONGeometry)>}\n */\nconst GEOMETRY_WRITERS = {\n  Point: writePointGeometry,\n  LineString: writeLineStringGeometry,\n  Polygon: writePolygonGeometry,\n  MultiPoint: writeMultiPointGeometry,\n  MultiLineString: writeMultiLineStringGeometry,\n  MultiPolygon: writeMultiPolygonGeometry,\n};\n\n/**\n * @typedef {Object} Options\n * @property {string} [geometryName] Geometry name to use when creating features.\n */\n\n/**\n * @classdesc\n * Feature format for reading and writing data in the EsriJSON format.\n *\n * @api\n */\nclass EsriJSON extends JSONFeature {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super();\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  /**\n   * @param {Object} object Object.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @param {string} [idField] Name of the field where to get the id from.\n   * @protected\n   * @return {import(\"../Feature.js\").default} Feature.\n   */\n  readFeatureFromObject(object, options, idField) {\n    const esriJSONFeature = /** @type {EsriJSONFeature} */ (object);\n    const geometry = readGeometry(esriJSONFeature.geometry, options);\n    const feature = new Feature();\n    if (this.geometryName_) {\n      feature.setGeometryName(this.geometryName_);\n    }\n    feature.setGeometry(geometry);\n    if (esriJSONFeature.attributes) {\n      feature.setProperties(esriJSONFeature.attributes, true);\n      const id = esriJSONFeature.attributes[idField];\n      if (id !== undefined) {\n        feature.setId(/** @type {number} */ (id));\n      }\n    }\n    return feature;\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   */\n  readFeaturesFromObject(object, options) {\n    options = options ? options : {};\n    if (object['features']) {\n      const esriJSONFeatureSet = /** @type {EsriJSONFeatureSet} */ (object);\n      /** @type {Array<import(\"../Feature.js\").default>} */\n      const features = [];\n      const esriJSONFeatures = esriJSONFeatureSet.features;\n      for (let i = 0, ii = esriJSONFeatures.length; i < ii; ++i) {\n        features.push(\n          this.readFeatureFromObject(\n            esriJSONFeatures[i],\n            options,\n            object.objectIdFieldName\n          )\n        );\n      }\n      return features;\n    }\n    return [this.readFeatureFromObject(object, options)];\n  }\n\n  /**\n   * @param {EsriJSONGeometry} 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 readGeometry(object, options);\n  }\n\n  /**\n   * @param {Object} object Object.\n   * @protected\n   * @return {import(\"../proj/Projection.js\").default} Projection.\n   */\n  readProjectionFromObject(object) {\n    if (\n      object['spatialReference'] &&\n      object['spatialReference']['wkid'] !== undefined\n    ) {\n      const spatialReference = /** @type {EsriJSONSpatialReferenceWkid} */ (\n        object['spatialReference']\n      );\n      const crs = spatialReference.wkid;\n      return getProjection('EPSG:' + crs);\n    }\n    return null;\n  }\n\n  /**\n   * Encode a geometry as a EsriJSON object.\n   *\n   * @param {import(\"../geom/Geometry.js\").default} geometry Geometry.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n   * @return {EsriJSONGeometry} Object.\n   * @api\n   */\n  writeGeometryObject(geometry, options) {\n    return writeGeometry(geometry, this.adaptOptions(options));\n  }\n\n  /**\n   * Encode a feature as a esriJSON Feature object.\n   *\n   * @param {import(\"../Feature.js\").default} feature Feature.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n   * @return {Object} Object.\n   * @api\n   */\n  writeFeatureObject(feature, options) {\n    options = this.adaptOptions(options);\n    const object = {};\n    if (!feature.hasProperties()) {\n      object['attributes'] = {};\n      return object;\n    }\n    const properties = feature.getProperties();\n    const geometry = feature.getGeometry();\n    if (geometry) {\n      object['geometry'] = writeGeometry(geometry, options);\n      const projection =\n        options && (options.dataProjection || options.featureProjection);\n      if (projection) {\n        object['geometry']['spatialReference'] =\n          /** @type {EsriJSONSpatialReferenceWkid} */ ({\n            wkid: Number(getProjection(projection).getCode().split(':').pop()),\n          });\n      }\n      delete properties[feature.getGeometryName()];\n    }\n    if (!isEmpty(properties)) {\n      object['attributes'] = properties;\n    } else {\n      object['attributes'] = {};\n    }\n    return object;\n  }\n\n  /**\n   * Encode an array of features as a EsriJSON object.\n   *\n   * @param {Array<import(\"../Feature.js\").default>} features Features.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n   * @return {EsriJSONFeatureSet} EsriJSON Object.\n   * @api\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      'features': objects,\n    };\n  }\n}\n\n/**\n * @param {EsriJSONGeometry} 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  if (!object) {\n    return null;\n  }\n  /** @type {import(\"../geom/Geometry.js\").Type} */\n  let type;\n  if (typeof object['x'] === 'number' && typeof object['y'] === 'number') {\n    type = 'Point';\n  } else if (object['points']) {\n    type = 'MultiPoint';\n  } else if (object['paths']) {\n    const esriJSONPolyline = /** @type {EsriJSONPolyline} */ (object);\n    if (esriJSONPolyline.paths.length === 1) {\n      type = 'LineString';\n    } else {\n      type = 'MultiLineString';\n    }\n  } else if (object['rings']) {\n    const esriJSONPolygon = /** @type {EsriJSONPolygon} */ (object);\n    const layout = getGeometryLayout(esriJSONPolygon);\n    const rings = convertRings(esriJSONPolygon.rings, layout);\n    if (rings.length === 1) {\n      type = 'Polygon';\n      object = Object.assign({}, object, {['rings']: rings[0]});\n    } else {\n      type = 'MultiPolygon';\n      object = Object.assign({}, object, {['rings']: rings});\n    }\n  }\n  const geometryReader = GEOMETRY_READERS[type];\n  return transformGeometryWithOptions(geometryReader(object), false, options);\n}\n\n/**\n * Determines inner and outer rings.\n * Checks if any polygons in this array contain any other polygons in this\n * array. It is used for checking for holes.\n * Logic inspired by: https://github.com/Esri/terraformer-arcgis-parser\n * @param {Array<!Array<!Array<number>>>} rings Rings.\n * @param {import(\"../geom/Geometry.js\").GeometryLayout} layout Geometry layout.\n * @return {Array<!Array<!Array<!Array<number>>>>} Transformed rings.\n */\nfunction convertRings(rings, layout) {\n  const flatRing = [];\n  const outerRings = [];\n  const holes = [];\n  let i, ii;\n  for (i = 0, ii = rings.length; i < ii; ++i) {\n    flatRing.length = 0;\n    deflateCoordinates(flatRing, 0, rings[i], layout.length);\n    // is this ring an outer ring? is it clockwise?\n    const clockwise = linearRingIsClockwise(\n      flatRing,\n      0,\n      flatRing.length,\n      layout.length\n    );\n    if (clockwise) {\n      outerRings.push([rings[i]]);\n    } else {\n      holes.push(rings[i]);\n    }\n  }\n  while (holes.length) {\n    const hole = holes.shift();\n    let matched = false;\n    // loop over all outer rings and see if they contain our hole.\n    for (i = outerRings.length - 1; i >= 0; i--) {\n      const outerRing = outerRings[i][0];\n      const containsHole = containsExtent(\n        new LinearRing(outerRing).getExtent(),\n        new LinearRing(hole).getExtent()\n      );\n      if (containsHole) {\n        // the hole is contained push it into our polygon\n        outerRings[i].push(hole);\n        matched = true;\n        break;\n      }\n    }\n    if (!matched) {\n      // no outer rings contain this hole turn it into and outer\n      // ring (reverse it)\n      outerRings.push([hole.reverse()]);\n    }\n  }\n  return outerRings;\n}\n\n/**\n * @param {EsriJSONPoint} object Object.\n * @return {import(\"../geom/Geometry.js\").default} Point.\n */\nfunction readPointGeometry(object) {\n  let point;\n  if (object.m !== undefined && object.z !== undefined) {\n    point = new Point([object.x, object.y, object.z, object.m], 'XYZM');\n  } else if (object.z !== undefined) {\n    point = new Point([object.x, object.y, object.z], 'XYZ');\n  } else if (object.m !== undefined) {\n    point = new Point([object.x, object.y, object.m], 'XYM');\n  } else {\n    point = new Point([object.x, object.y]);\n  }\n  return point;\n}\n\n/**\n * @param {EsriJSONPolyline} object Object.\n * @return {import(\"../geom/Geometry.js\").default} LineString.\n */\nfunction readLineStringGeometry(object) {\n  const layout = getGeometryLayout(object);\n  return new LineString(object.paths[0], layout);\n}\n\n/**\n * @param {EsriJSONPolyline} object Object.\n * @return {import(\"../geom/Geometry.js\").default} MultiLineString.\n */\nfunction readMultiLineStringGeometry(object) {\n  const layout = getGeometryLayout(object);\n  return new MultiLineString(object.paths, layout);\n}\n\n/**\n * @param {EsriJSONHasZM} object Object.\n * @return {import(\"../geom/Geometry.js\").GeometryLayout} The geometry layout to use.\n */\nfunction getGeometryLayout(object) {\n  /** @type {import(\"../geom/Geometry.js\").GeometryLayout} */\n  let layout = 'XY';\n  if (object.hasZ === true && object.hasM === true) {\n    layout = 'XYZM';\n  } else if (object.hasZ === true) {\n    layout = 'XYZ';\n  } else if (object.hasM === true) {\n    layout = 'XYM';\n  }\n  return layout;\n}\n\n/**\n * @param {EsriJSONMultipoint} object Object.\n * @return {import(\"../geom/Geometry.js\").default} MultiPoint.\n */\nfunction readMultiPointGeometry(object) {\n  const layout = getGeometryLayout(object);\n  return new MultiPoint(object.points, layout);\n}\n\n/**\n * @param {EsriJSONMultiPolygon} object Object.\n * @return {import(\"../geom/Geometry.js\").default} MultiPolygon.\n */\nfunction readMultiPolygonGeometry(object) {\n  const layout = getGeometryLayout(object);\n  return new MultiPolygon(object.rings, layout);\n}\n\n/**\n * @param {EsriJSONPolygon} object Object.\n * @return {import(\"../geom/Geometry.js\").default} Polygon.\n */\nfunction readPolygonGeometry(object) {\n  const layout = getGeometryLayout(object);\n  return new Polygon(object.rings, layout);\n}\n\n/**\n * @param {import(\"../geom/Point.js\").default} geometry Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {EsriJSONPoint} EsriJSON geometry.\n */\nfunction writePointGeometry(geometry, options) {\n  const coordinates = geometry.getCoordinates();\n  /** @type {EsriJSONPoint} */\n  let esriJSON;\n  const layout = geometry.getLayout();\n  if (layout === 'XYZ') {\n    esriJSON = {\n      x: coordinates[0],\n      y: coordinates[1],\n      z: coordinates[2],\n    };\n  } else if (layout === 'XYM') {\n    esriJSON = {\n      x: coordinates[0],\n      y: coordinates[1],\n      m: coordinates[2],\n    };\n  } else if (layout === 'XYZM') {\n    esriJSON = {\n      x: coordinates[0],\n      y: coordinates[1],\n      z: coordinates[2],\n      m: coordinates[3],\n    };\n  } else if (layout === 'XY') {\n    esriJSON = {\n      x: coordinates[0],\n      y: coordinates[1],\n    };\n  } else {\n    throw new Error('Invalid geometry layout');\n  }\n  return esriJSON;\n}\n\n/**\n * @param {import(\"../geom/SimpleGeometry.js\").default} geometry Geometry.\n * @return {Object} Object with boolean hasZ and hasM keys.\n */\nfunction getHasZM(geometry) {\n  const layout = geometry.getLayout();\n  return {\n    hasZ: layout === 'XYZ' || layout === 'XYZM',\n    hasM: layout === 'XYM' || layout === 'XYZM',\n  };\n}\n\n/**\n * @param {import(\"../geom/LineString.js\").default} lineString Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {EsriJSONPolyline} EsriJSON geometry.\n */\nfunction writeLineStringGeometry(lineString, options) {\n  const hasZM = getHasZM(lineString);\n  return {\n    hasZ: hasZM.hasZ,\n    hasM: hasZM.hasM,\n    paths: [\n      /** @type {Array<EsriJSONPosition>} */ (lineString.getCoordinates()),\n    ],\n  };\n}\n\n/**\n * @param {import(\"../geom/Polygon.js\").default} polygon Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {EsriJSONPolygon} EsriJSON geometry.\n */\nfunction writePolygonGeometry(polygon, options) {\n  // Esri geometries use the left-hand rule\n  const hasZM = getHasZM(polygon);\n  return {\n    hasZ: hasZM.hasZ,\n    hasM: hasZM.hasM,\n    rings: /** @type {Array<Array<EsriJSONPosition>>} */ (\n      polygon.getCoordinates(false)\n    ),\n  };\n}\n\n/**\n * @param {import(\"../geom/MultiLineString.js\").default} multiLineString Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {EsriJSONPolyline} EsriJSON geometry.\n */\nfunction writeMultiLineStringGeometry(multiLineString, options) {\n  const hasZM = getHasZM(multiLineString);\n  return {\n    hasZ: hasZM.hasZ,\n    hasM: hasZM.hasM,\n    paths: /** @type {Array<Array<EsriJSONPosition>>} */ (\n      multiLineString.getCoordinates()\n    ),\n  };\n}\n\n/**\n * @param {import(\"../geom/MultiPoint.js\").default} multiPoint Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {EsriJSONMultipoint} EsriJSON geometry.\n */\nfunction writeMultiPointGeometry(multiPoint, options) {\n  const hasZM = getHasZM(multiPoint);\n  return {\n    hasZ: hasZM.hasZ,\n    hasM: hasZM.hasM,\n    points: /** @type {Array<EsriJSONPosition>} */ (\n      multiPoint.getCoordinates()\n    ),\n  };\n}\n\n/**\n * @param {import(\"../geom/MultiPolygon.js\").default} geometry Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {EsriJSONPolygon} EsriJSON geometry.\n */\nfunction writeMultiPolygonGeometry(geometry, options) {\n  const hasZM = getHasZM(geometry);\n  const coordinates = geometry.getCoordinates(false);\n  const output = [];\n  for (let i = 0; i < coordinates.length; i++) {\n    for (let x = coordinates[i].length - 1; x >= 0; x--) {\n      output.push(coordinates[i][x]);\n    }\n  }\n  return {\n    hasZ: hasZM.hasZ,\n    hasM: hasZM.hasM,\n    rings: /** @type {Array<Array<EsriJSONPosition>>} */ (output),\n  };\n}\n\n/**\n * @param {import(\"../geom/Geometry.js\").default} geometry Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {EsriJSONGeometry} EsriJSON geometry.\n */\nfunction writeGeometry(geometry, options) {\n  const geometryWriter = GEOMETRY_WRITERS[geometry.getType()];\n  return geometryWriter(\n    transformGeometryWithOptions(geometry, true, options),\n    options\n  );\n}\n\nexport default EsriJSON;\n","/**\n * @module ol/format/XMLFeature\n */\nimport FeatureFormat from '../format/Feature.js';\nimport {abstract} from '../util.js';\nimport {extend} from '../array.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   */\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   */\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   */\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   */\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   */\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   */\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   */\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   */\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/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 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 XMLFeature from './XMLFeature.js';\nimport {extend} from '../array.js';\nimport {\n  getAllTextContent,\n  getAttributeNS,\n  makeArrayPusher,\n  makeReplacer,\n  parseNode,\n  pushParseAndPop,\n} from '../xml.js';\nimport {get as getProjection} from '../proj.js';\nimport {\n  transformExtentWithOptions,\n  transformGeometryWithOptions,\n} from './Feature.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   */\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   */\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   */\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/xsd\n */\nimport {getAllTextContent, getDocument} from '../xml.js';\nimport {padNumber} from '../string.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\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  node.appendChild(getDocument().createTextNode(string));\n}\n","/**\n * @module ol/format/GML2\n */\nimport GMLBase, {GMLNS} from './GMLBase.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 {createOrUpdate} from '../extent.js';\nimport {get as getProjection} from '../proj.js';\nimport {\n  transformExtentWithOptions,\n  transformGeometryWithOptions,\n} from './Feature.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.substr(0, 2) === '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) {\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    let axisOrientation = 'enu';\n    if (srsName) {\n      axisOrientation = getProjection(srsName).getAxisOrientation();\n    }\n    let coords =\n      axisOrientation.substr(0, 2) === '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 GML2 from './GML2.js';\nimport GMLBase, {GMLNS} from './GMLBase.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 {\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 {createOrUpdate} from '../extent.js';\nimport {extend} from '../array.js';\nimport {get as getProjection} from '../proj.js';\nimport {readNonNegativeIntegerString, writeStringTextNode} from './xsd.js';\nimport {\n  transformExtentWithOptions,\n  transformGeometryWithOptions,\n} from './Feature.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    let axisOrientation = 'enu';\n    if (containerSrs) {\n      const proj = getProjection(containerSrs);\n      axisOrientation = proj.getAxisOrientation();\n    }\n    if (axisOrientation === 'neu') {\n      let i, ii;\n      for (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    let axisOrientation = 'enu';\n    if (containerSrs) {\n      const proj = getProjection(containerSrs);\n      axisOrientation = proj.getAxisOrientation();\n    }\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    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 (axisOrientation.substr(0, 2) === '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 {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    let axisOrientation = 'enu';\n    if (srsName) {\n      axisOrientation = getProjection(srsName).getAxisOrientation();\n    }\n    const point = value.getCoordinates();\n    let coords;\n    // only 2d for simple features profile\n    if (axisOrientation.substr(0, 2) === 'en') {\n      coords = point[0] + ' ' + point[1];\n    } else {\n      coords = point[1] + ' ' + point[0];\n    }\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    let axisOrientation = 'enu';\n    if (srsName) {\n      axisOrientation = getProjection(srsName).getAxisOrientation();\n    }\n    let coords =\n      axisOrientation.substr(0, 2) === '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) {\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   */\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   */\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/GML\n */\nimport GML3 from './GML3.js';\n\n/**\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 * @class\n * @param {import(\"./GMLBase.js\").Options} [options]\n *     Optional configuration object.\n * @api\n */\nconst GML = GML3;\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 */\nGML.prototype.writeFeatures;\n\n/**\n * Encode an array of features in the GML 3.1.1 format as an XML node.\n *\n * @function\n * @param {Array<import(\"../Feature.js\").default>} features Features.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Options.\n * @return {Node} Node.\n * @api\n */\nGML.prototype.writeFeaturesNode;\n\nexport default GML;\n","/**\n * @module ol/format/GML32\n */\nimport GML2 from './GML2.js';\nimport GML3 from './GML3.js';\nimport GMLBase from './GMLBase.js';\nimport {\n  makeArrayExtender,\n  makeArrayPusher,\n  makeChildAppender,\n  makeReplacer,\n} from '../xml.js';\nimport {writeStringTextNode} from '../format/xsd.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   */\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/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 XMLFeature from './XMLFeature.js';\nimport {\n  OBJECT_PROPERTY_NODE_FACTORY,\n  XML_SCHEMA_INSTANCE_URI,\n  createElementNS,\n  makeArrayPusher,\n  makeArraySerializer,\n  makeChildAppender,\n  makeObjectPropertySetter,\n  makeSequence,\n  makeSimpleNodeFactory,\n  makeStructureNS,\n  parseNode,\n  pushParseAndPop,\n  pushSerializeAndPop,\n} from '../xml.js';\nimport {get as getProjection} from '../proj.js';\nimport {\n  readDateTime,\n  readDecimal,\n  readPositiveInteger,\n  readString,\n  writeDateTimeTextNode,\n  writeDecimalTextNode,\n  writeNonNegativeIntegerTextNode,\n  writeStringTextNode,\n} from './xsd.js';\nimport {transformGeometryWithOptions} from './Feature.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 * @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 * @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 * @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 {function(Feature, Node): void|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   * @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    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   */\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   */\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<*>} 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/GeoJSON\n */\n\nimport Feature from '../Feature.js';\nimport JSONFeature from './JSONFeature.js';\nimport RenderFeature from '../render/Feature.js';\nimport {\n  createGeometry,\n  createRenderFeature,\n  transformGeometryWithOptions,\n} from './Feature.js';\nimport {\n  deflateCoordinatesArray,\n  deflateMultiCoordinatesArray,\n} from '../geom/flat/deflate.js';\nimport {getLayoutForStride} from '../geom/SimpleGeometry.js';\nimport {get as getProjection} from '../proj.js';\nimport {isEmpty} from '../obj.js';\n\n/**\n * @typedef {import(\"geojson\").GeoJSON} GeoJSONObject\n * @typedef {import(\"geojson\").Feature} GeoJSONFeature\n * @typedef {import(\"geojson\").FeatureCollection} GeoJSONFeatureCollection\n * @typedef {import(\"geojson\").Geometry} GeoJSONGeometry\n * @typedef {import(\"geojson\").Point} GeoJSONPoint\n * @typedef {import(\"geojson\").LineString} GeoJSONLineString\n * @typedef {import(\"geojson\").Polygon} GeoJSONPolygon\n * @typedef {import(\"geojson\").MultiPoint} GeoJSONMultiPoint\n * @typedef {import(\"geojson\").MultiLineString} GeoJSONMultiLineString\n * @typedef {import(\"geojson\").MultiPolygon} GeoJSONMultiPolygon\n * @typedef {import(\"geojson\").GeometryCollection} GeoJSONGeometryCollection\n */\n\n/**\n * @typedef {Object} Options\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\").FeatureClass} [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 * @api\n */\nclass GeoJSON extends JSONFeature {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    options = options ? options : {};\n\n    super();\n\n    /**\n     * @type {import(\"../proj/Projection.js\").default}\n     */\n    this.dataProjection = getProjection(\n      options.dataProjection ? options.dataProjection : 'EPSG:4326'\n    );\n\n    if (options.featureProjection) {\n      /**\n       * @type {import(\"../proj/Projection.js\").default}\n       */\n      this.defaultFeatureProjection = getProjection(options.featureProjection);\n    }\n\n    if (options.featureClass) {\n      this.featureClass = options.featureClass;\n    }\n\n    /**\n     * Name of the geometry attribute for features.\n     * @type {string|undefined}\n     * @private\n     */\n    this.geometryName_ = options.geometryName;\n\n    /**\n     * Look for the geometry name in the feature GeoJSON\n     * @type {boolean|undefined}\n     * @private\n     */\n    this.extractGeometryName_ = options.extractGeometryName;\n\n    this.supportedMediaTypes = [\n      'application/geo+json',\n      'application/vnd.geo+json',\n    ];\n  }\n\n  /**\n   * @param {Object} object Object.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @protected\n   * @return {Feature|RenderFeature|Array<RenderFeature>}.default} Feature.\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 createRenderFeature(\n        {\n          geometry,\n          id: geoJSONFeature['id'],\n          properties: geoJSONFeature['properties'],\n        },\n        options\n      );\n    }\n\n    const feature = new Feature();\n    if (this.geometryName_) {\n      feature.setGeometryName(this.geometryName_);\n    } else if (\n      this.extractGeometryName_ &&\n      'geometry_name' in geoJSONFeature !== undefined\n    ) {\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 feature;\n  }\n\n  /**\n   * @param {Object} object Object.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @protected\n   * @return {Array<Feature|RenderFeature>} Features.\n   */\n  readFeaturesFromObject(object, options) {\n    const geoJSONObject = /** @type {GeoJSONObject} */ (object);\n    /** @type {Array<Feature|RenderFeature|Array<RenderFeature>>} */\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 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   */\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   */\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   */\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   */\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   */\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),\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;\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),\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;\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   */\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   */\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   */\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   */\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   */\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   */\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   */\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   */\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 TextFeature from './TextFeature.js';\nimport {get as getProjection} from '../proj.js';\nimport {transformGeometryWithOptions} from './Feature.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 * 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  /**\n   * @protected\n   * @param {string} text Text.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @return {import(\"../Feature.js\").default} Feature.\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 (m[6] == 'S') {\n            y = -y;\n          }\n          let x = parseInt(m[7], 10) + parseInt(m[8], 10) / 60000;\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 = 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    }\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   */\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 Fill from '../style/Fill.js';\nimport GeometryCollection from '../geom/GeometryCollection.js';\nimport Icon from '../style/Icon.js';\nimport ImageState from '../ImageState.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 Stroke from '../style/Stroke.js';\nimport Style from '../style/Style.js';\nimport Text from '../style/Text.js';\nimport XMLFeature from './XMLFeature.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 {asArray} from '../color.js';\nimport {extend} from '../array.js';\nimport {get as getProjection} from '../proj.js';\nimport {\n  readBoolean,\n  readDecimal,\n  readString,\n  writeBooleanTextNode,\n  writeCDATASection,\n  writeDecimalTextNode,\n  writeStringTextNode,\n} from './xsd.js';\nimport {toRadians} from '../math.js';\nimport {transformGeometryWithOptions} from './Feature.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 {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 {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   */\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   */\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   */\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      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') {\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\").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\").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 * @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  writeCDATASection(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","/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh <https://feross.org/opensource> */\nexports.read = function (buffer, offset, isLE, mLen, nBytes) {\n  var e, m\n  var eLen = (nBytes * 8) - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var nBits = -7\n  var i = isLE ? (nBytes - 1) : 0\n  var d = isLE ? -1 : 1\n  var s = buffer[offset + i]\n\n  i += d\n\n  e = s & ((1 << (-nBits)) - 1)\n  s >>= (-nBits)\n  nBits += eLen\n  for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n  m = e & ((1 << (-nBits)) - 1)\n  e >>= (-nBits)\n  nBits += mLen\n  for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n  if (e === 0) {\n    e = 1 - eBias\n  } else if (e === eMax) {\n    return m ? NaN : ((s ? -1 : 1) * Infinity)\n  } else {\n    m = m + Math.pow(2, mLen)\n    e = e - eBias\n  }\n  return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n  var e, m, c\n  var eLen = (nBytes * 8) - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n  var i = isLE ? 0 : (nBytes - 1)\n  var d = isLE ? 1 : -1\n  var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n  value = Math.abs(value)\n\n  if (isNaN(value) || value === Infinity) {\n    m = isNaN(value) ? 1 : 0\n    e = eMax\n  } else {\n    e = Math.floor(Math.log(value) / Math.LN2)\n    if (value * (c = Math.pow(2, -e)) < 1) {\n      e--\n      c *= 2\n    }\n    if (e + eBias >= 1) {\n      value += rt / c\n    } else {\n      value += rt * Math.pow(2, 1 - eBias)\n    }\n    if (value * c >= 2) {\n      e++\n      c /= 2\n    }\n\n    if (e + eBias >= eMax) {\n      m = 0\n      e = eMax\n    } else if (e + eBias >= 1) {\n      m = ((value * c) - 1) * Math.pow(2, mLen)\n      e = e + eBias\n    } else {\n      m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n      e = 0\n    }\n  }\n\n  for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n  e = (e << mLen) | m\n  eLen += mLen\n  for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n  buffer[offset + i - d] |= s * 128\n}\n","'use strict';\n\nmodule.exports = Pbf;\n\nvar ieee754 = require('ieee754');\n\nfunction Pbf(buf) {\n    this.buf = ArrayBuffer.isView && ArrayBuffer.isView(buf) ? buf : new Uint8Array(buf || 0);\n    this.pos = 0;\n    this.type = 0;\n    this.length = this.buf.length;\n}\n\nPbf.Varint  = 0; // varint: int32, int64, uint32, uint64, sint32, sint64, bool, enum\nPbf.Fixed64 = 1; // 64-bit: double, fixed64, sfixed64\nPbf.Bytes   = 2; // length-delimited: string, bytes, embedded messages, packed repeated fields\nPbf.Fixed32 = 5; // 32-bit: float, fixed32, sfixed32\n\nvar SHIFT_LEFT_32 = (1 << 16) * (1 << 16),\n    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)\nvar TEXT_DECODER_MIN_LENGTH = 12;\nvar utf8TextDecoder = typeof TextDecoder === 'undefined' ? null : new TextDecoder('utf8');\n\nPbf.prototype = {\n\n    destroy: function() {\n        this.buf = null;\n    },\n\n    // === READING =================================================================\n\n    readFields: function(readField, result, end) {\n        end = end || this.length;\n\n        while (this.pos < end) {\n            var 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    readMessage: function(readField, result) {\n        return this.readFields(readField, result, this.readVarint() + this.pos);\n    },\n\n    readFixed32: function() {\n        var val = readUInt32(this.buf, this.pos);\n        this.pos += 4;\n        return val;\n    },\n\n    readSFixed32: function() {\n        var val = readInt32(this.buf, this.pos);\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: function() {\n        var val = readUInt32(this.buf, this.pos) + readUInt32(this.buf, this.pos + 4) * SHIFT_LEFT_32;\n        this.pos += 8;\n        return val;\n    },\n\n    readSFixed64: function() {\n        var val = readUInt32(this.buf, this.pos) + readInt32(this.buf, this.pos + 4) * SHIFT_LEFT_32;\n        this.pos += 8;\n        return val;\n    },\n\n    readFloat: function() {\n        var val = ieee754.read(this.buf, this.pos, true, 23, 4);\n        this.pos += 4;\n        return val;\n    },\n\n    readDouble: function() {\n        var val = ieee754.read(this.buf, this.pos, true, 52, 8);\n        this.pos += 8;\n        return val;\n    },\n\n    readVarint: function(isSigned) {\n        var buf = this.buf,\n            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: function() { // for compatibility with v2.0.1\n        return this.readVarint(true);\n    },\n\n    readSVarint: function() {\n        var num = this.readVarint();\n        return num % 2 === 1 ? (num + 1) / -2 : num / 2; // zigzag encoding\n    },\n\n    readBoolean: function() {\n        return Boolean(this.readVarint());\n    },\n\n    readString: function() {\n        var end = this.readVarint() + this.pos;\n        var 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 readUtf8TextDecoder(this.buf, pos, end);\n        }\n        // short strings are fast with our custom implementation\n        return readUtf8(this.buf, pos, end);\n    },\n\n    readBytes: function() {\n        var 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    readPackedVarint: function(arr, isSigned) {\n        if (this.type !== Pbf.Bytes) return arr.push(this.readVarint(isSigned));\n        var end = readPackedEnd(this);\n        arr = arr || [];\n        while (this.pos < end) arr.push(this.readVarint(isSigned));\n        return arr;\n    },\n    readPackedSVarint: function(arr) {\n        if (this.type !== Pbf.Bytes) return arr.push(this.readSVarint());\n        var end = readPackedEnd(this);\n        arr = arr || [];\n        while (this.pos < end) arr.push(this.readSVarint());\n        return arr;\n    },\n    readPackedBoolean: function(arr) {\n        if (this.type !== Pbf.Bytes) return arr.push(this.readBoolean());\n        var end = readPackedEnd(this);\n        arr = arr || [];\n        while (this.pos < end) arr.push(this.readBoolean());\n        return arr;\n    },\n    readPackedFloat: function(arr) {\n        if (this.type !== Pbf.Bytes) return arr.push(this.readFloat());\n        var end = readPackedEnd(this);\n        arr = arr || [];\n        while (this.pos < end) arr.push(this.readFloat());\n        return arr;\n    },\n    readPackedDouble: function(arr) {\n        if (this.type !== Pbf.Bytes) return arr.push(this.readDouble());\n        var end = readPackedEnd(this);\n        arr = arr || [];\n        while (this.pos < end) arr.push(this.readDouble());\n        return arr;\n    },\n    readPackedFixed32: function(arr) {\n        if (this.type !== Pbf.Bytes) return arr.push(this.readFixed32());\n        var end = readPackedEnd(this);\n        arr = arr || [];\n        while (this.pos < end) arr.push(this.readFixed32());\n        return arr;\n    },\n    readPackedSFixed32: function(arr) {\n        if (this.type !== Pbf.Bytes) return arr.push(this.readSFixed32());\n        var end = readPackedEnd(this);\n        arr = arr || [];\n        while (this.pos < end) arr.push(this.readSFixed32());\n        return arr;\n    },\n    readPackedFixed64: function(arr) {\n        if (this.type !== Pbf.Bytes) return arr.push(this.readFixed64());\n        var end = readPackedEnd(this);\n        arr = arr || [];\n        while (this.pos < end) arr.push(this.readFixed64());\n        return arr;\n    },\n    readPackedSFixed64: function(arr) {\n        if (this.type !== Pbf.Bytes) return arr.push(this.readSFixed64());\n        var end = readPackedEnd(this);\n        arr = arr || [];\n        while (this.pos < end) arr.push(this.readSFixed64());\n        return arr;\n    },\n\n    skip: function(val) {\n        var 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    writeTag: function(tag, type) {\n        this.writeVarint((tag << 3) | type);\n    },\n\n    realloc: function(min) {\n        var length = this.length || 16;\n\n        while (length < this.pos + min) length *= 2;\n\n        if (length !== this.length) {\n            var buf = new Uint8Array(length);\n            buf.set(this.buf);\n            this.buf = buf;\n            this.length = length;\n        }\n    },\n\n    finish: function() {\n        this.length = this.pos;\n        this.pos = 0;\n        return this.buf.subarray(0, this.length);\n    },\n\n    writeFixed32: function(val) {\n        this.realloc(4);\n        writeInt32(this.buf, val, this.pos);\n        this.pos += 4;\n    },\n\n    writeSFixed32: function(val) {\n        this.realloc(4);\n        writeInt32(this.buf, val, this.pos);\n        this.pos += 4;\n    },\n\n    writeFixed64: function(val) {\n        this.realloc(8);\n        writeInt32(this.buf, val & -1, this.pos);\n        writeInt32(this.buf, Math.floor(val * SHIFT_RIGHT_32), this.pos + 4);\n        this.pos += 8;\n    },\n\n    writeSFixed64: function(val) {\n        this.realloc(8);\n        writeInt32(this.buf, val & -1, this.pos);\n        writeInt32(this.buf, Math.floor(val * SHIFT_RIGHT_32), this.pos + 4);\n        this.pos += 8;\n    },\n\n    writeVarint: function(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    writeSVarint: function(val) {\n        this.writeVarint(val < 0 ? -val * 2 - 1 : val * 2);\n    },\n\n    writeBoolean: function(val) {\n        this.writeVarint(Boolean(val));\n    },\n\n    writeString: function(str) {\n        str = String(str);\n        this.realloc(str.length * 4);\n\n        this.pos++; // reserve 1 byte for short string length\n\n        var 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        var 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    writeFloat: function(val) {\n        this.realloc(4);\n        ieee754.write(this.buf, val, this.pos, true, 23, 4);\n        this.pos += 4;\n    },\n\n    writeDouble: function(val) {\n        this.realloc(8);\n        ieee754.write(this.buf, val, this.pos, true, 52, 8);\n        this.pos += 8;\n    },\n\n    writeBytes: function(buffer) {\n        var len = buffer.length;\n        this.writeVarint(len);\n        this.realloc(len);\n        for (var i = 0; i < len; i++) this.buf[this.pos++] = buffer[i];\n    },\n\n    writeRawMessage: function(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        var startPos = this.pos;\n        fn(obj, this);\n        var 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    writeMessage: function(tag, fn, obj) {\n        this.writeTag(tag, Pbf.Bytes);\n        this.writeRawMessage(fn, obj);\n    },\n\n    writePackedVarint:   function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedVarint, arr);   },\n    writePackedSVarint:  function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedSVarint, arr);  },\n    writePackedBoolean:  function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedBoolean, arr);  },\n    writePackedFloat:    function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedFloat, arr);    },\n    writePackedDouble:   function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedDouble, arr);   },\n    writePackedFixed32:  function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedFixed32, arr);  },\n    writePackedSFixed32: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedSFixed32, arr); },\n    writePackedFixed64:  function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedFixed64, arr);  },\n    writePackedSFixed64: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedSFixed64, arr); },\n\n    writeBytesField: function(tag, buffer) {\n        this.writeTag(tag, Pbf.Bytes);\n        this.writeBytes(buffer);\n    },\n    writeFixed32Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed32);\n        this.writeFixed32(val);\n    },\n    writeSFixed32Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed32);\n        this.writeSFixed32(val);\n    },\n    writeFixed64Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed64);\n        this.writeFixed64(val);\n    },\n    writeSFixed64Field: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed64);\n        this.writeSFixed64(val);\n    },\n    writeVarintField: function(tag, val) {\n        this.writeTag(tag, Pbf.Varint);\n        this.writeVarint(val);\n    },\n    writeSVarintField: function(tag, val) {\n        this.writeTag(tag, Pbf.Varint);\n        this.writeSVarint(val);\n    },\n    writeStringField: function(tag, str) {\n        this.writeTag(tag, Pbf.Bytes);\n        this.writeString(str);\n    },\n    writeFloatField: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed32);\n        this.writeFloat(val);\n    },\n    writeDoubleField: function(tag, val) {\n        this.writeTag(tag, Pbf.Fixed64);\n        this.writeDouble(val);\n    },\n    writeBooleanField: function(tag, val) {\n        this.writeVarintField(tag, Boolean(val));\n    }\n};\n\nfunction readVarintRemainder(l, s, p) {\n    var buf = p.buf,\n        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\nfunction readPackedEnd(pbf) {\n    return pbf.type === Pbf.Bytes ?\n        pbf.readVarint() + pbf.pos : pbf.pos + 1;\n}\n\nfunction toNum(low, high, isSigned) {\n    if (isSigned) {\n        return high * 0x100000000 + (low >>> 0);\n    }\n\n    return ((high >>> 0) * 0x100000000) + (low >>> 0);\n}\n\nfunction writeBigVarint(val, pbf) {\n    var 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\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\nfunction writeBigVarintHigh(high, pbf) {\n    var 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\nfunction makeRoomForExtraLength(startPos, len, pbf) {\n    var 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 (var i = pbf.pos - 1; i >= startPos; i--) pbf.buf[i + extraLen] = pbf.buf[i];\n}\n\nfunction writePackedVarint(arr, pbf)   { for (var i = 0; i < arr.length; i++) pbf.writeVarint(arr[i]);   }\nfunction writePackedSVarint(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeSVarint(arr[i]);  }\nfunction writePackedFloat(arr, pbf)    { for (var i = 0; i < arr.length; i++) pbf.writeFloat(arr[i]);    }\nfunction writePackedDouble(arr, pbf)   { for (var i = 0; i < arr.length; i++) pbf.writeDouble(arr[i]);   }\nfunction writePackedBoolean(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeBoolean(arr[i]);  }\nfunction writePackedFixed32(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeFixed32(arr[i]);  }\nfunction writePackedSFixed32(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSFixed32(arr[i]); }\nfunction writePackedFixed64(arr, pbf)  { for (var i = 0; i < arr.length; i++) pbf.writeFixed64(arr[i]);  }\nfunction writePackedSFixed64(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSFixed64(arr[i]); }\n\n// Buffer code below from https://github.com/feross/buffer, MIT-licensed\n\nfunction readUInt32(buf, pos) {\n    return ((buf[pos]) |\n        (buf[pos + 1] << 8) |\n        (buf[pos + 2] << 16)) +\n        (buf[pos + 3] * 0x1000000);\n}\n\nfunction writeInt32(buf, val, pos) {\n    buf[pos] = val;\n    buf[pos + 1] = (val >>> 8);\n    buf[pos + 2] = (val >>> 16);\n    buf[pos + 3] = (val >>> 24);\n}\n\nfunction readInt32(buf, pos) {\n    return ((buf[pos]) |\n        (buf[pos + 1] << 8) |\n        (buf[pos + 2] << 16)) +\n        (buf[pos + 3] << 24);\n}\n\nfunction readUtf8(buf, pos, end) {\n    var str = '';\n    var i = pos;\n\n    while (i < end) {\n        var b0 = buf[i];\n        var c = null; // codepoint\n        var bytesPerSequence =\n            b0 > 0xEF ? 4 :\n            b0 > 0xDF ? 3 :\n            b0 > 0xBF ? 2 : 1;\n\n        if (i + bytesPerSequence > end) break;\n\n        var 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\nfunction readUtf8TextDecoder(buf, pos, end) {\n    return utf8TextDecoder.decode(buf.subarray(pos, end));\n}\n\nfunction writeUtf8(buf, str, pos) {\n    for (var 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 FeatureFormat, {transformGeometryWithOptions} 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 PBF from 'pbf';\nimport Point from '../geom/Point.js';\nimport Polygon from '../geom/Polygon.js';\nimport Projection from '../proj/Projection.js';\nimport RenderFeature from '../render/Feature.js';\nimport {get} from '../proj.js';\nimport {inflateEnds} from '../geom/flat/orient.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../Feature.js\").FeatureClass} [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 * @param {Options} [options] Options.\n * @api\n */\nclass MVT extends FeatureFormat {\n  /**\n   * @param {Options} [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    /**\n     * @private\n     * @type {import(\"../Feature.js\").FeatureClass}\n     */\n    this.featureClass_ = options.featureClass\n      ? options.featureClass\n      : RenderFeature;\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 {import(\"../Feature.js\").FeatureLike|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 = new this.featureClass_(\n        geometryType,\n        flatCoordinates,\n        ends,\n        2,\n        values,\n        id\n      );\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 feature;\n  }\n\n  /**\n   * @return {import(\"./Feature.js\").Type} Format.\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<import(\"../Feature.js\").FeatureLike>} Features.\n   * @api\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 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   */\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 LineString from '../geom/LineString.js';\nimport Point from '../geom/Point.js';\nimport Polygon from '../geom/Polygon.js';\nimport XMLFeature from './XMLFeature.js';\nimport {extend} from '../array.js';\nimport {get as getProjection} from '../proj.js';\nimport {isEmpty} from '../obj.js';\nimport {makeStructureNS, pushParseAndPop} from '../xml.js';\nimport {transformGeometryWithOptions} from './Feature.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   */\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 XML from './XML.js';\nimport {\n  makeObjectPropertyPusher,\n  makeObjectPropertySetter,\n  makeStructureNS,\n  pushParseAndPop,\n} 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   */\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 TextFeature from './TextFeature.js';\nimport {flipXY} from '../geom/flat/flip.js';\nimport {get as getProjection} from '../proj.js';\nimport {getStrideForLayout} from '../geom/SimpleGeometry.js';\nimport {inflateCoordinates} from '../geom/flat/inflate.js';\nimport {transformGeometryWithOptions} from './Feature.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   */\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   */\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   */\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 coordinates = inflateCoordinates(\n      flatCoordinates,\n      0,\n      flatCoordinates.length,\n      stride\n    );\n    const lineString = new LineString(coordinates, 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   */\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   */\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   */\n  writeGeometryText(geometry, options) {\n    geometry =\n      /** @type {LineString} */\n      (\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 */\nexport function encodeDeltas(numbers, stride, factor) {\n  factor = factor ? factor : 1e5;\n  let d;\n\n  const lastNumbers = new Array(stride);\n  for (d = 0; d < stride; ++d) {\n    lastNumbers[d] = 0;\n  }\n\n  for (let i = 0, ii = numbers.length; i < ii; ) {\n    for (d = 0; d < stride; ++d, ++i) {\n      const num = numbers[i];\n      const delta = num - lastNumbers[d];\n      lastNumbers[d] = num;\n\n      numbers[i] = delta;\n    }\n  }\n\n  return encodeFloats(numbers, factor);\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 */\nexport function decodeDeltas(encoded, stride, factor) {\n  factor = factor ? factor : 1e5;\n  let d;\n\n  /** @type {Array<number>} */\n  const lastNumbers = new Array(stride);\n  for (d = 0; d < stride; ++d) {\n    lastNumbers[d] = 0;\n  }\n\n  const numbers = decodeFloats(encoded, factor);\n\n  for (let i = 0, ii = numbers.length; i < ii; ) {\n    for (d = 0; d < stride; ++d, ++i) {\n      lastNumbers[d] += numbers[i];\n\n      numbers[i] = lastNumbers[d];\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 * @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 * @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 JSONFeature from './JSONFeature.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';\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   */\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   */\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/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 Filter from './Filter.js';\nimport {assert} from '../../asserts.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/filter/Spatial\n */\nimport Filter from './Filter.js';\n\n/**\n * @classdesc\n * Abstract class; normally only used for creating subclasses and not instantiated in apps.\n * Represents a spatial operator to test whether a geometry-valued property\n * relates to a given geometry.\n *\n * @abstract\n */\nclass Spatial extends Filter {\n  /**\n   * @param {!string} tagName The XML tag name for this filter.\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   */\n  constructor(tagName, geometryName, geometry, srsName) {\n    super(tagName);\n\n    /**\n     * @type {!string}\n     */\n    this.geometryName = geometryName || 'the_geom';\n\n    /**\n     * @type {import(\"../../geom/Geometry.js\").default}\n     */\n    this.geometry = geometry;\n\n    /**\n     * @type {string|undefined}\n     */\n    this.srsName = srsName;\n  }\n}\n\nexport default Spatial;\n","/**\n * @module ol/format/filter/Contains\n */\nimport Spatial from './Spatial.js';\n\n/**\n * @classdesc\n * Represents a `<Contains>` operator to test whether a geometry-valued property\n * contains a given geometry.\n * @api\n */\nclass Contains extends Spatial {\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   */\n  constructor(geometryName, geometry, srsName) {\n    super('Contains', geometryName, geometry, srsName);\n  }\n}\n\nexport default Contains;\n","/**\n * @module ol/format/filter/DWithin\n */\nimport Spatial from './Spatial.js';\n\n/**\n * @classdesc\n * Represents a `<DWithin>` operator to test whether a geometry-valued property\n * is within a distance to a given geometry.\n * @api\n */\nclass DWithin extends Spatial {\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   */\n  constructor(geometryName, geometry, distance, unit, srsName) {\n    super('DWithin', geometryName, geometry, srsName);\n\n    /**\n     * @public\n     * @type {!number}\n     */\n    this.distance = distance;\n\n    /**\n     * @public\n     * @type {!string}\n     */\n    this.unit = unit;\n  }\n}\n\nexport default DWithin;\n","/**\n * @module ol/format/filter/Disjoint\n */\nimport Spatial from './Spatial.js';\n\n/**\n * @classdesc\n * Represents a `<Disjoint>` operator to test whether a geometry-valued property\n * is disjoint to a given geometry.\n * @api\n */\nclass Disjoint extends Spatial {\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   */\n  constructor(geometryName, geometry, srsName) {\n    super('Disjoint', geometryName, geometry, srsName);\n  }\n}\n\nexport default Disjoint;\n","/**\n * @module ol/format/filter/Comparison\n */\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 property comparison filters.\n *\n * @abstract\n */\nclass Comparison extends Filter {\n  /**\n   * @param {!string} tagName The XML tag name for this filter.\n   * @param {!string} propertyName Name of the context property to compare.\n   */\n  constructor(tagName, propertyName) {\n    super(tagName);\n\n    /**\n     * @type {!string}\n     */\n    this.propertyName = propertyName;\n  }\n}\n\nexport default Comparison;\n","/**\n * @module ol/format/filter/During\n */\nimport Comparison from './Comparison.js';\n\n/**\n * @classdesc\n * Represents a `<During>` comparison operator.\n * @api\n */\nclass During extends Comparison {\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   */\n  constructor(propertyName, begin, end) {\n    super('During', propertyName);\n\n    /**\n     * @type {!string}\n     */\n    this.begin = begin;\n\n    /**\n     * @type {!string}\n     */\n    this.end = end;\n  }\n}\n\nexport default During;\n","/**\n * @module ol/format/filter/ComparisonBinary\n */\nimport Comparison from './Comparison.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 property binary comparison filters.\n *\n * @abstract\n */\nclass ComparisonBinary extends Comparison {\n  /**\n   * @param {!string} tagName The XML tag name for this filter.\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   */\n  constructor(tagName, propertyName, expression, matchCase) {\n    super(tagName, propertyName);\n\n    /**\n     * @type {!(string|number)}\n     */\n    this.expression = expression;\n\n    /**\n     * @type {boolean|undefined}\n     */\n    this.matchCase = matchCase;\n  }\n}\n\nexport default ComparisonBinary;\n","/**\n * @module ol/format/filter/EqualTo\n */\nimport ComparisonBinary from './ComparisonBinary.js';\n\n/**\n * @classdesc\n * Represents a `<PropertyIsEqualTo>` comparison operator.\n * @api\n */\nclass EqualTo extends ComparisonBinary {\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   */\n  constructor(propertyName, expression, matchCase) {\n    super('PropertyIsEqualTo', propertyName, expression, matchCase);\n  }\n}\n\nexport default EqualTo;\n","/**\n * @module ol/format/filter/GreaterThan\n */\nimport ComparisonBinary from './ComparisonBinary.js';\n\n/**\n * @classdesc\n * Represents a `<PropertyIsGreaterThan>` comparison operator.\n * @api\n */\nclass GreaterThan extends ComparisonBinary {\n  /**\n   * @param {!string} propertyName Name of the context property to compare.\n   * @param {!number} expression The value to compare.\n   */\n  constructor(propertyName, expression) {\n    super('PropertyIsGreaterThan', propertyName, expression);\n  }\n}\n\nexport default GreaterThan;\n","/**\n * @module ol/format/filter/GreaterThanOrEqualTo\n */\nimport ComparisonBinary from './ComparisonBinary.js';\n\n/**\n * @classdesc\n * Represents a `<PropertyIsGreaterThanOrEqualTo>` comparison operator.\n * @api\n */\nclass GreaterThanOrEqualTo extends ComparisonBinary {\n  /**\n   * @param {!string} propertyName Name of the context property to compare.\n   * @param {!number} expression The value to compare.\n   */\n  constructor(propertyName, expression) {\n    super('PropertyIsGreaterThanOrEqualTo', propertyName, expression);\n  }\n}\n\nexport default GreaterThanOrEqualTo;\n","/**\n * @module ol/format/filter/Intersects\n */\nimport Spatial from './Spatial.js';\n\n/**\n * @classdesc\n * Represents a `<Intersects>` operator to test whether a geometry-valued property\n * intersects a given geometry.\n * @api\n */\nclass Intersects extends Spatial {\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   */\n  constructor(geometryName, geometry, srsName) {\n    super('Intersects', geometryName, geometry, srsName);\n  }\n}\n\nexport default Intersects;\n","/**\n * @module ol/format/filter/IsBetween\n */\nimport Comparison from './Comparison.js';\n\n/**\n * @classdesc\n * Represents a `<PropertyIsBetween>` comparison operator.\n * @api\n */\nclass IsBetween extends Comparison {\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   */\n  constructor(propertyName, lowerBoundary, upperBoundary) {\n    super('PropertyIsBetween', propertyName);\n\n    /**\n     * @type {!number}\n     */\n    this.lowerBoundary = lowerBoundary;\n\n    /**\n     * @type {!number}\n     */\n    this.upperBoundary = upperBoundary;\n  }\n}\n\nexport default IsBetween;\n","/**\n * @module ol/format/filter/IsLike\n */\nimport Comparison from './Comparison.js';\n\n/**\n * @classdesc\n * Represents a `<PropertyIsLike>` comparison operator.\n * @api\n */\nclass IsLike extends Comparison {\n  /**\n   * [constructor description]\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   */\n  constructor(\n    propertyName,\n    pattern,\n    wildCard,\n    singleChar,\n    escapeChar,\n    matchCase\n  ) {\n    super('PropertyIsLike', propertyName);\n\n    /**\n     * @type {!string}\n     */\n    this.pattern = pattern;\n\n    /**\n     * @type {!string}\n     */\n    this.wildCard = wildCard !== undefined ? wildCard : '*';\n\n    /**\n     * @type {!string}\n     */\n    this.singleChar = singleChar !== undefined ? singleChar : '.';\n\n    /**\n     * @type {!string}\n     */\n    this.escapeChar = escapeChar !== undefined ? escapeChar : '!';\n\n    /**\n     * @type {boolean|undefined}\n     */\n    this.matchCase = matchCase;\n  }\n}\n\nexport default IsLike;\n","/**\n * @module ol/format/filter/IsNull\n */\nimport Comparison from './Comparison.js';\n\n/**\n * @classdesc\n * Represents a `<PropertyIsNull>` comparison operator.\n * @api\n */\nclass IsNull extends Comparison {\n  /**\n   * @param {!string} propertyName Name of the context property to compare.\n   */\n  constructor(propertyName) {\n    super('PropertyIsNull', propertyName);\n  }\n}\n\nexport default IsNull;\n","/**\n * @module ol/format/filter/LessThan\n */\nimport ComparisonBinary from './ComparisonBinary.js';\n\n/**\n * @classdesc\n * Represents a `<PropertyIsLessThan>` comparison operator.\n * @api\n */\nclass LessThan extends ComparisonBinary {\n  /**\n   * @param {!string} propertyName Name of the context property to compare.\n   * @param {!number} expression The value to compare.\n   */\n  constructor(propertyName, expression) {\n    super('PropertyIsLessThan', propertyName, expression);\n  }\n}\n\nexport default LessThan;\n","/**\n * @module ol/format/filter/LessThanOrEqualTo\n */\nimport ComparisonBinary from './ComparisonBinary.js';\n\n/**\n * @classdesc\n * Represents a `<PropertyIsLessThanOrEqualTo>` comparison operator.\n * @api\n */\nclass LessThanOrEqualTo extends ComparisonBinary {\n  /**\n   * @param {!string} propertyName Name of the context property to compare.\n   * @param {!number} expression The value to compare.\n   */\n  constructor(propertyName, expression) {\n    super('PropertyIsLessThanOrEqualTo', propertyName, expression);\n  }\n}\n\nexport default LessThanOrEqualTo;\n","/**\n * @module ol/format/filter/Not\n */\nimport Filter from './Filter.js';\n\n/**\n * @classdesc\n * Represents a logical `<Not>` operator for a filter condition.\n * @api\n */\nclass Not extends Filter {\n  /**\n   * @param {!import(\"./Filter.js\").default} condition Filter condition.\n   */\n  constructor(condition) {\n    super('Not');\n\n    /**\n     * @type {!import(\"./Filter.js\").default}\n     */\n    this.condition = condition;\n  }\n}\n\nexport default Not;\n","/**\n * @module ol/format/filter/NotEqualTo\n */\nimport ComparisonBinary from './ComparisonBinary.js';\n\n/**\n * @classdesc\n * Represents a `<PropertyIsNotEqualTo>` comparison operator.\n * @api\n */\nclass NotEqualTo extends ComparisonBinary {\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   */\n  constructor(propertyName, expression, matchCase) {\n    super('PropertyIsNotEqualTo', propertyName, expression, matchCase);\n  }\n}\n\nexport default NotEqualTo;\n","/**\n * @module ol/format/filter/Or\n */\nimport LogicalNary from './LogicalNary.js';\n\n/**\n * @classdesc\n * Represents a logical `<Or>` operator between two or more filter conditions.\n * @api\n */\nclass Or extends LogicalNary {\n  /**\n   * @param {...import(\"./Filter.js\").default} conditions Conditions.\n   */\n  constructor(conditions) {\n    super('Or', Array.prototype.slice.call(arguments));\n  }\n}\n\nexport default Or;\n","/**\n * @module ol/format/filter/ResourceId\n */\nimport Filter from './Filter.js';\n\n/**\n * @classdesc\n *\n * @abstract\n */\nclass ResourceId extends Filter {\n  /**\n   * @param {!string} rid Resource ID.\n   */\n  constructor(rid) {\n    super('ResourceId');\n\n    /**\n     * @type {!string}\n     */\n    this.rid = rid;\n  }\n}\n\nexport default ResourceId;\n","/**\n * @module ol/format/filter/Within\n */\nimport Spatial from './Spatial.js';\n\n/**\n * @classdesc\n * Represents a `<Within>` operator to test whether a geometry-valued property\n * is within a given geometry.\n * @api\n */\nclass Within extends Spatial {\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   */\n  constructor(geometryName, geometry, srsName) {\n    super('Within', geometryName, geometry, srsName);\n  }\n}\n\nexport default Within;\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/WFS\n */\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 {\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 {and as andFilterFn, bbox as bboxFilterFn} from './filter.js';\nimport {assert} from '../asserts.js';\nimport {get as getProjection} from '../proj.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 * Total deleted; total inserted; total updated; array of insert ids.\n * @typedef {Object} TransactionResponse\n * @property {number} totalDeleted TotalDeleted.\n * @property {number} totalInserted TotalInserted.\n * @property {number} totalUpdated TotalUpdated.\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   */\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   */\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   */\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/WKB\n */\nimport Feature from '../Feature.js';\nimport FeatureFormat, {transformGeometryWithOptions} 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 {get as getProjection} from '../proj.js';\n\nimport SimpleGeometry from '../geom/SimpleGeometry.js';\n\n// WKB spec: https://www.ogc.org/standards/sfa\n// EWKB spec: https://raw.githubusercontent.com/postgis/postgis/2.1.0/doc/ZMSgeoms.txt\n\n/**\n * @const\n * @enum {number}\n */\nconst WKBGeometryType = {\n  POINT: 1,\n  LINE_STRING: 2,\n  POLYGON: 3,\n  MULTI_POINT: 4,\n  MULTI_LINE_STRING: 5,\n  MULTI_POLYGON: 6,\n  GEOMETRY_COLLECTION: 7,\n\n  /*\n  CIRCULAR_STRING: 8,\n  COMPOUND_CURVE: 9,\n  CURVE_POLYGON: 10,\n\n  MULTI_CURVE: 11,\n  MULTI_SURFACE: 12,\n  CURVE: 13,\n  SURFACE: 14,\n  */\n\n  POLYHEDRAL_SURFACE: 15,\n  TIN: 16,\n  TRIANGLE: 17,\n};\n\nclass WkbReader {\n  /**\n   * @param {DataView} view source to read\n   */\n  constructor(view) {\n    /** @private */\n    this.view_ = view;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.pos_ = 0;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.initialized_ = false;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.isLittleEndian_ = false;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.hasZ_ = false;\n\n    /**\n     * @type {boolean}\n     * @private\n     */\n    this.hasM_ = false;\n\n    /**\n     * @type {number|null}\n     * @private\n     */\n    this.srid_ = null;\n\n    /**\n     * @type {import(\"../geom/Geometry.js\").GeometryLayout}\n     * @private\n     */\n    this.layout_ = 'XY';\n  }\n\n  /**\n   * @return {number} value\n   */\n  readUint8() {\n    return this.view_.getUint8(this.pos_++);\n  }\n\n  /**\n   * @param {boolean} [isLittleEndian] Whether read value as little endian\n   * @return {number} value\n   */\n  readUint32(isLittleEndian) {\n    return this.view_.getUint32(\n      (this.pos_ += 4) - 4,\n      isLittleEndian !== undefined ? isLittleEndian : this.isLittleEndian_\n    );\n  }\n\n  /**\n   * @param {boolean} [isLittleEndian] Whether read value as little endian\n   * @return {number} value\n   */\n  readDouble(isLittleEndian) {\n    return this.view_.getFloat64(\n      (this.pos_ += 8) - 8,\n      isLittleEndian !== undefined ? isLittleEndian : this.isLittleEndian_\n    );\n  }\n\n  /**\n   * @return {import('../coordinate.js').Coordinate} coords for Point\n   */\n  readPoint() {\n    /** @type import('../coordinate.js').Coordinate */\n    const coords = [];\n\n    coords.push(this.readDouble());\n    coords.push(this.readDouble());\n    if (this.hasZ_) {\n      coords.push(this.readDouble());\n    }\n    if (this.hasM_) {\n      coords.push(this.readDouble());\n    }\n\n    return coords;\n  }\n\n  /**\n   * @return {Array<import('../coordinate.js').Coordinate>} coords for LineString / LinearRing\n   */\n  readLineString() {\n    const numPoints = this.readUint32();\n\n    /** @type Array<import('../coordinate.js').Coordinate> */\n    const coords = [];\n    for (let i = 0; i < numPoints; i++) {\n      coords.push(this.readPoint());\n    }\n\n    return coords;\n  }\n\n  /**\n   * @return {Array<Array<import('../coordinate.js').Coordinate>>} coords for Polygon like\n   */\n  readPolygon() {\n    const numRings = this.readUint32();\n\n    /** @type Array<Array<import('../coordinate.js').Coordinate>> */\n    const rings = [];\n    for (let i = 0; i < numRings; i++) {\n      rings.push(this.readLineString()); // as a LinearRing\n    }\n\n    return rings;\n  }\n\n  /**\n   * @param {number} [expectedTypeId] Expected WKB Type ID\n   * @return {number} WKB Type ID\n   */\n  readWkbHeader(expectedTypeId) {\n    const byteOrder = this.readUint8();\n    const isLittleEndian = byteOrder > 0;\n\n    const wkbType = this.readUint32(isLittleEndian);\n    const wkbTypeThousandth = Math.floor((wkbType & 0x0fffffff) / 1000);\n    const hasZ =\n      Boolean(wkbType & 0x80000000) ||\n      wkbTypeThousandth === 1 ||\n      wkbTypeThousandth === 3;\n    const hasM =\n      Boolean(wkbType & 0x40000000) ||\n      wkbTypeThousandth === 2 ||\n      wkbTypeThousandth === 3;\n    const hasSRID = Boolean(wkbType & 0x20000000);\n    const typeId = (wkbType & 0x0fffffff) % 1000; // Assume 1000 is an upper limit for type ID\n    const layout = /** @type {import(\"../geom/Geometry.js\").GeometryLayout} */ (\n      ['XY', hasZ ? 'Z' : '', hasM ? 'M' : ''].join('')\n    );\n\n    const srid = hasSRID ? this.readUint32(isLittleEndian) : null;\n\n    if (expectedTypeId !== undefined && expectedTypeId !== typeId) {\n      throw new Error('Unexpected WKB geometry type ' + typeId);\n    }\n\n    if (this.initialized_) {\n      // sanity checks\n      if (this.isLittleEndian_ !== isLittleEndian) {\n        throw new Error('Inconsistent endian');\n      }\n      if (this.layout_ !== layout) {\n        throw new Error('Inconsistent geometry layout');\n      }\n      if (srid && this.srid_ !== srid) {\n        throw new Error('Inconsistent coordinate system (SRID)');\n      }\n    } else {\n      this.isLittleEndian_ = isLittleEndian;\n      this.hasZ_ = hasZ;\n      this.hasM_ = hasM;\n      this.layout_ = layout;\n      this.srid_ = srid;\n      this.initialized_ = true;\n    }\n\n    return typeId;\n  }\n\n  /**\n   * @param {number} typeId WKB Type ID\n   * @return {any} values read\n   */\n  readWkbPayload(typeId) {\n    switch (typeId) {\n      case WKBGeometryType.POINT:\n        return this.readPoint();\n\n      case WKBGeometryType.LINE_STRING:\n        return this.readLineString();\n\n      case WKBGeometryType.POLYGON:\n      case WKBGeometryType.TRIANGLE:\n        return this.readPolygon();\n\n      case WKBGeometryType.MULTI_POINT:\n        return this.readMultiPoint();\n\n      case WKBGeometryType.MULTI_LINE_STRING:\n        return this.readMultiLineString();\n\n      case WKBGeometryType.MULTI_POLYGON:\n      case WKBGeometryType.POLYHEDRAL_SURFACE:\n      case WKBGeometryType.TIN:\n        return this.readMultiPolygon();\n\n      case WKBGeometryType.GEOMETRY_COLLECTION:\n        return this.readGeometryCollection();\n\n      default:\n        throw new Error(\n          'Unsupported WKB geometry type ' + typeId + ' is found'\n        );\n    }\n  }\n\n  /**\n   * @param {number} expectedTypeId Expected WKB Type ID\n   * @return {any} values read\n   */\n  readWkbBlock(expectedTypeId) {\n    return this.readWkbPayload(this.readWkbHeader(expectedTypeId));\n  }\n\n  /**\n   * @param {Function} reader reader function for each item\n   * @param {number} [expectedTypeId] Expected WKB Type ID\n   * @return {any} values read\n   */\n  readWkbCollection(reader, expectedTypeId) {\n    const num = this.readUint32();\n\n    const items = [];\n    for (let i = 0; i < num; i++) {\n      const result = reader.call(this, expectedTypeId);\n      if (result) {\n        items.push(result);\n      }\n    }\n\n    return items;\n  }\n\n  /**\n   * @return {Array<import('../coordinate.js').Coordinate>} coords for MultiPoint\n   */\n  readMultiPoint() {\n    return this.readWkbCollection(this.readWkbBlock, WKBGeometryType.POINT);\n  }\n\n  /**\n   * @return {Array<Array<import('../coordinate.js').Coordinate>>} coords for MultiLineString like\n   */\n  readMultiLineString() {\n    return this.readWkbCollection(\n      this.readWkbBlock,\n      WKBGeometryType.LINE_STRING\n    );\n  }\n\n  /**\n   * @return {Array<Array<Array<import('../coordinate.js').Coordinate>>>} coords for MultiPolygon like\n   */\n  readMultiPolygon() {\n    return this.readWkbCollection(this.readWkbBlock, WKBGeometryType.POLYGON);\n  }\n\n  /**\n   * @return {Array<import('../geom/Geometry.js').default>} array of geometries\n   */\n  readGeometryCollection() {\n    return this.readWkbCollection(this.readGeometry);\n  }\n\n  /**\n   * @return {import('../geom/Geometry.js').default} geometry\n   */\n  readGeometry() {\n    const typeId = this.readWkbHeader();\n    const result = this.readWkbPayload(typeId);\n\n    switch (typeId) {\n      case WKBGeometryType.POINT:\n        return new Point(\n          /** @type {import('../coordinate.js').Coordinate} */ (result),\n          this.layout_\n        );\n\n      case WKBGeometryType.LINE_STRING:\n        return new LineString(\n          /** @type {Array<import('../coordinate.js').Coordinate>} */ (result),\n          this.layout_\n        );\n\n      case WKBGeometryType.POLYGON:\n      case WKBGeometryType.TRIANGLE:\n        return new Polygon(\n          /** @type {Array<Array<import('../coordinate.js').Coordinate>>} */ (\n            result\n          ),\n          this.layout_\n        );\n\n      case WKBGeometryType.MULTI_POINT:\n        return new MultiPoint(\n          /** @type {Array<import('../coordinate.js').Coordinate>} */ (result),\n          this.layout_\n        );\n\n      case WKBGeometryType.MULTI_LINE_STRING:\n        return new MultiLineString(\n          /** @type {Array<Array<import('../coordinate.js').Coordinate>>} */ (\n            result\n          ),\n          this.layout_\n        );\n\n      case WKBGeometryType.MULTI_POLYGON:\n      case WKBGeometryType.POLYHEDRAL_SURFACE:\n      case WKBGeometryType.TIN:\n        return new MultiPolygon(\n          /** @type {Array<Array<Array<import('../coordinate.js').Coordinate>>>} */ (\n            result\n          ),\n          this.layout_\n        );\n\n      case WKBGeometryType.GEOMETRY_COLLECTION:\n        return new GeometryCollection(\n          /** @type {Array<import('../geom/Geometry.js').default>} */ (result)\n        );\n\n      default:\n        return null;\n    }\n  }\n\n  /**\n   * @return {number|null} SRID in the EWKB. `null` if not defined.\n   */\n  getSrid() {\n    return this.srid_;\n  }\n}\n\nclass WkbWriter {\n  /**\n   * @type {Object}\n   * @property {string} [layout] geometryLayout\n   * @property {boolean} [littleEndian=true] littleEndian\n   * @property {boolean} [ewkb=true] Whether writes in EWKB format\n   * @property {Object} [nodata] NoData value for each axes\n   * @param {Object} opts options\n   */\n  constructor(opts) {\n    opts = opts || {};\n\n    /** @type {string} */\n    this.layout_ = opts.layout;\n    this.isLittleEndian_ = opts.littleEndian !== false;\n\n    this.isEWKB_ = opts.ewkb !== false;\n\n    /** @type {Array<Array<number>>} */\n    this.writeQueue_ = [];\n\n    /**\n     * @type {Object}\n     * @property {number} X NoData value for X\n     * @property {number} Y NoData value for Y\n     * @property {number} Z NoData value for Z\n     * @property {number} M NoData value for M\n     */\n    this.nodata_ = Object.assign({X: 0, Y: 0, Z: 0, M: 0}, opts.nodata);\n  }\n\n  /**\n   * @param {number} value value\n   */\n  writeUint8(value) {\n    this.writeQueue_.push([1, value]);\n  }\n\n  /**\n   * @param {number} value value\n   */\n  writeUint32(value) {\n    this.writeQueue_.push([4, value]);\n  }\n\n  /**\n   * @param {number} value value\n   */\n  writeDouble(value) {\n    this.writeQueue_.push([8, value]);\n  }\n\n  /**\n   * @param {import('../coordinate.js').Coordinate} coords coords\n   * @param {import(\"../geom/Geometry.js\").GeometryLayout} layout layout\n   */\n  writePoint(coords, layout) {\n    /**\n     * @type {Object}\n     * @property {number} X NoData value for X\n     * @property {number} Y NoData value for Y\n     * @property {number} [Z] NoData value for Z\n     * @property {number} [M] NoData value for M\n     */\n    const coordsObj = Object.assign.apply(\n      null,\n      layout.split('').map((axis, idx) => ({[axis]: coords[idx]}))\n    );\n\n    for (const axis of this.layout_) {\n      this.writeDouble(\n        axis in coordsObj ? coordsObj[axis] : this.nodata_[axis]\n      );\n    }\n  }\n\n  /**\n   * @param {Array<import('../coordinate.js').Coordinate>} coords coords\n   * @param {import(\"../geom/Geometry.js\").GeometryLayout} layout layout\n   */\n  writeLineString(coords, layout) {\n    this.writeUint32(coords.length); // numPoints\n    for (let i = 0; i < coords.length; i++) {\n      this.writePoint(coords[i], layout);\n    }\n  }\n\n  /**\n   * @param {Array<Array<import('../coordinate.js').Coordinate>>} rings rings\n   * @param {import(\"../geom/Geometry.js\").GeometryLayout} layout layout\n   */\n  writePolygon(rings, layout) {\n    this.writeUint32(rings.length); // numRings\n    for (let i = 0; i < rings.length; i++) {\n      this.writeLineString(rings[i], layout); // as a LinearRing\n    }\n  }\n\n  /**\n   * @param {number} wkbType WKB Type ID\n   * @param {number} [srid] SRID\n   */\n  writeWkbHeader(wkbType, srid) {\n    wkbType %= 1000; // Assume 1000 is an upper limit for type ID\n    if (this.layout_.includes('Z')) {\n      wkbType += this.isEWKB_ ? 0x80000000 : 1000;\n    }\n    if (this.layout_.includes('M')) {\n      wkbType += this.isEWKB_ ? 0x40000000 : 2000;\n    }\n    if (this.isEWKB_ && Number.isInteger(srid)) {\n      wkbType |= 0x20000000;\n    }\n\n    this.writeUint8(this.isLittleEndian_ ? 1 : 0);\n    this.writeUint32(wkbType);\n    if (this.isEWKB_ && Number.isInteger(srid)) {\n      this.writeUint32(srid);\n    }\n  }\n\n  /**\n   * @param {Array<import('../coordinate.js').Coordinate>} coords coords\n   * @param {import(\"../geom/Geometry.js\").GeometryLayout} layout layout\n   */\n  writeMultiPoint(coords, layout) {\n    this.writeUint32(coords.length); // numItems\n    for (let i = 0; i < coords.length; i++) {\n      this.writeWkbHeader(1);\n      this.writePoint(coords[i], layout);\n    }\n  }\n\n  /**\n   * @param {Array<Array<import('../coordinate.js').Coordinate>>} coords coords\n   * @param {import(\"../geom/Geometry.js\").GeometryLayout} layout layout\n   */\n  writeMultiLineString(coords, layout) {\n    this.writeUint32(coords.length); // numItems\n    for (let i = 0; i < coords.length; i++) {\n      this.writeWkbHeader(2);\n      this.writeLineString(coords[i], layout);\n    }\n  }\n\n  /**\n   * @param {Array<Array<Array<import('../coordinate.js').Coordinate>>>} coords coords\n   * @param {import(\"../geom/Geometry.js\").GeometryLayout} layout layout\n   */\n  writeMultiPolygon(coords, layout) {\n    this.writeUint32(coords.length); // numItems\n    for (let i = 0; i < coords.length; i++) {\n      this.writeWkbHeader(3);\n      this.writePolygon(coords[i], layout);\n    }\n  }\n\n  /**\n   * @param {Array<import('../geom/Geometry.js').default>} geometries geometries\n   */\n  writeGeometryCollection(geometries) {\n    this.writeUint32(geometries.length); // numItems\n\n    for (let i = 0; i < geometries.length; i++) {\n      this.writeGeometry(geometries[i]);\n    }\n  }\n\n  /**\n   * @param {import(\"../geom/Geometry.js\").default} geom geometry\n   * @param {import(\"../geom/Geometry.js\").GeometryLayout} [layout] layout\n   * @return {import(\"../geom/Geometry.js\").GeometryLayout} minimum layout made by common axes\n   */\n  findMinimumLayout(geom, layout = 'XYZM') {\n    /**\n     * @param {import(\"../geom/Geometry.js\").GeometryLayout} a A\n     * @param {import(\"../geom/Geometry.js\").GeometryLayout} b B\n     * @return {import(\"../geom/Geometry.js\").GeometryLayout} minimum layout made by common axes\n     */\n    const GeometryLayout_min = (a, b) => {\n      if (a === b) {\n        return a;\n      }\n\n      if (a === 'XYZM') {\n        // anything `b` is minimum\n        return b;\n      }\n      if (b === 'XYZM') {\n        // anything `a` is minimum\n        return a;\n      }\n\n      // otherwise, incompatible\n      return 'XY';\n    };\n\n    if (geom instanceof SimpleGeometry) {\n      return GeometryLayout_min(geom.getLayout(), layout);\n    }\n\n    if (geom instanceof GeometryCollection) {\n      const geoms = geom.getGeometriesArray();\n      for (let i = 0; i < geoms.length && layout !== 'XY'; i++) {\n        layout = this.findMinimumLayout(geoms[i], layout);\n      }\n    }\n\n    return layout;\n  }\n\n  /**\n   * @param {import(\"../geom/Geometry.js\").default} geom geometry\n   * @param {number} [srid] SRID\n   */\n  writeGeometry(geom, srid) {\n    /**\n     * @type {Object<import(\"../geom/Geometry.js\").Type, WKBGeometryType>}\n     */\n    const wkblut = {\n      Point: WKBGeometryType.POINT,\n      LineString: WKBGeometryType.LINE_STRING,\n      Polygon: WKBGeometryType.POLYGON,\n      MultiPoint: WKBGeometryType.MULTI_POINT,\n      MultiLineString: WKBGeometryType.MULTI_LINE_STRING,\n      MultiPolygon: WKBGeometryType.MULTI_POLYGON,\n      GeometryCollection: WKBGeometryType.GEOMETRY_COLLECTION,\n    };\n    const geomType = geom.getType();\n    const typeId = wkblut[geomType];\n\n    if (!typeId) {\n      throw new Error('GeometryType ' + geomType + ' is not supported');\n    }\n\n    // first call of writeGeometry() traverse whole geometries to determine its output layout if not specified on constructor.\n    if (!this.layout_) {\n      this.layout_ = this.findMinimumLayout(geom);\n    }\n\n    this.writeWkbHeader(typeId, srid);\n\n    if (geom instanceof SimpleGeometry) {\n      const writerLUT = {\n        Point: this.writePoint,\n        LineString: this.writeLineString,\n        Polygon: this.writePolygon,\n        MultiPoint: this.writeMultiPoint,\n        MultiLineString: this.writeMultiLineString,\n        MultiPolygon: this.writeMultiPolygon,\n      };\n      writerLUT[geomType].call(this, geom.getCoordinates(), geom.getLayout());\n    } else if (geom instanceof GeometryCollection) {\n      this.writeGeometryCollection(geom.getGeometriesArray());\n    }\n  }\n\n  getBuffer() {\n    const byteLength = this.writeQueue_.reduce((acc, item) => acc + item[0], 0);\n    const buffer = new ArrayBuffer(byteLength);\n    const view = new DataView(buffer);\n\n    let pos = 0;\n    this.writeQueue_.forEach((item) => {\n      switch (item[0]) {\n        case 1:\n          view.setUint8(pos, item[1]);\n          break;\n        case 4:\n          view.setUint32(pos, item[1], this.isLittleEndian_);\n          break;\n        case 8:\n          view.setFloat64(pos, item[1], this.isLittleEndian_);\n          break;\n        default:\n          break;\n      }\n\n      pos += item[0];\n    });\n\n    return buffer;\n  }\n}\n\n/**\n * @typedef {Object} Options\n * @property {boolean} [splitCollection=false] Whether to split GeometryCollections into multiple features on reading.\n * @property {boolean} [hex=true] Returns hex string instead of ArrayBuffer for output. This also is used as a hint internally whether it should load contents as text or ArrayBuffer on reading.\n * @property {boolean} [littleEndian=true] Use littleEndian for output.\n * @property {boolean} [ewkb=true] Use EWKB format for output.\n * @property {import(\"../geom/Geometry.js\").GeometryLayout} [geometryLayout=null] Use specific coordinate layout for output features (null: auto detect)\n * @property {number} [nodataZ=0] If the `geometryLayout` doesn't match with geometry to be output, this value is used to fill missing coordinate value of Z.\n * @property {number} [nodataM=0] If the `geometryLayout` doesn't match with geometry to be output, this value is used to fill missing coordinate value of M.\n * @property {number|boolean} [srid=true] SRID for output. Specify integer value to enforce the value as a SRID. Specify `true` to extract from `dataProjection`. `false` to suppress the output. This option only takes effect when `ewkb` is `true`.\n */\n\n/**\n * @classdesc\n * Geometry format for reading and writing data in the `Well-Known Binary` (WKB) format.\n * Also supports `Extended Well-Known Binary` (EWKB) format, used in PostGIS for example.\n *\n * @api\n */\nclass WKB extends FeatureFormat {\n  /**\n   * @param {Options} [options] Optional configuration object.\n   */\n  constructor(options) {\n    super();\n\n    options = options ? options : {};\n\n    this.splitCollection = Boolean(options.splitCollection);\n\n    this.viewCache_ = null;\n\n    this.hex_ = options.hex !== false;\n    this.littleEndian_ = options.littleEndian !== false;\n    this.ewkb_ = options.ewkb !== false;\n\n    this.layout_ = options.geometryLayout; // null for auto detect\n    this.nodataZ_ = options.nodataZ || 0;\n    this.nodataM_ = options.nodataM || 0;\n\n    this.srid_ = options.srid;\n  }\n\n  /**\n   * @return {import(\"./Feature.js\").Type} Format.\n   */\n  getType() {\n    return this.hex_ ? 'text' : 'arraybuffer';\n  }\n\n  /**\n   * Read a single feature from a source.\n   *\n   * @param {string|ArrayBuffer|ArrayBufferView} source Source.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @return {import(\"../Feature.js\").default} Feature.\n   * @api\n   */\n  readFeature(source, options) {\n    return new Feature({\n      geometry: this.readGeometry(source, options),\n    });\n  }\n\n  /**\n   * Read all features from a source.\n   *\n   * @param {string|ArrayBuffer|ArrayBufferView} source Source.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @return {Array<import(\"../Feature.js\").default>} Features.\n   * @api\n   */\n  readFeatures(source, options) {\n    let geometries = [];\n    const geometry = this.readGeometry(source, options);\n    if (this.splitCollection && geometry instanceof GeometryCollection) {\n      geometries = geometry.getGeometriesArray();\n    } else {\n      geometries = [geometry];\n    }\n    return geometries.map((geometry) => new Feature({geometry}));\n  }\n\n  /**\n   * Read a single geometry from a source.\n   *\n   * @param {string|ArrayBuffer|ArrayBufferView} source Source.\n   * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n   * @return {import(\"../geom/Geometry.js\").default} Geometry.\n   * @api\n   */\n  readGeometry(source, options) {\n    const view = getDataView(source);\n    if (!view) {\n      return null;\n    }\n\n    const reader = new WkbReader(view);\n    const geometry = reader.readGeometry();\n\n    this.viewCache_ = view; // cache for internal subsequent call of readProjection()\n    options = this.getReadOptions(source, options);\n    this.viewCache_ = null; // release\n\n    return transformGeometryWithOptions(geometry, false, options);\n  }\n\n  /**\n   * Read the projection from a source.\n   *\n   * @param {string|ArrayBuffer|ArrayBufferView} source Source.\n   * @return {import(\"../proj/Projection.js\").default|undefined} Projection.\n   * @api\n   */\n  readProjection(source) {\n    const view = this.viewCache_ || getDataView(source);\n    if (!view) {\n      return undefined;\n    }\n\n    const reader = new WkbReader(view);\n    reader.readWkbHeader();\n\n    return (\n      (reader.getSrid() && getProjection('EPSG:' + reader.getSrid())) ||\n      undefined\n    );\n  }\n\n  /**\n   * Encode a feature in this format.\n   *\n   * @param {import(\"../Feature.js\").default} feature Feature.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n   * @return {string|ArrayBuffer} Result.\n   * @api\n   */\n  writeFeature(feature, options) {\n    return this.writeGeometry(feature.getGeometry(), options);\n  }\n\n  /**\n   * Encode an array of features in this format.\n   *\n   * @param {Array<import(\"../Feature.js\").default>} features Features.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n   * @return {string|ArrayBuffer} Result.\n   * @api\n   */\n  writeFeatures(features, options) {\n    return this.writeGeometry(\n      new GeometryCollection(features.map((f) => f.getGeometry())),\n      options\n    );\n  }\n\n  /**\n   * Write a single geometry in this format.\n   *\n   * @param {import(\"../geom/Geometry.js\").default} geometry Geometry.\n   * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n   * @return {string|ArrayBuffer} Result.\n   * @api\n   */\n  writeGeometry(geometry, options) {\n    options = this.adaptOptions(options);\n\n    const writer = new WkbWriter({\n      layout: this.layout_,\n      littleEndian: this.littleEndian_,\n      ewkb: this.ewkb_,\n\n      nodata: {\n        Z: this.nodataZ_,\n        M: this.nodataM_,\n      },\n    });\n\n    // extract SRID from `dataProjection`\n    let srid = Number.isInteger(this.srid_) ? Number(this.srid_) : null;\n    if (this.srid_ !== false && !Number.isInteger(this.srid_)) {\n      const dataProjection =\n        options.dataProjection && getProjection(options.dataProjection);\n      if (dataProjection) {\n        const code = dataProjection.getCode();\n        if (code.startsWith('EPSG:')) {\n          srid = Number(code.substring(5));\n        }\n      }\n    }\n\n    writer.writeGeometry(\n      transformGeometryWithOptions(geometry, true, options),\n      srid\n    );\n    const buffer = writer.getBuffer();\n\n    return this.hex_ ? encodeHexString(buffer) : buffer;\n  }\n}\n\n/**\n * @param {ArrayBuffer} buffer source buffer\n * @return {string} encoded hex string\n */\nfunction encodeHexString(buffer) {\n  const view = new Uint8Array(buffer);\n  return Array.from(view.values())\n    .map((x) => (x < 16 ? '0' : '') + Number(x).toString(16).toUpperCase())\n    .join('');\n}\n\n/**\n * @param {string} text source text\n * @return {DataView} decoded binary buffer\n */\nfunction decodeHexString(text) {\n  const buffer = new Uint8Array(text.length / 2);\n  for (let i = 0; i < text.length / 2; i++) {\n    buffer[i] = parseInt(text.substr(i * 2, 2), 16);\n  }\n  return new DataView(buffer.buffer);\n}\n\n/**\n * @param {string | ArrayBuffer | ArrayBufferView} source source\n * @return {DataView} data view\n */\nfunction getDataView(source) {\n  if (typeof source === 'string') {\n    return decodeHexString(source);\n  }\n  if (ArrayBuffer.isView(source)) {\n    if (source instanceof DataView) {\n      return source;\n    }\n    return new DataView(source.buffer, source.byteOffset, source.byteLength);\n  }\n  if (source instanceof ArrayBuffer) {\n    return new DataView(source);\n  }\n  return null;\n}\n\nexport default WKB;\n","/**\n * @module ol/format/WKT\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 TextFeature from './TextFeature.js';\nimport {transformGeometryWithOptions} from './Feature.js';\n\n/**\n * Geometry constructors\n * @enum {function (new:import(\"../geom/Geometry.js\").default, Array, import(\"../geom/Geometry.js\").GeometryLayout)}\n */\nconst GeometryConstructor = {\n  'POINT': Point,\n  'LINESTRING': LineString,\n  'POLYGON': Polygon,\n  'MULTIPOINT': MultiPoint,\n  'MULTILINESTRING': MultiLineString,\n  'MULTIPOLYGON': MultiPolygon,\n};\n\n/**\n * @typedef {Object} Options\n * @property {boolean} [splitCollection=false] Whether to split GeometryCollections into\n * multiple features on reading.\n */\n\n/**\n * @typedef {Object} Token\n * @property {number} type Type.\n * @property {number|string} [value] Value.\n * @property {number} position Position.\n */\n\n/**\n * @const\n * @type {string}\n */\nconst EMPTY = 'EMPTY';\n\n/**\n * @const\n * @type {string}\n */\nconst Z = 'Z';\n\n/**\n * @const\n * @type {string}\n */\nconst M = 'M';\n\n/**\n * @const\n * @type {string}\n */\nconst ZM = 'ZM';\n\n/**\n * @const\n * @enum {number}\n */\nconst TokenType = {\n  START: 0,\n  TEXT: 1,\n  LEFT_PAREN: 2,\n  RIGHT_PAREN: 3,\n  NUMBER: 4,\n  COMMA: 5,\n  EOF: 6,\n};\n\n/**\n * @type {Object<import(\"../geom/Geometry.js\").Type, string>}\n */\nconst wktTypeLookup = {\n  Point: 'POINT',\n  LineString: 'LINESTRING',\n  Polygon: 'POLYGON',\n  MultiPoint: 'MULTIPOINT',\n  MultiLineString: 'MULTILINESTRING',\n  MultiPolygon: 'MULTIPOLYGON',\n  GeometryCollection: 'GEOMETRYCOLLECTION',\n  Circle: 'CIRCLE',\n};\n\n/**\n * Class to tokenize a WKT string.\n */\nclass Lexer {\n  /**\n   * @param {string} wkt WKT string.\n   */\n  constructor(wkt) {\n    /**\n     * @type {string}\n     */\n    this.wkt = wkt;\n\n    /**\n     * @type {number}\n     * @private\n     */\n    this.index_ = -1;\n  }\n\n  /**\n   * @param {string} c Character.\n   * @return {boolean} Whether the character is alphabetic.\n   * @private\n   */\n  isAlpha_(c) {\n    return (c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z');\n  }\n\n  /**\n   * @param {string} c Character.\n   * @param {boolean} [decimal] Whether the string number\n   *     contains a dot, i.e. is a decimal number.\n   * @return {boolean} Whether the character is numeric.\n   * @private\n   */\n  isNumeric_(c, decimal) {\n    decimal = decimal !== undefined ? decimal : false;\n    return (c >= '0' && c <= '9') || (c == '.' && !decimal);\n  }\n\n  /**\n   * @param {string} c Character.\n   * @return {boolean} Whether the character is whitespace.\n   * @private\n   */\n  isWhiteSpace_(c) {\n    return c == ' ' || c == '\\t' || c == '\\r' || c == '\\n';\n  }\n\n  /**\n   * @return {string} Next string character.\n   * @private\n   */\n  nextChar_() {\n    return this.wkt.charAt(++this.index_);\n  }\n\n  /**\n   * Fetch and return the next token.\n   * @return {Token} Next string token.\n   */\n  nextToken() {\n    const c = this.nextChar_();\n    const position = this.index_;\n    /** @type {number|string} */\n    let value = c;\n    let type;\n\n    if (c == '(') {\n      type = TokenType.LEFT_PAREN;\n    } else if (c == ',') {\n      type = TokenType.COMMA;\n    } else if (c == ')') {\n      type = TokenType.RIGHT_PAREN;\n    } else if (this.isNumeric_(c) || c == '-') {\n      type = TokenType.NUMBER;\n      value = this.readNumber_();\n    } else if (this.isAlpha_(c)) {\n      type = TokenType.TEXT;\n      value = this.readText_();\n    } else if (this.isWhiteSpace_(c)) {\n      return this.nextToken();\n    } else if (c === '') {\n      type = TokenType.EOF;\n    } else {\n      throw new Error('Unexpected character: ' + c);\n    }\n\n    return {position: position, value: value, type: type};\n  }\n\n  /**\n   * @return {number} Numeric token value.\n   * @private\n   */\n  readNumber_() {\n    let c;\n    const index = this.index_;\n    let decimal = false;\n    let scientificNotation = false;\n    do {\n      if (c == '.') {\n        decimal = true;\n      } else if (c == 'e' || c == 'E') {\n        scientificNotation = true;\n      }\n      c = this.nextChar_();\n    } while (\n      this.isNumeric_(c, decimal) ||\n      // if we haven't detected a scientific number before, 'e' or 'E'\n      // hint that we should continue to read\n      (!scientificNotation && (c == 'e' || c == 'E')) ||\n      // once we know that we have a scientific number, both '-' and '+'\n      // are allowed\n      (scientificNotation && (c == '-' || c == '+'))\n    );\n    return parseFloat(this.wkt.substring(index, this.index_--));\n  }\n\n  /**\n   * @return {string} String token value.\n   * @private\n   */\n  readText_() {\n    let c;\n    const index = this.index_;\n    do {\n      c = this.nextChar_();\n    } while (this.isAlpha_(c));\n    return this.wkt.substring(index, this.index_--).toUpperCase();\n  }\n}\n\n/**\n * Class to parse the tokens from the WKT string.\n */\nclass Parser {\n  /**\n   * @param {Lexer} lexer The lexer.\n   */\n  constructor(lexer) {\n    /**\n     * @type {Lexer}\n     * @private\n     */\n    this.lexer_ = lexer;\n\n    /**\n     * @type {Token}\n     * @private\n     */\n    this.token_ = {\n      position: 0,\n      type: TokenType.START,\n    };\n\n    /**\n     * @type {import(\"../geom/Geometry.js\").GeometryLayout}\n     * @private\n     */\n    this.layout_ = 'XY';\n  }\n\n  /**\n   * Fetch the next token form the lexer and replace the active token.\n   * @private\n   */\n  consume_() {\n    this.token_ = this.lexer_.nextToken();\n  }\n\n  /**\n   * Tests if the given type matches the type of the current token.\n   * @param {TokenType} type Token type.\n   * @return {boolean} Whether the token matches the given type.\n   */\n  isTokenType(type) {\n    return this.token_.type == type;\n  }\n\n  /**\n   * If the given type matches the current token, consume it.\n   * @param {TokenType} type Token type.\n   * @return {boolean} Whether the token matches the given type.\n   */\n  match(type) {\n    const isMatch = this.isTokenType(type);\n    if (isMatch) {\n      this.consume_();\n    }\n    return isMatch;\n  }\n\n  /**\n   * Try to parse the tokens provided by the lexer.\n   * @return {import(\"../geom/Geometry.js\").default} The geometry.\n   */\n  parse() {\n    this.consume_();\n    return this.parseGeometry_();\n  }\n\n  /**\n   * Try to parse the dimensional info.\n   * @return {import(\"../geom/Geometry.js\").GeometryLayout} The layout.\n   * @private\n   */\n  parseGeometryLayout_() {\n    /** @type {import(\"../geom/Geometry.js\").GeometryLayout} */\n    let layout = 'XY';\n    const dimToken = this.token_;\n    if (this.isTokenType(TokenType.TEXT)) {\n      const dimInfo = dimToken.value;\n      if (dimInfo === Z) {\n        layout = 'XYZ';\n      } else if (dimInfo === M) {\n        layout = 'XYM';\n      } else if (dimInfo === ZM) {\n        layout = 'XYZM';\n      }\n      if (layout !== 'XY') {\n        this.consume_();\n      }\n    }\n    return layout;\n  }\n\n  /**\n   * @return {Array<import(\"../geom/Geometry.js\").default>} A collection of geometries.\n   * @private\n   */\n  parseGeometryCollectionText_() {\n    if (this.match(TokenType.LEFT_PAREN)) {\n      const geometries = [];\n      do {\n        geometries.push(this.parseGeometry_());\n      } while (this.match(TokenType.COMMA));\n      if (this.match(TokenType.RIGHT_PAREN)) {\n        return geometries;\n      }\n    }\n    throw new Error(this.formatErrorMessage_());\n  }\n\n  /**\n   * @return {Array<number>} All values in a point.\n   * @private\n   */\n  parsePointText_() {\n    if (this.match(TokenType.LEFT_PAREN)) {\n      const coordinates = this.parsePoint_();\n      if (this.match(TokenType.RIGHT_PAREN)) {\n        return coordinates;\n      }\n    }\n    throw new Error(this.formatErrorMessage_());\n  }\n\n  /**\n   * @return {Array<Array<number>>} All points in a linestring.\n   * @private\n   */\n  parseLineStringText_() {\n    if (this.match(TokenType.LEFT_PAREN)) {\n      const coordinates = this.parsePointList_();\n      if (this.match(TokenType.RIGHT_PAREN)) {\n        return coordinates;\n      }\n    }\n    throw new Error(this.formatErrorMessage_());\n  }\n\n  /**\n   * @return {Array<Array<Array<number>>>} All points in a polygon.\n   * @private\n   */\n  parsePolygonText_() {\n    if (this.match(TokenType.LEFT_PAREN)) {\n      const coordinates = this.parseLineStringTextList_();\n      if (this.match(TokenType.RIGHT_PAREN)) {\n        return coordinates;\n      }\n    }\n    throw new Error(this.formatErrorMessage_());\n  }\n\n  /**\n   * @return {Array<Array<number>>} All points in a multipoint.\n   * @private\n   */\n  parseMultiPointText_() {\n    if (this.match(TokenType.LEFT_PAREN)) {\n      let coordinates;\n      if (this.token_.type == TokenType.LEFT_PAREN) {\n        coordinates = this.parsePointTextList_();\n      } else {\n        coordinates = this.parsePointList_();\n      }\n      if (this.match(TokenType.RIGHT_PAREN)) {\n        return coordinates;\n      }\n    }\n    throw new Error(this.formatErrorMessage_());\n  }\n\n  /**\n   * @return {Array<Array<Array<number>>>} All linestring points\n   *                                          in a multilinestring.\n   * @private\n   */\n  parseMultiLineStringText_() {\n    if (this.match(TokenType.LEFT_PAREN)) {\n      const coordinates = this.parseLineStringTextList_();\n      if (this.match(TokenType.RIGHT_PAREN)) {\n        return coordinates;\n      }\n    }\n    throw new Error(this.formatErrorMessage_());\n  }\n\n  /**\n   * @return {Array<Array<Array<Array<number>>>>} All polygon points in a multipolygon.\n   * @private\n   */\n  parseMultiPolygonText_() {\n    if (this.match(TokenType.LEFT_PAREN)) {\n      const coordinates = this.parsePolygonTextList_();\n      if (this.match(TokenType.RIGHT_PAREN)) {\n        return coordinates;\n      }\n    }\n    throw new Error(this.formatErrorMessage_());\n  }\n\n  /**\n   * @return {Array<number>} A point.\n   * @private\n   */\n  parsePoint_() {\n    const coordinates = [];\n    const dimensions = this.layout_.length;\n    for (let i = 0; i < dimensions; ++i) {\n      const token = this.token_;\n      if (this.match(TokenType.NUMBER)) {\n        coordinates.push(/** @type {number} */ (token.value));\n      } else {\n        break;\n      }\n    }\n    if (coordinates.length == dimensions) {\n      return coordinates;\n    }\n    throw new Error(this.formatErrorMessage_());\n  }\n\n  /**\n   * @return {Array<Array<number>>} An array of points.\n   * @private\n   */\n  parsePointList_() {\n    const coordinates = [this.parsePoint_()];\n    while (this.match(TokenType.COMMA)) {\n      coordinates.push(this.parsePoint_());\n    }\n    return coordinates;\n  }\n\n  /**\n   * @return {Array<Array<number>>} An array of points.\n   * @private\n   */\n  parsePointTextList_() {\n    const coordinates = [this.parsePointText_()];\n    while (this.match(TokenType.COMMA)) {\n      coordinates.push(this.parsePointText_());\n    }\n    return coordinates;\n  }\n\n  /**\n   * @return {Array<Array<Array<number>>>} An array of points.\n   * @private\n   */\n  parseLineStringTextList_() {\n    const coordinates = [this.parseLineStringText_()];\n    while (this.match(TokenType.COMMA)) {\n      coordinates.push(this.parseLineStringText_());\n    }\n    return coordinates;\n  }\n\n  /**\n   * @return {Array<Array<Array<Array<number>>>>} An array of points.\n   * @private\n   */\n  parsePolygonTextList_() {\n    const coordinates = [this.parsePolygonText_()];\n    while (this.match(TokenType.COMMA)) {\n      coordinates.push(this.parsePolygonText_());\n    }\n    return coordinates;\n  }\n\n  /**\n   * @return {boolean} Whether the token implies an empty geometry.\n   * @private\n   */\n  isEmptyGeometry_() {\n    const isEmpty =\n      this.isTokenType(TokenType.TEXT) && this.token_.value == EMPTY;\n    if (isEmpty) {\n      this.consume_();\n    }\n    return isEmpty;\n  }\n\n  /**\n   * Create an error message for an unexpected token error.\n   * @return {string} Error message.\n   * @private\n   */\n  formatErrorMessage_() {\n    return (\n      'Unexpected `' +\n      this.token_.value +\n      '` at position ' +\n      this.token_.position +\n      ' in `' +\n      this.lexer_.wkt +\n      '`'\n    );\n  }\n\n  /**\n   * @return {import(\"../geom/Geometry.js\").default} The geometry.\n   * @private\n   */\n  parseGeometry_() {\n    const token = this.token_;\n    if (this.match(TokenType.TEXT)) {\n      const geomType = /** @type {string} */ (token.value);\n      this.layout_ = this.parseGeometryLayout_();\n      const isEmpty = this.isEmptyGeometry_();\n      if (geomType == 'GEOMETRYCOLLECTION') {\n        if (isEmpty) {\n          return new GeometryCollection([]);\n        }\n        const geometries = this.parseGeometryCollectionText_();\n        return new GeometryCollection(geometries);\n      }\n      const ctor = GeometryConstructor[geomType];\n      if (!ctor) {\n        throw new Error('Invalid geometry type: ' + geomType);\n      }\n\n      let coordinates;\n\n      if (isEmpty) {\n        if (geomType == 'POINT') {\n          coordinates = [NaN, NaN];\n        } else {\n          coordinates = [];\n        }\n      } else {\n        switch (geomType) {\n          case 'POINT': {\n            coordinates = this.parsePointText_();\n            break;\n          }\n          case 'LINESTRING': {\n            coordinates = this.parseLineStringText_();\n            break;\n          }\n          case 'POLYGON': {\n            coordinates = this.parsePolygonText_();\n            break;\n          }\n          case 'MULTIPOINT': {\n            coordinates = this.parseMultiPointText_();\n            break;\n          }\n          case 'MULTILINESTRING': {\n            coordinates = this.parseMultiLineStringText_();\n            break;\n          }\n          case 'MULTIPOLYGON': {\n            coordinates = this.parseMultiPolygonText_();\n            break;\n          }\n          default:\n            break;\n        }\n      }\n\n      return new ctor(coordinates, this.layout_);\n    }\n    throw new Error(this.formatErrorMessage_());\n  }\n}\n\n/**\n * @classdesc\n * Geometry format for reading and writing data in the `WellKnownText` (WKT)\n * format.\n *\n * @api\n */\nclass WKT extends TextFeature {\n  /**\n   * @param {Options} [options] Options.\n   */\n  constructor(options) {\n    super();\n\n    options = options ? options : {};\n\n    /**\n     * Split GeometryCollection into multiple features.\n     * @type {boolean}\n     * @private\n     */\n    this.splitCollection_ =\n      options.splitCollection !== undefined ? options.splitCollection : false;\n  }\n\n  /**\n   * Parse a WKT string.\n   * @param {string} wkt WKT string.\n   * @return {import(\"../geom/Geometry.js\").default}\n   *     The geometry created.\n   * @private\n   */\n  parse_(wkt) {\n    const lexer = new Lexer(wkt);\n    const parser = new Parser(lexer);\n    return parser.parse();\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   */\n  readFeatureFromText(text, options) {\n    const geom = this.readGeometryFromText(text, options);\n    const feature = new Feature();\n    feature.setGeometry(geom);\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   */\n  readFeaturesFromText(text, options) {\n    let geometries = [];\n    const geometry = this.readGeometryFromText(text, options);\n    if (this.splitCollection_ && geometry.getType() == 'GeometryCollection') {\n      geometries = /** @type {GeometryCollection} */ (\n        geometry\n      ).getGeometriesArray();\n    } else {\n      geometries = [geometry];\n    }\n    const features = [];\n    for (let i = 0, ii = geometries.length; i < ii; ++i) {\n      const feature = new Feature();\n      feature.setGeometry(geometries[i]);\n      features.push(feature);\n    }\n    return features;\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   */\n  readGeometryFromText(text, options) {\n    const geometry = this.parse_(text);\n    return transformGeometryWithOptions(geometry, false, options);\n  }\n\n  /**\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    const geometry = feature.getGeometry();\n    if (geometry) {\n      return this.writeGeometryText(geometry, options);\n    }\n    return '';\n  }\n\n  /**\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    if (features.length == 1) {\n      return this.writeFeatureText(features[0], options);\n    }\n    const geometries = [];\n    for (let i = 0, ii = features.length; i < ii; ++i) {\n      geometries.push(features[i].getGeometry());\n    }\n    const collection = new GeometryCollection(geometries);\n    return this.writeGeometryText(collection, options);\n  }\n\n  /**\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 encode(transformGeometryWithOptions(geometry, true, options));\n  }\n}\n\n/**\n * @param {Point} geom Point geometry.\n * @return {string} Coordinates part of Point as WKT.\n */\nfunction encodePointGeometry(geom) {\n  const coordinates = geom.getCoordinates();\n  if (coordinates.length === 0) {\n    return '';\n  }\n  return coordinates.join(' ');\n}\n\n/**\n * @param {MultiPoint} geom MultiPoint geometry.\n * @return {string} Coordinates part of MultiPoint as WKT.\n */\nfunction encodeMultiPointGeometry(geom) {\n  const array = [];\n  const components = geom.getPoints();\n  for (let i = 0, ii = components.length; i < ii; ++i) {\n    array.push('(' + encodePointGeometry(components[i]) + ')');\n  }\n  return array.join(',');\n}\n\n/**\n * @param {GeometryCollection} geom GeometryCollection geometry.\n * @return {string} Coordinates part of GeometryCollection as WKT.\n */\nfunction encodeGeometryCollectionGeometry(geom) {\n  const array = [];\n  const geoms = geom.getGeometries();\n  for (let i = 0, ii = geoms.length; i < ii; ++i) {\n    array.push(encode(geoms[i]));\n  }\n  return array.join(',');\n}\n\n/**\n * @param {LineString|import(\"../geom/LinearRing.js\").default} geom LineString geometry.\n * @return {string} Coordinates part of LineString as WKT.\n */\nfunction encodeLineStringGeometry(geom) {\n  const coordinates = geom.getCoordinates();\n  const array = [];\n  for (let i = 0, ii = coordinates.length; i < ii; ++i) {\n    array.push(coordinates[i].join(' '));\n  }\n  return array.join(',');\n}\n\n/**\n * @param {MultiLineString} geom MultiLineString geometry.\n * @return {string} Coordinates part of MultiLineString as WKT.\n */\nfunction encodeMultiLineStringGeometry(geom) {\n  const array = [];\n  const components = geom.getLineStrings();\n  for (let i = 0, ii = components.length; i < ii; ++i) {\n    array.push('(' + encodeLineStringGeometry(components[i]) + ')');\n  }\n  return array.join(',');\n}\n\n/**\n * @param {Polygon} geom Polygon geometry.\n * @return {string} Coordinates part of Polygon as WKT.\n */\nfunction encodePolygonGeometry(geom) {\n  const array = [];\n  const rings = geom.getLinearRings();\n  for (let i = 0, ii = rings.length; i < ii; ++i) {\n    array.push('(' + encodeLineStringGeometry(rings[i]) + ')');\n  }\n  return array.join(',');\n}\n\n/**\n * @param {MultiPolygon} geom MultiPolygon geometry.\n * @return {string} Coordinates part of MultiPolygon as WKT.\n */\nfunction encodeMultiPolygonGeometry(geom) {\n  const array = [];\n  const components = geom.getPolygons();\n  for (let i = 0, ii = components.length; i < ii; ++i) {\n    array.push('(' + encodePolygonGeometry(components[i]) + ')');\n  }\n  return array.join(',');\n}\n\n/**\n * @param {import(\"../geom/SimpleGeometry.js\").default} geom SimpleGeometry geometry.\n * @return {string} Potential dimensional information for WKT type.\n */\nfunction encodeGeometryLayout(geom) {\n  const layout = geom.getLayout();\n  let dimInfo = '';\n  if (layout === 'XYZ' || layout === 'XYZM') {\n    dimInfo += Z;\n  }\n  if (layout === 'XYM' || layout === 'XYZM') {\n    dimInfo += M;\n  }\n  return dimInfo;\n}\n\n/**\n * @const\n * @type {Object<string, function(import(\"../geom/Geometry.js\").default): string>}\n */\nconst GeometryEncoder = {\n  'Point': encodePointGeometry,\n  'LineString': encodeLineStringGeometry,\n  'Polygon': encodePolygonGeometry,\n  'MultiPoint': encodeMultiPointGeometry,\n  'MultiLineString': encodeMultiLineStringGeometry,\n  'MultiPolygon': encodeMultiPolygonGeometry,\n  'GeometryCollection': encodeGeometryCollectionGeometry,\n};\n\n/**\n * Encode a geometry as WKT.\n * @param {import(\"../geom/Geometry.js\").default} geom The geometry to encode.\n * @return {string} WKT string for the geometry.\n */\nfunction encode(geom) {\n  const type = geom.getType();\n  const geometryEncoder = GeometryEncoder[type];\n  const enc = geometryEncoder(geom);\n  let wktType = wktTypeLookup[type];\n  if (typeof (/** @type {?} */ (geom).getFlatCoordinates) === 'function') {\n    const dimInfo = encodeGeometryLayout(\n      /** @type {import(\"../geom/SimpleGeometry.js\").default} */ (geom)\n    );\n    if (dimInfo.length > 0) {\n      wktType += ' ' + dimInfo;\n    }\n  }\n  if (enc.length === 0) {\n    return wktType + ' ' + EMPTY;\n  }\n  return wktType + '(' + enc + ')';\n}\n\nexport default WKT;\n","/**\n * @module ol/format/WMSCapabilities\n */\nimport XML from './XML.js';\nimport {\n  makeArrayPusher,\n  makeObjectPropertyPusher,\n  makeObjectPropertySetter,\n  makeStructureNS,\n  pushParseAndPop,\n} from '../xml.js';\nimport {\n  readBooleanString,\n  readDecimal,\n  readDecimalString,\n  readNonNegativeIntegerString,\n  readPositiveInteger,\n  readString,\n} from './xsd.js';\nimport {readHref} from './xlink.js';\n\n/**\n * @const\n * @type {Array<null|string>}\n */\nconst NAMESPACE_URIS = [null, 'http://www.opengis.net/wms'];\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Service': makeObjectPropertySetter(readService),\n  'Capability': makeObjectPropertySetter(readCapability),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst CAPABILITY_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Request': makeObjectPropertySetter(readRequest),\n  'Exception': makeObjectPropertySetter(readException),\n  'Layer': makeObjectPropertySetter(readCapabilityLayer),\n});\n\n/**\n * @classdesc\n * Format for reading WMS capabilities data\n *\n * @api\n */\nclass WMSCapabilities extends XML {\n  constructor() {\n    super();\n\n    /**\n     * @type {string|undefined}\n     */\n    this.version = undefined;\n  }\n\n  /**\n   * @param {Element} node Node.\n   * @return {Object|null} Object\n   */\n  readFromNode(node) {\n    this.version = node.getAttribute('version').trim();\n    const wmsCapabilityObject = pushParseAndPop(\n      {\n        'version': this.version,\n      },\n      PARSERS,\n      node,\n      []\n    );\n    return wmsCapabilityObject ? wmsCapabilityObject : null;\n  }\n}\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst SERVICE_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Name': makeObjectPropertySetter(readString),\n  'Title': makeObjectPropertySetter(readString),\n  'Abstract': makeObjectPropertySetter(readString),\n  'KeywordList': makeObjectPropertySetter(readKeywordList),\n  'OnlineResource': makeObjectPropertySetter(readHref),\n  'ContactInformation': makeObjectPropertySetter(readContactInformation),\n  'Fees': makeObjectPropertySetter(readString),\n  'AccessConstraints': makeObjectPropertySetter(readString),\n  'LayerLimit': makeObjectPropertySetter(readPositiveInteger),\n  'MaxWidth': makeObjectPropertySetter(readPositiveInteger),\n  'MaxHeight': makeObjectPropertySetter(readPositiveInteger),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst CONTACT_INFORMATION_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'ContactPersonPrimary': makeObjectPropertySetter(readContactPersonPrimary),\n  'ContactPosition': makeObjectPropertySetter(readString),\n  'ContactAddress': makeObjectPropertySetter(readContactAddress),\n  'ContactVoiceTelephone': makeObjectPropertySetter(readString),\n  'ContactFacsimileTelephone': makeObjectPropertySetter(readString),\n  'ContactElectronicMailAddress': makeObjectPropertySetter(readString),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst CONTACT_PERSON_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'ContactPerson': makeObjectPropertySetter(readString),\n  'ContactOrganization': makeObjectPropertySetter(readString),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst CONTACT_ADDRESS_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'AddressType': makeObjectPropertySetter(readString),\n  'Address': makeObjectPropertySetter(readString),\n  'City': makeObjectPropertySetter(readString),\n  'StateOrProvince': makeObjectPropertySetter(readString),\n  'PostCode': makeObjectPropertySetter(readString),\n  'Country': makeObjectPropertySetter(readString),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst EXCEPTION_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Format': makeArrayPusher(readString),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst LAYER_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Name': makeObjectPropertySetter(readString),\n  'Title': makeObjectPropertySetter(readString),\n  'Abstract': makeObjectPropertySetter(readString),\n  'KeywordList': makeObjectPropertySetter(readKeywordList),\n  'CRS': makeObjectPropertyPusher(readString),\n  'EX_GeographicBoundingBox': makeObjectPropertySetter(\n    readEXGeographicBoundingBox\n  ),\n  'BoundingBox': makeObjectPropertyPusher(readBoundingBox),\n  'Dimension': makeObjectPropertyPusher(readDimension),\n  'Attribution': makeObjectPropertySetter(readAttribution),\n  'AuthorityURL': makeObjectPropertyPusher(readAuthorityURL),\n  'Identifier': makeObjectPropertyPusher(readString),\n  'MetadataURL': makeObjectPropertyPusher(readMetadataURL),\n  'DataURL': makeObjectPropertyPusher(readFormatOnlineresource),\n  'FeatureListURL': makeObjectPropertyPusher(readFormatOnlineresource),\n  'Style': makeObjectPropertyPusher(readStyle),\n  'MinScaleDenominator': makeObjectPropertySetter(readDecimal),\n  'MaxScaleDenominator': makeObjectPropertySetter(readDecimal),\n  'Layer': makeObjectPropertyPusher(readLayer),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst ATTRIBUTION_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Title': makeObjectPropertySetter(readString),\n  'OnlineResource': makeObjectPropertySetter(readHref),\n  'LogoURL': makeObjectPropertySetter(readSizedFormatOnlineresource),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst EX_GEOGRAPHIC_BOUNDING_BOX_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'westBoundLongitude': makeObjectPropertySetter(readDecimal),\n  'eastBoundLongitude': makeObjectPropertySetter(readDecimal),\n  'southBoundLatitude': makeObjectPropertySetter(readDecimal),\n  'northBoundLatitude': makeObjectPropertySetter(readDecimal),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst REQUEST_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'GetCapabilities': makeObjectPropertySetter(readOperationType),\n  'GetMap': makeObjectPropertySetter(readOperationType),\n  'GetFeatureInfo': makeObjectPropertySetter(readOperationType),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst OPERATIONTYPE_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Format': makeObjectPropertyPusher(readString),\n  'DCPType': makeObjectPropertyPusher(readDCPType),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst DCPTYPE_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': makeObjectPropertySetter(readFormatOnlineresource),\n  'Post': makeObjectPropertySetter(readFormatOnlineresource),\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  'Name': makeObjectPropertySetter(readString),\n  'Title': makeObjectPropertySetter(readString),\n  'Abstract': makeObjectPropertySetter(readString),\n  'LegendURL': makeObjectPropertyPusher(readSizedFormatOnlineresource),\n  'StyleSheetURL': makeObjectPropertySetter(readFormatOnlineresource),\n  'StyleURL': makeObjectPropertySetter(readFormatOnlineresource),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst FORMAT_ONLINERESOURCE_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Format': makeObjectPropertySetter(readString),\n  'OnlineResource': makeObjectPropertySetter(readHref),\n});\n\n/**\n * @const\n * @type {Object<string, Object<string, import(\"../xml.js\").Parser>>}\n */\n// @ts-ignore\nconst KEYWORDLIST_PARSERS = makeStructureNS(NAMESPACE_URIS, {\n  'Keyword': makeArrayPusher(readString),\n});\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Attribution object.\n */\nfunction readAttribution(node, objectStack) {\n  return pushParseAndPop({}, ATTRIBUTION_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object} Bounding box object.\n */\nfunction readBoundingBox(node, objectStack) {\n  const extent = [\n    readDecimalString(node.getAttribute('minx')),\n    readDecimalString(node.getAttribute('miny')),\n    readDecimalString(node.getAttribute('maxx')),\n    readDecimalString(node.getAttribute('maxy')),\n  ];\n\n  const resolutions = [\n    readDecimalString(node.getAttribute('resx')),\n    readDecimalString(node.getAttribute('resy')),\n  ];\n\n  return {\n    'crs': node.getAttribute('CRS'),\n    'extent': extent,\n    'res': resolutions,\n  };\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {import(\"../extent.js\").Extent|undefined} Bounding box object.\n */\nfunction readEXGeographicBoundingBox(node, objectStack) {\n  const geographicBoundingBox = pushParseAndPop(\n    {},\n    EX_GEOGRAPHIC_BOUNDING_BOX_PARSERS,\n    node,\n    objectStack\n  );\n  if (!geographicBoundingBox) {\n    return undefined;\n  }\n  const westBoundLongitude =\n    /** @type {number|undefined} */\n    (geographicBoundingBox['westBoundLongitude']);\n  const southBoundLatitude =\n    /** @type {number|undefined} */\n    (geographicBoundingBox['southBoundLatitude']);\n  const eastBoundLongitude =\n    /** @type {number|undefined} */\n    (geographicBoundingBox['eastBoundLongitude']);\n  const northBoundLatitude =\n    /** @type {number|undefined} */\n    (geographicBoundingBox['northBoundLatitude']);\n  if (\n    westBoundLongitude === undefined ||\n    southBoundLatitude === undefined ||\n    eastBoundLongitude === undefined ||\n    northBoundLatitude === undefined\n  ) {\n    return undefined;\n  }\n  return [\n    westBoundLongitude,\n    southBoundLatitude,\n    eastBoundLongitude,\n    northBoundLatitude,\n  ];\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Capability object.\n */\nfunction readCapability(node, objectStack) {\n  return pushParseAndPop({}, CAPABILITY_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Service object.\n */\nfunction readService(node, objectStack) {\n  return pushParseAndPop({}, SERVICE_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Contact information object.\n */\nfunction readContactInformation(node, objectStack) {\n  return pushParseAndPop({}, CONTACT_INFORMATION_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Contact person object.\n */\nfunction readContactPersonPrimary(node, objectStack) {\n  return pushParseAndPop({}, CONTACT_PERSON_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Contact address object.\n */\nfunction readContactAddress(node, objectStack) {\n  return pushParseAndPop({}, CONTACT_ADDRESS_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Array<string>|undefined} Format array.\n */\nfunction readException(node, objectStack) {\n  return pushParseAndPop([], EXCEPTION_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Layer object.\n */\nfunction readCapabilityLayer(node, objectStack) {\n  const layerObject = pushParseAndPop({}, LAYER_PARSERS, node, objectStack);\n\n  if (layerObject['Layer'] === undefined) {\n    return Object.assign(layerObject, readLayer(node, objectStack));\n  }\n\n  return layerObject;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Layer object.\n */\nfunction readLayer(node, objectStack) {\n  const parentLayerObject = /**  @type {!Object<string,*>} */ (\n    objectStack[objectStack.length - 1]\n  );\n\n  const layerObject = pushParseAndPop({}, LAYER_PARSERS, node, objectStack);\n\n  if (!layerObject) {\n    return undefined;\n  }\n  let queryable = readBooleanString(node.getAttribute('queryable'));\n  if (queryable === undefined) {\n    queryable = parentLayerObject['queryable'];\n  }\n  layerObject['queryable'] = queryable !== undefined ? queryable : false;\n\n  let cascaded = readNonNegativeIntegerString(node.getAttribute('cascaded'));\n  if (cascaded === undefined) {\n    cascaded = parentLayerObject['cascaded'];\n  }\n  layerObject['cascaded'] = cascaded;\n\n  let opaque = readBooleanString(node.getAttribute('opaque'));\n  if (opaque === undefined) {\n    opaque = parentLayerObject['opaque'];\n  }\n  layerObject['opaque'] = opaque !== undefined ? opaque : false;\n\n  let noSubsets = readBooleanString(node.getAttribute('noSubsets'));\n  if (noSubsets === undefined) {\n    noSubsets = parentLayerObject['noSubsets'];\n  }\n  layerObject['noSubsets'] = noSubsets !== undefined ? noSubsets : false;\n\n  let fixedWidth = readDecimalString(node.getAttribute('fixedWidth'));\n  if (!fixedWidth) {\n    fixedWidth = parentLayerObject['fixedWidth'];\n  }\n  layerObject['fixedWidth'] = fixedWidth;\n\n  let fixedHeight = readDecimalString(node.getAttribute('fixedHeight'));\n  if (!fixedHeight) {\n    fixedHeight = parentLayerObject['fixedHeight'];\n  }\n  layerObject['fixedHeight'] = fixedHeight;\n\n  // See 7.2.4.8\n  const addKeys = ['Style', 'CRS', 'AuthorityURL'];\n  addKeys.forEach(function (key) {\n    if (key in parentLayerObject) {\n      const childValue = layerObject[key] || [];\n      layerObject[key] = childValue.concat(parentLayerObject[key]);\n    }\n  });\n\n  const replaceKeys = [\n    'EX_GeographicBoundingBox',\n    'BoundingBox',\n    'Dimension',\n    'Attribution',\n    'MinScaleDenominator',\n    'MaxScaleDenominator',\n  ];\n  replaceKeys.forEach(function (key) {\n    if (!(key in layerObject)) {\n      const parentValue = parentLayerObject[key];\n      layerObject[key] = parentValue;\n    }\n  });\n\n  return layerObject;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object} Dimension object.\n */\nfunction readDimension(node, objectStack) {\n  const dimensionObject = {\n    'name': node.getAttribute('name'),\n    'units': node.getAttribute('units'),\n    'unitSymbol': node.getAttribute('unitSymbol'),\n    'default': node.getAttribute('default'),\n    'multipleValues': readBooleanString(node.getAttribute('multipleValues')),\n    'nearestValue': readBooleanString(node.getAttribute('nearestValue')),\n    'current': readBooleanString(node.getAttribute('current')),\n    'values': readString(node),\n  };\n  return dimensionObject;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Online resource object.\n */\nfunction readFormatOnlineresource(node, objectStack) {\n  return pushParseAndPop({}, FORMAT_ONLINERESOURCE_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Request object.\n */\nfunction readRequest(node, objectStack) {\n  return pushParseAndPop({}, REQUEST_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} DCP type object.\n */\nfunction readDCPType(node, objectStack) {\n  return pushParseAndPop({}, DCPTYPE_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} 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} Operation type object.\n */\nfunction readOperationType(node, objectStack) {\n  return pushParseAndPop({}, OPERATIONTYPE_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Online resource object.\n */\nfunction readSizedFormatOnlineresource(node, objectStack) {\n  const formatOnlineresource = readFormatOnlineresource(node, objectStack);\n  if (formatOnlineresource) {\n    const size = [\n      readNonNegativeIntegerString(node.getAttribute('width')),\n      readNonNegativeIntegerString(node.getAttribute('height')),\n    ];\n    formatOnlineresource['size'] = size;\n    return formatOnlineresource;\n  }\n  return undefined;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Authority URL object.\n */\nfunction readAuthorityURL(node, objectStack) {\n  const authorityObject = readFormatOnlineresource(node, objectStack);\n  if (authorityObject) {\n    authorityObject['name'] = node.getAttribute('name');\n    return authorityObject;\n  }\n  return undefined;\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Object|undefined} Metadata URL object.\n */\nfunction readMetadataURL(node, objectStack) {\n  const metadataObject = readFormatOnlineresource(node, objectStack);\n  if (metadataObject) {\n    metadataObject['type'] = node.getAttribute('type');\n    return metadataObject;\n  }\n  return undefined;\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  return pushParseAndPop({}, STYLE_PARSERS, node, objectStack);\n}\n\n/**\n * @param {Element} node Node.\n * @param {Array<*>} objectStack Object stack.\n * @return {Array<string>|undefined} Keyword list.\n */\nfunction readKeywordList(node, objectStack) {\n  return pushParseAndPop([], KEYWORDLIST_PARSERS, node, objectStack);\n}\n\nexport default WMSCapabilities;\n","/**\n * @module ol/format/WMSGetFeatureInfo\n */\nimport GML2 from './GML2.js';\nimport XMLFeature from './XMLFeature.js';\nimport {extend} from '../array.js';\nimport {makeArrayPusher, makeStructureNS, pushParseAndPop} from '../xml.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   */\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/format/WMTSCapabilities\n */\nimport OWS from './OWS.js';\nimport XML from './XML.js';\nimport {boundingExtent} from '../extent.js';\nimport {\n  makeArrayPusher,\n  makeObjectPropertyPusher,\n  makeObjectPropertySetter,\n  makeStructureNS,\n  pushParseAndPop,\n} from '../xml.js';\nimport {readDecimal, readPositiveInteger, readString} from './xsd.js';\nimport {readHref} from './xlink.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   */\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    '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} 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 Control from './Control.js';\nimport EventType from '../events/EventType.js';\nimport MapProperty from '../MapProperty.js';\nimport {CLASS_CONTROL, CLASS_UNSELECTABLE, CLASS_UNSUPPORTED} from '../css.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport {replaceNode} from '../dom.js';\n\nconst events = [\n  'fullscreenchange',\n  'webkitfullscreenchange',\n  'MSFullscreenChange',\n];\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\").OnSignature<import(\"../Observable\").EventTypes|\n *     'enterfullscreen'|'leavefullscreen', import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types, import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|\n *     'enterfullscreen'|'leavefullscreen'|import(\"../ObjectEventType\").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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {FullScreenOnSignature<import(\"../events\").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   */\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 Control from './Control.js';\nimport EventType from '../pointer/EventType.js';\nimport {\n  get as getProjection,\n  getTransformFromProjections,\n  getUserProjection,\n  identityTransform,\n} from '../proj.js';\nimport {listen} from '../events.js';\nimport {wrapX} from '../coordinate.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\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types|\n *     'change:coordinateFormat'|'change:projection', import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {MousePositionOnSignature<import(\"../events\").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   */\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 Control from './Control.js';\nimport EventType from '../events/EventType.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 {\n  containsExtent,\n  equals as equalsExtent,\n  getBottomRight,\n  getTopLeft,\n  scaleFromCenter,\n} from '../extent.js';\nimport {listen, listenOnce} from '../events.js';\nimport {fromExtent as polygonFromExtent} from '../geom/Polygon.js';\nimport {replaceNode} from '../dom.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 scope = this;\n\n    const overlay = this.boxOverlay_;\n    const overlayBox = this.boxOverlay_.getElement();\n\n    /* Functions definition */\n\n    const computeDesiredMousePosition = function (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.getEventCoordinateInternal(\n        /** @type {MouseEvent} */ (position)\n      );\n\n      overlay.setPosition(coordinates);\n    };\n\n    const endMoving = function (event) {\n      const coordinates = ovmap.getEventCoordinateInternal(event);\n\n      scope.getMap().getView().setCenterInternal(coordinates);\n\n      window.removeEventListener('mousemove', move);\n      window.removeEventListener('mouseup', endMoving);\n    };\n\n    /* Binding */\n\n    overlayBox.addEventListener('mousedown', function () {\n      window.addEventListener('mousemove', move);\n      window.addEventListener('mouseup', 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   */\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        if (view.isDef()) {\n          this.ovmap_.updateSize();\n          this.resetExtent_();\n        }\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\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.getCenterInternal();\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      function (event) {\n        delete this.ovmapPostrenderKey_;\n        this.updateBox_();\n      },\n      this\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 Control from './Control.js';\nimport {CLASS_UNSELECTABLE} from '../css.js';\nimport {METERS_PER_UNIT, getPointResolution} from '../proj.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\").OnSignature<import(\"../Observable\").EventTypes, import(\"../events/Event.js\").default, Return> &\n *   import(\"../Observable\").OnSignature<import(\"../ObjectEventType\").Types|\n *     'change:units', import(\"../Object\").ObjectEvent, Return> &\n *   import(\"../Observable\").CombinedOnSignature<import(\"../Observable\").EventTypes|import(\"../ObjectEventType\").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 *\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\").EventsKey>}\n     */\n    this.on;\n\n    /***\n     * @type {ScaleLineOnSignature<import(\"../events\").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 < 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, 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 Control from './Control.js';\nimport EventType from '../events/EventType.js';\nimport PointerEventType from '../pointer/EventType.js';\nimport {CLASS_CONTROL, CLASS_UNSELECTABLE} from '../css.js';\nimport {clamp} from '../math.js';\nimport {easeOut} from '../easing.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport {stopPropagation} from '../events/Event.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   */\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","/**\n * @module ol/control/ZoomToExtent\n */\nimport Control from './Control.js';\nimport EventType from '../events/EventType.js';\nimport {CLASS_CONTROL, CLASS_UNSELECTABLE} from '../css.js';\nimport {fromExtent as polygonFromExtent} from '../geom/Polygon.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 */\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    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      : this.extent;\n    view.fitInternal(polygonFromExtent(extent));\n  }\n}\n\nexport default ZoomToExtent;\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 {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$TileCache from './ol/TileCache.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$VectorTile from './ol/VectorTile.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 {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 {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 {normalize as _ol_color$normalize} 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 {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 {getFontParameters as _ol_css$getFontParameters} from './ol/css.js';\nimport {createCanvasContext2D as _ol_dom$createCanvasContext2D} 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 {removeNode as _ol_dom$removeNode} 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 {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 {FIREFOX as _ol_has$FIREFOX} from './ol/has.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 {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 {fromKey as _ol_tilecoord$fromKey} from './ol/tilecoord.js';\nimport {hash as _ol_tilecoord$hash} 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 {expandUrl as _ol_tileurlfunction$expandUrl} 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 {appendParams as _ol_uri$appendParams} 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 {ARRAY_BUFFER as _ol_webgl$ARRAY_BUFFER} from './ol/webgl.js';\nimport {ELEMENT_ARRAY_BUFFER as _ol_webgl$ELEMENT_ARRAY_BUFFER} from './ol/webgl.js';\nimport {STREAM_DRAW as _ol_webgl$STREAM_DRAW} from './ol/webgl.js';\nimport {STATIC_DRAW as _ol_webgl$STATIC_DRAW} from './ol/webgl.js';\nimport {DYNAMIC_DRAW as _ol_webgl$DYNAMIC_DRAW} from './ol/webgl.js';\nimport {UNSIGNED_BYTE as _ol_webgl$UNSIGNED_BYTE} from './ol/webgl.js';\nimport {UNSIGNED_SHORT as _ol_webgl$UNSIGNED_SHORT} from './ol/webgl.js';\nimport {UNSIGNED_INT as _ol_webgl$UNSIGNED_INT} from './ol/webgl.js';\nimport {FLOAT as _ol_webgl$FLOAT} from './ol/webgl.js';\nimport {getContext as _ol_webgl$getContext} from './ol/webgl.js';\nimport {getSupportedExtensions as _ol_webgl$getSupportedExtensions} from './ol/webgl.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 $ol$webgl$BaseTileRepresentation from './ol/webgl/BaseTileRepresentation.js';\nimport $ol$webgl$Buffer from './ol/webgl/Buffer.js';\nimport {getArrayClassForType as _ol_webgl_Buffer$getArrayClassForType} from './ol/webgl/Buffer.js';\nimport $ol$webgl$Helper from './ol/webgl/Helper.js';\nimport {computeAttributesStride as _ol_webgl_Helper$computeAttributesStride} from './ol/webgl/Helper.js';\nimport $ol$webgl$PaletteTexture from './ol/webgl/PaletteTexture.js';\nimport $ol$webgl$PostProcessingPass from './ol/webgl/PostProcessingPass.js';\nimport $ol$webgl$RenderTarget from './ol/webgl/RenderTarget.js';\nimport {COMMON_HEADER as _ol_webgl_ShaderBuilder$COMMON_HEADER} from './ol/webgl/ShaderBuilder.js';\nimport {ShaderBuilder as _ol_webgl_ShaderBuilder$ShaderBuilder} from './ol/webgl/ShaderBuilder.js';\nimport $ol$webgl$TileGeometry from './ol/webgl/TileGeometry.js';\nimport $ol$webgl$TileTexture from './ol/webgl/TileTexture.js';\nimport {expressionToGlsl as _ol_webgl_styleparser$expressionToGlsl} from './ol/webgl/styleparser.js';\nimport {packColor as _ol_webgl_styleparser$packColor} from './ol/webgl/styleparser.js';\nimport {computeHash as _ol_webgl_styleparser$computeHash} from './ol/webgl/styleparser.js';\nimport {parseLiteralStyle as _ol_webgl_styleparser$parseLiteralStyle} from './ol/webgl/styleparser.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 $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 {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 $ol$structs$LinkedList from './ol/structs/LinkedList.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$CartoDB from './ol/source/CartoDB.js';\nimport $ol$source$Cluster from './ol/source/Cluster.js';\nimport $ol$source$DataTile from './ol/source/DataTile.js';\nimport $ol$source$GeoTIFF from './ol/source/GeoTIFF.js';\nimport $ol$source$IIIF from './ol/source/IIIF.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$ImageMapGuide from './ol/source/ImageMapGuide.js';\nimport $ol$source$ImageStatic from './ol/source/ImageStatic.js';\nimport $ol$source$ImageWMS from './ol/source/ImageWMS.js';\nimport $ol$source$OGCMapTile from './ol/source/OGCMapTile.js';\nimport $ol$source$OGCVectorTile from './ol/source/OGCVectorTile.js';\nimport {ATTRIBUTION as _ol_source_OSM$ATTRIBUTION} from './ol/source/OSM.js';\nimport $ol$source$OSM from './ol/source/OSM.js';\nimport {newImageData as _ol_source_Raster$newImageData} from './ol/source/Raster.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 $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$VectorTile from './ol/source/VectorTile.js';\nimport {defaultLoadFunction as _ol_source_VectorTile$defaultLoadFunction} from './ol/source/VectorTile.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 {CustomTile as _ol_source_Zoomify$CustomTile} from './ol/source/Zoomify.js';\nimport $ol$source$Zoomify from './ol/source/Zoomify.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_mapguide$createLoader} from './ol/source/mapguide.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 {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 $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$webgl$Layer from './ol/renderer/webgl/Layer.js';\nimport $ol$renderer$webgl$PointsLayer from './ol/renderer/webgl/PointsLayer.js';\nimport {Uniforms as _ol_renderer_webgl_TileLayer$Uniforms} from './ol/renderer/webgl/TileLayer.js';\nimport {Attributes as _ol_renderer_webgl_TileLayer$Attributes} from './ol/renderer/webgl/TileLayer.js';\nimport $ol$renderer$webgl$TileLayer from './ol/renderer/webgl/TileLayer.js';\nimport {Uniforms as _ol_renderer_webgl_TileLayerBase$Uniforms} from './ol/renderer/webgl/TileLayerBase.js';\nimport {newTileRepresentationLookup as _ol_renderer_webgl_TileLayerBase$newTileRepresentationLookup} from './ol/renderer/webgl/TileLayerBase.js';\nimport {getCacheKey as _ol_renderer_webgl_TileLayerBase$getCacheKey} from './ol/renderer/webgl/TileLayerBase.js';\nimport $ol$renderer$webgl$TileLayerBase from './ol/renderer/webgl/TileLayerBase.js';\nimport {Uniforms as _ol_renderer_webgl_VectorLayer$Uniforms} from './ol/renderer/webgl/VectorLayer.js';\nimport $ol$renderer$webgl$VectorLayer from './ol/renderer/webgl/VectorLayer.js';\nimport {Uniforms as _ol_renderer_webgl_VectorTileLayer$Uniforms} from './ol/renderer/webgl/VectorTileLayer.js';\nimport {Attributes as _ol_renderer_webgl_VectorTileLayer$Attributes} from './ol/renderer/webgl/VectorTileLayer.js';\nimport $ol$renderer$webgl$VectorTileLayer from './ol/renderer/webgl/VectorTileLayer.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$renderer$canvas$VectorTileLayer from './ol/renderer/canvas/VectorTileLayer.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 {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$webgl$MixedGeometryBatch from './ol/render/webgl/MixedGeometryBatch.js';\nimport $ol$render$webgl$VectorStyleRenderer from './ol/render/webgl/VectorStyleRenderer.js';\nimport {getCustomAttributesSize as _ol_render_webgl_renderinstructions$getCustomAttributesSize} from './ol/render/webgl/renderinstructions.js';\nimport {generatePointRenderInstructions as _ol_render_webgl_renderinstructions$generatePointRenderInstructions} from './ol/render/webgl/renderinstructions.js';\nimport {generateLineStringRenderInstructions as _ol_render_webgl_renderinstructions$generateLineStringRenderInstructions} from './ol/render/webgl/renderinstructions.js';\nimport {generatePolygonRenderInstructions as _ol_render_webgl_renderinstructions$generatePolygonRenderInstructions} from './ol/render/webgl/renderinstructions.js';\nimport {LINESTRING_ANGLE_COSINE_CUTOFF as _ol_render_webgl_utils$LINESTRING_ANGLE_COSINE_CUTOFF} from './ol/render/webgl/utils.js';\nimport {writePointFeatureToBuffers as _ol_render_webgl_utils$writePointFeatureToBuffers} from './ol/render/webgl/utils.js';\nimport {writeLineSegmentToBuffers as _ol_render_webgl_utils$writeLineSegmentToBuffers} from './ol/render/webgl/utils.js';\nimport {writePolygonTrianglesToBuffers as _ol_render_webgl_utils$writePolygonTrianglesToBuffers} from './ol/render/webgl/utils.js';\nimport {getBlankImageData as _ol_render_webgl_utils$getBlankImageData} from './ol/render/webgl/utils.js';\nimport {colorEncodeId as _ol_render_webgl_utils$colorEncodeId} from './ol/render/webgl/utils.js';\nimport {colorDecodeId as _ol_render_webgl_utils$colorDecodeId} from './ol/render/webgl/utils.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 $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 {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 {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 $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$layer$VectorTile from './ol/layer/VectorTile.js';\nimport $ol$layer$WebGLPoints from './ol/layer/WebGLPoints.js';\nimport $ol$layer$WebGLTile from './ol/layer/WebGLTile.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 {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$EsriJSON from './ol/format/EsriJSON.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$GML from './ol/format/GML.js';\nimport $ol$format$GML2 from './ol/format/GML2.js';\nimport $ol$format$GML3 from './ol/format/GML3.js';\nimport $ol$format$GML32 from './ol/format/GML32.js';\nimport {GMLNS as _ol_format_GMLBase$GMLNS} from './ol/format/GMLBase.js';\nimport $ol$format$GMLBase from './ol/format/GMLBase.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$IIIFInfo from './ol/format/IIIFInfo.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$WKB from './ol/format/WKB.js';\nimport $ol$format$WKT from './ol/format/WKT.js';\nimport $ol$format$WMSCapabilities from './ol/format/WMSCapabilities.js';\nimport $ol$format$WMSGetFeatureInfo from './ol/format/WMSGetFeatureInfo.js';\nimport $ol$format$WMTSCapabilities from './ol/format/WMTSCapabilities.js';\nimport $ol$format$XML from './ol/format/XML.js';\nimport $ol$format$XMLFeature from './ol/format/XMLFeature.js';\nimport {and as _ol_format_filter$and} from './ol/format/filter.js';\nimport {or as _ol_format_filter$or} from './ol/format/filter.js';\nimport {not as _ol_format_filter$not} from './ol/format/filter.js';\nimport {bbox as _ol_format_filter$bbox} from './ol/format/filter.js';\nimport {contains as _ol_format_filter$contains} from './ol/format/filter.js';\nimport {intersects as _ol_format_filter$intersects} from './ol/format/filter.js';\nimport {disjoint as _ol_format_filter$disjoint} from './ol/format/filter.js';\nimport {within as _ol_format_filter$within} from './ol/format/filter.js';\nimport {dwithin as _ol_format_filter$dwithin} from './ol/format/filter.js';\nimport {equalTo as _ol_format_filter$equalTo} from './ol/format/filter.js';\nimport {notEqualTo as _ol_format_filter$notEqualTo} from './ol/format/filter.js';\nimport {lessThan as _ol_format_filter$lessThan} from './ol/format/filter.js';\nimport {lessThanOrEqualTo as _ol_format_filter$lessThanOrEqualTo} from './ol/format/filter.js';\nimport {greaterThan as _ol_format_filter$greaterThan} from './ol/format/filter.js';\nimport {greaterThanOrEqualTo as _ol_format_filter$greaterThanOrEqualTo} from './ol/format/filter.js';\nimport {isNull as _ol_format_filter$isNull} from './ol/format/filter.js';\nimport {between as _ol_format_filter$between} from './ol/format/filter.js';\nimport {like as _ol_format_filter$like} from './ol/format/filter.js';\nimport {during as _ol_format_filter$during} from './ol/format/filter.js';\nimport {resourceId as _ol_format_filter$resourceId} from './ol/format/filter.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 $ol$format$filter$And from './ol/format/filter/And.js';\nimport $ol$format$filter$Bbox from './ol/format/filter/Bbox.js';\nimport $ol$format$filter$Comparison from './ol/format/filter/Comparison.js';\nimport $ol$format$filter$ComparisonBinary from './ol/format/filter/ComparisonBinary.js';\nimport $ol$format$filter$Contains from './ol/format/filter/Contains.js';\nimport $ol$format$filter$DWithin from './ol/format/filter/DWithin.js';\nimport $ol$format$filter$Disjoint from './ol/format/filter/Disjoint.js';\nimport $ol$format$filter$During from './ol/format/filter/During.js';\nimport $ol$format$filter$EqualTo from './ol/format/filter/EqualTo.js';\nimport $ol$format$filter$Filter from './ol/format/filter/Filter.js';\nimport $ol$format$filter$GreaterThan from './ol/format/filter/GreaterThan.js';\nimport $ol$format$filter$GreaterThanOrEqualTo from './ol/format/filter/GreaterThanOrEqualTo.js';\nimport $ol$format$filter$Intersects from './ol/format/filter/Intersects.js';\nimport $ol$format$filter$IsBetween from './ol/format/filter/IsBetween.js';\nimport $ol$format$filter$IsLike from './ol/format/filter/IsLike.js';\nimport $ol$format$filter$IsNull from './ol/format/filter/IsNull.js';\nimport $ol$format$filter$LessThan from './ol/format/filter/LessThan.js';\nimport $ol$format$filter$LessThanOrEqualTo from './ol/format/filter/LessThanOrEqualTo.js';\nimport $ol$format$filter$LogicalNary from './ol/format/filter/LogicalNary.js';\nimport $ol$format$filter$Not from './ol/format/filter/Not.js';\nimport $ol$format$filter$NotEqualTo from './ol/format/filter/NotEqualTo.js';\nimport $ol$format$filter$Or from './ol/format/filter/Or.js';\nimport $ol$format$filter$ResourceId from './ol/format/filter/ResourceId.js';\nimport $ol$format$filter$Spatial from './ol/format/filter/Spatial.js';\nimport $ol$format$filter$Within from './ol/format/filter/Within.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 {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 {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 {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 {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.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.TileCache = $ol$TileCache;\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.VectorTile = $ol$VectorTile;\nol.View = $ol$View;\nol.View.createCenterConstraint = _ol_View$createCenterConstraint;\nol.View.createResolutionConstraint = _ol_View$createResolutionConstraint;\nol.View.createRotationConstraint = _ol_View$createRotationConstraint;\nol.View.isNoopAnimation = _ol_View$isNoopAnimation;\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.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.normalize = _ol_color$normalize;\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.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.getFontParameters = _ol_css$getFontParameters;\nol.dom = {};\nol.dom.createCanvasContext2D = _ol_dom$createCanvasContext2D;\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.removeNode = _ol_dom$removeNode;\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.StringType = _ol_expr_expression$StringType;\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.PALETTE_TEXTURE_ARRAY = _ol_expr_gpu$PALETTE_TEXTURE_ARRAY;\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.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.EsriJSON = $ol$format$EsriJSON;\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.GML = $ol$format$GML;\nol.format.GML2 = $ol$format$GML2;\nol.format.GML3 = $ol$format$GML3;\nol.format.GML32 = $ol$format$GML32;\nol.format.GMLBase = $ol$format$GMLBase;\nol.format.GMLBase.GMLNS = _ol_format_GMLBase$GMLNS;\nol.format.GPX = $ol$format$GPX;\nol.format.GeoJSON = $ol$format$GeoJSON;\nol.format.IGC = $ol$format$IGC;\nol.format.IIIFInfo = $ol$format$IIIFInfo;\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.WKB = $ol$format$WKB;\nol.format.WKT = $ol$format$WKT;\nol.format.WMSCapabilities = $ol$format$WMSCapabilities;\nol.format.WMSGetFeatureInfo = $ol$format$WMSGetFeatureInfo;\nol.format.WMTSCapabilities = $ol$format$WMTSCapabilities;\nol.format.XML = $ol$format$XML;\nol.format.XMLFeature = $ol$format$XMLFeature;\nol.format.filter = {};\nol.format.filter.And = $ol$format$filter$And;\nol.format.filter.Bbox = $ol$format$filter$Bbox;\nol.format.filter.Comparison = $ol$format$filter$Comparison;\nol.format.filter.ComparisonBinary = $ol$format$filter$ComparisonBinary;\nol.format.filter.Contains = $ol$format$filter$Contains;\nol.format.filter.DWithin = $ol$format$filter$DWithin;\nol.format.filter.Disjoint = $ol$format$filter$Disjoint;\nol.format.filter.During = $ol$format$filter$During;\nol.format.filter.EqualTo = $ol$format$filter$EqualTo;\nol.format.filter.Filter = $ol$format$filter$Filter;\nol.format.filter.GreaterThan = $ol$format$filter$GreaterThan;\nol.format.filter.GreaterThanOrEqualTo = $ol$format$filter$GreaterThanOrEqualTo;\nol.format.filter.Intersects = $ol$format$filter$Intersects;\nol.format.filter.IsBetween = $ol$format$filter$IsBetween;\nol.format.filter.IsLike = $ol$format$filter$IsLike;\nol.format.filter.IsNull = $ol$format$filter$IsNull;\nol.format.filter.LessThan = $ol$format$filter$LessThan;\nol.format.filter.LessThanOrEqualTo = $ol$format$filter$LessThanOrEqualTo;\nol.format.filter.LogicalNary = $ol$format$filter$LogicalNary;\nol.format.filter.Not = $ol$format$filter$Not;\nol.format.filter.NotEqualTo = $ol$format$filter$NotEqualTo;\nol.format.filter.Or = $ol$format$filter$Or;\nol.format.filter.ResourceId = $ol$format$filter$ResourceId;\nol.format.filter.Spatial = $ol$format$filter$Spatial;\nol.format.filter.Within = $ol$format$filter$Within;\nol.format.filter.and = _ol_format_filter$and;\nol.format.filter.bbox = _ol_format_filter$bbox;\nol.format.filter.between = _ol_format_filter$between;\nol.format.filter.contains = _ol_format_filter$contains;\nol.format.filter.disjoint = _ol_format_filter$disjoint;\nol.format.filter.during = _ol_format_filter$during;\nol.format.filter.dwithin = _ol_format_filter$dwithin;\nol.format.filter.equalTo = _ol_format_filter$equalTo;\nol.format.filter.greaterThan = _ol_format_filter$greaterThan;\nol.format.filter.greaterThanOrEqualTo = _ol_format_filter$greaterThanOrEqualTo;\nol.format.filter.intersects = _ol_format_filter$intersects;\nol.format.filter.isNull = _ol_format_filter$isNull;\nol.format.filter.lessThan = _ol_format_filter$lessThan;\nol.format.filter.lessThanOrEqualTo = _ol_format_filter$lessThanOrEqualTo;\nol.format.filter.like = _ol_format_filter$like;\nol.format.filter.not = _ol_format_filter$not;\nol.format.filter.notEqualTo = _ol_format_filter$notEqualTo;\nol.format.filter.or = _ol_format_filter$or;\nol.format.filter.resourceId = _ol_format_filter$resourceId;\nol.format.filter.within = _ol_format_filter$within;\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.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.FIREFOX = _ol_has$FIREFOX;\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.layer.VectorTile = $ol$layer$VectorTile;\nol.layer.WebGLPoints = $ol$layer$WebGLPoints;\nol.layer.WebGLTile = $ol$layer$WebGLTile;\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.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.getEPSGLookup = _ol_proj_proj4$getEPSGLookup;\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.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.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.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.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.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.render.webgl = {};\nol.render.webgl.MixedGeometryBatch = $ol$render$webgl$MixedGeometryBatch;\nol.render.webgl.VectorStyleRenderer = $ol$render$webgl$VectorStyleRenderer;\nol.render.webgl.renderinstructions = {};\nol.render.webgl.renderinstructions.generateLineStringRenderInstructions = _ol_render_webgl_renderinstructions$generateLineStringRenderInstructions;\nol.render.webgl.renderinstructions.generatePointRenderInstructions = _ol_render_webgl_renderinstructions$generatePointRenderInstructions;\nol.render.webgl.renderinstructions.generatePolygonRenderInstructions = _ol_render_webgl_renderinstructions$generatePolygonRenderInstructions;\nol.render.webgl.renderinstructions.getCustomAttributesSize = _ol_render_webgl_renderinstructions$getCustomAttributesSize;\nol.render.webgl.utils = {};\nol.render.webgl.utils.LINESTRING_ANGLE_COSINE_CUTOFF = _ol_render_webgl_utils$LINESTRING_ANGLE_COSINE_CUTOFF;\nol.render.webgl.utils.colorDecodeId = _ol_render_webgl_utils$colorDecodeId;\nol.render.webgl.utils.colorEncodeId = _ol_render_webgl_utils$colorEncodeId;\nol.render.webgl.utils.getBlankImageData = _ol_render_webgl_utils$getBlankImageData;\nol.render.webgl.utils.writeLineSegmentToBuffers = _ol_render_webgl_utils$writeLineSegmentToBuffers;\nol.render.webgl.utils.writePointFeatureToBuffers = _ol_render_webgl_utils$writePointFeatureToBuffers;\nol.render.webgl.utils.writePolygonTrianglesToBuffers = _ol_render_webgl_utils$writePolygonTrianglesToBuffers;\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.canvas.VectorTileLayer = $ol$renderer$canvas$VectorTileLayer;\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.renderer.webgl = {};\nol.renderer.webgl.Layer = $ol$renderer$webgl$Layer;\nol.renderer.webgl.PointsLayer = $ol$renderer$webgl$PointsLayer;\nol.renderer.webgl.TileLayer = $ol$renderer$webgl$TileLayer;\nol.renderer.webgl.TileLayer.Attributes = _ol_renderer_webgl_TileLayer$Attributes;\nol.renderer.webgl.TileLayer.Uniforms = _ol_renderer_webgl_TileLayer$Uniforms;\nol.renderer.webgl.TileLayerBase = $ol$renderer$webgl$TileLayerBase;\nol.renderer.webgl.TileLayerBase.Uniforms = _ol_renderer_webgl_TileLayerBase$Uniforms;\nol.renderer.webgl.TileLayerBase.getCacheKey = _ol_renderer_webgl_TileLayerBase$getCacheKey;\nol.renderer.webgl.TileLayerBase.newTileRepresentationLookup = _ol_renderer_webgl_TileLayerBase$newTileRepresentationLookup;\nol.renderer.webgl.VectorLayer = $ol$renderer$webgl$VectorLayer;\nol.renderer.webgl.VectorLayer.Uniforms = _ol_renderer_webgl_VectorLayer$Uniforms;\nol.renderer.webgl.VectorTileLayer = $ol$renderer$webgl$VectorTileLayer;\nol.renderer.webgl.VectorTileLayer.Attributes = _ol_renderer_webgl_VectorTileLayer$Attributes;\nol.renderer.webgl.VectorTileLayer.Uniforms = _ol_renderer_webgl_VectorTileLayer$Uniforms;\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.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.CartoDB = $ol$source$CartoDB;\nol.source.Cluster = $ol$source$Cluster;\nol.source.DataTile = $ol$source$DataTile;\nol.source.GeoTIFF = $ol$source$GeoTIFF;\nol.source.IIIF = $ol$source$IIIF;\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.ImageMapGuide = $ol$source$ImageMapGuide;\nol.source.ImageStatic = $ol$source$ImageStatic;\nol.source.ImageWMS = $ol$source$ImageWMS;\nol.source.OGCMapTile = $ol$source$OGCMapTile;\nol.source.OGCVectorTile = $ol$source$OGCVectorTile;\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.Raster.newImageData = _ol_source_Raster$newImageData;\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.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.VectorTile = $ol$source$VectorTile;\nol.source.VectorTile.defaultLoadFunction = _ol_source_VectorTile$defaultLoadFunction;\nol.source.WMTS = $ol$source$WMTS;\nol.source.WMTS.optionsFromCapabilities = _ol_source_WMTS$optionsFromCapabilities;\nol.source.XYZ = $ol$source$XYZ;\nol.source.Zoomify = $ol$source$Zoomify;\nol.source.Zoomify.CustomTile = _ol_source_Zoomify$CustomTile;\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.mapguide = {};\nol.source.mapguide.createLoader = _ol_source_mapguide$createLoader;\nol.source.ogcTileUtil = {};\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.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.LinkedList = $ol$structs$LinkedList;\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.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.getCacheKeyForTileKey = _ol_tilecoord$getCacheKeyForTileKey;\nol.tilecoord.getKey = _ol_tilecoord$getKey;\nol.tilecoord.getKeyZXY = _ol_tilecoord$getKeyZXY;\nol.tilecoord.hash = _ol_tilecoord$hash;\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.expandUrl = _ol_tileurlfunction$expandUrl;\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.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.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.webgl = {};\nol.webgl.ARRAY_BUFFER = _ol_webgl$ARRAY_BUFFER;\nol.webgl.BaseTileRepresentation = $ol$webgl$BaseTileRepresentation;\nol.webgl.Buffer = $ol$webgl$Buffer;\nol.webgl.Buffer.getArrayClassForType = _ol_webgl_Buffer$getArrayClassForType;\nol.webgl.DYNAMIC_DRAW = _ol_webgl$DYNAMIC_DRAW;\nol.webgl.ELEMENT_ARRAY_BUFFER = _ol_webgl$ELEMENT_ARRAY_BUFFER;\nol.webgl.FLOAT = _ol_webgl$FLOAT;\nol.webgl.Helper = $ol$webgl$Helper;\nol.webgl.Helper.computeAttributesStride = _ol_webgl_Helper$computeAttributesStride;\nol.webgl.PaletteTexture = $ol$webgl$PaletteTexture;\nol.webgl.PostProcessingPass = $ol$webgl$PostProcessingPass;\nol.webgl.RenderTarget = $ol$webgl$RenderTarget;\nol.webgl.STATIC_DRAW = _ol_webgl$STATIC_DRAW;\nol.webgl.STREAM_DRAW = _ol_webgl$STREAM_DRAW;\nol.webgl.ShaderBuilder = {};\nol.webgl.ShaderBuilder.COMMON_HEADER = _ol_webgl_ShaderBuilder$COMMON_HEADER;\nol.webgl.ShaderBuilder.ShaderBuilder = _ol_webgl_ShaderBuilder$ShaderBuilder;\nol.webgl.TileGeometry = $ol$webgl$TileGeometry;\nol.webgl.TileTexture = $ol$webgl$TileTexture;\nol.webgl.UNSIGNED_BYTE = _ol_webgl$UNSIGNED_BYTE;\nol.webgl.UNSIGNED_INT = _ol_webgl$UNSIGNED_INT;\nol.webgl.UNSIGNED_SHORT = _ol_webgl$UNSIGNED_SHORT;\nol.webgl.getContext = _ol_webgl$getContext;\nol.webgl.getSupportedExtensions = _ol_webgl$getSupportedExtensions;\nol.webgl.styleparser = {};\nol.webgl.styleparser.computeHash = _ol_webgl_styleparser$computeHash;\nol.webgl.styleparser.expressionToGlsl = _ol_webgl_styleparser$expressionToGlsl;\nol.webgl.styleparser.packColor = _ol_webgl_styleparser$packColor;\nol.webgl.styleparser.parseLiteralStyle = _ol_webgl_styleparser$parseLiteralStyle;\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\nexport default ol;","/**\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/source\n */\n\nimport LRUCache from './structs/LRUCache.js';\nimport {getIntersection} from './extent.js';\n\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 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 ImageWMS} from './source/ImageWMS.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 {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 {default as WMTS} from './source/WMTS.js';\nexport {default as XYZ} from './source/XYZ.js';\nexport {default as Zoomify} from './source/Zoomify.js';\nexport {createLoader as createWMSLoader} from './source/wms.js';\nexport {createLoader as createArcGISRestLoader} from './source/arcgisRest.js';\nexport {createLoader as createStaticLoader} from './source/static.js';\nexport {createLoader as createMapGuideLoader} from './source/mapguide.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":["stopPropagation","evt","$ol$events$Event","constructor","type","this","propagationStopped","defaultPrevented","target","preventDefault","ObjectEventType","$ol$Disposable","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","called","nextArgs","prototype","slice","call","arguments","arrayEquals","apply","toPromise","getter","value","err","Promise","reject","resolve","promiseGetter","clear","object","property","isEmpty","$ol$events$Target","Disposable","super","eventTarget_","pendingRemovals_","dispatching_","listeners_","addEventListener","listener","listeners","listenersForType","includes","push","dispatchEvent","event","isString","Event","dispatching","pendingRemovals","propagate","ii","handleEvent","pr","removeEventListener","getListeners","undefined","hasListener","Object","keys","indexOf","splice","EventType$1","listen","thisArg","once","bind","originalListener","eventsKey","listenOnce","unlistenByKey","key","Observable","EventTarget","on","un","revision_","changed","EventType","getRevision","onInternal","len","onceInternal","ol_key","unInternal","unByKey","$ol$Observable","abstract","Error","uidCounter_","getUid","obj","ol_uid","String","ObjectEvent","oldValue","$ol$Object","values","values_","setProperties","get","hasOwnProperty","getKeys","getProperties","assign","getPropertiesInternal","hasProperties","notify","eventType","addChangeListener","removeChangeListener","set","silent","applyProperties","source","unset","CollectionEventType","Property","CollectionEvent","element","Collection","BaseObject","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","$ol$Tile","tileCoord","state","interimTile","transition_","transition","transitionStarts_","interpolate","release","setState","getKey","getInterimTile","tile","getState","refreshInterimChain","getTileCoord","load","getAlpha","id","time","start","delta","inTransition","endTransition","ua","navigator","userAgent","toLowerCase","FIREFOX","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","error","createCanvasContext2D","width","height","canvasPool","settings","canvas","shift","document","createElement","getContext","releaseCanvas","context","clearRect","outerWidth","offsetWidth","style","getComputedStyle","parseInt","marginLeft","marginRight","outerHeight","offsetHeight","marginTop","marginBottom","replaceNode","newNode","oldNode","parent","parentNode","replaceChild","removeNode","node","removeChild","removeChildren","lastChild","replaceChildren","children","oldChildren","childNodes","oldChild","newChild","insertBefore","appendChild","asImageLike","HTMLCanvasElement","HTMLVideoElement","ImageBitmap","asArrayLike","Uint8Array","Uint8ClampedArray","Float32Array","DataView","sharedContext","toArray","image","willReadFrequently","drawImage","getImageData","defaultSize","$ol$DataTile","Tile","loader_","loader","data_","error_","size_","size","getSize","imageData","getData","getError","then","catch","assert","assertion","errorMessage","Feature","geometryOrProperties","id_","geometryName_","style_","styleFunction_","geometryChangeKey_","handleGeometryChanged_","geometry","setGeometry","properties","clone","setGeometryName","getGeometryName","getGeometry","getStyle","setStyle","getId","getStyleFunction","handleGeometryChange_","createStyleFunction","setId","name","styles","$ol$Feature","tmp_","create","reset","transform","multiply","transform1","transform2","a1","b1","c1","d1","e1","f1","a2","b2","c2","d2","e2","f2","c","d","e","setFromArray","coordinate","x","y","rotate","angle","cos","sin","scale","makeScale","translate","dx","dy","compose","dx1","dy1","sx","sy","dx2","dy2","makeInverse","det","determinant","mat","transformStringDiv","toString","transformString","join","Relationship","UNKNOWN","INTERSECTING","ABOVE","RIGHT","BELOW","LEFT","boundingExtent","coordinates","extent","createEmpty","extendCoordinate","buffer","dest","closestSquaredDistanceXY","containsCoordinate","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","sinRotation","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","isFinite","unitByCode","fromCode","code","METERS_PER_UNIT","radians","PI","degrees","ft","m","$ol$proj$Projection","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","Projection","units","point","cosh","PROJECTIONS","fromEPSG4326","input","output","dimension","toEPSG4326","atan","exp","EPSG4326Projection","cache","replace","add","transforms","destination","sourceCode","destinationCode","clamp","squaredSegmentDistance","squaredDistance","solveLinearSystem","maxRow","maxEl","r","absValue","j","coef","k","toDegrees","angleInRadians","toRadians","angleInDegrees","modulo","lerp","toFixed","decimals","factor","round","ceil","padNumber","number","precision","numberString","decimal","compareVersions","v1","v2","s1","split","s2","n1","n2","closestOnCircle","circle","getRadius","sqrt","closestOnSegment","segment","along","degreesToStringHDMS","hemispheres","fractionDigits","normalizedDegrees","deg","sec","hdms","charAt","format","template","coordinate1","coordinate2","cosAngle","sinAngle","coord1","coord2","distance","squaredDistanceToSegment","toStringXY","worldsAway","getWorldsAway","sourceExtentWidth","DEFAULT_RADIUS","getDistance","radius","lat1","lat2","deltaLatBy2","deltaLonBy2","atan2","getLengthInternal","getAreaInternal","bearing","lon1","dByR","lat","asin","levels","info","warn","none","level","args","console","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","forward","inverse","sourceProj","destProj","equivalent","equalUnits","sourceProjection","destinationProjection","transformFunc","getTransformFunc","getTransform","transformExtent","userProjection","setUserProjection","getUserProjection","toUserCoordinate","fromUserCoordinate","destProjection","toUserExtent","fromUserExtent","toUserResolution","sourceMetersPerUnit","userMetersPerUnit","fromUserResolution","destMetersPerUnit","createSafeCoordinateTransform","coord","transformed","sourceExtent","addCommon","EPSG3857_PROJECTIONS","EPSG4326_PROJECTIONS","transform2D","anchor","anchorX","anchorY","tmpTransform","$ol$geom$Geometry","extentRevision_","simplifiedGeometryMaxMinSquaredTolerance","simplifiedGeometryRevision","simplifyTransformedInternal","revision","squaredTolerance","getSimplifiedGeometry","simplifyTransformed","closestPointXY","closestPoint","minSquaredDistance","getClosestPoint","NaN","intersectsCoordinate","computeExtent","isNaN","simplify","getType","intersectsExtent","getProjection","inCoordinates","outCoordinates","pixelExtent","projectedExtent","composeTransform","getLayoutForStride","layout","getStrideForLayout","transformGeom2D","simpleGeometry","getFlatCoordinates","getStride","$ol$geom$SimpleGeometry","Geometry","getCoordinates","getFirstCoordinate","getLastCoordinate","getLayout","simplifiedGeometry","getSimplifiedGeometryInternal","setFlatCoordinates","setCoordinates","setLayout","nesting","assignClosest","offset1","offset2","maxSquaredDelta","squaredDelta","squaredDx","arrayMaxSquaredDelta","ends","multiArrayMaxSquaredDelta","endss","assignClosestPoint","maxDelta","isRing","tmpPoint","assignClosestArrayPoint","assignClosestMultiArrayPoint","deflateCoordinate","deflateCoordinates","deflateCoordinatesArray","coordinatess","deflateMultiCoordinatesArray","coordinatesss","douglasPeucker","simplifiedFlatCoordinates","simplifiedOffset","markers","stack","last","first","maxSquaredDistance","douglasPeuckerArray","simplifiedEnds","radialDistance","snap","quantize","quantizeArray","quantizeMultiArray","simplifiedEndss","inflateCoordinates","inflateCoordinatesArray","inflateMultiCoordinatesArray","linearRing","twiceArea","linearRings","linearRingss","LinearRing","SimpleGeometry","maxDelta_","maxDeltaRevision_","linearRingArea","$ol$geom$LinearRing","Point","$ol$geom$Point","linearRingContainsExtent","linearRingContainsXY","wn","linearRingsContainsXY","linearRingssContainsXY","getInteriorPointOfArray","flatCenters","flatCentersOffset","intersections","rr","pointX","maxSegmentLength","sort","segmentLength","getInteriorPointsOfMultiArray","interiorPoints","ret","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","$ol$geom$Polygon","circular","sphereRadius","sphereOffset","fromExtent","fromCircle","sides","arrayLength","makeRegular","startAngle","GeolocationErrorType","GeolocationError","BaseEvent","message","$ol$Geolocation","position_","transform_","watchId_","handleProjectionChanged_","handleTrackingChanged_","setProjection","trackingOptions","setTrackingOptions","setTracking","tracking","getTracking","geolocation","watchPosition","positionChange_","positionError_","getTrackingOptions","clearWatch","position","coords","accuracy","altitude","altitudeAccuracy","heading","longitude","latitude","projectedPosition","speed","circularPolygon","getAccuracy","getAccuracyGeometry","getAltitude","getAltitudeAccuracy","getHeading","getPosition","getSpeed","ImageState","listenImage","loadHandler","errorHandler","img","listening","decoding","loaded","listenerKeys","src","handleLoad","unlisten","handleError","decodeFallback","complete","$ol$Image","pixelRatio","stateOrLoader","pixelRatio_","image_","getImage","getPixelRatio","getResolution","requestResolution","HTMLImageElement","finally","setImage","setResolution","$ol$ImageCanvas","ImageWrapper","canvas_","handleLoad_","$ol$ImageTile","crossOrigin","tileLoadFunction","crossOrigin_","src_","unlisten_","tileLoadFunction_","unlistenImage_","handleImageError_","ctx","fillStyle","fillRect","getBlankImage","handleImageLoad_","naturalWidth","naturalHeight","$ol$Kinetic","decay","minVelocity","delay","decay_","minVelocity_","delay_","points_","angle_","initialVelocity_","update","Date","now","lastIndex","firstIndex","duration","getAngle","rgb","channel","alias","xyz","A","C","D50","D55","D65","D75","F2","F7","F11","E","whitepoint","_xyz","white","g","z","xyz$1","luv","arg","o","_u","_v","u","v","xn","yn","zn","vn","yr","lchuv","hr","h","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgreen","darkgrey","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","green","greenyellow","grey","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgreen","lightgrey","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","teal","thistle","tomato","turquoise","violet","wheat","whitesmoke","yellow","yellowgreen","baseHues","hsl","t1","t2","t3","s","rgba","color","raw","Number","parsed","cstr","space","parts","alpha","names","base","exec","dims","trim","map","parseFloat","endsWith","match","parse","asString","MAX_CACHE_SIZE","cacheSize","withAlpha","rgbaToLcha","lchaToRgba","fromString","parseRgba","normalize","asArray","isStringColor","_","IconImageCache","cache_","cacheSize_","maxCacheSize_","canExpireCache","expire","iconImage","setSize","maxCacheSize","$ol$style$IconImageCache","shared","LayerProperty","$ol$layer$Base","background_","background","opacity","visible","zIndex","maxResolution","minResolution","minZoom","maxZoom","className_","className","state_","getBackground","getClassName","getLayerState","managed","layer","getZIndex","getOpacity","getVisible","getMaxResolution","getMinResolution","getMinZoom","getMaxZoom","getLayersArray","getLayerStatesArray","states","getSourceState","setBackground","setMaxResolution","setMinResolution","setMaxZoom","setMinZoom","setOpacity","setVisible","setZIndex","zindex","ViewHint","ViewProperty","CENTER","RESOLUTION","ROTATION","DEFAULT_MAX_ZOOM","DEFAULT_TILE_SIZE","createExtent","onlyCenter","smooth","isMoving","centerShift","viewWidth","viewHeight","shiftX","shiftY","ratio","getViewportClampedResolution","maxExtent","viewportSize","showFullExtent","xResolution","yResolution","getSmoothClampedResolution","result","createSnapToResolutions","resolutions","cappedMaxRes","capped","createSnapToPower","power","minZoomLevel","cappedZoomLevel","zoomLevel","createMinMaxResolution","createSnapToN","theta","createSnapToZero","animationCallback","returnValue","setTimeout","createCenterConstraint","smoothExtentConstraint","constrainOnlyCenter","multiWorld","centerNone","createResolutionConstraint","resolutionConstraint","zoomFactor","smoothResolutionConstraint","projExtent","constrainResolution","defaultMaxResolution","defaultMinResolution","defaultMaxZoom","constraint","createRotationConstraint","enableRotation","constrainRotation","rotationNone","isNoopAnimation","animation","sourceCenter","targetCenter","coordinatesEqual","sourceResolution","targetResolution","sourceRotation","targetRotation","calculateCenterOn","rotX","rotY","$ol$View","hints_","animations_","updateAnimationKey_","projection_","viewportSize_","targetCenter_","targetResolution_","targetRotation_","nextCenter_","nextResolution_","nextRotation_","cancelAnchor_","applyOptions_","resolutionConstraintInfo","maxResolution_","minResolution_","zoomFactor_","resolutions_","padding_","padding","minZoom_","centerConstraint","rotationConstraint","constraints_","setRotation","setCenterInternal","zoom","setZoom","oldPadding","getCenterInternal","newPadding","offsetX","offsetY","getUpdatedOptions_","newOptions","getZoom","getRotation","animate","var_args","isDef","getAnimating","resolveConstraints","animateInternal","animationCount","series","easing","getResolutionForZoom","setHint","updateAnimations_","getInteracting","cancelAnimations","cancelAnimationFrame","more","seriesComplete","elapsed","fraction","progress","getViewportSize_","constrainedResolution","calculateCenterZoom","applyTargetState_","constrainedRotation","calculateCenterRotate","filter","Boolean","requestAnimationFrame","currentCenter","rotateCoordinate","addCoordinate","currentResolution","w","setViewportSize","getConstraints","getConstrainResolution","getHints","hints","calculateExtent","calculateExtentInternal","getViewportSizeMinusPadding_","getZoomForResolution","setConstrainResolution","enabled","getResolutions","getResolutionForExtent","getResolutionForExtentInternal","getResolutionForValueFunction","getConstrainedResolution","getValueForResolutionFunction","logPower","reducedSize","nextCenter","nextResolution","nextRotation","getViewStateAndExtent","viewState","nearest","baseLevel","fit","geometryOrExtent","polygonFromExtent","fitInternal","rotatedExtentForGeometry","minRotX","minRotY","maxRotX","maxRotY","rotatedExtent","centerRot","centerX","centerY","getConstrainedCenter","centerOn","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","inView","layerState","$ol$layer$Layer","BaseLayer","baseOptions","mapPrecomposeKey_","mapRenderKey_","sourceChangeKey_","renderer_","sourceReady_","rendered","render","setMap","handleSourcePropertyChange_","setSource","getSource","getRenderSource","handleSourceChange_","getFeatures","pixel","isVisible","view","frameState","getMapInternal","getView","View","layerStatesArray","getLayerGroup","find","layerExtent","getAttributions","attributions","layerRenderer","getRenderer","prepareFrame","renderFrame","unrender","setMapInternal","RenderEventType","some","arrayLayerState","createRenderer","hasRenderer","expireIconCache","iconImageCache","$ol$renderer$Map","map_","dispatchRenderEvent","calculateMatrices2D","coordinateToPixelTransform","pixelToCoordinateTransform","forEachFeatureAtCoordinate","hitTolerance","checkWrapped","layerFilter","thisArg2","feature","translatedCoordinate","offsets","layerStates","numLayers","matches","tmpCoord","getWrapX","order","distanceSq","hasFeatureAtCoordinate","getMap","flushDeclutterItems","scheduleExpireIconCache","postRenderFunctions","$ol$render$Event","inversePixelTransform","CLASS_HIDDEN","CLASS_SELECTABLE","CLASS_UNSELECTABLE","CLASS_UNSUPPORTED","CLASS_CONTROL","CLASS_COLLAPSED","fontRegEx","RegExp","fontRegExMatchIndex","getFontParameters","fontSpec","lineHeight","weight","variant","families","family","defaultFont","defaultFillStyle","defaultLineCap","defaultLineDash","defaultLineJoin","defaultMiterLimit","defaultStrokeStyle","defaultTextAlign","defaultTextBaseline","defaultPadding","checkedFonts","measureFont","measureContext","textHeights","registerFont","referenceFonts","text","interval","referenceWidth","isAvailable","fontStyle","fontWeight","fontFamily","available","referenceFont","measureTextWidth","check","done","fonts","font","clearInterval","setInterval","measureTextHeight","measureElement","metrics","measureText","actualBoundingBoxAscent","actualBoundingBoxDescent","innerHTML","minHeight","maxHeight","border","display","left","body","measureAndCacheTextWidth","reduce","curr","getTextDimensions","baseStyle","chunks","widths","heights","lineWidths","lineWidth","currentWidth","currentHeight","drawImageOrLabel","labelOrImage","originX","originY","save","globalAlpha","contextInstructions","label","executeLabelInstructions","restore","$ol$renderer$Composite","MapRenderer","fontChangeListenerKey_","redrawText","element_","container","getViewport","firstChild","children_","renderedVisible_","declutterLayers_","RenderEvent","declutterLayers","previousElement","layerIndex","sourceState","layers","renderDeclutter","GroupEvent","LayerGroup","layersListenerKeys_","listenerKeys_","handleLayersChanged_","setLayers","handleLayerChange_","getLayers","handleLayersAdd_","handleLayersRemove_","layersArray","registerLayerListeners_","handleLayerGroupAdd_","handleLayerGroupRemove_","collectionEvent","collection","currentLayers","pos","ownLayerState","defaultZIndex","$ol$layer$Group","$ol$MapEvent","$ol$MapBrowserEvent","MapEvent","originalEvent","dragging","activePointers","pixel_","coordinate_","getEventPixel","getCoordinateFromPixel","MapBrowserEventType","SINGLECLICK","CLICK","DBLCLICK","POINTERDRAG","POINTERMOVE","POINTERDOWN","POINTERUP","POINTEROVER","POINTEROUT","POINTERENTER","POINTERLEAVE","POINTERCANCEL","PointerEventType","$ol$MapBrowserEventHandler","Target","moveTolerance","clickTimeoutId_","emulateClicks_","dragging_","dragListenerKeys_","moveTolerance_","down_","activePointers_","trackedTouches_","pointerdownListenerKey_","handlePointerDown_","originalPointerMoveEvent_","relayedListenerKey_","relayMoveEvent_","boundHandleTouchMove_","handleTouchMove_","emulateClick_","pointerEvent","newEvent","MapBrowserEvent","clearTimeout","updateActivePointers_","pointerId","handlePointerUp_","isMouseActionButton_","button","PointerEvent","writable","doc","getOwnerDocument","handlePointerMove_","getRootNode","isMoving_","cancelable","clientX","clientY","MapEventType","MapProperty","DROP","$ol$structs$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","$ol$TileQueue","PriorityQueue","tilePriorityFunction","tileChangeCallback","boundHandleTileChange_","handleTileChange","tileChangeCallback_","tilesLoading_","tilesLoadingKeys_","added","getTilesLoading","tileKey","loadMoreTiles","maxTotalLoading","maxNewLoads","newLoads","getTilePriority","tileSourceKey","tileCenter","tileResolution","wantedTiles","$ol$control$Control","pointerEvents","target_","setTarget","getOverlayContainerStopEvent","mapEvent","getElementById","$ol$control$Attribution","Control","ulElement_","collapsed_","collapsed","userCollapsed_","overrideCollapsible_","collapsible","collapsible_","tipLabel","expandClassName","collapseLabel","collapseClassName","collapseLabel_","textContent","label_","activeLabel","toggleButton_","setAttribute","title","handleClick_","cssClasses","renderedAttributions_","collectSourceAttributions_","visibleAttributions","from","Set","getAllLayers","flatMap","getAttributionsCollapsible","setCollapsible","updateElement_","handleToggle_","classList","toggle","getCollapsible","setCollapsed","getCollapsed","$ol$control$Rotate","compassClassName","callResetNorth_","resetNorth","duration_","autoHide_","autoHide","rotation_","resetNorth_","contains","$ol$control$Zoom","zoomInClassName","zoomOutClassName","zoomInLabel","zoomOutLabel","zoomInTipLabel","zoomOutTipLabel","inElement","createTextNode","outElement","zoomByDelta_","currentZoom","newZoom","defaults","controls","Zoom","zoomOptions","Rotate","rotateOptions","attribution","Attribution","attributionOptions","InteractionProperty","pan","zoomByDelta","$ol$interaction$Interaction","setActive","getActive","mapBrowserEvent","active","$ol$interaction$DoubleClickZoom","Interaction","delta_","stopEvent","browserEvent","shiftKey","centroid","$ol$interaction$Pointer","handleDownEvent","handleDragEvent","handleMoveEvent","handleUpEvent","stopDown","handlingDownUpSequence","targetPointers","getPointerCount","updateTrackedPointers_","handledUp","handled","all","conditions","pass","altKeyOnly","altKey","metaKey","ctrlKey","altShiftKeysOnly","focus","targetElement","getTargetElement","activeElement","focusWithTabindex","hasAttribute","always","mouseActionButton","never","singleClick","noModifierKeys","platformModifierKey","shiftKeyOnly","targetNotEditable","tagName","isContentEditable","mouseOnly","pointerType","primaryAction","isPrimary","$ol$interaction$DragPan","PointerInteraction","kinetic_","kinetic","lastCentroid","lastPointersCount_","panning_","condition","condition_","onFocusOnly","noKinetic_","centroidFromPointers","scaleCoordinate","centerpx","getPixelFromCoordinateInternal","getCoordinateFromPixelInternal","$ol$interaction$DragRotate","lastAngle_","$ol$render$Box","geometry_","startPixel_","endPixel_","render_","startPixel","endPixel","px","top","getOverlayContainer","setPixels","createOrUpdateGeometry","DragBoxEventType","DragBoxEvent","$ol$interaction$DragBox","box_","RenderBox","minArea_","minArea","onBoxEnd","boxEndCondition_","boxEndCondition","defaultBoxEndCondition","completeBox","$ol$interaction$DragZoom","DragBox","out_","out","Key","$ol$interaction$KeyboardPan","defaultCondition_","pixelDelta_","pixelDelta","keyEvent","mapUnitsDelta","$ol$interaction$KeyboardZoom","$ol$interaction$MouseWheelZoom","totalDelta_","lastDelta_","timeout_","timeout","useAnchor_","useAnchor","constrainResolution_","lastAnchor_","startTime_","timeoutId_","mode_","trackpadEventGap_","trackpadTimeoutId_","deltaPerZoom_","endInteraction_","wheelEvent","deltaMode","WheelEvent","DOM_DELTA_PIXEL","DOM_DELTA_LINE","timeLeft","handleWheelZoom_","setMouseAnchor","$ol$interaction$PinchRotate","pointerOptions","anchor_","rotating_","rotationDelta_","threshold_","threshold","rotationDelta","touch0","touch1","$ol$interaction$PinchZoom","lastDistance_","lastScaleDelta_","scaleDelta","interactions","Kinetic","altShiftDragRotate","DragRotate","doubleClickZoom","DoubleClickZoom","zoomDelta","zoomDuration","dragPan","DragPan","pinchRotate","PinchRotate","pinchZoom","PinchZoom","keyboard","KeyboardPan","KeyboardZoom","mouseWheelZoom","MouseWheelZoom","shiftDragZoom","DragZoom","hasArea","toSize","removeLayerMapProperty","Layer","setLayerMapProperty","$ol$Map","optionsInternal","keyboardEventTarget","layerGroup","overlays","createOptionsInternal","renderComplete_","loaded_","boundHandleBrowserEvent_","handleBrowserEvent","maxTilesLoading_","maxTilesLoading","postRenderTimeoutHandle_","animationDelayKey_","animationDelay_","coordinateToPixelTransform_","pixelToCoordinateTransform_","frameIndex_","frameState_","previousExtent_","viewPropertyListenerKey_","viewChangeListenerKey_","layerGroupPropertyListenerKeys_","viewport_","overflow","overlayContainer_","overlayContainerStopEvent_","mapBrowserEventHandler_","keyboardEventTarget_","targetChangeHandlerKeys_","targetElement_","resizeObserver_","ResizeObserver","updateSize","defaultControls","defaultInteractions","overlays_","overlayIdIndex_","postRenderFunctions_","tileQueue_","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","renderer","ready","loading","getPixelFromCoordinate","viewCoordinate","ownerDocument","handleMapBrowserEvent","rootNode","documentElement","interactionsArray","handlePostRender","tileQueue","viewHints","lowOnFrameBudget","unobserve","ShadowRoot","host","CompositeMapRenderer","MapBrowserEventHandler","observe","handleViewPropertyChanged_","updateViewportSize_","handleLayerRemove_","isRendered","renderFrame_","renderSync","handleFontsChanged","removeControl","removeInteraction","removeLayer","removeOverlay","previousFrameState","declutterTree","usedTiles","mapId","renderTargets","nextExtent","equalsExtent","setLayerGroup","oldLayerGroup","computedStyle","getClientRects","oldSize","$ol$Overlay","insertFirst","autoPan","mapPostrenderListenerKey","handleElementChanged","handleMapChanged","handleOffsetChanged","handlePositionChanged","handlePositioningChanged","setElement","setOffset","setPositioning","positioning","setPosition","getElement","getOffset","getPositioning","updatePixelPosition","performAutoPan","panIntoView","panIntoViewOptions","mapRect","getRect","overlayRect","myMargin","margin","offsetLeft","offsetRight","offsetTop","offsetBottom","centerPx","newCenterPx","panOptions","box","pageXOffset","pageYOffset","mapSize","updateRenderedPosition","posX","posY","getOptions","$ol$structs$LRUCache","highWaterMark","count_","entries_","oldest_","newest_","expireCache","keep","containsKey","entry","value_","key_","newer","older","getValues","peekLast","peekLastKey","peekFirstKey","peek","getKeyZXY","getCacheKeyForTileKey","substring","lastIndexOf","fromKey","hash","withinExtentAndZ","tileRange","getFullTileRange","$ol$TileCache","LRUCache","pruneExceptNewestZ","TileRange","containsTileRange","$ol$TileRange","$ol$VectorRenderTile","urlTileCoord","getSourceTiles","context_","executorGroups","declutterExecutorGroups","loadingSourceTiles","hitDetectionImageData","replayState_","sourceTiles","errorTileKeys","wantedResolution","wrappedTileCoord","hasContext","getReplayState","dirty","renderedRenderOrder","renderedResolution","renderedRevision","renderedTileResolution","renderedTileRevision","renderedTileZ","$ol$VectorTile","format_","features_","url_","getFormat","onLoad","dataProjection","setFeatures","onError","setLoader","asColorLike","originalXHR","withCredentials","loadFeaturesXhr","url","success","failure","xhr","XMLHttpRequest","open","responseType","onload","status","JSON","responseText","responseXML","DOMParser","parseFromString","readFeatures","featureProjection","readProjection","onerror","send","addFeatures","jsonp","errback","callbackParam","script","cleanup","async","timer","head","ResponseError","response","ClientError","client","getJSON","setRequestHeader","resolveUrl","URL","href","$ol$render$VectorContext","drawCustom","hitDetectionRenderer","drawGeometry","drawCircle","circleGeometry","drawFeature","drawGeometryCollection","geometryCollectionGeometry","drawLineString","lineStringGeometry","drawMultiLineString","multiLineStringGeometry","drawMultiPoint","multiPointGeometry","drawMultiPolygon","multiPolygonGeometry","drawPoint","pointGeometry","drawPolygon","polygonGeometry","drawText","setFillStrokeStyle","strokeStyle","setImageStyle","imageStyle","declutterImageWithText","setTextStyle","textStyle","$ol$render$canvas$Immediate","VectorContext","viewRotation","userTransform","transformRotation_","viewRotation_","squaredTolerance_","userTransform_","contextFillState_","contextStrokeState_","contextTextState_","fillState_","strokeState_","imageAnchorX_","imageAnchorY_","imageHeight_","imageOpacity_","imageOriginX_","imageOriginY_","imageRotateWithView_","imageRotation_","imageScale_","imageWidth_","text_","textOffsetX_","textOffsetY_","textRotateWithView_","textRotation_","textScale_","textFillState_","textStrokeState_","textState_","pixelCoordinates_","tmpLocalTransform_","drawImages_","pixelCoordinates","localTransform","drawText_","setContextFillState_","setContextStrokeState_","setContextTextState_","strokeText","fillText","moveToLineTo_","close","moveTo","lineTo","closePath","drawRings_","beginPath","arc","fill","stroke","getFill","getStroke","getText","setTransform","getGeometryFunction","geometries","getGeometriesArray","flatMidpoint","getFlatMidpoint","geometryExtent","flatMidpoints","getFlatMidpoints","flatInteriorPoint","getEndss","flatInteriorPoints","getFlatInteriorPoints","fillState","contextFillState","strokeState","contextStrokeState","lineCap","lineDash","setLineDash","lineDashOffset","lineJoin","miterLimit","textState","contextTextState","textAlign","textBaseline","fillStyleColor","getColor","strokeStyleColor","strokeStyleLineCap","getLineCap","strokeStyleLineDash","getLineDash","strokeStyleLineDashOffset","getLineDashOffset","strokeStyleLineJoin","getLineJoin","strokeStyleWidth","strokeStyleMiterLimit","getMiterLimit","imageSize","imagePixelRatio","imageAnchor","getAnchor","imageOrigin","getOrigin","getRotateWithView","imageScale","getScaleArray","textFillStyle","textFillStyleColor","textStrokeStyle","textStrokeStyleColor","textStrokeStyleLineCap","textStrokeStyleLineDash","textStrokeStyleLineDashOffset","textStrokeStyleLineJoin","textStrokeStyleWidth","textStrokeStyleMiterLimit","textFont","getFont","textOffsetX","getOffsetX","textOffsetY","getOffsetY","textRotateWithView","textRotation","textScale","textText","textTextAlign","getTextAlign","textTextBaseline","getTextBaseline","acc","SIMPLIFY_TOLERANCE","GEOMETRY_RENDERERS","builderGroup","declutterBuilderGroup","getImageState","imageBuilderGroup","declutterMode","getDeclutterMode","imageReplay","getBuilder","textBuilderGroup","textReplay","LineString","lineStringReplay","polygonReplay","MultiPoint","MultiLineString","MultiPolygon","GeometryCollection","replayGroup","geometryRenderer","Circle","circleReplay","defaultOrder","feature1","feature2","getSquaredTolerance","getTolerance","renderFeature","imageState","unlistenImageChange","listenImageChange","renderGeometry","renderFeatureInternal","getGeometries","getHitDetectionRenderer","getVectorContext","CanvasRenderingContext2D","canvasPixelRatio","multiplyTransform","CanvasImmediateRenderer","brokenDiagonalRendering_","drawTestTriangle","u1","u2","clip","verifyBrokenDiagonalRendering","calculateSourceResolution","targetProj","targetMetersPerUnit","compensationFactor","calculateSourceExtentResolution","targetExtent","triangulation","sources","gutter","renderEdges","drawSingle","imageSmoothingEnabled","pixelRound","globalCompositeOperation","sourceDataExtent","stitchContext","canvasWidthInUnits","canvasHeightInUnits","stitchScale","xPos","yPos","srcWidth","srcHeight","targetTopLeft","getTriangles","triangle","u0","v0","sourceNumericalShiftX","sourceNumericalShiftY","affineCoefs","isBrokenDiagonalRendering","steps","ud","vd","step","fromResolutionLike","ERROR_THRESHOLD","$ol$reproj$Triangulation","maxSourceExtent","errorThreshold","destinationResolution","sourceProj_","targetProj_","transformInvCache","transformInv","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","$ol$reproj$Tile","sourceTileGrid","targetTileGrid","getTileFunction","renderEdges_","gutter_","sourceTileGrid_","targetTileGrid_","wrappedTileCoord_","sourceTiles_","sourcesListenerKeys_","sourceZ_","getTileCoordExtent","maxTargetExtent","limitedTargetExtent","sourceProjExtent","errorThresholdInPixels","triangulation_","Triangulation","getZForResolution","sourceRange","getTileRangeForExtentAndZ","srcX","srcY","reproject_","getTileSize","renderReprojected","leftToLoad","sourceListenKey","unlistenSources_","TileEventType","adaptAttributions","attributionLike","$ol$source$Source","attributions_","attributionsCollapsible_","attributionsCollapsible","wrapX_","interpolate_","viewResolver","viewRejector","viewPromise_","getInterpolate","refresh","setAttributions","tmpTileCoord","$ol$tilegrid$TileGrid","origins","origin_","origin","origins_","tileSizes_","tileSizes","tileSize_","tileSize","fullTileRanges_","tmpSize_","tmpExtent_","sizes","restrictedTileRange","calculateTileRanges_","forEachTileCoord","forEachTileCoordParentTileRange","tempTileRange","tempExtent","tileCoordExtent","createOrUpdateTileRange","getTileCoordChildTileRange","getTileRangeForTileCoordAndZ","tileCoordZ","tileCoordX","tileCoordY","getTileCoordForXYAndZ_","getTileCoordCenter","getTileCoordForCoordAndResolution","opt_tileCoord","getTileCoordForXYAndResolution_","reverseIntersectionPolicy","createOrUpdateTileCoord","getTileCoordForCoordAndZ","getTileCoordResolution","opt_direction","tileCoordIntersectsViewport","viewport","fullTileRanges","getForProjection","createForProjection","extentFromProjection","createForExtent","resolutionsFromExtent","TileGrid","createXYZ","xyzOptions","gridOptions","half","TileSourceEvent","$ol$source$Tile","Source","opaque_","opaque","tilePixelRatio_","tilePixelRatio","tileCache","TileCache","tmpSize","tileOptions","zDirection","getTileCacheForProjection","forEachLoadedTile","tileCoordKey","covered","getGutterForProjection","setKey","getOpaque","getTileGridForProjection","getTile","getTileGrid","getTilePixelRatio","getTilePixelSize","scaleSize","getTileCoordForTileUrlFunction","updateCacheSize","tileCount","useTile","createFromTemplate","zRegEx","xRegEx","yRegEx","dashYRegEx","range","createFromTemplates","templates","tileUrlFunctions","createFromTileUrlFunctions","tileCoordHash","nullTileUrlFunction","expandUrl","urls","startCharCode","charCodeAt","stopCharCode","charCode","fromCharCode","stop","UrlTile","TileSource","generateTileUrlFunction_","tileUrlFunction","setUrls","setUrl","tileLoadingKeys_","getTileLoadFunction","getTileUrlFunction","getPrototypeOf","getUrls","uid","tileState","setTileLoadFunction","setTileUrlFunction","$ol$source$UrlTile","defaultTileLoadFunction","imageTile","$ol$source$TileImage","tileClass","ImageTile","tileCacheForProjection","tileGridForProjection","reprojectionErrorThreshold_","reprojectionErrorThreshold","renderReprojectionEdges_","usedTileCache","getGutter","thisProj","projKey","createTile_","tileUrl","getTileInternal","newTile","ReprojTile","setRenderReprojectionEdges","setTileGridForProjection","tilegrid","proj","quadKey","digits","mask","$ol$source$BingMaps","TileImage","hidpi","hidpi_","culture_","culture","maxZoom_","apiKey_","imagerySet_","imagerySet","placeholderTiles_","placeholderTiles","fetch","json","handleImageryMetadataResponse","getApiKey","getImagerySet","statusCode","statusDescription","authenticationResultCode","resourceSets","resources","resource","zoomMax","imageWidth","imageHeight","zoomMin","imageUrlSubdomains","subdomain","quadKeyTileCoord","imageUrl","params","searchParams","delete","imageryProviders","imageryProvider","intersecting","coverageAreas","coverageArea","bbox","$ol$source$XYZ","$ol$source$CartoDB","XYZ","account_","account","mapId_","config_","config","templateCache_","initializeMap_","getConfig","updateConfig","setConfig","paramHash","stringify","applyTemplate_","mapUrl","handleInitResponse_","handleInitError_","tilesUrl","cdn_url","https","layergroupid","quickselect","quickselectStep","defaultCompare","sd","swap","RBush$1","maxEntries","_maxEntries","_minEntries","_all","search","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","bboxMargin","siblings","p","destNode","$ol$structs$RBush","rbush_","RBush_","items_","extents","getAll","getInExtent","forEach_","forEachInExtent","concat","rbush","setCenterAndRadius","getRadiusSquared_","setRadius","$ol$geom$Circle","geometries_","changeEventsKeys_","listenGeometriesChange_","unlistenGeometriesChange_","geometryCollection","setGeometries","cloneGeometries","getGeometriesArrayRecursive","geometriesArray","simplifiedGeometries","simplified","simplifiedGeometryCollection","setGeometriesArray","clonedGeometries","$ol$geom$GeometryCollection","interpolatePoint","cumulativeLengths","lineStringCoordinateAtM","extrapolate","lo","hi","m0","lineStringsCoordinateAtM","lineStringLength","flatMidpoint_","flatMidpointRevision_","appendCoordinate","lineString","getCoordinateAtM","getCoordinateAt","$ol$geom$LineString","lineStrings","appendLineString","multiLineString","getLineString","getLineStrings","midpoints","$ol$geom$MultiLineString","appendPoint","multiPoint","getPoint","getPoints","points","$ol$geom$MultiPoint","endss_","flatInteriorPointsRevision_","flatInteriorPoints_","polygons","thisEndss","appendPolygon","newEndss","multiPolygon","linearRingssArea","linearRingssCenter","getInteriorPoints","getPolygon","prevEnds","getPolygons","lastEnds","$ol$geom$MultiPolygon","RenderFeature","styleFunction","type_","flatCoordinates_","flatMidpoints_","properties_","stride_","simplifiedGeometry_","midpoint","enableSimplifyTransformed","toGeometry","geometryType","$ol$render$Feature","VectorEventType","VectorSourceEvent","$ol$source$Vector","overlaps_","overlaps","strategy_","strategy","allStrategy","useSpatialIndex","featuresRtree_","RBush","loadedExtentsRtree_","loadingExtentsCount_","nullGeometryFeatures_","idIndex_","uidIndex_","featureChangeKeys_","featuresCollection_","addFeaturesInternal","bindFeaturesCollection_","addFeature","addFeatureInternal","featureKey","addToIndex_","setupChangeEvents_","handleFeatureChange_","valid","indexedFeature","newFeatures","geometryFeatures","modifyingCollection","removeFeature","fast","featureId","removeAndIgnoreReturn","removeFeatureInternal","clearEvent","forEachFeature","forEachFeatureAtCoordinateDirect","forEachFeatureInExtent","forEachFeatureIntersectingExtent","getFeaturesCollection","getFeaturesAtCoordinate","getFeaturesInExtent","anExtent","getClosestFeatureToCoordinate","closestFeature","previousMinSquaredDistance","minDistance","getFeatureById","getFeatureByUid","getOverlaps","getUrl","sid","removeFromIdIndex_","hasFeature","loadFeatures","loadedExtentsRtree","extentsToLoad","extentToLoad","removeLoadedExtent","featureChangeKeys","removed","$ol$source$Cluster","VectorSource","interpolationRatio","geometryFunction","createCustomCluster_","createCluster","boundRefresh_","updateDistance","setDistance","setMinDistance","getMinDistance","cluster","mapDistance","clustered","neighbors","neighbor","searchCenter","$ol$reproj$DataTile","DataTile","reprojData_","reprojError_","reprojSize_","dataSources","tileData","arrayData","pixelSize","isFloat","pixelCount","DataType","tileDataR","bytesPerElement","BYTES_PER_ELEMENT","bytesPerPixel","bytesPerRow","byteLength","bandCount","packedLength","packedData","dataIndex","rowOffset","colCount","rowIndex","colIndex","dataType","targetWidth","targetHeight","dataR","dataU","reproj","dataSource","createImageData","putImageData","$ol$source$DataTile","tileGridForProjection_","tileCacheForProjection_","setTileSizes","getReprojTile_","reprojTilePixelRatio","textureSize","ReprojDataTile","sourceLoader","readRGB","preference","getSamplesPerPixel","interpretation","fileDirectory","PhotometricInterpretation","interpretations","GeoTIFF","globals","photometricInterpretations","CMYK","YCbCr","CIELab","ICCLab","STATISTICS_MAXIMUM","STATISTICS_MINIMUM","workerPool","getBoundingBox","referenceImage","geoKeys","ProjectedCSTypeGeoKey","getCachedProjection","unitsFromCode","ProjLinearUnitsGeoKey","GeographicTypeGeoKey","GeogAngularUnitsGeoKey","getImagesForTIFF","tiff","getImageCount","requests","getImagesForSource","request","blob","fromBlob","overviews","fromUrls","fromUrl","assertEqual","expected","got","rejector","getMaxForDataType","Int8Array","Int16Array","Uint16Array","Int32Array","Uint32Array","GeoTIFFSource","sourceInfo_","numSources","sourceOptions_","sourceOptions","sourceImagery_","sourceMasks_","resolutionFactors_","samplesPerPixel_","nodataValues_","metadata_","normalize_","addAlpha_","convertToRGB_","convertToRGB","configure_","logError","determineProjection","firstSource","commonRenderTileSizes","commonSourceTileSizes","samplesPerPixel","nodataValues","metadata","sourceCount","sourceIndex","images","masks","NewSubfileType","imageCount","sourceOrigin","sourceTileSizes","renderTileSizes","sourceResolutions","imageIndex","nodataValue","getGDALNoData","getGDALMetadata","wantedSamples","bands","imageResolutions","sourceTileSize","getTileWidth","getTileHeight","aspectRatio","resolutionFactor","scaledSourceResolutions","reverse","sourceImagery","unshift","outer","nodata","loadTile_","sourceInfo","pool","Pool","pixelBounds","samples","fillValue","bandNumber","sampleIndex","readOptions","interleave","readRasters","maskIndex","composeTile_","sourceSamples","addAlpha","dataLength","pixelIndex","transparent","gain","bias","stats","sourceValue","bandIndex","nodataIsNaN","$ol$source$GeoTIFF","zoomifyImage_","$ol$source$Zoomify","tierSizeCalculation","tierSizeInTiles","tileSizeForTierSizeCalculation","tileCountUpToTier","tileWidth","tileIndex","localContext","TileGroup","ZoomifyTileClass","CustomTile","testTileUrl","Versions","IIIF_PROFILE_VALUES","level0","supports","formats","qualities","level1","level2","COMPLIANCE_VERSION1","COMPLIANCE_VERSION2","COMPLIANCE_VERSION3","versionFunctions","iiifInfo","levelProfile","getComplianceLevelSupportedFeatures","imageInfo","scale_factors","tile_width","tile_height","additionalProfile","profile","profileSupports","profileFormats","profileQualities","tiles","scaleFactors","extraFormats","preferredFormat","preferredFormats","extraFeatures","extraQualities","$ol$format$IIIFInfo","setImageInfo","getImageApiVersion","getComplianceLevelEntryFromProfile","identifier","version","getComplianceLevelFromProfile","complianceLevel","getTileSourceOptions","preferredOptions","imageOptions","quality","formatPercentage","percentage","toLocaleString","maximumFractionDigits","$ol$source$IIIF","partialOptions","baseUrl","supportsListedSizes","supportsListedTiles","isInteger","supportsArbitraryTiling","tileHeight","LN2","maxScaleFactor","ignoredSizesIndex","IiifTileClass","regionParam","sizeParam","tileX","tileY","regionX","regionY","regionW","regionH","sizeW","sizeH","regionWidth","regionHeight","$ol$reproj$Image","getImageFunction","sourceImage","sourcePixelRatio","targetExtent_","sourceImage_","sourcePixelRatio_","sourceListenerKey_","unlistenSource_","DECIMALS","ImageSourceEventType","ImageSourceEvent","defaultImageLoadFunction","getRequestExtent","imageResolution","$ol$source$Image","reprojectedImage_","reprojectedRevision_","wantedExtent_","wantedResolution_","static_","wantedProjection_","setResolutions","findNearestResolution","getImageInternal","ReprojImage","requestExtent","handleImageChange","appendParams","uri","keyParams","encodeURIComponent","qs","getRequestUrl","srid","modifiedUrl","createLoader","F","FORMAT","TRANSPARENT","$ol$source$ImageArcGISRest","ImageSource","imageLoadFunction_","imageLoadFunction","params_","imageSize_","renderedRevision_","ratio_","loaderProjection_","getParams","getImageLoadFunction","setImageLoadFunction","updateParams","$ol$source$ImageCanvas","canvasFunction_","canvasFunction","canvasElement","ImageCanvas","useOverlay","displayDpi","dpi","mcsW","mcsH","devW","devH","mpp","getScale","baseParams","OPERATION","VERSION","LOCALE","CLIENTAGENT","CLIP","SETDISPLAYDPI","SETDISPLAYWIDTH","SETDISPLAYHEIGHT","SETVIEWSCALE","SETVIEWCENTERX","SETVIEWCENTERY","$ol$source$ImageMapGuide","displayDpi_","useOverlay_","imageExtent","resolutionX","resolutionY","$ol$source$ImageStatic","imageExtent_","getImageExtent","DEFAULT_VERSION","GETFEATUREINFO_IMAGE_SIZE","v13","substr","getImageSrc","serverType","REQUEST","getRequestParams","SERVICE","STYLES","getFeatureInfoUrl","projectionObj","QUERY_LAYERS","INFO_FORMAT","getLegendUrl","LAYERS","mpu","$ol$source$ImageWMS","serverType_","sourceProjectionObj","knownMapMediaTypes","knownVectorMediaTypes","getMapTileUrlTemplate","links","mediaType","tileUrlTemplate","fallbackUrlTemplate","link","rel","startsWith","getVectorTileUrlTemplate","supportedMediaTypes","hrefLookup","supportedMediaType","parseTileMatrixSet","tileMatrixSet","tileMatrixSetLimits","crs","backwards","matrices","tileMatrices","matrixLookup","matrix","limitLookup","matrixIds","limit","tileMatrix","pointOfOrigin","cellSize","matrixWidth","matrixHeight","tileMapWidth","minTileCol","maxTileCol","tileMapHeight","cornerOfOrigin","minTileRow","maxTileRow","intersectExtents","grid","urlTemplate","urlFunction","upsideDown","tileCol","tileRow","getTileSetInfo","tileSet","tileMatrixSetLink","tileMatrixSetDefinition","parseTileSetMetadata","$ol$source$OGCMapTile","handleTileSetInfo_","handleError_","tileSetInfo","$ol$source$VectorTile","defaultLoadFunction","sourceTileCache","tileGrids_","sourceTile","tileFeatures","usedSourceTiles","cacheKey","bufferExtent","sourceZ","sourceTileCoord","sourceTileState","listenChange","sourceTileKey","coordKey","tileExtent","empty","VectorRenderTile","$ol$source$OGCVectorTile","VectorTileSource","ATTRIBUTION","$ol$source$OSM","$ol$layer$BaseImage","$ol$renderer$Layer","boundHandleImageChange_","handleImageChange_","layer_","declutterExecutorGroup","loadedTileCallback","createLoadedTileFinder","getLayer","renderIfReadyAndVisible","loadImage","pixelContext","$ol$renderer$canvas$Layer","LayerRenderer","tempTransform","pixelTransform","containerReused","pixelContext_","col","row","useContainer","backgroundColor","layerClassName","firstElementChild","transformOrigin","clipUnrotated","topLeft","topRight","bottomRight","bottomLeft","inverted","dispatchRenderEvent_","preRender","postRender","getRenderTransform","$ol$renderer$canvas$ImageLayer","CanvasLayerRenderer","imageLayer","viewResolution","imageSource","renderedExtent","imageMapWidth","imageMapHeight","imageResolutionX","imageResolutionY","viewCenter","canvasTransform","toTransformString","clipped","dw","dh","previousAlpha","$ol$layer$Image","BaseImageLayer","CanvasImageLayerRenderer","TileProperty","$ol$layer$BaseTile","preload","useInterimTilesOnError","setPreload","setUseInterimTilesOnError","getPreload","getUseInterimTilesOnError","$ol$renderer$canvas$TileLayer","tileLayer","extentChanged","renderedExtent_","renderedPixelRatio","renderedProjection","renderedTiles","newTiles_","tmpExtent","tmpTileRange_","isDrawableTile","tileOrigin","tileSource","sourceRevision","canvasExtent","tilesToDrawByZ","findLoadedTiles","tmpTileRange","childTileRange","canvasScale","clips","clipZs","currentClip","zs","currentZ","currentTilePixelSize","currentScale","originTileCoord","originTileExtent","tileGutter","tilesToDraw","xIndex","nextX","yIndex","nextY","contextSaved","drawTileImage","updateUsedTiles","manageTilePyramid","scheduleExpireCache","getTileImage","alphaChanged","postRenderFunction","tileCallback","$ol$layer$Tile","BaseTileLayer","CanvasTileLayerRenderer","hasImageData","ImageData","newImageData","createMinion","operation","workerHasImageData","newWorkerImageData","buffers","meta","imageOps","numBuffers","numBytes","arrays","pixels","createWorker","onMessage","lines","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_","iMax","sourceOrLayer","attributionGetter","sourceAttribution","setOperation","updateFrameState_","allSourcesReady_","imageDatas","onWorkerComplete_","layerOrSource","TileLayer","ImageLayer","$ol$source$Raster","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_watercolor","alidade_smooth","alidade_smooth_dark","outdoors","osm_bright","ProviderConfig","retina","$ol$source$StadiaMaps","provider","providerConfig","layerConfig","query","apiKey","OSM_ATTRIBUTION","$ol$source$TileArcGISRest","getKeyForParams_","getRequestUrl_","$ol$source$TileDebug","strokeRect","$ol$source$TileJSON","tileJSON_","requestJSONP","handleTileJSONResponse","handleTileJSONError","onXHRLoad_","onXHRError_","tileJSON","getTileJSON","epsg4326Projection","gridExtent","attributionExtent","$ol$source$TileWMS","v13_","updateV13_","sourceProjCoord","preemptive","preemptive_","grid_","keys_","jsonp_","xRelative","yRelative","forDataAtCoordinate","loadInternal_","$ol$source$UTFGrid","tileUrlFunction_","template_","getTemplate","forDataAtCoordinateAndResolution","grids","WMTSTileGrid","matrixIds_","getMatrixId","getMatrixIds","$ol$tilegrid$WMTS","createFromCapabilitiesMatrixSet","matrixSet","matrixLimits","matrixIdsPropName","identifierPropName","scaleDenominatorPropName","topLeftCornerPropName","switchOriginXY","elt","matrixAvailable","elt_ml","$ol$source$WMTS","requestEncoding","version_","dimensions_","dimensions","matrixSet_","requestEncoding_","getKeyForDimensions_","createFromWMTSTemplate","getDimensions","getMatrixSet","getRequestEncoding","getVersion","updateDimensions","tilematrixset","Service","Request","Version","Format","TileMatrix","TileCol","TileRow","ARRAY_BUFFER","ELEMENT_ARRAY_BUFFER","STATIC_DRAW","DYNAMIC_DRAW","FLOAT","CONTEXT_IDS","attributes","preserveDrawingBuffer","antialias","supportedExtensions","XML_SCHEMA_INSTANCE_URI","createElementNS","namespaceURI","qualifiedName","getDocument","getAllTextContent","normalizeWhitespace","getAllTextContent_","accumulator","nodeType","Node","CDATA_SECTION_NODE","TEXT_NODE","nodeValue","nextSibling","isDocument","getAttributeNS","xml","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","parsers","parser","pushParseAndPop","pushSerializeAndPop","xmlSerializer_","document_","getXMLSerializer","XMLSerializer","implementation","createDocument","$ol$webgl$BaseTileRepresentation","helper_","helper","setTile","uploadTile","setReady","BufferUsage","getArrayClassForType","$ol$webgl$Buffer","usage","usage_","ofSize","fromArray","fromArrayBuffer","getUsage","ContextEventType","$ol$webgl$PostProcessingPass","gl_","webGlContext","gl","scaleRatio_","scaleRatio","renderTargetTexture_","createTexture","renderTargetTextureSize_","frameBuffer_","createFramebuffer","depthBuffer_","createRenderbuffer","vertexShader","createShader","VERTEX_SHADER","shaderSource","compileShader","fragmentShader","FRAGMENT_SHADER","renderTargetProgram_","createProgram","attachShader","linkProgram","renderTargetVerticesBuffer_","createBuffer","bindBuffer","bufferData","renderTargetAttribLocation_","getAttribLocation","renderTargetUniformLocation_","getUniformLocation","renderTargetOpacityLocation_","renderTargetTextureLocation_","uniforms_","uniforms","location","getGL","init","drawingBufferWidth","drawingBufferHeight","bindFramebuffer","FRAMEBUFFER","getFrameBuffer","bindRenderbuffer","RENDERBUFFER","getDepthBuffer","internalFormat","RGBA","UNSIGNED_BYTE","bindTexture","TEXTURE_2D","texImage2D","texParameteri","TEXTURE_MIN_FILTER","LINEAR","TEXTURE_WRAP_S","CLAMP_TO_EDGE","TEXTURE_WRAP_T","framebufferTexture2D","COLOR_ATTACHMENT0","renderbufferStorage","DEPTH_COMPONENT16","framebufferRenderbuffer","DEPTH_ATTACHMENT","nextPass","preCompose","postCompose","activeTexture","TEXTURE0","canvasId","getContextAttributes","clearColor","clearDepth","COLOR_BUFFER_BIT","DEPTH_BUFFER_BIT","DEPTH_TEST","enable","BLEND","blendFunc","ONE","ONE_MINUS_SRC_ALPHA","useProgram","enableVertexAttribArray","vertexAttribPointer","uniform2f","uniform1i","uniform1f","applyUniforms","drawArrays","TRIANGLES","textureSlot","uniform","texture","uniform3f","uniform4f","fromTransform","mat4","DefaultUniform","PROJECTION_MATRIX","SCREEN_TO_WORLD_MATRIX","TIME","ZOOM","VIEWPORT_SIZE_PX","PIXEL_RATIO","HIT_DETECTION","AttributeType","UNSIGNED_SHORT","UNSIGNED_INT","canvasCache","getSharedCanvasCacheKey","uniqueCanvasCacheKeyCount","computeAttributesStride","attr","getByteSizeFromType","$ol$webgl$Helper","boundHandleWebGLContextLost_","handleWebGLContextLost","boundHandleWebGLContextRestored_","handleWebGLContextRestored","canvasCacheKey_","canvasCacheKey","getUniqueCanvasCacheKey","cacheItem","users","getOrCreateContext","bufferCache_","extensionCache_","currentProgram_","needsToBeRecreated_","offsetRotateMatrix_","offsetScaleMatrix_","tmpMat4_","uniformLocationsByProgram_","attribLocationsByProgram_","setUniforms","postProcessPasses_","postProcesses","WebGLPostProcessingPass","shaderCompileErrors_","addUniforms","canvasCacheKeyMatches","getExtension","bufferKey","bufferCache","webGlBuffer","flushBufferData","deleteBuffer","buf","bufferCacheEntry","isContextLost","loseContext","prepareDraw","disableAlphaBlend","enableDepth","getCanvas","depthRange","ZERO","depthFunc","LEQUAL","slot","uniformName","prepareDrawToRenderTarget","renderTarget","getFramebuffer","getDepthbuffer","getTexture","drawElements","elementType","numItems","offsetInBytes","finalizeDraw","applyFrameState","setUniformFloatValue","setUniformFloatVec2","applyHitDetectionUniform","loc","prevValue","setUniformMatrixValue","program","shader","getProgram","fragmentShaderSource","vertexShaderSource","getShaderParameter","COMPILE_STATUS","getShaderInfoLog","deleteShader","getProgramParameter","LINK_STATUS","getProgramInfoLog","programUid","getAttributeLocation","makeProjectionTransform","uniform2fv","setUniformFloatVec4","uniform4fv","uniformMatrix4fv","enableAttributeArray_","attribName","enableAttributes","needsToBeRecreated","$ol$webgl$PaletteTexture","texture_","NEAREST","TEXTURE_MAG_FILTER","tmpArray4","$ol$webgl$RenderTarget","framebuffer_","depthbuffer_","dataCacheDirty_","updateSize_","clearCachedData","readAll","readPixels","readPixel","earcut","holeIndices","dim","invSize","hasHoles","outerLen","outerNode","linkedList","triangles","next","list","steiner","getLeftmost","compareX","eliminateHole","eliminateHoles","earcutLinked","clockwise","signedArea","insertNode","filterPoints","again","ear","zOrder","prevZ","nextZ","q","tail","numMerges","pSize","qSize","inSize","sortLinked","indexCurve","isEarHashed","isEar","cureLocalIntersections","splitEarcut","ax","bx","cx","ay","by","cy","pointInTriangle","minZ","maxZ","locallyInside","isValidDiagonal","splitPolygon","hole","bridge","hx","hy","qx","mx","my","tanMin","sectorContainsSector","findHoleBridge","bridgeReverse","leftmost","py","intersectsPolygon","inside","middleInside","p1","p2","q1","q2","o1","sign","o2","o3","o4","onSegment","num","an","bp","sum","earcutModule","exports","default","deviation","polygonArea","trianglesArea","flatten","holes","holeIndex","LINESTRING_ANGLE_COSINE_CUTOFF","tmpArray_","bufferPositions_","vertexPosition","indexPosition","writePointVertex","colorEncodeId","radix","divide","colorDecodeId","mult","numTypes","NoneType","BooleanType","NumberType","StringType","ColorType","NumberArrayType","AnyType","typeNames","namedTypes","typeName","namedType","includesType","broad","specific","overlapsType","oneType","otherType","isType","LiteralExpression","CallExpression","operator","newParsingContext","variables","encoded","typeHint","parseCallExpression","Ops","Get","Var","Concat","GeometryType","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","Case","In","Color","Id","Band","Palette","createParser","getTypeFromHint","withArgsCount","firstArg","parsedArgs","varName","initialValue","withNoArgs","parseArgsOfType","narrowArgsType","outputType","withEvenArgs","argsCount","inputType","fallback","expectedInputType","interpolationType","interpolation","argCount","needleType","colors","parsedColors","minArgs","maxArgs","argType","expression","gotType","expectedType","sameType","returnType","argValidators","actualType","bindAndConfigure","resampleFilter","uploadDataTexture","textureType","canInterpolate","unpackAlignment","LUMINANCE","LUMINANCE_ALPHA","RGB","oldUnpackAlignment","getParameter","UNPACK_ALIGNMENT","pixelStorei","$ol$webgl$TileTexture","BaseTileRepresentation","textures","renderSize_","WebGLArrayBuffer","uploadImageTexture","textureCount","textureDataArrays","textureIndex","dataValue","textureData","deleteTexture","getImagePixelData_","renderCol","renderRow","renderWidth","renderHeight","sourceWidthWithoutGutter","sourceHeightWithoutGutter","sourceCol","sourceRow","getArrayPixelData_","sourceSize","sourceWidth","sourceHeight","getPixelData","WebGLLayerRenderer","inversePixelTransform_","postProcesses_","removeHelper","dispatchPreComposeEvent","dispatchPostComposeEvent","incrementGroup","groupNumber","WebGLHelper","afterHelperCreated","prepareFrameInternal","$ol$renderer$webgl$Layer","Uniforms","TILE_TRANSFORM","TRANSITION_ALPHA","DEPTH","RENDER_EXTENT","PATTERN_ORIGIN","GLOBAL_ALPHA","depthForZ","newTileRepresentationLookup","tileIds","representationsByZ","lookupHasTile","tileRepresentationLookup","has","addTileRepresentationToLookup","tileRepresentation","getRenderExtent","getCacheKey","getTileCoordKey","$ol$renderer$webgl$TileLayerBase","renderComplete","tileTransform_","tempMat4","tempTileRange_","tempTileCoord_","createTileCoord","tempSize_","tileRepresentationCache","isDrawableTile_","clearCache","createTileRepresentation","enqueueTiles","initialZ","tileQueueKey","beforeTilesRender","tilesWithAlpha","beforeTilesMaskRender","renderTile","tileTransform","renderExtent","depth","renderTileMask","tileZ","drawTile_","alphaLookup","tileWidthWithGutter","tileHeightWithGutter","centerI","centerJ","tileScale","tileCenterI","tileCenterJ","resetTransform","scaleTransform","rotateTransform","translateTransform","targetZ","blend","findAltTiles_","parentZ","altZ","BaseUniforms","TILE_TEXTURE_ARRAY","TEXTURE_PIXEL_WIDTH","TEXTURE_PIXEL_HEIGHT","TEXTURE_RESOLUTION","TEXTURE_ORIGIN_X","TEXTURE_ORIGIN_Y","Attributes","TEXTURE_COORD","attributeDescriptions","$ol$renderer$webgl$TileLayer","WebGLBaseTileLayerRenderer","program_","vertexShader_","fragmentShader_","indices_","paletteTextures_","paletteTextures","TileTexture","tileTexture","paletteIndex","paletteTexture","mat4FromTransform","gutterExtent","getSources","tileTextureCache","deleteProgram","numberToGlsl","arrayToGlsl","colorToGlsl","stringToFloatMap","stringToFloatCounter","getStringNumberEquivalent","string","stringToGlsl","uniformNameForVariable","variableName","newCompilationContext","inFragmentShader","functions","GET_BAND_VALUE_FUNC","PALETTE_TEXTURE_ARRAY","buildExpression","parsingContext","compilationContext","actual","compile","createCompiler","compilers","propName","computeType","evaluator","compiledArgs","firstValue","secondValue","exponent","stop1","output1","stop2","output2","funcName","computeOperatorFunctionName","tests","band","xOffset","yOffset","ifBlocks","colorIndex","numColors","palette","paletteName","PaletteTexture","compiler","createDefaultStyle","COMMON_HEADER","DEFAULT_STYLE","ShaderBuilder","attributes_","varyings_","hasSymbol_","symbolSizeExpression_","symbolRotationExpression_","symbolOffsetExpression_","symbolColorExpression_","texCoordExpression_","discardExpression_","symbolRotateWithView_","hasStroke_","strokeWidthExpression_","strokeColorExpression_","strokeOffsetExpression_","strokeCapExpression_","strokeJoinExpression_","strokeMiterLimitExpression_","strokeDistanceFieldExpression_","hasFill_","fillColorExpression_","vertexShaderFunctions_","fragmentShaderFunctions_","addUniform","addAttribute","addVarying","setSymbolSizeExpression","getSymbolSizeExpression","setSymbolRotationExpression","setSymbolOffsetExpression","getSymbolOffsetExpression","setSymbolColorExpression","getSymbolColorExpression","setTextureCoordinateExpression","setFragmentDiscardExpression","getFragmentDiscardExpression","setSymbolRotateWithView","rotateWithView","setStrokeWidthExpression","setStrokeColorExpression","getStrokeColorExpression","setStrokeOffsetExpression","setStrokeCapExpression","setStrokeJoinExpression","setStrokeMiterLimitExpression","setStrokeDistanceFieldExpression","setFillColorExpression","getFillColorExpression","addVertexShaderFunction","addFragmentShaderFunction","getSymbolVertexShader","attribute","varying","getSymbolFragmentShader","getStrokeVertexShader","getStrokeFragmentShader","getFillVertexShader","getFillFragmentShader","getFlatCoordinatesXY","flatCoords","$ol$render$webgl$MixedGeometryBatch","globalCounter_","refToFeature_","Map","uidToRef_","freeGlobalRef_","polygonBatch","entries","geometriesCount","verticesCount","ringsCount","pointBatch","lineStringBatch","projectionTransform","addGeometry_","clearFeatureEntryInPointBatch_","flatCoordss","clearFeatureEntryInLineStringBatch_","clearFeatureEntryInPolygonBatch_","multiPolygonGeom","addCoordinates_","multiLineGeom","multiPointGeom","polygonGeom","pointGeom","lineGeom","featureUid","multiPolygonEndss","polygonEnds","prevPolygonEnds","endIndex","multiLineEnds","multiPolygonEnds","addRefToEntry_","ringsVerticesCounts","ringsVerticesCount","ind","currentRef","ref","returnRef_","changeFeature","getFeatureFromRef","$ol$webgl$TileGeometry","styleRenderers","batch_","MixedGeometryBatch","styleRenderers_","maskVertices","generateMaskBuffer_","generatePromises","generateBuffers","expressionToGlsl","packColor","getGlslSizeFromType","getGlslTypeFromType","computeHash","parseCommonSymbolProperties","builder","vertContext","prefix","getColorFromDistanceField","distanceField","fillColor","strokeColor","strokeWidth","parseImageProperties","textureId","parseImageOffsetProperties","sampleSize","offsetExpression","parseLiteralStyle","fragContext","sizeExpression","fullsize","shiftPx","offsetPx","parseIconProperties","currentPoint","numPoints","shapeField","radiusOuter","radiusInner","colorExpression","parseShapeProperties","parseCircleProperties","sampleSizeExpression","spacingExpression","textureName","tintExpression","dashPattern","dashFunctionName","dashLengthsDef","totalLengthDef","currentDashOffset","distanceExpression","parseStrokeProperties","parseFillProperties","parsedFilter","variable","functionName","ImageStyle","opacity_","rotateWithView_","scale_","scaleArray_","displacement_","displacement","declutterMode_","getDisplacement","getHitDetectionImage","getImageSize","setDisplacement","setRotateWithView","setScale","$ol$style$Image","RegularShape","canvases_","hitDetectionCanvas_","fill_","radius_","radius1","radius2_","radius2","stroke_","renderOptions_","getRadius2","setFill","createHitDetectionCanvas_","renderOptions","draw_","setStroke","calculateLineJoinSize_","r1","r2","miterRatio","bevelAdd","aa","dd","innerMiterRatio","innerLength","createRenderOptions","maxRadius","createPath_","drawHitDetectionCanvas_","angle0","radiusC","$ol$style$RegularShape","CircleStyle","$ol$style$Circle","Fill","color_","setColor","$ol$style$Fill","taintedTestContext","IconImage","hitDetectionImage_","imageState_","tainted_","initializeImage_","isTainted_","dispatchChangeEvent_","replaceColor_","getSrc","$ol$style$IconImage","calculateScale","wantedWidth","wantedHeight","Icon","normalizedAnchor_","anchorOrigin_","anchorOrigin","anchorXUnits_","anchorXUnits","anchorYUnits_","anchorYUnits","iconImage_","getIconImage","offset_","offsetOrigin_","offsetOrigin","initialOptions_","setAnchor","iconImageSize","$ol$style$Icon","Stroke","lineCap_","lineDash_","lineDashOffset_","lineJoin_","miterLimit_","width_","setLineCap","setLineDashOffset","setLineJoin","setMiterLimit","setWidth","$ol$style$Stroke","Style","geometryFunction_","defaultGeometryFunction","hitDetectionRenderer_","zIndex_","setRenderer","setHitDetectionRenderer","setText","toFunction","defaultStyles","createEditingStyle","$ol$style$Style","Text","font_","textAlign_","justify_","justify","repeat_","repeat","textBaseline_","maxAngle_","maxAngle","placement_","placement","overflow_","offsetX_","offsetY_","backgroundFill_","backgroundFill","backgroundStroke_","backgroundStroke","getPlacement","getRepeat","getMaxAngle","getOverflow","getJustify","getBackgroundFill","getBackgroundStroke","getPadding","setOverflow","setFont","setMaxAngle","setOffsetX","setOffsetY","setPlacement","setRepeat","setTextAlign","setJustify","setTextBaseline","setBackgroundFill","setBackgroundStroke","setPadding","$ol$style$Text","$ol$structs$LinkedList","first_","last_","head_","circular_","length_","insertItem","removeItem","firstItem","lastItem","nextItem","getNextItem","prevItem","getPrevItem","getCurrItem","setFirstItem","newEvaluationContext","compileExpression","colorValue","compileAssertionExpression","nameExpression","compileAccessorExpression","op","compileLogicalExpression","compileComparisonExpression","compileNumericExpression","compileMatchExpression","previousInput","previousOutput","isColor","interpolateColor","interpolateNumber","compileInterpolateExpression","input1","input2","rgba1","rgba2","lcha1","lcha2","deltaHue","rulesToStyleFunction","rules","buildRuleSet","evaluationContext","flatStylesToStyleFunction","flatStyles","evaluators","buildStyle","nonNullCount","compiledRules","rule","styleLength","someMatched","filterEvaluator","else","styleEvaluator","flatStyle","evaluateFill","buildFill","evaluateStroke","buildStroke","evaluateText","evaluateValue","stringEvaluator","evaluateBackgroundFill","evaluateBackgroundStroke","evaluateFont","evaluateMaxAngle","numberEvaluator","evaluateOffsetX","evaluateOffsetY","evaluateOverflow","booleanEvaluator","evaluatePlacement","evaluateRepeat","evaluateScale","sizeLikeEvaluator","evaluateRotateWithView","evaluateRotation","evaluateAlign","evaluateJustify","evaluateBaseline","evaluatePadding","numberArrayEvaluator","buildText","evaluateImage","srcName","requireString","evaluateAnchor","coordinateEvaluator","evaluateOpacity","evaluateDisplacement","optionalIconOrigin","optionalIconAnchorUnits","requireColorLike","optionalColorLike","optionalString","requireNumberArray","optionalNumberArray","optionalNumber","optionalSize","optionalDeclutterMode","icon","buildIcon","pointsName","requireNumber","shape","buildShape","evaluateRadius","buildCircle","buildImage","evaluateZIndex","evaluateColor","colorLikeEvaluator","evaluateWidth","evaluateLineCap","evaluateLineJoin","evaluateLineDash","evaluateLineDashOffset","evaluateMiterLimit","requireSizeLike","$ol$layer$BaseVector","renderBuffer","updateWhileAnimating","updateWhileInteracting","declutter_","declutter","renderBuffer_","updateWhileAnimating_","updateWhileInteracting_","getDeclutter","getRenderBuffer","getRenderOrder","getUpdateWhileAnimating","getUpdateWhileInteracting","setRenderOrder","renderOrder","toStyleLike","toStyleFunction","WebGLWorkerMessageType","getWorldParameters","endWorld","$ol$renderer$webgl$PointsLayer","projectionMatrixTransform","sourceRevision_","verticesBuffer_","indicesBuffer_","hitDetectionEnabled_","hitDetectionEnabled","customAttributes","currentTransform_","renderTransform_","invertRenderTransform_","renderInstructions_","hitRenderTarget_","lastSentId","worker_","createWebGLWorker","received","vertexBuffer","indexBuffer","makeInverseTransform","renderInstructions","featureCache_","featureCount_","sourceListenKeys_","handleSourceFeatureAdded_","handleSourceFeatureChanged_","handleSourceFeatureDelete_","handleSourceFeatureClear_","WebGLRenderTarget","startWorld","renderWorlds","vectorSource","viewNotMoving","sourceChanged","BaseVector","rebuildBuffers_","singleInstructionLength","totalSize","featureCache","tmpCoords","tmpColor","idx","userCoords","hitColor","customAttributesSize","forHitDetection","world","renderCount","pushCustomAttributesInRenderInstructions","batchEntry","currentIndex","getCustomAttributesSize","generatePointRenderInstructions","batch","totalInstructionsCount","renderIndex","generateLineStringRenderInstructions","generatePolygonRenderInstructions","WEBGL_WORKER","workerMessageCounter","$ol$render$webgl$VectorStyleRenderer","styleOrShaders","enableHitDetection","shaders","parseResult","fillVertexShader_","fillFragmentShader_","fillProgram_","strokeVertexShader_","strokeFragmentShader_","strokeProgram_","symbolVertexShader_","symbolFragmentShader_","symbolProgram_","hitDetectionAttributes","customAttributes_","customAttributesDesc","polygonAttributesDesc_","lineStringAttributesDesc_","pointAttributesDesc_","geometryBatch","generateRenderInstructions_","polygonBuffers","lineStringBuffers","pointBuffers","generateBuffersForType_","polygonInstructions","lineStringInstructions","pointInstructions","invertVerticesTransform","messageId","messageType","renderInstructionsTransform","handleMessage","verticesBuffer","indicesBuffer","preRenderCallback","renderInternal_","$ol$renderer$webgl$VectorLayer","disableHitDetection","tmpCoords_","tmpTransform_","currentFrameStateTransform_","styles_","buffers_","initialFeaturesAdded_","addInitialFeatures_","createRenderers_","VectorStyleRenderer","applyUniforms_","batchInvertTransform","setFromTransform","TILE_MASK_TEXTURE","TILE_ZOOM_LEVEL","POSITION","$ol$renderer$webgl$VectorTileLayer","tileMaskTarget_","tileMaskIndices_","tileMaskAttributes_","tileMaskProgram_","initTileMask_","addBuilderParams","exisitingDiscard","discardFromMask","tileRep","TileGeometry","Instruction","fillInstruction","strokeInstruction","beginPathInstruction","closePathInstruction","$ol$render$canvas$Builder","maxLineWidth","beginGeometryInstruction1_","beginGeometryInstruction2_","bufferedMaxExtent_","instructions","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","instruction","createFill","applyStroke","createStroke","updateFillStyle","currentFillStyle","updateStrokeStyle","currentStrokeStyle","currentLineCap","currentLineDash","currentLineDashOffset","currentLineJoin","currentLineWidth","currentMiterLimit","endGeometryInstruction","$ol$render$canvas$ImageBuilder","CanvasBuilder","imagePixelRatio_","anchorX_","anchorY_","height_","originX_","originY_","declutterImageWithText_","myBegin","sharedData","$ol$render$canvas$LineStringBuilder","drawFlatCoordinates_","moveToLineToInstruction","lastStroke","$ol$render$canvas$PolygonBuilder","drawFlatCoordinatess_","numEnds","setFillStrokeStyles_","circleInstruction","lineChunk","chunkLength","cursor","chunkM","currentChunk","missing","matchingChunk","acos","m12","m23","x12","y12","x23","y23","chunkStart","chunkEnd","TEXT_ALIGN","middle","hanging","alphabetic","ideographic","bottom","$ol$render$canvas$TextBuilder","labels_","fillStates","strokeStates","textStates","textKey_","fillKey_","strokeKey_","geometryWidths","beg","saveTextStates_","p0","p3","flatOffset","oo","cc","chunk","chunkBegin","drawChars_","strokeKey","textKey","fillKey","baseline","BATCH_CONSTRUCTORS","PolygonBuilder","Default","Builder","ImageBuilder","LineStringBuilder","TextBuilder","$ol$render$canvas$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","p4","getDeclutterBox","replayImageOrLabelArgs","declutterBox","rtlRegEx","horizontalTextAlign","align","createTextChunks","line","$ol$render$canvas$Executor","alignFill_","coordinateCache_","renderedTransform_","widths_","createLabel","textIsArray","leftRight","strokeInstructions","fillInstructions","previousFont","lineOffset","widthHeightIndex","lineWidthIndex","fillStrokeArgs","replayTextBackground_","setStrokeStyle_","calculateImageOrLabelDimensions_","sheetWidth","sheetHeight","snapToPixel","fillStroke","boxW","boxH","boxX","boxY","drawImageX","drawImageY","drawImageW","drawImageH","replayImageOrLabel_","contextScale","imageOrLabel","strokePadding","repeatSize","drawLabelWithPointPlacement_","execute_","featureCallback","hitExtent","transformSetFromArray","prevX","prevY","roundX","roundY","pendingFill","pendingStroke","lastFillInstruction","lastStrokeInstruction","coordinateCache","viewRotationFromTransform","batchSize","currentGeometry","labelWithAnchor","widthIndex","imageArgs","imageDeclutterBox","measurePixelRatio","pixelRatioScale","cachedWidths","pathLength","textLength","drawChars","part","execute","executeHitDetection","ORDER","circlePixelIndexArrayCache","getPixelIndexArray","maxDistanceSq","distances","$ol$render$canvas$ExecutorGroup","allInstructions","executorsByZIndex_","hitDetectionContext_","hitDetectionTransform_","createExecutors_","flatClipCoords","getClipCoords","executors","instructionByZindex","Executor","hasExecutors","candidates","declutteredFeatures","contextSize","newContext","executor","builderTypes","HIT_DETECT_RESOLUTION","createHitDetectionImageData","featureCount","indexFactor","featuresByZIndex","featureStyleFunction","padStart","originalStyle","imgSize","imgContext","byGeometryType","zIndexKeys","geomAndStyle","kk","hitDetect","resultFeatures","$ol$renderer$canvas$VectorLayer","vectorLayer","boundHandleStyleImageChange_","handleStyleImageChange_","animatingOrInteracting_","hitDetectionImageData_","renderedFeatures_","renderedResolution_","wrappedRenderedExtent_","renderedRotation_","renderedCenter_","renderedProjection_","renderedRenderOrder_","replayGroup_","replayGroupChanged","clipping","compositionContext_","executorGroup","setupCompositionContext_","compositionContext","releaseCompositionContext_","transformToString","animating","interacting","frameStateExtent","vectorLayerRevision","vectorLayerRenderBuffer","vectorLayerRenderOrder","defaultRenderOrder","loadExtents","wrapCoordinateX","loadExtent","wrapExtentX","CanvasBuilderGroup","getRenderTolerance","userExtent","getSquaredRenderTolerance","replayGroupInstructions","ExecutorGroup","$ol$renderer$canvas$VectorImageLayer","vectorRenderer_","CanvasVectorLayerRenderer","layerImageRatio_","getImageRatio","coordinateToVectorPixelTransform_","renderedPixelToCoordinateTransform_","vectorPixel","vectorRenderer","imageLayerState","imageFrameState","emptyImage","IMAGE_REPLAYS","hybrid","vector","VECTOR_REPLAYS","$ol$renderer$canvas$VectorTileLayer","renderedLayerRevision_","prepareTile","updateExecutorGroup_","tileImageNeedsRender_","hifi","getRenderMode","renderTileImage_","layerRevision","builderState","layerUid","tt","sourceTileExtent","sharedExtent","builderExtent","bufferedExtent","executorGroupInstructions","replayExtent","renderingReplayGroup","CanvasExecutorGroup","tilePixel","getTileRenderTransform","worldOffset","renderMode","replayTypes","replayState","renderPixelRatio","renderScale","pixelScale","registered","register","proj4","projCodes","defs","def","projName","axis","to_meter","code1","proj1","code2","proj2","epsgLookup","ok","$ol$layer$Vector","BaseVectorLayer","geoA","geoB","geoStack","fractionStack","fractions","geoM","fracA","fracB","fracM","maxIterations","meridian","lon","frac","parallel","lon2","DEFAULT_STROKE_STYLE","INTERVALS","$ol$layer$Graticule","VectorLayer","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","equivalentProjection","updateProjectionInfo_","createGraticule_","featuresColl","poolIndex","addMeridian_","minLat","maxLat","getMeridian_","geom","addParallel_","minLon","maxLon","getParallel_","rotationCenter","rotationExtent","unrotatedWidth","unrotatedHeight","labelsAtStart","vectorContext","textPoint","getMeridianPoint_","getParallelPoint_","getInterval_","validCenterP","centerLonLat","centerLon","centerLat","cnt","validExtentP","validExtent","clampedLat","clampedBottom","clampedTop","getMeridians","clampedLeft","clampedRight","getParallels","toLonLatTransform","lonLatCoordinates","worldExtentP","DEFAULT_GRADIENT","$ol$layer$Heatmap","gradient","blur","gradient_","handleGradientChanged_","setGradient","setBlur","weightFunction_","getBlur","getGradient","createLinearGradient","addColorStop","createGradient","WebGLPointsLayerRenderer","u_size","u_blurSlope","u_gradientTexture","u_opacity","$ol$layer$VectorImage","imageRatio","imageRatio_","CanvasVectorImageLayerRenderer","$ol$layer$VectorTile","renderMode_","CanvasVectorTileLayerRenderer","$ol$layer$WebGLPoints","parseResult_","styleVariables_","hitDetectionDisabled_","updateStyleVariables","parseStyle","pipeline","contrast","exposure","saturation","gamma","brightness","numVariables","uniformDeclarations","functionDefintions","WebGLTileLayer","sources_","renderedSource_","handleSourceUpdate_","getSourceBandCount_","MAX_SAFE_INTEGER","parsedStyle","WebGLTileLayerRenderer","renderSources","onChange","altSources","$ol$layer$WebGLTile","$ol$interaction$DblClickDragZoom","opt_options","scaleDeltaByPixel_","handlingDownUpSequence_","handlingDoubleDownSequence_","doubleTapTimeoutId_","trackedPointers_","waitForDblTap_","isPointerDraggingEvent","DragAndDropEventType","DragAndDropEvent","file","$ol$interaction$DragAndDrop","readAsBuffer_","formats_","formatConstructors","dropListenKeys_","source_","handleResult_","TextDecoder","tryReadFeatures_","registerListeners_","dropArea","handleDrop","handleStop","unregisterListeners_","files","dataTransfer","reader","FileReader","readAsArrayBuffer","readAsText","dropEffect","$ol$interaction$DragRotateAndZoom","lastMagnitude_","magnitude","angleDelta","DrawEventType","DrawEvent","getSquaredDistance","getCoordinate","getCumulativeSquaredDistance","lowIndex","highIndex","lowWholeIndex","highWholeIndex","interpolateCoordinate","appendGeometryTraceTargets","targets","appendTraceTarget","polys","sharedUpdateInfo","ring","getPointSegmentRelationship","sharedRel","getDefaultStyleFunction","$ol$interaction$Draw","shouldHandle_","downPx_","downTimeout_","lastDragTime_","pointerType_","freehand_","snapTolerance_","snapTolerance","getMode","stopClick_","stopClick","minPoints_","minPoints","maxPoints_","maxPoints","finishCondition_","finishCondition","geometryLayout_","geometryLayout","mode","squaredLength","squaredCoordinateDistance","dragVertexDelay_","dragVertexDelay","finishCoordinate_","sketchFeature_","sketchPoint_","sketchCoords_","sketchLine_","sketchLineCoords_","squaredClickTolerance_","clickTolerance","overlay_","geometryName","freehandCondition_","freehand","freehandCondition","traceCondition_","setTrace","trace","traceState_","traceSource_","traceSource","updateState_","getOverlay","move","addToDrawing_","startDrawing_","deactivateTrace_","toggleTraceState_","getTraceTargets","startPx","targetIndex","addOrRemoveTracedCoordinates_","previouslyForward","addTracedCoordinates_","removeTracedCoordinates_","fromIndex","toIndex","removeLastPoints_","appendCoordinates","updateTrace_","traceState","updatedTraceTarget","closestTargetDistance","newTargetIndex","newEndIndex","minSegmentDistance","coordinateIndex","newTarget","considerBothDirections","newCoordinate","forwardDistance","reverseDistance","getTraceTargetUpdate","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","ExtentEventType","ExtentEvent","getDefaultExtentStyleFunction","getDefaultPointerStyleFunction","getPointHandler","fixedPoint","getEdgeHandler","fixedP1","fixedP2","$ol$interaction$Extent","pointerHandler_","pixelTolerance_","pixelTolerance","snappedToVertex_","extentFeature_","vertexFeature_","extentOverlay_","boxStyle","vertexOverlay_","pointerStyle","snapToVertex_","pixelCoordinate","sortByDistance","getExtentInternal","segments","getSegments","closestSegment","vertex","vertexPixel","coordinateDistance","pixel1","pixel2","squaredDist1","squaredDist2","dist","createOrUpdatePointerFeature_","createOrUpdateExtentFeature_","extentFeature","vertexFeature","getOpposingPoint","x_","y_","readNumber","writeNumber","to5","differentNumber","$ol$interaction$Link","animationOptions","animationOptions_","replace_","prefix_","initial_","trackedCallbacks_","trackedValues_","getParamName_","get_","set_","delete_","oldMap","updateUrl_","handleChangeLayerGroup_","history","replaceState","updateView","viewProperties","layersParam","track","updateHistory_","visibilities","pushState","tempSegment","ModifyEventType","ModifyEvent","compareIndexes","projectedDistanceToSegmentDataSquared","pointCoordinates","segmentData","distanceToCenterSquared","distanceToCircumference","closestOnSegmentData","$ol$interaction$Modify","boundHandleFeatureChange_","defaultDeleteCondition_","deleteCondition_","deleteCondition","insertVertexCondition_","insertVertexCondition","vertexSegments_","lastPixel_","ignoreNextSingleClick_","featuresBeingModified_","rBush_","changingFeature_","dragSegments_","SEGMENT_WRITERS_","writePointGeometry_","writeLineStringGeometry_","writePolygonGeometry_","writeMultiPointGeometry_","writeMultiLineStringGeometry_","writeMultiPolygonGeometry_","writeCircleGeometry_","writeGeometryCollectionGeometry_","hitDetection_","handleSourceAdd_","handleSourceRemove_","hitDetection","addFeature_","handleFeatureAdd_","handleFeatureRemove_","lastPointerEvent_","snapToPointer_","snapToPointer","writer","handlePointerAtPixel_","willModifyFeatures_","ss","removeFeature_","removeFeatureSegmentData_","rBush","nodesToRemove","nodeToRemove","centerSegmentData","circumferenceSegmentData","featureSegments","createOrUpdateVertexFeature_","removePoint","dragSegment","setGeometryCoordinates_","insertVertices","vertexExtent","segmentDataMatches","componentSegments","segmentDataMatch","insertVertex_","nodes","hitPointGeometry","vertexSegments","geometryUid","rTree","updateSegmentIndices_","newSegmentData","newSegmentData2","removeVertex_","dragSegments","segmentsByFeature","component","newIndex","deleted","SelectEventType","SelectEvent","selected","deselected","originalFeatureStyles","Select","boundAddFeature_","boundRemoveFeature_","addCondition_","addCondition","removeCondition_","removeCondition","toggleCondition_","toggleCondition","multi_","multi","filter_","hitTolerance_","layerFilter_","featureLayerAssociation_","addFeatureLayerAssociation_","getHitTolerance","setHitTolerance","restorePreviousStyle_","applySelectedStyle_","removeFeatureLayerAssociation_","$ol$interaction$Select","SnapEventType","SnapEvent","getFeatureFromEvent","$ol$interaction$Snap","vertex_","edge_","featuresListenerKeys_","featureChangeListenerKeys_","indexedFeaturesExtents_","pendingFeatures_","GEOMETRY_SEGMENTERS_","segmentPointGeometry_","segmentLineStringGeometry_","segmentPolygonGeometry_","segmentMultiPointGeometry_","segmentMultiLineStringGeometry_","segmentMultiPolygonGeometry_","segmentGeometryCollectionGeometry_","segmentCircleGeometry_","feature_uid","segmenter","segmentsData","getFeatures_","snapTo","updateFeature_","featuresToUpdate","unregister","currentMap","projectedCoordinate","segmentsLength","closestVertex","squaredPixelTolerance","getResult","tempVertexCoord","segmentStart","segmentEnd","TranslateEventType","TranslateEvent","startCoordinate","$ol$interaction$Translate","lastCoordinate_","startCoordinate_","lastFeature_","handleActiveChanged_","featuresAtPixel_","newViewCoordinate","lastViewCoordinate","flipXY","destOffset","$ol$format$Feature","defaultFeatureProjection","featureClass","getReadOptions","adaptOptions","readFeature","readGeometry","writeFeature","writeFeatures","writeGeometry","transformGeometryWithOptions","write","fromProjection","toProjection","transformExtentWithOptions","GeometryConstructor","createRenderFeature","orientFlatCoordinates","createGeometry","getObject","$ol$format$JSONFeature","FeatureFormat","readFeatureFromObject","readFeaturesFromObject","readGeometryFromObject","readProjectionFromObject","writeFeatureObject","writeFeaturesObject","writeGeometryObject","GEOMETRY_READERS","getGeometryLayout","paths","GEOMETRY_WRITERS","esriJSON","hasZM","getHasZM","hasZ","hasM","esriJSONPolygon","flatRing","outerRings","matched","outerRing","convertRings","geometryReader","geometryWriter","$ol$format$EsriJSON","JSONFeature","idField","esriJSONFeature","esriJSONFeatures","objectIdFieldName","wkid","objects","$ol$format$XMLFeature","readFeatureFromDocument","readFeatureFromNode","readFeaturesFromDocument","readFeaturesFromNode","ELEMENT_NODE","readGeometryFromDocument","readGeometryFromNode","readProjectionFromDocument","readProjectionFromNode","writeFeatureNode","serializeToString","writeFeaturesNode","writeGeometryNode","GMLNS","ONLY_WHITESPACE_RE","GMLBase","XMLFeature","featureType","featureNS","srsName","schemaLocation","FEATURE_COLLECTION_PARSERS","namespace","featureMember","readFeaturesInternal","featureMembers","defaultPrefix","ns","featureTypes","readFeatureElement","readGeometryOrExtent","getAttribute","GEOMETRY_PARSERS","readExtentElement","readGeometryElement","readFeatureElementInternal","asFeature","_content_","fid","readPoint","readFlatCoordinatesFromNode","readMultiPoint","MULTIPOINT_PARSERS","readMultiLineString","MULTILINESTRING_PARSERS","readMultiPolygon","MULTIPOLYGON_PARSERS","pointMemberParser","POINTMEMBER_PARSERS","lineStringMemberParser","LINESTRINGMEMBER_PARSERS","polygonMemberParser","POLYGONMEMBER_PARSERS","readLineString","readFlatLinearRing","GEOMETRY_FLAT_COORDINATES_PARSERS","readLinearRing","readPolygon","flatLinearRings","FLAT_LINEAR_RINGS_PARSERS","internalOptions","pointMember","pointMembers","lineStringMember","lineStringMembers","polygonMember","polygonMembers","RING_PARSERS","$ol$format$GMLBase","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","MULTIGEOMETRY_TO_MEMBER_NODENAME","MultiCurve","MultiSurface","GML2","readFlatCoordinates","containerSrs","coordsGroups","readBox","BOX_PARSERS_","innerBoundaryIsParser","flatLinearRing","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","innerBoundaryIs","outerBoundaryIs","Box","Curve","Surface","Envelope","curveMember","surfaceMember","lowerCorner","upperCorner","$ol$format$GML2","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","re","readFlatPosList","contextDimension","writePos_","srsDimension","writePosList_","posList","writeFeatureMembers_","setAttributeNS","interior","exterior","curveMembers","surfaceMembers","PolygonPatch","LineStringSegment","Ring","$ol$format$GML3","GML","$ol$format$GML","GML32","$ol$format$GML32","NAMESPACE_URIS","FEATURE_READER","rte","readRte","trk","readTrk","wpt","readWpt","GPX_PARSERS","LINK_PARSERS","GPX_SERIALIZERS","RTE_SEQUENCE","RTE_SERIALIZERS","TRK_SEQUENCE","TRK_SERIALIZERS","writeWptType","RTE_PARSERS","cmt","desc","parseLink","extensions","parseExtensions","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","applyLayoutOptions","$ol$format$GPX","readExtensions_","readExtensions","handleReadExtensions_","extensionsNode","featureReader","gpx","readGeometryInternal","readPointGeometry","readLineStringGeometry","readPolygonGeometry","readMultiPointGeometry","readMultiLineStringGeometry","readMultiPolygonGeometry","readGeometryCollectionGeometry","geoJSON","writePointGeometry","writeLineStringGeometry","rightHanded","writePolygonGeometry","writeMultiPointGeometry","writeMultiLineStringGeometry","writeMultiPolygonGeometry","writeGeometryCollectionGeometry","$ol$format$GeoJSON","extractGeometryName_","extractGeometryName","geoJSONFeature","geoJSONFeatures","featureObject","geometryObject","$ol$format$TextFeature","readFeatureFromText","readFeaturesFromText","readGeometryFromText","readProjectionFromText","writeFeatureText","writeFeaturesText","writeGeometryText","B_RECORD_RE","H_RECORD_RE","HFDTE_RECORD_RE","NEWLINE_RE","$ol$format$IGC","TextFeature","altitudeMode_","altitudeMode","year","month","day","lastDateTime","hour","minute","second","UTC","GX_NAMESPACE_URIS","ICON_ANCHOR_UNITS_MAP","insetPixels","PLACEMARK_PARSERS","ExtendedData","extendedDataParser","Region","regionParser","MultiGeometry","readMultiGeometry","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","baseURI","readScale","STYLE_MAP_PARSERS","Pair","pairObject","PAIR_PARSERS","ICON_STYLE_PARSERS","iconObject","ICON_PARSERS","hotSpot","xunits","yunits","LABEL_STYLE_PARSERS","LINE_STYLE_PARSERS","POLY_STYLE_PARSERS","outline","FLAT_LINEAR_RING_PARSERS","GX_TRACK_PARSERS","when","whens","gxTrackObject","EXTRUDE_AND_ALTITUDE_MODE_PARSERS","extrude","tessellate","MULTI_GEOMETRY_PARSERS","multiGeometry","homogeneous","setCommonGeometryProperties","innerBoundaryFlatLinearRings","INNER_BOUNDARY_IS_PARSERS","OUTER_BOUNDARY_IS_PARSERS","STYLE_PARSERS","IconStyle","styleObject","IconObject","drawIcon","iconUrlFunction_","resizeScale","LabelStyle","LineStyle","PolyStyle","extrudes","tessellates","altitudeModes","hasExtrude","hasTessellate","hasAltitudeMode","DATA_PARSERS","displayName","EXTENDED_DATA_PARSERS","Data","SchemaData","SCHEMA_DATA_PARSERS","SimpleData","minAltitude","maxAltitude","north","south","east","west","minLodPixels","maxLodPixels","minFadeExtent","maxFadeExtent","writeColorTextNode","abgr","hex","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","POLY_STYLE_SERIALIZERS","iconProperties","$ol$format$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","ieee754","isLE","mLen","nBytes","eLen","eMax","eBias","nBits","rt","pbf","Pbf","require$$0","ArrayBuffer","isView","Varint","Fixed64","Bytes","Fixed32","SHIFT_LEFT_32","SHIFT_RIGHT_32","utf8TextDecoder","readPackedEnd","readVarint","toNum","isSigned","makeRoomForExtraLength","startPos","extraLen","realloc","writePackedVarint","writeVarint","writePackedSVarint","writeSVarint","writePackedFloat","writeFloat","writePackedDouble","writeDouble","writePackedBoolean","writeBoolean","writePackedFixed32","writeFixed32","writePackedSFixed32","writeSFixed32","writePackedFixed64","writeFixed64","writePackedSFixed64","writeSFixed64","readUInt32","writeInt32","readInt32","destroy","readFields","readField","tag","skip","readMessage","readFixed32","readSFixed32","readFixed64","readSFixed64","readFloat","read","readDouble","readVarintRemainder","readVarint64","readSVarint","subarray","readUtf8TextDecoder","str","b3","b0","bytesPerSequence","readUtf8","readBytes","readPackedVarint","readPackedSVarint","readPackedBoolean","readPackedFloat","readPackedDouble","readPackedFixed32","readPackedSFixed32","readPackedFixed64","readPackedSFixed64","writeTag","writeBigVarintLow","lsb","writeBigVarintHigh","writeBigVarint","writeString","lead","writeUtf8","writeBytes","writeRawMessage","writeMessage","writeBytesField","writeFixed32Field","writeSFixed32Field","writeFixed64Field","writeSFixed64Field","writeVarintField","writeSVarintField","writeStringField","writeFloatField","writeDoubleField","writeBooleanField","layersPBFReader","layerPBFReader","featurePBFReader","readRawFeature","$ol$format$MVT","featureClass_","layerName_","layerName","idProperty_","idProperty","readRawGeometry_","cmd","coordsLen","currentEnd","cmdLen","createFeature_","rawFeature","getGeometryType","ctor","PBF","pbfLayers","pbfLayer","WAY_PARSERS","nd","ndrefs","readTag","PARSERS","tags","NODE_PARSERS","way","ways","$ol$format$OSMXML","$ol$format$XML","readFromDocument","readFromNode","NAMESPACE_URI","readHref","ServiceIdentification","SERVICE_IDENTIFICATION_PARSERS","ServiceProvider","SERVICE_PROVIDER_PARSERS","OperationsMetadata","OPERATIONS_METADATA_PARSERS","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","$ol$format$OWS","XML","owsObject","encodeDeltas","numbers","lastNumbers","encodeFloats","decodeDeltas","decodeFloats","encodeSignedIntegers","decodeSignedIntegers","encodeUnsignedIntegers","decodeUnsignedIntegers","encodeUnsignedInteger","current","$ol$format$Polyline","factor_","transformVertex","arcs","concatenateArcs","polyArray","ringCoords","indices","readFeaturesFromGeometryCollection","readFeatureFromGeometry","transformArc","$ol$format$TopoJSON","topoJSONTopology","transformArcs","topoJSONFeatures","objectName","$ol$format$filter$Filter","tagName_","getTagName","$ol$format$filter$LogicalNary","Filter","$ol$format$filter$And","LogicalNary","$ol$format$filter$Bbox","$ol$format$filter$Spatial","$ol$format$filter$Contains","Spatial","$ol$format$filter$DWithin","unit","$ol$format$filter$Disjoint","$ol$format$filter$Comparison","propertyName","$ol$format$filter$During","Comparison","$ol$format$filter$ComparisonBinary","matchCase","$ol$format$filter$EqualTo","ComparisonBinary","$ol$format$filter$GreaterThan","$ol$format$filter$GreaterThanOrEqualTo","$ol$format$filter$Intersects","$ol$format$filter$IsBetween","lowerBoundary","upperBoundary","$ol$format$filter$IsLike","pattern","wildCard","singleChar","escapeChar","$ol$format$filter$IsNull","$ol$format$filter$LessThan","$ol$format$filter$LessThanOrEqualTo","$ol$format$filter$Not","$ol$format$filter$NotEqualTo","$ol$format$filter$Or","$ol$format$filter$ResourceId","rid","$ol$format$filter$Within","and","Function","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","writeExpression","timePeriod","writeTimeInstant","writeLiteral","timeInstant","timePosition","writeGetFeature","$ol$format$WFS","featureType_","featureNS_","gmlFormat_","gmlFormat","schemaLocation_","getFeatureType","setFeatureType","featuresNS","readTransactionResponse","readTransactionResponseFromDocument","readTransactionResponseFromNode","readFeatureCollectionMetadata","readFeatureCollectionMetadataFromDocument","readFeatureCollectionMetadataFromNode","handle","outputFormat","maxFeatures","resultType","viewParams","combineBboxAndFilter","completeFilter","bboxFilter","bboxFilterFn","andFilterFn","writeTransaction","inserts","updates","deletes","baseObj","gmlOptions","createTransactionRequest","nativeElements","WKBGeometryType","WkbReader","view_","pos_","initialized_","isLittleEndian_","hasZ_","hasM_","srid_","layout_","readUint8","getUint8","readUint32","isLittleEndian","getUint32","getFloat64","numRings","readWkbHeader","expectedTypeId","wkbType","wkbTypeThousandth","hasSRID","typeId","readWkbPayload","readGeometryCollection","readWkbBlock","readWkbCollection","getSrid","WkbWriter","opts","littleEndian","isEWKB_","ewkb","writeQueue_","nodata_","X","Y","Z","writeUint8","writeUint32","coordsObj","writeLineString","writeWkbHeader","writeMultiLineString","writeMultiPolygon","writeGeometryCollection","findMinimumLayout","geoms","wkblut","geomType","getBuffer","setUint8","setUint32","setFloat64","getDataView","decodeHexString","byteOffset","$ol$format$WKB","splitCollection","viewCache_","hex_","littleEndian_","ewkb_","nodataZ_","nodataZ","nodataM_","nodataM","toUpperCase","encodeHexString","POINT","LINESTRING","POLYGON","MULTIPOINT","MULTILINESTRING","MULTIPOLYGON","EMPTY","TokenType","wktTypeLookup","Lexer","wkt","index_","isAlpha_","isNumeric_","isWhiteSpace_","nextChar_","nextToken","readNumber_","readText_","scientificNotation","Parser","lexer","lexer_","token_","consume_","isTokenType","isMatch","parseGeometry_","parseGeometryLayout_","dimToken","dimInfo","parseGeometryCollectionText_","formatErrorMessage_","parsePointText_","parsePoint_","parseLineStringText_","parsePointList_","parsePolygonText_","parseLineStringTextList_","parseMultiPointText_","parsePointTextList_","parseMultiLineStringText_","parseMultiPolygonText_","parsePolygonTextList_","token","isEmptyGeometry_","encodePointGeometry","encodeLineStringGeometry","encodePolygonGeometry","GeometryEncoder","components","encode","enc","geometryEncoder","wktType","encodeGeometryLayout","$ol$format$WKT","splitCollection_","parse_","SERVICE_PARSERS","Capability","CAPABILITY_PARSERS","REQUEST_PARSERS","Exception","EXCEPTION_PARSERS","layerObject","LAYER_PARSERS","readLayer","Name","KeywordList","readKeywordList","OnlineResource","ContactInformation","CONTACT_INFORMATION_PARSERS","LayerLimit","MaxWidth","MaxHeight","ContactPersonPrimary","CONTACT_PERSON_PARSERS","ContactPosition","ContactAddress","CONTACT_ADDRESS_PARSERS","ContactVoiceTelephone","ContactFacsimileTelephone","ContactElectronicMailAddress","ContactPerson","ContactOrganization","AddressType","StateOrProvince","PostCode","CRS","EX_GeographicBoundingBox","geographicBoundingBox","EX_GEOGRAPHIC_BOUNDING_BOX_PARSERS","westBoundLongitude","southBoundLatitude","eastBoundLongitude","northBoundLatitude","BoundingBox","Dimension","unitSymbol","multipleValues","nearestValue","ATTRIBUTION_PARSERS","AuthorityURL","authorityObject","readFormatOnlineresource","Identifier","MetadataURL","metadataObject","DataURL","FeatureListURL","MinScaleDenominator","MaxScaleDenominator","LogoURL","readSizedFormatOnlineresource","GetCapabilities","readOperationType","GetMap","GetFeatureInfo","OPERATIONTYPE_PARSERS","DCPType","DCPTYPE_PARSERS","LegendURL","StyleSheetURL","StyleURL","FORMAT_ONLINERESOURCE_PARSERS","KEYWORDLIST_PARSERS","Keyword","parentLayerObject","queryable","cascaded","noSubsets","fixedWidth","fixedHeight","childValue","parentValue","formatOnlineresource","$ol$format$WMSCapabilities","wmsCapabilityObject","$ol$format$WMSGetFeatureInfo","readFeatures_","layerElement","toRemove","layerFeatures","gmlFeatures","OWS_NAMESPACE_URIS","Contents","CONTENTS_PARSERS","TileMatrixSet","TMS_PARSERS","isDefault","TileMatrixSetLink","TMS_LINKS_PARSERS","DIMENSION_PARSERS","ResourceURL","resourceType","WGS84BoundingBox","readBoundingBox","legend","TileMatrixSetLimits","TMS_LIMITS_LIST_PARSERS","TileMatrixLimits","TMS_LIMITS_PARSERS","MinTileRow","MaxTileRow","MinTileCol","MaxTileCol","WGS84_BBOX_READERS","LowerCorner","readCoordinates","UpperCorner","WellKnownScaleSet","TM_PARSERS","SupportedCRS","TopLeftCorner","ScaleDenominator","TileWidth","TileHeight","MatrixWidth","MatrixHeight","$ol$format$WMTSCapabilities","owsParser_","OWS","WMTSCapabilityObject","events","FullScreenEventType","isFullScreenSupported","requestFullscreen","fullscreenEnabled","isFullScreen","fullscreenElement","requestFullScreen","$ol$control$FullScreen","isInFullscreen_","boundHandleMapTargetChange_","handleMapTargetChange_","cssClassName_","documentListeners_","activeClassName_","activeClassName","inactiveClassName_","inactiveClassName","labelNode_","labelActive","labelActiveNode_","button_","setClassName_","handleFullScreen_","exitFullscreen","exitFullScreen","requestFullScreenWithKeys","handleFullScreenChange_","wasInFullscreen","fullscreen","PROJECTION","COORDINATE_FORMAT","$ol$control$MousePosition","coordinateFormat","setCoordinateFormat","renderOnMouseOut_","placeholder","placeholder_","renderedHTML_","mapProjection_","getCoordinateFormat","handleMouseMove","updateHTML_","handleMouseOut","html","MAX_RATIO","MIN_RATIO","$ol$control$OverviewMap","boundHandleRotationChanged_","handleRotationChanged_","viewExtent_","ovmapDiv_","ovmap","ovmap_","boxSizing","boxOverlay_","Overlay","scope","overlayBox","mousePosition","endMoving","oldView","unbindView_","handleMapPropertyChange_","bindView_","resetExtent_","updateBoxAfterOvmapIsRendered_","newView","validateExtent_","ovmapSize","ovextent","topLeftPixel","bottomRightPixel","boxWidth","boxHeight","ovmapWidth","ovmapHeight","recenter_","ovview","updateBox_","ovresolution","ovmapPostrenderKey_","getOverviewMap","UNITS_PROP","LEADING_DIGITS","DEFAULT_DPI","$ol$control$ScaleLine","bar","innerElement_","viewState_","minWidth_","minWidth","maxWidth_","maxWidth","renderedWidth_","handleUnitsChanged_","setUnits","scaleBar_","scaleBarSteps_","scaleBarText_","dpi_","setDpi","pointResolutionUnits","nominalCount","suffix","metersPerDegree","decimalCount","previousCount","previousWidth","previousDecimalCount","createScaleBar","resolutionScale","getScaleForResolution","mapScale","stepWidth","scaleSteps","createMarker","cls","createStepText","isLast","lengthString","Direction","$ol$control$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","$ol$control$ZoomToExtent","handleZoomToExtent","ol","$ol$Collection","_ol_Collection$CollectionEvent","_ol_DataTile$asArrayLike","_ol_DataTile$asImageLike","_ol_DataTile$toArray","_ol_Feature$createStyleFunction","Geolocation","_ol_Geolocation$GeolocationError","_ol_Image$decode","_ol_Image$decodeFallback","_ol_Image$listenImage","_ol_Image$load","_ol_Object$ObjectEvent","_ol_Observable$unByKey","_ol_TileQueue$getTilePriority","_ol_TileRange$createOrUpdate","VectorTile","_ol_View$createCenterConstraint","_ol_View$createResolutionConstraint","_ol_View$createRotationConstraint","_ol_View$isNoopAnimation","_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$asArray","_ol_color$asString","_ol_color$fromString","_ol_color$isStringColor","_ol_color$lchaToRgba","_ol_color$normalize","_ol_color$rgbaToLcha","_ol_color$toString","_ol_color$withAlpha","colorlike","_ol_colorlike$asColorLike","_ol_console$error","setLevel","_ol_console$warn","FullScreen","MousePosition","OverviewMap","ScaleLine","ZoomSlider","ZoomToExtent","_ol_control_defaults$defaults","_ol_coordinate$add","_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$getFontParameters","dom","_ol_dom$createCanvasContext2D","_ol_dom$outerHeight","_ol_dom$outerWidth","_ol_dom$releaseCanvas","_ol_dom$removeChildren","_ol_dom$removeNode","_ol_dom$replaceChildren","_ol_dom$replaceNode","_ol_easing$easeIn","_ol_easing$easeOut","_ol_easing$inAndOut","_ol_easing$linear","upAndDown","_ol_events_Event$stopPropagation","_ol_events_SnapEvent$SnapEvent","_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","_ol_expr_expression$NoneType","_ol_expr_expression$NumberArrayType","_ol_expr_expression$NumberType","_ol_expr_expression$Ops","_ol_expr_expression$StringType","_ol_expr_expression$includesType","_ol_expr_expression$isType","_ol_expr_expression$newParsingContext","_ol_expr_expression$overlapsType","_ol_expr_expression$parse","_ol_expr_expression$typeName","gpu","_ol_expr_gpu$PALETTE_TEXTURE_ARRAY","_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$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","EsriJSON","_ol_format_Feature$createGeometry","_ol_format_Feature$createRenderFeature","_ol_format_Feature$transformExtentWithOptions","_ol_format_Feature$transformGeometryWithOptions","_ol_format_GMLBase$GMLNS","GPX","GeoJSON","IGC","IIIFInfo","KML","getDefaultFillStyle","getDefaultImageStyle","getDefaultStrokeStyle","getDefaultStyle","getDefaultStyleArray","getDefaultTextStyle","_ol_format_KML$readFlatCoordinates","MVT","OSMXML","Polyline","_ol_format_Polyline$decodeDeltas","_ol_format_Polyline$decodeFloats","_ol_format_Polyline$decodeSignedIntegers","_ol_format_Polyline$decodeUnsignedIntegers","_ol_format_Polyline$encodeDeltas","_ol_format_Polyline$encodeFloats","_ol_format_Polyline$encodeSignedIntegers","_ol_format_Polyline$encodeUnsignedInteger","_ol_format_Polyline$encodeUnsignedIntegers","TopoJSON","WFS","writeFilter","WKB","WKT","WMSCapabilities","WMSGetFeatureInfo","WMTSCapabilities","EqualTo","IsBetween","IsLike","IsNull","NotEqualTo","_ol_format_filter$and","_ol_format_filter$bbox","between","disjoint","during","dwithin","equalTo","greaterThan","greaterThanOrEqualTo","isNull","lessThan","lessThanOrEqualTo","like","not","notEqualTo","or","resourceId","within","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_Polygon$circular","_ol_geom_Polygon$fromCircle","_ol_geom_Polygon$fromExtent","_ol_geom_Polygon$makeRegular","_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_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$FIREFOX","_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","DragAndDrop","_ol_interaction_DragAndDrop$DragAndDropEvent","_ol_interaction_DragBox$DragBoxEvent","DragRotateAndZoom","Draw","_ol_interaction_Draw$DrawEvent","createBox","boxCoordinates","createRegularPolygon","internalAngle","Extent","_ol_interaction_Extent$ExtentEvent","_ol_interaction_Interaction$pan","_ol_interaction_Interaction$zoomByDelta","Modify","_ol_interaction_Modify$ModifyEvent","Pointer","_ol_interaction_Pointer$centroid","_ol_interaction_Select$SelectEvent","Snap","Translate","_ol_interaction_Translate$TranslateEvent","_ol_interaction_defaults$defaults","Base","BaseImage","BaseTile","Graticule","Group","_ol_layer_Group$GroupEvent","Heatmap","_ol_layer_Layer$inView","Vector","VectorImage","WebGLPoints","WebGLTile","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","net","_ol_net$ClientError","_ol_net$ResponseError","_ol_net$getJSON","_ol_net$jsonp","overrideXHR","_ol_net$resolveUrl","restoreXHR","_ol_obj$clear","_ol_obj$isEmpty","Units","_ol_proj_Units$METERS_PER_UNIT","_ol_proj_Units$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","fromLonLat","_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","epsgCode","getEPSGLookup","isRegistered","_ol_proj_proj4$register","setEPSGLookup","_ol_proj_projections$add","_ol_proj_projections$clear","_ol_proj_projections$get","_ol_proj$setUserProjection","toLonLat","lonLat","_ol_proj$toUserCoordinate","_ol_proj$toUserExtent","_ol_proj$toUserResolution","_ol_proj$transform","_ol_proj$transformExtent","transformWithProjections","_ol_proj_transforms$add","_ol_proj_transforms$clear","_ol_proj_transforms$get","useGeographic","toFeature","_ol_render_Feature$toGeometry","BuilderGroup","_ol_render_canvas_ExecutorGroup$getPixelIndexArray","Immediate","_ol_render_canvas_Instruction$beginPathInstruction","_ol_render_canvas_Instruction$closePathInstruction","_ol_render_canvas_Instruction$fillInstruction","_ol_render_canvas_Instruction$strokeInstruction","_ol_render_canvas_TextBuilder$TEXT_ALIGN","_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","_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","webgl","renderinstructions","_ol_render_webgl_renderinstructions$generateLineStringRenderInstructions","_ol_render_webgl_renderinstructions$generatePointRenderInstructions","_ol_render_webgl_renderinstructions$generatePolygonRenderInstructions","_ol_render_webgl_renderinstructions$getCustomAttributesSize","utils","_ol_render_webgl_utils$LINESTRING_ANGLE_COSINE_CUTOFF","_ol_render_webgl_utils$colorDecodeId","_ol_render_webgl_utils$colorEncodeId","getBlankImageData","writeLineSegmentToBuffers","segmentStartIndex","segmentEndIndex","beforeSegmentIndex","afterSegmentIndex","vertexArray","indexArray","toWorldTransform","currentLength","currentAngleTangentSum","baseIndex","p0world","p1world","angleBetween","pA","pB","lenA","tangentA","orthoA","lenB","tangentB","angle1","newAngleTangentSum","joinAfter","computeParameters","vertexIndex","angleSum","writePointFeatureToBuffers","elementIndex","bufferPositions","customAttrs","vPos","iPos","writePolygonTrianglesToBuffers","polygonStartIndex","attributesPerVertex","instructionsIndex","Composite","_ol_renderer_canvas_Layer$canvasPool","VectorImageLayer","VectorTileLayer","_ol_renderer_vector$defaultOrder","_ol_renderer_vector$getSquaredTolerance","_ol_renderer_vector$getTolerance","_ol_renderer_vector$renderFeature","PointsLayer","_ol_renderer_webgl_TileLayer$Attributes","_ol_renderer_webgl_TileLayer$Uniforms","TileLayerBase","_ol_renderer_webgl_TileLayerBase$Uniforms","_ol_renderer_webgl_TileLayerBase$getCacheKey","_ol_renderer_webgl_TileLayerBase$newTileRepresentationLookup","_ol_renderer_webgl_VectorLayer$Uniforms","_ol_renderer_webgl_VectorTileLayer$Attributes","_ol_renderer_webgl_VectorTileLayer$Uniforms","_ol_reproj$calculateSourceExtentResolution","_ol_reproj$calculateSourceResolution","_ol_reproj$canvasPool","common","_ol_reproj_common$ERROR_THRESHOLD","_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","_ol_source_BingMaps$quadKey","CartoDB","Cluster","IIIF","_ol_source_Image$ImageSourceEvent","_ol_source_Image$defaultImageLoadFunction","_ol_source_Image$getRequestExtent","ImageArcGISRest","ImageMapGuide","ImageStatic","ImageWMS","OGCMapTile","OGCVectorTile","OSM","_ol_source_OSM$ATTRIBUTION","Raster","_ol_source_Raster$Processor","_ol_source_Raster$RasterSourceEvent","_ol_source_Raster$newImageData","StadiaMaps","_ol_source_Tile$TileSourceEvent","TileArcGISRest","TileDebug","TileJSON","TileWMS","UTFGrid","_ol_source_UTFGrid$CustomTile","_ol_source_Vector$VectorSourceEvent","_ol_source_VectorTile$defaultLoadFunction","WMTS","optionsFromCapabilities","wmtsCap","tileMatrixSets","findIndex","supportedCRS","el","matrixSetObj","projConfig","switchXY","selectedMatrixLimit","tileMatrixValue","tileSpanX","tileSpanY","matrixSetExtent","wgs84BoundingBox","wgs84ProjectionExtent","wgs84MatrixSetExtent","gets","encodings","Zoomify","_ol_source_Zoomify$CustomTile","arcgisRest","_ol_source_arcgisRest$createLoader","_ol_source_arcgisRest$getRequestUrl","_ol_source_common$DECIMALS","DEFAULT_WMS_VERSION","mapguide","_ol_source_mapguide$createLoader","ogcTileUtil","_ol_source_ogcTileUtil$getMapTileUrlTemplate","_ol_source_ogcTileUtil$getTileSetInfo","_ol_source_ogcTileUtil$getVectorTileUrlTemplate","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","LinkedList","_ol_structs_PriorityQueue$DROP","_ol_style_IconImage$get","_ol_style_IconImageCache$shared","_ol_style_Style$createDefaultStyle","_ol_style_Style$createEditingStyle","_ol_style_Style$toFunction","_ol_style_flat$createDefaultStyle","tilecoord","_ol_tilecoord$createOrUpdate","_ol_tilecoord$fromKey","_ol_tilecoord$getCacheKeyForTileKey","_ol_tilecoord$getKey","_ol_tilecoord$getKeyZXY","_ol_tilecoord$hash","_ol_tilecoord$withinExtentAndZ","_ol_tilegrid_WMTS$createFromCapabilitiesMatrixSet","_ol_tilegrid_common$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$expandUrl","_ol_tileurlfunction$nullTileUrlFunction","_ol_transform$apply","_ol_transform$compose","composeCssTransform","_ol_transform$create","_ol_transform$determinant","invert","_ol_transform$makeInverse","_ol_transform$makeScale","_ol_transform$multiply","_ol_transform$reset","_ol_transform$rotate","_ol_transform$scale","_ol_transform$set","_ol_transform$setFromArray","_ol_transform$toString","_ol_transform$translate","_ol_uri$appendParams","util","_ol_util$abstract","_ol_util$getUid","vec","_ol_vec_mat4$create","_ol_vec_mat4$fromTransform","_ol_webgl$ARRAY_BUFFER","_ol_webgl_Buffer$getArrayClassForType","_ol_webgl$DYNAMIC_DRAW","_ol_webgl$ELEMENT_ARRAY_BUFFER","_ol_webgl$FLOAT","Helper","_ol_webgl_Helper$computeAttributesStride","PostProcessingPass","RenderTarget","_ol_webgl$STATIC_DRAW","STREAM_DRAW","_ol_webgl_ShaderBuilder$COMMON_HEADER","_ol_webgl_ShaderBuilder$ShaderBuilder","_ol_webgl$getContext","getSupportedExtensions","styleparser","_ol_webgl_styleparser$computeHash","_ol_webgl_styleparser$expressionToGlsl","_ol_webgl_styleparser$packColor","_ol_webgl_styleparser$parseLiteralStyle","_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":"+BAiEO,SAASA,EAAgBC,GAC9BA,EAAID,iBACN,CASA,IAAAE,EA9DA,MAIE,WAAAC,CAAYC,GAIVC,KAAKC,mBAKLD,KAAKE,iBAOLF,KAAKD,KAAOA,EAOZC,KAAKG,OAAS,IACf,CAOD,cAAAC,GACEJ,KAAKE,kBAAmB,CACzB,CAMD,eAAAP,GACEK,KAAKC,oBAAqB,CAC3B,GCpDYI,EAMG,iBCsBlB,IAAAC,EA3BA,MACE,WAAAR,GAMEE,KAAKO,UAAW,CACjB,CAKD,OAAAC,GACOR,KAAKO,WACRP,KAAKO,UAAW,EAChBP,KAAKS,kBAER,CAMD,eAAAA,GAAoB,GCnBf,SAASC,EAAaC,EAAUC,EAAQC,GAC7C,IAAIC,EAAKC,EACTF,EAAaA,GAAcG,EAC3B,IAAIC,EAAM,EACNC,EAAOP,EAASQ,OAChBC,GAAQ,EAEZ,KAAOH,EAAMC,GAGXJ,EAAMG,GAAQC,EAAOD,GAAQ,GAC7BF,GAAOF,EAAWF,EAASG,GAAMF,GAE7BG,EAAM,EAERE,EAAMH,EAAM,GAGZI,EAAOJ,EACPM,GAASL,GAKb,OAAOK,EAAQH,GAAOA,CACxB,CASO,SAASD,EAAUK,EAAGC,GAC3B,OAAOD,EAAIC,EAAI,EAAID,EAAIC,GAAK,EAAI,CAClC,CASO,SAASC,EAAWF,EAAGC,GAC5B,OAAOD,EAAIC,EAAI,EAAID,EAAIC,GAAK,EAAI,CAClC,CAyBO,SAASE,EAAkBC,EAAKtB,EAAQuB,GAC7C,GAAID,EAAI,IAAMtB,EACZ,OAAO,EAGT,MAAMwB,EAAIF,EAAIN,OACd,GAAIhB,GAAUsB,EAAIE,EAAI,GACpB,OAAOA,EAAI,EAGb,GAAyB,mBAAdD,EAA0B,CACnC,IAAK,IAAIE,EAAI,EAAGA,EAAID,IAAKC,EAAG,CAC1B,MAAMC,EAAYJ,EAAIG,GACtB,GAAIC,IAAc1B,EAChB,OAAOyB,EAET,GAAIC,EAAY1B,EACd,OAAIuB,EAAUvB,EAAQsB,EAAIG,EAAI,GAAIC,GAAa,EACtCD,EAAI,EAENA,CAEV,CACD,OAAOD,EAAI,CACZ,CAED,GAAID,EAAY,EAAG,CACjB,IAAK,IAAIE,EAAI,EAAGA,EAAID,IAAKC,EACvB,GAAIH,EAAIG,GAAKzB,EACX,OAAOyB,EAAI,EAGf,OAAOD,EAAI,CACZ,CAED,GAAID,EAAY,EAAG,CACjB,IAAK,IAAIE,EAAI,EAAGA,EAAID,IAAKC,EACvB,GAAIH,EAAIG,IAAMzB,EACZ,OAAOyB,EAGX,OAAOD,EAAI,CACZ,CAED,IAAK,IAAIC,EAAI,EAAGA,EAAID,IAAKC,EAAG,CAC1B,GAAIH,EAAIG,IAAMzB,EACZ,OAAOyB,EAET,GAAIH,EAAIG,GAAKzB,EACX,OAAIsB,EAAIG,EAAI,GAAKzB,EAASA,EAASsB,EAAIG,GAC9BA,EAAI,EAENA,CAEV,CACD,OAAOD,EAAI,CACb,CAOO,SAASG,EAAgBL,EAAKM,EAAOC,GAC1C,KAAOD,EAAQC,GAAK,CAClB,MAAMC,EAAMR,EAAIM,GAChBN,EAAIM,GAASN,EAAIO,GACjBP,EAAIO,GAAOC,IACTF,IACAC,CACH,CACH,CAOO,SAASE,EAAOT,EAAKU,GAC1B,MAAMC,EAAYC,MAAMC,QAAQH,GAAQA,EAAO,CAACA,GAC1ChB,EAASiB,EAAUjB,OACzB,IAAK,IAAIS,EAAI,EAAGA,EAAIT,EAAQS,IAC1BH,EAAIA,EAAIN,QAAUiB,EAAUR,EAEhC,CAsBO,SAASW,EAAOC,EAAMC,GAC3B,MAAMC,EAAOF,EAAKrB,OAClB,GAAIuB,IAASD,EAAKtB,OAChB,OAAO,EAET,IAAK,IAAIS,EAAI,EAAGA,EAAIc,EAAMd,IACxB,GAAIY,EAAKZ,KAAOa,EAAKb,GACnB,OAAO,EAGX,OAAO,CACT,CA8BO,SAASe,EAASlB,EAAKmB,EAAMC,GAClC,MAAMC,EAAUF,GAAQ5B,EACxB,OAAOS,EAAIsB,OAAM,SAAUC,EAAYC,GACrC,GAAc,IAAVA,EACF,OAAO,EAET,MAAMC,EAAMJ,EAAQrB,EAAIwB,EAAQ,GAAID,GACpC,QAASE,EAAM,GAAML,GAAkB,IAARK,EACnC,GACA,CCvOO,SAASC,IACd,OAAO,CACT,CAMO,SAASC,IACd,OAAO,CACT,CAOO,SAASC,IAAS,CAWlB,SAASC,EAAWC,GACzB,IAGIC,EAGAC,EAEAC,EARAC,GAAS,EAUb,OAAO,WACL,MAAMC,EAAWvB,MAAMwB,UAAUC,MAAMC,KAAKC,WAO5C,OANKL,GAAU3D,OAAS0D,GAAaO,EAAYL,EAAUH,KACzDE,GAAS,EACTD,EAAW1D,KACXyD,EAAWG,EACXJ,EAAaD,EAAGW,MAAMlE,KAAMgE,YAEvBR,CACX,CACA,CAOO,SAASW,EAAUC,GAaxB,OAZA,WACE,IAAIC,EACJ,IACEA,EAAQD,GACT,CAAC,MAAOE,GACP,OAAOC,QAAQC,OAAOF,EACvB,CACD,OAAID,aAAiBE,QACZF,EAEFE,QAAQE,QAAQJ,EACxB,CACMK,EACT,CCxEO,SAASC,EAAMC,GACpB,IAAK,MAAMC,KAAYD,SACdA,EAAOC,EAElB,CAOO,SAASC,EAAQF,GACtB,IAAIC,EACJ,IAAKA,KAAYD,EACf,OAAO,EAET,OAAQC,CACV,CCsKA,IAAAE,EApKA,cAAqBC,EAInB,WAAAlF,CAAYK,GACV8E,QAMAjF,KAAKkF,aAAe/E,EAMpBH,KAAKmF,iBAAmB,KAMxBnF,KAAKoF,aAAe,KAMpBpF,KAAKqF,WAAa,IACnB,CAMD,gBAAAC,CAAiBvF,EAAMwF,GACrB,IAAKxF,IAASwF,EACZ,OAEF,MAAMC,EAAYxF,KAAKqF,aAAerF,KAAKqF,WAAa,CAAA,GAClDI,EAAmBD,EAAUzF,KAAUyF,EAAUzF,GAAQ,IAC1D0F,EAAiBC,SAASH,IAC7BE,EAAiBE,KAAKJ,EAEzB,CAYD,aAAAK,CAAcC,GACZ,MAAMC,EAA4B,iBAAVD,EAClB9F,EAAO+F,EAAWD,EAAQA,EAAM9F,KAChCyF,EAAYxF,KAAKqF,YAAcrF,KAAKqF,WAAWtF,GACrD,IAAKyF,EACH,OAGF,MAAM5F,EAAMkG,EAAW,IAAIC,EAAMF,GAA+B,EAC3DjG,EAAIO,SACPP,EAAIO,OAASH,KAAKkF,cAAgBlF,MAEpC,MAAMgG,EAAchG,KAAKoF,eAAiBpF,KAAKoF,aAAe,CAAA,GACxDa,EACJjG,KAAKmF,mBAAqBnF,KAAKmF,iBAAmB,CAAE,GAMtD,IAAIe,EALEnG,KAAQiG,IACZA,EAAYjG,GAAQ,EACpBkG,EAAgBlG,GAAQ,KAExBiG,EAAYjG,GAEd,IAAK,IAAI6B,EAAI,EAAGuE,EAAKX,EAAUrE,OAAQS,EAAIuE,IAAMvE,EAU/C,GAREsE,EADE,gBAAiBV,EAAU5D,GAE3B4D,EAAU5D,GACVwE,YAAYxG,GAGZ4F,EAAU5D,GACVmC,KAAK/D,KAAMJ,IAEG,IAAdsG,GAAuBtG,EAAIK,mBAAoB,CACjDiG,GAAY,EACZ,KACD,CAEH,GAA4B,KAAtBF,EAAYjG,GAAa,CAC7B,IAAIsG,EAAKJ,EAAgBlG,GAEzB,WADOkG,EAAgBlG,GAChBsG,KACLrG,KAAKsG,oBAAoBvG,EAAMsD,UAE1B2C,EAAYjG,EACpB,CACD,OAAOmG,CACR,CAKD,eAAAzF,GACET,KAAKqF,YAAcV,EAAM3E,KAAKqF,WAC/B,CASD,YAAAkB,CAAaxG,GACX,OAAQC,KAAKqF,YAAcrF,KAAKqF,WAAWtF,SAAUyG,CACtD,CAOD,WAAAC,CAAY1G,GACV,QAAKC,KAAKqF,aAGHtF,EACHA,KAAQC,KAAKqF,WACbqB,OAAOC,KAAK3G,KAAKqF,YAAYlE,OAAS,EAC3C,CAMD,mBAAAmF,CAAoBvG,EAAMwF,GACxB,IAAKvF,KAAKqF,WACR,OAEF,MAAMG,EAAYxF,KAAKqF,WAAWtF,GAClC,IAAKyF,EACH,OAEF,MAAMvC,EAAQuC,EAAUoB,QAAQrB,IACjB,IAAXtC,IACEjD,KAAKmF,kBAAoBpF,KAAQC,KAAKmF,kBAExCK,EAAUvC,GAASI,IACjBrD,KAAKmF,iBAAiBpF,KAExByF,EAAUqB,OAAO5D,EAAO,GACC,IAArBuC,EAAUrE,eACLnB,KAAKqF,WAAWtF,IAI9B,GCpLY+G,EAML,SANKA,EAaN,QAbMA,EAiBA,cAjBAA,EAkBN,QAlBMA,EAmBH,WAnBGA,EAoBF,YApBEA,EAqBH,WArBGA,EAsBP,OAtBOA,EAwBJ,UAxBIA,EAyBH,WAzBGA,EA0BP,OA1BOA,EA4BF,YA5BEA,EA6BN,QCSF,SAASC,EAAO5G,EAAQJ,EAAMwF,EAAUyB,EAASC,GAItD,GAHID,GAAWA,IAAY7G,IACzBoF,EAAWA,EAAS2B,KAAKF,IAEvBC,EAAM,CACR,MAAME,EAAmB5B,EACzBA,EAAW,WACTpF,EAAOmG,oBAAoBvG,EAAMwF,GACjC4B,EAAiBjD,MAAMlE,KAAMgE,UACnC,CACG,CACD,MAAMoD,EAAY,CAChBjH,OAAQA,EACRJ,KAAMA,EACNwF,SAAUA,GAGZ,OADApF,EAAOmF,iBAAiBvF,EAAMwF,GACvB6B,CACT,CAsBO,SAASC,EAAWlH,EAAQJ,EAAMwF,EAAUyB,GACjD,OAAOD,EAAO5G,EAAQJ,EAAMwF,EAAUyB,GAAS,EACjD,CAWO,SAASM,EAAcC,GACxBA,GAAOA,EAAIpH,SACboH,EAAIpH,OAAOmG,oBAAoBiB,EAAIxH,KAAMwH,EAAIhC,UAC7CZ,EAAM4C,GAEV,CChEA,MAAMC,UAAmBC,EACvB,WAAA3H,GACEmF,QAEAjF,KAAK0H,GAED1H,KACR,WAEIA,KAAKiH,KAEDjH,KACR,aAEIA,KAAK2H,GAAiD3H,KAAe,WAMrEA,KAAK4H,UAAY,CAClB,CAMD,OAAAC,KACI7H,KAAK4H,UACP5H,KAAK4F,cAAckC,EACpB,CAQD,WAAAC,GACE,OAAO/H,KAAK4H,SACb,CAQD,UAAAI,CAAWjI,EAAMwF,GACf,GAAIlD,MAAMC,QAAQvC,GAAO,CACvB,MAAMkI,EAAMlI,EAAKoB,OACXwF,EAAO,IAAItE,MAAM4F,GACvB,IAAK,IAAIrG,EAAI,EAAGA,EAAIqG,IAAOrG,EACzB+E,EAAK/E,GAAKmF,EAAO/G,KAAMD,EAAK6B,GAAI2D,GAElC,OAAOoB,CACR,CACD,OAAOI,EAAO/G,OAAoCuF,EACnD,CAQD,YAAA2C,CAAanI,EAAMwF,GACjB,IAAIgC,EACJ,GAAIlF,MAAMC,QAAQvC,GAAO,CACvB,MAAMkI,EAAMlI,EAAKoB,OACjBoG,EAAM,IAAIlF,MAAM4F,GAChB,IAAK,IAAIrG,EAAI,EAAGA,EAAIqG,IAAOrG,EACzB2F,EAAI3F,GAAKyF,EAAWrH,KAAMD,EAAK6B,GAAI2D,EAE3C,MACMgC,EAAMF,EAAWrH,OAAoCuF,GAGvD,OADsB,EAAW4C,OAASZ,EACnCA,CACR,CAQD,UAAAa,CAAWrI,EAAMwF,GACf,MAAMgC,EAA4B,EAAWY,OAC7C,GAAIZ,EACFc,EAAQd,QACH,GAAIlF,MAAMC,QAAQvC,GACvB,IAAK,IAAI6B,EAAI,EAAGuE,EAAKpG,EAAKoB,OAAQS,EAAIuE,IAAMvE,EAC1C5B,KAAKsG,oBAAoBvG,EAAK6B,GAAI2D,QAGpCvF,KAAKsG,oBAAoBvG,EAAMwF,EAElC,EA0CI,SAAS8C,EAAQd,GACtB,GAAIlF,MAAMC,QAAQiF,GAChB,IAAK,IAAI3F,EAAI,EAAGuE,EAAKoB,EAAIpG,OAAQS,EAAIuE,IAAMvE,EACzC0F,EAAcC,EAAI3F,SAGpB0F,EAAa,EAEjB,CArCAE,EAAW3D,UAAU6D,GAYrBF,EAAW3D,UAAUoD,KASrBO,EAAW3D,UAAU8D,GAkBrB,IAAAW,EAAed,ECvLR,SAASe,IACd,MAAM,IAAIC,MAAM,iCAClB,CAOA,IAAIC,EAAc,EAWX,SAASC,EAAOC,GACrB,OAAOA,EAAIC,SAAWD,EAAIC,OAASC,SAASJ,GAC9C,CChBO,MAAMK,UAAoB/C,EAM/B,WAAAjG,CAAYC,EAAMwH,EAAKwB,GACrB9D,MAAMlF,GAONC,KAAKuH,IAAMA,EAQXvH,KAAK+I,SAAWA,CACjB,EA4OH,IAAAC,EAvLA,cAAyBxB,EAIvB,WAAA1H,CAAYmJ,GACVhE,QAKAjF,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAMLe,EAAO1I,MAMPA,KAAKkJ,QAAU,UAEA1C,IAAXyC,GACFjJ,KAAKmJ,cAAcF,EAEtB,CAQD,GAAAG,CAAI7B,GACF,IAAIlD,EAIJ,OAHIrE,KAAKkJ,SAAWlJ,KAAKkJ,QAAQG,eAAe9B,KAC9ClD,EAAQrE,KAAKkJ,QAAQ3B,IAEhBlD,CACR,CAOD,OAAAiF,GACE,OAAQtJ,KAAKkJ,SAAWxC,OAAOC,KAAK3G,KAAKkJ,UAAa,EACvD,CAOD,aAAAK,GACE,OAAQvJ,KAAKkJ,SAAWxC,OAAO8C,OAAO,CAAA,EAAIxJ,KAAKkJ,UAAa,EAC7D,CAMD,qBAAAO,GACE,OAAOzJ,KAAKkJ,OACb,CAKD,aAAAQ,GACE,QAAS1J,KAAKkJ,OACf,CAMD,MAAAS,CAAOpC,EAAKwB,GACV,IAAIa,EACJA,EAAY,UAAUrC,IAClBvH,KAAKyG,YAAYmD,IACnB5J,KAAK4F,cAAc,IAAIkD,EAAYc,EAAWrC,EAAKwB,IAErDa,EAAYvJ,EACRL,KAAKyG,YAAYmD,IACnB5J,KAAK4F,cAAc,IAAIkD,EAAYc,EAAWrC,EAAKwB,GAEtD,CAMD,iBAAAc,CAAkBtC,EAAKhC,GACrBvF,KAAKsF,iBAAiB,UAAUiC,IAAOhC,EACxC,CAMD,oBAAAuE,CAAqBvC,EAAKhC,GACxBvF,KAAKsG,oBAAoB,UAAUiB,IAAOhC,EAC3C,CASD,GAAAwE,CAAIxC,EAAKlD,EAAO2F,GACd,MAAMf,EAASjJ,KAAKkJ,UAAYlJ,KAAKkJ,QAAU,CAAA,GAC/C,GAAIc,EACFf,EAAO1B,GAAOlD,MACT,CACL,MAAM0E,EAAWE,EAAO1B,GACxB0B,EAAO1B,GAAOlD,EACV0E,IAAa1E,GACfrE,KAAK2J,OAAOpC,EAAKwB,EAEpB,CACF,CASD,aAAAI,CAAcF,EAAQe,GACpB,IAAK,MAAMzC,KAAO0B,EAChBjJ,KAAK+J,IAAIxC,EAAK0B,EAAO1B,GAAMyC,EAE9B,CAOD,eAAAC,CAAgBC,GACTA,EAAOhB,SAGZxC,OAAO8C,OAAOxJ,KAAKkJ,UAAYlJ,KAAKkJ,QAAU,IAAKgB,EAAOhB,QAC3D,CAQD,KAAAiB,CAAM5C,EAAKyC,GACT,GAAIhK,KAAKkJ,SAAW3B,KAAOvH,KAAKkJ,QAAS,CACvC,MAAMH,EAAW/I,KAAKkJ,QAAQ3B,UACvBvH,KAAKkJ,QAAQ3B,GAChBzC,EAAQ9E,KAAKkJ,WACflJ,KAAKkJ,QAAU,MAEZc,GACHhK,KAAK2J,OAAOpC,EAAKwB,EAEpB,CACF,GCtQYqB,EAMR,MANQA,EAYL,SCRV,MAAMC,EACI,SASH,MAAMC,UAAwBvE,EAMnC,WAAAjG,CAAYC,EAAMwK,EAAStH,GACzBgC,MAAMlF,GAONC,KAAKuK,QAAUA,EAOfvK,KAAKiD,MAAQA,CACd,EAgCH,MAAMuH,UAAmBC,EAKvB,WAAA3K,CAAY4K,EAAOC,GAgCjB,GA/BA1F,QAKAjF,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAELgD,EAAUA,GAAW,GAMrB3K,KAAK4K,UAAYD,EAAQE,OAMzB7K,KAAK8K,OAASJ,GAAgB,GAE1B1K,KAAK4K,QACP,IAAK,IAAIhJ,EAAI,EAAGuE,EAAKnG,KAAK8K,OAAO3J,OAAQS,EAAIuE,IAAMvE,EACjD5B,KAAK+K,cAAc/K,KAAK8K,OAAOlJ,GAAIA,GAIvC5B,KAAKgL,eACN,CAMD,KAAArG,GACE,KAAO3E,KAAKiL,YAAc,GACxBjL,KAAKkL,KAER,CASD,MAAAhJ,CAAOT,GACL,IAAK,IAAIG,EAAI,EAAGuE,EAAK1E,EAAIN,OAAQS,EAAIuE,IAAMvE,EACzC5B,KAAK2F,KAAKlE,EAAIG,IAEhB,OAAO5B,IACR,CASD,OAAAmL,CAAQC,GACN,MAAMV,EAAQ1K,KAAK8K,OACnB,IAAK,IAAIlJ,EAAI,EAAGuE,EAAKuE,EAAMvJ,OAAQS,EAAIuE,IAAMvE,EAC3CwJ,EAAEV,EAAM9I,GAAIA,EAAG8I,EAElB,CAUD,QAAAW,GACE,OAAOrL,KAAK8K,MACb,CAQD,IAAAQ,CAAKrI,GACH,OAAOjD,KAAK8K,OAAO7H,EACpB,CAQD,SAAAgI,GACE,OAAOjL,KAAKoJ,IAAIiB,EACjB,CAQD,QAAAkB,CAAStI,EAAOuI,GACd,GAAIvI,EAAQ,GAAKA,EAAQjD,KAAKiL,YAC5B,MAAM,IAAIzC,MAAM,wBAA0BvF,GAExCjD,KAAK4K,SACP5K,KAAK+K,cAAcS,GAErBxL,KAAK8K,OAAOjE,OAAO5D,EAAO,EAAGuI,GAC7BxL,KAAKgL,gBACLhL,KAAK4F,cACH,IAAI0E,EAAgBF,EAAyBoB,EAAMvI,GAEtD,CAQD,GAAAiI,GACE,OAAOlL,KAAKyL,SAASzL,KAAKiL,YAAc,EACzC,CAQD,IAAAtF,CAAK6F,GACCxL,KAAK4K,SACP5K,KAAK+K,cAAcS,GAErB,MAAM7J,EAAI3B,KAAKiL,YAEf,OADAjL,KAAKuL,SAAS5J,EAAG6J,GACVxL,KAAKiL,WACb,CAQD,MAAAS,CAAOF,GACL,MAAM/J,EAAMzB,KAAK8K,OACjB,IAAK,IAAIlJ,EAAI,EAAGuE,EAAK1E,EAAIN,OAAQS,EAAIuE,IAAMvE,EACzC,GAAIH,EAAIG,KAAO4J,EACb,OAAOxL,KAAKyL,SAAS7J,EAI1B,CASD,QAAA6J,CAASxI,GACP,GAAIA,EAAQ,GAAKA,GAASjD,KAAKiL,YAC7B,OAEF,MAAMU,EAAO3L,KAAK8K,OAAO7H,GAQzB,OAPAjD,KAAK8K,OAAOjE,OAAO5D,EAAO,GAC1BjD,KAAKgL,gBACLhL,KAAK4F,cACT,IACY0E,EAAgBF,EAA4BuB,EAAM1I,IAGnD0I,CACR,CAQD,KAAAC,CAAM3I,EAAOuI,GAEX,GAAIvI,GADMjD,KAAKiL,YAGb,YADAjL,KAAKuL,SAAStI,EAAOuI,GAGvB,GAAIvI,EAAQ,EACV,MAAM,IAAIuF,MAAM,wBAA0BvF,GAExCjD,KAAK4K,SACP5K,KAAK+K,cAAcS,EAAMvI,GAE3B,MAAM0I,EAAO3L,KAAK8K,OAAO7H,GACzBjD,KAAK8K,OAAO7H,GAASuI,EACrBxL,KAAK4F,cACT,IACY0E,EAAgBF,EAA4BuB,EAAM1I,IAG1DjD,KAAK4F,cACT,IACY0E,EAAgBF,EAAyBoB,EAAMvI,GAGxD,CAKD,aAAA+H,GACEhL,KAAK+J,IAAIM,EAAiBrK,KAAK8K,OAAO3J,OACvC,CAOD,aAAA4J,CAAcS,EAAMK,GAClB,IAAK,IAAIjK,EAAI,EAAGuE,EAAKnG,KAAK8K,OAAO3J,OAAQS,EAAIuE,IAAMvE,EACjD,GAAI5B,KAAK8K,OAAOlJ,KAAO4J,GAAQ5J,IAAMiK,EACnC,MAAM,IAAIrD,MAAM,8CAGrB,EC7TY,IAAAsD,EACP,EADOA,EAEJ,EAFIA,EAGL,EAHKA,EAQN,EARMA,EASN,ECNF,SAASC,GAAOC,GACrB,OAAOC,KAAKC,IAAIF,EAAG,EACrB,CAQO,SAASG,GAAQH,GACtB,OAAO,EAAID,GAAO,EAAIC,EACxB,CAQO,SAASI,GAASJ,GACvB,OAAO,EAAIA,EAAIA,EAAI,EAAIA,EAAIA,EAAIA,CACjC,CAQO,SAASK,GAAOL,GACrB,OAAOA,CACT,CCoRA,IAAAM,GAlPA,cAAmB7E,EAMjB,WAAA3H,CAAYyM,EAAWC,EAAO7B,GAC5B1F,QAEA0F,EAAUA,GAAoB,GAK9B3K,KAAKuM,UAAYA,EAMjBvM,KAAKwM,MAAQA,EAQbxM,KAAKyM,YAAc,KAQnBzM,KAAKuH,IAAM,GAMXvH,KAAK0M,iBACoBlG,IAAvBmE,EAAQgC,WAA2B,IAAMhC,EAAQgC,WAOnD3M,KAAK4M,kBAAoB,GAKzB5M,KAAK6M,cAAgBlC,EAAQkC,WAC9B,CAKD,OAAAhF,GACE7H,KAAK4F,cAAckC,EACpB,CAKD,OAAAgF,GACM9M,KAAKwM,QAAUV,GAEjB9L,KAAK+M,SAASjB,EAEjB,CAKD,MAAAkB,GACE,OAAOhN,KAAKuH,IAAM,IAAMvH,KAAKuM,SAC9B,CAQD,cAAAU,GACE,IAAIC,EAAOlN,KAAKyM,YAChB,IAAKS,EAEH,OAAOlN,KAOT,EAAG,CACD,GAAIkN,EAAKC,YAAcrB,EAIrB,OADA9L,KAAK0M,YAAc,EACZQ,EAETA,EAAOA,EAAKT,WACb,OAAQS,GAGT,OAAOlN,IACR,CAMD,mBAAAoN,GACE,IAAIF,EAAOlN,KAAKyM,YAChB,IAAKS,EACH,OAIF,IAAIvB,EAAO3L,KACX,EAAG,CACD,GAAIkN,EAAKC,YAAcrB,EAAkB,CAIvCoB,EAAKT,YAAc,KACnB,KACD,CACGS,EAAKC,YAAcrB,EAGrBH,EAAOuB,EACEA,EAAKC,YAAcrB,EAG5BH,EAAKc,YAAcS,EAAKT,YAExBd,EAAOuB,EAETA,EAAOvB,EAAKc,WACb,OAAQS,EACV,CAOD,YAAAG,GACE,OAAOrN,KAAKuM,SACb,CAKD,QAAAY,GACE,OAAOnN,KAAKwM,KACb,CAUD,QAAAO,CAASP,GACP,GAAIxM,KAAKwM,QAAUV,GAAmB9L,KAAKwM,MAAQA,EACjD,MAAM,IAAIhE,MAAM,gCAElBxI,KAAKwM,MAAQA,EACbxM,KAAK6H,SACN,CASD,IAAAyF,GACE/E,GACD,CAQD,QAAAgF,CAASC,EAAIC,GACX,IAAKzN,KAAK0M,YACR,OAAO,EAGT,IAAIgB,EAAQ1N,KAAK4M,kBAAkBY,GACnC,GAAKE,GAGE,IAAe,IAAXA,EACT,OAAO,OAHPA,EAAQD,EACRzN,KAAK4M,kBAAkBY,GAAME,EAK/B,MAAMC,EAAQF,EAAOC,EAAQ,IAAO,GACpC,OAAIC,GAAS3N,KAAK0M,YACT,EAEFX,GAAO4B,EAAQ3N,KAAK0M,YAC5B,CASD,YAAAkB,CAAaJ,GACX,QAAKxN,KAAK0M,cAG6B,IAAhC1M,KAAK4M,kBAAkBY,EAC/B,CAMD,aAAAK,CAAcL,GACRxN,KAAK0M,cACP1M,KAAK4M,kBAAkBY,IAAO,EAEjC,GCvTH,MAAMM,GACiB,oBAAdC,gBAA4D,IAAxBA,UAAUC,UACjDD,UAAUC,UAAUC,cACpB,GAMOC,GAAUJ,GAAGpI,SAAS,WAMtByI,GAASL,GAAGpI,SAAS,YAAcoI,GAAGpI,SAAS,SAM/C0I,GACXD,KACCL,GAAGpI,SAAS,iBACX,wCAAwC2I,KAAKP,KAMpCQ,GAASR,GAAGpI,SAAS,YAAcoI,GAAGpI,SAAS,QAM/C6I,GAAMT,GAAGpI,SAAS,aASlB8I,GACiB,oBAArBC,iBAAmCA,iBAAmB,EAOlDC,GACkB,oBAAtBC,mBACoB,oBAApBC,iBACPC,gBAAgBF,kBAMLG,GACM,oBAAVC,OAAyBA,MAAMlL,UAAUmL,OAMrCC,GAAmD,mBAAtBC,kBAK7BC,GAA0B,WACrC,IAAIC,GAAU,EACd,IACE,MAAMzE,EAAUjE,OAAO2I,eAAe,CAAA,EAAI,UAAW,CACnDjG,IAAK,WACHgG,GAAU,CACX,IAIHE,OAAOhK,iBAAiB,IAAK,KAAMqF,GAEnC2E,OAAOhJ,oBAAoB,IAAK,KAAMqE,EACvC,CAAC,MAAO4E,GAER,CACD,OAAOH,CACR,CAjBsC,GC/DhC,SAASI,GAAsBC,EAAOC,EAAQC,EAAYC,GAE/D,IAAIC,EAeJ,OAbEA,EADEF,GAAcA,EAAWxO,OACgBwO,EAAWG,QAC7CpB,GACA,IAAIE,gBAAgBa,GAAS,IAAKC,GAAU,KAE5CK,SAASC,cAAc,UAE9BP,IACFI,EAAOJ,MAAQA,GAEbC,IACFG,EAAOH,OAASA,GAIhBG,EAAOI,WAAW,KAAML,EAE5B,CAOO,SAASM,GAAcC,GAC5B,MAAMN,EAASM,EAAQN,OACvBA,EAAOJ,MAAQ,EACfI,EAAOH,OAAS,EAChBS,EAAQC,UAAU,EAAG,EAAG,EAAG,EAC7B,CASO,SAASC,GAAW9F,GACzB,IAAIkF,EAAQlF,EAAQ+F,YACpB,MAAMC,EAAQC,iBAAiBjG,GAG/B,OAFAkF,GAASgB,SAASF,EAAMG,WAAY,IAAMD,SAASF,EAAMI,YAAa,IAE/DlB,CACT,CASO,SAASmB,GAAYrG,GAC1B,IAAImF,EAASnF,EAAQsG,aACrB,MAAMN,EAAQC,iBAAiBjG,GAG/B,OAFAmF,GAAUe,SAASF,EAAMO,UAAW,IAAML,SAASF,EAAMQ,aAAc,IAEhErB,CACT,CAMO,SAASsB,GAAYC,EAASC,GACnC,MAAMC,EAASD,EAAQE,WACnBD,GACFA,EAAOE,aAAaJ,EAASC,EAEjC,CAMO,SAASI,GAAWC,GACzB,OAAOA,GAAQA,EAAKH,WAAaG,EAAKH,WAAWI,YAAYD,GAAQ,IACvE,CAKO,SAASE,GAAeF,GAC7B,KAAOA,EAAKG,WACVH,EAAKC,YAAYD,EAAKG,UAE1B,CAUO,SAASC,GAAgBJ,EAAMK,GACpC,MAAMC,EAAcN,EAAKO,WAEzB,IAAK,IAAIlQ,EAAI,KAAWA,EAAG,CACzB,MAAMmQ,EAAWF,EAAYjQ,GACvBoQ,EAAWJ,EAAShQ,GAG1B,IAAKmQ,IAAaC,EAChB,MAIED,IAAaC,IAKZD,EAMAC,EAOLT,EAAKU,aAAaD,EAAUD,IAN1BR,EAAKC,YAAYO,KACfnQ,GAPF2P,EAAKW,YAAYF,GAapB,CACH,CC5HO,SAASG,GAAYhQ,GAC1B,OAAOA,aAAgB4M,OACrB5M,aAAgBiQ,mBAChBjQ,aAAgBkQ,kBAChBlQ,aAAgBmQ,YACdnQ,EACA,IACN,CAMO,SAASoQ,GAAYpQ,GAC1B,OAAOA,aAAgBqQ,YACrBrQ,aAAgBsQ,mBAChBtQ,aAAgBuQ,cAChBvQ,aAAgBwQ,SACdxQ,EACA,IACN,CAKA,IAAIyQ,GAAgB,KAMb,SAASC,GAAQC,GACjBF,KACHA,GAAgBpD,GACdsD,EAAMrD,MACNqD,EAAMpD,YACNlJ,EACA,CAACuM,oBAAoB,KAGzB,MAAMlD,EAAS+C,GAAc/C,OACvBJ,EAAQqD,EAAMrD,MAChBI,EAAOJ,QAAUA,IACnBI,EAAOJ,MAAQA,GAEjB,MAAMC,EAASoD,EAAMpD,OAMrB,OALIG,EAAOH,SAAWA,IACpBG,EAAOH,OAASA,GAElBkD,GAAcxC,UAAU,EAAG,EAAGX,EAAOC,GACrCkD,GAAcI,UAAUF,EAAO,EAAG,GAC3BF,GAAcK,aAAa,EAAG,EAAGxD,EAAOC,GAAQvN,IACzD,CAKA,MAAM+Q,GAAc,CAAC,IAAK,KA+G1B,IAAAC,GAhGA,cAAuBC,GAIrB,WAAAtT,CAAY6K,GACV,MAAM6B,EAAQV,EAEd7G,MAAM0F,EAAQ4B,UAAWC,EAAO,CAC9BG,WAAYhC,EAAQgC,WACpBE,YAAalC,EAAQkC,cAOvB7M,KAAKqT,QAAU1I,EAAQ2I,OAMvBtT,KAAKuT,MAAQ,KAMbvT,KAAKwT,OAAS,KAMdxT,KAAKyT,MAAQ9I,EAAQ+I,MAAQ,IAC9B,CAMD,OAAAC,GACE,GAAI3T,KAAKyT,MACP,OAAOzT,KAAKyT,MAEd,MAAMG,EAAYzB,GAAYnS,KAAKuT,OACnC,OAAIK,EACK,CAACA,EAAUnE,MAAOmE,EAAUlE,QAE9BwD,EACR,CAOD,OAAAW,GACE,OAAO7T,KAAKuT,KACb,CAOD,QAAAO,GACE,OAAO9T,KAAKwT,MACb,CAMD,IAAAlG,GACE,GAAItN,KAAKwM,QAAUV,GAAkB9L,KAAKwM,QAAUV,EAClD,OAEF9L,KAAKwM,MAAQV,EACb9L,KAAK6H,UAEL,MAAMgH,EAAO7O,KACbA,KAAKqT,UACFU,MAAK,SAAU5R,GACd0M,EAAK0E,MAAQpR,EACb0M,EAAKrC,MAAQV,EACb+C,EAAKhH,SACb,IACOmM,OAAM,SAAUzE,GACfV,EAAK2E,OAASjE,EACdV,EAAKrC,MAAQV,EACb+C,EAAKhH,SACb,GACG,GCrLI,SAASoM,GAAOC,EAAWC,GAChC,IAAKD,EACH,MAAM,IAAI1L,MAAM2L,EAEpB,CC8DA,MAAMC,WAAgB3J,EAOpB,WAAA3K,CAAYuU,GAmDV,GAlDApP,QAKAjF,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAML3H,KAAKsU,SAAM9N,EAMXxG,KAAKuU,cAAgB,WAOrBvU,KAAKwU,OAAS,KAMdxU,KAAKyU,oBAAiBjO,EAMtBxG,KAAK0U,mBAAqB,KAE1B1U,KAAK6J,kBAAkB7J,KAAKuU,cAAevU,KAAK2U,wBAE5CN,EACF,GAGQ,mBADa,EAC3B,sBACQ,CACA,MAAMO,EAAoC,EAC1C5U,KAAK6U,YAAYD,EACzB,KAAa,CAEL,MAAME,EAAaT,EACnBrU,KAAKmJ,cAAc2L,EACpB,CAEJ,CAQD,KAAAC,GACE,MAAMA,EAAK,IACLX,GAAQpU,KAAK0J,gBAAkB1J,KAAKuJ,gBAAkB,MAE5DwL,EAAMC,gBAAgBhV,KAAKiV,mBAC3B,MAAML,EAAW5U,KAAKkV,cAClBN,GACFG,EAAMF,YAAqCD,EAASG,SAEtD,MAAMxE,EAAQvQ,KAAKmV,WAInB,OAHI5E,GACFwE,EAAMK,SAAS7E,GAEVwE,CACR,CAUD,WAAAG,GACE,OAA0ClV,KAAKoJ,IAAIpJ,KAAKuU,cACzD,CASD,KAAAc,GACE,OAAOrV,KAAKsU,GACb,CASD,eAAAW,GACE,OAAOjV,KAAKuU,aACb,CAQD,QAAAY,GACE,OAAOnV,KAAKwU,MACb,CAQD,gBAAAc,GACE,OAAOtV,KAAKyU,cACb,CAKD,qBAAAc,GACEvV,KAAK6H,SACN,CAKD,sBAAA8M,GACM3U,KAAK0U,qBACPpN,EAActH,KAAK0U,oBACnB1U,KAAK0U,mBAAqB,MAE5B,MAAME,EAAW5U,KAAKkV,cAClBN,IACF5U,KAAK0U,mBAAqB3N,EACxB6N,EACA9M,EACA9H,KAAKuV,sBACLvV,OAGJA,KAAK6H,SACN,CASD,WAAAgN,CAAYD,GACV5U,KAAK+J,IAAI/J,KAAKuU,cAAeK,EAC9B,CAWD,QAAAQ,CAAS7E,GACPvQ,KAAKwU,OAASjE,EACdvQ,KAAKyU,eAAkBlE,EAAoBiF,GAAoBjF,QAAhC/J,EAC/BxG,KAAK6H,SACN,CAWD,KAAA4N,CAAMjI,GACJxN,KAAKsU,IAAM9G,EACXxN,KAAK6H,SACN,CASD,eAAAmN,CAAgBU,GACd1V,KAAK8J,qBAAqB9J,KAAKuU,cAAevU,KAAK2U,wBACnD3U,KAAKuU,cAAgBmB,EACrB1V,KAAK6J,kBAAkB7J,KAAKuU,cAAevU,KAAK2U,wBAChD3U,KAAK2U,wBACN,EAWI,SAASa,GAAoB7M,GAClC,GAAmB,mBAARA,EACT,OAAOA,EAKT,IAAIgN,EACJ,GAAItT,MAAMC,QAAQqG,GAChBgN,EAAShN,MACJ,CACLsL,GACgD,mBAArB,EAAe,UACxC,mEAGF0B,EAAS,CADwD,EAElE,CACD,OAAO,WACL,OAAOA,CACX,CACA,CACA,IAAAC,GAAexB,GCnTf,MAAMyB,GAAO,IAAIxT,MAAM,GAMhB,SAASyT,KACd,MAAO,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,EACzB,CAOO,SAASC,GAAMC,GACpB,OAAOjM,GAAIiM,EAAW,EAAG,EAAG,EAAG,EAAG,EAAG,EACvC,CASO,SAASC,GAASC,EAAYC,GACnC,MAAMC,EAAKF,EAAW,GAChBG,EAAKH,EAAW,GAChBI,EAAKJ,EAAW,GAChBK,EAAKL,EAAW,GAChBM,EAAKN,EAAW,GAChBO,EAAKP,EAAW,GAChBQ,EAAKP,EAAW,GAChBQ,EAAKR,EAAW,GAChBS,EAAKT,EAAW,GAChBU,EAAKV,EAAW,GAChBW,EAAKX,EAAW,GAChBY,EAAKZ,EAAW,GAStB,OAPAD,EAAW,GAAKE,EAAKM,EAAKJ,EAAKK,EAC/BT,EAAW,GAAKG,EAAKK,EAAKH,EAAKI,EAC/BT,EAAW,GAAKE,EAAKQ,EAAKN,EAAKO,EAC/BX,EAAW,GAAKG,EAAKO,EAAKL,EAAKM,EAC/BX,EAAW,GAAKE,EAAKU,EAAKR,EAAKS,EAAKP,EACpCN,EAAW,GAAKG,EAAKS,EAAKP,EAAKQ,EAAKN,EAE7BP,CACT,CAaO,SAASnM,GAAIiM,EAAW3U,EAAGC,EAAG0V,EAAGC,EAAGC,EAAG9L,GAO5C,OANA4K,EAAU,GAAK3U,EACf2U,EAAU,GAAK1U,EACf0U,EAAU,GAAKgB,EACfhB,EAAU,GAAKiB,EACfjB,EAAU,GAAKkB,EACflB,EAAU,GAAK5K,EACR4K,CACT,CAQO,SAASmB,GAAajB,EAAYC,GAOvC,OANAD,EAAW,GAAKC,EAAW,GAC3BD,EAAW,GAAKC,EAAW,GAC3BD,EAAW,GAAKC,EAAW,GAC3BD,EAAW,GAAKC,EAAW,GAC3BD,EAAW,GAAKC,EAAW,GAC3BD,EAAW,GAAKC,EAAW,GACpBD,CACT,CAWO,SAAShS,GAAM8R,EAAWoB,GAC/B,MAAMC,EAAID,EAAW,GACfE,EAAIF,EAAW,GAGrB,OAFAA,EAAW,GAAKpB,EAAU,GAAKqB,EAAIrB,EAAU,GAAKsB,EAAItB,EAAU,GAChEoB,EAAW,GAAKpB,EAAU,GAAKqB,EAAIrB,EAAU,GAAKsB,EAAItB,EAAU,GACzDoB,CACT,CAQO,SAASG,GAAOvB,EAAWwB,GAChC,MAAMC,EAAMxL,KAAKwL,IAAID,GACfE,EAAMzL,KAAKyL,IAAIF,GACrB,OAAOvB,GAASD,EAAWjM,GAAI8L,GAAM4B,EAAKC,GAAMA,EAAKD,EAAK,EAAG,GAC/D,CASO,SAASE,GAAM3B,EAAWqB,EAAGC,GAClC,OAAOrB,GAASD,EAAWjM,GAAI8L,GAAMwB,EAAG,EAAG,EAAGC,EAAG,EAAG,GACtD,CASO,SAASM,GAAUzX,EAAQkX,EAAGC,GACnC,OAAOvN,GAAI5J,EAAQkX,EAAG,EAAG,EAAGC,EAAG,EAAG,EACpC,CASO,SAASO,GAAU7B,EAAW8B,EAAIC,GACvC,OAAO9B,GAASD,EAAWjM,GAAI8L,GAAM,EAAG,EAAG,EAAG,EAAGiC,EAAIC,GACvD,CAeO,SAASC,GAAQhC,EAAWiC,EAAKC,EAAKC,EAAIC,EAAIZ,EAAOa,EAAKC,GAC/D,MAAMZ,EAAMzL,KAAKyL,IAAIF,GACfC,EAAMxL,KAAKwL,IAAID,GAOrB,OANAxB,EAAU,GAAKmC,EAAKV,EACpBzB,EAAU,GAAKoC,EAAKV,EACpB1B,EAAU,IAAMmC,EAAKT,EACrB1B,EAAU,GAAKoC,EAAKX,EACpBzB,EAAU,GAAKqC,EAAMF,EAAKV,EAAMa,EAAMH,EAAKT,EAAMO,EACjDjC,EAAU,GAAKqC,EAAMD,EAAKV,EAAMY,EAAMF,EAAKX,EAAMS,EAC1ClC,CACT,CAoCO,SAASuC,GAAYpY,EAAQ+J,GAClC,MAAMsO,EAAMC,GAAYvO,GACxB+J,GAAe,IAARuE,EAAW,4CAElB,MAAMnX,EAAI6I,EAAO,GACX5I,EAAI4I,EAAO,GACX8M,EAAI9M,EAAO,GACX+M,EAAI/M,EAAO,GACXgN,EAAIhN,EAAO,GACXkB,EAAIlB,EAAO,GASjB,OAPA/J,EAAO,GAAK8W,EAAIuB,EAChBrY,EAAO,IAAMmB,EAAIkX,EACjBrY,EAAO,IAAM6W,EAAIwB,EACjBrY,EAAO,GAAKkB,EAAImX,EAChBrY,EAAO,IAAM6W,EAAI5L,EAAI6L,EAAIC,GAAKsB,EAC9BrY,EAAO,KAAOkB,EAAI+J,EAAI9J,EAAI4V,GAAKsB,EAExBrY,CACT,CAOO,SAASsY,GAAYC,GAC1B,OAAOA,EAAI,GAAKA,EAAI,GAAKA,EAAI,GAAKA,EAAI,EACxC,CAMA,IAAIC,GAQG,SAASC,GAASF,GACvB,MAAMG,EAAkB,UAAYH,EAAII,KAAK,MAAQ,IACrD,GAAIpK,GACF,OAAOmK,EAET,MAAMtH,EACJoH,KAAuBA,GAAqB5I,SAASC,cAAc,QAErE,OADAuB,EAAKhB,MAAMyF,UAAY6C,EAChBtH,EAAKhB,MAAMyF,SACpB,CCxRe,IAAA+C,GAAA,CACbC,QAAS,EACTC,aAAc,EACdC,MAAO,EACPC,MAAO,EACPC,MAAO,EACPC,KAAM,ICSD,SAASC,GAAeC,GAC7B,MAAMC,EAASC,KACf,IAAK,IAAI7X,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAQS,EAAIuE,IAAMvE,EACjD8X,GAAiBF,EAAQD,EAAY3X,IAEvC,OAAO4X,CACT,CAyBO,SAASG,GAAOH,EAAQnV,EAAOuV,GACpC,OAAIA,GACFA,EAAK,GAAKJ,EAAO,GAAKnV,EACtBuV,EAAK,GAAKJ,EAAO,GAAKnV,EACtBuV,EAAK,GAAKJ,EAAO,GAAKnV,EACtBuV,EAAK,GAAKJ,EAAO,GAAKnV,EACfuV,GAEF,CACLJ,EAAO,GAAKnV,EACZmV,EAAO,GAAKnV,EACZmV,EAAO,GAAKnV,EACZmV,EAAO,GAAKnV,EAEhB,CASO,SAAS0Q,GAAMyE,EAAQI,GAC5B,OAAIA,GACFA,EAAK,GAAKJ,EAAO,GACjBI,EAAK,GAAKJ,EAAO,GACjBI,EAAK,GAAKJ,EAAO,GACjBI,EAAK,GAAKJ,EAAO,GACVI,GAEFJ,EAAO1V,OAChB,CAQO,SAAS+V,GAAyBL,EAAQnC,EAAGC,GAClD,IAAIQ,EAAIC,EAeR,OAbED,EADET,EAAImC,EAAO,GACRA,EAAO,GAAKnC,EACRmC,EAAO,GAAKnC,EAChBA,EAAImC,EAAO,GAEX,EAGLzB,EADET,EAAIkC,EAAO,GACRA,EAAO,GAAKlC,EACRkC,EAAO,GAAKlC,EAChBA,EAAIkC,EAAO,GAEX,EAEA1B,EAAKA,EAAKC,EAAKA,CACxB,CAUO,SAAS+B,GAAmBN,EAAQpC,GACzC,OAAO2C,GAAWP,EAAQpC,EAAW,GAAIA,EAAW,GACtD,CAcO,SAAS4C,GAAeC,EAASC,GACtC,OACED,EAAQ,IAAMC,EAAQ,IACtBA,EAAQ,IAAMD,EAAQ,IACtBA,EAAQ,IAAMC,EAAQ,IACtBA,EAAQ,IAAMD,EAAQ,EAE1B,CAWO,SAASF,GAAWP,EAAQnC,EAAGC,GACpC,OAAOkC,EAAO,IAAMnC,GAAKA,GAAKmC,EAAO,IAAMA,EAAO,IAAMlC,GAAKA,GAAKkC,EAAO,EAC3E,CASO,SAASW,GAAuBX,EAAQpC,GAC7C,MAAMgD,EAAOZ,EAAO,GACda,EAAOb,EAAO,GACdc,EAAOd,EAAO,GACde,EAAOf,EAAO,GACdnC,EAAID,EAAW,GACfE,EAAIF,EAAW,GACrB,IAAIoD,EAAezB,GAAaC,QAchC,OAbI3B,EAAI+C,EACNI,GAA8BzB,GAAaM,KAClChC,EAAIiD,IACbE,GAA8BzB,GAAaI,OAEzC7B,EAAI+C,EACNG,GAA8BzB,GAAaK,MAClC9B,EAAIiD,IACbC,GAA8BzB,GAAaG,OAEzCsB,IAAiBzB,GAAaC,UAChCwB,EAAezB,GAAaE,cAEvBuB,CACT,CAOO,SAASf,KACd,MAAO,CAACgB,IAAUA,KAAWA,KAAWA,IAC1C,CAWO,SAASC,GAAeN,EAAMC,EAAMC,EAAMC,EAAMX,GACrD,OAAIA,GACFA,EAAK,GAAKQ,EACVR,EAAK,GAAKS,EACVT,EAAK,GAAKU,EACVV,EAAK,GAAKW,EACHX,GAEF,CAACQ,EAAMC,EAAMC,EAAMC,EAC5B,CAOO,SAASI,GAAoBf,GAClC,OAAOc,GAAeD,IAAUA,KAAWA,KAAWA,IAAUb,EAClE,CAOO,SAASgB,GAA6BxD,EAAYwC,GACvD,MAAMvC,EAAID,EAAW,GACfE,EAAIF,EAAW,GACrB,OAAOsD,GAAerD,EAAGC,EAAGD,EAAGC,EAAGsC,EACpC,CAoBO,SAASiB,GACdC,EACAC,EACA/Y,EACAgZ,EACApB,GAGA,OAAOqB,GADQN,GAAoBf,GACEkB,EAAiBC,EAAQ/Y,EAAKgZ,EACrE,CAmBO,SAASzY,GAAO0X,EAASC,GAC9B,OACED,EAAQ,IAAMC,EAAQ,IACtBD,EAAQ,IAAMC,EAAQ,IACtBD,EAAQ,IAAMC,EAAQ,IACtBD,EAAQ,IAAMC,EAAQ,EAE1B,CASO,SAASgB,GAAoBjB,EAASC,EAASiB,GACpD,OACElP,KAAKmP,IAAInB,EAAQ,GAAKC,EAAQ,IAAMiB,GACpClP,KAAKmP,IAAInB,EAAQ,GAAKC,EAAQ,IAAMiB,GACpClP,KAAKmP,IAAInB,EAAQ,GAAKC,EAAQ,IAAMiB,GACpClP,KAAKmP,IAAInB,EAAQ,GAAKC,EAAQ,IAAMiB,CAExC,CASO,SAASjZ,GAAO+X,EAASC,GAa9B,OAZIA,EAAQ,GAAKD,EAAQ,KACvBA,EAAQ,GAAKC,EAAQ,IAEnBA,EAAQ,GAAKD,EAAQ,KACvBA,EAAQ,GAAKC,EAAQ,IAEnBA,EAAQ,GAAKD,EAAQ,KACvBA,EAAQ,GAAKC,EAAQ,IAEnBA,EAAQ,GAAKD,EAAQ,KACvBA,EAAQ,GAAKC,EAAQ,IAEhBD,CACT,CAMO,SAASP,GAAiBF,EAAQpC,GACnCA,EAAW,GAAKoC,EAAO,KACzBA,EAAO,GAAKpC,EAAW,IAErBA,EAAW,GAAKoC,EAAO,KACzBA,EAAO,GAAKpC,EAAW,IAErBA,EAAW,GAAKoC,EAAO,KACzBA,EAAO,GAAKpC,EAAW,IAErBA,EAAW,GAAKoC,EAAO,KACzBA,EAAO,GAAKpC,EAAW,GAE3B,CAOO,SAASiE,GAAkB7B,EAAQD,GACxC,IAAK,IAAI3X,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAQS,EAAIuE,IAAMvE,EACjD8X,GAAiBF,EAAQD,EAAY3X,IAEvC,OAAO4X,CACT,CAUO,SAASyB,GACdzB,EACAsB,EACAC,EACA/Y,EACAgZ,GAEA,KAAOD,EAAS/Y,EAAK+Y,GAAUC,EAC7BM,GAAS9B,EAAQsB,EAAgBC,GAASD,EAAgBC,EAAS,IAErE,OAAOvB,CACT,CAOO,SAAS+B,GAAY/B,EAAQgC,GAClC,IAAK,IAAI5Z,EAAI,EAAGuE,EAAKqV,EAAMra,OAAQS,EAAIuE,IAAMvE,EAC3CyZ,GAAkB7B,EAAQgC,EAAM5Z,IAElC,OAAO4X,CACT,CAOO,SAAS8B,GAAS9B,EAAQnC,EAAGC,GAClCkC,EAAO,GAAKvN,KAAKwP,IAAIjC,EAAO,GAAInC,GAChCmC,EAAO,GAAKvN,KAAKwP,IAAIjC,EAAO,GAAIlC,GAChCkC,EAAO,GAAKvN,KAAKyP,IAAIlC,EAAO,GAAInC,GAChCmC,EAAO,GAAKvN,KAAKyP,IAAIlC,EAAO,GAAIlC,EAClC,CAWO,SAASqE,GAAcnC,EAAQoC,GACpC,IAAIC,EAEJ,OADAA,EAAMD,EAASE,GAActC,IACzBqC,IAGJA,EAAMD,EAASG,GAAevC,IAC1BqC,IAGJA,EAAMD,EAASI,GAAYxC,IACvBqC,IAGJA,EAAMD,EAASK,GAAWzC,IACtBqC,IAGG,IACT,CAQO,SAASK,GAAQ1C,GACtB,IAAI2C,EAAO,EAIX,OAHKrX,GAAQ0U,KACX2C,EAAOC,GAAS5C,GAAU6C,GAAU7C,IAE/B2C,CACT,CAQO,SAASL,GAActC,GAC5B,MAAO,CAACA,EAAO,GAAIA,EAAO,GAC5B,CAQO,SAASuC,GAAevC,GAC7B,MAAO,CAACA,EAAO,GAAIA,EAAO,GAC5B,CAQO,SAAS8C,GAAU9C,GACxB,MAAO,EAAEA,EAAO,GAAKA,EAAO,IAAM,GAAIA,EAAO,GAAKA,EAAO,IAAM,EACjE,CAQO,SAAS+C,GAAU/C,EAAQgD,GAChC,IAAIpF,EACJ,GAAe,gBAAXoF,EACFpF,EAAa0E,GAActC,QACtB,GAAe,iBAAXgD,EACTpF,EAAa2E,GAAevC,QACvB,GAAe,aAAXgD,EACTpF,EAAa6E,GAAWzC,OACnB,IAAe,cAAXgD,EAGT,MAAM,IAAIhU,MAAM,kBAFhB4O,EAAa4E,GAAYxC,EAG1B,CACD,OAAOpC,CACT,CAuBO,SAASqF,GAAkBC,EAAQC,EAAYC,EAAUlJ,EAAMkG,GACpE,MAAOiD,EAAIC,EAAIC,EAAIC,EAAIC,EAAIC,EAAIC,EAAIC,GAAMC,GACvCX,EACAC,EACAC,EACAlJ,GAEF,OAAOgH,GACLzO,KAAKwP,IAAIoB,EAAIE,EAAIE,EAAIE,GACrBlR,KAAKwP,IAAIqB,EAAIE,EAAIE,EAAIE,GACrBnR,KAAKyP,IAAImB,EAAIE,EAAIE,EAAIE,GACrBlR,KAAKyP,IAAIoB,EAAIE,EAAIE,EAAIE,GACrBxD,EAEJ,CASO,SAASyD,GAAmBX,EAAQC,EAAYC,EAAUlJ,GAC/D,MAAMoE,EAAM6E,EAAajJ,EAAK,GAAM,EAC9BqE,EAAM4E,EAAajJ,EAAK,GAAM,EAC9B4J,EAAcrR,KAAKwL,IAAImF,GACvBW,EAActR,KAAKyL,IAAIkF,GACvBY,EAAO1F,EAAKwF,EACZG,EAAO3F,EAAKyF,EACZG,EAAO3F,EAAKuF,EACZK,EAAO5F,EAAKwF,EACZlG,EAAIqF,EAAO,GACXpF,EAAIoF,EAAO,GACjB,MAAO,CACLrF,EAAImG,EAAOG,EACXrG,EAAImG,EAAOC,EACXrG,EAAImG,EAAOG,EACXrG,EAAImG,EAAOC,EACXrG,EAAImG,EAAOG,EACXrG,EAAImG,EAAOC,EACXrG,EAAImG,EAAOG,EACXrG,EAAImG,EAAOC,EACXrG,EAAImG,EAAOG,EACXrG,EAAImG,EAAOC,EAEf,CAQO,SAASrB,GAAU7C,GACxB,OAAOA,EAAO,GAAKA,EAAO,EAC5B,CAoBO,SAASoE,GAAgB3D,EAASC,EAASN,GAChD,MAAMiE,EAAejE,GAvZd,CAACa,IAAUA,KAAU,KAAW,KAgbvC,OAxBIqD,GAAW7D,EAASC,IAClBD,EAAQ,GAAKC,EAAQ,GACvB2D,EAAa,GAAK5D,EAAQ,GAE1B4D,EAAa,GAAK3D,EAAQ,GAExBD,EAAQ,GAAKC,EAAQ,GACvB2D,EAAa,GAAK5D,EAAQ,GAE1B4D,EAAa,GAAK3D,EAAQ,GAExBD,EAAQ,GAAKC,EAAQ,GACvB2D,EAAa,GAAK5D,EAAQ,GAE1B4D,EAAa,GAAK3D,EAAQ,GAExBD,EAAQ,GAAKC,EAAQ,GACvB2D,EAAa,GAAK5D,EAAQ,GAE1B4D,EAAa,GAAK3D,EAAQ,IAG5BS,GAAoBkD,GAEfA,CACT,CA0BO,SAAS5B,GAAWzC,GACzB,MAAO,CAACA,EAAO,GAAIA,EAAO,GAC5B,CAQO,SAASwC,GAAYxC,GAC1B,MAAO,CAACA,EAAO,GAAIA,EAAO,GAC5B,CAQO,SAAS4C,GAAS5C,GACvB,OAAOA,EAAO,GAAKA,EAAO,EAC5B,CASO,SAASsE,GAAW7D,EAASC,GAClC,OACED,EAAQ,IAAMC,EAAQ,IACtBD,EAAQ,IAAMC,EAAQ,IACtBD,EAAQ,IAAMC,EAAQ,IACtBD,EAAQ,IAAMC,EAAQ,EAE1B,CAQO,SAASpV,GAAQ0U,GACtB,OAAOA,EAAO,GAAKA,EAAO,IAAMA,EAAO,GAAKA,EAAO,EACrD,CAOO,SAASuE,GAAevE,EAAQI,GACrC,OAAIA,GACFA,EAAK,GAAKJ,EAAO,GACjBI,EAAK,GAAKJ,EAAO,GACjBI,EAAK,GAAKJ,EAAO,GACjBI,EAAK,GAAKJ,EAAO,GACVI,GAEFJ,CACT,CAMO,SAASwE,GAAgBxE,EAAQnV,GACtC,MAAM4Z,GAAWzE,EAAO,GAAKA,EAAO,IAAM,GAAMnV,EAAQ,GAClD6Z,GAAW1E,EAAO,GAAKA,EAAO,IAAM,GAAMnV,EAAQ,GACxDmV,EAAO,IAAMyE,EACbzE,EAAO,IAAMyE,EACbzE,EAAO,IAAM0E,EACb1E,EAAO,IAAM0E,CACf,CAUO,SAASC,GAAkB3E,EAAQ9L,EAAO1L,GAC/C,IAAI8b,GAAa,EACjB,MAAMM,EAAWjE,GAAuBX,EAAQ9L,GAC1C2Q,EAASlE,GAAuBX,EAAQxX,GAC9C,GACEoc,IAAarF,GAAaE,cAC1BoF,IAAWtF,GAAaE,aAExB6E,GAAa,MACR,CACL,MAAM1D,EAAOZ,EAAO,GACda,EAAOb,EAAO,GACdc,EAAOd,EAAO,GACde,EAAOf,EAAO,GACd8E,EAAS5Q,EAAM,GACf6Q,EAAS7Q,EAAM,GACf8Q,EAAOxc,EAAI,GACXyc,EAAOzc,EAAI,GACX0c,GAASD,EAAOF,IAAWC,EAAOF,GACxC,IAAIjH,EAAGC,EACA+G,EAAStF,GAAaG,SAAYkF,EAAWrF,GAAaG,SAE/D7B,EAAImH,GAAQC,EAAOlE,GAAQmE,EAC3BZ,EAAazG,GAAK+C,GAAQ/C,GAAKiD,GAG9BwD,KACEO,EAAStF,GAAaI,QACvBiF,EAAWrF,GAAaI,QAG1B7B,EAAImH,GAAQD,EAAOlE,GAAQoE,EAC3BZ,EAAaxG,GAAK+C,GAAQ/C,GAAKiD,GAG9BuD,KACEO,EAAStF,GAAaK,QACvBgF,EAAWrF,GAAaK,QAG1B/B,EAAImH,GAAQC,EAAOpE,GAAQqE,EAC3BZ,EAAazG,GAAK+C,GAAQ/C,GAAKiD,GAG9BwD,KACEO,EAAStF,GAAaM,OACvB+E,EAAWrF,GAAaM,OAG1B/B,EAAImH,GAAQD,EAAOpE,GAAQsE,EAC3BZ,EAAaxG,GAAK+C,GAAQ/C,GAAKiD,EAElC,CACD,OAAOuD,CACT,CAaO,SAASa,GAAenF,EAAQoF,EAAahF,EAAMiF,GACxD,GAAI/Z,GAAQ0U,GACV,OAAOmB,GAAoBf,GAE7B,IAAIL,EAAc,GAClB,GAAIsF,EAAQ,EAAG,CACb,MAAMpP,EAAQ+J,EAAO,GAAKA,EAAO,GAC3B9J,EAAS8J,EAAO,GAAKA,EAAO,GAClC,IAAK,IAAI5X,EAAI,EAAGA,EAAIid,IAASjd,EAC3B2X,EAAY5T,KACV6T,EAAO,GAAM/J,EAAQ7N,EAAKid,EAC1BrF,EAAO,GACPA,EAAO,GACPA,EAAO,GAAM9J,EAAS9N,EAAKid,EAC3BrF,EAAO,GAAM/J,EAAQ7N,EAAKid,EAC1BrF,EAAO,GACPA,EAAO,GACPA,EAAO,GAAM9J,EAAS9N,EAAKid,EAGnC,MACItF,EAAc,CACZC,EAAO,GACPA,EAAO,GACPA,EAAO,GACPA,EAAO,GACPA,EAAO,GACPA,EAAO,GACPA,EAAO,GACPA,EAAO,IAGXoF,EAAYrF,EAAaA,EAAa,GACtC,MAAMuF,EAAK,GACLC,EAAK,GACX,IAAK,IAAInd,EAAI,EAAGod,EAAIzF,EAAYpY,OAAQS,EAAIod,EAAGpd,GAAK,EAClDkd,EAAGnZ,KAAK4T,EAAY3X,IACpBmd,EAAGpZ,KAAK4T,EAAY3X,EAAI,IAE1B,OA1yBF,SAA4Bkd,EAAIC,EAAInF,GAKlC,OAAOc,GAJMzO,KAAKwP,IAAIvX,MAAM,KAAM4a,GACrB7S,KAAKwP,IAAIvX,MAAM,KAAM6a,GACrB9S,KAAKyP,IAAIxX,MAAM,KAAM4a,GACrB7S,KAAKyP,IAAIxX,MAAM,KAAM6a,GACYnF,EAChD,CAoyBSqF,CAAmBH,EAAIC,EAAInF,EACpC,CAUO,SAASsF,GAAM1F,EAAQ2F,GAC5B,MAAMC,EAAmBD,EAAWE,YAC9B3C,EAASJ,GAAU9C,GACzB,GACE2F,EAAWG,aACV5C,EAAO,GAAK0C,EAAiB,IAAM1C,EAAO,IAAM0C,EAAiB,IAClE,CACA,MAAMG,EAAanD,GAASgD,GAItBrE,EAHa9O,KAAKuT,OACrB9C,EAAO,GAAK0C,EAAiB,IAAMG,GAEVA,EAC5B/F,EAAO,IAAMuB,EACbvB,EAAO,IAAMuB,CACd,CACD,OAAOvB,CACT,CAcO,SAASiG,GAAcjG,EAAQ2F,GACpC,GAAIA,EAAWG,WAAY,CACzB,MAAMF,EAAmBD,EAAWE,YAEpC,IAAKK,SAASlG,EAAO,MAAQkG,SAASlG,EAAO,IAC3C,MAAO,CAAC,CAAC4F,EAAiB,GAAI5F,EAAO,GAAI4F,EAAiB,GAAI5F,EAAO,KAGvE0F,GAAM1F,EAAQ2F,GACd,MAAMI,EAAanD,GAASgD,GAE5B,GAAIhD,GAAS5C,GAAU+F,EAErB,MAAO,CAAC,CAACH,EAAiB,GAAI5F,EAAO,GAAI4F,EAAiB,GAAI5F,EAAO,KAEvE,GAAIA,EAAO,GAAK4F,EAAiB,GAE/B,MAAO,CACL,CAAC5F,EAAO,GAAK+F,EAAY/F,EAAO,GAAI4F,EAAiB,GAAI5F,EAAO,IAChE,CAAC4F,EAAiB,GAAI5F,EAAO,GAAIA,EAAO,GAAIA,EAAO,KAGvD,GAAIA,EAAO,GAAK4F,EAAiB,GAE/B,MAAO,CACL,CAAC5F,EAAO,GAAIA,EAAO,GAAI4F,EAAiB,GAAI5F,EAAO,IACnD,CAAC4F,EAAiB,GAAI5F,EAAO,GAAIA,EAAO,GAAK+F,EAAY/F,EAAO,IAGrE,CAED,MAAO,CAACA,EACV,CC54BA,MAAMmG,GAAa,CACjB,KAAQ,IACR,KAAQ,KACR,KAAQ,QACR,KAAQ,UACR,KAAQ,WAOH,SAASC,GAASC,GACvB,OAAOF,GAAWE,EACpB,CAiBO,MAAMC,GAAkB,CAE7BC,QAAW,SAAW,EAAI9T,KAAK+T,IAC/BC,QAAY,EAAIhU,KAAK+T,GAAK,QAAW,IACrCE,GAAM,MACNC,EAAK,EACL,QAAS,KAAO,MC4NlB,IAAAC,GA3NA,MAIE,WAAAtgB,CAAY6K,GAKV3K,KAAKqgB,MAAQ1V,EAAQkV,KASrB7f,KAAKsgB,OAAoD3V,EAAa,MAStE3K,KAAKugB,aAA6B/Z,IAAnBmE,EAAQ6O,OAAuB7O,EAAQ6O,OAAS,KAS/DxZ,KAAKwgB,kBACqBha,IAAxBmE,EAAQ8V,YAA4B9V,EAAQ8V,YAAc,KAM5DzgB,KAAK0gB,sBACyBla,IAA5BmE,EAAQgW,gBAAgChW,EAAQgW,gBAAkB,MAMpE3gB,KAAK4gB,aAA6Bpa,IAAnBmE,EAAQkW,QAAuBlW,EAAQkW,OAMtD7gB,KAAK8gB,aAAe9gB,KAAK4gB,UAAW5gB,KAAKugB,SAMzCvgB,KAAK+gB,wBAA0BpW,EAAQqW,mBAMvChhB,KAAKihB,iBAAmB,KAMxBjhB,KAAKkhB,eAAiBvW,EAAQwW,aAC/B,CAKD,QAAA7B,GACE,OAAOtf,KAAK8gB,SACb,CAOD,OAAAM,GACE,OAAOphB,KAAKqgB,KACb,CAOD,SAAAhB,GACE,OAAOrf,KAAKugB,OACb,CAOD,QAAAc,GACE,OAAOrhB,KAAKsgB,MACb,CASD,gBAAAgB,GACE,OAAOthB,KAAKkhB,gBAAkBpB,GAAgB9f,KAAKsgB,OACpD,CAOD,cAAAiB,GACE,OAAOvhB,KAAKwgB,YACb,CAaD,kBAAAgB,GACE,OAAOxhB,KAAK0gB,gBACb,CAOD,QAAAe,GACE,OAAOzhB,KAAK4gB,OACb,CAOD,SAAAc,CAAUb,GACR7gB,KAAK4gB,QAAUC,EACf7gB,KAAK8gB,aAAeD,IAAU7gB,KAAKugB,QACpC,CAKD,kBAAAoB,GACE,OAAO3hB,KAAKihB,gBACb,CAKD,kBAAAW,CAAmBC,GACjB7hB,KAAKihB,iBAAmBY,CACzB,CAOD,SAAAC,CAAUtI,GACRxZ,KAAKugB,QAAU/G,EACfxZ,KAAK8gB,aAAe9gB,KAAK4gB,UAAWpH,EACrC,CAQD,cAAAuI,CAAetB,GACbzgB,KAAKwgB,aAAeC,CACrB,CAQD,qBAAAuB,CAAsBpf,GACpB5C,KAAK+gB,wBAA0Bne,CAChC,CAOD,sBAAAqf,GACE,OAAOjiB,KAAK+gB,uBACb,GChQI,MAAMmB,GAAS,QAMTC,GAAYlW,KAAK+T,GAAKkC,GAMtBE,GAAS,EAAED,IAAYA,GAAWA,GAAWA,IAM7CE,GAAe,EAAE,KAAM,GAAI,IAAK,IAOhCC,GAAaJ,GAASjW,KAAKsW,IAAItW,KAAKuW,IAAIvW,KAAK+T,GAAK,IAM/D,MAAMyC,WAA2BC,GAI/B,WAAA5iB,CAAY+f,GACV5a,MAAM,CACJ4a,KAAMA,EACN8C,MAAO,IACPnJ,OAAQ4I,GACRvB,QAAQ,EACRJ,YAAa4B,GACbrB,mBAAoB,SAAUrE,EAAYiG,GACxC,OAAOjG,EAAa1Q,KAAK4W,KAAKD,EAAM,GAAKV,GAC1C,GAEJ,EASI,MAAMY,GAAc,CACzB,IAAIL,GAAmB,aACvB,IAAIA,GAAmB,eACvB,IAAIA,GAAmB,eACvB,IAAIA,GAAmB,eACvB,IAAIA,GAAmB,8CACvB,IAAIA,GAAmB,iDAWlB,SAASM,GAAaC,EAAOC,EAAQC,GAC1C,MAAM/hB,EAAS6hB,EAAM7hB,OACrB+hB,EAAYA,EAAY,EAAIA,EAAY,OACzB1c,IAAXyc,IAGAA,EAFEC,EAAY,EAELF,EAAMlf,QAEN,IAAIzB,MAAMlB,IAGvB,IAAK,IAAIS,EAAI,EAAGA,EAAIT,EAAQS,GAAKshB,EAAW,CAC1CD,EAAOrhB,GAAMugB,GAAYa,EAAMphB,GAAM,IACrC,IAAI0V,EAAI4K,GAASjW,KAAKsW,IAAItW,KAAKuW,IAAKvW,KAAK+T,KAAOgD,EAAMphB,EAAI,GAAK,IAAO,MAClE0V,EAAIgL,GACNhL,EAAIgL,GACKhL,GAAKgL,KACdhL,GAAKgL,IAEPW,EAAOrhB,EAAI,GAAK0V,CACjB,CACD,OAAO2L,CACT,CAUO,SAASE,GAAWH,EAAOC,EAAQC,GACxC,MAAM/hB,EAAS6hB,EAAM7hB,OACrB+hB,EAAYA,EAAY,EAAIA,EAAY,OACzB1c,IAAXyc,IAGAA,EAFEC,EAAY,EAELF,EAAMlf,QAEN,IAAIzB,MAAMlB,IAGvB,IAAK,IAAIS,EAAI,EAAGA,EAAIT,EAAQS,GAAKshB,EAC/BD,EAAOrhB,GAAM,IAAMohB,EAAMphB,GAAMugB,GAC/Bc,EAAOrhB,EAAI,GACR,IAAMqK,KAAKmX,KAAKnX,KAAKoX,IAAIL,EAAMphB,EAAI,GAAKsgB,KAAYjW,KAAK+T,GAAK,GAEnE,OAAOiD,CACT,CCzHO,MAAMf,GAAS,QAQTE,GAAS,EAAE,KAAM,GAAI,IAAK,IAM1BtC,GAAmB7T,KAAK+T,GAAKkC,GAAU,IAUpD,MAAMoB,WAA2BZ,GAK/B,WAAA5iB,CAAY+f,EAAMc,GAChB1b,MAAM,CACJ4a,KAAMA,EACN8C,MAAO,UACPnJ,OAAQ4I,GACRzB,gBAAiBA,EACjBE,QAAQ,EACRM,cAAerB,GACfW,YAAa2B,IAEhB,EASI,MAAMU,GAAc,CACzB,IAAIQ,GAAmB,UACvB,IAAIA,GAAmB,YAAa,OACpC,IAAIA,GAAmB,iCACvB,IAAIA,GAAmB,4BACvB,IAAIA,GAAmB,gDACvB,IAAIA,GAAmB,+CAAgD,OACvE,IAAIA,GAAmB,6CAA8C,QC3DvE,IAAIC,GAAQ,CAAA,EAKL,SAAS5e,KACd4e,GAAQ,CAAA,CACV,CAOO,SAASna,GAAIyW,GAClB,OACE0D,GAAM1D,IACN0D,GAAM1D,EAAK2D,QAAQ,yCAA0C,aAC7D,IAEJ,CAOO,SAASC,GAAI5D,EAAMV,GACxBoE,GAAM1D,GAAQV,CAChB,CC3BA,IAAIuE,GAAa,CAAA,EAKV,SAAS/e,KACd+e,GAAa,CAAA,CACf,CAUO,SAASD,GAAIvZ,EAAQyZ,EAAa/E,GACvC,MAAMgF,EAAa1Z,EAAOkX,UACpByC,EAAkBF,EAAYvC,UAC9BwC,KAAcF,KAClBA,GAAWE,GAAc,IAE3BF,GAAWE,GAAYC,GAAmBjF,CAC5C,CA4BO,SAASxV,GAAIwa,EAAYC,GAC9B,IAAI7N,EAIJ,OAHI4N,KAAcF,IAAcG,KAAmBH,GAAWE,KAC5D5N,EAAY0N,GAAWE,GAAYC,IAE9B7N,CACT,CCvDO,SAAS8N,GAAMzf,EAAOoX,EAAKC,GAChC,OAAOzP,KAAKwP,IAAIxP,KAAKyP,IAAIrX,EAAOoX,GAAMC,EACxC,CAaO,SAASqI,GAAuB1M,EAAGC,EAAGyF,EAAIC,EAAIC,EAAIC,GACvD,MAAMpF,EAAKmF,EAAKF,EACVhF,EAAKmF,EAAKF,EAChB,GAAW,IAAPlF,GAAmB,IAAPC,EAAU,CACxB,MAAM/L,IAAMqL,EAAI0F,GAAMjF,GAAMR,EAAI0F,GAAMjF,IAAOD,EAAKA,EAAKC,EAAKA,GACxD/L,EAAI,GACN+Q,EAAKE,EACLD,EAAKE,GACIlR,EAAI,IACb+Q,GAAMjF,EAAK9L,EACXgR,GAAMjF,EAAK/L,EAEd,CACD,OAAOgY,GAAgB3M,EAAGC,EAAGyF,EAAIC,EACnC,CAUO,SAASgH,GAAgBjH,EAAIC,EAAIC,EAAIC,GAC1C,MAAMpF,EAAKmF,EAAKF,EACVhF,EAAKmF,EAAKF,EAChB,OAAOlF,EAAKA,EAAKC,EAAKA,CACxB,CASO,SAASkM,GAAkBvL,GAChC,MAAM/W,EAAI+W,EAAIvX,OAEd,IAAK,IAAIS,EAAI,EAAGA,EAAID,EAAGC,IAAK,CAE1B,IAAIsiB,EAAStiB,EACTuiB,EAAQlY,KAAKmP,IAAI1C,EAAI9W,GAAGA,IAC5B,IAAK,IAAIwiB,EAAIxiB,EAAI,EAAGwiB,EAAIziB,EAAGyiB,IAAK,CAC9B,MAAMC,EAAWpY,KAAKmP,IAAI1C,EAAI0L,GAAGxiB,IAC7ByiB,EAAWF,IACbA,EAAQE,EACRH,EAASE,EAEZ,CAED,GAAc,IAAVD,EACF,OAAO,KAIT,MAAMliB,EAAMyW,EAAIwL,GAChBxL,EAAIwL,GAAUxL,EAAI9W,GAClB8W,EAAI9W,GAAKK,EAGT,IAAK,IAAIqiB,EAAI1iB,EAAI,EAAG0iB,EAAI3iB,EAAG2iB,IAAK,CAC9B,MAAMC,GAAQ7L,EAAI4L,GAAG1iB,GAAK8W,EAAI9W,GAAGA,GACjC,IAAK,IAAI4iB,EAAI5iB,EAAG4iB,EAAI7iB,EAAI,EAAG6iB,IACrB5iB,GAAK4iB,EACP9L,EAAI4L,GAAGE,GAAK,EAEZ9L,EAAI4L,GAAGE,IAAMD,EAAO7L,EAAI9W,GAAG4iB,EAGhC,CACF,CAGD,MAAMnN,EAAI,IAAIhV,MAAMV,GACpB,IAAK,IAAIqd,EAAIrd,EAAI,EAAGqd,GAAK,EAAGA,IAAK,CAC/B3H,EAAE2H,GAAKtG,EAAIsG,GAAGrd,GAAK+W,EAAIsG,GAAGA,GAC1B,IAAK,IAAImB,EAAInB,EAAI,EAAGmB,GAAK,EAAGA,IAC1BzH,EAAIyH,GAAGxe,IAAM+W,EAAIyH,GAAGnB,GAAK3H,EAAE2H,EAE9B,CACD,OAAO3H,CACT,CAQO,SAASoN,GAAUC,GACxB,OAAyB,IAAjBA,EAAwBzY,KAAK+T,EACvC,CAQO,SAAS2E,GAAUC,GACxB,OAAQA,EAAiB3Y,KAAK+T,GAAM,GACtC,CASO,SAAS6E,GAAOxjB,EAAGC,GACxB,MAAM8iB,EAAI/iB,EAAIC,EACd,OAAO8iB,EAAI9iB,EAAI,EAAI8iB,EAAI9iB,EAAI8iB,CAC7B,CAUO,SAASU,GAAKzjB,EAAGC,EAAG+V,GACzB,OAAOhW,EAAIgW,GAAK/V,EAAID,EACtB,CAQO,SAAS0jB,GAAQpjB,EAAGqjB,GACzB,MAAMC,EAAShZ,KAAKC,IAAI,GAAI8Y,GAC5B,OAAO/Y,KAAKiZ,MAAMvjB,EAAIsjB,GAAUA,CAClC,CASO,SAASC,GAAMvjB,EAAGqjB,GACvB,OAAO/Y,KAAKiZ,MAAMH,GAAQpjB,EAAGqjB,GAC/B,CASO,SAASxF,GAAM7d,EAAGqjB,GACvB,OAAO/Y,KAAKuT,MAAMuF,GAAQpjB,EAAGqjB,GAC/B,CASO,SAASG,GAAKxjB,EAAGqjB,GACtB,OAAO/Y,KAAKkZ,KAAKJ,GAAQpjB,EAAGqjB,GAC9B,CC5LO,SAASI,GAAUC,EAAQ5V,EAAO6V,GACvC,MAAMC,OACU/e,IAAd8e,EAA0BD,EAAON,QAAQO,GAAa,GAAKD,EAC7D,IAAIG,EAAUD,EAAa3e,QAAQ,KAEnC,OADA4e,GAAuB,IAAbA,EAAiBD,EAAapkB,OAASqkB,EAC1CA,EAAU/V,EACb8V,EACA,IAAIljB,MAAM,EAAIoN,EAAQ+V,GAAS1M,KAAK,KAAOyM,CACjD,CAQO,SAASE,GAAgBC,EAAIC,GAClC,MAAMC,GAAM,GAAKF,GAAIG,MAAM,KACrBC,GAAM,GAAKH,GAAIE,MAAM,KAE3B,IAAK,IAAIjkB,EAAI,EAAGA,EAAIqK,KAAKyP,IAAIkK,EAAGzkB,OAAQ2kB,EAAG3kB,QAASS,IAAK,CACvD,MAAMmkB,EAAKtV,SAASmV,EAAGhkB,IAAM,IAAK,IAC5BokB,EAAKvV,SAASqV,EAAGlkB,IAAM,IAAK,IAElC,GAAImkB,EAAKC,EACP,OAAO,EAET,GAAIA,EAAKD,EACP,OAAQ,CAEX,CAED,OAAO,CACT,CCHO,SAAStC,GAAIrM,EAAYzJ,GAG9B,OAFAyJ,EAAW,KAAOzJ,EAAM,GACxByJ,EAAW,KAAOzJ,EAAM,GACjByJ,CACT,CASO,SAAS6O,GAAgB7O,EAAY8O,GAC1C,MAAM9B,EAAI8B,EAAOC,YACXzJ,EAASwJ,EAAO5J,YAChBO,EAAKH,EAAO,GACZI,EAAKJ,EAAO,GAIlB,IAAI5E,EAHOV,EAAW,GAGRyF,EACd,MAAM9E,EAHKX,EAAW,GAGN0F,EACL,IAAPhF,GAAmB,IAAPC,IACdD,EAAK,GAEP,MAAMb,EAAIhL,KAAKma,KAAKtO,EAAKA,EAAKC,EAAKA,GAKnC,MAAO,CAHG8E,EAAMuH,EAAItM,EAAMb,EAChB6F,EAAMsH,EAAIrM,EAAMd,EAG5B,CAcO,SAASoP,GAAiBjP,EAAYkP,GAC3C,MAAMzJ,EAAKzF,EAAW,GAChB0F,EAAK1F,EAAW,GAChB1J,EAAQ4Y,EAAQ,GAChBtkB,EAAMskB,EAAQ,GACdvJ,EAAKrP,EAAM,GACXsP,EAAKtP,EAAM,GACXuP,EAAKjb,EAAI,GACTkb,EAAKlb,EAAI,GACT8V,EAAKmF,EAAKF,EACVhF,EAAKmF,EAAKF,EACVuJ,EACG,IAAPzO,GAAmB,IAAPC,EACR,GACCD,GAAM+E,EAAKE,GAAMhF,GAAM+E,EAAKE,KAAQlF,EAAKA,EAAKC,EAAKA,GAAM,GAChE,IAAIV,EAAGC,EAWP,OAVIiP,GAAS,GACXlP,EAAI0F,EACJzF,EAAI0F,GACKuJ,GAAS,GAClBlP,EAAI4F,EACJ3F,EAAI4F,IAEJ7F,EAAI0F,EAAKwJ,EAAQzO,EACjBR,EAAI0F,EAAKuJ,EAAQxO,GAEZ,CAACV,EAAGC,EACb,CAiDO,SAASkP,GAAoBC,EAAaxG,EAASyG,GACxD,MAAMC,EAAoB9B,GAAO5E,EAAU,IAAK,KAAO,IACjD5I,EAAIpL,KAAKmP,IAAI,KAAOuL,GACpB3B,EAAW0B,GAAkB,EAEnC,IAAIE,EAAM3a,KAAKuT,MAAMnI,EAAI,MACrBoE,EAAMxP,KAAKuT,OAAOnI,EAAU,KAANuP,GAAc,IACpCC,EAAM9B,GAAQ1N,EAAU,KAANuP,EAAmB,GAANnL,EAAUuJ,GAEzC6B,GAAO,KACTA,EAAM,EACNpL,GAAO,GAGLA,GAAO,KACTA,EAAM,EACNmL,GAAO,GAGT,IAAIE,EAAOF,EAAM,IAWjB,OAVY,IAARnL,GAAqB,IAARoL,IACfC,GAAQ,IAAM1B,GAAU3J,EAAK,GAAK,KAExB,IAARoL,IACFC,GAAQ,IAAM1B,GAAUyB,EAAK,EAAG7B,GAAY,KAEpB,IAAtB2B,IACFG,GAAQ,IAAML,EAAYM,OAAOJ,EAAoB,EAAI,EAAI,IAGxDG,CACT,CAiCO,SAASE,GAAO5P,EAAY6P,EAAUP,GAC3C,OAAItP,EACK6P,EACJzD,QAAQ,MAAOpM,EAAW,GAAG2N,QAAQ2B,IACrClD,QAAQ,MAAOpM,EAAW,GAAG2N,QAAQ2B,IAEnC,EACT,CAOO,SAASnkB,GAAO2kB,EAAaC,GAClC,IAAI5kB,GAAS,EACb,IAAK,IAAIX,EAAIslB,EAAY/lB,OAAS,EAAGS,GAAK,IAAKA,EAC7C,GAAIslB,EAAYtlB,IAAMulB,EAAYvlB,GAAI,CACpCW,GAAS,EACT,KACD,CAEH,OAAOA,CACT,CAoBO,SAASgV,GAAOH,EAAYI,GACjC,MAAM4P,EAAWnb,KAAKwL,IAAID,GACpB6P,EAAWpb,KAAKyL,IAAIF,GACpBH,EAAID,EAAW,GAAKgQ,EAAWhQ,EAAW,GAAKiQ,EAC/C/P,EAAIF,EAAW,GAAKgQ,EAAWhQ,EAAW,GAAKiQ,EAGrD,OAFAjQ,EAAW,GAAKC,EAChBD,EAAW,GAAKE,EACTF,CACT,CAmBO,SAASO,GAAMP,EAAYO,GAGhC,OAFAP,EAAW,IAAMO,EACjBP,EAAW,IAAMO,EACVP,CACT,CAOO,SAAS4M,GAAgBsD,EAAQC,GACtC,MAAMzP,EAAKwP,EAAO,GAAKC,EAAO,GACxBxP,EAAKuP,EAAO,GAAKC,EAAO,GAC9B,OAAOzP,EAAKA,EAAKC,EAAKA,CACxB,CAOO,SAASyP,GAASF,EAAQC,GAC/B,OAAOtb,KAAKma,KAAKpC,GAAgBsD,EAAQC,GAC3C,CAUO,SAASE,GAAyBrQ,EAAYkP,GACnD,OAAOtC,GAAgB5M,EAAYiP,GAAiBjP,EAAYkP,GAClE,CAgEO,SAASoB,GAAWtQ,EAAYsP,GACrC,OAAOM,GAAO5P,EAAY,WAAYsP,EACxC,CAWO,SAASxH,GAAM9H,EAAY+H,GAChC,GAAIA,EAAWG,WAAY,CACzB,MAAMC,EAAanD,GAAS+C,EAAWE,aACjCsI,EAAaC,GAAcxQ,EAAY+H,EAAYI,GACrDoI,IACFvQ,EAAW,IAAMuQ,EAAapI,EAEjC,CACD,OAAOnI,CACT,CAOO,SAASwQ,GAAcxQ,EAAY+H,EAAY0I,GACpD,MAAMzI,EAAmBD,EAAWE,YACpC,IAAIsI,EAAa,EAUjB,OARExI,EAAWG,aACVlI,EAAW,GAAKgI,EAAiB,IAAMhI,EAAW,GAAKgI,EAAiB,MAEzEyI,EAAoBA,GAAqBzL,GAASgD,GAClDuI,EAAa1b,KAAKuT,OACfpI,EAAW,GAAKgI,EAAiB,IAAMyI,IAGrCF,CACT,CChaO,MAAMG,GAAiB,UAWvB,SAASC,GAAYzR,EAAIM,EAAIoR,GAClCA,EAASA,GAAUF,GACnB,MAAMG,EAAOtD,GAAUrO,EAAG,IACpB4R,EAAOvD,GAAU/N,EAAG,IACpBuR,GAAeD,EAAOD,GAAQ,EAC9BG,EAAczD,GAAU/N,EAAG,GAAKN,EAAG,IAAM,EACzCjV,EACJ4K,KAAKyL,IAAIyQ,GAAelc,KAAKyL,IAAIyQ,GACjClc,KAAKyL,IAAI0Q,GACPnc,KAAKyL,IAAI0Q,GACTnc,KAAKwL,IAAIwQ,GACThc,KAAKwL,IAAIyQ,GACb,OAAO,EAAIF,EAAS/b,KAAKoc,MAAMpc,KAAKma,KAAK/kB,GAAI4K,KAAKma,KAAK,EAAI/kB,GAC7D,CAQA,SAASinB,GAAkB/O,EAAayO,GACtC,IAAI7mB,EAAS,EACb,IAAK,IAAIS,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAQS,EAAIuE,EAAK,IAAKvE,EACrDT,GAAU4mB,GAAYxO,EAAY3X,GAAI2X,EAAY3X,EAAI,GAAIomB,GAE5D,OAAO7mB,CACT,CA0FA,SAASonB,GAAgBhP,EAAayO,GACpC,IAAI7L,EAAO,EACX,MAAMlU,EAAMsR,EAAYpY,OACxB,IAAI4b,EAAKxD,EAAYtR,EAAM,GAAG,GAC1B+U,EAAKzD,EAAYtR,EAAM,GAAG,GAC9B,IAAK,IAAIrG,EAAI,EAAGA,EAAIqG,EAAKrG,IAAK,CAC5B,MAAMqb,EAAK1D,EAAY3X,GAAG,GACpBsb,EAAK3D,EAAY3X,GAAG,GAC1Bua,GACEwI,GAAU1H,EAAKF,IACd,EAAI9Q,KAAKyL,IAAIiN,GAAU3H,IAAO/Q,KAAKyL,IAAIiN,GAAUzH,KACpDH,EAAKE,EACLD,EAAKE,CACN,CACD,OAAQf,EAAO6L,EAASA,EAAU,CACpC,CAiFO,SAASjN,GAAOzE,EAAIkR,EAAUgB,EAASR,GAC5CA,EAASA,GAAUF,GACnB,MAAMG,EAAOtD,GAAUrO,EAAG,IACpBmS,EAAO9D,GAAUrO,EAAG,IACpBoS,EAAOlB,EAAWQ,EAClBW,EAAM1c,KAAK2c,KACf3c,KAAKyL,IAAIuQ,GAAQhc,KAAKwL,IAAIiR,GACxBzc,KAAKwL,IAAIwQ,GAAQhc,KAAKyL,IAAIgR,GAAQzc,KAAKwL,IAAI+Q,IAQ/C,MAAO,CAAC/D,GALNgE,EACAxc,KAAKoc,MACHpc,KAAKyL,IAAI8Q,GAAWvc,KAAKyL,IAAIgR,GAAQzc,KAAKwL,IAAIwQ,GAC9Chc,KAAKwL,IAAIiR,GAAQzc,KAAKyL,IAAIuQ,GAAQhc,KAAKyL,IAAIiR,KAEvBlE,GAAUkE,GACpC,CC3PA,MAAME,GAAS,CACbC,KAAM,EACNC,KAAM,EACNxZ,MAAO,EACPyZ,KAAM,GAMR,IAAIC,GAAQJ,GAAOC,KA0BZ,SAASC,MAAQG,GAClBD,GAAQJ,GAAOE,MAGnBI,QAAQJ,QAAQG,EAClB,CAKO,SAAS3Z,MAAS2Z,GACnBD,GAAQJ,GAAOtZ,OAGnB4Z,QAAQ5Z,SAAS2Z,EACnB,CCsCA,IAAIE,IAAwB,EAKrB,SAASC,GAAyBC,GAEvCF,UADyB5iB,IAAZ8iB,GAA+BA,EAE9C,CAQO,SAASC,GAAevG,EAAOC,GACpC,QAAezc,IAAXyc,EACF,IAAK,IAAIrhB,EAAI,EAAGuE,EAAK6c,EAAM7hB,OAAQS,EAAIuE,IAAMvE,EAC3CqhB,EAAOrhB,GAAKohB,EAAMphB,QAIpBqhB,EAASD,EAAMlf,QAEjB,OAAOmf,CACT,CAOO,SAASuG,GAAkBxG,EAAOC,GACvC,QAAezc,IAAXyc,GAAwBD,IAAUC,EAAQ,CAC5C,IAAK,IAAIrhB,EAAI,EAAGuE,EAAK6c,EAAM7hB,OAAQS,EAAIuE,IAAMvE,EAC3CqhB,EAAOrhB,GAAKohB,EAAMphB,GAEpBohB,EAAQC,CACT,CACD,OAAOD,CACT,CASO,SAASyG,GAActK,GAC5BuK,GAAQvK,EAAWiC,UAAWjC,GAC9BwK,GAAiBxK,EAAYA,EAAYoK,GAC3C,CAKO,SAASK,GAAeC,GAC7BA,EAAY1e,QAAQse,GACtB,CAWO,SAASrgB,GAAI0gB,GAClB,MAAiC,iBAAnBA,EACVC,GAA+B,GACL,GAAoB,IACpD,CAsBO,SAAS/I,GAAmB7B,EAAYxC,EAAYiG,EAAOD,GAEhE,IAAIqH,EACJ,MAAM5lB,GAFN+a,EAAa/V,GAAI+V,IAES8C,yBAC1B,GAAI7d,GAEF,GADA4lB,EAAkB5lB,EAAOuY,EAAYiG,GACjCD,GAASA,IAAUxD,EAAWkC,WAAY,CAC5C,MAAMF,EAAgBhC,EAAWmC,mBAC7BH,IACF6I,EACGA,EAAkB7I,EAAiBrB,GAAgB6C,GAEzD,MACI,CACL,MAAMsH,EAAY9K,EAAWkC,WAC7B,GAAkB,WAAb4I,IAA2BtH,GAAmB,WAATA,EACxCqH,EAAkBrN,MACb,CAIL,MAAMwG,EAAa+G,GACjB/K,EACA/V,GAAI,cAEN,GAAI+Z,IAAeqG,IAAmC,YAAdS,EAEtCD,EAAkBrN,EAAawC,EAAWmC,uBACrC,CACL,IAAI6I,EAAW,CACbvH,EAAM,GAAKjG,EAAa,EACxBiG,EAAM,GACNA,EAAM,GAAKjG,EAAa,EACxBiG,EAAM,GACNA,EAAM,GACNA,EAAM,GAAKjG,EAAa,EACxBiG,EAAM,GACNA,EAAM,GAAKjG,EAAa,GAE1BwN,EAAWhH,EAAWgH,EAAUA,EAAU,GAG1CH,GAFcjC,GAAYoC,EAASrmB,MAAM,EAAG,GAAIqmB,EAASrmB,MAAM,EAAG,IACnDikB,GAAYoC,EAASrmB,MAAM,EAAG,GAAIqmB,EAASrmB,MAAM,EAAG,KAC9B,CACtC,CACD,MAAMqd,EAAgBwB,EAClB7C,GAAgB6C,GAChBxD,EAAWmC,wBACO9a,IAAlB2a,IACF6I,GAAmB7I,EAEtB,CACF,CACD,OAAO6I,CACT,CASO,SAASI,GAAyBP,GACvCD,GAAeC,GACfA,EAAY1e,SAAQ,SAAUjB,GAC5B2f,EAAY1e,SAAQ,SAAUwY,GACxBzZ,IAAWyZ,GACbgG,GAAiBzf,EAAQyZ,EAAa4F,GAE9C,GACA,GACA,CAeO,SAASc,GACdC,EACAC,EACAC,EACAC,GAEAH,EAAanf,SAAQ,SAAUuf,GAC7BH,EAAapf,SAAQ,SAAUwf,GAC7BhB,GAAiBe,EAAaC,EAAaH,GAC3Cb,GAAiBgB,EAAaD,EAAaD,EACjD,GACA,GACA,CAeO,SAASG,GAAiBzL,EAAY0L,GAC3C,OAAK1L,EAGqB,iBAAfA,EACF/V,GAAI+V,GAEb,EALS/V,GAAIyhB,EAMf,CASO,SAASC,GAAuCC,GACrD,OAAA,SAOY/H,EAAOC,EAAQC,GACvB,MAAM/hB,EAAS6hB,EAAM7hB,OACrB+hB,OAA0B1c,IAAd0c,EAA0BA,EAAY,EAClDD,OAAoBzc,IAAXyc,EAAuBA,EAAS,IAAI5gB,MAAMlB,GACnD,IAAK,IAAIS,EAAI,EAAGA,EAAIT,EAAQS,GAAKshB,EAAW,CAC1C,MAAMN,EAAQmI,EAAe/H,EAAMlf,MAAMlC,EAAGA,EAAIshB,IAC1C8H,EAAcpI,EAAMzhB,OAC1B,IAAK,IAAImjB,EAAI,EAAG2G,EAAK/H,EAAWoB,EAAI2G,IAAM3G,EACxCrB,EAAOrhB,EAAI0iB,GAAKA,GAAK0G,EAAchI,EAAMphB,EAAI0iB,GAAK1B,EAAM0B,EAE3D,CACD,OAAOrB,CAET,CACJ,CAwBO,SAASiI,GAAwBhhB,EAAQyZ,EAAawH,EAASC,GACpE,MAAMC,EAAajiB,GAAIc,GACjBohB,EAAWliB,GAAIua,GACrBgG,GACE0B,EACAC,EACAR,GAAuCK,IAEzCxB,GACE2B,EACAD,EACAP,GAAuCM,GAE3C,CAoDO,SAASG,GAAWb,EAAaC,GACtC,GAAID,IAAgBC,EAClB,OAAO,EAET,MAAMa,EAAad,EAAYrJ,aAAesJ,EAAYtJ,WAC1D,GAAIqJ,EAAYtJ,YAAcuJ,EAAYvJ,UACxC,OAAOoK,EAGT,OADsBtB,GAA4BQ,EAAaC,KACtCpB,IAAkBiC,CAC7C,CAWO,SAAStB,GACduB,EACAC,GAIA,IAAIC,EAAgBC,GAFDH,EAAiBrK,UACZsK,EAAsBtK,WAK9C,OAHKuK,IACHA,EAAgBnC,IAEXmC,CACT,CAYO,SAASE,GAAa3hB,EAAQyZ,GAGnC,OAAOuG,GAFkB9gB,GAAIc,GACCd,GAAIua,GAEpC,CAgBO,SAAS3N,GAAUoB,EAAYlN,EAAQyZ,GAE5C,OADsBkI,GAAa3hB,EAAQyZ,EACpCgI,CAAcvU,OAAY5Q,EAAW4Q,EAAWjW,OACzD,CAcO,SAAS2qB,GAAgBtS,EAAQtP,EAAQyZ,EAAa9E,GAE3D,OAAOF,GAAenF,EADAqS,GAAa3hB,EAAQyZ,QACEnd,EAAWqY,EAC1D,CAyBA,IAAIkN,GAAiB,KASd,SAASC,GAAkB7M,GAChC4M,GAAiB3iB,GAAI+V,EACvB,CAeO,SAAS8M,KACd,OAAOF,EACT,CAmBO,SAASG,GAAiB9U,EAAYqU,GAC3C,OAAKM,GAGE/V,GAAUoB,EAAYqU,EAAkBM,IAFtC3U,CAGX,CASO,SAAS+U,GAAmB/U,EAAYgV,GAC7C,OAAKL,GAgBE/V,GAAUoB,EAAY2U,GAAgBK,IAdzChD,KACC7mB,GAAO6U,EAAY,CAAC,EAAG,KACxBA,EAAW,KAAO,KAClBA,EAAW,IAAM,KACjBA,EAAW,KAAO,IAClBA,EAAW,IAAM,KAEjBgS,IAAwB,EACxBL,GACE,2FAGG3R,EAGX,CASO,SAASiV,GAAa7S,EAAQiS,GACnC,OAAKM,GAGED,GAAgBtS,EAAQiS,EAAkBM,IAFxCvS,CAGX,CASO,SAAS8S,GAAe9S,EAAQ4S,GACrC,OAAKL,GAGED,GAAgBtS,EAAQuS,GAAgBK,GAFtC5S,CAGX,CAUO,SAAS+S,GAAiB5P,EAAY8O,GAC3C,IAAKM,GACH,OAAOpP,EAET,MAAM6P,EAAsBpjB,GAAIqiB,GAAkBnK,mBAC5CmL,EAAoBV,GAAezK,mBACzC,OAAOkL,GAAuBC,EACzB9P,EAAa6P,EAAuBC,EACrC9P,CACN,CAUO,SAAS+P,GAAmB/P,EAAYyP,GAC7C,IAAKL,GACH,OAAOpP,EAET,MAAMgQ,EAAoBvjB,GAAIgjB,GAAgB9K,mBACxCmL,EAAoBV,GAAezK,mBACzC,OAAOqL,GAAqBF,EACvB9P,EAAa8P,EAAqBE,EACnChQ,CACN,CAYO,SAASiQ,GAA8BvB,EAAYC,EAAUtV,GAClE,OAAO,SAAU6W,GACf,IAAIC,EAAanF,EACjB,GAAI0D,EAAW/L,WAAY,CACzB,MAAMyN,EAAe1B,EAAWhM,YAC1BwI,EAAoBzL,GAAS2Q,GAEnCpF,EAAaC,GADbiF,EAAQA,EAAM/oB,MAAM,GACcunB,EAAYxD,GAC1CF,IAEFkF,EAAM,GAAKA,EAAM,GAAKlF,EAAaE,GAErCgF,EAAM,GAAK/I,GAAM+I,EAAM,GAAIE,EAAa,GAAIA,EAAa,IACzDF,EAAM,GAAK/I,GAAM+I,EAAM,GAAIE,EAAa,GAAIA,EAAa,IACzDD,EAAc9W,EAAU6W,EAC9B,MACMC,EAAc9W,EAAU6W,GAM1B,OAJIlF,GAAc2D,EAAShM,aAEzBwN,EAAY,IAAMnF,EAAavL,GAASkP,EAASjM,cAE5CyN,CACX,CACA,CAOO,SAASE,KAGd5C,GAAyB6C,IACzB7C,GAAyB8C,IAGzB7C,GACE6C,GACAD,GACAlK,GACAI,GAEJ,CC/tBO,SAASgK,GACdrS,EACAC,EACA/Y,EACAgZ,EACAhF,EACA4D,GAEAA,EAAOA,GAAc,GACrB,IAAIhY,EAAI,EACR,IAAK,IAAI0iB,EAAIvJ,EAAQuJ,EAAItiB,EAAKsiB,GAAKtJ,EAAQ,CACzC,MAAM3D,EAAIyD,EAAgBwJ,GACpBhN,EAAIwD,EAAgBwJ,EAAI,GAC9B1K,EAAKhY,KAAOoU,EAAU,GAAKqB,EAAIrB,EAAU,GAAKsB,EAAItB,EAAU,GAC5D4D,EAAKhY,KAAOoU,EAAU,GAAKqB,EAAIrB,EAAU,GAAKsB,EAAItB,EAAU,EAC7D,CAID,OAHI4D,GAAQA,EAAKzY,QAAUS,IACzBgY,EAAKzY,OAASS,GAETgY,CACT,CAYO,SAASrC,GACduD,EACAC,EACA/Y,EACAgZ,EACAxD,EACA4V,EACAxT,GAEAA,EAAOA,GAAc,GACrB,MAAMnC,EAAMxL,KAAKwL,IAAID,GACfE,EAAMzL,KAAKyL,IAAIF,GACf6V,EAAUD,EAAO,GACjBE,EAAUF,EAAO,GACvB,IAAIxrB,EAAI,EACR,IAAK,IAAI0iB,EAAIvJ,EAAQuJ,EAAItiB,EAAKsiB,GAAKtJ,EAAQ,CACzC,MAAMiD,EAASnD,EAAgBwJ,GAAK+I,EAC9BnP,EAASpD,EAAgBwJ,EAAI,GAAKgJ,EACxC1T,EAAKhY,KAAOyrB,EAAUpP,EAASxG,EAAMyG,EAASxG,EAC9CkC,EAAKhY,KAAO0rB,EAAUrP,EAASvG,EAAMwG,EAASzG,EAC9C,IAAK,IAAI+M,EAAIF,EAAI,EAAGE,EAAIF,EAAItJ,IAAUwJ,EACpC5K,EAAKhY,KAAOkZ,EAAgB0J,EAE/B,CAID,OAHI5K,GAAQA,EAAKzY,QAAUS,IACzBgY,EAAKzY,OAASS,GAETgY,CACT,CAcO,SAASjC,GACdmD,EACAC,EACA/Y,EACAgZ,EACA7C,EACAC,EACAgV,EACAxT,GAEAA,EAAOA,GAAc,GACrB,MAAMyT,EAAUD,EAAO,GACjBE,EAAUF,EAAO,GACvB,IAAIxrB,EAAI,EACR,IAAK,IAAI0iB,EAAIvJ,EAAQuJ,EAAItiB,EAAKsiB,GAAKtJ,EAAQ,CACzC,MAAMiD,EAASnD,EAAgBwJ,GAAK+I,EAC9BnP,EAASpD,EAAgBwJ,EAAI,GAAKgJ,EACxC1T,EAAKhY,KAAOyrB,EAAUlV,EAAK8F,EAC3BrE,EAAKhY,KAAO0rB,EAAUlV,EAAK8F,EAC3B,IAAK,IAAIsG,EAAIF,EAAI,EAAGE,EAAIF,EAAItJ,IAAUwJ,EACpC5K,EAAKhY,KAAOkZ,EAAgB0J,EAE/B,CAID,OAHI5K,GAAQA,EAAKzY,QAAUS,IACzBgY,EAAKzY,OAASS,GAETgY,CACT,CAYO,SAAS/B,GACdiD,EACAC,EACA/Y,EACAgZ,EACAiD,EACAC,EACAtE,GAEAA,EAAOA,GAAc,GACrB,IAAIhY,EAAI,EACR,IAAK,IAAI0iB,EAAIvJ,EAAQuJ,EAAItiB,EAAKsiB,GAAKtJ,EAAQ,CACzCpB,EAAKhY,KAAOkZ,EAAgBwJ,GAAKrG,EACjCrE,EAAKhY,KAAOkZ,EAAgBwJ,EAAI,GAAKpG,EACrC,IAAK,IAAIsG,EAAIF,EAAI,EAAGE,EAAIF,EAAItJ,IAAUwJ,EACpC5K,EAAKhY,KAAOkZ,EAAgB0J,EAE/B,CAID,OAHI5K,GAAQA,EAAKzY,QAAUS,IACzBgY,EAAKzY,OAASS,GAETgY,CACT,CD0lBAoT,KE3sBA,MAAMO,GhBCG,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GgBoTzB,IAAAC,GAvSA,cAAuB/iB,EACrB,WAAA3K,GACEmF,QAMAjF,KAAKugB,Qd2IA,CAAC9F,IAAUA,KAAU,KAAW,KcrIrCza,KAAKytB,iBAAmB,EAMxBztB,KAAK0tB,yCAA2C,EAMhD1tB,KAAK2tB,2BAA6B,EAUlC3tB,KAAK4tB,4BAA8BtqB,GACjC,CAACuqB,EAAUC,EAAkB9X,KAC3B,IAAKA,EACH,OAAOhW,KAAK+tB,sBAAsBD,GAEpC,MAAM/Y,EAAQ/U,KAAK+U,QAEnB,OADAA,EAAM4J,eAAe3I,GACdjB,EAAMgZ,sBAAsBD,EAAiB,GAGzD,CASD,mBAAAE,CAAoBF,EAAkB9X,GACpC,OAAOhW,KAAK4tB,4BACV5tB,KAAK+H,cACL+lB,EACA9X,EAEH,CAOD,KAAAjB,GACE,OAAOxM,GACR,CAUD,cAAA0lB,CAAe5W,EAAGC,EAAG4W,EAAcC,GACjC,OAAO5lB,GACR,CAOD,UAAAwR,CAAW1C,EAAGC,GACZ,MAAMuV,EAAQ7sB,KAAKouB,gBAAgB,CAAC/W,EAAGC,IACvC,OAAOuV,EAAM,KAAOxV,GAAKwV,EAAM,KAAOvV,CACvC,CAUD,eAAA8W,CAAgBxL,EAAOsL,GAGrB,OAFAA,EAAeA,GAA8B,CAACG,IAAKA,KACnDruB,KAAKiuB,eAAerL,EAAM,GAAIA,EAAM,GAAIsL,EAAczT,KAC/CyT,CACR,CASD,oBAAAI,CAAqBlX,GACnB,OAAOpX,KAAK+Z,WAAW3C,EAAW,GAAIA,EAAW,GAClD,CAQD,aAAAmX,CAAc/U,GACZ,OAAOjR,GACR,CAQD,SAAA8W,CAAU7F,GACR,GAAIxZ,KAAKytB,iBAAmBztB,KAAK+H,cAAe,CAC9C,MAAMyR,EAASxZ,KAAKuuB,cAAcvuB,KAAKugB,UACnCiO,MAAMhV,EAAO,KAAOgV,MAAMhV,EAAO,MACnCmB,GAAoBnB,GAEtBxZ,KAAKytB,gBAAkBztB,KAAK+H,aAC7B,CACD,OAAOgW,GAAe/d,KAAKugB,QAAS/G,EACrC,CAUD,MAAAjC,CAAOC,EAAO4V,GACZ7kB,GACD,CAYD,KAAAoP,CAAMQ,EAAIC,EAAIgV,GACZ7kB,GACD,CAWD,QAAAkmB,CAAStT,GACP,OAAOnb,KAAK+tB,sBAAsB5S,EAAYA,EAC/C,CAUD,qBAAA4S,CAAsBD,GACpB,OAAOvlB,GACR,CAOD,OAAAmmB,GACE,OAAOnmB,GACR,CAWD,cAAAoW,CAAeC,GACbrW,GACD,CAQD,gBAAAomB,CAAiBnV,GACf,OAAOjR,GACR,CAUD,SAAAsP,CAAUoG,EAAQC,GAChB3V,GACD,CAiBD,SAAAyN,CAAU9L,EAAQyZ,GAEhB,MAAM0H,EAAauD,GAAc1kB,GAC3B0U,EACqB,eAAzByM,EAAWhK,WACP,SAAUwN,EAAeC,EAAgB9T,GACvC,MAAM+T,EAAc1D,EAAWhM,YACzB2P,EAAkB3D,EAAW9J,iBAC7B5J,EAAQ0E,GAAU2S,GAAmB3S,GAAU0S,GAmBrD,OAlBAE,GACE1B,GACAyB,EAAgB,GAChBA,EAAgB,GAChBrX,GACCA,EACD,EACA,EACA,GAEFwV,GACE0B,EACA,EACAA,EAAc1tB,OACd6Z,EACAuS,GACAuB,GAEKjD,GAAaR,EAAY1H,EAAzBkI,CACLgD,EACAC,EACA9T,EAEH,EACD6Q,GAAaR,EAAY1H,GAE/B,OADA3jB,KAAK2e,eAAeC,GACb5e,IACR,GC5CI,SAASkvB,GAAmBlU,GACjC,IAAImU,EAQJ,OAPc,GAAVnU,EACFmU,EAAS,KACU,GAAVnU,EACTmU,EAAS,MACU,GAAVnU,IACTmU,EAAS,QAEX,CACF,CAMO,SAASC,GAAmBD,GACjC,IAAInU,EAQJ,MAPc,MAAVmU,EACFnU,EAAS,EACU,OAAVmU,GAA6B,OAAVA,EAC5BnU,EAAS,EACU,QAAVmU,IACTnU,EAAS,GAEX,CACF,CAQO,SAASqU,GAAgBC,EAAgBtZ,EAAW4D,GACzD,MAAMkB,EAAkBwU,EAAeC,qBACvC,IAAKzU,EACH,OAAO,KAET,MAAME,EAASsU,EAAeE,YAC9B,OAAOrC,GACLrS,EACA,EACAA,EAAgB3Z,OAChB6Z,EACAhF,EACA4D,EAEJ,CAEA,IAAA6V,GA3UA,cAA6BC,GAC3B,WAAA5vB,GACEmF,QAMAjF,KAAKmvB,OAAS,KAMdnvB,KAAKgb,OAAS,EAMdhb,KAAK8a,eACN,CAOD,aAAAyT,CAAc/U,GACZ,OAAOqB,GACL7a,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OACLxB,EAEH,CAMD,cAAAmW,GACE,OAAOpnB,GACR,CAOD,kBAAAqnB,GACE,OAAO5vB,KAAK8a,gBAAgBhX,MAAM,EAAG9D,KAAKgb,OAC3C,CAKD,kBAAAuU,GACE,OAAOvvB,KAAK8a,eACb,CAOD,iBAAA+U,GACE,OAAO7vB,KAAK8a,gBAAgBhX,MAC1B9D,KAAK8a,gBAAgB3Z,OAASnB,KAAKgb,OAEtC,CAOD,SAAA8U,GACE,OAAO9vB,KAAKmvB,MACb,CAOD,qBAAApB,CAAsBD,GAOpB,GANI9tB,KAAK2tB,6BAA+B3tB,KAAK+H,gBAC3C/H,KAAK0tB,yCAA2C,EAChD1tB,KAAK2tB,2BAA6B3tB,KAAK+H,eAKvC+lB,EAAmB,GACgC,IAAlD9tB,KAAK0tB,0CACJI,GAAoB9tB,KAAK0tB,yCAE3B,OAAO1tB,KAGT,MAAM+vB,EACJ/vB,KAAKgwB,8BAA8BlC,GAErC,OADkCiC,EAAmBR,qBACvBpuB,OAASnB,KAAK8a,gBAAgB3Z,OACnD4uB,GAQT/vB,KAAK0tB,yCAA2CI,EACzC9tB,KACR,CAOD,6BAAAgwB,CAA8BlC,GAC5B,OAAO9tB,IACR,CAKD,SAAAwvB,GACE,OAAOxvB,KAAKgb,MACb,CAMD,kBAAAiV,CAAmBd,EAAQrU,GACzB9a,KAAKgb,OAASoU,GAAmBD,GACjCnvB,KAAKmvB,OAASA,EACdnvB,KAAK8a,gBAAkBA,CACxB,CAOD,cAAAoV,CAAe3W,EAAa4V,GAC1B5mB,GACD,CAQD,SAAA4nB,CAAUhB,EAAQ5V,EAAa6W,GAC7B,IAAIpV,EACJ,GAAImU,EACFnU,EAASoU,GAAmBD,OACvB,CACL,IAAK,IAAIvtB,EAAI,EAAGA,EAAIwuB,IAAWxuB,EAAG,CAChC,GAA2B,IAAvB2X,EAAYpY,OAGd,OAFAnB,KAAKmvB,OAAS,UACdnvB,KAAKgb,OAAS,GAGhBzB,EAA6CA,EAAY,EAC1D,CACDyB,EAASzB,EAAYpY,OACrBguB,EAASD,GAAmBlU,EAC7B,CACDhb,KAAKmvB,OAASA,EACdnvB,KAAKgb,OAASA,CACf,CAWD,cAAA2D,CAAeC,GACT5e,KAAK8a,kBACP8D,EAAY5e,KAAK8a,gBAAiB9a,KAAK8a,gBAAiB9a,KAAKgb,QAC7Dhb,KAAK6H,UAER,CASD,MAAA0P,CAAOC,EAAO4V,GACZ,MAAMtS,EAAkB9a,KAAKuvB,qBAC7B,GAAIzU,EAAiB,CACnB,MAAME,EAAShb,KAAKwvB,YACpBjY,GACEuD,EACA,EACAA,EAAgB3Z,OAChB6Z,EACAxD,EACA4V,EACAtS,GAEF9a,KAAK6H,SACN,CACF,CAWD,KAAA8P,CAAMQ,EAAIC,EAAIgV,QACD5mB,IAAP4R,IACFA,EAAKD,GAEFiV,IACHA,EAAS9Q,GAAUtc,KAAKqf,cAE1B,MAAMvE,EAAkB9a,KAAKuvB,qBAC7B,GAAIzU,EAAiB,CACnB,MAAME,EAAShb,KAAKwvB,YACpB7X,GACEmD,EACA,EACAA,EAAgB3Z,OAChB6Z,EACA7C,EACAC,EACAgV,EACAtS,GAEF9a,KAAK6H,SACN,CACF,CASD,SAAAgQ,CAAUoG,EAAQC,GAChB,MAAMpD,EAAkB9a,KAAKuvB,qBAC7B,GAAIzU,EAAiB,CACnB,MAAME,EAAShb,KAAKwvB,YACpB3X,GACEiD,EACA,EACAA,EAAgB3Z,OAChB6Z,EACAiD,EACAC,EACApD,GAEF9a,KAAK6H,SACN,CACF,GCjRH,SAASwoB,GACPvV,EACAwV,EACAC,EACAvV,EACA3D,EACAC,EACA4W,GAEA,MAAMnR,EAAKjC,EAAgBwV,GACrBtT,EAAKlC,EAAgBwV,EAAU,GAC/BxY,EAAKgD,EAAgByV,GAAWxT,EAChChF,EAAK+C,EAAgByV,EAAU,GAAKvT,EAC1C,IAAIjC,EACJ,GAAW,IAAPjD,GAAmB,IAAPC,EACdgD,EAASuV,MACJ,CACL,MAAMtkB,IAAMqL,EAAI0F,GAAMjF,GAAMR,EAAI0F,GAAMjF,IAAOD,EAAKA,EAAKC,EAAKA,GAC5D,GAAI/L,EAAI,EACN+O,EAASwV,MACJ,IAAIvkB,EAAI,EAAG,CAChB,IAAK,IAAIpK,EAAI,EAAGA,EAAIoZ,IAAUpZ,EAC5BssB,EAAatsB,GAAKkjB,GAChBhK,EAAgBwV,EAAU1uB,GAC1BkZ,EAAgByV,EAAU3uB,GAC1BoK,GAIJ,YADAkiB,EAAa/sB,OAAS6Z,EAE5B,CACMD,EAASuV,CACV,CACF,CACD,IAAK,IAAI1uB,EAAI,EAAGA,EAAIoZ,IAAUpZ,EAC5BssB,EAAatsB,GAAKkZ,EAAgBC,EAASnZ,GAE7CssB,EAAa/sB,OAAS6Z,CACxB,CAYO,SAASwV,GAAgB1V,EAAiBC,EAAQ/Y,EAAKgZ,EAAQU,GACpE,IAAIqB,EAAKjC,EAAgBC,GACrBiC,EAAKlC,EAAgBC,EAAS,GAClC,IAAKA,GAAUC,EAAQD,EAAS/Y,EAAK+Y,GAAUC,EAAQ,CACrD,MAAMiC,EAAKnC,EAAgBC,GACrBmC,EAAKpC,EAAgBC,EAAS,GAC9B0V,EAAeC,GAAU3T,EAAIC,EAAIC,EAAIC,GACvCuT,EAAe/U,IACjBA,EAAM+U,GAER1T,EAAKE,EACLD,EAAKE,CACN,CACD,OAAOxB,CACT,CAUO,SAASiV,GACd7V,EACAC,EACA6V,EACA5V,EACAU,GAEA,IAAK,IAAI9Z,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC7C,MAAMI,EAAM4uB,EAAKhvB,GACjB8Z,EAAM8U,GAAgB1V,EAAiBC,EAAQ/Y,EAAKgZ,EAAQU,GAC5DX,EAAS/Y,CACV,CACD,OAAO0Z,CACT,CAUO,SAASmV,GACd/V,EACAC,EACA+V,EACA9V,EACAU,GAEA,IAAK,IAAI9Z,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAMgvB,EAAOE,EAAMlvB,GACnB8Z,EAAMiV,GAAqB7V,EAAiBC,EAAQ6V,EAAM5V,EAAQU,GAClEX,EAAS6V,EAAKA,EAAKzvB,OAAS,EAC7B,CACD,OAAOua,CACT,CAgBO,SAASqV,GACdjW,EACAC,EACA/Y,EACAgZ,EACAgW,EACAC,EACA5Z,EACAC,EACA4W,EACAC,EACA+C,GAEA,GAAInW,GAAU/Y,EACZ,OAAOmsB,EAET,IAAIvsB,EAAGoiB,EACP,GAAiB,IAAbgN,EAAgB,CAQlB,GANAhN,EAAkB0M,GAChBrZ,EACAC,EACAwD,EAAgBC,GAChBD,EAAgBC,EAAS,IAEvBiJ,EAAkBmK,EAAoB,CACxC,IAAKvsB,EAAI,EAAGA,EAAIoZ,IAAUpZ,EACxBssB,EAAatsB,GAAKkZ,EAAgBC,EAASnZ,GAG7C,OADAssB,EAAa/sB,OAAS6Z,EACfgJ,CACR,CACD,OAAOmK,CACR,CACD+C,EAAWA,GAAsB,CAAC7C,IAAKA,KACvC,IAAIprB,EAAQ8X,EAASC,EACrB,KAAO/X,EAAQjB,GAWb,GAVAquB,GACEvV,EACA7X,EAAQ+X,EACR/X,EACA+X,EACA3D,EACAC,EACA4Z,GAEFlN,EAAkB0M,GAAUrZ,EAAGC,EAAG4Z,EAAS,GAAIA,EAAS,IACpDlN,EAAkBmK,EAAoB,CAExC,IADAA,EAAqBnK,EAChBpiB,EAAI,EAAGA,EAAIoZ,IAAUpZ,EACxBssB,EAAatsB,GAAKsvB,EAAStvB,GAE7BssB,EAAa/sB,OAAS6Z,EACtB/X,GAAS+X,CACf,MAWM/X,GACE+X,EACA/O,KAAKyP,KACDzP,KAAKma,KAAKpC,GAAmB/X,KAAKma,KAAK+H,IACvC6C,EACA,EACF,GAIR,GAAIC,IAEFZ,GACEvV,EACA9Y,EAAMgZ,EACND,EACAC,EACA3D,EACAC,EACA4Z,GAEFlN,EAAkB0M,GAAUrZ,EAAGC,EAAG4Z,EAAS,GAAIA,EAAS,IACpDlN,EAAkBmK,GAAoB,CAExC,IADAA,EAAqBnK,EAChBpiB,EAAI,EAAGA,EAAIoZ,IAAUpZ,EACxBssB,EAAatsB,GAAKsvB,EAAStvB,GAE7BssB,EAAa/sB,OAAS6Z,CACvB,CAEH,OAAOmT,CACT,CAgBO,SAASgD,GACdrW,EACAC,EACA6V,EACA5V,EACAgW,EACAC,EACA5Z,EACAC,EACA4W,EACAC,EACA+C,GAEAA,EAAWA,GAAsB,CAAC7C,IAAKA,KACvC,IAAK,IAAIzsB,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC7C,MAAMI,EAAM4uB,EAAKhvB,GACjBusB,EAAqB4C,GACnBjW,EACAC,EACA/Y,EACAgZ,EACAgW,EACAC,EACA5Z,EACAC,EACA4W,EACAC,EACA+C,GAEFnW,EAAS/Y,CACV,CACD,OAAOmsB,CACT,CAgBO,SAASiD,GACdtW,EACAC,EACA+V,EACA9V,EACAgW,EACAC,EACA5Z,EACAC,EACA4W,EACAC,EACA+C,GAEAA,EAAWA,GAAsB,CAAC7C,IAAKA,KACvC,IAAK,IAAIzsB,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAMgvB,EAAOE,EAAMlvB,GACnBusB,EAAqBgD,GACnBrW,EACAC,EACA6V,EACA5V,EACAgW,EACAC,EACA5Z,EACAC,EACA4W,EACAC,EACA+C,GAEFnW,EAAS6V,EAAKA,EAAKzvB,OAAS,EAC7B,CACD,OAAOgtB,CACT,CCpUO,SAASkD,GAAkBvW,EAAiBC,EAAQ3D,EAAY4D,GACrE,IAAK,IAAIpZ,EAAI,EAAGuE,EAAKiR,EAAWjW,OAAQS,EAAIuE,IAAMvE,EAChDkZ,EAAgBC,KAAY3D,EAAWxV,GAEzC,OAAOmZ,CACT,CASO,SAASuW,GACdxW,EACAC,EACAxB,EACAyB,GAEA,IAAK,IAAIpZ,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAQS,EAAIuE,IAAMvE,EAAG,CACpD,MAAMwV,EAAamC,EAAY3X,GAC/B,IAAK,IAAI0iB,EAAI,EAAGA,EAAItJ,IAAUsJ,EAC5BxJ,EAAgBC,KAAY3D,EAAWkN,EAE1C,CACD,OAAOvJ,CACT,CAUO,SAASwW,GACdzW,EACAC,EACAyW,EACAxW,EACA4V,GAEAA,EAAOA,GAAc,GACrB,IAAIhvB,EAAI,EACR,IAAK,IAAI0iB,EAAI,EAAG2G,EAAKuG,EAAarwB,OAAQmjB,EAAI2G,IAAM3G,EAAG,CACrD,MAAMtiB,EAAMsvB,GACVxW,EACAC,EACAyW,EAAalN,GACbtJ,GAEF4V,EAAKhvB,KAAOI,EACZ+Y,EAAS/Y,CACV,CAED,OADA4uB,EAAKzvB,OAASS,EACPgvB,CACT,CAUO,SAASa,GACd3W,EACAC,EACA2W,EACA1W,EACA8V,GAEAA,EAAQA,GAAgB,GACxB,IAAIlvB,EAAI,EACR,IAAK,IAAI0iB,EAAI,EAAG2G,EAAKyG,EAAcvwB,OAAQmjB,EAAI2G,IAAM3G,EAAG,CACtD,MAAMsM,EAAOW,GACXzW,EACAC,EACA2W,EAAcpN,GACdtJ,EACA8V,EAAMlvB,IAEY,IAAhBgvB,EAAKzvB,SACPyvB,EAAK,GAAK7V,GAEZ+V,EAAMlvB,KAAOgvB,EACb7V,EAAS6V,EAAKA,EAAKzvB,OAAS,EAC7B,CAED,OADA2vB,EAAM3vB,OAASS,EACRkvB,CACT,CCdO,SAASa,GACd7W,EACAC,EACA/Y,EACAgZ,EACA8S,EACA8D,EACAC,GAEA,MAAMlwB,GAAKK,EAAM+Y,GAAUC,EAC3B,GAAIrZ,EAAI,EAAG,CACT,KAAOoZ,EAAS/Y,EAAK+Y,GAAUC,EAC7B4W,EAA0BC,KAAsB/W,EAAgBC,GAChE6W,EAA0BC,KACxB/W,EAAgBC,EAAS,GAE7B,OAAO8W,CACR,CAED,MAAMC,EAAU,IAAIzvB,MAAMV,GAC1BmwB,EAAQ,GAAK,EACbA,EAAQnwB,EAAI,GAAK,EAEjB,MAAMowB,EAAQ,CAAChX,EAAQ/Y,EAAMgZ,GAC7B,IAAI/X,EAAQ,EACZ,KAAO8uB,EAAM5wB,OAAS,GAAG,CACvB,MAAM6wB,EAAOD,EAAM7mB,MACb+mB,EAAQF,EAAM7mB,MACpB,IAAIgnB,EAAqB,EACzB,MAAMnV,EAAKjC,EAAgBmX,GACrBjV,EAAKlC,EAAgBmX,EAAQ,GAC7BhV,EAAKnC,EAAgBkX,GACrB9U,EAAKpC,EAAgBkX,EAAO,GAClC,IAAK,IAAIpwB,EAAIqwB,EAAQjX,EAAQpZ,EAAIowB,EAAMpwB,GAAKoZ,EAAQ,CAClD,MAEMgJ,EAAkBD,GAFdjJ,EAAgBlZ,GAChBkZ,EAAgBlZ,EAAI,GACuBmb,EAAIC,EAAIC,EAAIC,GAC7D8G,EAAkBkO,IACpBjvB,EAAQrB,EACRswB,EAAqBlO,EAExB,CACGkO,EAAqBpE,IACvBgE,GAAS7uB,EAAQ8X,GAAUC,GAAU,EACjCiX,EAAQjX,EAAS/X,GACnB8uB,EAAMpsB,KAAKssB,EAAOhvB,GAEhBA,EAAQ+X,EAASgX,GACnBD,EAAMpsB,KAAK1C,EAAO+uB,GAGvB,CACD,IAAK,IAAIpwB,EAAI,EAAGA,EAAID,IAAKC,EACnBkwB,EAAQlwB,KACVgwB,EAA0BC,KACxB/W,EAAgBC,EAASnZ,EAAIoZ,GAC/B4W,EAA0BC,KACxB/W,EAAgBC,EAASnZ,EAAIoZ,EAAS,IAG5C,OAAO6W,CACT,CAcO,SAASM,GACdrX,EACAC,EACA6V,EACA5V,EACA8S,EACA8D,EACAC,EACAO,GAEA,IAAK,IAAIxwB,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC7C,MAAMI,EAAM4uB,EAAKhvB,GACjBiwB,EAAmBF,GACjB7W,EACAC,EACA/Y,EACAgZ,EACA8S,EACA8D,EACAC,GAEFO,EAAezsB,KAAKksB,GACpB9W,EAAS/Y,CACV,CACD,OAAO6vB,CACT,CAuDO,SAASQ,GACdvX,EACAC,EACA/Y,EACAgZ,EACA8S,EACA8D,EACAC,GAEA,GAAI7vB,GAAO+Y,EAASC,EAAQ,CAE1B,KAAOD,EAAS/Y,EAAK+Y,GAAUC,EAC7B4W,EAA0BC,KAAsB/W,EAAgBC,GAChE6W,EAA0BC,KACxB/W,EAAgBC,EAAS,GAE7B,OAAO8W,CACR,CACD,IAAI9U,EAAKjC,EAAgBC,GACrBiC,EAAKlC,EAAgBC,EAAS,GAElC6W,EAA0BC,KAAsB9U,EAChD6U,EAA0BC,KAAsB7U,EAChD,IAAIC,EAAKF,EACLG,EAAKF,EACT,IAAKjC,GAAUC,EAAQD,EAAS/Y,EAAK+Y,GAAUC,EAC7CiC,EAAKnC,EAAgBC,GACrBmC,EAAKpC,EAAgBC,EAAS,GAC1BiJ,GAAgBjH,EAAIC,EAAIC,EAAIC,GAAM4Q,IAEpC8D,EAA0BC,KAAsB5U,EAChD2U,EAA0BC,KAAsB3U,EAChDH,EAAKE,EACLD,EAAKE,GAQT,OALID,GAAMF,GAAMG,GAAMF,IAEpB4U,EAA0BC,KAAsB5U,EAChD2U,EAA0BC,KAAsB3U,GAE3C2U,CACT,CAOO,SAASS,GAAKjuB,EAAO8W,GAC1B,OAAOA,EAAYlP,KAAKiZ,MAAM7gB,EAAQ8W,EACxC,CAqBO,SAASoX,GACdzX,EACAC,EACA/Y,EACAgZ,EACAG,EACAyW,EACAC,GAGA,GAAI9W,GAAU/Y,EACZ,OAAO6vB,EAGT,IAQI5U,EAAIC,EARJH,EAAKuV,GAAKxX,EAAgBC,GAASI,GACnC6B,EAAKsV,GAAKxX,EAAgBC,EAAS,GAAII,GAC3CJ,GAAUC,EAEV4W,EAA0BC,KAAsB9U,EAChD6U,EAA0BC,KAAsB7U,EAIhD,GAIE,GAHAC,EAAKqV,GAAKxX,EAAgBC,GAASI,GACnC+B,EAAKoV,GAAKxX,EAAgBC,EAAS,GAAII,IACvCJ,GAAUC,IACIhZ,EAOZ,OAFA4vB,EAA0BC,KAAsB5U,EAChD2U,EAA0BC,KAAsB3U,EACzC2U,QAEF5U,GAAMF,GAAMG,GAAMF,GAC3B,KAAOjC,EAAS/Y,GAAK,CAEnB,MAAMmb,EAAKmV,GAAKxX,EAAgBC,GAASI,GACnCiC,EAAKkV,GAAKxX,EAAgBC,EAAS,GAAII,GAG7C,GAFAJ,GAAUC,EAENmC,GAAMF,GAAMG,GAAMF,EACpB,SAGF,MAAMjF,EAAMgF,EAAKF,EACX7E,EAAMgF,EAAKF,EAEX3E,EAAM8E,EAAKJ,EACXzE,EAAM8E,EAAKJ,EAKf/E,EAAMK,GAAOJ,EAAMG,IACjBJ,EAAM,GAAKI,EAAMJ,GAAQA,GAAOI,GAAQJ,EAAM,GAAKI,EAAMJ,KACzDC,EAAM,GAAKI,EAAMJ,GAAQA,GAAOI,GAAQJ,EAAM,GAAKI,EAAMJ,IAG3D+E,EAAKE,EACLD,EAAKE,IAMPwU,EAA0BC,KAAsB5U,EAChD2U,EAA0BC,KAAsB3U,EAChDH,EAAKE,EACLD,EAAKE,EACLD,EAAKE,EACLD,EAAKE,EACN,CAID,OAFAwU,EAA0BC,KAAsB5U,EAChD2U,EAA0BC,KAAsB3U,EACzC2U,CACT,CAcO,SAASW,GACd1X,EACAC,EACA6V,EACA5V,EACAG,EACAyW,EACAC,EACAO,GAEA,IAAK,IAAIxwB,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC7C,MAAMI,EAAM4uB,EAAKhvB,GACjBiwB,EAAmBU,GACjBzX,EACAC,EACA/Y,EACAgZ,EACAG,EACAyW,EACAC,GAEFO,EAAezsB,KAAKksB,GACpB9W,EAAS/Y,CACV,CACD,OAAO6vB,CACT,CAcO,SAASY,GACd3X,EACAC,EACA+V,EACA9V,EACAG,EACAyW,EACAC,EACAa,GAEA,IAAK,IAAI9wB,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAMgvB,EAAOE,EAAMlvB,GAEbwwB,EAAiB,GACvBP,EAAmBW,GACjB1X,EACAC,EACA6V,EACA5V,EACAG,EACAyW,EACAC,EACAO,GAEFM,EAAgB/sB,KAAKysB,GACrBrX,EAAS6V,EAAKA,EAAKzvB,OAAS,EAC7B,CACD,OAAO0wB,CACT,CCjdO,SAASc,GACd7X,EACAC,EACA/Y,EACAgZ,EACAzB,GAEAA,OAA8B/S,IAAhB+S,EAA4BA,EAAc,GACxD,IAAI3X,EAAI,EACR,IAAK,IAAI0iB,EAAIvJ,EAAQuJ,EAAItiB,EAAKsiB,GAAKtJ,EACjCzB,EAAY3X,KAAOkZ,EAAgBhX,MAAMwgB,EAAGA,EAAItJ,GAGlD,OADAzB,EAAYpY,OAASS,EACd2X,CACT,CAUO,SAASqZ,GACd9X,EACAC,EACA6V,EACA5V,EACAwW,GAEAA,OAAgChrB,IAAjBgrB,EAA6BA,EAAe,GAC3D,IAAI5vB,EAAI,EACR,IAAK,IAAI0iB,EAAI,EAAG2G,EAAK2F,EAAKzvB,OAAQmjB,EAAI2G,IAAM3G,EAAG,CAC7C,MAAMtiB,EAAM4uB,EAAKtM,GACjBkN,EAAa5vB,KAAO+wB,GAClB7X,EACAC,EACA/Y,EACAgZ,EACAwW,EAAa5vB,IAEfmZ,EAAS/Y,CACV,CAED,OADAwvB,EAAarwB,OAASS,EACf4vB,CACT,CAWO,SAASqB,GACd/X,EACAC,EACA+V,EACA9V,EACA0W,GAEAA,OAAkClrB,IAAlBkrB,EAA8BA,EAAgB,GAC9D,IAAI9vB,EAAI,EACR,IAAK,IAAI0iB,EAAI,EAAG2G,EAAK6F,EAAM3vB,OAAQmjB,EAAI2G,IAAM3G,EAAG,CAC9C,MAAMsM,EAAOE,EAAMxM,GACnBoN,EAAc9vB,KACI,IAAhBgvB,EAAKzvB,QAAgByvB,EAAK,KAAO7V,EAC7B,GACA6X,GACE9X,EACAC,EACA6V,EACA5V,EACA0W,EAAc9vB,IAEtBmZ,EAAS6V,EAAKA,EAAKzvB,OAAS,EAC7B,CAED,OADAuwB,EAAcvwB,OAASS,EAChB8vB,CACT,CCnFO,SAASoB,GAAWhY,EAAiBC,EAAQ/Y,EAAKgZ,GACvD,IAAI+X,EAAY,EACZhW,EAAKjC,EAAgB9Y,EAAMgZ,GAC3BgC,EAAKlC,EAAgB9Y,EAAMgZ,EAAS,GACxC,KAAOD,EAAS/Y,EAAK+Y,GAAUC,EAAQ,CACrC,MAAMiC,EAAKnC,EAAgBC,GACrBmC,EAAKpC,EAAgBC,EAAS,GACpCgY,GAAa/V,EAAKC,EAAKF,EAAKG,EAC5BH,EAAKE,EACLD,EAAKE,CACN,CACD,OAAO6V,EAAY,CACrB,CASO,SAASC,GAAYlY,EAAiBC,EAAQ6V,EAAM5V,GACzD,IAAImB,EAAO,EACX,IAAK,IAAIva,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC7C,MAAMI,EAAM4uB,EAAKhvB,GACjBua,GAAQ2W,GAAWhY,EAAiBC,EAAQ/Y,EAAKgZ,GACjDD,EAAS/Y,CACV,CACD,OAAOma,CACT,CASO,SAAS8W,GAAanY,EAAiBC,EAAQ+V,EAAO9V,GAC3D,IAAImB,EAAO,EACX,IAAK,IAAIva,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAMgvB,EAAOE,EAAMlvB,GACnBua,GAAQ6W,GAAYlY,EAAiBC,EAAQ6V,EAAM5V,GACnDD,EAAS6V,EAAKA,EAAKzvB,OAAS,EAC7B,CACD,OAAOgb,CACT,CCvCA,MAAM+W,WAAmBC,GAMvB,WAAArzB,CAAYyZ,EAAa4V,GACvBlqB,QAMAjF,KAAKozB,WAAa,EAMlBpzB,KAAKqzB,mBAAqB,OAEX7sB,IAAX2oB,GAAyB9sB,MAAMC,QAAQiX,EAAY,IAMrDvZ,KAAKkwB,eACX,EAGQf,GATFnvB,KAAKiwB,mBACHd,EACR,EAUG,CAOD,KAAApa,GACE,OAAO,IAAIme,GAAWlzB,KAAK8a,gBAAgBhX,QAAS9D,KAAKmvB,OAC1D,CASD,cAAAlB,CAAe5W,EAAGC,EAAG4W,EAAcC,GACjC,OAAIA,EAAqBtU,GAAyB7Z,KAAKqf,YAAahI,EAAGC,GAC9D6W,GAELnuB,KAAKqzB,mBAAqBrzB,KAAK+H,gBACjC/H,KAAKozB,UAAYnnB,KAAKma,KACpBoK,GACExwB,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OACL,IAGJhb,KAAKqzB,kBAAoBrzB,KAAK+H,eAEzBgpB,GACL/wB,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OACLhb,KAAKozB,WACL,EACA/b,EACAC,EACA4W,EACAC,GAEH,CAOD,OAAAjS,GACE,OAAOoX,GACLtzB,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OAER,CAOD,cAAA2U,GACE,OAAOgD,GACL3yB,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OAER,CAOD,6BAAAgV,CAA8BlC,GAE5B,MAAM8D,EAA4B,GAUlC,OATAA,EAA0BzwB,OAASwwB,GACjC3xB,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OACL8S,EACA8D,EACA,GAEK,IAAIsB,GAAWtB,EAA2B,KAClD,CAOD,OAAAlD,GACE,MAAO,YACR,CAQD,gBAAAC,CAAiBnV,GACf,OAAO,CACR,CAQD,cAAA0W,CAAe3W,EAAa4V,GAC1BnvB,KAAKmwB,UAAUhB,EAAQ5V,EAAa,GAC/BvZ,KAAK8a,kBACR9a,KAAK8a,gBAAkB,IAEzB9a,KAAK8a,gBAAgB3Z,OAASmwB,GAC5BtxB,KAAK8a,gBACL,EACAvB,EACAvZ,KAAKgb,QAEPhb,KAAK6H,SACN,EAGH,IAAA0rB,GAAeL,GC9Kf,MAAMM,WAAcL,GAKlB,WAAArzB,CAAYyZ,EAAa4V,GACvBlqB,QACAjF,KAAKkwB,eAAe3W,EAAa4V,EAClC,CAOD,KAAApa,GACE,MAAM6N,EAAQ,IAAI4Q,GAAMxzB,KAAK8a,gBAAgBhX,QAAS9D,KAAKmvB,QAE3D,OADAvM,EAAM3Y,gBAAgBjK,MACf4iB,CACR,CASD,cAAAqL,CAAe5W,EAAGC,EAAG4W,EAAcC,GACjC,MAAMrT,EAAkB9a,KAAK8a,gBACvBkJ,EAAkB0M,GACtBrZ,EACAC,EACAwD,EAAgB,GAChBA,EAAgB,IAElB,GAAIkJ,EAAkBmK,EAAoB,CACxC,MAAMnT,EAAShb,KAAKgb,OACpB,IAAK,IAAIpZ,EAAI,EAAGA,EAAIoZ,IAAUpZ,EAC5BssB,EAAatsB,GAAKkZ,EAAgBlZ,GAGpC,OADAssB,EAAa/sB,OAAS6Z,EACfgJ,CACR,CACD,OAAOmK,CACR,CAOD,cAAAwB,GACE,OAAO3vB,KAAK8a,gBAAgBhX,OAC7B,CAOD,aAAAyqB,CAAc/U,GACZ,OAAOoB,GAA6B5a,KAAK8a,gBAAiBtB,EAC3D,CAOD,OAAAkV,GACE,MAAO,OACR,CAQD,gBAAAC,CAAiBnV,GACf,OAAOO,GAAWP,EAAQxZ,KAAK8a,gBAAgB,GAAI9a,KAAK8a,gBAAgB,GACzE,CAOD,cAAAoV,CAAe3W,EAAa4V,GAC1BnvB,KAAKmwB,UAAUhB,EAAQ5V,EAAa,GAC/BvZ,KAAK8a,kBACR9a,KAAK8a,gBAAkB,IAEzB9a,KAAK8a,gBAAgB3Z,OAASkwB,GAC5BrxB,KAAK8a,gBACL,EACAvB,EACAvZ,KAAKgb,QAEPhb,KAAK6H,SACN,EAGH,IAAA4rB,GAAeD,GCzGR,SAASE,GACd5Y,EACAC,EACA/Y,EACAgZ,EACAxB,GAmBA,OAjBgBmC,GACdnC,GAKA,SAAUpC,GACR,OAAQuc,GACN7Y,EACAC,EACA/Y,EACAgZ,EACA5D,EAAW,GACXA,EAAW,GAEd,GAGL,CAWO,SAASuc,GACd7Y,EACAC,EACA/Y,EACAgZ,EACA3D,EACAC,GASA,IAAIsc,EAAK,EACL7W,EAAKjC,EAAgB9Y,EAAMgZ,GAC3BgC,EAAKlC,EAAgB9Y,EAAMgZ,EAAS,GACxC,KAAOD,EAAS/Y,EAAK+Y,GAAUC,EAAQ,CACrC,MAAMiC,EAAKnC,EAAgBC,GACrBmC,EAAKpC,EAAgBC,EAAS,GAChCiC,GAAM1F,EACJ4F,EAAK5F,IAAM2F,EAAKF,IAAOzF,EAAI0F,IAAO3F,EAAI0F,IAAOG,EAAKF,GAAM,GAC1D4W,IAEO1W,GAAM5F,IAAM2F,EAAKF,IAAOzF,EAAI0F,IAAO3F,EAAI0F,IAAOG,EAAKF,GAAM,GAClE4W,IAEF7W,EAAKE,EACLD,EAAKE,CACN,CACD,OAAc,IAAP0W,CACT,CAWO,SAASC,GACd/Y,EACAC,EACA6V,EACA5V,EACA3D,EACAC,GAEA,GAAoB,IAAhBsZ,EAAKzvB,OACP,OAAO,EAET,IAAKwyB,GAAqB7Y,EAAiBC,EAAQ6V,EAAK,GAAI5V,EAAQ3D,EAAGC,GACrE,OAAO,EAET,IAAK,IAAI1V,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAC1C,GACE+xB,GAAqB7Y,EAAiB8V,EAAKhvB,EAAI,GAAIgvB,EAAKhvB,GAAIoZ,EAAQ3D,EAAGC,GAEvE,OAAO,EAGX,OAAO,CACT,CAWO,SAASwc,GACdhZ,EACAC,EACA+V,EACA9V,EACA3D,EACAC,GAEA,GAAqB,IAAjBwZ,EAAM3vB,OACR,OAAO,EAET,IAAK,IAAIS,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAMgvB,EAAOE,EAAMlvB,GACnB,GAAIiyB,GAAsB/Y,EAAiBC,EAAQ6V,EAAM5V,EAAQ3D,EAAGC,GAClE,OAAO,EAETyD,EAAS6V,EAAKA,EAAKzvB,OAAS,EAC7B,CACD,OAAO,CACT,CC7HO,SAAS4yB,GACdjZ,EACAC,EACA6V,EACA5V,EACAgZ,EACAC,EACAra,GAEA,IAAIhY,EAAGuE,EAAIkR,EAAG0F,EAAIE,EAAID,EAAIE,EAC1B,MAAM5F,EAAI0c,EAAYC,EAAoB,GAEpCC,EAAgB,GAEtB,IAAK,IAAI9P,EAAI,EAAG+P,EAAKvD,EAAKzvB,OAAQijB,EAAI+P,IAAM/P,EAAG,CAC7C,MAAMpiB,EAAM4uB,EAAKxM,GAGjB,IAFArH,EAAKjC,EAAgB9Y,EAAMgZ,GAC3BgC,EAAKlC,EAAgB9Y,EAAMgZ,EAAS,GAC/BpZ,EAAImZ,EAAQnZ,EAAII,EAAKJ,GAAKoZ,EAC7BiC,EAAKnC,EAAgBlZ,GACrBsb,EAAKpC,EAAgBlZ,EAAI,IACpB0V,GAAK0F,GAAME,GAAM5F,GAAO0F,GAAM1F,GAAKA,GAAK4F,KAC3C7F,GAAMC,EAAI0F,IAAOE,EAAKF,IAAQC,EAAKF,GAAMA,EACzCmX,EAAcvuB,KAAK0R,IAErB0F,EAAKE,EACLD,EAAKE,CAER,CAGD,IAAIkX,EAAS/F,IACTgG,GAAoB5Z,IAGxB,IAFAyZ,EAAcI,KAAKtzB,GACnB+b,EAAKmX,EAAc,GACdtyB,EAAI,EAAGuE,EAAK+tB,EAAc/yB,OAAQS,EAAIuE,IAAMvE,EAAG,CAClDqb,EAAKiX,EAActyB,GACnB,MAAM2yB,EAAgBtoB,KAAKmP,IAAI6B,EAAKF,GAChCwX,EAAgBF,IAClBhd,GAAK0F,EAAKE,GAAM,EACZ4W,GAAsB/Y,EAAiBC,EAAQ6V,EAAM5V,EAAQ3D,EAAGC,KAClE8c,EAAS/c,EACTgd,EAAmBE,IAGvBxX,EAAKE,CACN,CAMD,OALIuR,MAAM4F,KAGRA,EAASJ,EAAYC,IAEnBra,GACFA,EAAKjU,KAAKyuB,EAAQ9c,EAAG+c,GACdza,GAEF,CAACwa,EAAQ9c,EAAG+c,EACrB,CAWO,SAASG,GACd1Z,EACAC,EACA+V,EACA9V,EACAgZ,GAGA,IAAIS,EAAiB,GACrB,IAAK,IAAI7yB,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAMgvB,EAAOE,EAAMlvB,GACnB6yB,EAAiBV,GACfjZ,EACAC,EACA6V,EACA5V,EACAgZ,EACA,EAAIpyB,EACJ6yB,GAEF1Z,EAAS6V,EAAKA,EAAKzvB,OAAS,EAC7B,CACD,OAAOszB,CACT,CC7FO,SAAStpB,GAAQ2P,EAAiBC,EAAQ/Y,EAAKgZ,EAAQY,GAC5D,IAAI8Y,EAEJ,IADA3Z,GAAUC,EACHD,EAAS/Y,EAAK+Y,GAAUC,EAK7B,GAJA0Z,EAAM9Y,EACJd,EAAgBhX,MAAMiX,EAASC,EAAQD,GACvCD,EAAgBhX,MAAMiX,EAAQA,EAASC,IAErC0Z,EACF,OAAOA,EAGX,OAAO,CACT,CCTO,SAASC,GACd7Z,EACAC,EACA/Y,EACAgZ,EACAxB,GAEA,MAAMob,EAAoB3Z,G1BwKnB,CAACR,IAAUA,KAAU,KAAW,K0BtKrCK,EACAC,EACA/Y,EACAgZ,GAEF,QAAK8C,GAAWtE,EAAQob,OAGpB5a,GAAeR,EAAQob,KAGvBA,EAAkB,IAAMpb,EAAO,IAAMob,EAAkB,IAAMpb,EAAO,KAGpEob,EAAkB,IAAMpb,EAAO,IAAMob,EAAkB,IAAMpb,EAAO,IAGjEqb,GACL/Z,EACAC,EACA/Y,EACAgZ,GAOA,SAAU8Z,EAAQC,GAChB,OAAO5W,GAAkB3E,EAAQsb,EAAQC,EAC1C,MAEL,CAUO,SAASC,GACdla,EACAC,EACA6V,EACA5V,EACAxB,GAEA,IAAK,IAAI5X,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC7C,GACE+yB,GAAqB7Z,EAAiBC,EAAQ6V,EAAKhvB,GAAIoZ,EAAQxB,GAE/D,OAAO,EAETuB,EAAS6V,EAAKhvB,EACf,CACD,OAAO,CACT,CAUO,SAASqzB,GACdna,EACAC,EACA/Y,EACAgZ,EACAxB,GAEA,QAAImb,GAAqB7Z,EAAiBC,EAAQ/Y,EAAKgZ,EAAQxB,OAI7Dma,GACE7Y,EACAC,EACA/Y,EACAgZ,EACAxB,EAAO,GACPA,EAAO,QAMTma,GACE7Y,EACAC,EACA/Y,EACAgZ,EACAxB,EAAO,GACPA,EAAO,QAMTma,GACE7Y,EACAC,EACA/Y,EACAgZ,EACAxB,EAAO,GACPA,EAAO,OAMTma,GACE7Y,EACAC,EACA/Y,EACAgZ,EACAxB,EAAO,GACPA,EAAO,MAMb,CAUO,SAAS0b,GACdpa,EACAC,EACA6V,EACA5V,EACAxB,GAEA,IAAKyb,GAAqBna,EAAiBC,EAAQ6V,EAAK,GAAI5V,EAAQxB,GAClE,OAAO,EAET,GAAoB,IAAhBoX,EAAKzvB,OACP,OAAO,EAET,IAAK,IAAIS,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAC1C,GACE8xB,GACE5Y,EACA8V,EAAKhvB,EAAI,GACTgvB,EAAKhvB,GACLoZ,EACAxB,KAICmb,GACC7Z,EACA8V,EAAKhvB,EAAI,GACTgvB,EAAKhvB,GACLoZ,EACAxB,GAGF,OAAO,EAIb,OAAO,CACT,CAUO,SAAS2b,GACdra,EACAC,EACA+V,EACA9V,EACAxB,GAEA,IAAK,IAAI5X,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAMgvB,EAAOE,EAAMlvB,GACnB,GACEszB,GAA0Bpa,EAAiBC,EAAQ6V,EAAM5V,EAAQxB,GAEjE,OAAO,EAETuB,EAAS6V,EAAKA,EAAKzvB,OAAS,EAC7B,CACD,OAAO,CACT,CC7NO,SAASoY,GAAYuB,EAAiBC,EAAQ/Y,EAAKgZ,GACxD,KAAOD,EAAS/Y,EAAMgZ,GAAQ,CAC5B,IAAK,IAAIpZ,EAAI,EAAGA,EAAIoZ,IAAUpZ,EAAG,CAC/B,MAAMK,EAAM6Y,EAAgBC,EAASnZ,GACrCkZ,EAAgBC,EAASnZ,GAAKkZ,EAAgB9Y,EAAMgZ,EAASpZ,GAC7DkZ,EAAgB9Y,EAAMgZ,EAASpZ,GAAKK,CACrC,CACD8Y,GAAUC,EACVhZ,GAAOgZ,CACR,CACH,CCLO,SAASoa,GAAsBta,EAAiBC,EAAQ/Y,EAAKgZ,GAGlE,IAAIqa,EAAO,EACPtY,EAAKjC,EAAgB9Y,EAAMgZ,GAC3BgC,EAAKlC,EAAgB9Y,EAAMgZ,EAAS,GACxC,KAAOD,EAAS/Y,EAAK+Y,GAAUC,EAAQ,CACrC,MAAMiC,EAAKnC,EAAgBC,GACrBmC,EAAKpC,EAAgBC,EAAS,GACpCsa,IAASpY,EAAKF,IAAOG,EAAKF,GAC1BD,EAAKE,EACLD,EAAKE,CACN,CACD,OAAgB,IAATmY,OAAa7uB,EAAY6uB,EAAO,CACzC,CAeO,SAASC,GACdxa,EACAC,EACA6V,EACA5V,EACAua,GAEAA,OAAkB/uB,IAAV+uB,GAAsBA,EAC9B,IAAK,IAAI3zB,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC7C,MAAMI,EAAM4uB,EAAKhvB,GACX4zB,EAAcJ,GAClBta,EACAC,EACA/Y,EACAgZ,GAEF,GAAU,IAANpZ,GACF,GAAK2zB,GAASC,IAAkBD,IAAUC,EACxC,OAAO,OAGT,GAAKD,IAAUC,IAAkBD,GAASC,EACxC,OAAO,EAGXza,EAAS/Y,CACV,CACD,OAAO,CACT,CAeO,SAASyzB,GACd3a,EACAC,EACA+V,EACA9V,EACAua,GAEA,IAAK,IAAI3zB,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAMgvB,EAAOE,EAAMlvB,GACnB,IAAK0zB,GAAuBxa,EAAiBC,EAAQ6V,EAAM5V,EAAQua,GACjE,OAAO,EAEL3E,EAAKzvB,SACP4Z,EAAS6V,EAAKA,EAAKzvB,OAAS,GAE/B,CACD,OAAO,CACT,CAeO,SAASu0B,GACd5a,EACAC,EACA6V,EACA5V,EACAua,GAEAA,OAAkB/uB,IAAV+uB,GAAsBA,EAC9B,IAAK,IAAI3zB,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC7C,MAAMI,EAAM4uB,EAAKhvB,GACX4zB,EAAcJ,GAClBta,EACAC,EACA/Y,EACAgZ,IAGM,IAANpZ,EACK2zB,GAASC,IAAkBD,IAAUC,EACrCD,IAAUC,IAAkBD,GAASC,IAE1CG,GAAmB7a,EAAiBC,EAAQ/Y,EAAKgZ,GAEnDD,EAAS/Y,CACV,CACD,OAAO+Y,CACT,CAeO,SAAS6a,GACd9a,EACAC,EACA+V,EACA9V,EACAua,GAEA,IAAK,IAAI3zB,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAC3CmZ,EAAS2a,GACP5a,EACAC,EACA+V,EAAMlvB,GACNoZ,EACAua,GAGJ,OAAOxa,CACT,CASO,SAAS8a,GAAY/a,EAAiB8V,GAC3C,MAAME,EAAQ,GACd,IAEIgF,EAFA/a,EAAS,EACTgb,EAAe,EAEnB,IAAK,IAAIn0B,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC7C,MAAMI,EAAM4uB,EAAKhvB,GAEXo0B,EAAcZ,GAAsBta,EAAiBC,EAAQ/Y,EAAK,GAIxE,QAHyBwE,IAArBsvB,IACFA,EAAmBE,GAEjBA,IAAgBF,EAClBhF,EAAMnrB,KAAKirB,EAAK9sB,MAAMiyB,EAAcn0B,EAAI,QACnC,CACL,GAAqB,IAAjBkvB,EAAM3vB,OACR,SAEF2vB,EAAMA,EAAM3vB,OAAS,GAAGwE,KAAKirB,EAAKmF,GACnC,CACDA,EAAen0B,EAAI,EACnBmZ,EAAS/Y,CACV,CACD,OAAO8uB,CACT,CCxLA,MAAMmF,WAAgB9C,GAYpB,WAAArzB,CAAYyZ,EAAa4V,EAAQyB,GAC/B3rB,QAMAjF,KAAKk2B,MAAQ,GAMbl2B,KAAKm2B,4BAA8B,EAMnCn2B,KAAKo2B,mBAAqB,KAM1Bp2B,KAAKozB,WAAa,EAMlBpzB,KAAKqzB,mBAAqB,EAM1BrzB,KAAKq2B,mBAAqB,EAM1Br2B,KAAKs2B,yBAA2B,UAEjB9vB,IAAX2oB,GAAwByB,GAC1B5wB,KAAKiwB,mBACHd,EACR,GAEMnvB,KAAKk2B,MAAQtF,GAEb5wB,KAAKkwB,eACX,EAGQf,EAGL,CAOD,gBAAAoH,CAAiBzD,GACV9yB,KAAK8a,gBAGR5Y,EAAOlC,KAAK8a,gBAAiBgY,EAAWvD,sBAFxCvvB,KAAK8a,gBAAkBgY,EAAWvD,qBAAqBzrB,QAIzD9D,KAAKk2B,MAAMvwB,KAAK3F,KAAK8a,gBAAgB3Z,QACrCnB,KAAK6H,SACN,CAOD,KAAAkN,GACE,MAAMyhB,EAAU,IAAIP,GAClBj2B,KAAK8a,gBAAgBhX,QACrB9D,KAAKmvB,OACLnvB,KAAKk2B,MAAMpyB,SAGb,OADA0yB,EAAQvsB,gBAAgBjK,MACjBw2B,CACR,CASD,cAAAvI,CAAe5W,EAAGC,EAAG4W,EAAcC,GACjC,OAAIA,EAAqBtU,GAAyB7Z,KAAKqf,YAAahI,EAAGC,GAC9D6W,GAELnuB,KAAKqzB,mBAAqBrzB,KAAK+H,gBACjC/H,KAAKozB,UAAYnnB,KAAKma,KACpBuK,GACE3wB,KAAK8a,gBACL,EACA9a,KAAKk2B,MACLl2B,KAAKgb,OACL,IAGJhb,KAAKqzB,kBAAoBrzB,KAAK+H,eAEzBopB,GACLnxB,KAAK8a,gBACL,EACA9a,KAAKk2B,MACLl2B,KAAKgb,OACLhb,KAAKozB,WACL,EACA/b,EACAC,EACA4W,EACAC,GAEH,CAOD,UAAApU,CAAW1C,EAAGC,GACZ,OAAOuc,GACL7zB,KAAKy2B,6BACL,EACAz2B,KAAKk2B,MACLl2B,KAAKgb,OACL3D,EACAC,EAEH,CAOD,OAAA4E,GACE,OAAOwa,GACL12B,KAAKy2B,6BACL,EACAz2B,KAAKk2B,MACLl2B,KAAKgb,OAER,CAeD,cAAA2U,CAAe4F,GACb,IAAIza,EAQJ,YAPctU,IAAV+uB,GACFza,EAAkB9a,KAAKy2B,6BAA6B3yB,QACpD4xB,GAAkB5a,EAAiB,EAAG9a,KAAKk2B,MAAOl2B,KAAKgb,OAAQua,IAE/Dza,EAAkB9a,KAAK8a,gBAGlB8X,GAAwB9X,EAAiB,EAAG9a,KAAKk2B,MAAOl2B,KAAKgb,OACrE,CAKD,OAAA2b,GACE,OAAO32B,KAAKk2B,KACb,CAKD,oBAAAU,GACE,GAAI52B,KAAKm2B,4BAA8Bn2B,KAAK+H,cAAe,CACzD,MAAM8uB,EAAava,GAAUtc,KAAKqf,aAClCrf,KAAKo2B,mBAAqBrC,GACxB/zB,KAAKy2B,6BACL,EACAz2B,KAAKk2B,MACLl2B,KAAKgb,OACL6b,EACA,GAEF72B,KAAKm2B,2BAA6Bn2B,KAAK+H,aACxC,CACD,OACE/H,KACA,kBACH,CAQD,gBAAA82B,GACE,OAAO,IAAItD,GAAMxzB,KAAK42B,uBAAwB,MAC/C,CASD,kBAAAG,GACE,OAAO/2B,KAAKk2B,MAAM/0B,MACnB,CAYD,aAAA61B,CAAc/zB,GACZ,OAAIA,EAAQ,GAAKjD,KAAKk2B,MAAM/0B,QAAU8B,EAC7B,KAEF,IAAIiwB,GACTlzB,KAAK8a,gBAAgBhX,MACT,IAAVb,EAAc,EAAIjD,KAAKk2B,MAAMjzB,EAAQ,GACrCjD,KAAKk2B,MAAMjzB,IAEbjD,KAAKmvB,OAER,CAOD,cAAA8H,GACE,MAAM9H,EAASnvB,KAAKmvB,OACdrU,EAAkB9a,KAAK8a,gBACvB8V,EAAO5wB,KAAKk2B,MACZlD,EAAc,GACpB,IAAIjY,EAAS,EACb,IAAK,IAAInZ,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC7C,MAAMI,EAAM4uB,EAAKhvB,GACXkxB,EAAa,IAAII,GACrBpY,EAAgBhX,MAAMiX,EAAQ/Y,GAC9BmtB,GAEF6D,EAAYrtB,KAAKmtB,GACjB/X,EAAS/Y,CACV,CACD,OAAOgxB,CACR,CAKD,0BAAAyD,GACE,GAAIz2B,KAAKq2B,mBAAqBr2B,KAAK+H,cAAe,CAChD,MAAM+S,EAAkB9a,KAAK8a,gBACzBwa,GAAuBxa,EAAiB,EAAG9a,KAAKk2B,MAAOl2B,KAAKgb,QAC9Dhb,KAAKs2B,yBAA2Bxb,GAEhC9a,KAAKs2B,yBAA2Bxb,EAAgBhX,QAChD9D,KAAKs2B,yBAAyBn1B,OAASu0B,GACrC11B,KAAKs2B,yBACL,EACAt2B,KAAKk2B,MACLl2B,KAAKgb,SAGThb,KAAKq2B,kBAAoBr2B,KAAK+H,aAC/B,CACD,OAAqC/H,KAA6B,wBACnE,CAOD,6BAAAgwB,CAA8BlC,GAE5B,MAAM8D,EAA4B,GAE5BQ,EAAiB,GAWvB,OAVAR,EAA0BzwB,OAASqxB,GACjCxyB,KAAK8a,gBACL,EACA9a,KAAKk2B,MACLl2B,KAAKgb,OACL/O,KAAKma,KAAK0H,GACV8D,EACA,EACAQ,GAEK,IAAI6D,GAAQrE,EAA2B,KAAMQ,EACrD,CAOD,OAAA1D,GACE,MAAO,SACR,CAQD,gBAAAC,CAAiBnV,GACf,OAAO0b,GACLl1B,KAAKy2B,6BACL,EACAz2B,KAAKk2B,MACLl2B,KAAKgb,OACLxB,EAEH,CAQD,cAAA0W,CAAe3W,EAAa4V,GAC1BnvB,KAAKmwB,UAAUhB,EAAQ5V,EAAa,GAC/BvZ,KAAK8a,kBACR9a,KAAK8a,gBAAkB,IAEzB,MAAM8V,EAAOW,GACXvxB,KAAK8a,gBACL,EACAvB,EACAvZ,KAAKgb,OACLhb,KAAKk2B,OAEPl2B,KAAK8a,gBAAgB3Z,OAAyB,IAAhByvB,EAAKzvB,OAAe,EAAIyvB,EAAKA,EAAKzvB,OAAS,GACzEnB,KAAK6H,SACN,EAGH,IAAAqvB,GAAejB,GAcR,SAASkB,GAASza,EAAQsL,EAAQrmB,EAAGy1B,GAC1Cz1B,EAAIA,GAAQ,GAEZ,MAAMmZ,EAAkB,GACxB,IAAK,IAAIlZ,EAAI,EAAGA,EAAID,IAAKC,EACvBM,EACE4Y,EACAuc,GAAa3a,EAAQsL,EAAS,EAAI/b,KAAK+T,GAAKpe,EAAKD,EAAGy1B,IAIxD,OADAtc,EAAgBnV,KAAKmV,EAAgB,GAAIA,EAAgB,IAClD,IAAImb,GAAQnb,EAAiB,KAAM,CAACA,EAAgB3Z,QAC7D,CAQO,SAASm2B,GAAW9d,GACzB,GAAI1U,GAAQ0U,GACV,MAAM,IAAIhR,MAAM,2CAElB,MAAM4R,EAAOZ,EAAO,GACda,EAAOb,EAAO,GACdc,EAAOd,EAAO,GACde,EAAOf,EAAO,GACdsB,EAAkB,CACtBV,EACAC,EACAD,EACAG,EACAD,EACAC,EACAD,EACAD,EACAD,EACAC,GAEF,OAAO,IAAI4b,GAAQnb,EAAiB,KAAM,CAACA,EAAgB3Z,QAC7D,CAWO,SAASo2B,GAAWrR,EAAQsR,EAAOhgB,GACxCggB,EAAQA,GAAgB,GACxB,MAAMxc,EAASkL,EAAOsJ,YAChBL,EAASjJ,EAAO4J,YAChBpT,EAASwJ,EAAO5J,YAChBmb,EAAczc,GAAUwc,EAAQ,GAChC1c,EAAkB,IAAIzY,MAAMo1B,GAClC,IAAK,IAAI71B,EAAI,EAAGA,EAAI61B,EAAa71B,GAAKoZ,EAAQ,CAC5CF,EAAgBlZ,GAAK,EACrBkZ,EAAgBlZ,EAAI,GAAK,EACzB,IAAK,IAAI0iB,EAAI,EAAGA,EAAItJ,EAAQsJ,IAC1BxJ,EAAgBlZ,EAAI0iB,GAAK5H,EAAO4H,EAEnC,CACD,MAAMsM,EAAO,CAAC9V,EAAgB3Z,QACxBq1B,EAAU,IAAIP,GAAQnb,EAAiBqU,EAAQyB,GAErD,OADA8G,GAAYlB,EAAS9Z,EAAQwJ,EAAOC,YAAa3O,GAC1Cgf,CACT,CAUO,SAASkB,GAAYlB,EAAS9Z,EAAQsL,EAAQxQ,GACnD,MAAMsD,EAAkB0b,EAAQjH,qBAC1BvU,EAASwb,EAAQhH,YACjBgI,EAAQ1c,EAAgB3Z,OAAS6Z,EAAS,EAC1C2c,EAAangB,GAAgB,EACnC,IAAK,IAAI5V,EAAI,EAAGA,GAAK41B,IAAS51B,EAAG,CAC/B,MAAMmZ,EAASnZ,EAAIoZ,EACbxD,EAAQmgB,EAAiC,EAAnB9S,GAAOjjB,EAAG41B,GAAavrB,KAAK+T,GAAMwX,EAC9D1c,EAAgBC,GAAU2B,EAAO,GAAKsL,EAAS/b,KAAKwL,IAAID,GACxDsD,EAAgBC,EAAS,GAAK2B,EAAO,GAAKsL,EAAS/b,KAAKyL,IAAIF,EAC7D,CACDgf,EAAQ3uB,SACV,CCnfA,MAAMwC,GACM,WADNA,GAEe,mBAFfA,GAGM,WAHNA,GAIe,mBAJfA,GAKK,UALLA,GAMM,WANNA,GAOQ,aAPRA,GAQG,QARHA,GASM,WATNA,GAUc,kBAMdutB,GAMG,QAOF,MAAMC,WAAyBC,EAIpC,WAAAh4B,CAAYyP,GACVtK,MAAM2yB,IAON53B,KAAK6f,KAAOtQ,EAAMsQ,KAOlB7f,KAAK+3B,QAAUxoB,EAAMwoB,OACtB,EA+VH,IAAAC,GAzSA,cAA0BvtB,EAIxB,WAAA3K,CAAY6K,GACV1F,QAKAjF,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAELgD,EAAUA,GAAW,GAOrB3K,KAAKi4B,UAAY,KAMjBj4B,KAAKk4B,WAAa1O,GAMlBxpB,KAAKm4B,cAAW3xB,EAEhBxG,KAAK6J,kBAAkBQ,GAAqBrK,KAAKo4B,0BACjDp4B,KAAK6J,kBAAkBQ,GAAmBrK,KAAKq4B,6BAEpB7xB,IAAvBmE,EAAQwU,YACVnf,KAAKs4B,cAAc3tB,EAAQwU,iBAEG3Y,IAA5BmE,EAAQ4tB,iBACVv4B,KAAKw4B,mBAAmB7tB,EAAQ4tB,iBAGlCv4B,KAAKy4B,iBAAiCjyB,IAArBmE,EAAQ+tB,UAAyB/tB,EAAQ+tB,SAC3D,CAKD,eAAAj4B,GACET,KAAKy4B,aAAY,GACjBxzB,MAAMxE,iBACP,CAKD,wBAAA23B,GACE,MAAMjZ,EAAanf,KAAK4uB,gBACpBzP,IACFnf,KAAKk4B,WAAahO,GAChB0E,GAAc,aACdzP,GAEEnf,KAAKi4B,WACPj4B,KAAK+J,IAAIM,GAAmBrK,KAAKk4B,WAAWl4B,KAAKi4B,YAGtD,CAKD,sBAAAI,GACE,GAAI,gBAAiBtqB,UAAW,CAC9B,MAAM2qB,EAAW14B,KAAK24B,cAClBD,QAA8BlyB,IAAlBxG,KAAKm4B,SACnBn4B,KAAKm4B,SAAWpqB,UAAU6qB,YAAYC,cACpC74B,KAAK84B,gBAAgB5xB,KAAKlH,MAC1BA,KAAK+4B,eAAe7xB,KAAKlH,MACzBA,KAAKg5B,sBAEGN,QAA8BlyB,IAAlBxG,KAAKm4B,WAC3BpqB,UAAU6qB,YAAYK,WAAWj5B,KAAKm4B,UACtCn4B,KAAKm4B,cAAW3xB,EAEnB,CACF,CAMD,eAAAsyB,CAAgBI,GACd,MAAMC,EAASD,EAASC,OACxBn5B,KAAK+J,IAAIM,GAAmB8uB,EAAOC,UACnCp5B,KAAK+J,IACHM,GACoB,OAApB8uB,EAAOE,cAAoB7yB,EAAY2yB,EAAOE,UAEhDr5B,KAAK+J,IACHM,GAC4B,OAA5B8uB,EAAOG,sBAA4B9yB,EAAY2yB,EAAOG,kBAExDt5B,KAAK+J,IACHM,GACmB,OAAnB8uB,EAAOI,aAAmB/yB,EAAYme,GAAUwU,EAAOI,UAEpDv5B,KAAKi4B,WAGRj4B,KAAKi4B,UAAU,GAAKkB,EAAOK,UAC3Bx5B,KAAKi4B,UAAU,GAAKkB,EAAOM,UAH3Bz5B,KAAKi4B,UAAY,CAACkB,EAAOK,UAAWL,EAAOM,UAK7C,MAAMC,EAAoB15B,KAAKk4B,WAAWl4B,KAAKi4B,WAC/Cj4B,KAAK+J,IAAIM,GAAmBqvB,EAAkB51B,SAC9C9D,KAAK+J,IAAIM,GAAiC,OAAjB8uB,EAAOQ,WAAiBnzB,EAAY2yB,EAAOQ,OACpE,MAAM/kB,EAAWglB,GAAgB55B,KAAKi4B,UAAWkB,EAAOC,UACxDxkB,EAAS+J,eAAe3e,KAAKk4B,YAC7Bl4B,KAAK+J,IAAIM,GAA4BuK,GACrC5U,KAAK6H,SACN,CAMD,cAAAkxB,CAAexpB,GACbvP,KAAK4F,cAAc,IAAIiyB,GAAiBtoB,GACzC,CASD,WAAAsqB,GACE,OAAwC75B,KAAKoJ,IAAIiB,GAClD,CAQD,mBAAAyvB,GACE,OACE95B,KAAKoJ,IAAIiB,KAA+B,IAE3C,CASD,WAAA0vB,GACE,OAAwC/5B,KAAKoJ,IAAIiB,GAClD,CASD,mBAAA2vB,GACE,OACEh6B,KAAKoJ,IAAIiB,GAEZ,CAUD,UAAA4vB,GACE,OAAwCj6B,KAAKoJ,IAAIiB,GAClD,CASD,WAAA6vB,GACE,OACEl6B,KAAKoJ,IAAIiB,GAEZ,CASD,aAAAukB,GACE,OACE5uB,KAAKoJ,IAAIiB,GAEZ,CASD,QAAA8vB,GACE,OAAwCn6B,KAAKoJ,IAAIiB,GAClD,CAQD,WAAAsuB,GACE,OAA+B34B,KAAKoJ,IAAIiB,GACzC,CAWD,kBAAA2uB,GACE,OACEh5B,KAAKoJ,IAAIiB,GAEZ,CASD,aAAAiuB,CAAcnZ,GACZnf,KAAK+J,IAAIM,GAAqBukB,GAAczP,GAC7C,CAQD,WAAAsZ,CAAYC,GACV14B,KAAK+J,IAAIM,GAAmBquB,EAC7B,CAWD,kBAAAF,CAAmB7tB,GACjB3K,KAAK+J,IAAIM,GAA2BM,EACrC,GCtZYyvB,GACP,EADOA,GAEJ,EAFIA,GAGL,EAHKA,GAIN,EAJMA,GAKN,EC6MF,SAASC,GAAYvnB,EAAOwnB,EAAaC,GAC9C,MAAMC,EAAuC,EAC7C,IAAIC,GAAY,EACZC,GAAW,EACXC,GAAS,EAEb,MAAMC,EAAe,CACnBvzB,EAAWmzB,EAAK1yB,GAAgB,WAC9B6yB,GAAS,EACJD,GACHJ,GAER,KAyBE,OAtBIE,EAAIK,KAAO/rB,IACb4rB,GAAW,EACXF,EACGxrB,SACA+E,MAAK,WACA0mB,GACFH,GAEV,IACOtmB,OAAM,SAAUzE,GACXkrB,IACEE,EACFL,IAEAC,IAGZ,KAEIK,EAAaj1B,KAAK0B,EAAWmzB,EAAK1yB,EAAiByyB,IAG9C,WACLE,GAAY,EACZG,EAAazvB,QAAQ7D,EACzB,CACA,CASO,SAASgG,GAAKwF,EAAO+nB,GAC1B,OAAO,IAAIt2B,SAAQ,CAACE,EAASD,KAC3B,SAASs2B,IACPC,IACAt2B,EAAQqO,EACT,CACD,SAASkoB,IACPD,IACAv2B,EAAO,IAAIgE,MAAM,oBAClB,CACD,SAASuyB,IACPjoB,EAAMxM,oBAAoB,OAAQw0B,GAClChoB,EAAMxM,oBAAoB,QAAS00B,EACpC,CACDloB,EAAMxN,iBAAiB,OAAQw1B,GAC/BhoB,EAAMxN,iBAAiB,QAAS01B,GAC5BH,IACF/nB,EAAM+nB,IAAMA,EACb,GAEL,CAOO,SAASI,GAAenoB,EAAO+nB,GAIpC,OAHIA,IACF/nB,EAAM+nB,IAAMA,GAEP/nB,EAAM+nB,KAAO/rB,GAChB,IAAIvK,SAAQ,CAACE,EAASD,IACpBsO,EACG9D,SACA+E,MAAK,IAAMtP,EAAQqO,KACnBkB,OAAOkD,GACNpE,EAAMooB,UAAYpoB,EAAMrD,MAAQhL,EAAQqO,GAAStO,EAAO0S,OAG9D5J,GAAKwF,EACX,CAWO,SAAS9D,GAAO8D,EAAO+nB,GAI5B,OAHIA,IACF/nB,EAAM+nB,IAAMA,GAEP/nB,EAAM+nB,KAAO/rB,IAAgBG,GAChC6D,EACG9D,SACA+E,MAAK,IAAM7E,kBAAkB4D,KAC7BkB,OAAOkD,IACN,GAAIpE,EAAMooB,UAAYpoB,EAAMrD,MAC1B,OAAOqD,EAET,MAAMoE,CAAC,IAEX+jB,GAAenoB,EACrB,CAEA,IAAAqoB,GAtRA,cAA2B1zB,EAQzB,WAAA3H,CAAY0Z,EAAQmD,EAAYye,EAAYC,GAC1Cp2B,QAMAjF,KAAKwZ,OAASA,EAMdxZ,KAAKs7B,YAAcF,EAMnBp7B,KAAK2c,WAAaA,EAMlB3c,KAAKwM,MACsB,mBAAlB6uB,EAA+BjB,GAAkBiB,EAM1Dr7B,KAAKu7B,OAAS,KAMdv7B,KAAKsT,OAAkC,mBAAlB+nB,EAA+BA,EAAgB,IACrE,CAKD,OAAAxzB,GACE7H,KAAK4F,cAAckC,EACpB,CAKD,SAAAuX,GACE,OAAOrf,KAAKwZ,MACb,CAKD,QAAAgiB,GACE,OAAOx7B,KAAKu7B,MACb,CAKD,aAAAE,GACE,OAAOz7B,KAAKs7B,WACb,CAKD,aAAAI,GACE,OAA8B17B,KAAe,UAC9C,CAKD,QAAAmN,GACE,OAAOnN,KAAKwM,KACb,CAKD,IAAAc,GACE,GAAItN,KAAKwM,OAAS4tB,IACZp6B,KAAKsT,OAAQ,CACftT,KAAKwM,MAAQ4tB,GACbp6B,KAAK6H,UACL,MAAM8U,EAAa3c,KAAK07B,gBAClBC,EAAoBt5B,MAAMC,QAAQqa,GACpCA,EAAW,GACXA,EACJxY,GAAU,IACRnE,KAAKsT,OAAOtT,KAAKqf,YAAasc,EAAmB37B,KAAKy7B,mBAErD1nB,MAAMjB,IACD,UAAWA,IACb9S,KAAKu7B,OAASzoB,EAAMA,OAElB,WAAYA,IACd9S,KAAKwZ,OAAS1G,EAAM0G,QAElB,eAAgB1G,IAClB9S,KAAK2c,WAAa7J,EAAM6J,YAEtB,eAAgB7J,IAClB9S,KAAKs7B,YAAcxoB,EAAMsoB,aAGzBtoB,aAAiB8oB,kBACjB9oB,aAAiBR,aACjBQ,aAAiBV,mBACjBU,aAAiBT,oBAEjBrS,KAAKu7B,OAASzoB,GAEhB9S,KAAKwM,MAAQ4tB,EAAiB,IAE/BpmB,OAAOzE,IACNvP,KAAKwM,MAAQ4tB,GACbjR,QAAQ5Z,MAAMA,EAAM,IAErBssB,SAAQ,IAAM77B,KAAK6H,WACvB,CAEJ,CAKD,QAAAi0B,CAAShpB,GACP9S,KAAKu7B,OAASzoB,CACf,CAKD,aAAAipB,CAAcpf,GACZ3c,KAAK2c,WAAaA,CACnB,GCrHH,IAAAqf,GA5EA,cAA0BC,GASxB,WAAAn8B,CAAY0Z,EAAQmD,EAAYye,EAAYvrB,EAAQyD,GAGlDrO,MAAMuU,EAAQmD,EAAYye,OAFD50B,IAAX8M,EAAuB8mB,GAAkBA,IASvDp6B,KAAKqT,aAAqB7M,IAAX8M,EAAuBA,EAAS,KAM/CtT,KAAKk8B,QAAUrsB,EAMf7P,KAAKwT,OAAS,IACf,CAMD,QAAAM,GACE,OAAO9T,KAAKwT,MACb,CAOD,WAAA2oB,CAAY73B,GACNA,GACFtE,KAAKwT,OAASlP,EACdtE,KAAKwM,MAAQ4tB,IAEbp6B,KAAKwM,MAAQ4tB,GAEfp6B,KAAK6H,SACN,CAKD,IAAAyF,GACMtN,KAAKwM,OAAS4tB,KAChBp6B,KAAKwM,MAAQ4tB,GACbp6B,KAAK6H,UACL7H,KAAKqT,QAAQrT,KAAKm8B,YAAYj1B,KAAKlH,OAEtC,CAKD,QAAAw7B,GACE,OAAOx7B,KAAKk8B,OACb,GCmGH,IAAAE,GAnLA,cAAwBhpB,GAStB,WAAAtT,CAAYyM,EAAWC,EAAOquB,EAAKwB,EAAaC,EAAkB3xB,GAChE1F,MAAMsH,EAAWC,EAAO7B,GAMxB3K,KAAKu8B,aAAeF,EAQpBr8B,KAAKw8B,KAAO3B,EAEZ76B,KAAKuH,IAAMszB,EAMX76B,KAAKu7B,OAAS,IAAIxsB,MACE,OAAhBstB,IACFr8B,KAAKu7B,OAAOc,YAAcA,GAO5Br8B,KAAKy8B,UAAY,KAMjBz8B,KAAK08B,kBAAoBJ,CAC1B,CAOD,QAAAd,GACE,OAAOx7B,KAAKu7B,MACb,CAMD,QAAAO,CAASvxB,GACPvK,KAAKu7B,OAAShxB,EACdvK,KAAKwM,MAAQV,EACb9L,KAAK28B,iBACL38B,KAAK6H,SACN,CAOD,iBAAA+0B,GACE58B,KAAKwM,MAAQV,EACb9L,KAAK28B,iBACL38B,KAAKu7B,OA8FT,WACE,MAAMsB,EAAMrtB,GAAsB,EAAG,GAGrC,OAFAqtB,EAAIC,UAAY,gBAChBD,EAAIE,SAAS,EAAG,EAAG,EAAG,GACfF,EAAIhtB,MACb,CAnGkBmtB,GACdh9B,KAAK6H,SACN,CAOD,gBAAAo1B,GACE,MAAMnqB,EAAyC9S,KAAW,OACtD8S,EAAMoqB,cAAgBpqB,EAAMqqB,cAC9Bn9B,KAAKwM,MAAQV,EAEb9L,KAAKwM,MAAQV,EAEf9L,KAAK28B,iBACL38B,KAAK6H,SACN,CAuCD,IAAAyF,GACMtN,KAAKwM,OAASV,IAChB9L,KAAKwM,MAAQV,EACb9L,KAAKu7B,OAAS,IAAIxsB,MACQ,OAAtB/O,KAAKu8B,eACPv8B,KAAKu7B,OAAOc,YAAcr8B,KAAKu8B,eAG/Bv8B,KAAKwM,OAASV,IAChB9L,KAAKwM,MAAQV,EACb9L,KAAK6H,UACL7H,KAAK08B,kBAAkB18B,KAAMA,KAAKw8B,MAClCx8B,KAAKy8B,UAAYpC,GACfr6B,KAAKu7B,OACLv7B,KAAKi9B,iBAAiB/1B,KAAKlH,MAC3BA,KAAK48B,kBAAkB11B,KAAKlH,OAGjC,CAOD,cAAA28B,GACM38B,KAAKy8B,YACPz8B,KAAKy8B,YACLz8B,KAAKy8B,UAAY,KAEpB,GChDH,IAAAW,GAnHA,MAOE,WAAAt9B,CAAYu9B,EAAOC,EAAaC,GAK9Bv9B,KAAKw9B,OAASH,EAMdr9B,KAAKy9B,aAAeH,EAMpBt9B,KAAK09B,OAASH,EAMdv9B,KAAK29B,QAAU,GAMf39B,KAAK49B,OAAS,EAMd59B,KAAK69B,iBAAmB,CACzB,CAKD,KAAA97B,GACE/B,KAAK29B,QAAQx8B,OAAS,EACtBnB,KAAK49B,OAAS,EACd59B,KAAK69B,iBAAmB,CACzB,CAMD,MAAAC,CAAOzmB,EAAGC,GACRtX,KAAK29B,QAAQh4B,KAAK0R,EAAGC,EAAGymB,KAAKC,MAC9B,CAKD,GAAAh8B,GACE,GAAIhC,KAAK29B,QAAQx8B,OAAS,EAGxB,OAAO,EAET,MAAMo8B,EAAQQ,KAAKC,MAAQh+B,KAAK09B,OAC1BO,EAAYj+B,KAAK29B,QAAQx8B,OAAS,EACxC,GAAInB,KAAK29B,QAAQM,EAAY,GAAKV,EAGhC,OAAO,EAIT,IAAIW,EAAaD,EAAY,EAC7B,KAAOC,EAAa,GAAKl+B,KAAK29B,QAAQO,EAAa,GAAKX,GACtDW,GAAc,EAGhB,MAAMC,EAAWn+B,KAAK29B,QAAQM,EAAY,GAAKj+B,KAAK29B,QAAQO,EAAa,GAIzE,GAAIC,EAAW,IAAO,GACpB,OAAO,EAGT,MAAMrmB,EAAK9X,KAAK29B,QAAQM,GAAaj+B,KAAK29B,QAAQO,GAC5CnmB,EAAK/X,KAAK29B,QAAQM,EAAY,GAAKj+B,KAAK29B,QAAQO,EAAa,GAGnE,OAFAl+B,KAAK49B,OAAS3xB,KAAKoc,MAAMtQ,EAAID,GAC7B9X,KAAK69B,iBAAmB5xB,KAAKma,KAAKtO,EAAKA,EAAKC,EAAKA,GAAMomB,EAChDn+B,KAAK69B,iBAAmB79B,KAAKy9B,YACrC,CAKD,WAAA1V,GACE,OAAQ/nB,KAAKy9B,aAAez9B,KAAK69B,kBAAoB79B,KAAKw9B,MAC3D,CAKD,QAAAY,GACE,OAAOp+B,KAAK49B,MACb,GCpHYS,GAAA,CACd3oB,KAAM,MACN+F,IAAK,CAAC,EAAE,EAAE,GACVC,IAAK,CAAC,IAAI,IAAI,KACd4iB,QAAS,CAAC,MAAO,QAAS,QAC1BC,MAAO,CAAC,QCJLC,GAAM,CACT9oB,KAAM,MACN+F,IAAK,CAAC,EAAE,EAAE,GACV6iB,QAAS,CAAC,IAAI,IAAI,KAClBC,MAAO,CAAC,MAAO,SAAU,WAS1BC,WAAiB,CAEhB,EAAG,CAEFC,EAAE,CAAC,OAAQ,IAAK,QAEhBC,EAAG,CAAC,OAAQ,IAAK,SACjBC,IAAK,CAAC,OAAQ,IAAK,QACnBC,IAAK,CAAC,OAAQ,IAAK,QAEnBC,IAAK,CAAC,gBAAiB,IAAK,mBAC5BC,IAAK,CAAC,OAAQ,IAAK,SAGnBC,GAAI,CAAC,OAAQ,IAAK,QAKlBC,GAAI,CAAC,OAAQ,IAAK,SAIlBC,IAAK,CAAC,QAAS,IAAK,OAEpBC,EAAG,CAAC,IAAI,IAAI,MAIb,GAAI,CAEHT,EAAE,CAAC,QAAS,IAAK,MACjBC,EAAG,CAAC,OAAQ,IAAK,SACjBC,IAAK,CAAC,MAAQ,IAAK,QACnBC,IAAK,CAAC,OAAQ,IAAK,QAEnBC,IAAK,CAAC,OAAQ,IAAK,SACnBC,IAAK,CAAC,OAAQ,IAAK,SAEnBC,GAAI,CAAC,OAAS,IAAK,QACnBC,GAAI,CAAC,OAAQ,IAAK,SAClBC,IAAK,CAAC,QAAS,IAAK,QACpBC,EAAG,CAAC,IAAI,IAAI,QAQdV,GAAI9iB,IAAM8iB,GAAIW,WAAW,GAAGN,IAU5BL,GAAIH,IAAM,SAAUe,EAAMC,GAEzBA,EAAQA,GAASb,GAAIW,WAAW,GAAGD,EAEnC,IAGC9a,EAAGkb,EAAGh+B,EAHH+V,EAAI+nB,EAAK,GAAKC,EAAM,GACvB/nB,EAAI8nB,EAAK,GAAKC,EAAM,GACpBE,EAAIH,EAAK,GAAKC,EAAM,GAsBrB,OAhBAC,GAAU,gBAALjoB,EAA8B,iBAAJC,EAA6B,iBAAJioB,EACxDj+B,EAAS,iBAAJ+V,GAA+B,gBAALC,EAA8B,kBAAJioB,EAEzDnb,GAJAA,EAAS,kBAAJ/M,GAA+B,kBAALC,GAAgC,cAALioB,GAIlD,SAAc,MAAQtzB,KAAKC,IAAIkY,EAAG,EAAM,KAAQ,KACrDA,GAAS,MAEZkb,EAAIA,EAAI,SAAc,MAAQrzB,KAAKC,IAAIozB,EAAG,EAAM,KAAQ,KACrDA,GAAS,MAEZh+B,EAAIA,EAAI,SAAc,MAAQ2K,KAAKC,IAAI5K,EAAG,EAAM,KAAQ,KACrDA,GAAS,MAML,CAAK,KAJZ8iB,EAAInY,KAAKwP,IAAIxP,KAAKyP,IAAI,EAAG0I,GAAI,IAIR,KAHrBkb,EAAIrzB,KAAKwP,IAAIxP,KAAKyP,IAAI,EAAG4jB,GAAI,IAGC,KAF9Bh+B,EAAI2K,KAAKwP,IAAIxP,KAAKyP,IAAI,EAAGpa,GAAI,IAG9B,EAWA+8B,GAAIG,IAAM,SAASH,EAAKgB,GACvB,IAAIjb,EAAIia,EAAI,GAAK,IACfiB,EAAIjB,EAAI,GAAK,IACb/8B,EAAI+8B,EAAI,GAAK,IAQX/mB,EAAS,iBALb8M,EAAIA,EAAI,OAAUnY,KAAKC,KAAMkY,EAAI,MAAS,MAAQ,KAAQA,EAAI,OAKxB,iBAJtCkb,EAAIA,EAAI,OAAUrzB,KAAKC,KAAMozB,EAAI,MAAS,MAAQ,KAAQA,EAAI,OAIC,kBAH/Dh+B,EAAIA,EAAI,OAAU2K,KAAKC,KAAM5K,EAAI,MAAS,MAAQ,KAAQA,EAAI,OAI1Di+B,EAAS,iBAAJnb,EAA8B,gBAAJkb,EAA6B,gBAAJh+B,EAI5D,MAAO,EANM,gBAAJ8iB,EAA6B,gBAAJkb,EAA6B,gBAAJh+B,IAI3D+9B,EAAQA,GAASb,GAAIW,WAAW,GAAGD,GAEjB,GAAI5nB,EAAI+nB,EAAM,GAAIE,EAAIF,EAAM,GAC/C,EAIA,IAAAG,GAAehB,GCtIAiB,GAAA,CACd/pB,KAAM,MAKN+F,IAAK,CAAC,GAAG,KAAK,KACdC,IAAK,CAAC,IAAI,IAAI,KACd4iB,QAAS,CAAC,YAAa,IAAK,KAC5BC,MAAO,CAAC,MAAO,SAAU,WAEzBC,IAAK,SAASkB,EAAK99B,EAAG+9B,GACrB,IAAIC,EAAIC,EAAI7gB,EAAG8gB,EAAGC,EAAMzoB,EAAM0oB,EAAIC,EAAIC,EAGtC,GAFAlhB,EAAI0gB,EAAI,GAAII,EAAIJ,EAAI,GAAIK,EAAIL,EAAI,GAEtB,IAAN1gB,EAAS,MAAO,CAAC,EAAE,EAAE,GAkCzB,OA3BApd,EAAIA,GAAK,MACT+9B,EAAIA,GAAK,EAYTC,EAAKE,GAAK,GAAK9gB,GANT,GAJNghB,EAAKxB,GAAIW,WAAWQ,GAAG/9B,GAAG,KAITo+B,EAAM,IAHvBC,EAAKzB,GAAIW,WAAWQ,GAAG/9B,GAAG,IAGS,GAFnCs+B,EAAK1B,GAAIW,WAAWQ,GAAG/9B,GAAG,MAQA,EAC1Bi+B,EAAKE,GAAK,GAAK/gB,GANT,EAAIihB,GAAOD,EAAM,GAAKC,EAAO,EAAIC,IAMb,EAanB,CARC,GAHR5oB,EAAI0H,EAAI,EAAIihB,EAAKh0B,KAAKC,KAAM8S,EAAI,IAAM,IAAM,GAAKihB,EAAKjhB,EAnB9C,sBAsBI4gB,GAAM,EAAIC,IAAO,EAQlBvoB,EAPPA,GAAK,GAAK,EAAIsoB,EAAK,GAAKC,IAAO,EAAIA,IAAO,EAQ9C,GAOCL,GAACC,IAAM,SAASC,EAAK99B,EAAG+9B,GAC1B,IAAIC,EAAIC,EAAI7gB,EAAS3H,EAAGC,EAAGioB,EAAGS,EAAIC,EAAIC,EAAIv4B,EAAIw4B,EAO9Cv+B,EAAIA,GAAK,MACT+9B,EAAIA,GAAK,EAMTh4B,EAAM,GAJNq4B,EAAKxB,GAAIW,WAAWQ,GAAG/9B,GAAG,KAITo+B,EAAM,IAHvBC,EAAKzB,GAAIW,WAAWQ,GAAG/9B,GAAG,IAGS,GAFnCs+B,EAAK1B,GAAIW,WAAWQ,GAAG/9B,GAAG,KAG1Bu+B,EAAM,EAAIF,GAAOD,EAAM,GAAKC,EAAO,EAAIC,GAMvCN,EAAM,GAHNvoB,EAAIqoB,EAAI,KAGQroB,EAAK,IAHTC,EAAIooB,EAAI,IAGY,GAHRH,EAAIG,EAAI,MAGW,EAC3CG,EAAM,EAAIvoB,GAAMD,EAAK,GAAKC,EAAM,EAAIioB,IAAO,EAE3C,IAAIa,EAAK9oB,EAAE2oB,EAOX,MAAO,CALPjhB,EAAIohB,GAvBI,oBACA,kBAsBUA,EAAK,IAAMn0B,KAAKC,IAAIk0B,EAAI,EAAE,GAAK,GAE7C,GAAKphB,GAAK4gB,EAAKj4B,GACf,GAAKqX,GAAK6gB,EAAKM,GAGpB,ECxFA,IAAIE,GAAQ,CACX3qB,KAAM,QACN4oB,QAAS,CAAC,YAAa,SAAU,OACjCC,MAAO,CAAC,QAAS,YACjB9iB,IAAK,CAAC,EAAE,EAAE,GACVC,IAAK,CAAC,IAAI,IAAI,KAEd+jB,IAAK,SAASA,GACb,IAGMa,EAHFthB,EAAIygB,EAAI,GACZzoB,EAAIyoB,EAAI,GAOR,OAHAa,EAHIb,EAAI,GAGC,IAAM,EAAIxzB,KAAK+T,GAGjB,CAAChB,EAFJhI,EAAI/K,KAAKwL,IAAI6oB,GACbtpB,EAAI/K,KAAKyL,IAAI4oB,GAEjB,EAED9B,IAAK,SAASkB,GACb,OAAOD,GAAIjB,IAAI6B,GAAMZ,IAAIC,GACzB,wGAKFD,GAAIY,MAAQ,SAASZ,GACpB,IAAIzgB,EAAIygB,EAAI,GAAIK,EAAIL,EAAI,GAAIM,EAAIN,EAAI,GAEhCzoB,EAAI/K,KAAKma,KAAK0Z,EAAEA,EAAIC,EAAEA,GAEtBQ,EAAS,IADJt0B,KAAKoc,MAAM0X,EAAED,GACH,EAAI7zB,KAAK+T,GAK5B,OAJIugB,EAAI,IACPA,GAAK,KAGC,CAACvhB,EAAEhI,EAAEupB,EACb,EAEA/B,GAAI6B,MAAQ,SAASX,GACnB,OAAOD,GAAIY,MAAM7B,GAAIiB,IAAIC,GAC3B,EChDA,UAAiB,CAChBc,UAAa,CAAC,IAAK,IAAK,KACxBC,aAAgB,CAAC,IAAK,IAAK,KAC3BC,KAAQ,CAAC,EAAG,IAAK,KACjBC,WAAc,CAAC,IAAK,IAAK,KACzBC,MAAS,CAAC,IAAK,IAAK,KACpBC,MAAS,CAAC,IAAK,IAAK,KACpBC,OAAU,CAAC,IAAK,IAAK,KACrBC,MAAS,CAAC,EAAG,EAAG,GAChBC,eAAkB,CAAC,IAAK,IAAK,KAC7BC,KAAQ,CAAC,EAAG,EAAG,KACfC,WAAc,CAAC,IAAK,GAAI,KACxBC,MAAS,CAAC,IAAK,GAAI,IACnBC,UAAa,CAAC,IAAK,IAAK,KACxBC,UAAa,CAAC,GAAI,IAAK,KACvBC,WAAc,CAAC,IAAK,IAAK,GACzBC,UAAa,CAAC,IAAK,IAAK,IACxBC,MAAS,CAAC,IAAK,IAAK,IACpBC,eAAkB,CAAC,IAAK,IAAK,KAC7BC,SAAY,CAAC,IAAK,IAAK,KACvBC,QAAW,CAAC,IAAK,GAAI,IACrBC,KAAQ,CAAC,EAAG,IAAK,KACjBC,SAAY,CAAC,EAAG,EAAG,KACnBC,SAAY,CAAC,EAAG,IAAK,KACrBC,cAAiB,CAAC,IAAK,IAAK,IAC5BC,SAAY,CAAC,IAAK,IAAK,KACvBC,UAAa,CAAC,EAAG,IAAK,GACtBC,SAAY,CAAC,IAAK,IAAK,KACvBC,UAAa,CAAC,IAAK,IAAK,KACxBC,YAAe,CAAC,IAAK,EAAG,KACxBC,eAAkB,CAAC,GAAI,IAAK,IAC5BC,WAAc,CAAC,IAAK,IAAK,GACzBC,WAAc,CAAC,IAAK,GAAI,KACxBC,QAAW,CAAC,IAAK,EAAG,GACpBC,WAAc,CAAC,IAAK,IAAK,KACzBC,aAAgB,CAAC,IAAK,IAAK,KAC3BC,cAAiB,CAAC,GAAI,GAAI,KAC1BC,cAAiB,CAAC,GAAI,GAAI,IAC1BC,cAAiB,CAAC,GAAI,GAAI,IAC1BC,cAAiB,CAAC,EAAG,IAAK,KAC1BC,WAAc,CAAC,IAAK,EAAG,KACvBC,SAAY,CAAC,IAAK,GAAI,KACtBC,YAAe,CAAC,EAAG,IAAK,KACxBC,QAAW,CAAC,IAAK,IAAK,KACtBC,QAAW,CAAC,IAAK,IAAK,KACtBC,WAAc,CAAC,GAAI,IAAK,KACxBC,UAAa,CAAC,IAAK,GAAI,IACvBC,YAAe,CAAC,IAAK,IAAK,KAC1BC,YAAe,CAAC,GAAI,IAAK,IACzBC,QAAW,CAAC,IAAK,EAAG,KACpBC,UAAa,CAAC,IAAK,IAAK,KACxBC,WAAc,CAAC,IAAK,IAAK,KACzBC,KAAQ,CAAC,IAAK,IAAK,GACnBC,UAAa,CAAC,IAAK,IAAK,IACxBC,KAAQ,CAAC,IAAK,IAAK,KACnBC,MAAS,CAAC,EAAG,IAAK,GAClBC,YAAe,CAAC,IAAK,IAAK,IAC1BC,KAAQ,CAAC,IAAK,IAAK,KACnBC,SAAY,CAAC,IAAK,IAAK,KACvBC,QAAW,CAAC,IAAK,IAAK,KACtBC,UAAa,CAAC,IAAK,GAAI,IACvBC,OAAU,CAAC,GAAI,EAAG,KAClBC,MAAS,CAAC,IAAK,IAAK,KACpBC,MAAS,CAAC,IAAK,IAAK,KACpBC,SAAY,CAAC,IAAK,IAAK,KACvBC,cAAiB,CAAC,IAAK,IAAK,KAC5BC,UAAa,CAAC,IAAK,IAAK,GACxBC,aAAgB,CAAC,IAAK,IAAK,KAC3BC,UAAa,CAAC,IAAK,IAAK,KACxBC,WAAc,CAAC,IAAK,IAAK,KACzBC,UAAa,CAAC,IAAK,IAAK,KACxBC,qBAAwB,CAAC,IAAK,IAAK,KACnCC,UAAa,CAAC,IAAK,IAAK,KACxBC,WAAc,CAAC,IAAK,IAAK,KACzBC,UAAa,CAAC,IAAK,IAAK,KACxBC,UAAa,CAAC,IAAK,IAAK,KACxBC,YAAe,CAAC,IAAK,IAAK,KAC1BC,cAAiB,CAAC,GAAI,IAAK,KAC3BC,aAAgB,CAAC,IAAK,IAAK,KAC3BC,eAAkB,CAAC,IAAK,IAAK,KAC7BC,eAAkB,CAAC,IAAK,IAAK,KAC7BC,eAAkB,CAAC,IAAK,IAAK,KAC7BC,YAAe,CAAC,IAAK,IAAK,KAC1BC,KAAQ,CAAC,EAAG,IAAK,GACjBC,UAAa,CAAC,GAAI,IAAK,IACvBC,MAAS,CAAC,IAAK,IAAK,KACpBC,QAAW,CAAC,IAAK,EAAG,KACpBC,OAAU,CAAC,IAAK,EAAG,GACnBC,iBAAoB,CAAC,IAAK,IAAK,KAC/BC,WAAc,CAAC,EAAG,EAAG,KACrBC,aAAgB,CAAC,IAAK,GAAI,KAC1BC,aAAgB,CAAC,IAAK,IAAK,KAC3BC,eAAkB,CAAC,GAAI,IAAK,KAC5BC,gBAAmB,CAAC,IAAK,IAAK,KAC9BC,kBAAqB,CAAC,EAAG,IAAK,KAC9BC,gBAAmB,CAAC,GAAI,IAAK,KAC7BC,gBAAmB,CAAC,IAAK,GAAI,KAC7BC,aAAgB,CAAC,GAAI,GAAI,KACzBC,UAAa,CAAC,IAAK,IAAK,KACxBC,UAAa,CAAC,IAAK,IAAK,KACxBC,SAAY,CAAC,IAAK,IAAK,KACvBC,YAAe,CAAC,IAAK,IAAK,KAC1BC,KAAQ,CAAC,EAAG,EAAG,KACfC,QAAW,CAAC,IAAK,IAAK,KACtBC,MAAS,CAAC,IAAK,IAAK,GACpBC,UAAa,CAAC,IAAK,IAAK,IACxBC,OAAU,CAAC,IAAK,IAAK,GACrBC,UAAa,CAAC,IAAK,GAAI,GACvBC,OAAU,CAAC,IAAK,IAAK,KACrBC,cAAiB,CAAC,IAAK,IAAK,KAC5BC,UAAa,CAAC,IAAK,IAAK,KACxBC,cAAiB,CAAC,IAAK,IAAK,KAC5BC,cAAiB,CAAC,IAAK,IAAK,KAC5BC,WAAc,CAAC,IAAK,IAAK,KACzBC,UAAa,CAAC,IAAK,IAAK,KACxBC,KAAQ,CAAC,IAAK,IAAK,IACnBC,KAAQ,CAAC,IAAK,IAAK,KACnBC,KAAQ,CAAC,IAAK,IAAK,KACnBC,WAAc,CAAC,IAAK,IAAK,KACzBC,OAAU,CAAC,IAAK,EAAG,KACnBC,cAAiB,CAAC,IAAK,GAAI,KAC3BC,IAAO,CAAC,IAAK,EAAG,GAChBC,UAAa,CAAC,IAAK,IAAK,KACxBC,UAAa,CAAC,GAAI,IAAK,KACvBC,YAAe,CAAC,IAAK,GAAI,IACzBC,OAAU,CAAC,IAAK,IAAK,KACrBC,WAAc,CAAC,IAAK,IAAK,IACzBC,SAAY,CAAC,GAAI,IAAK,IACtBC,SAAY,CAAC,IAAK,IAAK,KACvBC,OAAU,CAAC,IAAK,GAAI,IACpBC,OAAU,CAAC,IAAK,IAAK,KACrBC,QAAW,CAAC,IAAK,IAAK,KACtBC,UAAa,CAAC,IAAK,GAAI,KACvBC,UAAa,CAAC,IAAK,IAAK,KACxBC,UAAa,CAAC,IAAK,IAAK,KACxBC,KAAQ,CAAC,IAAK,IAAK,KACnBC,YAAe,CAAC,EAAG,IAAK,KACxBC,UAAa,CAAC,GAAI,IAAK,KACvBxmB,IAAO,CAAC,IAAK,IAAK,KAClBymB,KAAQ,CAAC,EAAG,IAAK,KACjBC,QAAW,CAAC,IAAK,IAAK,KACtBC,OAAU,CAAC,IAAK,GAAI,IACpBC,UAAa,CAAC,GAAI,IAAK,KACvBC,OAAU,CAAC,IAAK,IAAK,KACrBC,MAAS,CAAC,IAAK,IAAK,KACpBjK,MAAS,CAAC,IAAK,IAAK,KACpBkK,WAAc,CAAC,IAAK,IAAK,KACzBC,OAAU,CAAC,IAAK,IAAK,GACrBC,YAAe,CAAC,IAAK,IAAK,MC1IvBC,GAAW,CACd1B,IAAK,EACLf,OAAQ,GACRuC,OAAQ,IACR1F,MAAO,IACP7C,KAAM,IACN6G,OAAQ,KCbM,IAAA6B,GAAA,CACdj0B,KAAM,MACN+F,IAAK,CAAC,EAAE,EAAE,GACVC,IAAK,CAAC,IAAI,IAAI,KACd4iB,QAAS,CAAC,MAAO,aAAc,aAC/BC,MAAO,CAAC,OAERF,IAAK,SAASsL,GACb,IAAoDC,EAAIC,EAAIC,EAAIzL,EAAKxiB,EAAjE0kB,EAAIoJ,EAAI,GAAG,IAAKI,EAAIJ,EAAI,GAAG,IAAK3qB,EAAI2qB,EAAI,GAAG,IAA2B/nC,EAAE,EAE5E,GAAU,IAANmoC,EAAS,MAAsB,CAAfluB,EAAU,IAAJmD,EAAenD,EAAKA,GAM9C,IAHA+tB,EAAK,EAAI5qB,GADT6qB,EAAK7qB,EAAI,GAAMA,GAAK,EAAI+qB,GAAK/qB,EAAI+qB,EAAI/qB,EAAI+qB,GAGzC1L,EAAM,CAAC,EAAG,EAAG,GACPz8B,EAAE,IACPkoC,EAAKvJ,EAAI,EAAI,IAAO3+B,EAAI,IACnB,EAAIkoC,IAAOA,EAAK,GAAKA,IAC1BjuB,EAAM,EAAIiuB,EAAK,EAAIF,EAAiB,GAAXC,EAAKD,GAAUE,EACxC,EAAIA,EAAK,EAAID,EACb,EAAIC,EAAK,EAAKF,GAAMC,EAAKD,IAAO,EAAI,EAAIE,GAAM,EAC9CF,EACAvL,EAAIz8B,KAAa,IAANia,EAGZ,OAAOwiB,CACP,GC3Ba,SAAS2L,GAAKC,GAKzB,IAAChhC,EAHA5G,MAAMC,QAAQ2nC,IAAUA,EAAMC,MAAKD,EAAQphC,OAAOqhC,OAAOlmC,YACzDimC,aAAiBE,SAAQF,GAASA,GAKtC,IAAIG,EFaL,SAAeC,GACd,IAAIlqB,EAA0BmqB,EAAvBC,EAAQ,GAAIC,EAAQ,EAG3B,GAAoB,iBAATH,EACV,MAAO,CAAEC,MAAO,MAAOrhC,OAAQ,CAACohC,IAAS,IAAY,MAAPA,KAAqB,EAAU,IAAPA,GAAkBG,MAAO,GAEhG,GAAoB,iBAATH,EAAmB,MAAO,CAAEC,MAAO,MAAOrhC,OAAQ,CAACohC,IAAS,IAAY,MAAPA,KAAqB,EAAU,IAAPA,GAAkBG,MAAO,GAK7H,GAHAH,EAAOxhC,OAAOwhC,GAAMp8B,cAGhBw8B,GAAMJ,GACTE,EAAQE,GAAMJ,GAAMvmC,QACpBwmC,EAAQ,WAIJ,GAAa,gBAATD,EACRG,EAAQ,EACRF,EAAQ,MACRC,EAAQ,CAAC,EAAG,EAAG,QAIX,GAAgB,MAAZF,EAAK,GAAY,CACzB,IAAIK,EAAOL,EAAKvmC,MAAM,GAClB4P,EAAOg3B,EAAKvpC,OAEhBqpC,EAAQ,EADM92B,GAAQ,GAIrB62B,EAAQ,CACP95B,SAASi6B,EAAK,GAAKA,EAAK,GAAI,IAC5Bj6B,SAASi6B,EAAK,GAAKA,EAAK,GAAI,IAC5Bj6B,SAASi6B,EAAK,GAAKA,EAAK,GAAI,KAEhB,IAATh3B,IACH82B,EAAQ/5B,SAASi6B,EAAK,GAAKA,EAAK,GAAI,IAAM,OAI3CH,EAAQ,CACP95B,SAASi6B,EAAK,GAAKA,EAAK,GAAI,IAC5Bj6B,SAASi6B,EAAK,GAAKA,EAAK,GAAI,IAC5Bj6B,SAASi6B,EAAK,GAAKA,EAAK,GAAI,KAEhB,IAATh3B,IACH82B,EAAQ/5B,SAASi6B,EAAK,GAAKA,EAAK,GAAI,IAAM,MAIvCH,EAAM,KAAIA,EAAM,GAAK,GACrBA,EAAM,KAAIA,EAAM,GAAK,GACrBA,EAAM,KAAIA,EAAM,GAAK,GAE1BD,EAAQ,KACR,MAGI,GAAInqB,EAAI,yGAAyGwqB,KAAKN,GAAO,CACjI,IAAI30B,EAAOyK,EAAE,GAETyqB,EAAiB,UADrBN,EAAQ50B,EAAK8N,QAAQ,KAAM,KACG,EAAc,SAAV8mB,EAAmB,EAAI,EACzDC,EAAQpqB,EAAE,GAAG0qB,OAAOhlB,MAAM,mBAGZ,UAAVykB,IAAmBA,EAAQC,EAAMz6B,SA2CrC06B,GAzCAD,EAAQA,EAAMO,KAAI,SAAUzzB,EAAGzV,GAE9B,GAAwB,MAApByV,EAAEA,EAAElW,OAAS,GAGhB,OAFAkW,EAAI0zB,WAAW1zB,GAAK,IAEV,IAANzV,EAAgByV,EAEN,QAAVizB,EAA4B,IAAJjzB,EAEX,MAAbizB,EAAM,GAAuB,IAAJjzB,EAEZ,MAAbizB,EAAM,IAAe1oC,EAEX,QAAV0oC,EAA4B,IAAJjzB,EAEd,QAAVizB,EAAwB1oC,EAAI,EAAQ,IAAJyV,EAAc,IAAJA,EAE7B,MAAbizB,EAAM,IAAe1oC,EAEX,UAAV0oC,EAA8B,GAAJjzB,EAEhB,UAAVizB,EAA0B1oC,EAAI,EAAQ,GAAJyV,EAAc,IAAJA,EAEzCA,EAN4BA,EANI,IAAJA,EAgBpC,GAAiB,MAAbizB,EAAM1oC,IAAqB,IAANA,GAAuC,MAA5B0oC,EAAMA,EAAMnpC,OAAS,GAAa,CAErE,QAAoBqF,IAAhBkjC,GAASryB,GAAkB,OAAOqyB,GAASryB,GAE/C,GAAIA,EAAE2zB,SAAS,OAAQ,OAAOD,WAAW1zB,GAEzC,GAAIA,EAAE2zB,SAAS,QAAS,OAAuB,IAAhBD,WAAW1zB,GAC1C,GAAIA,EAAE2zB,SAAS,QAAS,OAAuB,IAAhBD,WAAW1zB,GAAW,IACrD,GAAIA,EAAE2zB,SAAS,OAAQ,OAAuB,IAAhBD,WAAW1zB,GAAWpL,KAAK+T,EACzD,CACD,MAAU,SAAN3I,EAAqB,EAClB0zB,WAAW1zB,EACrB,KAEgBlW,OAASypC,EAAOL,EAAMr/B,MAAQ,CAC5C,KAGQ,mBAAmBmD,KAAKg8B,KAChCE,EAAQF,EAAKY,MAAM,aAAaH,KAAI,SAAUzmC,GAC7C,OAAO0mC,WAAW1mC,EACrB,IAEEimC,EAAQD,EAAKY,MAAM,cAAcnyB,KAAK,KAAK7K,eAAiB,OAG7D,MAAO,CACNq8B,QACArhC,OAAQshC,EACRC,QAEF,CE5IcU,CAAMjB,GAEnB,IAAKG,EAAOE,MAAO,MAAO,GAE1B,MAAM7uB,EAA0B,MAApB2uB,EAAOE,MAAM,GAAaX,GAAIluB,IAAM4iB,GAAI5iB,IAC9CC,EAA0B,MAApB0uB,EAAOE,MAAM,GAAaX,GAAIjuB,IAAM2iB,GAAI3iB,IAapD,OAXAzS,EAAS5G,MAAM,IACR,GAAK4J,KAAKwP,IAAIxP,KAAKyP,IAAI0uB,EAAOnhC,OAAO,GAAIwS,EAAI,IAAKC,EAAI,IAC7DzS,EAAO,GAAKgD,KAAKwP,IAAIxP,KAAKyP,IAAI0uB,EAAOnhC,OAAO,GAAIwS,EAAI,IAAKC,EAAI,IAC7DzS,EAAO,GAAKgD,KAAKwP,IAAIxP,KAAKyP,IAAI0uB,EAAOnhC,OAAO,GAAIwS,EAAI,IAAKC,EAAI,IAErC,MAApB0uB,EAAOE,MAAM,KAChBrhC,EAAS0gC,GAAItL,IAAIp1B,IAGlBA,EAAOtD,KAAKsG,KAAKwP,IAAIxP,KAAKyP,IAAI0uB,EAAOI,MAAO,GAAI,IAEzCvhC,CACR,CCRO,SAASkiC,GAASlB,GACvB,MAAqB,iBAAVA,EACFA,EAEFrxB,GAASqxB,EAClB,CFQA5L,GAAIsL,IAAM,SAAStL,GAClB,IAMEkC,EAAMvhB,EANJoF,EAAIia,EAAI,GAAG,IACbiB,EAAIjB,EAAI,GAAG,IACX/8B,EAAI+8B,EAAI,GAAG,IACX5iB,EAAMxP,KAAKwP,IAAI2I,EAAGkb,EAAGh+B,GACrBoa,EAAMzP,KAAKyP,IAAI0I,EAAGkb,EAAGh+B,GACrBqM,EAAQ+N,EAAMD,EAkChB,OA/BIC,IAAQD,EACX8kB,EAAI,EAEInc,IAAM1I,EACd6kB,GAAKjB,EAAIh+B,GAAKqM,EAEN2xB,IAAM5jB,EACd6kB,EAAI,GAAKj/B,EAAI8iB,GAAKzW,EAEVrM,IAAMoa,IACd6kB,EAAI,GAAKnc,EAAIkb,GAAI3xB,IAGlB4yB,EAAIt0B,KAAKwP,IAAQ,GAAJ8kB,EAAQ,MAEb,IACPA,GAAK,KAGNvhB,GAAKvD,EAAMC,GAAO,EAYX,CAAC6kB,EAAO,KAVX7kB,IAAQD,EACP,EAEIuD,GAAK,GACTrR,GAAS+N,EAAMD,GAGf9N,GAAS,EAAI+N,EAAMD,IAGA,IAAJuD,EACrB,EE5CA,MAAMosB,GAAiB,KAQjB7nB,GAAQ,CAAA,EAKd,IAAI8nB,GAAY,EAQT,SAASC,GAAUrB,GACxB,GAAqB,IAAjBA,EAAM9oC,OACR,OAAO8oC,EAET,MAAMhnB,EAASgnB,EAAMnmC,QAErB,OADAmf,EAAO,GAAK,EACLA,CACT,CAMO,SAASsoB,GAAWtB,GACzB,MAAMhnB,EAASub,GAAI6B,MAAMhC,GAAIG,IAAIyL,IAEjC,OADAhnB,EAAO,GAAKgnB,EAAM,GACXhnB,CACT,CAMO,SAASuoB,GAAWvB,GACzB,MAAMhnB,EAASub,GAAIH,IAAIgC,GAAM7B,IAAIyL,IAEjC,OADAhnB,EAAO,GAAKgnB,EAAM,GACXhnB,CACT,CAMO,SAASwoB,GAAW1B,GACzB,GAAIxmB,GAAMla,eAAe0gC,GACvB,OAAOxmB,GAAMwmB,GAEf,GAAIsB,IAAaD,GAAgB,CAC/B,IAAIxpC,EAAI,EACR,IAAK,MAAM2F,KAAOgc,GACE,IAAP,EAAN3hB,cACI2hB,GAAMhc,KACX8jC,GAGP,CAED,MAAMpB,EAAQyB,GAAU3B,GACxB,GAAqB,IAAjBE,EAAM9oC,OACR,MAAM,IAAIqH,MAAM,oBAAsBuhC,EAAI,cAE5C,IAAK,MAAM/yB,KAAKizB,EACd,GAAIzb,MAAMxX,GACR,MAAM,IAAIxO,MAAM,oBAAsBuhC,EAAI,cAM9C,OAHA4B,GAAU1B,GACV1mB,GAAMwmB,GAAKE,IACToB,GACKpB,CACT,CASO,SAAS2B,GAAQ3B,GACtB,OAAI5nC,MAAMC,QAAQ2nC,GACTA,EAEFwB,GAAWxB,EACpB,CAOO,SAAS0B,GAAU1B,GAKxB,OAJAA,EAAM,GAAKnmB,GAAOmmB,EAAM,GAAK,GAAO,EAAG,EAAG,KAC1CA,EAAM,GAAKnmB,GAAOmmB,EAAM,GAAK,GAAO,EAAG,EAAG,KAC1CA,EAAM,GAAKnmB,GAAOmmB,EAAM,GAAK,GAAO,EAAG,EAAG,KAC1CA,EAAM,GAAKnmB,GAAMmmB,EAAM,GAAI,EAAG,GACvBA,CACT,CAMO,SAASrxB,GAASqxB,GACvB,IAAI7lB,EAAI6lB,EAAM,GACV7lB,IAAU,EAAJA,KACRA,EAAKA,EAAI,GAAO,GAElB,IAAIkb,EAAI2K,EAAM,GACV3K,IAAU,EAAJA,KACRA,EAAKA,EAAI,GAAO,GAElB,IAAIh+B,EAAI2oC,EAAM,GACV3oC,IAAU,EAAJA,KACRA,EAAKA,EAAI,GAAO,GAGlB,MAAO,QAAU8iB,EAAI,IAAMkb,EAAI,IAAMh+B,EAAI,UADlBkF,IAAbyjC,EAAM,GAAmB,EAAIh+B,KAAKiZ,MAAiB,IAAX+kB,EAAM,IAAY,KACjB,GACrD,CAMO,SAAS4B,GAAc9B,GAC5B,IAEE,OADA0B,GAAW1B,IACJ,CACR,CAAC,MAAO+B,GACP,OAAO,CACR,CACH,CCvKA,MAAMC,GACJ,WAAAjsC,GAKEE,KAAKgsC,OAAS,GAMdhsC,KAAKisC,WAAa,EAMlBjsC,KAAKksC,cAAgB,EACtB,CAKD,KAAAvnC,GACE3E,KAAKgsC,OAAS,GACdhsC,KAAKisC,WAAa,CACnB,CAKD,cAAAE,GACE,OAAOnsC,KAAKisC,WAAajsC,KAAKksC,aAC/B,CAKD,MAAAE,GACE,GAAIpsC,KAAKmsC,iBAAkB,CACzB,IAAIvqC,EAAI,EACR,IAAK,MAAM2F,KAAOvH,KAAKgsC,OAAQ,CAC7B,MAAMK,EAAYrsC,KAAKgsC,OAAOzkC,GACZ,IAAP,EAAN3F,MAAmByqC,EAAU5lC,uBACzBzG,KAAKgsC,OAAOzkC,KACjBvH,KAAKisC,WAEV,CACF,CACF,CAQD,GAAA7iC,CAAIyxB,EAAKwB,EAAa4N,GACpB,MAAM1iC,EAAMyF,GAAO6tB,EAAKwB,EAAa4N,GACrC,OAAO1iC,KAAOvH,KAAKgsC,OAAShsC,KAAKgsC,OAAOzkC,GAAO,IAChD,CAQD,GAAAwC,CAAI8wB,EAAKwB,EAAa4N,EAAOoC,GAC3B,MAAM9kC,EAAMyF,GAAO6tB,EAAKwB,EAAa4N,GACrCjqC,KAAKgsC,OAAOzkC,GAAO8kC,IACjBrsC,KAAKisC,UACR,CASD,OAAAK,CAAQC,GACNvsC,KAAKksC,cAAgBK,EACrBvsC,KAAKosC,QACN,EASH,SAASp/B,GAAO6tB,EAAKwB,EAAa4N,GAEhC,OAAO5N,EAAc,IAAMxB,EAAM,KADboP,EAAQkB,GAASlB,GAAS,OAEhD,CAEA,IAAAuC,GAAeT,GAOR,MAAMU,GAAS,IAAIV,GC5GX,IAAAW,GACJ,UADIA,GAEJ,UAFIA,GAGL,SAHKA,GAIJ,SAJIA,GAKG,gBALHA,GAMG,gBANHA,GAOH,UAPGA,GAQH,UARGA,GASL,SATKA,GAUR,MCmYP,IAAAC,GAtVA,cAAwBliC,EAItB,WAAA3K,CAAY6K,GACV1F,QAKAjF,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAML3H,KAAK4sC,YAAcjiC,EAAQkiC,WAK3B,MAAM/3B,EAAapO,OAAO8C,OAAO,CAAE,EAAEmB,GACH,iBAAvBA,EAAQmK,oBACVA,EAAWA,WAClBpO,OAAO8C,OAAOsL,EAAYnK,EAAQmK,aAGpCA,EAAW43B,SACWlmC,IAApBmE,EAAQmiC,QAAwBniC,EAAQmiC,QAAU,EACpD74B,GAC+C,iBAAtCa,EAAW43B,IAClB,kCAGF53B,EAAW43B,SACWlmC,IAApBmE,EAAQoiC,SAAwBpiC,EAAQoiC,QAC1Cj4B,EAAW43B,IAAyB/hC,EAAQqiC,OAC5Cl4B,EAAW43B,SACiBlmC,IAA1BmE,EAAQsiC,cAA8BtiC,EAAQsiC,cAAgBxyB,IAChE3F,EAAW43B,SACiBlmC,IAA1BmE,EAAQuiC,cAA8BviC,EAAQuiC,cAAgB,EAChEp4B,EAAW43B,SACWlmC,IAApBmE,EAAQwiC,QAAwBxiC,EAAQwiC,SAAW1yB,IACrD3F,EAAW43B,SACWlmC,IAApBmE,EAAQyiC,QAAwBziC,EAAQyiC,QAAU3yB,IAMpDza,KAAKqtC,gBACsB7mC,IAAzBsO,EAAWw4B,UAA0Bx4B,EAAWw4B,UAAY,kBACvDx4B,EAAWw4B,UAElBttC,KAAKmJ,cAAc2L,GAMnB9U,KAAKutC,OAAS,IACf,CAMD,aAAAC,GACE,OAAOxtC,KAAK4sC,WACb,CAKD,YAAAa,GACE,OAAOztC,KAAKqtC,UACb,CASD,aAAAK,CAAcC,GAEZ,MAAMnhC,EACJxM,KAAKutC,QACa,CAChBK,MAAO5tC,KACP2tC,aAAqBnnC,IAAZmnC,GAA+BA,GAEtCX,EAAShtC,KAAK6tC,YAWpB,OAVArhC,EAAMsgC,QAAUhpB,GAAM7X,KAAKiZ,MAA0B,IAApBllB,KAAK8tC,cAAsB,IAAK,EAAG,GACpEthC,EAAMugC,QAAU/sC,KAAK+tC,aACrBvhC,EAAMgN,OAASxZ,KAAKqf,YACpB7S,EAAMwgC,YAAoBxmC,IAAXwmC,GAAyBxgC,EAAMmhC,QAAqBX,EAAXvyB,IACxDjO,EAAMygC,cAAgBjtC,KAAKguC,mBAC3BxhC,EAAM0gC,cAAgBjhC,KAAKyP,IAAI1b,KAAKiuC,mBAAoB,GACxDzhC,EAAM2gC,QAAUntC,KAAKkuC,aACrB1hC,EAAM4gC,QAAUptC,KAAKmuC,aACrBnuC,KAAKutC,OAAS/gC,EAEPA,CACR,CAQD,cAAA4hC,CAAe1jC,GACb,OAAOnC,GACR,CAQD,mBAAA8lC,CAAoBC,GAClB,OAAO/lC,GACR,CASD,SAAA8W,GACE,OACErf,KAAKoJ,IAAIsjC,GAEZ,CASD,gBAAAsB,GACE,OAA8BhuC,KAAKoJ,IAAIsjC,GACxC,CASD,gBAAAuB,GACE,OAA8BjuC,KAAKoJ,IAAIsjC,GACxC,CASD,UAAAwB,GACE,OAA8BluC,KAAKoJ,IAAIsjC,GACxC,CASD,UAAAyB,GACE,OAA8BnuC,KAAKoJ,IAAIsjC,GACxC,CAQD,UAAAoB,GACE,OAA8B9tC,KAAKoJ,IAAIsjC,GACxC,CAMD,cAAA6B,GACE,OAAOhmC,GACR,CASD,UAAAwlC,GACE,OAA+B/tC,KAAKoJ,IAAIsjC,GACzC,CASD,SAAAmB,GACE,OAAwC7tC,KAAKoJ,IAAIsjC,GAClD,CAMD,aAAA8B,CAAc3B,GACZ7sC,KAAK4sC,YAAcC,EACnB7sC,KAAK6H,SACN,CASD,SAAAia,CAAUtI,GACRxZ,KAAK+J,IAAI2iC,GAAsBlzB,EAChC,CAQD,gBAAAi1B,CAAiBxB,GACfjtC,KAAK+J,IAAI2iC,GAA8BO,EACxC,CAQD,gBAAAyB,CAAiBxB,GACfltC,KAAK+J,IAAI2iC,GAA8BQ,EACxC,CAUD,UAAAyB,CAAWvB,GACTptC,KAAK+J,IAAI2iC,GAAwBU,EAClC,CAUD,UAAAwB,CAAWzB,GACTntC,KAAK+J,IAAI2iC,GAAwBS,EAClC,CAQD,UAAA0B,CAAW/B,GACT74B,GAA0B,iBAAZ64B,EAAsB,kCACpC9sC,KAAK+J,IAAI2iC,GAAuBI,EACjC,CAQD,UAAAgC,CAAW/B,GACT/sC,KAAK+J,IAAI2iC,GAAuBK,EACjC,CASD,SAAAgC,CAAUC,GACRhvC,KAAK+J,IAAI2iC,GAAuBsC,EACjC,CAKD,eAAAvuC,GACMT,KAAKutC,SACPvtC,KAAKutC,OAAOK,MAAQ,KACpB5tC,KAAKutC,OAAS,MAEhBtoC,MAAMxE,iBACP,GC1YYqH,GAMF,YANEA,GAaD,aAbCA,GAsBD,aAtBCA,GA+BA,cA/BAA,GAwCG,iBCxCHmnC,GACF,EADEA,GAEA,ECFAC,GAAA,CACbC,OAAQ,SACRC,WAAY,aACZC,SAAU,YCFL,MAAMC,GAAmB,GAMnBC,GAAoB,ICE1B,SAASC,GAAah2B,EAAQi2B,EAAYC,GAC/C,OAAA,SASYhzB,EAAQC,EAAYjJ,EAAMi8B,EAAUC,GAC5C,IAAKlzB,EACH,OAEF,IAAKC,IAAe8yB,EAClB,OAAO/yB,EAET,MAAMmzB,EAAYJ,EAAa,EAAI/7B,EAAK,GAAKiJ,EACvCmzB,EAAaL,EAAa,EAAI/7B,EAAK,GAAKiJ,EACxCozB,EAASH,EAAcA,EAAY,GAAK,EACxCI,EAASJ,EAAcA,EAAY,GAAK,EAC9C,IAAIx1B,EAAOZ,EAAO,GAAKq2B,EAAY,EAAIE,EACnCz1B,EAAOd,EAAO,GAAKq2B,EAAY,EAAIE,EACnC11B,EAAOb,EAAO,GAAKs2B,EAAa,EAAIE,EACpCz1B,EAAOf,EAAO,GAAKs2B,EAAa,EAAIE,EAIpC51B,EAAOE,IACTF,GAAQE,EAAOF,GAAQ,EACvBE,EAAOF,GAELC,EAAOE,IACTF,GAAQE,EAAOF,GAAQ,EACvBE,EAAOF,GAGT,IAAIhD,EAAIyM,GAAMpH,EAAO,GAAItC,EAAME,GAC3BhD,EAAIwM,GAAMpH,EAAO,GAAIrC,EAAME,GAG/B,GAAIo1B,GAAYD,GAAU/yB,EAAY,CACpC,MAAMszB,EAAQ,GAAKtzB,EACnBtF,IACG44B,EAAQhkC,KAAKsW,IAAI,EAAItW,KAAKyP,IAAI,EAAGtB,EAAOsC,EAAO,IAAMuzB,GACtDA,EAAQhkC,KAAKsW,IAAI,EAAItW,KAAKyP,IAAI,EAAGgB,EAAO,GAAKpC,GAAQ21B,GACvD34B,IACG24B,EAAQhkC,KAAKsW,IAAI,EAAItW,KAAKyP,IAAI,EAAGrB,EAAOqC,EAAO,IAAMuzB,GACtDA,EAAQhkC,KAAKsW,IAAI,EAAItW,KAAKyP,IAAI,EAAGgB,EAAO,GAAKnC,GAAQ01B,EACxD,CAED,MAAO,CAAC54B,EAAGC,EAEb,CACJ,CAMO,SAAS0R,GAAKtM,GACnB,OAAOA,CACT,CC1DA,SAASwzB,GACPvzB,EACAwzB,EACAC,EACAC,GAEA,MAAMC,EAAcl0B,GAAS+zB,GAAaC,EAAa,GACjDG,EAAcl0B,GAAU8zB,GAAaC,EAAa,GAExD,OAAIC,EACKpkC,KAAKwP,IAAIkB,EAAY1Q,KAAKyP,IAAI40B,EAAaC,IAE7CtkC,KAAKwP,IAAIkB,EAAY1Q,KAAKwP,IAAI60B,EAAaC,GACpD,CAcA,SAASC,GAA2B7zB,EAAYswB,EAAeC,GAC7D,IAAIuD,EAASxkC,KAAKwP,IAAIkB,EAAYswB,GAalC,OAVAwD,GACExkC,KAAKsW,IAAI,EAHG,GAGStW,KAAKyP,IAAI,EAAGiB,EAAaswB,EAAgB,IAHlD,GAIZ,EACEC,IACFuD,EAASxkC,KAAKyP,IAAI+0B,EAAQvD,GAC1BuD,GACExkC,KAAKsW,IAAI,EARC,GAQWtW,KAAKyP,IAAI,EAAGwxB,EAAgBvwB,EAAa,IARpD,GAUV,GAEGmH,GAAM2sB,EAAQvD,EAAgB,EAAmB,EAAhBD,EAC1C,CASO,SAASyD,GACdC,EACAjB,EACAS,EACAE,GAGA,OADAX,OAAoBlpC,IAAXkpC,GAAuBA,EAChC,SAQY/yB,EAAYjb,EAAWgS,EAAMi8B,GACrC,QAAmBnpC,IAAfmW,EAA0B,CAC5B,MAAMswB,EAAgB0D,EAAY,GAC5BzD,EAAgByD,EAAYA,EAAYxvC,OAAS,GACjDyvC,EAAeT,EACjBD,GACEjD,EACAkD,EACAz8B,EACA28B,GAEFpD,EAGJ,GAAI0C,EACF,OAAKD,EAGEc,GACL7zB,EACAi0B,EACA1D,GALOppB,GAAMnH,EAAYuwB,EAAe0D,GAS5C,MAAMC,EAAS5kC,KAAKwP,IAAIm1B,EAAcj0B,GAChC4iB,EAAItzB,KAAKuT,MAAMhe,EAAkBmvC,EAAaE,EAAQnvC,IAC5D,OAAIivC,EAAYpR,GAAKqR,GAAgBrR,EAAIoR,EAAYxvC,OAAS,EACrDwvC,EAAYpR,EAAI,GAElBoR,EAAYpR,EACpB,CAGH,CACJ,CAWO,SAASuR,GACdC,EACA9D,EACAC,EACAwC,EACAS,EACAE,GAKA,OAHAX,OAAoBlpC,IAAXkpC,GAAuBA,EAChCxC,OAAkC1mC,IAAlB0mC,EAA8BA,EAAgB,EAE9D,SAQYvwB,EAAYjb,EAAWgS,EAAMi8B,GACrC,QAAmBnpC,IAAfmW,EAA0B,CAC5B,MAAMi0B,EAAeT,EACjBD,GACEjD,EACAkD,EACAz8B,EACA28B,GAEFpD,EAGJ,GAAI0C,EACF,OAAKD,EAGEc,GACL7zB,EACAi0B,EACA1D,GALOppB,GAAMnH,EAAYuwB,EAAe0D,GAS5C,MAAMz1B,EAAY,KACZ61B,EAAe/kC,KAAKkZ,KACxBlZ,KAAKsW,IAAI0qB,EAAgB2D,GAAgB3kC,KAAKsW,IAAIwuB,GAAS51B,GAEvDJ,GAAUrZ,GAAa,GAAMyZ,GAAa,GAC1C01B,EAAS5kC,KAAKwP,IAAIm1B,EAAcj0B,GAChCs0B,EAAkBhlC,KAAKuT,MAC3BvT,KAAKsW,IAAI0qB,EAAgB4D,GAAU5kC,KAAKsW,IAAIwuB,GAASh2B,GAEjDm2B,EAAYjlC,KAAKyP,IAAIs1B,EAAcC,GAEzC,OAAOntB,GADempB,EAAgBhhC,KAAKC,IAAI6kC,EAAOG,GAC1BhE,EAAe0D,EAC5C,CAGH,CACJ,CAUO,SAASO,GACdlE,EACAC,EACAwC,EACAS,EACAE,GAIA,OAFAX,OAAoBlpC,IAAXkpC,GAAuBA,EAEhC,SAQY/yB,EAAYjb,EAAWgS,EAAMi8B,GACrC,QAAmBnpC,IAAfmW,EAA0B,CAC5B,MAAMi0B,EAAeT,EACjBD,GACEjD,EACAkD,EACAz8B,EACA28B,GAEFpD,EAEJ,OAAKyC,GAAWC,EAGTa,GACL7zB,EACAi0B,EACA1D,GALOppB,GAAMnH,EAAYuwB,EAAe0D,EAO3C,CAGH,CACJ,CCnOO,SAAStnB,GAAQ1M,GACtB,QAAiBpW,IAAboW,EACF,OAAO,CAGX,CAMO,SAASoM,GAAKpM,GACnB,QAAiBpW,IAAboW,EACF,OAAOA,CAGX,CAMO,SAASw0B,GAAczvC,GAC5B,MAAM0vC,EAAS,EAAIplC,KAAK+T,GAAMre,EAC9B,OAAA,SAMYib,EAAU+yB,GAClB,OAAIA,EACK/yB,OAGQpW,IAAboW,EACFA,EAAW3Q,KAAKuT,MAAM5C,EAAWy0B,EAAQ,IAAOA,OADlD,CAMF,CACJ,CAMO,SAASC,GAAiBn2B,GAC/B,MAAMnP,OAAkBxF,IAAd2U,EAA0BwJ,GAAU,GAAKxJ,EACnD,OAAA,SAMYyB,EAAU+yB,GAClB,OAAIA,QAAyBnpC,IAAboW,EACPA,EAGL3Q,KAAKmP,IAAIwB,IAAa5Q,EACjB,EAEF4Q,CAET,CACJ,CCizDA,SAAS20B,GAAkB31B,EAAU41B,GACnCC,YAAW,WACT71B,EAAS41B,EACV,GAAE,EACL,CAMO,SAASE,GAAuB/mC,GACrC,QAAuBnE,IAAnBmE,EAAQ6O,OAAsB,CAChC,MAAMk2B,OAC+BlpC,IAAnCmE,EAAQgnC,wBACJhnC,EAAQgnC,uBAEd,OAAOnC,GAAa7kC,EAAQ6O,OAAQ7O,EAAQinC,oBAAqBlC,EAClE,CAED,MAAMvwB,EAAayL,GAAiBjgB,EAAQwU,WAAY,aACxD,IAA2B,IAAvBxU,EAAQknC,YAAuB1yB,EAAWsC,WAAY,CACxD,MAAMjI,EAAS2F,EAAWE,YAAYvb,QAGtC,OAFA0V,EAAO,IAAMiB,IACbjB,EAAO,GAAKiB,IACL+0B,GAAah2B,GAAQ,GAAO,EACpC,CAED,OAAOs4B,EACT,CAOO,SAASC,GAA2BpnC,GACzC,IAAIqnC,EACA/E,EACAC,EAOJ,IAAIC,OACkB3mC,IAApBmE,EAAQwiC,QAAwBxiC,EAAQwiC,QA5sDnB,EA8sDnBC,OACkB5mC,IAApBmE,EAAQyiC,QAAwBziC,EAAQyiC,QAPnB,GASvB,MAAM6E,OACmBzrC,IAAvBmE,EAAQsnC,WAA2BtnC,EAAQsnC,WATnB,EAWpBJ,OACmBrrC,IAAvBmE,EAAQknC,YAA2BlnC,EAAQknC,WAEvCnC,OACmClpC,IAAvCmE,EAAQunC,4BACJvnC,EAAQunC,2BAGR7B,OACuB7pC,IAA3BmE,EAAQ0lC,gBAA+B1lC,EAAQ0lC,eAE3ClxB,EAAayL,GAAiBjgB,EAAQwU,WAAY,aAClDgzB,EAAahzB,EAAWE,YAC9B,IAAIuyB,EAAsBjnC,EAAQinC,oBAC9Bp4B,EAAS7O,EAAQ6O,OAMrB,GALKq4B,GAAer4B,IAAU2F,EAAWsC,aACvCmwB,GAAsB,EACtBp4B,EAAS24B,QAGiB3rC,IAAxBmE,EAAQgmC,YAA2B,CACrC,MAAMA,EAAchmC,EAAQgmC,YAC5B1D,EAAgB0D,EAAYxD,GAC5BD,OAC2B1mC,IAAzBmqC,EAAYvD,GACRuD,EAAYvD,GACZuD,EAAYA,EAAYxvC,OAAS,GAGrC6wC,EADErnC,EAAQynC,oBACa1B,GACrBC,EACAjB,GACCkC,GAAuBp4B,EACxB62B,GAGqBc,GACrBlE,EACAC,EACAwC,GACCkC,GAAuBp4B,EACxB62B,EAGR,KAAS,CAEL,MAKMgC,GALQF,EAGVlmC,KAAKyP,IAAIU,GAAS+1B,GAAa91B,GAAU81B,IADxC,IAAMryB,GAAgBG,QAAWd,EAAWmC,oBAIxCiuB,GAAoBtjC,KAAKC,IA/DV,EAzsDH,GA0wDfomC,EACJD,EACApmC,KAAKC,IAnEiB,EAmEMqmC,IAG9BtF,EAAgBtiC,EAAQsiC,mBACFzmC,IAAlBymC,EACFE,EAAU,EAEVF,EAAgBoF,EAAuBpmC,KAAKC,IAAI+lC,EAAY9E,GAI9DD,EAAgBviC,EAAQuiC,mBACF1mC,IAAlB0mC,IAGEA,OAFoB1mC,IAApBmE,EAAQyiC,aACoB5mC,IAA1BmE,EAAQsiC,cACMA,EAAgBhhC,KAAKC,IAAI+lC,EAAY7E,GAErCiF,EAAuBpmC,KAAKC,IAAI+lC,EAAY7E,GAG9CkF,GAKpBlF,EACED,EACAlhC,KAAKuT,MACHvT,KAAKsW,IAAI0qB,EAAgBC,GAAiBjhC,KAAKsW,IAAI0vB,IAEvD/E,EAAgBD,EAAgBhhC,KAAKC,IAAI+lC,EAAY7E,EAAUD,GAG7D6E,EADErnC,EAAQynC,oBACatB,GACrBmB,EACAhF,EACAC,EACAwC,GACCkC,GAAuBp4B,EACxB62B,GAGqBc,GACrBlE,EACAC,EACAwC,GACCkC,GAAuBp4B,EACxB62B,EAGL,CACD,MAAO,CACLmC,WAAYR,EACZ/E,cAAeA,EACfC,cAAeA,EACfC,QAASA,EACT8E,WAAYA,EAEhB,CAMO,SAASQ,GAAyB9nC,GAGvC,QAD6BnE,IAA3BmE,EAAQ+nC,gBAA+B/nC,EAAQ+nC,eAC7B,CAClB,MAAMC,EAAoBhoC,EAAQgoC,kBAClC,YAA0BnsC,IAAtBmsC,IAAyD,IAAtBA,EAC9BrB,MAEiB,IAAtBqB,EACKC,GAEwB,iBAAtBD,EACFvB,GAAcuB,GAEhBC,EACR,CACD,OAAOtpB,EACT,CAOO,SAASupB,GAAgBC,GAC9B,QAAIA,EAAUC,cAAgBD,EAAUE,eACjCC,GAAiBH,EAAUC,aAAcD,EAAUE,iBAItDF,EAAUI,mBAAqBJ,EAAUK,kBAGzCL,EAAUM,iBAAmBN,EAAUO,eAI7C,CAUA,SAASC,GAAkBl8B,EAAY1D,EAAMwlB,EAAUvc,EAAYC,GAEjE,MAAMwK,EAAWnb,KAAKwL,KAAKmF,GAC3B,IAAIyK,EAAWpb,KAAKyL,KAAKkF,GACrB22B,EAAOn8B,EAAW,GAAKgQ,EAAWhQ,EAAW,GAAKiQ,EAClDmsB,EAAOp8B,EAAW,GAAKgQ,EAAWhQ,EAAW,GAAKiQ,EACtDksB,IAAS7/B,EAAK,GAAK,EAAIwlB,EAAS,IAAMvc,EACtC62B,IAASta,EAAS,GAAKxlB,EAAK,GAAK,GAAKiJ,EAGtC0K,GAAYA,EAIZ,MAAO,CAHSksB,EAAOnsB,EAAWosB,EAAOnsB,EACzBmsB,EAAOpsB,EAAWmsB,EAAOlsB,EAG3C,CAEA,IAAAosB,GAvzDA,cAAmBhpC,EAIjB,WAAA3K,CAAY6K,GACV1F,QAKAjF,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAELgD,EAAUjE,OAAO8C,OAAO,CAAE,EAAEmB,GAM5B3K,KAAK0zC,OAAS,CAAC,EAAG,GAMlB1zC,KAAK2zC,YAAc,GAMnB3zC,KAAK4zC,oBAOL5zC,KAAK6zC,YAAcjpB,GAAiBjgB,EAAQwU,WAAY,aAMxDnf,KAAK8zC,cAAgB,CAAC,IAAK,KAM3B9zC,KAAK+zC,cAAgB,KAMrB/zC,KAAKg0C,kBAMLh0C,KAAKi0C,gBAMLj0C,KAAKk0C,YAAc,KAMnBl0C,KAAKm0C,gBAMLn0C,KAAKo0C,cAMLp0C,KAAKq0C,mBAAgB7tC,EAEjBmE,EAAQwU,YACVkK,KAEE1e,EAAQ+R,SACV/R,EAAQ+R,OAASyP,GAAmBxhB,EAAQ+R,OAAQ1c,KAAK6zC,cAEvDlpC,EAAQ6O,SACV7O,EAAQ6O,OAAS8S,GAAe3hB,EAAQ6O,OAAQxZ,KAAK6zC,cAGvD7zC,KAAKs0C,cAAc3pC,EACpB,CAMD,aAAA2pC,CAAc3pC,GACZ,MAAMmK,EAAapO,OAAO8C,OAAO,CAAE,EAAEmB,GACrC,IAAK,MAAMpD,KAAO2nC,UACTp6B,EAAWvN,GAEpBvH,KAAKmJ,cAAc2L,GAAY,GAE/B,MAAMy/B,EAA2BxC,GAA2BpnC,GAM5D3K,KAAKw0C,eAAiBD,EAAyBtH,cAM/CjtC,KAAKy0C,eAAiBF,EAAyBrH,cAM/CltC,KAAK00C,YAAcH,EAAyBtC,WAM5CjyC,KAAK20C,aAAehqC,EAAQgmC,YAM5B3wC,KAAK40C,SAAWjqC,EAAQkqC,QAMxB70C,KAAK80C,SAAWP,EAAyBpH,QAEzC,MAAM4H,EAAmBrD,GAAuB/mC,GAC1CqnC,EAAuBuC,EAAyB/B,WAChDwC,EAAqBvC,GAAyB9nC,GAMpD3K,KAAKi1C,aAAe,CAClBv4B,OAAQq4B,EACRp4B,WAAYq1B,EACZp1B,SAAUo4B,GAGZh1C,KAAKk1C,iBAAiC1uC,IAArBmE,EAAQiS,SAAyBjS,EAAQiS,SAAW,GACrE5c,KAAKm1C,uBACgB3uC,IAAnBmE,EAAQ+R,OAAuB/R,EAAQ+R,OAAS,WAEvBlW,IAAvBmE,EAAQgS,WACV3c,KAAK+7B,cAAcpxB,EAAQgS,iBACDnW,IAAjBmE,EAAQyqC,MACjBp1C,KAAKq1C,QAAQ1qC,EAAQyqC,KAExB,CAWD,WAAIP,GACF,OAAO70C,KAAK40C,QACb,CACD,WAAIC,CAAQA,GACV,IAAIS,EAAat1C,KAAK40C,SACtB50C,KAAK40C,SAAWC,EAChB,MAAMn4B,EAAS1c,KAAKu1C,oBACpB,GAAI74B,EAAQ,CACV,MAAM84B,EAAaX,GAAW,CAAC,EAAG,EAAG,EAAG,GACxCS,EAAaA,GAAc,CAAC,EAAG,EAAG,EAAG,GACrC,MAAM34B,EAAa3c,KAAK07B,gBAClB+Z,EACH94B,EAAa,GACb64B,EAAW,GAAKF,EAAW,GAAKA,EAAW,GAAKE,EAAW,IACxDE,EACH/4B,EAAa,GACb64B,EAAW,GAAKF,EAAW,GAAKA,EAAW,GAAKE,EAAW,IAC9Dx1C,KAAKm1C,kBAAkB,CAACz4B,EAAO,GAAK+4B,EAAS/4B,EAAO,GAAKg5B,GAC1D,CACF,CAUD,kBAAAC,CAAmBC,GACjB,MAAMjrC,EAAU3K,KAAKuJ,gBAerB,YAZ2B/C,IAAvBmE,EAAQgS,WACVhS,EAAQgS,WAAa3c,KAAK07B,gBAE1B/wB,EAAQyqC,KAAOp1C,KAAK61C,UAItBlrC,EAAQ+R,OAAS1c,KAAKu1C,oBAGtB5qC,EAAQiS,SAAW5c,KAAK81C,cAEjBpvC,OAAO8C,OAAO,CAAE,EAAEmB,EAASirC,EACnC,CAmCD,OAAAG,CAAQC,GACFh2C,KAAKi2C,UAAYj2C,KAAKk2C,gBACxBl2C,KAAKm2C,mBAAmB,GAE1B,MAAMjtB,EAAO,IAAI7mB,MAAM2B,UAAU7C,QACjC,IAAK,IAAIS,EAAI,EAAGA,EAAIsnB,EAAK/nB,SAAUS,EAAG,CACpC,IAAI+I,EAAU3G,UAAUpC,GACpB+I,EAAQ+R,SACV/R,EAAUjE,OAAO8C,OAAO,CAAE,EAAEmB,GAC5BA,EAAQ+R,OAASyP,GACfxhB,EAAQ+R,OACR1c,KAAK4uB,kBAGLjkB,EAAQyiB,SACVziB,EAAUjE,OAAO8C,OAAO,CAAE,EAAEmB,GAC5BA,EAAQyiB,OAASjB,GACfxhB,EAAQyiB,OACRptB,KAAK4uB,kBAGT1F,EAAKtnB,GAAK+I,CACX,CACD3K,KAAKo2C,gBAAgBlyC,MAAMlE,KAAMkpB,EAClC,CAKD,eAAAktB,CAAgBJ,GACd,IACIp6B,EADAy6B,EAAiBryC,UAAU7C,OAG7Bk1C,EAAiB,GACwB,mBAAlCryC,UAAUqyC,EAAiB,KAElCz6B,EAAW5X,UAAUqyC,EAAiB,KACpCA,GAGJ,IAAIz0C,EAAI,EACR,KAAOA,EAAIy0C,IAAmBr2C,KAAKi2C,UAAWr0C,EAAG,CAE/C,MAAM4K,EAAQxI,UAAUpC,GACpB4K,EAAMkQ,QACR1c,KAAKm1C,kBAAkB3oC,EAAMkQ,aAEZlW,IAAfgG,EAAM4oC,KACRp1C,KAAKq1C,QAAQ7oC,EAAM4oC,MACV5oC,EAAMmQ,YACf3c,KAAK+7B,cAAcvvB,EAAMmQ,iBAEJnW,IAAnBgG,EAAMoQ,UACR5c,KAAKk1C,YAAY1oC,EAAMoQ,SAE1B,CACD,GAAIhb,IAAMy0C,EAIR,YAHIz6B,GACF21B,GAAkB31B,GAAU,IAKhC,IAAIlO,EAAQqwB,KAAKC,MACbthB,EAAS1c,KAAK+zC,cAAcjwC,QAC5B6Y,EAAa3c,KAAKg0C,kBAClBp3B,EAAW5c,KAAKi0C,gBACpB,MAAMqC,EAAS,GACf,KAAO10C,EAAIy0C,IAAkBz0C,EAAG,CAC9B,MAAM+I,EAA2C3G,UAAUpC,GAErDkxC,EAAY,CAChBplC,MAAOA,EACPwtB,UAAU,EACV9N,OAAQziB,EAAQyiB,OAChB+Q,cAA+B33B,IAArBmE,EAAQwzB,SAAyBxzB,EAAQwzB,SAAW,IAC9DoY,OAAQ5rC,EAAQ4rC,QAAUnqC,GAC1BwP,SAAUA,GAmBZ,GAhBIjR,EAAQ+R,SACVo2B,EAAUC,aAAer2B,EACzBo2B,EAAUE,aAAeroC,EAAQ+R,OAAO5Y,QACxC4Y,EAASo2B,EAAUE,mBAGAxsC,IAAjBmE,EAAQyqC,MACVtC,EAAUI,iBAAmBv2B,EAC7Bm2B,EAAUK,iBAAmBnzC,KAAKw2C,qBAAqB7rC,EAAQyqC,MAC/Dz4B,EAAam2B,EAAUK,kBACdxoC,EAAQgS,aACjBm2B,EAAUI,iBAAmBv2B,EAC7Bm2B,EAAUK,iBAAmBxoC,EAAQgS,WACrCA,EAAam2B,EAAUK,uBAGA3sC,IAArBmE,EAAQiS,SAAwB,CAClCk2B,EAAUM,eAAiBx2B,EAC3B,MAAMjP,EACJkX,GAAOla,EAAQiS,SAAWA,EAAW3Q,KAAK+T,GAAI,EAAI/T,KAAK+T,IAAM/T,KAAK+T,GACpE8yB,EAAUO,eAAiBz2B,EAAWjP,EACtCiP,EAAWk2B,EAAUO,cACtB,CAGGR,GAAgBC,GAClBA,EAAU5X,UAAW,EAGrBxtB,GAASolC,EAAU3U,SAErBmY,EAAO3wC,KAAKmtC,EACb,CACD9yC,KAAK2zC,YAAYhuC,KAAK2wC,GACtBt2C,KAAKy2C,QAAQxH,GAAoB,GACjCjvC,KAAK02C,mBACN,CAOD,YAAAR,GACE,OAAOl2C,KAAK0zC,OAAOzE,IAAsB,CAC1C,CAOD,cAAA0H,GACE,OAAO32C,KAAK0zC,OAAOzE,IAAwB,CAC5C,CAMD,gBAAA2H,GAEE,IAAIxpB,EADJptB,KAAKy2C,QAAQxH,IAAqBjvC,KAAK0zC,OAAOzE,KAE9C,IAAK,IAAIrtC,EAAI,EAAGuE,EAAKnG,KAAK2zC,YAAYxyC,OAAQS,EAAIuE,IAAMvE,EAAG,CACzD,MAAM00C,EAASt2C,KAAK2zC,YAAY/xC,GAIhC,GAHI00C,EAAO,GAAG16B,UACZ21B,GAAkB+E,EAAO,GAAG16B,UAAU,IAEnCwR,EACH,IAAK,IAAI9I,EAAI,EAAG2G,EAAKqrB,EAAOn1C,OAAQmjB,EAAI2G,IAAM3G,EAAG,CAC/C,MAAMwuB,EAAYwD,EAAOhyB,GACzB,IAAKwuB,EAAU5X,SAAU,CACvB9N,EAAS0lB,EAAU1lB,OACnB,KACD,CACF,CAEJ,CACDptB,KAAK2zC,YAAYxyC,OAAS,EAC1BnB,KAAKq0C,cAAgBjnB,EACrBptB,KAAKk0C,YAAc,KACnBl0C,KAAKm0C,gBAAkB9lB,IACvBruB,KAAKo0C,cAAgB/lB,GACtB,CAKD,iBAAAqoB,GAKE,QAJiClwC,IAA7BxG,KAAK4zC,sBACPiD,qBAAqB72C,KAAK4zC,qBAC1B5zC,KAAK4zC,yBAAsBptC,IAExBxG,KAAKk2C,eACR,OAEF,MAAMlY,EAAMD,KAAKC,MACjB,IAAI8Y,GAAO,EACX,IAAK,IAAIl1C,EAAI5B,KAAK2zC,YAAYxyC,OAAS,EAAGS,GAAK,IAAKA,EAAG,CACrD,MAAM00C,EAASt2C,KAAK2zC,YAAY/xC,GAChC,IAAIm1C,GAAiB,EACrB,IAAK,IAAIzyB,EAAI,EAAG2G,EAAKqrB,EAAOn1C,OAAQmjB,EAAI2G,IAAM3G,EAAG,CAC/C,MAAMwuB,EAAYwD,EAAOhyB,GACzB,GAAIwuB,EAAU5X,SACZ,SAEF,MAAM8b,EAAUhZ,EAAM8U,EAAUplC,MAChC,IAAIupC,EACFnE,EAAU3U,SAAW,EAAI6Y,EAAUlE,EAAU3U,SAAW,EACtD8Y,GAAY,GACdnE,EAAU5X,UAAW,EACrB+b,EAAW,GAEXF,GAAiB,EAEnB,MAAMG,EAAWpE,EAAUyD,OAAOU,GAClC,GAAInE,EAAUC,aAAc,CAC1B,MAAMl2B,EAAKi2B,EAAUC,aAAa,GAC5Bj2B,EAAKg2B,EAAUC,aAAa,GAC5Bh2B,EAAK+1B,EAAUE,aAAa,GAC5Bh2B,EAAK81B,EAAUE,aAAa,GAClChzC,KAAKk0C,YAAcpB,EAAUE,aAC7B,MAAM37B,EAAIwF,EAAKq6B,GAAYn6B,EAAKF,GAC1BvF,EAAIwF,EAAKo6B,GAAYl6B,EAAKF,GAChC9c,KAAK+zC,cAAgB,CAAC18B,EAAGC,EAC1B,CACD,GAAIw7B,EAAUI,kBAAoBJ,EAAUK,iBAAkB,CAC5D,MAAMx2B,EACS,IAAbu6B,EACIpE,EAAUK,iBACVL,EAAUI,iBACVgE,GACGpE,EAAUK,iBAAmBL,EAAUI,kBAChD,GAAIJ,EAAU1lB,OAAQ,CACpB,MAAM1Z,EAAO1T,KAAKm3C,iBAAiBn3C,KAAK81C,eAClCsB,EAAwBp3C,KAAKi1C,aAAat4B,WAC9CA,EACA,EACAjJ,GACA,GAEF1T,KAAK+zC,cAAgB/zC,KAAKq3C,oBACxBD,EACAtE,EAAU1lB,OAEb,CACDptB,KAAKm0C,gBAAkBrB,EAAUK,iBACjCnzC,KAAKg0C,kBAAoBr3B,EACzB3c,KAAKs3C,mBAAkB,EACxB,CACD,QAC+B9wC,IAA7BssC,EAAUM,qBACmB5sC,IAA7BssC,EAAUO,eACV,CACA,MAAMz2B,EACS,IAAbs6B,EACIryB,GAAOiuB,EAAUO,eAAiBpnC,KAAK+T,GAAI,EAAI/T,KAAK+T,IACpD/T,KAAK+T,GACL8yB,EAAUM,eACV8D,GACGpE,EAAUO,eAAiBP,EAAUM,gBAC9C,GAAIN,EAAU1lB,OAAQ,CACpB,MAAMmqB,EAAsBv3C,KAAKi1C,aAAar4B,SAC5CA,GACA,GAEF5c,KAAK+zC,cAAgB/zC,KAAKw3C,sBACxBD,EACAzE,EAAU1lB,OAEb,CACDptB,KAAKo0C,cAAgBtB,EAAUO,eAC/BrzC,KAAKi0C,gBAAkBr3B,CACxB,CAGD,GAFA5c,KAAKs3C,mBAAkB,GACvBR,GAAO,GACFhE,EAAU5X,SACb,KAEH,CACD,GAAI6b,EAAgB,CAClB/2C,KAAK2zC,YAAY/xC,GAAK,KACtB5B,KAAKy2C,QAAQxH,IAAqB,GAClCjvC,KAAKk0C,YAAc,KACnBl0C,KAAKm0C,gBAAkB9lB,IACvBruB,KAAKo0C,cAAgB/lB,IACrB,MAAMzS,EAAW06B,EAAO,GAAG16B,SACvBA,GACF21B,GAAkB31B,GAAU,EAE/B,CACF,CAED5b,KAAK2zC,YAAc3zC,KAAK2zC,YAAY8D,OAAOC,SACvCZ,QAAqCtwC,IAA7BxG,KAAK4zC,sBACf5zC,KAAK4zC,oBAAsB+D,sBACzB33C,KAAK02C,kBAAkBxvC,KAAKlH,OAGjC,CAOD,qBAAAw3C,CAAsB56B,EAAUwQ,GAC9B,IAAI1Q,EACJ,MAAMk7B,EAAgB53C,KAAKu1C,oBAM3B,YALsB/uC,IAAlBoxC,IACFl7B,EAAS,CAACk7B,EAAc,GAAKxqB,EAAO,GAAIwqB,EAAc,GAAKxqB,EAAO,IAClEyqB,GAAiBn7B,EAAQE,EAAW5c,KAAK81C,eACzCgC,GAAcp7B,EAAQ0Q,IAEjB1Q,CACR,CAOD,mBAAA26B,CAAoB16B,EAAYyQ,GAC9B,IAAI1Q,EACJ,MAAMk7B,EAAgB53C,KAAKu1C,oBACrBwC,EAAoB/3C,KAAK07B,gBAC/B,QAAsBl1B,IAAlBoxC,QAAqDpxC,IAAtBuxC,EAAiC,CAOlEr7B,EAAS,CALP0Q,EAAO,GACNzQ,GAAcyQ,EAAO,GAAKwqB,EAAc,IAAOG,EAEhD3qB,EAAO,GACNzQ,GAAcyQ,EAAO,GAAKwqB,EAAc,IAAOG,EAEnD,CACD,OAAOr7B,CACR,CAQD,gBAAAy6B,CAAiBv6B,GACf,MAAMlJ,EAAO1T,KAAK8zC,cAClB,GAAIl3B,EAAU,CACZ,MAAMo7B,EAAItkC,EAAK,GACT6sB,EAAI7sB,EAAK,GACf,MAAO,CACLzH,KAAKmP,IAAI48B,EAAI/rC,KAAKwL,IAAImF,IAAa3Q,KAAKmP,IAAImlB,EAAIt0B,KAAKyL,IAAIkF,IACzD3Q,KAAKmP,IAAI48B,EAAI/rC,KAAKyL,IAAIkF,IAAa3Q,KAAKmP,IAAImlB,EAAIt0B,KAAKwL,IAAImF,IAE5D,CACD,OAAOlJ,CACR,CASD,eAAAukC,CAAgBvkC,GACd1T,KAAK8zC,cAAgBzxC,MAAMC,QAAQoR,GAAQA,EAAK5P,QAAU,CAAC,IAAK,KAC3D9D,KAAKk2C,gBACRl2C,KAAKm2C,mBAAmB,EAE3B,CAQD,SAAA75B,GACE,MAAMI,EAAS1c,KAAKu1C,oBACpB,OAAK74B,EAGEwP,GAAiBxP,EAAQ1c,KAAK4uB,iBAF5BlS,CAGV,CAMD,iBAAA64B,GACE,OACEv1C,KAAKoJ,IAAI8lC,GAAaC,OAEzB,CAKD,cAAA+I,GACE,OAAOl4C,KAAKi1C,YACb,CAKD,sBAAAkD,GACE,OAAOn4C,KAAKoJ,IAAI,sBACjB,CAMD,QAAAgvC,CAASC,GACP,YAAc7xC,IAAV6xC,GACFA,EAAM,GAAKr4C,KAAK0zC,OAAO,GACvB2E,EAAM,GAAKr4C,KAAK0zC,OAAO,GAChB2E,GAEFr4C,KAAK0zC,OAAO5vC,OACpB,CAYD,eAAAw0C,CAAgB5kC,GAEd,OAAO2Y,GADQrsB,KAAKu4C,wBAAwB7kC,GAChB1T,KAAK4uB,gBAClC,CAOD,uBAAA2pB,CAAwB7kC,GACtBA,EAAOA,GAAQ1T,KAAKw4C,+BACpB,MAAM97B,EACJ1c,KAAKu1C,oBAEPthC,GAAOyI,EAAQ,kCACf,MAAMC,EAAqC3c,KAAK07B,gBAChDznB,QAAsBzN,IAAfmW,EAA0B,sCACjC,MAAMC,EAAmC5c,KAAK81C,cAG9C,OAFA7hC,QAAoBzN,IAAboW,EAAwB,oCAExBH,GAAkBC,EAAQC,EAAYC,EAAUlJ,EACxD,CAOD,gBAAAs6B,GACE,OAAOhuC,KAAKw0C,cACb,CAOD,gBAAAvG,GACE,OAAOjuC,KAAKy0C,cACb,CAOD,UAAAtG,GACE,OACEnuC,KAAKy4C,qBAAqBz4C,KAAKy0C,eAElC,CAOD,UAAA9F,CAAWyG,GACTp1C,KAAKs0C,cAAct0C,KAAK21C,mBAAmB,CAACvI,QAASgI,IACtD,CAOD,UAAAlH,GACE,OACEluC,KAAKy4C,qBAAqBz4C,KAAKw0C,eAElC,CAOD,UAAA5F,CAAWwG,GACTp1C,KAAKs0C,cAAct0C,KAAK21C,mBAAmB,CAACxI,QAASiI,IACtD,CAOD,sBAAAsD,CAAuBC,GACrB34C,KAAKs0C,cAAct0C,KAAK21C,mBAAmB,CAACvD,oBAAqBuG,IAClE,CAOD,aAAA/pB,GACE,OAAO5uB,KAAK6zC,WACb,CAQD,aAAAnY,GACE,OAAwC17B,KAAKoJ,IAAI8lC,GAAaE,WAC/D,CAQD,cAAAwJ,GACE,OAAO54C,KAAK20C,YACb,CAUD,sBAAAkE,CAAuBr/B,EAAQ9F,GAC7B,OAAO1T,KAAK84C,+BACVxsB,GAAe9S,EAAQxZ,KAAK4uB,iBAC5Blb,EAEH,CASD,8BAAAolC,CAA+Bt/B,EAAQ9F,GACrCA,EAAOA,GAAQ1T,KAAKw4C,+BACpB,MAAMlI,EAAcl0B,GAAS5C,GAAU9F,EAAK,GACtC68B,EAAcl0B,GAAU7C,GAAU9F,EAAK,GAC7C,OAAOzH,KAAKyP,IAAI40B,EAAaC,EAC9B,CAQD,6BAAAwI,CAA8BhI,GAC5BA,EAAQA,GAAS,EACjB,MAAM9D,EAAgBjtC,KAAKg5C,yBAAyBh5C,KAAKw0C,gBACnDtH,EAAgBltC,KAAKy0C,eACrB/4B,EAAMzP,KAAKsW,IAAI0qB,EAAgBC,GAAiBjhC,KAAKsW,IAAIwuB,GAC/D,OAAA,SAKY1sC,GAER,OADmB4oC,EAAgBhhC,KAAKC,IAAI6kC,EAAO1sC,EAAQqX,EAG7D,CACH,CAQD,WAAAo6B,GACE,OAA8B91C,KAAKoJ,IAAI8lC,GAAaG,SACrD,CAQD,6BAAA4J,CAA8BlI,GAC5B,MAAMmI,EAAWjtC,KAAKsW,IAAIwuB,GAAS,GAC7B9D,EAAgBjtC,KAAKg5C,yBAAyBh5C,KAAKw0C,gBACnDtH,EAAgBltC,KAAKy0C,eACrB/4B,EAAMzP,KAAKsW,IAAI0qB,EAAgBC,GAAiBgM,EACtD,OAAA,SAKYv8B,GAER,OADc1Q,KAAKsW,IAAI0qB,EAAgBtwB,GAAcu8B,EAAWx9B,CAGlE,CACH,CAQD,4BAAA88B,CAA6B57B,GAC3B,IAAIlJ,EAAO1T,KAAKm3C,iBAAiBv6B,GACjC,MAAMi4B,EAAU70C,KAAK40C,SAOrB,OANIC,IACFnhC,EAAO,CACLA,EAAK,GAAKmhC,EAAQ,GAAKA,EAAQ,GAC/BnhC,EAAK,GAAKmhC,EAAQ,GAAKA,EAAQ,KAG5BnhC,CACR,CAKD,QAAAvG,GACE,MAAMgS,EAAanf,KAAK4uB,gBAClBjS,EAAa3c,KAAK07B,gBAClB9e,EAAW5c,KAAK81C,cACtB,IAAIp5B,EACF1c,KAAKu1C,oBAEP,MAAMV,EAAU70C,KAAK40C,SACrB,GAAIC,EAAS,CACX,MAAMsE,EAAcn5C,KAAKw4C,+BACzB97B,EAAS42B,GACP52B,EACA1c,KAAKm3C,mBACL,CAACgC,EAAY,GAAK,EAAItE,EAAQ,GAAIsE,EAAY,GAAK,EAAItE,EAAQ,IAC/Dl4B,EACAC,EAEH,CACD,MAAO,CACLF,OAAQA,EAAO5Y,MAAM,GACrBqb,gBAA2B3Y,IAAf2Y,EAA2BA,EAAa,KACpDxC,WAAYA,EACZy8B,WAAYp5C,KAAKk0C,YACjBmF,eAAgBr5C,KAAKm0C,gBACrBmF,aAAct5C,KAAKo0C,cACnBx3B,SAAUA,EACVw4B,KAAMp1C,KAAK61C,UAEd,CAKD,qBAAA0D,GACE,MAAO,CACLC,UAAWx5C,KAAKmN,WAChBqM,OAAQxZ,KAAKs4C,kBAEhB,CASD,OAAAzC,GACE,IAAIT,EACJ,MAAMz4B,EAAa3c,KAAK07B,gBAIxB,YAHmBl1B,IAAfmW,IACFy4B,EAAOp1C,KAAKy4C,qBAAqB97B,IAE5By4B,CACR,CAQD,oBAAAqD,CAAqB97B,GACnB,IACIjB,EAAKu2B,EADLl3B,EAAS/a,KAAK80C,UAAY,EAE9B,GAAI90C,KAAK20C,aAAc,CACrB,MAAM8E,EAAUj4C,EAAkBxB,KAAK20C,aAAch4B,EAAY,GACjE5B,EAAS0+B,EACT/9B,EAAM1b,KAAK20C,aAAa8E,GAEtBxH,EADEwH,GAAWz5C,KAAK20C,aAAaxzC,OAAS,EAC3B,EAEAua,EAAM1b,KAAK20C,aAAa8E,EAAU,EAEvD,MACM/9B,EAAM1b,KAAKw0C,eACXvC,EAAajyC,KAAK00C,YAEpB,OAAO35B,EAAS9O,KAAKsW,IAAI7G,EAAMiB,GAAc1Q,KAAKsW,IAAI0vB,EACvD,CAQD,oBAAAuE,CAAqBpB,GACnB,GAAIp1C,KAAK20C,aAAc,CACrB,GAAI30C,KAAK20C,aAAaxzC,QAAU,EAC9B,OAAO,EAET,MAAMu4C,EAAY51B,GAChB7X,KAAKuT,MAAM41B,GACX,EACAp1C,KAAK20C,aAAaxzC,OAAS,GAEvB8wC,EACJjyC,KAAK20C,aAAa+E,GAAa15C,KAAK20C,aAAa+E,EAAY,GAC/D,OACE15C,KAAK20C,aAAa+E,GAClBztC,KAAKC,IAAI+lC,EAAYnuB,GAAMsxB,EAAOsE,EAAW,EAAG,GAEnD,CACD,OACE15C,KAAKw0C,eAAiBvoC,KAAKC,IAAIlM,KAAK00C,YAAaU,EAAOp1C,KAAK80C,SAEhE,CAYD,GAAA6E,CAAIC,EAAkBjvC,GAEpB,IAAIiK,EAOJ,GANAX,GACE5R,MAAMC,QAAQs3C,IAEV,mBADuB,EAAwC,sBAEnE,qDAEEv3C,MAAMC,QAAQs3C,GAAmB,CACnC3lC,IACGnP,GAAQ80C,GACT,kDAGFhlC,EAAWilC,GADIvtB,GAAestB,EAAkB55C,KAAK4uB,iBAEtD,MAAM,GAAmC,WAA/BgrB,EAAiBlrB,UAAwB,CAClD,MAAMlV,EAAS8S,GACbstB,EAAiBv6B,YACjBrf,KAAK4uB,iBAEPha,EAAWilC,GAAkBrgC,GAC7B5E,EAAS2C,OAAOvX,KAAK81C,cAAex5B,GAAU9C,GACpD,KAAW,CACL,MAAMuS,EAAiBE,KAErBrX,EADEmX,EAEA6tB,EACG7kC,QACAiB,UAAU+V,EAAgB/rB,KAAK4uB,iBAGzBgrB,CAEd,CAED55C,KAAK85C,YAAYllC,EAAUjK,EAC5B,CAOD,wBAAAovC,CAAyBnlC,GACvB,MAAMgI,EAAW5c,KAAK81C,cAChB1uB,EAAWnb,KAAKwL,IAAImF,GACpByK,EAAWpb,KAAKyL,KAAKkF,GACrBuc,EAASvkB,EAAS2a,qBAClBvU,EAASpG,EAAS4a,YACxB,IAAIwqB,EAAWv/B,IACXw/B,EAAWx/B,IACXy/B,GAAWz/B,IACX0/B,GAAW1/B,IACf,IAAK,IAAI7Y,EAAI,EAAGuE,EAAKgzB,EAAOh4B,OAAQS,EAAIuE,EAAIvE,GAAKoZ,EAAQ,CACvD,MAAMu4B,EAAOpa,EAAOv3B,GAAKwlB,EAAW+R,EAAOv3B,EAAI,GAAKylB,EAC9CmsB,EAAOra,EAAOv3B,GAAKylB,EAAW8R,EAAOv3B,EAAI,GAAKwlB,EACpD4yB,EAAU/tC,KAAKwP,IAAIu+B,EAASzG,GAC5B0G,EAAUhuC,KAAKwP,IAAIw+B,EAASzG,GAC5B0G,EAAUjuC,KAAKyP,IAAIw+B,EAAS3G,GAC5B4G,EAAUluC,KAAKyP,IAAIy+B,EAAS3G,EAC7B,CACD,MAAO,CAACwG,EAASC,EAASC,EAASC,EACpC,CAMD,WAAAL,CAAYllC,EAAUjK,GAEpB,IAAI+I,GADJ/I,EAAUA,GAAW,IACF+I,KACdA,IACHA,EAAO1T,KAAKw4C,gCAEd,MAAM3D,OACgBruC,IAApBmE,EAAQkqC,QAAwBlqC,EAAQkqC,QAAU,CAAC,EAAG,EAAG,EAAG,GACxD4E,OAA8BjzC,IAApBmE,EAAQ8uC,SAAwB9uC,EAAQ8uC,QACxD,IAAIvM,EAEFA,OAD4B1mC,IAA1BmE,EAAQuiC,cACMviC,EAAQuiC,mBACK1mC,IAApBmE,EAAQyiC,QACDptC,KAAKw2C,qBAAqB7rC,EAAQyiC,SAElC,EAGlB,MAAMgN,EAAgBp6C,KAAK+5C,yBAAyBnlC,GAGpD,IAAI+H,EAAa3c,KAAK84C,+BAA+BsB,EAAe,CAClE1mC,EAAK,GAAKmhC,EAAQ,GAAKA,EAAQ,GAC/BnhC,EAAK,GAAKmhC,EAAQ,GAAKA,EAAQ,KAEjCl4B,EAAa6R,MAAM7R,GACfuwB,EACAjhC,KAAKyP,IAAIiB,EAAYuwB,GACzBvwB,EAAa3c,KAAKg5C,yBAAyBr8B,EAAY88B,EAAU,EAAI,GAGrE,MAAM78B,EAAW5c,KAAK81C,cAChBzuB,EAAWpb,KAAKyL,IAAIkF,GACpBwK,EAAWnb,KAAKwL,IAAImF,GACpBy9B,EAAY/9B,GAAU89B,GAC5BC,EAAU,KAAQxF,EAAQ,GAAKA,EAAQ,IAAM,EAAKl4B,EAClD09B,EAAU,KAAQxF,EAAQ,GAAKA,EAAQ,IAAM,EAAKl4B,EAClD,MAAM29B,EAAUD,EAAU,GAAKjzB,EAAWizB,EAAU,GAAKhzB,EACnDkzB,EAAUF,EAAU,GAAKjzB,EAAWizB,EAAU,GAAKhzB,EACnD3K,EAAS1c,KAAKw6C,qBAAqB,CAACF,EAASC,GAAU59B,GACvDf,EAAWjR,EAAQiR,SAAWjR,EAAQiR,SAAWvY,OAE9BmD,IAArBmE,EAAQwzB,SACVn+B,KAAKo2C,gBACH,CACEz5B,WAAYA,EACZD,OAAQA,EACRyhB,SAAUxzB,EAAQwzB,SAClBoY,OAAQ5rC,EAAQ4rC,QAElB36B,IAGF5b,KAAKg0C,kBAAoBr3B,EACzB3c,KAAK+zC,cAAgBr3B,EACrB1c,KAAKs3C,mBAAkB,GAAO,GAC9B/F,GAAkB31B,GAAU,GAE/B,CASD,QAAA6+B,CAASrjC,EAAY1D,EAAMwlB,GACzBl5B,KAAK06C,iBACHvuB,GAAmB/U,EAAYpX,KAAK4uB,iBACpClb,EACAwlB,EAEH,CAOD,gBAAAwhB,CAAiBtjC,EAAY1D,EAAMwlB,GACjCl5B,KAAKm1C,kBACH7B,GACEl8B,EACA1D,EACAwlB,EACAl5B,KAAK07B,gBACL17B,KAAK81C,eAGV,CAUD,oBAAA6E,CAAqBj+B,EAAQC,EAAYC,EAAUlJ,GACjD,IAAIk8B,EACJ,MAAMiF,EAAU70C,KAAK40C,SACrB,GAAIC,GAAWn4B,EAAQ,CACrB,MAAMy8B,EAAcn5C,KAAKw4C,8BAA8B57B,GACjDg+B,EAAgBtH,GACpB52B,EACAhJ,EACA,CAACylC,EAAY,GAAK,EAAItE,EAAQ,GAAIsE,EAAY,GAAK,EAAItE,EAAQ,IAC/Dl4B,EACAC,GAEFgzB,EAAc,CACZlzB,EAAO,GAAKk+B,EAAc,GAC1Bl+B,EAAO,GAAKk+B,EAAc,GAE7B,CACD,OAAOhL,CACR,CAKD,KAAAqG,GACE,QAASj2C,KAAKu1C,0BAAgD/uC,IAAzBxG,KAAK07B,eAC3C,CAOD,YAAAmf,CAAaC,GACX,MAAMp+B,EAASwP,GAAiBlsB,KAAK+zC,cAAe/zC,KAAK4uB,iBACzD5uB,KAAK+6C,UAAU,CACbr+B,EAAO,GAAKo+B,EAAiB,GAC7Bp+B,EAAO,GAAKo+B,EAAiB,IAEhC,CAMD,oBAAAE,CAAqBF,GACnB,MAAMp+B,EAAS1c,KAAK+zC,cACpB/zC,KAAKm1C,kBAAkB,CACrBz4B,EAAO,GAAKo+B,EAAiB,GAC7Bp+B,EAAO,GAAKo+B,EAAiB,IAEhC,CASD,gBAAAG,CAAiBhL,EAAO7iB,GACtBA,EAASA,GAAUjB,GAAmBiB,EAAQptB,KAAK4uB,iBACnD5uB,KAAKk7C,yBAAyBjL,EAAO7iB,EACtC,CAQD,wBAAA8tB,CAAyBjL,EAAO7iB,GAC9B,MAAMuiB,EAAW3vC,KAAKk2C,gBAAkBl2C,KAAK22C,iBACvCjjC,EAAO1T,KAAKm3C,iBAAiBn3C,KAAK81C,eAClCqF,EAAgBn7C,KAAKi1C,aAAat4B,WACtC3c,KAAKg0C,kBAAoB/D,EACzB,EACAv8B,EACAi8B,GAGEviB,IACFptB,KAAK+zC,cAAgB/zC,KAAKq3C,oBAAoB8D,EAAe/tB,IAG/DptB,KAAKg0C,mBAAqB/D,EAC1BjwC,KAAKs3C,mBACN,CASD,UAAA8D,CAAWztC,EAAOyf,GAChBptB,KAAKi7C,iBAAiBhvC,KAAKC,IAAIlM,KAAK00C,aAAc/mC,GAAQyf,EAC3D,CASD,cAAAiuB,CAAe1tC,EAAOyf,GAChBA,IACFA,EAASjB,GAAmBiB,EAAQptB,KAAK4uB,kBAE3C5uB,KAAKs7C,uBAAuB3tC,EAAOyf,EACpC,CAMD,sBAAAkuB,CAAuB3tC,EAAOyf,GAC5B,MAAMuiB,EAAW3vC,KAAKk2C,gBAAkBl2C,KAAK22C,iBACvC4E,EAAcv7C,KAAKi1C,aAAar4B,SACpC5c,KAAKi0C,gBAAkBtmC,EACvBgiC,GAEEviB,IACFptB,KAAK+zC,cAAgB/zC,KAAKw3C,sBAAsB+D,EAAanuB,IAE/DptB,KAAKi0C,iBAAmBtmC,EACxB3N,KAAKs3C,mBACN,CAQD,SAAAyD,CAAUr+B,GACR1c,KAAKm1C,kBACHz4B,EAASyP,GAAmBzP,EAAQ1c,KAAK4uB,iBAAmBlS,EAE/D,CAMD,iBAAAy4B,CAAkBz4B,GAChB1c,KAAK+zC,cAAgBr3B,EACrB1c,KAAKs3C,mBACN,CAOD,OAAAb,CAAQ+E,EAAM7tC,GAGZ,OAFA3N,KAAK0zC,OAAO8H,IAAS7tC,EACrB3N,KAAK6H,UACE7H,KAAK0zC,OAAO8H,EACpB,CAQD,aAAAzf,CAAcpf,GACZ3c,KAAKg0C,kBAAoBr3B,EACzB3c,KAAKs3C,mBACN,CAQD,WAAApC,CAAYt4B,GACV5c,KAAKi0C,gBAAkBr3B,EACvB5c,KAAKs3C,mBACN,CAOD,OAAAjC,CAAQD,GACNp1C,KAAK+7B,cAAc/7B,KAAKw2C,qBAAqBpB,GAC9C,CAUD,iBAAAkC,CAAkBmE,EAAkBC,GAClC,MAAM/L,EACJ3vC,KAAKk2C,gBAAkBl2C,KAAK22C,kBAAoB+E,EAG5CH,EAAcv7C,KAAKi1C,aAAar4B,SACpC5c,KAAKi0C,gBACLtE,GAEIj8B,EAAO1T,KAAKm3C,iBAAiBoE,GAC7BJ,EAAgBn7C,KAAKi1C,aAAat4B,WACtC3c,KAAKg0C,kBACL,EACAtgC,EACAi8B,GAEIgM,EAAY37C,KAAKi1C,aAAav4B,OAClC1c,KAAK+zC,cACLoH,EACAznC,EACAi8B,EACA3vC,KAAK26C,qBACH36C,KAAK+zC,cACLoH,EACAI,EACA7nC,IAIA1T,KAAKoJ,IAAI8lC,GAAaG,YAAckM,GACtCv7C,KAAK+J,IAAImlC,GAAaG,SAAUkM,GAE9Bv7C,KAAKoJ,IAAI8lC,GAAaE,cAAgB+L,IACxCn7C,KAAK+J,IAAImlC,GAAaE,WAAY+L,GAClCn7C,KAAK+J,IAAI,OAAQ/J,KAAK61C,WAAW,IAGhC8F,GACA37C,KAAKoJ,IAAI8lC,GAAaC,SACtB5sC,GAAOvC,KAAKoJ,IAAI8lC,GAAaC,QAASwM,IAEvC37C,KAAK+J,IAAImlC,GAAaC,OAAQwM,GAG5B37C,KAAKk2C,iBAAmBuF,GAC1Bz7C,KAAK42C,mBAEP52C,KAAKq0C,mBAAgB7tC,CACtB,CAWD,kBAAA2vC,CAAmBhY,EAAUyd,EAAqBxuB,GAChD+Q,OAAwB33B,IAAb23B,EAAyBA,EAAW,IAC/C,MAAMz8B,EAAYk6C,GAAuB,EAEnCL,EAAcv7C,KAAKi1C,aAAar4B,SAAS5c,KAAKi0C,iBAC9CvgC,EAAO1T,KAAKm3C,iBAAiBoE,GAC7BJ,EAAgBn7C,KAAKi1C,aAAat4B,WACtC3c,KAAKg0C,kBACLtyC,EACAgS,GAEIioC,EAAY37C,KAAKi1C,aAAav4B,OAClC1c,KAAK+zC,cACLoH,EACAznC,GACA,EACA1T,KAAK26C,qBACH36C,KAAK+zC,cACLoH,EACAI,EACA7nC,IAIJ,GAAiB,IAAbyqB,IAAmBn+B,KAAKq0C,cAK1B,OAJAr0C,KAAKg0C,kBAAoBmH,EACzBn7C,KAAKi0C,gBAAkBsH,EACvBv7C,KAAK+zC,cAAgB4H,OACrB37C,KAAKs3C,oBAIPlqB,EAASA,IAAwB,IAAb+Q,EAAiBn+B,KAAKq0C,mBAAgB7tC,GAC1DxG,KAAKq0C,mBAAgB7tC,EAGnBxG,KAAK07B,kBAAoByf,GACzBn7C,KAAK81C,gBAAkByF,GACtBv7C,KAAKu1C,qBACLhzC,GAAOvC,KAAKu1C,oBAAqBoG,KAE9B37C,KAAKk2C,gBACPl2C,KAAK42C,mBAGP52C,KAAKo2C,gBAAgB,CACnBx5B,SAAU2+B,EACV7+B,OAAQi/B,EACRh/B,WAAYw+B,EACZhd,SAAUA,EACVoY,OAAQpqC,GACRihB,OAAQA,IAGb,CAQD,gBAAAyuB,GACE77C,KAAKm2C,mBAAmB,GAExBn2C,KAAKy2C,QAAQxH,GAAsB,EACpC,CAUD,cAAA6M,CAAe3d,EAAUyd,EAAqBxuB,GAC5CA,EAASA,GAAUjB,GAAmBiB,EAAQptB,KAAK4uB,iBACnD5uB,KAAK+7C,uBAAuB5d,EAAUyd,EAAqBxuB,EAC5D,CASD,sBAAA2uB,CAAuB5d,EAAUyd,EAAqBxuB,GAC/CptB,KAAK22C,mBAGV32C,KAAKy2C,QAAQxH,IAAuB,GACpCjvC,KAAKm2C,mBAAmBhY,EAAUyd,EAAqBxuB,GACxD,CASD,oBAAAotB,CAAqBxH,EAAcG,GACjC,MAAMz/B,EAAO1T,KAAKm3C,iBAAiBn3C,KAAK81C,eACxC,OAAO91C,KAAKi1C,aAAav4B,OACvBs2B,EACAG,GAAoBnzC,KAAK07B,gBACzBhoB,EAEH,CAWD,kBAAAsoC,CAAmBC,EAAYv6C,GAC7B,MAAMw6C,EAAYl8C,KAAKw2C,qBAAqByF,GAC5C,OAAOj8C,KAAKy4C,qBACVz4C,KAAKg5C,yBAAyBkD,EAAWx6C,GAE5C,CAWD,wBAAAs3C,CAAyB7F,EAAkBzxC,GACzCA,EAAYA,GAAa,EACzB,MAAMgS,EAAO1T,KAAKm3C,iBAAiBn3C,KAAK81C,eAExC,OAAO91C,KAAKi1C,aAAat4B,WAAWw2B,EAAkBzxC,EAAWgS,EAClE,GC/3CI,SAASyoC,GAAOC,EAAY5C,GACjC,IAAK4C,EAAWrP,QACd,OAAO,EAET,MAAMpwB,EAAa68B,EAAU78B,WAC7B,GACEA,EAAay/B,EAAWlP,eACxBvwB,GAAcy/B,EAAWnP,cAEzB,OAAO,EAET,MAAMmI,EAAOoE,EAAUpE,KACvB,OAAOA,EAAOgH,EAAWjP,SAAWiI,GAAQgH,EAAWhP,OACzD,CAEA,IAAAiP,GAvaA,cAAoBC,GAIlB,WAAAx8C,CAAY6K,GACV,MAAM4xC,EAAc71C,OAAO8C,OAAO,CAAE,EAAEmB,UAC/B4xC,EAAYryC,OAEnBjF,MAAMs3C,GAKNv8C,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAML3H,KAAKw8C,kBAAoB,KAMzBx8C,KAAKy8C,cAAgB,KAMrBz8C,KAAK08C,iBAAmB,KAMxB18C,KAAK28C,UAAY,KAMjB38C,KAAK48C,cAAe,EAMpB58C,KAAK68C,UAAW,EAGZlyC,EAAQmyC,SACV98C,KAAK88C,OAASnyC,EAAQmyC,QAGpBnyC,EAAQmgC,KACV9qC,KAAK+8C,OAAOpyC,EAAQmgC,KAGtB9qC,KAAK6J,kBACH6iC,GACA1sC,KAAKg9C,6BAGP,MAAM9yC,EAASS,EAAQT,OACQS,EAAc,OACzC,KACJ3K,KAAKi9C,UAAU/yC,EAChB,CAMD,cAAAkkC,CAAe1jC,GAGb,OAFAA,EAAQA,GAAgB,IAClB/E,KAAK3F,MACJ0K,CACR,CAMD,mBAAA2jC,CAAoBC,GAGlB,OAFAA,EAASA,GAAkB,IACpB3oC,KAAK3F,KAAK0tC,iBACVY,CACR,CAQD,SAAA4O,GACE,OAAkCl9C,KAAKoJ,IAAIsjC,KAA0B,IACtE,CAKD,eAAAyQ,GACE,OAAOn9C,KAAKk9C,WACb,CAKD,cAAA3O,GACE,MAAMrkC,EAASlK,KAAKk9C,YACpB,OAAQhzC,EAAuBA,EAAOiD,WAArB,WAClB,CAKD,mBAAAiwC,GACEp9C,KAAK6H,UACD7H,KAAK48C,cAAgD,UAAhC58C,KAAKk9C,YAAY/vC,aAG1CnN,KAAK48C,cAAe,EACpB58C,KAAK4F,cAAc,eACpB,CAKD,2BAAAo3C,GACMh9C,KAAK08C,mBACPp1C,EAActH,KAAK08C,kBACnB18C,KAAK08C,iBAAmB,MAE1B18C,KAAK48C,cAAe,EACpB,MAAM1yC,EAASlK,KAAKk9C,YAChBhzC,IACFlK,KAAK08C,iBAAmB31C,EACtBmD,EACApC,EACA9H,KAAKo9C,oBACLp9C,MAEwB,UAAtBkK,EAAOiD,aACTnN,KAAK48C,cAAe,EACpBnL,YAAW,KACTzxC,KAAK4F,cAAc,cAAc,GAChC,KAGP5F,KAAK6H,SACN,CAOD,WAAAw1C,CAAYC,GACV,OAAKt9C,KAAK28C,UAGH38C,KAAK28C,UAAUU,YAAYC,GAFzB/4C,QAAQE,QAAQ,GAG1B,CAMD,OAAAoP,CAAQypC,GACN,OAAKt9C,KAAK28C,WAAc38C,KAAK68C,SAGtB78C,KAAK28C,UAAU9oC,QAAQypC,GAFrB,IAGV,CAWD,SAAAC,CAAUC,GACR,IAAIC,EACJ,MAAM3S,EAAM9qC,KAAK09C,iBAejB,IAAItB,GAdCoB,GAAQ1S,IACX0S,EAAO1S,EAAI6S,WAGXF,EADED,aAAgBI,GACL,CACXpE,UAAWgE,EAAKrwC,WAChBqM,OAAQgkC,EAAKlF,mBAGFkF,GAEVC,EAAWI,kBAAoB/S,IAClC2S,EAAWI,iBAAmB/S,EAAIgT,gBAAgBzP,uBAIlD+N,EADEqB,EAAWI,iBACAJ,EAAWI,iBAAiBE,MACtC3B,GAAeA,EAAWxO,QAAU5tC,OAG1BA,KAAK0tC,gBAGpB,MAAMsQ,EAAch+C,KAAKqf,YAEzB,OACE88B,GAAOC,EAAYqB,EAAWjE,cAC5BwE,GAAelgC,GAAWkgC,EAAaP,EAAWjkC,QAEvD,CASD,eAAAykC,CAAgBT,GACd,IAAKx9C,KAAKu9C,UAAUC,GAClB,MAAO,GAET,IAAIS,EACJ,MAAM/zC,EAASlK,KAAKk9C,YAIpB,GAHIhzC,IACF+zC,EAAkB/zC,EAAO+zC,oBAEtBA,EACH,MAAO,GAIT,IAAIC,EAAeD,EADjBT,aAAgBI,GAAOJ,EAAKjE,wBAA0BiE,GAKxD,OAHKn7C,MAAMC,QAAQ47C,KACjBA,EAAe,CAACA,IAEXA,CACR,CAUD,MAAApB,CAAOW,EAAYt9C,GACjB,MAAMg+C,EAAgBn+C,KAAKo+C,cAE3B,OAAID,EAAcE,aAAaZ,IAC7Bz9C,KAAK68C,UAAW,EACTsB,EAAcG,YAAYb,EAAYt9C,IAExC,IACR,CAKD,QAAAo+C,GACEv+C,KAAK68C,UAAW,CACjB,CAMD,cAAA2B,CAAe1T,GACRA,GACH9qC,KAAKu+C,WAEPv+C,KAAK+J,IAAI2iC,GAAmB5B,EAC7B,CAMD,cAAA4S,GACE,OAAO19C,KAAKoJ,IAAIsjC,GACjB,CAaD,MAAAqQ,CAAOjS,GACD9qC,KAAKw8C,oBACPl1C,EAActH,KAAKw8C,mBACnBx8C,KAAKw8C,kBAAoB,MAEtB1R,GACH9qC,KAAK6H,UAEH7H,KAAKy8C,gBACPn1C,EAActH,KAAKy8C,eACnBz8C,KAAKy8C,cAAgB,MAEnB3R,IACF9qC,KAAKw8C,kBAAoBz1C,EACvB+jC,EACA2T,IACA,SAAU7+C,GACR,MAEMi+C,EADiD,EAClBJ,WAAWI,iBAC1CzB,EAAap8C,KAAK0tC,eAAc,GACtCz5B,IACG4pC,EAAiBa,MAAK,SAAUC,GAC/B,OAAOA,EAAgB/Q,QAAUwO,EAAWxO,KAC1D,IACY,yGAEFiQ,EAAiBl4C,KAAKy2C,EACvB,GACDp8C,MAEFA,KAAKy8C,cAAgB11C,EAAO/G,KAAM8H,EAAkBgjC,EAAIgS,OAAQhS,GAChE9qC,KAAK6H,UAER,CAQD,SAAAo1C,CAAU/yC,GACRlK,KAAK+J,IAAI2iC,GAAsBxiC,EAChC,CAMD,WAAAk0C,GAIE,OAHKp+C,KAAK28C,YACR38C,KAAK28C,UAAY38C,KAAK4+C,kBAEjB5+C,KAAK28C,SACb,CAKD,WAAAkC,GACE,QAAS7+C,KAAK28C,SACf,CAOD,cAAAiC,GACE,OAAO,IACR,CAKD,eAAAn+C,GACMT,KAAK28C,YACP38C,KAAK28C,UAAUn8C,iBACRR,KAAK28C,WAGd38C,KAAKi9C,UAAU,MACfh4C,MAAMxE,iBACP,GC9PH,SAASq+C,GAAgBhU,EAAK2S,GAC5BsB,GAAe3S,QACjB,CAEA,IAAA4S,GA9NA,cAA0Bh6C,EAIxB,WAAAlF,CAAYgrC,GACV7lC,QAMAjF,KAAKi/C,KAAOnU,CACb,CAOD,mBAAAoU,CAAoBn/C,EAAM09C,GACxBl1C,GACD,CAMD,mBAAA42C,CAAoB1B,GAClB,MAAMjE,EAAYiE,EAAWjE,UACvB4F,EAA6B3B,EAAW2B,2BACxCC,EAA6B5B,EAAW4B,2BAE9CpwB,GACEmwB,EACA3B,EAAW/pC,KAAK,GAAK,EACrB+pC,EAAW/pC,KAAK,GAAK,EACrB,EAAI8lC,EAAU78B,YACb,EAAI68B,EAAU78B,YACd68B,EAAU58B,UACV48B,EAAU98B,OAAO,IACjB88B,EAAU98B,OAAO,IAGpBnE,GAAY8mC,EAA4BD,EACzC,CAiBD,0BAAAE,CACEloC,EACAqmC,EACA8B,EACAC,EACA5jC,EACA5U,EACAy4C,EACAC,GAEA,IAAIjP,EACJ,MAAM+I,EAAYiE,EAAWjE,UAS7B,SAAS8F,EAA2B3R,EAASgS,EAAS/R,EAAOh5B,GAC3D,OAAOgH,EAAS7X,KAAKiD,EAAS24C,EAAShS,EAAUC,EAAQ,KAAMh5B,EAChE,CAED,MAAMuK,EAAaq6B,EAAUr6B,WAEvBygC,EAAuB1gC,GAAM9H,EAAWtT,QAASqb,GACjD0gC,EAAU,CAAC,CAAC,EAAG,IACrB,GAAI1gC,EAAWG,YAAckgC,EAAc,CACzC,MACMjgC,EAAanD,GADM+C,EAAWE,aAEpCwgC,EAAQl6C,KAAK,EAAE4Z,EAAY,GAAI,CAACA,EAAY,GAC7C,CAED,MAAMugC,EAAcrC,EAAWI,iBACzBkC,EAAYD,EAAY3+C,OAExB6+C,EAA6C,GAC7CC,EAAW,GACjB,IAAK,IAAIr+C,EAAI,EAAGA,EAAIi+C,EAAQ1+C,OAAQS,IAClC,IAAK,IAAI0iB,EAAIy7B,EAAY,EAAGz7B,GAAK,IAAKA,EAAG,CACvC,MAAM83B,EAAa0D,EAAYx7B,GACzBspB,EAAQwO,EAAWxO,MACzB,GACEA,EAAMiR,eACN1C,GAAOC,EAAY5C,IACnBiG,EAAY17C,KAAK27C,EAAU9R,GAC3B,CACA,MAAMuQ,EAAgBvQ,EAAMwQ,cACtBl0C,EAAS0jC,EAAMsP,YACrB,GAAIiB,GAAiBj0C,EAAQ,CAC3B,MAAMqP,EAAcrP,EAAOg2C,WACvBN,EACAxoC,EACEwE,EAAW0jC,EAA2Bp4C,KAC1C,KACAk1C,EAAWzO,SAEbsS,EAAS,GAAK1mC,EAAY,GAAKsmC,EAAQj+C,GAAG,GAC1Cq+C,EAAS,GAAK1mC,EAAY,GAAKsmC,EAAQj+C,GAAG,GAC1C6uC,EAAS0N,EAAcmB,2BACrBW,EACAxC,EACA8B,EACA3jC,EACAokC,EAEH,CACD,GAAIvP,EACF,OAAOA,CAEV,CACF,CAEH,GAAuB,IAAnBuP,EAAQ7+C,OACV,OAEF,MAAMg/C,EAAQ,EAAIH,EAAQ7+C,OAM1B,OALA6+C,EAAQ70C,SAAQ,CAACgV,EAAGve,IAAOue,EAAEigC,YAAcx+C,EAAIu+C,IAC/CH,EAAQ1rB,MAAK,CAACjzB,EAAGC,IAAMD,EAAE++C,WAAa9+C,EAAE8+C,aACxCJ,EAAQtB,MAAMv+B,GACJswB,EAAStwB,EAAEvE,SAASuE,EAAEw/B,QAASx/B,EAAEytB,MAAOztB,EAAEvL,YAE7C67B,CACR,CAeD,sBAAA4P,CACEjpC,EACAqmC,EACA8B,EACAC,EACAC,EACAz4C,GAaA,YAAsBR,IAXHxG,KAAKs/C,2BACtBloC,EACAqmC,EACA8B,EACAC,EACAr8C,EACAnD,KACAy/C,EACAz4C,EAIH,CAKD,MAAAs5C,GACE,OAAOtgD,KAAKi/C,IACb,CAOD,WAAAX,CAAYb,GACVl1C,GACD,CAKD,mBAAAg4C,CAAoB9C,GAAc,CAMlC,uBAAA+C,CAAwB/C,GAClBsB,GAAe5S,kBACjBsR,EAAWgD,oBAAoB96C,KAAKm5C,GAEvC,GCjMH,IAAA4B,GArCA,cAA0B36C,EAQxB,WAAAjG,CAAYC,EAAM4gD,EAAuBlD,EAAYttC,GACnDlL,MAAMlF,GAQNC,KAAK2gD,sBAAwBA,EAO7B3gD,KAAKy9C,WAAaA,EASlBz9C,KAAKmQ,QAAUA,CAChB,GCnBI,MAAMywC,GAAe,YAQfC,GAAmB,gBAQnBC,GAAqB,kBAQrBC,GAAoB,iBAQpBC,GAAgB,aAShBC,GAAkB,eAMzBC,GAAY,IAAIC,OACpB,CACE,qDACA,4CACA,8DACA,gDACA,8EACA,gEACA,mCACAroC,KAAK,IACP,KAGIsoC,GAAsB,CAC1B,QACA,UACA,SACA,OACA,aACA,UASWC,GAAoB,SAAUC,GACzC,MAAMrW,EAAQqW,EAASrW,MAAMiW,IAC7B,IAAKjW,EACH,OAAO,KAET,MAAM16B,EAAuC,CAC3CgxC,WAAY,SACZ7tC,KAAM,QACNnD,MAAO,SACPixC,OAAQ,SACRC,QAAS,UAEX,IAAK,IAAI7/C,EAAI,EAAGuE,EAAKi7C,GAAoBjgD,OAAQS,EAAIuE,IAAMvE,EAAG,CAC5D,MAAMyC,EAAQ4mC,EAAMrpC,EAAI,QACV4E,IAAVnC,IACFkM,EAAM6wC,GAAoBx/C,IAAMyC,EAEnC,CAED,OADAkM,EAAMmxC,SAAWnxC,EAAMoxC,OAAO97B,MAAM,QAC7BtV,CACT,ECzBaqxC,GAAc,kBAMdC,GAAmB,OAMnBC,GAAiB,QAMjBC,GAAkB,GAYlBC,GAAkB,QAMlBC,GAAoB,GAMpBC,GAAqB,OAMrBC,GAAmB,SAMnBC,GAAsB,SAMtBC,GAAiB,CAAC,EAAG,EAAG,EAAG,GAW3BC,GAAe,IAAI73C,EAKhC,IAKI83C,GALAC,GAAiB,KAUd,MAAMC,GAAc,CAAA,EAMdC,GAAe,WAC1B,MACMhvC,EAAO,QACPivC,EAAiB,CAAC,YAAa,SAC/B16C,EAAM06C,EAAexhD,OACrByhD,EAAO,2BACb,IAAIC,EAAUC,EAQd,SAASC,EAAYC,EAAWC,EAAYC,GAC1C,IAAIC,GAAY,EAChB,IAAK,IAAIvhD,EAAI,EAAGA,EAAIqG,IAAOrG,EAAG,CAC5B,MAAMwhD,EAAgBT,EAAe/gD,GAKrC,GAJAkhD,EAAiBO,GACfL,EAAY,IAAMC,EAAa,IAAMvvC,EAAO0vC,EAC5CR,GAEEM,GAAcE,EAAe,CAC/B,MAAM3zC,EAAQ4zC,GACZL,EACE,IACAC,EACA,IACAvvC,EACAwvC,EACA,IACAE,EACFR,GAIFO,EAAYA,GAAa1zC,GAASqzC,CACnC,CACF,CACD,QAAIK,CAIL,CAED,SAASG,IACP,IAAIC,GAAO,EACX,MAAMC,EAAQlB,GAAah5C,UAC3B,IAAK,IAAI1H,EAAI,EAAGuE,EAAKq9C,EAAMriD,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAM6hD,EAAOD,EAAM5hD,GACf0gD,GAAal5C,IAAIq6C,GAjDT,MAkDNV,EAAY7+C,MAAMlE,KAAMyjD,EAAK59B,MAAM,QACrClhB,EAAM89C,IAEND,GAAiB,KACjBD,QAAc/7C,EACd87C,GAAav4C,IAAI05C,EAvDT,OAyDRnB,GAAav4C,IAAI05C,EAAMnB,GAAal5C,IAAIq6C,GAAQ,GAAG,GACnDF,GAAO,GAGZ,CACGA,IACFG,cAAcb,GACdA,OAAWr8C,EAEd,CAED,OAAO,SAAU86C,GACf,MAAMmC,EAAOpC,GAAkBC,GAC/B,IAAKmC,EACH,OAEF,MAAM/B,EAAW+B,EAAK/B,SACtB,IAAK,IAAI9/C,EAAI,EAAGuE,EAAKu7C,EAASvgD,OAAQS,EAAIuE,IAAMvE,EAAG,CACjD,MAAM+/C,EAASD,EAAS9/C,GAClB2F,EAAMk8C,EAAKlzC,MAAQ,KAAOkzC,EAAKjC,OAAS,KAAOG,OACvBn7C,IAA1B87C,GAAal5C,IAAI7B,KACnB+6C,GAAav4C,IAAIxC,EA9EP,KA8EqB,GAC1Bw7C,EAAYU,EAAKlzC,MAAOkzC,EAAKjC,OAAQG,KACxCW,GAAav4C,IAAIxC,EAAK,GAAG,QACRf,IAAbq8C,IACFA,EAAWc,YAAYL,EAAO,MAIrC,CACL,CACC,CAzF2B,GA+FfM,GAAoB,WAI/B,IAAIC,EACJ,OAAO,SAAUvC,GACf,IAAI5xC,EAAS+yC,GAAYnB,GACzB,GAAc96C,MAAVkJ,EAAqB,CACvB,GAAIhB,GAAyB,CAC3B,MAAM+0C,EAAOpC,GAAkBC,GACzBwC,EAAUC,GAAYzC,EAAU,MAItC5xC,GAHmB8e,MAAM2b,OAAOsZ,EAAKlC,aACjC,IACApX,OAAOsZ,EAAKlC,cAGbuC,EAAQE,wBAA0BF,EAAQG,yBACrD,MACaJ,IACHA,EAAiB9zC,SAASC,cAAc,OACxC6zC,EAAeK,UAAY,IAC3BL,EAAetzC,MAAM4zC,UAAY,IACjCN,EAAetzC,MAAM6zC,UAAY,OACjCP,EAAetzC,MAAMb,OAAS,OAC9Bm0C,EAAetzC,MAAMskC,QAAU,IAC/BgP,EAAetzC,MAAM8zC,OAAS,OAC9BR,EAAetzC,MAAM2oB,SAAW,WAChC2qB,EAAetzC,MAAM+zC,QAAU,QAC/BT,EAAetzC,MAAMg0C,KAAO,YAE9BV,EAAetzC,MAAMkzC,KAAOnC,EAC5BvxC,SAASy0C,KAAKtyC,YAAY2xC,GAC1Bn0C,EAASm0C,EAAehzC,aACxBd,SAASy0C,KAAKhzC,YAAYqyC,GAE5BpB,GAAYnB,GAAY5xC,CACzB,CACD,OAAOA,CACX,CACC,CAvCgC,GA8CjC,SAASq0C,GAAYN,EAAMb,GAQzB,OAPKJ,KACHA,GAAiBhzC,GAAsB,EAAG,IAExCi0C,GAAQlB,KACVC,GAAeiB,KAAOA,EACtBlB,GAAcC,GAAeiB,MAExBjB,GAAeuB,YAAYnB,EACpC,CAOO,SAASS,GAAiBI,EAAMb,GACrC,OAAOmB,GAAYN,EAAMb,GAAMnzC,KACjC,CASO,SAASg1C,GAAyBhB,EAAMb,EAAMr/B,GACnD,GAAIq/B,KAAQr/B,EACV,OAAOA,EAAMq/B,GAEf,MAAMnzC,EAAQmzC,EACX/8B,MAAM,MACN6+B,QAAO,CAAC/4C,EAAMg5C,IAAS14C,KAAKyP,IAAI/P,EAAM03C,GAAiBI,EAAMkB,KAAQ,GAExE,OADAphC,EAAMq/B,GAAQnzC,EACPA,CACT,CAOO,SAASm1C,GAAkBC,EAAWC,GAC3C,MAAMC,EAAS,GACTC,EAAU,GACVC,EAAa,GACnB,IAAIx1C,EAAQ,EACRy1C,EAAY,EACZx1C,EAAS,EACT6xC,EAAa,EACjB,IAAK,IAAI3/C,EAAI,EAAGuE,EAAK2+C,EAAO3jD,OAAQS,GAAKuE,EAAIvE,GAAK,EAAG,CACnD,MAAMghD,EAAOkC,EAAOljD,GACpB,GAAa,OAATghD,GAAiBhhD,IAAMuE,EAAI,CAC7BsJ,EAAQxD,KAAKyP,IAAIjM,EAAOy1C,GACxBD,EAAWt/C,KAAKu/C,GAChBA,EAAY,EACZx1C,GAAU6xC,EACV,QACD,CACD,MAAMkC,EAAOqB,EAAOljD,EAAI,IAAMijD,EAAUpB,KAClC0B,EAAe9B,GAAiBI,EAAMb,GAC5CmC,EAAOp/C,KAAKw/C,GACZD,GAAaC,EACb,MAAMC,EAAgBxB,GAAkBH,GACxCuB,EAAQr/C,KAAKy/C,GACb7D,EAAat1C,KAAKyP,IAAI6lC,EAAY6D,EACnC,CACD,MAAO,CAAC31C,QAAOC,SAAQq1C,SAAQC,UAASC,aAC1C,CA6BO,SAASI,GACdl1C,EACA6F,EACA82B,EACAwY,EACAC,EACAC,EACAxN,EACAzX,EACAlpB,EACAC,EACAK,GAEAxH,EAAQs1C,OAEQ,IAAZ3Y,IACF38B,EAAQu1C,aAAe5Y,GAErB92B,GACF7F,EAAQ6F,UAAU9R,MAAMiM,EAAS6F,GAGd,EAAe2vC,qBAElCx1C,EAAQ0H,UAAUR,EAAGC,GACrBnH,EAAQwH,MAAMA,EAAM,GAAIA,EAAM,IA2ClC,SAAkCiuC,EAAOz1C,GACvC,MAAMw1C,EAAsBC,EAAMD,oBAClC,IAAK,IAAI/jD,EAAI,EAAGuE,EAAKw/C,EAAoBxkD,OAAQS,EAAIuE,EAAIvE,GAAK,EACxDS,MAAMC,QAAQqjD,EAAoB/jD,EAAI,IACxCuO,EAAQw1C,EAAoB/jD,IAAIsC,MAC9BiM,EACAw1C,EAAoB/jD,EAAI,IAG1BuO,EAAQw1C,EAAoB/jD,IAAM+jD,EAAoB/jD,EAAI,EAGhE,CAtDIikD,CAA+C,EAAe11C,IACrDwH,EAAM,GAAK,GAAKA,EAAM,GAAK,GAEpCxH,EAAQ0H,UAAUR,EAAGC,GACrBnH,EAAQwH,MAAMA,EAAM,GAAIA,EAAM,IAC9BxH,EAAQ6C,UACZ,EAGMuyC,EACAC,EACAxN,EACAzX,EACA,EACA,EACAyX,EACAzX,IAIFpwB,EAAQ6C,UACZ,EAGMuyC,EACAC,EACAxN,EACAzX,EACAlpB,EACAC,EACA0gC,EAAIrgC,EAAM,GACV4oB,EAAI5oB,EAAM,IAIdxH,EAAQ21C,SACV,CC7TA,IAAAC,GArJA,cAAmCC,GAIjC,WAAAlmD,CAAYgrC,GACV7lC,MAAM6lC,GAKN9qC,KAAKimD,uBAAyBl/C,EAC5Bu7C,GACAjiD,EACAyqC,EAAIob,WAAWh/C,KAAK4jC,IAOtB9qC,KAAKmmD,SAAWp2C,SAASC,cAAc,OACvC,MAAMO,EAAQvQ,KAAKmmD,SAAS51C,MAC5BA,EAAM2oB,SAAW,WACjB3oB,EAAMd,MAAQ,OACdc,EAAMb,OAAS,OACfa,EAAMy8B,OAAS,IAEfhtC,KAAKmmD,SAAS7Y,UAAYwT,GAAqB,aAE/C,MAAMsF,EAAYtb,EAAIub,cACtBD,EAAUn0C,aAAajS,KAAKmmD,SAAUC,EAAUE,YAAc,MAM9DtmD,KAAKumD,UAAY,GAMjBvmD,KAAKwmD,kBAAmB,EAKxBxmD,KAAKymD,iBAAmB,EACzB,CAMD,mBAAAvH,CAAoBn/C,EAAM09C,GACxB,MAAM3S,EAAM9qC,KAAKsgD,SACjB,GAAIxV,EAAIrkC,YAAY1G,GAAO,CACzB,MAAM8F,EAAQ,IAAI6gD,GAAY3mD,OAAMyG,EAAWi3C,GAC/C3S,EAAIllC,cAAcC,EACnB,CACF,CAED,eAAApF,GACE6G,EAActH,KAAKimD,wBACnBjmD,KAAKmmD,SAAS/0C,WAAWI,YAAYxR,KAAKmmD,UAC1ClhD,MAAMxE,iBACP,CAMD,WAAA69C,CAAYb,GACV,IAAKA,EAKH,YAJIz9C,KAAKwmD,mBACPxmD,KAAKmmD,SAAS51C,MAAM+zC,QAAU,OAC9BtkD,KAAKwmD,kBAAmB,IAK5BxmD,KAAKm/C,oBAAoB1B,GACzBz9C,KAAKk/C,oBAAoBT,GAA4BhB,GAErD,MAAMI,EAAmBJ,EAAWI,iBAAiBvpB,MAAK,SAAUjzB,EAAGC,GACrE,OAAOD,EAAE2rC,OAAS1rC,EAAE0rC,MAC1B,IACUwM,EAAYiE,EAAWjE,UAE7Bx5C,KAAKumD,UAAUplD,OAAS,EAExB,MAAMwlD,EAAkB3mD,KAAKymD,iBAC7BE,EAAgBxlD,OAAS,EAEzB,IAAIylD,EAAkB,KACtB,IAAK,IAAIhlD,EAAI,EAAGuE,EAAK03C,EAAiB18C,OAAQS,EAAIuE,IAAMvE,EAAG,CACzD,MAAMw6C,EAAayB,EAAiBj8C,GACpC67C,EAAWoJ,WAAajlD,EAExB,MAAMgsC,EAAQwO,EAAWxO,MACnBkZ,EAAclZ,EAAMW,iBAC1B,IACG4N,GAAOC,EAAY5C,IACJ,SAAfsN,GAAyC,aAAfA,EAC3B,CACAlZ,EAAM2Q,WACN,QACD,CAED,MAAMh0C,EAAUqjC,EAAMkP,OAAOW,EAAYmJ,GACpCr8C,IAGDA,IAAYq8C,IACd5mD,KAAKumD,UAAU5gD,KAAK4E,GACpBq8C,EAAkBr8C,GAEhB,iBAAkBqjC,GACpB+Y,EAAgBhhD,KACxB,GAGK,CACD3F,KAAKugD,oBAAoB9C,GAEzB9rC,GAAgB3R,KAAKmmD,SAAUnmD,KAAKumD,WAEpCvmD,KAAKk/C,oBAAoBT,GAA6BhB,GAEjDz9C,KAAKwmD,mBACRxmD,KAAKmmD,SAAS51C,MAAM+zC,QAAU,GAC9BtkD,KAAKwmD,kBAAmB,GAG1BxmD,KAAKwgD,wBAAwB/C,EAC9B,CAKD,mBAAA8C,CAAoB9C,GAClB,MAAMsJ,EAAS/mD,KAAKymD,iBACpB,IAAK,IAAI7kD,EAAImlD,EAAO5lD,OAAS,EAAGS,GAAK,IAAKA,EACxCmlD,EAAOnlD,GAAGolD,gBAAgBvJ,GAE5BsJ,EAAO5lD,OAAS,CACjB,GC3II,MAAM8lD,WAAmBlhD,EAK9B,WAAAjG,CAAYC,EAAM6tC,GAChB3oC,MAAMlF,GAONC,KAAK4tC,MAAQA,CACd,EAqCH,MAAMvjC,GACI,SAWV,MAAM68C,WAAmB5K,GAIvB,WAAAx8C,CAAY6K,GACVA,EAAUA,GAAW,GACrB,MAAM4xC,EAAsC71C,OAAO8C,OAAO,CAAA,EAAImB,UACvD4xC,EAAYwK,OAEnB,IAAIA,EAASp8C,EAAQo8C,OAErB9hD,MAAMs3C,GAKNv8C,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAML3H,KAAKmnD,oBAAsB,GAM3BnnD,KAAKonD,cAAgB,GAErBpnD,KAAK6J,kBAAkBQ,GAAiBrK,KAAKqnD,sBAEzCN,EACE1kD,MAAMC,QAAQykD,GAChBA,EAAS,IAAIv8C,EAAWu8C,EAAOjjD,QAAS,CAAC+G,QAAQ,IAEjDoJ,GACkD,mBAAvB,EAAiB,SAC1C,sDAIJ8yC,EAAS,IAAIv8C,OAAWhE,EAAW,CAACqE,QAAQ,IAG9C7K,KAAKsnD,UAAUP,EAChB,CAKD,kBAAAQ,GACEvnD,KAAK6H,SACN,CAKD,oBAAAw/C,GACErnD,KAAKmnD,oBAAoBh8C,QAAQ7D,GACjCtH,KAAKmnD,oBAAoBhmD,OAAS,EAElC,MAAM4lD,EAAS/mD,KAAKwnD,YACpBxnD,KAAKmnD,oBAAoBxhD,KACvBoB,EAAOggD,EAAQ38C,EAAyBpK,KAAKynD,iBAAkBznD,MAC/D+G,EAAOggD,EAAQ38C,EAA4BpK,KAAK0nD,oBAAqB1nD,OAGvE,IAAK,MAAMwN,KAAMxN,KAAKonD,cACpBpnD,KAAKonD,cAAc55C,GAAIrC,QAAQ7D,GAEjC3C,EAAM3E,KAAKonD,eAEX,MAAMO,EAAcZ,EAAO17C,WAC3B,IAAK,IAAIzJ,EAAI,EAAGuE,EAAKwhD,EAAYxmD,OAAQS,EAAIuE,EAAIvE,IAAK,CACpD,MAAMgsC,EAAQ+Z,EAAY/lD,GAC1B5B,KAAK4nD,wBAAwBha,GAC7B5tC,KAAK4F,cAAc,IAAIqhD,GAAW,WAAYrZ,GAC/C,CACD5tC,KAAK6H,SACN,CAKD,uBAAA+/C,CAAwBha,GACtB,MAAMhT,EAAe,CACnB7zB,EACE6mC,EACAvtC,EACAL,KAAKunD,mBACLvnD,MAEF+G,EAAO6mC,EAAO9lC,EAAkB9H,KAAKunD,mBAAoBvnD,OAGvD4tC,aAAiBsZ,IACnBtsB,EAAaj1B,KACXoB,EAAO6mC,EAAO,WAAY5tC,KAAK6nD,qBAAsB7nD,MACrD+G,EAAO6mC,EAAO,cAAe5tC,KAAK8nD,wBAAyB9nD,OAI/DA,KAAKonD,cAAc1+C,EAAOklC,IAAUhT,CACrC,CAKD,oBAAAitB,CAAqBhiD,GACnB7F,KAAK4F,cAAc,IAAIqhD,GAAW,WAAYphD,EAAM+nC,OACrD,CAKD,uBAAAka,CAAwBjiD,GACtB7F,KAAK4F,cAAc,IAAIqhD,GAAW,cAAephD,EAAM+nC,OACxD,CAMD,gBAAA6Z,CAAiBM,GACf,MAAMna,EAAQma,EAAgBx9C,QAC9BvK,KAAK4nD,wBAAwBha,GAC7B5tC,KAAK4F,cAAc,IAAIqhD,GAAW,WAAYrZ,IAC9C5tC,KAAK6H,SACN,CAMD,mBAAA6/C,CAAoBK,GAClB,MAAMna,EAAQma,EAAgBx9C,QACxBhD,EAAMmB,EAAOklC,GACnB5tC,KAAKonD,cAAc7/C,GAAK4D,QAAQ7D,UACzBtH,KAAKonD,cAAc7/C,GAC1BvH,KAAK4F,cAAc,IAAIqhD,GAAW,cAAerZ,IACjD5tC,KAAK6H,SACN,CAUD,SAAA2/C,GACE,OACExnD,KAAKoJ,IAAIiB,GAEZ,CAUD,SAAAi9C,CAAUP,GACR,MAAMiB,EAAahoD,KAAKwnD,YACxB,GAAIQ,EAAY,CACd,MAAMC,EAAgBD,EAAW38C,WACjC,IAAK,IAAIzJ,EAAI,EAAGuE,EAAK8hD,EAAc9mD,OAAQS,EAAIuE,IAAMvE,EACnD5B,KAAK4F,cAAc,IAAIqhD,GAAW,cAAegB,EAAcrmD,IAElE,CAED5B,KAAK+J,IAAIM,GAAiB08C,EAC3B,CAMD,cAAA3Y,CAAe1jC,GAKb,OAJAA,OAAkBlE,IAAVkE,EAAsBA,EAAQ,GACtC1K,KAAKwnD,YAAYr8C,SAAQ,SAAUyiC,GACjCA,EAAMQ,eAAe1jC,EAC3B,IACWA,CACR,CAWD,mBAAA2jC,CAAoBz0B,GAClB,MAAM00B,OAAkB9nC,IAAToT,EAAqBA,EAAO,GACrCsuC,EAAM5Z,EAAOntC,OAEnBnB,KAAKwnD,YAAYr8C,SAAQ,SAAUyiC,GACjCA,EAAMS,oBAAoBC,EAChC,IAEI,MAAM6Z,EAAgBnoD,KAAK0tC,gBAC3B,IAAI0a,EAAgBD,EAAcnb,OAC7BpzB,QAAiCpT,IAAzB2hD,EAAcnb,SACzBob,EAAgB,GAElB,IAAK,IAAIxmD,EAAIsmD,EAAK/hD,EAAKmoC,EAAOntC,OAAQS,EAAIuE,EAAIvE,IAAK,CACjD,MAAMw6C,EAAa9N,EAAO1sC,GAC1Bw6C,EAAWtP,SAAWqb,EAAcrb,QACpCsP,EAAWrP,QAAUqP,EAAWrP,SAAWob,EAAcpb,QACzDqP,EAAWnP,cAAgBhhC,KAAKwP,IAC9B2gC,EAAWnP,cACXkb,EAAclb,eAEhBmP,EAAWlP,cAAgBjhC,KAAKyP,IAC9B0gC,EAAWlP,cACXib,EAAcjb,eAEhBkP,EAAWjP,QAAUlhC,KAAKyP,IAAI0gC,EAAWjP,QAASgb,EAAchb,SAChEiP,EAAWhP,QAAUnhC,KAAKwP,IAAI2gC,EAAWhP,QAAS+a,EAAc/a,cACnC5mC,IAAzB2hD,EAAc3uC,cACUhT,IAAtB41C,EAAW5iC,OACb4iC,EAAW5iC,OAASoE,GAClBw+B,EAAW5iC,OACX2uC,EAAc3uC,QAGhB4iC,EAAW5iC,OAAS2uC,EAAc3uC,aAGZhT,IAAtB41C,EAAWpP,SACboP,EAAWpP,OAASob,EAEvB,CAED,OAAO9Z,CACR,CAKD,cAAAC,GACE,MAAO,OACR,EAGH,IAAA8Z,GAAenB,GC3Tf,IAAAoB,GAzBA,cAAuBviD,EAMrB,WAAAjG,CAAYC,EAAM+qC,EAAK2S,GACrBx4C,MAAMlF,GAONC,KAAK8qC,IAAMA,EAOX9qC,KAAKy9C,gBAA4Bj3C,IAAfi3C,EAA2BA,EAAa,IAC3D,GCkFH,IAAA8K,GAvGA,cAA8BC,GAS5B,WAAA1oD,CAAYC,EAAM+qC,EAAK2d,EAAeC,EAAUjL,EAAYkL,GAC1D1jD,MAAMlF,EAAM+qC,EAAK2S,GAQjBz9C,KAAKyoD,cAAgBA,EAMrBzoD,KAAK4oD,OAAS,KAMd5oD,KAAK6oD,YAAc,KASnB7oD,KAAK0oD,cAAwBliD,IAAbkiD,GAAyBA,EAKzC1oD,KAAK2oD,eAAiBA,CACvB,CAOD,SAAIrL,GAIF,OAHKt9C,KAAK4oD,SACR5oD,KAAK4oD,OAAS5oD,KAAK8qC,IAAIge,cAAc9oD,KAAKyoD,gBAErCzoD,KAAK4oD,MACb,CACD,SAAItL,CAAMA,GACRt9C,KAAK4oD,OAAStL,CACf,CAQD,cAAIlmC,GAIF,OAHKpX,KAAK6oD,cACR7oD,KAAK6oD,YAAc7oD,KAAK8qC,IAAIie,uBAAuB/oD,KAAKs9C,QAEnDt9C,KAAK6oD,WACb,CACD,cAAIzxC,CAAWA,GACbpX,KAAK6oD,YAAczxC,CACpB,CAOD,cAAAhX,GACE6E,MAAM7E,iBACF,mBAAoBJ,KAAKyoD,eACHzoD,KAAkB,cAAEI,gBAE/C,CAOD,eAAAT,GACEsF,MAAMtF,kBACF,oBAAqBK,KAAKyoD,eACJzoD,KAAkB,cAAEL,iBAE/C,GCtGYqpD,GAAA,CAObC,YAAa,cAObC,MAAOphD,EAOPqhD,SAAUrhD,EAOVshD,YAAa,cAQbC,YAAa,cAEbC,YAAa,cACbC,UAAW,YACXC,YAAa,cACbC,WAAY,aACZC,aAAc,eACdC,aAAc,eACdC,cAAe,iBC7CFC,GACA,cADAA,GAEA,cAFAA,GAGF,YAHEA,GAKD,aCiZd,IAAAC,GAlZA,cAAqCC,EAKnC,WAAAjqD,CAAYgrC,EAAKkf,GACf/kD,MAAM6lC,GAON9qC,KAAKi/C,KAAOnU,EAMZ9qC,KAAKiqD,gBAMLjqD,KAAKkqD,gBAAiB,EAMtBlqD,KAAKmqD,WAAY,EAMjBnqD,KAAKoqD,kBAAoB,GAMzBpqD,KAAKqqD,oBAAmC7jD,IAAlBwjD,EAA8B,EAAIA,EAQxDhqD,KAAKsqD,MAAQ,KAEb,MAAM//C,EAAUvK,KAAKi/C,KAAKoH,cAM1BrmD,KAAKuqD,gBAAkB,GAMvBvqD,KAAKwqD,gBAAkB,GAEvBxqD,KAAKmmD,SAAW57C,EAMhBvK,KAAKyqD,wBAA0B1jD,EAC7BwD,EACAs/C,GACA7pD,KAAK0qD,mBACL1qD,MAOFA,KAAK2qD,0BAML3qD,KAAK4qD,oBAAsB7jD,EACzBwD,EACAs/C,GACA7pD,KAAK6qD,gBACL7qD,MAMFA,KAAK8qD,sBAAwB9qD,KAAK+qD,iBAAiB7jD,KAAKlH,MAExDA,KAAKmmD,SAAS7gD,iBACZwC,EACA9H,KAAK8qD,wBACL37C,IAA0B,CAACC,SAAS,GAEvC,CAOD,aAAA47C,CAAcC,GACZ,IAAIC,EAAW,IAAIC,GACjBnC,GAAoBE,MACpBlpD,KAAKi/C,KACLgM,GAEFjrD,KAAK4F,cAAcslD,QACU1kD,IAAzBxG,KAAKiqD,iBAEPmB,aAAaprD,KAAKiqD,iBAClBjqD,KAAKiqD,qBAAkBzjD,EACvB0kD,EAAW,IAAIC,GACbnC,GAAoBG,SACpBnpD,KAAKi/C,KACLgM,GAEFjrD,KAAK4F,cAAcslD,IAGnBlrD,KAAKiqD,gBAAkBxY,YAAW,KAChCzxC,KAAKiqD,qBAAkBzjD,EACvB,MAAM0kD,EAAW,IAAIC,GACnBnC,GAAoBC,YACpBjpD,KAAKi/C,KACLgM,GAEFjrD,KAAK4F,cAAcslD,EAAS,GAC3B,IAEN,CASD,qBAAAG,CAAsBJ,GACpB,MAAMplD,EAAQolD,EACRz9C,EAAK3H,EAAMylD,UAEjB,GACEzlD,EAAM9F,MAAQipD,GAAoBO,WAClC1jD,EAAM9F,MAAQipD,GAAoBY,cAClC,QACO5pD,KAAKwqD,gBAAgBh9C,GAC5B,IAAK,MAAM89C,KAAatrD,KAAKwqD,gBAC3B,GAAIxqD,KAAKwqD,gBAAgBc,GAAWnrD,SAAW0F,EAAM1F,OAAQ,QAKpDH,KAAKwqD,gBAAgBc,GAC5B,KACD,CAET,MACMzlD,EAAM9F,MAAQipD,GAAoBM,aAClCzjD,EAAM9F,MAAQipD,GAAoBK,cAElCrpD,KAAKwqD,gBAAgBh9C,GAAM3H,GAE7B7F,KAAKuqD,gBAAkB7jD,OAAOuC,OAAOjJ,KAAKwqD,gBAC3C,CAOD,gBAAAe,CAAiBN,GACfjrD,KAAKqrD,sBAAsBJ,GAC3B,MAAMC,EAAW,IAAIC,GACnBnC,GAAoBO,UACpBvpD,KAAKi/C,KACLgM,OACAzkD,OACAA,EACAxG,KAAKuqD,iBAEPvqD,KAAK4F,cAAcslD,GASjBlrD,KAAKkqD,iBACJgB,EAAShrD,mBACTF,KAAKmqD,WACNnqD,KAAKwrD,qBAAqBP,IAE1BjrD,KAAKgrD,cAAchrD,KAAKsqD,OAGU,IAAhCtqD,KAAKuqD,gBAAgBppD,SACvBnB,KAAKoqD,kBAAkBj/C,QAAQ7D,GAC/BtH,KAAKoqD,kBAAkBjpD,OAAS,EAChCnB,KAAKmqD,WAAY,EACjBnqD,KAAKsqD,MAAQ,KAEhB,CAQD,oBAAAkB,CAAqBP,GACnB,OAA+B,IAAxBA,EAAaQ,MACrB,CAOD,kBAAAf,CAAmBO,GACjBjrD,KAAKkqD,eAAiD,IAAhClqD,KAAKuqD,gBAAgBppD,OAC3CnB,KAAKqrD,sBAAsBJ,GAC3B,MAAMC,EAAW,IAAIC,GACnBnC,GAAoBM,YACpBtpD,KAAKi/C,KACLgM,OACAzkD,OACAA,EACAxG,KAAKuqD,iBAUP,GARAvqD,KAAK4F,cAAcslD,GAEnBlrD,KAAKsqD,MAAQ,IAAIoB,aAAaT,EAAalrD,KAAMkrD,GACjDvkD,OAAO2I,eAAerP,KAAKsqD,MAAO,SAAU,CAC1CqB,UAAU,EACVtnD,MAAO4mD,EAAa9qD,SAGgB,IAAlCH,KAAKoqD,kBAAkBjpD,OAAc,CACvC,MAAMyqD,EAAM5rD,KAAKi/C,KAAK4M,mBACtB7rD,KAAKoqD,kBAAkBzkD,KACrBoB,EACE6kD,EACA5C,GAAoBK,YACpBrpD,KAAK8rD,mBACL9rD,MAEF+G,EAAO6kD,EAAK5C,GAAoBO,UAAWvpD,KAAKurD,iBAAkBvrD,MAclE+G,EACE/G,KAAKmmD,SACL6C,GAAoBY,cACpB5pD,KAAKurD,iBACLvrD,OAGAA,KAAKmmD,SAAS4F,aAAe/rD,KAAKmmD,SAAS4F,gBAAkBH,GAC/D5rD,KAAKoqD,kBAAkBzkD,KACrBoB,EACE/G,KAAKmmD,SAAS4F,cACd/C,GAAoBO,UACpBvpD,KAAKurD,iBACLvrD,MAIP,CACF,CAOD,kBAAA8rD,CAAmBb,GAIjB,GAAIjrD,KAAKgsD,UAAUf,GAAe,CAChCjrD,KAAKqrD,sBAAsBJ,GAC3BjrD,KAAKmqD,WAAY,EACjB,MAAMe,EAAW,IAAIC,GACnBnC,GAAoBI,YACpBppD,KAAKi/C,KACLgM,EACAjrD,KAAKmqD,eACL3jD,EACAxG,KAAKuqD,iBAEPvqD,KAAK4F,cAAcslD,EACpB,CACF,CAQD,eAAAL,CAAgBI,GACdjrD,KAAK2qD,0BAA4BM,EACjC,MAAMvC,KAAc1oD,KAAKsqD,QAAStqD,KAAKgsD,UAAUf,IACjDjrD,KAAK4F,cACH,IAAIulD,GACFnC,GAAoBK,YACpBrpD,KAAKi/C,KACLgM,EACAvC,GAGL,CAUD,gBAAAqC,CAAiBllD,GAIf,MAAM4iD,EAAgBzoD,KAAK2qD,0BAEvBlC,IAAiBA,EAAcvoD,kBACJ,kBAArB2F,EAAMomD,aAAiD,IAArBpmD,EAAMomD,YAEhDpmD,EAAMzF,gBAET,CAQD,SAAA4rD,CAAUf,GACR,OACEjrD,KAAKmqD,WACLl+C,KAAKmP,IAAI6vC,EAAaiB,QAAUlsD,KAAKsqD,MAAM4B,SACzClsD,KAAKqqD,gBACPp+C,KAAKmP,IAAI6vC,EAAakB,QAAUnsD,KAAKsqD,MAAM6B,SAAWnsD,KAAKqqD,cAE9D,CAKD,eAAA5pD,GACMT,KAAK4qD,sBACPtjD,EAActH,KAAK4qD,qBACnB5qD,KAAK4qD,oBAAsB,MAE7B5qD,KAAKmmD,SAAS7/C,oBACZwB,EACA9H,KAAK8qD,uBAGH9qD,KAAKyqD,0BACPnjD,EAActH,KAAKyqD,yBACnBzqD,KAAKyqD,wBAA0B,MAGjCzqD,KAAKoqD,kBAAkBj/C,QAAQ7D,GAC/BtH,KAAKoqD,kBAAkBjpD,OAAS,EAEhCnB,KAAKmmD,SAAW,KAChBlhD,MAAMxE,iBACP,GCpZY2rD,GAMD,aANCA,GAaF,YAbEA,GAoBJ,UApBIA,GA2BF,YA3BEA,GAkCJ,UClCIC,GACD,aADCA,GAEP,OAFOA,GAGL,SAHKA,GAIP,OCFD,MAAMC,GAAO7xC,IA+PpB,IAAA8xC,GAjPA,MAKE,WAAAzsD,CAAY0sD,EAAkBC,GAK5BzsD,KAAK0sD,kBAAoBF,EAMzBxsD,KAAK2sD,aAAeF,EAMpBzsD,KAAK4sD,UAAY,GAMjB5sD,KAAK6sD,YAAc,GAMnB7sD,KAAK8sD,gBAAkB,EACxB,CAKD,KAAAnoD,GACE3E,KAAK4sD,UAAUzrD,OAAS,EACxBnB,KAAK6sD,YAAY1rD,OAAS,EAC1BwD,EAAM3E,KAAK8sD,gBACZ,CAMD,OAAAC,GACE,MAAMC,EAAWhtD,KAAK4sD,UAChBK,EAAajtD,KAAK6sD,YAClBtiD,EAAUyiD,EAAS,GACF,GAAnBA,EAAS7rD,QACX6rD,EAAS7rD,OAAS,EAClB8rD,EAAW9rD,OAAS,IAEpB6rD,EAAS,GAAuBA,EAAS9hD,MACzC+hD,EAAW,GAA4BA,EAAW/hD,MAClDlL,KAAKktD,QAAQ,IAEf,MAAMC,EAAantD,KAAK2sD,aAAapiD,GAErC,cADOvK,KAAK8sD,gBAAgBK,GACrB5iD,CACR,CAOD,OAAA6iD,CAAQ7iD,GACN0J,KACIjU,KAAK2sD,aAAapiD,KAAYvK,KAAK8sD,iBACrC,qEAEF,MAAMO,EAAWrtD,KAAK0sD,kBAAkBniD,GACxC,OAAI8iD,GAAYf,KACdtsD,KAAK4sD,UAAUjnD,KAAK4E,GACpBvK,KAAK6sD,YAAYlnD,KAAK0nD,GACtBrtD,KAAK8sD,gBAAgB9sD,KAAK2sD,aAAapiD,KAAY,EACnDvK,KAAKstD,UAAU,EAAGttD,KAAK4sD,UAAUzrD,OAAS,IACnC,EAGV,CAKD,QAAAosD,GACE,OAAOvtD,KAAK4sD,UAAUzrD,MACvB,CAQD,kBAAAqsD,CAAmBvqD,GACjB,OAAe,EAARA,EAAY,CACpB,CAQD,mBAAAwqD,CAAoBxqD,GAClB,OAAe,EAARA,EAAY,CACpB,CAQD,eAAAyqD,CAAgBzqD,GACd,OAAQA,EAAQ,GAAM,CACvB,CAMD,QAAA0qD,GACE,IAAI/rD,EACJ,IAAKA,GAAK5B,KAAK4sD,UAAUzrD,QAAU,GAAK,EAAGS,GAAK,EAAGA,IACjD5B,KAAKktD,QAAQtrD,EAEhB,CAKD,OAAAkD,GACE,OAAiC,IAA1B9E,KAAK4sD,UAAUzrD,MACvB,CAMD,WAAAysD,CAAYrmD,GACV,OAAOA,KAAOvH,KAAK8sD,eACpB,CAMD,QAAAe,CAAStjD,GACP,OAAOvK,KAAK4tD,YAAY5tD,KAAK2sD,aAAapiD,GAC3C,CAMD,OAAA2iD,CAAQjqD,GACN,MAAM+pD,EAAWhtD,KAAK4sD,UAChBK,EAAajtD,KAAK6sD,YAClBiB,EAAQd,EAAS7rD,OACjBoJ,EAAUyiD,EAAS/pD,GACnBoqD,EAAWJ,EAAWhqD,GACtB8qD,EAAa9qD,EAEnB,KAAOA,EAAQ6qD,GAAS,GAAG,CACzB,MAAME,EAAShuD,KAAKwtD,mBAAmBvqD,GACjCgrD,EAASjuD,KAAKytD,oBAAoBxqD,GAElCirD,EACJD,EAASH,GAASb,EAAWgB,GAAUhB,EAAWe,GAC9CC,EACAD,EAENhB,EAAS/pD,GAAS+pD,EAASkB,GAC3BjB,EAAWhqD,GAASgqD,EAAWiB,GAC/BjrD,EAAQirD,CACT,CAEDlB,EAAS/pD,GAASsH,EAClB0iD,EAAWhqD,GAASoqD,EACpBrtD,KAAKstD,UAAUS,EAAY9qD,EAC5B,CAOD,SAAAqqD,CAAUS,EAAY9qD,GACpB,MAAM+pD,EAAWhtD,KAAK4sD,UAChBK,EAAajtD,KAAK6sD,YAClBtiD,EAAUyiD,EAAS/pD,GACnBoqD,EAAWJ,EAAWhqD,GAE5B,KAAOA,EAAQ8qD,GAAY,CACzB,MAAMI,EAAcnuD,KAAK0tD,gBAAgBzqD,GACzC,KAAIgqD,EAAWkB,GAAed,GAK5B,MAJAL,EAAS/pD,GAAS+pD,EAASmB,GAC3BlB,EAAWhqD,GAASgqD,EAAWkB,GAC/BlrD,EAAQkrD,CAIX,CACDnB,EAAS/pD,GAASsH,EAClB0iD,EAAWhqD,GAASoqD,CACrB,CAKD,YAAAe,GACE,MAAM5B,EAAmBxsD,KAAK0sD,kBACxBM,EAAWhtD,KAAK4sD,UAChBK,EAAajtD,KAAK6sD,YACxB,IAAI5pD,EAAQ,EACZ,MAAMtB,EAAIqrD,EAAS7rD,OACnB,IAAIoJ,EAAS3I,EAAGyrD,EAChB,IAAKzrD,EAAI,EAAGA,EAAID,IAAKC,EACnB2I,EAAUyiD,EAASprD,GACnByrD,EAAWb,EAAiBjiD,GACxB8iD,GAAYf,UACPtsD,KAAK8sD,gBAAgB9sD,KAAK2sD,aAAapiD,KAE9C0iD,EAAWhqD,GAASoqD,EACpBL,EAAS/pD,KAAWsH,GAGxByiD,EAAS7rD,OAAS8B,EAClBgqD,EAAW9rD,OAAS8B,EACpBjD,KAAK2tD,UACN,GCxIH,IAAAU,GAlHA,cAAwBC,GAKtB,WAAAxuD,CAAYyuD,EAAsBC,GAChCvpD,OAKE,SAAUsF,GACR,OAAOgkD,EAAqBrqD,MAAM,KAAMqG,EACzC,IAKD,SAAUA,GACR,OAAmDA,EAAQ,GAAIyC,QAChE,IAIHhN,KAAKyuD,uBAAyBzuD,KAAK0uD,iBAAiBxnD,KAAKlH,MAMzDA,KAAK2uD,oBAAsBH,EAM3BxuD,KAAK4uD,cAAgB,EAMrB5uD,KAAK6uD,kBAAoB,EAC1B,CAMD,OAAAzB,CAAQ7iD,GACN,MAAMukD,EAAQ7pD,MAAMmoD,QAAQ7iD,GAC5B,GAAIukD,EAAO,CACIvkD,EAAQ,GAChBjF,iBAAiBwC,EAAkB9H,KAAKyuD,uBAC9C,CACD,OAAOK,CACR,CAKD,eAAAC,GACE,OAAO/uD,KAAK4uD,aACb,CAMD,gBAAAF,CAAiB7oD,GACf,MAAMqH,EAAmDrH,EAAY,OAC/D2G,EAAQU,EAAKC,WACnB,GACEX,IAAUV,GACVU,IAAUV,GACVU,IAAUV,EACV,CACIU,IAAUV,GACZoB,EAAK5G,oBAAoBwB,EAAkB9H,KAAKyuD,wBAElD,MAAMO,EAAU9hD,EAAKF,SACjBgiD,KAAWhvD,KAAK6uD,2BACX7uD,KAAK6uD,kBAAkBG,KAC5BhvD,KAAK4uD,eAET5uD,KAAK2uD,qBACN,CACF,CAMD,aAAAM,CAAcC,EAAiBC,GAC7B,IACI3iD,EAAOU,EAAM8hD,EADbI,EAAW,EAEf,KACEpvD,KAAK4uD,cAAgBM,GACrBE,EAAWD,GACXnvD,KAAKutD,WAAa,GAElBrgD,EAAmDlN,KAAK+sD,UAAU,GAClEiC,EAAU9hD,EAAKF,SACfR,EAAQU,EAAKC,WACTX,IAAUV,GAAoBkjD,KAAWhvD,KAAK6uD,oBAChD7uD,KAAK6uD,kBAAkBG,IAAW,IAChChvD,KAAK4uD,gBACLQ,EACFliD,EAAKI,OAGV,GAaI,SAAS+hD,GACd5R,EACAvwC,EACAoiD,EACAC,EACAC,GAIA,IAAK/R,KAAgB6R,KAAiB7R,EAAWgS,aAC/C,OAAOnD,GAET,IAAK7O,EAAWgS,YAAYH,GAAepiD,EAAKF,UAC9C,OAAOs/C,GAQT,MAAM5vC,EAAS+gC,EAAWjE,UAAU98B,OAC9BuB,EAASsxC,EAAW,GAAK7yC,EAAO,GAChCwB,EAASqxC,EAAW,GAAK7yC,EAAO,GACtC,OACE,MAAQzQ,KAAKsW,IAAIitC,GACjBvjD,KAAKma,KAAKnI,EAASA,EAASC,EAASA,GAAUsxC,CAEnD,CCHA,IAAAE,GAnHA,cAAsBjlD,EAIpB,WAAA3K,CAAY6K,GACV1F,QAEA,MAAMsF,EAAUI,EAAQJ,SACpBA,GAAYI,EAAQxK,QAAWoK,EAAQgG,MAAMo/C,gBAC/CplD,EAAQgG,MAAMo/C,cAAgB,QAOhC3vD,KAAKuK,QAAUA,GAAoB,KAMnCvK,KAAK4vD,QAAU,KAMf5vD,KAAKi/C,KAAO,KAMZj/C,KAAK46B,aAAe,GAEhBjwB,EAAQmyC,SACV98C,KAAK88C,OAASnyC,EAAQmyC,QAGpBnyC,EAAQxK,QACVH,KAAK6vD,UAAUllD,EAAQxK,OAE1B,CAKD,eAAAM,GACE6Q,GAAWtR,KAAKuK,SAChBtF,MAAMxE,iBACP,CAOD,MAAA6/C,GACE,OAAOtgD,KAAKi/C,IACb,CAUD,MAAAlC,CAAOjS,GACD9qC,KAAKi/C,MACP3tC,GAAWtR,KAAKuK,SAElB,IAAK,IAAI3I,EAAI,EAAGuE,EAAKnG,KAAK46B,aAAaz5B,OAAQS,EAAIuE,IAAMvE,EACvD0F,EAActH,KAAK46B,aAAah5B,IAIlC,GAFA5B,KAAK46B,aAAaz5B,OAAS,EAC3BnB,KAAKi/C,KAAOnU,EACRA,EAAK,EACQ9qC,KAAK4vD,QAChB5vD,KAAK4vD,QACL9kB,EAAIglB,gCACD59C,YAAYlS,KAAKuK,SACpBvK,KAAK88C,SAAWz5C,GAClBrD,KAAK46B,aAAaj1B,KAChBoB,EAAO+jC,EAAKshB,GAAyBpsD,KAAK88C,OAAQ98C,OAGtD8qC,EAAIgS,QACL,CACF,CAOD,MAAAA,CAAOiT,GAAY,CAWnB,SAAAF,CAAU1vD,GACRH,KAAK4vD,QACe,iBAAXzvD,EAAsB4P,SAASigD,eAAe7vD,GAAUA,CAClE,GCiLH,IAAA8vD,GAjSA,cAA0BC,GAIxB,WAAApwD,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B1F,MAAM,CACJsF,QAASwF,SAASC,cAAc,OAChC8sC,OAAQnyC,EAAQmyC,OAChB38C,OAAQwK,EAAQxK,SAOlBH,KAAKmwD,WAAapgD,SAASC,cAAc,MAMzChQ,KAAKowD,gBACmB5pD,IAAtBmE,EAAQ0lD,WAA0B1lD,EAAQ0lD,UAM5CrwD,KAAKswD,eAAiBtwD,KAAKowD,WAM3BpwD,KAAKuwD,0BAA+C/pD,IAAxBmE,EAAQ6lD,YAMpCxwD,KAAKywD,kBACqBjqD,IAAxBmE,EAAQ6lD,aAA4B7lD,EAAQ6lD,YAEzCxwD,KAAKywD,eACRzwD,KAAKowD,YAAa,GAGpB,MAAM9iB,OACkB9mC,IAAtBmE,EAAQ2iC,UAA0B3iC,EAAQ2iC,UAAY,iBAElDojB,OACiBlqD,IAArBmE,EAAQ+lD,SAAyB/lD,EAAQ+lD,SAAW,eAEhDC,OACwBnqD,IAA5BmE,EAAQgmD,gBACJhmD,EAAQgmD,gBACRrjB,EAAY,UAEZsjB,OACsBpqD,IAA1BmE,EAAQimD,cAA8BjmD,EAAQimD,cAAgB,IAE1DC,OAC0BrqD,IAA9BmE,EAAQkmD,kBACJlmD,EAAQkmD,kBACRvjB,EAAY,YAEW,iBAAlBsjB,GAKT5wD,KAAK8wD,eAAiB/gD,SAASC,cAAc,QAC7ChQ,KAAK8wD,eAAeC,YAAcH,EAClC5wD,KAAK8wD,eAAexjB,UAAYujB,GAEhC7wD,KAAK8wD,eAAiBF,EAGxB,MAAMhL,OAA0Bp/C,IAAlBmE,EAAQi7C,MAAsBj7C,EAAQi7C,MAAQ,IAEvC,iBAAVA,GAKT5lD,KAAKgxD,OAASjhD,SAASC,cAAc,QACrChQ,KAAKgxD,OAAOD,YAAcnL,EAC1B5lD,KAAKgxD,OAAO1jB,UAAYqjB,GAExB3wD,KAAKgxD,OAASpL,EAGhB,MAAMqL,EACJjxD,KAAKywD,eAAiBzwD,KAAKowD,WAAapwD,KAAK8wD,eAAiB9wD,KAAKgxD,OAMrEhxD,KAAKkxD,cAAgBnhD,SAASC,cAAc,UAC5ChQ,KAAKkxD,cAAcC,aAAa,OAAQ,UACxCnxD,KAAKkxD,cAAcC,aAAa,gBAAiBtoD,QAAQ7I,KAAKowD,aAC9DpwD,KAAKkxD,cAAcE,MAAQV,EAC3B1wD,KAAKkxD,cAAch/C,YAAY++C,GAE/BjxD,KAAKkxD,cAAc5rD,iBACjBwC,EACA9H,KAAKqxD,aAAanqD,KAAKlH,OACvB,GAGF,MAAMsxD,EACJhkB,EACA,IACAwT,GACA,IACAE,IACChhD,KAAKowD,YAAcpwD,KAAKywD,aAAe,IAAMxP,GAAkB,KAC/DjhD,KAAKywD,aAAe,GAAK,qBACtBlmD,EAAUvK,KAAKuK,QACrBA,EAAQ+iC,UAAYgkB,EACpB/mD,EAAQ2H,YAAYlS,KAAKkxD,eACzB3mD,EAAQ2H,YAAYlS,KAAKmwD,YAOzBnwD,KAAKuxD,sBAAwB,GAM7BvxD,KAAKwmD,kBAAmB,CACzB,CAQD,0BAAAgL,CAA2B/T,GACzB,MAAMgU,EAAsBpvD,MAAMqvD,KAChC,IAAIC,IACF3xD,KAAKsgD,SACFsR,eACAC,SAASjkB,GAAUA,EAAMqQ,gBAAgBR,OAI1C+S,GAAexwD,KAAKsgD,SACvBsR,eACAlT,MACE9Q,GACCA,EAAMsP,cAC6C,IAAnDtP,EAAMsP,YAAY4U,+BAKxB,OAHK9xD,KAAKuwD,sBACRvwD,KAAK+xD,eAAevB,GAEfiB,CACR,CAMD,cAAAO,CAAevU,GACb,IAAKA,EAKH,YAJIz9C,KAAKwmD,mBACPxmD,KAAKuK,QAAQgG,MAAM+zC,QAAU,OAC7BtkD,KAAKwmD,kBAAmB,IAK5B,MAAMtI,EAAel+C,KAAKwxD,2BAA2B/T,GAE/C1Q,EAAUmR,EAAa/8C,OAAS,EAMtC,GALInB,KAAKwmD,kBAAoBzZ,IAC3B/sC,KAAKuK,QAAQgG,MAAM+zC,QAAUvX,EAAU,GAAK,OAC5C/sC,KAAKwmD,iBAAmBzZ,IAGtBxqC,EAAO27C,EAAcl+C,KAAKuxD,uBAA9B,CAIA9/C,GAAezR,KAAKmwD,YAGpB,IAAK,IAAIvuD,EAAI,EAAGuE,EAAK+3C,EAAa/8C,OAAQS,EAAIuE,IAAMvE,EAAG,CACrD,MAAM2I,EAAUwF,SAASC,cAAc,MACvCzF,EAAQ25C,UAAYhG,EAAat8C,GACjC5B,KAAKmwD,WAAWj+C,YAAY3H,EAC7B,CAEDvK,KAAKuxD,sBAAwBrT,CAX5B,CAYF,CAMD,YAAAmT,CAAaxrD,GACXA,EAAMzF,iBACNJ,KAAKiyD,gBACLjyD,KAAKswD,eAAiBtwD,KAAKowD,UAC5B,CAKD,aAAA6B,GACEjyD,KAAKuK,QAAQ2nD,UAAUC,OAAOlR,IAC1BjhD,KAAKowD,WACPp/C,GAAYhR,KAAK8wD,eAAgB9wD,KAAKgxD,QAEtChgD,GAAYhR,KAAKgxD,OAAQhxD,KAAK8wD,gBAEhC9wD,KAAKowD,YAAcpwD,KAAKowD,WACxBpwD,KAAKkxD,cAAcC,aAAa,gBAAiBtoD,QAAQ7I,KAAKowD,YAC/D,CAOD,cAAAgC,GACE,OAAOpyD,KAAKywD,YACb,CAOD,cAAAsB,CAAevB,GACTxwD,KAAKywD,eAAiBD,IAG1BxwD,KAAKywD,aAAeD,EACpBxwD,KAAKuK,QAAQ2nD,UAAUC,OAAO,oBAC1BnyD,KAAKswD,gBACPtwD,KAAKiyD,gBAER,CASD,YAAAI,CAAahC,GACXrwD,KAAKswD,eAAiBD,EACjBrwD,KAAKywD,cAAgBzwD,KAAKowD,aAAeC,GAG9CrwD,KAAKiyD,eACN,CAQD,YAAAK,GACE,OAAOtyD,KAAKowD,UACb,CAOD,MAAAtT,CAAOiT,GACL/vD,KAAKgyD,eAAejC,EAAStS,WAC9B,GCtJH,IAAA8U,GApJA,cAAqBrC,GAInB,WAAApwD,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B1F,MAAM,CACJsF,QAASwF,SAASC,cAAc,OAChC8sC,OAAQnyC,EAAQmyC,OAChB38C,OAAQwK,EAAQxK,SAGlB,MAAMmtC,OACkB9mC,IAAtBmE,EAAQ2iC,UAA0B3iC,EAAQ2iC,UAAY,YAElDsY,OAA0Bp/C,IAAlBmE,EAAQi7C,MAAsBj7C,EAAQi7C,MAAQ,IAEtD4M,OACyBhsD,IAA7BmE,EAAQ6nD,iBACJ7nD,EAAQ6nD,iBACR,aAMNxyD,KAAKgxD,OAAS,KAEO,iBAAVpL,GACT5lD,KAAKgxD,OAASjhD,SAASC,cAAc,QACrChQ,KAAKgxD,OAAO1jB,UAAYklB,EACxBxyD,KAAKgxD,OAAOD,YAAcnL,IAE1B5lD,KAAKgxD,OAASpL,EACd5lD,KAAKgxD,OAAOkB,UAAUzuC,IAAI+uC,IAG5B,MAAM9B,EAAW/lD,EAAQ+lD,SAAW/lD,EAAQ+lD,SAAW,iBAEjDjF,EAAS17C,SAASC,cAAc,UACtCy7C,EAAOne,UAAYA,EAAY,SAC/Bme,EAAO0F,aAAa,OAAQ,UAC5B1F,EAAO2F,MAAQV,EACfjF,EAAOv5C,YAAYlS,KAAKgxD,QAExBvF,EAAOnmD,iBACLwC,EACA9H,KAAKqxD,aAAanqD,KAAKlH,OACvB,GAGF,MAAMsxD,EACJhkB,EAAY,IAAMwT,GAAqB,IAAME,GACzCz2C,EAAUvK,KAAKuK,QACrBA,EAAQ+iC,UAAYgkB,EACpB/mD,EAAQ2H,YAAYu5C,GAEpBzrD,KAAKyyD,gBAAkB9nD,EAAQ+nD,WAAa/nD,EAAQ+nD,gBAAalsD,EAMjExG,KAAK2yD,eAAiCnsD,IAArBmE,EAAQwzB,SAAyBxzB,EAAQwzB,SAAW,IAMrEn+B,KAAK4yD,eAAiCpsD,IAArBmE,EAAQkoD,UAAyBloD,EAAQkoD,SAM1D7yD,KAAK8yD,eAAYtsD,EAEbxG,KAAK4yD,WACP5yD,KAAKuK,QAAQ2nD,UAAUzuC,IAAIm9B,GAE9B,CAMD,YAAAyQ,CAAaxrD,GACXA,EAAMzF,sBACuBoG,IAAzBxG,KAAKyyD,gBACPzyD,KAAKyyD,kBAELzyD,KAAK+yD,aAER,CAKD,WAAAA,GACE,MACMvV,EADMx9C,KAAKsgD,SACA3C,UACjB,IAAKH,EAGH,OAEF,MAAM5gC,EAAW4gC,EAAK1H,mBACLtvC,IAAboW,IACE5c,KAAK2yD,UAAY,GAAK/1C,GAAY,EAAI3Q,KAAK+T,KAAQ,EACrDw9B,EAAKzH,QAAQ,CACXn5B,SAAU,EACVuhB,SAAUn+B,KAAK2yD,UACfpc,OAAQpqC,KAGVqxC,EAAKtI,YAAY,GAGtB,CAOD,MAAA4H,CAAOiT,GACL,MAAMtS,EAAasS,EAAStS,WAC5B,IAAKA,EACH,OAEF,MAAM7gC,EAAW6gC,EAAWjE,UAAU58B,SACtC,GAAIA,GAAY5c,KAAK8yD,UAAW,CAC9B,MAAM98C,EAAY,UAAY4G,EAAW,OACzC,GAAI5c,KAAK4yD,UAAW,CAClB,MAAMI,EAAWhzD,KAAKuK,QAAQ2nD,UAAUc,SAASpS,IAC5CoS,GAAyB,IAAbp2C,EAENo2C,GAAyB,IAAbp2C,GACrB5c,KAAKuK,QAAQ2nD,UAAUxmD,OAAOk1C,IAF9B5gD,KAAKuK,QAAQ2nD,UAAUzuC,IAAIm9B,GAI9B,CACD5gD,KAAKgxD,OAAOzgD,MAAMyF,UAAYA,CAC/B,CACDhW,KAAK8yD,UAAYl2C,CAClB,GCnBH,IAAAq2C,GA9HA,cAAmB/C,GAIjB,WAAApwD,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B1F,MAAM,CACJsF,QAASwF,SAASC,cAAc,OAChC7P,OAAQwK,EAAQxK,SAGlB,MAAMmtC,OACkB9mC,IAAtBmE,EAAQ2iC,UAA0B3iC,EAAQ2iC,UAAY,UAElD3/B,OAA0BnH,IAAlBmE,EAAQgD,MAAsBhD,EAAQgD,MAAQ,EAEtDulD,OACwB1sD,IAA5BmE,EAAQuoD,gBACJvoD,EAAQuoD,gBACR5lB,EAAY,MAEZ6lB,OACyB3sD,IAA7BmE,EAAQwoD,iBACJxoD,EAAQwoD,iBACR7lB,EAAY,OAEZ8lB,OACoB5sD,IAAxBmE,EAAQyoD,YAA4BzoD,EAAQyoD,YAAc,IACtDC,OACqB7sD,IAAzBmE,EAAQ0oD,aAA6B1oD,EAAQ0oD,aAAe,IAExDC,OACuB9sD,IAA3BmE,EAAQ2oD,eAA+B3oD,EAAQ2oD,eAAiB,UAC5DC,OACwB/sD,IAA5BmE,EAAQ4oD,gBACJ5oD,EAAQ4oD,gBACR,WAEAC,EAAYzjD,SAASC,cAAc,UACzCwjD,EAAUlmB,UAAY4lB,EACtBM,EAAUrC,aAAa,OAAQ,UAC/BqC,EAAUpC,MAAQkC,EAClBE,EAAUthD,YACe,iBAAhBkhD,EACHrjD,SAAS0jD,eAAeL,GACxBA,GAGNI,EAAUluD,iBACRwC,EACA9H,KAAKqxD,aAAanqD,KAAKlH,KAAM2N,IAC7B,GAGF,MAAM+lD,EAAa3jD,SAASC,cAAc,UAC1C0jD,EAAWpmB,UAAY6lB,EACvBO,EAAWvC,aAAa,OAAQ,UAChCuC,EAAWtC,MAAQmC,EACnBG,EAAWxhD,YACe,iBAAjBmhD,EACHtjD,SAAS0jD,eAAeJ,GACxBA,GAGNK,EAAWpuD,iBACTwC,EACA9H,KAAKqxD,aAAanqD,KAAKlH,MAAO2N,IAC9B,GAGF,MAAM2jD,EACJhkB,EAAY,IAAMwT,GAAqB,IAAME,GACzCz2C,EAAUvK,KAAKuK,QACrBA,EAAQ+iC,UAAYgkB,EACpB/mD,EAAQ2H,YAAYshD,GACpBjpD,EAAQ2H,YAAYwhD,GAMpB1zD,KAAK2yD,eAAiCnsD,IAArBmE,EAAQwzB,SAAyBxzB,EAAQwzB,SAAW,GACtE,CAOD,YAAAkzB,CAAa1jD,EAAO9H,GAClBA,EAAMzF,iBACNJ,KAAK2zD,aAAahmD,EACnB,CAMD,YAAAgmD,CAAahmD,GACX,MACM6vC,EADMx9C,KAAKsgD,SACA3C,UACjB,IAAKH,EAGH,OAEF,MAAMoW,EAAcpW,EAAK3H,UACzB,QAAoBrvC,IAAhBotD,EAA2B,CAC7B,MAAMC,EAAUrW,EAAKxB,mBAAmB4X,EAAcjmD,GAClD3N,KAAK2yD,UAAY,GACfnV,EAAKtH,gBACPsH,EAAK5G,mBAEP4G,EAAKzH,QAAQ,CACXX,KAAMye,EACN11B,SAAUn+B,KAAK2yD,UACfpc,OAAQpqC,MAGVqxC,EAAKnI,QAAQwe,EAEhB,CACF,GCxHI,SAASC,GAASnpD,GACvBA,EAAUA,GAAoB,GAG9B,MAAMopD,EAAW,IAAIvpD,QAEgBhE,IAAjBmE,EAAQyqC,MAAqBzqC,EAAQyqC,OAEvD2e,EAASpuD,KAAK,IAAIquD,GAAKrpD,EAAQspD,oBAGQztD,IAAnBmE,EAAQ4M,QAAuB5M,EAAQ4M,SAE3Dw8C,EAASpuD,KAAK,IAAIuuD,GAAOvpD,EAAQwpD,gBASnC,YAL0B3tD,IAAxBmE,EAAQypD,aAA4BzpD,EAAQypD,cAE5CL,EAASpuD,KAAK,IAAI0uD,GAAY1pD,EAAQ2pD,qBAGjCP,CACT,CCpDe,IAAAQ,GACL,SC0HH,SAASC,GAAIhX,EAAM7vC,EAAOwwB,GAC/B,MAAMyZ,EAAgB4F,EAAKjI,oBAC3B,GAAIqC,EAAe,CACjB,MAAMl7B,EAAS,CAACk7B,EAAc,GAAKjqC,EAAM,GAAIiqC,EAAc,GAAKjqC,EAAM,IACtE6vC,EAAKpH,gBAAgB,CACnBjY,cAAuB33B,IAAb23B,EAAyBA,EAAW,IAC9CoY,OAAQlqC,GACRqQ,OAAQ8gC,EAAKhD,qBAAqB99B,IAErC,CACH,CAQO,SAAS+3C,GAAYjX,EAAM7vC,EAAOyf,EAAQ+Q,GAC/C,MAAMy1B,EAAcpW,EAAK3H,UAEzB,QAAoBrvC,IAAhBotD,EACF,OAGF,MAAMC,EAAUrW,EAAKxB,mBAAmB4X,EAAcjmD,GAChDwtC,EAAgBqC,EAAKhH,qBAAqBqd,GAE5CrW,EAAKtH,gBACPsH,EAAK5G,mBAEP4G,EAAKzH,QAAQ,CACXp5B,WAAYw+B,EACZ/tB,OAAQA,EACR+Q,cAAuB33B,IAAb23B,EAAyBA,EAAW,IAC9CoY,OAAQpqC,IAEZ,CAEA,IAAAuoD,GAjIA,cAA0BjqD,EAIxB,WAAA3K,CAAY6K,GACV1F,QAKAjF,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAEDgD,GAAWA,EAAQvE,cACrBpG,KAAKoG,YAAcuE,EAAQvE,aAO7BpG,KAAKi/C,KAAO,KAEZj/C,KAAK20D,WAAU,EAChB,CAQD,SAAAC,GACE,OAA+B50D,KAAKoJ,IAAImrD,GACzC,CAOD,MAAAjU,GACE,OAAOtgD,KAAKi/C,IACb,CAQD,WAAA74C,CAAYyuD,GACV,OAAO,CACR,CAQD,SAAAF,CAAUG,GACR90D,KAAK+J,IAAIwqD,GAA4BO,EACtC,CAQD,MAAA/X,CAAOjS,GACL9qC,KAAKi/C,KAAOnU,CACb,GC3DH,IAAAiqB,GA9CA,cAA8BC,GAI5B,WAAAl1D,CAAY6K,GACV1F,QAEA0F,EAAUA,GAAoB,GAM9B3K,KAAKi1D,OAAStqD,EAAQgD,MAAQhD,EAAQgD,MAAQ,EAM9C3N,KAAK2yD,eAAiCnsD,IAArBmE,EAAQwzB,SAAyBxzB,EAAQwzB,SAAW,GACtE,CAQD,WAAA/3B,CAAYyuD,GACV,IAAIK,GAAY,EAChB,GAAIL,EAAgB90D,MAAQipD,GAAoBG,SAAU,CACxD,MAAMgM,EACJN,EACR,cACY/pB,EAAM+pB,EAAgB/pB,IACtB1d,EAASynC,EAAgBz9C,WACzBzJ,EAAQwnD,EAAaC,UAAYp1D,KAAKi1D,OAASj1D,KAAKi1D,OAE1DR,GADa3pB,EAAI6S,UACChwC,EAAOyf,EAAQptB,KAAK2yD,WACtCwC,EAAa/0D,iBACb80D,GAAY,CACb,CACD,OAAQA,CACT,GCsII,SAASG,GAAS1F,GACvB,MAAMxuD,EAASwuD,EAAcxuD,OAC7B,IAAI+qD,EAAU,EACVC,EAAU,EACd,IAAK,IAAIvqD,EAAI,EAAGA,EAAIT,EAAQS,IAC1BsqD,GAAWyD,EAAc/tD,GAAGsqD,QAC5BC,GAAWwD,EAAc/tD,GAAGuqD,QAE9B,MAAO,CAACD,QAASA,EAAU/qD,EAAQgrD,QAASA,EAAUhrD,EACxD,CAEA,IAAAm0D,GAjKA,cAAiCN,GAI/B,WAAAl1D,CAAY6K,GAGV1F,MAFA0F,EAAUA,GAAoB,IAM1BA,EAAQ4qD,kBACVv1D,KAAKu1D,gBAAkB5qD,EAAQ4qD,iBAG7B5qD,EAAQ6qD,kBACVx1D,KAAKw1D,gBAAkB7qD,EAAQ6qD,iBAG7B7qD,EAAQ8qD,kBACVz1D,KAAKy1D,gBAAkB9qD,EAAQ8qD,iBAG7B9qD,EAAQ+qD,gBACV11D,KAAK01D,cAAgB/qD,EAAQ+qD,eAG3B/qD,EAAQgrD,WACV31D,KAAK21D,SAAWhrD,EAAQgrD,UAO1B31D,KAAK41D,wBAAyB,EAM9B51D,KAAK61D,eAAiB,EACvB,CAQD,eAAAC,GACE,OAAO91D,KAAK61D,eAAe10D,MAC5B,CAQD,eAAAo0D,CAAgBV,GACd,OAAO,CACR,CAOD,eAAAW,CAAgBX,GAAmB,CAUnC,WAAAzuD,CAAYyuD,GACV,IAAKA,EAAgBpM,cACnB,OAAO,EAGT,IAAIyM,GAAY,EAEhB,GADAl1D,KAAK+1D,uBAAuBlB,GACxB70D,KAAK41D,wBACP,GAAIf,EAAgB90D,MAAQipD,GAAoBI,YAC9CppD,KAAKw1D,gBAAgBX,GAErBA,EAAgBpM,cAAcroD,sBACzB,GAAIy0D,EAAgB90D,MAAQipD,GAAoBO,UAAW,CAChE,MAAMyM,EAAYh2D,KAAK01D,cAAcb,GACrC70D,KAAK41D,uBACHI,GAAah2D,KAAK61D,eAAe10D,OAAS,CAC7C,OAED,GAAI0zD,EAAgB90D,MAAQipD,GAAoBM,YAAa,CAC3D,MAAM2M,EAAUj2D,KAAKu1D,gBAAgBV,GACrC70D,KAAK41D,uBAAyBK,EAC9Bf,EAAYl1D,KAAK21D,SAASM,EAC3B,MAAUpB,EAAgB90D,MAAQipD,GAAoBK,aACrDrpD,KAAKy1D,gBAAgBZ,GAGzB,OAAQK,CACT,CAOD,eAAAO,CAAgBZ,GAAmB,CAQnC,aAAAa,CAAcb,GACZ,OAAO,CACR,CAQD,QAAAc,CAASM,GACP,OAAOA,CACR,CAMD,sBAAAF,CAAuBlB,GACjBA,EAAgBlM,iBAClB3oD,KAAK61D,eAAiBhB,EAAgBlM,eAEzC,GCvKI,SAASuN,GAAIlgB,GAClB,MAAMmgB,EAAanyD,UAKnB,OAAO,SAAU6B,GACf,IAAIuwD,GAAO,EACX,IAAK,IAAIx0D,EAAI,EAAGuE,EAAKgwD,EAAWh1D,OAAQS,EAAIuE,IAC1CiwD,EAAOA,GAAQD,EAAWv0D,GAAGiE,GACxBuwD,KAF2Cx0D,GAMlD,OAAOw0D,CACX,CACA,CAUO,MAAMC,GAAa,SAAUxB,GAClC,MAAMpM,EACJoM,EACJ,cACE,OACEpM,EAAc6N,UACZ7N,EAAc8N,SAAW9N,EAAc+N,WACxC/N,EAAc2M,QAEnB,EAUaqB,GAAmB,SAAU5B,GACxC,MAAMpM,EACJoM,EACJ,cACE,OACEpM,EAAc6N,UACZ7N,EAAc8N,SAAW9N,EAAc+N,UACzC/N,EAAc2M,QAElB,EAUasB,GAAQ,SAAU7wD,GAC7B,MAAM8wD,EAAgB9wD,EAAMilC,IAAI8rB,mBAC1BC,EAAgBhxD,EAAMilC,IAAI+gB,mBAAmBgL,cACnD,OAAOF,EAAc3D,SAAS6D,EAChC,EAQaC,GAAoB,SAAUjxD,GACzC,OAAOA,EAAMilC,IAAI8rB,mBAAmBG,aAAa,aAC7CL,GAAM7wD,EAEZ,EASamxD,GAAS7zD,EAsBT8zD,GAAoB,SAAUpC,GACzC,MAAMpM,EACJoM,EACJ,cACE,OAA+B,GAAxBpM,EAAcgD,UAAiBn9C,IAAUC,IAAOk6C,EAAc+N,QACvE,EASaU,GAAQ9zD,EAqBR+zD,GAAc,SAAUtC,GACnC,OAAOA,EAAgB90D,MAAQipD,GAAoBC,WACrD,EAqBamO,GAAiB,SAAUvC,GACtC,MAAMpM,EACJoM,EACJ,cACE,OACGpM,EAAc6N,UACb7N,EAAc8N,SAAW9N,EAAc+N,WACxC/N,EAAc2M,QAEnB,EA8BaiC,GAAsB,SAAUxC,GAC3C,MAAMpM,EACJoM,EACJ,cACE,OAAOtmD,GAAMk6C,EAAc8N,QAAU9N,EAAc+N,OACrD,EAUac,GAAe,SAAUzC,GACpC,MAAMpM,EACJoM,EACJ,cACE,OACGpM,EAAc6N,UACb7N,EAAc8N,SAAW9N,EAAc+N,UACzC/N,EAAc2M,QAElB,EAWamC,GAAoB,SAAU1C,GACzC,MAAMpM,EACJoM,EACJ,cACQ2C,EAAkC/O,EAAoB,OAAE+O,QAC9D,MACc,UAAZA,GACY,WAAZA,GACY,aAAZA,IAIC/O,EAActoD,OAAOs3D,iBAE1B,EASaC,GAAY,SAAU7C,GACjC,MAAM5J,EAAmE,EAEvExC,cAMF,OALAx0C,QACmBzN,IAAjBykD,EACA,uDAGiC,SAA5BA,EAAa0M,WACtB,EAiDaC,GAAgB,SAAU/C,GACrC,MAAM5J,EAAmE,EAEvExC,cAKF,OAJAx0C,QACmBzN,IAAjBykD,EACA,uDAEKA,EAAa4M,WAAqC,IAAxB5M,EAAaQ,MAChD,ECvKA,IAAAqM,GAzJA,cAAsBC,GAIpB,WAAAj4D,CAAY6K,GACV1F,MAAM,CACJ0wD,SAAUvyD,IAGZuH,EAAUA,GAAoB,GAM9B3K,KAAKg4D,SAAWrtD,EAAQstD,QAKxBj4D,KAAKk4D,aAAe,KAKpBl4D,KAAKm4D,mBAKLn4D,KAAKo4D,UAAW,EAEhB,MAAMC,EAAY1tD,EAAQ0tD,UACtB1tD,EAAQ0tD,UACRnC,GAAIkB,GAAgBQ,IAMxB53D,KAAKs4D,WAAa3tD,EAAQ4tD,YACtBrC,GAAIY,GAAmBuB,GACvBA,EAMJr4D,KAAKw4D,YAAa,CACnB,CAMD,eAAAhD,CAAgBX,GACd,MAAM/pB,EAAM+pB,EAAgB/pB,IACvB9qC,KAAKo4D,WACRp4D,KAAKo4D,UAAW,EAChBttB,EAAI6S,UAAU9B,oBAEhB,MAAMga,EAAiB71D,KAAK61D,eACtBR,EAAWvqB,EAAIge,cAAc2P,GAAqB5C,IACxD,GAAIA,EAAe10D,QAAUnB,KAAKm4D,oBAIhC,GAHIn4D,KAAKg4D,UACPh4D,KAAKg4D,SAASl6B,OAAOu3B,EAAS,GAAIA,EAAS,IAEzCr1D,KAAKk4D,aAAc,CACrB,MAAMvqD,EAAQ,CACZ3N,KAAKk4D,aAAa,GAAK7C,EAAS,GAChCA,EAAS,GAAKr1D,KAAKk4D,aAAa,IAG5B1a,EADMqX,EAAgB/pB,IACX6S,UACjB+a,GAAgB/qD,EAAO6vC,EAAK9hB,iBAC5Bmc,GAAiBlqC,EAAO6vC,EAAK1H,eAC7B0H,EAAKxC,qBAAqBrtC,EAC3B,OACQ3N,KAAKg4D,UAGdh4D,KAAKg4D,SAASj2D,QAEhB/B,KAAKk4D,aAAe7C,EACpBr1D,KAAKm4D,mBAAqBtC,EAAe10D,OACzC0zD,EAAgBpM,cAAcroD,gBAC/B,CAOD,aAAAs1D,CAAcb,GACZ,MAAM/pB,EAAM+pB,EAAgB/pB,IACtB0S,EAAO1S,EAAI6S,UACjB,GAAmC,IAA/B39C,KAAK61D,eAAe10D,OAAc,CACpC,IAAKnB,KAAKw4D,YAAcx4D,KAAKg4D,UAAYh4D,KAAKg4D,SAASh2D,MAAO,CAC5D,MAAMwlB,EAAWxnB,KAAKg4D,SAASjwC,cACzBvQ,EAAQxX,KAAKg4D,SAAS55B,WACtB1hB,EAAS8gC,EAAKjI,oBACdojB,EAAW7tB,EAAI8tB,+BAA+Bl8C,GAC9C9C,EAAOkxB,EAAI+tB,+BAA+B,CAC9CF,EAAS,GAAKnxC,EAAWvb,KAAKwL,IAAID,GAClCmhD,EAAS,GAAKnxC,EAAWvb,KAAKyL,IAAIF,KAEpCgmC,EAAKpH,gBAAgB,CACnB15B,OAAQ8gC,EAAKhD,qBAAqB5gC,GAClCukB,SAAU,IACVoY,OAAQpqC,IAEX,CAKD,OAJInM,KAAKo4D,WACPp4D,KAAKo4D,UAAW,EAChB5a,EAAK1B,mBAEA,CACR,CAOD,OANI97C,KAAKg4D,UAGPh4D,KAAKg4D,SAASj2D,QAEhB/B,KAAKk4D,aAAe,MACb,CACR,CAOD,eAAA3C,CAAgBV,GACd,GAAI70D,KAAK61D,eAAe10D,OAAS,GAAKnB,KAAKs4D,WAAWzD,GAAkB,CACtE,MACMrX,EADMqX,EAAgB/pB,IACX6S,UAYjB,OAXA39C,KAAKk4D,aAAe,KAEhB1a,EAAKtH,gBACPsH,EAAK5G,mBAEH52C,KAAKg4D,UACPh4D,KAAKg4D,SAASj2D,QAIhB/B,KAAKw4D,WAAax4D,KAAK61D,eAAe10D,OAAS,GACxC,CACR,CACD,OAAO,CACR,GC7DH,IAAA23D,GA7FA,cAAyBf,GAIvB,WAAAj4D,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B1F,MAAM,CACJ0wD,SAAUvyD,IAOZpD,KAAKs4D,WAAa3tD,EAAQ0tD,UAAY1tD,EAAQ0tD,UAAY5B,GAM1Dz2D,KAAK+4D,gBAAavyD,EAMlBxG,KAAK2yD,eAAiCnsD,IAArBmE,EAAQwzB,SAAyBxzB,EAAQwzB,SAAW,GACtE,CAMD,eAAAq3B,CAAgBX,GACd,IAAK6C,GAAU7C,GACb,OAGF,MAAM/pB,EAAM+pB,EAAgB/pB,IACtB0S,EAAO1S,EAAI6S,UACjB,GAAIH,EAAKtF,iBAAiBt7B,WAAa0M,GACrC,OAEF,MAAM5V,EAAOo3B,EAAIn3B,UACXoH,EAAS85C,EAAgBvX,MACzBjM,EAAQplC,KAAKoc,MAAM3U,EAAK,GAAK,EAAIqH,EAAO,GAAIA,EAAO,GAAKrH,EAAK,GAAK,GACxE,QAAwBlN,IAApBxG,KAAK+4D,WAA0B,CACjC,MAAMprD,EAAQ0jC,EAAQrxC,KAAK+4D,WAC3Bvb,EAAKlC,wBAAwB3tC,EAC9B,CACD3N,KAAK+4D,WAAa1nB,CACnB,CAOD,aAAAqkB,CAAcb,GACZ,IAAK6C,GAAU7C,GACb,OAAO,EAMT,OAHYA,EAAgB/pB,IACX6S,UACZ7B,eAAe97C,KAAK2yD,YAClB,CACR,CAOD,eAAA4C,CAAgBV,GACd,IAAK6C,GAAU7C,GACb,OAAO,EAGT,GACEoC,GAAkBpC,IAClB70D,KAAKs4D,WAAWzD,GAChB,CAIA,OAHYA,EAAgB/pB,IACxB6S,UAAU9B,mBACd77C,KAAK+4D,gBAAavyD,GACX,CACR,CACD,OAAO,CACR,GCWH,IAAAwyD,GA5HA,cAAwBh0D,EAItB,WAAAlF,CAAYwtC,GACVroC,QAMAjF,KAAKi5D,UAAY,KAMjBj5D,KAAKmmD,SAAWp2C,SAASC,cAAc,OACvChQ,KAAKmmD,SAAS51C,MAAM2oB,SAAW,WAC/Bl5B,KAAKmmD,SAAS51C,MAAMo/C,cAAgB,OACpC3vD,KAAKmmD,SAAS7Y,UAAY,UAAYA,EAMtCttC,KAAKi/C,KAAO,KAMZj/C,KAAKk5D,YAAc,KAMnBl5D,KAAKm5D,UAAY,IAClB,CAKD,eAAA14D,GACET,KAAK+8C,OAAO,KACb,CAKD,OAAAqc,GACE,MAAMC,EAAar5D,KAAKk5D,YAClBI,EAAWt5D,KAAKm5D,UAChBI,EAAK,KACLhpD,EAAQvQ,KAAKmmD,SAAS51C,MAC5BA,EAAMg0C,KAAOt4C,KAAKwP,IAAI49C,EAAW,GAAIC,EAAS,IAAMC,EACpDhpD,EAAMipD,IAAMvtD,KAAKwP,IAAI49C,EAAW,GAAIC,EAAS,IAAMC,EACnDhpD,EAAMd,MAAQxD,KAAKmP,IAAIk+C,EAAS,GAAKD,EAAW,IAAME,EACtDhpD,EAAMb,OAASzD,KAAKmP,IAAIk+C,EAAS,GAAKD,EAAW,IAAME,CACxD,CAKD,MAAAxc,CAAOjS,GACL,GAAI9qC,KAAKi/C,KAAM,CACbj/C,KAAKi/C,KAAKwa,sBAAsBjoD,YAAYxR,KAAKmmD,UACjD,MAAM51C,EAAQvQ,KAAKmmD,SAAS51C,MAC5BA,EAAMg0C,KAAO,UACbh0C,EAAMipD,IAAM,UACZjpD,EAAMd,MAAQ,UACdc,EAAMb,OAAS,SAChB,CACD1P,KAAKi/C,KAAOnU,EACR9qC,KAAKi/C,MACPj/C,KAAKi/C,KAAKwa,sBAAsBvnD,YAAYlS,KAAKmmD,SAEpD,CAMD,SAAAuT,CAAUL,EAAYC,GACpBt5D,KAAKk5D,YAAcG,EACnBr5D,KAAKm5D,UAAYG,EACjBt5D,KAAK25D,yBACL35D,KAAKo5D,SACN,CAKD,sBAAAO,GACE,MAAMN,EAAar5D,KAAKk5D,YAClBI,EAAWt5D,KAAKm5D,UAOhB5/C,EANS,CACb8/C,EACA,CAACA,EAAW,GAAIC,EAAS,IACzBA,EACA,CAACA,EAAS,GAAID,EAAW,KAEAvuB,IACzB9qC,KAAKi/C,KAAK4Z,+BACV74D,KAAKi/C,MAGP1lC,EAAY,GAAKA,EAAY,GAAGzV,QAC3B9D,KAAKi5D,UAGRj5D,KAAKi5D,UAAU/oC,eAAe,CAAC3W,IAF/BvZ,KAAKi5D,UAAY,IAAIhjC,GAAQ,CAAC1c,GAIjC,CAKD,WAAArE,GACE,OAAOlV,KAAKi5D,SACb,GC9FH,MAAMW,GAMM,WANNA,GAaK,UAbLA,GAoBI,SApBJA,GA2BO,YAQN,MAAMC,WAAqB9zD,EAMhC,WAAAjG,CAAYC,EAAMqX,EAAYy9C,GAC5B5vD,MAAMlF,GAQNC,KAAKoX,WAAaA,EAOlBpX,KAAK60D,gBAAkBA,CACxB,EAqLH,IAAAiF,GA5JA,cAAsB/B,GAIpB,WAAAj4D,CAAY6K,GACV1F,QAKAjF,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAELgD,EAAUA,GAAoB,GAM9B3K,KAAK+5D,KAAO,IAAIC,GAAUrvD,EAAQ2iC,WAAa,cAM/CttC,KAAKi6D,cAA+BzzD,IAApBmE,EAAQuvD,QAAwBvvD,EAAQuvD,QAAU,GAE9DvvD,EAAQwvD,WACVn6D,KAAKm6D,SAAWxvD,EAAQwvD,UAO1Bn6D,KAAKk5D,YAAc,KAMnBl5D,KAAKs4D,WAAa3tD,EAAQ0tD,UAAY1tD,EAAQ0tD,UAAYpB,GAM1Dj3D,KAAKo6D,iBAAmBzvD,EAAQ0vD,gBAC5B1vD,EAAQ0vD,gBACRr6D,KAAKs6D,sBACV,CAWD,sBAAAA,CAAuBzF,EAAiBwE,EAAYC,GAClD,MAAM7pD,EAAQ6pD,EAAS,GAAKD,EAAW,GACjC3pD,EAAS4pD,EAAS,GAAKD,EAAW,GACxC,OAAO5pD,EAAQA,EAAQC,EAASA,GAAU1P,KAAKi6D,QAChD,CAOD,WAAA/kD,GACE,OAAOlV,KAAK+5D,KAAK7kD,aAClB,CAMD,eAAAsgD,CAAgBX,GACd70D,KAAK+5D,KAAKL,UAAU15D,KAAKk5D,YAAarE,EAAgBvX,OAEtDt9C,KAAK4F,cACH,IAAIi0D,GACFD,GACA/E,EAAgBz9C,WAChBy9C,GAGL,CAOD,aAAAa,CAAcb,GACZ70D,KAAK+5D,KAAKhd,OAAO,MAEjB,MAAMwd,EAAcv6D,KAAKo6D,iBACvBvF,EACA70D,KAAKk5D,YACLrE,EAAgBvX,OAYlB,OAVIid,GACFv6D,KAAKm6D,SAAStF,GAEhB70D,KAAK4F,cACH,IAAIi0D,GACFU,EAAcX,GAA0BA,GACxC/E,EAAgBz9C,WAChBy9C,KAGG,CACR,CAOD,eAAAU,CAAgBV,GACd,QAAI70D,KAAKs4D,WAAWzD,KAClB70D,KAAKk5D,YAAcrE,EAAgBvX,MACnCt9C,KAAK+5D,KAAKhd,OAAO8X,EAAgB/pB,KACjC9qC,KAAK+5D,KAAKL,UAAU15D,KAAKk5D,YAAal5D,KAAKk5D,aAC3Cl5D,KAAK4F,cACH,IAAIi0D,GACFD,GACA/E,EAAgBz9C,WAChBy9C,KAGG,EAGV,CAMD,QAAAsF,CAASt0D,GAAS,GC3LpB,IAAA20D,GApDA,cAAuBC,GAIrB,WAAA36D,CAAY6K,GAKV1F,MAAM,CACJozD,WALF1tD,EAAUA,GAAoB,IAEJ0tD,UAAY1tD,EAAQ0tD,UAAYf,GAIxDhqB,UAAW3iC,EAAQ2iC,WAAa,cAChC4sB,QAASvvD,EAAQuvD,UAOnBl6D,KAAK2yD,eAAiCnsD,IAArBmE,EAAQwzB,SAAyBxzB,EAAQwzB,SAAW,IAMrEn+B,KAAK06D,UAAuBl0D,IAAhBmE,EAAQgwD,KAAoBhwD,EAAQgwD,GACjD,CAMD,QAAAR,CAASt0D,GACP,MACM23C,EADMx9C,KAAKsgD,SAC8C3C,UAC/D,IAAI/oC,EAAW5U,KAAKkV,cAEpB,GAAIlV,KAAK06D,KAAM,CACb,MAAMtgB,EAAgBoD,EAAKzD,yBAAyBnlC,GAC9C+H,EAAa6gC,EAAK1E,+BAA+BsB,GACjDn1B,EAASu4B,EAAK9hB,gBAAkB/e,EACtC/H,EAAWA,EAASG,QACpBH,EAAS+C,MAAMsN,EAASA,EACzB,CAEDu4B,EAAK1D,YAAYllC,EAAU,CACzBupB,SAAUn+B,KAAK2yD,UACfpc,OAAQpqC,IAEX,GCxEYyuD,GACP,YADOA,GAET,UAFSA,GAGN,aAHMA,GAIP,YC+GR,IAAAC,GAzFA,cAA0B7F,GAIxB,WAAAl1D,CAAY6K,GACV1F,QAEA0F,EAAUA,GAAW,GAOrB3K,KAAK86D,kBAAoB,SAAUjG,GACjC,OACEuC,GAAevC,IAAoB0C,GAAkB1C,EAE7D,EAMI70D,KAAKs4D,gBACmB9xD,IAAtBmE,EAAQ0tD,UACJ1tD,EAAQ0tD,UACRr4D,KAAK86D,kBAMX96D,KAAK2yD,eAAiCnsD,IAArBmE,EAAQwzB,SAAyBxzB,EAAQwzB,SAAW,IAMrEn+B,KAAK+6D,iBACoBv0D,IAAvBmE,EAAQqwD,WAA2BrwD,EAAQqwD,WAAa,GAC3D,CASD,WAAA50D,CAAYyuD,GACV,IAAIK,GAAY,EAChB,GAAIL,EAAgB90D,MAAQ+H,EAAmB,CAC7C,MAAMmzD,EACJpG,EACR,cACYttD,EAAM0zD,EAAS1zD,IACrB,GACEvH,KAAKs4D,WAAWzD,KACfttD,GAAOqzD,IACNrzD,GAAOqzD,IACPrzD,GAAOqzD,IACPrzD,GAAOqzD,IACT,CACA,MACMpd,EADMqX,EAAgB/pB,IACX6S,UACXud,EAAgB1d,EAAK9hB,gBAAkB17B,KAAK+6D,YAClD,IAAI98C,EAAS,EACXC,EAAS,EACP3W,GAAOqzD,GACT18C,GAAUg9C,EACD3zD,GAAOqzD,GAChB38C,GAAUi9C,EACD3zD,GAAOqzD,GAChB38C,EAASi9C,EAETh9C,EAASg9C,EAEX,MAAMvtD,EAAQ,CAACsQ,EAAQC,GACvB25B,GAAiBlqC,EAAO6vC,EAAK1H,eAC7B0e,GAAIhX,EAAM7vC,EAAO3N,KAAK2yD,WACtBsI,EAAS76D,iBACT80D,GAAY,CACb,CACF,CACD,OAAQA,CACT,GCvBH,IAAAiG,GAjEA,cAA2BnG,GAIzB,WAAAl1D,CAAY6K,GACV1F,QAEA0F,EAAUA,GAAoB,GAM9B3K,KAAKs4D,WAAa3tD,EAAQ0tD,UACtB1tD,EAAQ0tD,UACR,SAAUxD,GACR,OACGwC,GAAoBxC,IACrB0C,GAAkB1C,EAE9B,EAMI70D,KAAKi1D,OAAStqD,EAAQgD,MAAQhD,EAAQgD,MAAQ,EAM9C3N,KAAK2yD,eAAiCnsD,IAArBmE,EAAQwzB,SAAyBxzB,EAAQwzB,SAAW,GACtE,CASD,WAAA/3B,CAAYyuD,GACV,IAAIK,GAAY,EAChB,GACEL,EAAgB90D,MAAQ+H,GACxB+sD,EAAgB90D,MAAQ+H,EACxB,CACA,MAAMmzD,EACJpG,EACR,cACYttD,EAAM0zD,EAAS1zD,IACrB,GAAIvH,KAAKs4D,WAAWzD,KAA6B,MAARttD,GAAuB,MAARA,GAAc,CACpE,MAAMujC,EAAM+pB,EAAgB/pB,IACtBn9B,EAAgB,MAARpG,EAAcvH,KAAKi1D,QAAUj1D,KAAKi1D,OAEhDR,GADa3pB,EAAI6S,UACChwC,OAAOnH,EAAWxG,KAAK2yD,WACzCsI,EAAS76D,iBACT80D,GAAY,CACb,CACF,CACD,OAAQA,CACT,GC2MH,IAAAkG,GApQA,cAA6BpG,GAI3B,WAAAl1D,CAAY6K,GAGV1F,MAFA0F,EAAUA,GAAoB,IAU9B3K,KAAKq7D,YAAc,EAMnBr7D,KAAKs7D,WAAa,EAMlBt7D,KAAKozB,eAAiC5sB,IAArBmE,EAAQqmB,SAAyBrmB,EAAQqmB,SAAW,EAMrEhxB,KAAK2yD,eAAiCnsD,IAArBmE,EAAQwzB,SAAyBxzB,EAAQwzB,SAAW,IAMrEn+B,KAAKu7D,cAA+B/0D,IAApBmE,EAAQ6wD,QAAwB7wD,EAAQ6wD,QAAU,GAMlEx7D,KAAKy7D,gBACmBj1D,IAAtBmE,EAAQ+wD,WAA0B/wD,EAAQ+wD,UAM5C17D,KAAK27D,0BAC6Bn1D,IAAhCmE,EAAQynC,qBACJznC,EAAQynC,oBAGd,MAAMimB,EAAY1tD,EAAQ0tD,UAAY1tD,EAAQ0tD,UAAYrB,GAM1Dh3D,KAAKs4D,WAAa3tD,EAAQ4tD,YACtBrC,GAAIY,GAAmBuB,GACvBA,EAMJr4D,KAAK47D,YAAc,KAMnB57D,KAAK67D,gBAAar1D,EAMlBxG,KAAK87D,WAML97D,KAAK+7D,WAAQv1D,EAQbxG,KAAKg8D,kBAAoB,IAMzBh8D,KAAKi8D,mBAOLj8D,KAAKk8D,cAAgB,GACtB,CAKD,eAAAC,GACEn8D,KAAKi8D,wBAAqBz1D,EAC1B,MAAMskC,EAAM9qC,KAAKsgD,SACjB,IAAKxV,EACH,OAEWA,EAAI6S,UACZ7B,oBACHt1C,EACAxG,KAAKs7D,WAAct7D,KAAKs7D,WAAa,EAAI,GAAK,EAAK,EACnDt7D,KAAK47D,YAER,CAQD,WAAAx1D,CAAYyuD,GACV,IAAK70D,KAAKs4D,WAAWzD,GACnB,OAAO,EAGT,GADaA,EAAgB90D,OAChB+H,EACX,OAAO,EAGT,MAAMgjC,EAAM+pB,EAAgB/pB,IACtBsxB,EACJvH,EACN,cASI,IAAIlnD,EAWJ,GAnBAyuD,EAAWh8D,iBAEPJ,KAAKy7D,aACPz7D,KAAK47D,YAAc/G,EAAgBz9C,YAMjCy9C,EAAgB90D,MAAQ+H,IAC1B6F,EAAQyuD,EAAWl+C,OACfhQ,IAAWkuD,EAAWC,YAAcC,WAAWC,kBACjD5uD,GAASa,IAEP4tD,EAAWC,YAAcC,WAAWE,iBACtC7uD,GAAS,KAIC,IAAVA,EACF,OAAO,EAET3N,KAAKs7D,WAAa3tD,EAElB,MAAMqwB,EAAMD,KAAKC,WAEOx3B,IAApBxG,KAAK67D,aACP77D,KAAK67D,WAAa79B,KAGfh+B,KAAK+7D,OAAS/9B,EAAMh+B,KAAK67D,WAAa77D,KAAKg8D,qBAC9Ch8D,KAAK+7D,MAAQ9vD,KAAKmP,IAAIzN,GAAS,EAAI,WAAa,SAGlD,MAAM6vC,EAAO1S,EAAI6S,UACjB,GACiB,aAAf39C,KAAK+7D,QACHve,EAAKrF,2BAA4Bn4C,KAAK27D,qBAgBxC,OAdI37D,KAAKi8D,mBACP7Q,aAAaprD,KAAKi8D,qBAEdze,EAAKtH,gBACPsH,EAAK5G,mBAEP4G,EAAK3B,oBAEP77C,KAAKi8D,mBAAqBxqB,WACxBzxC,KAAKm8D,gBAAgBj1D,KAAKlH,MAC1BA,KAAKu7D,UAEP/d,EAAKpC,YAAYztC,EAAQ3N,KAAKk8D,cAAel8D,KAAK47D,aAClD57D,KAAK67D,WAAa79B,GACX,EAGTh+B,KAAKq7D,aAAe1tD,EAEpB,MAAM8uD,EAAWxwD,KAAKyP,IAAI1b,KAAKu7D,UAAYv9B,EAAMh+B,KAAK67D,YAAa,GAQnE,OANAzQ,aAAaprD,KAAK87D,YAClB97D,KAAK87D,WAAarqB,WAChBzxC,KAAK08D,iBAAiBx1D,KAAKlH,KAAM8qC,GACjC2xB,IAGK,CACR,CAMD,gBAAAC,CAAiB5xB,GACf,MAAM0S,EAAO1S,EAAI6S,UACbH,EAAKtH,gBACPsH,EAAK5G,mBAEP,IAAIjpC,GACDmW,GACC9jB,KAAKq7D,aACJr7D,KAAKozB,UAAYpzB,KAAKk8D,cACvBl8D,KAAKozB,UAAYpzB,KAAKk8D,eACpBl8D,KAAKk8D,eACP1e,EAAKrF,0BAA4Bn4C,KAAK27D,wBAExChuD,EAAQA,EAASA,EAAQ,EAAI,GAAK,EAAK,GAEzC8mD,GAAYjX,EAAM7vC,EAAO3N,KAAK47D,YAAa57D,KAAK2yD,WAEhD3yD,KAAK+7D,WAAQv1D,EACbxG,KAAKq7D,YAAc,EACnBr7D,KAAK47D,YAAc,KACnB57D,KAAK67D,gBAAar1D,EAClBxG,KAAK87D,gBAAat1D,CACnB,CAQD,cAAAm2D,CAAejB,GACb17D,KAAKy7D,WAAaC,EACbA,IACH17D,KAAK47D,YAAc,KAEtB,GCxIH,IAAAgB,GAxIA,cAA0B7E,GAIxB,WAAAj4D,CAAY6K,GAGV,MAAMkyD,EAFNlyD,EAAUA,GAAoB,GAMzBkyD,EAAelH,WAClBkH,EAAelH,SAAWvyD,GAG5B6B,MAAM43D,GAMN78D,KAAK88D,QAAU,KAMf98D,KAAK+4D,gBAAavyD,EAMlBxG,KAAK+8D,WAAY,EAMjB/8D,KAAKg9D,eAAiB,EAMtBh9D,KAAKi9D,gBAAmCz2D,IAAtBmE,EAAQuyD,UAA0BvyD,EAAQuyD,UAAY,GAMxEl9D,KAAK2yD,eAAiCnsD,IAArBmE,EAAQwzB,SAAyBxzB,EAAQwzB,SAAW,GACtE,CAMD,eAAAq3B,CAAgBX,GACd,IAAIsI,EAAgB,EAEpB,MAAMC,EAASp9D,KAAK61D,eAAe,GAC7BwH,EAASr9D,KAAK61D,eAAe,GAG7Br+C,EAAQvL,KAAKoc,MACjBg1C,EAAOlR,QAAUiR,EAAOjR,QACxBkR,EAAOnR,QAAUkR,EAAOlR,SAG1B,QAAwB1lD,IAApBxG,KAAK+4D,WAA0B,CACjC,MAAMprD,EAAQ6J,EAAQxX,KAAK+4D,WAC3B/4D,KAAKg9D,gBAAkBrvD,GAClB3N,KAAK+8D,WAAa9wD,KAAKmP,IAAIpb,KAAKg9D,gBAAkBh9D,KAAKi9D,aAC1Dj9D,KAAK+8D,WAAY,GAEnBI,EAAgBxvD,CACjB,CACD3N,KAAK+4D,WAAavhD,EAElB,MAAMszB,EAAM+pB,EAAgB/pB,IACtB0S,EAAO1S,EAAI6S,UACbH,EAAKtF,iBAAiBt7B,WAAa0M,KAOvCtpB,KAAK88D,QAAUhyB,EAAI+tB,+BACjB/tB,EAAIge,cAAc2P,GAAqBz4D,KAAK61D,kBAI1C71D,KAAK+8D,YACPjyB,EAAIgS,SACJU,EAAKlC,uBAAuB6hB,EAAen9D,KAAK88D,UAEnD,CAOD,aAAApH,CAAcb,GACZ,GAAI70D,KAAK61D,eAAe10D,OAAS,EAAG,CAIlC,OAHY0zD,EAAgB/pB,IACX6S,UACZ7B,eAAe97C,KAAK2yD,YAClB,CACR,CACD,OAAO,CACR,CAOD,eAAA4C,CAAgBV,GACd,GAAI70D,KAAK61D,eAAe10D,QAAU,EAAG,CACnC,MAAM2pC,EAAM+pB,EAAgB/pB,IAQ5B,OAPA9qC,KAAK88D,QAAU,KACf98D,KAAK+4D,gBAAavyD,EAClBxG,KAAK+8D,WAAY,EACjB/8D,KAAKg9D,eAAiB,EACjBh9D,KAAK41D,wBACR9qB,EAAI6S,UAAU9B,oBAET,CACR,CACD,OAAO,CACR,GCrBH,IAAAyhB,GAnHA,cAAwBvF,GAItB,WAAAj4D,CAAY6K,GAGV,MAAMkyD,EAFNlyD,EAAUA,GAAoB,GAMzBkyD,EAAelH,WAClBkH,EAAelH,SAAWvyD,GAG5B6B,MAAM43D,GAMN78D,KAAK88D,QAAU,KAMf98D,KAAK2yD,eAAiCnsD,IAArBmE,EAAQwzB,SAAyBxzB,EAAQwzB,SAAW,IAMrEn+B,KAAKu9D,mBAAgB/2D,EAMrBxG,KAAKw9D,gBAAkB,CACxB,CAMD,eAAAhI,CAAgBX,GACd,IAAI4I,EAAa,EAEjB,MAAML,EAASp9D,KAAK61D,eAAe,GAC7BwH,EAASr9D,KAAK61D,eAAe,GAC7B/9C,EAAKslD,EAAOlR,QAAUmR,EAAOnR,QAC7Bn0C,EAAKqlD,EAAOjR,QAAUkR,EAAOlR,QAG7B3kC,EAAWvb,KAAKma,KAAKtO,EAAKA,EAAKC,EAAKA,QAEfvR,IAAvBxG,KAAKu9D,gBACPE,EAAaz9D,KAAKu9D,cAAgB/1C,GAEpCxnB,KAAKu9D,cAAgB/1C,EAErB,MAAMsjB,EAAM+pB,EAAgB/pB,IACtB0S,EAAO1S,EAAI6S,UAEC,GAAd8f,IACFz9D,KAAKw9D,gBAAkBC,GAIzBz9D,KAAK88D,QAAUhyB,EAAI+tB,+BACjB/tB,EAAIge,cAAc2P,GAAqBz4D,KAAK61D,kBAI9C/qB,EAAIgS,SACJU,EAAKtC,yBAAyBuiB,EAAYz9D,KAAK88D,QAChD,CAOD,aAAApH,CAAcb,GACZ,GAAI70D,KAAK61D,eAAe10D,OAAS,EAAG,CAClC,MACMq8C,EADMqX,EAAgB/pB,IACX6S,UACXj8C,EAAY1B,KAAKw9D,gBAAkB,EAAI,GAAK,EAElD,OADAhgB,EAAK1B,eAAe97C,KAAK2yD,UAAWjxD,IAC7B,CACR,CACD,OAAO,CACR,CAOD,eAAA6zD,CAAgBV,GACd,GAAI70D,KAAK61D,eAAe10D,QAAU,EAAG,CACnC,MAAM2pC,EAAM+pB,EAAgB/pB,IAO5B,OANA9qC,KAAK88D,QAAU,KACf98D,KAAKu9D,mBAAgB/2D,EACrBxG,KAAKw9D,gBAAkB,EAClBx9D,KAAK41D,wBACR9qB,EAAI6S,UAAU9B,oBAET,CACR,CACD,OAAO,CACR,GCrEI,SAASiY,GAASnpD,GACvBA,EAAUA,GAAoB,GAG9B,MAAM+yD,EAAe,IAAIlzD,EAEnBytD,EAAU,IAAI0F,IAAS,KAAO,IAAM,WAGTn3D,IAA/BmE,EAAQizD,oBACJjzD,EAAQizD,qBAGZF,EAAa/3D,KAAK,IAAIk4D,UAIMr3D,IAA5BmE,EAAQmzD,iBAAgCnzD,EAAQmzD,kBAEhDJ,EAAa/3D,KACX,IAAIo4D,GAAgB,CAClBpwD,MAAOhD,EAAQqzD,UACf7/B,SAAUxzB,EAAQszD,sBAKYz3D,IAApBmE,EAAQuzD,SAAwBvzD,EAAQuzD,UAEtDR,EAAa/3D,KACX,IAAIw4D,GAAQ,CACV5F,YAAa5tD,EAAQ4tD,YACrBN,QAASA,WAMWzxD,IAAxBmE,EAAQyzD,aAA4BzzD,EAAQyzD,cAE5CV,EAAa/3D,KAAK,IAAI04D,UAGgB73D,IAAtBmE,EAAQ2zD,WAA0B3zD,EAAQ2zD,YAE1DZ,EAAa/3D,KACX,IAAI44D,GAAU,CACZpgC,SAAUxzB,EAAQszD,sBAKcz3D,IAArBmE,EAAQ6zD,UAAyB7zD,EAAQ6zD,YAExDd,EAAa/3D,KAAK,IAAI84D,IACtBf,EAAa/3D,KACX,IAAI+4D,GAAa,CACf/wD,MAAOhD,EAAQqzD,UACf7/B,SAAUxzB,EAAQszD,uBAMKz3D,IAA3BmE,EAAQg0D,gBAA+Bh0D,EAAQg0D,iBAE/CjB,EAAa/3D,KACX,IAAIi5D,GAAe,CACjBrG,YAAa5tD,EAAQ4tD,YACrBp6B,SAAUxzB,EAAQszD,gBAexB,YAT4Bz3D,IAA1BmE,EAAQk0D,eAA8Bl0D,EAAQk0D,gBAE9CnB,EAAa/3D,KACX,IAAIm5D,GAAS,CACX3gC,SAAUxzB,EAAQszD,gBAKjBP,CACT,CCpHO,SAASqB,GAAQrrD,GACtB,OAAOA,EAAK,GAAK,GAAKA,EAAK,GAAK,CAClC,CASO,SAASiE,GAAMjE,EAAMu8B,EAAOr2B,GAMjC,YALapT,IAAToT,IACFA,EAAO,CAAC,EAAG,IAEbA,EAAK,GAAMlG,EAAK,GAAKu8B,EAAQ,GAAO,EACpCr2B,EAAK,GAAMlG,EAAK,GAAKu8B,EAAQ,GAAO,EAC7Br2B,CACT,CAWO,SAASolD,GAAOtrD,EAAMkG,GAC3B,OAAIvX,MAAMC,QAAQoR,GACTA,QAEIlN,IAAToT,EACFA,EAAO,CAAClG,EAAMA,IAEdkG,EAAK,GAAKlG,EACVkG,EAAK,GAAKlG,GAELkG,EACT,CCuFA,SAASqlD,GAAuBrxB,GAC1BA,aAAiBsxB,GACnBtxB,EAAM4Q,eAAe,MAGnB5Q,aAAiBsZ,IACnBtZ,EAAM4Z,YAAYr8C,QAAQ8zD,GAE9B,CAMA,SAASE,GAAoBvxB,EAAO9C,GAClC,GAAI8C,aAAiBsxB,GACnBtxB,EAAM4Q,eAAe1T,QAGvB,GAAI8C,aAAiBsZ,GAAY,CAC/B,MAAMH,EAASnZ,EAAM4Z,YAAYn8C,WACjC,IAAK,IAAIzJ,EAAI,EAAGuE,EAAK4gD,EAAO5lD,OAAQS,EAAIuE,IAAMvE,EAC5Cu9D,GAAoBpY,EAAOnlD,GAAIkpC,EAElC,CACH,CAioDA,IAAAs0B,GA3kDA,cAAkB30D,EAIhB,WAAA3K,CAAY6K,GACV1F,QAEA0F,EAAUA,GAAW,GAKrB3K,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAEL,MAAM03D,EA49CV,SAA+B10D,GAI7B,IAAI20D,EAAsB,UACU94D,IAAhCmE,EAAQ20D,sBACVA,EACyC,iBAAhC30D,EAAQ20D,oBACXvvD,SAASigD,eAAerlD,EAAQ20D,qBAChC30D,EAAQ20D,qBAMhB,MAAMr2D,EAAS,CAAA,EAETs2D,EACJ50D,EAAQo8C,QACiD,mBAA/Bp8C,EAAc,OAAW,UACpBA,EAAc,OACzC,IAAIu8C,GAAW,CACbH,OAEIp8C,EACD,SAUX,IAAIopD,EAcA2J,EAeA8B,EArCJv2D,EAAOojD,IAA0BkT,EAEjCt2D,EAAOojD,IAAsB1hD,EAAQxK,OAErC8I,EAAOojD,IACL1hD,EAAQ6yC,gBAAgBI,GAAOjzC,EAAQ6yC,KAAO,IAAII,QAI3Bp3C,IAArBmE,EAAQopD,WACN1xD,MAAMC,QAAQqI,EAAQopD,UACxBA,EAAW,IAAIvpD,EAAWG,EAAQopD,SAASjwD,UAE3CmQ,GAC4D,mBAAhCtJ,EAAgB,SAAU,SACpD,+DAEFopD,EAAWppD,EAAQopD,gBAMMvtD,IAAzBmE,EAAQ+yD,eACNr7D,MAAMC,QAAQqI,EAAQ+yD,cACxBA,EAAe,IAAIlzD,EAAWG,EAAQ+yD,aAAa55D,UAEnDmQ,GAEI,mBADwBtJ,EAAoB,aAAU,SAExD,mEAEF+yD,EAAe/yD,EAAQ+yD,oBAMFl3D,IAArBmE,EAAQ60D,SACNn9D,MAAMC,QAAQqI,EAAQ60D,UACxBA,EAAW,IAAIh1D,EAAWG,EAAQ60D,SAAS17D,UAE3CmQ,GAC4D,mBAAhCtJ,EAAgB,SAAU,SACpD,+DAEF60D,EAAW70D,EAAQ60D,UAGrBA,EAAW,IAAIh1D,EAGjB,MAAO,CACLupD,SAAUA,EACV2J,aAAcA,EACd4B,oBAAqBA,EACrBE,SAAUA,EACVv2D,OAAQA,EAEZ,CAljD4Bw2D,CAAsB90D,GAM9C3K,KAAK0/D,gBAML1/D,KAAK2/D,SAAU,EAGf3/D,KAAK4/D,yBAA2B5/D,KAAK6/D,mBAAmB34D,KAAKlH,MAM7DA,KAAK8/D,sBACyBt5D,IAA5BmE,EAAQo1D,gBAAgCp1D,EAAQo1D,gBAAkB,GAMpE//D,KAAKs7B,iBACoB90B,IAAvBmE,EAAQywB,WACJzwB,EAAQywB,WACR5sB,GAMNxO,KAAKggE,yBAMLhgE,KAAKigE,mBAKLjgE,KAAKkgE,gBAAkBlgE,KAAKkgE,gBAAgBh5D,KAAKlH,MAMjDA,KAAKmgE,4BjGvRA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GiG6RrBngE,KAAKogE,4BjG7RA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GiGmSrBpgE,KAAKqgE,YAAc,EAMnBrgE,KAAKsgE,YAAc,KAOnBtgE,KAAKugE,gBAAkB,KAMvBvgE,KAAKwgE,yBAA2B,KAMhCxgE,KAAKygE,uBAAyB,KAM9BzgE,KAAK0gE,gCAAkC,KAMvC1gE,KAAK2gE,UAAY5wD,SAASC,cAAc,OACxChQ,KAAK2gE,UAAUrzB,UACb,eAAiB,iBAAkBh+B,OAAS,YAAc,IAC5DtP,KAAK2gE,UAAUpwD,MAAM2oB,SAAW,WAChCl5B,KAAK2gE,UAAUpwD,MAAMqwD,SAAW,SAChC5gE,KAAK2gE,UAAUpwD,MAAMd,MAAQ,OAC7BzP,KAAK2gE,UAAUpwD,MAAMb,OAAS,OAM9B1P,KAAK6gE,kBAAoB9wD,SAASC,cAAc,OAChDhQ,KAAK6gE,kBAAkBtwD,MAAM2oB,SAAW,WACxCl5B,KAAK6gE,kBAAkBtwD,MAAMy8B,OAAS,IACtChtC,KAAK6gE,kBAAkBtwD,MAAMd,MAAQ,OACrCzP,KAAK6gE,kBAAkBtwD,MAAMb,OAAS,OACtC1P,KAAK6gE,kBAAkBtwD,MAAMo/C,cAAgB,OAC7C3vD,KAAK6gE,kBAAkBvzB,UAAY,sBACnCttC,KAAK2gE,UAAUzuD,YAAYlS,KAAK6gE,mBAMhC7gE,KAAK8gE,2BAA6B/wD,SAASC,cAAc,OACzDhQ,KAAK8gE,2BAA2BvwD,MAAM2oB,SAAW,WACjDl5B,KAAK8gE,2BAA2BvwD,MAAMy8B,OAAS,IAC/ChtC,KAAK8gE,2BAA2BvwD,MAAMd,MAAQ,OAC9CzP,KAAK8gE,2BAA2BvwD,MAAMb,OAAS,OAC/C1P,KAAK8gE,2BAA2BvwD,MAAMo/C,cAAgB,OACtD3vD,KAAK8gE,2BAA2BxzB,UAAY,gCAC5CttC,KAAK2gE,UAAUzuD,YAAYlS,KAAK8gE,4BAMhC9gE,KAAK+gE,wBAA0B,KAM/B/gE,KAAKqqD,eAAiB1/C,EAAQq/C,cAM9BhqD,KAAKghE,qBAAuB3B,EAAgBC,oBAM5Ct/D,KAAKihE,yBAA2B,KAMhCjhE,KAAKkhE,eAAiB,KAKtBlhE,KAAKmhE,gBAAkB,IAAIC,gBAAe,IAAMphE,KAAKqhE,eAMrDrhE,KAAK+zD,SAAWsL,EAAgBtL,UAAYuN,KAM5CthE,KAAK09D,aACH2B,EAAgB3B,cAChB6D,GAAoB,CAClBhJ,aAAa,IAOjBv4D,KAAKwhE,UAAYnC,EAAgBG,SAOjCx/D,KAAKyhE,gBAAkB,GAMvBzhE,KAAK28C,UAAY,KAMjB38C,KAAK0hE,qBAAuB,GAM5B1hE,KAAK2hE,WAAa,IAAIC,GACpB5hE,KAAKqvD,gBAAgBnoD,KAAKlH,MAC1BA,KAAK6hE,kBAAkB36D,KAAKlH,OAG9BA,KAAK6J,kBACHwiD,GACArsD,KAAK8hE,0BAEP9hE,KAAK6J,kBAAkBwiD,GAAkBrsD,KAAK+hE,oBAC9C/hE,KAAK6J,kBAAkBwiD,GAAkBrsD,KAAKgiE,oBAC9ChiE,KAAK6J,kBAAkBwiD,GAAoBrsD,KAAKiiE,sBAIhDjiE,KAAKmJ,cAAck2D,EAAgBp2D,QAEnC,MAAM6hC,EAAM9qC,MACR2K,EAAQ6yC,MAAU7yC,EAAQ6yC,gBAAgBI,IAC5CjzC,EAAQ6yC,KAAKzpC,MAAK,SAAUmuD,GAC1Bp3B,EAAIq3B,QAAQ,IAAIvkB,GAAKskB,GAC7B,IAGIliE,KAAK+zD,SAASzuD,iBACZ8E,GAICvE,IACCA,EAAM0E,QAAQwyC,OAAO/8C,KAAK,IAI9BA,KAAK+zD,SAASzuD,iBACZ8E,GAICvE,IACCA,EAAM0E,QAAQwyC,OAAO,KAAK,IAI9B/8C,KAAK09D,aAAap4D,iBAChB8E,GAICvE,IACCA,EAAM0E,QAAQwyC,OAAO/8C,KAAK,IAI9BA,KAAK09D,aAAap4D,iBAChB8E,GAICvE,IACCA,EAAM0E,QAAQwyC,OAAO,KAAK,IAI9B/8C,KAAKwhE,UAAUl8D,iBACb8E,GAICvE,IACC7F,KAAKoiE,oBAAoBv8D,EAAM0E,QAAQ,IAI3CvK,KAAKwhE,UAAUl8D,iBACb8E,GAICvE,IACC,MAAM2H,EAAK3H,EAAM0E,QAAQ8K,aACd7O,IAAPgH,UACKxN,KAAKyhE,gBAAgBj0D,EAAGoL,YAEjC/S,EAAM0E,QAAQwyC,OAAO,KAAK,IAI9B/8C,KAAK+zD,SAAS5oD,SAIXk3D,IACCA,EAAQtlB,OAAO/8C,KAAK,IAIxBA,KAAK09D,aAAavyD,SAIfm3D,IACCA,EAAYvlB,OAAO/8C,KAAK,IAI5BA,KAAKwhE,UAAUr2D,QAAQnL,KAAKoiE,oBAAoBl7D,KAAKlH,MACtD,CAOD,UAAAuiE,CAAWF,GACTriE,KAAKwiE,cAAc78D,KAAK08D,EACzB,CAWD,cAAAI,CAAeH,GACbtiE,KAAK0iE,kBAAkB/8D,KAAK28D,EAC7B,CASD,QAAAK,CAAS/0B,GACQ5tC,KAAK89C,gBAAgB0J,YAC7B7hD,KAAKioC,EACb,CAMD,eAAAg1B,CAAgB/8D,GACds5D,GAAoBt5D,EAAM+nC,MAAO5tC,KAClC,CAOD,UAAA6iE,CAAWC,GACT9iE,KAAK+iE,cAAcp9D,KAAKm9D,EACzB,CAOD,mBAAAV,CAAoBU,GAClB,MAAMt1D,EAAKs1D,EAAQztD,aACR7O,IAAPgH,IACFxN,KAAKyhE,gBAAgBj0D,EAAGoL,YAAckqD,GAExCA,EAAQ/lB,OAAO/8C,KAChB,CAMD,eAAAS,GACET,KAAK+zD,SAASpvD,QACd3E,KAAK09D,aAAa/4D,QAClB3E,KAAKwhE,UAAU78D,QACf3E,KAAKmhE,gBAAgB6B,aACrBhjE,KAAK6vD,UAAU,MACf5qD,MAAMxE,iBACP,CAoBD,qBAAAwiE,CAAsB3lB,EAAO1hC,EAAUjR,GACrC,IAAK3K,KAAKsgE,cAAgBtgE,KAAK28C,UAC7B,OAEF,MAAMvlC,EAAapX,KAAK64D,+BAA+Bvb,GAEjDiC,OACqB/4C,KAF3BmE,OAAsBnE,IAAZmE,EAAwBA,EAAU,CAAA,GAElC40C,aAA6B50C,EAAQ40C,aAAe,EACxDE,OACoBj5C,IAAxBmE,EAAQ80C,YAA4B90C,EAAQ80C,YAAct8C,EACtDq8C,GAAwC,IAAzB70C,EAAQ60C,aAC7B,OAAOx/C,KAAK28C,UAAU2C,2BACpBloC,EACApX,KAAKsgE,YACL/gB,EACAC,EACA5jC,EACA,KACA6jC,EACA,KAEH,CAUD,kBAAAyjB,CAAmB5lB,EAAO3yC,GACxB,MAAMw4D,EAAW,GAQjB,OAPAnjE,KAAKijE,sBACH3lB,GACA,SAAUqC,GACRwjB,EAASx9D,KAAKg6C,EACf,GACDh1C,GAEKw4D,CACR,CAOD,YAAAvR,GACE,MAAM7K,EAAS,GAWf,OAVA,SAASqc,EAAc7D,GACrBA,EAAWp0D,SAAQ,SAAUyiC,GACvBA,aAAiBsZ,GACnBkc,EAAcx1B,EAAM4Z,aAEpBT,EAAOphD,KAAKioC,EAEtB,GACK,CACDw1B,CAAcpjE,KAAKwnD,aACZT,CACR,CAUD,iBAAAsc,CAAkB/lB,EAAO3yC,GACvB,IAAK3K,KAAKsgE,cAAgBtgE,KAAK28C,UAC7B,OAAO,EAET,MAAMvlC,EAAapX,KAAK64D,+BAA+Bvb,GAEjDmC,OACoBj5C,KAF1BmE,OAAsBnE,IAAZmE,EAAwBA,EAAU,CAAA,GAElC80C,YAA4B90C,EAAQ80C,YAAct8C,EACtDo8C,OACqB/4C,IAAzBmE,EAAQ40C,aAA6B50C,EAAQ40C,aAAe,EACxDC,GAAwC,IAAzB70C,EAAQ60C,aAC7B,OAAOx/C,KAAK28C,UAAU0D,uBACpBjpC,EACApX,KAAKsgE,YACL/gB,EACAC,EACAC,EACA,KAEH,CAQD,kBAAA6jB,CAAmBz9D,GACjB,OAAO7F,KAAK+oD,uBAAuB/oD,KAAK8oD,cAAcjjD,GACvD,CAOD,0BAAA09D,CAA2B19D,GACzB,OAAO7F,KAAK64D,+BAA+B74D,KAAK8oD,cAAcjjD,GAC/D,CAQD,aAAAijD,CAAcjjD,GACZ,MACM29D,EADWxjE,KAAK2gE,UACY8C,wBAC5BrzB,EAAepwC,KAAK2T,UACpB+vD,EAASF,EAAiB/zD,MAAQ2gC,EAAa,GAC/CuzB,EAASH,EAAiB9zD,OAAS0gC,EAAa,GAChDwzB,EAEJ,mBAAoB/9D,EACU,EAAQg+D,eAAe,GACtB,EAEjC,MAAO,EACJD,EAAc1X,QAAUsX,EAAiBjf,MAAQmf,GACjDE,EAAczX,QAAUqX,EAAiBhK,KAAOmK,EAEpD,CAWD,SAAAG,GACE,OACE9jE,KAAKoJ,IAAIijD,GAEZ,CASD,gBAAAuK,GACE,OAAO52D,KAAKkhE,cACb,CASD,sBAAAnY,CAAuBzL,GACrB,OAAOpxB,GACLlsB,KAAK64D,+BAA+Bvb,GACpCt9C,KAAK29C,UAAU/uB,gBAElB,CAQD,8BAAAiqC,CAA+Bvb,GAC7B,MAAMG,EAAaz9C,KAAKsgE,YACxB,OAAK7iB,EAGE9+B,GAAe8+B,EAAW4B,2BAA4B/B,EAAMx5C,SAF1D,IAGV,CAQD,WAAA0+D,GACE,OAAOxiE,KAAK+zD,QACb,CAQD,WAAAgP,GACE,OAAO/iE,KAAKwhE,SACb,CAUD,cAAAuC,CAAev2D,GACb,MAAMs1D,EAAU9iE,KAAKyhE,gBAAgBj0D,EAAGoL,YACxC,YAAmBpS,IAAZs8D,EAAwBA,EAAU,IAC1C,CAUD,eAAAJ,GACE,OAAO1iE,KAAK09D,YACb,CAQD,aAAA5f,GACE,OAAkC99C,KAAKoJ,IAAIijD,GAC5C,CAOD,SAAA/E,CAAUP,GACR,MAAMid,EAAQhkE,KAAK89C,gBACnB,GAAIiJ,aAAkBv8C,EAEpB,YADAw5D,EAAM1c,UAAUP,GAIlB,MAAMiB,EAAagc,EAAMxc,YACzBQ,EAAWrjD,QACXqjD,EAAW9lD,OAAO6kD,EACnB,CAOD,SAAAS,GAEE,OADexnD,KAAK89C,gBAAgB0J,WAErC,CAKD,oBAAAyc,GACE,MAAMpmB,EAAmB79C,KAAK89C,gBAAgBzP,sBAC9C,IAAK,IAAIzsC,EAAI,EAAGuE,EAAK03C,EAAiB18C,OAAQS,EAAIuE,IAAMvE,EAAG,CACzD,MAAM4K,EAAQqxC,EAAiBj8C,GAC/B,IAAK4K,EAAMugC,QACT,SAEF,MAAMm3B,EAAW13D,EAAMohC,MAAMwQ,cAC7B,GAAI8lB,IAAaA,EAASC,MACxB,OAAO,EAET,MAAMj6D,EAASsC,EAAMohC,MAAMsP,YAC3B,GAAIhzC,GAAUA,EAAOk6D,QACnB,OAAO,CAEV,CACD,OAAO,CACR,CASD,sBAAAC,CAAuBjtD,GACrB,MAAMktD,EAAiBn4C,GACrB/U,EACApX,KAAK29C,UAAU/uB,iBAEjB,OAAO5uB,KAAK44D,+BAA+B0L,EAC5C,CAQD,8BAAA1L,CAA+BxhD,GAC7B,MAAMqmC,EAAaz9C,KAAKsgE,YACxB,OAAK7iB,EAGE9+B,GACL8+B,EAAW2B,2BACXhoC,EAAWtT,MAAM,EAAG,IAJb,IAMV,CAMD,WAAAs6C,GACE,OAAOp+C,KAAK28C,SACb,CAQD,OAAAhpC,GACE,OACE3T,KAAKoJ,IAAIijD,GAEZ,CASD,OAAA1O,GACE,OAA4B39C,KAAKoJ,IAAIijD,GACtC,CAOD,WAAAhG,GACE,OAAOrmD,KAAK2gE,SACb,CASD,mBAAAlH,GACE,OAAOz5D,KAAK6gE,iBACb,CASD,4BAAA/Q,GACE,OAAO9vD,KAAK8gE,0BACb,CAKD,gBAAAjV,GACE,MAAM8K,EAAgB32D,KAAK42D,mBAC3B,OAAOD,EAAgBA,EAAc4N,cAAgBx0D,QACtD,CASD,eAAAs/C,CAAgBniD,EAAMoiD,EAAeC,EAAYC,GAC/C,OAAOH,GACLrvD,KAAKsgE,YACLpzD,EACAoiD,EACAC,EACAC,EAEH,CAMD,kBAAAqQ,CAAmB1K,EAAcp1D,GAC/BA,EAAOA,GAAQo1D,EAAap1D,KAC5B,MAAM80D,EAAkB,IAAI1J,GAAgBprD,EAAMC,KAAMm1D,GACxDn1D,KAAKwkE,sBAAsB3P,EAC5B,CAKD,qBAAA2P,CAAsB3P,GACpB,IAAK70D,KAAKsgE,YAGR,OAEF,MAAM7X,EACJoM,EACN,cACUjrD,EAAY6+C,EAAc1oD,KAChC,GACE6J,IAAcigD,IACdjgD,IAAc9B,GACd8B,IAAc9B,EACd,CACA,MAAM8jD,EAAM5rD,KAAK6rD,mBACX4Y,EAAWzkE,KAAK2gE,UAAU5U,YAC5B/rD,KAAK2gE,UAAU5U,cACfH,EACEzrD,EAA8BsoD,EAAoB,OACxD,GAGEzoD,KAAK8gE,2BAA2B9N,SAAS7yD,MAKvCskE,IAAa7Y,EAAMA,EAAI8Y,gBAAkBD,GAAUzR,SAAS7yD,GAE9D,MAEH,CAED,GADA00D,EAAgBpX,WAAaz9C,KAAKsgE,aACU,IAAxCtgE,KAAK4F,cAAcivD,GAA4B,CACjD,MAAM8P,EAAoB3kE,KAAK0iE,kBAAkBr3D,WAAWvH,QAC5D,IAAK,IAAIlC,EAAI+iE,EAAkBxjE,OAAS,EAAGS,GAAK,EAAGA,IAAK,CACtD,MAAM0gE,EAAcqC,EAAkB/iE,GACtC,GACE0gE,EAAYhiB,WAAatgD,OACxBsiE,EAAY1N,cACZ50D,KAAK42D,mBAEN,SAGF,IADa0L,EAAYl8D,YAAYyuD,IACxBA,EAAgB50D,mBAC3B,KAEH,CACF,CACF,CAKD,gBAAA2kE,GACE,MAAMnnB,EAAaz9C,KAAKsgE,YAWlBuE,EAAY7kE,KAAK2hE,WACvB,IAAKkD,EAAU//D,UAAW,CACxB,IAAIoqD,EAAkBlvD,KAAK8/D,iBACvB3Q,EAAcD,EAClB,GAAIzR,EAAY,CACd,MAAMpF,EAAQoF,EAAWqnB,UACzB,GAAIzsB,EAAMpJ,KAAuBoJ,EAAMpJ,IAAuB,CAC5D,MAAM81B,EAAmBhnC,KAAKC,MAAQyf,EAAWhwC,KAAO,EACxDyhD,EAAkB6V,EAAmB,EAAI,EACzC5V,EAAc4V,EAAmB,EAAI,CACtC,CACF,CACGF,EAAU9V,kBAAoBG,IAChC2V,EAAUzW,eACVyW,EAAU5V,cAAcC,EAAiBC,GAE5C,CAEG1R,GAAcz9C,KAAK28C,YAAcc,EAAW1H,WACjB,IAAzB/1C,KAAK0/D,iBACH1/D,KAAKyG,YAAYg4C,KACnBz+C,KAAK28C,UAAUuC,oBACbT,GACAhB,IAGiB,IAAjBz9C,KAAK2/D,UACP3/D,KAAK2/D,SAAU,EACf3/D,KAAK4F,cACH,IAAI4iD,GAAS4D,GAAsBpsD,KAAMy9C,OAGnB,IAAjBz9C,KAAK2/D,UACd3/D,KAAK2/D,SAAU,EACf3/D,KAAK4F,cACH,IAAI4iD,GAAS4D,GAAwBpsD,KAAMy9C,MAKjD,MAAMgD,EAAsBzgD,KAAK0hE,qBACjC,IAAK,IAAI9/D,EAAI,EAAGuE,EAAKs6C,EAAoBt/C,OAAQS,EAAIuE,IAAMvE,EACzD6+C,EAAoB7+C,GAAG5B,KAAMy9C,GAE/BgD,EAAoBt/C,OAAS,CAC9B,CAKD,kBAAA6gE,GACMhiE,KAAK29C,YAAc39C,KAAK29C,UAAUzH,gBACpCl2C,KAAK29C,UAAUxH,mBAAmB,GAGpCn2C,KAAK88C,QACN,CAKD,oBAAAmlB,GACE,GAAIjiE,KAAK+gE,wBAAyB,CAChC,IAAK,IAAIn/D,EAAI,EAAGuE,EAAKnG,KAAKihE,yBAAyB9/D,OAAQS,EAAIuE,IAAMvE,EACnE0F,EAActH,KAAKihE,yBAAyBr/D,IAE9C5B,KAAKihE,yBAA2B,KAChCjhE,KAAK2gE,UAAUr6D,oBACbwB,EACA9H,KAAK4/D,0BAEP5/D,KAAK2gE,UAAUr6D,oBACbwB,EACA9H,KAAK4/D,0BAEP5/D,KAAK+gE,wBAAwBvgE,UAC7BR,KAAK+gE,wBAA0B,KAC/BzvD,GAAWtR,KAAK2gE,UACjB,CAED,GAAI3gE,KAAKkhE,eAAgB,CACvBlhE,KAAKmhE,gBAAgB6D,UAAUhlE,KAAKkhE,gBACpC,MAAMuD,EAAWzkE,KAAKkhE,eAAenV,cACjC0Y,aAAoBQ,YACtBjlE,KAAKmhE,gBAAgB6D,UAAUP,EAASS,MAE1CllE,KAAKssC,aAAQ9lC,EACd,CAOD,MAAMrG,EAASH,KAAK8jE,YACdnN,EACc,iBAAXx2D,EAAsB4P,SAASigD,eAAe7vD,GAAUA,EAEjE,GADAH,KAAKkhE,eAAiBvK,EACjBA,EAYE,CACLA,EAAczkD,YAAYlS,KAAK2gE,WAC1B3gE,KAAK28C,YACR38C,KAAK28C,UAAY,IAAIwoB,GAAqBnlE,OAG5CA,KAAK+gE,wBAA0B,IAAIqE,GACjCplE,KACAA,KAAKqqD,gBAEP,IAAK,MAAM9iD,KAAOyhD,GAChBhpD,KAAK+gE,wBAAwBz7D,iBAC3B0jD,GAAoBzhD,GACpBvH,KAAKwkE,sBAAsBt9D,KAAKlH,OAGpCA,KAAK2gE,UAAUr7D,iBACbwC,EACA9H,KAAK4/D,0BACL,GAEF5/D,KAAK2gE,UAAUr7D,iBACbwC,EACA9H,KAAK4/D,2BACLzwD,IAA0B,CAACC,SAAS,IAGtC,MAAMkwD,EAAuBt/D,KAAKghE,qBAE9BhhE,KAAKghE,qBADLrK,EAEJ32D,KAAKihE,yBAA2B,CAC9Bl6D,EACEu4D,EACAx3D,EACA9H,KAAK6/D,mBACL7/D,MAEF+G,EACEu4D,EACAx3D,EACA9H,KAAK6/D,mBACL7/D,OAGJ,MAAMykE,EAAW9N,EAAc5K,cAC3B0Y,aAAoBQ,YACtBjlE,KAAKmhE,gBAAgBkE,QAAQZ,EAASS,MAExCllE,KAAKmhE,gBAAgBkE,QAAQ1O,EAC9B,MA5DK32D,KAAK28C,YACPyO,aAAaprD,KAAKggE,0BAClBhgE,KAAKggE,8BAA2Bx5D,EAChCxG,KAAK0hE,qBAAqBvgE,OAAS,EACnCnB,KAAK28C,UAAUn8C,UACfR,KAAK28C,UAAY,MAEf38C,KAAKigE,qBACPppB,qBAAqB72C,KAAKigE,oBAC1BjgE,KAAKigE,wBAAqBz5D,GAqD9BxG,KAAKqhE,YAGN,CAKD,iBAAAQ,GACE7hE,KAAK88C,QACN,CAKD,0BAAAwoB,GACEtlE,KAAK88C,QACN,CAKD,kBAAAilB,GACM/hE,KAAKwgE,2BACPl5D,EAActH,KAAKwgE,0BACnBxgE,KAAKwgE,yBAA2B,MAE9BxgE,KAAKygE,yBACPn5D,EAActH,KAAKygE,wBACnBzgE,KAAKygE,uBAAyB,MAEhC,MAAMjjB,EAAOx9C,KAAK29C,UACdH,IACFx9C,KAAKulE,oBAAoBvlE,KAAK2T,WAE9B3T,KAAKwgE,yBAA2Bz5D,EAC9By2C,EACAn9C,EACAL,KAAKslE,2BACLtlE,MAEFA,KAAKygE,uBAAyB15D,EAC5By2C,EACA11C,EACA9H,KAAKslE,2BACLtlE,MAGFw9C,EAAKrH,mBAAmB,IAE1Bn2C,KAAK88C,QACN,CAKD,wBAAAglB,GACM9hE,KAAK0gE,kCACP1gE,KAAK0gE,gCAAgCv1D,QAAQ7D,GAC7CtH,KAAK0gE,gCAAkC,MAEzC,MAAMnB,EAAav/D,KAAK89C,gBACpByhB,IACFv/D,KAAK4iE,gBAAgB,IAAI3b,GAAW,WAAYsY,IAChDv/D,KAAK0gE,gCAAkC,CACrC35D,EAAOw4D,EAAYl/D,EAAgCL,KAAK88C,OAAQ98C,MAChE+G,EAAOw4D,EAAYz3D,EAAkB9H,KAAK88C,OAAQ98C,MAClD+G,EAAOw4D,EAAY,WAAYv/D,KAAK4iE,gBAAiB5iE,MACrD+G,EAAOw4D,EAAY,cAAev/D,KAAKwlE,mBAAoBxlE,QAG/DA,KAAK88C,QACN,CAKD,UAAA2oB,GACE,QAASzlE,KAAKsgE,WACf,CAKD,eAAAJ,GACElgE,KAAKigE,wBAAqBz5D,EAC1BxG,KAAK0lE,aAAa3nC,KAAKC,MACxB,CAMD,UAAA2nC,GACM3lE,KAAKigE,oBACPppB,qBAAqB72C,KAAKigE,oBAE5BjgE,KAAKkgE,iBACN,CAKD,UAAAha,GACE,MAAMpG,EAAc9/C,KAAK89C,gBAAgBzP,sBACzC,IAAK,IAAIzsC,EAAI,EAAGuE,EAAK25C,EAAY3+C,OAAQS,EAAIuE,IAAMvE,EAAG,CACpD,MAAMgsC,EAAQkS,EAAYl+C,GAAGgsC,MACzBA,EAAMiR,eACRjR,EAAMwQ,cAAcwnB,oBAEvB,CACF,CAMD,MAAA9oB,GACM98C,KAAK28C,gBAAyCn2C,IAA5BxG,KAAKigE,qBACzBjgE,KAAKigE,mBAAqBtoB,sBAAsB33C,KAAKkgE,iBAExD,CASD,mBAAA3f,GACE,MAAM9C,EAAaz9C,KAAKsgE,YACnB7iB,GAGLz9C,KAAK28C,UAAU4D,oBAAoB9C,EACpC,CASD,aAAAooB,CAAcxD,GACZ,OAAOriE,KAAKwiE,cAAc92D,OAAO22D,EAClC,CASD,iBAAAyD,CAAkBxD,GAChB,OAAOtiE,KAAK0iE,kBAAkBh3D,OAAO42D,EACtC,CASD,WAAAyD,CAAYn4B,GAEV,OADe5tC,KAAK89C,gBAAgB0J,YACtB97C,OAAOkiC,EACtB,CAMD,kBAAA43B,CAAmB3/D,GACjBo5D,GAAuBp5D,EAAM+nC,MAC9B,CASD,aAAAo4B,CAAclD,GACZ,OAAO9iE,KAAK+iE,cAAcr3D,OAAOo3D,EAClC,CAMD,YAAA4C,CAAaj4D,GACX,MAAMiG,EAAO1T,KAAK2T,UACZ6pC,EAAOx9C,KAAK29C,UACZsoB,EAAqBjmE,KAAKsgE,YAEhC,IAAI7iB,EAAa,KACjB,QAAaj3C,IAATkN,GAAsBqrD,GAAQrrD,IAAS8pC,GAAQA,EAAKvH,QAAS,CAC/D,MAAM6uB,EAAYtnB,EAAKpF,SACrBp4C,KAAKsgE,YAActgE,KAAKsgE,YAAYwE,eAAYt+D,GAE5CgzC,EAAYgE,EAAKrwC,WA2BvB,GA1BAswC,EAAa,CACX1H,SAAS,EACTqJ,2BAA4Bp/C,KAAKmgE,4BACjC+F,cAAe,KACf1sD,OAAQiD,GACN+8B,EAAU98B,OACV88B,EAAU78B,WACV68B,EAAU58B,SACVlJ,GAEFzQ,MAAOjD,KAAKqgE,cACZxZ,WAAY,EACZhJ,iBAAkB79C,KAAK89C,gBAAgBzP,sBACvCjT,WAAYp7B,KAAKs7B,YACjB+jB,2BAA4Br/C,KAAKogE,4BACjC3f,oBAAqB,GACrB/sC,KAAMA,EACNmxD,UAAW7kE,KAAK2hE,WAChBl0D,KAAMA,EACN04D,UAAW,CAAE,EACb3sB,UAAWA,EACXsrB,UAAWA,EACXrV,YAAa,CAAE,EACf2W,MAAO19D,EAAO1I,MACdqmE,cAAe,CAAE,GAEf7sB,EAAUJ,YAAcI,EAAUH,eAAgB,CACpD,MAAMz8B,EAAW4R,MAAMgrB,EAAUF,cAC7BE,EAAU58B,SACV48B,EAAUF,aAEdmE,EAAW6oB,WAAa7pD,GACtB+8B,EAAUJ,WACVI,EAAUH,eACVz8B,EACAlJ,EAEH,CACF,CAKD,GAHA1T,KAAKsgE,YAAc7iB,EACnBz9C,KAAK28C,UAAU2B,YAAYb,GAEvBA,EAAY,CASd,GARIA,EAAW1H,SACb/1C,KAAK88C,SAEPz6C,MAAMwB,UAAU8B,KAAKzB,MACnBlE,KAAK0hE,qBACLjkB,EAAWgD,qBAGTwlB,EAAoB,GAEnBjmE,KAAKugE,kBACJz7D,GAAQ9E,KAAKugE,mBACZgG,GAAa9oB,EAAWjkC,OAAQxZ,KAAKugE,oBAExCvgE,KAAK4F,cACH,IAAI4iD,GAAS4D,GAAwBpsD,KAAMimE,IAE7CjmE,KAAKugE,gBAAkB5lD,GAAoB3a,KAAKugE,iBAEnD,CAGCvgE,KAAKugE,kBACJ9iB,EAAWqnB,UAAU71B,MACrBwO,EAAWqnB,UAAU71B,MACrBs3B,GAAa9oB,EAAWjkC,OAAQxZ,KAAKugE,mBAGtCvgE,KAAK4F,cACH,IAAI4iD,GAAS4D,GAAsBpsD,KAAMy9C,IAE3C1oC,GAAM0oC,EAAWjkC,OAAQxZ,KAAKugE,iBAEjC,CAEDvgE,KAAK4F,cAAc,IAAI4iD,GAAS4D,GAAyBpsD,KAAMy9C,IAE/Dz9C,KAAK0/D,gBACH1/D,KAAKyG,YAAY2lD,KACjBpsD,KAAKyG,YAAY2lD,KACjBpsD,KAAKyG,YAAYg4C,KACZz+C,KAAK2hE,WAAW5S,oBAChB/uD,KAAK2hE,WAAWpU,aAChBvtD,KAAKikE,4BACNz9D,EAEDxG,KAAKggE,2BACRhgE,KAAKggE,yBAA2BvuB,YAAW,KACzCzxC,KAAKggE,8BAA2Bx5D,EAChCxG,KAAK4kE,kBAAkB,GACtB,GAEN,CAQD,aAAA4B,CAAcjH,GACZ,MAAMkH,EAAgBzmE,KAAK89C,gBACvB2oB,GACFzmE,KAAKwlE,mBAAmB,IAAIve,GAAW,cAAewf,IAExDzmE,KAAK+J,IAAIsiD,GAAwBkT,EAClC,CAQD,OAAAjzB,CAAQ54B,GACN1T,KAAK+J,IAAIsiD,GAAkB34C,EAC5B,CASD,SAAAm8C,CAAU1vD,GACRH,KAAK+J,IAAIsiD,GAAoBlsD,EAC9B,CAWD,OAAAgiE,CAAQ3kB,GACN,IAAKA,GAAQA,aAAgBI,GAE3B,YADA59C,KAAK+J,IAAIsiD,GAAkB7O,GAG7Bx9C,KAAK+J,IAAIsiD,GAAkB,IAAIzO,IAE/B,MAAM9S,EAAM9qC,KACZw9C,EAAKzpC,MAAK,SAAUmuD,GAClBp3B,EAAIq3B,QAAQ,IAAIvkB,GAAKskB,GAC3B,GACG,CAOD,UAAAb,GACE,MAAM1K,EAAgB32D,KAAK42D,mBAE3B,IAAIljD,EACJ,GAAIijD,EAAe,CACjB,MAAM+P,EAAgBl2D,iBAAiBmmD,GACjClnD,EACJknD,EAAcrmD,YACdy6B,WAAW27B,EAA+B,iBAC1C37B,WAAW27B,EAA2B,aACtC37B,WAAW27B,EAA4B,cACvC37B,WAAW27B,EAAgC,kBACvCh3D,EACJinD,EAAc9lD,aACdk6B,WAAW27B,EAA8B,gBACzC37B,WAAW27B,EAA0B,YACrC37B,WAAW27B,EAA6B,eACxC37B,WAAW27B,EAAiC,mBACzCl4C,MAAM/e,IAAW+e,MAAM9e,KAC1BgE,EAAO,CAACjE,EAAOC,IAEZqvD,GAAQrrD,KAEPijD,EAAcrmD,aACdqmD,EAAc9lD,cACd8lD,EAAcgQ,iBAAiBxlE,SAGjC4nB,GACE,qEAIP,CAED,MAAM69C,EAAU5mE,KAAK2T,WACjBD,GAAUkzD,GAAYrkE,EAAOmR,EAAMkzD,KACrC5mE,KAAKssC,QAAQ54B,GACb1T,KAAKulE,oBAAoB7xD,GAE5B,CAOD,mBAAA6xD,CAAoB7xD,GAClB,MAAM8pC,EAAOx9C,KAAK29C,UACdH,GACFA,EAAKvF,gBAAgBvkC,EAExB,GCppDH,MAAMrJ,GACK,UADLA,GAEC,MAFDA,GAGI,SAHJA,GAIM,WAJNA,GAKS,cA0ff,IAAAw8D,GAtdA,cAAsBp8D,EAIpB,WAAA3K,CAAY6K,GACV1F,QAKAjF,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAML3H,KAAK2K,QAAUA,EAMf3K,KAAKwN,GAAK7C,EAAQ6C,GAMlBxN,KAAK8mE,iBACqBtgE,IAAxBmE,EAAQm8D,aAA4Bn8D,EAAQm8D,YAM9C9mE,KAAKk1D,eAAkC1uD,IAAtBmE,EAAQuqD,WAA0BvqD,EAAQuqD,UAM3Dl1D,KAAKuK,QAAUwF,SAASC,cAAc,OACtChQ,KAAKuK,QAAQ+iC,eACW9mC,IAAtBmE,EAAQ2iC,UACJ3iC,EAAQ2iC,UACR,wBAA0BuT,GAChC7gD,KAAKuK,QAAQgG,MAAM2oB,SAAW,WAC9Bl5B,KAAKuK,QAAQgG,MAAMo/C,cAAgB,OAMnC3vD,KAAK+mE,SAA8B,IAApBp8D,EAAQo8D,QAAmB,GAAKp8D,EAAQo8D,cAAWvgE,EAOlExG,KAAK68C,SAAW,CACd3kB,WAAY,GACZ6U,SAAS,GAOX/sC,KAAKgnE,yBAA2B,KAEhChnE,KAAK6J,kBAAkBQ,GAAkBrK,KAAKinE,sBAC9CjnE,KAAK6J,kBAAkBQ,GAAcrK,KAAKknE,kBAC1ClnE,KAAK6J,kBAAkBQ,GAAiBrK,KAAKmnE,qBAC7CnnE,KAAK6J,kBAAkBQ,GAAmBrK,KAAKonE,uBAC/CpnE,KAAK6J,kBAAkBQ,GAAsBrK,KAAKqnE,+BAE1B7gE,IAApBmE,EAAQJ,SACVvK,KAAKsnE,WAAW38D,EAAQJ,SAG1BvK,KAAKunE,eAA6B/gE,IAAnBmE,EAAQoQ,OAAuBpQ,EAAQoQ,OAAS,CAAC,EAAG,IAEnE/a,KAAKwnE,eAAe78D,EAAQ88D,aAAe,iBAElBjhE,IAArBmE,EAAQuuB,UACVl5B,KAAK0nE,YAAY/8D,EAAQuuB,SAE5B,CAQD,UAAAyuC,GACE,OAA6C3nE,KAAKoJ,IAAIiB,GACvD,CAOD,KAAAgL,GACE,OAAOrV,KAAKwN,EACb,CASD,MAAA8yC,GACE,OACEtgD,KAAKoJ,IAAIiB,KAAiB,IAE7B,CAQD,SAAAu9D,GACE,OAAqC5nE,KAAKoJ,IAAIiB,GAC/C,CASD,WAAA6vB,GACE,OACEl6B,KAAKoJ,IAAIiB,GAEZ,CASD,cAAAw9D,GACE,OAAmC7nE,KAAKoJ,IAAIiB,GAC7C,CAKD,oBAAA48D,GACEx1D,GAAezR,KAAKuK,SACpB,MAAMA,EAAUvK,KAAK2nE,aACjBp9D,GACFvK,KAAKuK,QAAQ2H,YAAY3H,EAE5B,CAKD,gBAAA28D,GACMlnE,KAAKgnE,2BACP11D,GAAWtR,KAAKuK,SAChBjD,EAActH,KAAKgnE,0BACnBhnE,KAAKgnE,yBAA2B,MAElC,MAAMl8B,EAAM9qC,KAAKsgD,SACjB,GAAIxV,EAAK,CACP9qC,KAAKgnE,yBAA2BjgE,EAC9B+jC,EACAshB,GACApsD,KAAK88C,OACL98C,MAEFA,KAAK8nE,sBACL,MAAM1hB,EAAYpmD,KAAKk1D,UACnBpqB,EAAIglB,+BACJhlB,EAAI2uB,sBACJz5D,KAAK8mE,YACP1gB,EAAUn0C,aAAajS,KAAKuK,QAAS67C,EAAUt0C,WAAW,IAAM,MAEhEs0C,EAAUl0C,YAAYlS,KAAKuK,SAE7BvK,KAAK+nE,gBACN,CACF,CAKD,MAAAjrB,GACE98C,KAAK8nE,qBACN,CAKD,mBAAAX,GACEnnE,KAAK8nE,qBACN,CAKD,qBAAAV,GACEpnE,KAAK8nE,sBACL9nE,KAAK+nE,gBACN,CAKD,wBAAAV,GACErnE,KAAK8nE,qBACN,CAQD,UAAAR,CAAW/8D,GACTvK,KAAK+J,IAAIM,GAAkBE,EAC5B,CASD,MAAAwyC,CAAOjS,GACL9qC,KAAK+J,IAAIM,GAAcygC,EACxB,CAQD,SAAAy8B,CAAUxsD,GACR/a,KAAK+J,IAAIM,GAAiB0Q,EAC3B,CAUD,WAAA2sD,CAAYxuC,GACVl5B,KAAK+J,IAAIM,GAAmB6uB,EAC7B,CAOD,cAAA6uC,GACM/nE,KAAK+mE,SACP/mE,KAAKgoE,YAAYhoE,KAAK+mE,QAEzB,CAQD,WAAAiB,CAAYC,GACV,MAAMn9B,EAAM9qC,KAAKsgD,SAEjB,IAAKxV,IAAQA,EAAI8rB,qBAAuB52D,KAAKoJ,IAAIiB,IAC/C,OAGF,MAAM69D,EAAUloE,KAAKmoE,QAAQr9B,EAAI8rB,mBAAoB9rB,EAAIn3B,WACnDpJ,EAAUvK,KAAK2nE,aACfS,EAAcpoE,KAAKmoE,QAAQ59D,EAAS,CACxC8F,GAAW9F,GACXqG,GAAYrG,KAKR89D,OAC0B7hE,KAHhCyhE,EAAqBA,GAAsB,IAGtBK,OAAuB,GAAKL,EAAmBK,OACpE,IAAKtuD,GAAekuD,EAASE,GAAc,CAEzC,MAAMG,EAAaH,EAAY,GAAKF,EAAQ,GACtCM,EAAcN,EAAQ,GAAKE,EAAY,GACvCK,EAAYL,EAAY,GAAKF,EAAQ,GACrCQ,EAAeR,EAAQ,GAAKE,EAAY,GAExCz6D,EAAQ,CAAC,EAAG,GAgBlB,GAfI46D,EAAa,EAEf56D,EAAM,GAAK46D,EAAaF,EACfG,EAAc,IAEvB76D,EAAM,GAAK1B,KAAKmP,IAAIotD,GAAeH,GAEjCI,EAAY,EAEd96D,EAAM,GAAK86D,EAAYJ,EACdK,EAAe,IAExB/6D,EAAM,GAAK1B,KAAKmP,IAAIstD,GAAgBL,GAGrB,IAAb16D,EAAM,IAAyB,IAAbA,EAAM,GAAU,CACpC,MAAM+O,EACJouB,EAAI6S,UAAUpI,oBAEVozB,EAAW79B,EAAI8tB,+BAA+Bl8C,GACpD,IAAKisD,EACH,OAEF,MAAMC,EAAc,CAACD,EAAS,GAAKh7D,EAAM,GAAIg7D,EAAS,GAAKh7D,EAAM,IAE3Dk7D,EAAaZ,EAAmBn1B,WAAa,GACnDhI,EAAI6S,UAAUvH,gBAAgB,CAC5B15B,OAAQouB,EAAI+tB,+BAA+B+P,GAC3CzqC,SAAU0qC,EAAW1qC,SACrBoY,OAAQsyB,EAAWtyB,QAEtB,CACF,CACF,CASD,OAAA4xB,CAAQ59D,EAASmJ,GACf,MAAMo1D,EAAMv+D,EAAQk5D,wBACdhuB,EAAUqzB,EAAIvkB,KAAOj1C,OAAOy5D,YAC5BrzB,EAAUozB,EAAItP,IAAMlqD,OAAO05D,YACjC,MAAO,CAACvzB,EAASC,EAASD,EAAU/hC,EAAK,GAAIgiC,EAAUhiC,EAAK,GAC7D,CASD,cAAA8zD,CAAeC,GACbznE,KAAK+J,IAAIM,GAAsBo9D,EAChC,CAOD,UAAA34B,CAAW/B,GACL/sC,KAAK68C,SAAS9P,UAAYA,IAC5B/sC,KAAKuK,QAAQgG,MAAM+zC,QAAUvX,EAAU,GAAK,OAC5C/sC,KAAK68C,SAAS9P,QAAUA,EAE3B,CAMD,mBAAA+6B,GACE,MAAMh9B,EAAM9qC,KAAKsgD,SACXpnB,EAAWl5B,KAAKk6B,cACtB,IAAK4Q,IAAQA,EAAI26B,eAAiBvsC,EAEhC,YADAl5B,KAAK8uC,YAAW,GAIlB,MAAMwO,EAAQxS,EAAIu5B,uBAAuBnrC,GACnC+vC,EAAUn+B,EAAIn3B,UACpB3T,KAAKkpE,uBAAuB5rB,EAAO2rB,EACpC,CAOD,sBAAAC,CAAuB5rB,EAAO2rB,GAC5B,MAAM14D,EAAQvQ,KAAKuK,QAAQgG,MACrBwK,EAAS/a,KAAK4nE,YAEdH,EAAcznE,KAAK6nE,iBAEzB7nE,KAAK8uC,YAAW,GAIhB,IAAIq6B,EAAO,KACPC,EAAO,KAEM,gBAAf3B,GACe,gBAAfA,GACe,aAAfA,EAEA0B,EAAO,QAEQ,iBAAf1B,GACe,iBAAfA,GACe,cAAfA,IAEA0B,EAAO,QAGQ,eAAf1B,GACe,iBAAfA,GACe,gBAAfA,EAEA2B,EAAO,QAEQ,eAAf3B,GACe,iBAAfA,GACe,gBAAfA,IAEA2B,EAAO,QAET,MAAMpzD,EAAY,aAAamzD,MAASC,gBA9B9Bn9D,KAAKiZ,MAAMo4B,EAAM,GAAKviC,EAAO,IAAM,SACnC9O,KAAKiZ,MAAMo4B,EAAM,GAAKviC,EAAO,IAAM,QA8BzC/a,KAAK68C,SAAS3kB,YAAcliB,IAC9BhW,KAAK68C,SAAS3kB,WAAaliB,EAC3BzF,EAAMyF,UAAYA,EAErB,CAMD,UAAAqzD,GACE,OAAOrpE,KAAK2K,OACb,GC9RH,IAAA2+D,GA7QA,MAIE,WAAAxpE,CAAYypE,GAMVvpE,KAAKupE,mBAAkC/iE,IAAlB+iE,EAA8BA,EAAgB,KAMnEvpE,KAAKwpE,OAAS,EAMdxpE,KAAKypE,SAAW,GAMhBzpE,KAAK0pE,QAAU,KAMf1pE,KAAK2pE,QAAU,IAChB,CAKD,cAAAx9B,GACE,OAAOnsC,KAAKupE,cAAgB,GAAKvpE,KAAKutD,WAAavtD,KAAKupE,aACzD,CAMD,WAAAK,CAAYC,GACV,KAAO7pE,KAAKmsC,kBACVnsC,KAAKkL,KAER,CAKD,KAAAvG,GACE3E,KAAKwpE,OAAS,EACdxpE,KAAKypE,SAAW,GAChBzpE,KAAK0pE,QAAU,KACf1pE,KAAK2pE,QAAU,IAChB,CAMD,WAAAG,CAAYviE,GACV,OAAOvH,KAAKypE,SAASpgE,eAAe9B,EACrC,CAQD,OAAA4D,CAAQC,GACN,IAAI2+D,EAAQ/pE,KAAK0pE,QACjB,KAAOK,GACL3+D,EAAE2+D,EAAMC,OAAQD,EAAME,KAAMjqE,MAC5B+pE,EAAQA,EAAMG,KAEjB,CAOD,GAAA9gE,CAAI7B,EAAKoD,GACP,MAAMo/D,EAAQ/pE,KAAKypE,SAASliE,GAK5B,OAJA0M,QACYzN,IAAVujE,EACA,mEAEEA,IAAU/pE,KAAK2pE,UAGfI,IAAU/pE,KAAK0pE,SACjB1pE,KAAK0pE,QAAgC1pE,KAAK0pE,QAAa,MACvD1pE,KAAK0pE,QAAQS,MAAQ,OAErBJ,EAAMG,MAAMC,MAAQJ,EAAMI,MAC1BJ,EAAMI,MAAMD,MAAQH,EAAMG,OAE5BH,EAAMG,MAAQ,KACdH,EAAMI,MAAQnqE,KAAK2pE,QACnB3pE,KAAK2pE,QAAQO,MAAQH,EACrB/pE,KAAK2pE,QAAUI,GAZNA,EAAMC,MAchB,CAOD,MAAAt+D,CAAOnE,GACL,MAAMwiE,EAAQ/pE,KAAKypE,SAASliE,GAqB5B,OApBA0M,QACYzN,IAAVujE,EACA,mEAEEA,IAAU/pE,KAAK2pE,SACjB3pE,KAAK2pE,QAAgCI,EAAW,MAC5C/pE,KAAK2pE,UACP3pE,KAAK2pE,QAAQO,MAAQ,OAEdH,IAAU/pE,KAAK0pE,SACxB1pE,KAAK0pE,QAAgCK,EAAW,MAC5C/pE,KAAK0pE,UACP1pE,KAAK0pE,QAAQS,MAAQ,QAGvBJ,EAAMG,MAAMC,MAAQJ,EAAMI,MAC1BJ,EAAMI,MAAMD,MAAQH,EAAMG,cAErBlqE,KAAKypE,SAASliE,KACnBvH,KAAKwpE,OACAO,EAAMC,MACd,CAKD,QAAAzc,GACE,OAAOvtD,KAAKwpE,MACb,CAKD,OAAAlgE,GACE,MAAM3C,EAAO,IAAItE,MAAMrC,KAAKwpE,QAC5B,IACIO,EADAnoE,EAAI,EAER,IAAKmoE,EAAQ/pE,KAAK2pE,QAASI,EAAOA,EAAQA,EAAMI,MAC9CxjE,EAAK/E,KAAOmoE,EAAME,KAEpB,OAAOtjE,CACR,CAKD,SAAAyjE,GACE,MAAMnhE,EAAS,IAAI5G,MAAMrC,KAAKwpE,QAC9B,IACIO,EADAnoE,EAAI,EAER,IAAKmoE,EAAQ/pE,KAAK2pE,QAASI,EAAOA,EAAQA,EAAMI,MAC9ClhE,EAAOrH,KAAOmoE,EAAMC,OAEtB,OAAO/gE,CACR,CAKD,QAAAohE,GACE,OAAOrqE,KAAK0pE,QAAQM,MACrB,CAKD,WAAAM,GACE,OAAOtqE,KAAK0pE,QAAQO,IACrB,CAMD,YAAAM,GACE,OAAOvqE,KAAK2pE,QAAQM,IACrB,CAOD,IAAAO,CAAKjjE,GACH,OAAOvH,KAAKypE,SAASliE,IAAMyiE,MAC5B,CAKD,GAAA9+D,GACE,MAAM6+D,EAAQ/pE,KAAK0pE,QAUnB,cATO1pE,KAAKypE,SAASM,EAAME,MACvBF,EAAMG,QACRH,EAAMG,MAAMC,MAAQ,MAEtBnqE,KAAK0pE,QAAgCK,EAAW,MAC3C/pE,KAAK0pE,UACR1pE,KAAK2pE,QAAU,QAEf3pE,KAAKwpE,OACAO,EAAMC,MACd,CAMD,OAAAxmD,CAAQjc,EAAKlD,GACXrE,KAAKoJ,IAAI7B,GACTvH,KAAKypE,SAASliE,GAAKyiE,OAAS3lE,CAC7B,CAMD,GAAA0F,CAAIxC,EAAKlD,GACP4P,KACI1M,KAAOvH,KAAKypE,UACd,uDAEF,MAAMM,EAAQ,CACZE,KAAM1iE,EACN2iE,MAAO,KACPC,MAAOnqE,KAAK2pE,QACZK,OAAQ3lE,GAELrE,KAAK2pE,QAGR3pE,KAAK2pE,QAAQO,MAAQH,EAFrB/pE,KAAK0pE,QAAUK,EAIjB/pE,KAAK2pE,QAAUI,EACf/pE,KAAKypE,SAASliE,GAAOwiE,IACnB/pE,KAAKwpE,MACR,CAOD,OAAAl9B,CAAQ54B,GACN1T,KAAKupE,cAAgB71D,CACtB,GC/QI,SAASgH,GAAe6kB,EAAGloB,EAAGC,EAAG/K,GACtC,YAAkB/F,IAAd+F,GACFA,EAAU,GAAKgzB,EACfhzB,EAAU,GAAK8K,EACf9K,EAAU,GAAK+K,EACR/K,GAEF,CAACgzB,EAAGloB,EAAGC,EAChB,CAQO,SAASmzD,GAAUlrC,EAAGloB,EAAGC,GAC9B,OAAOioB,EAAI,IAAMloB,EAAI,IAAMC,CAC7B,CAOO,SAAStK,GAAOT,GACrB,OAAOk+D,GAAUl+D,EAAU,GAAIA,EAAU,GAAIA,EAAU,GACzD,CAOO,SAASm+D,GAAsB1b,GACpC,MAAOzvB,EAAGloB,EAAGC,GAAK03C,EACf2b,UAAU3b,EAAQ4b,YAAY,KAAO,EAAG5b,EAAQ7tD,QAChD0kB,MAAM,KACNilB,IAAIX,QACP,OAAOsgC,GAAUlrC,EAAGloB,EAAGC,EACzB,CAOO,SAASuzD,GAAQtjE,GACtB,OAAOA,EAAIse,MAAM,KAAKilB,IAAIX,OAC5B,CAMO,SAAS2gC,GAAKv+D,GACnB,OAAQA,EAAU,IAAMA,EAAU,IAAMA,EAAU,EACpD,CAOO,SAASw+D,GAAiBx+D,EAAWsV,GAC1C,MAAM0d,EAAIhzB,EAAU,GACd8K,EAAI9K,EAAU,GACd+K,EAAI/K,EAAU,GAEpB,GAAIsV,EAASqsB,aAAe3O,GAAKA,EAAI1d,EAASssB,aAC5C,OAAO,EAET,MAAM68B,EAAYnpD,EAASopD,iBAAiB1rC,GAC5C,OAAKyrC,GAGEA,EAAUjxD,WAAW1C,EAAGC,EACjC,CChDA,IAAA4zD,GAzCA,cAAwBC,GACtB,KAAAxmE,GACE,KAAO3E,KAAKutD,WAAa,GACvBvtD,KAAKkL,MAAM4B,UAEb7H,MAAMN,OACP,CAKD,WAAAilE,CAAYzD,GACV,KAAOnmE,KAAKmsC,kBAAkB,CAE5B,GADansC,KAAKqqE,WACTr9D,WAAYm5D,EACnB,MAEAnmE,KAAKkL,MAAM4B,SAEd,CACF,CAKD,kBAAAs+D,GACE,GAAwB,IAApBprE,KAAKutD,WACP,OAEF,MAEMhuB,EADYsrC,GADN7qE,KAAKuqE,gBAEG,GACpBvqE,KAAKmL,SAAS+B,IACRA,EAAKX,UAAU,KAAOgzB,IACxBv/B,KAAK0L,OAAOsB,GAAOE,EAAKX,YACxBW,EAAKJ,UACN,GAEJ,GCpCH,MAAMu+D,GAOJ,WAAAvrE,CAAYsa,EAAME,EAAMD,EAAME,GAI5Bva,KAAKoa,KAAOA,EAKZpa,KAAKsa,KAAOA,EAKZta,KAAKqa,KAAOA,EAKZra,KAAKua,KAAOA,CACb,CAMD,QAAAy4C,CAASzmD,GACP,OAAOvM,KAAK+Z,WAAWxN,EAAU,GAAIA,EAAU,GAChD,CAMD,iBAAA++D,CAAkBN,GAChB,OACEhrE,KAAKoa,MAAQ4wD,EAAU5wD,MACvB4wD,EAAU1wD,MAAQta,KAAKsa,MACvBta,KAAKqa,MAAQ2wD,EAAU3wD,MACvB2wD,EAAUzwD,MAAQva,KAAKua,IAE1B,CAOD,UAAAR,CAAW1C,EAAGC,GACZ,OAAOtX,KAAKoa,MAAQ/C,GAAKA,GAAKrX,KAAKsa,MAAQta,KAAKqa,MAAQ/C,GAAKA,GAAKtX,KAAKua,IACxE,CAMD,MAAAhY,CAAOyoE,GACL,OACEhrE,KAAKoa,MAAQ4wD,EAAU5wD,MACvBpa,KAAKqa,MAAQ2wD,EAAU3wD,MACvBra,KAAKsa,MAAQ0wD,EAAU1wD,MACvBta,KAAKua,MAAQywD,EAAUzwD,IAE1B,CAKD,MAAArY,CAAO8oE,GACDA,EAAU5wD,KAAOpa,KAAKoa,OACxBpa,KAAKoa,KAAO4wD,EAAU5wD,MAEpB4wD,EAAU1wD,KAAOta,KAAKsa,OACxBta,KAAKsa,KAAO0wD,EAAU1wD,MAEpB0wD,EAAU3wD,KAAOra,KAAKqa,OACxBra,KAAKqa,KAAO2wD,EAAU3wD,MAEpB2wD,EAAUzwD,KAAOva,KAAKua,OACxBva,KAAKua,KAAOywD,EAAUzwD,KAEzB,CAKD,SAAA8B,GACE,OAAOrc,KAAKua,KAAOva,KAAKqa,KAAO,CAChC,CAKD,OAAA1G,GACE,MAAO,CAAC3T,KAAKoc,WAAYpc,KAAKqc,YAC/B,CAKD,QAAAD,GACE,OAAOpc,KAAKsa,KAAOta,KAAKoa,KAAO,CAChC,CAMD,UAAA0D,CAAWktD,GACT,OACEhrE,KAAKoa,MAAQ4wD,EAAU1wD,MACvBta,KAAKsa,MAAQ0wD,EAAU5wD,MACvBpa,KAAKqa,MAAQ2wD,EAAUzwD,MACvBva,KAAKua,MAAQywD,EAAU3wD,IAE1B,EAWI,SAASK,GAAeN,EAAME,EAAMD,EAAME,EAAMywD,GACrD,YAAkBxkE,IAAdwkE,GACFA,EAAU5wD,KAAOA,EACjB4wD,EAAU1wD,KAAOA,EACjB0wD,EAAU3wD,KAAOA,EACjB2wD,EAAUzwD,KAAOA,EACVywD,GAEF,IAAIK,GAAUjxD,EAAME,EAAMD,EAAME,EACzC,CAEA,IAAAgxD,GAAeF,GCnIf,MAAM17D,GAAa,GAgJnB,IAAA67D,GA9IA,cAA+Bp4D,GAQ7B,WAAAtT,CAAYyM,EAAWC,EAAOi/D,EAAcC,GAC1CzmE,MAAMsH,EAAWC,EAAO,CAACG,WAAY,IAMrC3M,KAAK2rE,SAAW,GAMhB3rE,KAAK4rE,eAAiB,GAMtB5rE,KAAK6rE,wBAA0B,GAM/B7rE,KAAK8rE,mBAAqB,EAK1B9rE,KAAK+rE,sBAAwB,GAM7B/rE,KAAKgsE,aAAe,GAKpBhsE,KAAKisE,YAAc,GAKnBjsE,KAAKksE,cAAgB,GAKrBlsE,KAAKmsE,iBAKLnsE,KAAK0rE,eAAiBA,EAAexkE,UAAKV,EAAWxG,MAKrDA,KAAKosE,iBAAmBX,CACzB,CAMD,UAAAx7D,CAAW29B,GACT,MAAMrmC,EAAMmB,EAAOklC,GAInB,OAHMrmC,KAAOvH,KAAK2rE,WAChB3rE,KAAK2rE,SAASpkE,GAAOiI,GAAsB,EAAG,EAAGG,KAE5C3P,KAAK2rE,SAASpkE,EACtB,CAMD,UAAA8kE,CAAWz+B,GACT,OAAOllC,EAAOklC,KAAU5tC,KAAK2rE,QAC9B,CAOD,QAAAnwC,CAASoS,GACP,OAAO5tC,KAAKqsE,WAAWz+B,GAAS5tC,KAAKiQ,WAAW29B,GAAO/9B,OAAS,IACjE,CAMD,cAAAy8D,CAAe1+B,GACb,MAAMrmC,EAAMmB,EAAOklC,GAYnB,OAXMrmC,KAAOvH,KAAKgsE,eAChBhsE,KAAKgsE,aAAazkE,GAAO,CACvBglE,OAAO,EACPC,oBAAqB,KACrBC,mBAAoBp+C,IACpBq+C,kBAAmB,EACnBC,uBAAwBt+C,IACxBu+C,sBAAuB,EACvBC,eAAgB,IAGb7sE,KAAKgsE,aAAazkE,EAC1B,CAKD,IAAA+F,GACEtN,KAAK0rE,gBACN,CAKD,OAAA5+D,GACE,IAAK,MAAMvF,KAAOvH,KAAK2rE,SAAU,CAC/B,MAAMx7D,EAAUnQ,KAAK2rE,SAASpkE,GAC9B2I,GAAcC,GACdR,GAAWhK,KAAKwK,EAAQN,eACjB7P,KAAK2rE,SAASpkE,EACtB,CACDtC,MAAM6H,SACP,GCzBH,IAAAggE,GAnIA,cAAyB15D,GASvB,WAAAtT,CAAYyM,EAAWC,EAAOquB,EAAK7T,EAAQsV,EAAkB3xB,GAC3D1F,MAAMsH,EAAWC,EAAO7B,GAMxB3K,KAAKwZ,OAAS,KAMdxZ,KAAK+sE,QAAU/lD,EAMfhnB,KAAKgtE,UAAY,KAMjBhtE,KAAKqT,QAMLrT,KAAKmf,WAAa,KAMlBnf,KAAK2c,WAML3c,KAAK08B,kBAAoBJ,EAMzBt8B,KAAKitE,KAAOpyC,EAEZ76B,KAAKuH,IAAMszB,CACZ,CAOD,SAAAqyC,GACE,OAAOltE,KAAK+sE,OACb,CAOD,WAAA1vB,GACE,OAAOr9C,KAAKgtE,SACb,CAKD,IAAA1/D,GACMtN,KAAKwM,OAASV,IAChB9L,KAAK+M,SAASjB,GACd9L,KAAK08B,kBAAkB18B,KAAMA,KAAKitE,MAC9BjtE,KAAKqT,SACPrT,KAAKqT,QAAQrT,KAAKwZ,OAAQxZ,KAAK2c,WAAY3c,KAAKmf,YAGrD,CAOD,MAAAguD,CAAOhK,EAAUiK,GACfptE,KAAKqtE,YAAYlK,EAClB,CAKD,OAAAmK,GACEttE,KAAK+M,SAASjB,EACf,CAQD,WAAAuhE,CAAYlK,GACVnjE,KAAKgtE,UAAY7J,EACjBnjE,KAAK+M,SAASjB,EACf,CAOD,SAAAyhE,CAAUj6D,GACRtT,KAAKqT,QAAUC,CAChB,GChHI,SAASk6D,GAAYvjC,GAC1B,OAAI5nC,MAAMC,QAAQ2nC,GACTrxB,GAASqxB,GAEXA,CACT,CCjBA,ICiIIwjC,GDjIAC,IAAkB,EAgDf,SAASC,GACdC,EACA5mD,EACAxN,EACAmD,EACAwC,EACA0uD,EACAC,GAEA,MAAMC,EAAM,IAAIC,eAChBD,EAAIE,KACF,MACe,mBAARL,EAAqBA,EAAIp0D,EAAQmD,EAAYwC,GAAcyuD,GAClE,GAEsB,eAApB5mD,EAAO0H,YACTq/C,EAAIG,aAAe,eAErBH,EAAIL,gBAAkBA,GAKtBK,EAAII,OAAS,SAAUtoE,GAErB,IAAKkoE,EAAIK,QAAWL,EAAIK,QAAU,KAAOL,EAAIK,OAAS,IAAM,CAC1D,MAAMruE,EAAOinB,EAAO0H,UAEpB,IAAIxkB,EACQ,QAARnK,EACFmK,EAASmkE,KAAKnjC,MAAM6iC,EAAIO,cACP,QAARvuE,EACTmK,EAAS6jE,EAAIO,aACI,OAARvuE,GACTmK,EAAS6jE,EAAIQ,YACRrkE,IACHA,GAAS,IAAIskE,WAAYC,gBACvBV,EAAIO,aACJ,qBAGa,eAARvuE,IACTmK,EAAqC6jE,EAAY,UAE/C7jE,EACF2jE,EAGI7mD,EAAO0nD,aAAaxkE,EAAQ,CAC1BsP,OAAQA,EACRm1D,kBAAmBxvD,IAGvB6H,EAAO4nD,eAAe1kE,IAGxB4jE,GAER,MACMA,GAEN,EAIEC,EAAIc,QAAUf,EACdC,EAAIe,MACN,CAWO,SAASf,GAAIH,EAAK5mD,GAUvB,OAAO,SAAUxN,EAAQmD,EAAYwC,EAAY0uD,EAASC,GACxD,MAAM5jE,EAA2D,KACjEyjE,GACEC,EACA5mD,EACAxN,EACAmD,EACAwC,GAMA,SAAUgkD,EAAUiK,GAClBljE,EAAO6kE,YAAY5L,QACH38D,IAAZqnE,GACFA,EAAQ1K,EAEX,GACwB2K,GAAoBzqE,EAEnD,CACA,CE3JO,SAAS6yD,GAAI18C,EAAQmD,GAC1B,MAAO,CAAC,EAAElC,KAAWA,IAAUA,IAAUA,KAC3C,CDCO,SAASu0D,GAAMpB,EAAKhyD,EAAUqzD,EAASC,GAC5C,MAAMC,EAASp/D,SAASC,cAAc,UAChCzI,EAAM,OAASmB,EAAOkT,GAC5B,SAASwzD,WACA9/D,OAAO/H,GACd4nE,EAAO/9D,WAAWI,YAAY29D,EAC/B,CACDA,EAAOE,OAAQ,EACfF,EAAOt0C,IACL+yC,GACCA,EAAIloE,SAAS,KAAO,IAAM,MAC1BwpE,GAAiB,YAClB,IACA3nE,EACF,MAAM+nE,EAAQ79B,YAAW,WACvB29B,IACIH,GACFA,GAEH,GAAE,KACH3/D,OAAO/H,GAAO,SAAUpF,GACtBipD,aAAakkB,GACbF,IACAxzD,EAASzZ,EACb,EACE4N,SAASw/D,KAAKr9D,YAAYi9D,EAC5B,CAEO,MAAMK,WAAsBhnE,MAIjC,WAAA1I,CAAY2vE,GAEVxqE,MADgB,+BAAiCwqE,EAASrB,QAM1DpuE,KAAK0V,KAAO,gBAKZ1V,KAAKyvE,SAAWA,CACjB,EAGI,MAAMC,WAAoBlnE,MAI/B,WAAA1I,CAAY6vE,GACV1qE,MAAM,2BAKNjF,KAAK0V,KAAO,cAKZ1V,KAAK2vE,OAASA,CACf,EAOI,SAASC,GAAQhC,GACtB,OAAO,IAAIrpE,SAAQ,SAAUE,EAASD,GA8BpC,MAAMmrE,EAAS,IAAI3B,eACnB2B,EAAOrqE,iBAAiB,QA3BxB,SAAgBO,GACd,MAAM8pE,EAAS9pE,EAAM1F,OAErB,IAAKwvE,EAAOvB,QAAWuB,EAAOvB,QAAU,KAAOuB,EAAOvB,OAAS,IAA/D,CACE,IAAIjsE,EACJ,IACEA,EAAOksE,KAAKnjC,MAAMykC,EAAOrB,aAC1B,CAAC,MAAOhqE,GACP,MAAMyzB,EAAU,wCAA0CzzB,EAAIyzB,QAE9D,YADAvzB,EAAO,IAAIgE,MAAMuvB,GAElB,CACDtzB,EAAQtC,EAET,MAEDqC,EAAO,IAAIgrE,GAAcG,GAC1B,IAWDA,EAAOrqE,iBAAiB,SANxB,SAAiBO,GACfrB,EAAO,IAAIkrE,GAAY7pE,EAAM1F,QAC9B,IAKDwvE,EAAO1B,KAAK,MAAOL,GACnB+B,EAAOE,iBAAiB,SAAU,oBAClCF,EAAOb,MACX,GACA,CAOO,SAASgB,GAAWplC,EAAMkjC,GAC/B,OAAIA,EAAIloE,SAAS,OACRkoE,EAEF,IAAImC,IAAInC,EAAKljC,GAAMslC,IAC5B,CEvBA,IAAAC,GAxGA,MASE,UAAAC,CAAWt7D,EAAU+qC,EAASukB,EAAUiM,GAAwB,CAOhE,YAAAC,CAAax7D,GAAY,CAOzB,QAAAQ,CAAS7E,GAAS,CAMlB,UAAA8/D,CAAWC,EAAgB3wB,GAAW,CAMtC,WAAA4wB,CAAY5wB,EAASpvC,GAAS,CAM9B,sBAAAigE,CAAuBC,EAA4B9wB,GAAW,CAM9D,cAAA+wB,CAAeC,EAAoBhxB,GAAW,CAM9C,mBAAAixB,CAAoBC,EAAyBlxB,GAAW,CAMxD,cAAAmxB,CAAeC,EAAoBpxB,GAAW,CAM9C,gBAAAqxB,CAAiBC,EAAsBtxB,GAAW,CAMlD,SAAAuxB,CAAUC,EAAexxB,GAAW,CAMpC,WAAAyxB,CAAYC,EAAiB1xB,GAAW,CAMxC,QAAA2xB,CAAS18D,EAAU+qC,GAAW,CAM9B,kBAAA4xB,CAAmBz0C,EAAW00C,GAAe,CAM7C,aAAAC,CAAcC,EAAYC,GAA0B,CAMpD,YAAAC,CAAaC,EAAWF,GAA0B,GC4iCpD,IAAAG,GAlnCA,cAAsCC,GAUpC,WAAAjyE,CACEqQ,EACAirB,EACA5hB,EACAxD,EACAg8D,EACAlkD,EACAmkD,GAEAhtE,QAMAjF,KAAK2rE,SAAWx7D,EAMhBnQ,KAAKs7B,YAAcF,EAMnBp7B,KAAKugB,QAAU/G,EAMfxZ,KAAKk4B,WAAaliB,EAMlBhW,KAAKkyE,mBAAqBl8D,EACtB+O,GAAQ9Y,KAAKoc,MAAMrS,EAAU,GAAIA,EAAU,IAAK,IAChD,EAMJhW,KAAKmyE,cAAgBH,EAMrBhyE,KAAKoyE,kBAAoBtkD,EAMzB9tB,KAAKqyE,eAAiBJ,EAMtBjyE,KAAKsyE,kBAAoB,KAMzBtyE,KAAKuyE,oBAAsB,KAM3BvyE,KAAKwyE,kBAAoB,KAMzBxyE,KAAKyyE,WAAa,KAMlBzyE,KAAK0yE,aAAe,KAMpB1yE,KAAKu7B,OAAS,KAMdv7B,KAAK2yE,cAAgB,EAMrB3yE,KAAK4yE,cAAgB,EAMrB5yE,KAAK6yE,aAAe,EAMpB7yE,KAAK8yE,cAAgB,EAMrB9yE,KAAK+yE,cAAgB,EAMrB/yE,KAAKgzE,cAAgB,EAMrBhzE,KAAKizE,sBAAuB,EAM5BjzE,KAAKkzE,eAAiB,EAMtBlzE,KAAKmzE,YAAc,CAAC,EAAG,GAMvBnzE,KAAKozE,YAAc,EAMnBpzE,KAAKqzE,MAAQ,GAMbrzE,KAAKszE,aAAe,EAMpBtzE,KAAKuzE,aAAe,EAMpBvzE,KAAKwzE,qBAAsB,EAM3BxzE,KAAKyzE,cAAgB,EAMrBzzE,KAAK0zE,WAAa,CAAC,EAAG,GAMtB1zE,KAAK2zE,eAAiB,KAMtB3zE,KAAK4zE,iBAAmB,KAMxB5zE,KAAK6zE,WAAa,KAMlB7zE,KAAK8zE,kBAAoB,GAMzB9zE,KAAK+zE,mB9G5OA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,E8G6OtB,CASD,WAAAC,CAAYl5D,EAAiBC,EAAQ/Y,EAAKgZ,GACxC,IAAKhb,KAAKu7B,OACR,OAEF,MAAM04C,EAAmB9mD,GACvBrS,EACAC,EACA/Y,EACAgZ,EACAhb,KAAKk4B,WACLl4B,KAAK8zE,mBAED3jE,EAAUnQ,KAAK2rE,SACfuI,EAAiBl0E,KAAK+zE,mBACtBvpC,EAAQr6B,EAAQu1C,YACI,GAAtB1lD,KAAK8yE,gBACP3iE,EAAQu1C,YAAclb,EAAQxqC,KAAK8yE,eAErC,IAAIl2D,EAAW5c,KAAKkzE,eACY,IAA5BlzE,KAAKkyE,qBACPt1D,GAAY5c,KAAKmyE,eAEfnyE,KAAKizE,uBACPr2D,GAAY5c,KAAKmyE,eAEnB,IAAK,IAAIvwE,EAAI,EAAGuE,EAAK8tE,EAAiB9yE,OAAQS,EAAIuE,EAAIvE,GAAK,EAAG,CAC5D,MAAMyV,EAAI48D,EAAiBryE,GAAK5B,KAAK2yE,cAC/Br7D,EAAI28D,EAAiBryE,EAAI,GAAK5B,KAAK4yE,cACzC,GACe,IAAbh2D,GACuB,GAAvB5c,KAAKmzE,YAAY,IACM,GAAvBnzE,KAAKmzE,YAAY,GACjB,CACA,MAAM74B,EAAUjjC,EAAIrX,KAAK2yE,cACnBp4B,EAAUjjC,EAAItX,KAAK4yE,cACzB3jD,GACEilD,EACA55B,EACAC,EACA,EACA,EACA39B,GACC09B,GACAC,GAEHpqC,EAAQs1C,OACRt1C,EAAQ6F,UAAU9R,MAAMiM,EAAS+jE,GACjC/jE,EAAQ0H,UAAUyiC,EAASC,GAC3BpqC,EAAQwH,MAAM3X,KAAKmzE,YAAY,GAAInzE,KAAKmzE,YAAY,IACpDhjE,EAAQ6C,UACNhT,KAAKu7B,OACLv7B,KAAK+yE,cACL/yE,KAAKgzE,cACLhzE,KAAKozE,YACLpzE,KAAK6yE,cACJ7yE,KAAK2yE,eACL3yE,KAAK4yE,cACN5yE,KAAKozE,YACLpzE,KAAK6yE,cAEP1iE,EAAQ21C,SAChB,MACQ31C,EAAQ6C,UACNhT,KAAKu7B,OACLv7B,KAAK+yE,cACL/yE,KAAKgzE,cACLhzE,KAAKozE,YACLpzE,KAAK6yE,aACLx7D,EACAC,EACAtX,KAAKozE,YACLpzE,KAAK6yE,aAGV,CACyB,GAAtB7yE,KAAK8yE,gBACP3iE,EAAQu1C,YAAclb,EAEzB,CASD,SAAA2pC,CAAUr5D,EAAiBC,EAAQ/Y,EAAKgZ,GACtC,IAAKhb,KAAK6zE,YAA6B,KAAf7zE,KAAKqzE,MAC3B,OAEErzE,KAAK2zE,gBACP3zE,KAAKo0E,qBAAqBp0E,KAAK2zE,gBAE7B3zE,KAAK4zE,kBACP5zE,KAAKq0E,uBAAuBr0E,KAAK4zE,kBAEnC5zE,KAAKs0E,qBAAqBt0E,KAAK6zE,YAC/B,MAAMI,EAAmB9mD,GACvBrS,EACAC,EACA/Y,EACAgZ,EACAhb,KAAKk4B,WACLl4B,KAAK8zE,mBAED3jE,EAAUnQ,KAAK2rE,SACrB,IAAI/uD,EAAW5c,KAAKyzE,cAOpB,IANgC,IAA5BzzE,KAAKkyE,qBACPt1D,GAAY5c,KAAKmyE,eAEfnyE,KAAKwzE,sBACP52D,GAAY5c,KAAKmyE,eAEZp3D,EAAS/Y,EAAK+Y,GAAUC,EAAQ,CACrC,MAAM3D,EAAI48D,EAAiBl5D,GAAU/a,KAAKszE,aACpCh8D,EAAI28D,EAAiBl5D,EAAS,GAAK/a,KAAKuzE,aAE/B,IAAb32D,GACsB,GAAtB5c,KAAK0zE,WAAW,IACM,GAAtB1zE,KAAK0zE,WAAW,IAEhBvjE,EAAQs1C,OACRt1C,EAAQ0H,UAAUR,EAAIrX,KAAKszE,aAAch8D,EAAItX,KAAKuzE,cAClDpjE,EAAQoH,OAAOqF,GACfzM,EAAQ0H,UAAU7X,KAAKszE,aAActzE,KAAKuzE,cAC1CpjE,EAAQwH,MAAM3X,KAAK0zE,WAAW,GAAI1zE,KAAK0zE,WAAW,IAC9C1zE,KAAK4zE,kBACPzjE,EAAQokE,WAAWv0E,KAAKqzE,MAAO,EAAG,GAEhCrzE,KAAK2zE,gBACPxjE,EAAQqkE,SAASx0E,KAAKqzE,MAAO,EAAG,GAElCljE,EAAQ21C,YAEJ9lD,KAAK4zE,kBACPzjE,EAAQokE,WAAWv0E,KAAKqzE,MAAOh8D,EAAGC,GAEhCtX,KAAK2zE,gBACPxjE,EAAQqkE,SAASx0E,KAAKqzE,MAAOh8D,EAAGC,GAGrC,CACF,CAWD,aAAAm9D,CAAc35D,EAAiBC,EAAQ/Y,EAAKgZ,EAAQ05D,GAClD,MAAMvkE,EAAUnQ,KAAK2rE,SACfsI,EAAmB9mD,GACvBrS,EACAC,EACA/Y,EACAgZ,EACAhb,KAAKk4B,WACLl4B,KAAK8zE,mBAEP3jE,EAAQwkE,OAAOV,EAAiB,GAAIA,EAAiB,IACrD,IAAI9yE,EAAS8yE,EAAiB9yE,OAC1BuzE,IACFvzE,GAAU,GAEZ,IAAK,IAAIS,EAAI,EAAGA,EAAIT,EAAQS,GAAK,EAC/BuO,EAAQykE,OAAOX,EAAiBryE,GAAIqyE,EAAiBryE,EAAI,IAK3D,OAHI8yE,GACFvkE,EAAQ0kE,YAEH7yE,CACR,CAUD,UAAA8yE,CAAWh6D,EAAiBC,EAAQ6V,EAAM5V,GACxC,IAAK,IAAIpZ,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAC1CmZ,EAAS/a,KAAKy0E,cACZ35D,EACAC,EACA6V,EAAKhvB,GACLoZ,GACA,GAGJ,OAAOD,CACR,CASD,UAAAs1D,CAAWz7D,GAST,GARI5U,KAAKoyE,oBACPx9D,EACEA,EAASoZ,oBACPhuB,KAAKoyE,kBACLpyE,KAAKqyE,iBAINv0D,GAAW9d,KAAKugB,QAAS3L,EAASyK,aAAvC,CAGA,GAAIrf,KAAKyyE,YAAczyE,KAAK0yE,aAAc,CACpC1yE,KAAKyyE,YACPzyE,KAAKo0E,qBAAqBp0E,KAAKyyE,YAE7BzyE,KAAK0yE,cACP1yE,KAAKq0E,uBAAuBr0E,KAAK0yE,cAEnC,MAAMuB,EAAmB5kD,GACvBza,EACA5U,KAAKk4B,WACLl4B,KAAK8zE,mBAEDh8D,EAAKm8D,EAAiB,GAAKA,EAAiB,GAC5Cl8D,EAAKk8D,EAAiB,GAAKA,EAAiB,GAC5CjsD,EAAS/b,KAAKma,KAAKtO,EAAKA,EAAKC,EAAKA,GAClC5H,EAAUnQ,KAAK2rE,SACrBx7D,EAAQ4kE,YACR5kE,EAAQ6kE,IACNf,EAAiB,GACjBA,EAAiB,GACjBjsD,EACA,EACA,EAAI/b,KAAK+T,IAEPhgB,KAAKyyE,YACPtiE,EAAQ8kE,OAENj1E,KAAK0yE,cACPviE,EAAQ+kE,QAEX,CACkB,KAAfl1E,KAAKqzE,OACPrzE,KAAKm0E,UAAUv/D,EAAS0H,YAAa,EAAG,EAAG,EAjC5C,CAmCF,CASD,QAAAlH,CAAS7E,GACPvQ,KAAKuxE,mBAAmBhhE,EAAM4kE,UAAW5kE,EAAM6kE,aAC/Cp1E,KAAKyxE,cAAclhE,EAAMirB,YACzBx7B,KAAK4xE,aAAarhE,EAAM8kE,UACzB,CAKD,YAAAC,CAAat/D,GACXhW,KAAKk4B,WAAaliB,CACnB,CASD,YAAAo6D,CAAax7D,GAEX,OADaA,EAAS8Z,WAEpB,IAAK,QACH1uB,KAAKkxE,UACb,GAEQ,MACF,IAAK,aACHlxE,KAAK0wE,eACb,GAEQ,MACF,IAAK,UACH1wE,KAAKoxE,YACb,GAEQ,MACF,IAAK,aACHpxE,KAAK8wE,eACb,GAEQ,MACF,IAAK,kBACH9wE,KAAK4wE,oBACb,GAIQ,MACF,IAAK,eACH5wE,KAAKgxE,iBACb,GAEQ,MACF,IAAK,qBACHhxE,KAAKwwE,uBACb,GAIQ,MACF,IAAK,SACHxwE,KAAKqwE,WACb,GAKG,CAYD,WAAAE,CAAY5wB,EAASpvC,GACnB,MAAMqE,EAAWrE,EAAMglE,qBAANhlE,CAA4BovC,GACxC/qC,IAGL5U,KAAKoV,SAAS7E,GACdvQ,KAAKowE,aAAax7D,GACnB,CAQD,sBAAA47D,CAAuB57D,GACrB,MAAM4gE,EAAa5gE,EAAS6gE,qBAC5B,IAAK,IAAI7zE,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAChD5B,KAAKowE,aAAaoF,EAAW5zE,GAEhC,CAQD,SAAAsvE,CAAUt8D,GACJ5U,KAAKoyE,oBACPx9D,EACEA,EAASoZ,oBACPhuB,KAAKoyE,kBACLpyE,KAAKqyE,iBAIX,MAAMv3D,EAAkBlG,EAAS2a,qBAC3BvU,EAASpG,EAAS4a,YACpBxvB,KAAKu7B,QACPv7B,KAAKg0E,YAAYl5D,EAAiB,EAAGA,EAAgB3Z,OAAQ6Z,GAE5C,KAAfhb,KAAKqzE,OACPrzE,KAAKm0E,UAAUr5D,EAAiB,EAAGA,EAAgB3Z,OAAQ6Z,EAE9D,CAQD,cAAA81D,CAAel8D,GACT5U,KAAKoyE,oBACPx9D,EACEA,EAASoZ,oBACPhuB,KAAKoyE,kBACLpyE,KAAKqyE,iBAIX,MAAMv3D,EAAkBlG,EAAS2a,qBAC3BvU,EAASpG,EAAS4a,YACpBxvB,KAAKu7B,QACPv7B,KAAKg0E,YAAYl5D,EAAiB,EAAGA,EAAgB3Z,OAAQ6Z,GAE5C,KAAfhb,KAAKqzE,OACPrzE,KAAKm0E,UAAUr5D,EAAiB,EAAGA,EAAgB3Z,OAAQ6Z,EAE9D,CAQD,cAAA01D,CAAe97D,GASb,GARI5U,KAAKoyE,oBACPx9D,EACEA,EAASoZ,oBACPhuB,KAAKoyE,kBACLpyE,KAAKqyE,iBAINv0D,GAAW9d,KAAKugB,QAAS3L,EAASyK,aAAvC,CAGA,GAAIrf,KAAK0yE,aAAc,CACrB1yE,KAAKq0E,uBAAuBr0E,KAAK0yE,cACjC,MAAMviE,EAAUnQ,KAAK2rE,SACf7wD,EAAkBlG,EAAS2a,qBACjCpf,EAAQ4kE,YACR/0E,KAAKy0E,cACH35D,EACA,EACAA,EAAgB3Z,OAChByT,EAAS4a,aACT,GAEFrf,EAAQ+kE,QACT,CACD,GAAmB,KAAfl1E,KAAKqzE,MAAc,CACrB,MAAMqC,EAAe9gE,EAAS+gE,kBAC9B31E,KAAKm0E,UAAUuB,EAAc,EAAG,EAAG,EACpC,CAlBA,CAmBF,CAQD,mBAAA9E,CAAoBh8D,GACd5U,KAAKoyE,oBACPx9D,EAEIA,EAASoZ,oBACPhuB,KAAKoyE,kBACLpyE,KAAKqyE,iBAIb,MAAMuD,EAAiBhhE,EAASyK,YAChC,GAAKvB,GAAW9d,KAAKugB,QAASq1D,GAA9B,CAGA,GAAI51E,KAAK0yE,aAAc,CACrB1yE,KAAKq0E,uBAAuBr0E,KAAK0yE,cACjC,MAAMviE,EAAUnQ,KAAK2rE,SACf7wD,EAAkBlG,EAAS2a,qBACjC,IAAIxU,EAAS,EACb,MAAM6V,EAAqChc,EAAS+hB,UAC9C3b,EAASpG,EAAS4a,YACxBrf,EAAQ4kE,YACR,IAAK,IAAInzE,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAC1CmZ,EAAS/a,KAAKy0E,cACZ35D,EACAC,EACA6V,EAAKhvB,GACLoZ,GACA,GAGJ7K,EAAQ+kE,QACT,CACD,GAAmB,KAAfl1E,KAAKqzE,MAAc,CACrB,MAAMwC,EAAgBjhE,EAASkhE,mBAC/B91E,KAAKm0E,UAAU0B,EAAe,EAAGA,EAAc10E,OAAQ,EACxD,CAvBA,CAwBF,CAQD,WAAAiwE,CAAYx8D,GASV,GARI5U,KAAKoyE,oBACPx9D,EACEA,EAASoZ,oBACPhuB,KAAKoyE,kBACLpyE,KAAKqyE,iBAINv0D,GAAW9d,KAAKugB,QAAS3L,EAASyK,aAAvC,CAGA,GAAIrf,KAAK0yE,cAAgB1yE,KAAKyyE,WAAY,CACpCzyE,KAAKyyE,YACPzyE,KAAKo0E,qBAAqBp0E,KAAKyyE,YAE7BzyE,KAAK0yE,cACP1yE,KAAKq0E,uBAAuBr0E,KAAK0yE,cAEnC,MAAMviE,EAAUnQ,KAAK2rE,SACrBx7D,EAAQ4kE,YACR/0E,KAAK80E,WACHlgE,EAAS6hB,6BACT,EAC8B7hB,EAAS+hB,UACvC/hB,EAAS4a,aAEPxvB,KAAKyyE,YACPtiE,EAAQ8kE,OAENj1E,KAAK0yE,cACPviE,EAAQ+kE,QAEX,CACD,GAAmB,KAAfl1E,KAAKqzE,MAAc,CACrB,MAAM0C,EAAoBnhE,EAASgiB,uBACnC52B,KAAKm0E,UAAU4B,EAAmB,EAAG,EAAG,EACzC,CA1BA,CA2BF,CAOD,gBAAA/E,CAAiBp8D,GASf,GARI5U,KAAKoyE,oBACPx9D,EACEA,EAASoZ,oBACPhuB,KAAKoyE,kBACLpyE,KAAKqyE,iBAINv0D,GAAW9d,KAAKugB,QAAS3L,EAASyK,aAAvC,CAGA,GAAIrf,KAAK0yE,cAAgB1yE,KAAKyyE,WAAY,CACpCzyE,KAAKyyE,YACPzyE,KAAKo0E,qBAAqBp0E,KAAKyyE,YAE7BzyE,KAAK0yE,cACP1yE,KAAKq0E,uBAAuBr0E,KAAK0yE,cAEnC,MAAMviE,EAAUnQ,KAAK2rE,SACf7wD,EAAkBlG,EAAS6hB,6BACjC,IAAI1b,EAAS,EACb,MAAM+V,EAAQlc,EAASohE,WACjBh7D,EAASpG,EAAS4a,YACxBrf,EAAQ4kE,YACR,IAAK,IAAInzE,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAMgvB,EAAOE,EAAMlvB,GACnBmZ,EAAS/a,KAAK80E,WAAWh6D,EAAiBC,EAAQ6V,EAAM5V,EACzD,CACGhb,KAAKyyE,YACPtiE,EAAQ8kE,OAENj1E,KAAK0yE,cACPviE,EAAQ+kE,QAEX,CACD,GAAmB,KAAfl1E,KAAKqzE,MAAc,CACrB,MAAM4C,EAAqBrhE,EAASshE,wBACpCl2E,KAAKm0E,UAAU8B,EAAoB,EAAGA,EAAmB90E,OAAQ,EAClE,CA5BA,CA6BF,CAMD,oBAAAizE,CAAqB+B,GACnB,MAAMhmE,EAAUnQ,KAAK2rE,SACfyK,EAAmBp2E,KAAKsyE,kBACzB8D,EAMCA,EAAiBt5C,WAAaq5C,EAAUr5C,YAC1Cs5C,EAAiBt5C,UAAYq5C,EAAUr5C,UACvC3sB,EAAQ2sB,UAAYq5C,EAAUr5C,YAPhC3sB,EAAQ2sB,UAAYq5C,EAAUr5C,UAC9B98B,KAAKsyE,kBAAoB,CACvBx1C,UAAWq5C,EAAUr5C,WAQ1B,CAMD,sBAAAu3C,CAAuBgC,GACrB,MAAMlmE,EAAUnQ,KAAK2rE,SACf2K,EAAqBt2E,KAAKuyE,oBAC3B+D,GAkBCA,EAAmBC,SAAWF,EAAYE,UAC5CD,EAAmBC,QAAUF,EAAYE,QACzCpmE,EAAQomE,QAAUF,EAAYE,SAE3Bh0E,EAAO+zE,EAAmBE,SAAUH,EAAYG,WACnDrmE,EAAQsmE,YACLH,EAAmBE,SAAWH,EAAYG,UAG3CF,EAAmBI,gBAAkBL,EAAYK,iBACnDJ,EAAmBI,eAAiBL,EAAYK,eAChDvmE,EAAQumE,eAAiBL,EAAYK,gBAEnCJ,EAAmBK,UAAYN,EAAYM,WAC7CL,EAAmBK,SAAWN,EAAYM,SAC1CxmE,EAAQwmE,SAAWN,EAAYM,UAE7BL,EAAmBpxB,WAAamxB,EAAYnxB,YAC9CoxB,EAAmBpxB,UAAYmxB,EAAYnxB,UAC3C/0C,EAAQ+0C,UAAYmxB,EAAYnxB,WAE9BoxB,EAAmBM,YAAcP,EAAYO,aAC/CN,EAAmBM,WAAaP,EAAYO,WAC5CzmE,EAAQymE,WAAaP,EAAYO,YAE/BN,EAAmB9E,aAAe6E,EAAY7E,cAChD8E,EAAmB9E,YAAc6E,EAAY7E,YAC7CrhE,EAAQqhE,YAAc6E,EAAY7E,eA5CpCrhE,EAAQomE,QAAUF,EAAYE,QAC9BpmE,EAAQsmE,YAAYJ,EAAYG,UAChCrmE,EAAQumE,eAAiBL,EAAYK,eACrCvmE,EAAQwmE,SAAWN,EAAYM,SAC/BxmE,EAAQ+0C,UAAYmxB,EAAYnxB,UAChC/0C,EAAQymE,WAAaP,EAAYO,WACjCzmE,EAAQqhE,YAAc6E,EAAY7E,YAClCxxE,KAAKuyE,oBAAsB,CACzBgE,QAASF,EAAYE,QACrBC,SAAUH,EAAYG,SACtBE,eAAgBL,EAAYK,eAC5BC,SAAUN,EAAYM,SACtBzxB,UAAWmxB,EAAYnxB,UACvB0xB,WAAYP,EAAYO,WACxBpF,YAAa6E,EAAY7E,aAiC9B,CAMD,oBAAA8C,CAAqBuC,GACnB,MAAM1mE,EAAUnQ,KAAK2rE,SACfmL,EAAmB92E,KAAKwyE,kBACxBuE,EAAYF,EAAUE,UACxBF,EAAUE,UACV50B,GACC20B,GAUCA,EAAiBrzB,MAAQozB,EAAUpzB,OACrCqzB,EAAiBrzB,KAAOozB,EAAUpzB,KAClCtzC,EAAQszC,KAAOozB,EAAUpzB,MAEvBqzB,EAAiBC,WAAaA,IAChCD,EAAiBC,UAAYA,EAC7B5mE,EAAQ4mE,UAAYA,GAElBD,EAAiBE,cAAgBH,EAAUG,eAC7CF,EAAiBE,aAAeH,EAAUG,aAC1C7mE,EAAQ6mE,aAAeH,EAAUG,gBAnBnC7mE,EAAQszC,KAAOozB,EAAUpzB,KACzBtzC,EAAQ4mE,UAAYA,EACpB5mE,EAAQ6mE,aAAeH,EAAUG,aACjCh3E,KAAKwyE,kBAAoB,CACvB/uB,KAAMozB,EAAUpzB,KAChBszB,UAAWA,EACXC,aAAcH,EAAUG,cAgB7B,CASD,kBAAAzF,CAAmBz0C,EAAW00C,GAC5B,GAAK10C,EAEE,CACL,MAAMm6C,EAAiBn6C,EAAUo6C,WACjCl3E,KAAKyyE,WAAa,CAChB31C,UAAW0wC,GACTyJ,GAAkCp1B,IAGvC,MARC7hD,KAAKyyE,WAAa,KASpB,GAAKjB,EAEE,CACL,MAAM2F,EAAmB3F,EAAY0F,WAC/BE,EAAqB5F,EAAY6F,aACjCC,EAAsB9F,EAAY+F,cAClCC,EAA4BhG,EAAYiG,oBACxCC,EAAsBlG,EAAYmG,cAClCC,EAAmBpG,EAAYp1D,WAC/By7D,EAAwBrG,EAAYsG,gBACpCtB,EAAWc,GAEbv1B,GACJ/hD,KAAK0yE,aAAe,CAClB6D,aACyB/vE,IAAvB4wE,EACIA,EACAt1B,GACN00B,SACuB,IAArBx2E,KAAKs7B,YACDk7C,EACAA,EAAS1rC,KAAKnpC,GAAMA,EAAI3B,KAAKs7B,cACnCo7C,gBACGc,GhD94B0B,GgDg5BEx3E,KAAKs7B,YACpCq7C,cAC0BnwE,IAAxBkxE,EACIA,EACA11B,GACNkD,gBACwB1+C,IAArBoxE,EACGA,EhD72BkB,GgD82BE53E,KAAKs7B,YAC/Bs7C,gBAC4BpwE,IAA1BqxE,EACIA,EACA51B,GACNuvB,YAAahE,GACX2J,GAAsCj1B,IAG3C,MAzCCliD,KAAK0yE,aAAe,IA0CvB,CAQD,aAAAjB,CAAcC,GACZ,IAAIqG,EACJ,IAAKrG,KAAgBqG,EAAYrG,EAAW/9D,WAE1C,YADA3T,KAAKu7B,OAAS,MAGhB,MAAMy8C,EAAkBtG,EAAWj2C,cAAcz7B,KAAKs7B,aAChD28C,EAAcvG,EAAWwG,YACzBC,EAAczG,EAAW0G,YAC/Bp4E,KAAKu7B,OAASm2C,EAAWl2C,SAASx7B,KAAKs7B,aACvCt7B,KAAK2yE,cAAgBsF,EAAY,GAAKD,EACtCh4E,KAAK4yE,cAAgBqF,EAAY,GAAKD,EACtCh4E,KAAK6yE,aAAekF,EAAU,GAAKC,EACnCh4E,KAAK8yE,cAAgBpB,EAAW5jC,aAChC9tC,KAAK+yE,cAAgBoF,EAAY,GACjCn4E,KAAKgzE,cAAgBmF,EAAY,GACjCn4E,KAAKizE,qBAAuBvB,EAAW2G,oBACvCr4E,KAAKkzE,eAAiBxB,EAAW57B,cACjC,MAAMwiC,EAAa5G,EAAW6G,gBAC9Bv4E,KAAKmzE,YAAc,CAChBmF,EAAW,GAAKt4E,KAAKs7B,YAAe08C,EACpCM,EAAW,GAAKt4E,KAAKs7B,YAAe08C,GAEvCh4E,KAAKozE,YAAc2E,EAAU,GAAKC,CACnC,CAQD,YAAApG,CAAaC,GACX,GAAKA,EAEE,CACL,MAAM2G,EAAgB3G,EAAUsD,UAChC,GAAKqD,EAEE,CACL,MAAMC,EAAqBD,EAActB,WACzCl3E,KAAK2zE,eAAiB,CACpB72C,UAAW0wC,GACTiL,GAA0C52B,IAG/C,MARC7hD,KAAK2zE,eAAiB,KASxB,MAAM+E,EAAkB7G,EAAUuD,YAClC,GAAKsD,EAEE,CACL,MAAMC,EAAuBD,EAAgBxB,WACvC0B,EAAyBF,EAAgBrB,aACzCwB,EAA0BH,EAAgBnB,cAC1CuB,EACJJ,EAAgBjB,oBACZsB,EAA0BL,EAAgBf,cAC1CqB,EAAuBN,EAAgBt8D,WACvC68D,EAA4BP,EAAgBZ,gBAClD93E,KAAK4zE,iBAAmB,CACtB2C,aAC6B/vE,IAA3BoyE,EACIA,EACA92B,GACN00B,SAAUqC,GAEN92B,GACJ20B,eAAgBoC,GhD7+BW,EgDg/B3BnC,cAC8BnwE,IAA5BuyE,EACIA,EACA/2B,GACNkD,eAC2B1+C,IAAzBwyE,EACIA,EhD58BgB,EgD88BtBpC,gBACgCpwE,IAA9ByyE,EACIA,EACAh3B,GACNuvB,YAAahE,GACXmL,GAA8Cz2B,IAGnD,MArCCliD,KAAK4zE,iBAAmB,KAsC1B,MAAMsF,EAAWrH,EAAUsH,UACrBC,EAAcvH,EAAUwH,aACxBC,EAAczH,EAAU0H,aACxBC,EAAqB3H,EAAUwG,oBAC/BoB,EAAe5H,EAAU/7B,cACzB4jC,EAAY7H,EAAU0G,gBACtBoB,EAAW9H,EAAUwD,UACrBuE,EAAgB/H,EAAUgI,eAC1BC,EAAmBjI,EAAUkI,kBACnC/5E,KAAK6zE,WAAa,CAChBpwB,UAAmBj9C,IAAb0yE,EAAyBA,EAAWt3B,GAC1Cm1B,eACoBvwE,IAAlBozE,EAA8BA,EAAgBz3B,GAChD60B,kBACuBxwE,IAArBszE,EACIA,EACA13B,IAERpiD,KAAKqzE,WACU7sE,IAAbmzE,EACIt3E,MAAMC,QAAQq3E,GACZA,EAASj1B,QAAO,CAACs1B,EAAKhuE,EAAGpK,IAAOo4E,GAAOp4E,EAAI,EAAI,IAAMoK,IAAI,IACzD2tE,EACF,GACN35E,KAAKszE,kBACa9sE,IAAhB4yE,EAA4Bp5E,KAAKs7B,YAAc89C,EAAc,EAC/Dp5E,KAAKuzE,kBACa/sE,IAAhB8yE,EAA4Bt5E,KAAKs7B,YAAcg+C,EAAc,EAC/Dt5E,KAAKwzE,yBACoBhtE,IAAvBgzE,GAAmCA,EACrCx5E,KAAKyzE,mBAAiCjtE,IAAjBizE,EAA6BA,EAAe,EACjEz5E,KAAK0zE,WAAa,CAChB1zE,KAAKs7B,YAAco+C,EAAU,GAC7B15E,KAAKs7B,YAAco+C,EAAU,GAEhC,MAxFC15E,KAAKqzE,MAAQ,EAyFhB,GCpoCH,MAAM4G,GAAqB,GAQrBC,GAAqB,CACzB1mD,MA2TF,SACE2mD,EACAvlE,EACArE,EACAovC,EACAy6B,GAEA,MAAM1I,EAAanhE,EAAMirB,WACnBq2C,EAAYthE,EAAM8kE,UAExB,IAAI1D,EACJ,GAAID,EAAY,CACd,GAAIA,EAAW2I,iBAAmBjgD,GAChC,OAEF,IAAIkgD,EAAoBH,EACxB,GAAIC,EAAuB,CACzB,MAAMG,EAAgB7I,EAAW8I,mBACjC,GAAsB,SAAlBD,EAEF,GADAD,EAAoBF,EACE,aAAlBG,EAA8B,CAEhC,MAAME,EAAcN,EAAaO,WAC/BnqE,EAAMs9B,YACN,SAEF4sC,EAAYhJ,cAAcC,EAAYC,GACtC8I,EAAYvJ,UAAUt8D,EAAU+qC,EACjC,MAAUkyB,GAAaA,EAAUwD,YAChC1D,EAAyB,CAAA,EAG9B,CACD,MAAM8I,EAAcH,EAAkBI,WACpCnqE,EAAMs9B,YACN,SAEF4sC,EAAYhJ,cAAcC,EAAYC,GACtC8I,EAAYvJ,UAAUt8D,EAAU+qC,EACjC,CACD,GAAIkyB,GAAaA,EAAUwD,UAAW,CACpC,IAAIsF,EAAmBR,EACnBC,IACFO,EAAmBP,GAErB,MAAMQ,EAAaD,EAAiBD,WAAWnqE,EAAMs9B,YAAa,QAClE+sC,EAAWhJ,aAAaC,EAAWF,GACnCiJ,EAAWtJ,SAAS18D,EAAU+qC,EAC/B,CACH,EA3WEk7B,WAsNF,SACEV,EACAvlE,EACArE,EACAovC,EACAy6B,GAEA,MAAM5I,EAAcjhE,EAAM6kE,YAC1B,GAAI5D,EAAa,CACf,MAAMsJ,EAAmBX,EAAaO,WACpCnqE,EAAMs9B,YACN,cAEFitC,EAAiBvJ,mBAAmB,KAAMC,GAC1CsJ,EAAiBpK,eAAe97D,EAAU+qC,EAC3C,CACD,MAAMkyB,EAAYthE,EAAM8kE,UACxB,GAAIxD,GAAaA,EAAUwD,UAAW,CACpC,MAAMuF,GAAcR,GAAyBD,GAAcO,WACzDnqE,EAAMs9B,YACN,QAEF+sC,EAAWhJ,aAAaC,GACxB+I,EAAWtJ,SAAS18D,EAAU+qC,EAC/B,CACH,EA9OE1pB,QA6aF,SACEkkD,EACAvlE,EACArE,EACAovC,EACAy6B,GAEA,MAAMt9C,EAAYvsB,EAAM4kE,UAClB3D,EAAcjhE,EAAM6kE,YAC1B,GAAIt4C,GAAa00C,EAAa,CAC5B,MAAMuJ,EAAgBZ,EAAaO,WAAWnqE,EAAMs9B,YAAa,WACjEktC,EAAcxJ,mBAAmBz0C,EAAW00C,GAC5CuJ,EAAc3J,YAAYx8D,EAAU+qC,EACrC,CACD,MAAMkyB,EAAYthE,EAAM8kE,UACxB,GAAIxD,GAAaA,EAAUwD,UAAW,CACpC,MAAMuF,GAAcR,GAAyBD,GAAcO,WACzDnqE,EAAMs9B,YACN,QAEF+sC,EAAWhJ,aAAaC,GACxB+I,EAAWtJ,SAAS18D,EAAU+qC,EAC/B,CACH,EAncEq7B,WAkXF,SACEb,EACAvlE,EACArE,EACAovC,EACAy6B,GAEA,MAAM1I,EAAanhE,EAAMirB,WACnBq2C,EAAYthE,EAAM8kE,UAExB,IAAI1D,EACJ,GAAID,EAAY,CACd,GAAIA,EAAW2I,iBAAmBjgD,GAChC,OAEF,IAAIkgD,EAAoBH,EACxB,GAAIC,EAAuB,CACzB,MAAMG,EAAgB7I,EAAW8I,mBACjC,GAAsB,SAAlBD,EAEF,GADAD,EAAoBF,EACE,aAAlBG,EAA8B,CAEhC,MAAME,EAAcN,EAAaO,WAC/BnqE,EAAMs9B,YACN,SAEF4sC,EAAYhJ,cAAcC,EAAYC,GACtC8I,EAAY3J,eAAel8D,EAAU+qC,EACtC,MAAUkyB,GAAaA,EAAUwD,YAChC1D,EAAyB,CAAA,EAG9B,CACD,MAAM8I,EAAcH,EAAkBI,WACpCnqE,EAAMs9B,YACN,SAEF4sC,EAAYhJ,cAAcC,EAAYC,GACtC8I,EAAY3J,eAAel8D,EAAU+qC,EACtC,CACD,GAAIkyB,GAAaA,EAAUwD,UAAW,CACpC,IAAIsF,EAAmBR,EACnBC,IACFO,EAAmBP,GAErB,MAAMQ,EAAaD,EAAiBD,WAAWnqE,EAAMs9B,YAAa,QAClE+sC,EAAWhJ,aAAaC,EAAWF,GACnCiJ,EAAWtJ,SAAS18D,EAAU+qC,EAC/B,CACH,EAlaEs7B,gBAqPF,SACEd,EACAvlE,EACArE,EACAovC,EACAy6B,GAEA,MAAM5I,EAAcjhE,EAAM6kE,YAC1B,GAAI5D,EAAa,CACf,MAAMsJ,EAAmBX,EAAaO,WACpCnqE,EAAMs9B,YACN,cAEFitC,EAAiBvJ,mBAAmB,KAAMC,GAC1CsJ,EAAiBlK,oBAAoBh8D,EAAU+qC,EAChD,CACD,MAAMkyB,EAAYthE,EAAM8kE,UACxB,GAAIxD,GAAaA,EAAUwD,UAAW,CACpC,MAAMuF,GAAcR,GAAyBD,GAAcO,WACzDnqE,EAAMs9B,YACN,QAEF+sC,EAAWhJ,aAAaC,GACxB+I,EAAWtJ,SAAS18D,EAAU+qC,EAC/B,CACH,EA7QEu7B,aAsRF,SACEf,EACAvlE,EACArE,EACAovC,EACAy6B,GAEA,MAAMt9C,EAAYvsB,EAAM4kE,UAClB3D,EAAcjhE,EAAM6kE,YAC1B,GAAI5D,GAAe10C,EAAW,CAC5B,MAAMi+C,EAAgBZ,EAAaO,WAAWnqE,EAAMs9B,YAAa,WACjEktC,EAAcxJ,mBAAmBz0C,EAAW00C,GAC5CuJ,EAAc/J,iBAAiBp8D,EAAU+qC,EAC1C,CACD,MAAMkyB,EAAYthE,EAAM8kE,UACxB,GAAIxD,GAAaA,EAAUwD,UAAW,CACpC,MAAMuF,GAAcR,GAAyBD,GAAcO,WACzDnqE,EAAMs9B,YACN,QAEF+sC,EAAWhJ,aAAaC,GACxB+I,EAAWtJ,SAAS18D,EAAU+qC,EAC/B,CACH,EA5SEw7B,mBAqLF,SACEC,EACAxmE,EACArE,EACAovC,EACAy6B,GAEA,MAAM5E,EAAa5gE,EAAS6gE,qBAC5B,IAAI7zE,EAAGuE,EACP,IAAKvE,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAAG,EAE/Cy5E,EADyBnB,GAAmB1E,EAAW5zE,GAAG8sB,YAExD0sD,EACA5F,EAAW5zE,GACX2O,EACAovC,EACAy6B,EAEH,CACH,EAvMEkB,OAsCF,SACEnB,EACAvlE,EACArE,EACAovC,EACAy6B,GAEA,MAAMt9C,EAAYvsB,EAAM4kE,UAClB3D,EAAcjhE,EAAM6kE,YAC1B,GAAIt4C,GAAa00C,EAAa,CAC5B,MAAM+J,EAAepB,EAAaO,WAAWnqE,EAAMs9B,YAAa,UAChE0tC,EAAahK,mBAAmBz0C,EAAW00C,GAC3C+J,EAAalL,WAAWz7D,EAAU+qC,EACnC,CACD,MAAMkyB,EAAYthE,EAAM8kE,UACxB,GAAIxD,GAAaA,EAAUwD,UAAW,CACpC,MAAMuF,GAAcR,GAAyBD,GAAcO,WACzDnqE,EAAMs9B,YACN,QAEF+sC,EAAWhJ,aAAaC,GACxB+I,EAAWtJ,SAAS18D,EAAU+qC,EAC/B,CACH,GArDO,SAAS67B,GAAaC,EAAUC,GACrC,OAAOjrE,SAAS/H,EAAO+yE,GAAW,IAAMhrE,SAAS/H,EAAOgzE,GAAW,GACrE,CAOO,SAASC,GAAoBh/D,EAAYye,GAC9C,MAAMjgB,EAAYygE,GAAaj/D,EAAYye,GAC3C,OAAOjgB,EAAYA,CACrB,CAOO,SAASygE,GAAaj/D,EAAYye,GACvC,OAAQ6+C,GAAqBt9D,EAAcye,CAC7C,CA4CO,SAASygD,GACdT,EACAz7B,EACApvC,EACAud,EACAvoB,EACAyQ,EACAokE,GAEA,IAAIhW,GAAU,EACd,MAAMsN,EAAanhE,EAAMirB,WACzB,GAAIk2C,EAAY,CACd,MAAMoK,EAAapK,EAAW2I,gBAC1ByB,GAAc1hD,IAAqB0hD,GAAc1hD,GACnDs3C,EAAWqK,oBAAoBx2E,IAE3Bu2E,GAAc1hD,IAChBs3C,EAAWpkE,OAEbokE,EAAWsK,kBAAkBz2E,GAC7B6+D,GAAU,EAEb,CAUD,OAWF,SACEgX,EACAz7B,EACApvC,EACAud,EACA9X,EACAokE,GAEA,MAAMxlE,EAAWrE,EAAMglE,qBAANhlE,CAA4BovC,GAC7C,IAAK/qC,EACH,OAEF,MAAMmb,EAAqBnb,EAASoZ,oBAClCF,EACA9X,GAEIkuD,EAAW3zD,EAAM6tC,cACvB,GAAI8lB,EACF+X,GAAeb,EAAarrD,EAAoBxf,EAAOovC,OAClD,EAEL07B,EADyBnB,GAAmBnqD,EAAmBrB,YAE7D0sD,EACArrD,EACAxf,EACAovC,EACAy6B,EAEH,CACH,CAjDE8B,CACEd,EACAz7B,EACApvC,EACAud,EACA9X,EACAokE,GAGKhW,CACT,CA+CA,SAAS6X,GAAeb,EAAaxmE,EAAUrE,EAAOovC,GACpD,GAA0B,sBAAtB/qC,EAAS8Z,UAAmC,CAC9C,MAAM8mD,EAC2D,EAE7D2G,gBACJ,IAAK,IAAIv6E,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAChDq6E,GAAeb,EAAa5F,EAAW5zE,GAAI2O,EAAOovC,GAEpD,MACD,CACcy7B,EAAYV,WAAWnqE,EAAMs9B,YAAa,WAClDqiC,WACT,EACIvwB,EACApvC,EAAM6tC,cACN7tC,EAAM6rE,0BAEV,CCnHO,SAASC,GAAiBx2E,GAC/B,KAAMA,EAAMsK,mBAAmBmsE,0BAC7B,MAAM,IAAI9zE,MAAM,sDAIlB,MAAMnH,EAAIwE,EAAM86C,sBAAsB,GAChCr/C,EAAIuE,EAAM86C,sBAAsB,GAChC47B,EAAmBtwE,KAAKma,KAAK/kB,EAAIA,EAAIC,EAAIA,GACzCm8C,EAAa53C,EAAM43C,WACnBznC,EAAYwmE,GAChB32E,EAAM86C,sBAAsB78C,QAC5B25C,EAAW2B,4BAEPtxB,EAAmB6tD,GACvBl+B,EAAWjE,UAAU78B,WACrB4/D,GAEF,IAAItK,EACJ,MAAMlmD,EAAiBE,KAQvB,OAPIF,IACFkmD,EAAgB/nD,GACd6B,EACA0xB,EAAWjE,UAAUr6B,aAIlB,IAAIs9D,GACT52E,EAAMsK,QACNosE,EACA9+B,EAAWjkC,OACXxD,EACAynC,EAAWjE,UAAU58B,SACrBkR,EACAmkD,EAEJ,CC/GA,IAAIyK,GAKG,MAAM/sE,GAAa,GAY1B,SAASgtE,GAAiB9/C,EAAK+/C,EAAIl3D,EAAIm3D,EAAIl3D,GACzCkX,EAAIk4C,YACJl4C,EAAI83C,OAAO,EAAG,GACd93C,EAAI+3C,OAAOgI,EAAIl3D,GACfmX,EAAI+3C,OAAOiI,EAAIl3D,GACfkX,EAAIg4C,YACJh4C,EAAI4oB,OACJ5oB,EAAIigD,OACJjgD,EAAIE,SAAS,EAAG,EAAG9wB,KAAKyP,IAAIkhE,EAAIC,GAAM,EAAG5wE,KAAKyP,IAAIgK,EAAIC,IACtDkX,EAAIipB,SACN,CAUA,SAASi3B,GAA8B56E,EAAM4Y,GAE3C,OACE9O,KAAKmP,IAAIjZ,EAAc,EAAT4Y,GAAc,KAAO,GACnC9O,KAAKmP,IAAIjZ,EAAc,EAAT4Y,EAAa,GAAK,QAAc,CAElD,CA2CO,SAASiiE,GACd3xD,EACA4xD,EACAjqC,EACAG,GAEA,MAAMJ,EAAe/8B,GAAUg9B,EAAciqC,EAAY5xD,GAGzD,IAAI6nB,EAAmBlyB,GACrBi8D,EACA9pC,EACAH,GAGF,MAAMkqC,EAAsBD,EAAW37D,wBACX9a,IAAxB02E,IACFhqC,GAAoBgqC,GAEtB,MAAM1wD,EAAsBnB,EAAW/J,wBACX9a,IAAxBgmB,IACF0mB,GAAoB1mB,GAOtB,MAAMO,EAAe1B,EAAWhM,YAChC,IAAK0N,GAAgBjT,GAAmBiT,EAAcgmB,GAAe,CACnE,MAAMoqC,EACJn8D,GAAmBqK,EAAY6nB,EAAkBH,GACjDG,EACExzB,SAASy9D,IAAuBA,EAAqB,IACvDjqC,GAAoBiqC,EAEvB,CAED,OAAOjqC,CACT,CAcO,SAASkqC,GACd/xD,EACA4xD,EACAI,EACAlqC,GAEA,MAAMH,EAAe12B,GAAU+gE,GAC/B,IAAInqC,EAAmB8pC,GACrB3xD,EACA4xD,EACAjqC,EACAG,GAeF,QAZKzzB,SAASwzB,IAAqBA,GAAoB,IACrDv3B,GAAc0hE,GAAc,SAAU7gE,GAOpC,OANA02B,EAAmB8pC,GACjB3xD,EACA4xD,EACAzgE,EACA22B,GAEKzzB,SAASwzB,IAAqBA,EAAmB,CAC9D,IAGSA,CACT,CA0BO,SAAS4J,GACdrtC,EACAC,EACA0rB,EACA8X,EACAnmB,EACAomB,EACAkqC,EACAC,EACAC,EACAC,EACAC,EACA5wE,EACA6wE,GAEA,MAAMvtE,EAAUX,GACdvD,KAAKiZ,MAAMkW,EAAa3rB,GACxBxD,KAAKiZ,MAAMkW,EAAa1rB,GACxBC,IAOF,GAJK9C,IACHsD,EAAQwtE,uBAAwB,GAGX,IAAnBJ,EAAQp8E,OACV,OAAOgP,EAAQN,OAKjB,SAAS+tE,EAAWv5E,GAClB,OAAO4H,KAAKiZ,MAAM7gB,EAAQ+2B,GAAcA,CACzC,CAJDjrB,EAAQwH,MAAMyjB,EAAYA,GAM1BjrB,EAAQ0tE,yBAA2B,UAEnC,MAAMC,E/GlDC,CAACrjE,IAAUA,KAAU,KAAW,K+GuDvC,IAAIsjE,EACJ,GALAR,EAAQpyE,SAAQ,SAAU0vB,EAAKj5B,EAAGH,GAChCS,GAAO47E,EAAkBjjD,EAAIrhB,OACjC,KAGOkkE,GAAiC,IAAnBH,EAAQp8E,QAA2B,IAAXq8E,EAAc,CACvD,MAAMQ,EAAqB5hE,GAAS0hE,GAC9BG,EAAsB5hE,GAAUyhE,GACtCC,EAAgBvuE,GACdvD,KAAKiZ,MAAOkW,EAAa4iD,EAAsB9qC,GAC/CjnC,KAAKiZ,MAAOkW,EAAa6iD,EAAuB/qC,GAChDvjC,IAGG9C,IACHkxE,EAAcJ,uBAAwB,GAGxC,MAAMO,EAAc9iD,EAAa8X,EAEjCqqC,EAAQpyE,SAAQ,SAAU0vB,EAAKj5B,EAAGH,GAChC,MAAM08E,EAAOtjD,EAAIrhB,OAAO,GAAKskE,EAAiB,GACxCM,IAASvjD,EAAIrhB,OAAO,GAAKskE,EAAiB,IAC1CO,EAAWjiE,GAASye,EAAIrhB,QACxB8kE,EAAYjiE,GAAUwe,EAAIrhB,QAG5BqhB,EAAI/nB,MAAMrD,MAAQ,GAAKorB,EAAI/nB,MAAMpD,OAAS,GAC5CquE,EAAc/qE,UACZ6nB,EAAI/nB,MACJ0qE,EACAA,EACA3iD,EAAI/nB,MAAMrD,MAAQ,EAAI+tE,EACtB3iD,EAAI/nB,MAAMpD,OAAS,EAAI8tE,EACvBW,EAAOD,EACPE,EAAOF,EACPG,EAAWH,EACXI,EAAYJ,EAGtB,GACG,CACD,MAAMK,EAAgBtiE,GAAWohE,GAwKjC,OAtKAC,EAAckB,eAAerzE,SAAQ,SAAUszE,EAAU78E,EAAGH,GAqB1D,MAAMyI,EAASu0E,EAASv0E,OAClB/J,EAASs+E,EAASt+E,OACxB,IAAI0c,EAAK3S,EAAO,GAAG,GACjB4S,EAAK5S,EAAO,GAAG,GACb6S,EAAK7S,EAAO,GAAG,GACjB8S,EAAK9S,EAAO,GAAG,GACb+S,EAAK/S,EAAO,GAAG,GACjBgT,EAAKhT,EAAO,GAAG,GAEjB,MAAMw0E,EAAKd,GAAYz9E,EAAO,GAAG,GAAKo+E,EAAc,IAAMprC,GACpDwrC,EAAKf,IACPz9E,EAAO,GAAG,GAAKo+E,EAAc,IAAMprC,GAEjCypC,EAAKgB,GAAYz9E,EAAO,GAAG,GAAKo+E,EAAc,IAAMprC,GACpDztB,EAAKk4D,IACPz9E,EAAO,GAAG,GAAKo+E,EAAc,IAAMprC,GAEjC0pC,EAAKe,GAAYz9E,EAAO,GAAG,GAAKo+E,EAAc,IAAMprC,GACpDxtB,EAAKi4D,IACPz9E,EAAO,GAAG,GAAKo+E,EAAc,IAAMprC,GAMjCyrC,EAAwB/hE,EACxBgiE,EAAwB/hE,EAC9BD,EAAK,EACLC,EAAK,EACLC,GAAM6hE,EACN5hE,GAAM6hE,EACN5hE,GAAM2hE,EACN1hE,GAAM2hE,EAEN,MAMMC,EAAc76D,GANI,CACtB,CAAClH,EAAIC,EAAI,EAAG,EAAG4/D,EAAK8B,GACpB,CAACzhE,EAAIC,EAAI,EAAG,EAAG2/D,EAAK6B,GACpB,CAAC,EAAG,EAAG3hE,EAAIC,EAAI0I,EAAKi5D,GACpB,CAAC,EAAG,EAAG1hE,EAAIC,EAAIyI,EAAKg5D,KAGtB,IAAKG,EACH,OAMF,GAHA3uE,EAAQs1C,OACRt1C,EAAQ4kE,YA9RZ,WACE,QAAiCvuE,IAA7Bk2E,GAAwC,CAC1C,MAAM7/C,EAAMrtB,GAAsB,EAAG,EAAGG,IACxCktB,EAAIghD,yBAA2B,UAC/BhhD,EAAIC,UAAY,wBAChB6/C,GAAiB9/C,EAAK,EAAG,EAAG,EAAG,GAC/B8/C,GAAiB9/C,EAAK,EAAG,EAAG,EAAG,GAC/B,MAAM16B,EAAO06B,EAAI5pB,aAAa,EAAG,EAAG,EAAG,GAAG9Q,KAC1Cu6E,GACEK,GAA8B56E,EAAM,IACpC46E,GAA8B56E,EAAM,IACpC46E,GAA8B56E,EAAM,GACtC+N,GAAc2sB,GACdltB,GAAWhK,KAAKk3B,EAAIhtB,OACrB,CAED,OAAO6sE,EACT,CA+QQqC,KAAgClyE,EAAa,CAE/CsD,EAAQwkE,OAAOiI,EAAIl3D,GAEnB,MAAMs5D,EAAQ,EACRC,EAAKP,EAAK9B,EACVsC,EAAKP,EAAKj5D,EAChB,IAAK,IAAIy5D,EAAO,EAAGA,EAAOH,EAAOG,IAE/BhvE,EAAQykE,OACNgI,EAAKgB,GAAauB,EAAO,GAAKF,EAAMD,GACpCt5D,EAAKk4D,EAAYuB,EAAOD,GAAOF,EAAQ,KAGrCG,GAAQH,EAAQ,GAClB7uE,EAAQykE,OACNgI,EAAKgB,GAAauB,EAAO,GAAKF,EAAMD,GACpCt5D,EAAKk4D,GAAauB,EAAO,GAAKD,GAAOF,EAAQ,KAKnD7uE,EAAQykE,OAAOiI,EAAIl3D,EACzB,MACMxV,EAAQwkE,OAAOiI,EAAIl3D,GACnBvV,EAAQykE,OAAO8J,EAAIC,GACnBxuE,EAAQykE,OAAOiI,EAAIl3D,GAmBrB,IAAI7S,EACJ,GAjBA3C,EAAQ2sE,OAER3sE,EAAQ6F,UACN8oE,EAAY,GACZA,EAAY,GACZA,EAAY,GACZA,EAAY,GACZJ,EACAC,GAGFxuE,EAAQ0H,UACNimE,EAAiB,GAAKc,EACtBd,EAAiB,GAAKe,GAIpBd,EACFjrE,EAAQirE,EAAcluE,OACtBM,EAAQwH,MACNu7B,EAAmB9X,GAClB8X,EAAmB9X,OAEjB,CACL,MAAMlxB,EAASqzE,EAAQ,GACjB/jE,EAAStP,EAAOsP,OACtB1G,EAAQ5I,EAAO4I,MACf3C,EAAQwH,MACNyE,GAAS5C,GAAU1G,EAAMrD,OACxB4M,GAAU7C,GAAU1G,EAAMpD,OAE9B,CAEDS,EAAQ6C,UAAUF,EAAO,EAAG,GAC5B3C,EAAQ21C,SACZ,IAEMi4B,IACF7tE,GAAc6tE,GACdpuE,GAAWhK,KAAKo4E,EAAcluE,SAG5B4tE,IACFttE,EAAQs1C,OAERt1C,EAAQ0tE,yBAA2B,cACnC1tE,EAAQqhE,YAAc,QACtBrhE,EAAQ+0C,UAAY,EAEpBo4B,EAAckB,eAAerzE,SAAQ,SAAUszE,EAAU78E,EAAGH,GAC1D,MAAMtB,EAASs+E,EAASt+E,OAClBu+E,GAAMv+E,EAAO,GAAG,GAAKo+E,EAAc,IAAMprC,EACzCwrC,IAAOx+E,EAAO,GAAG,GAAKo+E,EAAc,IAAMprC,EAC1CypC,GAAMz8E,EAAO,GAAG,GAAKo+E,EAAc,IAAMprC,EACzCztB,IAAOvlB,EAAO,GAAG,GAAKo+E,EAAc,IAAMprC,EAC1C0pC,GAAM18E,EAAO,GAAG,GAAKo+E,EAAc,IAAMprC,EACzCxtB,IAAOxlB,EAAO,GAAG,GAAKo+E,EAAc,IAAMprC,EAEhDhjC,EAAQ4kE,YACR5kE,EAAQwkE,OAAOiI,EAAIl3D,GACnBvV,EAAQykE,OAAO8J,EAAIC,GACnBxuE,EAAQykE,OAAOiI,EAAIl3D,GACnBxV,EAAQ0kE,YACR1kE,EAAQ+kE,QACd,IAEI/kE,EAAQ21C,WAEH31C,EAAQN,MACjB,CC9bO,SAASuvE,GAAmBziE,GACjC,OAAIta,MAAMC,QAAQqa,GACT1Q,KAAKwP,OAAOkB,GAEdA,CACT,CCRO,MAAM0iE,GAAkB,GC4e/B,IAAAC,GApcA,MASE,WAAAx/E,CACEurB,EACA4xD,EACAI,EACAkC,EACAC,EACAC,GAMAz/E,KAAK0/E,YAAcr0D,EAMnBrrB,KAAK2/E,YAAc1C,EAGnB,IAAI2C,EAAoB,CAAA,EACxB,MAAMC,EAAeh0D,GAAa7rB,KAAK2/E,YAAa3/E,KAAK0/E,aAOzD1/E,KAAK8/E,cAAgB,SAAU9oE,GAC7B,MAAMzP,EAAMyP,EAAE,GAAK,IAAMA,EAAE,GAI3B,OAHK4oE,EAAkBr4E,KACrBq4E,EAAkBr4E,GAAOs4E,EAAa7oE,IAEjC4oE,EAAkBr4E,EAC/B,EAMIvH,KAAK+/E,iBAAmBR,EAMxBv/E,KAAKggF,uBAAyBR,EAAiBA,EAM/Cx/E,KAAKigF,WAAa,GAOlBjgF,KAAKkgF,iBAAkB,EAMvBlgF,KAAKmgF,kBACHngF,KAAK0/E,YAAYpgE,cACfigE,KACAv/E,KAAK0/E,YAAYrgE,aACnBjD,GAASmjE,IAAoBnjE,GAASpc,KAAK0/E,YAAYrgE,aAMzDrf,KAAKogF,kBAAoBpgF,KAAK0/E,YAAYrgE,YACtCjD,GAASpc,KAAK0/E,YAAYrgE,aAC1B,KAMJrf,KAAKqgF,kBAAoBrgF,KAAK2/E,YAAYtgE,YACtCjD,GAASpc,KAAK2/E,YAAYtgE,aAC1B,KAEJ,MAAMihE,EAAqBrkE,GAAWohE,GAChCkD,EAAsBvkE,GAAYqhE,GAClCmD,EAAyBzkE,GAAeshE,GACxCoD,EAAwB3kE,GAAcuhE,GACtCqD,EAAgB1gF,KAAK8/E,cAAcQ,GACnCK,EAAiB3gF,KAAK8/E,cAAcS,GACpCK,EAAoB5gF,KAAK8/E,cAAcU,GACvCK,EAAmB7gF,KAAK8/E,cAAcW,GAYtCK,EArIc,IAuIjBrB,EACGxzE,KAAKyP,IACH,EACAzP,KAAKkZ,KACHlZ,KAAK80E,KACH7kE,GAAQmhE,IACLoC,EAAwBA,EAAwB,IAAM,QAI/D,GAcN,GAZAz/E,KAAKghF,SACHV,EACAC,EACAC,EACAC,EACAC,EACAC,EACAC,EACAC,EACAC,GAGE9gF,KAAKkgF,gBAAiB,CACxB,IAAIe,EAAYxmE,IAChBza,KAAKigF,WAAW90E,SAAQ,SAAUszE,EAAU78E,EAAGH,GAC7Cw/E,EAAYh1E,KAAKwP,IACfwlE,EACAxC,EAASv0E,OAAO,GAAG,GACnBu0E,EAASv0E,OAAO,GAAG,GACnBu0E,EAASv0E,OAAO,GAAG,GAE7B,IAIMlK,KAAKigF,WAAW90E,SAASszE,IACvB,GACExyE,KAAKyP,IACH+iE,EAASv0E,OAAO,GAAG,GACnBu0E,EAASv0E,OAAO,GAAG,GACnBu0E,EAASv0E,OAAO,GAAG,IAEnB+2E,EACFjhF,KAAKogF,kBAAoB,EACzB,CACA,MAAMc,EAAc,CAClB,CAACzC,EAASv0E,OAAO,GAAG,GAAIu0E,EAASv0E,OAAO,GAAG,IAC3C,CAACu0E,EAASv0E,OAAO,GAAG,GAAIu0E,EAASv0E,OAAO,GAAG,IAC3C,CAACu0E,EAASv0E,OAAO,GAAG,GAAIu0E,EAASv0E,OAAO,GAAG,KAEzCg3E,EAAY,GAAG,GAAKD,EAAYjhF,KAAKogF,kBAAoB,IAC3Dc,EAAY,GAAG,IAAMlhF,KAAKogF,mBAExBc,EAAY,GAAG,GAAKD,EAAYjhF,KAAKogF,kBAAoB,IAC3Dc,EAAY,GAAG,IAAMlhF,KAAKogF,mBAExBc,EAAY,GAAG,GAAKD,EAAYjhF,KAAKogF,kBAAoB,IAC3Dc,EAAY,GAAG,IAAMlhF,KAAKogF,mBAM5B,MAAMhmE,EAAOnO,KAAKwP,IAChBylE,EAAY,GAAG,GACfA,EAAY,GAAG,GACfA,EAAY,GAAG,IAEJj1E,KAAKyP,IAChBwlE,EAAY,GAAG,GACfA,EAAY,GAAG,GACfA,EAAY,GAAG,IAEN9mE,EAAOpa,KAAKogF,kBAAoB,IACzC3B,EAASv0E,OAASg3E,EAErB,IAEJ,CAEDtB,EAAoB,CAAA,CACrB,CAYD,YAAAuB,CAAa9/E,EAAGC,EAAG0V,EAAGoqE,EAAMC,EAAMC,GAChCthF,KAAKigF,WAAWt6E,KAAK,CACnBuE,OAAQ,CAACk3E,EAAMC,EAAMC,GACrBnhF,OAAQ,CAACkB,EAAGC,EAAG0V,IAElB,CAkBD,QAAAgqE,CAAS3/E,EAAGC,EAAG0V,EAAGC,EAAGmqE,EAAMC,EAAMC,EAAMC,EAAMT,GAC3C,MAAMU,EAAmBloE,GAAe,CAAC8nE,EAAMC,EAAMC,EAAMC,IACrDE,EAAkBzhF,KAAKogF,kBACzBhkE,GAASolE,GAAoBxhF,KAAKogF,kBAClC,KACEsB,EAA0C1hF,KAAsB,kBAIhE2hF,EACJ3hF,KAAK0/E,YAAYpgE,YACjBmiE,EAAkB,IAClBA,EAAkB,EAEpB,IAAIG,GAAmB,EAEvB,GAAId,EAAiB,EAAG,CACtB,GAAI9gF,KAAK2/E,YAAYl+D,YAAczhB,KAAKqgF,kBAAmB,CAIzDuB,EADExlE,GAFuB9C,GAAe,CAACjY,EAAGC,EAAG0V,EAAGC,KAEnBjX,KAAKqgF,kBAvQjB,KAyQuBuB,CAC3C,EACID,GAAU3hF,KAAK0/E,YAAYj+D,YAAcggE,IAC5CG,EACEH,EA7QiB,KA6QuBG,EAE7C,CAED,IAAKA,GAAoB5hF,KAAK+/E,kBAE1BrgE,SAAS8hE,EAAiB,KAC1B9hE,SAAS8hE,EAAiB,KAC1B9hE,SAAS8hE,EAAiB,KAC1B9hE,SAAS8hE,EAAiB,MAErB1jE,GAAW0jE,EAAkBxhF,KAAK+/E,kBAErC,OAKN,IAAI8B,EAAc,EAElB,KAAKD,GAEAliE,SAAS0hE,EAAK,KACd1hE,SAAS0hE,EAAK,KACd1hE,SAAS2hE,EAAK,KACd3hE,SAAS2hE,EAAK,KACd3hE,SAAS4hE,EAAK,KACd5hE,SAAS4hE,EAAK,KACd5hE,SAAS6hE,EAAK,KACd7hE,SAAS6hE,EAAK,KAEf,GAAIT,EAAiB,EACnBc,GAAmB,OASnB,GALAC,GACIniE,SAAS0hE,EAAK,KAAQ1hE,SAAS0hE,EAAK,IAAU,EAAJ,IAC1C1hE,SAAS2hE,EAAK,KAAQ3hE,SAAS2hE,EAAK,IAAU,EAAJ,IAC1C3hE,SAAS4hE,EAAK,KAAQ5hE,SAAS4hE,EAAK,IAAU,EAAJ,IAC1C5hE,SAAS6hE,EAAK,KAAQ7hE,SAAS6hE,EAAK,IAAU,EAAJ,GAE7B,GAAfM,GACe,GAAfA,GACe,GAAfA,GACe,GAAfA,EAEA,OAMR,GAAIf,EAAiB,EAAG,CACtB,IAAKc,EAAkB,CACrB,MAAMllE,EAAS,EAAErb,EAAE,GAAK2V,EAAE,IAAM,GAAI3V,EAAE,GAAK2V,EAAE,IAAM,GAC7C8qE,EAAY9hF,KAAK8/E,cAAcpjE,GAErC,IAAI5E,EACJ,GAAI6pE,EAAQ,CAKV7pE,GAHG+M,GAAOu8D,EAAK,GAAIM,GACf78D,GAAOy8D,EAAK,GAAII,IAClB,EACqB78D,GAAOi9D,EAAU,GAAIJ,EACtD,MACU5pE,GAAMspE,EAAK,GAAKE,EAAK,IAAM,EAAIQ,EAAU,GAE3C,MAAM/pE,GAAMqpE,EAAK,GAAKE,EAAK,IAAM,EAAIQ,EAAU,GAE/CF,EAD8B9pE,EAAKA,EAAKC,EAAKA,EACF/X,KAAKggF,sBACjD,CACD,GAAI4B,EAAkB,CACpB,GAAI31E,KAAKmP,IAAI/Z,EAAE,GAAK2V,EAAE,KAAO/K,KAAKmP,IAAI/Z,EAAE,GAAK2V,EAAE,IAAK,CAElD,MAAM+qE,EAAK,EAAEzgF,EAAE,GAAK0V,EAAE,IAAM,GAAI1V,EAAE,GAAK0V,EAAE,IAAM,GACzCgrE,EAAQhiF,KAAK8/E,cAAciC,GAC3BE,EAAK,EAAEhrE,EAAE,GAAK5V,EAAE,IAAM,GAAI4V,EAAE,GAAK5V,EAAE,IAAM,GACzC6gF,EAAQliF,KAAK8/E,cAAcmC,GAEjCjiF,KAAKghF,SACH3/E,EACAC,EACAygF,EACAE,EACAb,EACAC,EACAW,EACAE,EACApB,EAAiB,GAEnB9gF,KAAKghF,SACHiB,EACAF,EACA/qE,EACAC,EACAirE,EACAF,EACAV,EACAC,EACAT,EAAiB,EAE7B,KAAe,CAEL,MAAMqB,EAAK,EAAE9gF,EAAE,GAAKC,EAAE,IAAM,GAAID,EAAE,GAAKC,EAAE,IAAM,GACzC8gF,EAAQpiF,KAAK8/E,cAAcqC,GAC3BE,EAAK,EAAErrE,EAAE,GAAKC,EAAE,IAAM,GAAID,EAAE,GAAKC,EAAE,IAAM,GACzCqrE,EAAQtiF,KAAK8/E,cAAcuC,GAEjCriF,KAAKghF,SACH3/E,EACA8gF,EACAE,EACAprE,EACAmqE,EACAgB,EACAE,EACAf,EACAT,EAAiB,GAEnB9gF,KAAKghF,SACHmB,EACA7gF,EACA0V,EACAqrE,EACAD,EACAf,EACAC,EACAgB,EACAxB,EAAiB,EAEpB,CACD,MACD,CACF,CAED,GAAIa,EAAQ,CACV,IAAK3hF,KAAKmgF,kBACR,OAEFngF,KAAKkgF,iBAAkB,CACxB,CAM0B,IAAR,GAAd2B,IACH7hF,KAAKmhF,aAAa9/E,EAAG2V,EAAGC,EAAGmqE,EAAME,EAAMC,GAEd,IAAR,GAAdM,IACH7hF,KAAKmhF,aAAa9/E,EAAG2V,EAAG1V,EAAG8/E,EAAME,EAAMD,GAErCQ,IAEyB,IAAR,GAAdA,IACH7hF,KAAKmhF,aAAa7/E,EAAG2V,EAAG5V,EAAGggF,EAAME,EAAMH,GAEd,IAAR,EAAdS,IACH7hF,KAAKmhF,aAAa7/E,EAAG2V,EAAGD,EAAGqqE,EAAME,EAAMD,GAG5C,CAOD,qBAAAiB,GACE,MAAM/oE,ElH7RD,CAACiB,IAAUA,KAAU,KAAW,KkHsSrC,OAPAza,KAAKigF,WAAW90E,SAAQ,SAAUszE,EAAU78E,EAAGH,GAC7C,MAAMo5B,EAAM4jD,EAASv0E,OACrBwP,GAAiBF,EAAQqhB,EAAI,IAC7BnhB,GAAiBF,EAAQqhB,EAAI,IAC7BnhB,GAAiBF,EAAQqhB,EAAI,GACnC,IAEWrhB,CACR,CAKD,YAAAglE,GACE,OAAOx+E,KAAKigF,UACb,GCvIH,IAAAuC,GA9UA,cAAyBpvE,GAgBvB,WAAAtT,CACEurB,EACAo3D,EACAxF,EACAyF,EACAn2E,EACA6/D,EACAhxC,EACAoiD,EACAmF,EACAnD,EACA/B,EACA9yE,GAEA1F,MAAMsH,EAAWT,EAAgBnB,GAMjC3K,KAAK4iF,kBAA+Bp8E,IAAhBi3E,GAA4BA,EAMhDz9E,KAAKs7B,YAAcF,EAMnBp7B,KAAK6iF,QAAUrF,EAMfx9E,KAAKk8B,QAAU,KAMfl8B,KAAK8iF,gBAAkBL,EAMvBziF,KAAK+iF,gBAAkBL,EAMvB1iF,KAAKgjF,kBAAoB5W,GAAsC7/D,EAM/DvM,KAAKijF,aAAe,GAMpBjjF,KAAKkjF,qBAAuB,KAM5BljF,KAAKmjF,SAAW,EAEhB,MAAM9F,EAAeqF,EAAeU,mBAClCpjF,KAAKgjF,mBAEDK,EAAkBrjF,KAAK+iF,gBAAgB1jE,YAC7C,IAAIkgE,EAAkBv/E,KAAK8iF,gBAAgBzjE,YAE3C,MAAMikE,EAAsBD,EACxBzlE,GAAgBy/D,EAAcgG,GAC9BhG,EAEJ,GAAqC,IAAjCnhE,GAAQonE,GAIV,YADAtjF,KAAKwM,MAAQV,GAIf,MAAMy3E,EAAmBl4D,EAAWhM,YAChCkkE,IAIAhE,EAHGA,EAGe3hE,GAAgB2hE,EAAiBgE,GAFjCA,GAMtB,MAAMpwC,EAAmBuvC,EAAehnD,cACtC17B,KAAKgjF,kBAAkB,IAGnB9vC,EAAmBkqC,GACvB/xD,EACA4xD,EACAqG,EACAnwC,GAGF,IAAKzzB,SAASwzB,IAAqBA,GAAoB,EAIrD,YADAlzC,KAAKwM,MAAQV,GAIf,MAAM03E,OACeh9E,IAAnBg5E,EAA+BA,EAAiBH,GAelD,GATAr/E,KAAKyjF,eAAiB,IAAIC,GACxBr4D,EACA4xD,EACAqG,EACA/D,EACArsC,EAAmBswC,EACnBrwC,GAGgD,IAA9CnzC,KAAKyjF,eAAejF,eAAer9E,OAGrC,YADAnB,KAAKwM,MAAQV,GAIf9L,KAAKmjF,SAAWV,EAAekB,kBAAkBzwC,GACjD,IAAInmB,EAAe/sB,KAAKyjF,eAAelB,wBAmBvC,GAjBIhD,IACEl0D,EAAW/L,YACbyN,EAAa,GAAKjJ,GAChBiJ,EAAa,GACbwyD,EAAgB,GAChBA,EAAgB,IAElBxyD,EAAa,GAAKjJ,GAChBiJ,EAAa,GACbwyD,EAAgB,GAChBA,EAAgB,KAGlBxyD,EAAenP,GAAgBmP,EAAcwyD,IAI5CrjE,GAAQ6Q,GAEN,CACL,MAAM62D,EAAcnB,EAAeoB,0BACjC92D,EACA/sB,KAAKmjF,UAGP,IAAK,IAAIW,EAAOF,EAAYxpE,KAAM0pE,GAAQF,EAAYtpE,KAAMwpE,IAC1D,IAAK,IAAIC,EAAOH,EAAYvpE,KAAM0pE,GAAQH,EAAYrpE,KAAMwpE,IAAQ,CAClE,MAAM72E,EAAOy1E,EAAgB3iF,KAAKmjF,SAAUW,EAAMC,EAAM3oD,GACpDluB,GACFlN,KAAKijF,aAAat9E,KAAKuH,EAE1B,CAG8B,IAA7BlN,KAAKijF,aAAa9hF,SACpBnB,KAAKwM,MAAQV,EAEhB,MAnBC9L,KAAKwM,MAAQV,CAoBhB,CAMD,QAAA0vB,GACE,OAAOx7B,KAAKk8B,OACb,CAKD,UAAA8nD,GACE,MAAMzG,EAAU,GAWhB,GAVAv9E,KAAKijF,aAAa93E,SAAS+B,IACrBA,GAAQA,EAAKC,YAAcrB,GAC7ByxE,EAAQ53E,KAAK,CACX6T,OAAQxZ,KAAK8iF,gBAAgBM,mBAAmBl2E,EAAKX,WACrDuG,MAAO5F,EAAKsuB,YAEf,IAEHx7B,KAAKijF,aAAa9hF,OAAS,EAEJ,IAAnBo8E,EAAQp8E,OACVnB,KAAKwM,MAAQV,MACR,CACL,MAAMyzB,EAAIv/B,KAAKgjF,kBAAkB,GAC3BtvE,EAAO1T,KAAK+iF,gBAAgBkB,YAAY1kD,GACxC9vB,EAAwB,iBAATiE,EAAoBA,EAAOA,EAAK,GAC/ChE,EAAyB,iBAATgE,EAAoBA,EAAOA,EAAK,GAChDy/B,EAAmBnzC,KAAK+iF,gBAAgBrnD,cAAc6D,GACtD2T,EAAmBlzC,KAAK8iF,gBAAgBpnD,cAC5C17B,KAAKmjF,UAGD9F,EAAer9E,KAAK+iF,gBAAgBK,mBACxCpjF,KAAKgjF,mBAGPhjF,KAAKk8B,QAAUgoD,GACbz0E,EACAC,EACA1P,KAAKs7B,YACL4X,EACAlzC,KAAK8iF,gBAAgBzjE,YACrB8zB,EACAkqC,EACAr9E,KAAKyjF,eACLlG,EACAv9E,KAAK6iF,QACL7iF,KAAK4iF,aACL5iF,KAAK6M,aAGP7M,KAAKwM,MAAQV,CACd,CACD9L,KAAK6H,SACN,CAKD,IAAAyF,GACE,GAAItN,KAAKwM,OAASV,EAAgB,CAChC9L,KAAKwM,MAAQV,EACb9L,KAAK6H,UAEL,IAAIs8E,EAAa,EAEjBnkF,KAAKkjF,qBAAuB,GAC5BljF,KAAKijF,aAAa93E,SAAS+B,IACzB,MAAMV,EAAQU,EAAKC,WACnB,GAAIX,GAASV,GAAkBU,GAASV,EAAmB,CACzDq4E,IAEA,MAAMC,EAAkBr9E,EACtBmG,EACApF,GACA,SAAUoP,GACR,MAAM1K,EAAQU,EAAKC,WAEjBX,GAASV,GACTU,GAASV,GACTU,GAASV,IAETxE,EAAc88E,GACdD,IACmB,IAAfA,IACFnkF,KAAKqkF,mBACLrkF,KAAKgkF,cAGV,GACDhkF,MAEFA,KAAKkjF,qBAAqBv9E,KAAKy+E,EAChC,KAGgB,IAAfD,EACF1yC,WAAWzxC,KAAKgkF,WAAW98E,KAAKlH,MAAO,GAEvCA,KAAKijF,aAAa93E,SAAQ,SAAU+B,EAAMtL,EAAGH,GAC7ByL,EAAKC,YACNrB,GACXoB,EAAKI,MAEjB,GAEK,CACF,CAKD,gBAAA+2E,GACErkF,KAAKkjF,qBAAqB/3E,QAAQ7D,GAClCtH,KAAKkjF,qBAAuB,IAC7B,CAKD,OAAAp2E,GACM9M,KAAKk8B,UACPhsB,GAAclQ,KAAKk8B,QAAQjsB,WAAW,OACtCN,GAAWhK,KAAK3F,KAAKk8B,SACrBl8B,KAAKk8B,QAAU,MAEjBj3B,MAAM6H,SACP,GCjWYw3E,GAME,gBANFA,GAcA,cAdAA,GAuBE,gBCmMjB,SAASC,GAAkBC,GACzB,OAAKA,EAGDniF,MAAMC,QAAQkiF,GACT,SAAU/mC,GACf,OAAO+mC,CACb,EAGiC,mBAApBA,EACFA,EAGF,SAAU/mC,GACf,MAAO,CAAC+mC,EACZ,EAdW,IAeX,CAEA,IAAAC,GAlMA,cAAqBh6E,EAInB,WAAA3K,CAAY6K,GACV1F,QAMAjF,KAAKmf,WAAayP,GAAcjkB,EAAQwU,YAMxCnf,KAAK0kF,cAAgBH,GAAkB55E,EAAQuzC,cAM/Cl+C,KAAK2kF,8BACiCn+E,IAApCmE,EAAQi6E,yBACJj6E,EAAQi6E,wBAQd5kF,KAAKokE,SAAU,EAMfpkE,KAAKutC,YAA2B/mC,IAAlBmE,EAAQ6B,MAAsB7B,EAAQ6B,MAAQ,QAM5DxM,KAAK6kF,YAA2Br+E,IAAlBmE,EAAQuU,OAAsBvU,EAAQuU,MAMpDlf,KAAK8kF,eAAiBn6E,EAAQkC,YAM9B7M,KAAK+kF,aAAe,KAMpB/kF,KAAKglF,aAAe,KAEpB,MAAMn2E,EAAO7O,KAKbA,KAAKilF,aAAe,IAAI1gF,SAAQ,SAAUE,EAASD,GACjDqK,EAAKk2E,aAAetgF,EACpBoK,EAAKm2E,aAAexgF,CAC1B,GACG,CAOD,eAAAy5C,GACE,OAAOj+C,KAAK0kF,aACb,CAMD,0BAAA5yB,GACE,OAAO9xD,KAAK2kF,wBACb,CAOD,aAAA/1D,GACE,OAAO5uB,KAAKmf,UACb,CAMD,cAAAy5B,CAAez5B,GACb,OAAO,IACR,CAKD,OAAAw+B,GACE,OAAO39C,KAAKilF,YACb,CAOD,QAAA93E,GACE,OAAOnN,KAAKutC,MACb,CAKD,QAAA2S,GACE,OAAOlgD,KAAK6kF,MACb,CAKD,cAAAK,GACE,OAAOllF,KAAK8kF,YACb,CAMD,OAAAK,GACEnlF,KAAK6H,SACN,CASD,eAAAu9E,CAAgBlnC,GACdl+C,KAAK0kF,cAAgBH,GAAkBrmC,GACvCl+C,KAAK6H,SACN,CAMD,QAAAkF,CAASP,GACPxM,KAAKutC,OAAS/gC,EACdxM,KAAK6H,SACN,GCtMH,MAAMw9E,GAAe,CAAC,EAAG,EAAG,GA6oB5B,IAAAC,GAhmBA,MAIE,WAAAxlF,CAAY6K,GA2BV,IAAIsnC,EACJ,GAvBAjyC,KAAKmtC,aAA8B3mC,IAApBmE,EAAQwiC,QAAwBxiC,EAAQwiC,QAAU,EAMjEntC,KAAK20C,aAAehqC,EAAQgmC,YAC5B18B,GACEtR,EACE3C,KAAK20C,cAML,CAACtzC,EAAGC,IAAMA,EAAID,IACd,GAEF,qDAKGsJ,EAAQ46E,QACX,IAAK,IAAI3jF,EAAI,EAAGuE,EAAKnG,KAAK20C,aAAaxzC,OAAS,EAAGS,EAAIuE,IAAMvE,EAC3D,GAAKqwC,GAGH,GAAIjyC,KAAK20C,aAAa/yC,GAAK5B,KAAK20C,aAAa/yC,EAAI,KAAOqwC,EAAY,CAClEA,OAAazrC,EACb,KACD,OALDyrC,EAAajyC,KAAK20C,aAAa/yC,GAAK5B,KAAK20C,aAAa/yC,EAAI,GAchE5B,KAAK00C,YAAczC,EAMnBjyC,KAAKotC,QAAUptC,KAAK20C,aAAaxzC,OAAS,EAM1CnB,KAAKwlF,aAA6Bh/E,IAAnBmE,EAAQ86E,OAAuB96E,EAAQ86E,OAAS,KAM/DzlF,KAAK0lF,SAAW,UACQl/E,IAApBmE,EAAQ46E,UACVvlF,KAAK0lF,SAAW/6E,EAAQ46E,QACxBtxE,GACEjU,KAAK0lF,SAASvkF,QAAUnB,KAAK20C,aAAaxzC,OAC1C,wDAIJ,MAAMqY,EAAS7O,EAAQ6O,YAERhT,IAAXgT,GAAyBxZ,KAAKwlF,SAAYxlF,KAAK0lF,WACjD1lF,KAAKwlF,QAAUvpE,GAAWzC,IAG5BvF,IACIjU,KAAKwlF,SAAWxlF,KAAK0lF,UAAc1lF,KAAKwlF,UAAYxlF,KAAK0lF,SAC3D,+DAOF1lF,KAAK2lF,WAAa,UACQn/E,IAAtBmE,EAAQi7E,YACV5lF,KAAK2lF,WAAah7E,EAAQi7E,UAC1B3xE,GACEjU,KAAK2lF,WAAWxkF,QAAUnB,KAAK20C,aAAaxzC,OAC5C,0DAQJnB,KAAK6lF,eACkBr/E,IAArBmE,EAAQm7E,SACJn7E,EAAQm7E,SACP9lF,KAAK2lF,WAEN,KADAp2C,GAENt7B,IACIjU,KAAK6lF,WAAa7lF,KAAK2lF,YACtB3lF,KAAK6lF,YAAc7lF,KAAK2lF,WAC3B,mEAOF3lF,KAAKugB,aAAqB/Z,IAAXgT,EAAuBA,EAAS,KAM/CxZ,KAAK+lF,gBAAkB,KAMvB/lF,KAAKgmF,SAAW,CAAC,EAAG,GAMpBhmF,KAAKimF,WAAa,CAAC,EAAG,EAAG,EAAG,QAENz/E,IAAlBmE,EAAQu7E,MACVlmF,KAAK+lF,gBAAkBp7E,EAAQu7E,MAAMp7C,KAAI,CAACp3B,EAAM6rB,KAC9C,MAAMyrC,EAAY,IAAIK,GACpBp/D,KAAKwP,IAAI,EAAG/H,EAAK,IACjBzH,KAAKyP,IAAIhI,EAAK,GAAK,GAAI,GACvBzH,KAAKwP,IAAI,EAAG/H,EAAK,IACjBzH,KAAKyP,IAAIhI,EAAK,GAAK,GAAI,IAEzB,GAAI8F,EAAQ,CACV,MAAM2sE,EAAsBnmF,KAAK6jF,0BAA0BrqE,EAAQ+lB,GACnEyrC,EAAU5wD,KAAOnO,KAAKyP,IAAIyqE,EAAoB/rE,KAAM4wD,EAAU5wD,MAC9D4wD,EAAU1wD,KAAOrO,KAAKwP,IAAI0qE,EAAoB7rE,KAAM0wD,EAAU1wD,MAC9D0wD,EAAU3wD,KAAOpO,KAAKyP,IAAIyqE,EAAoB9rE,KAAM2wD,EAAU3wD,MAC9D2wD,EAAUzwD,KAAOtO,KAAKwP,IAAI0qE,EAAoB5rE,KAAMywD,EAAUzwD,KAC/D,CACD,OAAOywD,CAAS,IAETxxD,GACTxZ,KAAKomF,qBAAqB5sE,EAE7B,CAUD,gBAAA6sE,CAAiB7sE,EAAQ47B,EAAMx5B,GAC7B,MAAMovD,EAAYhrE,KAAK6jF,0BAA0BrqE,EAAQ47B,GACzD,IAAK,IAAIxzC,EAAIopE,EAAU5wD,KAAMjU,EAAK6kE,EAAU1wD,KAAM1Y,GAAKuE,IAAMvE,EAC3D,IAAK,IAAI0iB,EAAI0mD,EAAU3wD,KAAM4Q,EAAK+/C,EAAUzwD,KAAM+J,GAAK2G,IAAM3G,EAC3D1I,EAAS,CAACw5B,EAAMxzC,EAAG0iB,GAGxB,CASD,+BAAAgiE,CACE/5E,EACAqP,EACA2qE,EACAC,GAEA,IAAIxb,EAAW3zD,EAAGC,EACdmvE,EAAkB,KAClBlnD,EAAIhzB,EAAU,GAAK,EAOvB,IANyB,IAArBvM,KAAK00C,aACPr9B,EAAI9K,EAAU,GACd+K,EAAI/K,EAAU,IAEdk6E,EAAkBzmF,KAAKojF,mBAAmB72E,EAAWi6E,GAEhDjnD,GAAKv/B,KAAKmtC,SAAS,CAYxB,QAXU3mC,IAAN6Q,QAAyB7Q,IAAN8Q,GACrBD,EAAIpL,KAAKuT,MAAMnI,EAAI,GACnBC,EAAIrL,KAAKuT,MAAMlI,EAAI,GACnB0zD,EAAY0b,GAAwBrvE,EAAGA,EAAGC,EAAGA,EAAGivE,IAEhDvb,EAAYhrE,KAAK6jF,0BACf4C,EACAlnD,EACAgnD,GAGA3qE,EAAS2jB,EAAGyrC,GACd,OAAO,IAEPzrC,CACH,CACD,OAAO,CACR,CAOD,SAAAlgB,GACE,OAAOrf,KAAKugB,OACb,CAOD,UAAA4tB,GACE,OAAOnuC,KAAKotC,OACb,CAOD,UAAAc,GACE,OAAOluC,KAAKmtC,OACb,CAQD,SAAAirC,CAAU74C,GACR,OAAIv/B,KAAKwlF,QACAxlF,KAAKwlF,QAEPxlF,KAAK0lF,SAASnmD,EACtB,CAQD,aAAA7D,CAAc6D,GACZ,OAAOv/B,KAAK20C,aAAapV,EAC1B,CAOD,cAAAqZ,GACE,OAAO54C,KAAK20C,YACb,CAQD,0BAAAgyC,CAA2Bp6E,EAAWg6E,EAAeC,GACnD,GAAIj6E,EAAU,GAAKvM,KAAKotC,QAAS,CAC/B,GAAyB,IAArBptC,KAAK00C,YAAmB,CAC1B,MAAMt6B,EAAsB,EAAf7N,EAAU,GACjB8N,EAAsB,EAAf9N,EAAU,GACvB,OAAOm6E,GACLtsE,EACAA,EAAO,EACPC,EACAA,EAAO,EACPksE,EAEH,CACD,MAAME,EAAkBzmF,KAAKojF,mBAC3B72E,EACAi6E,GAAcxmF,KAAKimF,YAErB,OAAOjmF,KAAK6jF,0BACV4C,EACAl6E,EAAU,GAAK,EACfg6E,EAEH,CACD,OAAO,IACR,CAQD,4BAAAK,CAA6Br6E,EAAWgzB,EAAGgnD,GACzC,GAAIhnD,EAAIv/B,KAAKotC,SAAW7N,EAAIv/B,KAAKmtC,QAC/B,OAAO,KAGT,MAAM05C,EAAat6E,EAAU,GACvBu6E,EAAav6E,EAAU,GACvBw6E,EAAax6E,EAAU,GAE7B,GAAIgzB,IAAMsnD,EACR,OAAOH,GACLI,EACAC,EACAD,EACAC,EACAR,GAIJ,GAAIvmF,KAAK00C,YAAa,CACpB,MAAMzvB,EAAShZ,KAAKC,IAAIlM,KAAK00C,YAAanV,EAAIsnD,GACxCzsE,EAAOnO,KAAKuT,MAAMsnE,EAAa7hE,GAC/B5K,EAAOpO,KAAKuT,MAAMunE,EAAa9hE,GACrC,GAAIsa,EAAIsnD,EACN,OAAOH,GAAwBtsE,EAAMA,EAAMC,EAAMA,EAAMksE,GAKzD,OAAOG,GAAwBtsE,EAFlBnO,KAAKuT,MAAMyF,GAAU6hE,EAAa,IAAM,EAEVzsE,EAD9BpO,KAAKuT,MAAMyF,GAAU8hE,EAAa,IAAM,EACER,EACxD,CAED,MAAME,EAAkBzmF,KAAKojF,mBAAmB72E,EAAWvM,KAAKimF,YAChE,OAAOjmF,KAAK6jF,0BAA0B4C,EAAiBlnD,EAAGgnD,EAC3D,CASD,yBAAA1C,CAA0BrqE,EAAQ+lB,EAAGgnD,GACnCvmF,KAAKgnF,uBAAuBxtE,EAAO,GAAIA,EAAO,GAAI+lB,GAAG,EAAO8lD,IAC5D,MAAMjrE,EAAOirE,GAAa,GACpBhrE,EAAOgrE,GAAa,GAC1BrlF,KAAKgnF,uBAAuBxtE,EAAO,GAAIA,EAAO,GAAI+lB,GAAG,EAAM8lD,IAG3D,OAAOqB,GAAwBtsE,EAFlBirE,GAAa,GAEiBhrE,EAD9BgrE,GAAa,GAC6BkB,EACxD,CAMD,kBAAAU,CAAmB16E,GACjB,MAAMk5E,EAASzlF,KAAKo4E,UAAU7rE,EAAU,IAClCoQ,EAAa3c,KAAK07B,cAAcnvB,EAAU,IAC1Cu5E,EAAW9mB,GAAOh/D,KAAKikF,YAAY13E,EAAU,IAAKvM,KAAKgmF,UAC7D,MAAO,CACLP,EAAO,IAAMl5E,EAAU,GAAK,IAAOu5E,EAAS,GAAKnpE,EACjD8oE,EAAO,IAAMl5E,EAAU,GAAK,IAAOu5E,EAAS,GAAKnpE,EAEpD,CAUD,kBAAAymE,CAAmB72E,EAAWi6E,GAC5B,MAAMf,EAASzlF,KAAKo4E,UAAU7rE,EAAU,IAClCoQ,EAAa3c,KAAK07B,cAAcnvB,EAAU,IAC1Cu5E,EAAW9mB,GAAOh/D,KAAKikF,YAAY13E,EAAU,IAAKvM,KAAKgmF,UACvD5rE,EAAOqrE,EAAO,GAAKl5E,EAAU,GAAKu5E,EAAS,GAAKnpE,EAChDtC,EAAOorE,EAAO,IAAMl5E,EAAU,GAAK,GAAKu5E,EAAS,GAAKnpE,EAG5D,OAAOjC,GAAeN,EAAMC,EAFfD,EAAO0rE,EAAS,GAAKnpE,EACrBtC,EAAOyrE,EAAS,GAAKnpE,EACY6pE,EAC/C,CAaD,iCAAAU,CAAkC9vE,EAAYuF,EAAYwqE,GACxD,OAAOnnF,KAAKonF,gCACVhwE,EAAW,GACXA,EAAW,GACXuF,GACA,EACAwqE,EAEH,CAeD,+BAAAC,CACE/vE,EACAC,EACAqF,EACA0qE,EACAF,GAEA,MAAM5nD,EAAIv/B,KAAK2jF,kBAAkBhnE,GAC3BhF,EAAQgF,EAAa3c,KAAK07B,cAAc6D,GACxCkmD,EAASzlF,KAAKo4E,UAAU74C,GACxBumD,EAAW9mB,GAAOh/D,KAAKikF,YAAY1kD,GAAIv/B,KAAKgmF,UAElD,IAAIc,EAAcnvE,GAASN,EAAIouE,EAAO,IAAO9oE,EAAampE,EAAS,GAC/DiB,EAAcpvE,GAAS8tE,EAAO,GAAKnuE,GAAMqF,EAAampE,EAAS,GAUnE,OARIuB,GACFP,EAAa3hE,GAAK2hE,EA7eP,GA6e+B,EAC1CC,EAAa5hE,GAAK4hE,EA9eP,GA8e+B,IAE1CD,EAAatnE,GAAMsnE,EAhfR,GAifXC,EAAavnE,GAAMunE,EAjfR,IAofNO,GAAwB/nD,EAAGunD,EAAYC,EAAYI,EAC3D,CAiBD,sBAAAH,CAAuB3vE,EAAGC,EAAGioB,EAAG8nD,EAA2BF,GACzD,MAAM1B,EAASzlF,KAAKo4E,UAAU74C,GACxB5iB,EAAa3c,KAAK07B,cAAc6D,GAChCumD,EAAW9mB,GAAOh/D,KAAKikF,YAAY1kD,GAAIv/B,KAAKgmF,UAElD,IAAIc,GAAczvE,EAAIouE,EAAO,IAAM9oE,EAAampE,EAAS,GACrDiB,GAActB,EAAO,GAAKnuE,GAAKqF,EAAampE,EAAS,GAUzD,OARIuB,GACFP,EAAa3hE,GAAK2hE,EA/gBP,GA+gB+B,EAC1CC,EAAa5hE,GAAK4hE,EAhhBP,GAghB+B,IAE1CD,EAAatnE,GAAMsnE,EAlhBR,GAmhBXC,EAAavnE,GAAMunE,EAnhBR,IAshBNO,GAAwB/nD,EAAGunD,EAAYC,EAAYI,EAC3D,CAUD,wBAAAI,CAAyBnwE,EAAYmoB,EAAG4nD,GACtC,OAAOnnF,KAAKgnF,uBACV5vE,EAAW,GACXA,EAAW,GACXmoB,GACA,EACA4nD,EAEH,CAMD,sBAAAK,CAAuBj7E,GACrB,OAAOvM,KAAK20C,aAAapoC,EAAU,GACpC,CAUD,WAAA03E,CAAY1kD,GACV,OAAIv/B,KAAK6lF,UACA7lF,KAAK6lF,UAEP7lF,KAAK2lF,WAAWpmD,EACxB,CAMD,gBAAA0rC,CAAiB1rC,GACf,OAAKv/B,KAAK+lF,gBAKH/lF,KAAK+lF,gBAAgBxmD,GAJnBv/B,KAAKugB,QACRvgB,KAAK6jF,0BAA0B7jF,KAAKugB,QAASgf,GAC7C,IAGP,CAmBD,iBAAAokD,CAAkBhnE,EAAY8qE,GAM5B,OAAO3jE,GALGtiB,EACRxB,KAAK20C,aACLh4B,EACA8qE,GAAiB,GAEHznF,KAAKmtC,QAASntC,KAAKotC,QACpC,CAQD,2BAAAs6C,CAA4Bn7E,EAAWo7E,GACrC,OAAO1yD,GACL0yD,EACA,EACAA,EAASxmF,OACT,EACAnB,KAAKojF,mBAAmB72E,GAE3B,CAMD,oBAAA65E,CAAqB5sE,GACnB,MAAMrY,EAASnB,KAAK20C,aAAaxzC,OAC3BymF,EAAiB,IAAIvlF,MAAMlB,GACjC,IAAK,IAAIo+B,EAAIv/B,KAAKmtC,QAAS5N,EAAIp+B,IAAUo+B,EACvCqoD,EAAeroD,GAAKv/B,KAAK6jF,0BAA0BrqE,EAAQ+lB,GAE7Dv/B,KAAK+lF,gBAAkB6B,CACxB,GCzoBI,SAASC,GAAiB1oE,GAC/B,IAAI0C,EAAW1C,EAAWwC,qBAK1B,OAJKE,IACHA,EAAWimE,GAAoB3oE,GAC/BA,EAAWyC,mBAAmBC,IAEzBA,CACT,CAQO,SAAS3C,GAAM2C,EAAUtV,EAAW4S,GACzC,MAAMogB,EAAIhzB,EAAU,GACdmQ,EAASmF,EAASolE,mBAAmB16E,GACrC6S,EAAmB2oE,GAAqB5oE,GAC9C,IAAKrF,GAAmBsF,EAAkB1C,GAAS,CACjD,MAAM6C,EAAanD,GAASgD,GACtBuI,EAAa1b,KAAKkZ,MACrB/F,EAAiB,GAAK1C,EAAO,IAAM6C,GAGtC,OADA7C,EAAO,IAAM6C,EAAaoI,EACnB9F,EAAS0lE,yBAAyB7qE,EAAQ6iB,EAClD,CACD,OAAOhzB,CACT,CAWO,SAASy7E,GAAgBxuE,EAAQ4zB,EAAS04C,EAAUtpE,GACzDA,OAAoBhW,IAAXgW,EAAuBA,EAAS,WAEzC,MAAMm0B,EAAcs3C,GAAsBzuE,EAAQ4zB,EAAS04C,GAE3D,OAAO,IAAIoC,GAAS,CAClB1uE,OAAQA,EACRisE,OAAQlpE,GAAU/C,EAAQgD,GAC1Bm0B,YAAaA,EACbm1C,SAAUA,GAEd,CAoBO,SAASqC,GAAUx9E,GACxB,MAAMy9E,EAAaz9E,GAAW,GAExB6O,EAAS4uE,EAAW5uE,QAAUoV,GAAc,aAAavP,YAEzDgpE,EAAc,CAClB7uE,OAAQA,EACR2zB,QAASi7C,EAAWj7C,QACpB24C,SAAUsC,EAAWtC,SACrBn1C,YAAas3C,GACXzuE,EACA4uE,EAAWh7C,QACXg7C,EAAWtC,SACXsC,EAAWn7C,gBAGf,OAAO,IAAIi7C,GAASG,EACtB,CAYA,SAASJ,GAAsBzuE,EAAQ4zB,EAAS04C,EAAU74C,GACxDG,OAAsB5mC,IAAZ4mC,EAAwBA,EAAUkC,GAC5Cw2C,EAAW9mB,QAAoBx4D,IAAbs/E,EAAyBA,EAAWv2C,IAEtD,MAAM7/B,EAAS2M,GAAU7C,GACnB/J,EAAQ2M,GAAS5C,GAEvByzB,EACEA,EAAgB,EACZA,EACAhhC,KAAKyP,IAAIjM,EAAQq2E,EAAS,GAAIp2E,EAASo2E,EAAS,IAEtD,MAAM3kF,EAASisC,EAAU,EACnBuD,EAAc,IAAItuC,MAAMlB,GAC9B,IAAK,IAAIo+B,EAAI,EAAGA,EAAIp+B,IAAUo+B,EAC5BoR,EAAYpR,GAAK0N,EAAgBhhC,KAAKC,IAAI,EAAGqzB,GAE/C,OAAOoR,CACT,CAWO,SAASm3C,GAAoB3oE,EAAYiuB,EAAS04C,EAAUtpE,GAEjE,OAAOwrE,GADQD,GAAqB5oE,GACLiuB,EAAS04C,EAAUtpE,EACpD,CAQO,SAASurE,GAAqB5oE,GAEnC,IAAI3F,GADJ2F,EAAayP,GAAczP,IACHE,YACxB,IAAK7F,EAAQ,CACX,MAAM8uE,EACH,IAAMxoE,GAAgBG,QAAWd,EAAWmC,mBAC/C9H,EAASkB,IAAgB4tE,GAAOA,EAAMA,EAAMA,EAC7C,CACD,OAAO9uE,CACT,CCoNO,MAAM+uE,WAAwBxiF,EAKnC,WAAAjG,CAAYC,EAAMmN,GAChBjI,MAAMlF,GAONC,KAAKkN,KAAOA,CACb,EAGH,IAAAs7E,GAzVA,cAAyBC,GAIvB,WAAA3oF,CAAY6K,GACV1F,MAAM,CACJi5C,aAAcvzC,EAAQuzC,aACtB0mC,wBAAyBj6E,EAAQi6E,wBACjCzlE,WAAYxU,EAAQwU,WACpB3S,MAAO7B,EAAQ6B,MACf0S,MAAOvU,EAAQuU,MACfrS,YAAalC,EAAQkC,cAMvB7M,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAML3H,KAAK0oF,aAA6BliF,IAAnBmE,EAAQg+E,QAAuBh+E,EAAQg+E,OAMtD3oF,KAAK4oF,qBACwBpiF,IAA3BmE,EAAQk+E,eAA+Bl+E,EAAQk+E,eAAiB,EAKlE7oF,KAAK6hB,cAAgCrb,IAArBmE,EAAQkX,SAAyBlX,EAAQkX,SAAW,KAEpE,MAAMikE,EAAW,CAAC,IAAK,KACnB9lF,KAAK6hB,UACPm9C,GAAOh/D,KAAK6hB,SAASoiE,YAAYjkF,KAAK6hB,SAASqsB,cAAe43C,GAOhE9lF,KAAK8oF,UAAY,IAAIC,GAAUp+E,EAAQ0gC,WAAa,GAMpDrrC,KAAKgpF,QAAU,CAAC,EAAG,GAMnBhpF,KAAKiqE,KAAOt/D,EAAQpD,KAAO,GAM3BvH,KAAKipF,YAAc,CACjBt8E,WAAYhC,EAAQgC,WACpBE,YAAalC,EAAQkC,aAUvB7M,KAAKkpF,WAAav+E,EAAQu+E,WAAav+E,EAAQu+E,WAAa,CAC7D,CAKD,cAAA/8C,GACE,OAAOnsC,KAAK8oF,UAAU38C,gBACvB,CAMD,WAAAy9B,CAAYzqD,EAAYgnD,GACtB,MAAM2iB,EAAY9oF,KAAKmpF,0BAA0BhqE,GAC7C2pE,GACFA,EAAUlf,YAAYzD,EAEzB,CAWD,iBAAAijB,CAAkBjqE,EAAYogB,EAAGyrC,EAAWpvD,GAC1C,MAAMktE,EAAY9oF,KAAKmpF,0BAA0BhqE,GACjD,IAAK2pE,EACH,OAAO,EAGT,IACI57E,EAAMm8E,EAAc1uD,EADpB2uD,GAAU,EAEd,IAAK,IAAIjyE,EAAI2zD,EAAU5wD,KAAM/C,GAAK2zD,EAAU1wD,OAAQjD,EAClD,IAAK,IAAIC,EAAI0zD,EAAU3wD,KAAM/C,GAAK0zD,EAAUzwD,OAAQjD,EAClD+xE,EAAe5e,GAAUlrC,EAAGloB,EAAGC,GAC/BqjB,GAAS,EACLmuD,EAAUhf,YAAYuf,KACxBn8E,EACE47E,EAAU1/E,IAAIigF,GAEhB1uD,EAASztB,EAAKC,aAAerB,EACzB6uB,IACFA,GAA4B,IAAnB/e,EAAS1O,KAGjBytB,IACH2uD,GAAU,GAIhB,OAAOA,CACR,CAMD,sBAAAC,CAAuBpqE,GACrB,OAAO,CACR,CAMD,MAAAnS,GACE,OAAOhN,KAAKiqE,IACb,CAOD,MAAAuf,CAAOjiF,GACDvH,KAAKiqE,OAAS1iE,IAChBvH,KAAKiqE,KAAO1iE,EACZvH,KAAK6H,UAER,CAMD,SAAA4hF,CAAUtqE,GACR,OAAOnf,KAAK0oF,OACb,CAMD,cAAA9vC,CAAez5B,GACb,MAAM0C,EAAW1C,EACbnf,KAAK0pF,yBAAyBvqE,GAC9Bnf,KAAK6hB,SACT,OAAKA,EAGEA,EAAS+2B,iBAFP,IAGV,CAWD,OAAA+wC,CAAQpqD,EAAGloB,EAAGC,EAAG8jB,EAAYjc,GAC3B,OAAO5W,GACR,CAOD,WAAAqhF,GACE,OAAO5pF,KAAK6hB,QACb,CAMD,wBAAA6nE,CAAyBvqE,GACvB,OAAKnf,KAAK6hB,SAGH7hB,KAAK6hB,SAFH6nE,GAAyBvqE,EAGnC,CAOD,yBAAAgqE,CAA0BhqE,GACxB,MAAMsM,EAAmBzrB,KAAK4uB,gBAK9B,OAJA3a,GACuB,OAArBwX,GAA6BF,GAAWE,EAAkBtM,GAC1D,wGAEKnf,KAAK8oF,SACb,CASD,iBAAAe,CAAkBzuD,GAChB,OAAOp7B,KAAK4oF,eACb,CAQD,gBAAAkB,CAAiBvqD,EAAGnE,EAAYjc,GAC9B,MAAM0C,EAAW7hB,KAAK0pF,yBAAyBvqE,GACzC0pE,EAAiB7oF,KAAK6pF,kBAAkBzuD,GACxC0qD,EAAW9mB,GAAOn9C,EAASoiE,YAAY1kD,GAAIv/B,KAAKgpF,SACtD,OAAsB,GAAlBH,EACK/C,EAEFiE,GAAUjE,EAAU+C,EAAgB7oF,KAAKgpF,QACjD,CAWD,8BAAAgB,CAA+Bz9E,EAAW4S,GACxCA,OAA4B3Y,IAAf2Y,EAA2BA,EAAanf,KAAK4uB,gBAC1D,MAAM/M,EAAW7hB,KAAK0pF,yBAAyBvqE,GAI/C,OAHInf,KAAKkgD,YAAc/gC,EAAWsC,aAChClV,EAAY2S,GAAM2C,EAAUtV,EAAW4S,IAElC4rD,GAAiBx+D,EAAWsV,GAAYtV,EAAY,IAC5D,CAMD,KAAA5H,GACE3E,KAAK8oF,UAAUnkF,OAChB,CAED,OAAAwgF,GACEnlF,KAAK2E,QACLM,MAAMkgF,SACP,CAOD,eAAA8E,CAAgBC,EAAW/qE,GACzB,MAAM2pE,EAAY9oF,KAAKmpF,0BAA0BhqE,GAC7C+qE,EAAYpB,EAAUvf,gBACxBuf,EAAUvf,cAAgB2gB,EAE7B,CAUD,OAAAC,CAAQ5qD,EAAGloB,EAAGC,EAAG6H,GAAc,GCzW1B,SAASirE,GAAmBnjE,EAAUpF,GAC3C,MAAMwoE,EAAS,SACTC,EAAS,SACTC,EAAS,SACTC,EAAa,UACnB,OAAA,SAOYj+E,EAAW6uB,EAAYjc,GAC/B,GAAK5S,EAGL,OAAO0a,EACJzD,QAAQ6mE,EAAQ99E,EAAU,GAAGqM,YAC7B4K,QAAQ8mE,EAAQ/9E,EAAU,GAAGqM,YAC7B4K,QAAQ+mE,EAAQh+E,EAAU,GAAGqM,YAC7B4K,QAAQgnE,GAAY,WACnB,MAAMjrD,EAAIhzB,EAAU,GACdk+E,EAAQ5oE,EAASopD,iBAAiB1rC,GACxC,IAAKkrD,EACH,MAAM,IAAIjiF,MACR,yDAIJ,OADUiiF,EAAMpuE,YAAc9P,EAAU,GAAK,GACpCqM,UACnB,GAEI,CACJ,CAOO,SAAS8xE,GAAoBC,EAAW9oE,GAC7C,MAAM5Z,EAAM0iF,EAAUxpF,OAChBypF,EAAmB,IAAIvoF,MAAM4F,GACnC,IAAK,IAAIrG,EAAI,EAAGA,EAAIqG,IAAOrG,EACzBgpF,EAAiBhpF,GAAKwoF,GAAmBO,EAAU/oF,GAAIigB,GAEzD,OAAOgpE,GAA2BD,EACpC,CAMO,SAASC,GAA2BD,GACzC,OAAgC,IAA5BA,EAAiBzpF,OACZypF,EAAiB,GAE1B,SAOYr+E,EAAW6uB,EAAYjc,GAC/B,IAAK5S,EACH,OAEF,MACMtJ,EAAQ4hB,GADJimE,GAAcv+E,GACAq+E,EAAiBzpF,QACzC,OAAOypF,EAAiB3nF,GAAOsJ,EAAW6uB,EAAYjc,EAExD,CACJ,CAQO,SAAS4rE,GAAoBx+E,EAAW6uB,EAAYjc,GAE3D,CAMO,SAAS6rE,GAAUpd,GACxB,MAAMqd,EAAO,GACb,IAAIhgD,EAAQ,sBAAsBN,KAAKijC,GACvC,GAAI3iC,EAAO,CAET,MAAMigD,EAAgBjgD,EAAM,GAAGkgD,WAAW,GACpCC,EAAengD,EAAM,GAAGkgD,WAAW,GACzC,IAAIE,EACJ,IAAKA,EAAWH,EAAeG,GAAYD,IAAgBC,EACzDJ,EAAKtlF,KAAKioE,EAAIpqD,QAAQynB,EAAM,GAAIpiC,OAAOyiF,aAAaD,KAEtD,OAAOJ,CACR,CAED,GADAhgD,EAAQ,kBAAkBN,KAAKijC,GAC3B3iC,EAAO,CAET,MAAMsgD,EAAO96E,SAASw6B,EAAM,GAAI,IAChC,IAAK,IAAIrpC,EAAI6O,SAASw6B,EAAM,GAAI,IAAKrpC,GAAK2pF,EAAM3pF,IAC9CqpF,EAAKtlF,KAAKioE,EAAIpqD,QAAQynB,EAAM,GAAIrpC,EAAEgX,aAEpC,OAAOqyE,CACR,CAED,OADAA,EAAKtlF,KAAKioE,GACHqd,CACT,CCtFA,MAAMO,WAAgBC,GAIpB,WAAA3rF,CAAY6K,GACV1F,MAAM,CACJi5C,aAAcvzC,EAAQuzC,aACtB7S,UAAW1gC,EAAQ0gC,UACnBs9C,OAAQh+E,EAAQg+E,OAChBxpE,WAAYxU,EAAQwU,WACpB3S,MAAO7B,EAAQ6B,MACfqV,SAAUlX,EAAQkX,SAClBgnE,eAAgBl+E,EAAQk+E,eACxB3pE,MAAOvU,EAAQuU,MACfvS,WAAYhC,EAAQgC,WACpBE,YAAalC,EAAQkC,YACrBtF,IAAKoD,EAAQpD,IACbq9E,wBAAyBj6E,EAAQi6E,wBACjCsE,WAAYv+E,EAAQu+E,aAOtBlpF,KAAK0rF,yBACH1rF,KAAK2rF,kBAAoBH,GAAQ3nF,UAAU8nF,gBAM7C3rF,KAAKs8B,iBAAmB3xB,EAAQ2xB,iBAE5B3xB,EAAQghF,kBACV3rF,KAAK2rF,gBAAkBhhF,EAAQghF,iBAOjC3rF,KAAKirF,KAAO,KAERtgF,EAAQsgF,KACVjrF,KAAK4rF,QAAQjhF,EAAQsgF,MACZtgF,EAAQijE,KACjB5tE,KAAK6rF,OAAOlhF,EAAQijE,KAOtB5tE,KAAK8rF,iBAAmB,EACzB,CAOD,mBAAAC,GACE,OAAO/rF,KAAKs8B,gBACb,CAOD,kBAAA0vD,GACE,OAAOtlF,OAAOulF,eAAejsF,MAAM2rF,kBAAoB3rF,KAAK2rF,gBACxD3rF,KAAK2rF,gBAAgBzkF,KAAKlH,MAC1BA,KAAK2rF,eACV,CASD,OAAAO,GACE,OAAOlsF,KAAKirF,IACb,CAOD,gBAAAv8B,CAAiB7oD,GACf,MAAMqH,EAAoDrH,EAAY,OAChEsmF,EAAMzjF,EAAOwE,GACbk/E,EAAYl/E,EAAKC,WACvB,IAAIpN,EACAqsF,GAAatgF,GACf9L,KAAK8rF,iBAAiBK,IAAO,EAC7BpsF,EAAOukF,IACE6H,KAAOnsF,KAAK8rF,0BACd9rF,KAAK8rF,iBAAiBK,GAC7BpsF,EACEqsF,GAAatgF,EACTw4E,GACA8H,GAAatgF,EACbw4E,QACA99E,GAEIA,MAARzG,GACFC,KAAK4F,cAAc,IAAI2iF,GAAgBxoF,EAAMmN,GAEhD,CAOD,mBAAAm/E,CAAoB/vD,GAClBt8B,KAAK8oF,UAAUnkF,QACf3E,KAAKs8B,iBAAmBA,EACxBt8B,KAAK6H,SACN,CAQD,kBAAAykF,CAAmBX,EAAiBpkF,GAClCvH,KAAK2rF,gBAAkBA,EACvB3rF,KAAK8oF,UAAU1d,0BACI,IAAR7jE,EACTvH,KAAKwpF,OAAOjiF,GAEZvH,KAAK6H,SAER,CAOD,MAAAgkF,CAAOje,GACL,MAAMqd,EAAOD,GAAUpd,GACvB5tE,KAAKirF,KAAOA,EACZjrF,KAAK4rF,QAAQX,EACd,CAOD,OAAAW,CAAQX,GACNjrF,KAAKirF,KAAOA,EACZ,MAAM1jF,EAAM0jF,EAAKnyE,KAAK,MAClB9Y,KAAK0rF,yBACP1rF,KAAKssF,mBAAmB5B,GAAoBO,EAAMjrF,KAAK6hB,UAAWta,GAElEvH,KAAKwpF,OAAOjiF,EAEf,CAQD,eAAAokF,CAAgBp/E,EAAW6uB,EAAYjc,GAEtC,CAQD,OAAAgrE,CAAQ5qD,EAAGloB,EAAGC,GACZ,MAAM+xE,EAAe5e,GAAUlrC,EAAGloB,EAAGC,GACjCtX,KAAK8oF,UAAUhf,YAAYuf,IAC7BrpF,KAAK8oF,UAAU1/E,IAAIigF,EAEtB,EAGH,IAAAkD,GAAef,GC+Mf,SAASgB,GAAwBC,EAAW5xD,GACQ4xD,EAAUjxD,WAAYX,IACtEA,CACJ,CAEA,IAAA6xD,GAxXA,cAAwBlB,GAItB,WAAA1rF,CAAY6K,GACV1F,MAAM,CACJi5C,aAAcvzC,EAAQuzC,aACtB7S,UAAW1gC,EAAQ0gC,UACnBs9C,OAAQh+E,EAAQg+E,OAChBxpE,WAAYxU,EAAQwU,WACpB3S,MAAO7B,EAAQ6B,MACfqV,SAAUlX,EAAQkX,SAClBya,iBAAkB3xB,EAAQ2xB,iBACtB3xB,EAAQ2xB,iBACRkwD,GACJ3D,eAAgBl+E,EAAQk+E,eACxB8C,gBAAiBhhF,EAAQghF,gBACzB/d,IAAKjjE,EAAQijE,IACbqd,KAAMtgF,EAAQsgF,KACd/rE,MAAOvU,EAAQuU,MACfvS,WAAYhC,EAAQgC,WACpBE,iBAC0BrG,IAAxBmE,EAAQkC,aAA4BlC,EAAQkC,YAC9CtF,IAAKoD,EAAQpD,IACbq9E,wBAAyBj6E,EAAQi6E,wBACjCsE,WAAYv+E,EAAQu+E,aAOtBlpF,KAAKq8B,iBACqB71B,IAAxBmE,EAAQ0xB,YAA4B1xB,EAAQ0xB,YAAc,KAM5Dr8B,KAAK2sF,eACmBnmF,IAAtBmE,EAAQgiF,UAA0BhiF,EAAQgiF,UAAYC,GAMxD5sF,KAAK6sF,uBAAyB,GAM9B7sF,KAAK8sF,sBAAwB,GAM7B9sF,KAAK+sF,4BAA8BpiF,EAAQqiF,2BAM3ChtF,KAAKitF,0BAA2B,CACjC,CAKD,cAAA9gD,GACE,GAAInsC,KAAK8oF,UAAU38C,iBACjB,OAAO,EAET,IAAK,MAAM5kC,KAAOvH,KAAK6sF,uBACrB,GAAI7sF,KAAK6sF,uBAAuBtlF,GAAK4kC,iBACnC,OAAO,EAIX,OAAO,CACR,CAMD,WAAAy9B,CAAYzqD,EAAYgnD,GACtB,MAAM+mB,EAAgBltF,KAAKmpF,0BAA0BhqE,GAErDnf,KAAK8oF,UAAUlf,YACb5pE,KAAK8oF,WAAaoE,EAAgB/mB,EAAY,CAAE,GAElD,IAAK,MAAM34D,KAAMxN,KAAK6sF,uBAAwB,CAC5C,MAAM/D,EAAY9oF,KAAK6sF,uBAAuBr/E,GAC9Cs7E,EAAUlf,YAAYkf,GAAaoE,EAAgB/mB,EAAY,CAAE,EAClE,CACF,CAMD,sBAAAojB,CAAuBpqE,GACrB,OACEnf,KAAK4uB,iBACLzP,IACCoM,GAAWvrB,KAAK4uB,gBAAiBzP,GAE3B,EAEFnf,KAAKmtF,WACb,CAKD,SAAAA,GACE,OAAO,CACR,CAMD,MAAAngF,GACE,IAAIzF,EAAMtC,MAAM+H,SAIhB,OAHKhN,KAAKklF,mBACR39E,GAAO,0BAEFA,CACR,CAMD,SAAAkiF,CAAUtqE,GACR,QACEnf,KAAK4uB,iBACLzP,IACCoM,GAAWvrB,KAAK4uB,gBAAiBzP,KAI7Bla,MAAMwkF,UAAUtqE,EACxB,CAMD,wBAAAuqE,CAAyBvqE,GACvB,MAAMiuE,EAAWptF,KAAK4uB,gBACtB,GAAI5uB,KAAK6hB,YAAcurE,GAAY7hE,GAAW6hE,EAAUjuE,IACtD,OAAOnf,KAAK6hB,SAEd,MAAMwrE,EAAU3kF,EAAOyW,GAKvB,OAJMkuE,KAAWrtF,KAAK8sF,wBACpB9sF,KAAK8sF,sBAAsBO,GACzB3D,GAAyBvqE,IAEtBnf,KAAK8sF,sBAAsBO,EACnC,CAMD,yBAAAlE,CAA0BhqE,GACxB,MAAMiuE,EAAWptF,KAAK4uB,gBACtB,IAAKw+D,GAAY7hE,GAAW6hE,EAAUjuE,GACpC,OAAOnf,KAAK8oF,UAEd,MAAMuE,EAAU3kF,EAAOyW,GAMvB,OALMkuE,KAAWrtF,KAAK6sF,yBACpB7sF,KAAK6sF,uBAAuBQ,GAAW,IAAItE,GACzC/oF,KAAK8oF,UAAUvf,gBAGZvpE,KAAK6sF,uBAAuBQ,EACpC,CAYD,WAAAC,CAAY/tD,EAAGloB,EAAGC,EAAG8jB,EAAYjc,EAAY5X,GAC3C,MAAMgF,EAAY,CAACgzB,EAAGloB,EAAGC,GACnBm0D,EAAezrE,KAAKgqF,+BACxBz9E,EACA4S,GAEIouE,EAAU9hB,EACZzrE,KAAK2rF,gBAAgBlgB,EAAcrwC,EAAYjc,QAC/C3Y,EACE0G,EAAO,IAAIlN,KAAK2sF,UACpBpgF,OACY/F,IAAZ+mF,EAAwBzhF,EAAiBA,OAC7BtF,IAAZ+mF,EAAwBA,EAAU,GAClCvtF,KAAKq8B,YACLr8B,KAAKs8B,iBACLt8B,KAAKipF,aAIP,OAFA/7E,EAAK3F,IAAMA,EACX2F,EAAK5H,iBAAiBwC,EAAkB9H,KAAK0uD,iBAAiBxnD,KAAKlH,OAC5DkN,CACR,CAUD,OAAAy8E,CAAQpqD,EAAGloB,EAAGC,EAAG8jB,EAAYjc,GAC3B,MAAMsM,EAAmBzrB,KAAK4uB,gBAC9B,IACGnD,IACAtM,GACDoM,GAAWE,EAAkBtM,GAE7B,OAAOnf,KAAKwtF,gBACVjuD,EACAloB,EACAC,EACA8jB,EACA3P,GAAoBtM,GAGxB,MAAMoE,EAAQvjB,KAAKmpF,0BAA0BhqE,GACvC5S,EAAY,CAACgzB,EAAGloB,EAAGC,GACzB,IAAIpK,EACJ,MAAMm8E,EAAer8E,GAAOT,GACxBgX,EAAMumD,YAAYuf,KACpBn8E,EAAOqW,EAAMna,IAAIigF,IAEnB,MAAM9hF,EAAMvH,KAAKgN,SACjB,GAAIE,GAAQA,EAAK3F,KAAOA,EACtB,OAAO2F,EAET,MAAMu1E,EAAiBziF,KAAK0pF,yBAAyBj+D,GAC/Ci3D,EAAiB1iF,KAAK0pF,yBAAyBvqE,GAC/CitD,EAAmBpsE,KAAKgqF,+BAC5Bz9E,EACA4S,GAEIsuE,EAAU,IAAIC,GAClBjiE,EACAg3D,EACAtjE,EACAujE,EACAn2E,EACA6/D,EACApsE,KAAK6pF,kBAAkBzuD,GACvBp7B,KAAKmtF,aACL,CAAC5tD,EAAGloB,EAAGC,EAAG8jB,IACRp7B,KAAKwtF,gBAAgBjuD,EAAGloB,EAAGC,EAAG8jB,EAAY3P,IAC5CzrB,KAAK+sF,4BACL/sF,KAAKitF,yBACLjtF,KAAKipF,aAWP,OATAwE,EAAQlmF,IAAMA,EAEV2F,GACFugF,EAAQhhF,YAAcS,EACtBugF,EAAQrgF,sBACRmW,EAAMC,QAAQ6lE,EAAcoE,IAE5BlqE,EAAMxZ,IAAIs/E,EAAcoE,GAEnBA,CACR,CAWD,eAAAD,CAAgBjuD,EAAGloB,EAAGC,EAAG8jB,EAAYjc,GACnC,IAAIjS,EAAO,KACX,MAAMm8E,EAAe5e,GAAUlrC,EAAGloB,EAAGC,GAC/B/P,EAAMvH,KAAKgN,SACjB,GAAKhN,KAAK8oF,UAAUhf,YAAYuf,IAK9B,GADAn8E,EAAOlN,KAAK8oF,UAAU1/E,IAAIigF,GACtBn8E,EAAK3F,KAAOA,EAAK,CAInB,MAAMkF,EAAcS,EACpBA,EAAOlN,KAAKstF,YAAY/tD,EAAGloB,EAAGC,EAAG8jB,EAAYjc,EAAY5X,GAGrDkF,EAAYU,YAAcrB,EAE5BoB,EAAKT,YAAcA,EAAYA,YAE/BS,EAAKT,YAAcA,EAErBS,EAAKE,sBACLpN,KAAK8oF,UAAUtlE,QAAQ6lE,EAAcn8E,EACtC,OApBDA,EAAOlN,KAAKstF,YAAY/tD,EAAGloB,EAAGC,EAAG8jB,EAAYjc,EAAY5X,GACzDvH,KAAK8oF,UAAU/+E,IAAIs/E,EAAcn8E,GAqBnC,OAAOA,CACR,CAOD,0BAAAygF,CAA2B7wC,GACzB,GAAI98C,KAAKitF,0BAA4BnwC,EAArC,CAGA98C,KAAKitF,yBAA2BnwC,EAChC,IAAK,MAAMtvC,KAAMxN,KAAK6sF,uBACpB7sF,KAAK6sF,uBAAuBr/E,GAAI7I,QAElC3E,KAAK6H,SALJ,CAMF,CAcD,wBAAA+lF,CAAyBzuE,EAAY0uE,GACnC,MAAMC,EAAOl/D,GAAczP,GAC3B,GAAI2uE,EAAM,CACR,MAAMT,EAAU3kF,EAAOolF,GACjBT,KAAWrtF,KAAK8sF,wBACpB9sF,KAAK8sF,sBAAsBO,GAAWQ,EAEzC,CACF,CAED,KAAAlpF,GACEM,MAAMN,QACN,IAAK,MAAM6I,KAAMxN,KAAK6sF,uBACpB7sF,KAAK6sF,uBAAuBr/E,GAAI7I,OAEnC,GC/ZI,SAASopF,GAAQxhF,GACtB,MAAMgzB,EAAIhzB,EAAU,GACdyhF,EAAS,IAAI3rF,MAAMk9B,GACzB,IACI39B,EAAGypF,EADH4C,EAAO,GAAM1uD,EAAI,EAErB,IAAK39B,EAAI,EAAGA,EAAI29B,IAAK39B,EAEnBypF,EAAW,GACP9+E,EAAU,GAAK0hF,IACjB5C,GAAY,GAEV9+E,EAAU,GAAK0hF,IACjB5C,GAAY,GAEd2C,EAAOpsF,GAAKiH,OAAOyiF,aAAaD,GAChC4C,IAAS,EAEX,OAAOD,EAAOl1E,KAAK,GACrB,CA+SA,IAAAo1E,GA3NA,cAAuBC,GAIrB,WAAAruF,CAAY6K,GACV,MAAMyjF,OAA0B5nF,IAAlBmE,EAAQyjF,OAAsBzjF,EAAQyjF,MAEpDnpF,MAAM,CACJomC,UAAW1gC,EAAQ0gC,UACnBhP,YAAa,YACbxvB,YAAalC,EAAQkC,YACrB87E,QAAQ,EACRxpE,WAAYyP,GAAc,aAC1Bo+D,2BAA4BriF,EAAQqiF,2BACpCxgF,MAAO,UACP8vB,iBAAkB3xB,EAAQ2xB,iBAC1BusD,eAAgBuF,EAAQ,EAAI,EAC5BlvE,WAAyB1Y,IAAlBmE,EAAQuU,OAAsBvU,EAAQuU,MAC7CvS,WAAYhC,EAAQgC,WACpBu8E,WAAYv+E,EAAQu+E,aAOtBlpF,KAAKquF,OAASD,EAMdpuF,KAAKsuF,cAA+B9nF,IAApBmE,EAAQ4jF,QAAwB5jF,EAAQ4jF,QAAU,QAMlEvuF,KAAKwuF,cAA+BhoF,IAApBmE,EAAQyiC,QAAwBziC,EAAQyiC,SAAW,EAMnEptC,KAAKyuF,QAAU9jF,EAAQpD,IAMvBvH,KAAK0uF,YAAc/jF,EAAQgkF,WAM3B3uF,KAAK4uF,kBAAoBjkF,EAAQkkF,iBAEjC,MAAMjhB,EACJ,yDACA5tE,KAAK0uF,YACL,iDACA1uF,KAAKyuF,QACL,MACAzuF,KAAKsuF,SAEPQ,MAAMlhB,GACH75D,MAAM07D,GAAaA,EAASsf,SAC5Bh7E,MAAMg7E,GAAS/uF,KAAKgvF,8BAA8BD,IACtD,CAQD,SAAAE,GACE,OAAOjvF,KAAKyuF,OACb,CAQD,aAAAS,GACE,OAAOlvF,KAAK0uF,WACb,CAKD,6BAAAM,CAA8Bvf,GAC5B,GACyB,KAAvBA,EAAS0f,YACqB,MAA9B1f,EAAS2f,mBAC4B,oBAArC3f,EAAS4f,0BACuB,GAAhC5f,EAAS6f,aAAanuF,QACuB,GAA7CsuE,EAAS6f,aAAa,GAAGC,UAAUpuF,OAGnC,YADAnB,KAAK+M,SAAS,SAIhB,MAAMyiF,EAAW/f,EAAS6f,aAAa,GAAGC,UAAU,GAC9CniD,GAA4B,GAAlBptC,KAAKwuF,SAAiBgB,EAASC,QAAUzvF,KAAKwuF,SAGxDh1E,EAASuuE,GADU/nF,KAAK4uB,iBAExBjX,EAAQ3X,KAAKquF,OAAS,EAAI,EAC1BvI,EACJ0J,EAASE,YAAcF,EAASG,YAC5BH,EAASE,WAAa/3E,EACtB,CAAC63E,EAASE,WAAa/3E,EAAO63E,EAASG,YAAch4E,GAErDkK,EAAWsmE,GAAU,CACzB3uE,OAAQA,EACR2zB,QAASqiD,EAASI,QAClBxiD,QAASA,EACT04C,SAAUA,IAEZ9lF,KAAK6hB,SAAWA,EAEhB,MAAM0sE,EAAUvuF,KAAKsuF,SACfF,EAAQpuF,KAAKquF,OACbQ,EAAmB7uF,KAAK4uF,kBA4C9B,GA3CA5uF,KAAK2rF,gBAAkBd,GACrB2E,EAASK,mBAAmB/kD,KAAI,SAAUglD,GAExC,MAAMC,EAAmB,CAAC,EAAG,EAAG,GAC1BC,EAAWR,EAASQ,SACvBxsE,QAAQ,cAAessE,GACvBtsE,QAAQ,YAAa+qE,GACxB,OAAA,SAOYhiF,EAAW6uB,EAAYjc,GAC/B,IAAK5S,EACH,OAEFmO,GACEnO,EAAU,GACVA,EAAU,GACVA,EAAU,GACVwjF,GAEF,MAAMniB,EAAM,IAAImC,IACdigB,EAASxsE,QAAQ,YAAauqE,GAAQgC,KAElCE,EAASriB,EAAIsiB,aAUnB,OATI9B,IACF6B,EAAOlmF,IAAI,MAAO,MAClBkmF,EAAOlmF,IAAI,SAAU,YAEE,IAArB8kF,EACFoB,EAAOE,OAAO,MACgB,IAArBtB,GACToB,EAAOlmF,IAAI,IAAK,KAEX6jE,EAAIh1D,UAEb,CACV,KAGQ42E,EAASY,iBAAkB,CAC7B,MAAMp6E,EAAYkU,GAChB0E,GAAc,aACd5uB,KAAK4uB,iBAGP5uB,KAAKolF,iBAAiB3nC,IACpB,MAAMS,EAAe,GACf1E,EAAYiE,EAAWjE,UACvB33B,EAAW7hB,KAAK4pF,cAChBrqD,EAAI1d,EAAS8hE,kBACjBnqC,EAAU78B,WACV3c,KAAKkpF,YAMD9zC,EAJYvzB,EAAS0lE,yBACzB/tC,EAAU98B,OACV6iB,GAEqB,GAsBvB,OArBAiwD,EAASY,iBAAiBtlD,KAAI,SAAUulD,GACtC,IAAIC,GAAe,EACnB,MAAMC,EAAgBF,EAAgBE,cACtC,IAAK,IAAI3uF,EAAI,EAAGuE,EAAKoqF,EAAcpvF,OAAQS,EAAIuE,IAAMvE,EAAG,CACtD,MAAM4uF,EAAeD,EAAc3uF,GACnC,GAAIwzC,GAAQo7C,EAAaZ,SAAWx6C,GAAQo7C,EAAaf,QAAS,CAChE,MAAMgB,EAAOD,EAAaC,KAG1B,GAAI3yE,GADWa,GADQ,CAAC8xE,EAAK,GAAIA,EAAK,GAAIA,EAAK,GAAIA,EAAK,IACVz6E,GACvBynC,EAAWjkC,QAAS,CACzC82E,GAAe,EACf,KACD,CACF,CACF,CACGA,GACFpyC,EAAav4C,KAAK0qF,EAAgBj8B,YAE9C,IAEQlW,EAAav4C,KA7RnB,gIA8Rau4C,CAAY,GAEtB,CAEDl+C,KAAK+M,SAAS,QACf,GC7MH,IAAA2jF,GAxDA,cAAkBvC,GAIhB,WAAAruF,CAAY6K,GAGV,MAAMwU,OACmB3Y,KAHzBmE,EAAUA,GAAW,IAGXwU,WAA2BxU,EAAQwU,WAAa,YAEpD0C,OACiBrb,IAArBmE,EAAQkX,SACJlX,EAAQkX,SACRsmE,GAAU,CACR3uE,OAAQuuE,GAAqB5oE,GAC7B8tB,cAAetiC,EAAQsiC,cACvBG,QAASziC,EAAQyiC,QACjBD,QAASxiC,EAAQwiC,QACjB24C,SAAUn7E,EAAQm7E,WAG1B7gF,MAAM,CACJi5C,aAAcvzC,EAAQuzC,aACtB7S,UAAW1gC,EAAQ0gC,UACnBhP,YAAa1xB,EAAQ0xB,YACrBxvB,YAAalC,EAAQkC,YACrB87E,OAAQh+E,EAAQg+E,OAChBxpE,WAAYA,EACZ6tE,2BAA4BriF,EAAQqiF,2BACpCnrE,SAAUA,EACVya,iBAAkB3xB,EAAQ2xB,iBAC1BusD,eAAgBl+E,EAAQk+E,eACxB8C,gBAAiBhhF,EAAQghF,gBACzB/d,IAAKjjE,EAAQijE,IACbqd,KAAMtgF,EAAQsgF,KACd/rE,WAAyB1Y,IAAlBmE,EAAQuU,OAAsBvU,EAAQuU,MAC7CvS,WAAYhC,EAAQgC,WACpBi4E,wBAAyBj6E,EAAQi6E,wBACjCsE,WAAYv+E,EAAQu+E,aAOtBlpF,KAAK6iF,aAA6Br8E,IAAnBmE,EAAQ6yE,OAAuB7yE,EAAQ6yE,OAAS,CAChE,CAKD,SAAA2P,GACE,OAAOntF,KAAK6iF,OACb,GC6EH,IAAA8N,GA7JA,cAAsBC,GAIpB,WAAA9wF,CAAY6K,GACV1F,MAAM,CACJi5C,aAAcvzC,EAAQuzC,aACtB7S,UAAW1gC,EAAQ0gC,UACnBhP,YAAa1xB,EAAQ0xB,YACrB+Q,aAA6B5mC,IAApBmE,EAAQyiC,QAAwBziC,EAAQyiC,QAAU,GAC3DD,QAASxiC,EAAQwiC,QACjBhuB,WAAYxU,EAAQwU,WACpBxS,WAAYhC,EAAQgC,WACpBuS,MAAOvU,EAAQuU,MACfgqE,WAAYv+E,EAAQu+E,aAOtBlpF,KAAK6wF,SAAWlmF,EAAQmmF,QAMxB9wF,KAAK+wF,OAASpmF,EAAQmgC,KAAO,GAM7B9qC,KAAKgxF,QAAUrmF,EAAQsmF,QAAU,CAAA,EAMjCjxF,KAAKkxF,eAAiB,GAEtBlxF,KAAKmxF,gBACN,CAOD,SAAAC,GACE,OAAOpxF,KAAKgxF,OACb,CAQD,YAAAK,CAAaJ,GACXvqF,OAAO8C,OAAOxJ,KAAKgxF,QAASC,GAC5BjxF,KAAKmxF,gBACN,CASD,SAAAG,CAAUL,GACRjxF,KAAKgxF,QAAUC,GAAU,GACzBjxF,KAAKmxF,gBACN,CAMD,cAAAA,GACE,MAAMI,EAAYljB,KAAKmjB,UAAUxxF,KAAKgxF,SACtC,GAAIhxF,KAAKkxF,eAAeK,GAEtB,YADAvxF,KAAKyxF,eAAezxF,KAAKkxF,eAAeK,IAG1C,IAAIG,EAAS,WAAa1xF,KAAK6wF,SAAW,wBAEtC7wF,KAAK+wF,SACPW,GAAU,UAAY1xF,KAAK+wF,QAG7B,MAAMphB,EAAS,IAAI3B,eACnB2B,EAAOrqE,iBACL,OACAtF,KAAK2xF,oBAAoBzqF,KAAKlH,KAAMuxF,IAEtC5hB,EAAOrqE,iBAAiB,QAAStF,KAAK4xF,iBAAiB1qF,KAAKlH,OAC5D2vE,EAAO1B,KAAK,OAAQyjB,GACpB/hB,EAAOE,iBAAiB,eAAgB,oBACxCF,EAAOb,KAAKT,KAAKmjB,UAAUxxF,KAAKgxF,SACjC,CASD,mBAAAW,CAAoBJ,EAAW1rF,GAC7B,MAAM8pE,EAAwC9pE,EAAY,OAE1D,IAAK8pE,EAAOvB,QAAWuB,EAAOvB,QAAU,KAAOuB,EAAOvB,OAAS,IAAM,CACnE,IAAIqB,EACJ,IACEA,EACEpB,KAAKnjC,MAAMykC,EAAOrB,aAErB,CAAC,MAAOhqE,GAEP,YADAtE,KAAK+M,SAAS,QAEf,CACD/M,KAAKyxF,eAAehiB,GACpBzvE,KAAKkxF,eAAeK,GAAa9hB,EACjCzvE,KAAK+M,SAAS,QACpB,MACM/M,KAAK+M,SAAS,QAEjB,CAMD,gBAAA6kF,CAAiB/rF,GACf7F,KAAK+M,SAAS,QACf,CAOD,cAAA0kF,CAAetvF,GACb,MAAM0vF,EACJ,WACA1vF,EAAK2vF,QAAQC,MACb,IACA/xF,KAAK6wF,SACL,eACA1uF,EAAK6vF,aACL,mBACFhyF,KAAK6rF,OAAOgG,EACb,GCtMY,SAASI,GAAYxwF,EAAK+iB,EAAG+/B,EAAMhvB,EAAOzyB,GACrDovF,GAAgBzwF,EAAK+iB,EAAG+/B,GAAQ,EAAGhvB,GAAU9zB,EAAIN,OAAS,EAAI2B,GAAWqvF,GAC7E,CAEA,SAASD,GAAgBzwF,EAAK+iB,EAAG+/B,EAAMhvB,EAAOzyB,GAE1C,KAAOyyB,EAAQgvB,GAAM,CACjB,GAAIhvB,EAAQgvB,EAAO,IAAK,CACpB,IAAI5iD,EAAI4zB,EAAQgvB,EAAO,EACnBpkC,EAAIqE,EAAI+/B,EAAO,EACfhlB,EAAItzB,KAAKsW,IAAI5gB,GACbooC,EAAI,GAAM99B,KAAKoX,IAAI,EAAIkc,EAAI,GAC3B6yD,EAAK,GAAMnmF,KAAKma,KAAKmZ,EAAIwK,GAAKpoC,EAAIooC,GAAKpoC,IAAMwe,EAAIxe,EAAI,EAAI,GAAK,EAAI,GAGtEuwF,GAAgBzwF,EAAK+iB,EAFPvY,KAAKyP,IAAI6oC,EAAMt4C,KAAKuT,MAAMgF,EAAIrE,EAAI4pB,EAAIpoC,EAAIywF,IACzCnmF,KAAKwP,IAAI8Z,EAAOtpB,KAAKuT,MAAMgF,GAAK7iB,EAAIwe,GAAK4pB,EAAIpoC,EAAIywF,IACrBtvF,EAC9C,CAED,IAAIkJ,EAAIvK,EAAI+iB,GACR5iB,EAAI2iD,EACJjgC,EAAIiR,EAKR,IAHA88D,GAAK5wF,EAAK8iD,EAAM//B,GACZ1hB,EAAQrB,EAAI8zB,GAAQvpB,GAAK,GAAGqmF,GAAK5wF,EAAK8iD,EAAMhvB,GAEzC3zB,EAAI0iB,GAAG,CAIV,IAHA+tE,GAAK5wF,EAAKG,EAAG0iB,GACb1iB,IACA0iB,IACOxhB,EAAQrB,EAAIG,GAAIoK,GAAK,GAAGpK,IAC/B,KAAOkB,EAAQrB,EAAI6iB,GAAItY,GAAK,GAAGsY,GAClC,CAE6B,IAA1BxhB,EAAQrB,EAAI8iD,GAAOv4C,GAAUqmF,GAAK5wF,EAAK8iD,EAAMjgC,GAG7C+tE,GAAK5wF,IADL6iB,EACaiR,GAGbjR,GAAKE,IAAG+/B,EAAOjgC,EAAI,GACnBE,GAAKF,IAAGiR,EAAQjR,EAAI,EAC3B,CACL,CAEA,SAAS+tE,GAAK5wF,EAAKG,EAAG0iB,GAClB,IAAIriB,EAAMR,EAAIG,GACdH,EAAIG,GAAKH,EAAI6iB,GACb7iB,EAAI6iB,GAAKriB,CACb,CAEA,SAASkwF,GAAe9wF,EAAGC,GACvB,OAAOD,EAAIC,GAAK,EAAID,EAAIC,EAAI,EAAI,CACpC,CCnDe,IAAAgxF,GAAA,MACX,WAAAxyF,CAAYyyF,EAAa,GAErBvyF,KAAKwyF,YAAcvmF,KAAKyP,IAAI,EAAG62E,GAC/BvyF,KAAKyyF,YAAcxmF,KAAKyP,IAAI,EAAGzP,KAAKkZ,KAAwB,GAAnBnlB,KAAKwyF,cAC9CxyF,KAAK2E,OACR,CAED,GAAAuxD,GACI,OAAOl2D,KAAK0yF,KAAK1yF,KAAKmC,KAAM,GAC/B,CAED,MAAAwwF,CAAOlC,GACH,IAAIl/E,EAAOvR,KAAKmC,KAChB,MAAMsuC,EAAS,GAEf,IAAK3yB,GAAW2yE,EAAMl/E,GAAO,OAAOk/B,EAEpC,MAAMmiD,EAAS5yF,KAAK4yF,OACdC,EAAgB,GAEtB,KAAOthF,GAAM,CACT,IAAK,IAAI3P,EAAI,EAAGA,EAAI2P,EAAKK,SAASzQ,OAAQS,IAAK,CAC3C,MAAMkxF,EAAQvhF,EAAKK,SAAShQ,GACtBmxF,EAAYxhF,EAAKyhF,KAAOJ,EAAOE,GAASA,EAE1Ch1E,GAAW2yE,EAAMsC,KACbxhF,EAAKyhF,KAAMviD,EAAO9qC,KAAKmtF,GAClB9/B,GAASy9B,EAAMsC,GAAY/yF,KAAK0yF,KAAKI,EAAOriD,GAChDoiD,EAAcltF,KAAKmtF,GAE/B,CACDvhF,EAAOshF,EAAc3nF,KACxB,CAED,OAAOulC,CACV,CAED,QAAAwiD,CAASxC,GACL,IAAIl/E,EAAOvR,KAAKmC,KAEhB,IAAK2b,GAAW2yE,EAAMl/E,GAAO,OAAO,EAEpC,MAAMshF,EAAgB,GACtB,KAAOthF,GAAM,CACT,IAAK,IAAI3P,EAAI,EAAGA,EAAI2P,EAAKK,SAASzQ,OAAQS,IAAK,CAC3C,MAAMkxF,EAAQvhF,EAAKK,SAAShQ,GACtBmxF,EAAYxhF,EAAKyhF,KAAOhzF,KAAK4yF,OAAOE,GAASA,EAEnD,GAAIh1E,GAAW2yE,EAAMsC,GAAY,CAC7B,GAAIxhF,EAAKyhF,MAAQhgC,GAASy9B,EAAMsC,GAAY,OAAO,EACnDF,EAAcltF,KAAKmtF,EACtB,CACJ,CACDvhF,EAAOshF,EAAc3nF,KACxB,CAED,OAAO,CACV,CAED,IAAAoC,CAAKnL,GACD,IAAMA,IAAQA,EAAKhB,OAAS,OAAOnB,KAEnC,GAAImC,EAAKhB,OAASnB,KAAKyyF,YAAa,CAChC,IAAK,IAAI7wF,EAAI,EAAGA,EAAIO,EAAKhB,OAAQS,IAC7B5B,KAAKkzF,OAAO/wF,EAAKP,IAErB,OAAO5B,IACV,CAGD,IAAIuR,EAAOvR,KAAKmzF,OAAOhxF,EAAK2B,QAAS,EAAG3B,EAAKhB,OAAS,EAAG,GAEzD,GAAKnB,KAAKmC,KAAKyP,SAASzQ,OAIjB,GAAInB,KAAKmC,KAAKuN,SAAW6B,EAAK7B,OAEjC1P,KAAKozF,WAAWpzF,KAAKmC,KAAMoP,OAExB,CACH,GAAIvR,KAAKmC,KAAKuN,OAAS6B,EAAK7B,OAAQ,CAEhC,MAAM2jF,EAAUrzF,KAAKmC,KACrBnC,KAAKmC,KAAOoP,EACZA,EAAO8hF,CACV,CAGDrzF,KAAKszF,QAAQ/hF,EAAMvR,KAAKmC,KAAKuN,OAAS6B,EAAK7B,OAAS,GAAG,EAC1D,MAhBG1P,KAAKmC,KAAOoP,EAkBhB,OAAOvR,IACV,CAED,MAAAkzF,CAAO5nF,GAEH,OADIA,GAAMtL,KAAKszF,QAAQhoF,EAAMtL,KAAKmC,KAAKuN,OAAS,GACzC1P,IACV,CAED,KAAA2E,GAEI,OADA3E,KAAKmC,KAAOoxF,GAAW,IAChBvzF,IACV,CAED,MAAA0L,CAAOJ,EAAMkoF,GACT,IAAKloF,EAAM,OAAOtL,KAElB,IAAIuR,EAAOvR,KAAKmC,KAChB,MAAMsuF,EAAOzwF,KAAK4yF,OAAOtnF,GACnBmoF,EAAO,GACPC,EAAU,GAChB,IAAI9xF,EAAGuP,EAAQwiF,EAGf,KAAOpiF,GAAQkiF,EAAKtyF,QAAQ,CASxB,GAPKoQ,IACDA,EAAOkiF,EAAKvoF,MACZiG,EAASsiF,EAAKA,EAAKtyF,OAAS,GAC5BS,EAAI8xF,EAAQxoF,MACZyoF,GAAU,GAGVpiF,EAAKyhF,KAAM,CACX,MAAM/vF,EAAQ2wF,GAAStoF,EAAMiG,EAAKK,SAAU4hF,GAE5C,IAAe,IAAXvwF,EAKA,OAHAsO,EAAKK,SAAS/K,OAAO5D,EAAO,GAC5BwwF,EAAK9tF,KAAK4L,GACVvR,KAAK6zF,UAAUJ,GACRzzF,IAEd,CAEI2zF,GAAYpiF,EAAKyhF,OAAQhgC,GAASzhD,EAAMk/E,GAOlCt/E,GACPvP,IACA2P,EAAOJ,EAAOS,SAAShQ,GACvB+xF,GAAU,GAEPpiF,EAAO,MAXVkiF,EAAK9tF,KAAK4L,GACVmiF,EAAQ/tF,KAAK/D,GACbA,EAAI,EACJuP,EAASI,EACTA,EAAOA,EAAKK,SAAS,GAQ5B,CAED,OAAO5R,IACV,CAED,MAAA4yF,CAAOtnF,GAAQ,OAAOA,CAAO,CAE7B,WAAAwoF,CAAYzyF,EAAGC,GAAK,OAAOD,EAAE+Y,KAAO9Y,EAAE8Y,IAAO,CAC7C,WAAA25E,CAAY1yF,EAAGC,GAAK,OAAOD,EAAEgZ,KAAO/Y,EAAE+Y,IAAO,CAE7C,MAAA25E,GAAW,OAAOh0F,KAAKmC,IAAO,CAE9B,QAAA8xF,CAAS9xF,GAEL,OADAnC,KAAKmC,KAAOA,EACLnC,IACV,CAED,IAAA0yF,CAAKnhF,EAAMk/B,GACP,MAAMoiD,EAAgB,GACtB,KAAOthF,GACCA,EAAKyhF,KAAMviD,EAAO9qC,QAAQ4L,EAAKK,UAC9BihF,EAAcltF,QAAQ4L,EAAKK,UAEhCL,EAAOshF,EAAc3nF,MAEzB,OAAOulC,CACV,CAED,MAAA0iD,CAAOe,EAAO3vC,EAAMhvB,EAAO7lB,GAEvB,MAAMykF,EAAI5+D,EAAQgvB,EAAO,EACzB,IACIhzC,EADA6iF,EAAIp0F,KAAKwyF,YAGb,GAAI2B,GAAKC,EAIL,OAFA7iF,EAAOgiF,GAAWW,EAAMpwF,MAAMygD,EAAMhvB,EAAQ,IAC5C8+D,GAAS9iF,EAAMvR,KAAK4yF,QACbrhF,EAGN7B,IAEDA,EAASzD,KAAKkZ,KAAKlZ,KAAKsW,IAAI4xE,GAAKloF,KAAKsW,IAAI6xE,IAG1CA,EAAInoF,KAAKkZ,KAAKgvE,EAAIloF,KAAKC,IAAIkoF,EAAG1kF,EAAS,KAG3C6B,EAAOgiF,GAAW,IAClBhiF,EAAKyhF,MAAO,EACZzhF,EAAK7B,OAASA,EAId,MAAM4kF,EAAKroF,KAAKkZ,KAAKgvE,EAAIC,GACnBG,EAAKD,EAAKroF,KAAKkZ,KAAKlZ,KAAKma,KAAKguE,IAEpCI,GAAYN,EAAO3vC,EAAMhvB,EAAOg/D,EAAIv0F,KAAK8zF,aAEzC,IAAK,IAAIlyF,EAAI2iD,EAAM3iD,GAAK2zB,EAAO3zB,GAAK2yF,EAAI,CAEpC,MAAME,EAASxoF,KAAKwP,IAAI7Z,EAAI2yF,EAAK,EAAGh/D,GAEpCi/D,GAAYN,EAAOtyF,EAAG6yF,EAAQH,EAAIt0F,KAAK+zF,aAEvC,IAAK,IAAIzvE,EAAI1iB,EAAG0iB,GAAKmwE,EAAQnwE,GAAKgwE,EAAI,CAElC,MAAMI,EAASzoF,KAAKwP,IAAI6I,EAAIgwE,EAAK,EAAGG,GAGpCljF,EAAKK,SAASjM,KAAK3F,KAAKmzF,OAAOe,EAAO5vE,EAAGowE,EAAQhlF,EAAS,GAC7D,CACJ,CAID,OAFA2kF,GAAS9iF,EAAMvR,KAAK4yF,QAEbrhF,CACV,CAED,cAAAojF,CAAelE,EAAMl/E,EAAM0X,EAAOwqE,GAC9B,KACIA,EAAK9tF,KAAK4L,IAENA,EAAKyhF,MAAQS,EAAKtyF,OAAS,IAAM8nB,GAH5B,CAKT,IAEI2rE,EAFA16B,EAAUz/C,IACVo6E,EAAiBp6E,IAGrB,IAAK,IAAI7Y,EAAI,EAAGA,EAAI2P,EAAKK,SAASzQ,OAAQS,IAAK,CAC3C,MAAMkxF,EAAQvhF,EAAKK,SAAShQ,GACtBua,EAAO24E,GAAShC,GAChBiC,GAgNA1zF,EAhN2BovF,EAgNxBnvF,EAhN8BwxF,GAiN3C7mF,KAAKyP,IAAIpa,EAAEgZ,KAAMjZ,EAAEiZ,MAAQrO,KAAKwP,IAAIna,EAAE8Y,KAAM/Y,EAAE+Y,QAC9CnO,KAAKyP,IAAIpa,EAAEiZ,KAAMlZ,EAAEkZ,MAAQtO,KAAKwP,IAAIna,EAAE+Y,KAAMhZ,EAAEgZ,OAlNM8B,GAG5C44E,EAAcF,GACdA,EAAiBE,EACjB76B,EAAU/9C,EAAO+9C,EAAU/9C,EAAO+9C,EAClC06B,EAAa9B,GAENiC,IAAgBF,GAEnB14E,EAAO+9C,IACPA,EAAU/9C,EACVy4E,EAAa9B,EAGxB,CAEDvhF,EAAOqjF,GAAcrjF,EAAKK,SAAS,EACtC,CA8LT,IAAsBvQ,EAAGC,EA5LjB,OAAOiQ,CACV,CAED,OAAA+hF,CAAQhoF,EAAM2d,EAAO+rE,GACjB,MAAMvE,EAAOuE,EAAS1pF,EAAOtL,KAAK4yF,OAAOtnF,GACnC2pF,EAAa,GAGb1jF,EAAOvR,KAAK20F,eAAelE,EAAMzwF,KAAKmC,KAAM8mB,EAAOgsE,GAOzD,IAJA1jF,EAAKK,SAASjM,KAAK2F,GACnBpJ,GAAOqP,EAAMk/E,GAGNxnE,GAAS,GACRgsE,EAAWhsE,GAAOrX,SAASzQ,OAASnB,KAAKwyF,aACzCxyF,KAAKk1F,OAAOD,EAAYhsE,GACxBA,IAKRjpB,KAAKm1F,oBAAoB1E,EAAMwE,EAAYhsE,EAC9C,CAGD,MAAAisE,CAAOD,EAAYhsE,GACf,MAAM1X,EAAO0jF,EAAWhsE,GAClBmrE,EAAI7iF,EAAKK,SAASzQ,OAClBgf,EAAIngB,KAAKyyF,YAEfzyF,KAAKo1F,iBAAiB7jF,EAAM4O,EAAGi0E,GAE/B,MAAMiB,EAAar1F,KAAKs1F,kBAAkB/jF,EAAM4O,EAAGi0E,GAE7CnjF,EAAUsiF,GAAWhiF,EAAKK,SAAS/K,OAAOwuF,EAAY9jF,EAAKK,SAASzQ,OAASk0F,IACnFpkF,EAAQvB,OAAS6B,EAAK7B,OACtBuB,EAAQ+hF,KAAOzhF,EAAKyhF,KAEpBqB,GAAS9iF,EAAMvR,KAAK4yF,QACpByB,GAASpjF,EAASjR,KAAK4yF,QAEnB3pE,EAAOgsE,EAAWhsE,EAAQ,GAAGrX,SAASjM,KAAKsL,GAC1CjR,KAAKozF,WAAW7hF,EAAMN,EAC9B,CAED,UAAAmiF,CAAW7hF,EAAMN,GAEbjR,KAAKmC,KAAOoxF,GAAW,CAAChiF,EAAMN,IAC9BjR,KAAKmC,KAAKuN,OAAS6B,EAAK7B,OAAS,EACjC1P,KAAKmC,KAAK6wF,MAAO,EACjBqB,GAASr0F,KAAKmC,KAAMnC,KAAK4yF,OAC5B,CAED,iBAAA0C,CAAkB/jF,EAAM4O,EAAGi0E,GACvB,IAAInxF,EACAsyF,EAAa96E,IACby/C,EAAUz/C,IAEd,IAAK,IAAI7Y,EAAIue,EAAGve,GAAKwyF,EAAIj0E,EAAGve,IAAK,CAC7B,MAAM4zF,EAAQC,GAASlkF,EAAM,EAAG3P,EAAG5B,KAAK4yF,QAClC8C,EAAQD,GAASlkF,EAAM3P,EAAGwyF,EAAGp0F,KAAK4yF,QAElC+C,EAAUC,GAAiBJ,EAAOE,GAClCv5E,EAAO24E,GAASU,GAASV,GAASY,GAGpCC,EAAUJ,GACVA,EAAaI,EACb1yF,EAAQrB,EAERs4D,EAAU/9C,EAAO+9C,EAAU/9C,EAAO+9C,GAE3By7B,IAAYJ,GAEfp5E,EAAO+9C,IACPA,EAAU/9C,EACVlZ,EAAQrB,EAGnB,CAED,OAAOqB,GAASmxF,EAAIj0E,CACvB,CAGD,gBAAAi1E,CAAiB7jF,EAAM4O,EAAGi0E,GACtB,MAAMN,EAAcviF,EAAKyhF,KAAOhzF,KAAK8zF,YAAc+B,GAC7C9B,EAAcxiF,EAAKyhF,KAAOhzF,KAAK+zF,YAAc+B,GACnC91F,KAAK+1F,eAAexkF,EAAM4O,EAAGi0E,EAAGN,GAChC9zF,KAAK+1F,eAAexkF,EAAM4O,EAAGi0E,EAAGL,IAIzBxiF,EAAKK,SAAS0iB,KAAKw/D,EAC7C,CAGD,cAAAiC,CAAexkF,EAAM4O,EAAGi0E,EAAGtxF,GACvByO,EAAKK,SAAS0iB,KAAKxxB,GAEnB,MAAM8vF,EAAS5yF,KAAK4yF,OACdoD,EAAWP,GAASlkF,EAAM,EAAG4O,EAAGyyE,GAChCqD,EAAYR,GAASlkF,EAAM6iF,EAAIj0E,EAAGi0E,EAAGxB,GAC3C,IAAItqB,EAAS4tB,GAAWF,GAAYE,GAAWD,GAE/C,IAAK,IAAIr0F,EAAIue,EAAGve,EAAIwyF,EAAIj0E,EAAGve,IAAK,CAC5B,MAAMkxF,EAAQvhF,EAAKK,SAAShQ,GAC5BM,GAAO8zF,EAAUzkF,EAAKyhF,KAAOJ,EAAOE,GAASA,GAC7CxqB,GAAU4tB,GAAWF,EACxB,CAED,IAAK,IAAIp0F,EAAIwyF,EAAIj0E,EAAI,EAAGve,GAAKue,EAAGve,IAAK,CACjC,MAAMkxF,EAAQvhF,EAAKK,SAAShQ,GAC5BM,GAAO+zF,EAAW1kF,EAAKyhF,KAAOJ,EAAOE,GAASA,GAC9CxqB,GAAU4tB,GAAWD,EACxB,CAED,OAAO3tB,CACV,CAED,mBAAA6sB,CAAoB1E,EAAMgD,EAAMxqE,GAE5B,IAAK,IAAIrnB,EAAIqnB,EAAOrnB,GAAK,EAAGA,IACxBM,GAAOuxF,EAAK7xF,GAAI6uF,EAEvB,CAED,SAAAoD,CAAUJ,GAEN,IAAK,IAAyB0C,EAArBv0F,EAAI6xF,EAAKtyF,OAAS,EAAaS,GAAK,EAAGA,IACZ,IAA5B6xF,EAAK7xF,GAAGgQ,SAASzQ,OACbS,EAAI,GACJu0F,EAAW1C,EAAK7xF,EAAI,GAAGgQ,SACvBukF,EAAStvF,OAAOsvF,EAASvvF,QAAQ6sF,EAAK7xF,IAAK,IAExC5B,KAAK2E,QAET0vF,GAASZ,EAAK7xF,GAAI5B,KAAK4yF,OAErC,GAGL,SAASgB,GAAStoF,EAAM4oF,EAAOV,GAC3B,IAAKA,EAAU,OAAOU,EAAMttF,QAAQ0E,GAEpC,IAAK,IAAI1J,EAAI,EAAGA,EAAIsyF,EAAM/yF,OAAQS,IAC9B,GAAI4xF,EAASloF,EAAM4oF,EAAMtyF,IAAK,OAAOA,EAEzC,OAAQ,CACZ,CAGA,SAASyyF,GAAS9iF,EAAMqhF,GACpB6C,GAASlkF,EAAM,EAAGA,EAAKK,SAASzQ,OAAQyxF,EAAQrhF,EACpD,CAGA,SAASkkF,GAASlkF,EAAMiT,EAAG4xE,EAAGxD,EAAQyD,GAC7BA,IAAUA,EAAW9C,GAAW,OACrC8C,EAASj8E,KAAOK,IAChB47E,EAASh8E,KAAOI,IAChB47E,EAAS/7E,MAAQG,IACjB47E,EAAS97E,MAAQE,IAEjB,IAAK,IAAI7Y,EAAI4iB,EAAG5iB,EAAIw0F,EAAGx0F,IAAK,CACxB,MAAMkxF,EAAQvhF,EAAKK,SAAShQ,GAC5BM,GAAOm0F,EAAU9kF,EAAKyhF,KAAOJ,EAAOE,GAASA,EAChD,CAED,OAAOuD,CACX,CAEA,SAASn0F,GAAOb,EAAGC,GAKf,OAJAD,EAAE+Y,KAAOnO,KAAKwP,IAAIpa,EAAE+Y,KAAM9Y,EAAE8Y,MAC5B/Y,EAAEgZ,KAAOpO,KAAKwP,IAAIpa,EAAEgZ,KAAM/Y,EAAE+Y,MAC5BhZ,EAAEiZ,KAAOrO,KAAKyP,IAAIra,EAAEiZ,KAAMhZ,EAAEgZ,MAC5BjZ,EAAEkZ,KAAOtO,KAAKyP,IAAIra,EAAEkZ,KAAMjZ,EAAEiZ,MACrBlZ,CACX,CAEA,SAASw0F,GAAgBx0F,EAAGC,GAAK,OAAOD,EAAE+Y,KAAO9Y,EAAE8Y,IAAO,CAC1D,SAAS07E,GAAgBz0F,EAAGC,GAAK,OAAOD,EAAEgZ,KAAO/Y,EAAE+Y,IAAO,CAE1D,SAASy6E,GAASzzF,GAAO,OAAQA,EAAEiZ,KAAOjZ,EAAE+Y,OAAS/Y,EAAEkZ,KAAOlZ,EAAEgZ,KAAQ,CACxE,SAAS67E,GAAW70F,GAAK,OAAQA,EAAEiZ,KAAOjZ,EAAE+Y,MAAS/Y,EAAEkZ,KAAOlZ,EAAEgZ,KAAQ,CAOxE,SAASu7E,GAAiBv0F,EAAGC,GACzB,MAAM8Y,EAAOnO,KAAKyP,IAAIra,EAAE+Y,KAAM9Y,EAAE8Y,MAC1BC,EAAOpO,KAAKyP,IAAIra,EAAEgZ,KAAM/Y,EAAE+Y,MAC1BC,EAAOrO,KAAKwP,IAAIpa,EAAEiZ,KAAMhZ,EAAEgZ,MAC1BC,EAAOtO,KAAKwP,IAAIpa,EAAEkZ,KAAMjZ,EAAEiZ,MAEhC,OAAOtO,KAAKyP,IAAI,EAAGpB,EAAOF,GACnBnO,KAAKyP,IAAI,EAAGnB,EAAOF,EAC9B,CAEA,SAAS24C,GAAS3xD,EAAGC,GACjB,OAAOD,EAAE+Y,MAAQ9Y,EAAE8Y,MACZ/Y,EAAEgZ,MAAQ/Y,EAAE+Y,MACZ/Y,EAAEgZ,MAAQjZ,EAAEiZ,MACZhZ,EAAEiZ,MAAQlZ,EAAEkZ,IACvB,CAEA,SAASuD,GAAWzc,EAAGC,GACnB,OAAOA,EAAE8Y,MAAQ/Y,EAAEiZ,MACZhZ,EAAE+Y,MAAQhZ,EAAEkZ,MACZjZ,EAAEgZ,MAAQjZ,EAAE+Y,MACZ9Y,EAAEiZ,MAAQlZ,EAAEgZ,IACvB,CAEA,SAASk5E,GAAW3hF,GAChB,MAAO,CACHA,WACAlC,OAAQ,EACRsjF,MAAM,EACN54E,KAAMK,IACNJ,KAAMI,IACNH,MAAOG,IACPF,MAAOE,IAEf,CAKA,SAAS+5E,GAAY/yF,EAAK8iD,EAAMhvB,EAAO5zB,EAAGmB,GACtC,MAAMivB,EAAQ,CAACwyB,EAAMhvB,GAErB,KAAOxD,EAAM5wB,QAAQ,CAIjB,IAHAo0B,EAAQxD,EAAM7mB,QACdq5C,EAAOxyB,EAAM7mB,QAEOvJ,EAAG,SAEvB,MAAMb,EAAMyjD,EAAOt4C,KAAKkZ,MAAMoQ,EAAQgvB,GAAQ5iD,EAAI,GAAKA,EACvDswF,GAAYxwF,EAAKX,EAAKyjD,EAAMhvB,EAAOzyB,GAEnCivB,EAAMpsB,KAAK4+C,EAAMzjD,EAAKA,EAAKy0B,EAC9B,CACL,CCpSA,IAAA+gE,GAnMA,MAIE,WAAAx2F,CAAYyyF,GAIVvyF,KAAKu2F,OAAS,IAAIC,GAAOjE,GAQzBvyF,KAAKy2F,OAAS,EACf,CAOD,MAAAvD,CAAO15E,EAAQnV,GAEb,MAAMiH,EAAO,CACX8O,KAAMZ,EAAO,GACba,KAAMb,EAAO,GACbc,KAAMd,EAAO,GACbe,KAAMf,EAAO,GACbnV,MAAOA,GAGTrE,KAAKu2F,OAAOrD,OAAO5nF,GACnBtL,KAAKy2F,OAAO/tF,EAAOrE,IAAUiH,CAC9B,CAOD,IAAAgC,CAAKopF,EAASztF,GACZ,MAAMirF,EAAQ,IAAI7xF,MAAM4G,EAAO9H,QAC/B,IAAK,IAAIS,EAAI,EAAGod,EAAI/V,EAAO9H,OAAQS,EAAIod,EAAGpd,IAAK,CAC7C,MAAM4X,EAASk9E,EAAQ90F,GACjByC,EAAQ4E,EAAOrH,GAGf0J,EAAO,CACX8O,KAAMZ,EAAO,GACba,KAAMb,EAAO,GACbc,KAAMd,EAAO,GACbe,KAAMf,EAAO,GACbnV,MAAOA,GAET6vF,EAAMtyF,GAAK0J,EACXtL,KAAKy2F,OAAO/tF,EAAOrE,IAAUiH,CAC9B,CACDtL,KAAKu2F,OAAOjpF,KAAK4mF,EAClB,CAOD,MAAAxoF,CAAOrH,GACL,MAAM8nF,EAAMzjF,EAAOrE,GAIbiH,EAAOtL,KAAKy2F,OAAOtK,GAEzB,cADOnsF,KAAKy2F,OAAOtK,GACiB,OAA7BnsF,KAAKu2F,OAAO7qF,OAAOJ,EAC3B,CAOD,MAAAwyB,CAAOtkB,EAAQnV,GACb,MAAMiH,EAAOtL,KAAKy2F,OAAO/tF,EAAOrE,IAE3B9B,GADQ,CAAC+I,EAAK8O,KAAM9O,EAAK+O,KAAM/O,EAAKgP,KAAMhP,EAAKiP,MAClCf,KAChBxZ,KAAK0L,OAAOrH,GACZrE,KAAKkzF,OAAO15E,EAAQnV,GAEvB,CAMD,MAAAsyF,GAEE,OADc32F,KAAKu2F,OAAOrgC,MACbprB,KAAI,SAAUx/B,GACzB,OAAOA,EAAKjH,KAClB,GACG,CAOD,WAAAuyF,CAAYp9E,GAEV,MAAMi3E,EAAO,CACXr2E,KAAMZ,EAAO,GACba,KAAMb,EAAO,GACbc,KAAMd,EAAO,GACbe,KAAMf,EAAO,IAGf,OADcxZ,KAAKu2F,OAAO5D,OAAOlC,GACpB3lD,KAAI,SAAUx/B,GACzB,OAAOA,EAAKjH,KAClB,GACG,CASD,OAAA8G,CAAQyQ,GACN,OAAO5b,KAAK62F,SAAS72F,KAAK22F,SAAU/6E,EACrC,CAQD,eAAAk7E,CAAgBt9E,EAAQoC,GACtB,OAAO5b,KAAK62F,SAAS72F,KAAK42F,YAAYp9E,GAASoC,EAChD,CAQD,QAAAi7E,CAAS5tF,EAAQ2S,GACf,IAAI60B,EACJ,IAAK,IAAI7uC,EAAI,EAAGod,EAAI/V,EAAO9H,OAAQS,EAAIod,EAAGpd,IAExC,GADA6uC,EAAS70B,EAAS3S,EAAOrH,IACrB6uC,EACF,OAAOA,EAGX,OAAOA,CACR,CAKD,OAAA3rC,GACE,OAAOA,EAAQ9E,KAAKy2F,OACrB,CAKD,KAAA9xF,GACE3E,KAAKu2F,OAAO5xF,QACZ3E,KAAKy2F,OAAS,EACf,CAMD,SAAAp3E,CAAU7F,GACR,MAAMrX,EAAOnC,KAAKu2F,OAAOvC,SACzB,OAAOt5E,GAAevY,EAAKiY,KAAMjY,EAAKkY,KAAMlY,EAAKmY,KAAMnY,EAAKoY,KAAMf,EACnE,CAKD,MAAAu9E,CAAOC,GACLh3F,KAAKu2F,OAAOjpF,KAAK0pF,EAAMT,OAAOrgC,OAC9B,IAAK,MAAMt0D,KAAKo1F,EAAMP,OACpBz2F,KAAKy2F,OAAO70F,GAAKo1F,EAAMP,OAAO70F,EAEjC,GC1MH,MAAM05E,WAAenoD,GAQnB,WAAArzB,CAAY4c,EAAQsL,EAAQmH,GAC1BlqB,aACeuB,IAAX2oB,QAAmC3oB,IAAXwhB,EAC1BhoB,KAAKiwB,mBAAmBd,EAAQzS,IAEhCsL,EAASA,GAAkB,EAC3BhoB,KAAKi3F,mBAAmBv6E,EAAQsL,EAAQmH,GAE3C,CAOD,KAAApa,GACE,MAAMmR,EAAS,IAAIo1D,GACjBt7E,KAAK8a,gBAAgBhX,aACrB0C,EACAxG,KAAKmvB,QAGP,OADAjJ,EAAOjc,gBAAgBjK,MAChBkmB,CACR,CASD,cAAA+H,CAAe5W,EAAGC,EAAG4W,EAAcC,GACjC,MAAMrT,EAAkB9a,KAAK8a,gBACvBhD,EAAKT,EAAIyD,EAAgB,GACzB/C,EAAKT,EAAIwD,EAAgB,GACzBkJ,EAAkBlM,EAAKA,EAAKC,EAAKA,EACvC,GAAIiM,EAAkBmK,EAAoB,CACxC,GAAwB,IAApBnK,EACF,IAAK,IAAIpiB,EAAI,EAAGA,EAAI5B,KAAKgb,SAAUpZ,EACjCssB,EAAatsB,GAAKkZ,EAAgBlZ,OAE/B,CACL,MAAM+L,EAAQ3N,KAAKmmB,YAAcla,KAAKma,KAAKpC,GAC3CkK,EAAa,GAAKpT,EAAgB,GAAKnN,EAAQmK,EAC/CoW,EAAa,GAAKpT,EAAgB,GAAKnN,EAAQoK,EAC/C,IAAK,IAAInW,EAAI,EAAGA,EAAI5B,KAAKgb,SAAUpZ,EACjCssB,EAAatsB,GAAKkZ,EAAgBlZ,EAErC,CAED,OADAssB,EAAa/sB,OAASnB,KAAKgb,OACpBgJ,CACR,CACD,OAAOmK,CACR,CAOD,UAAApU,CAAW1C,EAAGC,GACZ,MAAMwD,EAAkB9a,KAAK8a,gBACvBhD,EAAKT,EAAIyD,EAAgB,GACzB/C,EAAKT,EAAIwD,EAAgB,GAC/B,OAAOhD,EAAKA,EAAKC,EAAKA,GAAM/X,KAAKk3F,mBAClC,CAOD,SAAA56E,GACE,OAAOtc,KAAK8a,gBAAgBhX,MAAM,EAAG9D,KAAKgb,OAC3C,CAOD,aAAAuT,CAAc/U,GACZ,MAAMsB,EAAkB9a,KAAK8a,gBACvBkN,EAASlN,EAAgB9a,KAAKgb,QAAUF,EAAgB,GAC9D,OAAOJ,GACLI,EAAgB,GAAKkN,EACrBlN,EAAgB,GAAKkN,EACrBlN,EAAgB,GAAKkN,EACrBlN,EAAgB,GAAKkN,EACrBxO,EAEH,CAOD,SAAA2M,GACE,OAAOla,KAAKma,KAAKpmB,KAAKk3F,oBACvB,CAMD,iBAAAA,GACE,MAAMp/E,EAAK9X,KAAK8a,gBAAgB9a,KAAKgb,QAAUhb,KAAK8a,gBAAgB,GAC9D/C,EAAK/X,KAAK8a,gBAAgB9a,KAAKgb,OAAS,GAAKhb,KAAK8a,gBAAgB,GACxE,OAAOhD,EAAKA,EAAKC,EAAKA,CACvB,CAOD,OAAA2W,GACE,MAAO,QACR,CAQD,gBAAAC,CAAiBnV,GAEf,GAAIsE,GAAWtE,EADMxZ,KAAKqf,aACY,CACpC,MAAM3C,EAAS1c,KAAKsc,YAEpB,OAAI9C,EAAO,IAAMkD,EAAO,IAAMlD,EAAO,IAAMkD,EAAO,KAG9ClD,EAAO,IAAMkD,EAAO,IAAMlD,EAAO,IAAMkD,EAAO,IAI3Cf,GAAcnC,EAAQxZ,KAAKsuB,qBAAqBpnB,KAAKlH,OAC7D,CACD,OAAO,CACR,CAOD,SAAA+6C,CAAUr+B,GACR,MAAM1B,EAAShb,KAAKgb,OACdgN,EAAShoB,KAAK8a,gBAAgBE,GAAUhb,KAAK8a,gBAAgB,GAC7DA,EAAkB4B,EAAO5Y,QAC/BgX,EAAgBE,GAAUF,EAAgB,GAAKkN,EAC/C,IAAK,IAAIpmB,EAAI,EAAGA,EAAIoZ,IAAUpZ,EAC5BkZ,EAAgBE,EAASpZ,GAAK8a,EAAO9a,GAEvC5B,KAAKiwB,mBAAmBjwB,KAAKmvB,OAAQrU,GACrC9a,KAAK6H,SACN,CAUD,kBAAAovF,CAAmBv6E,EAAQsL,EAAQmH,GACjCnvB,KAAKmwB,UAAUhB,EAAQzS,EAAQ,GAC1B1c,KAAK8a,kBACR9a,KAAK8a,gBAAkB,IAGzB,MAAMA,EAAkB9a,KAAK8a,gBAC7B,IAAIC,EAASsW,GAAkBvW,EAAiB,EAAG4B,EAAQ1c,KAAKgb,QAChEF,EAAgBC,KAAYD,EAAgB,GAAKkN,EACjD,IAAK,IAAIpmB,EAAI,EAAGuE,EAAKnG,KAAKgb,OAAQpZ,EAAIuE,IAAMvE,EAC1CkZ,EAAgBC,KAAYD,EAAgBlZ,GAE9CkZ,EAAgB3Z,OAAS4Z,EACzB/a,KAAK6H,SACN,CAED,cAAA8nB,GACE,OAAO,IACR,CAED,cAAAO,CAAe3W,EAAa4V,GAAU,CAOtC,SAAAgoE,CAAUnvE,GACRhoB,KAAK8a,gBAAgB9a,KAAKgb,QAAUhb,KAAK8a,gBAAgB,GAAKkN,EAC9DhoB,KAAK6H,SACN,CASD,MAAA0P,CAAOC,EAAO4V,GACZ,MAAM1Q,EAAS1c,KAAKsc,YACdtB,EAAShb,KAAKwvB,YACpBxvB,KAAK+6C,UACHxjC,GAAOmF,EAAQ,EAAGA,EAAOvb,OAAQ6Z,EAAQxD,EAAO4V,EAAQ1Q,IAE1D1c,KAAK6H,SACN,EAyBHyzE,GAAOz3E,UAAUmS,UACjB,IAAAohF,GAAe9b,GCrPf,MAAMH,WAA2BzrD,GAI/B,WAAA5vB,CAAY01E,GACVvwE,QAMAjF,KAAKq3F,YAAc7hB,GAA0B,KAK7Cx1E,KAAKs3F,kBAAoB,GAEzBt3F,KAAKu3F,yBACN,CAKD,yBAAAC,GACEx3F,KAAKs3F,kBAAkBnsF,QAAQ7D,GAC/BtH,KAAKs3F,kBAAkBn2F,OAAS,CACjC,CAKD,uBAAAo2F,GACE,GAAKv3F,KAAKq3F,YAGV,IAAK,IAAIz1F,EAAI,EAAGuE,EAAKnG,KAAKq3F,YAAYl2F,OAAQS,EAAIuE,IAAMvE,EACtD5B,KAAKs3F,kBAAkB3xF,KACrBoB,EAAO/G,KAAKq3F,YAAYz1F,GAAIkG,EAAkB9H,KAAK6H,QAAS7H,MAGjE,CAOD,KAAA+U,GACE,MAAM0iF,EAAqB,IAAItc,GAAmB,MAGlD,OAFAsc,EAAmBC,cAAc13F,KAAKq3F,aACtCI,EAAmBxtF,gBAAgBjK,MAC5By3F,CACR,CASD,cAAAxpE,CAAe5W,EAAGC,EAAG4W,EAAcC,GACjC,GAAIA,EAAqBtU,GAAyB7Z,KAAKqf,YAAahI,EAAGC,GACrE,OAAO6W,EAET,MAAMqnD,EAAax1E,KAAKq3F,YACxB,IAAK,IAAIz1F,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAChDusB,EAAqBqnD,EAAW5zE,GAAGqsB,eACjC5W,EACAC,EACA4W,EACAC,GAGJ,OAAOA,CACR,CAOD,UAAApU,CAAW1C,EAAGC,GACZ,MAAMk+D,EAAax1E,KAAKq3F,YACxB,IAAK,IAAIz1F,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAChD,GAAI4zE,EAAW5zE,GAAGmY,WAAW1C,EAAGC,GAC9B,OAAO,EAGX,OAAO,CACR,CAOD,aAAAiX,CAAc/U,GACZmB,GAAoBnB,GACpB,MAAMg8D,EAAax1E,KAAKq3F,YACxB,IAAK,IAAIz1F,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAChDM,GAAOsX,EAAQg8D,EAAW5zE,GAAGyd,aAE/B,OAAO7F,CACR,CAOD,aAAA2iE,GACE,OAAOwb,GAAgB33F,KAAKq3F,YAC7B,CAKD,kBAAA5hB,GACE,OAAOz1E,KAAKq3F,WACb,CAKD,2BAAAO,GAEE,IAAIC,EAAkB,GACtB,MAAMriB,EAAax1E,KAAKq3F,YACxB,IAAK,IAAIz1F,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAC5C4zE,EAAW5zE,GAAG8sB,YAAc1uB,KAAK0uB,UACnCmpE,EAAkBA,EAAgBd,OAE9BvhB,EAAW5zE,GACXg2F,+BAGJC,EAAgBlyF,KAAK6vE,EAAW5zE,IAGpC,OAAOi2F,CACR,CAOD,qBAAA9pE,CAAsBD,GAKpB,GAJI9tB,KAAK2tB,6BAA+B3tB,KAAK+H,gBAC3C/H,KAAK0tB,yCAA2C,EAChD1tB,KAAK2tB,2BAA6B3tB,KAAK+H,eAGvC+lB,EAAmB,GACgC,IAAlD9tB,KAAK0tB,0CACJI,EAAmB9tB,KAAK0tB,yCAE1B,OAAO1tB,KAGT,MAAM83F,EAAuB,GACvBtiB,EAAax1E,KAAKq3F,YACxB,IAAIU,GAAa,EACjB,IAAK,IAAIn2F,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAAG,CACnD,MAAMgT,EAAW4gE,EAAW5zE,GACtBmuB,EACJnb,EAASmZ,sBAAsBD,GACjCgqE,EAAqBnyF,KAAKoqB,GACtBA,IAAuBnb,IACzBmjF,GAAa,EAEhB,CACD,GAAIA,EAAY,CACd,MAAMC,EAA+B,IAAI7c,GAAmB,MAE5D,OADA6c,EAA6BC,mBAAmBH,GACzCE,CACR,CAED,OADAh4F,KAAK0tB,yCAA2CI,EACzC9tB,IACR,CAOD,OAAA0uB,GACE,MAAO,oBACR,CAQD,gBAAAC,CAAiBnV,GACf,MAAMg8D,EAAax1E,KAAKq3F,YACxB,IAAK,IAAIz1F,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAChD,GAAI4zE,EAAW5zE,GAAG+sB,iBAAiBnV,GACjC,OAAO,EAGX,OAAO,CACR,CAKD,OAAA1U,GACE,OAAmC,IAA5B9E,KAAKq3F,YAAYl2F,MACzB,CASD,MAAAoW,CAAOC,EAAO4V,GACZ,MAAMooD,EAAax1E,KAAKq3F,YACxB,IAAK,IAAIz1F,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAChD4zE,EAAW5zE,GAAG2V,OAAOC,EAAO4V,GAE9BptB,KAAK6H,SACN,CAYD,KAAA8P,CAAMQ,EAAIC,EAAIgV,GACPA,IACHA,EAAS9Q,GAAUtc,KAAKqf,cAE1B,MAAMm2D,EAAax1E,KAAKq3F,YACxB,IAAK,IAAIz1F,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAChD4zE,EAAW5zE,GAAG+V,MAAMQ,EAAIC,EAAIgV,GAE9BptB,KAAK6H,SACN,CAOD,aAAA6vF,CAAcliB,GACZx1E,KAAKi4F,mBAAmBN,GAAgBniB,GACzC,CAKD,kBAAAyiB,CAAmBziB,GACjBx1E,KAAKw3F,4BACLx3F,KAAKq3F,YAAc7hB,EACnBx1E,KAAKu3F,0BACLv3F,KAAK6H,SACN,CAWD,cAAA8W,CAAeC,GACb,MAAM42D,EAAax1E,KAAKq3F,YACxB,IAAK,IAAIz1F,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAChD4zE,EAAW5zE,GAAG+c,eAAeC,GAE/B5e,KAAK6H,SACN,CASD,SAAAgQ,CAAUoG,EAAQC,GAChB,MAAMs3D,EAAax1E,KAAKq3F,YACxB,IAAK,IAAIz1F,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAChD4zE,EAAW5zE,GAAGiW,UAAUoG,EAAQC,GAElCle,KAAK6H,SACN,CAKD,eAAApH,GACET,KAAKw3F,4BACLvyF,MAAMxE,iBACP,EAOH,SAASk3F,GAAgBniB,GACvB,MAAM0iB,EAAmB,GACzB,IAAK,IAAIt2F,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAChDs2F,EAAiBvyF,KAAK6vE,EAAW5zE,GAAGmT,SAEtC,OAAOmjF,CACT,CAEA,IAAAC,GAAehd,GCtUR,SAASid,GACdt9E,EACAC,EACA/Y,EACAgZ,EACAi8B,EACAr9B,EACAsJ,GAEA,IAAIyc,EAAG3zB,EACP,MAAMrK,GAAKK,EAAM+Y,GAAUC,EAC3B,GAAU,IAANrZ,EACFg+B,EAAI5kB,OACC,GAAU,IAANpZ,EACTg+B,EAAI5kB,EACJ/O,EAAIirC,OACC,GAAU,IAANt1C,EAAS,CAClB,IAAIob,EAAKjC,EAAgBC,GACrBiC,EAAKlC,EAAgBC,EAAS,GAC9B5Z,EAAS,EACb,MAAMk3F,EAAoB,CAAC,GAC3B,IAAK,IAAIz2F,EAAImZ,EAASC,EAAQpZ,EAAII,EAAKJ,GAAKoZ,EAAQ,CAClD,MAAMiC,EAAKnC,EAAgBlZ,GACrBsb,EAAKpC,EAAgBlZ,EAAI,GAC/BT,GAAU8K,KAAKma,MAAMnJ,EAAKF,IAAOE,EAAKF,IAAOG,EAAKF,IAAOE,EAAKF,IAC9Dq7E,EAAkB1yF,KAAKxE,GACvB4b,EAAKE,EACLD,EAAKE,CACN,CACD,MAAM/c,EAAS82C,EAAW91C,EACpB8B,EAAQvC,EAAa23F,EAAmBl4F,GAC1C8C,EAAQ,GACV+I,GACG7L,EAASk4F,GAAmBp1F,EAAQ,KACpCo1F,GAAmBp1F,EAAQ,GAAKo1F,GAAmBp1F,EAAQ,IAC9D08B,EAAI5kB,IAAW9X,EAAQ,GAAK+X,GAE5B2kB,EAAI5kB,EAAS9X,EAAQ+X,CAExB,CACDkI,EAAYA,EAAY,EAAIA,EAAY,EACxCtJ,EAAOA,GAAc,IAAIvX,MAAM6gB,GAC/B,IAAK,IAAIthB,EAAI,EAAGA,EAAIshB,IAAathB,EAC/BgY,EAAKhY,QACG4E,IAANm5B,EACItR,SACM7nB,IAANwF,EACA8O,EAAgB6kB,EAAI/9B,GACpBkjB,GAAKhK,EAAgB6kB,EAAI/9B,GAAIkZ,EAAgB6kB,EAAI3kB,EAASpZ,GAAIoK,GAEtE,OAAO4N,CACT,CAWO,SAAS0+E,GACdx9E,EACAC,EACA/Y,EACAgZ,EACAmF,EACAo4E,GAEA,GAAIv2F,GAAO+Y,EACT,OAAO,KAET,IAAI3D,EACJ,GAAI+I,EAAIrF,EAAgBC,EAASC,EAAS,GACxC,OAAIu9E,GACFnhF,EAAa0D,EAAgBhX,MAAMiX,EAAQA,EAASC,GACpD5D,EAAW4D,EAAS,GAAKmF,EAClB/I,GAEF,KAET,GAAI0D,EAAgB9Y,EAAM,GAAKme,EAC7B,OAAIo4E,GACFnhF,EAAa0D,EAAgBhX,MAAM9B,EAAMgZ,EAAQhZ,GACjDoV,EAAW4D,EAAS,GAAKmF,EAClB/I,GAEF,KAGT,GAAI+I,GAAKrF,EAAgBC,EAASC,EAAS,GACzC,OAAOF,EAAgBhX,MAAMiX,EAAQA,EAASC,GAEhD,IAAIw9E,EAAKz9E,EAASC,EACdy9E,EAAKz2F,EAAMgZ,EACf,KAAOw9E,EAAKC,GAAI,CACd,MAAM33F,EAAO03F,EAAKC,GAAO,EACrBt4E,EAAIrF,GAAiBha,EAAM,GAAKka,EAAS,GAC3Cy9E,EAAK33F,EAEL03F,EAAK13F,EAAM,CAEd,CACD,MAAM43F,EAAK59E,EAAgB09E,EAAKx9E,EAAS,GACzC,GAAImF,GAAKu4E,EACP,OAAO59E,EAAgBhX,OAAO00F,EAAK,GAAKx9E,GAASw9E,EAAK,GAAKx9E,EAASA,GAEtE,MACMhP,GAAKmU,EAAIu4E,IADJ59E,GAAiB09E,EAAK,GAAKx9E,EAAS,GACpB09E,GAC3BthF,EAAa,GACb,IAAK,IAAIxV,EAAI,EAAGA,EAAIoZ,EAAS,IAAKpZ,EAChCwV,EAAWzR,KACTmf,GACEhK,GAAiB09E,EAAK,GAAKx9E,EAASpZ,GACpCkZ,EAAgB09E,EAAKx9E,EAASpZ,GAC9BoK,IAKN,OADAoL,EAAWzR,KAAKwa,GACT/I,CACT,CAYO,SAASuhF,GACd79E,EACAC,EACA6V,EACA5V,EACAmF,EACAo4E,EACA1rF,GAEA,GAAIA,EACF,OAAOyrF,GACLx9E,EACAC,EACA6V,EAAKA,EAAKzvB,OAAS,GACnB6Z,EACAmF,EACAo4E,GAGJ,IAAInhF,EACJ,GAAI+I,EAAIrF,EAAgBE,EAAS,GAC/B,OAAIu9E,GACFnhF,EAAa0D,EAAgBhX,MAAM,EAAGkX,GACtC5D,EAAW4D,EAAS,GAAKmF,EAClB/I,GAEF,KAET,GAAI0D,EAAgBA,EAAgB3Z,OAAS,GAAKgf,EAChD,OAAIo4E,GACFnhF,EAAa0D,EAAgBhX,MAAMgX,EAAgB3Z,OAAS6Z,GAC5D5D,EAAW4D,EAAS,GAAKmF,EAClB/I,GAEF,KAET,IAAK,IAAIxV,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC7C,MAAMI,EAAM4uB,EAAKhvB,GACjB,GAAImZ,GAAU/Y,EAAd,CAGA,GAAIme,EAAIrF,EAAgBC,EAASC,EAAS,GACxC,OAAO,KAET,GAAImF,GAAKrF,EAAgB9Y,EAAM,GAC7B,OAAOs2F,GACLx9E,EACAC,EACA/Y,EACAgZ,EACAmF,GACA,GAGJpF,EAAS/Y,CAdR,CAeF,CACD,OAAO,IACT,CCpMO,SAAS42F,GAAiB99E,EAAiBC,EAAQ/Y,EAAKgZ,GAC7D,IAAI+B,EAAKjC,EAAgBC,GACrBiC,EAAKlC,EAAgBC,EAAS,GAC9B5Z,EAAS,EACb,IAAK,IAAIS,EAAImZ,EAASC,EAAQpZ,EAAII,EAAKJ,GAAKoZ,EAAQ,CAClD,MAAMiC,EAAKnC,EAAgBlZ,GACrBsb,EAAKpC,EAAgBlZ,EAAI,GAC/BT,GAAU8K,KAAKma,MAAMnJ,EAAKF,IAAOE,EAAKF,IAAOG,EAAKF,IAAOE,EAAKF,IAC9DD,EAAKE,EACLD,EAAKE,CACN,CACD,OAAO/b,CACT,CCFA,MAAM05E,WAAmB1nD,GAMvB,WAAArzB,CAAYyZ,EAAa4V,GACvBlqB,QAMAjF,KAAK64F,cAAgB,KAMrB74F,KAAK84F,uBAAyB,EAM9B94F,KAAKozB,WAAa,EAMlBpzB,KAAKqzB,mBAAqB,OAEX7sB,IAAX2oB,GAAyB9sB,MAAMC,QAAQiX,EAAY,IAMrDvZ,KAAKkwB,eACX,EAGQf,GATFnvB,KAAKiwB,mBACHd,EACR,EAUG,CAOD,gBAAA4pE,CAAiB3hF,GACflV,EAAOlC,KAAK8a,gBAAiB1D,GAC7BpX,KAAK6H,SACN,CAOD,KAAAkN,GACE,MAAMikF,EAAa,IAAIne,GACrB76E,KAAK8a,gBAAgBhX,QACrB9D,KAAKmvB,QAGP,OADA6pE,EAAW/uF,gBAAgBjK,MACpBg5F,CACR,CASD,cAAA/qE,CAAe5W,EAAGC,EAAG4W,EAAcC,GACjC,OAAIA,EAAqBtU,GAAyB7Z,KAAKqf,YAAahI,EAAGC,GAC9D6W,GAELnuB,KAAKqzB,mBAAqBrzB,KAAK+H,gBACjC/H,KAAKozB,UAAYnnB,KAAKma,KACpBoK,GACExwB,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OACL,IAGJhb,KAAKqzB,kBAAoBrzB,KAAK+H,eAEzBgpB,GACL/wB,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OACLhb,KAAKozB,WACL,EACA/b,EACAC,EACA4W,EACAC,GAEH,CAaD,cAAA0G,CAAejZ,GACb,OAAOiZ,GACL70B,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OACLY,EAEH,CAgBD,gBAAAq9E,CAAiB94E,EAAGo4E,GAClB,MAAmB,OAAfv4F,KAAKmvB,QAAkC,QAAfnvB,KAAKmvB,OACxB,MAETopE,OAA8B/xF,IAAhB+xF,GAA4BA,EACnCD,GACLt4F,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OACLmF,EACAo4E,GAEH,CAOD,cAAA5oE,GACE,OAAOgD,GACL3yB,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OAER,CAYD,eAAAk+E,CAAgBjiD,EAAUr9B,GACxB,OAAOw+E,GACLp4F,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OACLi8B,EACAr9B,EACA5Z,KAAKgb,OAER,CAOD,SAAA/P,GACE,OAAO2tF,GACL54F,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OAER,CAKD,eAAA26D,GAQE,OAPI31E,KAAK84F,uBAAyB94F,KAAK+H,gBACrC/H,KAAK64F,cAAgB74F,KAAKk5F,gBACxB,GACAl5F,KAAK64F,oBAAiBryF,GAExBxG,KAAK84F,sBAAwB94F,KAAK+H,eAEC/H,KAAkB,aACxD,CAOD,6BAAAgwB,CAA8BlC,GAE5B,MAAM8D,EAA4B,GAUlC,OATAA,EAA0BzwB,OAASwwB,GACjC3xB,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OACL8S,EACA8D,EACA,GAEK,IAAIipD,GAAWjpD,EAA2B,KAClD,CAOD,OAAAlD,GACE,MAAO,YACR,CAQD,gBAAAC,CAAiBnV,GACf,OAAOmb,GACL30B,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OACLxB,EAEH,CAQD,cAAA0W,CAAe3W,EAAa4V,GAC1BnvB,KAAKmwB,UAAUhB,EAAQ5V,EAAa,GAC/BvZ,KAAK8a,kBACR9a,KAAK8a,gBAAkB,IAEzB9a,KAAK8a,gBAAgB3Z,OAASmwB,GAC5BtxB,KAAK8a,gBACL,EACAvB,EACAvZ,KAAKgb,QAEPhb,KAAK6H,SACN,EAGH,IAAAsxF,GAAete,GC/Rf,MAAMI,WAAwB9nD,GAQ5B,WAAArzB,CAAYyZ,EAAa4V,EAAQyB,GAqB/B,GApBA3rB,QAMAjF,KAAKk2B,MAAQ,GAMbl2B,KAAKozB,WAAa,EAMlBpzB,KAAKqzB,mBAAqB,EAEtBhxB,MAAMC,QAAQiX,EAAY,IAC5BvZ,KAAKkwB,eACX,EAGQf,QAEG,QAAe3oB,IAAX2oB,GAAwByB,EACjC5wB,KAAKiwB,mBACHd,EACR,GAEMnvB,KAAKk2B,MAAQtF,MACR,CACL,MAAMwoE,EAAgD,EAEhDt+E,EAAkB,GAClB8V,EAAO,GACb,IAAK,IAAIhvB,EAAI,EAAGuE,EAAKizF,EAAYj4F,OAAQS,EAAIuE,IAAMvE,EAAG,CAEpDM,EAAO4Y,EADYs+E,EAAYx3F,GACI2tB,sBACnCqB,EAAKjrB,KAAKmV,EAAgB3Z,OAC3B,CACD,MAAMguB,EACmB,IAAvBiqE,EAAYj4F,OACRnB,KAAK8vB,YACLspE,EAAY,GAAGtpE,YACrB9vB,KAAKiwB,mBAAmBd,EAAQrU,GAChC9a,KAAKk2B,MAAQtF,CACd,CACF,CAOD,gBAAAyoE,CAAiBL,GACf92F,EAAOlC,KAAK8a,gBAAiBk+E,EAAWzpE,qBAAqBzrB,SAC7D9D,KAAKk2B,MAAMvwB,KAAK3F,KAAK8a,gBAAgB3Z,QACrCnB,KAAK6H,SACN,CAOD,KAAAkN,GACE,MAAMukF,EAAkB,IAAIre,GAC1Bj7E,KAAK8a,gBAAgBhX,QACrB9D,KAAKmvB,OACLnvB,KAAKk2B,MAAMpyB,SAGb,OADAw1F,EAAgBrvF,gBAAgBjK,MACzBs5F,CACR,CASD,cAAArrE,CAAe5W,EAAGC,EAAG4W,EAAcC,GACjC,OAAIA,EAAqBtU,GAAyB7Z,KAAKqf,YAAahI,EAAGC,GAC9D6W,GAELnuB,KAAKqzB,mBAAqBrzB,KAAK+H,gBACjC/H,KAAKozB,UAAYnnB,KAAKma,KACpBuK,GACE3wB,KAAK8a,gBACL,EACA9a,KAAKk2B,MACLl2B,KAAKgb,OACL,IAGJhb,KAAKqzB,kBAAoBrzB,KAAK+H,eAEzBopB,GACLnxB,KAAK8a,gBACL,EACA9a,KAAKk2B,MACLl2B,KAAKgb,OACLhb,KAAKozB,WACL,EACA/b,EACAC,EACA4W,EACAC,GAEH,CAwBD,gBAAA8qE,CAAiB94E,EAAGo4E,EAAa1rF,GAC/B,MACkB,OAAf7M,KAAKmvB,QAAkC,QAAfnvB,KAAKmvB,QACE,IAAhCnvB,KAAK8a,gBAAgB3Z,OAEd,MAETo3F,OAA8B/xF,IAAhB+xF,GAA4BA,EAC1C1rF,OAA8BrG,IAAhBqG,GAA4BA,EACnC8rF,GACL34F,KAAK8a,gBACL,EACA9a,KAAKk2B,MACLl2B,KAAKgb,OACLmF,EACAo4E,EACA1rF,GAEH,CAOD,cAAA8iB,GACE,OAAOiD,GACL5yB,KAAK8a,gBACL,EACA9a,KAAKk2B,MACLl2B,KAAKgb,OAER,CAKD,OAAA2b,GACE,OAAO32B,KAAKk2B,KACb,CAQD,aAAAqjE,CAAct2F,GACZ,OAAIA,EAAQ,GAAKjD,KAAKk2B,MAAM/0B,QAAU8B,EAC7B,KAEF,IAAI43E,GACT76E,KAAK8a,gBAAgBhX,MACT,IAAVb,EAAc,EAAIjD,KAAKk2B,MAAMjzB,EAAQ,GACrCjD,KAAKk2B,MAAMjzB,IAEbjD,KAAKmvB,OAER,CAOD,cAAAqqE,GACE,MAAM1+E,EAAkB9a,KAAK8a,gBACvB8V,EAAO5wB,KAAKk2B,MACZ/G,EAASnvB,KAAKmvB,OAEdiqE,EAAc,GACpB,IAAIr+E,EAAS,EACb,IAAK,IAAInZ,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC7C,MAAMI,EAAM4uB,EAAKhvB,GACXo3F,EAAa,IAAIne,GACrB//D,EAAgBhX,MAAMiX,EAAQ/Y,GAC9BmtB,GAEFiqE,EAAYzzF,KAAKqzF,GACjBj+E,EAAS/Y,CACV,CACD,OAAOo3F,CACR,CAKD,gBAAAtjB,GAEE,MAAM2jB,EAAY,GACZ3+E,EAAkB9a,KAAK8a,gBAC7B,IAAIC,EAAS,EACb,MAAM6V,EAAO5wB,KAAKk2B,MACZlb,EAAShb,KAAKgb,OACpB,IAAK,IAAIpZ,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC7C,MAAMI,EAAM4uB,EAAKhvB,GAQjBM,EAAOu3F,EAPUrB,GACft9E,EACAC,EACA/Y,EACAgZ,EACA,KAGFD,EAAS/Y,CACV,CACD,OAAOy3F,CACR,CAOD,6BAAAzpE,CAA8BlC,GAE5B,MAAM8D,EAA4B,GAE5BQ,EAAiB,GAWvB,OAVAR,EAA0BzwB,OAASgxB,GACjCnyB,KAAK8a,gBACL,EACA9a,KAAKk2B,MACLl2B,KAAKgb,OACL8S,EACA8D,EACA,EACAQ,GAEK,IAAI6oD,GAAgBrpD,EAA2B,KAAMQ,EAC7D,CAOD,OAAA1D,GACE,MAAO,iBACR,CAQD,gBAAAC,CAAiBnV,GACf,OAAOwb,GACLh1B,KAAK8a,gBACL,EACA9a,KAAKk2B,MACLl2B,KAAKgb,OACLxB,EAEH,CAQD,cAAA0W,CAAe3W,EAAa4V,GAC1BnvB,KAAKmwB,UAAUhB,EAAQ5V,EAAa,GAC/BvZ,KAAK8a,kBACR9a,KAAK8a,gBAAkB,IAEzB,MAAM8V,EAAOW,GACXvxB,KAAK8a,gBACL,EACAvB,EACAvZ,KAAKgb,OACLhb,KAAKk2B,OAEPl2B,KAAK8a,gBAAgB3Z,OAAyB,IAAhByvB,EAAKzvB,OAAe,EAAIyvB,EAAKA,EAAKzvB,OAAS,GACzEnB,KAAK6H,SACN,EAGH,IAAA6xF,GAAeze,GC5Uf,MAAMD,WAAmB7nD,GAMvB,WAAArzB,CAAYyZ,EAAa4V,GACvBlqB,QACIkqB,IAAW9sB,MAAMC,QAAQiX,EAAY,IACvCvZ,KAAKiwB,mBACHd,EACR,GAGMnvB,KAAKkwB,eACX,EAGQf,EAGL,CAOD,WAAAwqE,CAAY/2E,GACV1gB,EAAOlC,KAAK8a,gBAAiB8H,EAAM2M,sBACnCvvB,KAAK6H,SACN,CAOD,KAAAkN,GACE,MAAM6kF,EAAa,IAAI5e,GACrBh7E,KAAK8a,gBAAgBhX,QACrB9D,KAAKmvB,QAGP,OADAyqE,EAAW3vF,gBAAgBjK,MACpB45F,CACR,CASD,cAAA3rE,CAAe5W,EAAGC,EAAG4W,EAAcC,GACjC,GAAIA,EAAqBtU,GAAyB7Z,KAAKqf,YAAahI,EAAGC,GACrE,OAAO6W,EAET,MAAMrT,EAAkB9a,KAAK8a,gBACvBE,EAAShb,KAAKgb,OACpB,IAAK,IAAIpZ,EAAI,EAAGuE,EAAK2U,EAAgB3Z,OAAQS,EAAIuE,EAAIvE,GAAKoZ,EAAQ,CAChE,MAAMgJ,EAAkB0M,GACtBrZ,EACAC,EACAwD,EAAgBlZ,GAChBkZ,EAAgBlZ,EAAI,IAEtB,GAAIoiB,EAAkBmK,EAAoB,CACxCA,EAAqBnK,EACrB,IAAK,IAAIM,EAAI,EAAGA,EAAItJ,IAAUsJ,EAC5B4J,EAAa5J,GAAKxJ,EAAgBlZ,EAAI0iB,GAExC4J,EAAa/sB,OAAS6Z,CACvB,CACF,CACD,OAAOmT,CACR,CAOD,cAAAwB,GACE,OAAOgD,GACL3yB,KAAK8a,gBACL,EACA9a,KAAK8a,gBAAgB3Z,OACrBnB,KAAKgb,OAER,CAQD,QAAA6+E,CAAS52F,GACP,MAAMtB,EAAI3B,KAAK8a,gBAAgB3Z,OAASnB,KAAKgb,OAC7C,OAAI/X,EAAQ,GAAKtB,GAAKsB,EACb,KAEF,IAAIuwB,GACTxzB,KAAK8a,gBAAgBhX,MACnBb,EAAQjD,KAAKgb,QACZ/X,EAAQ,GAAKjD,KAAKgb,QAErBhb,KAAKmvB,OAER,CAOD,SAAA2qE,GACE,MAAMh/E,EAAkB9a,KAAK8a,gBACvBqU,EAASnvB,KAAKmvB,OACdnU,EAAShb,KAAKgb,OAEd++E,EAAS,GACf,IAAK,IAAIn4F,EAAI,EAAGuE,EAAK2U,EAAgB3Z,OAAQS,EAAIuE,EAAIvE,GAAKoZ,EAAQ,CAChE,MAAM4H,EAAQ,IAAI4Q,GAAM1Y,EAAgBhX,MAAMlC,EAAGA,EAAIoZ,GAASmU,GAC9D4qE,EAAOp0F,KAAKid,EACb,CACD,OAAOm3E,CACR,CAOD,OAAArrE,GACE,MAAO,YACR,CAQD,gBAAAC,CAAiBnV,GACf,MAAMsB,EAAkB9a,KAAK8a,gBACvBE,EAAShb,KAAKgb,OACpB,IAAK,IAAIpZ,EAAI,EAAGuE,EAAK2U,EAAgB3Z,OAAQS,EAAIuE,EAAIvE,GAAKoZ,EAAQ,CAGhE,GAAIjB,GAAWP,EAFLsB,EAAgBlZ,GAChBkZ,EAAgBlZ,EAAI,IAE5B,OAAO,CAEV,CACD,OAAO,CACR,CAQD,cAAAsuB,CAAe3W,EAAa4V,GAC1BnvB,KAAKmwB,UAAUhB,EAAQ5V,EAAa,GAC/BvZ,KAAK8a,kBACR9a,KAAK8a,gBAAkB,IAEzB9a,KAAK8a,gBAAgB3Z,OAASmwB,GAC5BtxB,KAAK8a,gBACL,EACAvB,EACAvZ,KAAKgb,QAEPhb,KAAK6H,SACN,EAGH,IAAAmyF,GAAehf,GCxLR,SAAS/nD,GAAanY,EAAiBC,EAAQ+V,EAAO9V,GAC3D,MAAMgZ,EAAc,GACpB,IAAIxa,EzIsLG,CAACiB,IAAUA,KAAU,KAAW,KyIrLvC,IAAK,IAAI7Y,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAMgvB,EAAOE,EAAMlvB,GACnB4X,EAASqB,GACPC,EACAC,EACA6V,EAAK,GACL5V,GAEFgZ,EAAYruB,MAAM6T,EAAO,GAAKA,EAAO,IAAM,GAAIA,EAAO,GAAKA,EAAO,IAAM,GACxEuB,EAAS6V,EAAKA,EAAKzvB,OAAS,EAC7B,CACD,OAAO6yB,CACT,CCIA,MAAMknD,WAAqB/nD,GAOzB,WAAArzB,CAAYyZ,EAAa4V,EAAQ2B,GA6C/B,GA5CA7rB,QAMAjF,KAAKi6F,OAAS,GAMdj6F,KAAKk6F,6BAA+B,EAMpCl6F,KAAKm6F,oBAAsB,KAM3Bn6F,KAAKozB,WAAa,EAMlBpzB,KAAKqzB,mBAAqB,EAM1BrzB,KAAKq2B,mBAAqB,EAM1Br2B,KAAKs2B,yBAA2B,MAE3BxF,IAAUzuB,MAAMC,QAAQiX,EAAY,IAAK,CAC5C,MAAM6gF,EAA0C,EAE1Ct/E,EAAkB,GAClBu/E,EAAY,GAClB,IAAK,IAAIz4F,EAAI,EAAGuE,EAAKi0F,EAASj5F,OAAQS,EAAIuE,IAAMvE,EAAG,CACjD,MAAM40B,EAAU4jE,EAASx4F,GACnBmZ,EAASD,EAAgB3Z,OACzByvB,EAAO4F,EAAQG,UACrB,IAAK,IAAIrS,EAAI,EAAG2G,EAAK2F,EAAKzvB,OAAQmjB,EAAI2G,IAAM3G,EAC1CsM,EAAKtM,IAAMvJ,EAEb7Y,EAAO4Y,EAAiB0b,EAAQjH,sBAChC8qE,EAAU10F,KAAKirB,EAChB,CACDzB,EACsB,IAApBirE,EAASj5F,OAAenB,KAAK8vB,YAAcsqE,EAAS,GAAGtqE,YACzDvW,EAAcuB,EACdgW,EAAQupE,CACT,MACc7zF,IAAX2oB,GAAwB2B,GAC1B9wB,KAAKiwB,mBACHd,EACR,GAEMnvB,KAAKi6F,OAASnpE,GAEd9wB,KAAKkwB,eACX,EAGQf,EAGL,CAOD,aAAAmrE,CAAc9jE,GAEZ,IAAI5F,EACJ,GAAK5wB,KAAK8a,gBAIH,CACL,MAAMC,EAAS/a,KAAK8a,gBAAgB3Z,OACpCe,EAAOlC,KAAK8a,gBAAiB0b,EAAQjH,sBACrCqB,EAAO4F,EAAQG,UAAU7yB,QACzB,IAAK,IAAIlC,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAC1CgvB,EAAKhvB,IAAMmZ,CAEd,MAVC/a,KAAK8a,gBAAkB0b,EAAQjH,qBAAqBzrB,QACpD8sB,EAAO4F,EAAQG,UAAU7yB,QACzB9D,KAAKi6F,OAAOt0F,OASd3F,KAAKi6F,OAAOt0F,KAAKirB,GACjB5wB,KAAK6H,SACN,CAOD,KAAAkN,GACE,MAAM9M,EAAMjI,KAAKi6F,OAAO94F,OAClBo5F,EAAW,IAAIl4F,MAAM4F,GAC3B,IAAK,IAAIrG,EAAI,EAAGA,EAAIqG,IAAOrG,EACzB24F,EAAS34F,GAAK5B,KAAKi6F,OAAOr4F,GAAGkC,QAG/B,MAAM02F,EAAe,IAAItf,GACvBl7E,KAAK8a,gBAAgBhX,QACrB9D,KAAKmvB,OACLorE,GAIF,OAFAC,EAAavwF,gBAAgBjK,MAEtBw6F,CACR,CASD,cAAAvsE,CAAe5W,EAAGC,EAAG4W,EAAcC,GACjC,OAAIA,EAAqBtU,GAAyB7Z,KAAKqf,YAAahI,EAAGC,GAC9D6W,GAELnuB,KAAKqzB,mBAAqBrzB,KAAK+H,gBACjC/H,KAAKozB,UAAYnnB,KAAKma,KACpByK,GACE7wB,KAAK8a,gBACL,EACA9a,KAAKi6F,OACLj6F,KAAKgb,OACL,IAGJhb,KAAKqzB,kBAAoBrzB,KAAK+H,eAEzBqpB,GACLpxB,KAAKy2B,6BACL,EACAz2B,KAAKi6F,OACLj6F,KAAKgb,OACLhb,KAAKozB,WACL,EACA/b,EACAC,EACA4W,EACAC,GAEH,CAOD,UAAApU,CAAW1C,EAAGC,GACZ,OAAOwc,GACL9zB,KAAKy2B,6BACL,EACAz2B,KAAKi6F,OACLj6F,KAAKgb,OACL3D,EACAC,EAEH,CAOD,OAAA4E,GACE,OAAOu+E,GACLz6F,KAAKy2B,6BACL,EACAz2B,KAAKi6F,OACLj6F,KAAKgb,OAER,CAeD,cAAA2U,CAAe4F,GACb,IAAIza,EAcJ,YAbctU,IAAV+uB,GACFza,EAAkB9a,KAAKy2B,6BAA6B3yB,QACpD8xB,GACE9a,EACA,EACA9a,KAAKi6F,OACLj6F,KAAKgb,OACLua,IAGFza,EAAkB9a,KAAK8a,gBAGlB+X,GACL/X,EACA,EACA9a,KAAKi6F,OACLj6F,KAAKgb,OAER,CAKD,QAAAg7D,GACE,OAAOh2E,KAAKi6F,MACb,CAKD,qBAAA/jB,GACE,GAAIl2E,KAAKk6F,6BAA+Bl6F,KAAK+H,cAAe,CAC1D,MAAMisB,EAAc0mE,GAClB16F,KAAK8a,gBACL,EACA9a,KAAKi6F,OACLj6F,KAAKgb,QAEPhb,KAAKm6F,oBAAsB3lE,GACzBx0B,KAAKy2B,6BACL,EACAz2B,KAAKi6F,OACLj6F,KAAKgb,OACLgZ,GAEFh0B,KAAKk6F,4BAA8Bl6F,KAAK+H,aACzC,CACD,OAAqC/H,KAAwB,mBAC9D,CAQD,iBAAA26F,GACE,OAAO,IAAI3f,GAAWh7E,KAAKk2E,wBAAwBpyE,QAAS,MAC7D,CAKD,0BAAA2yB,GACE,GAAIz2B,KAAKq2B,mBAAqBr2B,KAAK+H,cAAe,CAChD,MAAM+S,EAAkB9a,KAAK8a,gBAE3B2a,GAAwB3a,EAAiB,EAAG9a,KAAKi6F,OAAQj6F,KAAKgb,QAE9Dhb,KAAKs2B,yBAA2Bxb,GAEhC9a,KAAKs2B,yBAA2Bxb,EAAgBhX,QAChD9D,KAAKs2B,yBAAyBn1B,OAASy0B,GACrC51B,KAAKs2B,yBACL,EACAt2B,KAAKi6F,OACLj6F,KAAKgb,SAGThb,KAAKq2B,kBAAoBr2B,KAAK+H,aAC/B,CACD,OAAqC/H,KAA6B,wBACnE,CAOD,6BAAAgwB,CAA8BlC,GAE5B,MAAM8D,EAA4B,GAE5Bc,EAAkB,GAWxB,OAVAd,EAA0BzwB,OAASsxB,GACjCzyB,KAAK8a,gBACL,EACA9a,KAAKi6F,OACLj6F,KAAKgb,OACL/O,KAAKma,KAAK0H,GACV8D,EACA,EACAc,GAEK,IAAIwoD,GAAatpD,EAA2B,KAAMc,EAC1D,CAQD,UAAAkoE,CAAW33F,GACT,GAAIA,EAAQ,GAAKjD,KAAKi6F,OAAO94F,QAAU8B,EACrC,OAAO,KAET,IAAI8X,EACJ,GAAc,IAAV9X,EACF8X,EAAS,MACJ,CACL,MAAM8/E,EAAW76F,KAAKi6F,OAAOh3F,EAAQ,GACrC8X,EAAS8/E,EAASA,EAAS15F,OAAS,EACrC,CACD,MAAMyvB,EAAO5wB,KAAKi6F,OAAOh3F,GAAOa,QAC1B9B,EAAM4uB,EAAKA,EAAKzvB,OAAS,GAC/B,GAAe,IAAX4Z,EACF,IAAK,IAAInZ,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAC1CgvB,EAAKhvB,IAAMmZ,EAGf,OAAO,IAAIkb,GACTj2B,KAAK8a,gBAAgBhX,MAAMiX,EAAQ/Y,GACnChC,KAAKmvB,OACLyB,EAEH,CAOD,WAAAkqE,GACE,MAAM3rE,EAASnvB,KAAKmvB,OACdrU,EAAkB9a,KAAK8a,gBACvBgW,EAAQ9wB,KAAKi6F,OACbG,EAAW,GACjB,IAAIr/E,EAAS,EACb,IAAK,IAAInZ,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAMgvB,EAAOE,EAAMlvB,GAAGkC,QAChB9B,EAAM4uB,EAAKA,EAAKzvB,OAAS,GAC/B,GAAe,IAAX4Z,EACF,IAAK,IAAIuJ,EAAI,EAAG2G,EAAK2F,EAAKzvB,OAAQmjB,EAAI2G,IAAM3G,EAC1CsM,EAAKtM,IAAMvJ,EAGf,MAAMyb,EAAU,IAAIP,GAClBnb,EAAgBhX,MAAMiX,EAAQ/Y,GAC9BmtB,EACAyB,GAEFwpE,EAASz0F,KAAK6wB,GACdzb,EAAS/Y,CACV,CACD,OAAOo4F,CACR,CAOD,OAAA1rE,GACE,MAAO,cACR,CAQD,gBAAAC,CAAiBnV,GACf,OAAO2b,GACLn1B,KAAKy2B,6BACL,EACAz2B,KAAKi6F,OACLj6F,KAAKgb,OACLxB,EAEH,CAQD,cAAA0W,CAAe3W,EAAa4V,GAC1BnvB,KAAKmwB,UAAUhB,EAAQ5V,EAAa,GAC/BvZ,KAAK8a,kBACR9a,KAAK8a,gBAAkB,IAEzB,MAAMgW,EAAQW,GACZzxB,KAAK8a,gBACL,EACAvB,EACAvZ,KAAKgb,OACLhb,KAAKi6F,QAEP,GAAqB,IAAjBnpE,EAAM3vB,OACRnB,KAAK8a,gBAAgB3Z,OAAS,MACzB,CACL,MAAM45F,EAAWjqE,EAAMA,EAAM3vB,OAAS,GACtCnB,KAAK8a,gBAAgB3Z,OACC,IAApB45F,EAAS55F,OAAe,EAAI45F,EAASA,EAAS55F,OAAS,EAC1D,CACDnB,KAAK6H,SACN,EAGH,IAAAmzF,GAAe9f,GCtaf,MAAM3tD,G7IZG,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,G6ImBzB,MAAM0tE,GAUJ,WAAAn7F,CAAYC,EAAM+a,EAAiB8V,EAAM5V,EAAQlG,EAAYtH,GAI3DxN,KAAKk7F,cAMLl7F,KAAKugB,QAMLvgB,KAAKsU,IAAM9G,EAMXxN,KAAKm7F,MAAQp7F,EAMbC,KAAKo7F,iBAAmBtgF,EAMxB9a,KAAKm6F,oBAAsB,KAM3Bn6F,KAAKq7F,eAAiB,KAMtBr7F,KAAKk2B,MAAQtF,EAMb5wB,KAAKs7F,YAAcxmF,EAKnB9U,KAAKoyE,kBAKLpyE,KAAKu7F,QAAUvgF,EAMfhb,KAAKw7F,mBACN,CAQD,GAAApyF,CAAI7B,GACF,OAAOvH,KAAKs7F,YAAY/zF,EACzB,CAOD,SAAA8X,GAYE,OAXKrf,KAAKugB,UACRvgB,KAAKugB,QACY,UAAfvgB,KAAKm7F,MACDvgF,GAA6B5a,KAAKo7F,kBAClCvgF,GACE7a,KAAKo7F,iBACL,EACAp7F,KAAKo7F,iBAAiBj6F,OACtB,IAGHnB,KAAKugB,OACb,CAKD,oBAAAqW,GACE,IAAK52B,KAAKm6F,oBAAqB,CAC7B,MAAMtjE,EAAava,GAAUtc,KAAKqf,aAClCrf,KAAKm6F,oBAAsBpmE,GACzB/zB,KAAKo7F,iBACL,EAC8Bp7F,KAAU,MACxC,EACA62B,EACA,EAEH,CACD,OAAO72B,KAAKm6F,mBACb,CAKD,qBAAAjkB,GACE,IAAKl2E,KAAKm6F,oBAAqB,CAC7B,MAAMvpE,EAAOiF,GAAY71B,KAAKo7F,iBAAkBp7F,KAAKk2B,OAC/ClC,EAAc0mE,GAAmB16F,KAAKo7F,iBAAkB,EAAGxqE,EAAM,GACvE5wB,KAAKm6F,oBAAsB3lE,GACzBx0B,KAAKo7F,iBACL,EACAxqE,EACA,EACAoD,EAEH,CACD,OAAOh0B,KAAKm6F,mBACb,CAKD,eAAAxkB,GAUE,OATK31E,KAAKq7F,iBACRr7F,KAAKq7F,eAAiBjD,GACpBp4F,KAAKo7F,iBACL,EACAp7F,KAAKo7F,iBAAiBj6F,OACtB,EACA,KAGGnB,KAAKq7F,cACb,CAKD,gBAAAvlB,GACE,IAAK91E,KAAKq7F,eAAgB,CACxBr7F,KAAKq7F,eAAiB,GACtB,MAAMvgF,EAAkB9a,KAAKo7F,iBAC7B,IAAIrgF,EAAS,EACb,MAAM6V,EAAqC5wB,KAAU,MACrD,IAAK,IAAI4B,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC7C,MAAMI,EAAM4uB,EAAKhvB,GACX65F,EAAWrD,GAAiBt9E,EAAiBC,EAAQ/Y,EAAK,EAAG,IACnEE,EAAOlC,KAAKq7F,eAAgBI,GAC5B1gF,EAAS/Y,CACV,CACF,CACD,OAAOhC,KAAKq7F,cACb,CAQD,KAAAhmF,GACE,OAAOrV,KAAKsU,GACb,CAKD,0BAAAmiB,GACE,OAAOz2B,KAAKo7F,gBACb,CAQD,WAAAlmF,GACE,OAAOlV,IACR,CAMD,qBAAA+tB,CAAsBD,GACpB,OAAO9tB,IACR,CAQD,mBAAAguB,CAAoBF,EAAkB9X,GACpC,OAAOhW,IACR,CAOD,aAAAuJ,GACE,OAAOvJ,KAAKs7F,WACb,CAOD,qBAAA7xF,GACE,OAAOzJ,KAAKs7F,WACb,CAKD,SAAA9rE,GACE,OAAOxvB,KAAKu7F,OACb,CAKD,gBAAAjmF,GACE,OAAOtV,KAAKk7F,aACb,CAOD,OAAAxsE,GACE,OAAO1uB,KAAKm7F,KACb,CAOD,SAAAnlF,CAAUmJ,GAER,MAAM4P,GADN5P,EAAayP,GAAczP,IACIE,YACzB2P,EAAkB7P,EAAWoC,iBACnC,GAAIwN,GAAeC,EAAiB,CAClC,MAAMrX,EAAQ0E,GAAU2S,GAAmB3S,GAAU0S,GACrDE,GACE1B,GACAyB,EAAgB,GAChBA,EAAgB,GAChBrX,GACCA,EACD,EACA,EACA,GAEFwV,GACEntB,KAAKo7F,iBACL,EACAp7F,KAAKo7F,iBAAiBj6F,OACtB,EACAosB,GACAvtB,KAAKo7F,iBAER,CACF,CASD,cAAAz8E,CAAeC,GACbA,EAAY5e,KAAKo7F,iBAAkBp7F,KAAKo7F,iBAAkBp7F,KAAKu7F,QAChE,CAKD,KAAAxmF,GACE,OAAO,IAAIkmF,GACTj7F,KAAKm7F,MACLn7F,KAAKo7F,iBAAiBt3F,QACtB9D,KAAKk2B,MAAMpyB,QACX9D,KAAKu7F,QACL70F,OAAO8C,OAAO,GAAIxJ,KAAKs7F,aACvBt7F,KAAKsU,IAER,CAKD,OAAAqiB,GACE,OAAO32B,KAAKk2B,KACb,CAMD,yBAAAwlE,GAkEE,OAjEA17F,KAAKguB,oBAAsB1qB,GAAW,CAACwqB,EAAkB9X,KACvD,GAAI8X,IAAqB9tB,KAAKoyE,kBAC5B,OAAOpyE,KAAKw7F,oBAEdx7F,KAAKw7F,oBAAsBx7F,KAAK+U,QAC5BiB,GACFhW,KAAKw7F,oBAAoB78E,eAAe3I,GAE1C,MAAM4b,EACJ5xB,KAAKw7F,oBAAoBjsE,qBAC3B,IAAI6C,EACJ,OAAQpyB,KAAKm7F,OACX,IAAK,aACHvpE,EAA0BzwB,OAASwwB,GACjCC,EACA,EACA5xB,KAAKw7F,oBAAoBJ,iBAAiBj6F,OAC1CnB,KAAKw7F,oBAAoBD,QACzBztE,EACA8D,EACA,GAEFQ,EAAiB,CAACR,EAA0BzwB,QAC5C,MACF,IAAK,kBACHixB,EAAiB,GACjBR,EAA0BzwB,OAASgxB,GACjCP,EACA,EACA5xB,KAAKw7F,oBAAoBtlE,MACzBl2B,KAAKw7F,oBAAoBD,QACzBztE,EACA8D,EACA,EACAQ,GAEF,MACF,IAAK,UACHA,EAAiB,GACjBR,EAA0BzwB,OAASqxB,GACjCZ,EACA,EACA5xB,KAAKw7F,oBAAoBtlE,MACzBl2B,KAAKw7F,oBAAoBD,QACzBtvF,KAAKma,KAAK0H,GACV8D,EACA,EACAQ,GAgBN,OAXIA,IACFpyB,KAAKw7F,oBAAsB,IAAIP,GAC7Bj7F,KAAKm7F,MACLvpE,EACAQ,EACA,EACApyB,KAAKs7F,YACLt7F,KAAKsU,MAGTtU,KAAKoyE,kBAAoBtkD,EAClB9tB,KAAKw7F,mBAAmB,IAE1Bx7F,IACR,EAiBI,SAAS27F,GAAW9f,GACzB,MAAM+f,EAAe/f,EAAcntD,UACnC,OAAQktE,GACN,IAAK,QACH,OAAO,IAAIpoE,GAAMqoD,EAActsD,sBACjC,IAAK,aACH,OAAO,IAAIyrD,GAAWa,EAActsD,qBAAsB,MAC5D,IAAK,aACH,OAAO,IAAIsrD,GAAWgB,EAActsD,qBAAsB,MAC5D,IAAK,kBACH,OAAO,IAAI0rD,GACTY,EAActsD,qBACd,KAC8BssD,EAAcllD,WAEhD,IAAK,UACH,MAAM7b,EAAkB+gE,EAActsD,qBAChCqB,EAAqCirD,EAAcllD,UACnD7F,EAAQ+E,GAAY/a,EAAiB8V,GAC3C,OAAOE,EAAM3vB,OAAS,EAClB,IAAI+5E,GAAapgE,EAAiB,KAAMgW,GACxC,IAAImF,GAAQnb,EAAiB,KAAM8V,GACzC,QACE,MAAM,IAAIpoB,MAAM,yBAA2BozF,GAEjD,CApCAX,GAAcp3F,UAAU0rB,mBACtB0rE,GAAcp3F,UAAU4yB,2BA8D1B,IAAAolE,GAAeZ,GCxgBAa,GAMD,aANCA,GAaE,gBAbFA,GAoBN,QApBMA,GA4BE,gBA5BFA,GAmCM,oBAnCNA,GA0CI,kBA1CJA,GAiDM,oBClBd,MAAMC,WAA0Bh2F,EAMrC,WAAAjG,CAAYC,EAAM4/C,EAASwjB,GACzBl+D,MAAMlF,GAONC,KAAK2/C,QAAUA,EAOf3/C,KAAKmjE,SAAWA,CACjB,EA4kCH,IAAA64B,GAz9BA,cAA2BvT,GAIzB,WAAA3oF,CAAY6K,GAGV1F,MAAM,CACJi5C,cAHFvzC,EAAUA,GAAW,IAGGuzC,aACtBrxC,aAAa,EACbsS,gBAAY3Y,EACZgG,MAAO,QACP0S,WAAyB1Y,IAAlBmE,EAAQuU,OAAsBvU,EAAQuU,QAM/Clf,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAML3H,KAAKqT,QAAUhQ,EAMfrD,KAAK+sE,QAAUpiE,EAAQqc,OAMvBhnB,KAAKi8F,eAAiCz1F,IAArBmE,EAAQuxF,UAAgCvxF,EAAQuxF,SAMjEl8F,KAAKitE,KAAOtiE,EAAQijE,SAEGpnE,IAAnBmE,EAAQ2I,OACVtT,KAAKqT,QAAU1I,EAAQ2I,YACA9M,IAAdxG,KAAKitE,OACdh5D,GAAOjU,KAAK+sE,QAAS,0CAErB/sE,KAAKqT,QAAU06D,GACb/tE,KAAKitE,KACkDjtE,KAAY,UAQvEA,KAAKm8F,eACkB31F,IAArBmE,EAAQyxF,SAAyBzxF,EAAQyxF,SAAWC,GAEtD,MAAMC,OACwB91F,IAA5BmE,EAAQ2xF,iBAAgC3xF,EAAQ2xF,gBAqDlD,IAAIt0C,EAEAmb,EAjDJnjE,KAAKu8F,eAAiBD,EAAkB,IAAIE,GAAU,KAMtDx8F,KAAKy8F,oBAAsB,IAAID,GAM/Bx8F,KAAK08F,qBAAuB,EAM5B18F,KAAK28F,sBAAwB,GAO7B38F,KAAK48F,SAAW,GAOhB58F,KAAK68F,UAAY,GAMjB78F,KAAK88F,mBAAqB,GAM1B98F,KAAK+8F,oBAAsB,KAMvB16F,MAAMC,QAAQqI,EAAQw4D,UACxBA,EAAWx4D,EAAQw4D,SACVx4D,EAAQw4D,WACjBnb,EAAar9C,EAAQw4D,SACrBA,EAAWnb,EAAW38C,YAEnBixF,QAAkC91F,IAAfwhD,IACtBA,EAAa,IAAIx9C,EAAW24D,SAEb38D,IAAb28D,GACFnjE,KAAKg9F,oBAAoB75B,QAER38D,IAAfwhD,GACFhoD,KAAKi9F,wBAAwBj1C,EAEhC,CAcD,UAAAk1C,CAAWv9C,GACT3/C,KAAKm9F,mBAAmBx9C,GACxB3/C,KAAK6H,SACN,CAOD,kBAAAs1F,CAAmBx9C,GACjB,MAAMy9C,EAAa10F,EAAOi3C,GAE1B,IAAK3/C,KAAKq9F,YAAYD,EAAYz9C,GAIhC,YAHI3/C,KAAK+8F,qBACP/8F,KAAK+8F,oBAAoBrxF,OAAOi0C,IAKpC3/C,KAAKs9F,mBAAmBF,EAAYz9C,GAEpC,MAAM/qC,EAAW+qC,EAAQzqC,cACzB,GAAIN,EAAU,CACZ,MAAM4E,EAAS5E,EAASyK,YACpBrf,KAAKu8F,gBACPv8F,KAAKu8F,eAAerJ,OAAO15E,EAAQmmC,EAE3C,MACM3/C,KAAK28F,sBAAsBS,GAAcz9C,EAG3C3/C,KAAK4F,cACH,IAAIm2F,GAAkBD,GAA4Bn8C,GAErD,CAOD,kBAAA29C,CAAmBF,EAAYz9C,GACzBA,aAAmBs7C,KAGvBj7F,KAAK88F,mBAAmBM,GAAc,CACpCr2F,EAAO44C,EAAS73C,EAAkB9H,KAAKu9F,qBAAsBv9F,MAC7D+G,EACE44C,EACAt/C,EACAL,KAAKu9F,qBACLv9F,OAGL,CASD,WAAAq9F,CAAYD,EAAYz9C,GACtB,IAAI69C,GAAQ,EACZ,QAAwBh3F,IAApBm5C,EAAQtqC,QAAuB,CACjC,MAAM7H,EAAK3E,OAAO82C,EAAQtqC,SAC1B,GAAM7H,KAAMxN,KAAK48F,SAEV,GAAIj9C,aAAmBs7C,GAAe,CAC3C,MAAMwC,EAAiBz9F,KAAK48F,SAASpvF,GAC/BiwF,aAA0BxC,GAGzB54F,MAAMC,QAAQm7F,GAGjBA,EAAe93F,KAAKg6C,GAFpB3/C,KAAK48F,SAASpvF,GAAM,CAACiwF,EAAgB99C,GAHvC69C,GAAQ,CAQlB,MACQA,GAAQ,OAbRx9F,KAAK48F,SAASpvF,GAAMmyC,CAevB,CAQD,OAPI69C,IACFvpF,KACImpF,KAAcp9F,KAAK68F,WACrB,wDAEF78F,KAAK68F,UAAUO,GAAcz9C,GAExB69C,CACR,CAOD,WAAAzuB,CAAY5L,GACVnjE,KAAKg9F,oBAAoB75B,GACzBnjE,KAAK6H,SACN,CAOD,mBAAAm1F,CAAoB75B,GAClB,MAAMuzB,EAAU,GAEVgH,EAAc,GAEdC,EAAmB,GAEzB,IAAK,IAAI/7F,EAAI,EAAGT,EAASgiE,EAAShiE,OAAQS,EAAIT,EAAQS,IAAK,CACzD,MAAM+9C,EAAUwjB,EAASvhE,GACnBw7F,EAAa10F,EAAOi3C,GACtB3/C,KAAKq9F,YAAYD,EAAYz9C,IAC/B+9C,EAAY/3F,KAAKg6C,EAEpB,CAED,IAAK,IAAI/9C,EAAI,EAAGT,EAASu8F,EAAYv8F,OAAQS,EAAIT,EAAQS,IAAK,CAC5D,MAAM+9C,EAAU+9C,EAAY97F,GACtBw7F,EAAa10F,EAAOi3C,GAC1B3/C,KAAKs9F,mBAAmBF,EAAYz9C,GAEpC,MAAM/qC,EAAW+qC,EAAQzqC,cACzB,GAAIN,EAAU,CACZ,MAAM4E,EAAS5E,EAASyK,YACxBq3E,EAAQ/wF,KAAK6T,GACbmkF,EAAiBh4F,KAAKg6C,EAC9B,MACQ3/C,KAAK28F,sBAAsBS,GAAcz9C,CAE5C,CAKD,GAJI3/C,KAAKu8F,gBACPv8F,KAAKu8F,eAAejvF,KAAKopF,EAASiH,GAGhC39F,KAAKyG,YAAYq1F,IACnB,IAAK,IAAIl6F,EAAI,EAAGT,EAASu8F,EAAYv8F,OAAQS,EAAIT,EAAQS,IACvD5B,KAAK4F,cACH,IAAIm2F,GAAkBD,GAA4B4B,EAAY97F,IAIrE,CAMD,uBAAAq7F,CAAwBj1C,GACtB,IAAI41C,GAAsB,EAC1B59F,KAAKsF,iBACHw2F,IAIA,SAAUl8F,GACHg+F,IACHA,GAAsB,EACtB51C,EAAWriD,KAAK/F,EAAI+/C,SACpBi+C,GAAsB,EAEzB,IAEH59F,KAAKsF,iBACHw2F,IAIA,SAAUl8F,GACHg+F,IACHA,GAAsB,EACtB51C,EAAWt8C,OAAO9L,EAAI+/C,SACtBi+C,GAAsB,EAEzB,IAEH51C,EAAW1iD,iBACT8E,GAICxK,IACMg+F,IACHA,GAAsB,EACtB59F,KAAKk9F,WAAWt9F,EAAI2K,SACpBqzF,GAAsB,EACvB,IAGL51C,EAAW1iD,iBACT8E,GAICxK,IACMg+F,IACHA,GAAsB,EACtB59F,KAAK69F,cAAcj+F,EAAI2K,SACvBqzF,GAAsB,EACvB,IAGL59F,KAAK+8F,oBAAsB/0C,CAC5B,CAOD,KAAArjD,CAAMm5F,GACJ,GAAIA,EAAM,CACR,IAAK,MAAMC,KAAa/9F,KAAK88F,mBAAoB,CAClC98F,KAAK88F,mBAAmBiB,GAChC5yF,QAAQ7D,EACd,CACItH,KAAK+8F,sBACR/8F,KAAK88F,mBAAqB,GAC1B98F,KAAK48F,SAAW,GAChB58F,KAAK68F,UAAY,GAEzB,MACM,GAAI78F,KAAKu8F,eAAgB,CACvB,MAAMyB,EAAyBr+C,IAC7B3/C,KAAKi+F,sBAAsBt+C,EAAQ,EAErC3/C,KAAKu8F,eAAepxF,QAAQ6yF,GAC5B,IAAK,MAAMxwF,KAAMxN,KAAK28F,sBACpB38F,KAAKi+F,sBAAsBj+F,KAAK28F,sBAAsBnvF,GAEzD,CAECxN,KAAK+8F,qBACP/8F,KAAK+8F,oBAAoBp4F,QAGvB3E,KAAKu8F,gBACPv8F,KAAKu8F,eAAe53F,QAEtB3E,KAAK28F,sBAAwB,GAE7B,MAAMuB,EAAa,IAAInC,GAAkBD,IACzC97F,KAAK4F,cAAcs4F,GACnBl+F,KAAK6H,SACN,CAcD,cAAAs2F,CAAeviF,GACb,GAAI5b,KAAKu8F,eACP,OAAOv8F,KAAKu8F,eAAepxF,QAAQyQ,GAEjC5b,KAAK+8F,qBACP/8F,KAAK+8F,oBAAoB5xF,QAAQyQ,EAEpC,CAiBD,gCAAAwiF,CAAiChnF,EAAYwE,GAC3C,MAAMpC,EAAS,CAACpC,EAAW,GAAIA,EAAW,GAAIA,EAAW,GAAIA,EAAW,IACxE,OAAOpX,KAAKq+F,uBAAuB7kF,GAAQ,SAAUmmC,GACnD,MAAM/qC,EAAW+qC,EAAQzqC,cACzB,GACEN,aAAoBqmF,IACpBrmF,EAAS0Z,qBAAqBlX,GAE9B,OAAOwE,EAAS+jC,EAGxB,GACG,CAqBD,sBAAA0+C,CAAuB7kF,EAAQoC,GAC7B,GAAI5b,KAAKu8F,eACP,OAAOv8F,KAAKu8F,eAAezF,gBAAgBt9E,EAAQoC,GAEjD5b,KAAK+8F,qBACP/8F,KAAK+8F,oBAAoB5xF,QAAQyQ,EAEpC,CAiBD,gCAAA0iF,CAAiC9kF,EAAQoC,GACvC,OAAO5b,KAAKq+F,uBACV7kF,GAKA,SAAUmmC,GACR,MAAM/qC,EAAW+qC,EAAQzqC,cACzB,GACEN,aAAoBqmF,IACpBrmF,EAAS+Z,iBAAiBnV,GAC1B,CACA,MAAMi3B,EAAS70B,EAAS+jC,GACxB,GAAIlP,EACF,OAAOA,CAEV,CACF,GAEJ,CASD,qBAAA8tD,GACE,OAAOv+F,KAAK+8F,mBACb,CAQD,WAAA1/C,GACE,IAAI8lB,EASJ,OARInjE,KAAK+8F,oBACP55B,EAAWnjE,KAAK+8F,oBAAoB1xF,WAAWvH,MAAM,GAC5C9D,KAAKu8F,iBACdp5B,EAAWnjE,KAAKu8F,eAAe5F,SAC1B7xF,EAAQ9E,KAAK28F,wBAChBz6F,EAAOihE,EAAUz8D,OAAOuC,OAAOjJ,KAAK28F,yBAGjCx5B,CACR,CAQD,uBAAAq7B,CAAwBpnF,GACtB,MAAM+rD,EAAW,GAIjB,OAHAnjE,KAAKo+F,iCAAiChnF,GAAY,SAAUuoC,GAC1DwjB,EAASx9D,KAAKg6C,EACpB,IACWwjB,CACR,CAgBD,mBAAAs7B,CAAoBjlF,EAAQ2F,GAC1B,GAAInf,KAAKu8F,eAAgB,CAGvB,KAFmBp9E,GAAcA,EAAWG,YAActf,KAAKkgD,YAG7D,OAAOlgD,KAAKu8F,eAAe3F,YAAYp9E,GAGzC,MAAMk9E,EAAUj3E,GAAcjG,EAAQ2F,GAEtC,MAAO,GAAG43E,UACLL,EAAQ5rD,KAAK4zD,GAAa1+F,KAAKu8F,eAAe3F,YAAY8H,KAEhE,CACD,OAAI1+F,KAAK+8F,oBACA/8F,KAAK+8F,oBAAoB1xF,WAAWvH,MAAM,GAE5C,EACR,CAeD,6BAAA66F,CAA8BvnF,EAAYqgC,GAQxC,MAAMpgC,EAAID,EAAW,GACfE,EAAIF,EAAW,GACrB,IAAIwnF,EAAiB,KACrB,MAAM1wE,EAAe,CAACG,IAAKA,KAC3B,IAAIF,EAAqB1T,IACzB,MAAMjB,EAAS,EAAEiB,KAAWA,IAAUA,IAAUA,KA8BhD,OA7BAg9B,EAASA,GAAkBt0C,EAC3BnD,KAAKu8F,eAAezF,gBAClBt9E,GAIA,SAAUmmC,GACR,GAAIlI,EAAOkI,GAAU,CACnB,MAAM/qC,EAAW+qC,EAAQzqC,cACnB2pF,EAA6B1wE,EAKnC,GAJAA,EACEvZ,aAAoBqmF,GAChB,EACArmF,EAASqZ,eAAe5W,EAAGC,EAAG4W,EAAcC,GAC9CA,EAAqB0wE,EAA4B,CACnDD,EAAiBj/C,EAKjB,MAAMm/C,EAAc7yF,KAAKma,KAAK+H,GAC9B3U,EAAO,GAAKnC,EAAIynF,EAChBtlF,EAAO,GAAKlC,EAAIwnF,EAChBtlF,EAAO,GAAKnC,EAAIynF,EAChBtlF,EAAO,GAAKlC,EAAIwnF,CACjB,CACF,CACF,IAEIF,CACR,CAYD,SAAAv/E,CAAU7F,GACR,OAAOxZ,KAAKu8F,eAAel9E,UAAU7F,EACtC,CAcD,cAAAulF,CAAevxF,GACb,MAAMmyC,EAAU3/C,KAAK48F,SAASpvF,EAAGoL,YACjC,YAAmBpS,IAAZm5C,EAAwBA,EAAU,IAC1C,CAQD,eAAAq/C,CAAgB7S,GACd,MAAMxsC,EAAU3/C,KAAK68F,UAAU1Q,GAC/B,YAAmB3lF,IAAZm5C,EAAwBA,EAAU,IAC1C,CAQD,SAAAutB,GACE,OAAOltE,KAAK+sE,OACb,CAKD,WAAAkyB,GACE,OAAOj/F,KAAKi8F,SACb,CAQD,MAAAiD,GACE,OAAOl/F,KAAKitE,IACb,CAMD,oBAAAswB,CAAqB13F,GACnB,MAAM85C,EAAuC95C,EAAY,OACnDu3F,EAAa10F,EAAOi3C,GACpB/qC,EAAW+qC,EAAQzqC,cACzB,GAAKN,EAOE,CACL,MAAM4E,EAAS5E,EAASyK,YACpB+9E,KAAcp9F,KAAK28F,8BACd38F,KAAK28F,sBAAsBS,GAC9Bp9F,KAAKu8F,gBACPv8F,KAAKu8F,eAAerJ,OAAO15E,EAAQmmC,IAGjC3/C,KAAKu8F,gBACPv8F,KAAKu8F,eAAez+D,OAAOtkB,EAAQmmC,EAGxC,MAlBOy9C,KAAcp9F,KAAK28F,wBACnB38F,KAAKu8F,gBACPv8F,KAAKu8F,eAAe7wF,OAAOi0C,GAE7B3/C,KAAK28F,sBAAsBS,GAAcz9C,GAe7C,MAAMnyC,EAAKmyC,EAAQtqC,QACnB,QAAW7O,IAAPgH,EAAkB,CACpB,MAAM2xF,EAAM3xF,EAAGoL,WACX5Y,KAAK48F,SAASuC,KAASx/C,IACzB3/C,KAAKo/F,mBAAmBz/C,GACxB3/C,KAAK48F,SAASuC,GAAOx/C,EAE7B,MACM3/C,KAAKo/F,mBAAmBz/C,GACxB3/C,KAAK68F,UAAUO,GAAcz9C,EAE/B3/C,KAAK6H,UACL7H,KAAK4F,cACH,IAAIm2F,GAAkBD,GAA+Bn8C,GAExD,CAQD,UAAA0/C,CAAW1/C,GACT,MAAMnyC,EAAKmyC,EAAQtqC,QACnB,YAAW7O,IAAPgH,EACKA,KAAMxN,KAAK48F,SAEbl0F,EAAOi3C,KAAY3/C,KAAK68F,SAChC,CAKD,OAAA/3F,GACE,OAAI9E,KAAKu8F,eAELv8F,KAAKu8F,eAAez3F,WAAaA,EAAQ9E,KAAK28F,wBAG9C38F,KAAK+8F,qBACyC,IAAzC/8F,KAAK+8F,oBAAoB9xF,WAGnC,CAOD,YAAAq0F,CAAa9lF,EAAQmD,EAAYwC,GAC/B,MAAMogF,EAAqBv/F,KAAKy8F,oBAC1B+C,EAAgBx/F,KAAKm8F,UAAU3iF,EAAQmD,EAAYwC,GACzD,IAAK,IAAIvd,EAAI,EAAGuE,EAAKq5F,EAAcr+F,OAAQS,EAAIuE,IAAMvE,EAAG,CACtD,MAAM69F,EAAeD,EAAc59F,GACb29F,EAAmBzI,gBACvC2I,GAKA,SAAU76F,GACR,OAAOoV,GAAepV,EAAO4U,OAAQimF,EACtC,QAGCz/F,KAAK08F,qBACP18F,KAAK4F,cACH,IAAIm2F,GAAkBD,KAExB97F,KAAKqT,QAAQtP,KACX/D,KACAy/F,EACA9iF,EACAwC,GACCgkD,MACGnjE,KAAK08F,qBACP18F,KAAK4F,cACH,IAAIm2F,GACFD,QACAt1F,EACA28D,GAEH,IAEH,OACInjE,KAAK08F,qBACP18F,KAAK4F,cACH,IAAIm2F,GAAkBD,IACvB,IAGLyD,EAAmBrM,OAAOuM,EAAc,CAACjmF,OAAQimF,EAAa37F,UAEjE,CACD9D,KAAKokE,UACHpkE,KAAKqT,QAAQlS,OAAS,IAAYnB,KAAK08F,qBAAuB,CACjE,CAED,OAAAvX,GACEnlF,KAAK2E,OAAM,GACX3E,KAAKy8F,oBAAoB93F,QACzBM,MAAMkgF,SACP,CAOD,kBAAAua,CAAmBlmF,GACjB,MAAM+lF,EAAqBv/F,KAAKy8F,oBAChC,IAAI9zF,EACJ42F,EAAmBzI,gBAAgBt9E,GAAQ,SAAU5U,GACnD,GAAIrC,GAAOqC,EAAO4U,OAAQA,GAExB,OADA7Q,EAAM/D,GACC,CAEf,IACQ+D,GACF42F,EAAmB7zF,OAAO/C,EAE7B,CASD,aAAAk1F,CAAcl+C,GACZ,IAAKA,EACH,OAEF,MAAMy9C,EAAa10F,EAAOi3C,GACtBy9C,KAAcp9F,KAAK28F,6BACd38F,KAAK28F,sBAAsBS,GAE9Bp9F,KAAKu8F,gBACPv8F,KAAKu8F,eAAe7wF,OAAOi0C,GAGhB3/C,KAAKi+F,sBAAsBt+C,IAExC3/C,KAAK6H,SAER,CASD,qBAAAo2F,CAAsBt+C,GACpB,MAAMy9C,EAAa10F,EAAOi3C,GACpBggD,EAAoB3/F,KAAK88F,mBAAmBM,GAClD,IAAKuC,EACH,OAEFA,EAAkBx0F,QAAQ7D,UACnBtH,KAAK88F,mBAAmBM,GAC/B,MAAM5vF,EAAKmyC,EAAQtqC,QAQnB,YAPW7O,IAAPgH,UACKxN,KAAK48F,SAASpvF,EAAGoL,mBAEnB5Y,KAAK68F,UAAUO,GACtBp9F,KAAK4F,cACH,IAAIm2F,GAAkBD,GAA+Bn8C,IAEhDA,CACR,CASD,kBAAAy/C,CAAmBz/C,GACjB,IAAIigD,GAAU,EACd,IAAK,MAAMpyF,KAAMxN,KAAK48F,SAAU,CAC9B,MAAMa,EAAiBz9F,KAAK48F,SAASpvF,GACrC,GACEmyC,aAAmBs7C,IACnB54F,MAAMC,QAAQm7F,IACdA,EAAe/3F,SAASi6C,GAExB89C,EAAe52F,OAAO42F,EAAe72F,QAAQ+4C,GAAU,QAClD,GAAI3/C,KAAK48F,SAASpvF,KAAQmyC,EAAS,QACjC3/C,KAAK48F,SAASpvF,GACrBoyF,GAAU,EACV,KACD,CACF,CACD,OAAOA,CACR,CAQD,SAAAryB,CAAUj6D,GACRtT,KAAKqT,QAAUC,CAChB,CAOD,MAAAu4E,CAAOje,GACL35D,GAAOjU,KAAK+sE,QAAS,0CACrB/sE,KAAKitE,KAAOW,EACZ5tE,KAAKutE,UAAUQ,GAAIH,EAAK5tE,KAAK+sE,SAC9B,GC5zBH,IAAA8yB,GArQA,cAAsBC,GAIpB,WAAAhgG,CAAY6K,GACV1F,MAAM,CACJi5C,aAAcvzC,EAAQuzC,aACtBh/B,MAAOvU,EAAQuU,QAOjBlf,KAAK2c,gBAAanW,EAMlBxG,KAAKwnB,cAAgChhB,IAArBmE,EAAQ6c,SAAyB7c,EAAQ6c,SAAW,GAMpExnB,KAAK8+F,YAAcn0F,EAAQm0F,aAAe,EAM1C9+F,KAAK+/F,mBAAqB,EAM1B//F,KAAKmjE,SAAW,GAOhBnjE,KAAKggG,iBACHr1F,EAAQq1F,kBACR,SAAUrgD,GACR,MAAM/qC,EAAiC+qC,EAAQzqC,cAK/C,OAJAjB,IACGW,GAAmC,UAAvBA,EAAS8Z,UACtB,6EAEK9Z,CACf,EAMI5U,KAAKigG,qBAAuBt1F,EAAQu1F,cAMpClgG,KAAKkK,OAAS,KAKdlK,KAAKmgG,cAAgBngG,KAAKmlF,QAAQj+E,KAAKlH,MAEvCA,KAAKogG,eAAepgG,KAAKwnB,SAAUxnB,KAAK8+F,aACxC9+F,KAAKi9C,UAAUtyC,EAAQT,QAAU,KAClC,CAOD,KAAAvF,CAAMm5F,GACJ99F,KAAKmjE,SAAShiE,OAAS,EACvB8D,MAAMN,MAAMm5F,EACb,CAOD,WAAA/1E,GACE,OAAO/nB,KAAKwnB,QACb,CAOD,SAAA01B,GACE,OAAOl9C,KAAKkK,MACb,CAOD,YAAAo1F,CAAa9lF,EAAQmD,EAAYwC,GAC/Bnf,KAAKkK,OAAOo1F,aAAa9lF,EAAQmD,EAAYwC,GACzCxC,IAAe3c,KAAK2c,aACtB3c,KAAK2c,WAAaA,EAClB3c,KAAKmlF,UAER,CAOD,WAAAkb,CAAY74E,GACVxnB,KAAKogG,eAAe54E,EAAUxnB,KAAK8+F,YACpC,CAQD,cAAAwB,CAAexB,GACb9+F,KAAKogG,eAAepgG,KAAKwnB,SAAUs3E,EACpC,CAOD,cAAAyB,GACE,OAAOvgG,KAAK8+F,WACb,CAOD,SAAA7hD,CAAU/yC,GACJlK,KAAKkK,QACPlK,KAAKkK,OAAO5D,oBAAoBwB,EAAkB9H,KAAKmgG,eAEzDngG,KAAKkK,OAASA,EACVA,GACFA,EAAO5E,iBAAiBwC,EAAkB9H,KAAKmgG,eAEjDngG,KAAKmlF,SACN,CAKD,OAAAA,GACEnlF,KAAK2E,QACL3E,KAAKwgG,UACLxgG,KAAK+uE,YAAY/uE,KAAKmjE,SACvB,CAOD,cAAAi9B,CAAe54E,EAAUs3E,GACvB,MAAM7uD,EACS,IAAbzoB,EAAiB,EAAIvb,KAAKwP,IAAIqjF,EAAat3E,GAAYA,EACnD3f,EACJ2f,IAAaxnB,KAAKwnB,UAAYxnB,KAAK+/F,qBAAuB9vD,EAC5DjwC,KAAKwnB,SAAWA,EAChBxnB,KAAK8+F,YAAcA,EACnB9+F,KAAK+/F,mBAAqB9vD,EACtBpoC,GACF7H,KAAKmlF,SAER,CAKD,OAAAqb,GACE,QAAwBh6F,IAApBxG,KAAK2c,aAA6B3c,KAAKkK,OACzC,OAEF,MAAMsP,E9IpED,CAACiB,IAAUA,KAAU,KAAW,K8IqE/BgmF,EAAczgG,KAAKwnB,SAAWxnB,KAAK2c,WACnCwmD,EAAWnjE,KAAKkK,OAAOmzC,cAGvBqjD,EAAY,CAAA,EAElB,IAAK,IAAI9+F,EAAI,EAAGuE,EAAKg9D,EAAShiE,OAAQS,EAAIuE,EAAIvE,IAAK,CACjD,MAAM+9C,EAAUwjB,EAASvhE,GACzB,KAAM8G,EAAOi3C,KAAY+gD,GAAY,CACnC,MAAM9rF,EAAW5U,KAAKggG,iBAAiBrgD,GACvC,GAAI/qC,EAAU,CAEZgG,GADoBhG,EAAS+a,iBACanW,GAC1CG,GAAOH,EAAQinF,EAAajnF,GAE5B,MAAMmnF,EAAY3gG,KAAKkK,OACpBu0F,oBAAoBjlF,GACpBi+B,QAAO,SAAUmpD,GAChB,MAAMzU,EAAMzjF,EAAOk4F,GACnB,QAAIzU,KAAOuU,KAGXA,EAAUvU,IAAO,GACV,EACrB,IACUnsF,KAAKmjE,SAASx9D,KAAK3F,KAAKkgG,cAAcS,EAAWnnF,GAClD,CACF,CACF,CACF,CAQD,aAAA0mF,CAAc/8B,EAAU3pD,GACtB,MAAM67C,EAAW,CAAC,EAAG,GACrB,IAAK,IAAIzzD,EAAIuhE,EAAShiE,OAAS,EAAGS,GAAK,IAAKA,EAAG,CAC7C,MAAMgT,EAAW5U,KAAKggG,iBAAiB78B,EAASvhE,IAC5CgT,EACFkjC,GAAcud,EAAUzgD,EAAS+a,kBAEjCwzC,EAASt8D,OAAOjF,EAAG,EAEtB,CACD82D,GAAgBrD,EAAU,EAAI8N,EAAShiE,QACvC,MAAM0/F,EAAevkF,GAAU9C,GACzBy2B,EAAQjwC,KAAK+/F,mBACbnrF,EAAW,IAAI4e,GAAM,CACzB6hC,EAAS,IAAM,EAAIplB,GAAS4wD,EAAa,GAAK5wD,EAC9ColB,EAAS,IAAM,EAAIplB,GAAS4wD,EAAa,GAAK5wD,IAEhD,OAAIjwC,KAAKigG,qBACAjgG,KAAKigG,qBAAqBrrF,EAAUuuD,GAEtC,IAAI/uD,GAAQ,CACjBQ,WACAuuD,YAEH,GCyKH,IAAA29B,GAhcA,cAA6BC,GAI3B,WAAAjhG,CAAY6K,GACV1F,MAAM,CACJsH,UAAW5B,EAAQ4B,UACnB+G,OAAQ,IAAM/O,QAAQE,QAAQ,IAAI+N,WAAW,IAC7C3F,YAAalC,EAAQkC,YACrBF,WAAYhC,EAAQgC,aAOtB3M,KAAKs7B,YAAc3wB,EAAQywB,WAM3Bp7B,KAAK6iF,QAAUl4E,EAAQ6yE,OAMvBx9E,KAAKghG,YAAc,KAMnBhhG,KAAKihG,aAAe,KAMpBjhG,KAAKkhG,iBAAc16F,EAMnBxG,KAAK8iF,gBAAkBn4E,EAAQ83E,eAM/BziF,KAAK+iF,gBAAkBp4E,EAAQ+3E,eAM/B1iF,KAAKgjF,kBAAoBr4E,EAAQyhE,kBAAoBzhE,EAAQ4B,UAM7DvM,KAAKijF,aAAe,GAMpBjjF,KAAKkjF,qBAAuB,KAM5BljF,KAAKmjF,SAAW,EAEhB,MAAM9F,EAAer9E,KAAK+iF,gBAAgBK,mBACxCpjF,KAAKgjF,mBAEDK,EAAkBrjF,KAAK+iF,gBAAgB1jE,YAC7C,IAAIkgE,EAAkBv/E,KAAK8iF,gBAAgBzjE,YAE3C,MAAMikE,EAAsBD,EACxBzlE,GAAgBy/D,EAAcgG,GAC9BhG,EAEJ,GAAqC,IAAjCnhE,GAAQonE,GAIV,YADAtjF,KAAKwM,MAAQV,GAIf,MAAMuf,EAAa1gB,EAAQ0gB,WACrBk4D,EAAmBl4D,EAAWhM,YAChCkkE,IAIAhE,EAHGA,EAGe3hE,GAAgB2hE,EAAiBgE,GAFjCA,GAMtB,MAAMpwC,EAAmBnzC,KAAK+iF,gBAAgBrnD,cAC5C17B,KAAKgjF,kBAAkB,IAGnB/F,EAAatyE,EAAQsyE,WACrB/pC,EAAmBkqC,GACvB/xD,EACA4xD,EACAqG,EACAnwC,GAGF,IAAKzzB,SAASwzB,IAAqBA,GAAoB,EAIrD,YADAlzC,KAAKwM,MAAQV,GAIf,MAAM03E,OACuBh9E,IAA3BmE,EAAQ60E,eACJ70E,EAAQ60E,eACRH,GAeN,GATAr/E,KAAKyjF,eAAiB,IAAIC,GACxBr4D,EACA4xD,EACAqG,EACA/D,EACArsC,EAAmBswC,EACnBrwC,GAGgD,IAA9CnzC,KAAKyjF,eAAejF,eAAer9E,OAGrC,YADAnB,KAAKwM,MAAQV,GAIf9L,KAAKmjF,SAAWnjF,KAAK8iF,gBAAgBa,kBAAkBzwC,GACvD,IAAInmB,EAAe/sB,KAAKyjF,eAAelB,wBAmBvC,GAjBIhD,IACEl0D,EAAW/L,YACbyN,EAAa,GAAKjJ,GAChBiJ,EAAa,GACbwyD,EAAgB,GAChBA,EAAgB,IAElBxyD,EAAa,GAAKjJ,GAChBiJ,EAAa,GACbwyD,EAAgB,GAChBA,EAAgB,KAGlBxyD,EAAenP,GAAgBmP,EAAcwyD,IAI5CrjE,GAAQ6Q,GAEN,CACL,MAAM62D,EAAc5jF,KAAK8iF,gBAAgBe,0BACvC92D,EACA/sB,KAAKmjF,UAEDwG,EAAUh/E,EAAQg4E,gBACxB,IAAK,IAAImB,EAAOF,EAAYxpE,KAAM0pE,GAAQF,EAAYtpE,KAAMwpE,IAC1D,IAAK,IAAIC,EAAOH,EAAYvpE,KAAM0pE,GAAQH,EAAYrpE,KAAMwpE,IAAQ,CAClE,MAAM72E,EAAOy8E,EAAQ3pF,KAAKmjF,SAAUW,EAAMC,EAAM/jF,KAAKs7B,aACjDpuB,GACFlN,KAAKijF,aAAat9E,KAAKuH,EAE1B,CAG8B,IAA7BlN,KAAKijF,aAAa9hF,SACpBnB,KAAKwM,MAAQV,EAEhB,MAnBC9L,KAAKwM,MAAQV,CAoBhB,CAMD,OAAA6H,GACE,OAAO3T,KAAKkhG,WACb,CAMD,OAAArtF,GACE,OAAO7T,KAAKghG,WACb,CAMD,QAAAltF,GACE,OAAO9T,KAAKihG,YACb,CAKD,UAAAjd,GACE,MAAMmd,EAAc,GAoDpB,GAnDAnhG,KAAKijF,aAAa93E,SAAS+B,IACzB,IAAKA,GAAQA,EAAKC,aAAerB,EAC/B,OAEF,MAAM4H,EAAOxG,EAAKyG,UACZ6pE,EAASx9E,KAAK6iF,QAIpB,IAAIue,EACJ,MAAMC,EAAY9uF,GAAYrF,EAAK2G,WAEjCutF,EADEC,GAGSxuF,GAAQV,GAAYjF,EAAK2G,YAEtC,MAAMytF,EAAY,CAAC5tF,EAAK,GAAK,EAAI8pE,EAAQ9pE,EAAK,GAAK,EAAI8pE,GACjD+jB,EAAUH,aAAoB1uF,aAC9B8uF,EAAaF,EAAU,GAAKA,EAAU,GACtCG,EAAWF,EAAU7uF,aAAeF,WACpCkvF,EAAY,IAAID,EAASL,EAASznF,QAClCgoF,EAAkBF,EAASG,kBAC3BC,EAAiBF,EAAkBD,EAAUvgG,OAAUqgG,EACvDM,EAAcJ,EAAUK,WAAaT,EAAU,GAC/CU,EAAY/1F,KAAKuT,MACrBsiF,EAAcH,EAAkBL,EAAU,IAEtCW,EAAeT,EAAaQ,EAClC,IAAIE,EAAaR,EACjB,GAAIA,EAAUvgG,SAAW8gG,EAAc,CACrCC,EAAa,IAAIT,EAASQ,GAC1B,IAAIE,EAAY,EACZC,EAAY,EAChB,MAAMC,EAAWf,EAAU,GAAKU,EAChC,IAAK,IAAIM,EAAW,EAAGA,EAAWhB,EAAU,KAAMgB,EAAU,CAC1D,IAAK,IAAIC,EAAW,EAAGA,EAAWF,IAAYE,EAC5CL,EAAWC,KAAeT,EAAUU,EAAYG,GAElDH,GAAaN,EAAcH,CAC5B,CACF,CACDR,EAAYx7F,KAAK,CACf6T,OAAQxZ,KAAK8iF,gBAAgBM,mBAAmBl2E,EAAKX,WACrDpK,KAAM,IAAIqQ,WAAW0vF,EAAWvoF,QAChC6oF,SAAUf,EACVI,cAAeA,EACfP,UAAWA,GACX,IAEJthG,KAAKijF,aAAa9hF,OAAS,EAEA,IAAvBggG,EAAYhgG,OACdnB,KAAKwM,MAAQV,MACR,CACL,MAAMyzB,EAAIv/B,KAAKgjF,kBAAkB,GAC3BtvE,EAAO1T,KAAK+iF,gBAAgBkB,YAAY1kD,GACxCkjE,EAA8B,iBAAT/uF,EAAoBA,EAAOA,EAAK,GACrDgvF,EAA+B,iBAAThvF,EAAoBA,EAAOA,EAAK,GACtDy/B,EAAmBnzC,KAAK+iF,gBAAgBrnD,cAAc6D,GACtD2T,EAAmBlzC,KAAK8iF,gBAAgBpnD,cAC5C17B,KAAKmjF,UAGD9F,EAAer9E,KAAK+iF,gBAAgBK,mBACxCpjF,KAAKgjF,mBAGP,IAAI2f,EAAOC,EAEX,MAAMf,EAAgBV,EAAY,GAAGU,cAGrC,IAAK,IAAIgB,EADO52F,KAAKkZ,KAAK08E,EAAgB,GACd,EAAGgB,GAAU,IAAKA,EAAQ,CACpD,MAAMtlB,EAAU,GAChB,IAAK,IAAI37E,EAAI,EAAGqG,EAAMk5F,EAAYhgG,OAAQS,EAAIqG,IAAOrG,EAAG,CACtD,MAAMkhG,EAAa3B,EAAYv/F,GACzB+X,EAASmpF,EAAW3gG,KACpBm/F,EAAYwB,EAAWxB,UACvB7xF,EAAQ6xF,EAAU,GAClB5xF,EAAS4xF,EAAU,GACnBnxF,EAAUX,GAAsBC,EAAOC,EAAQC,IAC/CiE,EAAYzD,EAAQ4yF,gBAAgBtzF,EAAOC,GAC3CvN,EAAOyR,EAAUzR,KACvB,IAAI4Y,EAAkB,EAAT8nF,EACb,IAAK,IAAIv+E,EAAI,EAAGrc,EAAM9F,EAAKhB,OAAQmjB,EAAIrc,EAAKqc,GAAK,EAC/CniB,EAAKmiB,GAAK3K,EAAOoB,GACjB5Y,EAAKmiB,EAAI,GAAK3K,EAAOoB,EAAS,GAC9B5Y,EAAKmiB,EAAI,GAAK3K,EAAOoB,EAAS,GAC9B5Y,EAAKmiB,EAAI,GAAK,IACdvJ,GAAU8mF,EAEZ1xF,EAAQ6yF,aAAapvF,EAAW,EAAG,GACnC2pE,EAAQ53E,KAAK,CACX6T,OAAQspF,EAAWtpF,OACnB1G,MAAO3C,EAAQN,QAElB,CAED,MAAMA,EAASq0E,GACbue,EACAC,EACA1iG,KAAKs7B,YACL4X,EACAlzC,KAAK8iF,gBAAgBzjE,YACrB8zB,EACAkqC,EACAr9E,KAAKyjF,eACLlG,EACAv9E,KAAK6iF,SACL,GACA,GAGF,IAAK,IAAIjhF,EAAI,EAAGqG,EAAMs1E,EAAQp8E,OAAQS,EAAIqG,IAAOrG,EAAG,CAClD,MACMuO,EADSotE,EAAQ37E,GAAGkR,MACH7C,WAAW,MAClCC,GAAcC,GACdR,GAAWhK,KAAKwK,EAAQN,OACzB,CAED,MAAMM,EAAUN,EAAOI,WAAW,MAC5B2D,EAAYzD,EAAQ8C,aACxB,EACA,EACApD,EAAOJ,MACPI,EAAOH,QAGTQ,GAAcC,GACdR,GAAWhK,KAAKkK,GAEX8yF,IACHC,EAAQ,IAAIpwF,WACVqvF,EAAgBjuF,EAAUnE,MAAQmE,EAAUlE,QAE9CizF,EAAQ,IAAIxB,EAAY,GAAGqB,SAASI,EAAMjpF,SAG5C,MAAMxX,EAAOyR,EAAUzR,KACvB,IAAI4Y,EAAkB,EAAT8nF,EACb,IAAK,IAAIjhG,EAAI,EAAGqG,EAAM9F,EAAKhB,OAAQS,EAAIqG,EAAKrG,GAAK,EAC3B,MAAhBO,EAAKP,EAAI,IACXghG,EAAM7nF,GAAU5Y,EAAKP,GACrBghG,EAAM7nF,EAAS,GAAK5Y,EAAKP,EAAI,GAC7BghG,EAAM7nF,EAAS,GAAK5Y,EAAKP,EAAI,KAE7BghG,EAAM7nF,GAAU,EAChB6nF,EAAM7nF,EAAS,GAAK,EACpB6nF,EAAM7nF,EAAS,GAAK,GAEtBA,GAAU8mF,CAEb,CAED7hG,KAAKghG,YAAc2B,EACnB3iG,KAAKkhG,YAAc,CACjBj1F,KAAKiZ,MAAMu9E,EAAcziG,KAAKs7B,aAC9BrvB,KAAKiZ,MAAMw9E,EAAe1iG,KAAKs7B,cAEjCt7B,KAAKwM,MAAQV,CACd,CACD9L,KAAK6H,SACN,CAKD,IAAAyF,GACE,GAAItN,KAAKwM,QAAUV,GAAkB9L,KAAKwM,QAAUV,EAClD,OAEF9L,KAAKwM,MAAQV,EACb9L,KAAK6H,UAEL,IAAIs8E,EAAa,EAEjBnkF,KAAKkjF,qBAAuB,GAC5BljF,KAAKijF,aAAa93E,SAAS+B,IACzB,MAAMV,EAAQU,EAAKC,WACnB,GAAIX,IAAUV,GAAkBU,IAAUV,EACxC,OAEFq4E,IAEA,MAAMC,EAAkBr9E,EACtBmG,EACApF,GACA,WACE,MAAM0E,EAAQU,EAAKC,WAEjBX,GAASV,GACTU,GAASV,GACTU,GAASV,IAETxE,EAAc88E,GACdD,IACmB,IAAfA,IACFnkF,KAAKqkF,mBACLrkF,KAAKgkF,cAGV,GACDhkF,MAEFA,KAAKkjF,qBAAqBv9E,KAAKy+E,EAAgB,IAG9B,IAAfD,EACF1yC,WAAWzxC,KAAKgkF,WAAW98E,KAAKlH,MAAO,GAEvCA,KAAKijF,aAAa93E,SAAQ,SAAU+B,GACpBA,EAAKC,YACNrB,GACXoB,EAAKI,MAEf,GAEG,CAKD,gBAAA+2E,GACErkF,KAAKkjF,qBAAqB/3E,QAAQ7D,GAClCtH,KAAKkjF,qBAAuB,IAC7B,GCvFH,IAAA+f,GAzVA,cAA6BxX,GAI3B,WAAA3rF,CAAY6K,GACV,MAAMwU,OACmB3Y,IAAvBmE,EAAQwU,WAA2B,YAAcxU,EAAQwU,WAE3D,IAAI0C,EAAWlX,EAAQkX,cACNrb,IAAbqb,GAA0B1C,IAC5B0C,EAAWsmE,GAAU,CACnB3uE,OAAQuuE,GAAqB5oE,GAC7B8tB,cAAetiC,EAAQsiC,cACvBG,QAASziC,EAAQyiC,QACjBD,QAASxiC,EAAQwiC,QACjB24C,SAAUn7E,EAAQm7E,YAItB7gF,MAAM,CACJomC,UAAW,GACX6S,aAAcvzC,EAAQuzC,aACtB0mC,wBAAyBj6E,EAAQi6E,wBACjCzlE,WAAYA,EACZ0C,SAAUA,EACV8mE,OAAQh+E,EAAQg+E,OAChBn8E,MAAO7B,EAAQ6B,MACf0S,MAAOvU,EAAQuU,MACfvS,WAAYhC,EAAQgC,WACpBE,YAAalC,EAAQkC,cAOvB7M,KAAK6iF,aAA6Br8E,IAAnBmE,EAAQ6yE,OAAuB7yE,EAAQ6yE,OAAS,EAM/Dx9E,KAAK6lF,UAAYl7E,EAAQm7E,SAAW9mB,GAAOr0D,EAAQm7E,UAAY,KAM/D9lF,KAAK2lF,WAAa,KAMlB3lF,KAAK8rF,iBAAmB,GAKxB9rF,KAAKqT,QAAU1I,EAAQ2I,OAEvBtT,KAAK6hE,kBAAoB7hE,KAAK6hE,kBAAkB36D,KAAKlH,MAKrDA,KAAKgiG,eAAkCx7F,IAAtBmE,EAAQq3F,UAA0B,EAAIr3F,EAAQq3F,UAM/DhiG,KAAKkjG,uBAAyB,GAM9BljG,KAAKmjG,wBAA0B,EAChC,CAQD,YAAAC,CAAaxd,GACX5lF,KAAK2lF,WAAaC,CACnB,CASD,WAAA3B,CAAY1kD,GACV,GAAIv/B,KAAK2lF,WACP,OAAO3lF,KAAK2lF,WAAWpmD,GAEzB,GAAIv/B,KAAK6lF,UACP,OAAO7lF,KAAK6lF,UAEd,MAAMhkE,EAAW7hB,KAAK4pF,cACtB,OAAO/nE,EAAWm9C,GAAOn9C,EAASoiE,YAAY1kD,IAAM,CAAC,IAAK,IAC3D,CAMD,sBAAAgqD,CAAuBpqE,GACrB,MAAMiuE,EAAWptF,KAAK4uB,gBACtB,OAAKw+D,GAAY7hE,GAAW6hE,EAAUjuE,GAC7Bnf,KAAK6iF,QAGP,CACR,CAMD,SAAAtV,CAAUj6D,GACRtT,KAAKqT,QAAUC,CAChB,CAUD,cAAA+vF,CAAe9jE,EAAGloB,EAAGC,EAAG2lE,EAAY5xD,GAClC,MAAM9H,EAAQvjB,KAAKmpF,0BAA0BlM,GACvCoM,EAAe5e,GAAUlrC,EAAGloB,EAAGC,GACrC,GAAIiM,EAAMumD,YAAYuf,GAAe,CACnC,MAAMn8E,EAAOqW,EAAMna,IAAIigF,GACvB,GAAIn8E,GAAQA,EAAK3F,KAAOvH,KAAKgN,SAC3B,OAAOE,CAEV,CAED,MAAM2U,EAAW7hB,KAAK4pF,cAChB0Z,EAAuBr3F,KAAKyP,IAAIxX,MACpC,KACA2d,EAAS+2B,iBAAiB9N,KAAI,CAAC1mB,EAAGmb,KAChC,MAAMumD,EAAW9mB,GAAOn9C,EAASoiE,YAAY1kD,IACvCgkE,EAAcvjG,KAAKikF,YAAY1kD,GACrC,OAAOtzB,KAAKyP,IACV6nF,EAAY,GAAKzd,EAAS,GAC1Byd,EAAY,GAAKzd,EAAS,GAC3B,KAICrD,EAAiBziF,KAAK0pF,yBAAyBr+D,GAC/Cq3D,EAAiB1iF,KAAK0pF,yBAAyBzM,GAC/C1wE,EAAY,CAACgzB,EAAGloB,EAAGC,GACnB80D,EAAmBpsE,KAAKgqF,+BAC5Bz9E,EACA0wE,GAGItyE,EAAUjE,OAAO8C,OACrB,CACE6hB,aACAo3D,iBACAxF,aACAyF,iBACAn2E,YACA6/D,mBACAhxC,WAAYkoE,EACZ9lB,OAAQx9E,KAAKupF,uBAAuBl+D,GACpCs3D,gBAAiB,CAACpjD,EAAGloB,EAAGC,EAAG8jB,IACzBp7B,KAAK2pF,QAAQpqD,EAAGloB,EAAGC,EAAG8jB,EAAY/P,IAEtCrrB,KAAKipF,aAEDwE,EAAU,IAAI+V,GAAe74F,GAEnC,OADA8iF,EAAQlmF,IAAMvH,KAAKgN,SACZygF,CACR,CAUD,OAAA9D,CAAQpqD,EAAGloB,EAAGC,EAAG8jB,EAAYjc,GAC3B,MAAMsM,EAAmBzrB,KAAK4uB,gBAC9B,GACEnD,GACAtM,IACCoM,GAAWE,EAAkBtM,GAE9B,OAAOnf,KAAKqjG,eAAe9jE,EAAGloB,EAAGC,EAAG6H,EAAYsM,GAGlD,MAAM/X,EAAO1T,KAAKikF,YAAY1kD,GACxB8pD,EAAe5e,GAAUlrC,EAAGloB,EAAGC,GACrC,GAAItX,KAAK8oF,UAAUhf,YAAYuf,GAC7B,OAAOrpF,KAAK8oF,UAAU1/E,IAAIigF,GAG5B,MAAMoa,EAAezjG,KAAKqT,QAQ1B,MAAM1I,EAAUjE,OAAO8C,OACrB,CACE+C,UAAW,CAACgzB,EAAGloB,EAAGC,GAClBhE,OATJ,WACE,OAAOnP,GAAU,WACf,OAAOs/F,EAAalkE,EAAGloB,EAAGC,EAClC,GACK,EAMG5D,KAAMA,GAER1T,KAAKipF,aAGD/7E,EAAO,IAAI6zF,GAASp2F,GAK1B,OAJAuC,EAAK3F,IAAMvH,KAAKgN,SAChBE,EAAK5H,iBAAiBwC,EAAkB9H,KAAK6hE,mBAE7C7hE,KAAK8oF,UAAU/+E,IAAIs/E,EAAcn8E,GAC1BA,CACR,CAMD,iBAAA20D,CAAkBh8D,GAChB,MAAMqH,EAAoDrH,EAAY,OAChEsmF,EAAMzjF,EAAOwE,GACbk/E,EAAYl/E,EAAKC,WACvB,IAAIpN,EACAqsF,GAAatgF,GACf9L,KAAK8rF,iBAAiBK,IAAO,EAC7BpsF,EAAOukF,IACE6H,KAAOnsF,KAAK8rF,0BACd9rF,KAAK8rF,iBAAiBK,GAC7BpsF,EACEqsF,GAAatgF,EACTw4E,GACA8H,GAAatgF,EACbw4E,QACA99E,GAEJzG,GACFC,KAAK4F,cAAc,IAAI2iF,GAAgBxoF,EAAMmN,GAEhD,CAMD,wBAAAw8E,CAAyBvqE,GACvB,MAAMiuE,EAAWptF,KAAK4uB,gBACtB,GAAI5uB,KAAK6hB,YAAcurE,GAAY7hE,GAAW6hE,EAAUjuE,IACtD,OAAOnf,KAAK6hB,SAGd,MAAMwrE,EAAU3kF,EAAOyW,GAKvB,OAJMkuE,KAAWrtF,KAAKkjG,yBACpBljG,KAAKkjG,uBAAuB7V,GAC1B3D,GAAyBvqE,IAEtBnf,KAAKkjG,uBAAuB7V,EACpC,CAcD,wBAAAO,CAAyBzuE,EAAY0uE,GACnC,MAAMC,EAAOl/D,GAAczP,GAC3B,GAAI2uE,EAAM,CACR,MAAMT,EAAU3kF,EAAOolF,GACjBT,KAAWrtF,KAAKkjG,yBACpBljG,KAAKkjG,uBAAuB7V,GAAWQ,EAE1C,CACF,CAMD,yBAAA1E,CAA0BhqE,GACxB,MAAMiuE,EAAWptF,KAAK4uB,gBACtB,IAAKw+D,GAAY7hE,GAAW6hE,EAAUjuE,GACpC,OAAOnf,KAAK8oF,UAGd,MAAMuE,EAAU3kF,EAAOyW,GAIvB,OAHMkuE,KAAWrtF,KAAKmjG,0BACpBnjG,KAAKmjG,wBAAwB9V,GAAW,IAAItE,GAAU,KAEjD/oF,KAAKmjG,wBAAwB9V,EACrC,CAMD,WAAAzjB,CAAYzqD,EAAYgnD,GACtB,MAAM+mB,EAAgBltF,KAAKmpF,0BAA0BhqE,GAErDnf,KAAK8oF,UAAUlf,YACb5pE,KAAK8oF,WAAaoE,EAAgB/mB,EAAY,CAAE,GAElD,IAAK,MAAM34D,KAAMxN,KAAKmjG,wBAAyB,CAC7C,MAAMra,EAAY9oF,KAAKmjG,wBAAwB31F,GAC/Cs7E,EAAUlf,YAAYkf,GAAaoE,EAAgB/mB,EAAY,CAAE,EAClE,CACF,CAED,KAAAxhE,GACEM,MAAMN,QACN,IAAK,MAAM6I,KAAMxN,KAAKmjG,wBACpBnjG,KAAKmjG,wBAAwB31F,GAAI7I,OAEpC,GC1WH,SAAA++F,GAAAC,EAAA7wF,GACA,IAAA6wF,EACA,OAAA,EAEA,IAAA,IAAAA,EACA,OAAA,EAEA,GAAA,IAAA7wF,EAAA8wF,qBACA,OAAA,EAEA,MAAAC,EAAA/wF,EAAAgxF,cAAAC,0BACAC,EAA0BC,QAAcC,QAAAC,2BACxC,OACAN,IAAAG,EAAAI,MACAP,IAAAG,EAAAK,OACAR,IAAAG,EAAAM,QACAT,IAAAG,EAAAO,MAEA,CAkDA,MAAAC,GAAA,qBACAC,GAAA,qBAQA,IAAAC,GAcA,SAAAC,GAAA7xF,GACA,IACA,OAAAA,EAAA6xF,gBACA,CAAA,MAAA74D,GACA,MAAA,CAAA,EAAA,EAAAh5B,EAAAsJ,WAAAtJ,EAAAuJ,YACA,CACA,CAQA,SAAA+7D,GAAAtlE,GACA,IACA,OAAAA,EAAAslE,YAAAt0E,MAAA,EAAA,EACA,CAAA,MAAAgoC,GACA,MAAA,CAAA,EAAAh5B,EAAAuJ,YACA,CACA,CASA,SAAAu8B,GAAA9lC,EAAA8xF,GACA,IACA,OAAA9xF,EAAA4oB,cAAAkpE,EACA,CAAA,MAAA94D,GACA,MAAA,CACA84D,EAAAxoF,WAAAtJ,EAAAsJ,WACAwoF,EAAAvoF,YAAAvJ,EAAAuJ,YAEA,CACA,CAMA,SAAAuS,GAAA9b,GACA,MAAA+xF,EAAA/xF,EAAA+xF,QACA,IAAAA,EACA,OAAA,KAGA,GACAA,EAAAC,uBACA,QAAAD,EAAAC,sBACA,CACA,MAAAjlF,EAAA,QAAAglF,EAAAC,sBACA,IAAA3lF,EAAA4lF,GAAAllF,GACA,IAAAV,EAAA,CACA,MAAAwD,EAAAqiF,GAAAH,EAAAI,uBACAtiF,IACAxD,EAAA,IAAAuD,GAAA,CACA7C,KAAAA,EACA8C,MAAAA,IAGA,CACA,OAAAxD,CACA,CAEA,GAAA0lF,EAAAK,sBAAA,QAAAL,EAAAK,qBAAA,CACA,MAAArlF,EAAA,QAAAglF,EAAAK,qBACA,IAAA/lF,EAAA4lF,GAAAllF,GACA,IAAAV,EAAA,CACA,MAAAwD,EAAAqiF,GAAAH,EAAAM,wBACAxiF,IACAxD,EAAA,IAAAuD,GAAA,CACA7C,KAAAA,EACA8C,MAAAA,IAGA,CACA,OAAAxD,CACA,CAEA,OAAA,IACA,CAMA,SAAAimF,GAAAC,GACA,OAAAA,EAAAC,gBAAAvxF,MAAA,SAAA+5C,GACA,MAAAy3C,EAAA,IAAAljG,MAAAyrD,GACA,IAAA,IAAAlsD,EAAA,EAAAA,EAAAksD,IAAAlsD,EACA2jG,EAAA3jG,GAAAyjG,EAAA7pE,SAAA55B,GAEA,OAAA2C,QAAA2xD,IAAAqvC,EACA,GACA,CAOA,SAAAC,GAAAt7F,EAAAS,GACA,IAAA86F,EAQA,OANAA,EADAv7F,EAAAw7F,KACczB,QAAY0B,SAAAz7F,EAAAw7F,MAC1Bx7F,EAAA07F,UACc3B,QAAY4B,SAAA37F,EAAA0jE,IAAA1jE,EAAA07F,UAAAj7F,GAEZs5F,QAAW6B,QAAA57F,EAAA0jE,IAAAjjE,GAEzB86F,EAAA1xF,KAAAqxF,GACA,CASA,SAAAW,GAAAC,EAAAC,EAAA9qF,EAAA4c,EAAAmuE,GACA,GAAA7jG,MAAAC,QAAA0jG,GAAA,CACA,MAAA7kG,EAAA6kG,EAAA7kG,OACA,IAAAkB,MAAAC,QAAA2jG,IAAA9kG,GAAA8kG,EAAA9kG,OAAA,CACA,MAAAoO,EAAA,IAAA/G,MAAAuvB,GAEA,MADAmuE,EAAA32F,GACAA,CACA,CACA,IAAA,IAAA3N,EAAA,EAAAA,EAAAT,IAAAS,EACAmkG,GAAAC,EAAApkG,GAAAqkG,EAAArkG,GAAAuZ,EAAA4c,EAAAmuE,EAGA,MAGA,GAAAj6F,KAAAmP,IAAA4qF,EAAAC,GAAA9qF,EAAA6qF,EACA,MAAA,IAAAx9F,MAAAuvB,EAEA,CA0BA,SAAAouE,GAAAz7F,GACA,OAAAA,aAAA07F,UACA,IAEA17F,aAAA8H,YAGA9H,aAAA+H,kBAFA,IAKA/H,aAAA27F,WACA,MAEA37F,aAAA47F,YACA,MAEA57F,aAAA67F,WACA,WAEA77F,aAAA87F,YACA,WAEA97F,aAAAgI,aACA,MAEA,GACA,CAqDA,MAAA+zF,WAAA1F,GAIA,WAAAjhG,CAAA6K,GACA1F,MAAA,CACAuH,MAAA,UACAqV,SAAA,KACA1C,WAAAxU,EAAAwU,YAAA,KACAwpE,OAAAh+E,EAAAg+E,OACAh8E,WAAAhC,EAAAgC,WACAE,aAAA,IAAAlC,EAAAkC,YACAqS,MAAAvU,EAAAuU,QAOAlf,KAAA0mG,YAAA/7F,EAAA4yE,QAEA,MAAAopB,EAAA3mG,KAAA0mG,YAAAvlG,OAMAnB,KAAA4mG,eAAAj8F,EAAAk8F,cAMA7mG,KAAA8mG,eAAA,IAAAzkG,MAAAskG,GAMA3mG,KAAA+mG,aAAA,IAAA1kG,MAAAskG,GAMA3mG,KAAAgnG,mBAAA,IAAA3kG,MAAAskG,GAMA3mG,KAAAinG,iBAMAjnG,KAAAknG,cAMAlnG,KAAAmnG,UAMAnnG,KAAAonG,YAAA,IAAAz8F,EAAAghC,UAMA3rC,KAAAqnG,WAAA,EAMArnG,KAAAwT,OAAA,KAKAxT,KAAAsnG,cAAA38F,EAAA48F,eAAA,EAEAvnG,KAAAwpF,OAAAxpF,KAAA0mG,YAAA57D,KAAA5gC,GAAAA,EAAA0jE,MAAA90D,KAAA,MAEA,MAAAjK,EAAA7O,KACAulG,EAAA,IAAAljG,MAAAskG,GACA,IAAA,IAAA/kG,EAAA,EAAAA,EAAA+kG,IAAA/kG,EACA2jG,EAAA3jG,GAAA4jG,GACAxlG,KAAA0mG,YAAA9kG,GACA5B,KAAA4mG,gBAGAriG,QAAA2xD,IAAAqvC,GACAxxF,MAAA,SAAAwpE,GACA1uE,EAAA24F,WAAAjqB,EACA,IACAvpE,OAAA,SAAAzE,GACAk4F,GAAAl4F,GACAV,EAAA2E,OAAAjE,EACAV,EAAA9B,SAAA,QACA,GACA,CAcA,QAAA+G,GACA,OAAA9T,KAAAwT,MACA,CAWA,mBAAAk0F,CAAAnqB,GACA,MAAAoqB,EAAApqB,EAAA,GACA,IAAA,IAAA37E,EAAA+lG,EAAAxmG,OAAA,EAAAS,GAAA,IAAAA,EAAA,CACA,MACAud,EAAAyP,GADA+4E,EAAA/lG,IAEA,GAAAud,EAAA,CACAnf,KAAAmf,WAAAA,EACA,KACA,CACA,CACA,CASA,UAAAqoF,CAAAjqB,GACA,IAAA/jE,EACAisE,EACAmiB,EACAC,EACAl3D,EACA,MAAAm3D,EAAA,IAAAzlG,MAAAk7E,EAAAp8E,QACA4mG,EAAA,IAAA1lG,MAAAk7E,EAAAp8E,QACA6mG,EAAA,IAAA3lG,MAAAk7E,EAAAp8E,QACA,IAAAgsC,EAAA,EAEA,MAAA86D,EAAA1qB,EAAAp8E,OACA,IAAA,IAAA+mG,EAAA,EAAAA,EAAAD,IAAAC,EAAA,CACA,MAAAC,EAAA,GACAC,EAAA,GACA7qB,EAAA2qB,GAAA/8F,SAAAG,IAlgBA,IAAA,GAmgBAA,EArgBAw4F,cACAuE,gBAAA,IAqgBAD,EAAAziG,KAAA2F,GAEA68F,EAAAxiG,KAAA2F,EACA,IAGA,MAAAg9F,EAAAH,EAAAhnG,OACA,GAAAinG,EAAAjnG,OAAA,GAAAinG,EAAAjnG,SAAAmnG,EACA,MAAA,IAAA9/F,MACA,qCAAA4/F,EAAAjnG,oBAAAmnG,YAIA,IAAAv7E,EACAw7E,EACA,MAAAC,EAAA,IAAAnmG,MAAAimG,GACAG,EAAA,IAAApmG,MAAAimG,GACAI,EAAA,IAAArmG,MAAAimG,GAEAP,EAAAG,GAAA,IAAA7lG,MAAAimG,GACAN,EAAAE,GAAA,IAAA7lG,MAAAimG,GAEA,IAAA,IAAAK,EAAA,EAAAA,EAAAL,IAAAK,EAAA,CACA,MAAA71F,EAAAq1F,EAAAQ,GACAC,EAAA91F,EAAA+1F,gBACAb,EAAAE,GAAAS,GAAA71F,EAAAg2F,gBAAA,GACAf,EAAAG,GAAAS,GAAAC,EAEA,MAAAG,EAAA/oG,KAAA0mG,YAAAwB,GAAAc,MACAlB,EAAAI,GAAAa,EACAA,EAAA5nG,OACA2R,EAAA8wF,qBACA,MAAA36E,EAAAq/E,GAAAK,EAAA,GAEA57E,IACAA,EAAA43E,GAAA7xF,IAGAy1F,IACAA,EAAAnwB,GAAAtlE,IAGA,MAAAm2F,EAAArwD,GAAA9lC,EAAAq1F,EAAA,IACAO,EAAAz/E,GAAAggF,EAAA,GAEA,MAAAC,EAAA,CAAAp2F,EAAAq2F,eAAAr2F,EAAAs2F,iBAIAF,EAAA,KAAAA,EAAA,IACAA,EAAA,GAveA,MAyeAA,EAAA,GAzeA,IA0eAA,EAAA,GA1eA,KA6eAV,EAAAv/E,GAAAigF,EAEA,MAAAG,EAAAJ,EAAA,GAAAh9F,KAAAmP,IAAA6tF,EAAA,IACAR,EAAAx/E,GAAA,CACAigF,EAAA,GACAA,EAAA,GAAAG,EAEA,CAQA,GANA7vF,EAGAoE,GAAApE,EAAAuT,EAAAvT,GAFAA,EAAAuT,EAKA04D,EAEA,CAEAsgB,GAAAtgB,EAAA8iB,EAAA,EADA,8BAAAL,WAAAK,oBAAA9iB,KACAzlF,KAAAglF,aACA,MAJAS,EAAA8iB,EAMA,GAAA53D,EAGA,CACAA,EAAAxvC,OAAAgsC,EAAAu7D,EAAAvnG,SACAgsC,EAAAwD,EAAAxvC,OAAAunG,EAAAvnG,QAEA,MAAAmoG,EACA34D,EAAAA,EAAAxvC,OAAA,GACAunG,EAAAA,EAAAvnG,OAAA,GACAnB,KAAAgnG,mBAAAkB,GAAAoB,EACA,MAAAC,EAAAb,EAAA59D,KACAnuB,GAAAA,EAAA2sF,IAEAvxE,EAAA,kCAAAmwE,WAAAqB,oBAAA54D,KACAo1D,GACAp1D,EAAA7sC,MAAAqpC,EAAAwD,EAAAxvC,QACAooG,EACA,IACAxxE,EACA/3B,KAAAglF,aAEA,MArBAr0C,EAAA+3D,EACA1oG,KAAAgnG,mBAAAkB,GAAA,EAsBAN,EAGA7B,GACA6B,EAAA9jG,MAAAqpC,EAAAy6D,EAAAzmG,QACAsnG,EACA,IACA,iCAAAP,IACAloG,KAAAglF,cAPA4iB,EAAAa,EAWAZ,EAGA9B,GACA8B,EAAA/jG,MAAAqpC,EAAA06D,EAAA1mG,QACAqnG,EACA,EACA,iCAAAN,IACAloG,KAAAglF,cAPA6iB,EAAAW,EAWAxoG,KAAA8mG,eAAAoB,GAAAC,EAAAqB,UACAxpG,KAAA+mG,aAAAmB,GAAAE,EAAAoB,SACA,CAEA,IAAA,IAAA5nG,EAAA,EAAAuE,EAAAnG,KAAA8mG,eAAA3lG,OAAAS,EAAAuE,IAAAvE,EAAA,CACA,MAAA6nG,EAAAzpG,KAAA8mG,eAAAllG,GACA,KAAA6nG,EAAAtoG,OAAAwvC,EAAAxvC,QACAsoG,EAAAC,aAAAljG,EAEA,CAEAxG,KAAA4uB,iBACA5uB,KAAA0nG,oBAAAnqB,GAGAv9E,KAAAinG,iBAAAa,EACA9nG,KAAAknG,cAAAa,EACA/nG,KAAAmnG,UAAAa,EAGA2B,EAAA,IAAA,IAAAzB,EAAA,EAAAA,EAAAD,IAAAC,EAAA,CAEA,QAAA1hG,IAAAxG,KAAA0mG,YAAAwB,GAAA0B,OAAA,CACA5pG,KAAAqnG,WAAA,EACA,KACA,CACA,GAAArnG,KAAA+mG,aAAAmB,GAAA/mG,OAAA,CACAnB,KAAAqnG,WAAA,EACA,KACA,CAEA,MAAAp+F,EAAA8+F,EAAAG,GAGAc,EAAAhpG,KAAA0mG,YAAAwB,GAAAc,MACA,GAAAA,GACA,IAAA,IAAApnG,EAAA,EAAAA,EAAAonG,EAAA7nG,SAAAS,EACA,GAAA,OAAAqH,EAAA+/F,EAAApnG,GAAA,GAAA,CACA5B,KAAAqnG,WAAA,EACA,MAAAsC,CACA,OAMA,IAAA,IAAAhB,EAAA,EAAAA,EAAA1/F,EAAA9H,SAAAwnG,EACA,GAAA,OAAA1/F,EAAA0/F,GAAA,CACA3oG,KAAAqnG,WAAA,EACA,MAAAsC,CACA,CAEA,CAEA,IAAA3H,EAAAhiG,KAAAqnG,UAAA,EAAA,EACA,IAAA,IAAAa,EAAA,EAAAA,EAAAD,IAAAC,EACAlG,GAAA8F,EAAAI,GAEAloG,KAAAgiG,UAAAA,EAEA,MAAAngF,EAAA,IAAAqmE,GAAA,CACA1uE,OAAAA,EACA2zB,QAAAA,EACAs4C,OAAAA,EACA90C,YAAAA,EACAi1C,UAAAgiB,IAGA5nG,KAAA6hB,SAAAA,EACA7hB,KAAAojG,aAAAyE,GAEA7nG,KAAAutE,UAAAvtE,KAAA6pG,UAAA3iG,KAAAlH,OACAA,KAAA+M,SAAA,SAGA,IAAA4jC,EAAAxvC,OACAwvC,EAAA,CAAAA,EAAA,GAAAA,EAAA,GAAAA,EAAA,GAAA,GACA,IAAAA,EAAAxvC,SACAwvC,EAAA,CAAA,EAAAA,EAAA,GAAAA,EAAA,GAAAA,EAAA,GAAA,IAGA3wC,KAAA+kF,aAAA,CACA10C,gBAAA,EACAlxB,WAAAnf,KAAAmf,WACAwxB,YAAAA,EACAj0B,OAAAwP,GAAA5P,GAAA9C,GAAAxZ,KAAAmf,YACA3F,OAAA6S,GAAA7S,EAAAxZ,KAAAmf,YACAi2B,KAbA,GAeA,CASA,SAAAy0D,CAAAtqE,EAAAloB,EAAAC,GACA,MAAA4xF,EAAAlpG,KAAAikF,YAAA1kD,GACA0oE,EAAAjoG,KAAA8mG,eAAA3lG,OACAokG,EAAA,IAAAljG,MAAA,EAAA4lG,GACAF,EAAA/nG,KAAAknG,cACA4C,EAAA9pG,KAAA0mG,YACAqD,GAnpBArF,KACAA,GAAA,IAAqBT,QAAI+F,MAEzBtF,IAipBA,IAAA,IAAAwD,EAAA,EAAAA,EAAAD,IAAAC,EAAA,CACA,MAAAh+F,EAAA4/F,EAAA5B,GACAoB,EAAAtpG,KAAAgnG,mBAAAkB,GACA+B,EAAA,CACAh+F,KAAAiZ,MAAA7N,GAAA6xF,EAAA,GAAAI,IACAr9F,KAAAiZ,MAAA5N,GAAA4xF,EAAA,GAAAI,IACAr9F,KAAAiZ,OAAA7N,EAAA,IAAA6xF,EAAA,GAAAI,IACAr9F,KAAAiZ,OAAA5N,EAAA,IAAA4xF,EAAA,GAAAI,KAEAx2F,EAAA9S,KAAA8mG,eAAAoB,GAAA3oE,GACA,IAAA2qE,EAQAC,EAPAjgG,EAAA8+F,QACAkB,EAAAhgG,EAAA8+F,MAAAl+D,KAAA,SAAAs/D,GACA,OAAAA,EAAA,CACA,KAMAD,EADA,WAAAjgG,GAAA,OAAAA,EAAA0/F,OACA1/F,EAAA0/F,OAEAM,EAGAA,EAAAp/D,KAAA,SAAAu/D,GACA,OAAAtC,EAAAG,GAAAmC,EACA,IAJAtC,EAAAG,GAQA,MAAAoC,EAAA,CACAh7F,OAAA26F,EACAx6F,MAAAy5F,EAAA,GACAx5F,OAAAw5F,EAAA,GACAgB,QAAAA,EACAC,UAAAA,EACAJ,KAAAA,EACAQ,YAAA,GAEA7G,GAAA1jG,KAAAsnG,cAAAx0F,GACAyyF,EAAA2C,GAAAp1F,EAAA4wF,QAAA4G,GAEA/E,EAAA2C,GAAAp1F,EAAA03F,YAAAF,GAIA,MAAAG,EAAAxC,EAAAC,EACAja,EAAAjuF,KAAA+mG,aAAAmB,GAAA3oE,GACA0uD,EAKAsX,EAAAkF,GAAAxc,EAAAuc,YAAA,CACAl7F,OAAA26F,EACAx6F,MAAAy5F,EAAA,GACAx5F,OAAAw5F,EAAA,GACAgB,QAAA,CAAA,GACAH,KAAAA,EACAQ,YAAA,IAVAhF,EAAAkF,GAAAlmG,QAAAE,QAAA,KAYA,CAEA,OAAAF,QAAA2xD,IAAAqvC,GACAxxF,KAAA/T,KAAA0qG,aAAAxjG,KAAAlH,KAAAkpG,IACAl1F,OAAA,SAAAzE,GAEA,MADAk4F,GAAAl4F,GACAA,CACA,GACA,CAQA,YAAAm7F,CAAAxB,EAAAyB,GACA,MAAA3C,EAAAhoG,KAAAmnG,UACA2C,EAAA9pG,KAAA0mG,YACAuB,EAAAjoG,KAAA8mG,eAAA3lG,OACA6gG,EAAAhiG,KAAAgiG,UACA8F,EAAA9nG,KAAAinG,iBACAc,EAAA/nG,KAAAknG,cACAv7D,EAAA3rC,KAAAonG,WACAwD,EAAA5qG,KAAAqnG,UAEA7F,EAAA0H,EAAA,GAAAA,EAAA,GACA2B,EAAArJ,EAAAQ,EAGA,IAAA7/F,EAEAA,EADAwpC,EACA,IAAAn5B,WAAAq4F,GAEA,IAAAn4F,aAAAm4F,GAGA,IAAA1I,EAAA,EACA,IAAA,IAAA2I,EAAA,EAAAA,EAAAtJ,IAAAsJ,EAAA,CACA,IAAAC,EAAAH,EACA,IAAA,IAAA1C,EAAA,EAAAA,EAAAD,IAAAC,EAAA,CACA,MAAAh+F,EAAA4/F,EAAA5B,GAEA,IAEA8C,EAAAC,EAFAxvF,EAAAvR,EAAAuR,IACAC,EAAAxR,EAAAwR,IAEA,GAAAiwB,EAAA,CACA,MAAAu/D,EAAAlD,EAAAE,GAAA,QACA1hG,IAAAiV,IAEAA,EADAyvF,GAAAzG,MAAAyG,EACAngE,WAAAmgE,EAAAzG,MApmBA/5F,EAsmBAigG,EAAAzC,GAAA,cArmBA9B,WACA,IAEA17F,aAAA27F,YACA,MAEA37F,aAAA67F,YACA,WAEA77F,aAAAgI,aACA,OAEA,QA4lBAlM,IAAAkV,IAEAA,EADAwvF,GAAA1G,MAAA0G,EACAngE,WAAAmgE,EAAA1G,KAEA2B,GAAAwE,EAAAzC,GAAA,KAIA8C,EAAA,KAAAtvF,EAAAD,GACAwvF,GAAAxvF,EAAAuvF,CACA,CAEA,IACA,IAAAX,EAAA,EACAA,EAAAvC,EAAAI,KACAmC,EACA,CACA,MAAAc,EACAR,EAAAzC,GAAAmC,GAAAS,GAEA,IAAAzmG,EAOA,GALAA,EADAsnC,EACA7nB,GAAAknF,EAAAG,EAAAF,EAAA,EAAA,KAEAE,EAGAP,EAEA,CACA,IAAAhB,EAAA1/F,EAAA0/F,OACA,QAAApjG,IAAAojG,EAAA,CACA,IAAAwB,EAEAA,EADAlhG,EAAA8+F,MACA9+F,EAAA8+F,MAAAqB,GAAA,EAEAA,EAEAT,EAAA7B,EAAAG,GAAAkD,EACA,CAEA,MAAAC,EAAA78E,MAAAo7E,KAEAyB,GAAAF,IAAAvB,GACAyB,IAAA78E,MAAA28E,MAEAJ,GAAA,EACA5oG,EAAAggG,GAAA99F,EAEA,MArBAlC,EAAAggG,GAAA99F,EAsBA89F,GACA,CACA,IAAA4I,EAAA,CACA,MACA9c,EAAA0c,EADA1C,EAAAC,GAEAja,IAAAA,EAAA,GAAA6c,KACAC,GAAA,EAEA,CACA,CACAH,IACAG,IACA5oG,EAAAggG,GAAA,KAEAA,IAEA,CA3qBA,IAAAz3F,EA6qBA,OAAAvI,CACA,EAwBAskG,GAAA5iG,UAAA85C,QAEA,IAAA2tD,GAAA7E,UC78BO,cAAyB7Z,GAU9B,WAAA9sF,CACEgmF,EACAv5E,EACAC,EACAquB,EACAwB,EACAC,EACA3xB,GAEA1F,MAAMsH,EAAWC,EAAOquB,EAAKwB,EAAaC,EAAkB3xB,GAM5D3K,KAAKurG,cAAgB,KAKrBvrG,KAAK6lF,UAAYC,CAClB,CAMD,QAAAtqD,GACE,GAAIx7B,KAAKurG,cACP,OAAOvrG,KAAKurG,cAEd,MAAMz4F,EAAQ7N,MAAMu2B,WACpB,GAAIx7B,KAAKwM,OAASV,EAAkB,CAClC,MAAMg6E,EAAW9lF,KAAK6lF,UACtB,GAAI/yE,EAAMrD,OAASq2E,EAAS,IAAMhzE,EAAMpD,QAAUo2E,EAAS,GAEzD,OADA9lF,KAAKurG,cAAgBz4F,EACdA,EAET,MAAM3C,EAAUX,GAAsBs2E,EAAS,GAAIA,EAAS,IAG5D,OAFA31E,EAAQ6C,UAAUF,EAAO,EAAG,GAC5B9S,KAAKurG,cAAgBp7F,EAAQN,OACtBM,EAAQN,MAChB,CACD,OAAOiD,CACR,GAiNH,IAAA04F,GAjKA,cAAsBrd,GAIpB,WAAAruF,CAAY6K,GACV,MAAM+I,EAAO/I,EAAQ+I,KACf+3F,OAC4BjlG,IAAhCmE,EAAQ8gG,oBACJ9gG,EAAQ8gG,oBACR,UAEA5iB,EAAiBl+E,EAAQk+E,gBAAkB,EAC3C6G,EAAah8E,EAAK,GAClBi8E,EAAcj8E,EAAK,GACnBg4F,EAAkB,GAClB5lB,EAAWn7E,EAAQm7E,UAAYv2C,GACrC,IAAIo8D,EAAiC7lB,EAAW+C,EAEhD,OAAQ4iB,GACN,IAAK,UACH,KACE/b,EAAaic,GACbhc,EAAcgc,GAEdD,EAAgB/lG,KAAK,CACnBsG,KAAKkZ,KAAKuqE,EAAaic,GACvB1/F,KAAKkZ,KAAKwqE,EAAcgc,KAE1BA,GAAkCA,EAEpC,MACF,IAAK,YACH,IAAIl8F,EAAQigF,EACRhgF,EAASigF,EACb,KACElgF,EAAQk8F,GACRj8F,EAASi8F,GAETD,EAAgB/lG,KAAK,CACnBsG,KAAKkZ,KAAK1V,EAAQk8F,GAClB1/F,KAAKkZ,KAAKzV,EAASi8F,KAErBl8F,IAAU,EACVC,IAAW,EAEb,MACF,QACE,MAAM,IAAIlH,MAAM,4CAGpBkjG,EAAgB/lG,KAAK,CAAC,EAAG,IACzB+lG,EAAgBlC,UAEhB,MAAM74D,EAAc,CAACk4C,GACf+iB,EAAoB,CAAC,GAC3B,IAAK,IAAIhqG,EAAI,EAAGuE,EAAKulG,EAAgBvqG,OAAQS,EAAIuE,EAAIvE,IACnD+uC,EAAYhrC,KAAKkjF,GAAkBjnF,GACnCgqG,EAAkBjmG,KAChB+lG,EAAgB9pG,EAAI,GAAG,GAAK8pG,EAAgB9pG,EAAI,GAAG,GACjDgqG,EAAkBhqG,EAAI,IAG5B+uC,EAAY64D,UAEZ,MAAM3nF,EAAW,IAAIqmE,GAAS,CAC5BpC,SAAUA,EACVtsE,OAAQ7O,EAAQ6O,QAAU,CAAC,GAAIm2E,EAAaD,EAAY,GACxD/+C,YAAaA,IAGf,IAAIi9B,EAAMjjE,EAAQijE,KACdA,GAAQA,EAAIloE,SAAS,gBAAmBkoE,EAAIloE,SAAS,iBACvDkoE,GAAO,+BAET,MAAMqd,EAAOD,GAAUpd,GAEvB,IAAIi+B,EAAY/lB,EAAW+C,EAuC3B,MAAM8C,EAAkBd,GACtBI,EAAKngD,KAlCP,SAA4B7jB,GAC1B,OAAA,SAOY1a,EAAW6uB,EAAYjc,GAC/B,IAAK5S,EACH,OAEF,MAAMs6E,EAAat6E,EAAU,GACvBu6E,EAAav6E,EAAU,GACvBw6E,EAAax6E,EAAU,GACvBu/F,EACJhlB,EAAaC,EAAa2kB,EAAgB7kB,GAAY,GAGlDklB,EAAe,CACnBxsE,EAAKsnD,EACLxvE,EAAKyvE,EACLxvE,EAAKyvE,EACL+kB,UAAaA,EACbE,UAAa,cANXF,EAAYF,EAAkB/kB,IAAeglB,EAAa,IAQ9D,OAAO5kF,EAASzD,QAAQ,eAAe,SAAUrD,EAAGi2E,GAClD,OAAO2V,EAAa3V,EAChC,GAEQ,CACH,KAMK6V,EAAmBC,GAAWhlG,KAClC,KACA83D,GAAO8mB,EAAW+C,IAGpB5jF,MAAM,CACJi5C,aAAcvzC,EAAQuzC,aACtB7S,UAAW1gC,EAAQ0gC,UACnBhP,YAAa1xB,EAAQ0xB,YACrBxvB,YAAalC,EAAQkC,YACrBsS,WAAYxU,EAAQwU,WACpB0pE,eAAgBA,EAChBmE,2BAA4BriF,EAAQqiF,2BACpCL,UAAWsf,EACXpqF,SAAUA,EACV8pE,gBAAiBA,EACjBh/E,WAAYhC,EAAQgC,aAMtB3M,KAAKkpF,WAAav+E,EAAQu+E,WAM1B,MAIMijB,EAAcxgB,EAJJ9pE,EAASqlE,kCACvB5qE,GAAUuF,EAASxC,aACnBsxB,EAAYA,EAAYxvC,OAAS,IAEU,EAAG,MAC1C2R,EAAQ,IAAI/D,MAClB+D,EAAMxN,iBAAiB,SAAS,KAC9BumG,EAAY/lB,EACZ9lF,KAAK6H,SAAS,IAEhBiL,EAAM+nB,IAAMsxE,CACb,GCrOI,MAAMC,GACD,WADCA,GAED,WAFCA,GAGD,WASNC,GAAsB,CAAA,EAC5BA,GAAoBD,IAAqB,CACvCE,OAAU,CACRC,SAAU,GACVC,QAAS,GACTC,UAAW,CAAC,WAEdC,OAAU,CACRH,SAAU,CAAC,aAAc,UAAW,UAAW,aAC/CC,QAAS,CAAC,OACVC,UAAW,CAAC,WAEdE,OAAU,CACRJ,SAAU,CACR,aACA,cACA,UACA,UACA,YACA,mBACA,YAEFC,QAAS,CAAC,MAAO,OACjBC,UAAW,CAAC,SAAU,QAAS,OAAQ,aAG3CJ,GAAoBD,IAAqB,CACvCE,OAAU,CACRC,SAAU,GACVC,QAAS,CAAC,OACVC,UAAW,CAAC,YAEdC,OAAU,CACRH,SAAU,CAAC,aAAc,UAAW,UAAW,aAC/CC,QAAS,CAAC,OACVC,UAAW,CAAC,YAEdE,OAAU,CACRJ,SAAU,CACR,aACA,cACA,UACA,UACA,YACA,mBACA,oBACA,YAEFC,QAAS,CAAC,MAAO,OACjBC,UAAW,CAAC,UAAW,aAG3BJ,GAAoBD,IAAqB,CACvCE,OAAU,CACRC,SAAU,GACVC,QAAS,CAAC,OACVC,UAAW,CAAC,YAEdC,OAAU,CACRH,SAAU,CAAC,aAAc,eAAgB,UAAW,UAAW,YAC/DC,QAAS,CAAC,OACVC,UAAW,CAAC,YAEdE,OAAU,CACRJ,SAAU,CACR,aACA,eACA,cACA,UACA,UACA,YACA,mBACA,YAEFC,QAAS,CAAC,MAAO,OACjBC,UAAW,CAAC,aAGhBJ,GAA0B,KAAI,CAC5BrjF,KAAQ,CACNujF,SAAU,GACVC,QAAS,GACTC,UAAW,KAIf,MAAMG,GACJ,+FACIC,GACJ,8DACIC,GACJ,+EAgJF,MAAMC,GAAmB,CAAA,EACzBA,GAAiBX,IA/IjB,SAAiCY,GAC/B,IAAIC,EAAeD,EAASE,sCAK5B,YAHqB1mG,IAAjBymG,IACFA,EAAeZ,GAAoBD,IAA2B,QAEzD,CACLx+B,SACgCpnE,IAA9BwmG,EAASG,UAAU,YACf3mG,EACAwmG,EAASG,UAAU,OAAO3pF,QAAQ,uBAAwB,IAChE+oF,SAAUU,EAAaV,SACvBC,QAAS,IACJS,EAAaT,aACehmG,IAA/BwmG,EAASG,UAAUX,QACf,GACAQ,EAASG,UAAUX,SAEzBC,UAAW,IACNQ,EAAaR,eACiBjmG,IAAjCwmG,EAASG,UAAUV,UACf,GACAO,EAASG,UAAUV,WAEzB97D,YAAaq8D,EAASG,UAAUC,cAChCtnB,cACoCt/E,IAAlCwmG,EAASG,UAAUE,gBACoB7mG,IAAnCwmG,EAASG,UAAUG,YACjB,CAACN,EAASG,UAAUE,WAAYL,EAASG,UAAUG,aACnD,CAACN,EAASG,UAAUE,WAAYL,EAASG,UAAUE,YACnB7mG,MAAlCwmG,EAASG,UAAUG,YACnB,CAACN,EAASG,UAAUG,YAAaN,EAASG,UAAUG,kBACpD9mG,EAEV,EA8GAumG,GAAiBX,IA5GjB,SAAiCY,GAC/B,MAAMC,EAAeD,EAASE,sCAC5BK,EACElrG,MAAMC,QAAQ0qG,EAASG,UAAUK,UACjCR,EAASG,UAAUK,QAAQrsG,OAAS,EACtCssG,EACEF,GAAqBP,EAASG,UAAUK,QAAQ,GAAGjB,SAC/CS,EAASG,UAAUK,QAAQ,GAAGjB,SAC9B,GACNmB,EACEH,GAAqBP,EAASG,UAAUK,QAAQ,GAAGhB,QAC/CQ,EAASG,UAAUK,QAAQ,GAAGhB,QAC9B,GACNmB,EACEJ,GAAqBP,EAASG,UAAUK,QAAQ,GAAGf,UAC/CO,EAASG,UAAUK,QAAQ,GAAGf,UAC9B,GACR,MAAO,CACL7+B,IAAKo/B,EAASG,UAAU,OAAO3pF,QAAQ,uBAAwB,IAC/D0iE,WAC+B1/E,IAA7BwmG,EAASG,UAAUjnB,WACf1/E,EACAwmG,EAASG,UAAUjnB,MAAMp7C,KAAI,SAAUp3B,GACrC,MAAO,CAACA,EAAKjE,MAAOiE,EAAKhE,OACrC,IACIo2E,cAC+Bt/E,IAA7BwmG,EAASG,UAAUS,WACfpnG,EACA,CACEwmG,EAASG,UAAUS,MAAM9iE,KAAI,SAAU59B,GACrC,OAAOA,EAAKuC,KACb,IAAE,GACHu9F,EAASG,UAAUS,MAAM9iE,KAAI,SAAU59B,GACrC,YAAuB1G,IAAhB0G,EAAKwC,OAAuBxC,EAAKuC,MAAQvC,EAAKwC,MACtD,IAAE,IAEXihC,iBAC+BnqC,IAA7BwmG,EAASG,UAAUS,WACfpnG,EACAwmG,EAASG,UAAUS,MAAM9iE,KAAI,SAAU59B,GACrC,OAAOA,EAAK2gG,YACb,IAAE,GACTtB,SAAU,IAAIU,EAAaV,YAAakB,GACxCjB,QAAS,IAAIS,EAAaT,WAAYkB,GACtCjB,UAAW,IAAIQ,EAAaR,aAAckB,GAE9C,EA+DAZ,GAAiBX,IA7DjB,SAAiCY,GAC/B,MAAMC,EAAeD,EAASE,sCAC5BV,OACsChmG,IAApCwmG,EAASG,UAAUW,aACfb,EAAaT,QACb,IAAIS,EAAaT,WAAYQ,EAASG,UAAUW,cACtDC,OAC0CvnG,IAAxCwmG,EAASG,UAAUa,kBACnB3rG,MAAMC,QAAQ0qG,EAASG,UAAUa,mBACjChB,EAASG,UAAUa,iBAAiB7sG,OAAS,EACzC6rG,EAASG,UAAUa,iBAChBv2D,QAAO,SAAUzwB,GAChB,MAAO,CAAC,MAAO,MAAO,OAAOthB,SAASshB,EACpD,IACa09B,QAAO,SAAUs1B,EAAKhzD,GACrB,YAAexgB,IAARwzE,GAAqBwyB,EAAQ9mG,SAASshB,GACzCA,EACAgzD,CACL,QAAExzE,QACLA,EACR,MAAO,CACLonE,IAAKo/B,EAASG,UAAc,GAC5BjnB,WAC+B1/E,IAA7BwmG,EAASG,UAAUjnB,WACf1/E,EACAwmG,EAASG,UAAUjnB,MAAMp7C,KAAI,SAAUp3B,GACrC,MAAO,CAACA,EAAKjE,MAAOiE,EAAKhE,OACrC,IACIo2E,cAC+Bt/E,IAA7BwmG,EAASG,UAAUS,WACfpnG,EACA,CACEwmG,EAASG,UAAUS,MAAM9iE,KAAI,SAAU59B,GACrC,OAAOA,EAAKuC,KACb,IAAE,GACHu9F,EAASG,UAAUS,MAAM9iE,KAAI,SAAU59B,GACrC,OAAOA,EAAKwC,MACb,IAAE,IAEXihC,iBAC+BnqC,IAA7BwmG,EAASG,UAAUS,WACfpnG,EACAwmG,EAASG,UAAUS,MAAM9iE,KAAI,SAAU59B,GACrC,OAAOA,EAAK2gG,YACb,IAAE,GACTtB,cACuC/lG,IAArCwmG,EAASG,UAAUc,cACfhB,EAAaV,SACb,IAAIU,EAAaV,YAAaS,EAASG,UAAUc,eACvDzB,QAASA,EACTC,eACwCjmG,IAAtCwmG,EAASG,UAAUe,eACfjB,EAAaR,UACb,IAAIQ,EAAaR,aAAcO,EAASG,UAAUe,gBACxDH,gBAAiBA,EAErB,EAiMA,IAAAI,GAnLA,MAKE,WAAAruG,CAAYqtG,GACVntG,KAAKouG,aAAajB,EACnB,CAOD,YAAAiB,CAAajB,GAETntG,KAAKmtG,UADiB,iBAAbA,EACQ9+B,KAAKnjC,MAAMiiE,GAEXA,CAEpB,CAMD,kBAAAkB,GACE,QAAuB7nG,IAAnBxG,KAAKmtG,UACP,OAEF,IAAIh9F,EAAUnQ,KAAKmtG,UAAU,aAAe,gBACtB,iBAAXh9F,IACTA,EAAU,CAACA,IAEb,IAAK,IAAIvO,EAAI,EAAGA,EAAIuO,EAAQhP,OAAQS,IAClC,OAAQuO,EAAQvO,IACd,IAAK,8DACL,IAAK,0CACH,OAAOwqG,GACT,IAAK,0CACH,OAAOA,GACT,IAAK,0CACH,OAAOA,GACT,IAAK,gBAEH,GACEpsG,KAAKsuG,mCAAmClC,KACxCpsG,KAAKmtG,UAAUoB,WAEf,OAAOnC,GAMfn4F,IACE,EACA,+EAEH,CAOD,kCAAAq6F,CAAmCE,GACjC,QAAuBhoG,IAAnBxG,KAAKmtG,gBAAsD3mG,IAA3BxG,KAAKmtG,UAAUK,QAMnD,YAHgBhnG,IAAZgoG,IACFA,EAAUxuG,KAAKquG,sBAETG,GACN,KAAKpC,GACH,GAAIQ,GAAoBv+F,KAAKrO,KAAKmtG,UAAUK,SAC1C,OAAOxtG,KAAKmtG,UAAUK,QAExB,MACF,KAAKpB,GACH,GAAIU,GAAoBz+F,KAAKrO,KAAKmtG,UAAUK,SAC1C,OAAOxtG,KAAKmtG,UAAUK,QAExB,MACF,KAAKpB,GACH,GACoC,iBAA3BpsG,KAAKmtG,UAAUK,SACtBX,GAAoBx+F,KAAKrO,KAAKmtG,UAAUK,SAExC,OAAOxtG,KAAKmtG,UAAUK,QAExB,GACEnrG,MAAMC,QAAQtC,KAAKmtG,UAAUK,UAC7BxtG,KAAKmtG,UAAUK,QAAQrsG,OAAS,GACK,iBAA9BnB,KAAKmtG,UAAUK,QAAQ,IAC9BX,GAAoBx+F,KAAKrO,KAAKmtG,UAAUK,QAAQ,IAEhD,OAAOxtG,KAAKmtG,UAAUK,QAAQ,GAMrC,CAMD,6BAAAiB,CAA8BD,GAC5B,MAAME,EAAkB1uG,KAAKsuG,mCAAmCE,GAChE,QAAwBhoG,IAApBkoG,EACF,OAEF,MAAMzlF,EAAQylF,EAAgBzjE,MAAM,2BACpC,OAAO5oC,MAAMC,QAAQ2mB,GAASA,EAAM,GAAGzF,QAAQ,QAAS,SAAMhd,CAC/D,CAMD,mCAAA0mG,GACE,QAAuB1mG,IAAnBxG,KAAKmtG,UACP,OAEF,MAAMqB,EAAUxuG,KAAKquG,qBACfplF,EAAQjpB,KAAKyuG,8BAA8BD,GACjD,YAAchoG,IAAVyiB,EACKojF,GAA0B,KAAQ,KAEpCA,GAAoBmC,GAASvlF,EACrC,CAOD,oBAAA0lF,CAAqBC,GACnB,MAAMjkG,EAAUikG,GAAoB,CAAE,EACpCJ,EAAUxuG,KAAKquG,qBACjB,QAAgB7nG,IAAZgoG,EACF,OAEF,MAAMK,OACQroG,IAAZgoG,OAAwBhoG,EAAYumG,GAAiByB,GAASxuG,MAChE,YAAqBwG,IAAjBqoG,EAGG,CACLjhC,IAAKihC,EAAajhC,IAClB4gC,QAASA,EACT96F,KAAM,CAAC1T,KAAKmtG,UAAU19F,MAAOzP,KAAKmtG,UAAUz9F,QAC5Cw2E,MAAO2oB,EAAa3oB,MACpBl/D,YACqBxgB,IAAnBmE,EAAQqc,QACR6nF,EAAarC,QAAQ9mG,SAASiF,EAAQqc,QAClCrc,EAAQqc,YACyBxgB,IAAjCqoG,EAAad,gBACbc,EAAad,gBACb,MACNxB,SAAUsC,EAAatC,SACvBuC,QACEnkG,EAAQmkG,SAAWD,EAAapC,UAAU/mG,SAASiF,EAAQmkG,SACvDnkG,EAAQmkG,QACRD,EAAapC,UAAU/mG,SAAS,UAChC,SACA,UACNirC,YAAatuC,MAAMC,QAAQusG,EAAal+D,aACpCk+D,EAAal+D,YAAYrc,MAAK,SAAUjzB,EAAGC,GACzC,OAAOA,EAAID,CACvB,SACUmF,EACJs/E,SAAU+oB,EAAa/oB,eA3BzB,CA6BD,GClbH,SAASipB,GAAiBC,GACxB,OAAOA,EAAWC,eAAe,KAAM,CAACC,sBAAuB,IACjE,CA6SA,IAAAC,GAtSA,cAAmBhhB,GAMjB,WAAAruF,CAAY6K,GAIV,MAAMykG,EAAiBzkG,GAAW,GAElC,IAAI0kG,EAAUD,EAAexhC,KAAO,GACpCyhC,GAEGA,EAAQzkC,YAAY,OAASykC,EAAQluG,OAAS,GAAiB,KAAZkuG,EAChD,GACA,IACN,MAAMb,EAAUY,EAAeZ,SAAWpC,GACpClmB,EAAQkpB,EAAelpB,OAAS,GAChCxyE,EAAO07F,EAAe17F,KAC5BO,GACUzN,MAARkN,GACErR,MAAMC,QAAQoR,IACC,GAAfA,EAAKvS,SACJqtB,MAAM9a,EAAK,KACZA,EAAK,GAAK,IACT8a,MAAM9a,EAAK,KACZA,EAAK,GAAK,EACZ,6BAEF,MAAMjE,EAAQiE,EAAK,GACbhE,EAASgE,EAAK,GACdoyE,EAAWspB,EAAetpB,SAC1B+C,EAAiBumB,EAAevmB,gBAAkB,EAClD7hE,EAASooF,EAAepoF,QAAU,MAClC8nF,EACJM,EAAeN,UACdM,EAAeZ,SAAWpC,GAAoB,SAAW,WAC5D,IAAIz7D,EAAcy+D,EAAez+D,aAAe,GAChD,MAAM47D,EAAW6C,EAAe7C,UAAY,GACtC/yF,EAAS41F,EAAe51F,QAAU,CAAC,GAAI9J,EAAQD,EAAO,GAEtD6/F,EACK9oG,MAAT0/E,GAAsB7jF,MAAMC,QAAQ4jF,IAAUA,EAAM/kF,OAAS,EACzDouG,OACS/oG,IAAbs/E,IACsB,iBAAbA,GACP37C,OAAOqlE,UAAU1pB,IACjBA,EAAW,GACVzjF,MAAMC,QAAQwjF,IAAaA,EAAS3kF,OAAS,GAC5CsuG,EACQjpG,MAAZ+lG,GACAlqG,MAAMC,QAAQiqG,KACbA,EAAS7mG,SAAS,eAAiB6mG,EAAS7mG,SAAS,kBACrD6mG,EAAS7mG,SAAS,aACjB6mG,EAAS7mG,SAAS,YAClB6mG,EAAS7mG,SAAS,YAClB6mG,EAAS7mG,SAAS,cAEtB,IAAImmG,EAAW6D,EAAYtiE,EAM3B,GAJAuD,EAAYrc,MAAK,SAAUjzB,EAAGC,GAC5B,OAAOA,EAAID,CACjB,IAEQkuG,GAAuBE,EAsCzB,GArCgBjpG,MAAZs/E,IAEoB,iBAAbA,GACP37C,OAAOqlE,UAAU1pB,IACjBA,EAAW,GAEX+lB,EAAY/lB,EACZ4pB,EAAa5pB,GACJzjF,MAAMC,QAAQwjF,IAAaA,EAAS3kF,OAAS,KAEjC,GAAnB2kF,EAAS3kF,QACOqF,MAAfs/E,EAAS,IAAmB37C,OAAOqlE,UAAU1pB,EAAS,OAEvD+lB,EAAY/lB,EAAS,GACrB4pB,EAAa5pB,EAAS,IAED,GAAnBA,EAAS3kF,SAETgpC,OAAOqlE,UAAU1pB,EAAS,KAC1B37C,OAAOqlE,UAAU1pB,EAAS,KAE1B+lB,EAAY/lB,EAAS,GACrB4pB,EAAa5pB,EAAS,IAEPt/E,MAAfs/E,EAAS,IACT37C,OAAOqlE,UAAU1pB,EAAS,MAE1B+lB,EAAY/lB,EAAS,GACrB4pB,EAAa5pB,EAAS,YAKZt/E,IAAdqlG,QAA0CrlG,IAAfkpG,IAC7B7D,EAAYt8D,GACZmgE,EAAangE,IAEW,GAAtBoB,EAAYxvC,OAAa,CAC3BisC,EAAUnhC,KAAKyP,IACbzP,KAAKkZ,KAAKlZ,KAAKsW,IAAI9S,EAAQo8F,GAAa5/F,KAAK0jG,KAC7C1jG,KAAKkZ,KAAKlZ,KAAKsW,IAAI7S,EAASggG,GAAczjG,KAAK0jG,MAEjD,IAAK,IAAI/tG,EAAIwrC,EAASxrC,GAAK,EAAGA,IAC5B+uC,EAAYhrC,KAAKsG,KAAKC,IAAI,EAAGtK,GAEvC,KAAa,CACL,MAAMguG,EAAiB3jG,KAAKyP,OAAOi1B,GAEnCvD,EAAUnhC,KAAKiZ,MAAMjZ,KAAKsW,IAAIqtF,GAAkB3jG,KAAK0jG,IACtD,MAMD,GAHA9D,EAAYp8F,EACZigG,EAAahgG,EACbihC,EAAc,GACV2+D,EAAqB,CAKvBppB,EAAM5xD,MAAK,SAAUjzB,EAAGC,GACtB,OAAOD,EAAE,GAAKC,EAAE,EAC1B,IACQ8rC,GAAW,EACX,MAAMyiE,EAAoB,GAC1B,IAAK,IAAIjuG,EAAI,EAAGA,EAAIskF,EAAM/kF,OAAQS,IAAK,CACrC,MAAM+a,EAAalN,EAAQy2E,EAAMtkF,GAAG,GAElC+uC,EAAYxvC,OAAS,GACrBwvC,EAAYA,EAAYxvC,OAAS,IAAMwb,EAEvCkzF,EAAkBlqG,KAAK/D,IAGzB+uC,EAAYhrC,KAAKgX,GACjBywB,IACD,CACD,GAAIyiE,EAAkB1uG,OAAS,EAC7B,IAAK,IAAIS,EAAI,EAAGA,EAAIiuG,EAAkB1uG,OAAQS,IAC5CskF,EAAMr/E,OAAOgpG,EAAkBjuG,GAAKA,EAAG,EAGnD,MAEQ+uC,EAAYhrC,KAAK,GACjBugF,EAAMvgF,KAAK,CAAC8J,EAAOC,IACnB09B,EAAU,EAId,MAAMvrB,EAAW,IAAIqmE,GAAS,CAC5BpC,SAAU,CAAC+lB,EAAW6D,GACtBl2F,OAAQA,EACRisE,OAAQxpE,GAAWzC,GACnBm3B,YAAaA,IAuGTm/D,EAAgB5D,GAAWhlG,KAC/B,KACA83D,GAAO8mB,GAAY,KAAKh7C,KAAI,SAAUp3B,GACpC,OAAOA,EAAOm1E,CACtB,KAGI5jF,MAAM,CACJi5C,aAAckxD,EAAelxD,aAC7B0mC,wBAAyBwqB,EAAexqB,wBACxCv5C,UAAW+jE,EAAe/jE,UAC1BhP,YAAa+yE,EAAe/yE,YAC5BxvB,YAAauiG,EAAeviG,YAC5BsS,WAAYiwF,EAAejwF,WAC3B6tE,2BAA4BoiB,EAAepiB,2BAC3CxgF,MAAO4iG,EAAe5iG,MACtBmgF,UAAWmjB,EACXjuF,SAAUA,EACVgnE,eAAgBumB,EAAevmB,eAC/B8C,gBAvHsB,SAAUp/E,EAAW6uB,EAAYjc,GACvD,IAAI4wF,EAAaC,EACjB,MAAM56D,EAAO7oC,EAAU,GACvB,GAAI6oC,EAAOhI,EACT,OAEF,MAAM6iE,EAAQ1jG,EAAU,GACtB2jG,EAAQ3jG,EAAU,GAClBoL,EAAQg5B,EAAYyE,GACtB,UACY5uC,IAAVypG,QACUzpG,IAAV0pG,QACU1pG,IAAVmR,GACAs4F,EAAQ,GACRhkG,KAAKkZ,KAAK1V,EAAQkI,EAAQk0F,IAAcoE,GACxCC,EAAQ,GACRjkG,KAAKkZ,KAAKzV,EAASiI,EAAQ+3F,IAAeQ,GAP5C,CAWA,GAAIT,GAA2BF,EAAqB,CAClD,MAAMY,EAAUF,EAAQpE,EAAYl0F,EAClCy4F,EAAUF,EAAQR,EAAa/3F,EACjC,IAAI04F,EAAUxE,EAAYl0F,EACxB24F,EAAUZ,EAAa/3F,EACvB44F,EAAQ1E,EACR2E,EAAQd,EAaV,GAZIS,EAAUE,EAAU5gG,IACtB4gG,EAAU5gG,EAAQ0gG,GAEhBC,EAAUE,EAAU5gG,IACtB4gG,EAAU5gG,EAAS0gG,GAEjBD,EAAUtE,EAAYl0F,EAAQlI,IAChC8gG,EAAQtkG,KAAKuT,OAAO/P,EAAQ0gG,EAAUx4F,EAAQ,GAAKA,IAEjDy4F,EAAUV,EAAa/3F,EAAQjI,IACjC8gG,EAAQvkG,KAAKuT,OAAO9P,EAAS0gG,EAAUz4F,EAAQ,GAAKA,IAGzC,GAAXw4F,GACAE,GAAW5gG,GACA,GAAX2gG,GACAE,GAAW5gG,EAGXqgG,EAAc,YACT,IACJN,GACDlD,EAAS7mG,SAAS,cAElBqqG,EAAcI,EAAU,IAAMC,EAAU,IAAMC,EAAU,IAAMC,OACzD,GAAI/D,EAAS7mG,SAAS,eAAgB,CAK3CqqG,EAAc,OAJDhB,GAAkBoB,EAAU1gG,EAAS,KAIpB,IAHrBs/F,GAAkBqB,EAAU1gG,EAAU,KAGJ,IAFlCq/F,GAAkBsB,EAAU5gG,EAAS,KAEU,IAD/Cs/F,GAAkBuB,EAAU5gG,EAAU,IAEhD,CAEC8+F,GAAWpC,IACTqD,IAA2BlD,EAAS7mG,SAAS,aAGrC+pG,GAA2BlD,EAAS7mG,SAAS,WACvDsqG,EAAYO,EAAQ,IACXhE,EAAS7mG,SAAS,WAC3BsqG,EAAY,IAAMQ,EACTjE,EAAS7mG,SAAS,YAC3BsqG,EAAYO,EAAQ,IAAMC,EACjBjE,EAAS7mG,SAAS,eAC3BsqG,EAAY,OAASjB,GAAiB,IAAMp3F,IAR5Cq4F,EAAYO,EAAQ,IAAMC,CAUpC,MAEQ,GADAT,EAAc,OACVT,EAAqB,CACvB,MAAMmB,EAAcvqB,EAAM9wC,GAAM,GAC9Bs7D,EAAexqB,EAAM9wC,GAAM,GAGzB46D,EAFAxB,GAAWpC,GACTqE,GAAehhG,GAASihG,GAAgBhhG,EAC9B,MAEA+gG,EAAc,IAAMC,EAG9BD,GAAehhG,EACL,OAEAghG,EAAc,GAGxC,MACUT,EAAYxB,GAAWpC,GAAoB,MAAQ,OAGvD,OACEiD,EAAUU,EAAc,IAAMC,EAAY,MAAQlB,EAAU,IAAM9nF,CA7EnE,CA+EP,EAsBMra,WAAYyiG,EAAeziG,aAM7B3M,KAAKkpF,WAAakmB,EAAelmB,UAClC,GC5FH,IAAAynB,GAlOA,cAA0B10E,GAWxB,WAAAn8B,CACEurB,EACA4xD,EACAI,EACAlqC,EACA/X,EACAw1E,EACA/jG,GAEA,IAAI0yE,EAAkBl0D,EAAWhM,YAC7BkgE,GAAmBl0D,EAAW/L,aAChCigE,EAAkBA,EAAgBz7E,QAClCy7E,EAAgB,IAAM9kE,IACtB8kE,EAAgB,GAAK9kE,KAEvB,IAAI4oE,EAAkBpG,EAAW59D,YAC7BgkE,GAAmBpG,EAAW39D,aAChC+jE,EAAkBA,EAAgBv/E,QAClCu/E,EAAgB,IAAM5oE,IACtB4oE,EAAgB,GAAK5oE,KAGvB,MAAM6oE,EAAsBD,EACxBzlE,GAAgBy/D,EAAcgG,GAC9BhG,EAGEnqC,EAAmB8pC,GACvB3xD,EACA4xD,EAHmB3gE,GAAUgnE,GAK7BnwC,GAKImqC,EAAgB,IAAIoG,GACxBr4D,EACA4xD,EACAqG,EACA/D,EAN6BF,GAO7BnsC,EACAC,GAGIpmB,EAAeuwD,EAAciF,wBAC7BsuB,EAAc/rG,GAAQioB,GACxB,KACA6jF,EAAiB7jF,EAAcmmB,EAAkB9X,GAC/C5uB,EAAQqkG,EAAcz2E,GAAkBA,GACxC02E,EAAmBD,EAAcA,EAAYp1E,gBAAkB,EAErEx2B,MAAMo4E,EAAclqC,EAAkB29D,EAAkBtkG,GAMxDxM,KAAK2/E,YAAc1C,EAMnBj9E,KAAK+/E,iBAAmBR,EAMxBv/E,KAAKyjF,eAAiBnG,EAMtBt9E,KAAKg0C,kBAAoBb,EAMzBnzC,KAAK+wG,cAAgB1zB,EAMrBr9E,KAAKgxG,aAAeH,EAMpB7wG,KAAKixG,kBAAoBH,EAMzB9wG,KAAK8kF,aAAej4E,EAMpB7M,KAAKk8B,QAAU,KAMfl8B,KAAKkxG,mBAAqB,IAC3B,CAKD,eAAAzwG,GACMT,KAAKwM,OAAS4tB,IAChBp6B,KAAKmxG,kBAEPlsG,MAAMxE,iBACP,CAKD,QAAA+6B,GACE,OAAOx7B,KAAKk8B,OACb,CAKD,aAAAtN,GACE,OAAO5uB,KAAK2/E,WACb,CAKD,UAAAqE,GACE,MAAMl9B,EAAc9mD,KAAKgxG,aAAa7jG,WACtC,GAAI25C,GAAe1sB,GAAmB,CACpC,MAAM3qB,EAAQ2M,GAASpc,KAAK+wG,eAAiB/wG,KAAKg0C,kBAC5CtkC,EAAS2M,GAAUrc,KAAK+wG,eAAiB/wG,KAAKg0C,kBACpDh0C,KAAKk8B,QAAUgoD,GACbz0E,EACAC,EACA1P,KAAKixG,kBACL7xB,GAAmBp/E,KAAKgxG,aAAat1E,iBACrC17B,KAAK+/E,iBACL//E,KAAKg0C,kBACLh0C,KAAK+wG,cACL/wG,KAAKyjF,eACL,CACE,CACEjqE,OAAQxZ,KAAKgxG,aAAa3xF,YAC1BvM,MAAO9S,KAAKgxG,aAAax1E,aAG7B,OACAh1B,EACAxG,KAAK8kF,cACL,EAEH,CACD9kF,KAAKwM,MAAQs6C,EACb9mD,KAAK6H,SACN,CAKD,IAAAyF,GACE,GAAItN,KAAKwM,OAAS4tB,GAAiB,CACjCp6B,KAAKwM,MAAQ4tB,GACbp6B,KAAK6H,UAEL,MAAMi/C,EAAc9mD,KAAKgxG,aAAa7jG,WAClC25C,GAAe1sB,IAAqB0sB,GAAe1sB,GACrDp6B,KAAKgkF,cAELhkF,KAAKkxG,mBAAqBnqG,EACxB/G,KAAKgxG,aACLlpG,GACA,SAAUoP,GACR,MAAM4vC,EAAc9mD,KAAKgxG,aAAa7jG,WAEpC25C,GAAe1sB,IACf0sB,GAAe1sB,KAEfp6B,KAAKmxG,kBACLnxG,KAAKgkF,aAER,GACDhkF,MAEFA,KAAKgxG,aAAa1jG,OAErB,CACF,CAKD,eAAA6jG,GACE7pG,EACoDtH,KAAuB,oBAE3EA,KAAKkxG,mBAAqB,IAC3B,GCvPI,MAMME,GAAW,ECYXC,GAMK,iBANLA,GAaG,eAbHA,GAoBK,iBAYX,MAAMC,WAAyBvrG,EAKpC,WAAAjG,CAAYC,EAAM+S,GAChB7N,MAAMlF,GAONC,KAAK8S,MAAQA,CACd,EAiRI,SAASy+F,GAAyBz+F,EAAO+nB,GACI/nB,EAAM0oB,WAAYX,IAAMA,CAC5E,CAUO,SAAS22E,GAAiBh4F,EAAQmD,EAAYye,EAAY6U,GAC/D,MAAMwhE,EAAkB90F,EAAaye,EAC/B1e,EAASJ,GAAU9C,GACnBq2B,EAAY1qB,GAAK/I,GAAS5C,GAAUi4F,EAAiBL,IACrDthE,EAAa3qB,GAAK9I,GAAU7C,GAAUi4F,EAAiBL,IAK7D,OAAO30F,GAAkBC,EAAQ+0F,EAAiB,EAAG,CAHhC5hE,EAAY,EADb1qB,IAAO8qB,EAAQ,GAAKJ,EAAa,EAAGuhE,IAGlCthE,EAAa,EADd3qB,IAAO8qB,EAAQ,GAAKH,EAAc,EAAGshE,KAM5D,CAEA,IAAAM,GA5QA,cAA0BjpB,GAIxB,WAAA3oF,CAAY6K,GACV1F,MAAM,CACJi5C,aAAcvzC,EAAQuzC,aACtB/+B,WAAYxU,EAAQwU,WACpB3S,MAAO7B,EAAQ6B,MACfK,iBAC0BrG,IAAxBmE,EAAQkC,aAA4BlC,EAAQkC,cAMhD7M,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAML3H,KAAKsT,OAAS3I,EAAQ2I,QAAU,KAMhCtT,KAAK20C,kBACqBnuC,IAAxBmE,EAAQgmC,YAA4BhmC,EAAQgmC,YAAc,KAM5D3wC,KAAK2xG,kBAAoB,KAMzB3xG,KAAK4xG,qBAAuB,EAM5B5xG,KAAK8S,MAAQ,KAMb9S,KAAK6xG,cAML7xG,KAAK8xG,kBAML9xG,KAAK+xG,UAAUpnG,EAAQ2I,QAAmC,IAA1B3I,EAAQ2I,OAAOnS,OAM/CnB,KAAKgyG,kBAAoB,IAC1B,CAKD,cAAAp5D,GACE,OAAO54C,KAAK20C,YACb,CAKD,cAAAs9D,CAAethE,GACb3wC,KAAK20C,aAAehE,CACrB,CAOD,qBAAAuhE,CAAsBv1F,GACpB,MAAMg0B,EAAc3wC,KAAK44C,iBACzB,GAAIjI,EAAa,CAEfh0B,EAAag0B,EADDnvC,EAAkBmvC,EAAah0B,EAAY,GAExD,CACD,OAAOA,CACR,CASD,QAAA6e,CAAShiB,EAAQmD,EAAYye,EAAYjc,GACvC,MAAMsM,EAAmBzrB,KAAK4uB,gBAC9B,IACGnD,IACAtM,GACDoM,GAAWE,EAAkBtM,GAM7B,OAJIsM,IACFtM,EAAasM,GAGRzrB,KAAKmyG,iBAAiB34F,EAAQmD,EAAYye,EAAYjc,GAE/D,GAAInf,KAAK2xG,kBAAmB,CAC1B,GACE3xG,KAAK4xG,sBAAwB5xG,KAAK+H,eAClCwjB,GAAWvrB,KAAK2xG,kBAAkB/iF,gBAAiBzP,IACnDnf,KAAK2xG,kBAAkBj2E,iBAAmB/e,GAC1Cpa,GAAOvC,KAAK2xG,kBAAkBtyF,YAAa7F,GAE3C,OAAOxZ,KAAK2xG,kBAEd3xG,KAAK2xG,kBAAkBnxG,UACvBR,KAAK2xG,kBAAoB,IAC1B,CAcD,OAZA3xG,KAAK2xG,kBAAoB,IAAIS,GAC3B3mF,EACAtM,EACA3F,EACAmD,EACAye,GACA,CAAC5hB,EAAQmD,EAAYye,IACnBp7B,KAAKmyG,iBAAiB34F,EAAQmD,EAAYye,EAAY3P,IACxDzrB,KAAKklF,kBAEPllF,KAAK4xG,qBAAuB5xG,KAAK+H,cAE1B/H,KAAK2xG,iBACb,CAWD,gBAAAQ,CAAiB34F,EAAQmD,EAAYye,EAAYjc,GAC/C,GAAInf,KAAKsT,OAAQ,CACf,MAAM++F,EAAgBb,GAAiBh4F,EAAQmD,EAAYye,EAAY,GACjEO,EAAoB37B,KAAKkyG,sBAAsBv1F,GACrD,GACE3c,KAAK8S,QACJ9S,KAAK+xG,SACH/xG,KAAKgyG,oBAAsB7yF,IACxBnf,KAAK6xG,eACL73F,GAAeha,KAAK6xG,cAAeQ,IACnCr4F,GAAeha,KAAK8S,MAAMuM,YAAagzF,MACvCryG,KAAK8xG,mBACL1yB,GAAmBp/E,KAAK8xG,qBACtBn2E,GACFyjD,GAAmBp/E,KAAK8S,MAAM4oB,mBAC5BC,IAER,OAAO37B,KAAK8S,MAEd9S,KAAKgyG,kBAAoB7yF,EACzBnf,KAAK6xG,cAAgBQ,EACrBryG,KAAK8xG,kBAAoBn2E,EACzB37B,KAAK8S,MAAQ,IAAImpB,GACfo2E,EACA12E,EACAP,EACAp7B,KAAKsT,QAEPtT,KAAK8S,MAAMxN,iBACTwC,EACA9H,KAAKsyG,kBAAkBprG,KAAKlH,MAE/B,CACD,OAAOA,KAAK8S,KACb,CAOD,iBAAAw/F,CAAkBzsG,GAChB,MAAMiN,EAAsDjN,EAAY,OACxE,IAAI9F,EACJ,OAAQ+S,EAAM3F,YACZ,KAAKitB,GACHp6B,KAAKokE,SAAU,EACfrkE,EAAOsxG,GACP,MACF,KAAKj3E,GACHp6B,KAAKokE,SAAU,EACfrkE,EAAOsxG,GACP,MACF,KAAKj3E,GACHp6B,KAAKokE,SAAU,EACfrkE,EAAOsxG,GACP,MACF,QACE,OAEArxG,KAAKyG,YAAY1G,IACnBC,KAAK4F,cAAc,IAAI0rG,GAAiBvxG,EAAM+S,GAEjD,GCpUI,SAASy/F,GAAaC,EAAKviB,GAEhC,MAAMwiB,EAAY,GAElB/rG,OAAOC,KAAKspF,GAAQ9kF,SAAQ,SAAUqZ,GAClB,OAAdyrE,EAAOzrE,SAA6Bhe,IAAdypF,EAAOzrE,IAC/BiuF,EAAU9sG,KAAK6e,EAAI,IAAMkuF,mBAAmBziB,EAAOzrE,IAEzD,IACE,MAAMmuF,EAAKF,EAAU35F,KAAK,KAK1B,OAHA05F,EAAMA,EAAIhvF,QAAQ,QAAS,KAE3BgvF,GAAOA,EAAI9sG,SAAS,KAAO,IAAM,KACpBitG,CACf,CCNO,SAASC,GACdvD,EACA71F,EACAmD,EACAye,EACAjc,EACA8wE,GAKA,MAAM4iB,EAAO1zF,EACViC,UACAyE,MAAM,aACN3a,MAEGumG,EAAkB90F,EAAaye,EAE/B28C,EAAY,CAChB7yD,GAAM9I,GAAS5C,GAAUi4F,EAAiBL,IAC1ClsF,GAAM7I,GAAU7C,GAAUi4F,EAAiBL,KAG7CnhB,EAAa,KAAIlY,EAAU,GAAK,IAAMA,EAAU,GAChDkY,EAAa,KAAIz2E,EAAOV,KAAK,KAC7Bm3E,EAAe,OAAI4iB,EACnB5iB,EAAgB,QAAI4iB,EACpB5iB,EAAY,IAAIhkF,KAAKiZ,MACnB+qE,EAAY,IAAIA,EAAY,IAAI70D,EAAa,GAAKA,GAGpD,MAAM03E,EAAczD,EACjB7rF,QAAQ,gBAAiB,oBACzBA,QAAQ,kBAAmB,2BAC9B,GAAIsvF,GAAezD,EACjB,MAAM,IAAI7mG,MAAM,6CAElB,OAAO+pG,GAAaO,EAAa7iB,EACnC,CAiCO,SAAS8iB,GAAapoG,GAC3B,MAAM2C,EAAO3C,EAAQ2C,KAAO3C,EAAQ2C,KAAO0B,GACrCmQ,EAAayP,GAAcjkB,EAAQwU,YAAc,aAGvD,OAAO,SAAU3F,EAAQmD,EAAYye,GACnCA,EAAazwB,EAAQyjF,MAAQhzD,EAAa,EAE1C,MAAM60D,EAAS,CACb+iB,EAAK,QACLC,OAAU,QACVC,aAAe,GAEjBxsG,OAAO8C,OAAOymF,EAAQtlF,EAAQslF,QAE9Bz2E,EAASg4F,GAAiBh4F,EAAQmD,EAAYye,EAAYzwB,EAAQslC,OAElE,MAAMpV,EAAM+3E,GACVjoG,EAAQijE,IACRp0D,EACAmD,EACAye,EACAjc,EACA8wE,GAGIn9E,EAAQ,IAAI/D,MAKlB,OAJ4B,OAAxBpE,EAAQ0xB,cACVvpB,EAAMupB,YAAc1xB,EAAQ0xB,aAGvB/uB,EAAKwF,EAAO+nB,GAAK9mB,MAAMjB,IAE5B,MAAM6J,EAAcP,GAAS5C,GAAU1G,EAAMrD,MAAS2rB,EACtD,MAAO,CAACtoB,QAAO0G,SAAQmD,aAAYye,aAAW,GAEpD,CACA,CC+FA,IAAA+3E,GA/KA,cAA8BC,GAI5B,WAAAtzG,CAAY6K,GAGV1F,MAAM,CACJi5C,cAHFvzC,EAAUA,GAAoB,IAGNuzC,aACtBrxC,YAAalC,EAAQkC,YACrBsS,WAAYxU,EAAQwU,WACpBwxB,YAAahmC,EAAQgmC,cAOvB3wC,KAAKu8B,kBACqB/1B,IAAxBmE,EAAQ0xB,YAA4B1xB,EAAQ0xB,YAAc,KAM5Dr8B,KAAKquF,YAA2B7nF,IAAlBmE,EAAQyjF,OAAsBzjF,EAAQyjF,MAMpDpuF,KAAKitE,KAAOtiE,EAAQijE,IAMpB5tE,KAAKqzG,wBAC2B7sG,IAA9BmE,EAAQ2oG,kBACJ3oG,EAAQ2oG,kBACR/B,GAMNvxG,KAAKuzG,QAAU5oG,EAAQslF,QAAU,CAAA,EAMjCjwF,KAAKu7B,OAAS,KAMdv7B,KAAKwzG,WAAa,CAAC,EAAG,GAMtBxzG,KAAKyzG,kBAAoB,EAMzBzzG,KAAK0zG,YAA2BltG,IAAlBmE,EAAQslC,MAAsBtlC,EAAQslC,MAAQ,IAM5DjwC,KAAK2zG,kBAAoB,IAC1B,CAQD,SAAAC,GACE,OAAO5zG,KAAKuzG,OACb,CASD,gBAAApB,CAAiB34F,EAAQmD,EAAYye,EAAYjc,GAC/C,YAAkB3Y,IAAdxG,KAAKitE,KACA,MAEJjtE,KAAKsT,QAAUtT,KAAK2zG,oBAAsBx0F,IAE7Cnf,KAAK2zG,kBAAoBx0F,EACzBnf,KAAKsT,OAASy/F,GAAa,CACzB12E,YAAar8B,KAAKu8B,aAClB0zD,OAAQjwF,KAAKuzG,QACbp0F,WAAYA,EACZivE,MAAOpuF,KAAKquF,OACZzgB,IAAK5tE,KAAKitE,KACVh9B,MAAOjwC,KAAK0zG,OACZpmG,KAAM,CAACwF,EAAO+nB,KACZ76B,KAAK8S,MAAMgpB,SAAShpB,GACpB9S,KAAKqzG,mBAAmBrzG,KAAK8S,MAAO+nB,GAC7B7rB,GAAO8D,OAKb7N,MAAMktG,iBAAiB34F,EAAQmD,EAAYye,EAAYjc,GAC/D,CAOD,oBAAA00F,GACE,OAAO7zG,KAAKqzG,kBACb,CAOD,MAAAnU,GACE,OAAOl/F,KAAKitE,IACb,CAOD,oBAAA6mC,CAAqBR,GACnBtzG,KAAKu7B,OAAS,KACdv7B,KAAKqzG,mBAAqBC,EAC1BtzG,KAAK6H,SACN,CAOD,MAAAgkF,CAAOje,GACDA,GAAO5tE,KAAKitE,OACdjtE,KAAKitE,KAAOW,EACZ5tE,KAAKu7B,OAAS,KACdv7B,KAAK6H,UAER,CAOD,YAAAksG,CAAa9jB,GACXvpF,OAAO8C,OAAOxJ,KAAKuzG,QAAStjB,GAC5BjwF,KAAKu7B,OAAS,KACdv7B,KAAK6H,SACN,GCnFH,IAAAmsG,GArFA,cAAgCZ,GAI9B,WAAAtzG,CAAY6K,GAGV1F,MAAM,CACJi5C,cAHFvzC,EAAUA,GAAoB,IAGNuzC,aACtBrxC,YAAalC,EAAQkC,YACrBsS,WAAYxU,EAAQwU,WACpBwxB,YAAahmC,EAAQgmC,YACrBnkC,MAAO7B,EAAQ6B,QAOjBxM,KAAKi0G,gBAAkBtpG,EAAQupG,eAM/Bl0G,KAAKk8B,QAAU,KAMfl8B,KAAKyzG,kBAAoB,EAMzBzzG,KAAK0zG,YAA2BltG,IAAlBmE,EAAQslC,MAAsBtlC,EAAQslC,MAAQ,GAC7D,CASD,gBAAAkiE,CAAiB34F,EAAQmD,EAAYye,EAAYjc,GAC/CxC,EAAa3c,KAAKkyG,sBAAsBv1F,GAExC,IAAI9M,EAAS7P,KAAKk8B,QAClB,GACErsB,GACA7P,KAAKyzG,mBAAqBzzG,KAAK+H,eAC/B8H,EAAO6rB,iBAAmB/e,GAC1B9M,EAAO4rB,iBAAmBL,GAC1BphB,GAAenK,EAAOwP,YAAa7F,GAEnC,OAAO3J,EAITmO,GADAxE,EAASA,EAAO1V,QACQ9D,KAAK0zG,QAC7B,MAEMhgG,EAAO,CAFC0I,GAAS5C,GAAUmD,EAEXye,EADP/e,GAAU7C,GAAUmD,EACQye,GAErC+4E,EAAgBn0G,KAAKi0G,gBAAgBlwG,KACzC/D,KACAwZ,EACAmD,EACAye,EACA1nB,EACAyL,GAQF,OANIg1F,IACFtkG,EAAS,IAAIukG,GAAY56F,EAAQmD,EAAYye,EAAY+4E,IAE3Dn0G,KAAKk8B,QAAUrsB,EACf7P,KAAKyzG,kBAAoBzzG,KAAK+H,cAEvB8H,CACR,GC9EH,SAASqvF,GACPmQ,EACApf,EACAz2E,EACA9F,EACA2gG,EACAlzF,EACAmzF,GAEA,MAAM38F,EA/BR,SAAkB6B,EAAQ9F,EAAMyN,EAAeozF,GAC7C,MAAMC,EAAOp4F,GAAS5C,GAChBi7F,EAAOp4F,GAAU7C,GACjBk7F,EAAOhhG,EAAK,GACZihG,EAAOjhG,EAAK,GACZkhG,EAAM,MAASL,EACrB,OAAII,EAAOH,EAAOE,EAAOD,EACfD,EAAOrzF,GAAkBuzF,EAAOE,GAElCH,EAAOtzF,GAAkBwzF,EAAOC,EAC1C,CAqBgBC,CAASr7F,EAAQ9F,EAAMyN,EAAemzF,GAC9C53F,EAASJ,GAAU9C,GACnBs7F,EAAa,CACjBC,UAAaV,EAAa,4BAA8B,cACxDW,QAAW,QACXC,OAAU,KACVC,YAAe,iCACfC,KAAQ,IACRC,cAAiBd,EACjBe,gBAAmBppG,KAAKiZ,MAAMxR,EAAK,IACnC4hG,iBAAoBrpG,KAAKiZ,MAAMxR,EAAK,IACpC6hG,aAAgB59F,EAChB69F,eAAkB94F,EAAO,GACzB+4F,eAAkB/4F,EAAO,IAG3B,OADAhW,OAAO8C,OAAOsrG,EAAY7kB,GACnBsiB,GAAalD,EAASyF,EAC/B,CAQO,SAAS/B,GAAapoG,GAC3B,MAAM2C,EAAO3C,EAAQ2C,MAAQ0B,GAG7B,OAAO,SAAUwK,EAAQmD,EAAYye,GACnC,MAAMtoB,EAAQ,IAAI/D,MACU,OAAxBpE,EAAQ0xB,cACVvpB,EAAMupB,YAAc1xB,EAAQ0xB,aAG9B,MAAM5sB,EAAQ2M,GADd5C,EAASg4F,GAAiBh4F,EAAQmD,EAAYye,EAAYzwB,EAAQslC,QACjCtzB,EAC3BjN,EAAS2M,GAAU7C,GAAUmD,EAC7BjJ,EAAO,CAACjE,EAAQ2rB,EAAY1rB,EAAS0rB,GACrCP,EAAMqkE,GACVv0F,EAAQijE,IACRjjE,EAAQslF,OACRz2E,EACA9F,EACA/I,EAAQ0pG,WACR1pG,EAAQwW,eAAiB,EACzBxW,EAAQ2pG,YAAc,IAExB,OAAOhnG,EAAKwF,EAAO+nB,GAAK9mB,MAAMjB,IAAW,CAACA,QAAO0G,SAAQ4hB,gBAC7D,CACA,CCuFA,IAAAs6E,GArKA,cAA4BtC,GAI1B,WAAAtzG,CAAY6K,GACV1F,MAAM,CACJ4H,YAAalC,EAAQkC,YACrBsS,WAAYxU,EAAQwU,WACpBwxB,YAAahmC,EAAQgmC,cAOvB3wC,KAAKu8B,kBACqB/1B,IAAxBmE,EAAQ0xB,YAA4B1xB,EAAQ0xB,YAAc,KAM5Dr8B,KAAK21G,iBACoBnvG,IAAvBmE,EAAQ2pG,WAA2B3pG,EAAQ2pG,WAAa,GAM1Dt0G,KAAKuzG,QAAU5oG,EAAQslF,QAAU,CAAA,EAMjCjwF,KAAKitE,KAAOtiE,EAAQijE,IAMpB5tE,KAAKqzG,wBAC2B7sG,IAA9BmE,EAAQ2oG,kBACJ3oG,EAAQ2oG,kBACR/B,GAMNvxG,KAAKquF,YAA2B7nF,IAAlBmE,EAAQyjF,OAAsBzjF,EAAQyjF,MAMpDpuF,KAAKkhB,oBACuB1a,IAA1BmE,EAAQwW,cAA8BxW,EAAQwW,cAAgB,EAMhEnhB,KAAK0zG,YAA2BltG,IAAlBmE,EAAQslC,MAAsBtlC,EAAQslC,MAAQ,EAM5DjwC,KAAK41G,iBACoBpvG,IAAvBmE,EAAQ0pG,YAA2B1pG,EAAQ0pG,WAM7Cr0G,KAAKu7B,OAAS,KAMdv7B,KAAKyzG,kBAAoB,EAMzBzzG,KAAK2zG,kBAAoB,IAC1B,CAQD,SAAAC,GACE,OAAO5zG,KAAKuzG,OACb,CASD,gBAAApB,CAAiB34F,EAAQmD,EAAYye,EAAYjc,GAC/C,YAAkB3Y,IAAdxG,KAAKitE,KACA,MAEJjtE,KAAKsT,QAAUtT,KAAK2zG,oBAAsBx0F,IAE7Cnf,KAAK2zG,kBAAoBx0F,EACzBnf,KAAKsT,OAASy/F,GAAa,CACzB12E,YAAar8B,KAAKu8B,aAClB0zD,OAAQjwF,KAAKuzG,QACbnlB,MAAOpuF,KAAKquF,OACZltE,cAAenhB,KAAKkhB,eACpB0sD,IAAK5tE,KAAKitE,KACVonC,WAAYr0G,KAAK41G,YACjB3lE,MAAOjwC,KAAK0zG,OACZpmG,KAAM,CAACwF,EAAO+nB,KACZ76B,KAAK8S,MAAMgpB,SAAShpB,GACpB9S,KAAKqzG,mBAAmBrzG,KAAK8S,MAAO+nB,GAC7B7rB,GAAO8D,OAKb7N,MAAMktG,iBAAiB34F,EAAQmD,EAAYye,EAAYjc,GAC/D,CAOD,oBAAA00F,GACE,OAAO7zG,KAAKqzG,kBACb,CAOD,YAAAU,CAAa9jB,GACXvpF,OAAO8C,OAAOxJ,KAAKuzG,QAAStjB,GAC5BjwF,KAAK6H,SACN,CAOD,oBAAAisG,CAAqBR,GACnBtzG,KAAKu7B,OAAS,KACdv7B,KAAKqzG,mBAAqBC,EAC1BtzG,KAAK6H,SACN,GC5KI,SAASkrG,GAAapoG,GAC3B,MAAM2C,EAAO3C,EAAQ2C,MAAQ0B,GACvBwK,EAAS7O,EAAQkrG,YACjB/iG,EAAQ,IAAI/D,MAKlB,OAJ4B,OAAxBpE,EAAQ0xB,cACVvpB,EAAMupB,YAAc1xB,EAAQ0xB,aAGvB,IACL/uB,EAAKwF,EAAOnI,EAAQijE,KAAK75D,MAAMjB,IAC7B,MAAMgjG,EAAc15F,GAAS5C,GAAU1G,EAAMrD,MACvCsmG,EAAc15F,GAAU7C,GAAU1G,EAAMpD,OAG9C,MAAO,CAACoD,QAAO0G,SAAQmD,WADrBm5F,IAAgBC,EAAc,CAACD,EAAaC,GAAeA,EAC1B36E,WAAY,EAAE,GAEvD,CCgFA,IAAA46E,GA5FA,cAAqB5C,GAInB,WAAAtzG,CAAY6K,GACV,MAAM0xB,OACoB71B,IAAxBmE,EAAQ0xB,YAA4B1xB,EAAQ0xB,YAAc,KAEJi3E,OACtB9sG,IAA9BmE,EAAQ2oG,kBACJ3oG,EAAQ2oG,kBACR/B,GAERtsG,MAAM,CACJi5C,aAAcvzC,EAAQuzC,aACtBrxC,YAAalC,EAAQkC,YACrBsS,WAAYyP,GAAcjkB,EAAQwU,cAOpCnf,KAAKitE,KAAOtiE,EAAQijE,IAMpB5tE,KAAKi2G,aAAetrG,EAAQkrG,YAM5B71G,KAAK8S,MAAQ,KAEb9S,KAAK8S,MAAQ,IAAImpB,GACfj8B,KAAKi2G,kBACLzvG,EACA,EACAusG,GAAa,CACXnlC,IAAKjjE,EAAQijE,IACbioC,YAAalrG,EAAQkrG,YACrBx5E,cACA/uB,KAAM,CAACwF,EAAO+nB,KACZ76B,KAAK8S,MAAMgpB,SAAShpB,GACpBwgG,EAAkBtzG,KAAK8S,MAAO+nB,GACvB7rB,GAAO8D,OAKpB9S,KAAK8S,MAAMxN,iBACTwC,EACA9H,KAAKsyG,kBAAkBprG,KAAKlH,MAE/B,CAOD,cAAAk2G,GACE,OAAOl2G,KAAKi2G,YACb,CASD,gBAAA9D,CAAiB34F,EAAQmD,EAAYye,EAAYjc,GAC/C,OAAIrB,GAAWtE,EAAQxZ,KAAK8S,MAAMuM,aACzBrf,KAAK8S,MAEP,IACR,CAOD,MAAAosF,GACE,OAAOl/F,KAAKitE,IACb,GCvGI,MAAMkpC,GAAkB,QAMzBC,GAA4B,CAAC,IAAK,KAoBjC,SAASxD,GAAcvD,EAAS71F,EAAQ9F,EAAMyL,EAAY8wE,GAC/DA,EAAc,MAAIv8E,EAAK,GACvBu8E,EAAe,OAAIv8E,EAAK,GAExB,MAAMiN,EAAkBxB,EAAWqC,qBACnC,IAAIivE,EACJ,MAAM4lB,EAAM5wF,GAAgBwqE,EAAgB,QAAG,QAAU,EASzD,OARAA,EAAOomB,EAAM,MAAQ,OAASl3F,EAAWiC,UAEvCqvE,EADE4lB,GAAuC,MAAhC11F,EAAgB21F,OAAO,EAAG,GAC5B,CAAC98F,EAAO,GAAIA,EAAO,GAAIA,EAAO,GAAIA,EAAO,IAEzCA,EAETy2E,EAAa,KAAIQ,EAAK33E,KAAK,KAEpBy5F,GAAY,EAAkCtiB,EACvD,CAYO,SAASsmB,GACd/8F,EACAmD,EACAye,EACAjc,EACAyuD,EACAqiB,EACAumB,GAEAvmB,EAASvpF,OAAO8C,OAAO,CAACitG,QAAS,UAAWxmB,GAE5C,MAAMwhB,EAAkB90F,EAAaye,EAE/B28C,EAAY,CAChB7yD,GAAM9I,GAAS5C,GAAUi4F,EAAiBL,IAC1ClsF,GAAM7I,GAAU7C,GAAUi4F,EAAiBL,KAG7C,GAAkB,GAAdh2E,EACF,OAAQo7E,GACN,IAAK,YACH,MAAMjC,EAAO,GAAKn5E,EAAa,GAAO,EAClC,mBAAoB60D,EACtBA,EAAuB,gBAAK,QAAUskB,EAEtCtkB,EAAuB,eAAI,OAASskB,EAEtC,MACF,IAAK,YACHtkB,EAAuB,eAAI,GAAK70D,EAChC,MACF,IAAK,iBACL,IAAK,OACH60D,EAAY,IAAI,GAAK70D,EACrB,MACF,QACE,MAAM,IAAI5yB,MAAM,mCAKtB,OADYoqG,GAAchlC,EAAKp0D,EAAQu+D,EAAW54D,EAAY8wE,EAEhE,CAOO,SAASymB,GAAiBzmB,EAAQwV,GACvC,OAAO/+F,OAAO8C,OACZ,CACEitG,QAAWhR,EACXkR,QAAW,MACX3B,QAAWmB,GACXlD,OAAU,YACV2D,OAAU,GACV1D,aAAe,GAEjBjjB,EAEJ,CA+BO,SAAS8iB,GAAapoG,GAC3B,MAAMyjF,OAA0B5nF,IAAlBmE,EAAQyjF,OAA6BzjF,EAAQyjF,MACrDjvE,EAAayP,GAAcjkB,EAAQwU,YAAc,aACjD8wB,EAAQtlC,EAAQslC,OAAS,IACzB3iC,EAAO3C,EAAQ2C,MAAQ0B,GAK7B,MAAO,CAACwK,EAAQmD,EAAYye,KAC1B5hB,EAASg4F,GAAiBh4F,EAAQmD,EAAYye,EAAY6U,GACxC,GAAd7U,GAAqBgzD,QAAgC5nF,IAAvBmE,EAAQ6rG,aACxCp7E,EAAa,GAEf,MAAMP,EAAM07E,GACV/8F,EACAmD,EACAye,EACAjc,EACAxU,EAAQijE,IACR8oC,GAAiB/rG,EAAQslF,OAAQ,UACjCtlF,EAAQ6rG,YAEJ1jG,EAAQ,IAAI/D,MAIlB,OAH4B,OAAxBpE,EAAQ0xB,cACVvpB,EAAMupB,YAAc1xB,EAAQ0xB,aAEvB/uB,EAAKwF,EAAO+nB,GAAK9mB,MAAMjB,IAAW,CAACA,QAAO0G,SAAQ4hB,gBAAa,CAE1E,CAcO,SAASy7E,GAAkBlsG,EAASyM,EAAYuF,GACrD,QAAoBnW,IAAhBmE,EAAQijE,IACV,OAGF,MAAMkpC,EAAgBloF,GAAcjkB,EAAQwU,YAAc,aAEpD3F,EAASiD,GACbrF,EACAuF,EACA,EACAy5F,IAGItB,EAAa,CACjBiC,aAAgBpsG,EAAQslF,OAAe,OACvC+mB,YAAe,oBAEjBtwG,OAAO8C,OACLsrG,EACA4B,GAAiB/rG,EAAQslF,OAAQ,kBACjCtlF,EAAQslF,QAGV,MAAM54E,EAAImI,IAAOpI,EAAW,GAAKoC,EAAO,IAAMmD,EAAYy0F,IACpD95F,EAAIkI,IAAOhG,EAAO,GAAKpC,EAAW,IAAMuF,EAAYy0F,IACpDiF,EAAM5wF,GAAgBqvF,EAAoB,QAAG,QAAU,EAI7D,OAHAA,EAAWuB,EAAM,IAAM,KAAOh/F,EAC9By9F,EAAWuB,EAAM,IAAM,KAAO/+F,EAEvBs7F,GACLjoG,EAAQijE,IACRp0D,EACA48F,GACAU,EACAhC,EAEJ,CAaO,SAASmC,GAAatsG,EAASgS,GACpC,QAAoBnW,IAAhBmE,EAAQijE,IACV,OAGF,MAAMknC,EAAa,CACjB6B,QAAW,MACX3B,QAAWmB,GACXM,QAAW,mBACXxD,OAAU,aAGZ,QAAuBzsG,IAAnBmE,EAAQslF,aAAoDzpF,IAA5BmE,EAAQslF,OAAc,MAAiB,CACzE,MAAMlpC,EAASp8C,EAAQslF,OAAOinB,OAE9B,MADuB70G,MAAMC,QAAQykD,IAA6B,IAAlBA,EAAO5lD,QAErD,OAEF2zG,EAAkB,MAAI/tD,CACvB,CAED,QAAmBvgD,IAAfmW,EAA0B,CAC5B,MAAMw6F,EACJvoF,GAAcjkB,EAAQwU,YAAc,aAAamC,oBAAsB,EACnEggF,EAAY,MAClBwT,EAAkB,MAAKn4F,EAAaw6F,EAAO7V,CAC5C,CAID,OAFA56F,OAAO8C,OAAOsrG,EAAYnqG,EAAQslF,QAE3BsiB,GAAa5nG,EAAQijE,IAAKknC,EACnC,CCLA,IAAAsC,GA/OA,cAAuBhE,GAIrB,WAAAtzG,CAAY6K,GAGV1F,MAAM,CACJi5C,cAHFvzC,EAAUA,GAAoB,IAGNuzC,aACtBrxC,YAAalC,EAAQkC,YACrBsS,WAAYxU,EAAQwU,WACpBwxB,YAAahmC,EAAQgmC,cAOvB3wC,KAAKu8B,kBACqB/1B,IAAxBmE,EAAQ0xB,YAA4B1xB,EAAQ0xB,YAAc,KAM5Dr8B,KAAKitE,KAAOtiE,EAAQijE,IAMpB5tE,KAAKqzG,wBAC2B7sG,IAA9BmE,EAAQ2oG,kBACJ3oG,EAAQ2oG,kBACR/B,GAMNvxG,KAAKuzG,QAAU5oG,EAAQslF,OAMvBjwF,KAAKq3G,YAAc1sG,EAAQ6rG,WAM3Bx2G,KAAKquF,YAA2B7nF,IAAlBmE,EAAQyjF,OAAsBzjF,EAAQyjF,MAMpDpuF,KAAKyzG,kBAAoB,EAMzBzzG,KAAK0zG,YAA2BltG,IAAlBmE,EAAQslC,MAAsBtlC,EAAQslC,MAAQ,IAM5DjwC,KAAK2zG,kBAAoB,IAC1B,CAgBD,iBAAAkD,CAAkBz/F,EAAYuF,EAAYwC,EAAY8wE,GACpD,MAAM6mB,EAAgBloF,GAAczP,GAC9Bm4F,EAAsBt3G,KAAK4uB,gBAE7B0oF,GAAuBA,IAAwBR,IACjDn6F,EAAaqgE,GACXs6B,EACAR,EACA1/F,EACAuF,GAEFvF,EAAapB,GAAUoB,EAAY0/F,EAAeQ,IAWpD,OAAOT,GARS,CACdjpC,IAAK5tE,KAAKitE,KACVgjB,OAAQ,IACHjwF,KAAKuzG,WACLtjB,GAEL9wE,WAAYm4F,GAAuBR,GAEH1/F,EAAYuF,EAC/C,CAgBD,YAAAs6F,CAAat6F,EAAYszE,GACvB,OAAOgnB,GACL,CACErpC,IAAK5tE,KAAKitE,KACVgjB,OAAQ,IACHjwF,KAAKuzG,WACLtjB,IAGPtzE,EAEH,CAQD,SAAAi3F,GACE,OAAO5zG,KAAKuzG,OACb,CASD,gBAAApB,CAAiB34F,EAAQmD,EAAYye,EAAYjc,GAC/C,YAAkB3Y,IAAdxG,KAAKitE,KACA,MAEJjtE,KAAKsT,QAAUtT,KAAK2zG,oBAAsBx0F,IAE7Cnf,KAAK2zG,kBAAoBx0F,EACzBnf,KAAKsT,OAASy/F,GAAa,CACzB12E,YAAar8B,KAAKu8B,aAClB0zD,OAAQjwF,KAAKuzG,QACbp0F,WAAYA,EACZq3F,WAAYx2G,KAAKq3G,YACjBjpB,MAAOpuF,KAAKquF,OACZzgB,IAAK5tE,KAAKitE,KACVh9B,MAAOjwC,KAAK0zG,OACZpmG,KAAM,CAACwF,EAAO+nB,KACZ76B,KAAK8S,MAAMgpB,SAAShpB,GACpB9S,KAAKqzG,mBAAmBrzG,KAAK8S,MAAO+nB,GAC7B7rB,GAAO8D,OAKb7N,MAAMktG,iBAAiB34F,EAAQmD,EAAYye,EAAYjc,GAC/D,CAOD,oBAAA00F,GACE,OAAO7zG,KAAKqzG,kBACb,CAOD,MAAAnU,GACE,OAAOl/F,KAAKitE,IACb,CAOD,oBAAA6mC,CAAqBR,GACnBtzG,KAAKqzG,mBAAqBC,EAC1BtzG,KAAK6H,SACN,CAOD,MAAAgkF,CAAOje,GACDA,GAAO5tE,KAAKitE,OACdjtE,KAAKitE,KAAOW,EACZ5tE,KAAKsT,OAAS,KACdtT,KAAK6H,UAER,CAOD,YAAAksG,CAAa9jB,GACXvpF,OAAO8C,OAAOxJ,KAAKuzG,QAAStjB,GAC5BjwF,KAAK6H,SACN,CAED,OAAAA,GACE7H,KAAK8S,MAAQ,KACb7N,MAAM4C,SACP,GCnNH,MAAM0vG,GAAqB,CACzB,aAAa,EACb,cAAc,EACd,aAAa,EACb,cAAc,GAMVC,GAAwB,CAC5B,sCAAsC,EACtC,wBAAwB,GAwBnB,SAASC,GAAsBC,EAAOC,GAC3C,IAAIC,EACAC,EACJ,IAAK,IAAIj2G,EAAI,EAAGA,EAAI81G,EAAMv2G,SAAUS,EAAG,CACrC,MAAMk2G,EAAOJ,EAAM91G,GACnB,GAAiB,SAAbk2G,EAAKC,IAAgB,CACvB,GAAID,EAAK/3G,OAAS43G,EAAW,CAC3BC,EAAkBE,EAAK9nC,KACvB,KACD,EACGunC,GAAmBO,EAAK/3G,QAEhB83G,GAAuBC,EAAK/3G,KAAKi4G,WAAW,aADtDH,EAAsBC,EAAK9nC,KAI9B,CACF,CAED,IAAK4nC,EAAiB,CACpB,IAAIC,EAGF,MAAM,IAAIrvG,MAAM,8BAFhBovG,EAAkBC,CAIrB,CAED,OAAOD,CACT,CAQO,SAASK,GACdP,EACAC,EACAO,GAEA,IAAIN,EACAC,EAMJ,MAAMM,EAAa,CAAA,EAEnB,IAAK,IAAIv2G,EAAI,EAAGA,EAAI81G,EAAMv2G,SAAUS,EAAG,CACrC,MAAMk2G,EAAOJ,EAAM91G,GAEnB,GADAu2G,EAAWL,EAAK/3G,MAAQ+3G,EAAK9nC,KACZ,SAAb8nC,EAAKC,IAAgB,CACvB,GAAID,EAAK/3G,OAAS43G,EAAW,CAC3BC,EAAkBE,EAAK9nC,KACvB,KACD,CACGwnC,GAAsBM,EAAK/3G,QAC7B83G,EAAsBC,EAAK9nC,KAE9B,CACF,CAED,IAAK4nC,GAAmBM,EACtB,IAAK,IAAIt2G,EAAI,EAAGA,EAAIs2G,EAAoB/2G,SAAUS,EAAG,CACnD,MAAMw2G,EAAqBF,EAAoBt2G,GAC/C,GAAIu2G,EAAWC,GAAqB,CAClCR,EAAkBO,EAAWC,GAC7B,KACD,CACF,CAGH,IAAKR,EAAiB,CACpB,IAAIC,EAGF,MAAM,IAAIrvG,MAAM,8BAFhBovG,EAAkBC,CAIrB,CAED,OAAOD,CACT,CASA,SAASS,GACPvO,EACAwO,EACAV,EACAW,GAEA,IAAIp5F,EAAa2qF,EAAW3qF,WAC5B,IAAKA,IACHA,EAAayP,GAAc0pF,EAAcE,MACpCr5F,GACH,MAAM,IAAI3W,MAAM,oBAAoB8vG,EAAcE,OAGtD,MAAMC,EAA6D,OAAjDt5F,EAAWqC,qBAAqB80F,OAAO,EAAG,GAEtDoC,EAAWJ,EAAcK,aAKzBC,EAAe,CAAA,EACrB,IAAK,IAAIh3G,EAAI,EAAGA,EAAI82G,EAASv3G,SAAUS,EAAG,CACxC,MAAMi3G,EAASH,EAAS92G,GACxBg3G,EAAaC,EAAOrrG,IAAMqrG,CAC3B,CAKD,MAAMC,EAAc,CAAA,EAKdC,EAAY,GAElB,GAAIR,EACF,IAAK,IAAI32G,EAAI,EAAGA,EAAI22G,EAAoBp3G,SAAUS,EAAG,CACnD,MAAMo3G,EAAQT,EAAoB32G,GAC5B4L,EAAKwrG,EAAMC,WACjBF,EAAUpzG,KAAK6H,GACfsrG,EAAYtrG,GAAMwrG,CACnB,MAED,IAAK,IAAIp3G,EAAI,EAAGA,EAAI82G,EAASv3G,SAAUS,EAAG,CACxC,MAAM4L,EAAKkrG,EAAS92G,GAAG4L,GACvBurG,EAAUpzG,KAAK6H,EAChB,CAGH,MAAMrM,EAAS43G,EAAU53G,OACnBokF,EAAU,IAAIljF,MAAMlB,GACpBwvC,EAAc,IAAItuC,MAAMlB,GACxB+kF,EAAQ,IAAI7jF,MAAMlB,GAClBykF,EAAY,IAAIvjF,MAAMlB,GACtBqY,EAAS,EAAEiB,KAAWA,IAAUA,IAAUA,KAEhD,IAAK,IAAI7Y,EAAI,EAAGA,EAAIT,IAAUS,EAAG,CAC/B,MAAM4L,EAAKurG,EAAUn3G,GACfi3G,EAASD,EAAaprG,GACtBi4E,EAASozB,EAAOK,cAEpB3zB,EAAQ3jF,GADN62G,EACW,CAAChzB,EAAO,GAAIA,EAAO,IAEnBA,EAEf90C,EAAY/uC,GAAKi3G,EAAOM,SACxBjzB,EAAMtkF,GAAK,CAACi3G,EAAOO,YAAaP,EAAOQ,cACvCzzB,EAAUhkF,GAAK,CAACi3G,EAAOhN,UAAWgN,EAAOnJ,YACzC,MAAMsJ,EAAQF,EAAYtrG,GAC1B,GAAIwrG,EAAO,CACT,MAAMM,EAAeT,EAAOM,SAAWN,EAAOhN,UACxCzxF,EAAOmrE,EAAQ3jF,GAAG,GAAKo3G,EAAMO,WAAaD,EAC1Ch/F,EAAOirE,EAAQ3jF,GAAG,IAAMo3G,EAAMQ,WAAa,GAAKF,EAEhDG,EAAgBZ,EAAOM,SAAWN,EAAOnJ,WAG/C,IAAIr1F,EACAE,EAHyC,eAA1Bs+F,EAAOa,gBAKxBr/F,EAAOkrE,EAAQ3jF,GAAG,GAAKo3G,EAAMW,WAAaF,EAC1Cl/F,EAAOgrE,EAAQ3jF,GAAG,IAAMo3G,EAAMY,WAAa,GAAKH,IAEhDp/F,EAAOkrE,EAAQ3jF,GAAG,IAAMo3G,EAAMY,WAAa,GAAKH,EAChDl/F,EAAOgrE,EAAQ3jF,GAAG,GAAKo3G,EAAMW,WAAaF,GAG5CI,GAAiBrgG,EAAQ,CAACY,EAAMC,EAAMC,EAAMC,GAAOf,EACpD,CACF,CAED,MAAMqI,EAAW,IAAIqmE,GAAS,CAC5B3C,QAASA,EACT50C,YAAaA,EACbu1C,MAAOA,EACPN,UAAWA,EACXpsE,OAAQ++F,EAAsB/+F,OAAShT,IAGnC2J,EAAU25F,EAAW35F,QACrBu6B,EAAOo/D,EAAWl8B,IAuCxB,MAAO,CACLksC,KAAMj4F,EACNk4F,YAAanC,EACboC,YAvCF,SAAyBztG,EAAW6uB,EAAYjc,GAC9C,IAAK5S,EACH,OAGF,MAAMiB,EAAKurG,EAAUxsG,EAAU,IACzBssG,EAASD,EAAaprG,GACtBysG,EAAuC,eAA1BpB,EAAOa,eAEpB3N,EAAe,CACnBkN,WAAYzrG,EACZ0sG,QAAS3tG,EAAU,GACnB4tG,QAASF,GAAc1tG,EAAU,GAAK,EAAIA,EAAU,IAGtD,GAAIgsG,EAAqB,CACvB,MAAMS,EAAQF,EAAYD,EAAOrrG,IACjC,GACEu+F,EAAamO,QAAUlB,EAAMO,YAC7BxN,EAAamO,QAAUlB,EAAMQ,YAC7BzN,EAAaoO,QAAUnB,EAAMW,YAC7B5N,EAAaoO,QAAUnB,EAAMY,WAE7B,MAEH,CAEDlzG,OAAO8C,OAAOuiG,EAAc57F,GAE5B,MAAMy9D,EAAMgqC,EAAgBp0F,QAAQ,eAAe,SAAUrD,EAAGi2E,GAC9D,OAAO2V,EAAa3V,EAC1B,IAEI,OAAOtmB,GAAWplC,EAAMkjC,EACzB,EAOH,CA8DO,SAASwsC,GAAetQ,GAC7B,OAAOl6B,GAAQk6B,EAAWl8B,KAAK75D,MAAK,SAAUsmG,GAC5C,OAzDJ,SAA8BvQ,EAAYuQ,GACxC,MAAM9B,EAAsB8B,EAAQ9B,oBAEpC,IAAIX,EAEJ,GAAyB,QAArByC,EAAQ7X,SACVoV,EAAkBH,GAChB4C,EAAQ3C,MACR5N,EAAW6N,eAER,IAAyB,WAArB0C,EAAQ7X,SAOjB,MAAM,IAAIh6F,MAAM,sDANhBovG,EAAkBK,GAChBoC,EAAQ3C,MACR5N,EAAW6N,UACX7N,EAAWoO,oBAId,CAED,GAAImC,EAAQ/B,cACV,OAAOD,GACLvO,EACAuQ,EAAQ/B,cACRV,EACAW,GAIJ,MAAM+B,EAAoBD,EAAQ3C,MAAM35D,MACrC+5D,GACc,yDAAbA,EAAKC,MAET,IAAKuC,EACH,MAAM,IAAI9xG,MACR,uFAGJ,MAAM+xG,EAA0BD,EAAkBtqC,KAGlD,OAAOJ,GADKE,GAAWg6B,EAAWl8B,IAAK2sC,IACnBxmG,MAAK,SAAUukG,GACjC,OAAOD,GACLvO,EACAwO,EACAV,EACAW,EAEN,GACA,CAQWiC,CAAqB1Q,EAAYuQ,EAC5C,GACA,CCxTA,IAAAI,GAlDA,cAAyBtsB,GAIvB,WAAAruF,CAAY6K,GACV1F,MAAM,CACJi5C,aAAcvzC,EAAQuzC,aACtB7S,UAAW1gC,EAAQ0gC,UACnBhP,YAAa1xB,EAAQ0xB,YACrBxvB,YAAalC,EAAQkC,YACrBsS,WAAYxU,EAAQwU,WACpB6tE,2BAA4BriF,EAAQqiF,2BACpCxgF,MAAO,UACP8vB,iBAAkB3xB,EAAQ2xB,iBAC1Bpd,WAAyB1Y,IAAlBmE,EAAQuU,OAAsBvU,EAAQuU,MAC7CvS,WAAYhC,EAAQgC,aAUtBytG,GAPmB,CACjBxsC,IAAKjjE,EAAQijE,IACbzuD,WAAYnf,KAAK4uB,gBACjB+oF,UAAWhtG,EAAQgtG,UACnBxnG,QAASxF,EAAQwF,SAAW,OAI3B4D,KAAK/T,KAAK06G,mBAAmBxzG,KAAKlH,OAClCgU,MAAMhU,KAAK26G,aAAazzG,KAAKlH,MACjC,CAMD,kBAAA06G,CAAmBE,GACjB56G,KAAK6hB,SAAW+4F,EAAYd,KAC5B95G,KAAKssF,mBAAmBsuB,EAAYZ,YAAaY,EAAYb,aAC7D/5G,KAAK+M,SAAS,QACf,CAMD,YAAA4tG,CAAaprG,GACXk4F,GAASl4F,GACTvP,KAAK+M,SAAS,QACf,GC4YH,IAAA8tG,GAlYA,cAAyBrvB,GAIvB,WAAA1rF,CAAY6K,GACV,MAAMwU,EAAaxU,EAAQwU,YAAc,YAEnC3F,EAAS7O,EAAQ6O,QAAUuuE,GAAqB5oE,GAEhD0C,EACJlX,EAAQkX,UACRsmE,GAAU,CACR3uE,OAAQA,EACRyzB,cAAetiC,EAAQsiC,cACvBG,aAA6B5mC,IAApBmE,EAAQyiC,QAAwBziC,EAAQyiC,QAAU,GAC3DD,QAASxiC,EAAQwiC,QACjB24C,SAAUn7E,EAAQm7E,UAAY,MAGlC7gF,MAAM,CACJi5C,aAAcvzC,EAAQuzC,aACtB0mC,wBAAyBj6E,EAAQi6E,wBACjCv5C,UAAW1gC,EAAQ0gC,UACnBx+B,aAAa,EACb87E,QAAQ,EACRxpE,WAAYA,EACZ3S,MAAO7B,EAAQ6B,MACfqV,SAAUA,EACVya,iBAAkB3xB,EAAQ2xB,iBACtB3xB,EAAQ2xB,iBACRw+E,GACJnvB,gBAAiBhhF,EAAQghF,gBACzB/d,IAAKjjE,EAAQijE,IACbqd,KAAMtgF,EAAQsgF,KACd/rE,WAAyB1Y,IAAlBmE,EAAQuU,OAA6BvU,EAAQuU,MACpDvS,WAAYhC,EAAQgC,WACpBu8E,gBAAmC1iF,IAAvBmE,EAAQu+E,WAA2B,EAAIv+E,EAAQu+E,aAO7DlpF,KAAK+sE,QAAUpiE,EAAQqc,OAASrc,EAAQqc,OAAS,KAMjDhnB,KAAK+6G,gBAAkB,IAAIhyB,GAAU/oF,KAAK8oF,UAAUvf,eAMpDvpE,KAAKi8F,UAAgCz1F,MAApBmE,EAAQuxF,UAA+BvxF,EAAQuxF,SAMhEl8F,KAAK2sF,UAAYhiF,EAAQgiF,UAAYhiF,EAAQgiF,UAAYv5E,GAMzDpT,KAAKg7G,WAAa,EACnB,CAcD,mBAAAvc,CAAoBjlF,GAClB,MAAM2pD,EAAW,GACX2lB,EAAY9oF,KAAK8oF,UACvB,GAA6B,IAAzBA,EAAUv7B,WACZ,OAAO4V,EAET,MAAM5jC,EAAIsrC,GAAQie,EAAUve,gBAAgB,GACtC1oD,EAAW7hB,KAAK6hB,SAuBtB,OAtBAinE,EAAU39E,SAAQ,SAAU+B,GAC1B,GAAIA,EAAKX,UAAU,KAAOgzB,GAAKryB,EAAKC,aAAerB,EACjD,OAEF,MAAMmgE,EAAc/+D,EAAKw+D,iBACzB,IAAK,IAAI9pE,EAAI,EAAGuE,EAAK8lE,EAAY9qE,OAAQS,EAAIuE,IAAMvE,EAAG,CACpD,MAAMq5G,EAAahvC,EAAYrqE,GACzB2K,EAAY0uG,EAAW1uG,UAC7B,GAAIuR,GAAWtE,EAAQqI,EAASuhE,mBAAmB72E,IAAa,CAC9D,MAAM2uG,EAAeD,EAAW59D,cAChC,GAAI69D,EACF,IAAK,IAAI52F,EAAI,EAAG2G,EAAKiwF,EAAa/5G,OAAQmjB,EAAI2G,IAAM3G,EAAG,CACrD,MAAMziB,EAAYq5G,EAAa52F,GACzB1P,EAAW/S,EAAUqT,cACvB4I,GAAWtE,EAAQ5E,EAASyK,cAC9B8jD,EAASx9D,KAAK9D,EAEjB,CAEJ,CACF,CACP,IACWshE,CACR,CAKD,WAAA87B,GACE,OAAOj/F,KAAKi8F,SACb,CAMD,KAAAt3F,GACE3E,KAAK8oF,UAAUnkF,QACf3E,KAAK+6G,gBAAgBp2G,OACtB,CAMD,WAAAilE,CAAYzqD,EAAYgnD,GACtB,MAAM2iB,EAAY9oF,KAAKmpF,0BAA0BhqE,GAC3Cg8F,EAAkBz0G,OAAOC,KAAKw/D,GAAWzhB,QAAO,CAACs1B,EAAKzyE,KAC1D,MAAM6zG,EAAW1wC,GAAsBnjE,GACjC2F,EAAO47E,EAAUte,KAAK4wC,GAC5B,GAAIluG,EAAM,CACR,MAAM++D,EAAc/+D,EAAK++D,YACzB,IAAK,IAAIrqE,EAAI,EAAGuE,EAAK8lE,EAAY9qE,OAAQS,EAAIuE,IAAMvE,EACjDo4E,EAAI/N,EAAYrqE,GAAGoL,WAAY,CAElC,CACD,OAAOgtE,CAAG,GACT,CAAE,GACL/0E,MAAM2kE,YAAYzqD,EAAYgnD,GAC9BnmE,KAAK+6G,gBAAgBnxC,YAAYuxC,EAClC,CAQD,cAAAzvC,CAAetwC,EAAYjc,EAAYjS,GACrC,GAAIA,EAAKC,aAAerB,EAAgB,CACtCoB,EAAKH,SAASjB,GACd,MAAM2/D,EAAev+D,EAAKk/D,iBACpBvqD,EAAW7hB,KAAK0pF,yBAAyBvqE,GACzC3F,EAASqI,EAASuhE,mBAAmB3X,GACrClsC,EAAIksC,EAAa,GACjB9uD,EAAakF,EAAS6Z,cAAc6D,GAE1C87E,GAAa7hG,GAASmD,EAAYnD,GAClC,MAAMipE,EAAiBziF,KAAK6hB,SACtBkL,EAAe01D,EAAepjE,YAChC0N,GACFnP,GAAgBpE,EAAQuT,EAAcvT,GAExC,MAAM8hG,EAAU74B,EAAekB,kBAC7BhnE,EACA3c,KAAKkpF,YAGPzG,EAAe4D,iBAAiB7sE,EAAQ8hG,GAAUC,IAChD,MAAMhuB,EAAUvtF,KAAK2rF,gBACnB4vB,EACAngF,EACAjc,GAEI87F,EAAaj7G,KAAK+6G,gBAAgBjxC,YAAYyjB,GAChDvtF,KAAK+6G,gBAAgB3xG,IAAImkF,GACzB,IAAIvtF,KAAK2sF,UACP4uB,EACAhuB,EAAUzhF,EAAiBA,EAC3ByhF,EACAvtF,KAAK+sE,QACL/sE,KAAKs8B,kBAEXpvB,EAAK++D,YAAYtmE,KAAKs1G,GACtB,MAAMO,EAAkBP,EAAW9tG,WACnC,GAAIquG,EAAkB1vG,EAAkB,CACtC,MAAM2vG,EAAgB51G,IACpB7F,KAAK0uD,iBAAiB7oD,GACtB,MAAM2G,EAAQyuG,EAAW9tG,WACzB,GAAIX,IAAUV,GAAoBU,IAAUV,EAAiB,CAC3D,MAAM4vG,EAAgBT,EAAWjuG,SAC7B0uG,KAAiBxuG,EAAKg/D,cACpB+uC,EAAW9tG,aAAerB,UACrBoB,EAAKg/D,cAAcwvC,GAG5BxuG,EAAK4+D,qBAEHt/D,IAAUV,EACZoB,EAAKg/D,cAAcwvC,IAAiB,EAEpCT,EAAW30G,oBAAoBwB,EAAkB2zG,GAEnB,IAA5BvuG,EAAK4+D,oBACP5+D,EAAKH,SACHjI,EAAQoI,EAAKg/D,eACTpgE,EACAA,EAGT,GAEHmvG,EAAW31G,iBAAiBwC,EAAkB2zG,GAC9CvuG,EAAK4+D,oBACN,CACG0vC,IAAoB1vG,IACtBmvG,EAAWzhG,OACTipE,EAAeW,mBAAmBm4B,GACpCN,EAAW97F,WAAaA,EACxB87F,EAAWt+F,WAAa8lE,EAAe/mD,cACrC6/E,EAAgB,IAElBv7G,KAAK+6G,gBAAgBhxG,IAAIwjF,EAAS0tB,GAClCA,EAAW3tG,OACZ,IAEEJ,EAAK4+D,oBACR5+D,EAAKH,SACHG,EAAK++D,YAAYvtB,MACdu8D,GAAeA,EAAW9tG,aAAerB,IAExCA,EACAA,EAGT,CAED,OAAOoB,EAAK++D,WACb,CAUD,OAAA0d,CAAQpqD,EAAGloB,EAAGC,EAAG8jB,EAAYjc,GAC3B,MAAMw8F,EAAWlxC,GAAUlrC,EAAGloB,EAAGC,GAC3B/P,EAAMvH,KAAKgN,SACjB,IAAIE,EACJ,GAAIlN,KAAK8oF,UAAUhf,YAAY6xC,KAC7BzuG,EAAOlN,KAAK8oF,UAAU1/E,IAAIuyG,GACtBzuG,EAAK3F,MAAQA,GACf,OAAO2F,EAGX,MAAMX,EAAY,CAACgzB,EAAGloB,EAAGC,GACzB,IAAIm0D,EAAezrE,KAAKgqF,+BACtBz9E,EACA4S,GAEF,MAAM4N,EAAe/sB,KAAK4pF,cAAcvqE,YAClCwC,EAAW7hB,KAAK0pF,yBAAyBvqE,GAC/C,GAAIssD,GAAgB1+C,EAAc,CAChC,MAAM6uF,EAAa/5F,EAASuhE,mBAAmB3X,GAE/C4vC,GAAaO,GAAa/5F,EAAS6Z,cAAc6D,GAAIq8E,GAChD99F,GAAWiP,EAAc6uF,KAC5BnwC,EAAe,KAElB,CACD,IAAIowC,GAAQ,EACZ,GAAqB,OAAjBpwC,EAAuB,CACzB,MAAMgX,EAAiBziF,KAAK6hB,SACtBlF,EAAakF,EAAS6Z,cAAc6D,GACpC+7E,EAAU74B,EAAekB,kBAAkBhnE,EAAY,GAEvDnD,EAASqI,EAASuhE,mBAAmB3X,GAC3C4vC,GAAa7hG,GAASmD,EAAYnD,GAClCipE,EAAe4D,iBAAiB7sE,EAAQ8hG,GAAUC,IAChDM,EACEA,IACC77G,KAAK2rF,gBAAgB4vB,EAAiBngF,EAAYjc,EAAW,GAEnE,CACD,MAAMsuE,EAAU,IAAIquB,GAClBvvG,EACAsvG,EAAQ/vG,EAAkBA,EAC1B2/D,EACAzrE,KAAK0rE,eAAexkE,KAAKlH,KAAMo7B,EAAYjc,IAW7C,OARAsuE,EAAQlmF,IAAMA,EACV2F,GACFugF,EAAQhhF,YAAcS,EACtBugF,EAAQrgF,sBACRpN,KAAK8oF,UAAUtlE,QAAQm4F,EAAUluB,IAEjCztF,KAAK8oF,UAAU/+E,IAAI4xG,EAAUluB,GAExBA,CACR,CAMD,wBAAA/D,CAAyBvqE,GACvB,MAAMU,EAAOV,EAAWiC,UACxB,IAAIS,EAAW7hB,KAAKg7G,WAAWn7F,GAC/B,IAAKgC,EAAU,CAGb,MAAM4gE,EAAiBziF,KAAK6hB,SACtB8uB,EAAc8xC,EAAe7pC,iBAAiB90C,QAC9CyhF,EAAU50C,EAAY7F,KAAI,SAAUnuB,EAAY4iB,GACpD,OAAOkjD,EAAerK,UAAU74C,EACxC,IACYqmD,EAAYj1C,EAAY7F,KAAI,SAAUnuB,EAAY4iB,GACtD,OAAOkjD,EAAewB,YAAY1kD,EAC1C,IACYp+B,EAASmuC,GAAmB,EAClC,IAAK,IAAI/P,EAAIoR,EAAYxvC,OAAQo+B,EAAIp+B,IAAUo+B,EAC7CoR,EAAYhrC,KAAKgrC,EAAYpR,EAAI,GAAK,GACtCgmD,EAAQ5/E,KAAK4/E,EAAQhmD,EAAI,IACzBqmD,EAAUjgF,KAAKigF,EAAUrmD,EAAI,IAE/B1d,EAAW,IAAIqmE,GAAS,CACtB1uE,OAAQipE,EAAepjE,YACvBkmE,QAASA,EACT50C,YAAaA,EACbi1C,UAAWA,IAEb5lF,KAAKg7G,WAAWn7F,GAAQgC,CACzB,CACD,OAAOA,CACR,CAOD,iBAAAgoE,CAAkBzuD,GAChB,OAAOA,CACR,CAQD,gBAAA0uD,CAAiBvqD,EAAGnE,EAAYjc,GAC9B,MACM2mE,EAAW9mB,GADAh/D,KAAK0pF,yBAAyBvqE,GACd8kE,YAAY1kD,GAAIv/B,KAAKgpF,SACtD,MAAO,CACL/8E,KAAKiZ,MAAM4gE,EAAS,GAAK1qD,GACzBnvB,KAAKiZ,MAAM4gE,EAAS,GAAK1qD,GAE5B,CAOD,eAAA6uD,CAAgBC,EAAW/qE,GACzBla,MAAMglF,gBAA4B,EAAZC,EAAe/qE,GACrCnf,KAAK+6G,gBAAgBxxC,cACnBvpE,KAAKmpF,0BAA0BhqE,GAAYoqD,aAC9C,GAUI,SAASuxC,GAAoB5tG,EAAM0gE,GACxC1gE,EAAKqgE,WAMH,SAAU/zD,EAAQmD,EAAYwC,GAC5BwuD,GACEC,EACA1gE,EAAKggE,YACL1zD,EACAmD,EACAwC,EACAjS,EAAKigE,OAAOjmE,KAAKgG,GACjBA,EAAKogE,QAAQpmE,KAAKgG,GAErB,GAEL,CC7ZA,IAAA6uG,GApDA,cAA4BC,GAI1B,WAAAl8G,CAAY6K,GACV1F,MAAM,CACJi5C,aAAcvzC,EAAQuzC,aACtB0mC,wBAAyBj6E,EAAQi6E,wBACjCv5C,UAAW1gC,EAAQ0gC,UACnBrkB,OAAQrc,EAAQqc,OAChBk1E,SAAUvxF,EAAQuxF,SAClB/8E,WAAYxU,EAAQwU,WACpBwtE,UAAWhiF,EAAQgiF,UACnBhgF,WAAYhC,EAAQgC,WACpBuS,MAAOvU,EAAQuU,MACfgqE,WAAYv+E,EAAQu+E,WACpB18E,MAAO,YAWT4tG,GARmB,CACjBxsC,IAAKjjE,EAAQijE,IACbzuD,WAAYnf,KAAK4uB,gBACjB+oF,UAAWhtG,EAAQgtG,UACnBO,oBAAqBvtG,EAAQqc,OAAOkxF,oBACpC/nG,QAASxF,EAAQwF,SAAW,OAI3B4D,KAAK/T,KAAK06G,mBAAmBxzG,KAAKlH,OAClCgU,MAAMhU,KAAK26G,aAAazzG,KAAKlH,MACjC,CAMD,kBAAA06G,CAAmBE,GACjB56G,KAAK6hB,SAAW+4F,EAAYd,KAC5B95G,KAAKssF,mBAAmBsuB,EAAYZ,YAAaY,EAAYb,aAC7D/5G,KAAK+M,SAAS,QACf,CAMD,YAAA4tG,CAAaprG,GACXk4F,GAASl4F,GACTvP,KAAK+M,SAAS,QACf,GCpFI,MAAMkvG,GACX,2GA8EF,IAAAC,GAxCA,cAAkBtrB,GAIhB,WAAA9wF,CAAY6K,GAGV,IAAIuzC,EAEFA,OAD2B13C,KAH7BmE,EAAUA,GAAW,IAGTuzC,aACKvzC,EAAQuzC,aAER,CAAC+9D,IAGlB,MAAM5/E,OACoB71B,IAAxBmE,EAAQ0xB,YAA4B1xB,EAAQ0xB,YAAc,YAEtDuxC,OACYpnE,IAAhBmE,EAAQijE,IACJjjE,EAAQijE,IACR,iDAEN3oE,MAAM,CACJi5C,aAAcA,EACd0mC,yBAAyB,EACzBv5C,UAAW1gC,EAAQ0gC,UACnBhP,YAAaA,EACbxvB,YAAalC,EAAQkC,YACrBugC,aAA6B5mC,IAApBmE,EAAQyiC,QAAwBziC,EAAQyiC,QAAU,GAC3Du7C,YAA2BniF,IAAnBmE,EAAQg+E,QAAuBh+E,EAAQg+E,OAC/CqE,2BAA4BriF,EAAQqiF,2BACpC1wD,iBAAkB3xB,EAAQ2xB,iBAC1B3vB,WAAYhC,EAAQgC,WACpBihE,IAAKA,EACL1uD,MAAOvU,EAAQuU,MACfgqE,WAAYv+E,EAAQu+E,YAEvB,GCjCH,IAAAizB,GAVA,cAA6Bj9C,GAI3B,WAAAp/D,CAAY6K,GAEV1F,MADA0F,EAAUA,GAAoB,GAE/B,GCmJH,IAAAyxG,GA7LA,cAA4B50G,EAI1B,WAAA1H,CAAY8tC,GACV3oC,QAMAjF,KAAKmkE,OAAQ,EAGbnkE,KAAKq8G,wBAA0Br8G,KAAKs8G,mBAAmBp1G,KAAKlH,MAM5DA,KAAKu8G,OAAS3uE,EAKd5tC,KAAKw8G,uBAAyB,IAC/B,CAQD,WAAAn/D,CAAYC,GACV,OAAO/0C,GACR,CAMD,OAAAsL,CAAQypC,GACN,OAAO,IACR,CAQD,YAAAe,CAAaZ,GACX,OAAOl1C,GACR,CASD,WAAA+1C,CAAYb,EAAYt9C,GACtB,OAAOoI,GACR,CAQD,kBAAAk0G,CAAmB7O,EAAOx4D,EAAMloC,GACzB0gG,EAAMx4D,KACTw4D,EAAMx4D,GAAQ,IAEhBw4D,EAAMx4D,GAAMloC,EAAKX,UAAUqM,YAAc1L,CAE1C,CAWD,sBAAAwvG,CAAuBxyG,EAAQiV,EAAYyuF,GACzC,MAAA,CAMGx4D,EAAM41B,KACL,MAAMpvD,EAAW5b,KAAKy8G,mBAAmBv1G,KAAKlH,KAAM4tG,EAAOx4D,GAC3D,OAAOlrC,EAAOk/E,kBAAkBjqE,EAAYi2B,EAAM41B,EAAWpvD,EAE/D,CACH,CAWD,0BAAA0jC,CACEloC,EACAqmC,EACA8B,EACA3jC,EACAokC,GAGD,CAKD,QAAA28D,GACE,OAAO38G,KAAKu8G,MACb,CAMD,kBAAA32C,GAAuB,CAOvB,kBAAA02C,CAAmBz2G,GACjB,MAAMiN,EAAsDjN,EAAY,OAEtEiN,EAAM3F,aAAeitB,IACrBtnB,EAAM3F,aAAeitB,IAErBp6B,KAAK48G,yBAER,CASD,SAAAC,CAAU/pG,GACR,IAAIgpE,EAAahpE,EAAM3F,WAQvB,OAPI2uE,GAAc1hD,IAAqB0hD,GAAc1hD,IACnDtnB,EAAMxN,iBAAiBwC,EAAkB9H,KAAKq8G,yBAE5CvgC,GAAc1hD,KAChBtnB,EAAMxF,OACNwuE,EAAahpE,EAAM3F,YAEd2uE,GAAc1hD,EACtB,CAKD,uBAAAwiF,GACE,MAAMhvE,EAAQ5tC,KAAK28G,WACf/uE,GAASA,EAAMG,cAA2C,UAA3BH,EAAMW,kBACvCX,EAAM/lC,SAET,CAKD,eAAApH,UACST,KAAKu8G,OACZt3G,MAAMxE,iBACP,GC7KI,MAAMkP,GAAa,GAK1B,IAAImtG,GAAe,KAySnB,IAAAC,GA5RA,cAAkCC,GAIhC,WAAAl9G,CAAY8tC,GACV3oC,MAAM2oC,GAMN5tC,KAAKomD,UAAY,KAMjBpmD,KAAKysE,mBAQLzsE,KAAKi9G,c3K/BA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,G2KuCrBj9G,KAAKk9G,e3KvCA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,G2K+CrBl9G,KAAK2gD,sB3K/CA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,G2KoDrB3gD,KAAKmQ,QAAU,KAKfnQ,KAAKm9G,iBAAkB,EAMvBn9G,KAAKo9G,cAAgB,KAMrBp9G,KAAKy9C,WAAa,IACnB,CAQD,YAAAxqC,CAAaH,EAAOuqG,EAAKC,GAMvB,IAAIn7G,EALC26G,KAnFPA,GAAettG,GAAsB,EAAG,OAAGhJ,EAAW,CACpDuM,oBAAoB,KAqFpB+pG,GAAa1sG,UAAU,EAAG,EAAG,EAAG,GAGhC,IACE0sG,GAAa9pG,UAAUF,EAAOuqG,EAAKC,EAAK,EAAG,EAAG,EAAG,EAAG,EAAG,GACvDn7G,EAAO26G,GAAa7pG,aAAa,EAAG,EAAG,EAAG,GAAG9Q,IAC9C,CAAC,MAAOmC,GAEP,OADAw4G,GAAe,KACR,IACR,CACD,OAAO36G,CACR,CAMD,aAAAqrC,CAAciQ,GAEZ,IAAI5Q,EADU7sC,KAAK28G,WACInvE,gBAIvB,MAH0B,mBAAfX,IACTA,EAAaA,EAAW4Q,EAAWjE,UAAU78B,aAExCkwB,QAAcrmC,CACtB,CAQD,YAAA+2G,CAAap9G,EAAQ6V,EAAWwnG,GAC9B,MAAMC,EAAiBz9G,KAAK28G,WAAWlvE,eACvC,IAAI2Y,EAAWj2C,EACf,GACEhQ,GACAA,EAAOmtC,YAAcmwE,KACnBD,GACCr9G,GACCA,EAAOoQ,MAAMitG,iBACbj7G,EACEqpC,GAAQzrC,EAAOoQ,MAAMitG,iBACrB5xE,GAAQ4xE,KAEd,CACA,MAAM3tG,EAAS1P,EAAOu9G,kBAClB7tG,aAAkBuC,oBACpBjC,EAAUN,EAAOI,WAAW,MAE/B,CAcD,GAbIE,GAAWA,EAAQN,OAAOU,MAAMyF,YAAcA,GAEhDhW,KAAKomD,UAAYjmD,EACjBH,KAAKmQ,QAAUA,EACfnQ,KAAKm9G,iBAAkB,GACdn9G,KAAKm9G,iBAEdn9G,KAAKomD,UAAY,KACjBpmD,KAAKmQ,QAAU,KACfnQ,KAAKm9G,iBAAkB,GACdn9G,KAAKomD,YACdpmD,KAAKomD,UAAU71C,MAAMitG,gBAAkB,OAEpCx9G,KAAKomD,UAAW,CACnBA,EAAYr2C,SAASC,cAAc,OACnCo2C,EAAU9Y,UAAYmwE,EACtB,IAAIltG,EAAQ61C,EAAU71C,MACtBA,EAAM2oB,SAAW,WACjB3oB,EAAMd,MAAQ,OACdc,EAAMb,OAAS,OACfS,EAAUX,KACV,MAAMK,EAASM,EAAQN,OACvBu2C,EAAUl0C,YAAYrC,GACtBU,EAAQV,EAAOU,MACfA,EAAM2oB,SAAW,WACjB3oB,EAAMg0C,KAAO,IACbh0C,EAAMotG,gBAAkB,WACxB39G,KAAKomD,UAAYA,EACjBpmD,KAAKmQ,QAAUA,CAChB,CAEEnQ,KAAKm9G,kBACNK,GACCx9G,KAAKomD,UAAU71C,MAAMitG,kBAEtBx9G,KAAKomD,UAAU71C,MAAMitG,gBAAkBA,EAE1C,CAQD,aAAAI,CAAcztG,EAASstC,EAAYjkC,GACjC,MAAMqkG,EAAU5hG,GAAWzC,GACrBskG,EAAW9hG,GAAYxC,GACvBukG,EAAchiG,GAAevC,GAC7BwkG,EAAaliG,GAActC,GAEjCmF,GAAe8+B,EAAW2B,2BAA4By+D,GACtDl/F,GAAe8+B,EAAW2B,2BAA4B0+D,GACtDn/F,GAAe8+B,EAAW2B,2BAA4B2+D,GACtDp/F,GAAe8+B,EAAW2B,2BAA4B4+D,GAEtD,MAAMC,EAAWj+G,KAAK2gD,sBACtBhiC,GAAes/F,EAAUJ,GACzBl/F,GAAes/F,EAAUH,GACzBn/F,GAAes/F,EAAUF,GACzBp/F,GAAes/F,EAAUD,GAEzB7tG,EAAQs1C,OACRt1C,EAAQ4kE,YACR5kE,EAAQwkE,OAAO1oE,KAAKiZ,MAAM24F,EAAQ,IAAK5xG,KAAKiZ,MAAM24F,EAAQ,KAC1D1tG,EAAQykE,OAAO3oE,KAAKiZ,MAAM44F,EAAS,IAAK7xG,KAAKiZ,MAAM44F,EAAS,KAC5D3tG,EAAQykE,OAAO3oE,KAAKiZ,MAAM64F,EAAY,IAAK9xG,KAAKiZ,MAAM64F,EAAY,KAClE5tG,EAAQykE,OAAO3oE,KAAKiZ,MAAM84F,EAAW,IAAK/xG,KAAKiZ,MAAM84F,EAAW,KAChE7tG,EAAQ2sE,MACT,CAQD,oBAAAohC,CAAqBn+G,EAAMoQ,EAASstC,GAClC,MAAM7P,EAAQ5tC,KAAK28G,WACnB,GAAI/uE,EAAMnnC,YAAY1G,GAAO,CAC3B,MAAM8F,EAAQ,IAAI6gD,GAChB3mD,EACAC,KAAK2gD,sBACLlD,EACAttC,GAEFy9B,EAAMhoC,cAAcC,EACrB,CACF,CAOD,SAAAs4G,CAAUhuG,EAASstC,GACjBz9C,KAAKy9C,WAAaA,EAClBz9C,KAAKk+G,qBAAqBz/D,GAA2BtuC,EAASstC,EAC/D,CAOD,UAAA2gE,CAAWjuG,EAASstC,GAClBz9C,KAAKk+G,qBAAqBz/D,GAA4BtuC,EAASstC,EAChE,CAcD,kBAAA4gE,CACE3hG,EACAC,EACAC,EACAwe,EACA3rB,EACAC,EACA+lC,GAEA,MAAMx9B,EAAMxI,EAAQ,EACdyI,EAAMxI,EAAS,EACfyI,EAAKijB,EAAaze,EAClBvE,GAAMD,EACNE,GAAOqE,EAAO,GAAK+4B,EACnBn9B,GAAOoE,EAAO,GACpB,OAAOuS,GACLjvB,KAAKi9G,cACLhlG,EACAC,EACAC,EACAC,GACCwE,EACDvE,EACAC,EAEH,CAKD,eAAA7X,UACST,KAAKy9C,WACZx4C,MAAMxE,iBACP,GCrDH,IAAA69G,GAlPA,cAAuCC,GAIrC,WAAAz+G,CAAY0+G,GACVv5G,MAAMu5G,GAMNx+G,KAAKu7B,OAAS,IACf,CAKD,QAAAC,GACE,OAAQx7B,KAAKu7B,OAAgBv7B,KAAKu7B,OAAOC,WAAnB,IACvB,CAOD,YAAA6iB,CAAaZ,GACX,MAAMrB,EAAaqB,EAAWI,iBAAiBJ,EAAWoJ,YACpDzrB,EAAaqiB,EAAWriB,WACxBoe,EAAYiE,EAAWjE,UACvBilE,EAAiBjlE,EAAU78B,WAE3B+hG,EAAc1+G,KAAK28G,WAAWz/D,YAE9B7E,EAAQoF,EAAWqnB,UAEzB,IAAI65C,EAAiBlhE,EAAWjkC,OAQhC,QAP0BhT,IAAtB41C,EAAW5iC,SACbmlG,EAAiB/gG,GACf+gG,EACAryF,GAAe8vB,EAAW5iC,OAAQggC,EAAUr6B,eAK7Ck5B,EAAMpJ,MACNoJ,EAAMpJ,MACNnqC,GAAQ65G,GAET,GAAID,EAAa,CACf,MAAMv/F,EAAaq6B,EAAUr6B,WACvBrM,EAAQ4rG,EAAYljF,SACxBmjF,EACAF,EACArjF,EACAjc,GAEErM,IACE9S,KAAK68G,UAAU/pG,GACjB9S,KAAKu7B,OAASzoB,EACLA,EAAM3F,aAAeitB,KAC9Bp6B,KAAKu7B,OAAS,MAG1B,MACQv7B,KAAKu7B,OAAS,KAIlB,QAASv7B,KAAKu7B,MACf,CAMD,OAAA1nB,CAAQypC,GACN,MAAMG,EAAaz9C,KAAKy9C,WACxB,IAAKA,EACH,OAAO,KAGT,MAAM7P,EAAQ5tC,KAAK28G,WACbvlG,EAAauH,GACjB8+B,EAAW4B,2BACX/B,EAAMx5C,SAGFk6C,EAAcpQ,EAAMvuB,YAC1B,GAAI2+B,IACGlkC,GAAmBkkC,EAAa5mC,GACnC,OAAO,KAIX,MAAMy+F,EAAc71G,KAAKu7B,OAAOlc,YAC1Bmb,EAAMx6B,KAAKu7B,OAAOC,WAElBojF,EAAgBxiG,GAASy5F,GACzBwH,EAAMpxG,KAAKuT,MACfgb,EAAI/qB,QAAU2H,EAAW,GAAKy+F,EAAY,IAAM+I,IAElD,GAAIvB,EAAM,GAAKA,GAAO7iF,EAAI/qB,MACxB,OAAO,KAGT,MAAMovG,EAAiBxiG,GAAUw5F,GAC3ByH,EAAMrxG,KAAKuT,MACfgb,EAAI9qB,SAAWmmG,EAAY,GAAKz+F,EAAW,IAAMynG,IAEnD,OAAIvB,EAAM,GAAKA,GAAO9iF,EAAI9qB,OACjB,KAGF1P,KAAKiT,aAAaunB,EAAK6iF,EAAKC,EACpC,CAQD,WAAAh/D,CAAYb,EAAYt9C,GACtB,MAAM2S,EAAQ9S,KAAKu7B,OACbs6E,EAAc/iG,EAAMuM,YACpBoyF,EAAkB3+F,EAAM4oB,iBACvBojF,EAAkBC,GAAoB18G,MAAMC,QAAQmvG,GACvDA,EACA,CAACA,EAAiBA,GAChBz5B,EAAkBllE,EAAM2oB,gBACxB2gB,EAAaqB,EAAWI,iBAAiBJ,EAAWoJ,YACpDzrB,EAAaqiB,EAAWriB,WACxBoe,EAAYiE,EAAWjE,UACvBwlE,EAAaxlE,EAAU98B,OACvB+hG,EAAiBjlE,EAAU78B,WAC3B+mD,EACHtoC,EAAa0jF,GAAqBL,EAAiBzmC,GAChDrU,EACHvoC,EAAa2jF,GAAqBN,EAAiBzmC,GAEhDx+D,EAASikC,EAAWjkC,OACpBmD,EAAa68B,EAAU78B,WACvBC,EAAW48B,EAAU58B,SAErBnN,EAAQxD,KAAKiZ,MAAO9I,GAAS5C,GAAUmD,EAAcye,GACrD1rB,EAASzD,KAAKiZ,MAAO7I,GAAU7C,GAAUmD,EAAcye,GAG7DnM,GACEjvB,KAAKk9G,eACLz/D,EAAW/pC,KAAK,GAAK,EACrB+pC,EAAW/pC,KAAK,GAAK,EACrB,EAAI0nB,EACJ,EAAIA,EACJxe,GACCnN,EAAQ,GACRC,EAAS,GAEZ6I,GAAYvY,KAAK2gD,sBAAuB3gD,KAAKk9G,gBAE7C,MAAM+B,EAAkBC,GAAkBl/G,KAAKk9G,gBAE/Cl9G,KAAKu9G,aAAap9G,EAAQ8+G,EAAiBj/G,KAAKwtC,cAAciQ,IAE9D,MAAMttC,EAAUnQ,KAAKmQ,QACfN,EAASM,EAAQN,OAEnBA,EAAOJ,OAASA,GAASI,EAAOH,QAAUA,GAC5CG,EAAOJ,MAAQA,EACfI,EAAOH,OAASA,GACN1P,KAAKm9G,iBACfhtG,EAAQC,UAAU,EAAG,EAAGX,EAAOC,GAIjC,IAAIyvG,GAAU,EACVriE,GAAS,EACb,GAAIV,EAAW5iC,OAAQ,CACrB,MAAMwkC,EAAc1xB,GAClB8vB,EAAW5iC,OACXggC,EAAUr6B,YAEZ29B,EAASnuB,GAAiBqvB,EAAaP,EAAWjkC,QAClD2lG,EAAUriE,IAAW9iC,GAAegkC,EAAaP,EAAWjkC,QACxD2lG,GACFn/G,KAAK49G,cAAcztG,EAASstC,EAAYO,EAE3C,CAED,MAAMxjB,EAAM1nB,EAAM0oB,WAEZxlB,EAAYiZ,GAChBjvB,KAAKi9G,cACLxtG,EAAQ,EACRC,EAAS,EACTg0D,EACAC,EACA,EACCqU,GAAmB69B,EAAY,GAAKmJ,EAAW,IAAOF,EACtD9mC,GAAmBgnC,EAAW,GAAKnJ,EAAY,IAAOkJ,GAGzD/+G,KAAKysE,mBAAsBsyC,EAAmB3jF,EAAc48C,EAE5D,MAAMonC,EAAK5kF,EAAI/qB,MAAQuG,EAAU,GAC3BqpG,EAAK7kF,EAAI9qB,OAASsG,EAAU,GAOlC,GALKhW,KAAK28G,WAAWz/D,YAAYgoC,mBAC/B/0E,EAAQwtE,uBAAwB,GAGlC39E,KAAKm+G,UAAUhuG,EAASstC,GACpBX,GAAUsiE,GAAM,IAAOC,GAAM,GAAK,CACpC,MAAMvnG,EAAK9B,EAAU,GACf+B,EAAK/B,EAAU,GACf82B,EAAUsP,EAAWtP,QAC3B,IAAIwyE,EACY,IAAZxyE,IACFwyE,EAAgBnvG,EAAQu1C,YACxBv1C,EAAQu1C,YAAc5Y,GAExB38B,EAAQ6C,UAAUwnB,EAAK,EAAG,GAAIA,EAAI/qB,OAAQ+qB,EAAI9qB,OAAQoI,EAAIC,EAAIqnG,EAAIC,GAClD,IAAZvyE,IACF38B,EAAQu1C,YAAc45D,EAEzB,CAYD,OAXAt/G,KAAKo+G,WAAWjuG,EAASstC,GAErB0hE,GACFhvG,EAAQ21C,UAEV31C,EAAQwtE,uBAAwB,EAE5BshC,IAAoBpvG,EAAOU,MAAMyF,YACnCnG,EAAOU,MAAMyF,UAAYipG,GAGpBj/G,KAAKomD,SACb,GCzNH,IAAAm5D,GAhCA,cAAyBC,GAIvB,WAAA1/G,CAAY6K,GACV1F,MAAM0F,EACP,CAED,cAAAi0C,GACE,OAAO,IAAI6gE,GAAyBz/G,KACrC,CAiBD,OAAA6T,CAAQypC,GACN,OAAOr4C,MAAM4O,QAAQypC,EACtB,GCxCYoiE,GACJ,UADIA,GAEe,yBCsJ9B,IAAAC,GAnGA,cAA4BzgD,GAI1B,WAAAp/D,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B,MAAM4xC,EAAc71C,OAAO8C,OAAO,CAAE,EAAEmB,UAE/B4xC,EAAYqjE,eACZrjE,EAAYsjE,uBACnB56G,MAAMs3C,GAKNv8C,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAEL3H,KAAK8/G,gBAA+Bt5G,IAApBmE,EAAQi1G,QAAwBj1G,EAAQi1G,QAAU,GAClE5/G,KAAK+/G,+BACgCv5G,IAAnCmE,EAAQk1G,wBACJl1G,EAAQk1G,uBAGf,CAQD,UAAAG,GACE,OAA8BhgH,KAAKoJ,IAAIs2G,GACxC,CAQD,UAAAI,CAAWF,GACT5/G,KAAK+J,IAAI21G,GAAsBE,EAChC,CAQD,yBAAAK,GACE,OACEjgH,KAAKoJ,IAAIs2G,GAEZ,CAQD,yBAAAK,CAA0BF,GACxB7/G,KAAK+J,IAAI21G,GAAyCG,EACnD,CAkBD,OAAAhsG,CAAQypC,GACN,OAAOr4C,MAAM4O,QAAQypC,EACtB,GCqmBH,IAAA4iE,GA5tBA,cAAsC3B,GAIpC,WAAAz+G,CAAYqgH,GACVl7G,MAAMk7G,GAMNngH,KAAKogH,eAAgB,EAMrBpgH,KAAKqgH,gBAAkB,KAMvBrgH,KAAKsgH,mBAMLtgH,KAAKugH,mBAAqB,KAM1BvgH,KAAK0sE,iBAML1sE,KAAKwgH,cAAgB,GAMrBxgH,KAAKygH,WAAY,EAMjBzgH,KAAK0gH,U9K0GA,CAACjmG,IAAUA,KAAU,KAAW,K8KpGrCza,KAAK2gH,cAAgB,IAAIt1C,GAAU,EAAG,EAAG,EAAG,EAC7C,CAOD,cAAAu1C,CAAe1zG,GACb,MAAMizG,EAAYngH,KAAK28G,WACjBvwB,EAAYl/E,EAAKC,WACjB0yG,EAAyBM,EAAUF,4BACzC,OACE7zB,GAAatgF,GACbsgF,GAAatgF,GACZsgF,GAAatgF,IAAoB+zG,CAErC,CASD,OAAAl2B,CAAQpqD,EAAGloB,EAAGC,EAAGmmC,GACf,MAAMriB,EAAaqiB,EAAWriB,WACxBjc,EAAas+B,EAAWjE,UAAUr6B,WAClCghG,EAAYngH,KAAK28G,WAEvB,IAAIzvG,EADeizG,EAAUjjE,YACPysC,QAAQpqD,EAAGloB,EAAGC,EAAG8jB,EAAYjc,GAUnD,OATIjS,EAAKC,YAAcrB,GACjBq0G,EAAUF,6BAA+BE,EAAUH,aAAe,IAEpEhgH,KAAKygH,WAAY,GAGhBzgH,KAAK4gH,eAAe1zG,KACvBA,EAAOA,EAAKD,kBAEPC,CACR,CAMD,OAAA2G,CAAQypC,GACN,MAAMG,EAAaz9C,KAAKy9C,WACxB,IAAKA,EACH,OAAO,KAGT,MAAM7P,EAAQ5tC,KAAK28G,WACbvlG,EAAauH,GACjB8+B,EAAW4B,2BACX/B,EAAMx5C,SAGFk6C,EAAcpQ,EAAMvuB,YAC1B,GAAI2+B,IACGlkC,GAAmBkkC,EAAa5mC,GACnC,OAAO,KAIX,MAAMgkB,EAAaqiB,EAAWriB,WACxBjc,EAAas+B,EAAWjE,UAAUr6B,WAClCq6B,EAAYiE,EAAWjE,UACvBtvC,EAAS0jC,EAAMuP,kBACft7B,EAAW3X,EAAOw/E,yBAAyBlwC,EAAUr6B,YACrD0pE,EAAiB3+E,EAAO2/E,kBAAkBpsC,EAAWriB,YAE3D,IACE,IAAImE,EAAI1d,EAAS8hE,kBAAkBnqC,EAAU78B,YAC7C4iB,GAAK1d,EAASqsB,eACZ3O,EACF,CACA,MAAMhzB,EAAYsV,EAAS0lE,yBAAyBnwE,EAAYmoB,GAC1DryB,EAAOhD,EAAOy/E,QAClBpqD,EACAhzB,EAAU,GACVA,EAAU,GACV6uB,EACAjc,GAEF,KACIjS,aAAgB0/E,IAAa1/E,aAAgBwgF,KAC9CxgF,aAAgBwgF,IAAcxgF,EAAKC,aAAerB,EAEnD,OAAO,KAGT,GAAIoB,EAAKC,aAAerB,EACtB,SAGF,MAAM+0G,EAAah/F,EAASu2D,UAAU74C,GAChCumD,EAAW9mB,GAAOn9C,EAASoiE,YAAY1kD,IACvCiwB,EAAiB3tC,EAAS6Z,cAAc6D,GAExC89E,EAAMpxG,KAAKuT,MACfqpE,IACIzxE,EAAW,GAAKypG,EAAW,IAAMrxD,EACjCjjD,EAAU,GAAKu5E,EAAS,KAGxBw3B,EAAMrxG,KAAKuT,MACfqpE,IACIg4B,EAAW,GAAKzpG,EAAW,IAAMo4C,EACjCjjD,EAAU,GAAKu5E,EAAS,KAGxBtI,EAASvxE,KAAKiZ,MAClB2jE,EAAiB3+E,EAAOq/E,uBAAuB/vC,EAAUr6B,aAG3D,OAAOnf,KAAKiT,aAAa/F,EAAKsuB,WAAY6hF,EAAM7/B,EAAQ8/B,EAAM9/B,EAC/D,CAED,OAAO,IACR,CAQD,kBAAAi/B,CAAmB7O,EAAOx4D,EAAMloC,GAC9B,QAAIlN,KAAK4gH,eAAe1zG,IACfjI,MAAMw3G,mBAAmB7O,EAAOx4D,EAAMloC,EAGhD,CAOD,YAAAmxC,CAAaZ,GACX,QAASz9C,KAAK28G,WAAWz/D,WAC1B,CAQD,WAAAoB,CAAYb,EAAYt9C,GACtB,MAAMi8C,EAAaqB,EAAWI,iBAAiBJ,EAAWoJ,YACpDrN,EAAYiE,EAAWjE,UACvBr6B,EAAaq6B,EAAUr6B,WACvBs/F,EAAiBjlE,EAAU78B,WAC3BqiG,EAAaxlE,EAAU98B,OACvBE,EAAW48B,EAAU58B,SACrBwe,EAAaqiB,EAAWriB,WAExB+kF,EAAYngH,KAAK28G,WACjBmE,EAAaX,EAAUjjE,YACvB6jE,EAAiBD,EAAW/4G,cAC5B8Z,EAAWi/F,EAAWp3B,yBAAyBvqE,GAC/CogB,EAAI1d,EAAS8hE,kBAAkB86B,EAAgBqC,EAAW53B,YAC1D15B,EAAiB3tC,EAAS6Z,cAAc6D,GAE9C,IAAI/lB,EAASikC,EAAWjkC,OACxB,MAAMmD,EAAa8gC,EAAWjE,UAAU78B,WAClCksE,EAAiBi4B,EAAWj3B,kBAAkBzuD,GAE9C3rB,EAAQxD,KAAKiZ,MAAO9I,GAAS5C,GAAUmD,EAAcye,GACrD1rB,EAASzD,KAAKiZ,MAAO7I,GAAU7C,GAAUmD,EAAcye,GAEvD4iB,EACJ5B,EAAW5iC,QAAU8S,GAAe8vB,EAAW5iC,OAAQ2F,GACrD6+B,IACFxkC,EAASoE,GACPpE,EACA8S,GAAe8vB,EAAW5iC,OAAQ2F,KAItC,MAAMrH,EAAM03C,EAAiB//C,EAAS,EAAIo5E,EACpC9wE,EAAMy3C,EAAiB9/C,EAAU,EAAIm5E,EACrCm4B,EAAe,CACnBhC,EAAW,GAAKlnG,EAChBknG,EAAW,GAAKjnG,EAChBinG,EAAW,GAAKlnG,EAChBknG,EAAW,GAAKjnG,GAGZizD,EAAYnpD,EAASgiE,0BAA0BrqE,EAAQ+lB,GAKvD0hF,EAAiB,CAAA,EACvBA,EAAe1hF,GAAK,GAEpB,MAAM2hF,EAAkBlhH,KAAK08G,uBAC3BoE,EACA3hG,EACA8hG,GAGIP,EAAY1gH,KAAK0gH,UACjBS,EAAenhH,KAAK2gH,cAC1B3gH,KAAKygH,WAAY,EACjB,MAAM94B,EAAW/qE,EACbS,GACEm8B,EAAU98B,OACVC,EACAC,EACA6gC,EAAW/pC,WAEblN,EACJ,IAAK,IAAI6Q,EAAI2zD,EAAU5wD,KAAM/C,GAAK2zD,EAAU1wD,OAAQjD,EAClD,IAAK,IAAIC,EAAI0zD,EAAU3wD,KAAM/C,GAAK0zD,EAAUzwD,OAAQjD,EAAG,CACrD,GACEsF,IACCiF,EAAS6lE,4BAA4B,CAACnoD,EAAGloB,EAAGC,GAAIqwE,GAEjD,SAEF,MAAMz6E,EAAOlN,KAAK2pF,QAAQpqD,EAAGloB,EAAGC,EAAGmmC,GACnC,GAAIz9C,KAAK4gH,eAAe1zG,GAAO,CAC7B,MAAMi/E,EAAMzjF,EAAO1I,MACnB,GAAIkN,EAAKC,YAAcrB,EAAkB,CACvCm1G,EAAe1hF,GAAGryB,EAAKX,UAAUqM,YAAc1L,EAC/C,IAAIU,EAAeV,EAAKU,aAAau+E,GACjCv+E,GAAuC,IAAvBwuC,EAAWtP,UAE7B5/B,EAAKW,cAAcs+E,GACnBv+E,GAAe,GAGd5N,KAAKygH,YACL7yG,GAAiB5N,KAAKwgH,cAAc96G,SAASwH,KAE9ClN,KAAKygH,WAAY,EAEpB,CACD,GAA4C,IAAxCvzG,EAAKK,SAAS4+E,EAAK1uC,EAAWhwC,MAEhC,QAEH,CAED,MAAM2zG,EAAiBv/F,EAAS8kE,2BAC9Bz5E,EAAKX,UACL40G,EACAT,GAGF,IAAIp3B,GAAU,EACV83B,IACF93B,EAAU43B,EAAgB3hF,EAAI,EAAG6hF,IAE9B93B,GACHznE,EAASykE,gCACPp5E,EAAKX,UACL20G,EACAC,EACAT,EAGL,CAGH,MAAMW,EACF7xD,EAAiBivD,EAAkBrjF,EAAcytD,EAGrD55D,GACEjvB,KAAKk9G,eACLz/D,EAAW/pC,KAAK,GAAK,EACrB+pC,EAAW/pC,KAAK,GAAK,EACrB,EAAI0nB,EACJ,EAAIA,EACJxe,GACCnN,EAAQ,GACRC,EAAS,GAGZ,MAAMuvG,EAAkBC,GAAkBl/G,KAAKk9G,gBAE/Cl9G,KAAKu9G,aAAap9G,EAAQ8+G,EAAiBj/G,KAAKwtC,cAAciQ,IAC9D,MAAMttC,EAAUnQ,KAAKmQ,QACfN,EAASM,EAAQN,OAEvB0I,GAAYvY,KAAK2gD,sBAAuB3gD,KAAKk9G,gBAG7CjuF,GACEjvB,KAAKi9G,cACLxtG,EAAQ,EACRC,EAAS,EACT2xG,EACAA,EACA,GACC5xG,EAAQ,GACRC,EAAS,GAGRG,EAAOJ,OAASA,GAASI,EAAOH,QAAUA,GAC5CG,EAAOJ,MAAQA,EACfI,EAAOH,OAASA,GACN1P,KAAKm9G,iBACfhtG,EAAQC,UAAU,EAAG,EAAGX,EAAOC,GAG7BsuC,GACFh+C,KAAK49G,cAAcztG,EAASstC,EAAYO,GAGrC8iE,EAAW57B,mBACd/0E,EAAQwtE,uBAAwB,GAGlC39E,KAAKm+G,UAAUhuG,EAASstC,GAExBz9C,KAAKwgH,cAAcr/G,OAAS,EAE5B,IAGImgH,EAAOC,EAAQC,EAHfC,EAAK/6G,OAAOC,KAAKs6G,GAAgBn2E,IAAIX,QACzCs3E,EAAGntF,KAAKtzB,GAIiB,IAAvBo7C,EAAWtP,SACT9sC,KAAKm9G,kBACL2D,EAAWr3B,UAAUhsC,EAAWjE,UAAUr6B,aAI5CmiG,EAAQ,GACRC,EAAS,IAHTE,EAAKA,EAAGjY,UAKV,IAAK,IAAI5nG,EAAI6/G,EAAGtgH,OAAS,EAAGS,GAAK,IAAKA,EAAG,CACvC,MAAM8/G,EAAWD,EAAG7/G,GACd+/G,EAAuBb,EAAWh3B,iBACtC43B,EACAtmF,EACAjc,GAGIyiG,EADoB//F,EAAS6Z,cAAcgmF,GACRlyD,EACnC13C,EAAK6pG,EAAqB,GAAKC,EAAeP,EAC9CtpG,EAAK4pG,EAAqB,GAAKC,EAAeP,EAC9CQ,EAAkBhgG,EAAS0lE,yBAC/BtrE,GAAW+kG,GACXU,GAEII,EAAmBjgG,EAASuhE,mBAAmBy+B,GAC/Cp8B,EAAS9mE,GAAe3e,KAAKi9G,cAAe,CAC/Cp0B,GAAkBi5B,EAAiB,GAAKd,EAAa,IACpDxxD,EACDq5B,GAAkBm4B,EAAa,GAAKc,EAAiB,IACpDtyD,IAEEuyD,EACJl5B,EAAiBi4B,EAAWv3B,uBAAuBpqE,GAC/C6iG,EAAcf,EAAeS,GACnC,IAAK,MAAMr4B,KAAgB24B,EAAa,CACtC,MAAM90G,EACJ80G,EAAY34B,GAER98E,EAAYW,EAAKX,UAGjB01G,EAASJ,EAAgB,GAAKt1G,EAAU,GACxC21G,EAAQj2G,KAAKiZ,MAAMugE,EAAO,IAAMw8B,EAAS,GAAKnqG,GAC9CqqG,EAASN,EAAgB,GAAKt1G,EAAU,GACxC61G,EAAQn2G,KAAKiZ,MAAMugE,EAAO,IAAM08B,EAAS,GAAKpqG,GAC9CV,EAAIpL,KAAKiZ,MAAMugE,EAAO,GAAKw8B,EAASnqG,GACpCR,EAAIrL,KAAKiZ,MAAMugE,EAAO,GAAK08B,EAASpqG,GACpCigC,EAAIkqE,EAAQ7qG,EACZkpB,EAAI6hF,EAAQ9qG,EACZ3K,EAAa4yB,IAAMmiF,EAEnB9zG,EACJjB,GAA+D,IAAjDO,EAAKK,SAAS7E,EAAO1I,MAAOy9C,EAAWhwC,MACvD,IAAI40G,GAAe,EACnB,IAAKz0G,EACH,GAAI0zG,EAAO,CAETE,EAAc,CAACnqG,EAAGC,EAAGD,EAAI2gC,EAAG1gC,EAAGD,EAAI2gC,EAAG1gC,EAAIipB,EAAGlpB,EAAGC,EAAIipB,GACpD,IAAK,IAAI3+B,EAAI,EAAGuE,EAAKm7G,EAAMngH,OAAQS,EAAIuE,IAAMvE,EAC3C,GAAI29B,IAAMmiF,GAAYA,EAAWH,EAAO3/G,GAAI,CAC1C,MAAMk7E,EAAOwkC,EAAM1/G,GAEjBkc,GACE,CAACzG,EAAGC,EAAGD,EAAI2gC,EAAG1gC,EAAIipB,GAClB,CAACu8C,EAAK,GAAIA,EAAK,GAAIA,EAAK,GAAIA,EAAK,OAG9BulC,IACHlyG,EAAQs1C,OACR48D,GAAe,GAEjBlyG,EAAQ4kE,YAER5kE,EAAQwkE,OAAO6sC,EAAY,GAAIA,EAAY,IAC3CrxG,EAAQykE,OAAO4sC,EAAY,GAAIA,EAAY,IAC3CrxG,EAAQykE,OAAO4sC,EAAY,GAAIA,EAAY,IAC3CrxG,EAAQykE,OAAO4sC,EAAY,GAAIA,EAAY,IAE3CrxG,EAAQwkE,OAAOmI,EAAK,GAAIA,EAAK,IAC7B3sE,EAAQykE,OAAOkI,EAAK,GAAIA,EAAK,IAC7B3sE,EAAQykE,OAAOkI,EAAK,GAAIA,EAAK,IAC7B3sE,EAAQykE,OAAOkI,EAAK,GAAIA,EAAK,IAC7B3sE,EAAQ2sE,OAEX,CAEHwkC,EAAM37G,KAAK67G,GACXD,EAAO57G,KAAK+7G,EACxB,MACYvxG,EAAQC,UAAUiH,EAAGC,EAAG0gC,EAAGzX,GAG/BvgC,KAAKsiH,cACHp1G,EACAuwC,EACApmC,EACAC,EACA0gC,EACAzX,EACAwhF,EACAp1G,GAEE20G,IAAU1zG,GACRy0G,GACFlyG,EAAQ21C,UAEV9lD,KAAKwgH,cAAc9W,QAAQx8F,IAE3BlN,KAAKwgH,cAAc76G,KAAKuH,GAE1BlN,KAAKuiH,gBAAgB9kE,EAAW0oB,UAAW26C,EAAY5zG,EACxD,CACF,CAiCD,OA/BAlN,KAAK0sE,iBAAmBq0C,EACxB/gH,KAAKysE,mBAAqBjd,EAC1BxvD,KAAKogH,eACFpgH,KAAKqgH,kBAAoB99G,GAAOvC,KAAKqgH,gBAAiBW,GACzDhhH,KAAKqgH,gBAAkBW,EACvBhhH,KAAKsgH,mBAAqBllF,EAC1Bp7B,KAAKugH,mBAAqBphG,EAE1Bnf,KAAKwiH,kBACH/kE,EACAqjE,EACAj/F,EACAuZ,EACAjc,EACA3F,EACA+lB,EACA4gF,EAAUH,cAEZhgH,KAAKyiH,oBAAoBhlE,EAAYqjE,GAErC9gH,KAAKo+G,WAAWjuG,EAASstC,GAErBrB,EAAW5iC,QACbrJ,EAAQ21C,UAEV31C,EAAQwtE,uBAAwB,EAE5BshC,IAAoBpvG,EAAOU,MAAMyF,YACnCnG,EAAOU,MAAMyF,UAAYipG,GAGpBj/G,KAAKomD,SACb,CAYD,aAAAk8D,CAAcp1G,EAAMuwC,EAAYpmC,EAAGC,EAAG0gC,EAAGzX,EAAGi9C,EAAQ7wE,GAClD,MAAMmG,EAAQ9S,KAAK0iH,aAAax1G,GAChC,IAAK4F,EACH,OAEF,MAAMq5E,EAAMzjF,EAAO1I,MACbo8C,EAAaqB,EAAWI,iBAAiBJ,EAAWoJ,YACpDrc,EACJ4R,EAAWtP,SACVngC,EAAaO,EAAKK,SAAS4+E,EAAK1uC,EAAWhwC,MAAQ,GAChDk1G,EAAen4E,IAAUxqC,KAAKmQ,QAAQu1C,YACxCi9D,IACF3iH,KAAKmQ,QAAQs1C,OACbzlD,KAAKmQ,QAAQu1C,YAAclb,GAE7BxqC,KAAKmQ,QAAQ6C,UACXF,EACA0qE,EACAA,EACA1qE,EAAMrD,MAAQ,EAAI+tE,EAClB1qE,EAAMpD,OAAS,EAAI8tE,EACnBnmE,EACAC,EACA0gC,EACAzX,GAGEoiF,GACF3iH,KAAKmQ,QAAQ21C,UAEXtb,IAAU4R,EAAWtP,QACvB2Q,EAAW1H,SAAU,EACZppC,GACTO,EAAKW,cAAcs+E,EAEtB,CAKD,QAAA3wD,GACE,MAAMrrB,EAAUnQ,KAAKmQ,QACrB,OAAOA,EAAUA,EAAQN,OAAS,IACnC,CAQD,YAAA6yG,CAAax1G,GACX,OAAOA,EAAKsuB,UACb,CAOD,mBAAAinF,CAAoBhlE,EAAYqjE,GAC9B,GAAIA,EAAW30E,iBAAkB,CAM/B,MAAMy2E,EAAqB,SAAU9B,EAAYh2E,EAAK2S,GACpD,MAAM6R,EAAgB5mD,EAAOo4G,GACzBxxD,KAAiB7R,EAAW0oB,WAC9B26C,EAAWl3C,YACTnsB,EAAWjE,UAAUr6B,WACrBs+B,EAAW0oB,UAAU7W,GAGjC,EAAQpoD,KAAK,KAAM45G,GAEbrjE,EAAWgD,oBAAoB96C,KACrC,EAIK,CACF,CAQD,eAAA48G,CAAgBp8C,EAAW26C,EAAY5zG,GAErC,MAAMoiD,EAAgB5mD,EAAOo4G,GACvBxxD,KAAiB6W,IACrBA,EAAU7W,GAAiB,IAE7B6W,EAAU7W,GAAepiD,EAAKF,WAAY,CAC3C,CAoBD,iBAAAw1G,CACE/kE,EACAqjE,EACAj/F,EACAuZ,EACAjc,EACA3F,EACAkoG,EACA9B,EACAiD,GAEA,MAAMvzD,EAAgB5mD,EAAOo4G,GACvBxxD,KAAiB7R,EAAWgS,cAChChS,EAAWgS,YAAYH,GAAiB,IAE1C,MAAMG,EAAchS,EAAWgS,YAAYH,GACrCuV,EAAYpnB,EAAWonB,UACvB13B,EAAUtrB,EAASqsB,aACnBtxB,EAAW6gC,EAAWjE,UAAU58B,SAChC+qE,EAAW/qE,EACbS,GACEogC,EAAWjE,UAAU98B,OACrB+gC,EAAWjE,UAAU78B,WACrBC,EACA6gC,EAAW/pC,WAEblN,EACJ,IACI0G,EAAM89D,EAAWxb,EAAgBn4C,EAAGC,EAAGioB,EADvC2qD,EAAY,EAEhB,IAAK3qD,EAAI4N,EAAS5N,GAAKmiF,IAAYniF,EAGjC,IAFAyrC,EAAYnpD,EAASgiE,0BAA0BrqE,EAAQ+lB,EAAGyrC,GAC1Dxb,EAAiB3tC,EAAS6Z,cAAc6D,GACnCloB,EAAI2zD,EAAU5wD,KAAM/C,GAAK2zD,EAAU1wD,OAAQjD,EAC9C,IAAKC,EAAI0zD,EAAU3wD,KAAM/C,GAAK0zD,EAAUzwD,OAAQjD,EAE5CsF,IACCiF,EAAS6lE,4BAA4B,CAACnoD,EAAGloB,EAAGC,GAAIqwE,KAI/C+5B,EAAWniF,GAAKqgF,KAChB11B,EACFh9E,EAAO4zG,EAAWn3B,QAAQpqD,EAAGloB,EAAGC,EAAG8jB,EAAYjc,GAC3CjS,EAAKC,YAAcrB,IACrB2jD,EAAYviD,EAAKF,WAAY,EACxB63D,EAAUjX,YAAY1gD,EAAKF,WAC9B63D,EAAUzX,QAAQ,CAChBlgD,EACAoiD,EACAztC,EAASolE,mBAAmB/5E,EAAKX,WACjCijD,UAIehpD,IAAjBq8G,GACFA,EAAa31G,IAGf4zG,EAAW32B,QAAQ5qD,EAAGloB,EAAGC,EAAG6H,IAKpC2hG,EAAW72B,gBAAgBC,EAAW/qE,EACvC,GC/tBH,IAAA2jG,GAbA,cAAwBC,GAItB,WAAAjjH,CAAY6K,GACV1F,MAAM0F,EACP,CAED,cAAAi0C,GACE,OAAO,IAAIokE,GAAwBhjH,KACpC,GCVH,IAQImQ,GARA8yG,IAAe,EACnB,IACE,IAAIC,UAAU,GAAI,GACpB,CAAE,MAAOp3E,GACPm3E,IAAe,CACjB,CAWO,SAASE,GAAahhH,EAAMsN,EAAOC,GACxC,GAAIuzG,GACF,OAAO,IAAIC,UAAU/gH,EAAMsN,EAAOC,GAG/BS,KACHA,GAAUJ,SAASC,cAAc,UAAUC,WAAW,OAExD,MAAM2D,EAAYzD,GAAQ4yF,gBAAgBtzF,EAAOC,GAEjD,OADAkE,EAAUzR,KAAK4H,IAAI5H,GACZyR,CACT,CAoBA,SAASwvG,GAAaC,GACpB,IAAIC,GAAqB,EACzB,IACE,IAAIJ,UAAU,GAAI,GACnB,CAAC,MAAOp3E,GACPw3E,GAAqB,CACtB,CAED,SAASC,EAAmBphH,EAAMsN,EAAOC,GACvC,OAAI4zG,EACK,IAAIJ,UAAU/gH,EAAMsN,EAAOC,GAE7B,CAACvN,KAAMA,EAAMsN,MAAOA,EAAOC,OAAQA,EAC3C,CAED,OAAO,SAAUvN,GAEf,MAAMqhH,EAAUrhH,EAAc,QACxBshH,EAAOthH,EAAW,KAClBuhH,EAAWvhH,EAAe,SAC1BsN,EAAQtN,EAAY,MACpBuN,EAASvN,EAAa,OAEtBwhH,EAAaH,EAAQriH,OACrByiH,EAAWJ,EAAQ,GAAGzhB,WAE5B,GAAI2hB,EAAU,CACZ,MAAMvb,EAAS,IAAI9lG,MAAMshH,GACzB,IAAK,IAAIriH,EAAI,EAAGA,EAAIqiH,IAAcriH,EAChC6mG,EAAO7mG,GAAKiiH,EACV,IAAI9wG,kBAAkB+wG,EAAQliH,IAC9BmO,EACAC,GAIJ,OADe2zG,EAAUlb,EAAQsb,GAAMthH,KACzBwX,MACf,CAED,MAAMsJ,EAAS,IAAIxQ,kBAAkBmxG,GAC/BC,EAAS,IAAIxhH,MAAMshH,GACnBG,EAAS,IAAIzhH,MAAMshH,GACzB,IAAK,IAAIriH,EAAI,EAAGA,EAAIqiH,IAAcriH,EAChCuiH,EAAOviH,GAAK,IAAImR,kBAAkB+wG,EAAQliH,IAC1CwiH,EAAOxiH,GAAK,CAAC,EAAG,EAAG,EAAG,GAExB,IAAK,IAAIM,EAAI,EAAGA,EAAIgiH,EAAUhiH,GAAK,EAAG,CACpC,IAAK,IAAI0iB,EAAI,EAAGA,EAAIq/F,IAAcr/F,EAAG,CACnC,MAAM5Z,EAAQm5G,EAAOv/F,GACrBw/F,EAAOx/F,GAAG,GAAK5Z,EAAM9I,GACrBkiH,EAAOx/F,GAAG,GAAK5Z,EAAM9I,EAAI,GACzBkiH,EAAOx/F,GAAG,GAAK5Z,EAAM9I,EAAI,GACzBkiH,EAAOx/F,GAAG,GAAK5Z,EAAM9I,EAAI,EAC1B,CACD,MAAM07C,EAAQ+lE,EAAUS,EAAQL,GAChCxgG,EAAOrhB,GAAK07C,EAAM,GAClBr6B,EAAOrhB,EAAI,GAAK07C,EAAM,GACtBr6B,EAAOrhB,EAAI,GAAK07C,EAAM,GACtBr6B,EAAOrhB,EAAI,GAAK07C,EAAM,EACvB,CACD,OAAOr6B,EAAOtJ,MAClB,CACA,CAQA,SAASoqG,GAAa9yB,EAAQ+yB,GAC5B,MAIMC,EAJMv9G,OAAOC,KAAKsqF,EAAOizB,KAAO,IAAIp5E,KAAI,SAAUp1B,GACtD,MAAO,SAAWA,EAAO,MAAQu7E,EAAOizB,IAAIxuG,GAAMkD,WAAa,GACnE,IAEoBm+E,OAAO,CACvB,uBAAyBqsB,GAAaxqG,WAAa,KACnDq4E,EAAOoyB,UAAUzqG,WACjB,KACA,qDACA,2CACA,yEACA,QAGIurG,EAAS,IAAIC,OACD,oBAATC,KACH,+BACAC,OAAO5yD,KAAKuyD,EAAMnrG,KAAK,MAAO,UAAUF,SAAS,UACjDm3D,IAAIw0C,gBAAgB,IAAIF,KAAKJ,EAAO,CAAClkH,KAAM,sBAGjD,OADAokH,EAAO7+G,iBAAiB,UAAW0+G,GAC5BG,CACT,CAuDO,MAAMK,WAAkBx/G,EAI7B,WAAAlF,CAAYmxF,GAIV,IAAIwzB,EAHJx/G,QAEAjF,KAAK0kH,YAAczzB,EAAOyyB,SAGxBe,EADqB,IAAnBxzB,EAAOwzB,QACC,EACDzkH,KAAK0kH,UACJ,EAEAzzB,EAAOwzB,SAAW,EAM9B,MAAME,EAAU,IAAItiH,MAAMoiH,GAC1B,GAAIA,EACF,IAAK,IAAI7iH,EAAI,EAAGA,EAAI6iH,IAAW7iH,EAC7B+iH,EAAQ/iH,GAAKmiH,GAAa9yB,EAAQjxF,KAAK4kH,iBAAiB19G,KAAKlH,KAAM4B,SAGrE+iH,EAAQ,GApEd,SAA0B1zB,EAAQ+yB,GAChC,MAAMa,EAASzB,GAAanyB,EAAOoyB,WACnC,IAAIyB,GAAa,EACjB,MAAO,CACLC,YAAa,SAAU5iH,GACrBsvC,YAAW,WACLqzE,GAGJd,EAAU,CAAC7hH,KAAM,CAACwX,OAAQkrG,EAAO1iH,GAAOshH,KAAMthH,EAAW,OAC1D,GAAE,EACJ,EACD6iH,UAAW,WACTF,GAAa,CACd,EAEL,CAoDmBG,CACXh0B,EACAjxF,KAAK4kH,iBAAiB19G,KAAKlH,KAAM,IAGrCA,KAAKklH,SAAWP,EAMhB3kH,KAAKmlH,OAAS,GAEdnlH,KAAKolH,gBAAkBn0B,EAAOo0B,OAAS5qG,IACvCza,KAAKslH,SAAW,EAMhBtlH,KAAKulH,YAAc,GAMnBvlH,KAAKwlH,KAAO,IACb,CAWD,OAAAC,CAAQC,EAAQjC,EAAM7nG,GACpB5b,KAAK2lH,SAAS,CACZD,OAAQA,EACRjC,KAAMA,EACN7nG,SAAUA,IAEZ5b,KAAK4lH,WACN,CAMD,QAAAD,CAASE,GAEP,IADA7lH,KAAKmlH,OAAOx/G,KAAKkgH,GACV7lH,KAAKmlH,OAAOhkH,OAASnB,KAAKolH,iBAC/BplH,KAAKmlH,OAAOr1G,QAAQ8L,SAAS,KAAM,KAEtC,CAKD,SAAAgqG,GACE,GAAI5lH,KAAKslH,UAAmC,IAAvBtlH,KAAKmlH,OAAOhkH,OAC/B,OAGF,MAAM0kH,EAAM7lH,KAAKmlH,OAAOr1G,QACxB9P,KAAKwlH,KAAOK,EACZ,MAAMp2G,EAAQo2G,EAAIH,OAAO,GAAGj2G,MACtBC,EAASm2G,EAAIH,OAAO,GAAGh2G,OACvB8zG,EAAUqC,EAAIH,OAAO56E,KAAI,SAAU9nB,GACvC,OAAOA,EAAM7gB,KAAKwX,MACxB,IACU8qG,EAAUzkH,KAAKklH,SAAS/jH,OAE9B,GADAnB,KAAKslH,SAAWb,EACA,IAAZA,EAWF,YAVAzkH,KAAKklH,SAAS,GAAGH,YACf,CACEvB,QAASA,EACTC,KAAMoC,EAAIpC,KACVC,SAAU1jH,KAAK0kH,UACfj1G,MAAOA,EACPC,OAAQA,GAEV8zG,GAKJ,MAAMriH,EAAS0kH,EAAIH,OAAO,GAAGvjH,KAAKhB,OAC5BozB,EAAgB,EAAItoB,KAAKkZ,KAAKhkB,EAAS,EAAIsjH,GACjD,IAAK,IAAI7iH,EAAI,EAAGA,EAAI6iH,IAAW7iH,EAAG,CAChC,MAAMmZ,EAASnZ,EAAI2yB,EACbuxF,EAAS,GACf,IAAK,IAAIxhG,EAAI,EAAG2G,EAAKu4F,EAAQriH,OAAQmjB,EAAI2G,IAAM3G,EAC7CwhG,EAAOngH,KAAK69G,EAAQl/F,GAAGxgB,MAAMiX,EAAQA,EAASwZ,IAEhDv0B,KAAKklH,SAAStjH,GAAGmjH,YACf,CACEvB,QAASsC,EACTrC,KAAMoC,EAAIpC,KACVC,SAAU1jH,KAAK0kH,UACfj1G,MAAOA,EACPC,OAAQA,GAEVo2G,EAEH,CACF,CAOD,gBAAAlB,CAAiB3hH,EAAO4C,GAClB7F,KAAKO,WAGTP,KAAKulH,YAAYtiH,GAAS4C,EAAM1D,OAC9BnC,KAAKslH,SACe,IAAlBtlH,KAAKslH,UACPtlH,KAAK+lH,cAER,CAMD,WAAAA,GACE,MAAMF,EAAM7lH,KAAKwlH,KACXf,EAAUzkH,KAAKklH,SAAS/jH,OAC9B,IAAIgB,EAAMshH,EACV,GAAgB,IAAZgB,EACFtiH,EAAO,IAAIsQ,kBAAkBzS,KAAKulH,YAAY,GAAW,QACzD9B,EAAOzjH,KAAKulH,YAAY,GAAS,SAC5B,CACL,MAAMpkH,EAAS0kH,EAAIH,OAAO,GAAGvjH,KAAKhB,OAClCgB,EAAO,IAAIsQ,kBAAkBtR,GAC7BsiH,EAAO,IAAIphH,MAAMoiH,GACjB,MAAMlwF,EAAgB,EAAItoB,KAAKkZ,KAAKhkB,EAAS,EAAIsjH,GACjD,IAAK,IAAI7iH,EAAI,EAAGA,EAAI6iH,IAAW7iH,EAAG,CAChC,MAAM+X,EAAS3Z,KAAKulH,YAAY3jH,GAAW,OACrCmZ,EAASnZ,EAAI2yB,EACnBpyB,EAAK4H,IAAI,IAAI0I,kBAAkBkH,GAASoB,GACxC0oG,EAAK7hH,GAAK5B,KAAKulH,YAAY3jH,GAAS,IACrC,CACF,CACD5B,KAAKwlH,KAAO,KACZxlH,KAAKulH,YAAc,GACnBM,EAAIjqG,SACF,KACAunG,GAAahhH,EAAM0jH,EAAIH,OAAO,GAAGj2G,MAAOo2G,EAAIH,OAAO,GAAGh2G,QACtD+zG,GAEFzjH,KAAK4lH,WACN,CAKD,eAAAnlH,GACE,IAAK,IAAImB,EAAI,EAAGA,EAAI5B,KAAKklH,SAAS/jH,SAAUS,EAC1C5B,KAAKklH,SAAStjH,GAAGojH,YAEnBhlH,KAAKklH,SAAS/jH,OAAS,CACxB,EAyBH,MAAM6kH,GAOc,mBAPdA,GAgBa,kBAiBZ,MAAMC,WAA0BlgH,EAOrC,WAAAjG,CAAYC,EAAM09C,EAAYt7C,GAC5B8C,MAAMlF,GAONC,KAAKwZ,OAASikC,EAAWjkC,OAOzBxZ,KAAK2c,WAAa8gC,EAAWjE,UAAU78B,WAAa8gC,EAAWriB,WAQ/Dp7B,KAAKmC,KAAOA,CACb,EA6CH,MAAM+jH,WAAqB9S,GAIzB,WAAAtzG,CAAY6K,GACV1F,MAAM,CACJka,WAAY,OAMdnf,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAML3H,KAAKmmH,WAAa,KAMlBnmH,KAAKomH,oBACuB5/G,IAA1BmE,EAAQ07G,cAA8B17G,EAAQ07G,cAAgB,QAMhErmH,KAAKsmH,cAA+B9/G,IAApBmE,EAAQ85G,QAAwB95G,EAAQ85G,QAAU,EAMlEzkH,KAAKumH,QA0ZT,SAAsBhpC,GACpB,MAAMt1E,EAAMs1E,EAAQp8E,OACd4lD,EAAS,IAAI1kD,MAAM4F,GACzB,IAAK,IAAIrG,EAAI,EAAGA,EAAIqG,IAAOrG,EACzBmlD,EAAOnlD,GAAK4kH,GAAYjpC,EAAQ37E,IAElC,OAAOmlD,CACT,CAjamB0/D,CAAa97G,EAAQ4yE,SAEpC,MAAM11E,EAAU7H,KAAK6H,QAAQX,KAAKlH,MAClC,IAAK,IAAI4B,EAAI,EAAGuE,EAAKnG,KAAKumH,QAAQplH,OAAQS,EAAIuE,IAAMvE,EAClD5B,KAAKumH,QAAQ3kH,GAAG0D,iBAAiBwC,EAAkBD,GA2YzD,IAA6Bk/C,EAvYzB/mD,KAAK0mH,gBAA0C,OAAxB/7G,EAAQgmC,YAM/B3wC,KAAK2hE,WAAa,IAAIC,IAAU,WAC9B,OAAO,CACR,GAAE5hE,KAAK2mH,gBAAgBz/G,KAAKlH,OAO7BA,KAAK4mH,qBAOL5mH,KAAK6mH,qBAAuB,KAM5B7mH,KAAKyzG,kBAMLzzG,KAAKsgE,YAAc,CACjBvqB,SAAS,EACTqJ,2BlLnlBG,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GkLolBnB8mB,cAAe,KACf1sD,OAAQ,KACRvW,MAAO,EACP4jD,WAAY,EACZhJ,kBA8VuBkJ,EA9Ve/mD,KAAKumH,QA+VxCx/D,EAAOjc,KAAI,SAAU8C,GAC1B,OAAOA,EAAMF,eACjB,KAhWMtS,WAAY,EACZikB,2BlL1lBG,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GkL2lBnBoB,oBAAqB,GACrB/sC,KAAM,CAAC,EAAG,GACVmxD,UAAW7kE,KAAK2hE,WAChBl0D,KAAMswB,KAAKC,MACXmoC,UAAW,CAAE,EACb3sB,UAAsD,CACpD58B,SAAU,GAEZkoD,UAAW,GACXrV,YAAa,CAAE,EACf2W,MAAO19D,EAAO1I,MACdqmE,cAAe,CAAE,GAGnBrmE,KAAKolF,iBAAgB,SAAU3nC,GAC7B,MAAMS,EAAe,GACrB,IACE,IAAIj7C,EAAQ,EAAG6jH,EAAOn8G,EAAQ4yE,QAAQp8E,OACtC8B,EAAQ6jH,IACN7jH,EACF,CACA,MAAM8jH,EAAgBp8G,EAAQ4yE,QAAQt6E,GAChCiH,EACJ68G,aAAyBt+B,GACrBs+B,EACAA,EAAc7pE,YACpB,IAAKhzC,EACH,SAEF,MAAM88G,EAAoB98G,EAAO+zC,kBACjC,GAAiC,mBAAtB+oE,EAAkC,CAC3C,MAAMC,EAAoBD,EAAkBvpE,GAC5CS,EAAav4C,KAAKzB,MAAMg6C,EAAc+oE,EACvC,CACF,CACD,OAA+B,IAAxB/oE,EAAa/8C,OAAe+8C,EAAe,IACxD,SAE8B13C,IAAtBmE,EAAQ04G,WACVrjH,KAAKknH,aAAav8G,EAAQ04G,UAAW14G,EAAQu5G,IAEhD,CASD,YAAAgD,CAAa7D,EAAWa,GAClBlkH,KAAKmmH,YACPnmH,KAAKmmH,WAAW3lH,UAGlBR,KAAKmmH,WAAa,IAAI3B,GAAU,CAC9BnB,UAAWA,EACXK,SAAkC,UAAxB1jH,KAAKomH,eACff,MAAO,EACPnB,IAAKA,EACLO,QAASzkH,KAAKsmH,WAEhBtmH,KAAK6H,SACN,CAUD,iBAAAs/G,CAAkB3tG,EAAQmD,EAAYwC,GACpC,MAAMs+B,EACJ/2C,OAAO8C,OAAO,GAAIxJ,KAAKsgE,aAGzB7iB,EAAWjE,UACT9yC,OAAO8C,OAAO,GAAIi0C,EAAWjE,WAG/B,MAAM98B,EAASJ,GAAU9C,GAEzBikC,EAAW/pC,KAAK,GAAKzH,KAAKkZ,KAAK/I,GAAS5C,GAAUmD,GAClD8gC,EAAW/pC,KAAK,GAAKzH,KAAKkZ,KAAK9I,GAAU7C,GAAUmD,GACnD8gC,EAAWjkC,OAAS,CAClBkD,EAAO,GAAM+gC,EAAW/pC,KAAK,GAAKiJ,EAAc,EAChDD,EAAO,GAAM+gC,EAAW/pC,KAAK,GAAKiJ,EAAc,EAChDD,EAAO,GAAM+gC,EAAW/pC,KAAK,GAAKiJ,EAAc,EAChDD,EAAO,GAAM+gC,EAAW/pC,KAAK,GAAKiJ,EAAc,GAElD8gC,EAAWhwC,KAAOswB,KAAKC,MAEvB,MAAMwb,EAAYiE,EAAWjE,UAI7B,OAHAA,EAAU98B,OAASA,EACnB88B,EAAUr6B,WAAaA,EACvBq6B,EAAU78B,WAAaA,EAChB8gC,CACR,CAOD,gBAAA2pE,GACE,IACIl9G,EADAi6D,GAAQ,EAEZ,IAAK,IAAIviE,EAAI,EAAGuE,EAAKnG,KAAKumH,QAAQplH,OAAQS,EAAIuE,IAAMvE,EAElD,GADAsI,EAASlK,KAAKumH,QAAQ3kH,GAAGs7C,aACpBhzC,GAAgC,UAAtBA,EAAOiD,WAAwB,CAC5Cg3D,GAAQ,EACR,KACD,CAEH,OAAOA,CACR,CASD,QAAA3oC,CAAShiB,EAAQmD,EAAYye,EAAYjc,GACvC,IAAKnf,KAAKonH,mBACR,OAAO,KAGTpnH,KAAK2hE,WAAW1S,cAAc,GAAI,IAElCtyC,EAAa3c,KAAKkyG,sBAAsBv1F,GACxC,MAAM8gC,EAAaz9C,KAAKmnH,kBAAkB3tG,EAAQmD,EAAYwC,GAI9D,GAHAnf,KAAK4mH,qBAAuBnpE,EAGxBz9C,KAAK6mH,qBAAsB,CAC7B,MAAMp6C,EAAqBzsE,KAAK6mH,qBAAqBnrF,gBAC/CijF,EAAiB3+G,KAAK6mH,qBAAqBxnG,YAE/C1C,IAAe8vD,GACdlqE,GAAOk7C,EAAWjkC,OAAQmlG,KAE3B3+G,KAAK6mH,qBAAuB,KAE/B,CAaD,OAVG7mH,KAAK6mH,sBACN7mH,KAAK+H,gBAAkB/H,KAAKyzG,mBAE5BzzG,KAAK2mH,kBAGHlpE,EAAW1H,SACb4B,sBAAsB33C,KAAK6H,QAAQX,KAAKlH,OAGnCA,KAAK6mH,oBACb,CAMD,eAAAF,GACE,MAAMlpE,EAAaz9C,KAAK4mH,qBAClB3+G,EAAMjI,KAAKumH,QAAQplH,OACnBkmH,EAAa,IAAIhlH,MAAM4F,GAC7B,IAAK,IAAIrG,EAAI,EAAGA,EAAIqG,IAAOrG,EAAG,CAC5B67C,EAAWoJ,WAAajlD,EACxB67C,EAAW4oB,cAAgB,GAC3B,MAAMzyD,EAAYX,GAAajT,KAAKumH,QAAQ3kH,GAAI67C,GAChD,IAAI7pC,EAGF,OAFAyzG,EAAWzlH,GAAKgS,CAInB,CAED,MAAMzR,EAAO,CAAA,EACbnC,KAAK4F,cACH,IAAIqgH,GAAkBD,GAAkCvoE,EAAYt7C,IAEtEnC,KAAKmmH,WAAWV,QACd4B,EACAllH,EACAnC,KAAKsnH,kBAAkBpgH,KAAKlH,KAAMy9C,GAErC,CAUD,iBAAA6pE,CAAkB7pE,EAAYn5C,EAAK2e,EAAQ9gB,GACzC,GAAImC,IAAQ2e,EACV,OAIF,MAAMzJ,EAASikC,EAAWjkC,OACpBmD,EAAa8gC,EAAWjE,UAAU78B,WACxC,GACEA,IAAe3c,KAAK4mH,qBAAqBptE,UAAU78B,aAClDpa,GAAOiX,EAAQxZ,KAAK4mH,qBAAqBptG,QAE1C,OAGF,IAAIrJ,EACJ,GAAInQ,KAAK6mH,qBACP12G,EAAUnQ,KAAK6mH,qBAAqBrrF,WAAWvrB,WAAW,UACrD,CAGLE,EAAUX,GAFIvD,KAAKiZ,MAAM9I,GAAS5C,GAAUmD,GAC7B1Q,KAAKiZ,MAAM7I,GAAU7C,GAAUmD,IAE9C3c,KAAK6mH,qBAAuB,IAAIzS,GAC9B56F,EACAmD,EACA,EACAxM,EAAQN,OAEX,CACDM,EAAQ6yF,aAAa//E,EAAQ,EAAG,GAE5Bw6B,EAAW1H,QACb4B,sBAAsB33C,KAAK6H,QAAQX,KAAKlH,OAExCA,KAAK6H,UAEP7H,KAAKyzG,kBAAoBzzG,KAAK+H,cAE9B/H,KAAK4F,cACH,IAAIqgH,GAAkBD,GAAiCvoE,EAAYt7C,GAEtE,CAMD,cAAAy2C,CAAez5B,GACb,IAAKnf,KAAK0mH,gBACR,OAAO,KAET,IAAI/1E,EAAc1rC,MAAM2zC,iBACxB,IAAKjI,EACH,IAAK,IAAI/uC,EAAI,EAAGuE,EAAKnG,KAAKumH,QAAQplH,OAAQS,EAAIuE,IAAMvE,EAAG,CAGrD,GADA+uC,EADe3wC,KAAKumH,QAAQ3kH,GAAGs7C,YACVtE,eAAez5B,GAChCwxB,EACF,KAEH,CAEH,OAAOA,CACR,CAED,eAAAlwC,GACMT,KAAKmmH,YACPnmH,KAAKmmH,WAAW3lH,UAElByE,MAAMxE,iBACP,EAQHylH,GAAariH,UAAUrD,QAOvB,IAAIoS,GAAgB,KAQpB,SAASK,GAAa26B,EAAO6P,GAC3B,MAAMymB,EAAWt2B,EAAMwQ,cACvB,IAAK8lB,EACH,MAAM,IAAI17D,MAAM,2BAA6BolC,GAG/C,IAAKs2B,EAAS7lB,aAAaZ,GACzB,OAAO,KAET,MAAMhuC,EAAQguC,EAAW/pC,KAAK,GACxBhE,EAAS+tC,EAAW/pC,KAAK,GAC/B,GAAc,IAAVjE,GAA0B,IAAXC,EACjB,OAAO,KAET,MAAM02C,EAAY8d,EAAS5lB,YAAYb,EAAY,MACnD,IAAIlzC,EACJ,GAAI67C,aAAqBh0C,kBACvB7H,EAAU67C,MACL,CAIL,GAHIA,IACF77C,EAAU67C,EAAUs3D,qBAEhBnzG,aAAmB6H,mBACvB,MAAM,IAAI5J,MAAM,iCAAmC+B,GAErD,GAAIA,EAAQkF,QAAUA,GAASlF,EAAQmF,SAAWA,EAAQ,CAExD,OADgBnF,EAAQ0F,WAAW,MACpBgD,aAAa,EAAG,EAAGxD,EAAOC,EAC1C,CACF,CAED,GAAKkD,GAIE,CACL,MAAM/C,EAAS+C,GAAc/C,OACzBA,EAAOJ,QAAUA,GAASI,EAAOH,SAAWA,EAC9CkD,GAAgBpD,GAAsBC,EAAOC,OAAQlJ,EAAW,CAC9DuM,oBAAoB,IAGtBH,GAAcxC,UAAU,EAAG,EAAGX,EAAOC,EAExC,MAZCkD,GAAgBpD,GAAsBC,EAAOC,OAAQlJ,EAAW,CAC9DuM,oBAAoB,IAaxB,OADAH,GAAcI,UAAUzI,EAAS,EAAG,EAAGkF,EAAOC,GACvCkD,GAAcK,aAAa,EAAG,EAAGxD,EAAOC,EACjD,CAgCA,SAAS82G,GAAYe,GAEnB,IAAI35E,EAUJ,OATI25E,aAAyB9+B,GACvB8+B,aAAyB97B,GAC3B79C,EAAQ,IAAI45E,GAAU,CAACt9G,OAAQq9G,IACtBA,aAAyBnU,KAClCxlE,EAAQ,IAAI65E,GAAW,CAACv9G,OAAQq9G,KAGlC35E,EAAQ25E,EAEH35E,CACT,CAEA,IAAA85E,GAAexB,GCv/Bf,MAoBMyB,GAAc,CAClBC,eAAkB,CAChBxlH,UAAW,MACXumF,QAAQ,GAEVk/B,0BAA6B,CAC3BzlH,UAAW,MACXumF,QAAQ,GAEVm/B,sBAAyB,CACvB1lH,UAAW,MACXumF,QAAQ,GAEVo/B,qBAAwB,CACtB3lH,UAAW,MACXumF,QAAQ,GAEVq/B,wBAA2B,CACzB5lH,UAAW,MACXumF,QAAQ,GAEVs/B,aAAgB,CACd7lH,UAAW,MACXumF,QAAQ,GAEVu/B,oBAAuB,CACrB9lH,UAAW,MACXumF,QAAQ,GAEVw/B,mBAAsB,CACpB/lH,UAAW,MACXumF,QAAQ,GAEVy/B,kBAAqB,CACnBhmH,UAAW,MACXumF,QAAQ,GAEV0/B,kBAAqB,CACnBjmH,UAAW,MACXumF,QAAQ,GAEV2/B,eAAkB,CAChBlmH,UAAW,MACXumF,QAAQ,GAEV4/B,oBAAuB,CACrBnmH,UAAW,MACXumF,QAAQ,GAEV6/B,SAAY,CACVpmH,UAAW,MACXumF,QAAQ,GAEV8/B,WAAc,CACZrmH,UAAW,MACXumF,QAAQ,IAON+/B,GAAiB,CACrBd,eAAkB,CAChBz6E,QAAS,EACTC,QAAS,GACTu7E,QAAQ,GAEVV,aAAgB,CACd96E,QAAS,EACTC,QAAS,GACTu7E,QAAQ,GAEVN,kBAAqB,CACnBl7E,QAAS,EACTC,QAAS,GACTu7E,QAAQ,IAgGZ,IAAAC,GA3DA,cAAyBh4B,GAIvB,WAAA9wF,CAAY6K,GACV,MAAM/I,EAAI+I,EAAQijC,MAAMhnC,QAAQ,KAC1BiiH,GAAiB,GAANjnH,EAAU+I,EAAQijC,MAAQjjC,EAAQijC,MAAM9pC,MAAM,EAAGlC,GAC5DknH,EAAiBJ,GAAeG,IAAa,CACjD17E,QAAW,EACXC,QAAW,GACXu7E,QAAU,GAGNI,EAAcpB,GAAYh9G,EAAQijC,OAClCo7E,EAAQr+G,EAAQs+G,OAAS,YAAct+G,EAAQs+G,OAAS,GACxDN,EAASG,EAAeH,QAAUh+G,EAAQg+G,OAAS,MAAQ,GAE3D/6C,OACYpnE,IAAhBmE,EAAQijE,IACJjjE,EAAQijE,IACR,sCACAjjE,EAAQijC,MACR,eACA+6E,EACA,IACAI,EAAY3mH,UACZ4mH,EAEA9qE,EAAe,CAhKvB,+EAOA,8EAyJ6DgrE,IAEvDv+G,EAAQijC,MAAMoqE,WAAW,YAC3B95D,EAAar3C,OAAO,EAAG,EArJ3B,0EAwJE5B,MAAM,CACJi5C,aAAcA,EACd7S,UAAW1gC,EAAQ0gC,UACnBhP,YAAa,YACbxvB,YAAalC,EAAQkC,YACrBugC,aACsB5mC,IAApBmE,EAAQyiC,QACJziC,EAAQyiC,QACR07E,EAAe17E,QACrBD,aACsB3mC,IAApBmE,EAAQwiC,QACJxiC,EAAQwiC,QACR27E,EAAe37E,QACrBw7C,OAAQogC,EAAYpgC,OACpBqE,2BAA4BriF,EAAQqiF,2BACpC1wD,iBAAkB3xB,EAAQ2xB,iBAC1B3vB,WAAYhC,EAAQgC,WACpBihE,IAAKA,EACLib,eAAgB8/B,EAAS,EAAI,EAC7BzpG,MAAOvU,EAAQuU,MACfgqE,WAAYv+E,EAAQu+E,YAEvB,GC0CH,IAAAigC,GA/KA,cAA6Bh7B,GAI3B,WAAAruF,CAAY6K,GAGV1F,MAAM,CACJi5C,cAHFvzC,EAAUA,GAAoB,IAGNuzC,aACtB7S,UAAW1gC,EAAQ0gC,UACnBhP,YAAa1xB,EAAQ0xB,YACrBxvB,YAAalC,EAAQkC,YACrBsS,WAAYxU,EAAQwU,WACpB6tE,2BAA4BriF,EAAQqiF,2BACpCnrE,SAAUlX,EAAQkX,SAClBya,iBAAkB3xB,EAAQ2xB,iBAC1BsxC,IAAKjjE,EAAQijE,IACbqd,KAAMtgF,EAAQsgF,KACd/rE,WAAyB1Y,IAAlBmE,EAAQuU,OAAsBvU,EAAQuU,MAC7CvS,WAAYhC,EAAQgC,WACpBu8E,WAAYv+E,EAAQu+E,aAOtBlpF,KAAKuzG,QAAU5oG,EAAQslF,QAAU,CAAA,EAMjCjwF,KAAKquF,YAA2B7nF,IAAlBmE,EAAQyjF,OAAsBzjF,EAAQyjF,MAMpDpuF,KAAKimF,WlL0FA,CAACxrE,IAAUA,KAAU,KAAW,KkLxFrCza,KAAKwpF,OAAOxpF,KAAKopH,mBAClB,CAMD,gBAAAA,GACE,IAAIxnH,EAAI,EACR,MAAMsB,EAAM,GACZ,IAAK,MAAMqE,KAAOvH,KAAKuzG,QACrBrwG,EAAItB,KAAO2F,EAAM,IAAMvH,KAAKuzG,QAAQhsG,GAEtC,OAAOrE,EAAI4V,KAAK,IACjB,CAQD,SAAA86F,GACE,OAAO5zG,KAAKuzG,OACb,CAYD,cAAA8V,CACE98G,EACAu5E,EACA81B,EACAxgF,EACAjc,EACA8wE,GAEA,MAAMhF,EAAOjrF,KAAKirF,KAClB,IAAKA,EACH,OAEF,IAAIrd,EACJ,GAAmB,GAAfqd,EAAK9pF,OACPysE,EAAMqd,EAAK,OACN,CAELrd,EAAMqd,EADQpmE,GAAOimE,GAAcv+E,GAAY0+E,EAAK9pF,QAErD,CAED,OAAOyxG,GACLhlC,EACAguC,GAEE57G,KAAK6hB,UAAY7hB,KAAK0pF,yBAAyBvqE,IAC/Cuc,cAAcnvB,EAAU,IAC1B6uB,EACAjc,EACA8wE,EAEH,CAOD,iBAAApG,CAAkBzuD,GAChB,OAAOp7B,KAAKquF,OAASjzD,EAAa,CACnC,CAOD,YAAA24E,CAAa9jB,GACXvpF,OAAO8C,OAAOxJ,KAAKuzG,QAAStjB,GAC5BjwF,KAAKwpF,OAAOxpF,KAAKopH,mBAClB,CASD,eAAAz9B,CAAgBp/E,EAAW6uB,EAAYjc,GACrC,IAAI0C,EAAW7hB,KAAK4pF,cAKpB,GAJK/nE,IACHA,EAAW7hB,KAAK0pF,yBAAyBvqE,IAGvC0C,EAAS+2B,iBAAiBz3C,QAAUoL,EAAU,GAChD,OAGgB,GAAd6uB,GAAoBp7B,KAAKquF,SAC3BjzD,EAAa,GAGf,MAAMwgF,EAAa/5F,EAASuhE,mBAAmB72E,EAAWvM,KAAKimF,YAC/D,IAAIH,EAAW9mB,GAAOn9C,EAASoiE,YAAY13E,EAAU,IAAKvM,KAAKgpF,SAE7C,GAAd5tD,IACF0qD,EAAWiE,GAAUjE,EAAU1qD,EAAYp7B,KAAKgpF,UAIlD,MAAM8rB,EAAa,CACjB9B,EAAK,QACLC,OAAU,QACVC,aAAe,GAIjB,OAFAxsG,OAAO8C,OAAOsrG,EAAY90G,KAAKuzG,SAExBvzG,KAAKqpH,eACV98G,EACAu5E,EACA81B,EACAxgF,EACAjc,EACA21F,EAEH,GCzKH,IAAAwU,GA1CA,cAAwB14B,GAItB,WAAA9wF,CAAY6K,GAMV1F,MAAM,CACJ0jF,QAAQ,EACRxpE,YAJFxU,EAAUA,GAAW,IAICwU,WACpB0C,SAAUlX,EAAQkX,SAClB3C,WAAyB1Y,IAAlBmE,EAAQuU,OAAsBvU,EAAQuU,MAC7CgqE,WAAYv+E,EAAQu+E,WACpBtb,IAAKjjE,EAAQsc,UAAY,oBACzBqV,iBAAkB,CAACpvB,EAAM01C,KACvB,MAAMrjB,EAAIryB,EAAKG,eAAe,GACxBy4E,EAAW9mB,GAAOh/D,KAAK6hB,SAASoiE,YAAY1kD,IAC5CpvB,EAAUX,GAAsBs2E,EAAS,GAAIA,EAAS,IAE5D31E,EAAQqhE,YAAc,OACtBrhE,EAAQo5G,WAAW,GAAK,GAAKzjC,EAAS,GAAK,GAAKA,EAAS,GAAK,IAE9D31E,EAAQ2sB,UAAY,OACpB3sB,EAAQqhE,YAAc,QACtBrhE,EAAQ4mE,UAAY,SACpB5mE,EAAQ6mE,aAAe,SACvB7mE,EAAQszC,KAAO,kBACftzC,EAAQ+0C,UAAY,EACpB/0C,EAAQokE,WAAW3xB,EAAMkjC,EAAS,GAAK,EAAGA,EAAS,GAAK,EAAGA,EAAS,IACpE31E,EAAQqkE,SAAS5xB,EAAMkjC,EAAS,GAAK,EAAGA,EAAS,GAAK,EAAGA,EAAS,IAEjB,EAAOhqD,SACtD3rB,EAAQN,OACT,GAGN,GC+IH,IAAA25G,GA5IA,cAAuBr7B,GAIrB,WAAAruF,CAAY6K,GA2BV,GA1BA1F,MAAM,CACJi5C,aAAcvzC,EAAQuzC,aACtB7S,UAAW1gC,EAAQ0gC,UACnBhP,YAAa1xB,EAAQ0xB,YACrBxvB,YAAalC,EAAQkC,YACrBsS,WAAYyP,GAAc,aAC1Bo+D,2BAA4BriF,EAAQqiF,2BACpCxgF,MAAO,UACP8vB,iBAAkB3xB,EAAQ2xB,iBAC1Bpd,WAAyB1Y,IAAlBmE,EAAQuU,OAAsBvU,EAAQuU,MAC7CvS,WAAYhC,EAAQgC,WACpBu8E,WAAYv+E,EAAQu+E,aAOtBlpF,KAAKypH,UAAY,KAMjBzpH,KAAK6lF,UAAYl7E,EAAQm7E,SAErBn7E,EAAQijE,IACV,GAAIjjE,EAAQqkE,MACV06C,GACE/+G,EAAQijE,IACR5tE,KAAK2pH,uBAAuBziH,KAAKlH,MACjCA,KAAK4pH,oBAAoB1iH,KAAKlH,WAE3B,CACL,MAAM2vE,EAAS,IAAI3B,eACnB2B,EAAOrqE,iBAAiB,OAAQtF,KAAK6pH,WAAW3iH,KAAKlH,OACrD2vE,EAAOrqE,iBAAiB,QAAStF,KAAK8pH,YAAY5iH,KAAKlH,OACvD2vE,EAAO1B,KAAK,MAAOtjE,EAAQijE,KAC3B+B,EAAOb,MACR,KACI,KAAInkE,EAAQo/G,SAGjB,MAAM,IAAIvhH,MAAM,uDAFhBxI,KAAK2pH,uBAAuBh/G,EAAQo/G,SAGrC,CACF,CAMD,UAAAF,CAAWhkH,GACT,MAAM8pE,EAAwC9pE,EAAY,OAE1D,IAAK8pE,EAAOvB,QAAWuB,EAAOvB,QAAU,KAAOuB,EAAOvB,OAAS,IAAM,CACnE,IAAIqB,EACJ,IACEA,EAAkCpB,KAAKnjC,MAAMykC,EAAOrB,aACrD,CAAC,MAAOhqE,GAEP,YADAtE,KAAK4pH,qBAEN,CACD5pH,KAAK2pH,uBAAuBl6C,EAClC,MACMzvE,KAAK4pH,qBAER,CAMD,WAAAE,CAAYjkH,GACV7F,KAAK4pH,qBACN,CAMD,WAAAI,GACE,OAAOhqH,KAAKypH,SACb,CAMD,sBAAAE,CAAuBI,GACrB,MAAME,EAAqBr7F,GAAc,aAEnCnD,EAAmBzrB,KAAK4uB,gBAC9B,IAAIpV,EACJ,QAA2BhT,IAAvBujH,EAAiB,OAAiB,CACpC,MAAM/zG,EAAYkU,GAChB+/F,EACAx+F,GAEFjS,EAASmF,GAAeorG,EAAiB,OAAG/zG,EAC7C,CAED,MAAMk0G,EAAaniC,GAAqBt8D,GAClC0hB,EAAU48E,EAAkB,SAAK,EAEjCloG,EAAWsmE,GAAU,CACzB3uE,OAAQ0wG,EACR98E,QAHc28E,EAAkB,SAAK,GAIrC58E,QAASA,EACT24C,SAAU9lF,KAAK6lF,YAMjB,GAJA7lF,KAAK6hB,SAAWA,EAEhB7hB,KAAK2rF,gBAAkBjB,GAAoBq/B,EAAgB,MAAGloG,GAE1DkoG,EAAsB,cAAM/pH,KAAKi+C,kBAAmB,CACtD,MAAMksE,OAA+B3jH,IAAXgT,EAAuBA,EAAS0wG,EAC1DlqH,KAAKolF,iBAAgB,SAAU3nC,GAC7B,OAAI3/B,GAAWqsG,EAAmB1sE,EAAWjkC,QACpC,CAACuwG,EAAsB,aAEzB,IACf,GACK,CACD/pH,KAAKypH,UAAYM,EACjB/pH,KAAK+M,SAAS,QACf,CAKD,mBAAA68G,GACE5pH,KAAK+M,SAAS,QACf,GCuMH,IAAAq9G,GAzUA,cAAsBj8B,GAIpB,WAAAruF,CAAY6K,GACVA,EAAUA,GAA4C,CAAE,EAExD,MAAMslF,EAASvpF,OAAO8C,OAAO,CAAA,EAAImB,EAAQslF,QAEnC8a,IAAc,gBAAiB9a,IAASA,EAAoB,YAElEhrF,MAAM,CACJi5C,aAAcvzC,EAAQuzC,aACtB0mC,wBAAyBj6E,EAAQi6E,wBACjCv5C,UAAW1gC,EAAQ0gC,UACnBhP,YAAa1xB,EAAQ0xB,YACrBxvB,YAAalC,EAAQkC,YACrB87E,QAASoiB,EACT5rF,WAAYxU,EAAQwU,WACpB6tE,2BAA4BriF,EAAQqiF,2BACpCL,UAAWhiF,EAAQgiF,UACnB9qE,SAAUlX,EAAQkX,SAClBya,iBAAkB3xB,EAAQ2xB,iBAC1BsxC,IAAKjjE,EAAQijE,IACbqd,KAAMtgF,EAAQsgF,KACd/rE,WAAyB1Y,IAAlBmE,EAAQuU,OAAsBvU,EAAQuU,MAC7CvS,WAAYhC,EAAQgC,WACpBu8E,WAAYv+E,EAAQu+E,aAOtBlpF,KAAK6iF,aAA6Br8E,IAAnBmE,EAAQ6yE,OAAuB7yE,EAAQ6yE,OAAS,EAM/Dx9E,KAAKuzG,QAAUtjB,EAMfjwF,KAAKqqH,MAAO,EAMZrqH,KAAKq3G,YAAc1sG,EAAQ6rG,WAM3Bx2G,KAAKquF,YAA2B7nF,IAAlBmE,EAAQyjF,OAAsBzjF,EAAQyjF,MAMpDpuF,KAAKimF,WrLuDA,CAACxrE,IAAUA,KAAU,KAAW,KqLrDrCza,KAAKsqH,aACLtqH,KAAKwpF,OAAOxpF,KAAKopH,mBAClB,CAgBD,iBAAAvS,CAAkBz/F,EAAYuF,EAAYwC,EAAY8wE,GACpD,MAAM6mB,EAAgBloF,GAAczP,GAC9Bm4F,EAAsBt3G,KAAK4uB,iBAAmBkoF,EAEpD,IAAIj1F,EAAW7hB,KAAK4pF,cACf/nE,IACHA,EAAW7hB,KAAK0pF,yBAAyB4tB,IAG3C,MAAMiT,EAAkBv0G,GACtBoB,EACA0/F,EACAQ,GAEIpkE,EAAmB8pC,GACvBs6B,EACAR,EACA1/F,EACAuF,GAGI4iB,EAAI1d,EAAS8hE,kBAAkBzwC,EAAkBlzC,KAAKkpF,YACtD15B,EAAiB3tC,EAAS6Z,cAAc6D,GACxChzB,EAAYsV,EAAS0lE,yBAAyBgjC,EAAiBhrF,GAErE,GAAI1d,EAAS+2B,iBAAiBz3C,QAAUoL,EAAU,GAChD,OAGF,IAAIqvG,EAAa/5F,EAASuhE,mBAAmB72E,EAAWvM,KAAKimF,YAE7D,MAAMzI,EAASx9E,KAAK6iF,QACL,IAAXrF,IACFo+B,EAAajiG,GAAOiiG,EAAYpsD,EAAiBguB,EAAQo+B,IAG3D,MAAM9G,EAAa,CACjBiC,aAAgB/2G,KAAKuzG,QAAgB,QAEvC7sG,OAAO8C,OACLsrG,EACA4B,GAAiB12G,KAAKuzG,QAAS,kBAC/BtjB,GAGF,MAAM54E,EAAIpL,KAAKuT,OAAO+qG,EAAgB,GAAK3O,EAAW,IAAMpsD,GACtDl4C,EAAIrL,KAAKuT,OAAOo8F,EAAW,GAAK2O,EAAgB,IAAM/6D,GAK5D,OAHAslD,EAAW90G,KAAKqqH,KAAO,IAAM,KAAOhzG,EACpCy9F,EAAW90G,KAAKqqH,KAAO,IAAM,KAAO/yG,EAE7BtX,KAAKqpH,eACV98G,EACAqvG,EACA,EACAtE,GAAuBR,EACvBhC,EAEH,CAgBD,YAAAmC,CAAat6F,EAAYszE,GACvB,QAAqBzpF,IAAjBxG,KAAKirF,KAAK,GACZ,OAGF,MAAM6pB,EAAa,CACjB6B,QAAW,MACX3B,QAAWmB,GACXM,QAAW,mBACXxD,OAAU,aAGZ,QAAezsG,IAAXypF,QAA4CzpF,IAApBypF,EAAc,MAAiB,CACzD,MAAMlpC,EAAS/mD,KAAKuzG,QAAQ2D,OAE5B,MADuB70G,MAAMC,QAAQykD,IAA6B,IAAlBA,EAAO5lD,QAErD,OAEF2zG,EAAkB,MAAI/tD,CACvB,CAED,QAAmBvgD,IAAfmW,EAA0B,CAC5B,MAAMw6F,EAAMn3G,KAAK4uB,gBACb5uB,KAAK4uB,gBAAgBtN,mBACrB,EACEggF,EAAY,MAClBwT,EAAkB,MAAKn4F,EAAaw6F,EAAO7V,CAC5C,CAID,OAFA56F,OAAO8C,OAAOsrG,EAAY7kB,GAEnBsiB,GAAoCvyG,KAAKirF,KAAK,GAAK6pB,EAC3D,CAKD,SAAA3nB,GACE,OAAOntF,KAAK6iF,OACb,CAQD,SAAA+wB,GACE,OAAO5zG,KAAKuzG,OACb,CAWD,cAAA8V,CAAe98G,EAAWqvG,EAAYxgF,EAAYjc,EAAY8wE,GAC5D,MAAMhF,EAAOjrF,KAAKirF,KAClB,IAAKA,EACH,OAEF,IAAIrd,EACJ,GAAmB,GAAfqd,EAAK9pF,OACPysE,EAAMqd,EAAK,OACN,CAELrd,EAAMqd,EADQpmE,GAAOimE,GAAcv+E,GAAY0+E,EAAK9pF,QAErD,CAED,OAAOo1G,GACLqF,GAEE57G,KAAK6hB,UAAY7hB,KAAK0pF,yBAAyBvqE,IAC/Cuc,cAAcnvB,EAAU,IAC1B6uB,EACAjc,EACAyuD,EACAqiB,EACAjwF,KAAKq3G,YAER,CAOD,iBAAAxtB,CAAkBzuD,GAChB,OAAQp7B,KAAKquF,aAA+B7nF,IAArBxG,KAAKq3G,YAAgCj8E,EAAJ,CACzD,CAMD,gBAAAguF,GACE,IAAIxnH,EAAI,EACR,MAAMsB,EAAM,GACZ,IAAK,MAAMqE,KAAOvH,KAAKuzG,QACrBrwG,EAAItB,KAAO2F,EAAM,IAAMvH,KAAKuzG,QAAQhsG,GAEtC,OAAOrE,EAAI4V,KAAK,IACjB,CAOD,YAAAi7F,CAAa9jB,GACXvpF,OAAO8C,OAAOxJ,KAAKuzG,QAAStjB,GAC5BjwF,KAAKsqH,aACLtqH,KAAKwpF,OAAOxpF,KAAKopH,mBAClB,CAKD,UAAAkB,GACE,MAAM9b,EAAUxuG,KAAKuzG,QAAiB,SAAK4C,GAC3Cn2G,KAAKqqH,KAAO5kG,GAAgB+oF,EAAS,QAAU,CAChD,CASD,eAAA7iB,CAAgBp/E,EAAW6uB,EAAYjc,GACrC,IAAI0C,EAAW7hB,KAAK4pF,cAKpB,GAJK/nE,IACHA,EAAW7hB,KAAK0pF,yBAAyBvqE,IAGvC0C,EAAS+2B,iBAAiBz3C,QAAUoL,EAAU,GAChD,OAGgB,GAAd6uB,GAAqBp7B,KAAKquF,aAA+B7nF,IAArBxG,KAAKq3G,cAC3Cj8E,EAAa,GAGf,MAAMo0B,EAAiB3tC,EAAS6Z,cAAcnvB,EAAU,IACxD,IAAIqvG,EAAa/5F,EAASuhE,mBAAmB72E,EAAWvM,KAAKimF,YAE7D,MAAMzI,EAASx9E,KAAK6iF,QACL,IAAXrF,IACFo+B,EAAajiG,GAAOiiG,EAAYpsD,EAAiBguB,EAAQo+B,IAG3D,MAAM9G,EAAapuG,OAAO8C,OACxB,CAAE,EACFktG,GAAiB12G,KAAKuzG,QAAS,WAGjC,OAAOvzG,KAAKqpH,eACV98G,EACAqvG,EACAxgF,EACAjc,EACA21F,EAEH,GC5XI,MAAM5I,WAAmB94F,GAS9B,WAAAtT,CAAYyM,EAAWC,EAAOquB,EAAKrhB,EAAQgxG,EAAYx7C,GACrD/pE,MAAMsH,EAAWC,GAMjBxM,KAAKw8B,KAAO3B,EAMZ76B,KAAKugB,QAAU/G,EAMfxZ,KAAKyqH,YAAcD,EAMnBxqH,KAAK0qH,MAAQ,KAMb1qH,KAAK2qH,MAAQ,KAMb3qH,KAAKuT,MAAQ,KAMbvT,KAAK4qH,OAAS57C,CACf,CAMD,QAAAxzC,GACE,OAAO,IACR,CAOD,OAAA3nB,CAAQuD,GACN,IAAKpX,KAAK0qH,QAAU1qH,KAAK2qH,MACvB,OAAO,KAET,MAAME,GACHzzG,EAAW,GAAKpX,KAAKugB,QAAQ,KAAOvgB,KAAKugB,QAAQ,GAAKvgB,KAAKugB,QAAQ,IAChEuqG,GACH1zG,EAAW,GAAKpX,KAAKugB,QAAQ,KAAOvgB,KAAKugB,QAAQ,GAAKvgB,KAAKugB,QAAQ,IAEhE+8F,EAAMt9G,KAAK0qH,MAAMz+G,KAAKuT,OAAO,EAAIsrG,GAAa9qH,KAAK0qH,MAAMvpH,SAE/D,GAAmB,iBAARm8G,EACT,OAAO,KAGT,IAAIz9F,EAAOy9F,EAAInyB,WAAWl/E,KAAKuT,MAAMqrG,EAAYvN,EAAIn8G,SACjD0e,GAAQ,IACVA,IAEEA,GAAQ,IACVA,IAEFA,GAAQ,GAER,IAAI1d,EAAO,KACX,GAAI0d,KAAQ7f,KAAK2qH,MAAO,CACtB,MAAMn9G,EAAKxN,KAAK2qH,MAAM9qG,GAEpB1d,EADEnC,KAAKuT,OAAS/F,KAAMxN,KAAKuT,MACpBvT,KAAKuT,MAAM/F,GAEXA,CAEV,CACD,OAAOrL,CACR,CAUD,mBAAA4oH,CAAoB3zG,EAAYwE,EAAU6pF,GACpCzlG,KAAKwM,OAASV,IAA+B,IAAZ25F,GACnCzlG,KAAKwM,MAAQV,EACbzE,EACErH,KACA8H,GACA,SAAUoP,GACR0E,EAAS5b,KAAK6T,QAAQuD,GACvB,GACDpX,MAEFA,KAAKgrH,kBAEW,IAAZvlB,EACFh0D,YAAW,KACT71B,EAAS5b,KAAK6T,QAAQuD,GAAY,GACjC,GAEHwE,EAAS5b,KAAK6T,QAAQuD,GAG3B,CAMD,MAAApK,GACE,OAAOhN,KAAKw8B,IACb,CAKD,YAAAm+E,GACE36G,KAAKwM,MAAQV,EACb9L,KAAK6H,SACN,CAMD,WAAAs0B,CAAY4yD,GACV/uF,KAAK0qH,MAAQ37B,EAAW,KACxB/uF,KAAK2qH,MAAQ57B,EAAW,KACxB/uF,KAAKuT,MAAQw7E,EAAW,KAExB/uF,KAAKwM,MAAQV,EACb9L,KAAK6H,SACN,CAKD,aAAAmjH,GACE,GAAIhrH,KAAKwM,OAASV,EAEhB,GADA9L,KAAKwM,MAAQV,EACT9L,KAAK4qH,OACPlB,GACE1pH,KAAKw8B,KACLx8B,KAAKm8B,YAAYj1B,KAAKlH,MACtBA,KAAK26G,aAAazzG,KAAKlH,WAEpB,CACL,MAAM2vE,EAAS,IAAI3B,eACnB2B,EAAOrqE,iBAAiB,OAAQtF,KAAK6pH,WAAW3iH,KAAKlH,OACrD2vE,EAAOrqE,iBAAiB,QAAStF,KAAK8pH,YAAY5iH,KAAKlH,OACvD2vE,EAAO1B,KAAK,MAAOjuE,KAAKw8B,MACxBmzC,EAAOb,MACR,CAEJ,CAMD,UAAA+6C,CAAWhkH,GACT,MAAM8pE,EAAwC9pE,EAAY,OAE1D,IAAK8pE,EAAOvB,QAAWuB,EAAOvB,QAAU,KAAOuB,EAAOvB,OAAS,IAAM,CACnE,IAAIqB,EACJ,IACEA,EACEpB,KAAKnjC,MAAMykC,EAAOrB,aAErB,CAAC,MAAOhqE,GAEP,YADAtE,KAAK26G,cAEN,CACD36G,KAAKm8B,YAAYszC,EACvB,MACMzvE,KAAK26G,cAER,CAMD,WAAAmP,CAAYjkH,GACV7F,KAAK26G,cACN,CAID,IAAArtG,GACMtN,KAAKyqH,YACPzqH,KAAKgrH,gBAELhrH,KAAK+M,SAASjB,EAEjB,EAuQH,IAAAm/G,GA5OA,cAAsBx/B,GAIpB,WAAA3rF,CAAY6K,GAgCV,GA/BA1F,MAAM,CACJka,WAAYyP,GAAc,aAC1BpiB,MAAO,UACP08E,WAAYv+E,EAAQu+E,aAOtBlpF,KAAKyqH,iBACoBjkH,IAAvBmE,EAAQ6/G,YAA2B7/G,EAAQ6/G,WAM7CxqH,KAAKkrH,iBAAmBngC,GAMxB/qF,KAAKmrH,eAAY3kH,EAMjBxG,KAAK4qH,OAASjgH,EAAQqkE,QAAS,EAE3BrkE,EAAQijE,IACV,GAAI5tE,KAAK4qH,OACPlB,GACE/+G,EAAQijE,IACR5tE,KAAK2pH,uBAAuBziH,KAAKlH,MACjCA,KAAK4pH,oBAAoB1iH,KAAKlH,WAE3B,CACL,MAAM2vE,EAAS,IAAI3B,eACnB2B,EAAOrqE,iBAAiB,OAAQtF,KAAK6pH,WAAW3iH,KAAKlH,OACrD2vE,EAAOrqE,iBAAiB,QAAStF,KAAK8pH,YAAY5iH,KAAKlH,OACvD2vE,EAAO1B,KAAK,MAAOtjE,EAAQijE,KAC3B+B,EAAOb,MACR,KACI,KAAInkE,EAAQo/G,SAGjB,MAAM,IAAIvhH,MAAM,uDAFhBxI,KAAK2pH,uBAAuBh/G,EAAQo/G,SAGrC,CACF,CAMD,UAAAF,CAAWhkH,GACT,MAAM8pE,EAAwC9pE,EAAY,OAE1D,IAAK8pE,EAAOvB,QAAWuB,EAAOvB,QAAU,KAAOuB,EAAOvB,OAAS,IAAM,CACnE,IAAIqB,EACJ,IACEA,EACEpB,KAAKnjC,MAAMykC,EAAOrB,aAErB,CAAC,MAAOhqE,GAEP,YADAtE,KAAK4pH,qBAEN,CACD5pH,KAAK2pH,uBAAuBl6C,EAClC,MACMzvE,KAAK4pH,qBAER,CAMD,WAAAE,CAAYjkH,GACV7F,KAAK4pH,qBACN,CAOD,WAAAwB,GACE,OAAOprH,KAAKmrH,SACb,CAaD,gCAAAE,CAAiCj0G,EAAYuF,EAAYf,EAAU6pF,GACjE,GAAIzlG,KAAK6hB,SAAU,CACjB,MAAM0d,EAAIv/B,KAAK6hB,SAAS8hE,kBAAkBhnE,EAAY3c,KAAKkpF,YACrD38E,EAAYvM,KAAK6hB,SAAS0lE,yBAAyBnwE,EAAYmoB,GAEnEv/B,KAAK2pF,QACHp9E,EAAU,GACVA,EAAU,GACVA,EAAU,GACV,EACAvM,KAAK4uB,iBAGJm8F,oBAAoB3zG,EAAYwE,EAAU6pF,EACrD,MACsB,IAAZA,EACFh0D,YAAW,WACT71B,EAAS,KACV,GAAE,GAEHA,EAAS,KAGd,CAKD,mBAAAguG,GACE5pH,KAAK+M,SAAS,QACf,CAOD,sBAAA48G,CAAuBI,GACrB,MAAME,EAAqBr7F,GAAc,aAEnCnD,EAAmBzrB,KAAK4uB,gBAC9B,IAAIpV,EACJ,QAA2BhT,IAAvBujH,EAAiB,OAAiB,CACpC,MAAM/zG,EAAYkU,GAChB+/F,EACAx+F,GAEFjS,EAASmF,GAAeorG,EAAiB,OAAG/zG,EAC7C,CAED,MAAMk0G,EAAaniC,GAAqBt8D,GAClC0hB,EAAU48E,EAAkB,SAAK,EAEjCloG,EAAWsmE,GAAU,CACzB3uE,OAAQ0wG,EACR98E,QAHc28E,EAAkB,SAAK,GAIrC58E,QAASA,IAEXntC,KAAK6hB,SAAWA,EAEhB7hB,KAAKmrH,UAAYpB,EAAmB,SAEpC,MAAMuB,EAAQvB,EAAgB,MAC9B,GAAKuB,EAAL,CAOA,GAFAtrH,KAAKkrH,iBAAmBxgC,GAAoB4gC,EAAOzpG,QAEnBrb,IAA5BujH,EAAsB,YAAiB,CACzC,MAAMI,OAA+B3jH,IAAXgT,EAAuBA,EAAS0wG,EAC1DlqH,KAAKolF,iBAAgB,SAAU3nC,GAC7B,OAAI3/B,GAAWqsG,EAAmB1sE,EAAWjkC,QACpC,CAACuwG,EAAsB,aAEzB,IACf,GACK,CAED/pH,KAAK+M,SAAS,QAdb,MAFC/M,KAAK+M,SAAS,QAiBjB,CAUD,OAAA48E,CAAQpqD,EAAGloB,EAAGC,EAAG8jB,EAAYjc,GAC3B,MAAMkqE,EAAe5e,GAAUlrC,EAAGloB,EAAGC,GACrC,GAAItX,KAAK8oF,UAAUhf,YAAYuf,GAC7B,OAAOrpF,KAAK8oF,UAAU1/E,IAAIigF,GAE5B,MAAM98E,EAAY,CAACgzB,EAAGloB,EAAGC,GACnBm0D,EAAezrE,KAAKgqF,+BACxBz9E,EACA4S,GAEIouE,EAAUvtF,KAAKkrH,iBAAiBz/C,EAAcrwC,EAAYjc,GAC1DjS,EAAO,IAAIg/F,GACf3/F,OACY/F,IAAZ+mF,EAAwBzhF,EAAiBA,OAC7BtF,IAAZ+mF,EAAwBA,EAAU,GAClCvtF,KAAK6hB,SAASuhE,mBAAmB72E,GACjCvM,KAAKyqH,YACLzqH,KAAK4qH,QAGP,OADA5qH,KAAK8oF,UAAU/+E,IAAIs/E,EAAcn8E,GAC1BA,CACR,CAQD,OAAAi9E,CAAQ5qD,EAAGloB,EAAGC,GACZ,MAAM+xE,EAAe5e,GAAUlrC,EAAGloB,EAAGC,GACjCtX,KAAK8oF,UAAUhf,YAAYuf,IAC7BrpF,KAAK8oF,UAAU1/E,IAAIigF,EAEtB,GChdH,MAAMkiC,WAAqBrjC,GAIzB,WAAApoF,CAAY6K,GACV1F,MAAM,CACJuU,OAAQ7O,EAAQ6O,OAChBisE,OAAQ96E,EAAQ86E,OAChBF,QAAS56E,EAAQ46E,QACjB50C,YAAahmC,EAAQgmC,YACrBm1C,SAAUn7E,EAAQm7E,SAClBF,UAAWj7E,EAAQi7E,UACnBM,MAAOv7E,EAAQu7E,QAOjBlmF,KAAKwrH,WAAa7gH,EAAQouG,SAC3B,CAMD,WAAA0S,CAAYlsF,GACV,OAAOv/B,KAAKwrH,WAAWjsF,EACxB,CAOD,YAAAmsF,GACE,OAAO1rH,KAAKwrH,UACb,EAGH,IAAAG,GAAeJ,GAcR,SAASK,GACdC,EACAryG,EACAsyG,GAGA,MAAMn7E,EAAc,GAEdooE,EAAY,GAEZxzB,EAAU,GAEVK,EAAY,GAEZM,EAAQ,GAEd4lC,OAAgCtlH,IAAjBslH,EAA6BA,EAAe,GAE3D,MACMC,EAAoB,aACpBC,EAAqB,aACrBC,EAA2B,mBAC3BC,EAAwB,gBAKxB/sG,EAAayP,GADNi9F,EAA8B,cAErC1qG,EAAgBhC,EAAWmC,mBAE3B6qG,EAAiE,MAAhDhtG,EAAWqC,qBAAqB80F,OAAO,EAAG,GAmDjE,OAjDAuV,EAAUE,GAAmBz3F,MAAK,SAAUjzB,EAAGC,GAC7C,OAAOA,EAAE2qH,GAA4B5qH,EAAE4qH,EAC3C,IAEEJ,EAAUE,GAAmB5gH,SAAQ,SAAUihH,GAC7C,IAAIC,EAsBJ,GAlBEA,IADEP,EAAa3qH,OAAS,IACN2qH,EAAa/tE,MAAK,SAAUuuE,GAC5C,OAAIF,EAAIJ,IAAuBM,EAAOP,KAKjCK,EAAIJ,GAAoBtmH,SAAS,MAElCmmH,EAAUG,GAAsB,IAAMI,EAAIJ,KAC1CM,EAAOP,EAInB,IAKQM,EAAiB,CACnBtT,EAAUpzG,KAAKymH,EAAIJ,IACnB,MAAMrvG,EAC6B,MAAhCyvG,EAAIH,GAAuC9qG,EACxC0qF,EAAYugB,EAAqB,UACjC1c,EAAa0c,EAAsB,WACrCD,EACF5mC,EAAQ5/E,KAAK,CACXymH,EAAIF,GAAuB,GAC3BE,EAAIF,GAAuB,KAG7B3mC,EAAQ5/E,KAAKymH,EAAIF,IAEnBv7E,EAAYhrC,KAAKgX,GACjBipE,EAAUjgF,KACRkmG,GAAa6D,EAAa7D,EAAY,CAACA,EAAW6D,IAEpDxpB,EAAMvgF,KAAK,CAACymH,EAAiB,YAAGA,EAAkB,cACnD,CACL,IAES,IAAIb,GAAa,CACtB/xG,OAAQA,EACR+rE,QAASA,EACT50C,YAAaA,EACbooE,UAAWA,EACXnzB,UAAWA,EACXM,MAAOA,GAEX,CCoJA,IAAAqmC,GA1QA,cAAmBp+B,GAIjB,WAAAruF,CAAY6K,GAGV,MAAM6hH,OACwBhmH,IAA5BmE,EAAQ6hH,gBAAgC7hH,EAAQ6hH,gBAAkB,MAI9D3qG,EAAWlX,EAAQkX,SAEzB,IAAIopE,EAAOtgF,EAAQsgF,UACNzkF,IAATykF,QAAsCzkF,IAAhBmE,EAAQijE,MAChCqd,EAAOD,GAAUrgF,EAAQijE,MAG3B3oE,MAAM,CACJi5C,aAAcvzC,EAAQuzC,aACtB0mC,wBAAyBj6E,EAAQi6E,wBACjCv5C,UAAW1gC,EAAQ0gC,UACnBhP,YAAa1xB,EAAQ0xB,YACrBxvB,YAAalC,EAAQkC,YACrBsS,WAAYxU,EAAQwU,WACpB6tE,2BAA4BriF,EAAQqiF,2BACpCL,UAAWhiF,EAAQgiF,UACnB9qE,SAAUA,EACVya,iBAAkB3xB,EAAQ2xB,iBAC1BusD,eAAgBl+E,EAAQk+E,eACxBoC,KAAMA,EACN/rE,WAAyB1Y,IAAlBmE,EAAQuU,OAAsBvU,EAAQuU,MAC7CvS,WAAYhC,EAAQgC,WACpBu8E,WAAYv+E,EAAQu+E,aAOtBlpF,KAAKysH,cAA+BjmH,IAApBmE,EAAQ6jG,QAAwB7jG,EAAQ6jG,QAAU,QAMlExuG,KAAK+sE,aAA6BvmE,IAAnBmE,EAAQqc,OAAuBrc,EAAQqc,OAAS,aAM/DhnB,KAAK0sH,iBACoBlmH,IAAvBmE,EAAQgiH,WAA2BhiH,EAAQgiH,WAAa,CAAA,EAM1D3sH,KAAKu8G,OAAS5xG,EAAQijC,MAMtB5tC,KAAK4sH,WAAajiH,EAAQkhH,UAM1B7rH,KAAKwU,OAAS7J,EAAQ4F,MAStBvQ,KAAK6sH,iBAAmBL,EAExBxsH,KAAKwpF,OAAOxpF,KAAK8sH,wBAEb7hC,GAAQA,EAAK9pF,OAAS,IACxBnB,KAAK2rF,gBAAkBd,GACrBI,EAAKngD,IAAI9qC,KAAK+sH,uBAAuB7lH,KAAKlH,QAG/C,CAOD,OAAA4rF,CAAQX,GACNjrF,KAAKirF,KAAOA,EACZ,MAAM1jF,EAAM0jF,EAAKnyE,KAAK,MACtB9Y,KAAKssF,mBACHzB,GACEI,EAAKngD,IAAI9qC,KAAK+sH,uBAAuB7lH,KAAKlH,QAE5CuH,EAEH,CASD,aAAAylH,GACE,OAAOhtH,KAAK0sH,WACb,CAOD,SAAAx/C,GACE,OAAOltE,KAAK+sE,OACb,CAOD,QAAA4vC,GACE,OAAO38G,KAAKu8G,MACb,CAOD,YAAA0Q,GACE,OAAOjtH,KAAK4sH,UACb,CAOD,kBAAAM,GACE,OAAOltH,KAAK6sH,gBACb,CAOD,QAAA13G,GACE,OAAOnV,KAAKwU,MACb,CAOD,UAAA24G,GACE,OAAOntH,KAAKysH,QACb,CAMD,oBAAAK,GACE,MAAM5pH,EAAMlD,KAAKirF,KAAOjrF,KAAKirF,KAAKnnF,MAAM,GAAK,GAC7C,IAAK,MAAMyD,KAAOvH,KAAK0sH,YACrBxpH,EAAIyC,KAAK4B,EAAM,IAAMvH,KAAK0sH,YAAYnlH,IAExC,OAAOrE,EAAI4V,KAAK,IACjB,CAOD,gBAAAs0G,CAAiBT,GACfjmH,OAAO8C,OAAOxJ,KAAK0sH,YAAaC,GAChC3sH,KAAKwpF,OAAOxpF,KAAK8sH,uBAClB,CAMD,sBAAAC,CAAuB9lG,GACrB,MAAMulG,EAAkBxsH,KAAK6sH,iBAIvB18G,EAAU,CACdy9B,MAAS5tC,KAAKu8G,OACdhsG,MAASvQ,KAAKwU,OACd64G,cAAiBrtH,KAAK4sH,YAGD,OAAnBJ,GACF9lH,OAAO8C,OAAO2G,EAAS,CACrBm9G,QAAW,OACXC,QAAW,UACXC,QAAWxtH,KAAKysH,SAChBgB,OAAUztH,KAAK+sE,UAQnB9lD,EACqB,OAAnBulG,EACIja,GAAatrF,EAAU9W,GACvB8W,EAASzD,QAAQ,eAAe,SAAUrD,EAAGi2E,GAC3C,OAAOA,EAAEnoF,gBAAiBkC,EAAUA,EAAQimF,EAAEnoF,eAAiBkS,CAC3E,IAEI,MAAM0B,EACJ7hB,KACN,SACU2sH,EAAa3sH,KAAK0sH,YAExB,OAAA,SAOYngH,EAAW6uB,EAAYjc,GAC/B,IAAK5S,EACH,OAEF,MAAMw/F,EAAe,CACnB2hB,WAAc7rG,EAAS4pG,YAAYl/G,EAAU,IAC7CohH,QAAWphH,EAAU,GACrBqhH,QAAWrhH,EAAU,IAEvB7F,OAAO8C,OAAOuiG,EAAc4gB,GAC5B,IAAI/+C,EAAM3mD,EAQV,OANE2mD,EADqB,OAAnB4+C,EACIja,GAAa3kC,EAAKm+B,GAElBn+B,EAAIpqD,QAAQ,eAAe,SAAUrD,EAAGi2E,GAC5C,OAAO2V,EAAa3V,EAChC,IAEexoB,CAET,CACH,GC1TI,MAAMigD,GAAe,MAUfC,GAAuB,MAgBvBC,GAAc,MAQdC,GAAe,MAwBfC,GAAQ,KASfC,GAAc,CAAC,qBAAsB,QAAS,YAAa,aAO1D,SAASj+G,GAAWJ,EAAQs+G,GACjCA,EAAaznH,OAAO8C,OAClB,CACE4kH,uBAAuB,EACvBC,WAAWjgH,IAEb+/G,GAEF,MAAMhoH,EAAK+nH,GAAY/sH,OACvB,IAAK,IAAIS,EAAI,EAAGA,EAAIuE,IAAMvE,EACxB,IACE,MAAMuO,EAAUN,EAAOI,WAAWi+G,GAAYtsH,GAAIusH,GAClD,GAAIh+G,EACF,OAAA,CAEH,CAAC,MAAO+G,GAER,CAEH,OAAO,IACT,CAKA,IAAIo3G,GAAsB,KC7FnB,MAAMC,GACX,4CAOK,SAASC,GAAgBC,EAAcC,GAC5C,OAAOC,KAAcH,gBAAgBC,EAAcC,EACrD,CAUO,SAASE,GAAkBr9G,EAAMs9G,GACtC,OAAOC,GAAmBv9G,EAAMs9G,EAAqB,IAAI/1G,KAAK,GAChE,CAWO,SAASg2G,GAAmBv9G,EAAMs9G,EAAqBE,GAC5D,GACEx9G,EAAKy9G,UAAYC,KAAKC,oBACtB39G,EAAKy9G,UAAYC,KAAKE,UAElBN,EACFE,EAAYppH,KAAKkD,OAAO0I,EAAK69G,WAAW5rG,QAAQ,gBAAiB,KAEjEurG,EAAYppH,KAAK4L,EAAK69G,eAEnB,CACL,IAAIztH,EACJ,IAAKA,EAAI4P,EAAK+0C,WAAY3kD,EAAGA,EAAIA,EAAE0tH,YACjCP,GAAmBntH,EAAGktH,EAAqBE,EAE9C,CACD,OAAOA,CACT,CAMO,SAASO,GAAW1qH,GACzB,MAAO,oBAAqBA,CAC9B,CAQO,SAAS2qH,GAAeh+G,EAAMk9G,EAAc/4G,GACjD,OAAOnE,EAAKg+G,eAAed,EAAc/4G,IAAS,EACpD,CAQO,SAASw1B,GAAMskF,GACpB,OAAO,IAAIhhD,WAAYC,gBAAgB+gD,EAAK,kBAC9C,CAUO,SAASC,GAAkBC,EAAa1oH,GAC7C,OAAA,SAKYuK,EAAMo+G,GACd,MAAMtrH,EAAQqrH,EAAY3rH,UACZyC,IAAZQ,EAAwBA,EAAUhH,KAClCuR,EACAo+G,GAEF,QAAcnpH,IAAVnC,EAAqB,CAIvBnC,EAFEytH,EAAYA,EAAYxuH,OAAS,GAErBkD,EACf,CAEH,CACJ,CAUO,SAASurH,GAAgBF,EAAa1oH,GAC3C,OAAA,SAKYuK,EAAMo+G,GACd,MAAMtrH,EAAQqrH,EAAY3rH,UACZyC,IAAZQ,EAAwBA,EAAUhH,KAClCuR,EACAo+G,GAEF,QAAcnpH,IAAVnC,EAAqB,CAErBsrH,EAAYA,EAAYxuH,OAAS,GAE7BwE,KAAKtB,EACZ,CAEH,CACJ,CAUO,SAASwrH,GAAaH,EAAa1oH,GACxC,OAAA,SAKYuK,EAAMo+G,GACd,MAAMtrH,EAAQqrH,EAAY3rH,UACZyC,IAAZQ,EAAwBA,EAAUhH,KAClCuR,EACAo+G,QAEYnpH,IAAVnC,IACFsrH,EAAYA,EAAYxuH,OAAS,GAAKkD,EAG1C,CACJ,CAWO,SAASyrH,GAAyBJ,EAAa7qH,EAAUmC,GAC9D,OAAA,SAKYuK,EAAMo+G,GACd,MAAMtrH,EAAQqrH,EAAY3rH,UACZyC,IAAZQ,EAAwBA,EAAUhH,KAClCuR,EACAo+G,GAEF,QAAcnpH,IAAVnC,EAAqB,CACvB,MAAMO,EACJ+qH,EAAYA,EAAYxuH,OAAS,GAE7BuU,OAAoBlP,IAAb3B,EAAyBA,EAAW0M,EAAKw+G,UACtD,IAAIrlH,EACAgL,KAAQ9Q,EACV8F,EAAQ9F,EAAO8Q,IAEfhL,EAAQ,GACR9F,EAAO8Q,GAAQhL,GAEjBA,EAAM/E,KAAKtB,EACZ,CAEH,CACJ,CAUO,SAAS2rH,GAAyBN,EAAa7qH,EAAUmC,GAC9D,OAAA,SAKYuK,EAAMo+G,GACd,MAAMtrH,EAAQqrH,EAAY3rH,UACZyC,IAAZQ,EAAwBA,EAAUhH,KAClCuR,EACAo+G,GAEF,QAAcnpH,IAAVnC,EAAqB,CAErBsrH,EAAYA,EAAYxuH,OAAS,QAETqF,IAAb3B,EAAyBA,EAAW0M,EAAKw+G,WACvC1rH,CAChB,CAEH,CACJ,CAWO,SAAS4rH,GAAkBC,EAAYlpH,GAC5C,OAAO,SAAUuK,EAAMlN,EAAOsrH,GAC5BO,EAAWnsH,UACGyC,IAAZQ,EAAwBA,EAAUhH,KAClCuR,EACAlN,EACAsrH,GAGAA,EAAYA,EAAYxuH,OAAS,GAEToQ,KACfW,YAAYX,EAC3B,CACA,CAcO,SAAS4+G,GAAoBD,EAAYlpH,GAC9C,IAAIopH,EAAeC,EACnB,OAAO,SAAU9+G,EAAMlN,EAAOsrH,GAC5B,QAAsBnpH,IAAlB4pH,EAA6B,CAC/BA,EAAgB,CAAA,EAChB,MAAME,EAAc,CAAA,EACpBA,EAAY/+G,EAAKw+G,WAAaG,EAC9BE,EAAc7+G,EAAKk9G,cAAgB6B,EACnCD,EAAcE,GAAsBh/G,EAAKw+G,UAC1C,CACDS,GAAUJ,EAAeC,EAAahsH,EAAOsrH,EACjD,CACA,CAeO,SAASY,GAAsBE,EAAeC,GACnD,OAAA,SAOYrsH,EAAOsrH,EAAagB,GAC5B,MAGMp/G,EAFJo+G,EAAYA,EAAYxuH,OAAS,GAEdoQ,KACrB,IAAIq/G,EAAWH,OACEjqH,IAAboqH,IACFA,EAAWD,GAKb,OAAOnC,QADiBhoH,IAAtBkqH,EAAkCA,EAAoBn/G,EAAKk9G,aACD,EAE9D,CACJ,CASO,MAAMoC,GAA+BN,KAarC,SAASO,GAAalsH,EAAQmsH,GACnC,MAAM5vH,EAAS4vH,EAAY5vH,OACrB6vH,EAAW,IAAI3uH,MAAMlB,GAC3B,IAAK,IAAIS,EAAI,EAAGA,EAAIT,IAAUS,EAC5BovH,EAASpvH,GAAKgD,EAAOmsH,EAAYnvH,IAEnC,OAAOovH,CACT,CAYO,SAASC,GAAgBC,EAAeC,EAAWC,GAExD,IAAIxvH,EAAGuE,EACP,IAFAirH,OAA8B5qH,IAAhB4qH,EAA4BA,EAAc,CAAA,EAEnDxvH,EAAI,EAAGuE,EAAK+qH,EAAc/vH,OAAQS,EAAIuE,IAAMvE,EAC/CwvH,EAAYF,EAActvH,IAAMuvH,EAElC,OAAOC,CACT,CAUO,SAASC,GAAUC,EAAW//G,EAAMo+G,EAAa3oH,GACtD,IAAIrF,EACJ,IAAKA,EAAI4P,EAAKmsG,kBAAmB/7G,EAAGA,EAAIA,EAAE4vH,mBAAoB,CAC5D,MAAMC,EAAUF,EAAU3vH,EAAE8sH,cAC5B,QAAgBjoH,IAAZgrH,EAAuB,CACzB,MAAMC,EAASD,EAAQ7vH,EAAEouH,gBACVvpH,IAAXirH,GACFA,EAAO1tH,KAAKiD,EAASrF,EAAGguH,EAE3B,CACF,CACH,CAaO,SAAS+B,GAAgB9sH,EAAQ0sH,EAAW//G,EAAMo+G,EAAa3oH,GAGpE,OAFA2oH,EAAYhqH,KAAKf,GACjBysH,GAAUC,EAAW//G,EAAMo+G,EAAa3oH,GACf2oH,EAAYzkH,KACvC,CAwBO,SAASslH,GACdJ,EACAC,EACApnH,EACA0mH,EACAhpH,EACAK,GAEA,MAAM7F,QAAmBqF,IAATG,EAAqBA,EAAOsC,GAAQ9H,OACpD,IAAIkD,EAAOkN,EACX,IAAK,IAAI3P,EAAI,EAAGA,EAAIT,IAAUS,EAC5ByC,EAAQ4E,EAAOrH,QACD4E,IAAVnC,IACFkN,EAAO8+G,EAAYtsH,UACLyC,IAAZQ,EAAwBA,EAAUhH,KAClCqE,EACAsrH,OACSnpH,IAATG,EAAqBA,EAAK/E,QAAK4E,QAEpBA,IAAT+K,GACF6+G,EAAc7+G,EAAKk9G,cAAcl9G,EAAKw+G,WAAWhsH,KAC/CiD,EACAuK,EACAlN,EACAsrH,GAKV,CAyBO,SAASgC,GACd/sH,EACAwrH,EACAC,EACApnH,EACA0mH,EACAhpH,EACAK,GAIA,OAFA2oH,EAAYhqH,KAAKf,GACjB4rH,GAAUJ,EAAeC,EAAapnH,EAAQ0mH,EAAahpH,EAAMK,GAC9B2oH,EAAYzkH,KACjD,CAEA,IAAI0mH,GAuBAC,GAPG,SAASC,KAId,YAHuBtrH,IAAnBorH,IAAyD,oBAAlBG,gBACzCH,GAAiB,IAAIG,eAEhBH,EACT,CAmBO,SAASjD,KAId,YAHkBnoH,IAAdqrH,IAA+C,oBAAb9hH,WACpC8hH,GAAY9hH,SAASiiH,eAAeC,eAAe,GAAI,GAAI,OAEtDJ,EACT,CChdA,IAAAK,GA9EA,cAAqCzqH,EAInC,WAAA3H,CAAY6K,GACV1F,QAKAjF,KAAKkN,KACLlN,KAAK6hE,kBAAoB7hE,KAAK6hE,kBAAkB36D,KAAKlH,MAMrDA,KAAK6iF,QAAUl4E,EAAQ6yE,QAAU,EAMjCx9E,KAAKmyH,QAAUxnH,EAAQynH,OAEvBpyH,KAAK26B,QAAS,EACd36B,KAAKmkE,OAAQ,CACd,CAKD,OAAAkuD,CAAQnlH,GACN,GAAIA,IAASlN,KAAKkN,KAMhB,GALIlN,KAAKkN,MACPlN,KAAKkN,KAAK5G,oBAAoBwB,EAAkB9H,KAAK6hE,mBAEvD7hE,KAAKkN,KAAOA,EACZlN,KAAK26B,OAASztB,EAAKC,aAAerB,EAC9B9L,KAAK26B,OACP36B,KAAKsyH,iBACA,CACL,GAAIplH,aAAgB0/E,GAAW,CAC7B,MAAM95E,EAAQ5F,EAAKsuB,WACf1oB,aAAiB/D,QAAU+D,EAAMupB,cACnCvpB,EAAMupB,YAAc,YAEvB,CACDnvB,EAAK5H,iBAAiBwC,EAAkB9H,KAAK6hE,kBAC9C,CAEJ,CAMD,UAAAywD,GACE/pH,GACD,CAED,QAAAgqH,GACEvyH,KAAKmkE,OAAQ,EACbnkE,KAAK4F,cAAckC,EACpB,CAED,iBAAA+5D,GACM7hE,KAAKkN,KAAKC,aAAerB,IAC3B9L,KAAK26B,QAAS,EACd36B,KAAKsyH,aAER,CAED,eAAA7xH,GACET,KAAKkN,KAAK5G,oBAAoBwB,EAAkB9H,KAAK6hE,kBACtD,GCvFI,MAAM2wD,GACEzE,GAsHR,SAAS0E,GAAqB1yH,GACnC,OAAQA,GACN,KAAK8tH,GACH,OAAOn7G,aACT,KAAKo7G,GACH,OAAOtnB,YACT,QACE,OAAO9zF,aAEb,CAEA,IAAAggH,GA7GA,MAME,WAAA5yH,CAAYC,EAAM4yH,GAKhB3yH,KAAK8K,OAAS,KAMd9K,KAAKm7F,MAAQp7F,EAEbkU,GACElU,IAAS8tH,IAAgB9tH,IAAS+tH,GAClC,wFAOF9tH,KAAK4yH,YAAmBpsH,IAAVmsH,EAAsBA,EAAQH,EAC7C,CAOD,MAAAK,CAAOn/G,GAEL,OADA1T,KAAK8K,OAAS,IAAK2nH,GAAqBzyH,KAAKm7F,OAA/B,CAAuCznF,GAC9C1T,IACR,CAOD,SAAA8yH,CAAUpoH,GAER,OADA1K,KAAK8K,OAAS2nH,GAAqBzyH,KAAKm7F,OAAOzpC,KAAKhnD,GAC7C1K,IACR,CAQD,eAAA+yH,CAAgBp5G,GAEd,OADA3Z,KAAK8K,OAAS,IAAK2nH,GAAqBzyH,KAAKm7F,OAA/B,CAAuCxhF,GAC9C3Z,IACR,CAKD,OAAA0uB,GACE,OAAO1uB,KAAKm7F,KACb,CAMD,QAAA9vF,GACE,OAAOrL,KAAK8K,MACb,CAKD,QAAAkoH,GACE,OAAOhzH,KAAK4yH,MACb,CAMD,OAAAj/G,GACE,OAAO3T,KAAK8K,OAAS9K,KAAK8K,OAAO3J,OAAS,CAC3C,GCzHY8xH,GACP,mBADOA,GAEH,uBC4ZZ,IAAAC,GAjUA,MAIE,WAAApzH,CAAY6K,GACV3K,KAAKmzH,IAAMxoH,EAAQyoH,aACnB,MAAMC,EAAKrzH,KAAKmzH,IAEhBnzH,KAAKszH,YAAc3oH,EAAQ4oH,YAAc,EAEzCvzH,KAAKwzH,qBAAuBH,EAAGI,gBAC/BzzH,KAAK0zH,yBAA2B,KAEhC1zH,KAAK2zH,aAAeN,EAAGO,oBACvB5zH,KAAK6zH,aAAeR,EAAGS,qBAIvB,MAAMC,EAAeV,EAAGW,aAAaX,EAAGY,eACxCZ,EAAGa,aACDH,EACAppH,EAAQopH,cAnHgB,qUAqH1BV,EAAGc,cAAcJ,GACjB,MAAMK,EAAiBf,EAAGW,aAAaX,EAAGgB,iBAC1ChB,EAAGa,aACDE,EACAzpH,EAAQypH,gBAzGkB,6NA2G5Bf,EAAGc,cAAcC,GACjBp0H,KAAKs0H,qBAAuBjB,EAAGkB,gBAC/BlB,EAAGmB,aAAax0H,KAAKs0H,qBAAsBP,GAC3CV,EAAGmB,aAAax0H,KAAKs0H,qBAAsBF,GAC3Cf,EAAGoB,YAAYz0H,KAAKs0H,sBAGpBt0H,KAAK00H,4BAA8BrB,EAAGsB,eAEtCtB,EAAGuB,WAAWvB,EAAGxF,aAAc7tH,KAAK00H,6BACpCrB,EAAGwB,WACDxB,EAAGxF,aACH,IAAIn7G,aAJgB,EAAE,GAAI,EAAG,GAAI,GAAI,EAAG,EAAG,GAAI,EAAG,EAAG,GAAI,EAAG,IAK5D2gH,EAAGtF,aAGL/tH,KAAK80H,4BAA8BzB,EAAG0B,kBACpC/0H,KAAKs0H,qBACL,cAEFt0H,KAAKg1H,6BAA+B3B,EAAG4B,mBACrCj1H,KAAKs0H,qBACL,gBAEFt0H,KAAKk1H,6BAA+B7B,EAAG4B,mBACrCj1H,KAAKs0H,qBACL,aAEFt0H,KAAKm1H,6BAA+B9B,EAAG4B,mBACrCj1H,KAAKs0H,qBACL,WAQFt0H,KAAKo1H,UAAY,GACjBzqH,EAAQ0qH,UACN3uH,OAAOC,KAAKgE,EAAQ0qH,UAAUlqH,SAASuK,IACrC1V,KAAKo1H,UAAUzvH,KAAK,CAClBtB,MAAOsG,EAAQ0qH,SAAS3/G,GACxB4/G,SAAUjC,EAAG4B,mBAAmBj1H,KAAKs0H,qBAAsB5+G,IAC3D,GAEP,CAMD,KAAA6/G,GACE,OAAOv1H,KAAKmzH,GACb,CAQD,IAAAqC,CAAK/3E,GACH,MAAM41E,EAAKrzH,KAAKu1H,QACVhyB,EAAc,CAClB8vB,EAAGoC,mBAAqBz1H,KAAKszH,YAC7BD,EAAGqC,oBAAsB11H,KAAKszH,aAShC,GALAD,EAAGsC,gBAAgBtC,EAAGuC,YAAa51H,KAAK61H,kBACxCxC,EAAGyC,iBAAiBzC,EAAG0C,aAAc/1H,KAAKg2H,kBAC1C3C,EAAG1rC,SAAS,EAAG,EAAG4b,EAAY,GAAIA,EAAY,KAI3CvjG,KAAK0zH,0BACN1zH,KAAK0zH,yBAAyB,KAAOnwB,EAAY,IACjDvjG,KAAK0zH,yBAAyB,KAAOnwB,EAAY,GACjD,CACAvjG,KAAK0zH,yBAA2BnwB,EAGhC,MAAMt6E,EAAQ,EACRgtG,EAAiB5C,EAAG6C,KACpB7xE,EAAS,EACTr9B,EAASqsG,EAAG6C,KACZn2H,EAAOszH,EAAG8C,cACVh0H,EAAO,KACbkxH,EAAG+C,YAAY/C,EAAGgD,WAAYr2H,KAAKwzH,sBACnCH,EAAGiD,WACDjD,EAAGgD,WACHptG,EACAgtG,EACA1yB,EAAY,GACZA,EAAY,GACZl/C,EACAr9B,EACAjnB,EACAoC,GAGFkxH,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGmD,mBAAoBnD,EAAGoD,QAC1DpD,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGqD,eAAgBrD,EAAGsD,eACtDtD,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGuD,eAAgBvD,EAAGsD,eAGtDtD,EAAGwD,qBACDxD,EAAGuC,YACHvC,EAAGyD,kBACHzD,EAAGgD,WACHr2H,KAAKwzH,qBACL,GAGFH,EAAG0D,oBACD1D,EAAG0C,aACH1C,EAAG2D,kBACHzzB,EAAY,GACZA,EAAY,IAEd8vB,EAAG4D,wBACD5D,EAAGuC,YACHvC,EAAG6D,iBACH7D,EAAG0C,aACH/1H,KAAK6zH,aAER,CACF,CASD,KAAA3vH,CAAMu5C,EAAY05E,EAAUC,EAAYC,GACtC,MAAMhE,EAAKrzH,KAAKu1H,QACV7hH,EAAO+pC,EAAW/pC,KASxB,GAPA2/G,EAAGsC,gBACDtC,EAAGuC,YACHuB,EAAWA,EAAStB,iBAAmB,MAEzCxC,EAAGiE,cAAcjE,EAAGkE,UACpBlE,EAAG+C,YAAY/C,EAAGgD,WAAYr2H,KAAKwzH,uBAE9B2D,EAAU,CAGb,MAAMK,EAAW9uH,EAAO2qH,EAAGxjH,QAC3B,IAAK4tC,EAAW4oB,cAAcmxD,GAAW,CACvC,MAAMrJ,EAAakF,EAAGoE,uBAClBtJ,GAAcA,EAAWC,wBAC3BiF,EAAGqE,WAAW,EAAK,EAAK,EAAK,GAC7BrE,EAAGsE,WAAW,GACdtE,EAAG1uH,MAAM0uH,EAAGuE,iBAAmBvE,EAAGwE,mBAGpCp6E,EAAW4oB,cAAcmxD,IAAY,CACtC,CACF,CAEDnE,EAAG/pG,QAAQ+pG,EAAGyE,YACdzE,EAAG0E,OAAO1E,EAAG2E,OACb3E,EAAG4E,UAAU5E,EAAG6E,IAAK7E,EAAG8E,qBACxB9E,EAAG1rC,SAAS,EAAG,EAAG0rC,EAAGoC,mBAAoBpC,EAAGqC,qBAE5CrC,EAAGuB,WAAWvB,EAAGxF,aAAc7tH,KAAK00H,6BAEpCrB,EAAG+E,WAAWp4H,KAAKs0H,sBACnBjB,EAAGgF,wBAAwBr4H,KAAK80H,6BAChCzB,EAAGiF,oBACDt4H,KAAK80H,4BACL,EACAzB,EAAGpF,OACH,EACA,EACA,GAEFoF,EAAGkF,UAAUv4H,KAAKg1H,6BAA8BthH,EAAK,GAAIA,EAAK,IAC9D2/G,EAAGmF,UAAUx4H,KAAKm1H,6BAA8B,GAEhD,MAAMroF,EAAU2Q,EAAWI,iBAAiBJ,EAAWoJ,YAAY/Z,QACnEumF,EAAGoF,UAAUz4H,KAAKk1H,6BAA8BpoF,GAEhD9sC,KAAK04H,cAAcj7E,GAEf25E,GACFA,EAAW/D,EAAI51E,GAEjB41E,EAAGsF,WAAWtF,EAAGuF,UAAW,EAAG,GAC3BvB,GACFA,EAAYhE,EAAI51E,EAEnB,CAKD,cAAAo4E,GACE,OAAO71H,KAAK2zH,YACb,CAKD,cAAAqC,GACE,OAAOh2H,KAAK6zH,YACb,CAOD,aAAA6E,CAAcj7E,GACZ,MAAM41E,EAAKrzH,KAAKu1H,QAEhB,IAAIlxH,EACAw0H,EAAc,EAClB74H,KAAKo1H,UAAUjqH,SAAQ,SAAU2tH,GAO/B,GANAz0H,EAC2B,mBAAlBy0H,EAAQz0H,MACXy0H,EAAQz0H,MAAMo5C,GACdq7E,EAAQz0H,MAGVA,aAAiB+N,mBAAqB/N,aAAiB6+G,UAEpD4V,EAAQC,UACXD,EAAQC,QAAU1F,EAAGI,iBAEvBJ,EAAGiE,cAAcjE,EAAG,UAAUwF,MAC9BxF,EAAG+C,YAAY/C,EAAGgD,WAAYyC,EAAQC,SACtC1F,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGmD,mBAAoBnD,EAAGoD,QAC1DpD,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGqD,eAAgBrD,EAAGsD,eACtDtD,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGuD,eAAgBvD,EAAGsD,eAElDtyH,aAAiB6+G,UACnBmQ,EAAGiD,WACDjD,EAAGgD,WACH,EACAhD,EAAG6C,KACH7C,EAAG6C,KACH7xH,EAAMoL,MACNpL,EAAMqL,OACN,EACA2jH,EAAG8C,cACH,IAAI3jH,WAAWnO,EAAMlC,OAGvBkxH,EAAGiD,WACDjD,EAAGgD,WACH,EACAhD,EAAG6C,KACH7C,EAAG6C,KACH7C,EAAG8C,cACH9xH,GAKJgvH,EAAGmF,UAAUM,EAAQxD,SAAUuD,UAC1B,GAAIx2H,MAAMC,QAAQ+B,GACvB,OAAQA,EAAMlD,QACZ,KAAK,EAEH,YADAkyH,EAAGkF,UAAUO,EAAQxD,SAAUjxH,EAAM,GAAIA,EAAM,IAEjD,KAAK,EAEH,YADAgvH,EAAG2F,UAAUF,EAAQxD,SAAUjxH,EAAM,GAAIA,EAAM,GAAIA,EAAM,IAE3D,KAAK,EAQH,YAPAgvH,EAAG4F,UACDH,EAAQxD,SACRjxH,EAAM,GACNA,EAAM,GACNA,EAAM,GACNA,EAAM,IAGV,QACE,WAEsB,iBAAVA,GAChBgvH,EAAGoF,UAAUK,EAAQxD,SAAUjxH,EAEvC,GACG,GC3ZI,SAASyR,KACd,MAAO,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EACvD,CAOO,SAASojH,GAAcC,EAAMnjH,GAOlC,OANAmjH,EAAK,GAAKnjH,EAAU,GACpBmjH,EAAK,GAAKnjH,EAAU,GACpBmjH,EAAK,GAAKnjH,EAAU,GACpBmjH,EAAK,GAAKnjH,EAAU,GACpBmjH,EAAK,IAAMnjH,EAAU,GACrBmjH,EAAK,IAAMnjH,EAAU,GACdmjH,CACT,CCiBO,MAAMC,GAAiB,CAC5BC,kBAAmB,qBACnBC,uBAAwB,wBACxBC,KAAM,SACNC,KAAM,SACNpqF,WAAY,eACZC,SAAU,aACVoqF,iBAAkB,mBAClBC,YAAa,eACbC,cAAe,kBAQJC,GAAgB,CAC3BzD,cPD2B,KOE3B0D,ePI4B,KOH5BC,aPS0B,KOR1B7L,MAAOA,IA0DH8L,GAAc,CAAA,EAMpB,SAASC,GAAwBzyH,GAC/B,MAAO,UAAYA,CACrB,CAEA,IAAI0yH,GAA4B,EAw+BzB,SAASC,GAAwB/L,GACtC,IAAInzG,EAAS,EACb,IAAK,IAAIpZ,EAAI,EAAGA,EAAIusH,EAAWhtH,OAAQS,IAAK,CAC1C,MAAMu4H,EAAOhM,EAAWvsH,GACxBoZ,GAAUm/G,EAAKzmH,KAAO0mH,GAAoBD,EAAKp6H,KAChD,CACD,OAAOib,CACT,CAOA,SAASo/G,GAAoBr6H,GAC3B,OAAQA,GACN,KAAK65H,GAAczD,cACjB,OAAO3jH,WAAWovF,kBACpB,KAAKg4B,GAAcC,eACjB,OAAOvzB,YAAY1E,kBACrB,KAAKg4B,GAAcE,aACjB,OAAOtzB,YAAY5E,kBACrB,KAAKg4B,GAAc3L,MACnB,QACE,OAAOv7G,aAAakvF,kBAE1B,CAEA,IAAAy4B,GA90BA,cAA0Br1H,EAIxB,WAAAlF,CAAY6K,GACV1F,QACA0F,EAAUA,GAAW,GAGrB3K,KAAKs6H,6BAA+Bt6H,KAAKu6H,uBAAuBrzH,KAAKlH,MAGrEA,KAAKw6H,iCACHx6H,KAAKy6H,2BAA2BvzH,KAAKlH,MAMvCA,KAAK06H,gBAAkB/vH,EAAQgwH,eAC3BX,GAAwBrvH,EAAQgwH,gBArMxC,WACE,MAAMpzH,EAAM,UAAY0yH,GAExB,OADAA,IAA6B,EACtB1yH,CACT,CAkMQqzH,GAMJ56H,KAAKmzH,IAlMT,SAA4B5rH,GAC1B,IAAIszH,EAAYd,GAAYxyH,GAC5B,IAAKszH,EAAW,CACd,MAAMhrH,EAASE,SAASC,cAAc,UACtCH,EAAOJ,MAAQ,EACfI,EAAOH,OAAS,EAChBG,EAAOU,MAAM2oB,SAAW,WACxBrpB,EAAOU,MAAMg0C,KAAO,IAEpBs2E,EAAY,CAACC,MAAO,EAAG3qH,QADPF,GAAWJ,IAE3BkqH,GAAYxyH,GAAOszH,CACpB,CAGD,OADAA,EAAUC,OAAS,EACZD,EAAU1qH,OACnB,CAmLe4qH,CAAmB/6H,KAAK06H,iBAMnC16H,KAAKg7H,aAAe,GAMpBh7H,KAAKi7H,gBAAkB,GAMvBj7H,KAAKk7H,gBAAkB,KAMvBl7H,KAAKm7H,qBAAsB,EAE3B,MAAMtrH,EAAS7P,KAAKmzH,IAAItjH,OAExBA,EAAOvK,iBACL2tH,GACAjzH,KAAKs6H,8BAEPzqH,EAAOvK,iBACL2tH,GACAjzH,KAAKw6H,kCAOPx6H,KAAKo7H,oBlMxVA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GkM8VrBp7H,KAAKq7H,mBlM9VA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GkMoWrBr7H,KAAKs7H,SDhYA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,GCsYnDt7H,KAAKu7H,2BAA6B,GAMlCv7H,KAAKw7H,0BAA4B,GAQjCx7H,KAAKo1H,UAAY,GACbzqH,EAAQ0qH,UACVr1H,KAAKy7H,YAAY9wH,EAAQ0qH,UAU3Br1H,KAAK07H,mBAAqB/wH,EAAQgxH,cAC9BhxH,EAAQgxH,cAAc7wF,KACnBngC,GACC,IAAIixH,GAAwB,CAC1BxI,aAAcpzH,KAAKmzH,IACnBI,WAAY5oH,EAAQ4oH,WACpBQ,aAAcppH,EAAQopH,aACtBK,eAAgBzpH,EAAQypH,eACxBiB,SAAU1qH,EAAQ0qH,aAGxB,CAAC,IAAIuG,GAAwB,CAACxI,aAAcpzH,KAAKmzH,OAMrDnzH,KAAK67H,qBAAuB,KAM5B77H,KAAK67D,WAAa99B,KAAKC,KACxB,CAKD,WAAAy9F,CAAYpG,GACVr1H,KAAKo1H,UAAY,GACjBp1H,KAAK87H,YAAYzG,EAClB,CAKD,WAAAyG,CAAYzG,GACV,IAAK,MAAM3/G,KAAQ2/G,EACjBr1H,KAAKo1H,UAAUzvH,KAAK,CAClB+P,KAAMA,EACNrR,MAAOgxH,EAAS3/G,IAGrB,CAMD,qBAAAqmH,CAAsBpB,GACpB,OAAO36H,KAAK06H,kBAAoBV,GAAwBW,EACzD,CAQD,YAAAqB,CAAatmH,GACX,GAAIA,KAAQ1V,KAAKi7H,gBACf,OAAOj7H,KAAKi7H,gBAAgBvlH,GAE9B,MAAMtT,EAAYpC,KAAKmzH,IAAI6I,aAAatmH,GAExC,OADA1V,KAAKi7H,gBAAgBvlH,GAAQtT,EACtBA,CACR,CAQD,UAAAwyH,CAAWj7G,GACT,MAAM05G,EAAKrzH,KAAKmzH,IACV8I,EAAYvzH,EAAOiR,GACzB,IAAIuiH,EAAcl8H,KAAKg7H,aAAaiB,GACpC,IAAKC,EAAa,CAEhBA,EAAc,CACZviH,OAAQA,EACRwiH,YAHkB9I,EAAGsB,gBAKvB30H,KAAKg7H,aAAaiB,GAAaC,CAChC,CACD7I,EAAGuB,WAAWj7G,EAAO+U,UAAWwtG,EAAYC,YAC7C,CAOD,eAAAC,CAAgBziH,GACd,MAAM05G,EAAKrzH,KAAKmzH,IAChBnzH,KAAK40H,WAAWj7G,GAChB05G,EAAGwB,WAAWl7G,EAAO+U,UAAW/U,EAAOtO,WAAYsO,EAAOq5G,WAC3D,CAKD,YAAAqJ,CAAaC,GACX,MAAMjJ,EAAKrzH,KAAKmzH,IACV8I,EAAYvzH,EAAO4zH,GACnBC,EAAmBv8H,KAAKg7H,aAAaiB,GACvCM,IAAqBlJ,EAAGmJ,iBAC1BnJ,EAAGgJ,aAAaE,EAAiBJ,oBAE5Bn8H,KAAKg7H,aAAaiB,EAC1B,CAKD,eAAAx7H,GACE,MAAMoP,EAAS7P,KAAKmzH,IAAItjH,OACxBA,EAAOvJ,oBACL2sH,GACAjzH,KAAKs6H,8BAEPzqH,EAAOvJ,oBACL2sH,GACAjzH,KAAKw6H,kCAhYX,SAAuBjzH,GACrB,MAAMszH,EAAYd,GAAYxyH,GAC9B,IAAKszH,EACH,OAIF,GADAA,EAAUC,OAAS,EACfD,EAAUC,MAAQ,EACpB,OAGF,MAAMzH,EAAKwH,EAAU1qH,QACf/N,EAAYixH,EAAG2I,aAAa,sBAC9B55H,GACFA,EAAUq6H,cAEZ,MAAM5sH,EAASwjH,EAAGxjH,OAClBA,EAAOJ,MAAQ,EACfI,EAAOH,OAAS,SAETqqH,GAAYxyH,EACrB,CA8WI2I,CAAclQ,KAAK06H,wBAEZ16H,KAAKmzH,GACb,CAUD,WAAAuJ,CAAYj/E,EAAYk/E,EAAmBC,GACzC,MAAMvJ,EAAKrzH,KAAKmzH,IACVtjH,EAAS7P,KAAK68H,YACdnpH,EAAO+pC,EAAW/pC,KAClB0nB,EAAaqiB,EAAWriB,WAG5BvrB,EAAOJ,QAAUiE,EAAK,GAAK0nB,GAC3BvrB,EAAOH,SAAWgE,EAAK,GAAK0nB,IAE5BvrB,EAAOJ,MAAQiE,EAAK,GAAK0nB,EACzBvrB,EAAOH,OAASgE,EAAK,GAAK0nB,EAC1BvrB,EAAOU,MAAMd,MAAQiE,EAAK,GAAK,KAC/B7D,EAAOU,MAAMb,OAASgE,EAAK,GAAK,MAIlC,IAAK,IAAI9R,EAAI5B,KAAK07H,mBAAmBv6H,OAAS,EAAGS,GAAK,EAAGA,IACvD5B,KAAK07H,mBAAmB95H,GAAG4zH,KAAK/3E,GAGlC41E,EAAG+C,YAAY/C,EAAGgD,WAAY,MAE9BhD,EAAGqE,WAAW,EAAK,EAAK,EAAK,GAC7BrE,EAAGyJ,WAAW,EAAK,GACnBzJ,EAAGsE,WAAW,GACdtE,EAAG1uH,MAAM0uH,EAAGuE,iBAAmBvE,EAAGwE,kBAElCxE,EAAG0E,OAAO1E,EAAG2E,OACb3E,EAAG4E,UAAU5E,EAAG6E,IAAKyE,EAAoBtJ,EAAG0J,KAAO1J,EAAG8E,qBAClDyE,GACFvJ,EAAG0E,OAAO1E,EAAGyE,YACbzE,EAAG2J,UAAU3J,EAAG4J,SAEhB5J,EAAG/pG,QAAQ+pG,EAAGyE,WAEjB,CAQD,WAAA1B,CAAY2C,EAASmE,EAAMC,GACzB,MAAM9J,EAAKrzH,KAAKmzH,IAChBE,EAAGiE,cAAcjE,EAAGkE,SAAW2F,GAC/B7J,EAAG+C,YAAY/C,EAAGgD,WAAY0C,GAC9B1F,EAAGmF,UAAUx4H,KAAKi1H,mBAAmBkI,GAAcD,EACpD,CAWD,yBAAAE,CACE3/E,EACA4/E,EACAV,EACAC,GAEA,MAAMvJ,EAAKrzH,KAAKmzH,IACVz/G,EAAO2pH,EAAa1pH,UAE1B0/G,EAAGsC,gBAAgBtC,EAAGuC,YAAayH,EAAaC,kBAChDjK,EAAGyC,iBAAiBzC,EAAG0C,aAAcsH,EAAaE,kBAClDlK,EAAG1rC,SAAS,EAAG,EAAGj0E,EAAK,GAAIA,EAAK,IAChC2/G,EAAG+C,YAAY/C,EAAGgD,WAAYgH,EAAaG,cAC3CnK,EAAGqE,WAAW,EAAK,EAAK,EAAK,GAC7BrE,EAAGyJ,WAAW,EAAK,GACnBzJ,EAAGsE,WAAW,GACdtE,EAAG1uH,MAAM0uH,EAAGuE,iBAAmBvE,EAAGwE,kBAClCxE,EAAG0E,OAAO1E,EAAG2E,OACb3E,EAAG4E,UAAU5E,EAAG6E,IAAKyE,EAAoBtJ,EAAG0J,KAAO1J,EAAG8E,qBAClDyE,GACFvJ,EAAG0E,OAAO1E,EAAGyE,YACbzE,EAAG2J,UAAU3J,EAAG4J,SAEhB5J,EAAG/pG,QAAQ+pG,EAAGyE,WAEjB,CAOD,YAAA2F,CAAa/vH,EAAO1L,GAClB,MAAMqxH,EAAKrzH,KAAKmzH,IAChBnzH,KAAKg8H,aAAa,0BAElB,MAAM0B,EAAcrK,EAAGyG,aAGjB6D,EAAW37H,EAAM0L,EACjBkwH,EAHc,EAGElwH,EACtB2lH,EAAGoK,aAAapK,EAAGuF,UAAW+E,EAAUD,EAAaE,EACtD,CAQD,YAAAC,CAAapgF,EAAY25E,EAAYC,GAEnC,IAAK,IAAIz1H,EAAI,EAAGuE,EAAKnG,KAAK07H,mBAAmBv6H,OAAQS,EAAIuE,EAAIvE,IACvDA,IAAMuE,EAAK,EACbnG,KAAK07H,mBAAmB95H,GAAGsC,MACzBu5C,EACA,KACA25E,EACAC,GAGFr3H,KAAK07H,mBAAmB95H,GAAGsC,MACzBu5C,EACAz9C,KAAK07H,mBAAmB95H,EAAI,GAInC,CAKD,SAAAi7H,GACE,OAAyC78H,KAAKmzH,IAAU,MACzD,CAMD,KAAAoC,GACE,OAAOv1H,KAAKmzH,GACb,CAMD,eAAA2K,CAAgBrgF,GACd,MAAM/pC,EAAO+pC,EAAW/pC,KAClBkJ,EAAW6gC,EAAWjE,UAAU58B,SAChCwe,EAAaqiB,EAAWriB,WAE9Bp7B,KAAK+9H,qBACH3E,GAAeG,KACkB,MAAhCx7F,KAAKC,MAAQh+B,KAAK67D,aAErB77D,KAAK+9H,qBAAqB3E,GAAeI,KAAM/7E,EAAWjE,UAAUpE,MACpEp1C,KAAK+9H,qBACH3E,GAAehqF,WACfqO,EAAWjE,UAAU78B,YAEvB3c,KAAK+9H,qBAAqB3E,GAAeM,YAAat+F,GACtDp7B,KAAKg+H,oBAAoB5E,GAAeK,iBAAkB,CACxD/lH,EAAK,GACLA,EAAK,KAEP1T,KAAK+9H,qBAAqB3E,GAAe/pF,SAAUzyB,EACpD,CAMD,wBAAAqhH,CAAyBtlF,GACvB,MAAMulF,EAAMl+H,KAAKi1H,mBAAmBmE,GAAeO,eACnD35H,KAAKu1H,QAAQiD,UAAU0F,EAAKvlF,EAAU,EAAI,GAGtCA,GACF34C,KAAK+9H,qBAAqB3E,GAAeM,YAAa,GAEzD,CAMD,aAAAhB,CAAcj7E,GACZ,MAAM41E,EAAKrzH,KAAKmzH,IAEhB,IAAI9uH,EACAw0H,EAAc,EAClB74H,KAAKo1H,UAAUjqH,SAAS2tH,IAOtB,GANAz0H,EAC2B,mBAAlBy0H,EAAQz0H,MACXy0H,EAAQz0H,MAAMo5C,GACdq7E,EAAQz0H,MAIZA,aAAiB+N,mBACjB/N,aAAiBu3B,kBACjBv3B,aAAiB6+G,UACjB,CAEK4V,EAAQC,UACXD,EAAQqF,eAAY33H,EACpBsyH,EAAQC,QAAU1F,EAAGI,iBAEvBzzH,KAAKo2H,YAAY0C,EAAQC,QAASF,EAAaC,EAAQpjH,MACvD29G,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGmD,mBAAoBnD,EAAGoD,QAC1DpD,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGqD,eAAgBrD,EAAGsD,eACtDtD,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGuD,eAAgBvD,EAAGsD,kBAGlDtyH,aAAiBu3B,mBACa,EAAQV,WACxB49F,EAAQqF,YAAc95H,IACtCy0H,EAAQqF,UAAY95H,EACpBgvH,EAAGiD,WACDjD,EAAGgD,WACH,EACAhD,EAAG6C,KACH7C,EAAG6C,KACH7C,EAAG8C,cACH9xH,IAGJw0H,GACR,MAAa,GAAIx2H,MAAMC,QAAQ+B,IAA2B,IAAjBA,EAAMlD,OACvCnB,KAAKo+H,sBACHtF,EAAQpjH,KACRwjH,GAAcl5H,KAAKs7H,SAAUj3H,SAE1B,GAAIhC,MAAMC,QAAQ+B,IAAUA,EAAMlD,QAAU,EACjD,OAAQkD,EAAMlD,QACZ,KAAK,EAMH,YALAkyH,EAAGkF,UACDv4H,KAAKi1H,mBAAmB6D,EAAQpjH,MAChCrR,EAAM,GACNA,EAAM,IAGV,KAAK,EAOH,YANAgvH,EAAG2F,UACDh5H,KAAKi1H,mBAAmB6D,EAAQpjH,MAChCrR,EAAM,GACNA,EAAM,GACNA,EAAM,IAGV,KAAK,EAQH,YAPAgvH,EAAG4F,UACDj5H,KAAKi1H,mBAAmB6D,EAAQpjH,MAChCrR,EAAM,GACNA,EAAM,GACNA,EAAM,GACNA,EAAM,IAGV,QACE,WAEsB,iBAAVA,GAChBgvH,EAAGoF,UAAUz4H,KAAKi1H,mBAAmB6D,EAAQpjH,MAAOrR,EACrD,GAEJ,CAQD,UAAA+zH,CAAWiG,EAAS5gF,GACPz9C,KAAKmzH,IACbiF,WAAWiG,GACdr+H,KAAKk7H,gBAAkBmD,EACvBr+H,KAAK89H,gBAAgBrgF,GACrBz9C,KAAK04H,cAAcj7E,EACpB,CAWD,aAAA02E,CAAcjqH,EAAQnK,GACpB,MAAMszH,EAAKrzH,KAAKmzH,IACVmL,EAASjL,EAAGW,aAAaj0H,GAG/B,OAFAszH,EAAGa,aAAaoK,EAAQp0H,GACxBmpH,EAAGc,cAAcmK,GACVA,CACR,CAQD,UAAAC,CAAWC,EAAsBC,GAC/B,MAAMpL,EAAKrzH,KAAKmzH,IAEViB,EAAiBp0H,KAAKm0H,cAC1BqK,EACAnL,EAAGgB,iBAGCN,EAAe/zH,KAAKm0H,cACxBsK,EACApL,EAAGY,eAGCoK,EAAUhL,EAAGkB,gBAKnB,GAJAlB,EAAGmB,aAAa6J,EAASjK,GACzBf,EAAGmB,aAAa6J,EAAStK,GACzBV,EAAGoB,YAAY4J,IAEVhL,EAAGqL,mBAAmBtK,EAAgBf,EAAGsL,gBAAiB,CAC7D,MAAM5mG,EAAU,uCAAuCs7F,EAAGuL,iBACxDxK,KAEF,MAAM,IAAI5rH,MAAMuvB,EACjB,CAGD,GAFAs7F,EAAGwL,aAAazK,IAEXf,EAAGqL,mBAAmB3K,EAAcV,EAAGsL,gBAAiB,CAC3D,MAAM5mG,EAAU,qCAAqCs7F,EAAGuL,iBACtD7K,KAEF,MAAM,IAAIvrH,MAAMuvB,EACjB,CAGD,GAFAs7F,EAAGwL,aAAa9K,IAEXV,EAAGyL,oBAAoBT,EAAShL,EAAG0L,aAAc,CACpD,MAAMhnG,EAAU,8BAA8Bs7F,EAAG2L,kBAC/CX,KAEF,MAAM,IAAI71H,MAAMuvB,EACjB,CAED,OAAOsmG,CACR,CAOD,kBAAApJ,CAAmBv/G,GACjB,MAAMupH,EAAav2H,EAAO1I,KAAKk7H,iBAQ/B,YAPoD10H,IAAhDxG,KAAKu7H,2BAA2B0D,KAClCj/H,KAAKu7H,2BAA2B0D,GAAc,SAEUz4H,IAAtDxG,KAAKu7H,2BAA2B0D,GAAYvpH,KAC9C1V,KAAKu7H,2BAA2B0D,GAAYvpH,GAC1C1V,KAAKmzH,IAAI8B,mBAAmBj1H,KAAKk7H,gBAAiBxlH,IAE/C1V,KAAKu7H,2BAA2B0D,GAAYvpH,EACpD,CAOD,oBAAAwpH,CAAqBxpH,GACnB,MAAMupH,EAAav2H,EAAO1I,KAAKk7H,iBAQ/B,YAPmD10H,IAA/CxG,KAAKw7H,0BAA0ByD,KACjCj/H,KAAKw7H,0BAA0ByD,GAAc,SAEUz4H,IAArDxG,KAAKw7H,0BAA0ByD,GAAYvpH,KAC7C1V,KAAKw7H,0BAA0ByD,GAAYvpH,GACzC1V,KAAKmzH,IAAI4B,kBAAkB/0H,KAAKk7H,gBAAiBxlH,IAE9C1V,KAAKw7H,0BAA0ByD,GAAYvpH,EACnD,CASD,uBAAAypH,CAAwB1hF,EAAYznC,GAClC,MAAMtC,EAAO+pC,EAAW/pC,KAClBkJ,EAAW6gC,EAAWjE,UAAU58B,SAChCD,EAAa8gC,EAAWjE,UAAU78B,WAClCD,EAAS+gC,EAAWjE,UAAU98B,OAWpC,OAVAuS,GACEjZ,EACA,EACA,EACA,GAAK2G,EAAajJ,EAAK,IACvB,GAAKiJ,EAAajJ,EAAK,KACtBkJ,GACAF,EAAO,IACPA,EAAO,IAEH1G,CACR,CAOD,oBAAA+nH,CAAqBjF,EAASz0H,GAC5BrE,KAAKmzH,IAAIsF,UAAUz4H,KAAKi1H,mBAAmB6D,GAAUz0H,EACtD,CAOD,mBAAA25H,CAAoBlF,EAASz0H,GAC3BrE,KAAKmzH,IAAIiM,WAAWp/H,KAAKi1H,mBAAmB6D,GAAUz0H,EACvD,CAOD,mBAAAg7H,CAAoBvG,EAASz0H,GAC3BrE,KAAKmzH,IAAImM,WAAWt/H,KAAKi1H,mBAAmB6D,GAAUz0H,EACvD,CAOD,qBAAA+5H,CAAsBtF,EAASz0H,GAC7BrE,KAAKmzH,IAAIoM,iBAAiBv/H,KAAKi1H,mBAAmB6D,IAAU,EAAOz0H,EACpE,CAYD,qBAAAm7H,CAAsBC,EAAY/rH,EAAM3T,EAAMib,EAAQD,GACpD,MAAMu6G,EAAWt1H,KAAKk/H,qBAAqBO,GAEvCnK,EAAW,IAGft1H,KAAKmzH,IAAIkF,wBAAwB/C,GACjCt1H,KAAKmzH,IAAImF,oBAAoBhD,EAAU5hH,EAAM3T,GAAM,EAAOib,EAAQD,GACnE,CAQD,gBAAA2kH,CAAiBvR,GACf,MAAMnzG,EAASk/G,GAAwB/L,GACvC,IAAIpzG,EAAS,EACb,IAAK,IAAInZ,EAAI,EAAGA,EAAIusH,EAAWhtH,OAAQS,IAAK,CAC1C,MAAMu4H,EAAOhM,EAAWvsH,GACxB5B,KAAKw/H,sBACHrF,EAAKzkH,KACLykH,EAAKzmH,KACLymH,EAAKp6H,MAAQkuH,GACbjzG,EACAD,GAEFA,GAAUo/G,EAAKzmH,KAAO0mH,GAAoBD,EAAKp6H,KAChD,CACF,CAOD,sBAAAw6H,CAAuB10H,GACrBlB,EAAM3E,KAAKg7H,cACXh7H,KAAKk7H,gBAAkB,KAEvBr1H,EAAMzF,gBACP,CAMD,0BAAAq6H,GACEz6H,KAAKm7H,qBAAsB,CAC5B,CAMD,kBAAAwE,GACE,OAAO3/H,KAAKm7H,mBACb,CAYD,aAAA1H,CAAc//G,EAAMvR,EAAM42H,GACxB,MAAM1F,EAAKrzH,KAAKmzH,IAChB4F,EAAUA,GAAW1F,EAAGI,gBAGxB,MACMwC,EAAiB5C,EAAG6C,KAEpBlvG,EAASqsG,EAAG6C,KACZn2H,EAAOszH,EAAG8C,cAqBhB,OApBA9C,EAAG+C,YAAY/C,EAAGgD,WAAY0C,GAC1B52H,EACFkxH,EAAGiD,WAAWjD,EAAGgD,WAPL,EAOwBJ,EAAgBjvG,EAAQjnB,EAAMoC,GAElEkxH,EAAGiD,WACDjD,EAAGgD,WAVO,EAYVJ,EACAviH,EAAK,GACLA,EAAK,GAZM,EAcXsT,EACAjnB,EACA,MAGJszH,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGmD,mBAAoBnD,EAAGoD,QAC1DpD,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGqD,eAAgBrD,EAAGsD,eACtDtD,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGuD,eAAgBvD,EAAGsD,eAE/CoC,CACR,GCjjCH,IAAA6G,GA7CA,MAKE,WAAA9/H,CAAY4V,EAAMvT,GAChBnC,KAAK0V,KAAOA,EACZ1V,KAAKmC,KAAOA,EAMZnC,KAAK6/H,SAAW,IACjB,CAMD,UAAArC,CAAWnK,GACT,IAAKrzH,KAAK6/H,SAAU,CAClB,MAAM9G,EAAU1F,EAAGI,gBACnBJ,EAAG+C,YAAY/C,EAAGgD,WAAY0C,GAC9B1F,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGqD,eAAgBrD,EAAGsD,eACtDtD,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGuD,eAAgBvD,EAAGsD,eACtDtD,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGmD,mBAAoBnD,EAAGyM,SAC1DzM,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAG0M,mBAAoB1M,EAAGyM,SAC1DzM,EAAGiD,WACDjD,EAAGgD,WACH,EACAhD,EAAG6C,KACHl2H,KAAKmC,KAAKhB,OAAS,EACnB,EACA,EACAkyH,EAAG6C,KACH7C,EAAG8C,cACHn2H,KAAKmC,MAEPnC,KAAK6/H,SAAW9G,CACjB,CACD,OAAO/4H,KAAK6/H,QACb,GCvCH,MAAMG,GAAY,IAAIxtH,WAAW,GAwMjC,IAAAytH,GAjMA,MAKE,WAAAngI,CAAYsyH,EAAQ1+G,GAKlB1T,KAAKmyH,QAAUC,EACf,MAAMiB,EAAKjB,EAAOmD,QAMlBv1H,KAAK6/H,SAAWxM,EAAGI,gBAMnBzzH,KAAKkgI,aAAe7M,EAAGO,oBAMvB5zH,KAAKmgI,aAAe9M,EAAGS,qBAMvB9zH,KAAKyT,MAAQC,GAAQ,CAAC,EAAG,GAMzB1T,KAAKuT,MAAQ,IAAIf,WAAW,GAM5BxS,KAAKogI,iBAAkB,EAEvBpgI,KAAKqgI,aACN,CAOD,OAAA/zF,CAAQ54B,GACFnR,EAAOmR,EAAM1T,KAAKyT,SAGtBzT,KAAKyT,MAAM,GAAKC,EAAK,GACrB1T,KAAKyT,MAAM,GAAKC,EAAK,GACrB1T,KAAKqgI,cACN,CAMD,OAAA1sH,GACE,OAAO3T,KAAKyT,KACb,CAOD,eAAA6sH,GACEtgI,KAAKogI,iBAAkB,CACxB,CAOD,OAAAG,GACE,GAAIvgI,KAAKogI,gBAAiB,CACxB,MAAM1sH,EAAO1T,KAAKyT,MACZ4/G,EAAKrzH,KAAKmyH,QAAQoD,QAExBlC,EAAGsC,gBAAgBtC,EAAGuC,YAAa51H,KAAKkgI,cACxC7M,EAAGmN,WACD,EACA,EACA9sH,EAAK,GACLA,EAAK,GACL2/G,EAAG6C,KACH7C,EAAG8C,cACHn2H,KAAKuT,OAEPvT,KAAKogI,iBAAkB,CACxB,CACD,OAAOpgI,KAAKuT,KACb,CAUD,SAAAktH,CAAUppH,EAAGC,GACX,GAAID,EAAI,GAAKC,EAAI,GAAKD,EAAIrX,KAAKyT,MAAM,IAAM6D,GAAKtX,KAAKyT,MAAM,GAKzD,OAJAusH,GAAU,GAAK,EACfA,GAAU,GAAK,EACfA,GAAU,GAAK,EACfA,GAAU,GAAK,EACRA,GAGThgI,KAAKugI,UACL,MAAMt9H,EACJgJ,KAAKuT,MAAMnI,IAAMrX,KAAKyT,MAAM,GAAKxH,KAAKuT,MAAMlI,GAAK,GAAKtX,KAAKyT,MAAM,GAKnE,OAJAusH,GAAU,GAAKhgI,KAAKuT,MAAc,EAARtQ,GAC1B+8H,GAAU,GAAKhgI,KAAKuT,MAAc,EAARtQ,EAAY,GACtC+8H,GAAU,GAAKhgI,KAAKuT,MAAc,EAARtQ,EAAY,GACtC+8H,GAAU,GAAKhgI,KAAKuT,MAAc,EAARtQ,EAAY,GAC/B+8H,EACR,CAKD,UAAAxC,GACE,OAAOx9H,KAAK6/H,QACb,CAKD,cAAAvC,GACE,OAAOt9H,KAAKkgI,YACb,CAKD,cAAA3C,GACE,OAAOv9H,KAAKmgI,YACb,CAKD,WAAAE,GACE,MAAM3sH,EAAO1T,KAAKyT,MACZ4/G,EAAKrzH,KAAKmyH,QAAQoD,QAExBv1H,KAAK6/H,SAAW7/H,KAAKmyH,QAAQsB,cAAc//G,EAAM,KAAM1T,KAAK6/H,UAE5DxM,EAAGsC,gBAAgBtC,EAAGuC,YAAa51H,KAAKkgI,cACxC7M,EAAG1rC,SAAS,EAAG,EAAGj0E,EAAK,GAAIA,EAAK,IAChC2/G,EAAGwD,qBACDxD,EAAGuC,YACHvC,EAAGyD,kBACHzD,EAAGgD,WACHr2H,KAAK6/H,SACL,GAGFxM,EAAGyC,iBAAiBzC,EAAG0C,aAAc/1H,KAAKmgI,cAC1C9M,EAAG0D,oBACD1D,EAAG0C,aACH1C,EAAG2D,kBACHtjH,EAAK,GACLA,EAAK,IAEP2/G,EAAG4D,wBACD5D,EAAGuC,YACHvC,EAAG6D,iBACH7D,EAAG0C,aACH/1H,KAAKmgI,cAGPngI,KAAKuT,MAAQ,IAAIf,WAAWkB,EAAK,GAAKA,EAAK,GAAK,EACjD,mBCvMH,SAASgtH,GAAOv+H,EAAMw+H,EAAaC,GAE/BA,EAAMA,GAAO,EAEb,IAOIxmH,EAAMC,EAAMC,EAAMC,EAAMlD,EAAGC,EAAGupH,EAP9BC,EAAWH,GAAeA,EAAYx/H,OACtC4/H,EAAWD,EAAWH,EAAY,GAAKC,EAAMz+H,EAAKhB,OAClD6/H,EAAYC,GAAW9+H,EAAM,EAAG4+H,EAAUH,GAAK,GAC/CM,EAAY,GAEhB,IAAKF,GAAaA,EAAUG,OAASH,EAAUr1H,KAAM,OAAOu1H,EAO5D,GAHIJ,IAAUE,EA2PlB,SAAwB7+H,EAAMw+H,EAAaK,EAAWJ,GAClD,IACIh/H,EAAGqG,EAAiBm5H,EADpB/b,EAAQ,GAGZ,IAAKzjH,EAAI,EAAGqG,EAAM04H,EAAYx/H,OAAQS,EAAIqG,EAAKrG,KAG3Cw/H,EAAOH,GAAW9+H,EAFVw+H,EAAY/+H,GAAKg/H,EACnBh/H,EAAIqG,EAAM,EAAI04H,EAAY/+H,EAAI,GAAKg/H,EAAMz+H,EAAKhB,OAChBy/H,GAAK,MAC5BQ,EAAKD,OAAMC,EAAKC,SAAU,GACvChc,EAAM1/G,KAAK27H,GAAYF,IAM3B,IAHA/b,EAAM/wF,KAAKitG,IAGN3/H,EAAI,EAAGA,EAAIyjH,EAAMlkH,OAAQS,IAC1Bo/H,EAAYQ,GAAcnc,EAAMzjH,GAAIo/H,GAGxC,OAAOA,CACX,CA/Q8BS,CAAet/H,EAAMw+H,EAAaK,EAAWJ,IAGnEz+H,EAAKhB,OAAS,GAAKy/H,EAAK,CACxBxmH,EAAOE,EAAOnY,EAAK,GACnBkY,EAAOE,EAAOpY,EAAK,GAEnB,IAAK,IAAIP,EAAIg/H,EAAKh/H,EAAIm/H,EAAUn/H,GAAKg/H,GACjCvpH,EAAIlV,EAAKP,IAEDwY,IAAMA,EAAO/C,IADrBC,EAAInV,EAAKP,EAAI,IAELyY,IAAMA,EAAO/C,GACjBD,EAAIiD,IAAMA,EAAOjD,GACjBC,EAAIiD,IAAMA,EAAOjD,GAKzBupH,EAAsB,KADtBA,EAAU50H,KAAKyP,IAAIpB,EAAOF,EAAMG,EAAOF,IACb,MAAQwmH,EAAU,CAC/C,CAID,OAFAa,GAAaV,EAAWE,EAAWN,EAAKxmH,EAAMC,EAAMwmH,EAAS,GAEtDK,CACX,CAGA,SAASD,GAAW9+H,EAAMuL,EAAO1L,EAAK4+H,EAAKe,GACvC,IAAI//H,EAAGowB,EAEP,GAAI2vG,IAAeC,GAAWz/H,EAAMuL,EAAO1L,EAAK4+H,GAAO,EACnD,IAAKh/H,EAAI8L,EAAO9L,EAAII,EAAKJ,GAAKg/H,EAAK5uG,EAAO6vG,GAAWjgI,EAAGO,EAAKP,GAAIO,EAAKP,EAAI,GAAIowB,QAE9E,IAAKpwB,EAAII,EAAM4+H,EAAKh/H,GAAK8L,EAAO9L,GAAKg/H,EAAK5uG,EAAO6vG,GAAWjgI,EAAGO,EAAKP,GAAIO,EAAKP,EAAI,GAAIowB,GAQzF,OALIA,GAAQzvB,GAAOyvB,EAAMA,EAAKmvG,QAC1B7vH,GAAW0gB,GACXA,EAAOA,EAAKmvG,MAGTnvG,CACX,CAGA,SAAS8vG,GAAap0H,EAAO1L,GACzB,IAAK0L,EAAO,OAAOA,EACd1L,IAAKA,EAAM0L,GAEhB,IACIq0H,EADA3rC,EAAI1oF,EAER,GAGI,GAFAq0H,GAAQ,EAEH3rC,EAAEirC,UAAY9+H,GAAO6zF,EAAGA,EAAE+qC,OAAqC,IAA5BhlH,GAAKi6E,EAAEzqF,KAAMyqF,EAAGA,EAAE+qC,MAOtD/qC,EAAIA,EAAE+qC,SAP8D,CAGpE,GAFA7vH,GAAW8kF,IACXA,EAAIp0F,EAAMo0F,EAAEzqF,QACFyqF,EAAE+qC,KAAM,MAClBY,GAAQ,CAEpB,QAGaA,GAAS3rC,IAAMp0F,GAExB,OAAOA,CACX,CAGA,SAAS0/H,GAAaM,EAAKd,EAAWN,EAAKxmH,EAAMC,EAAMwmH,EAASzqE,GAC5D,GAAK4rE,EAAL,EAGK5rE,GAAQyqE,GAuRjB,SAAoBnzH,EAAO0M,EAAMC,EAAMwmH,GACnC,IAAIzqC,EAAI1oF,EACR,GACgB,IAAR0oF,EAAE72D,IAAS62D,EAAE72D,EAAI0iG,GAAO7rC,EAAE/+E,EAAG++E,EAAE9+E,EAAG8C,EAAMC,EAAMwmH,IAClDzqC,EAAE8rC,MAAQ9rC,EAAEzqF,KACZyqF,EAAE+rC,MAAQ/rC,EAAE+qC,KACZ/qC,EAAIA,EAAE+qC,WACD/qC,IAAM1oF,GAEf0oF,EAAE8rC,MAAMC,MAAQ,KAChB/rC,EAAE8rC,MAAQ,KAOd,SAAoBd,GAChB,IAAIx/H,EAAGw0F,EAAGgsC,EAAGlrH,EAAGmrH,EAAMC,EAAWC,EAAOC,EACpCC,EAAS,EAEb,EAAG,CAMC,IALArsC,EAAIgrC,EACJA,EAAO,KACPiB,EAAO,KACPC,EAAY,EAELlsC,GAAG,CAIN,IAHAksC,IACAF,EAAIhsC,EACJmsC,EAAQ,EACH3gI,EAAI,EAAGA,EAAI6gI,IACZF,IACAH,EAAIA,EAAED,OAFcvgI,KAOxB,IAFA4gI,EAAQC,EAEDF,EAAQ,GAAMC,EAAQ,GAAKJ,GAEhB,IAAVG,IAA0B,IAAVC,IAAgBJ,GAAKhsC,EAAE72D,GAAK6iG,EAAE7iG,IAC9CroB,EAAIk/E,EACJA,EAAIA,EAAE+rC,MACNI,MAEArrH,EAAIkrH,EACJA,EAAIA,EAAED,MACNK,KAGAH,EAAMA,EAAKF,MAAQjrH,EAClBkqH,EAAOlqH,EAEZA,EAAEgrH,MAAQG,EACVA,EAAOnrH,EAGXk/E,EAAIgsC,CACP,CAEDC,EAAKF,MAAQ,KACbM,GAAU,CAElB,OAAaH,EAAY,EAGzB,CAtDII,CAAWtsC,EACf,CApS0BusC,CAAWX,EAAK5nH,EAAMC,EAAMwmH,GAMlD,IAJA,IACIl1H,EAAMw1H,EADN51C,EAAOy2C,EAIJA,EAAIr2H,OAASq2H,EAAIb,MAIpB,GAHAx1H,EAAOq2H,EAAIr2H,KACXw1H,EAAOa,EAAIb,KAEPN,EAAU+B,GAAYZ,EAAK5nH,EAAMC,EAAMwmH,GAAWgC,GAAMb,GAExDd,EAAUv7H,KAAKgG,EAAK/J,EAAIg/H,EAAM,GAC9BM,EAAUv7H,KAAKq8H,EAAIpgI,EAAIg/H,EAAM,GAC7BM,EAAUv7H,KAAKw7H,EAAKv/H,EAAIg/H,EAAM,GAE9BtvH,GAAW0wH,GAGXA,EAAMb,EAAKA,KACX51C,EAAO41C,EAAKA,UAQhB,IAHAa,EAAMb,KAGM51C,EAAM,CAETn1B,EAIe,IAATA,EAEPsrE,GADAM,EAAMc,GAAuBhB,GAAaE,GAAMd,EAAWN,GACzCM,EAAWN,EAAKxmH,EAAMC,EAAMwmH,EAAS,GAGvC,IAATzqE,GACP2sE,GAAYf,EAAKd,EAAWN,EAAKxmH,EAAMC,EAAMwmH,GAT7Ca,GAAaI,GAAaE,GAAMd,EAAWN,EAAKxmH,EAAMC,EAAMwmH,EAAS,GAYzE,KACH,CA/CY,CAiDrB,CAGA,SAASgC,GAAMb,GACX,IAAI3gI,EAAI2gI,EAAIr2H,KACRrK,EAAI0gI,EACJhrH,EAAIgrH,EAAIb,KAEZ,GAAIhlH,GAAK9a,EAAGC,EAAG0V,IAAM,EAAG,OAAO,EAY/B,IATA,IAAIgsH,EAAK3hI,EAAEgW,EAAG4rH,EAAK3hI,EAAE+V,EAAG6rH,EAAKlsH,EAAEK,EAAG8rH,EAAK9hI,EAAEiW,EAAG8rH,EAAK9hI,EAAEgW,EAAG+rH,EAAKrsH,EAAEM,EAGzDuF,EAAKmmH,EAAKC,EAAMD,EAAKE,EAAKF,EAAKE,EAAOD,EAAKC,EAAKD,EAAKC,EACrDpmH,EAAKqmH,EAAKC,EAAMD,EAAKE,EAAKF,EAAKE,EAAOD,EAAKC,EAAKD,EAAKC,EACrDtmH,EAAKimH,EAAKC,EAAMD,EAAKE,EAAKF,EAAKE,EAAOD,EAAKC,EAAKD,EAAKC,EACrDlmH,EAAKmmH,EAAKC,EAAMD,EAAKE,EAAKF,EAAKE,EAAOD,EAAKC,EAAKD,EAAKC,EAErDjtC,EAAIp/E,EAAEmqH,KACH/qC,IAAM/0F,GAAG,CACZ,GAAI+0F,EAAE/+E,GAAKwF,GAAMu5E,EAAE/+E,GAAK0F,GAAMq5E,EAAE9+E,GAAKwF,GAAMs5E,EAAE9+E,GAAK0F,GAC9CsmH,GAAgBN,EAAIG,EAAIF,EAAIG,EAAIF,EAAIG,EAAIjtC,EAAE/+E,EAAG++E,EAAE9+E,IAC/C6E,GAAKi6E,EAAEzqF,KAAMyqF,EAAGA,EAAE+qC,OAAS,EAAG,OAAO,EACzC/qC,EAAIA,EAAE+qC,IACT,CAED,OAAO,CACX,CAEA,SAASyB,GAAYZ,EAAK5nH,EAAMC,EAAMwmH,GAClC,IAAIx/H,EAAI2gI,EAAIr2H,KACRrK,EAAI0gI,EACJhrH,EAAIgrH,EAAIb,KAEZ,GAAIhlH,GAAK9a,EAAGC,EAAG0V,IAAM,EAAG,OAAO,EAkB/B,IAhBA,IAAIgsH,EAAK3hI,EAAEgW,EAAG4rH,EAAK3hI,EAAE+V,EAAG6rH,EAAKlsH,EAAEK,EAAG8rH,EAAK9hI,EAAEiW,EAAG8rH,EAAK9hI,EAAEgW,EAAG+rH,EAAKrsH,EAAEM,EAGzDuF,EAAKmmH,EAAKC,EAAMD,EAAKE,EAAKF,EAAKE,EAAOD,EAAKC,EAAKD,EAAKC,EACrDpmH,EAAKqmH,EAAKC,EAAMD,EAAKE,EAAKF,EAAKE,EAAOD,EAAKC,EAAKD,EAAKC,EACrDtmH,EAAKimH,EAAKC,EAAMD,EAAKE,EAAKF,EAAKE,EAAOD,EAAKC,EAAKD,EAAKC,EACrDlmH,EAAKmmH,EAAKC,EAAMD,EAAKE,EAAKF,EAAKE,EAAOD,EAAKC,EAAKD,EAAKC,EAGrDE,EAAOtB,GAAOplH,EAAIC,EAAI1C,EAAMC,EAAMwmH,GAClC2C,EAAOvB,GAAOllH,EAAIC,EAAI5C,EAAMC,EAAMwmH,GAElCzqC,EAAI4rC,EAAIE,MACRvgI,EAAIqgI,EAAIG,MAGL/rC,GAAKA,EAAE72D,GAAKgkG,GAAQ5hI,GAAKA,EAAE49B,GAAKikG,GAAM,CACzC,GAAIptC,EAAE/+E,GAAKwF,GAAMu5E,EAAE/+E,GAAK0F,GAAMq5E,EAAE9+E,GAAKwF,GAAMs5E,EAAE9+E,GAAK0F,GAAMo5E,IAAM/0F,GAAK+0F,IAAMp/E,GACrEssH,GAAgBN,EAAIG,EAAIF,EAAIG,EAAIF,EAAIG,EAAIjtC,EAAE/+E,EAAG++E,EAAE9+E,IAAM6E,GAAKi6E,EAAEzqF,KAAMyqF,EAAGA,EAAE+qC,OAAS,EAAG,OAAO,EAG9F,GAFA/qC,EAAIA,EAAE8rC,MAEFvgI,EAAE0V,GAAKwF,GAAMlb,EAAE0V,GAAK0F,GAAMpb,EAAE2V,GAAKwF,GAAMnb,EAAE2V,GAAK0F,GAAMrb,IAAMN,GAAKM,IAAMqV,GACrEssH,GAAgBN,EAAIG,EAAIF,EAAIG,EAAIF,EAAIG,EAAI1hI,EAAE0V,EAAG1V,EAAE2V,IAAM6E,GAAKxa,EAAEgK,KAAMhK,EAAGA,EAAEw/H,OAAS,EAAG,OAAO,EAC9Fx/H,EAAIA,EAAEwgI,KACT,CAGD,KAAO/rC,GAAKA,EAAE72D,GAAKgkG,GAAM,CACrB,GAAIntC,EAAE/+E,GAAKwF,GAAMu5E,EAAE/+E,GAAK0F,GAAMq5E,EAAE9+E,GAAKwF,GAAMs5E,EAAE9+E,GAAK0F,GAAMo5E,IAAM/0F,GAAK+0F,IAAMp/E,GACrEssH,GAAgBN,EAAIG,EAAIF,EAAIG,EAAIF,EAAIG,EAAIjtC,EAAE/+E,EAAG++E,EAAE9+E,IAAM6E,GAAKi6E,EAAEzqF,KAAMyqF,EAAGA,EAAE+qC,OAAS,EAAG,OAAO,EAC9F/qC,EAAIA,EAAE8rC,KACT,CAGD,KAAOvgI,GAAKA,EAAE49B,GAAKikG,GAAM,CACrB,GAAI7hI,EAAE0V,GAAKwF,GAAMlb,EAAE0V,GAAK0F,GAAMpb,EAAE2V,GAAKwF,GAAMnb,EAAE2V,GAAK0F,GAAMrb,IAAMN,GAAKM,IAAMqV,GACrEssH,GAAgBN,EAAIG,EAAIF,EAAIG,EAAIF,EAAIG,EAAI1hI,EAAE0V,EAAG1V,EAAE2V,IAAM6E,GAAKxa,EAAEgK,KAAMhK,EAAGA,EAAEw/H,OAAS,EAAG,OAAO,EAC9Fx/H,EAAIA,EAAEwgI,KACT,CAED,OAAO,CACX,CAGA,SAASW,GAAuBp1H,EAAOwzH,EAAWN,GAC9C,IAAIxqC,EAAI1oF,EACR,EAAG,CACC,IAAIrM,EAAI+0F,EAAEzqF,KACNrK,EAAI80F,EAAE+qC,KAAKA,MAEV5+H,GAAOlB,EAAGC,IAAMwc,GAAWzc,EAAG+0F,EAAGA,EAAE+qC,KAAM7/H,IAAMmiI,GAAcpiI,EAAGC,IAAMmiI,GAAcniI,EAAGD,KAExF6/H,EAAUv7H,KAAKtE,EAAEO,EAAIg/H,EAAM,GAC3BM,EAAUv7H,KAAKywF,EAAEx0F,EAAIg/H,EAAM,GAC3BM,EAAUv7H,KAAKrE,EAAEM,EAAIg/H,EAAM,GAG3BtvH,GAAW8kF,GACX9kF,GAAW8kF,EAAE+qC,MAEb/qC,EAAI1oF,EAAQpM,GAEhB80F,EAAIA,EAAE+qC,IACd,OAAa/qC,IAAM1oF,GAEf,OAAOo0H,GAAa1rC,EACxB,CAGA,SAAS2sC,GAAYr1H,EAAOwzH,EAAWN,EAAKxmH,EAAMC,EAAMwmH,GAEpD,IAAIx/H,EAAIqM,EACR,EAAG,CAEC,IADA,IAAIpM,EAAID,EAAE8/H,KAAKA,KACR7/H,IAAMD,EAAEsK,MAAM,CACjB,GAAItK,EAAEO,IAAMN,EAAEM,GAAK8hI,GAAgBriI,EAAGC,GAAI,CAEtC,IAAI0V,EAAI2sH,GAAatiI,EAAGC,GASxB,OANAD,EAAIygI,GAAazgI,EAAGA,EAAE8/H,MACtBnqH,EAAI8qH,GAAa9qH,EAAGA,EAAEmqH,MAGtBO,GAAargI,EAAG6/H,EAAWN,EAAKxmH,EAAMC,EAAMwmH,EAAS,QACrDa,GAAa1qH,EAAGkqH,EAAWN,EAAKxmH,EAAMC,EAAMwmH,EAAS,EAExD,CACDv/H,EAAIA,EAAE6/H,IACT,CACD9/H,EAAIA,EAAE8/H,IACd,OAAa9/H,IAAMqM,EACnB,CAyBA,SAAS6zH,GAASlgI,EAAGC,GACjB,OAAOD,EAAEgW,EAAI/V,EAAE+V,CACnB,CAGA,SAASmqH,GAAcoC,EAAM5C,GACzB,IAAI6C,EAaR,SAAwBD,EAAM5C,GAC1B,IAII7gH,EAJAi2E,EAAI4qC,EACJ8C,EAAKF,EAAKvsH,EACV0sH,EAAKH,EAAKtsH,EACV0sH,GAAMvpH,IAKV,EAAG,CACC,GAAIspH,GAAM3tC,EAAE9+E,GAAKysH,GAAM3tC,EAAE+qC,KAAK7pH,GAAK8+E,EAAE+qC,KAAK7pH,IAAM8+E,EAAE9+E,EAAG,CACjD,IAAID,EAAI++E,EAAE/+E,GAAK0sH,EAAK3tC,EAAE9+E,IAAM8+E,EAAE+qC,KAAK9pH,EAAI++E,EAAE/+E,IAAM++E,EAAE+qC,KAAK7pH,EAAI8+E,EAAE9+E,GAC5D,GAAID,GAAKysH,GAAMzsH,EAAI2sH,IACfA,EAAK3sH,EACL8I,EAAIi2E,EAAE/+E,EAAI++E,EAAE+qC,KAAK9pH,EAAI++E,EAAIA,EAAE+qC,KACvB9pH,IAAMysH,GAAI,OAAO3jH,CAE5B,CACDi2E,EAAIA,EAAE+qC,IACd,OAAa/qC,IAAM4qC,GAEf,IAAK7gH,EAAG,OAAO,KAMf,IAIIqC,EAJA+oE,EAAOprE,EACP8jH,EAAK9jH,EAAE9I,EACP6sH,EAAK/jH,EAAE7I,EACP6sH,EAAS1pH,IAGb27E,EAAIj2E,EAEJ,GACQ2jH,GAAM1tC,EAAE/+E,GAAK++E,EAAE/+E,GAAK4sH,GAAMH,IAAO1tC,EAAE/+E,GAC/BisH,GAAgBS,EAAKG,EAAKJ,EAAKE,EAAID,EAAIE,EAAIC,EAAIH,EAAKG,EAAKF,EAAKF,EAAIC,EAAI3tC,EAAE/+E,EAAG++E,EAAE9+E,KAEjFkL,EAAMvW,KAAKmP,IAAI2oH,EAAK3tC,EAAE9+E,IAAMwsH,EAAK1tC,EAAE/+E,GAE/BosH,GAAcrtC,EAAGwtC,KAChBphH,EAAM2hH,GAAW3hH,IAAQ2hH,IAAW/tC,EAAE/+E,EAAI8I,EAAE9I,GAAM++E,EAAE/+E,IAAM8I,EAAE9I,GAAK+sH,GAAqBjkH,EAAGi2E,OAC1Fj2E,EAAIi2E,EACJ+tC,EAAS3hH,IAIjB4zE,EAAIA,EAAE+qC,WACD/qC,IAAM7K,GAEf,OAAOprE,CACX,CAjEiBkkH,CAAeT,EAAM5C,GAClC,IAAK6C,EACD,OAAO7C,EAGX,IAAIsD,EAAgBX,GAAaE,EAAQD,GAIzC,OADA9B,GAAawC,EAAeA,EAAcnD,MACnCW,GAAa+B,EAAQA,EAAO1C,KACvC,CA0DA,SAASiD,GAAqBjkH,EAAGi2E,GAC7B,OAAOj6E,GAAKgE,EAAExU,KAAMwU,EAAGi2E,EAAEzqF,MAAQ,GAAKwQ,GAAKi6E,EAAE+qC,KAAMhhH,EAAGA,EAAEghH,MAAQ,CACpE,CAwEA,SAASc,GAAO5qH,EAAGC,EAAG8C,EAAMC,EAAMwmH,GAe9B,OAPAxpH,EAAqB,aADrBA,EAAqB,YADrBA,EAAqB,YADrBA,EAAqB,WAHrBA,GAAKA,EAAI+C,GAAQymH,EAAU,GAGjBxpH,GAAK,IACLA,GAAK,IACLA,GAAK,IACLA,GAAK,KAKfC,EAAqB,aADrBA,EAAqB,YADrBA,EAAqB,YADrBA,EAAqB,WAPrBA,GAAKA,EAAI+C,GAAQwmH,EAAU,GAOjBvpH,GAAK,IACLA,GAAK,IACLA,GAAK,IACLA,GAAK,KAEE,CACrB,CAGA,SAASgqH,GAAY5zH,GACjB,IAAI0oF,EAAI1oF,EACJ62H,EAAW72H,EACf,IACQ0oF,EAAE/+E,EAAIktH,EAASltH,GAAM++E,EAAE/+E,IAAMktH,EAASltH,GAAK++E,EAAE9+E,EAAIitH,EAASjtH,KAAIitH,EAAWnuC,GAC7EA,EAAIA,EAAE+qC,WACD/qC,IAAM1oF,GAEf,OAAO62H,CACX,CAGA,SAASjB,GAAgBN,EAAIG,EAAIF,EAAIG,EAAIF,EAAIG,EAAI9pE,EAAIirE,GACjD,OAAQtB,EAAK3pE,IAAO4pE,EAAKqB,KAAQxB,EAAKzpE,IAAO8pE,EAAKmB,KAC1CxB,EAAKzpE,IAAO6pE,EAAKoB,KAAQvB,EAAK1pE,IAAO4pE,EAAKqB,KAC1CvB,EAAK1pE,IAAO8pE,EAAKmB,KAAQtB,EAAK3pE,IAAO6pE,EAAKoB,EACtD,CAGA,SAASd,GAAgBriI,EAAGC,GACxB,OAAOD,EAAE8/H,KAAKv/H,IAAMN,EAAEM,GAAKP,EAAEsK,KAAK/J,IAAMN,EAAEM,IA2C9C,SAA2BP,EAAGC,GAC1B,IAAI80F,EAAI/0F,EACR,EAAG,CACC,GAAI+0F,EAAEx0F,IAAMP,EAAEO,GAAKw0F,EAAE+qC,KAAKv/H,IAAMP,EAAEO,GAAKw0F,EAAEx0F,IAAMN,EAAEM,GAAKw0F,EAAE+qC,KAAKv/H,IAAMN,EAAEM,GAC7Dkc,GAAWs4E,EAAGA,EAAE+qC,KAAM9/H,EAAGC,GAAI,OAAO,EAC5C80F,EAAIA,EAAE+qC,IACd,OAAa/qC,IAAM/0F,GAEf,OAAO,CACX,CApDoDojI,CAAkBpjI,EAAGC,KAC7DmiI,GAAcpiI,EAAGC,IAAMmiI,GAAcniI,EAAGD,IA6DpD,SAAsBA,EAAGC,GACrB,IAAI80F,EAAI/0F,EACJqjI,GAAS,EACTnrE,GAAMl4D,EAAEgW,EAAI/V,EAAE+V,GAAK,EACnBmtH,GAAMnjI,EAAEiW,EAAIhW,EAAEgW,GAAK,EACvB,GACU8+E,EAAE9+E,EAAIktH,GAASpuC,EAAE+qC,KAAK7pH,EAAIktH,GAAQpuC,EAAE+qC,KAAK7pH,IAAM8+E,EAAE9+E,GAC9CiiD,GAAM68B,EAAE+qC,KAAK9pH,EAAI++E,EAAE/+E,IAAMmtH,EAAKpuC,EAAE9+E,IAAM8+E,EAAE+qC,KAAK7pH,EAAI8+E,EAAE9+E,GAAK8+E,EAAE/+E,IAC/DqtH,GAAUA,GACdtuC,EAAIA,EAAE+qC,WACD/qC,IAAM/0F,GAEf,OAAOqjI,CACX,CA1E0DC,CAAatjI,EAAGC,KAC7D6a,GAAK9a,EAAEsK,KAAMtK,EAAGC,EAAEqK,OAASwQ,GAAK9a,EAAGC,EAAEqK,KAAMrK,KAC5CiB,GAAOlB,EAAGC,IAAM6a,GAAK9a,EAAEsK,KAAMtK,EAAGA,EAAE8/H,MAAQ,GAAKhlH,GAAK7a,EAAEqK,KAAMrK,EAAGA,EAAE6/H,MAAQ,EACrF,CAGA,SAAShlH,GAAKi6E,EAAGgsC,EAAGh+G,GAChB,OAAQg+G,EAAE9qH,EAAI8+E,EAAE9+E,IAAM8M,EAAE/M,EAAI+qH,EAAE/qH,IAAM+qH,EAAE/qH,EAAI++E,EAAE/+E,IAAM+M,EAAE9M,EAAI8qH,EAAE9qH,EAC9D,CAGA,SAAS/U,GAAOqiI,EAAIC,GAChB,OAAOD,EAAGvtH,IAAMwtH,EAAGxtH,GAAKutH,EAAGttH,IAAMutH,EAAGvtH,CACxC,CAGA,SAASwG,GAAW8mH,EAAIE,EAAID,EAAIE,GAC5B,IAAIC,EAAKC,GAAK9oH,GAAKyoH,EAAIE,EAAID,IACvBK,EAAKD,GAAK9oH,GAAKyoH,EAAIE,EAAIC,IACvBI,EAAKF,GAAK9oH,GAAK0oH,EAAIE,EAAIH,IACvBQ,EAAKH,GAAK9oH,GAAK0oH,EAAIE,EAAID,IAE3B,OAAIE,IAAOE,GAAMC,IAAOC,MAEb,IAAPJ,IAAYK,GAAUT,EAAIC,EAAIC,QACvB,IAAPI,IAAYG,GAAUT,EAAIG,EAAID,QACvB,IAAPK,IAAYE,GAAUR,EAAID,EAAIG,OACvB,IAAPK,IAAYC,GAAUR,EAAIC,EAAIC,MAGtC,CAGA,SAASM,GAAUjvC,EAAGgsC,EAAGh+G,GACrB,OAAOg+G,EAAE/qH,GAAKpL,KAAKyP,IAAI06E,EAAE/+E,EAAG+M,EAAE/M,IAAM+qH,EAAE/qH,GAAKpL,KAAKwP,IAAI26E,EAAE/+E,EAAG+M,EAAE/M,IAAM+qH,EAAE9qH,GAAKrL,KAAKyP,IAAI06E,EAAE9+E,EAAG8M,EAAE9M,IAAM8qH,EAAE9qH,GAAKrL,KAAKwP,IAAI26E,EAAE9+E,EAAG8M,EAAE9M,EACzH,CAEA,SAAS2tH,GAAKK,GACV,OAAOA,EAAM,EAAI,EAAIA,EAAM,GAAK,EAAI,CACxC,CAeA,SAAS7B,GAAcpiI,EAAGC,GACtB,OAAO6a,GAAK9a,EAAEsK,KAAMtK,EAAGA,EAAE8/H,MAAQ,EAC7BhlH,GAAK9a,EAAGC,EAAGD,EAAE8/H,OAAS,GAAKhlH,GAAK9a,EAAGA,EAAEsK,KAAMrK,IAAM,EACjD6a,GAAK9a,EAAGC,EAAGD,EAAEsK,MAAQ,GAAKwQ,GAAK9a,EAAGA,EAAE8/H,KAAM7/H,GAAK,CACvD,CAoBA,SAASqiI,GAAatiI,EAAGC,GACrB,IAAIoV,EAAK,IAAIu4G,GAAK5tH,EAAEO,EAAGP,EAAEgW,EAAGhW,EAAEiW,GAC1BX,EAAK,IAAIs4G,GAAK3tH,EAAEM,EAAGN,EAAE+V,EAAG/V,EAAEgW,GAC1BiuH,EAAKlkI,EAAE8/H,KACPqE,EAAKlkI,EAAEqK,KAcX,OAZAtK,EAAE8/H,KAAO7/H,EACTA,EAAEqK,KAAOtK,EAETqV,EAAGyqH,KAAOoE,EACVA,EAAG55H,KAAO+K,EAEVC,EAAGwqH,KAAOzqH,EACVA,EAAG/K,KAAOgL,EAEV6uH,EAAGrE,KAAOxqH,EACVA,EAAGhL,KAAO65H,EAEH7uH,CACX,CAGA,SAASkrH,GAAWjgI,EAAGyV,EAAGC,EAAG0a,GACzB,IAAIokE,EAAI,IAAI64B,GAAKrtH,EAAGyV,EAAGC,GAYvB,OAVK0a,GAKDokE,EAAE+qC,KAAOnvG,EAAKmvG,KACd/qC,EAAEzqF,KAAOqmB,EACTA,EAAKmvG,KAAKx1H,KAAOyqF,EACjBpkE,EAAKmvG,KAAO/qC,IAPZA,EAAEzqF,KAAOyqF,EACTA,EAAE+qC,KAAO/qC,GAQNA,CACX,CAEA,SAAS9kF,GAAW8kF,GAChBA,EAAE+qC,KAAKx1H,KAAOyqF,EAAEzqF,KAChByqF,EAAEzqF,KAAKw1H,KAAO/qC,EAAE+qC,KAEZ/qC,EAAE8rC,QAAO9rC,EAAE8rC,MAAMC,MAAQ/rC,EAAE+rC,OAC3B/rC,EAAE+rC,QAAO/rC,EAAE+rC,MAAMD,MAAQ9rC,EAAE8rC,MACnC,CAEA,SAASjT,GAAKrtH,EAAGyV,EAAGC,GAEhBtX,KAAK4B,EAAIA,EAGT5B,KAAKqX,EAAIA,EACTrX,KAAKsX,EAAIA,EAGTtX,KAAK2L,KAAO,KACZ3L,KAAKmhI,KAAO,KAGZnhI,KAAKu/B,EAAI,EAGTv/B,KAAKkiI,MAAQ,KACbliI,KAAKmiI,MAAQ,KAGbniI,KAAKqhI,SAAU,CACnB,CA+BA,SAASO,GAAWz/H,EAAMuL,EAAO1L,EAAK4+H,GAElC,IADA,IAAI6E,EAAM,EACD7jI,EAAI8L,EAAO4W,EAAItiB,EAAM4+H,EAAKh/H,EAAII,EAAKJ,GAAKg/H,EAC7C6E,IAAQtjI,EAAKmiB,GAAKniB,EAAKP,KAAOO,EAAKP,EAAI,GAAKO,EAAKmiB,EAAI,IACrDA,EAAI1iB,EAER,OAAO6jI,CACX,CAppBAC,GAAcC,QAAGjF,GACKgF,GAAAC,QAAAC,QAAGlF,GAinBzBA,GAAOmF,UAAY,SAAU1jI,EAAMw+H,EAAaC,EAAKM,GACjD,IAAIJ,EAAWH,GAAeA,EAAYx/H,OACtC4/H,EAAWD,EAAWH,EAAY,GAAKC,EAAMz+H,EAAKhB,OAElD2kI,EAAc75H,KAAKmP,IAAIwmH,GAAWz/H,EAAM,EAAG4+H,EAAUH,IACzD,GAAIE,EACA,IAAK,IAAIl/H,EAAI,EAAGqG,EAAM04H,EAAYx/H,OAAQS,EAAIqG,EAAKrG,IAAK,CACpD,IAAI8L,EAAQizH,EAAY/+H,GAAKg/H,EACzB5+H,EAAMJ,EAAIqG,EAAM,EAAI04H,EAAY/+H,EAAI,GAAKg/H,EAAMz+H,EAAKhB,OACxD2kI,GAAe75H,KAAKmP,IAAIwmH,GAAWz/H,EAAMuL,EAAO1L,EAAK4+H,GACxD,CAGL,IAAImF,EAAgB,EACpB,IAAKnkI,EAAI,EAAGA,EAAIs/H,EAAU//H,OAAQS,GAAK,EAAG,CACtC,IAAIP,EAAI6/H,EAAUt/H,GAAKg/H,EACnBt/H,EAAI4/H,EAAUt/H,EAAI,GAAKg/H,EACvB5pH,EAAIkqH,EAAUt/H,EAAI,GAAKg/H,EAC3BmF,GAAiB95H,KAAKmP,KACjBjZ,EAAKd,GAAKc,EAAK6U,KAAO7U,EAAKb,EAAI,GAAKa,EAAKd,EAAI,KAC7Cc,EAAKd,GAAKc,EAAKb,KAAOa,EAAK6U,EAAI,GAAK7U,EAAKd,EAAI,IACrD,CAED,OAAuB,IAAhBykI,GAAuC,IAAlBC,EAAsB,EAC9C95H,KAAKmP,KAAK2qH,EAAgBD,GAAeA,EACjD,EAYApF,GAAOsF,QAAU,SAAU7jI,GAKvB,IAJA,IAAIy+H,EAAMz+H,EAAK,GAAG,GAAGhB,OACjBsvC,EAAS,CAACtmB,SAAU,GAAI87G,MAAO,GAAItZ,WAAYiU,GAC/CsF,EAAY,EAEPtkI,EAAI,EAAGA,EAAIO,EAAKhB,OAAQS,IAAK,CAClC,IAAK,IAAI0iB,EAAI,EAAGA,EAAIniB,EAAKP,GAAGT,OAAQmjB,IAChC,IAAK,IAAIrN,EAAI,EAAGA,EAAI2pH,EAAK3pH,IAAKw5B,EAAOtmB,SAASxkB,KAAKxD,EAAKP,GAAG0iB,GAAGrN,IAE9DrV,EAAI,IACJskI,GAAa/jI,EAAKP,EAAI,GAAGT,OACzBsvC,EAAOw1F,MAAMtgI,KAAKugI,GAEzB,CACD,OAAOz1F,CACX,wBCjqBO,MAAM01F,GAAiC,KAGxCC,GAAY,GAQZC,GAAmB,CAACC,eAAgB,EAAGC,cAAe,GAS5D,SAASC,GAAiB7sH,EAAQuuC,EAAK7wC,EAAGC,EAAGrU,GAC3C0W,EAAOuuC,EAAM,GAAK7wC,EAClBsC,EAAOuuC,EAAM,GAAK5wC,EAClBqC,EAAOuuC,EAAM,GAAKjlD,CACpB,CA2WO,SAASwjI,GAAcj5H,EAAI9C,GAEhC,MAAMg8H,EAAQ,IACRC,EAASD,IAKf,OAPAh8H,EAAQA,GAAS,IAGX,GAAKuB,KAAKuT,MAAMhS,EAAKk5H,EAAQA,EAAQA,GAASC,EACpDj8H,EAAM,GAAMuB,KAAKuT,MAAMhS,EAAKk5H,EAAQA,GAASA,EAASC,EACtDj8H,EAAM,GAAMuB,KAAKuT,MAAMhS,EAAKk5H,GAASA,EAASC,EAC9Cj8H,EAAM,GAAM8C,EAAKk5H,EAASC,EACnBj8H,CACT,CAQO,SAASk8H,GAAc38F,GAC5B,IAAIz8B,EAAK,EACT,MAAMk5H,EAAQ,IACRG,EAAOH,IAKb,OAJAl5H,GAAMvB,KAAKiZ,MAAM+kB,EAAM,GAAKy8F,EAAQA,EAAQA,EAAQG,GACpDr5H,GAAMvB,KAAKiZ,MAAM+kB,EAAM,GAAKy8F,EAAQA,EAAQG,GAC5Cr5H,GAAMvB,KAAKiZ,MAAM+kB,EAAM,GAAKy8F,EAAQG,GACpCr5H,GAAMvB,KAAKiZ,MAAM+kB,EAAM,GAAK48F,GACrBr5H,CACT,CC/SA,IAAIs5H,GAAW,EACR,MAAMC,GAAW,EACXC,GAAc,GAAKF,KACnBG,GAAa,GAAKH,KAClBI,GAAa,GAAKJ,KAClBK,GAAY,GAAKL,KACjBM,GAAkB,GAAKN,KACvBO,GAAUp7H,KAAKC,IAAI,EADI46H,GACW,EAEzCQ,GAAY,CAChBN,CAACA,IAAc,UACfC,CAACA,IAAa,SACdC,CAACA,IAAa,SACdC,CAACA,IAAY,QACbC,CAACA,IAAkB,YAGfG,GAAa7gI,OAAOC,KAAK2gI,IAAWx8F,IAAIX,QAAQ7V,KAAKtzB,GAOpD,SAASwmI,GAASznI,GACvB,MAAM0qC,EAAQ,GACd,IAAK,MAAMg9F,KAAaF,GAClBG,GAAa3nI,EAAM0nI,IACrBh9F,EAAM9kC,KAAK2hI,GAAUG,IAGzB,OAAqB,IAAjBh9F,EAAMtpC,OACD,UAELspC,EAAMtpC,OAAS,EACVspC,EAAM3xB,KAAK,QAEb2xB,EAAM3mC,MAAM,GAAI,GAAGgV,KAAK,MAAQ,QAAU2xB,EAAMA,EAAMtpC,OAAS,EACxE,CAOO,SAASumI,GAAaC,EAAOC,GAClC,OAAQD,EAAQC,KAAcA,CAChC,CAOO,SAASC,GAAaC,EAASC,GACpC,SAAUD,EAAUC,EACtB,CAOO,SAASC,GAAOjoI,EAAMimG,GAC3B,OAAOjmG,IAASimG,CAClB,CAMO,MAAMiiC,GAKX,WAAAnoI,CAAYC,EAAMsE,GAChBrE,KAAKD,KAAOA,EACZC,KAAKqE,MAAQA,CACd,EAGI,MAAM6jI,GAMX,WAAApoI,CAAYC,EAAMooI,KAAaj/G,GAC7BlpB,KAAKD,KAAOA,EACZC,KAAKmoI,SAAWA,EAChBnoI,KAAKkpB,KAAOA,CACb,EAkBI,SAASk/G,KACd,MAAO,CACLC,UAAW,IAAI12E,IACf78C,WAAY,IAAI68C,IAChBosC,WAAW,EACXxtF,MAAO,CAAE,EAEb,CAiCO,SAAS26B,GAAMo9F,EAASn4H,EAASo4H,GACtC,cAAeD,GACb,IAAK,UACH,OAAO,IAAIL,GAAkBjB,GAAasB,GAE5C,IAAK,SACH,OAAO,IAAIL,GAAkBhB,GAAYqB,GAE3C,IAAK,SAAU,CACb,IAAIvoI,EAAOmnI,GAQX,OAPIr7F,GAAcy8F,KAChBvoI,GAAQonI,IAGLa,GAAOjoI,EAAOwoI,EAAUxB,MAC3BhnI,GAAQwoI,GAEH,IAAIN,GAAkBloI,EAAMuoI,EACpC,EAMH,IAAKjmI,MAAMC,QAAQgmI,GACjB,MAAM,IAAI9/H,MAAM,oDAGlB,GAAuB,IAAnB8/H,EAAQnnI,OACV,MAAM,IAAIqH,MAAM,oBAGlB,GAA0B,iBAAf8/H,EAAQ,GACjB,OAsxBJ,SAA6BA,EAASn4H,EAASo4H,GAC7C,MAAMJ,EAAWG,EAAQ,GAEnB7W,EAASD,GAAQ2W,GACvB,IAAK1W,EACH,MAAM,IAAIjpH,MAAM,qBAAqB2/H,KAEvC,OAAO1W,EAAO6W,EAASn4H,EAASo4H,EAClC,CA9xBWC,CAAoBF,EAASn4H,EAASo4H,GAG/C,IAAK,MAAMj9H,KAAQg9H,EACjB,GAAoB,iBAATh9H,EACT,MAAM,IAAI9C,MAAM,gCAIpB,IAAIzI,EAAOqnI,GAOX,OANuB,IAAnBkB,EAAQnnI,QAAmC,IAAnBmnI,EAAQnnI,SAClCpB,GAAQonI,IAENoB,IACFxoI,GAAQwoI,GAEH,IAAIN,GAAkBloI,EAAMuoI,EACrC,CAKO,MAAMG,GAAM,CACjBC,IAAK,MACLC,IAAK,MACLC,OAAQ,SACRC,aAAc,gBACdC,IAAK,MACLC,IAAK,MACLC,IAAK,IACLC,WAAY,aACZj1E,KAAM,OACNk1E,KAAM,OACNC,MAAO,KACPC,SAAU,KACVC,YAAa,IACbC,qBAAsB,KACtBC,SAAU,IACVC,kBAAmB,KACnBC,SAAU,IACVC,OAAQ,IACRC,IAAK,IACLC,SAAU,IACVC,MAAO,QACPC,IAAK,IACLC,IAAK,IACLC,IAAK,MACLC,MAAO,QACPC,KAAM,OACNC,MAAO,QACPC,IAAK,MACLC,IAAK,MACLC,KAAM,OACNC,KAAM,OACNC,MAAO,QACPC,QAAS,UACTC,YAAa,cACbC,KAAM,OACNC,GAAI,KACJzgG,OAAQ,SACRthC,OAAQ,SACRxG,MAAO,QACPwoI,MAAO,QACPC,GAAI,KACJC,KAAM,OACNC,QAAS,WAWLxZ,GAAU,CACd,CAACiX,GAAIC,KAAMuC,IACT,EAAEn/F,EAAGy8F,UACc/hI,IAAb+hI,EA3IV,SAAyBA,GACvB,OAAQA,GACN,IAAK,SACH,OAAOrB,GACT,IAAK,QACH,OAAOC,GACT,IAAK,SACH,OAAOF,GACT,IAAK,UACH,OAAOD,GACT,IAAK,WACH,OAAOI,GACT,QACE,MAAM,IAAI5+H,MAAM,2BAA2B+/H,KAEjD,CA6He2C,CAE8B,EAC7C,OAGa7D,IAET8D,GAAc,EAAG,IA8OrB,SAAqB7C,EAASn4H,GAC5B,MAAMuvB,EAAMwL,GAAMo9F,EAAQ,GAAIn4H,GAC9B,KAAMuvB,aAAeuoG,IACnB,MAAM,IAAIz/H,MAAM,iDAElB,GAAyB,iBAAdk3B,EAAIr7B,MACb,MAAM,IAAImE,MAAM,gDAGlB,GADA2H,EAAQ2E,WAAW2O,IAAIic,EAAIr7B,OACJ,IAAnBikI,EAAQnnI,OAAc,CAExB,MAAO,CAACu+B,EADKwL,GAAMo9F,EAAQ,GAAIn4H,GAEhC,CACD,MAAO,CAACuvB,EACV,IAzPE,CAAC+oG,GAAIE,KAAMsC,IACT,EAAEG,KAAcA,EAASrrI,MACzBorI,GAAc,EAAG,IA4PrB,SAAqB7C,EAASn4H,EAASk7H,EAAY9C,GACjD,MAAM+C,EAAUhD,EAAQ,GACxB,GAAuB,iBAAZgD,EACT,MAAM,IAAI9iI,MAAM,gDAGlB,GADA2H,EAAQk4H,UAAU5kH,IAAI6nH,KAElB,cAAen7H,EAAQI,aACY/J,IAArC2J,EAAQI,MAAM83H,UAAUiD,GAExB,MAAO,CAAC,IAAIrD,GAAkBZ,GAASiE,IAEzC,MAAMC,EAAep7H,EAAQI,MAAM83H,UAAUiD,GACvC5rG,EAAwCwL,GAAMqgG,EAAcp7H,GAElE,GADAuvB,EAAIr7B,MAAQinI,EACR/C,IAAaV,GAAaU,EAAU7oG,EAAI3/B,MAC1C,MAAM,IAAIyI,MACR,gBAAgB8iI,cAAoB9D,GAClC9nG,EAAI3/B,8CACoCynI,GAASe,MAGvD,MAAO,CAAC7oG,EACV,IAhRE,CAAC+oG,GAAIqC,IAAKG,GAAahE,GAAaC,GAAYsE,IAqRlD,SAAuBlD,EAASn4H,GAC9BA,EAAQ4tF,WAAY,CACtB,IAtRE,CAAC0qC,GAAIG,QAASqC,GACZ/D,GACAiE,GAAc,EAAG1wH,KACjBgxH,GAAgBpE,KAElB,CAACoB,GAAII,cAAeoC,GAAa/D,GAAYsE,IAC7C,CAAC/C,GAAIQ,YAAagC,GAAahE,GAAYuE,IAC3C,CAAC/C,GAAIz0E,MAAOi3E,GAAahE,GAAYuE,IACrC,CAAC/C,GAAIS,MAAO+B,GAAahE,GAAYuE,IACrC,CAAC/C,GAAIK,KAAMmC,GACTjE,GACAmE,GAAc,EAAG1wH,KACjBgxH,GAAgBzE,KAElB,CAACyB,GAAIM,KAAMkC,GACTjE,GACAmE,GAAc,EAAG1wH,KACjBgxH,GAAgBzE,KAElB,CAACyB,GAAIO,KAAMiC,GACTjE,GACAmE,GAAc,EAAG,GACjBM,GAAgBzE,KAElB,CAACyB,GAAIU,OAAQ8B,GACXjE,GACAmE,GAAc,EAAG,GACjBM,GAAgBpE,IAChBqE,IAEF,CAACjD,GAAIW,UAAW6B,GACdjE,GACAmE,GAAc,EAAG,GACjBM,GAAgBpE,IAChBqE,IAEF,CAACjD,GAAIY,aAAc4B,GACjBjE,GACAmE,GAAc,EAAG,GACjBM,GAAgBpE,IAChBqE,IAEF,CAACjD,GAAIa,sBAAuB2B,GAC1BjE,GACAmE,GAAc,EAAG,GACjBM,GAAgBpE,IAChBqE,IAEF,CAACjD,GAAIc,UAAW0B,GACdjE,GACAmE,GAAc,EAAG,GACjBM,GAAgBpE,IAChBqE,IAEF,CAACjD,GAAIe,mBAAoByB,GACvBjE,GACAmE,GAAc,EAAG,GACjBM,GAAgBpE,IAChBqE,IAEF,CAACjD,GAAIgB,UAAWwB,IACbI,IACC,IAAIM,EAAa1E,GAAaE,GAC9B,IAAK,IAAIvlI,EAAI,EAAGA,EAAIypI,EAAWlqI,OAAQS,IACrC+pI,GAAcN,EAAWzpI,GAAG7B,KAE9B,OAAO4rI,CAAU,GAEnBR,GAAc,EAAG1wH,KACjBgxH,GAAgBxE,GAAaE,IAC7BuE,IAEF,CAACjD,GAAIiB,QAASuB,GACZhE,GACAkE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAIkB,KAAMsB,GACThE,GACAkE,GAAc,EAAG1wH,KACjBgxH,GAAgBxE,KAElB,CAACwB,GAAImB,UAAWqB,GACdhE,GACAkE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAIoB,OAAQoB,GACXhE,GACAkE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAIqB,KAAMmB,GACThE,GACAkE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAIsB,KAAMkB,GACThE,GACAkE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAIuB,KAAMiB,GACThE,GACAkE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAIwB,OAAQgB,GACXhE,GACAkE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAIyB,MAAOe,GACVhE,GACAkE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAI0B,OAAQc,GACXhE,GACAkE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAI2B,KAAMa,GACThE,GACAkE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAI4B,KAAMY,GACThE,GACAkE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAI6B,MAAOW,GACVhE,GACAkE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAI8B,MAAOU,GACVhE,GACAkE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAI+B,OAAQS,IACVI,IACC,IAAItrI,EAAOsnI,GACX,IAAK,IAAIzlI,EAAI,EAAGA,EAAIypI,EAAWlqI,OAAQS,GAAK,EAC1C7B,GAAQsrI,EAAWzpI,GAAG7B,KAGxB,OADAA,GAAQsrI,EAAWA,EAAWlqI,OAAS,GAAGpB,KACnCA,CAAI,GAEborI,GAAc,EAAG1wH,KACjBmxH,IAgQJ,SAAwBtD,EAASn4H,EAASk7H,EAAY9C,GACpD,MAAMsD,EAAYvD,EAAQnnI,OAAS,EAE7B6hB,EAAQkoB,GAAMo9F,EAAQ,GAAIn4H,GAChC,IAAI27H,EAAY9oH,EAAMjjB,KACtB,MAAMgsI,EAAW7gG,GAAMo9F,EAAQA,EAAQnnI,OAAS,GAAIgP,GACpD,IAAIw7H,OACWnlI,IAAb+hI,EAAyBA,EAAWwD,EAAShsI,KAAOgsI,EAAShsI,KAG/D,MAAMmpB,EAAO,IAAI7mB,MAAMwpI,EAAY,GACnC,IAAK,IAAIjqI,EAAI,EAAGA,EAAIiqI,EAAY,EAAGjqI,GAAK,EAAG,CACzC,MAAMqpC,EAAQC,GAAMo9F,EAAQ1mI,EAAI,GAAIuO,GAC9B8S,EAASioB,GAAMo9F,EAAQ1mI,EAAI,GAAIuO,GACrC27H,GAAa7gG,EAAMlrC,KACnB4rI,GAAc1oH,EAAOljB,KACrBmpB,EAAKtnB,GAAKqpC,EACV/hB,EAAKtnB,EAAI,GAAKqhB,CACf,CAGD,MAAM+oH,EAAoB9E,GAAaD,GAAaD,GACpD,IAAKa,GAAamE,EAAmBF,GACnC,MAAM,IAAItjI,MACR,6BAA6Bg/H,GAC3BwE,yCAC2CxE,GAASsE,cAG1D,GAAI9D,GAAO2D,EAAY5E,IACrB,MAAM,IAAIv+H,MACR,0EACE6lE,KAAKmjB,UAAU82C,IAKrB,IAAK,IAAI1mI,EAAI,EAAGA,EAAIiqI,EAAY,EAAGjqI,GAAK,EAAG,CACzC,MAAMqpC,EAAQC,GAAMo9F,EAAQ1mI,EAAI,GAAIuO,EAAS27H,GACvC7oH,EAASioB,GAAMo9F,EAAQ1mI,EAAI,GAAIuO,EAASw7H,GAC9CziH,EAAKtnB,GAAKqpC,EACV/hB,EAAKtnB,EAAI,GAAKqhB,CACf,CAED,MAAO,CACLioB,GAAMo9F,EAAQ,GAAIn4H,EAAS27H,MACxB5iH,EACHgiB,GAAMo9F,EAAQA,EAAQnnI,OAAS,GAAIgP,EAASw7H,GAEhD,IA9SE,CAAClD,GAAIgC,SAAUQ,GACbjE,GACAmE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAIiC,aAAcO,IAChBI,IACC,IAAItrI,EAAOonI,GAAYF,GACvB,IAAK,IAAIrlI,EAAI,EAAGA,EAAIypI,EAAWlqI,OAAQS,GAAK,EAC1C7B,GAAQsrI,EAAWzpI,GAAG7B,KAExB,OAAOA,CAAI,GAEborI,GAAc,EAAG1wH,KACjBmxH,IAqSJ,SAA8BtD,EAASn4H,EAASk7H,EAAY9C,GAC1D,MAAM0D,EAAoB3D,EAAQ,GAClC,IAAI4D,EACJ,OAAQD,EAAkB,IACxB,IAAK,SACHC,EAAgB,EAChB,MACF,IAAK,cAEH,GADAA,EAAgBD,EAAkB,GACL,iBAAlBC,EACT,MAAM,IAAI1jI,MAEN,6DAAS6lE,KAAKmjB,UAAU06C,cAG9B,MACF,QACEA,EAAgB,KAEpB,IAAKA,EACH,MAAM,IAAI1jI,MACR,+BAA+B6lE,KAAKmjB,UAAUy6C,MAGlDC,EAAgBhhG,GAAMghG,EAAe/7H,GAGrC,IAAI6S,EAAQkoB,GAAMo9F,EAAQ,GAAIn4H,GAC9B,IAAK03H,GAAaZ,GAAYjkH,EAAMjjB,MAClC,MAAM,IAAIyI,MAEN,uEAASg/H,GAASxkH,EAAMjjB,iBAG9BijB,EAAQkoB,GAAMo9F,EAAQ,GAAIn4H,EAAS82H,IAEnC,MAAM/9G,EAAO,IAAI7mB,MAAMimI,EAAQnnI,OAAS,GACxC,IAAK,IAAIS,EAAI,EAAGA,EAAIsnB,EAAK/nB,OAAQS,GAAK,EAAG,CACvC,IAAI2pF,EAAOrgD,GAAMo9F,EAAQ1mI,EAAI,GAAIuO,GACjC,IAAK03H,GAAaZ,GAAY17C,EAAKxrF,MACjC,MAAM,IAAIyI,MAEN,yFAASg/H,GAASj8C,EAAKxrF,qBAAqB6B,EAAI,aAGtD,IAAIqhB,EAASioB,GAAMo9F,EAAQ1mI,EAAI,GAAIuO,GACnC,IAAK03H,GAAaZ,GAAaE,GAAWlkH,EAAOljB,MAC/C,MAAM,IAAIyI,MAEN,6FAASg/H,GAASvkH,EAAOljB,qBAAqB6B,EAAI,aAIxD2pF,EAAOrgD,GAAMo9F,EAAQ1mI,EAAI,GAAIuO,EAAS82H,IACtChkH,EAASioB,GAAMo9F,EAAQ1mI,EAAI,GAAIuO,EAAS82H,GAAaE,IACrDj+G,EAAKtnB,GAAK2pF,EACVriE,EAAKtnB,EAAI,GAAKqhB,CACf,CAED,MAAO,CAACipH,EAAelpH,KAAUkG,EACnC,IA9VE,CAACu/G,GAAIkC,MAAOM,IACTI,IACC,IAAItrI,EAAOsnI,GACX,IAAK,IAAIzlI,EAAI,EAAGA,EAAIypI,EAAWlqI,OAAQS,GAAK,EAC1C7B,GAAQsrI,EAAWzpI,GAAG7B,KAGxB,OADAA,GAAQsrI,EAAWA,EAAWlqI,OAAS,GAAGpB,KACnCA,CAAI,GAEborI,GAAc,EAAG1wH,MAqMrB,SAAqB6tH,EAASn4H,GAC5B,MAAMkzG,EAAYilB,EAAQ,GACpB6D,EAAW7D,EAAQnnI,OAAS,EAClC,GAAIgrI,EAAW,GAAM,EACnB,MAAM,IAAI3jI,MACR,yDAAyD66G,UAAkBh1C,KAAKmjB,UAC9E26C,aAIR,IA2IA,SAAuB7D,EAASn4H,EAASk7H,EAAY9C,GACnD,MAAMwD,EAAW7gG,GAAMo9F,EAAQA,EAAQnnI,OAAS,GAAIgP,GACpD,IAAIw7H,OACWnlI,IAAb+hI,EAAyBA,EAAWwD,EAAShsI,KAAOgsI,EAAShsI,KAG/D,MAAMmpB,EAAO,IAAI7mB,MAAMimI,EAAQnnI,OAAS,GACxC,IAAK,IAAIS,EAAI,EAAGA,EAAIsnB,EAAK/nB,OAAS,EAAGS,GAAK,EAAG,CAC3C,MAAMy2D,EAAYntB,GAAMo9F,EAAQ1mI,EAAI,GAAIuO,GAClC8S,EAASioB,GAAMo9F,EAAQ1mI,EAAI,GAAIuO,GACrC,IAAK03H,GAAab,GAAa3uE,EAAUt4D,MACvC,MAAM,IAAIyI,MAEN,4EAASg/H,GAASnvE,EAAUt4D,qBAAqB6B,aAGvD+pI,GAAc1oH,EAAOljB,KACrBmpB,EAAKtnB,GAAKy2D,EACVnvC,EAAKtnB,EAAI,GAAKqhB,CACf,CAED,GAAI+kH,GAAO2D,EAAY5E,IACrB,MAAM,IAAIv+H,MACR,yEACE6lE,KAAKmjB,UAAU82C,IAKrB,IAAK,IAAI1mI,EAAI,EAAGA,EAAIsnB,EAAK/nB,OAAS,EAAGS,GAAK,EACxCsnB,EAAKtnB,EAAI,GAAKspC,GAAMo9F,EAAQ1mI,EAAI,GAAIuO,EAASw7H,GAQ/C,OANAziH,EAAKA,EAAK/nB,OAAS,GAAK+pC,GACtBo9F,EAAQA,EAAQnnI,OAAS,GACzBgP,EACAw7H,GAGKziH,CACT,IA7XE,CAACu/G,GAAImC,IAAKK,GAAajE,GAAamE,GAAc,EAAG,IAkYvD,SAAqB7C,EAASn4H,GAE5B,IAAIxP,EAA+B2nI,EAAQ,GAC3C,IAAKjmI,MAAMC,QAAQ3B,GACjB,MAAM,IAAI6H,MACR,6FAGJ,GAA2B,iBAAhB7H,EAAS,GAAiB,CACnC,GAAoB,YAAhBA,EAAS,GACX,MAAM,IAAI6H,MACR,qHAGJ,IAAKnG,MAAMC,QAAQ3B,EAAS,IAC1B,MAAM,IAAI6H,MACR,6FAGJ7H,EAAWA,EAAS,EACrB,CAED,IAAIyrI,EAAalF,GAAaD,GAC9B,MAAM/9G,EAAO,IAAI7mB,MAAM1B,EAASQ,QAChC,IAAK,IAAIS,EAAI,EAAGA,EAAIsnB,EAAK/nB,OAAQS,IAAK,CACpC,MAAM89B,EAAMwL,GAAMvqC,EAASiB,GAAIuO,GAC/Bi8H,GAAc1sG,EAAI3/B,KAClBmpB,EAAKtnB,GAAK89B,CACX,CACD,GAAIsoG,GAAOoE,EAAYrF,IACrB,MAAM,IAAIv+H,MACR,gEACE6lE,KAAKmjB,UAAU82C,IAIrB,MAAM1nI,EAASsqC,GAAMo9F,EAAQ,GAAIn4H,EAASi8H,GAC1C,MAAO,CAACxrI,KAAWsoB,EACrB,IAvaE,CAACu/G,GAAIt+F,QAAS8gG,GACZhE,GACAkE,GAAc,EAAG1wH,KACjBgxH,GAAgBpE,KAElB,CAACoB,GAAI5/H,QAASoiI,GACZ/D,GACAiE,GAAc,EAAG1wH,KACjBgxH,GAAgBpE,KAElB,CAACoB,GAAIpmI,OAAQ4oI,IACVI,GAC8B,IAAtBA,EAAWlqI,QAAsC,IAAtBkqI,EAAWlqI,OACzCimI,GAAkBD,GAClBC,IAEN+D,GAAc,EAAG1wH,KACjBgxH,GAAgBxE,KAElB,CAACwB,GAAIoC,OAAQI,GACX9D,GACAgE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAIsC,MAAOE,GACVhE,GACAkE,GAAc,EAAG,GACjBM,GAAgBxE,KAElB,CAACwB,GAAIuC,SAAUC,GAAa9D,GAAWgE,GAAc,EAAG,IA+Y1D,SAA0B7C,EAASn4H,GACjC,MAAMlN,EAAQioC,GAAMo9F,EAAQ,GAAIn4H,EAAS82H,IACzC,GAAIhkI,EAAMlD,OAASknI,GACjB,MAAM,IAAIz+H,MACR,wDAAwDg/H,GACtDvkI,EAAMlD,iBAIZ,MAAMssI,EAAS/D,EAAQ,GACvB,IAAKjmI,MAAMC,QAAQ+pI,GACjB,MAAM,IAAI7jI,MAAM,mDAElB,MAAM8jI,EAAe,IAAIjqI,MAAMgqI,EAAOlrI,QACtC,IAAK,IAAIS,EAAI,EAAGA,EAAI0qI,EAAanrI,OAAQS,IAAK,CAC5C,MAAMqoC,EAAQiB,GAAMmhG,EAAOzqI,GAAIuO,EAASg3H,IACxC,KAAMl9F,aAAiBg+F,IACrB,MAAM,IAAIz/H,MACR,8BAA8B5G,6BAGlC,IAAKimI,GAAa59F,EAAMlqC,KAAMonI,IAC5B,MAAM,IAAI3+H,MACR,8BAA8B5G,kCAAkC4lI,GAC9Dv9F,EAAMlqC,iBAIZusI,EAAa1qI,GAAKqoC,CACnB,CACD,MAAO,CAAChnC,KAAUqpI,EACpB,KA1WA,SAASd,GAAWlD,EAASn4H,GAC3B,MAAMkzG,EAAYilB,EAAQ,GAC1B,GAAuB,IAAnBA,EAAQnnI,OACV,MAAM,IAAIqH,MAAM,6BAA6B66G,eAE/C,MAAO,EACT,CAOA,SAAS8nB,GAAcoB,EAASC,GAC9B,OAAO,SAAUlE,EAASn4H,GACxB,MAAMkzG,EAAYilB,EAAQ,GACpB6D,EAAW7D,EAAQnnI,OAAS,EAClC,GAAIorI,IAAYC,GACd,GAAIL,IAAaI,EAAS,CAExB,MAAM,IAAI/jI,MACR,YAAY+jI,aAFa,IAAZA,EAAgB,GAAK,WAEWlpB,UAAkB8oB,IAElE,OACI,GAAIA,EAAWI,GAAWJ,EAAWK,EAAS,CAKnD,MAAM,IAAIhkI,MACR,YAJAgkI,IAAY/xH,IACR,GAAG8xH,YACH,GAAGA,QAAcC,qBAEcnpB,UAAkB8oB,IAExD,CACL,CACA,CAMA,SAASV,GAAgBgB,GACvB,OAAO,SAAUnE,EAASn4H,GACxB,MAAMkzG,EAAYilB,EAAQ,GACpB6D,EAAW7D,EAAQnnI,OAAS,EAI5B+nB,EAAO,IAAI7mB,MAAM8pI,GACvB,IAAK,IAAIvqI,EAAI,EAAGA,EAAIuqI,IAAYvqI,EAAG,CACjC,MAAM8qI,EAAaxhG,GAAMo9F,EAAQ1mI,EAAI,GAAIuO,GACzC,IAAK03H,GAAa4E,EAASC,EAAW3sI,MAAO,CAC3C,MAAM4sI,EAAUnF,GAASiF,GACnBG,EAAepF,GAASkF,EAAW3sI,MACzC,MAAM,IAAIyI,MACR,gCAAgC5G,QAAQyhH,oBAC7BspB,kBAAwBC,IAEtC,CACDF,EAAW3sI,MAAQ0sI,EACnBvjH,EAAKtnB,GAAK8qI,CACX,CACD,OAAOxjH,CACX,CACA,CAKA,SAASwiH,GAAepD,EAASn4H,EAASk7H,GACxC,MAAMhoB,EAAYilB,EAAQ,GACpB6D,EAAW7D,EAAQnnI,OAAS,EAGlC,IAAI0rI,EAAWxF,GACf,IAAK,IAAIzlI,EAAI,EAAGA,EAAIypI,EAAWlqI,SAAUS,EACvCirI,GAAYxB,EAAWzpI,GAAG7B,KAG5B,GAAI8sI,IAAa9F,GACf,MAAM,IAAIv+H,MACR,kDAAkD66G,eAKtD,MAAMn6F,EAAO,IAAI7mB,MAAM8pI,GACvB,IAAK,IAAIvqI,EAAI,EAAGA,EAAIuqI,IAAYvqI,EAC9BsnB,EAAKtnB,GAAKspC,GAAMo9F,EAAQ1mI,EAAI,GAAIuO,EAAS08H,GAE3C,OAAO3jH,CACT,CAoBA,SAAS0iH,GAAatD,EAASn4H,GAC7B,MAAMkzG,EAAYilB,EAAQ,GACpB6D,EAAW7D,EAAQnnI,OAAS,EAClC,GAAIgrI,EAAW,GAAM,EACnB,MAAM,IAAI3jI,MACR,0DAA0D66G,UAAkBh1C,KAAKmjB,UAC/E26C,aAIR,CA2PA,SAASlB,GAAa6B,KAAeC,GACnC,OAAO,SAAUzE,EAASn4H,EAASo4H,GACjC,MAAMJ,EAAWG,EAAQ,GACzB,IAAI+C,EAAa,GACjB,IAAK,IAAIzpI,EAAI,EAAGA,EAAImrI,EAAc5rI,OAAQS,IACxCypI,EACE0B,EAAcnrI,GAAG0mI,EAASn4H,EAASk7H,EAAY9C,IAAa8C,EAEhE,IAAI2B,EACoB,mBAAfF,EAA4BA,EAAWzB,GAAcyB,EAC9D,QAAiBtmI,IAAb+hI,EAAwB,CAC1B,IAAKV,GAAamF,EAAYzE,GAC5B,MAAM,IAAI//H,MACR,mDAAmDg/H,GACjDe,mBACgBf,GAASwF,eAAwB3+D,KAAKmjB,UACtD82C,MAIN0E,GAAczE,CACf,CACD,GAAIyE,IAAejG,GACjB,MAAM,IAAIv+H,MACR,4DAA4D6lE,KAAKmjB,UAC/D82C,MAIN,OAAO,IAAIJ,GAAe8E,EAAY7E,KAAakD,EACvD,CACA,CCviCA,SAAS4B,GAAiB5Z,EAAI0F,EAASlsH,GACrC,MAAMqgI,EAAiBrgI,EAAcwmH,EAAGoD,OAASpD,EAAGyM,QACpDzM,EAAG+C,YAAY/C,EAAGgD,WAAY0C,GAC9B1F,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGqD,eAAgBrD,EAAGsD,eACtDtD,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGuD,eAAgBvD,EAAGsD,eACtDtD,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAGmD,mBAAoB0W,GACvD7Z,EAAGkD,cAAclD,EAAGgD,WAAYhD,EAAG0M,mBAAoBmN,EACzD,CAsBA,SAASC,GACP/a,EACA2G,EACA52H,EACAuR,EACAsuF,EACAn1F,GAEA,MAAMwmH,EAAKjB,EAAOmD,QAClB,IAAI6X,EACAC,EACJ,GAAIlrI,aAAgBuQ,aAAc,CAChC06H,EAAc/Z,EAAGpF,MACjBmE,EAAO4J,aAAa,qBAEpBqR,EAA+B,OADbjb,EAAO4J,aAAa,2BAE1C,MACIoR,EAAc/Z,EAAG8C,cACjBkX,GAAiB,EAEnBJ,GAAiB5Z,EAAI0F,EAASlsH,GAAewgI,GAE7C,MAAMvrC,EAAc3/F,EAAK4/F,WAAaruF,EAAK,GAC3C,IASIsT,EATAsmH,EAAkB,EAUtB,OATIxrC,EAAc,GAAM,EACtBwrC,EAAkB,EACTxrC,EAAc,GAAM,EAC7BwrC,EAAkB,EACTxrC,EAAc,GAAM,IAC7BwrC,EAAkB,GAIZtrC,GACN,KAAK,EACHh7E,EAASqsG,EAAGka,UACZ,MAEF,KAAK,EACHvmH,EAASqsG,EAAGma,gBACZ,MAEF,KAAK,EACHxmH,EAASqsG,EAAGoa,IACZ,MAEF,KAAK,EACHzmH,EAASqsG,EAAG6C,KACZ,MAEF,QACE,MAAM,IAAI1tH,MAAM,gCAAgCw5F,KAIpD,MAAM0rC,EAAqBra,EAAGsa,aAAata,EAAGua,kBAC9Cva,EAAGwa,YAAYxa,EAAGua,iBAAkBN,GACpCja,EAAGiD,WACDjD,EAAGgD,WACH,EACArvG,EACAtT,EAAK,GACLA,EAAK,GACL,EACAsT,EACAomH,EACAjrI,GAEFkxH,EAAGwa,YAAYxa,EAAGua,iBAAkBF,EACtC,CAKA,IAAI5wB,GAAe,KA2RnB,IAAAgxB,GA5QA,cAA0BC,GAIxB,WAAAjuI,CAAY6K,GACV1F,MAAM0F,GAKN3K,KAAKguI,SAAW,GAMhBhuI,KAAKiuI,YAAcjvE,GACjBr0D,EAAQmvG,KAAK71B,YAAYt5E,EAAQuC,KAAKX,UAAU,KAMlDvM,KAAKgiG,UAAY3zE,IAEjB,MAAM8K,EAAS,IAAI+0G,GAAiBrgB,GAAcE,IAClD50F,EAAO25F,UAAU,CACf,EACA,EACA,EACA,EACA,EACA,EACA,EACA,IAEF9yH,KAAKmyH,QAAQiK,gBAAgBjjG,GAK7Bn5B,KAAKm5B,OAASA,EAEdn5B,KAAKqyH,QAAQ1nH,EAAQuC,KACtB,CAED,UAAAolH,GACE,MAAMF,EAASpyH,KAAKmyH,QACdkB,EAAKjB,EAAOmD,QACZroH,EAAOlN,KAAKkN,KAOlB,IAAI/K,EALJnC,KAAKguI,SAAS7sI,OAAS,EAQrBgB,EADE+K,aAAgB0/E,IAAa1/E,aAAgBwgF,GACxCxgF,EAAKsuB,WAELtuB,EAAK2G,UAGd,MAAMf,EAAQX,GAAYhQ,GAC1B,GAAI2Q,EAAO,CACT,MAAMimH,EAAU1F,EAAGI,gBAKnB,OAJAzzH,KAAKguI,SAASroI,KAAKozH,GACnB/4H,KAAKgiG,UAAY,EA3KvB,SAA4BqxB,EAAI0F,EAASjmH,EAAOjG,GAC9CogI,GAAiB5Z,EAAI0F,EAASlsH,GAE9BwmH,EAAGiD,WAAWjD,EAAGgD,WAAY,EAAGhD,EAAG6C,KAAM7C,EAAG6C,KAAM7C,EAAG8C,cAAerjH,EACtE,CAwKMq7H,CAAmB9a,EAAI0F,EAASjmH,EAAO5F,EAAKL,kBAC5C7M,KAAKuyH,UAEN,CAEDpwH,EAAOoQ,GAAYpQ,GAEnB,MAAM+mG,EAAyC,EAAOv1F,UAChD2tF,EAAY,CAChB4H,EAAe,GAAK,EAAIlpG,KAAK6iF,QAC7BqmB,EAAe,GAAK,EAAIlpG,KAAK6iF,SAEzB0e,EAAUp/F,aAAgBuQ,aAC1B8uF,EAAaF,EAAU,GAAKA,EAAU,GACtCG,EAAWF,EAAU7uF,aAAeF,WACpCmvF,EAAkBF,EAASG,kBAC3BE,EAAc3/F,EAAK4/F,WAAaT,EAAU,GAEhDthG,KAAKgiG,UAAY/1F,KAAKuT,MAAMsiF,EAAcH,EAAkBL,EAAU,IACtE,MAAM8sC,EAAeniI,KAAKkZ,KAAKnlB,KAAKgiG,UAAY,GAEhD,GAAqB,IAAjBosC,EAAoB,CACtB,MAAMrV,EAAU1F,EAAGI,gBAWnB,OAVAzzH,KAAKguI,SAASroI,KAAKozH,GACnBoU,GACE/a,EACA2G,EACA52H,EACAm/F,EACAthG,KAAKgiG,UACL90F,EAAKL,kBAEP7M,KAAKuyH,UAEN,CAED,MAAM8b,EAAoB,IAAIhsI,MAAM+rI,GACpC,IAAK,IAAIE,EAAe,EAAGA,EAAeF,IAAgBE,EAAc,CACtE,MAAMvV,EAAU1F,EAAGI,gBACnBzzH,KAAKguI,SAASroI,KAAKozH,GAEnB,MAAM/2B,EACJssC,EAAeF,EAAe,EAAI,GAAMpuI,KAAKgiG,UAAY,GAAK,EAAK,EACrEqsC,EAAkBC,GAAgB,IAAI7sC,EAASD,EAAaQ,EAC7D,CAED,IAAIG,EAAY,EACZC,EAAY,EAChB,MAAMC,EAAWf,EAAU,GAAKthG,KAAKgiG,UACrC,IAAK,IAAIM,EAAW,EAAGA,EAAWhB,EAAU,KAAMgB,EAAU,CAC1D,IAAK,IAAIC,EAAW,EAAGA,EAAWF,IAAYE,EAAU,CACtD,MAAMgsC,EAAYpsI,EAAKigG,EAAYG,GAE7BuI,EAAa7+F,KAAKuT,MAAM2iF,EAAYniG,KAAKgiG,WACzCoJ,EAAY7I,EAAWviG,KAAKgiG,UAE5BwsC,EAAcH,EADCpiI,KAAKuT,MAAM4rF,EAAY,IAI5CojC,EAAY1jC,GAFM0jC,EAAYrtI,OAASqgG,GACd4J,EAAY,GACoBmjC,IAEvDpsC,CACH,CACDC,GAAaN,EAAcH,CAC5B,CAED,IAAK,IAAI2sC,EAAe,EAAGA,EAAeF,IAAgBE,EAAc,CACtE,MAAMvV,EAAU/4H,KAAKguI,SAASM,GACxBE,EAAcH,EAAkBC,GAEtCnB,GACE/a,EACA2G,EACAyV,EACAltC,EALgBktC,EAAYrtI,OAASqgG,EAOrCt0F,EAAKL,YAER,CAED7M,KAAKuyH,UACN,CAED,eAAA9xH,GACE,MAAM4yH,EAAKrzH,KAAKmyH,QAAQoD,QACxBv1H,KAAKmyH,QAAQkK,aAAar8H,KAAKm5B,QAC/B,IAAK,IAAIv3B,EAAI,EAAGA,EAAI5B,KAAKguI,SAAS7sI,SAAUS,EAC1CyxH,EAAGob,cAAczuI,KAAKguI,SAASpsI,IAEjC5B,KAAKkN,KAAK5G,oBAAoBwB,EAAkB9H,KAAK6hE,kBACtD,CASD,kBAAA6sE,CAAmB57H,EAAO67H,EAAWC,GACnC,MAAMpxD,EAASx9E,KAAK6iF,QACdgsD,EAAc7uI,KAAKiuI,YAAY,GAC/Ba,EAAe9uI,KAAKiuI,YAAY,GAEjCnxB,KAzLPA,GAAettG,GAAsB,EAAG,OAAGhJ,EAAW,CACpDuM,oBAAoB,KA2LpB+pG,GAAa1sG,UAAU,EAAG,EAAG,EAAG,GAEhC,MAGM2+H,EAHcj8H,EAAMrD,MAGqB,EAAI+tE,EAC7CwxD,EAHel8H,EAAMpD,OAGsB,EAAI8tE,EAE/CyxD,EACJzxD,EAASvxE,KAAKuT,MAAMuvH,GAA4BJ,EAAYE,IAExDK,EACJ1xD,EACAvxE,KAAKuT,MAAMwvH,GAA6BJ,EAAYE,IAEtD,IAAI3sI,EACJ,IACE26G,GAAa9pG,UAAUF,EAAOm8H,EAAWC,EAAW,EAAG,EAAG,EAAG,EAAG,EAAG,GACnE/sI,EAAO26G,GAAa7pG,aAAa,EAAG,EAAG,EAAG,GAAG9Q,IAC9C,CAAC,MAAOmC,GAEP,OADAw4G,GAAe,KACR,IACR,CACD,OAAO36G,CACR,CAUD,kBAAAgtI,CAAmBhtI,EAAMitI,EAAYT,EAAWC,GAC9C,MAAMpxD,EAASx9E,KAAK6iF,QACdgsD,EAAc7uI,KAAKiuI,YAAY,GAC/Ba,EAAe9uI,KAAKiuI,YAAY,GAEhCc,EAA2BK,EAAW,GACtCJ,EAA4BI,EAAW,GACvCC,EAAcN,EAA2B,EAAIvxD,EAC7C8xD,EAAeN,EAA4B,EAAIxxD,EAE/CyxD,EACJzxD,EAASvxE,KAAKuT,MAAMuvH,GAA4BJ,EAAYE,IAExDK,EACJ1xD,EACAvxE,KAAKuT,MAAMwvH,GAA6BJ,EAAYE,IAEtD,GAAI3sI,aAAgBwQ,SAAU,CAC5B,MAAMkvF,EAAgB1/F,EAAK4/F,YAAcstC,EAAcC,GACjDv0H,EAAS8mF,GAAiBqtC,EAAYG,EAAcJ,GACpDt1H,EAASxX,EAAKwX,OAAO7V,MAAMiX,EAAQA,EAAS8mF,GAClD,OAAO,IAAIlvF,SAASgH,EACrB,CAED,MAAMoB,EAAS/a,KAAKgiG,WAAaktC,EAAYG,EAAcJ,GAC3D,OAAO9sI,EAAK2B,MAAMiX,EAAQA,EAAS/a,KAAKgiG,UACzC,CAQD,YAAAutC,CAAaZ,EAAWC,GACtB,IAAK5uI,KAAK26B,OACR,OAAO,KAGT,GAAI36B,KAAKkN,gBAAgB6zF,GAAU,CACjC,MAAM5+F,EAAOnC,KAAKkN,KAAK2G,UACjBwtF,EAAY9uF,GAAYpQ,GAC9B,GAAIk/F,EAAW,CACb,MAAM+tC,EAAapvI,KAAKkN,KAAKyG,UAC7B,OAAO3T,KAAKmvI,mBACV9tC,EACA+tC,EACAT,EACAC,EAEH,CACD,OAAO5uI,KAAK0uI,mBAAmBv8H,GAAYhQ,GAAOwsI,EAAWC,EAC9D,CAED,OAAO5uI,KAAK0uI,mBAAmB1uI,KAAKkN,KAAKsuB,WAAYmzG,EAAWC,EACjE,GC/WH,MAAMY,WAA2BxyB,GAK/B,WAAAl9G,CAAY8tC,EAAOjjC,GACjB1F,MAAM2oC,GAENjjC,EAAUA,GAAW,GAQrB3K,KAAKyvI,uBzMfA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GyMqBrBzvI,KAAKo9G,cAAgB,KAKrBp9G,KAAK0vI,eAAiB/kI,EAAQgxH,cAK9B37H,KAAKo1H,UAAYzqH,EAAQ0qH,SAMzBr1H,KAAKoyH,OAELxkF,EAAM/jC,kBAAkB6iC,GAAmB1sC,KAAK2vI,aAAazoI,KAAKlH,OAElEA,KAAK4vI,wBAA0B5vI,KAAK4vI,wBAAwB1oI,KAAKlH,MACjEA,KAAK6vI,yBAA2B7vI,KAAK6vI,yBAAyB3oI,KAAKlH,KACpE,CAOD,uBAAA4vI,CAAwBz/H,EAASstC,GAC/B,MAAM7P,EAAQ5tC,KAAK28G,WACnB,GAAI/uE,EAAMnnC,YAAYg4C,IAA6B,CACjD,MAAM54C,EAAQ,IAAI6gD,GAChBjI,QACAj4C,EACAi3C,EACAttC,GAEFy9B,EAAMhoC,cAAcC,EACrB,CACF,CAOD,wBAAAgqI,CAAyB1/H,EAASstC,GAChC,MAAM7P,EAAQ5tC,KAAK28G,WACnB,GAAI/uE,EAAMnnC,YAAYg4C,IAA8B,CAClD,MAAM54C,EAAQ,IAAI6gD,GAChBjI,QACAj4C,EACAi3C,EACAttC,GAEFy9B,EAAMhoC,cAAcC,EACrB,CACF,CAMD,KAAAkQ,CAAMpL,GACJ3K,KAAKo1H,UAAYzqH,EAAQ0qH,SACrBr1H,KAAKoyH,QACPpyH,KAAKoyH,OAAOqJ,YAAYz7H,KAAKo1H,UAEhC,CAKD,YAAAua,GACM3vI,KAAKoyH,SACPpyH,KAAKoyH,OAAO5xH,iBACLR,KAAKoyH,OAEf,CAOD,YAAA/zE,CAAaZ,GACX,GAAIz9C,KAAK28G,WAAWx/D,kBAAmB,CACrC,IAEI7P,EAFAwiG,GAAiB,EACjBC,GAAe,EAEnB,IAAK,IAAInuI,EAAI,EAAGuE,EAAKs3C,EAAWI,iBAAiB18C,OAAQS,EAAIuE,EAAIvE,IAAK,CACpE,MAAMgsC,EAAQ6P,EAAWI,iBAAiBj8C,GAAGgsC,MACvCs2B,EAAWt2B,EAAMwQ,cACvB,KAAM8lB,aAAoBsrE,IAAqB,CAC7CM,GAAiB,EACjB,QACD,CACD,MAAMryB,EAAiB7vE,EAAMH,eAM7B,IALIqiG,GAAkBryB,IAAmBnwE,KACvCyiG,GAAe,EACfD,GAAiB,GAEnBxiG,EAAYmwE,EACRv5C,IAAalkE,KACf,KAEH,CAED,MAAM26H,EACJ,OAASl9E,EAAW2oB,MAAQ,UAAY2pE,EAGvC/vI,KAAKoyH,QACLpyH,KAAKoyH,OAAO2J,sBAAsBpB,KACnC36H,KAAKoyH,OAAOuN,uBAEZ3/H,KAAK2vI,eAEL3vI,KAAKoyH,OAAS,IAAI4d,GAAY,CAC5BrU,cAAe37H,KAAK0vI,eACpBra,SAAUr1H,KAAKo1H,UACfuF,eAAgBA,IAGdrtF,IACFttC,KAAKoyH,OAAOyK,YAAYvvF,UAAYA,GAGtCttC,KAAKiwI,qBAER,CAED,OAAOjwI,KAAKkwI,qBAAqBzyF,EAClC,CAKD,kBAAAwyF,GAAuB,CAQvB,oBAAAC,CAAqBzyF,GACnB,OAAO,CACR,CAKD,eAAAh9C,GACET,KAAK2vI,eACL1qI,MAAMxE,iBACP,CAQD,oBAAAy9G,CAAqBn+G,EAAMoQ,EAASstC,GAClC,MAAM7P,EAAQ5tC,KAAK28G,WACnB,GAAI/uE,EAAMnnC,YAAY1G,GAAO,CAC3BkvB,GACEjvB,KAAKyvI,uBACL,EACA,EACAhyF,EAAWriB,YACVqiB,EAAWriB,WACZ,EACA,GACCqiB,EAAW/pC,KAAK,IAGnB,MAAM7N,EAAQ,IAAI6gD,GAChB3mD,EACAC,KAAKyvI,uBACLhyF,EACAttC,GAEFy9B,EAAMhoC,cAAcC,EACrB,CACF,CAOD,SAAAs4G,CAAUhuG,EAASstC,GACjBz9C,KAAKk+G,qBAAqBz/D,GAA2BtuC,EAASstC,EAC/D,CAOD,UAAA2gE,CAAWjuG,EAASstC,GAClBz9C,KAAKk+G,qBAAqBz/D,GAA4BtuC,EAASstC,EAChE,EAGH,IAAA0yF,GAAeX,GC9OR,MAAMY,GAAW,CACtBC,eAAgB,kBAChBC,iBAAkB,oBAClBC,MAAO,UACPC,cAAe,iBACfC,eAAgB,kBAChBrhG,WAAY,eACZoqF,KAAM,SACNkX,aAAc,gBACdrX,kBAAmB,qBACnBC,uBAAwB,yBAMpBzd,GAAQ,CAAA,EAQd,SAAS80B,GAAUpxG,GACjB,OAAO,GAAKA,EAAI,EAClB,CAcO,SAASqxG,KACd,MAAO,CAACC,QAAS,IAAIl/E,IAAOm/E,mBAAoB,CAAE,EACpD,CAQA,SAASC,GAAcC,EAA0B9jI,GAC/C,OAAO8jI,EAAyBH,QAAQI,IAAIvoI,EAAOwE,GACrD,CAQA,SAASgkI,GACPF,EACAG,EACA5xG,GAEA,MAAMuxG,EAAqBE,EAAyBF,mBAC9CvxG,KAAKuxG,IACTA,EAAmBvxG,GAAK,IAAIoyB,KAE9Bm/E,EAAmBvxG,GAAG9b,IAAI0tH,GAC1BH,EAAyBH,QAAQptH,IAAI/a,EAAOyoI,EAAmBjkI,MACjE,CAOA,SAASkkI,GAAgB3zF,EAAYjkC,GACnC,MAAM4iC,EAAaqB,EAAWI,iBAAiBJ,EAAWoJ,YACtDzK,EAAW5iC,SACbA,EAASoE,GACPpE,EACA8S,GAAe8vB,EAAW5iC,OAAQikC,EAAWjE,UAAUr6B,cAG3D,MAAMjV,EACJkyC,EAAWxO,MAAMuP,kBAEnB,IAAKjzC,EAAOg2C,WAAY,CACtB,MAAMgqE,EAAahgH,EAChBw/E,yBAAyBjsC,EAAWjE,UAAUr6B,YAC9CE,YACC6qG,IACF1wG,EAASoE,GAAgBpE,EAAQ0wG,GAEpC,CACD,OAAO1wG,CACT,CAEO,SAAS63H,GAAYnnI,EAAQqC,GAClC,MAAO,GAAGrC,EAAO8C,YAAYskI,GAAgB/kI,IAC/C,CA4rBA,IAAAglI,GAtqBA,cAAyC/B,GAKvC,WAAA1vI,CAAYqgH,EAAWx1G,GACrB1F,MAAMk7G,EAAW,CACfkV,SAAU1qH,EAAQ0qH,SAClBsG,cAAehxH,EAAQgxH,gBAOzB37H,KAAKwxI,gBAAiB,EAOtBxxI,KAAKyxI,e1MzIA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,G0M+IrBzxI,KAAK0xI,ST3KA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,GSiLnD1xI,KAAK2xI,eAAiB,IAAItmE,GAAU,EAAG,EAAG,EAAG,GAM7CrrE,KAAK4xI,eAAiBC,GAAgB,EAAG,EAAG,GAM5C7xI,KAAK8xI,UAAY,CAAC,EAAG,GAErB,MAAMzmG,OAAkC7kC,IAAtBmE,EAAQ0gC,UAA0B1gC,EAAQ0gC,UAAY,IAKxErrC,KAAK+xI,wBAA0B,IAAI5mE,GAAS9/B,GAM5CrrC,KAAKy9C,WAAa,KAMlBz9C,KAAK6zC,iBAAcrtC,CACpB,CAKD,KAAAuP,CAAMpL,GACJ1F,MAAM8Q,MAAM,CACVs/G,SAAU1qH,EAAQ0qH,UAErB,CAOD,eAAA2c,CAAgB9kI,GACd,MAAMizG,EAAYngH,KAAK28G,WACjBvwB,EAAYl/E,EAAKC,WACjB0yG,EAAyBM,EAAUF,4BACzC,OACE7zB,GAAatgF,GACbsgF,GAAatgF,GACZsgF,GAAatgF,IAAoB+zG,CAErC,CAOD,oBAAAqwB,CAAqBzyF,GACdz9C,KAAK6zC,YAEC4J,EAAWjE,UAAUr6B,aAAenf,KAAK6zC,cAClD7zC,KAAKiyI,aACLjyI,KAAK6zC,YAAc4J,EAAWjE,UAAUr6B,YAHxCnf,KAAK6zC,YAAc4J,EAAWjE,UAAUr6B,WAM1C,MACMjV,EADQlK,KAAK28G,WACEx/D,kBACrB,QAAKjzC,KAIDpF,GAAQssI,GAAgB3zF,EAAYA,EAAWjkC,UAGtB,UAAtBtP,EAAOiD,WACf,CAQD,wBAAA+kI,CAAyBvnI,GACvB,OAAOpC,GACR,CASD,YAAA4pI,CACE10F,EACAjkC,EACA44H,EACApB,EACApxB,GAEA,MAAMpmE,EAAYiE,EAAWjE,UACvB2mE,EAAYngH,KAAK28G,WACjBmE,EAAaX,EAAUhjE,kBACvBt7B,EAAWi/F,EAAWp3B,yBAAyBlwC,EAAUr6B,YACzDq+D,EAASsjC,EAAWv3B,uBAAuB/vC,EAAUr6B,YAErDmwC,EAAgB5mD,EAAOo4G,GACvBxxD,KAAiB7R,EAAWgS,cAChChS,EAAWgS,YAAYH,GAAiB,IAG1C,MAAMG,EAAchS,EAAWgS,YAAYH,GACrCyiF,EAA0B/xI,KAAK+xI,wBAE/BjnG,EAAMq1E,EAAUziE,iBAChB6lF,EAAOt3H,KAAKyP,IAChB02H,EAAWxyB,EACX/9F,EAASqsB,aACTrsB,EAAS8hE,kBACP13E,KAAKwP,IACH0kG,EAAUnyE,mBACVlD,EACIA,EACG6S,UACAnH,qBAAqBvqC,KAAKyP,IAAIykG,EAAUjyE,aAAc,IACzDrsB,EAAS6Z,cAAc,IAE7BolF,EAAW53B,aAGf,IAAK,IAAI3pD,EAAI6yG,EAAU7yG,GAAKgkG,IAAQhkG,EAAG,CACrC,MAAMyrC,EAAYnpD,EAASgiE,0BACzBrqE,EACA+lB,EACAv/B,KAAK2xI,gBAGDniF,EAAiB3tC,EAAS6Z,cAAc6D,GAE9C,IAAK,IAAIloB,EAAI2zD,EAAU5wD,KAAM/C,GAAK2zD,EAAU1wD,OAAQjD,EAClD,IAAK,IAAIC,EAAI0zD,EAAU3wD,KAAM/C,GAAK0zD,EAAUzwD,OAAQjD,EAAG,CACrD,MAAM/K,EAAYslI,GAAgBtyG,EAAGloB,EAAGC,EAAGtX,KAAK4xI,gBAC1Cx2B,EAAWi2B,GAAYvwB,EAAYv0G,GAGzC,IAAI4kI,EAGAjkI,EAmBJ,GAjBI6kI,EAAwBjoE,YAAYsxC,KACtC+1B,EAAqBY,EAAwB3oI,IAAIgyG,GACjDluG,EAAOikI,EAAmBjkI,MAGzBikI,GACDA,EAAmBjkI,KAAK3F,MAAQu5G,EAAW9zG,WAE3CE,EAAO4zG,EAAWn3B,QAChBpqD,EACAloB,EACAC,EACAmmC,EAAWriB,WACXoe,EAAUr6B,aAIV4xH,GAAcC,EAA0B9jI,GAC1C,SAGF,GAAKikI,EASH,GAAInxI,KAAKgyI,gBAAgB9kI,GACvBikI,EAAmB9e,QAAQnlH,OACtB,CACL,MAAMT,EACJS,EAAKD,iBAEPkkI,EAAmB9e,QAAQ5lH,EAC5B,MAfD0kI,EAAqBnxI,KAAKkyI,yBAAyB,CACjDhlI,KAAMA,EACN4sG,KAAMj4F,EACNuwG,OAAQpyH,KAAKoyH,OACb50C,OAAQA,IAEVu0D,EAAwBhoI,IAAIqxG,EAAU+1B,GAYxCD,GACEF,EACAG,EACA5xG,GAGF,MAAM8yG,EAAenlI,EAAKF,SAC1ByiD,EAAY4iF,IAAgB,EAExBnlI,EAAKC,aAAerB,IACjB2xC,EAAWonB,UAAUjX,YAAYykF,IACpC50F,EAAWonB,UAAUzX,QAAQ,CAC3BlgD,EACAoiD,EACAztC,EAASolE,mBAAmB16E,GAC5BijD,IAIP,CAEJ,CACF,CAOD,iBAAA8iF,CAAkB70F,EAAY80F,GAC5BvyI,KAAKoyH,OAAOsK,YAAY18H,KAAKy9C,YAAa80F,GAAgB,EAC3D,CAOD,qBAAAC,CAAsB/0F,GACpB,OAAO,CACR,CAgBD,UAAAg1F,CACEtB,EACAuB,EACAj1F,EACAk1F,EACAnjF,EACAs2B,EACA+6B,EACAjF,EACAg3B,EACAp1D,EACAhzC,GACE,CASJ,cAAAqoG,CAAe1B,EAAoB2B,EAAOt5H,EAAQo5H,GAAS,CAE3D,SAAAG,CACEt1F,EACA0zF,EACA2B,EACAt1D,EACAhkE,EACAw5H,EACAnxH,GAEA,IAAKsvH,EAAmBhtE,MACtB,OAEF,MACM53D,EADO4kI,EAAmBjkI,KACTX,UACjB88E,EAAeioD,GAAgB/kI,GAC/Bi+B,EAAQ6+C,KAAgB2pD,EAAcA,EAAY3pD,GAAgB,EAElE75B,EAAiB3tC,EAAS6Z,cAAco3G,GACxChtD,EAAW9mB,GAAOn9C,EAASoiE,YAAY6uD,GAAQ9yI,KAAK8xI,WACpDjxB,EAAah/F,EAASu2D,UAAU06D,GAChCl3B,EAAa/5F,EAASuhE,mBAAmB72E,GAEzCqmI,EAAQpoG,EAAQ,GAAK,EAAImmG,GAAUmC,GACrCtoG,EAAQ,IACViT,EAAW1H,SAAU,GAGvB,MAAMyD,EAAYiE,EAAWjE,UACvBc,EAAUd,EAAU98B,OAAO,GAC3B69B,EAAUf,EAAU98B,OAAO,GAE3Bu2H,EAAsBntD,EAAS,GAAK,EAAItI,EACxC01D,EAAuBptD,EAAS,GAAK,EAAItI,EAEzC6rB,EAAc4pC,EAAsBC,EAEpCC,GAAW74F,EAAUumE,EAAW,KAAO/6B,EAAS,GAAKt2B,GACrD4jF,GAAWvyB,EAAW,GAAKtmE,IAAYurC,EAAS,GAAKt2B,GAErD6jF,EAAY75F,EAAU78B,WAAa6yC,EAEnC8jF,EAAc/mI,EAAU,GACxBgnI,EAAchnI,EAAU,GAE9BinI,GAAexzI,KAAKyxI,gBACpBgC,GACEzzI,KAAKyxI,eACL,GAAMh0F,EAAW/pC,KAAK,GAAK2/H,EAAaJ,IACvC,GAAMx1F,EAAW/pC,KAAK,GAAK2/H,EAAaJ,IAE3CS,GAAgB1zI,KAAKyxI,eAAgBj4F,EAAU58B,UAC/C62H,GAAezzI,KAAKyxI,eAAgB,EAAG,EAAIpoC,GAC3CsqC,GACE3zI,KAAKyxI,gBACJ3rD,EAAS,IAAMwtD,EAAcH,GAAW31D,GAAUy1D,GAClDntD,EAAS,IAAMytD,EAAcH,GAAW51D,GAAU01D,GAGrDlzI,KAAKyyI,WACT,EACMzyI,KAAKyxI,eACLh0F,EACAjkC,EACAg2C,EACAs2B,EACA+6B,EACAjF,EACAg3B,EACAp1D,EACAhzC,EAEH,CAOD,WAAA8T,CAAYb,GACVz9C,KAAKy9C,WAAaA,EAClBz9C,KAAKwxI,gBAAiB,EACtB,MAAMne,EAAKrzH,KAAKoyH,OAAOmD,QACvBv1H,KAAKm+G,UAAUkV,EAAI51E,GAEnB,MAAMjE,EAAYiE,EAAWjE,UACvB2mE,EAAYngH,KAAK28G,WACjBmE,EAAaX,EAAUhjE,kBACvBt7B,EAAWi/F,EAAWp3B,yBAAyBlwC,EAAUr6B,YACzDq+D,EAASsjC,EAAWv3B,uBAAuB/vC,EAAUr6B,YACrD3F,EAAS43H,GAAgB3zF,EAAYA,EAAWjkC,QAChD+lB,EAAI1d,EAAS8hE,kBACjBnqC,EAAU78B,WACVmkG,EAAW53B,YAMP8nD,EAA2BJ,KAE3BhxB,EAAUO,EAAUH,aAC1B,GAAIviE,EAAW6oB,WAAY,CACzB,MAAMstE,EAAU/xH,EAAS8hE,kBACvBnqC,EAAUH,eACVynE,EAAW53B,YAEP5iB,EAAa8qE,GAAgB3zF,EAAYA,EAAW6oB,YAC1DtmE,KAAKmyI,aACH10F,EACA6oB,EACAstE,EACA5C,EACApxB,EAEH,CAED5/G,KAAKmyI,aAAa10F,EAAYjkC,EAAQ+lB,EAAGyxG,EAA0B,GAC/DpxB,EAAU,GACZnuE,YAAW,KACTzxC,KAAKmyI,aACH10F,EACAjkC,EACA+lB,EAAI,EACJyxG,EACApxB,EAAU,EACX,GACA,GASL,MAAMozB,EAAc,CAAA,EAEd7mD,EAAMzjF,EAAO1I,MACbyN,EAAOgwC,EAAWhwC,KACxB,IAAIomI,GAAQ,EAGZ,IAAK,MAAM1C,KAAsBH,EAC9BF,mBAAmBvxG,GAAI,CACxB,MAAMryB,EAAOikI,EAAmBjkI,KAChC,IACGA,aAAgBwgF,IAAcxgF,aAAgBs2F,KAC/Ct2F,EAAKC,aAAerB,EAEpB,SAEF,MAAMS,EAAYW,EAAKX,UAEvB,GAAI4kI,EAAmBhtE,MAAO,CAC5B,MAAM35B,EAAQt9B,EAAKK,SAAS4+E,EAAK1+E,GACjC,GAAc,IAAV+8B,EAAa,CAEft9B,EAAKW,cAAcs+E,GACnB,QACD,CACD0nD,GAAQ,EAERb,EADqB1B,GAAgB/kI,IACTi+B,CAC7B,CACDxqC,KAAKwxI,gBAAiB,EAUtB,GAP0BxxI,KAAK8zI,cAC7BjyH,EACAtV,EACAgzB,EAAI,EACJyxG,GAIA,SAIF,MAAM7jG,EAAUtrB,EAASqsB,aACzB,IAAK,IAAI6lG,EAAUx0G,EAAI,EAAGw0G,GAAW5mG,IAAW4mG,EAAS,CAQvD,GAPwB/zI,KAAK8zI,cAC3BjyH,EACAtV,EACAwnI,EACA/C,GAIA,KAEH,CACF,CAED,MAAMF,EAAqBE,EAAyBF,mBAC9CrvB,EAAK/6G,OAAOC,KAAKmqI,GAAoBhmG,IAAIX,QAAQ7V,KAAK/yB,GAI5D,GAFuBvB,KAAKwyI,sBAAsB/0F,GAGhD,IAAK,IAAIn5B,EAAI,EAAG2G,EAAKw2F,EAAGtgH,OAAQmjB,EAAI2G,IAAM3G,EAAG,CAC3C,MAAMwuH,EAAQrxB,EAAGn9F,GACjB,IAAK,MAAM6sH,KAAsBL,EAAmBgC,GAAQ,CAC1D,MAAMvmI,EAAY4kI,EAAmBjkI,KAAKX,UAG1C,GAFqB+kI,GAAgB/kI,KAEjBymI,EAClB,SAEF,MAAMp3B,EAAa/5F,EAASuhE,mBAAmB72E,GAC/CvM,KAAK6yI,eACf,EACYC,EACAl3B,EACA+0B,GAAUmC,GAEb,CACF,CAGH9yI,KAAKsyI,kBAAkB70F,EAAYo2F,GAEnC,IAAK,IAAIvvH,EAAI,EAAG2G,EAAKw2F,EAAGtgH,OAAQmjB,EAAI2G,IAAM3G,EAAG,CAC3C,MAAMwuH,EAAQrxB,EAAGn9F,GACjB,IAAK,MAAM6sH,KAAsBL,EAAmBgC,GAAQ,CAErCxB,GADHH,EAAmBjkI,KAAKX,aAEtBymI,GAIpBhzI,KAAK+yI,UACHt1F,EACA0zF,EACA2B,EACAt1D,EACAhkE,EACAw5H,EACAnxH,EAEH,CACF,CAED,IAAK,MAAMsvH,KAAsBL,EAAmBvxG,GAAI,CAEjC+xG,GADHH,EAAmBjkI,KAAKX,aAEtBymI,GAClBhzI,KAAK+yI,UACHt1F,EACA0zF,EACA5xG,EACAi+C,EACAhkE,EACAw5H,EACAnxH,EAGL,CAED7hB,KAAKoyH,OAAOyL,aACVpgF,EACAz9C,KAAK4vI,wBACL5vI,KAAK6vI,0BAGP,MAAMhgI,EAAS7P,KAAKoyH,OAAOyK,YAErBkV,EAA0B/xI,KAAK+xI,wBACrC,KAAOA,EAAwB5lG,kBAAkB,CACpB4lG,EAAwB7mI,MAChC1K,SACpB,CAiBD,OAHAi9C,EAAWgD,oBAAoB96C,MALJ,SAAUmlC,EAAK2S,GACxCqjE,EAAW72B,gBAAgB,GAAKxsC,EAAWjE,UAAUr6B,YACrD2hG,EAAWl3C,YAAYnsB,EAAWjE,UAAUr6B,WAAY08F,GAC9D,IAII77G,KAAKo+G,WAAWiV,EAAI51E,GACb5tC,CACR,CAaD,aAAAikI,CAAcjyH,EAAUtV,EAAWynI,EAAMhD,GACvC,MAAMhmE,EAAYnpD,EAAS+kE,6BACzBr6E,EACAynI,EACAh0I,KAAK2xI,gBAGP,IAAK3mE,EACH,OAAO,EAGT,IAAIse,GAAU,EACd,MAAMyoD,EAA0B/xI,KAAK+xI,wBAC/B7nI,EAASlK,KAAK28G,WAAWx/D,kBAC/B,IAAK,IAAI9lC,EAAI2zD,EAAU5wD,KAAM/C,GAAK2zD,EAAU1wD,OAAQjD,EAClD,IAAK,IAAIC,EAAI0zD,EAAU3wD,KAAM/C,GAAK0zD,EAAUzwD,OAAQjD,EAAG,CACrD,MAAM8jG,EAAWi2B,GAAYnnI,EAAQ,CAAC8pI,EAAM38H,EAAGC,IAC/C,IAAIqjB,GAAS,EACb,GAAIo3G,EAAwBjoE,YAAYsxC,GAAW,CACjD,MAAM+1B,EAAqBY,EAAwB3oI,IAAIgyG,GAErD+1B,EAAmBhtE,QAClB4sE,GAAcC,EAA0BG,EAAmBjkI,QAE5DgkI,GACEF,EACAG,EACA6C,GAEFr5G,GAAS,EAEZ,CACIA,IACH2uD,GAAU,EAEb,CAEH,OAAOA,CACR,CAED,UAAA2oD,GACE,MAAMF,EAA0B/xI,KAAK+xI,wBACrCA,EAAwB5mI,SAASgmI,GAC/BA,EAAmB3wI,YAErBuxI,EAAwBptI,OACzB,CAED,YAAAgrI,GACM3vI,KAAKoyH,QACPpyH,KAAKiyI,aAGPhtI,MAAM0qI,cACP,CAKD,eAAAlvI,GACEwE,MAAMxE,yBACCT,KAAKy9C,UACb,GClyBI,MAAM2yF,GAAW,IACnB6D,GACHC,mBAAoB,iBACpBC,oBAAqB,sBACrBC,qBAAsB,uBACtBC,mBAAoB,sBACpBC,iBAAkB,mBAClBC,iBAAkB,oBAGPC,GAAa,CACxBC,cAAe,kBAMXC,GAAwB,CAC5B,CACEh/H,KAAM8+H,GAAWC,cACjB/gI,KAAM,EACN3T,KAAM65H,GAAc3L,QAoUxB,IAAA0mB,GAtSA,cAAqCC,GAKnC,WAAA90I,CAAYqgH,EAAWx1G,GACrB1F,MAAMk7G,EAAWx1G,GAMjB3K,KAAK60I,SAKL70I,KAAK80I,cAAgBnqI,EAAQopH,aAK7B/zH,KAAK+0I,gBAAkBpqI,EAAQypH,eAmB/Bp0H,KAAKg1I,SAAW,IAAI9G,GAAiBpgB,GAAsBC,IAC3D/tH,KAAKg1I,SAASliB,UAAU,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAMxC9yH,KAAKi1I,iBAAmBtqI,EAAQuqI,iBAAmB,EACpD,CAKD,KAAAn/H,CAAMpL,GACJ1F,MAAM8Q,MAAMpL,GAEZ3K,KAAK80I,cAAgBnqI,EAAQopH,aAC7B/zH,KAAK+0I,gBAAkBpqI,EAAQypH,eAC/Bp0H,KAAKi1I,iBAAmBtqI,EAAQuqI,iBAAmB,GAC/Cl1I,KAAKoyH,SACPpyH,KAAK60I,SAAW70I,KAAKoyH,OAAOmM,WAC1Bv+H,KAAK+0I,gBACL/0I,KAAK80I,eAGV,CAED,kBAAA7E,GACEjwI,KAAK60I,SAAW70I,KAAKoyH,OAAOmM,WAC1Bv+H,KAAK+0I,gBACL/0I,KAAK80I,eAEP90I,KAAKoyH,OAAOgK,gBAAgBp8H,KAAKg1I,SAClC,CAED,wBAAA9C,CAAyBvnI,GACvB,OAAO,IAAIwqI,GAAYxqI,EACxB,CAED,iBAAA2nI,CAAkB70F,EAAY80F,GAC5BttI,MAAMqtI,kBAAkB70F,EAAY80F,GACpCvyI,KAAKoyH,OAAOgG,WAAWp4H,KAAK60I,SAAUp3F,EACvC,CAED,UAAAg1F,CACE2C,EACA1C,EACAj1F,EACAk1F,EACAnjF,EACAs2B,EACA+6B,EACAjF,EACAg3B,EACAp1D,EACAhzC,GAEA,MAAM6oF,EAAKrzH,KAAKoyH,OAAOmD,QACvBv1H,KAAKoyH,OAAOwC,WAAWwgB,EAAYj8G,QACnCn5B,KAAKoyH,OAAOwC,WAAW50H,KAAKg1I,UAC5Bh1I,KAAKoyH,OAAOsN,iBAAiBgV,IAE7B,IAAI7b,EAAc,EAClB,KAAOA,EAAcuc,EAAYpH,SAAS7sI,QAAQ,CAChD,MAAMg8H,EAAc,GAAGiT,GAAS8D,sBAAsBrb,KACtD74H,KAAKoyH,OAAOgE,YACVgf,EAAYpH,SAASnV,GACrBA,EACAsE,KAEAtE,CACH,CAED,IACE,IAAIwc,EAAe,EACnBA,EAAer1I,KAAKi1I,iBAAiB9zI,SACnCk0I,EACF,CACA,MAAMC,EAAiBt1I,KAAKi1I,iBAAiBI,GACvCtc,EAAUuc,EAAe9X,WAAWnK,GAC1CrzH,KAAKoyH,OAAOgE,YAAY2C,EAASF,EAAayc,EAAe5/H,QAC3DmjH,CACH,CAED,MAAMr/E,EAAYiE,EAAWjE,UAEvBy5F,EAAsBntD,EAAS,GAAK,EAAItI,EACxC01D,EAAuBptD,EAAS,GAAK,EAAItI,EAGzCjxE,EADO6oI,EAAYloI,KACFX,UAEjB+mI,EAAc/mI,EAAU,GACxBgnI,EAAchnI,EAAU,GAE9BvM,KAAKoyH,OAAOgM,sBACVgS,GAASC,eACTkF,GAAkBv1I,KAAK0xI,SAAUgB,IAGnC1yI,KAAKoyH,OAAO2L,qBAAqBqS,GAASE,iBAAkB9lG,GAC5DxqC,KAAKoyH,OAAO2L,qBAAqBqS,GAASG,MAAOqC,GAEjD,IAAI4C,EAAe7C,EACfn1D,EAAS,IACXg4D,EAAe55B,EACfh+F,GAAgB43H,EAAc7C,EAAc6C,IAE9Cx1I,KAAKoyH,OAAOiN,oBAAoB+Q,GAASI,cAAegF,GAExDx1I,KAAKoyH,OAAO2L,qBAAqBqS,GAAShhG,WAAYoK,EAAU78B,YAChE3c,KAAKoyH,OAAO2L,qBAAqBqS,GAAS5W,KAAMhgF,EAAUpE,MAE1Dp1C,KAAKoyH,OAAO2L,qBACVqS,GAAS+D,oBACTlB,GAEFjzI,KAAKoyH,OAAO2L,qBACVqS,GAASgE,qBACTlB,GAEFlzI,KAAKoyH,OAAO2L,qBACVqS,GAASiE,mBACT7kF,GAEFxvD,KAAKoyH,OAAO2L,qBACVqS,GAASkE,iBACTzzB,EAAW,GACTyyB,EAAcxtD,EAAS,GAAKt2B,EAC5BguB,EAAShuB,GAEbxvD,KAAKoyH,OAAO2L,qBACVqS,GAASmE,iBACT1zB,EAAW,GACT0yB,EAAcztD,EAAS,GAAKt2B,EAC5BguB,EAAShuB,GAGbxvD,KAAKoyH,OAAOqL,aAAa,EAAGz9H,KAAKg1I,SAASrhI,UAC3C,CAMD,OAAAE,CAAQypC,GAEN,IADWt9C,KAAKoyH,OAAOmD,QAErB,OAAO,KAGT,MAAM93E,EAAaz9C,KAAKy9C,WACxB,IAAKA,EACH,OAAO,KAGT,MAAM7P,EAAQ5tC,KAAK28G,WACbvlG,EAAauH,GACjB8+B,EAAW4B,2BACX/B,EAAMx5C,SAGF01C,EAAYiE,EAAWjE,UACvBwE,EAAcpQ,EAAMvuB,YAC1B,GAAI2+B,IAEClkC,GACCwS,GAAe0xB,EAAaxE,EAAUr6B,YACtC/H,GAGF,OAAO,KAKX,MAAMmmE,EAAU3vC,EAAM6nG,WACpBn8H,GAAe,CAAClC,IAChBoiC,EAAU78B,YAEZ,IAAI/a,EAAGsI,EAAQ2X,EACf,IAAKjgB,EAAI27E,EAAQp8E,OAAS,EAAGS,GAAK,IAAKA,EAErC,GADAsI,EAASqzE,EAAQ37E,GACS,UAAtBsI,EAAOiD,WAAwB,CAEjC,GADA0U,EAAW3X,EAAOw/E,yBAAyBlwC,EAAUr6B,YACjDjV,EAAOg2C,WACT,MAEF,MAAMgqE,EAAaroG,EAASxC,YAC5B,IAAK6qG,GAAcpwG,GAAmBowG,EAAY9yG,GAChD,KAEH,CAEH,GAAIxV,EAAI,EACN,OAAO,KAGT,MAAM8zI,EAAmB11I,KAAK+xI,wBAC9B,IACE,IAAIxyG,EAAI1d,EAAS8hE,kBAAkBnqC,EAAU78B,YAC7C4iB,GAAK1d,EAASqsB,eACZ3O,EACF,CACA,MAAMhzB,EAAYsV,EAAS0lE,yBAAyBnwE,EAAYmoB,GAC1D67E,EAAWi2B,GAAYnnI,EAAQqC,GACrC,IAAKmpI,EAAiB5rE,YAAYsxC,GAChC,SAEF,MAAMg6B,EAAcM,EAAiBtsI,IAAIgyG,GACnCluG,EAAOkoI,EAAYloI,KACzB,IACGA,aAAgBwgF,IAAcxgF,aAAgBs2F,KAC/Ct2F,EAAKC,aAAerB,EAEpB,OAAO,KAET,IAAKspI,EAAYz6G,OACf,SAEF,MAAMkmF,EAAah/F,EAASu2D,UAAU74C,GAChCumD,EAAW9mB,GAAOn9C,EAASoiE,YAAY1kD,IACvCiwB,EAAiB3tC,EAAS6Z,cAAc6D,GAExC89E,GACHjmG,EAAW,GAAKypG,EAAW,IAAMrxD,EAClCjjD,EAAU,GAAKu5E,EAAS,GAEpBw3B,GACHuD,EAAW,GAAKzpG,EAAW,IAAMo4C,EAClCjjD,EAAU,GAAKu5E,EAAS,GAE1B,OAAOsvD,EAAY7F,aAAalyB,EAAKC,EACtC,CACD,OAAO,IACR,CAKD,eAAA78G,GACE,MAAM2xH,EAASpyH,KAAKoyH,OACpB,GAAIA,EAAQ,CACCA,EAAOmD,QACfogB,cAAc31I,KAAK60I,iBACf70I,KAAK60I,SACZziB,EAAOiK,aAAar8H,KAAKg1I,SAC1B,CACD/vI,MAAMxE,yBACCT,KAAKg1I,QACb,GC3UI,SAASY,GAAa71G,GAC3B,MAAMgK,EAAIhK,EAAEnnB,WACZ,OAAOmxB,EAAErkC,SAAS,KAAOqkC,EAAIA,EAAI,IACnC,CAOO,SAAS8rG,GAAYnrI,GAC1B,GAAIA,EAAMvJ,OAAS,GAAKuJ,EAAMvJ,OAAS,EACrC,MAAM,IAAIqH,MACR,kEAGJ,MAAO,MAAMkC,EAAMvJ,UAAUuJ,EAAMogC,IAAI8qG,IAAc98H,KAAK,QAC5D,CASO,SAASg9H,GAAY7rG,GAC1B,MAAMv/B,EAAQkhC,GAAQ3B,GAChBO,EAAQ9/B,EAAMvJ,OAAS,EAAIuJ,EAAM,GAAK,EAE5C,OAAOmrI,GAAY,CAChBnrI,EAAM,GAAK,IAAO8/B,EAClB9/B,EAAM,GAAK,IAAO8/B,EAClB9/B,EAAM,GAAK,IAAO8/B,EACnBA,GAEJ,CAGA,MAAMurG,GAAmB,CAAA,EACzB,IAAIC,GAAuB,EAOpB,SAASC,GAA0BC,GAIxC,OAHMA,KAAUH,KACdA,GAAiBG,GAAUF,MAEtBD,GAAiBG,EAC1B,CASO,SAASC,GAAaD,GAC3B,OAAON,GAAaK,GAA0BC,GAChD,CAOO,SAASE,GAAuBC,GACrC,MAAO,SAAWA,CACpB,CA0CO,SAASC,KACd,MAAO,CACLC,kBAAkB,EAClBlO,UAAW,CAAE,EACbvzH,WAAY,CAAE,EACd0hI,UAAW,CAAE,EACbx0C,UAAW,EACXzxF,MAAO,CAAE,EAEb,CAEA,MAAMkmI,GAAsB,eAEfC,GAAwB,oBAkB9B,SAASC,GACdrO,EACAvoI,EACA62I,EACAC,GAEA,MAAMnK,EAAaxhG,GAAMo9F,EAASsO,EAAgB72I,GAClD,GAAIioI,GAAO0E,EAAW3sI,KAAMgnI,IAC1B,MAAM,IAAIv+H,MAAM,8BAElB,IAAKq/H,GAAa9nI,EAAM2sI,EAAW3sI,MAAO,CACxC,MAAMimG,EAAWwhC,GAASznI,GACpB+2I,EAAStP,GAASkF,EAAW3sI,MACnC,MAAM,IAAIyI,MACR,qCAAqCw9F,UAAiB8wC,IAEzD,CACD,OAAOC,GAAQrK,EAAY3sI,EAAM82I,EACnC,CAMA,SAASG,GAAe/zH,GACtB,MAAO,CAAC9S,EAASu8H,EAAY3sI,KAC3B,MAAMoB,EAASurI,EAAWxjH,KAAK/nB,OACzB+nB,EAAO,IAAI7mB,MAAMlB,GACvB,IAAK,IAAIS,EAAI,EAAGA,EAAIT,IAAUS,EAC5BsnB,EAAKtnB,GAAKm1I,GAAQrK,EAAWxjH,KAAKtnB,GAAI7B,EAAMoQ,GAE9C,OAAO8S,EAAOiG,EAAM/Y,EAAQ,CAEhC,CAKA,MAAM8mI,GAAY,CAChB,CAACxO,GAAIC,KAAM,CAACv4H,EAASu8H,KACnB,MACMwK,EAD6CxK,EAAWxjH,KAAK,GACb,MACnCguH,KAAY/mI,EAAQ2E,aAErC3E,EAAQ2E,WAAWoiI,GAAY,CAC7BxhI,KAAMwhI,EACNn3I,KAAM2sI,EAAW3sI,OAIrB,OADeoQ,EAAQomI,iBAAmB,UAAY,WACtCW,CAAQ,EAE1B,CAACzO,GAAII,cAAe,CAAC14H,EAASu8H,EAAY3sI,KACxC,MAAMm3I,EAAW,eACXC,EAAeviI,IACnB,MAAM7U,EAAO6U,EAAS8Z,UACtB,OAAQ3uB,GACN,IAAK,QACL,IAAK,aACL,IAAK,UACH,OAAOA,EACT,IAAK,aACL,IAAK,kBACL,IAAK,eACH,OAAOA,EAAK4qE,UAAU,GACxB,IAAK,SACH,MAAO,UACT,IAAK,qBACH,OAAOwsE,EAAYviI,EAASunE,gBAAgB,IAE/C,EAEgB+6D,KAAY/mI,EAAQ2E,aAErC3E,EAAQ2E,WAAWoiI,GAAY,CAC7BxhI,KAAMwhI,EACNn3I,KAAMmnI,GACNkQ,UAAYz3F,GACHw3F,EAAYx3F,EAAQzqC,iBAKjC,OADe/E,EAAQomI,iBAAmB,UAAY,WACtCW,CAAQ,EAE1B,CAACzO,GAAIE,KAAM,CAACx4H,EAASu8H,KACnB,MACMpB,EAD6CoB,EAAWxjH,KAAK,GACd,MAQrD,OAPmBoiH,KAAWn7H,EAAQk4H,YAEpCl4H,EAAQk4H,UAAUiD,GAAW,CAC3B51H,KAAM41H,EACNvrI,KAAM2sI,EAAW3sI,OAGdq2I,GAAuB9K,EAAQ,EAExC,CAAC7C,GAAIQ,YAAa,IAAM,eACxB,CAACR,GAAIz0E,MAAO,IAAM,SAClB,CAACy0E,GAAIS,MAAO,IAAM,SAClB,CAACT,GAAIK,KAAMkO,IAAgBK,GAAiB,IAAIA,EAAav+H,KAAK,aAClE,CAAC2vH,GAAIM,KAAMiO,IAAgBK,GAAiB,IAAIA,EAAav+H,KAAK,aAClE,CAAC2vH,GAAIO,KAAMgO,IAAe,EAAE3yI,KAAW,KAAKA,OAC5C,CAACokI,GAAIU,OAAQ6N,IACX,EAAEM,EAAYC,KAAiB,IAAID,QAAiBC,OAEtD,CAAC9O,GAAIW,UAAW4N,IACd,EAAEM,EAAYC,KAAiB,IAAID,QAAiBC,OAEtD,CAAC9O,GAAIY,aAAc2N,IACjB,EAAEM,EAAYC,KAAiB,IAAID,OAAgBC,OAErD,CAAC9O,GAAIa,sBAAuB0N,IAC1B,EAAEM,EAAYC,KAAiB,IAAID,QAAiBC,OAEtD,CAAC9O,GAAIc,UAAWyN,IACd,EAAEM,EAAYC,KAAiB,IAAID,OAAgBC,OAErD,CAAC9O,GAAIe,mBAAoBwN,IACvB,EAAEM,EAAYC,KAAiB,IAAID,QAAiBC,OAEtD,CAAC9O,GAAIgB,UAAWuN,IACbK,GAAiB,IAAIA,EAAav+H,KAAK,YAE1C,CAAC2vH,GAAIiB,QAASsN,IACZ,EAAEM,EAAYC,KAAiB,IAAID,OAAgBC,OAErD,CAAC9O,GAAIkB,KAAMqN,IAAgBK,GAAiB,IAAIA,EAAav+H,KAAK,YAClE,CAAC2vH,GAAImB,UAAWoN,IACd,EAAEM,EAAYC,KAAiB,IAAID,OAAgBC,OAErD,CAAC9O,GAAIoB,OAAQmN,IACX,EAAE3yI,EAAOoX,EAAKC,KAAS,SAASrX,MAAUoX,MAAQC,OAEpD,CAAC+sH,GAAIqB,KAAMkN,IAAe,EAAE3yI,EAAOwgB,KAAY,OAAOxgB,MAAUwgB,OAChE,CAAC4jH,GAAIsB,KAAMiN,IAAe,EAAE3yI,EAAO0sC,KAAW,OAAO1sC,MAAU0sC,OAC/D,CAAC03F,GAAIuB,KAAMgN,IAAe,EAAE3yI,KAAW,OAAOA,OAC9C,CAACokI,GAAIwB,OAAQ+M,IAAe,EAAE3yI,KAAW,SAASA,OAClD,CAACokI,GAAIyB,MAAO8M,IAAe,EAAE3yI,KAAW,QAAQA,OAChD,CAACokI,GAAI0B,OAAQ6M,IAAe,EAAE3yI,KAAW,SAASA,aAClD,CAACokI,GAAI2B,KAAM4M,IAAe,EAAE3yI,KAAW,OAAOA,OAC9C,CAACokI,GAAI4B,KAAM2M,IAAe,EAAE3yI,KAAW,OAAOA,OAC9C,CAACokI,GAAI6B,MAAO0M,IAAe,EAAEM,EAAYC,UAChB/wI,IAAhB+wI,EACH,QAAQD,MAAeC,KACvB,QAAQD,OAEd,CAAC7O,GAAI8B,MAAOyM,IAAe,EAAE3yI,KAAW,QAAQA,OAChD,CAACokI,GAAI+B,OAAQwM,IAAgBK,IAC3B,MAAMr0H,EAAQq0H,EAAa,GACrBtL,EAAWsL,EAAaA,EAAal2I,OAAS,GACpD,IAAIsvC,EAAS,KACb,IAAK,IAAI7uC,EAAIy1I,EAAal2I,OAAS,EAAGS,GAAK,EAAGA,GAAK,EAAG,CAGpD6uC,EAAS,IAAIztB,QAFCq0H,EAAaz1I,QACZy1I,EAAaz1I,EAAI,QACgB6uC,GAAUs7F,IAC3D,CACD,OAAOt7F,CAAM,IAEf,CAACg4F,GAAIgC,SAAUuM,IACb,EAAE3yI,EAAOoX,EAAKC,KAAS,IAAIrX,QAAYoX,QAAUpX,QAAYqX,OAE/D,CAAC+sH,GAAIiC,aAAcsM,IAAe,EAAEQ,EAAUx0H,KAAUq0H,MACtD,IAAI5mG,EAAS,GACb,IAAK,IAAI7uC,EAAI,EAAGA,EAAIy1I,EAAal2I,OAAS,EAAGS,GAAK,EAAG,CACnD,MAAM61I,EAAQJ,EAAaz1I,GACrB81I,EAAUjnG,GAAU4mG,EAAaz1I,EAAI,GACrC+1I,EAAQN,EAAaz1I,EAAI,GACzBg2I,EAAUP,EAAaz1I,EAAI,GACjC,IAAIquC,EAEFA,EADEunG,IAAa5B,GAAa,GACpB,IAAI5yH,OAAWy0H,SAAaE,OAAWF,KAEvC,QAAQD,OAAcx0H,OAAWy0H,qBAAyBD,OAAcG,OAAWF,aAE7FhnG,EAAS,OAAOinG,MAAYE,YAAkB3nG,eAC/C,CACD,OAAOQ,CAAM,IAEf,CAACg4F,GAAIkC,MAAOqM,IAAgBK,IAC1B,MAAMtL,EAAWsL,EAAaA,EAAal2I,OAAS,GACpD,IAAIsvC,EAAS,KACb,IAAK,IAAI7uC,EAAIy1I,EAAal2I,OAAS,EAAGS,GAAK,EAAGA,GAAK,EAAG,CAGpD6uC,EAAS,IAFS4mG,EAAaz1I,QAChBy1I,EAAaz1I,EAAI,QACQ6uC,GAAUs7F,IACnD,CACD,OAAOt7F,CAAM,IAEf,CAACg4F,GAAImC,IAAKoM,IAAe,EAAEp2I,KAAWD,GAAWwP,KAC/C,MAAM0nI,EAxVV,SAAqC1P,EAAUh4H,GAC7C,MAAO,YAAYg4H,KAAYzhI,OAAOC,KAAKwJ,EAAQqmI,WAAWr1I,QAChE,CAsVqB22I,CAA4B,KAAM3nI,GAC7C4nI,EAAQ,GACd,IAAK,IAAIn2I,EAAI,EAAGA,EAAIjB,EAASQ,OAAQS,GAAK,EACxCm2I,EAAMpyI,KAAK,uBAAuBhF,EAASiB,wBAM7C,OAJAuO,EAAQqmI,UAAUqB,GAAY,QAAQA,0BACxCE,EAAMj/H,KAAK,4BAGF,GAAG++H,KAAYj3I,IAAS,IAEjC,CAAC6nI,GAAIpmI,OAAQ20I,IACV9tH,GAAS,MAAMA,EAAK/nB,UAAU+nB,EAAKpQ,KAAK,WAE3C,CAAC2vH,GAAIoC,OAAQmM,IAAgBK,IAC3B,MAAMh5G,EAAMg5G,EAAavzI,MAAM,EAAG,GAAGgnC,KAAKb,GAAU,GAAGA,cACvD,GAA4B,IAAxBotG,EAAal2I,OACf,MAAO,QAAQk9B,EAAIvlB,KAAK,cAG1B,MAAO,IADOu+H,EAAa,aACAh5G,EAAIvlB,KAAK,cAAc,IAEpD,CAAC2vH,GAAIsC,MAAOiM,IAAe,EAAEgB,EAAMC,EAASC,GAAU/nI,KACpD,KAAMsmI,MAAuBtmI,EAAQqmI,WAAY,CAC/C,IAAI2B,EAAW,GACf,MAAMn2C,EAAY7xF,EAAQ6xF,WAAa,EACvC,IAAK,IAAIpgG,EAAI,EAAGA,EAAIogG,EAAWpgG,IAAK,CAClC,MAAMw2I,EAAansI,KAAKuT,MAAM5d,EAAI,GAClC,IAAIwpG,EAAYxpG,EAAI,EAChBA,IAAMogG,EAAY,GAAmB,IAAdoJ,IAEzBA,EAAY,GAGd+sC,GAAY,iBAAiBv2I,EAAI,gCADb,GAAGwuI,GAAS8D,sBAAsBkE,wCAEQhtC,YAG/D,CAEDj7F,EAAQqmI,UACNC,IACE,0FACerG,GAAS+D,gDACT/D,GAASgE,0BAChC+D,MAEG,CAED,MAAO,GAAG1B,MAAuBuB,MAASC,GAAW,UACnDC,GAAW,QACV,IAEL,CAACzP,GAAIuC,SAAU,CAAC76H,EAASu8H,KACvB,MAAOzpI,KAAUopI,GAAUK,EAAWxjH,KAChCmvH,EAAYhM,EAAOlrI,OACnBm3I,EAAU,IAAI9lI,WAAuB,EAAZ6lI,GAC/B,IAAK,IAAIz2I,EAAI,EAAGA,EAAIyqI,EAAOlrI,OAAQS,IAAK,CACtC,MAGMqoC,EAAQ2B,GAFsBygG,EAAOzqI,GACjD,OAEYmZ,EAAa,EAAJnZ,EACf02I,EAAQv9H,GAAUkvB,EAAM,GACxBquG,EAAQv9H,EAAS,GAAKkvB,EAAM,GAC5BquG,EAAQv9H,EAAS,GAAKkvB,EAAM,GAC5BquG,EAAQv9H,EAAS,GAAgB,IAAXkvB,EAAM,EAC7B,CACI95B,EAAQ+kI,kBACX/kI,EAAQ+kI,gBAAkB,IAE5B,MAAMqD,EAAc,GAAG7B,MAAyBvmI,EAAQ+kI,gBAAgB/zI,UAClEm0I,EAAiB,IAAIkD,GAAeD,EAAaD,GACvDnoI,EAAQ+kI,gBAAgBvvI,KAAK2vI,GAE7B,MAAO,aAAaiD,YADExB,GAAQ9zI,EAAOgkI,GAAY92H,eACmBkoI,YAAoB,GAc5F,SAAStB,GAAQrK,EAAYI,EAAY38H,GAEvC,GAAIu8H,aAAsBxE,GAAgB,CACxC,MAAMuQ,EAAWxB,GAAUvK,EAAWvE,UACtC,QAAiB3hI,IAAbiyI,EACF,MAAM,IAAIjwI,MACR,0CAA0C6lE,KAAKmjB,UAC7Ck7C,EAAWvE,aAIjB,OAAOsQ,EAAStoI,EAASu8H,EAAYI,EACtC,CAED,IAAKJ,EAAW3sI,KAAOknI,IAAc,EACnC,OAAO2O,GAAoClJ,EAAgB,OAG7D,IAAKA,EAAW3sI,KAAOinI,IAAe,EACpC,OAAO0F,EAAWroI,MAAMuU,WAG1B,IAAK8zH,EAAW3sI,KAAOmnI,IAAc,EACnC,OAAOiP,GAAazJ,EAAWroI,MAAMuU,YAGvC,IAAK8zH,EAAW3sI,KAAOonI,IAAa,EAClC,OAAO2O,GACkCpJ,EAAgB,OAI3D,IAAKA,EAAW3sI,KAAOqnI,IAAmB,EACxC,OAAOyO,GAA0CnJ,EAAgB,OAGnE,MAAM,IAAIlkI,MACR,yBAAyBkkI,EAAWroI,wBAAwBmjI,GAC1DsF,MAGN,CCnOO,SAAS4L,KACd,MAAO,CACL,aAAc,wBACd,eAAgB,UAChB,eAAgB,KAChB,gBAAiB,EACjB,oBAAqB,wBACrB,sBAAuB,KACvB,sBAAuB,UAE3B,CCnRO,MAAMC,GAAgB,uxBA6BvBC,GD6OG,CACL,aAAc,wBACd,eAAgB,UAChB,eAAgB,KAChB,gBAAiB,EACjB,oBAAqB,wBACrB,sBAAuB,KACvB,sBAAuB,WC5NpB,MAAMC,GACX,WAAA/4I,GAMEE,KAAKo1H,UAAY,GAOjBp1H,KAAK84I,YAAc,GAOnB94I,KAAK+4I,UAAY,GAMjB/4I,KAAKg5I,YAAa,EAMlBh5I,KAAKi5I,sBAAwB,QAAQrD,GACnCgD,GAAc,uBACThD,GAAoD,GAAvCgD,GAAc,2BAMlC54I,KAAKk5I,0BAA4B,MAMjCl5I,KAAKm5I,wBAA0B,YAM/Bn5I,KAAKo5I,uBAAyBtD,GACL8C,GAAc,sBAOvC54I,KAAKq5I,oBAAsB,2BAM3Br5I,KAAKs5I,mBAAqB,QAM1Bt5I,KAAKu5I,uBAAwB,EAM7Bv5I,KAAKw5I,YAAa,EAMlBx5I,KAAKy5I,uBAAyB7D,GAAagD,GAAc,iBAMzD54I,KAAK05I,uBAAyB5D,GACL8C,GAAc,iBAMvC54I,KAAK25I,wBAA0B,KAK/B35I,KAAK45I,qBAAuBzD,GAAa,SAKzCn2I,KAAK65I,sBAAwB1D,GAAa,SAK1Cn2I,KAAK85I,4BAA8B,MAKnC95I,KAAK+5I,+BAAiC,SAMtC/5I,KAAKg6I,UAAW,EAMhBh6I,KAAKi6I,qBAAuBnE,GACH8C,GAAc,eAOvC54I,KAAKk6I,uBAAyB,GAM9Bl6I,KAAKm6I,yBAA2B,EACjC,CAQD,UAAAC,CAAW1kI,GAET,OADA1V,KAAKo1H,UAAUzvH,KAAK+P,GACb1V,IACR,CAQD,YAAAq6I,CAAa3kI,GAEX,OADA1V,KAAK84I,YAAYnzI,KAAK+P,GACf1V,IACR,CAUD,UAAAs6I,CAAW5kI,EAAM3V,EAAM2sI,GAMrB,OALA1sI,KAAK+4I,UAAUpzI,KAAK,CAClB+P,KAAMA,EACN3V,KAAMA,EACN2sI,WAAYA,IAEP1sI,IACR,CASD,uBAAAu6I,CAAwB7N,GAGtB,OAFA1sI,KAAKg5I,YAAa,EAClBh5I,KAAKi5I,sBAAwBvM,EACtB1sI,IACR,CAKD,uBAAAw6I,GACE,OAAOx6I,KAAKi5I,qBACb,CASD,2BAAAwB,CAA4B/N,GAE1B,OADA1sI,KAAKk5I,0BAA4BxM,EAC1B1sI,IACR,CASD,yBAAA06I,CAA0BhO,GAExB,OADA1sI,KAAKm5I,wBAA0BzM,EACxB1sI,IACR,CAKD,yBAAA26I,GACE,OAAO36I,KAAKm5I,uBACb,CASD,wBAAAyB,CAAyBlO,GAGvB,OAFA1sI,KAAKg5I,YAAa,EAClBh5I,KAAKo5I,uBAAyB1M,EACvB1sI,IACR,CAKD,wBAAA66I,GACE,OAAO76I,KAAKo5I,sBACb,CASD,8BAAA0B,CAA+BpO,GAE7B,OADA1sI,KAAKq5I,oBAAsB3M,EACpB1sI,IACR,CAWD,4BAAA+6I,CAA6BrO,GAE3B,OADA1sI,KAAKs5I,mBAAqB5M,EACnB1sI,IACR,CAKD,4BAAAg7I,GACE,OAAOh7I,KAAKs5I,kBACb,CAQD,uBAAA2B,CAAwBC,GAEtB,OADAl7I,KAAKu5I,sBAAwB2B,EACtBl7I,IACR,CAMD,wBAAAm7I,CAAyBzO,GAGvB,OAFA1sI,KAAKw5I,YAAa,EAClBx5I,KAAKy5I,uBAAyB/M,EACvB1sI,IACR,CAMD,wBAAAo7I,CAAyB1O,GAGvB,OAFA1sI,KAAKw5I,YAAa,EAClBx5I,KAAK05I,uBAAyBhN,EACvB1sI,IACR,CAKD,wBAAAq7I,GACE,OAAOr7I,KAAK05I,sBACb,CAMD,yBAAA4B,CAA0B5O,GAExB,OADA1sI,KAAK25I,wBAA0BjN,EACxB1sI,IACR,CAMD,sBAAAu7I,CAAuB7O,GAErB,OADA1sI,KAAK45I,qBAAuBlN,EACrB1sI,IACR,CAMD,uBAAAw7I,CAAwB9O,GAEtB,OADA1sI,KAAK65I,sBAAwBnN,EACtB1sI,IACR,CAMD,6BAAAy7I,CAA8B/O,GAE5B,OADA1sI,KAAK85I,4BAA8BpN,EAC5B1sI,IACR,CAOD,gCAAA07I,CAAiChP,GAE/B,OADA1sI,KAAK+5I,+BAAiCrN,EAC/B1sI,IACR,CAMD,sBAAA27I,CAAuBjP,GAGrB,OAFA1sI,KAAKg6I,UAAW,EAChBh6I,KAAKi6I,qBAAuBvN,EACrB1sI,IACR,CAKD,sBAAA47I,GACE,OAAO57I,KAAKi6I,oBACb,CAED,uBAAA4B,CAAwBh8H,GAClB7f,KAAKk6I,uBAAuBx0I,SAASma,IAGzC7f,KAAKk6I,uBAAuBv0I,KAAKka,EAClC,CACD,yBAAAi8H,CAA0Bj8H,GACpB7f,KAAKm6I,yBAAyBz0I,SAASma,IAG3C7f,KAAKm6I,yBAAyBx0I,KAAKka,EACpC,CAMD,qBAAAk8H,GACE,OAAK/7I,KAAKg5I,WAIH,GAAGL,OACZ34I,KAAKo1H,UACJtqF,KAAI,SAAUguF,GACb,MAAO,WAAaA,EAAU,GAClC,IACGhgH,KAAK,4FAIN9Y,KAAK84I,YACJhuG,KAAI,SAAUkxG,GACb,MAAO,aAAeA,EAAY,GACtC,IACGljI,KAAK,uKAON9Y,KAAK+4I,UACJjuG,KAAI,SAAUmxG,GACb,MAAO,WAAaA,EAAQl8I,KAAO,IAAMk8I,EAAQvmI,KAAO,GAC5D,IACGoD,KAAK,UACN9Y,KAAKk6I,uBAAuBphI,KAAK,2PAWhB9Y,KAAKi5I,4FAEEj5I,KAAKm5I,8UAWbn5I,KAAKk5I,iCACnBl5I,KAAKu5I,sBAAwB,uBAAyB,wSAMtCv5I,KAAKq5I,gdAUvBr5I,KAAK+4I,UACJjuG,KAAI,SAAUmxG,GACb,MAAO,KAAOA,EAAQvmI,KAAO,MAAQumI,EAAQvP,WAAa,GAC9D,IACG5zH,KAAK,WAzEK,IA2EV,CAMD,uBAAAojI,GACE,OAAKl8I,KAAKg5I,WAIH,GAAGL,OACZ34I,KAAKo1H,UACJtqF,KAAI,SAAUguF,GACb,MAAO,WAAaA,EAAU,GAClC,IACGhgH,KAAK,4IAMN9Y,KAAK+4I,UACJjuG,KAAI,SAAUmxG,GACb,MAAO,WAAaA,EAAQl8I,KAAO,IAAMk8I,EAAQvmI,KAAO,GAC5D,IACGoD,KAAK,UACN9Y,KAAKm6I,yBAAyBrhI,KAAK,qCAG7B9Y,KAAKs5I,wRAKMt5I,KAAKo5I,6IA3BX,IAiCV,CAMD,qBAAA+C,GACE,OAAKn8I,KAAKw5I,WAIH,GAAGb,OACZ34I,KAAKo1H,UACJtqF,KAAI,SAAUguF,GACb,MAAO,WAAaA,EAAU,GAClC,IACGhgH,KAAK,oPASN9Y,KAAK84I,YACJhuG,KAAI,SAAUkxG,GACb,MAAO,aAAeA,EAAY,GACtC,IACGljI,KAAK,iNAQN9Y,KAAK+4I,UACJjuG,KAAI,SAAUmxG,GACb,MAAO,WAAaA,EAAQl8I,KAAO,IAAMk8I,EAAQvmI,KAAO,GAC5D,IACGoD,KAAK,UACN9Y,KAAKk6I,uBAAuBphI,KAAK,q/CAwCb9Y,KAAKy5I,mDACFz5I,KAAK25I,o3CA8B5B35I,KAAK+4I,UACJjuG,KAAI,SAAUmxG,GACb,MAAO,KAAOA,EAAQvmI,KAAO,MAAQumI,EAAQvP,WAAa,GAC9D,IACG5zH,KAAK,WA7GK,IA+GV,CAOD,uBAAAsjI,GACE,OAAKp8I,KAAKw5I,WAIH,GAAGb,OACZ34I,KAAKo1H,UACJtqF,KAAI,SAAUguF,GACb,MAAO,WAAaA,EAAU,GAClC,IACGhgH,KAAK,iNAQN9Y,KAAK+4I,UACJjuG,KAAI,SAAUmxG,GACb,MAAO,WAAaA,EAAQl8I,KAAO,IAAMk8I,EAAQvmI,KAAO,GAC5D,IACGoD,KAAK,UACN9Y,KAAKm6I,yBAAyBrhI,KAAK,49DAqDd9Y,KAAK85I,2QAQR3D,GAAa,4FAEPA,GAAa,iRAOnBA,GAAa,0GAENA,GAAa,y4BA4BhCn2I,KAAKs5I,2jBASIt5I,KAAK05I,8DACF15I,KAAK45I,6CACJ55I,KAAK65I,0fAOG75I,KAAK+5I,8MA3IrB,IAkJV,CAOD,mBAAAsC,GACE,OAAKr8I,KAAKg6I,SAIH,GAAGrB,OACZ34I,KAAKo1H,UACJtqF,KAAI,SAAUguF,GACb,MAAO,WAAaA,EAAU,GAClC,IACGhgH,KAAK,kEAGN9Y,KAAK84I,YACJhuG,KAAI,SAAUkxG,GACb,MAAO,aAAeA,EAAY,GACtC,IACGljI,KAAK,oCAEN9Y,KAAK+4I,UACJjuG,KAAI,SAAUmxG,GACb,MAAO,WAAaA,EAAQl8I,KAAO,IAAMk8I,EAAQvmI,KAAO,GAC5D,IACGoD,KAAK,UACN9Y,KAAKk6I,uBAAuBphI,KAAK,+HAIjC9Y,KAAK+4I,UACJjuG,KAAI,SAAUmxG,GACb,MAAO,KAAOA,EAAQvmI,KAAO,MAAQumI,EAAQvP,WAAa,GAC9D,IACG5zH,KAAK,WA9BK,IAgCV,CAMD,qBAAAwjI,GACE,OAAKt8I,KAAKg6I,SAIH,GAAGrB,OACZ34I,KAAKo1H,UACJtqF,KAAI,SAAUguF,GACb,MAAO,WAAaA,EAAU,GAClC,IACGhgH,KAAK,oCAEN9Y,KAAK+4I,UACJjuG,KAAI,SAAUmxG,GACb,MAAO,WAAaA,EAAQl8I,KAAO,IAAMk8I,EAAQvmI,KAAO,GAC5D,IACGoD,KAAK,UACN9Y,KAAKm6I,yBAAyBrhI,KAAK,gyBA2B7B9Y,KAAKs5I,sDACMt5I,KAAKi6I,0JA3CX,IAiDV,ECjZH,SAASsC,GAAqBC,EAAYxhI,GACxC,OAAe,IAAXA,EACKwhI,EAEFA,EAAW/kG,QAAO,CAAC1X,EAAGn+B,IAAMA,EAAIoZ,EAAS,GAClD,CAEA,IAAAyhI,GA9eA,MACE,WAAA38I,GACEE,KAAK08I,eAAiB,EAMtB18I,KAAK28I,cAAgB,IAAIC,IAOzB58I,KAAK68I,UAAY,IAAID,IAQrB58I,KAAK88I,eAAiB,GAKtB98I,KAAK+8I,aAAe,CAClBC,QAAS,CAAE,EACXC,gBAAiB,EACjBC,cAAe,EACfC,WAAY,GAMdn9I,KAAKo9I,WAAa,CAChBJ,QAAS,CAAE,EACXC,gBAAiB,GAMnBj9I,KAAKq9I,gBAAkB,CACrBL,QAAS,CAAE,EACXC,gBAAiB,EACjBC,cAAe,EAElB,CAMD,WAAAnuE,CAAY5L,EAAUm6E,GACpB,IAAK,IAAI17I,EAAI,EAAGA,EAAIuhE,EAAShiE,OAAQS,IACnC5B,KAAKk9F,WAAW/5B,EAASvhE,GAAI07I,EAEhC,CAMD,UAAApgD,CAAWv9C,EAAS29F,GAClB,IAAI1oI,EAAW+qC,EAAQzqC,cAClBN,IAGD0oI,IACF1oI,EAAWA,EAASG,QACpBH,EAAS+J,eAAe2+H,IAE1Bt9I,KAAKu9I,aAAa3oI,EAAU+qC,GAC7B,CAOD,8BAAA69F,CAA+B79F,GAC7B,MAAMoqB,EAAQ/pE,KAAKo9I,WAAWJ,QAAQt0I,EAAOi3C,IAC7C,GAAKoqB,EAKL,OAFA/pE,KAAKo9I,WAAWH,iBAAmBlzE,EAAM0zE,YAAYt8I,cAC9CnB,KAAKo9I,WAAWJ,QAAQt0I,EAAOi3C,IAC/BoqB,CACR,CAOD,mCAAA2zE,CAAoC/9F,GAClC,MAAMoqB,EAAQ/pE,KAAKq9I,gBAAgBL,QAAQt0I,EAAOi3C,IAClD,GAAKoqB,EAML,OAHA/pE,KAAKq9I,gBAAgBH,eAAiBnzE,EAAMmzE,cAC5Cl9I,KAAKq9I,gBAAgBJ,iBAAmBlzE,EAAM0zE,YAAYt8I,cACnDnB,KAAKq9I,gBAAgBL,QAAQt0I,EAAOi3C,IACpCoqB,CACR,CAOD,gCAAA4zE,CAAiCh+F,GAC/B,MAAMoqB,EAAQ/pE,KAAK+8I,aAAaC,QAAQt0I,EAAOi3C,IAC/C,GAAKoqB,EAOL,OAJA/pE,KAAK+8I,aAAaG,eAAiBnzE,EAAMmzE,cACzCl9I,KAAK+8I,aAAaI,YAAcpzE,EAAMozE,WACtCn9I,KAAK+8I,aAAaE,iBAAmBlzE,EAAM0zE,YAAYt8I,cAChDnB,KAAK+8I,aAAaC,QAAQt0I,EAAOi3C,IACjCoqB,CACR,CAOD,YAAAwzE,CAAa3oI,EAAU+qC,GACrB,MAAM5/C,EAAO6U,EAAS8Z,UACtB,OAAQ3uB,GACN,IAAK,qBAAsB,CACzB,MAAMy1E,EACsD,EAExDC,qBACJ,IAAK,MAAM7gE,KAAY4gE,EACrBx1E,KAAKu9I,aAAa3oI,EAAU+qC,GAE9B,KACD,CACD,IAAK,eAAgB,CACnB,MAAMi+F,EACiD,EACvD59I,KAAK69I,gBACH99I,EACA69I,EAAiBruH,qBACjBquH,EAAiB5nE,WACjBr2B,EACAj3C,EAAOi3C,GACPi+F,EAAiBpuH,aAEnB,KACD,CACD,IAAK,kBAAmB,CACtB,MAAMsuH,EACd,EAGQ99I,KAAK69I,gBACH99I,EACA+9I,EAAcvuH,qBACduuH,EAAcnnH,UACdgpB,EACAj3C,EAAOi3C,GACPm+F,EAActuH,aAEhB,KACD,CACD,IAAK,aAAc,CACjB,MAAMuuH,EACd,EAGQ/9I,KAAK69I,gBACH99I,EACAg+I,EAAexuH,qBACf,KACAowB,EACAj3C,EAAOi3C,GACPo+F,EAAevuH,aAEjB,KACD,CACD,IAAK,UAAW,CACd,MAAMwuH,EACd,EAGQh+I,KAAK69I,gBACH99I,EACAi+I,EAAYzuH,qBACZyuH,EAAYrnH,UACZgpB,EACAj3C,EAAOi3C,GACPq+F,EAAYxuH,aAEd,KACD,CACD,IAAK,QAAS,CACZ,MAAMyuH,EAAS,EAGfj+I,KAAK69I,gBACH99I,EACAk+I,EAAU1uH,qBACV,KACAowB,EACAj3C,EAAOi3C,GACPs+F,EAAUzuH,aAEZ,KACD,CACD,IAAK,aACL,IAAK,aAAc,CACjB,MAAM0uH,EAAQ,EAGdl+I,KAAK69I,gBACH99I,EACAm+I,EAAS3uH,qBACT,KACAowB,EACAj3C,EAAOi3C,GACPu+F,EAAS1uH,aAEX,KACD,EAIJ,CAWD,eAAAquH,CAAgB99I,EAAMy8I,EAAY5rH,EAAM+uB,EAASw+F,EAAYnjI,GAE3D,IAAIkiI,EACJ,OAAQn9I,GACN,IAAK,eAAgB,CACnB,MAAMq+I,EAAyD,EAC/D,IAAK,IAAIx8I,EAAI,EAAGuE,EAAKi4I,EAAkBj9I,OAAQS,EAAIuE,EAAIvE,IAAK,CAC1D,IAAIy8I,EAAcD,EAAkBx8I,GACpC,MAAM08I,EAAkB18I,EAAI,EAAIw8I,EAAkBx8I,EAAI,GAAK,KACrDmsD,EAAauwF,EACfA,EAAgBA,EAAgBn9I,OAAS,GACzC,EACEo9I,EAAWF,EAAYA,EAAYl9I,OAAS,GAClDk9I,EACEtwF,EAAa,EACTswF,EAAYvzG,KAAK9oC,GAAQA,EAAM+rD,IAC/BswF,EACNr+I,KAAK69I,gBACH,UACArB,EAAW14I,MAAMiqD,EAAYwwF,GAC7BF,EACA1+F,EACAw+F,EACAnjI,EAEH,CACD,KACD,CACD,IAAK,kBAAmB,CACtB,MAAMwjI,EAA8C,EACpD,IAAK,IAAI58I,EAAI,EAAGuE,EAAKq4I,EAAcr9I,OAAQS,EAAIuE,EAAIvE,IAAK,CACtD,MAAMmsD,EAAansD,EAAI,EAAI48I,EAAc58I,EAAI,GAAK,EAClD5B,KAAK69I,gBACH,aACArB,EAAW14I,MAAMiqD,EAAYywF,EAAc58I,IAC3C,KACA+9C,EACAw+F,EACAnjI,EAEH,CACD,KACD,CACD,IAAK,aACH,IAAK,IAAIpZ,EAAI,EAAGuE,EAAKq2I,EAAWr7I,OAAQS,EAAIuE,EAAIvE,GAAKoZ,EACnDhb,KAAK69I,gBACH,QACArB,EAAW14I,MAAMlC,EAAGA,EAAI,GACxB,KACA+9C,EACAw+F,EACA,MAGJ,MACF,IAAK,UAAW,CACd,MAAME,EAA4C,EAClD,GAAI1+F,aAAmBs7C,GAAe,CACpC,MAAMwjD,EAAmB5oH,GAAY2mH,EAAY6B,GACjD,GAAII,EAAiBt9I,OAAS,EAS5B,YARAnB,KAAK69I,gBACH,eACArB,EACAiC,EACA9+F,EACAw+F,EACAnjI,EAIL,CACIhb,KAAK+8I,aAAaC,QAAQmB,KAC7Bn+I,KAAK+8I,aAAaC,QAAQmB,GAAcn+I,KAAK0+I,eAC3CP,EACA,CACEx+F,QAASA,EACT89F,YAAa,GACbP,cAAe,EACfC,WAAY,EACZwB,oBAAqB,MAI3BzB,EAAgBV,EAAWr7I,OAAS6Z,EACpC,MAAMmiI,EAAavsH,EAAKzvB,OAClBy9I,EAAqBhuH,EAAKka,KAAI,CAAC9oC,EAAK68I,EAAKp9I,IAC7Co9I,EAAM,GAAK78I,EAAMP,EAAIo9I,EAAM,IAAM7jI,EAAShZ,EAAMgZ,IAElDhb,KAAK+8I,aAAaG,eAAiBA,EACnCl9I,KAAK+8I,aAAaI,YAAcA,EAChCn9I,KAAK+8I,aAAaE,kBAClBj9I,KAAK+8I,aAAaC,QAAQmB,GAAYV,YAAY93I,KAChD42I,GAAqBC,EAAYxhI,IAEnChb,KAAK+8I,aAAaC,QAAQmB,GAAYQ,oBAAoBh5I,KACxDi5I,GAEF5+I,KAAK+8I,aAAaC,QAAQmB,GAAYjB,eAAiBA,EACvDl9I,KAAK+8I,aAAaC,QAAQmB,GAAYhB,YAAcA,EACpD,IAAK,IAAIv7I,EAAI,EAAGuE,EAAKk4I,EAAYl9I,OAAQS,EAAIuE,EAAIvE,IAAK,CACpD,MAAMmsD,EAAansD,EAAI,EAAIy8I,EAAYz8I,EAAI,GAAK,EAChD5B,KAAK69I,gBACH,aACArB,EAAW14I,MAAMiqD,EAAYswF,EAAYz8I,IACzC,KACA+9C,EACAw+F,EACAnjI,EAEH,CACD,KACD,CACD,IAAK,QACEhb,KAAKo9I,WAAWJ,QAAQmB,KAC3Bn+I,KAAKo9I,WAAWJ,QAAQmB,GAAcn+I,KAAK0+I,eACzCP,EACA,CACEx+F,QAASA,EACT89F,YAAa,MAInBz9I,KAAKo9I,WAAWH,kBAChBj9I,KAAKo9I,WAAWJ,QAAQmB,GAAYV,YAAY93I,KAAK62I,GACrD,MACF,IAAK,aACL,IAAK,aACEx8I,KAAKq9I,gBAAgBL,QAAQmB,KAChCn+I,KAAKq9I,gBAAgBL,QAAQmB,GAAcn+I,KAAK0+I,eAC9CP,EACA,CACEx+F,QAASA,EACT89F,YAAa,GACbP,cAAe,KAIrBA,EAAgBV,EAAWr7I,OAAS6Z,EACpChb,KAAKq9I,gBAAgBH,eAAiBA,EACtCl9I,KAAKq9I,gBAAgBJ,kBACrBj9I,KAAKq9I,gBAAgBL,QAAQmB,GAAYV,YAAY93I,KACnD42I,GAAqBC,EAAYxhI,IAEnChb,KAAKq9I,gBAAgBL,QAAQmB,GAAYjB,eAAiBA,EAK/D,CAQD,cAAAwB,CAAeP,EAAYp0E,GACzB,MAAM+0E,EAAa9+I,KAAK68I,UAAUzzI,IAAI+0I,GAGhCY,EACJD,GAAc9+I,KAAK88I,eAAe5xI,SAAWlL,KAAK08I,eAMpD,OALA3yE,EAAMg1E,IAAMA,EACPD,IACH9+I,KAAK28I,cAAc5yI,IAAIg1I,EAAKh1E,EAAMpqB,SAClC3/C,KAAK68I,UAAU9yI,IAAIo0I,EAAYY,IAE1Bh1E,CACR,CAQD,UAAAi1E,CAAWD,EAAKZ,GACd,IAAKY,EACH,MAAM,IAAIv2I,MAAM,4BAA8B21I,GAEhDn+I,KAAK28I,cAAcxsD,OAAO4uD,GAC1B/+I,KAAK68I,UAAU1sD,OAAOguD,GACtBn+I,KAAK88I,eAAen3I,KAAKo5I,EAC1B,CAKD,aAAAE,CAAct/F,GACZ3/C,KAAK69F,cAAcl+C,GACnB,MAAM/qC,EAAW+qC,EAAQzqC,cACpBN,GAGL5U,KAAKu9I,aAAa3oI,EAAU+qC,EAC7B,CAKD,aAAAk+C,CAAcl+C,GACZ,IAAIoqB,EACJA,EAAQ/pE,KAAKw9I,+BAA+B79F,IAAYoqB,EACxDA,EAAQ/pE,KAAK29I,iCAAiCh+F,IAAYoqB,EAC1DA,EAAQ/pE,KAAK09I,oCAAoC/9F,IAAYoqB,EACzDA,GACF/pE,KAAKg/I,WAAWj1E,EAAMg1E,IAAKr2I,EAAOqhE,EAAMpqB,SAE3C,CAED,KAAAh7C,GACE3E,KAAK+8I,aAAaC,QAAU,GAC5Bh9I,KAAK+8I,aAAaE,gBAAkB,EACpCj9I,KAAK+8I,aAAaG,cAAgB,EAClCl9I,KAAK+8I,aAAaI,WAAa,EAC/Bn9I,KAAKq9I,gBAAgBL,QAAU,GAC/Bh9I,KAAKq9I,gBAAgBJ,gBAAkB,EACvCj9I,KAAKq9I,gBAAgBH,cAAgB,EACrCl9I,KAAKo9I,WAAWJ,QAAU,GAC1Bh9I,KAAKo9I,WAAWH,gBAAkB,EAClCj9I,KAAK08I,eAAiB,EACtB18I,KAAK88I,eAAiB,GACtB98I,KAAK28I,cAAch4I,QACnB3E,KAAK68I,UAAUl4I,OAChB,CAOD,iBAAAu6I,CAAkBH,GAChB,OAAO/+I,KAAK28I,cAAcvzI,IAAI21I,EAC/B,GCjcH,IAAAI,GAjFA,cAA2BpR,GAKzB,WAAAjuI,CAAY6K,EAASy0I,GACnBn6I,MAAM0F,GAKN3K,KAAKq/I,OAAS,IAAIC,GAKlBt/I,KAAKu/I,gBAAkBH,EAKvBp/I,KAAKwjH,QAAU,GAOfxjH,KAAKw/I,aAAe,IAAItR,GAAiBrgB,GAAcE,IAEvD/tH,KAAKqyH,QAAQ1nH,EAAQuC,KACtB,CAKD,mBAAAuyI,GACE,MAAMjmI,EAASxZ,KAAKkN,KAAKw+D,iBAAiB,GAAGlyD,OAC7CxZ,KAAKw/I,aAAa1sB,UAAU,CAC1Bt5G,EAAO,GACPA,EAAO,GACPA,EAAO,GACPA,EAAO,GACPA,EAAO,GACPA,EAAO,GACPA,EAAO,GACPA,EAAO,KAETxZ,KAAKmyH,QAAQiK,gBAAgBp8H,KAAKw/I,aACnC,CAED,UAAAltB,GACEtyH,KAAKy/I,sBAELz/I,KAAKq/I,OAAO16I,QACZ,MAAMsnE,EAAcjsE,KAAKkN,KAAKw+D,iBACxBvI,EAAW8I,EAAYvnB,QAC3B,CAACqqE,EAAa9T,IAAe8T,EAAYh4B,OAAOkkB,EAAW59D,gBAC3D,IAEFr9C,KAAKq/I,OAAOtwE,YAAY5L,GAExB,MAEMntD,EAAY29H,GhNhDb,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IgN8CD1nE,EAAY,GAAGzyD,OAAO,IACtByyD,EAAY,GAAGzyD,OAAO,IAOpCkmI,EAAmB1/I,KAAKu/I,gBAAgBz0G,KAAI,CAACo5B,EAAUtiE,IAC3DsiE,EAASy7E,gBAAgB3/I,KAAKq/I,OAAQrpI,GAAWjC,MAAMyvG,IACrDxjH,KAAKwjH,QAAQ5hH,GAAK4hH,CAAO,MAG7Bj/G,QAAQ2xD,IAAIwpF,GAAkB3rI,MAAK,KACjC/T,KAAKuyH,UAAU,GAElB,GCpEI,SAASqtB,GAAiB/I,EAAoBxyI,EAAOuoI,GAC1D,MAAMgK,EAAiBxO,KAEvB,OADAwO,EAAermI,MAAQsmI,EAAmBtmI,MACnComI,GACLtyI,EACAuoI,EACAgK,EACAC,EAEJ,CAOO,SAASgJ,GAAU51G,GACxB,MAAMv/B,EAAQkhC,GAAQ3B,GAKtB,MAAO,CAJc,IAAXv/B,EAAM,GACNA,EAAM,GACK,IAAXA,EAAM,GACNuB,KAAKiZ,MAAiB,IAAXxa,EAAM,IAE7B,CAeA,SAASo1I,GAAoB//I,GAC3B,OAAIA,IAASonI,GACJ,EAELpnI,IAASqnI,GACJ,EAEF,CACT,CAMA,SAAS2Y,GAAoBhgJ,GAC3B,MAAM2T,EAAOosI,GAAoB//I,GACjC,OAAI2T,EAAO,QACyCA,IAE7C,OACT,CAOO,SAASssI,GAAYh9H,GAI1B,OAHaqrD,KAAKmjB,UAAUxuE,GACzB6C,MAAM,IACN6+B,QAAO,CAAC/4C,EAAMg5C,KAAUh5C,GAAQ,GAAKA,EAAOg5C,EAAKwmC,WAAW,IAAI,KAClD,GAAGvyE,UACtB,CAQA,SAASqnI,GAA4B1vI,EAAO2vI,EAASC,EAAaC,GAChE,IAAIp4H,EAwBJ,GAvBI,GAAGo4H,YAAkB7vI,GAAoB,UAAX6vI,EAChCp4H,EAAS43H,GACPO,EACA5vI,EAAM,GAAG6vI,WACTnZ,IAEO,GAAGmZ,aAAmB7vI,GAAoB,WAAX6vI,IACxCp4H,EAAS43H,GACPO,EACA5vI,EAAM,GAAG6vI,YACTnZ,UAGWzgI,IAAXwhB,IACE,GAAGo4H,kBAAwB7vI,IAC7ByX,EAAS,IAAIA,OAAY43H,GACvBO,EACA5vI,EAAM,GAAG6vI,iBACTnZ,cAGJiZ,EAAQ3F,wBAAwB,QAAQvyH,kBAEtC,GAAGo4H,WAAiB7vI,EAAO,CAC7B,MAAMoH,EAAQioI,GACZO,EACA5vI,EAAM,GAAG6vI,UACTnZ,GAAaG,IAEf8Y,EAAQ3F,wBACN,GAAG2F,EAAQ1F,+BAA+B7iI,IAE7C,CACG,GAAGyoI,kBAAwB7vI,GAC7B2vI,EAAQxF,0BACNkF,GACEO,EACA5vI,EAAM,GAAG6vI,iBACThZ,KAIF,GAAGgZ,cAAoB7vI,GACzB2vI,EAAQzF,4BACNmF,GAAiBO,EAAa5vI,EAAM,GAAG6vI,aAAmBnZ,KAG1D,GAAGmZ,sBAA4B7vI,GACjC2vI,EAAQjF,0BAA0B1qI,EAAM,GAAG6vI,qBAE/C,CAUA,SAASC,GACPC,EACAC,EACAC,EACAC,EACA3zG,GAEA,IAAI7C,EAAQ,WAIZ,GAHkB,OAAds2G,IACFt2G,EAAQs2G,GAEU,OAAhBC,GAAwC,OAAhBC,EAAsB,CAEhDx2G,EAAQ,OAAOu2G,MAAgBv2G,MADP,eAAew2G,cAAwBA,aAAuBH,OAEvF,CAED,IAAI7vG,EAAS,GAAGxG,OADK,kCAAkCq2G,QAKvD,OAHgB,OAAZxzG,IACF2D,EAAS,GAAGA,OAAY3D,KAEnB2D,CACT,CAYA,SAASiwG,GAAqBnwI,EAAO2vI,EAAS7qB,EAAU+qB,EAAQO,GAC9D,MAAM7tI,EAAQ,IAAI/D,MAClB,IAAI2E,EAmBJ,OAlBAZ,EAAMupB,iBAC+B71B,IAAnC+J,EAAM,GAAG6vI,iBACL,YACA7vI,EAAM,GAAG6vI,iBACfttI,EAAM+nB,IAAMtqB,EAAM,GAAG6vI,QAEjBttI,EAAMooB,UAAYpoB,EAAMrD,OAASqD,EAAMpD,OACzCgE,EAAOmiI,GAAY,CAAC/iI,EAAMrD,MAAOqD,EAAMpD,UAGvC2lH,EAAS,YAAYsrB,UAAoB,IAChC7tI,EAAMooB,SAAW,CAACpoB,EAAMrD,MAAOqD,EAAMpD,QAAU,CAAC,EAAG,GAE5DwwI,EAAQ9F,WAAW,iBAAiBuG,UACpCjtI,EAAO,YAAYitI,UAErBtrB,EAAS,YAAYsrB,KAAe7tI,EACpCotI,EAAQ9F,WAAW,sBAAsBuG,KAClCjtI,CACT,CAWA,SAASktI,GACPrwI,EACA6vI,EACAjwI,EACA4nE,EACA8oE,GAEA,IAAIC,EAAmBlB,GACrBzvI,EACAI,EAAM,GAAG6vI,WACThZ,IAEF,GAAI,GAAGgZ,mBAAyB7vI,EAC9B,OAAQA,EAAM,GAAG6vI,mBACf,IAAK,YACHU,EAAmB,QAAQ/oE,cAAsB8oE,uBAAgCC,oBACjF,MACF,IAAK,cACHA,EAAmB,YAAY/oE,UAAkB8oE,uBAAgCC,oBACjF,MACF,IAAK,eACHA,EAAmB,GAAG/oE,OAAe8oE,OAAgBC,IAK3D,OAAOA,CACT,CAinBO,SAASC,GAAkBxwI,GAIhC,MAAM4vI,EAAc,CAClB5J,kBAAkB,EAClBzhI,WAAY,CAAE,EACduzH,UAAW,CAAE,EACbmO,UAAW,CAAE,EACbjmI,SAMIywI,EAAc,CAClBzK,kBAAkB,EAClBlO,UAAW8X,EAAY9X,UACvBvzH,WAAY,CAAE,EACd0hI,UAAW,CAAE,EACbjmI,SAGI2vI,EAAU,IAAIrH,GAGdxjB,EAAW,CAAA,EAYjB,GAVI,aAAc9kH,EA3YpB,SACEA,EACA2vI,EACA7qB,EACA8qB,EACAa,GAGA,IAAI/2G,EAAQ,YACR,eAAgB15B,IAClB05B,EAAQ21G,GAAiBoB,EAAazwI,EAAM,cAAe42H,KAIzD,iBAAkB52H,IACpB05B,EAAQ,GAAGA,OAAW21G,GACpBoB,EACAzwI,EAAM,gBACN02H,OAKJ,MAAM0Z,EAAYX,GAAYzvI,EAAM,aAC9B0wI,EAAiBP,GACrBnwI,EACA2vI,EACA7qB,EACA,QACAsrB,GAoBF,GAlBAT,EACGtF,yBACC,GAAG3wG,oCAAwC02G,kBAE5CpG,wBAAwB0G,GAGvB,eAAgB1wI,GAAS,gBAAiBA,GAC5C2vI,EAAQ3F,wBACN,QAAQqF,GACNO,EACA5vI,EAAM,cACN02H,QACI2Y,GAAiBO,EAAa5vI,EAAM,eAAgB02H,QAK1D,gBAAiB12H,GAAS,cAAeA,EAAO,CAClD,MAAMswI,EAAajB,GACjBO,EACA5vI,EAAM,aACN62H,IAEI8Z,EAAWhB,EAAQ1F,0BACzB0F,EAAQ3F,wBAAwBsG,GAChC,MAAM9lI,EAAS6lI,GACbrwI,EACA,QACA4vI,EACA,eACAU,GAEFX,EAAQpF,+BACN,UAAU//H,2BAAgC8lI,UAAmBK,UAEhE,CAID,GAFAjB,GAA4B1vI,EAAO2vI,EAASC,EAAa,SAErD,gBAAiB5vI,EAAO,CAC1B,MAAM6c,EAASwyH,GACbO,EACA5vI,EAAM,eACN62H,IAEF,IAQI+Z,EARAxpI,EAAQ,MACR,eAAgBpH,IAClBoH,EAAQioI,GACNO,EACA5vI,EAAM,cACN02H,GAAaG,KAQf+Z,EAHiC,WAAjC5wI,EAAM,wBAC2B,WAAjCA,EAAM,uBAEI,GAAG6c,OAAYzV,IACiB,WAAjCpH,EAAM,uBACL,GAAG6c,iBAAsBzV,wBACO,WAAjCpH,EAAM,uBACL,GAAG6c,iCAAsCzV,QAEzC,GAAGyV,mBAGf,IAAIg0H,EAAW,oCAAoCD,oBACnD,GAAI,uBAAwB5wI,EAC1B,OAAQA,EAAM,uBACZ,IAAK,YACH6wI,EAAW,yBAAyBD,IACpC,MACF,IAAK,cACHC,EAAW,wBAAwBD,IACnC,MACF,IAAK,eACHC,EAAW,oCAAoCD,oBAKrDjB,EAAQxF,0BACN,GAAGwF,EAAQvF,iCAAiCyG,IAE/C,CACH,CAsRIC,CAAoB9wI,EAAO2vI,EAAS7qB,EAAU8qB,EAAaa,GAClD,iBAAkBzwI,EAviB/B,SACEA,EACA2vI,EACA7qB,EACA8qB,EACAa,GAEAA,EAAYxK,UAAiB,MAAI,qEAOjCwK,EAAYxK,UAEd,kBAAM,m3BAeJwK,EAAYxK,UAEd,qBAAM,mxBAeJyJ,GAA4B1vI,EAAO2vI,EAASC,EAAa,UAGzD,IAAIrzG,EAAU,KACV,kBAAmBv8B,IACrBu8B,EAAU8yG,GAAiBoB,EAAazwI,EAAM,iBAAkB02H,KAIlE,IAAIqa,EAAe,WACf,gBAAiB/wI,IAMnB+wI,EAAe,cALD1B,GACZoB,EACAzwI,EAAM,eACN02H,GAAaG,OAMjB,IAAImZ,EAAY,KACZ,qBAAsBhwI,IACxBgwI,EAAYX,GACVoB,EACAzwI,EAAM,oBACN42H,KAKJ,IAAIqZ,EAAc,KACd,uBAAwBjwI,IAC1BiwI,EAAcZ,GACZoB,EACAzwI,EAAM,sBACN42H,KAKJ,IAAIsZ,EAAc,KACd,uBAAwBlwI,IAC1BkwI,EAAcb,GACZoB,EACAzwI,EAAM,sBACN02H,KAKJ,MAAMsa,EAAY3B,GAChBoB,EACAzwI,EAAM,gBACN02H,IAEF,IAIIua,EAJAhqI,EAAQ,KAKZ,GAJI,gBAAiBjH,IACnBiH,EAAQooI,GAAiBoB,EAAazwI,EAAM,eAAgB02H,KAG1D,iBAAkB12H,EAAO,CAC3B,IAAIyX,EAAS43H,GACXoB,EACAzwI,EAAM,gBACN02H,IAEkB,OAAhBwZ,IACFz4H,EAAS,GAAGA,OAAYy4H,WAE1Be,EAAa,wBAAwBF,MAAiBC,MAAcv5H,MAAWxQ,IACnF,KAAS,CACL,IAAIiqI,EAAc7B,GAChBoB,EACAzwI,EAAM,iBACN02H,IAEEya,EAAc9B,GAChBoB,EACAzwI,EAAM,iBACN02H,IAEkB,OAAhBwZ,IACFgB,EAAc,GAAGA,OAAiBhB,UAClCiB,EAAc,GAAGA,OAAiBjB,WAEpCe,EAAa,qBAAqBF,MAAiBC,MAAcG,MAAgBD,MAAgBjqI,IAClG,CAGD,MAAMmqI,EAAkBtB,GACtBmB,EACAjB,EACAC,EACAC,EACA3zG,GAEFozG,EAAQtF,yBAAyB+G,EACnC,CAuZIC,CAAqBrxI,EAAO2vI,EAAS7qB,EAAU8qB,EAAaa,GACnD,kBAAmBzwI,GAxoBhC,SACEA,EACA2vI,EACA7qB,EACA8qB,EACAa,GAIAA,EAAYxK,UAEd,oBAAM,6FAIJyJ,GAA4B1vI,EAAO2vI,EAASC,EAAa,WAGzD,IAAIrzG,EAAU,KACV,mBAAoBv8B,IACtBu8B,EAAU8yG,GACRoB,EACAzwI,EAAM,kBACN02H,KAKJ,IAAIqa,EAAe,WACf,iBAAkB/wI,IAMpB+wI,EAAe,cALD1B,GACZoB,EACAzwI,EAAM,gBACN02H,GAAaG,OAMjB,IAAImZ,EAAY,KACZ,sBAAuBhwI,IACzBgwI,EAAYX,GACVoB,EACAzwI,EAAM,qBACN42H,KAKJ,IAAIqZ,EAAc,KACd,wBAAyBjwI,IAC3BiwI,EAAcZ,GACZoB,EACAzwI,EAAM,uBACN42H,KAKJ,IAAIn/G,EAAS43H,GACXoB,EACAzwI,EAAM,iBACN02H,IAIEwZ,EAAc,KACd,wBAAyBlwI,IAC3BkwI,EAAcb,GACZoB,EACAzwI,EAAM,uBACN02H,IAEFj/G,EAAS,IAAIA,OAAYy4H,YAI3B,MACMkB,EAAkBtB,GADF,uBAAuBiB,MAAiBt5H,KAG5Du4H,EACAC,EACAC,EACA3zG,GAEFozG,EAAQtF,yBAAyB+G,EACnC,CAmjBIE,CAAsBtxI,EAAO2vI,EAAS7qB,EAAU8qB,EAAaa,GAjRjE,SACEzwI,EACA2vI,EACA7qB,EACA8qB,EACAa,GAOA,GALI,iBAAkBzwI,GACpB2vI,EAAQ9E,yBACNwE,GAAiBoB,EAAazwI,EAAM,gBAAiB42H,KAGrD,uBAAwB52H,EAAO,CACjC,MAAMowI,EAAYX,GAAYzvI,EAAM,uBAC9B0wI,EAAiBP,GACrBnwI,EACA2vI,EACA7qB,EACA,kBACAsrB,GAEF,IAAImB,EAAuBb,EACvBH,EAAmB,WACnB,0BAA2BvwI,GAAS,wBAAyBA,IAC/DuxI,EAAuBlC,GACrBoB,EACAzwI,EAAM,uBACN62H,IAEF0Z,EAAmBF,GACjBrwI,EACA,kBACAywI,EACAC,EACAa,IAGJ,IAAIC,EAAoB,KACpB,2BAA4BxxI,IAC9BwxI,EAAoBnC,GAClBoB,EACAzwI,EAAM,0BACN02H,KAGJ+Z,EAAYxK,UAEhB,oBAAQ,qoBAQJ,MAAMwL,EAAc,YAAYrB,IAChC,IAAIsB,EAAiB,KACjB,iBAAkB1xI,IACpB0xI,EAAiB/B,EAAQ7E,4BAE3B6E,EAAQ9E,yBACN,GAAG6G,2BAAwCD,MAAgBf,MAAmBH,MAAqBgB,MAAyBC,0CAE/H,CAgCD,GA9BI,iBAAkBxxI,GACpB2vI,EAAQ/E,yBACNyE,GAAiBO,EAAa5vI,EAAM,gBAAiB02H,KAIrD,kBAAmB12H,GACrB2vI,EAAQ5E,0BACNsE,GAAiBO,EAAa5vI,EAAM,iBAAkB02H,KAItD,oBAAqB12H,GACvB2vI,EAAQ3E,uBACNqE,GAAiBO,EAAa5vI,EAAM,mBAAoB22H,KAIxD,qBAAsB32H,GACxB2vI,EAAQ1E,wBACNoE,GAAiBO,EAAa5vI,EAAM,oBAAqB22H,KAIzD,uBAAwB32H,GAC1B2vI,EAAQzE,8BACNmE,GAAiBO,EAAa5vI,EAAM,sBAAuB02H,KAI3D,qBAAsB12H,EAAO,CAC/BywI,EAAYxK,UAEhB,sBAAQ,kYAIWL,GAAa,gFAENA,GAAa,yKAMnC,IAAI+L,EAAc3xI,EAAM,oBAAoBu6B,KAAK/K,GAC/C6/G,GAAiBoB,EAAajhH,EAAGknG,MAG/Bib,EAAY/gJ,OAAS,GAAM,IAC7B+gJ,EAAc,IAAIA,KAAgBA,IAGpC,IAAIpB,EAAmB,KACnB,4BAA6BvwI,IAC/BuwI,EAAmBlB,GACjBO,EACA5vI,EAAM,2BACN02H,KAKJ,MACMkb,EAAmB,qBADHnC,GAAYzvI,EAAM,uBAGlC6xI,EAAiBF,EAAYp3G,KACjC,CAAC/K,EAAGn+B,IAAM,mBAAmBA,OAAOm+B,OAEhCsiH,EAAiBH,EACpBp3G,KAAI,CAAC/K,EAAGn+B,IAAM,aAAaA,MAC3BkX,KAAK,OACR,IAAIwpI,EAAoB,KACpBC,EAAqB,2CAA2CD,4CACpE,IAAK,IAAI1gJ,EAAI,EAAGA,EAAIsgJ,EAAY/gJ,OAAQS,GAAK,EAC3C0gJ,EAAoB,GAAGA,iBACrB1gJ,EAAI,iBACUA,EAAI,IACpB2gJ,EAAqB,OAAOA,8CAA+DD,gBAAgC1gJ,gCAG7Ho/I,EAAYxK,UACV2L,GACE,SAASA,uDACbC,EAAetpI,KAAK,sCACIupI,gBACjBE,QAEPrC,EAAQxE,iCACN,GAAGyG,uBAAsCrB,+BAE5C,CACH,CAsHE0B,CAAsBjyI,EAAO2vI,EAAS7qB,EAAU8qB,EAAaa,GA7G/D,SACEzwI,EACA2vI,EACA7qB,EACA8qB,EACAa,GAOA,GALI,eAAgBzwI,GAClB2vI,EAAQvE,uBACNiE,GAAiBoB,EAAazwI,EAAM,cAAe42H,KAGnD,qBAAsB52H,EAAO,CAC/B,MAAMowI,EAAYX,GAAYzvI,EAAM,qBAC9B0wI,EAAiBP,GACrBnwI,EACA2vI,EACA7qB,EACA,gBACAsrB,GAEF,IAAImB,EAAuBb,EACvBH,EAAmB,WACnB,wBAAyBvwI,GAAS,sBAAuBA,IAC3DuxI,EAAuBlC,GACrBoB,EACAzwI,EAAM,qBACN62H,IAEF0Z,EAAmBF,GACjBrwI,EACA,gBACAywI,EACAC,EACAa,IAGJd,EAAYxK,UAEhB,kBAAQ,8bAMJ,MAAMwL,EAAc,YAAYrB,IAChC,IAAIsB,EAAiB,KACjB,eAAgB1xI,IAClB0xI,EAAiB/B,EAAQtE,0BAE3BsE,EAAQvE,uBACN,GAAGsG,yBAAsCD,MAAgBf,MAAmBH,MAAqBgB,sBAEpG,CACH,CAwDEW,CAAoBlyI,EAAO2vI,EAAS7qB,EAAU8qB,EAAaa,GAEvDzwI,EAAMknC,OAAQ,CAChB,MAAMirG,EAAe9C,GACnBoB,EACAzwI,EAAMknC,OACNuvF,IAEFkZ,EAAQnF,6BAA6B,IAAI2H,IAC1C,CAGDh8I,OAAOC,KAAKq6I,EAAY3Y,WAAWl9H,SAAQ,SAAUmgI,GACnD,MAAMqX,EAAW3B,EAAY3Y,UAAUiD,GACjCnO,EAAciZ,GAAuBuM,EAASjtI,MAGpD,IAAIkG,EAFJskI,EAAQ9F,WAAW,GAAG2F,GAAoB4C,EAAS5iJ,SAASo9H,KAI1DvhH,EADE+mI,EAAS5iJ,OAASmnI,GACT,IACT+O,GACyB1lI,EAAM83H,UAAUsa,EAASjtI,OAE3CitI,EAAS5iJ,OAASonI,GAChB,IACT0Y,GAAU,IACLj0G,GAECr7B,EAAM83H,UAAUsa,EAASjtI,OACtB,UAGFitI,EAAS5iJ,OAASinI,GAChB,IACez2H,EAAM83H,UAAUsa,EAASjtI,MAAS,EAAM,EAEvD,IAA6BnF,EAAM83H,UAAUsa,EAASjtI,MAEnE2/G,EAAS8H,GAAevhH,CAC5B,IAIElV,OAAOC,KAAKq6I,EAAYlsI,YAAY3J,SAAQ,SAAU+rI,GACpD,MAAMryI,EAAWm8I,EAAYlsI,WAAWoiI,GACnCiJ,EAAYrrI,WAAWoiI,KAC1BiJ,EAAYrrI,WAAWoiI,GAAYryI,GAErC,IAAI9E,EAAOggJ,GAAoBl7I,EAAS9E,MACpC2sI,EAAa,UAAU7nI,EAAS6Q,OAChC7Q,EAAS9E,OAASonI,KACpBpnI,EAAO,OACP2sI,EAAa,eAAeA,KAC5BwT,EAAQrE,wBA15BU,qPA45BpBqE,EAAQ5F,WAAW,UAAUz1I,EAAS6Q,OAAQ3V,EAAM2sI,EACxD,IAGEhmI,OAAOC,KAAKw5I,EAAYrrI,YAAY3J,SAAQ,SAAU+rI,GACpD,MAAMryI,EAAWs7I,EAAYrrI,WAAWoiI,GACxCgJ,EAAQ7F,aACN,GAAG0F,GAAoBl7I,EAAS9E,gBAAgB8E,EAAS6Q,OAE/D,IAEE,MAAMy4G,EAAaznH,OAAOC,KAAKw5I,EAAYrrI,YAAYg2B,KAAI,SACzDosG,GAEA,MAAMryI,EAAWs7I,EAAYrrI,WAAWoiI,GACxC,IAAIt7H,EAeJ,OAbEA,EADE/W,EAASuyI,UACAvyI,EAASuyI,UACXvyI,EAAS9E,OAASmnI,GACfvnF,GACVs2F,GAA0Bt2F,EAAQv2C,IAAIvE,EAAS6Q,OACxC7Q,EAAS9E,OAASonI,GACfxnF,GACVkgG,GAAU,IAAIj0G,GAAQ+T,EAAQv2C,IAAIvE,EAAS6Q,OAAS,UAC7C7Q,EAAS9E,OAASinI,GACfrnF,GAAaA,EAAQv2C,IAAIvE,EAAS6Q,MAAQ,EAAM,EAEhDiqC,GAAYA,EAAQv2C,IAAIvE,EAAS6Q,MAGxC,CACLA,KAAM7Q,EAAS6Q,KACfhC,KAAMosI,GAAoBj7I,EAAS9E,MACnC6b,WAEN,IAGE,IAAK,MAAMgnI,KAAgBzC,EAAY3J,UACrC0J,EAAQrE,wBAAwBsE,EAAY3J,UAAUoM,IAExD,IAAK,MAAMA,KAAgB5B,EAAYxK,UACrC0J,EAAQpE,0BAA0BkF,EAAYxK,UAAUoM,IAG1D,MAAO,CACL1C,QAASA,EACT/xB,WAAYA,EAAWzpE,QACrB,CAAC/4C,EAAMg5C,KAAU,IACZh5C,EACH,CAACg5C,EAAKjvC,MAAO,CAACkG,SAAU+oC,EAAK/oC,SAAUlI,KAAMixC,EAAKjxC,SAEpD,CAAE,GAEJ2hH,SAAUA,EAEd,CCp/BA,MAAMwtB,GAIJ,WAAA/iJ,CAAY6K,GAKV3K,KAAK8iJ,SAAWn4I,EAAQmiC,QAMxB9sC,KAAK+iJ,gBAAkBp4I,EAAQuwI,eAM/Bl7I,KAAK8yD,UAAYnoD,EAAQiS,SAMzB5c,KAAKgjJ,OAASr4I,EAAQgN,MAMtB3X,KAAKijJ,YAAcjkF,GAAOr0D,EAAQgN,OAMlC3X,KAAKkjJ,cAAgBv4I,EAAQw4I,aAM7BnjJ,KAAKojJ,eAAiBz4I,EAAQ4vE,aAC/B,CAOD,KAAAxlE,GACE,MAAM4C,EAAQ3X,KAAK60G,WACnB,OAAO,IAAIguC,GAAW,CACpB/1G,QAAS9sC,KAAK8tC,aACdn2B,MAAOtV,MAAMC,QAAQqV,GAASA,EAAM7T,QAAU6T,EAC9CiF,SAAU5c,KAAK81C,cACfolG,eAAgBl7I,KAAKq4E,oBACrB8qE,aAAcnjJ,KAAKqjJ,kBAAkBv/I,QACrCy2E,cAAev6E,KAAKw6E,oBAEvB,CAOD,UAAA1sC,GACE,OAAO9tC,KAAK8iJ,QACb,CAOD,iBAAAzqE,GACE,OAAOr4E,KAAK+iJ,eACb,CAOD,WAAAjtG,GACE,OAAO91C,KAAK8yD,SACb,CAOD,QAAA+hD,GACE,OAAO70G,KAAKgjJ,MACb,CAMD,aAAAzqE,GACE,OAAOv4E,KAAKijJ,WACb,CAOD,eAAAI,GACE,OAAOrjJ,KAAKkjJ,aACb,CAOD,gBAAA1oE,GACE,OAAOx6E,KAAKojJ,cACb,CAQD,SAAAlrE,GACE,OAAO3vE,GACR,CAQD,QAAAizB,CAASJ,GACP,OAAO7yB,GACR,CAMD,oBAAA+6I,GACE,OAAO/6I,GACR,CAOD,aAAAkzB,CAAcL,GACZ,OAAO,CACR,CAMD,aAAAi/C,GACE,OAAO9xE,GACR,CAMD,YAAAg7I,GACE,OAAOh7I,GACR,CAOD,SAAA6vE,GACE,OAAO7vE,GACR,CAOD,OAAAoL,GACE,OAAOpL,GACR,CAQD,eAAAi7I,CAAgBL,GACdnjJ,KAAKkjJ,cAAgBC,CACtB,CAQD,UAAAt0G,CAAW/B,GACT9sC,KAAK8iJ,SAAWh2G,CACjB,CAQD,iBAAA22G,CAAkBvI,GAChBl7I,KAAK+iJ,gBAAkB7H,CACxB,CAQD,WAAAhmG,CAAYt4B,GACV5c,KAAK8yD,UAAYl2C,CAClB,CAQD,QAAA8mI,CAAS/rI,GACP3X,KAAKgjJ,OAASrrI,EACd3X,KAAKijJ,YAAcjkF,GAAOrnD,EAC3B,CAMD,iBAAAqkE,CAAkBz2E,GAChBgD,GACD,CAMD,IAAA+E,GACE/E,GACD,CAMD,mBAAAwzE,CAAoBx2E,GAClBgD,GACD,EAGH,IAAAo7I,GAAed,GChPf,MAAMe,WAAqBf,GAIzB,WAAA/iJ,CAAY6K,GAOV1F,MAAM,CACJ6nC,QAAS,EACTouG,oBAJ2B10I,IAA3BmE,EAAQuwI,gBAA+BvwI,EAAQuwI,eAK/Ct+H,cAA+BpW,IAArBmE,EAAQiS,SAAyBjS,EAAQiS,SAAW,EAC9DjF,WAAyBnR,IAAlBmE,EAAQgN,MAAsBhN,EAAQgN,MAAQ,EACrDwrI,kBAC2B38I,IAAzBmE,EAAQw4I,aAA6Bx4I,EAAQw4I,aAAe,CAAC,EAAG,GAClE5oE,cAAe5vE,EAAQ4vE,gBAOzBv6E,KAAK6jJ,UAML7jJ,KAAK8jJ,oBAAsB,KAM3B9jJ,KAAK+jJ,WAAyBv9I,IAAjBmE,EAAQsqE,KAAqBtqE,EAAQsqE,KAAO,KAMzDj1E,KAAKwlF,QAAU,CAAC,EAAG,GAMnBxlF,KAAK29B,QAAUhzB,EAAQovF,OAMvB/5F,KAAKgkJ,aACgBx9I,IAAnBmE,EAAQqd,OAAuBrd,EAAQqd,OAASrd,EAAQs5I,QAM1DjkJ,KAAKkkJ,SAAWv5I,EAAQw5I,QAMxBnkJ,KAAK49B,YAA2Bp3B,IAAlBmE,EAAQ6M,MAAsB7M,EAAQ6M,MAAQ,EAM5DxX,KAAKokJ,aAA6B59I,IAAnBmE,EAAQuqE,OAAuBvqE,EAAQuqE,OAAS,KAM/Dl1E,KAAKyT,MAMLzT,KAAKqkJ,eAELrkJ,KAAK88C,QACN,CAOD,KAAA/nC,GACE,MAAM4C,EAAQ3X,KAAK60G,WACbtkG,EAAQ,IAAIqzI,GAAa,CAC7B3uE,KAAMj1E,KAAKm1E,UAAYn1E,KAAKm1E,UAAUpgE,aAAUvO,EAChDuzF,OAAQ/5F,KAAK85F,YACb9xE,OAAQhoB,KAAKmmB,YACbg+H,QAASnkJ,KAAKskJ,aACd9sI,MAAOxX,KAAKo+B,WACZ82C,OAAQl1E,KAAKo1E,YAAcp1E,KAAKo1E,YAAYrgE,aAAUvO,EACtDoW,SAAU5c,KAAK81C,cACfolG,eAAgBl7I,KAAKq4E,oBACrB1gE,MAAOtV,MAAMC,QAAQqV,GAASA,EAAM7T,QAAU6T,EAC9CwrI,aAAcnjJ,KAAKqjJ,kBAAkBv/I,QACrCy2E,cAAev6E,KAAKw6E,qBAGtB,OADAjqE,EAAMs+B,WAAW7uC,KAAK8tC,cACfv9B,CACR,CAQD,SAAA2nE,GACE,MAAMxkE,EAAO1T,KAAKyT,MACZ0vI,EAAenjJ,KAAKqjJ,kBACpB1rI,EAAQ3X,KAAKu4E,gBAGnB,MAAO,CACL7kE,EAAK,GAAK,EAAIyvI,EAAa,GAAKxrI,EAAM,GACtCjE,EAAK,GAAK,EAAIyvI,EAAa,GAAKxrI,EAAM,GAEzC,CAOD,QAAAymB,GACE,OAAOp+B,KAAK49B,MACb,CAOD,OAAAu3C,GACE,OAAOn1E,KAAK+jJ,KACb,CAOD,OAAAQ,CAAQtvE,GACNj1E,KAAK+jJ,MAAQ9uE,EACbj1E,KAAK88C,QACN,CAKD,oBAAAwmG,GAME,OALKtjJ,KAAK8jJ,sBACR9jJ,KAAK8jJ,oBAAsB9jJ,KAAKwkJ,0BAC9BxkJ,KAAKqkJ,iBAGFrkJ,KAAK8jJ,mBACb,CAQD,QAAAtoH,CAASJ,GACP,IAAItoB,EAAQ9S,KAAK6jJ,UAAUzoH,GAC3B,IAAKtoB,EAAO,CACV,MAAM2xI,EAAgBzkJ,KAAKqkJ,eACrBl0I,EAAUX,GACdi1I,EAAc/wI,KAAO0nB,EACrBqpH,EAAc/wI,KAAO0nB,GAEvBp7B,KAAK0kJ,MAAMD,EAAet0I,EAASirB,GAEnCtoB,EAAQ3C,EAAQN,OAChB7P,KAAK6jJ,UAAUzoH,GAActoB,CAC9B,CACD,OAAOA,CACR,CAOD,aAAA2oB,CAAcL,GACZ,OAAOA,CACR,CAKD,YAAAmoH,GACE,OAAOvjJ,KAAKyT,KACb,CAKD,aAAA4mE,GACE,OAAOjgD,EACR,CAOD,SAAAg+C,GACE,OAAOp4E,KAAKwlF,OACb,CAOD,SAAAsU,GACE,OAAO95F,KAAK29B,OACb,CAOD,SAAAxX,GACE,OAAOnmB,KAAKgkJ,OACb,CAOD,UAAAM,GACE,OAAOtkJ,KAAKkkJ,QACb,CAOD,OAAAvwI,GACE,OAAO3T,KAAKyT,KACb,CAOD,SAAA2hE,GACE,OAAOp1E,KAAKokJ,OACb,CAOD,SAAAO,CAAUzvE,GACRl1E,KAAKokJ,QAAUlvE,EACfl1E,KAAK88C,QACN,CAKD,iBAAAk/B,CAAkBz2E,GAAY,CAK9B,IAAA+H,GAAS,CAKT,mBAAAyuE,CAAoBx2E,GAAY,CAUhC,sBAAAq/I,CAAuBjuE,EAAU8pE,EAAa7pE,GAC5C,GACkB,IAAhB6pE,GACAzgJ,KAAK29B,UAAYljB,KACH,UAAbk8D,GAAqC,UAAbA,EAEzB,OAAO8pE,EAwBT,IAAIoE,EAAK7kJ,KAAKgkJ,QACVc,OAAuBt+I,IAAlBxG,KAAKkkJ,SAAyBW,EAAK7kJ,KAAKkkJ,SACjD,GAAIW,EAAKC,EAAI,CACX,MAAM7iJ,EAAM4iJ,EACZA,EAAKC,EACLA,EAAK7iJ,CACN,CACD,MAAM83F,OACcvzF,IAAlBxG,KAAKkkJ,SAAyBlkJ,KAAK29B,QAAyB,EAAf39B,KAAK29B,QAC9C6M,EAAS,EAAIv+B,KAAK+T,GAAM+5E,EACxB14F,EAAIyjJ,EAAK74I,KAAKyL,IAAI8yB,GAElBvzB,EAAI4tI,EADA54I,KAAKma,KAAK0+H,EAAKA,EAAKzjJ,EAAIA,GAE5B6V,EAAIjL,KAAKma,KAAK/kB,EAAIA,EAAI4V,EAAIA,GAC1B8tI,EAAa7tI,EAAI7V,EACvB,GAAiB,UAAbs1E,GAAwBouE,GAAcnuE,EACxC,OAAOmuE,EAAatE,EAetB,MAAMj8H,EAAIi8H,EAAc,EAAIsE,EACtB/lI,EAAKyhI,EAAc,GAAMxpI,EAAIC,GAE7B8tI,EADO/4I,KAAKma,MAAMy+H,EAAKrgI,IAAMqgI,EAAKrgI,GAAKxF,EAAIA,GACzB6lI,EACxB,QAAsBr+I,IAAlBxG,KAAKkkJ,UAAuC,UAAbvtE,EACjC,OAAkB,EAAXquE,EAIT,MAAMC,EAAKJ,EAAK54I,KAAKyL,IAAI8yB,GAEnB06G,EAAKJ,EADA74I,KAAKma,KAAKy+H,EAAKA,EAAKI,EAAKA,GAG9BE,EADKl5I,KAAKma,KAAK6+H,EAAKA,EAAKC,EAAKA,GACPD,EAC7B,GAAIE,GAAmBvuE,EAAY,CACjC,MAAMwuE,EAAeD,EAAkB1E,EAAe,EAAIqE,EAAKD,EAC/D,OAAO,EAAI54I,KAAKyP,IAAIspI,EAAUI,EAC/B,CACD,OAAkB,EAAXJ,CACR,CAMD,mBAAAK,GACE,IAKI7zE,EALA+E,EAAUz0B,GACV60B,EAAW30B,GACX40B,EAAa,EACbJ,EAAW,KACXE,EAAiB,EAEjB+pE,EAAc,EAEdzgJ,KAAKokJ,UACP5yE,EAAchE,GAAYxtE,KAAKokJ,QAAQltE,YAAch1B,IACrDu+F,EAAczgJ,KAAKokJ,QAAQhoI,YrJ9SD,EqJ+S1Bo6D,EAAWx2E,KAAKokJ,QAAQ7sE,cACxBb,EAAiB12E,KAAKokJ,QAAQ3sE,qBAAuB,EACrDd,EAAW32E,KAAKokJ,QAAQzsE,eAAiB31B,GACzCu0B,EAAUv2E,KAAKokJ,QAAQ/sE,cAAgBv1B,GACvC80B,EAAa52E,KAAKokJ,QAAQtsE,iBAAmB71B,IAG/C,MAAMx+B,EAAMzjB,KAAK4kJ,uBAAuBjuE,EAAU8pE,EAAa7pE,GACzD0uE,EAAYr5I,KAAKyP,IAAI1b,KAAKgkJ,QAAShkJ,KAAKkkJ,UAAY,GAG1D,MAAO,CACL1yE,YAAaA,EACbivE,YAAaA,EACb/sI,KALWzH,KAAKkZ,KAAK,EAAImgI,EAAY7hI,GAMrC8yD,QAASA,EACTC,SAAUA,EACVE,eAAgBA,EAChBC,SAAUA,EACVC,WAAYA,EAEf,CAKD,MAAA95B,GACE98C,KAAKqkJ,eAAiBrkJ,KAAKqlJ,sBAC3B,MAAM3xI,EAAO1T,KAAKqkJ,eAAe3wI,KACjC1T,KAAK6jJ,UAAY,GACjB7jJ,KAAK8jJ,oBAAsB,KAC3B9jJ,KAAKyT,MAAQ,CAACC,EAAMA,EACrB,CAQD,KAAAgxI,CAAMD,EAAet0I,EAASirB,GAO5B,GANAjrB,EAAQwH,MAAMyjB,EAAYA,GAE1BjrB,EAAQ0H,UAAU4sI,EAAc/wI,KAAO,EAAG+wI,EAAc/wI,KAAO,GAE/D1T,KAAKulJ,YAAYp1I,GAEbnQ,KAAK+jJ,MAAO,CACd,IAAI95G,EAAQjqC,KAAK+jJ,MAAM7sE,WACT,OAAVjtC,IACFA,EAAQ4X,IAEV1xC,EAAQ2sB,UAAY0wC,GAAYvjC,GAChC95B,EAAQ8kE,MACT,CACGwvE,EAAcjzE,cAChBrhE,EAAQqhE,YAAcizE,EAAcjzE,YACpCrhE,EAAQ+0C,UAAYu/F,EAAchE,YAC9BgE,EAAcjuE,WAChBrmE,EAAQsmE,YAAYguE,EAAcjuE,UAClCrmE,EAAQumE,eAAiB+tE,EAAc/tE,gBAEzCvmE,EAAQomE,QAAUkuE,EAAcluE,QAChCpmE,EAAQwmE,SAAW8tE,EAAc9tE,SACjCxmE,EAAQymE,WAAa6tE,EAAc7tE,WACnCzmE,EAAQ+kE,SAEX,CAOD,yBAAAsvE,CAA0BC,GACxB,IAAIt0I,EACJ,GAAInQ,KAAK+jJ,MAAO,CACd,IAAI95G,EAAQjqC,KAAK+jJ,MAAM7sE,WAGnBpqC,EAAU,EACO,iBAAV7C,IACTA,EAAQ2B,GAAQ3B,IAEJ,OAAVA,EACF6C,EAAU,EACDzqC,MAAMC,QAAQ2nC,KACvB6C,EAA2B,IAAjB7C,EAAM9oC,OAAe8oC,EAAM,GAAK,GAE5B,IAAZ6C,IAGF38B,EAAUX,GAAsBi1I,EAAc/wI,KAAM+wI,EAAc/wI,MAClE1T,KAAKwlJ,wBAAwBf,EAAet0I,GAE/C,CACD,OAAOA,EAAUA,EAAQN,OAAS7P,KAAKw7B,SAAS,EACjD,CAMD,WAAA+pH,CAAYp1I,GACV,IAAI4pF,EAAS/5F,KAAK29B,QAClB,MAAM3V,EAAShoB,KAAKgkJ,QACpB,GAAIjqD,IAAWt/E,IACbtK,EAAQ6kE,IAAI,EAAG,EAAGhtD,EAAQ,EAAG,EAAI/b,KAAK+T,QACjC,CACL,MAAMmkI,OAA4B39I,IAAlBxG,KAAKkkJ,SAAyBl8H,EAAShoB,KAAKkkJ,cACtC19I,IAAlBxG,KAAKkkJ,WACPnqD,GAAU,GAEZ,MAAMpiE,EAAa33B,KAAK49B,OAAS3xB,KAAK+T,GAAK,EACrCm/D,EAAQ,EAAIlzE,KAAK+T,GAAM+5E,EAC7B,IAAK,IAAIn4F,EAAI,EAAGA,EAAIm4F,EAAQn4F,IAAK,CAC/B,MAAM6jJ,EAAS9tH,EAAa/1B,EAAIu9E,EAC1BumE,EAAU9jJ,EAAI,GAAM,EAAIomB,EAASm8H,EACvCh0I,EAAQykE,OAAO8wE,EAAUz5I,KAAKwL,IAAIguI,GAASC,EAAUz5I,KAAKyL,IAAI+tI,GAC/D,CACDt1I,EAAQ0kE,WACT,CACF,CAOD,uBAAA2wE,CAAwBf,EAAet0I,GAErCA,EAAQ0H,UAAU4sI,EAAc/wI,KAAO,EAAG+wI,EAAc/wI,KAAO,GAE/D1T,KAAKulJ,YAAYp1I,GAEjBA,EAAQ2sB,UAAY+kB,GACpB1xC,EAAQ8kE,OACJwvE,EAAcjzE,cAChBrhE,EAAQqhE,YAAcizE,EAAcjzE,YACpCrhE,EAAQ+0C,UAAYu/F,EAAchE,YAC9BgE,EAAcjuE,WAChBrmE,EAAQsmE,YAAYguE,EAAcjuE,UAClCrmE,EAAQumE,eAAiB+tE,EAAc/tE,gBAEzCvmE,EAAQwmE,SAAW8tE,EAAc9tE,SACjCxmE,EAAQymE,WAAa6tE,EAAc7tE,WACnCzmE,EAAQ+kE,SAEX,EAGH,IAAAywE,GAAe/B,GCzkBf,MAAMgC,WAAoBhC,GAIxB,WAAA9jJ,CAAY6K,GAGV1F,MAAM,CACJ80F,OAAQt/E,IACRw6D,MAJFtqE,EAAUA,GAAoB,CAACqd,OAAQ,IAIvBitD,KACdjtD,OAAQrd,EAAQqd,OAChBktD,OAAQvqE,EAAQuqE,OAChBv9D,WAAyBnR,IAAlBmE,EAAQgN,MAAsBhN,EAAQgN,MAAQ,EACrDiF,cAA+BpW,IAArBmE,EAAQiS,SAAyBjS,EAAQiS,SAAW,EAC9Ds+H,oBAC6B10I,IAA3BmE,EAAQuwI,gBAA+BvwI,EAAQuwI,eACjDiI,kBAC2B38I,IAAzBmE,EAAQw4I,aAA6Bx4I,EAAQw4I,aAAe,CAAC,EAAG,GAClE5oE,cAAe5vE,EAAQ4vE,eAE1B,CAOD,KAAAxlE,GACE,MAAM4C,EAAQ3X,KAAK60G,WACbtkG,EAAQ,IAAIq1I,GAAY,CAC5B3wE,KAAMj1E,KAAKm1E,UAAYn1E,KAAKm1E,UAAUpgE,aAAUvO,EAChD0uE,OAAQl1E,KAAKo1E,YAAcp1E,KAAKo1E,YAAYrgE,aAAUvO,EACtDwhB,OAAQhoB,KAAKmmB,YACbxO,MAAOtV,MAAMC,QAAQqV,GAASA,EAAM7T,QAAU6T,EAC9CiF,SAAU5c,KAAK81C,cACfolG,eAAgBl7I,KAAKq4E,oBACrB8qE,aAAcnjJ,KAAKqjJ,kBAAkBv/I,QACrCy2E,cAAev6E,KAAKw6E,qBAGtB,OADAjqE,EAAMs+B,WAAW7uC,KAAK8tC,cACfv9B,CACR,CAQD,SAAA4mF,CAAUnvE,GACRhoB,KAAKgkJ,QAAUh8H,EACfhoB,KAAK88C,QACN,EAGH,IAAA+oG,GAAeD,GCjEf,MAAME,GAIJ,WAAAhmJ,CAAY6K,GACVA,EAAUA,GAAW,GAMrB3K,KAAK+lJ,YAA2Bv/I,IAAlBmE,EAAQs/B,MAAsBt/B,EAAQs/B,MAAQ,IAC7D,CAOD,KAAAl1B,GACE,MAAMk1B,EAAQjqC,KAAKk3E,WACnB,OAAO,IAAI4uE,GAAK,CACd77G,MAAO5nC,MAAMC,QAAQ2nC,GAASA,EAAMnmC,QAAUmmC,QAASzjC,GAE1D,CAOD,QAAA0wE,GACE,OAAOl3E,KAAK+lJ,MACb,CAQD,QAAAC,CAAS/7G,GACPjqC,KAAK+lJ,OAAS97G,CACf,EAGH,IAAAg8G,GAAeH,GC/Cf,IAAII,GAAqB,KAEzB,MAAMC,WAAkB1+I,EAQtB,WAAA3H,CAAYgT,EAAO+nB,EAAKwB,EAAay/C,EAAY7xC,GAC/ChlC,QAMAjF,KAAKomJ,mBAAqB,KAM1BpmJ,KAAKu7B,OAASzoB,EAMd9S,KAAKu8B,aAAeF,EAMpBr8B,KAAKk8B,QAAU,GAMfl8B,KAAK+lJ,OAAS97G,EAMdjqC,KAAKqmJ,iBAA6B7/I,IAAfs1E,EAA2B1hD,GAAkB0hD,EAMhE97E,KAAKyT,MACHX,GAASA,EAAMrD,OAASqD,EAAMpD,OAAS,CAACoD,EAAMrD,MAAOqD,EAAMpD,QAAU,KAMvE1P,KAAKw8B,KAAO3B,EAKZ76B,KAAKsmJ,QACN,CAKD,gBAAAC,GACEvmJ,KAAKu7B,OAAS,IAAIxsB,MACQ,OAAtB/O,KAAKu8B,eACPv8B,KAAKu7B,OAAOc,YAAcr8B,KAAKu8B,aAElC,CAMD,UAAAiqH,GACE,QAAsBhgJ,IAAlBxG,KAAKsmJ,UAA0BtmJ,KAAKqmJ,cAAgBjsH,GAAmB,CACpE8rH,KACHA,GAAqB12I,GAAsB,EAAG,OAAGhJ,EAAW,CAC1DuM,oBAAoB,KAGxBmzI,GAAmBlzI,UAAUhT,KAAKu7B,OAAQ,EAAG,GAC7C,IACE2qH,GAAmBjzI,aAAa,EAAG,EAAG,EAAG,GACzCjT,KAAKsmJ,UAAW,CACjB,CAAC,MAAOpvI,GACPgvI,GAAqB,KACrBlmJ,KAAKsmJ,UAAW,CACjB,CACF,CACD,OAAyB,IAAlBtmJ,KAAKsmJ,QACb,CAKD,oBAAAG,GACEzmJ,KAAK4F,cAAckC,EACpB,CAKD,iBAAA80B,GACE58B,KAAKqmJ,YAAcjsH,GACnBp6B,KAAKymJ,sBACN,CAKD,gBAAAxpH,GACEj9B,KAAKqmJ,YAAcjsH,GACnBp6B,KAAKyT,MAAQ,CAACzT,KAAKu7B,OAAO9rB,MAAOzP,KAAKu7B,OAAO7rB,QAC7C1P,KAAKymJ,sBACN,CAMD,QAAAjrH,CAASJ,GAKP,OAJKp7B,KAAKu7B,QACRv7B,KAAKumJ,mBAEPvmJ,KAAK0mJ,cAActrH,GACZp7B,KAAKk8B,QAAQd,GAAcp7B,KAAKk8B,QAAQd,GAAcp7B,KAAKu7B,MACnE,CAMD,aAAAE,CAAcL,GAEZ,OADAp7B,KAAK0mJ,cAActrH,GACZp7B,KAAKk8B,QAAQd,GAAcA,EAAa,CAChD,CAKD,aAAAi/C,GACE,OAAOr6E,KAAKqmJ,WACb,CAKD,oBAAA/C,GAIE,GAHKtjJ,KAAKu7B,QACRv7B,KAAKumJ,oBAEFvmJ,KAAKomJ,mBACR,GAAIpmJ,KAAKwmJ,aAAc,CACrB,MAAM/2I,EAAQzP,KAAKyT,MAAM,GACnB/D,EAAS1P,KAAKyT,MAAM,GACpBtD,EAAUX,GAAsBC,EAAOC,GAC7CS,EAAQ4sB,SAAS,EAAG,EAAGttB,EAAOC,GAC9B1P,KAAKomJ,mBAAqBj2I,EAAQN,MAC1C,MACQ7P,KAAKomJ,mBAAqBpmJ,KAAKu7B,OAGnC,OAAOv7B,KAAKomJ,kBACb,CAMD,OAAAzyI,GACE,OAAO3T,KAAKyT,KACb,CAKD,MAAAkzI,GACE,OAAO3mJ,KAAKw8B,IACb,CAKD,IAAAlvB,GACE,GAAItN,KAAKqmJ,cAAgBjsH,GAAzB,CAGKp6B,KAAKu7B,QACRv7B,KAAKumJ,mBAGPvmJ,KAAKqmJ,YAAcjsH,GACnB,SACoB5zB,IAAdxG,KAAKw8B,OAC0Bx8B,KAAW,OAAE66B,IAAM76B,KAAKw8B,KAE5D,CAAC,MAAOtlB,GACPlX,KAAK48B,mBACN,CACG58B,KAAKu7B,kBAAkBK,kBACzBX,GAAej7B,KAAKu7B,OAAQv7B,KAAKw8B,MAC9BzoB,MAAMjB,IACL9S,KAAKu7B,OAASzoB,EACd9S,KAAKi9B,kBAAkB,IAExBjpB,MAAMhU,KAAK48B,kBAAkB11B,KAAKlH,MAnBtC,CAqBF,CAMD,aAAA0mJ,CAActrH,GACZ,IACGp7B,KAAK+lJ,QACN/lJ,KAAKk8B,QAAQd,IACbp7B,KAAKqmJ,cAAgBjsH,GAErB,OAGF,MAAMtnB,EAAQ9S,KAAKu7B,OACb1rB,EAASE,SAASC,cAAc,UACtCH,EAAOJ,MAAQxD,KAAKkZ,KAAKrS,EAAMrD,MAAQ2rB,GACvCvrB,EAAOH,OAASzD,KAAKkZ,KAAKrS,EAAMpD,OAAS0rB,GAEzC,MAAMyB,EAAMhtB,EAAOI,WAAW,MAC9B4sB,EAAIllB,MAAMyjB,EAAYA,GACtByB,EAAI7pB,UAAUF,EAAO,EAAG,GAExB+pB,EAAIghD,yBAA2B,WAC/BhhD,EAAIC,UAAYqO,GAASnrC,KAAK+lJ,QAC9BlpH,EAAIE,SAAS,EAAG,EAAGltB,EAAOJ,MAAQ2rB,EAAYvrB,EAAOH,OAAS0rB,GAE9DyB,EAAIghD,yBAA2B,iBAC/BhhD,EAAI7pB,UAAUF,EAAO,EAAG,GAExB9S,KAAKk8B,QAAQd,GAAcvrB,CAC5B,EAWI,SAASzG,GAAI0J,EAAOsoG,EAAU/+E,EAAay/C,EAAY7xC,GAC5D,IAAIoC,OACW7lC,IAAb40G,OACI50G,EACAu4C,GAAe31C,IAAIgyG,EAAU/+E,EAAa4N,GAWhD,OAVKoC,IACHA,EAAY,IAAI85G,GACdrzI,EACAA,aAAiB8oB,iBAAmB9oB,EAAM+nB,UAAOr0B,EAAY40G,EAC7D/+E,EACAy/C,EACA7xC,GAEF8U,GAAeh1C,IAAIqxG,EAAU/+E,EAAa4N,EAAOoC,IAE5CA,CACT,CAEA,IAAAu6G,GAAeT,GCrOf,SAASU,GAAep3I,EAAOC,EAAQo3I,EAAaC,GAClD,YAAoBvgJ,IAAhBsgJ,QAA8CtgJ,IAAjBugJ,EACxB,CAACD,EAAcr3I,EAAOs3I,EAAer3I,QAE1BlJ,IAAhBsgJ,EACKA,EAAcr3I,OAEFjJ,IAAjBugJ,EACKA,EAAer3I,EAEjB,CACT,CAOA,MAAMs3I,WAAanE,GAIjB,WAAA/iJ,CAAY6K,GAMV,MAAMmiC,OAA8BtmC,KALpCmE,EAAUA,GAAW,IAKGmiC,QAAwBniC,EAAQmiC,QAAU,EAK5DlwB,OAAgCpW,IAArBmE,EAAQiS,SAAyBjS,EAAQiS,SAAW,EAK/DjF,OAA0BnR,IAAlBmE,EAAQgN,MAAsBhN,EAAQgN,MAAQ,EAKtDujI,OACuB10I,IAA3BmE,EAAQuwI,gBAA+BvwI,EAAQuwI,eAEjDj2I,MAAM,CACJ6nC,QAASA,EACTlwB,SAAUA,EACVjF,MAAOA,EACPwrI,kBAC2B38I,IAAzBmE,EAAQw4I,aAA6Bx4I,EAAQw4I,aAAe,CAAC,EAAG,GAClEjI,eAAgBA,EAChB3gE,cAAe5vE,EAAQ4vE,gBAOzBv6E,KAAK88D,aAA6Bt2D,IAAnBmE,EAAQyiB,OAAuBziB,EAAQyiB,OAAS,CAAC,GAAK,IAMrEptB,KAAKinJ,kBAAoB,KAMzBjnJ,KAAKknJ,mBACsB1gJ,IAAzBmE,EAAQw8I,aAA6Bx8I,EAAQw8I,aAAe,WAM9DnnJ,KAAKonJ,mBACsB5gJ,IAAzBmE,EAAQ08I,aAA6B18I,EAAQ08I,aAAe,WAM9DrnJ,KAAKsnJ,mBACsB9gJ,IAAzBmE,EAAQ48I,aAA6B58I,EAAQ48I,aAAe,WAM9DvnJ,KAAKu8B,kBACqB/1B,IAAxBmE,EAAQ0xB,YAA4B1xB,EAAQ0xB,YAAc,KAE5D,MAAMvpB,OAAwBtM,IAAhBmE,EAAQ6vB,IAAoB7vB,EAAQ6vB,IAAM,KAExD,IAuBIshD,EAvBAs/B,EAAWzwG,EAAQkwB,IAmFvB,GAjFA5mB,UACiBzN,IAAb40G,GAA0BtoG,GAC5B,8DAGgBtM,IAAb40G,GAA8C,IAApBA,EAASj6G,SAAiB2R,IACvDsoG,EAA2C,EAAQvgF,KAAOnyB,EAAOoK,IAEnEmB,QACezN,IAAb40G,GAA0BA,EAASj6G,OAAS,EAC5C,6DAGF8S,WAEuBzN,IAAlBmE,EAAQ8E,YAA0CjJ,IAAnBmE,EAAQ+E,cACtBlJ,IAAlBmE,EAAQgN,OAEV,qEAIkBnR,IAAhBmE,EAAQkwB,IACVihD,EAAa1hD,QACM5zB,IAAVsM,IAGLgpE,EAFAhpE,aAAiB8oB,iBACf9oB,EAAMooB,SACKpoB,EAAM+nB,IAAMT,GAAoBA,GAEhCA,GAGFA,IAQjBp6B,KAAK+lJ,YAA2Bv/I,IAAlBmE,EAAQs/B,MAAsB2B,GAAQjhC,EAAQs/B,OAAS,KAMrEjqC,KAAKwnJ,WAAaC,GAChB30I,EACN,EACM9S,KAAKu8B,aACLu/C,EACA97E,KAAK+lJ,QAOP/lJ,KAAK0nJ,aAA6BlhJ,IAAnBmE,EAAQoQ,OAAuBpQ,EAAQoQ,OAAS,CAAC,EAAG,GAKnE/a,KAAK2nJ,mBACsBnhJ,IAAzBmE,EAAQi9I,aAA6Bj9I,EAAQi9I,aAAe,WAM9D5nJ,KAAKwlF,QAAU,KAMfxlF,KAAKyT,WAAyBjN,IAAjBmE,EAAQ+I,KAAqB/I,EAAQ+I,KAAO,UAKnClN,IAAlBmE,EAAQ8E,YAA0CjJ,IAAnBmE,EAAQ+E,OAAsB,CAC/D,IAAID,EAAOC,EACX,GAAI/E,EAAQ+I,MACTjE,EAAOC,GAAU/E,EAAQ+I,SACrB,CACL,MAAMZ,EAAQ9S,KAAKw7B,SAAS,GAC5B,GAAI1oB,EAAMrD,OAASqD,EAAMpD,OACvBD,EAAQqD,EAAMrD,MACdC,EAASoD,EAAMpD,YACV,GAAIoD,aAAiB8oB,iBAAkB,CAC5C57B,KAAK6nJ,gBAAkBl9I,EACvB,MAAMwjE,EAAS,KAEb,GADAnuE,KAAK+7E,oBAAoB5N,IACpBnuE,KAAK6nJ,gBACR,OAEF,MAAM9vE,EAAY/3E,KAAKwnJ,WAAW7zI,UAClC3T,KAAK0jJ,SACHmD,GACE9uE,EAAU,GACVA,EAAU,GACVptE,EAAQ8E,MACR9E,EAAQ+E,QAEX,EAGH,YADA1P,KAAKg8E,kBAAkB7N,EAExB,CACF,MACa3nE,IAAViJ,GACFzP,KAAK0jJ,SACHmD,GAAep3I,EAAOC,EAAQ/E,EAAQ8E,MAAO9E,EAAQ+E,QAG1D,CACF,CAOD,KAAAqF,GACE,IAAI4C,EAAOlI,EAAOC,EAQlB,OAPI1P,KAAK6nJ,iBACPp4I,EAAQzP,KAAK6nJ,gBAAgBp4I,MAC7BC,EAAS1P,KAAK6nJ,gBAAgBn4I,SAE9BiI,EAAQ3X,KAAK60G,WACbl9F,EAAQtV,MAAMC,QAAQqV,GAASA,EAAM7T,QAAU6T,GAE1C,IAAIqvI,GAAK,CACd55H,OAAQptB,KAAK88D,QAAQh5D,QACrBqjJ,aAAcnnJ,KAAKknJ,cACnBG,aAAcrnJ,KAAKonJ,cACnBG,aAAcvnJ,KAAKsnJ,cACnBr9G,MACEjqC,KAAK+lJ,QAAU/lJ,KAAK+lJ,OAAOjiJ,MACvB9D,KAAK+lJ,OAAOjiJ,QACZ9D,KAAK+lJ,aAAUv/I,EACrB61B,YAAar8B,KAAKu8B,aAClBxhB,OAAQ/a,KAAK0nJ,QAAQ5jJ,QACrB8jJ,aAAc5nJ,KAAK2nJ,cACnB76G,QAAS9sC,KAAK8tC,aACdotG,eAAgBl7I,KAAKq4E,oBACrBz7D,SAAU5c,KAAK81C,cACfn+B,QACAlI,QACAC,SACAgE,KAAqB,OAAf1T,KAAKyT,MAAiBzT,KAAKyT,MAAM3P,aAAU0C,EACjDq0B,IAAK76B,KAAK2mJ,SACVxD,aAAcnjJ,KAAKqjJ,kBAAkBv/I,QACrCy2E,cAAev6E,KAAKw6E,oBAEvB,CAQD,SAAAtC,GACE,IAAI9qD,EAASptB,KAAKinJ,kBAClB,IAAK75H,EAAQ,CACXA,EAASptB,KAAK88D,QACd,MAAMppD,EAAO1T,KAAK2T,UAClB,GACwB,YAAtB3T,KAAKonJ,eACiB,YAAtBpnJ,KAAKsnJ,cACL,CACA,IAAK5zI,EACH,OAAO,KAET0Z,EAASptB,KAAK88D,QAAQh5D,QACI,YAAtB9D,KAAKonJ,gBACPh6H,EAAO,IAAM1Z,EAAK,IAEM,YAAtB1T,KAAKsnJ,gBACPl6H,EAAO,IAAM1Z,EAAK,GAErB,CAED,GAA0B,YAAtB1T,KAAKknJ,cAA6B,CACpC,IAAKxzI,EACH,OAAO,KAEL0Z,IAAWptB,KAAK88D,UAClB1vC,EAASptB,KAAK88D,QAAQh5D,SAGA,aAAtB9D,KAAKknJ,eACiB,gBAAtBlnJ,KAAKknJ,gBAEL95H,EAAO,IAAMA,EAAO,GAAK1Z,EAAK,IAGR,eAAtB1T,KAAKknJ,eACiB,gBAAtBlnJ,KAAKknJ,gBAEL95H,EAAO,IAAMA,EAAO,GAAK1Z,EAAK,GAEjC,CACD1T,KAAKinJ,kBAAoB75H,CAC1B,CACD,MAAM+1H,EAAenjJ,KAAKqjJ,kBACpB1rI,EAAQ3X,KAAKu4E,gBAGnB,MAAO,CACLnrD,EAAO,GAAK+1H,EAAa,GAAKxrI,EAAM,GACpCyV,EAAO,GAAK+1H,EAAa,GAAKxrI,EAAM,GAEvC,CASD,SAAAmwI,CAAU16H,GACRptB,KAAK88D,QAAU1vC,EACfptB,KAAKinJ,kBAAoB,IAC1B,CAOD,QAAA/vE,GACE,OAAOl3E,KAAK+lJ,MACb,CASD,QAAAvqH,CAASJ,GACP,OAAOp7B,KAAKwnJ,WAAWhsH,SAASJ,EACjC,CAQD,aAAAK,CAAcL,GACZ,OAAOp7B,KAAKwnJ,WAAW/rH,cAAcL,EACtC,CAKD,YAAAmoH,GACE,OAAOvjJ,KAAKwnJ,WAAW7zI,SACxB,CAKD,aAAA0mE,GACE,OAAOr6E,KAAKwnJ,WAAWntE,eACxB,CAKD,oBAAAipE,GACE,OAAOtjJ,KAAKwnJ,WAAWlE,sBACxB,CAOD,SAAAlrE,GACE,GAAIp4E,KAAKwlF,QACP,OAAOxlF,KAAKwlF,QAEd,IAAIzqE,EAAS/a,KAAK0nJ,QAElB,GAA0B,YAAtB1nJ,KAAK2nJ,cAA6B,CACpC,MAAMj0I,EAAO1T,KAAK2T,UACZo0I,EAAgB/nJ,KAAKwnJ,WAAW7zI,UACtC,IAAKD,IAASq0I,EACZ,OAAO,KAEThtI,EAASA,EAAOjX,QAEQ,aAAtB9D,KAAK2nJ,eACiB,gBAAtB3nJ,KAAK2nJ,gBAEL5sI,EAAO,GAAKgtI,EAAc,GAAKr0I,EAAK,GAAKqH,EAAO,IAG1B,eAAtB/a,KAAK2nJ,eACiB,gBAAtB3nJ,KAAK2nJ,gBAEL5sI,EAAO,GAAKgtI,EAAc,GAAKr0I,EAAK,GAAKqH,EAAO,GAEnD,CAED,OADA/a,KAAKwlF,QAAUzqE,EACR/a,KAAKwlF,OACb,CAOD,MAAAmhE,GACE,OAAO3mJ,KAAKwnJ,WAAWb,QACxB,CAOD,OAAAhzI,GACE,OAAQ3T,KAAKyT,MAAoCzT,KAAKyT,MAAjCzT,KAAKwnJ,WAAW7zI,SACtC,CAOD,QAAAyI,GACE,MAAMzE,EAAQ3X,KAAKu4E,gBACnB,OAAIv4E,KAAKyT,MACAzT,KAAKyT,MAAM,GAAKkE,EAAM,GAE3B3X,KAAKwnJ,WAAWntE,iBAAmBjgD,GAC9Bp6B,KAAKwnJ,WAAW7zI,UAAU,GAAKgE,EAAM,QAD9C,CAID,CAOD,SAAA0E,GACE,MAAM1E,EAAQ3X,KAAKu4E,gBACnB,OAAIv4E,KAAKyT,MACAzT,KAAKyT,MAAM,GAAKkE,EAAM,GAE3B3X,KAAKwnJ,WAAWntE,iBAAmBjgD,GAC9Bp6B,KAAKwnJ,WAAW7zI,UAAU,GAAKgE,EAAM,QAD9C,CAID,CAQD,QAAA+rI,CAAS/rI,UACA3X,KAAK6nJ,gBACZ5iJ,MAAMy+I,SAAS/rI,EAChB,CAKD,iBAAAqkE,CAAkBz2E,GAChBvF,KAAKwnJ,WAAWliJ,iBAAiBwC,EAAkBvC,EACpD,CASD,IAAA+H,GACEtN,KAAKwnJ,WAAWl6I,MACjB,CAKD,mBAAAyuE,CAAoBx2E,GAClBvF,KAAKwnJ,WAAWlhJ,oBAAoBwB,EAAkBvC,EACvD,EAGH,IAAAyiJ,GAAehB,GC5hBf,MAAMiB,GAIJ,WAAAnoJ,CAAY6K,GACVA,EAAUA,GAAW,GAMrB3K,KAAK+lJ,YAA2Bv/I,IAAlBmE,EAAQs/B,MAAsBt/B,EAAQs/B,MAAQ,KAM5DjqC,KAAKkoJ,SAAWv9I,EAAQ4rE,QAMxBv2E,KAAKmoJ,eAAiC3hJ,IAArBmE,EAAQ6rE,SAAyB7rE,EAAQ6rE,SAAW,KAMrEx2E,KAAKooJ,gBAAkBz9I,EAAQ+rE,eAM/B12E,KAAKqoJ,UAAY19I,EAAQgsE,SAMzB32E,KAAKsoJ,YAAc39I,EAAQisE,WAM3B52E,KAAKuoJ,OAAS59I,EAAQ8E,KACvB,CAOD,KAAAsF,GACE,MAAMk1B,EAAQjqC,KAAKk3E,WACnB,OAAO,IAAI+wE,GAAO,CAChBh+G,MAAO5nC,MAAMC,QAAQ2nC,GAASA,EAAMnmC,QAAUmmC,QAASzjC,EACvD+vE,QAASv2E,KAAKq3E,aACdb,SAAUx2E,KAAKu3E,cAAgBv3E,KAAKu3E,cAAczzE,aAAU0C,EAC5DkwE,eAAgB12E,KAAKy3E,oBACrBd,SAAU32E,KAAK23E,cACff,WAAY52E,KAAK83E,gBACjBroE,MAAOzP,KAAKoc,YAEf,CAOD,QAAA86D,GACE,OAAOl3E,KAAK+lJ,MACb,CAOD,UAAA1uE,GACE,OAAOr3E,KAAKkoJ,QACb,CAOD,WAAA3wE,GACE,OAAOv3E,KAAKmoJ,SACb,CAOD,iBAAA1wE,GACE,OAAOz3E,KAAKooJ,eACb,CAOD,WAAAzwE,GACE,OAAO33E,KAAKqoJ,SACb,CAOD,aAAAvwE,GACE,OAAO93E,KAAKsoJ,WACb,CAOD,QAAAlsI,GACE,OAAOpc,KAAKuoJ,MACb,CAQD,QAAAvC,CAAS/7G,GACPjqC,KAAK+lJ,OAAS97G,CACf,CAQD,UAAAu+G,CAAWjyE,GACTv2E,KAAKkoJ,SAAW3xE,CACjB,CAQD,WAAAE,CAAYD,GACVx2E,KAAKmoJ,UAAY3xE,CAClB,CAQD,iBAAAiyE,CAAkB/xE,GAChB12E,KAAKooJ,gBAAkB1xE,CACxB,CAQD,WAAAgyE,CAAY/xE,GACV32E,KAAKqoJ,UAAY1xE,CAClB,CAQD,aAAAgyE,CAAc/xE,GACZ52E,KAAKsoJ,YAAc1xE,CACpB,CAQD,QAAAgyE,CAASn5I,GACPzP,KAAKuoJ,OAAS94I,CACf,EAGH,IAAAo5I,GAAeZ,GC5Ef,MAAMa,GAIJ,WAAAhpJ,CAAY6K,GACVA,EAAUA,GAAW,GAMrB3K,KAAKi5D,UAAY,KAMjBj5D,KAAK+oJ,kBAAoBC,QAEAxiJ,IAArBmE,EAAQiK,UACV5U,KAAK6U,YAAYlK,EAAQiK,UAO3B5U,KAAK+jJ,WAAyBv9I,IAAjBmE,EAAQsqE,KAAqBtqE,EAAQsqE,KAAO,KAMzDj1E,KAAKu7B,YAA2B/0B,IAAlBmE,EAAQmI,MAAsBnI,EAAQmI,MAAQ,KAM5D9S,KAAK28C,eAAiCn2C,IAArBmE,EAAQu5D,SAAyBv5D,EAAQu5D,SAAW,KAMrElkE,KAAKipJ,2BAC8BziJ,IAAjCmE,EAAQwlE,qBACJxlE,EAAQwlE,qBACR,KAMNnwE,KAAKokJ,aAA6B59I,IAAnBmE,EAAQuqE,OAAuBvqE,EAAQuqE,OAAS,KAM/Dl1E,KAAKqzE,WAAyB7sE,IAAjBmE,EAAQi4C,KAAqBj4C,EAAQi4C,KAAO,KAMzD5iD,KAAKkpJ,QAAUv+I,EAAQqiC,MACxB,CAOD,KAAAj4B,GACE,IAAIH,EAAW5U,KAAKkV,cAMpB,OALIN,GAAgC,iBAAbA,IACrBA,EAAgE,EAE9DG,SAEG,IAAI+zI,GAAM,CACfl0I,SAAUA,QAAYpO,EACtByuE,KAAMj1E,KAAKm1E,UAAYn1E,KAAKm1E,UAAUpgE,aAAUvO,EAChDsM,MAAO9S,KAAKw7B,WAAax7B,KAAKw7B,WAAWzmB,aAAUvO,EACnD09D,SAAUlkE,KAAKo+C,oBAAiB53C,EAChC0uE,OAAQl1E,KAAKo1E,YAAcp1E,KAAKo1E,YAAYrgE,aAAUvO,EACtDo8C,KAAM5iD,KAAKq1E,UAAYr1E,KAAKq1E,UAAUtgE,aAAUvO,EAChDwmC,OAAQhtC,KAAK6tC,aAEhB,CAQD,WAAAuQ,GACE,OAAOp+C,KAAK28C,SACb,CAQD,WAAAwsG,CAAYjlF,GACVlkE,KAAK28C,UAAYunB,CAClB,CAQD,uBAAAklF,CAAwBllF,GACtBlkE,KAAKipJ,sBAAwB/kF,CAC9B,CAQD,uBAAAkY,GACE,OAAOp8E,KAAKipJ,qBACb,CASD,WAAA/zI,GACE,OAAOlV,KAAKi5D,SACb,CAQD,mBAAAsc,GACE,OAAOv1E,KAAK+oJ,iBACb,CAOD,OAAA5zE,GACE,OAAOn1E,KAAK+jJ,KACb,CAOD,OAAAQ,CAAQtvE,GACNj1E,KAAK+jJ,MAAQ9uE,CACd,CAOD,QAAAz5C,GACE,OAAOx7B,KAAKu7B,MACb,CAOD,QAAAO,CAAShpB,GACP9S,KAAKu7B,OAASzoB,CACf,CAOD,SAAAsiE,GACE,OAAOp1E,KAAKokJ,OACb,CAOD,SAAAO,CAAUzvE,GACRl1E,KAAKokJ,QAAUlvE,CAChB,CAOD,OAAAG,GACE,OAAOr1E,KAAKqzE,KACb,CAOD,OAAAg2E,CAAQzmG,GACN5iD,KAAKqzE,MAAQzwB,CACd,CAOD,SAAA/U,GACE,OAAO7tC,KAAKkpJ,OACb,CAUD,WAAAr0I,CAAYD,GACc,mBAAbA,EACT5U,KAAK+oJ,kBAAoBn0I,EACI,iBAAbA,EAChB5U,KAAK+oJ,kBAAoB,SAAUppG,GACjC,OACEA,EAAQv2C,IAAIwL,EAEtB,EACgBA,OAEYpO,IAAboO,IACT5U,KAAK+oJ,kBAAoB,WACvB,OAAA,CACR,GAJM/oJ,KAAK+oJ,kBAAoBC,GAM3BhpJ,KAAKi5D,UAAYrkD,CAClB,CAQD,SAAAm6B,CAAU/B,GACRhtC,KAAKkpJ,QAAUl8G,CAChB,EAWI,SAASs8G,GAAW3gJ,GACzB,IAAIuyF,EAEJ,GAAmB,mBAARvyF,EACTuyF,EAAgBvyF,MACX,CAIL,IAAIgN,EACJ,GAAItT,MAAMC,QAAQqG,GAChBgN,EAAShN,MACJ,CACLsL,GACgD,mBAArB,EAAe,UACxC,8CAGF0B,EAAS,CAD2B,EAErC,CACDulF,EAAgB,WACd,OAAOvlF,CACb,CACG,CACD,OAAOulF,CACT,CAKA,IAAIquD,GAAgB,KAOb,SAAS7Q,GAAmB/4F,EAAShjC,GAM1C,IAAK4sI,GAAe,CAClB,MAAMt0E,EAAO,IAAI6wE,GAAK,CACpB77G,MAAO,0BAEHirC,EAAS,IAAI+yE,GAAO,CACxBh+G,MAAO,UACPx6B,MAAO,OAET85I,GAAgB,CACd,IAAIT,GAAM,CACRh2I,MAAO,IAAI8yI,GAAY,CACrB3wE,KAAMA,EACNC,OAAQA,EACRltD,OAAQ,IAEVitD,KAAMA,EACNC,OAAQA,IAGb,CACD,OAAOq0E,EACT,CAMO,SAASC,KAEd,MAAM7zI,EAAS,CAAA,EACT0pB,EAAQ,CAAC,IAAK,IAAK,IAAK,GACxB4B,EAAO,CAAC,EAAG,IAAK,IAAK,GAmD3B,OAjDAtrB,EAAgB,QAAI,CAClB,IAAImzI,GAAM,CACR7zE,KAAM,IAAI6wE,GAAK,CACb77G,MAAO,CAAC,IAAK,IAAK,IAAK,SAI7Bt0B,EAAqB,aAAIA,EAAgB,QAEzCA,EAAmB,WAAI,CACrB,IAAImzI,GAAM,CACR5zE,OAAQ,IAAI+yE,GAAO,CACjBh+G,MAAO5K,EACP5vB,MAAOA,MAGX,IAAIq5I,GAAM,CACR5zE,OAAQ,IAAI+yE,GAAO,CACjBh+G,MAAOhJ,EACPxxB,MApBQ,OAwBdkG,EAAwB,gBAAIA,EAAmB,WAE/CA,EAAe,OAAIA,EAAgB,QAAEohF,OAAOphF,EAAmB,YAE/DA,EAAc,MAAI,CAChB,IAAImzI,GAAM,CACRh2I,MAAO,IAAI8yI,GAAY,CACrB59H,OAAQvY,EACRwlE,KAAM,IAAI6wE,GAAK,CACb77G,MAAOhJ,IAETi0C,OAAQ,IAAI+yE,GAAO,CACjBh+G,MAAO5K,EACP5vB,MAAOA,QAGXu9B,OAAQvyB,OAGZ9E,EAAmB,WAAIA,EAAc,MAErCA,EAA2B,mBAAIA,EAAgB,QAAEohF,OAC/CphF,EAAmB,WACnBA,EAAc,OAGTA,CACT,CAOA,SAASqzI,GAAwBrpG,GAC/B,OAAOA,EAAQzqC,aACjB,CAEA,IAAAu0I,GAAeX,GCjff,MAAMY,GAIJ,WAAA5pJ,CAAY6K,GACVA,EAAUA,GAAW,GAMrB3K,KAAK2pJ,MAAQh/I,EAAQ84C,KAMrBzjD,KAAK8yD,UAAYnoD,EAAQiS,SAMzB5c,KAAK+iJ,gBAAkBp4I,EAAQuwI,eAM/Bl7I,KAAKgjJ,OAASr4I,EAAQgN,MAMtB3X,KAAKijJ,YAAcjkF,QAAyBx4D,IAAlBmE,EAAQgN,MAAsBhN,EAAQgN,MAAQ,GAMxE3X,KAAKqzE,MAAQ1oE,EAAQi4C,KAMrB5iD,KAAK4pJ,WAAaj/I,EAAQosE,UAM1B/2E,KAAK6pJ,SAAWl/I,EAAQm/I,QAMxB9pJ,KAAK+pJ,QAAUp/I,EAAQq/I,OAMvBhqJ,KAAKiqJ,cAAgBt/I,EAAQqsE,aAM7Bh3E,KAAK+jJ,WACcv9I,IAAjBmE,EAAQsqE,KACJtqE,EAAQsqE,KACR,IAAI6wE,GAAK,CAAC77G,MAzHO,SA+HvBjqC,KAAKkqJ,eACkB1jJ,IAArBmE,EAAQw/I,SAAyBx/I,EAAQw/I,SAAWl+I,KAAK+T,GAAK,EAMhEhgB,KAAKoqJ,gBACmB5jJ,IAAtBmE,EAAQ0/I,UAA0B1/I,EAAQ0/I,UAAY,QAMxDrqJ,KAAKsqJ,YAAc3/I,EAAQi2D,SAM3B5gE,KAAKokJ,aAA6B59I,IAAnBmE,EAAQuqE,OAAuBvqE,EAAQuqE,OAAS,KAM/Dl1E,KAAKuqJ,cAA+B/jJ,IAApBmE,EAAQ8qC,QAAwB9qC,EAAQ8qC,QAAU,EAMlEz1C,KAAKwqJ,cAA+BhkJ,IAApBmE,EAAQ+qC,QAAwB/qC,EAAQ+qC,QAAU,EAMlE11C,KAAKyqJ,gBAAkB9/I,EAAQ+/I,eAC3B//I,EAAQ+/I,eACR,KAMJ1qJ,KAAK2qJ,kBAAoBhgJ,EAAQigJ,iBAC7BjgJ,EAAQigJ,iBACR,KAMJ5qJ,KAAK40C,cAA+BpuC,IAApBmE,EAAQkqC,QAAwB,KAAOlqC,EAAQkqC,OAChE,CAOD,KAAA9/B,GACE,MAAM4C,EAAQ3X,KAAK60G,WACnB,OAAO,IAAI60C,GAAK,CACdjmG,KAAMzjD,KAAKm5E,UACXkxE,UAAWrqJ,KAAK6qJ,eAChBb,OAAQhqJ,KAAK8qJ,YACbX,SAAUnqJ,KAAK+qJ,cACfnqF,SAAU5gE,KAAKgrJ,cACfpuI,SAAU5c,KAAK81C,cACfolG,eAAgBl7I,KAAKq4E,oBACrB1gE,MAAOtV,MAAMC,QAAQqV,GAASA,EAAM7T,QAAU6T,EAC9CirC,KAAM5iD,KAAKq1E,UACX0B,UAAW/2E,KAAK65E,eAChBiwE,QAAS9pJ,KAAKirJ,aACdj0E,aAAch3E,KAAK+5E,kBACnB9E,KAAMj1E,KAAKm1E,UAAYn1E,KAAKm1E,UAAUpgE,aAAUvO,EAChD0uE,OAAQl1E,KAAKo1E,YAAcp1E,KAAKo1E,YAAYrgE,aAAUvO,EACtDivC,QAASz1C,KAAKq5E,aACd3jC,QAAS11C,KAAKu5E,aACdmxE,eAAgB1qJ,KAAKkrJ,oBACjBlrJ,KAAKkrJ,oBAAoBn2I,aACzBvO,EACJokJ,iBAAkB5qJ,KAAKmrJ,sBACnBnrJ,KAAKmrJ,sBAAsBp2I,aAC3BvO,EACJquC,QAAS70C,KAAKorJ,mBAAgB5kJ,GAEjC,CAOD,WAAAwkJ,GACE,OAAOhrJ,KAAKsqJ,SACb,CAOD,OAAAnxE,GACE,OAAOn5E,KAAK2pJ,KACb,CAOD,WAAAoB,GACE,OAAO/qJ,KAAKkqJ,SACb,CAOD,YAAAW,GACE,OAAO7qJ,KAAKoqJ,UACb,CAOD,SAAAU,GACE,OAAO9qJ,KAAK+pJ,OACb,CAOD,UAAA1wE,GACE,OAAOr5E,KAAKuqJ,QACb,CAOD,UAAAhxE,GACE,OAAOv5E,KAAKwqJ,QACb,CAOD,OAAAr1E,GACE,OAAOn1E,KAAK+jJ,KACb,CAOD,iBAAA1rE,GACE,OAAOr4E,KAAK+iJ,eACb,CAOD,WAAAjtG,GACE,OAAO91C,KAAK8yD,SACb,CAOD,QAAA+hD,GACE,OAAO70G,KAAKgjJ,MACb,CAMD,aAAAzqE,GACE,OAAOv4E,KAAKijJ,WACb,CAOD,SAAA7tE,GACE,OAAOp1E,KAAKokJ,OACb,CAOD,OAAA/uE,GACE,OAAOr1E,KAAKqzE,KACb,CAOD,YAAAwG,GACE,OAAO75E,KAAK4pJ,UACb,CAOD,UAAAqB,GACE,OAAOjrJ,KAAK6pJ,QACb,CAOD,eAAA9vE,GACE,OAAO/5E,KAAKiqJ,aACb,CAOD,iBAAAiB,GACE,OAAOlrJ,KAAKyqJ,eACb,CAOD,mBAAAU,GACE,OAAOnrJ,KAAK2qJ,iBACb,CAOD,UAAAS,GACE,OAAOprJ,KAAK40C,QACb,CAQD,WAAAy2G,CAAYzqF,GACV5gE,KAAKsqJ,UAAY1pF,CAClB,CAQD,OAAA0qF,CAAQ7nG,GACNzjD,KAAK2pJ,MAAQlmG,CACd,CAQD,WAAA8nG,CAAYpB,GACVnqJ,KAAKkqJ,UAAYC,CAClB,CAQD,UAAAqB,CAAW/1G,GACTz1C,KAAKuqJ,SAAW90G,CACjB,CAQD,UAAAg2G,CAAW/1G,GACT11C,KAAKwqJ,SAAW90G,CACjB,CAQD,YAAAg2G,CAAarB,GACXrqJ,KAAKoqJ,WAAaC,CACnB,CAOD,SAAAsB,CAAU3B,GACRhqJ,KAAK+pJ,QAAUC,CAChB,CAQD,iBAAAvG,CAAkBvI,GAChBl7I,KAAK+iJ,gBAAkB7H,CACxB,CAQD,OAAAqJ,CAAQtvE,GACNj1E,KAAK+jJ,MAAQ9uE,CACd,CAQD,WAAA//B,CAAYt4B,GACV5c,KAAK8yD,UAAYl2C,CAClB,CAQD,QAAA8mI,CAAS/rI,GACP3X,KAAKgjJ,OAASrrI,EACd3X,KAAKijJ,YAAcjkF,QAAiBx4D,IAAVmR,EAAsBA,EAAQ,EACzD,CAQD,SAAAgtI,CAAUzvE,GACRl1E,KAAKokJ,QAAUlvE,CAChB,CAQD,OAAAm0E,CAAQzmG,GACN5iD,KAAKqzE,MAAQzwB,CACd,CAQD,YAAAgpG,CAAa70E,GACX/2E,KAAK4pJ,WAAa7yE,CACnB,CAQD,UAAA80E,CAAW/B,GACT9pJ,KAAK6pJ,SAAWC,CACjB,CAQD,eAAAgC,CAAgB90E,GACdh3E,KAAKiqJ,cAAgBjzE,CACtB,CAQD,iBAAA+0E,CAAkB92E,GAChBj1E,KAAKyqJ,gBAAkBx1E,CACxB,CAQD,mBAAA+2E,CAAoB92E,GAClBl1E,KAAK2qJ,kBAAoBz1E,CAC1B,CAQD,UAAA+2E,CAAWp3G,GACT70C,KAAK40C,SAAWC,CACjB,EAGH,IAAAq3G,GAAexC,GClWf,IAAAyC,GAnPA,MAKE,WAAArsJ,CAAYq3B,GAKVn3B,KAAKosJ,OAMLpsJ,KAAKqsJ,MAMLrsJ,KAAKssJ,MAMLtsJ,KAAKusJ,eAAyB/lJ,IAAb2wB,GAAgCA,EAMjDn3B,KAAKwsJ,QAAU,CAChB,CAOD,UAAAC,CAAWtqJ,GAET,MAAMmJ,EAAO,CACXK,UAAMnF,EACN26H,UAAM36H,EACNrE,KAAMA,GAGFotE,EAAOvvE,KAAKssJ,MAGlB,GAAK/8E,EAOE,CAEL,MAAM4xD,EAAO5xD,EAAK4xD,KAClB71H,EAAKK,KAAO4jE,EACZjkE,EAAK61H,KAAOA,EACZ5xD,EAAK4xD,KAAO71H,EACR61H,IACFA,EAAKx1H,KAAOL,GAGVikE,IAASvvE,KAAKqsJ,QAChBrsJ,KAAKqsJ,MAAQ/gJ,EAEhB,MAnBCtL,KAAKosJ,OAAS9gJ,EACdtL,KAAKqsJ,MAAQ/gJ,EACTtL,KAAKusJ,YACPjhJ,EAAK61H,KAAO71H,EACZA,EAAKK,KAAOL,GAgBhBtL,KAAKssJ,MAAQhhJ,EACbtL,KAAKwsJ,SACN,CAMD,UAAAE,GACE,MAAMn9E,EAAOvvE,KAAKssJ,MAClB,GAAI/8E,EAAM,CACR,MAAM4xD,EAAO5xD,EAAK4xD,KACZx1H,EAAO4jE,EAAK5jE,KACdw1H,IACFA,EAAKx1H,KAAOA,GAEVA,IACFA,EAAKw1H,KAAOA,GAEdnhI,KAAKssJ,MAAQnrB,GAAQx1H,EAEjB3L,KAAKosJ,SAAWpsJ,KAAKqsJ,OACvBrsJ,KAAKssJ,WAAQ9lJ,EACbxG,KAAKosJ,YAAS5lJ,EACdxG,KAAKqsJ,WAAQ7lJ,GACJxG,KAAKosJ,SAAW78E,EACzBvvE,KAAKosJ,OAASpsJ,KAAKssJ,MACVtsJ,KAAKqsJ,QAAU98E,IACxBvvE,KAAKqsJ,MAAQ1gJ,EAAO3L,KAAKssJ,MAAM3gJ,KAAO3L,KAAKssJ,OAE7CtsJ,KAAKwsJ,SACN,CACF,CAOD,SAAAG,GAEE,GADA3sJ,KAAKssJ,MAAQtsJ,KAAKosJ,OACdpsJ,KAAKssJ,MACP,OAAOtsJ,KAAKssJ,MAAMnqJ,IAGrB,CAOD,QAAAyqJ,GAEE,GADA5sJ,KAAKssJ,MAAQtsJ,KAAKqsJ,MACdrsJ,KAAKssJ,MACP,OAAOtsJ,KAAKssJ,MAAMnqJ,IAGrB,CAOD,QAAA0qJ,GACE,GAAI7sJ,KAAKssJ,OAAStsJ,KAAKssJ,MAAMnrB,KAE3B,OADAnhI,KAAKssJ,MAAQtsJ,KAAKssJ,MAAMnrB,KACjBnhI,KAAKssJ,MAAMnqJ,IAGrB,CAOD,WAAA2qJ,GACE,GAAI9sJ,KAAKssJ,OAAStsJ,KAAKssJ,MAAMnrB,KAC3B,OAAOnhI,KAAKssJ,MAAMnrB,KAAKh/H,IAG1B,CAOD,QAAA4qJ,GACE,GAAI/sJ,KAAKssJ,OAAStsJ,KAAKssJ,MAAM3gJ,KAE3B,OADA3L,KAAKssJ,MAAQtsJ,KAAKssJ,MAAM3gJ,KACjB3L,KAAKssJ,MAAMnqJ,IAGrB,CAOD,WAAA6qJ,GACE,GAAIhtJ,KAAKssJ,OAAStsJ,KAAKssJ,MAAM3gJ,KAC3B,OAAO3L,KAAKssJ,MAAM3gJ,KAAKxJ,IAG1B,CAOD,WAAA8qJ,GACE,GAAIjtJ,KAAKssJ,MACP,OAAOtsJ,KAAKssJ,MAAMnqJ,IAGrB,CAMD,YAAA+qJ,GACMltJ,KAAKusJ,WAAavsJ,KAAKssJ,QACzBtsJ,KAAKosJ,OAASpsJ,KAAKssJ,MACnBtsJ,KAAKqsJ,MAAQrsJ,KAAKssJ,MAAM3gJ,KAE3B,CAMD,MAAAorF,CAAOqqC,GACL,GAAIA,EAAKkrB,MAAO,CACd,GAAItsJ,KAAKssJ,MAAO,CACd,MAAMtqJ,EAAMhC,KAAKssJ,MAAMnrB,KACvBnhI,KAAKssJ,MAAMnrB,KAAOC,EAAKgrB,OACvBhrB,EAAKgrB,OAAOzgJ,KAAO3L,KAAKssJ,MACxBtqJ,EAAI2J,KAAOy1H,EAAKirB,MAChBjrB,EAAKirB,MAAMlrB,KAAOn/H,EAClBhC,KAAKwsJ,SAAWprB,EAAKorB,OAC7B,MACQxsJ,KAAKssJ,MAAQlrB,EAAKkrB,MAClBtsJ,KAAKosJ,OAAShrB,EAAKgrB,OACnBpsJ,KAAKqsJ,MAAQjrB,EAAKirB,MAClBrsJ,KAAKwsJ,QAAUprB,EAAKorB,QAEtBprB,EAAKkrB,WAAQ9lJ,EACb46H,EAAKgrB,YAAS5lJ,EACd46H,EAAKirB,WAAQ7lJ,EACb46H,EAAKorB,QAAU,CAChB,CACF,CAOD,SAAAvhJ,GACE,OAAOjL,KAAKwsJ,OACb,GCxNI,SAASW,KACd,MAAO,CACL9kB,UAAW,CAAE,EACbvzH,WAAY,CAAE,EACd6H,WAAY0R,IACZ0vE,UAAW,KAEf,CAwCO,SAAS44C,GAAgBrO,EAASvoI,EAAMoQ,GAC7C,MAAMu8H,EAAaxhG,GAAMo9F,EAASn4H,GAClC,IAAK03H,GAAa9nI,EAAM2sI,EAAW3sI,MAAO,CACxC,MAAMimG,EAAWwhC,GAASznI,GACpB+2I,EAAStP,GAASkF,EAAW3sI,MACnC,MAAM,IAAIyI,MACR,qCAAqCw9F,UAAiB8wC,IAEzD,CACD,OAAOsW,GAAkB1gB,EAC3B,CAOA,SAAS0gB,GAAkB1gB,EAAYv8H,GACrC,GAAIu8H,aAAsBzE,GAAmB,CAE3C,GAAIyE,EAAW3sI,OAASonI,IAAyC,iBAArBuF,EAAWroI,MAAoB,CACzE,MAAMgpJ,EAAa5hH,GAAWihG,EAAWroI,OACzC,OAAO,WACL,OAAOgpJ,CACf,CACK,CACD,OAAO,WACL,OAAO3gB,EAAWroI,KACxB,CACG,CACD,MAAM8jI,EAAWuE,EAAWvE,SAC5B,OAAQA,GACN,KAAKM,GAAIt+F,OACT,KAAKs+F,GAAI5/H,OACP,OA2EN,SAAoC6jI,EAAYv8H,GAC9C,MAAMpQ,EAAO2sI,EAAWvE,SAClBhnI,EAASurI,EAAWxjH,KAAK/nB,OAEzB+nB,EAAO,IAAI7mB,MAAMlB,GACvB,IAAK,IAAIS,EAAI,EAAGA,EAAIT,IAAUS,EAC5BsnB,EAAKtnB,GAAKwrJ,GAAkB1gB,EAAWxjH,KAAKtnB,IAE9C,OAAQ7B,GACN,KAAK0oI,GAAIt+F,OACT,KAAKs+F,GAAI5/H,OACP,OAAQsH,IACN,IAAK,IAAIvO,EAAI,EAAGA,EAAIT,IAAUS,EAAG,CAC/B,MAAMyC,EAAQ6kB,EAAKtnB,GAAGuO,GACtB,UAAW9L,IAAUtE,EACnB,OAAOsE,CAEV,CACD,MAAM,IAAImE,MAAM,sCAAsCzI,IAAO,EAGjE,QACE,MAAM,IAAIyI,MAAM,kCAAkCzI,KAGxD,CApGautJ,CAA2B5gB,GAEpC,KAAKjE,GAAIC,IACT,KAAKD,GAAIE,IACP,OAuGN,SAAmC+D,EAAYv8H,GAC7C,MAAMo9I,EAAmD7gB,EAAWxjH,KAAK,GACnExT,EAA8B63I,EAAoB,MACxD,OAAQ7gB,EAAWvE,UACjB,KAAKM,GAAIC,IACP,OAAQv4H,GAAYA,EAAQ2E,WAAWY,GAEzC,KAAK+yH,GAAIE,IACP,OAAQx4H,GAAYA,EAAQk4H,UAAU3yH,GAExC,QACE,MAAM,IAAIlN,MAAM,iCAAiCkkI,EAAWvE,YAGlE,CArHaqlB,CAA0B9gB,GAEnC,KAAKjE,GAAIqC,GACP,OAAQ4B,GAAeA,EAAW3uC,UAEpC,KAAK0qC,GAAIG,OAAQ,CACf,MAAM1/G,EAAOwjH,EAAWxjH,KAAK4hB,KAAK5zB,GAAMk2I,GAAkBl2I,KAC1D,OAAQ/G,GACN,GAAG4mF,UAAU7tE,EAAK4hB,KAAKpL,GAAQA,EAAIvvB,GAASyI,aAC/C,CACD,KAAK6vH,GAAIQ,WACP,OAAQ94H,GAAYA,EAAQwM,WAE9B,KAAK8rH,GAAIK,IACT,KAAKL,GAAIM,IACT,KAAKN,GAAIO,IACP,OA8IN,SAAkC0D,EAAYv8H,GAC5C,MAAMs9I,EAAK/gB,EAAWvE,SAChBhnI,EAASurI,EAAWxjH,KAAK/nB,OAEzB+nB,EAAO,IAAI7mB,MAAMlB,GACvB,IAAK,IAAIS,EAAI,EAAGA,EAAIT,IAAUS,EAC5BsnB,EAAKtnB,GAAKwrJ,GAAkB1gB,EAAWxjH,KAAKtnB,IAE9C,OAAQ6rJ,GACN,KAAKhlB,GAAIK,IACP,OAAQ34H,IACN,IAAK,IAAIvO,EAAI,EAAGA,EAAIT,IAAUS,EAC5B,GAAIsnB,EAAKtnB,GAAGuO,GACV,OAAO,EAGX,OAAO,CAAK,EAGhB,KAAKs4H,GAAIM,IACP,OAAQ54H,IACN,IAAK,IAAIvO,EAAI,EAAGA,EAAIT,IAAUS,EAC5B,IAAKsnB,EAAKtnB,GAAGuO,GACX,OAAO,EAGX,OAAO,CAAI,EAGf,KAAKs4H,GAAIO,IACP,OAAQ74H,IAAa+Y,EAAK,GAAG/Y,GAE/B,QACE,MAAM,IAAI3H,MAAM,gCAAgCilJ,KAGtD,CAlLaC,CAAyBhhB,GAElC,KAAKjE,GAAIU,MACT,KAAKV,GAAIW,SACT,KAAKX,GAAIc,SACT,KAAKd,GAAIe,kBACT,KAAKf,GAAIY,YACT,KAAKZ,GAAIa,qBACP,OAoGN,SAAqCoD,EAAYv8H,GAC/C,MAAMs9I,EAAK/gB,EAAWvE,SAChB5jF,EAAO6oG,GAAkB1gB,EAAWxjH,KAAK,IACzCqM,EAAQ63H,GAAkB1gB,EAAWxjH,KAAK,IAChD,OAAQukI,GACN,KAAKhlB,GAAIU,MACP,OAAQh5H,GAAYo0C,EAAKp0C,KAAaolB,EAAMplB,GAE9C,KAAKs4H,GAAIW,SACP,OAAQj5H,GAAYo0C,EAAKp0C,KAAaolB,EAAMplB,GAE9C,KAAKs4H,GAAIc,SACP,OAAQp5H,GAAYo0C,EAAKp0C,GAAWolB,EAAMplB,GAE5C,KAAKs4H,GAAIe,kBACP,OAAQr5H,GAAYo0C,EAAKp0C,IAAYolB,EAAMplB,GAE7C,KAAKs4H,GAAIY,YACP,OAAQl5H,GAAYo0C,EAAKp0C,GAAWolB,EAAMplB,GAE5C,KAAKs4H,GAAIa,qBACP,OAAQn5H,GAAYo0C,EAAKp0C,IAAYolB,EAAMplB,GAE7C,QACE,MAAM,IAAI3H,MAAM,mCAAmCilJ,KAGzD,CA/HaE,CAA4BjhB,GAErC,KAAKjE,GAAIgB,SACT,KAAKhB,GAAIiB,OACT,KAAKjB,GAAIkB,IACT,KAAKlB,GAAImB,SACT,KAAKnB,GAAIoB,MACT,KAAKpB,GAAIqB,IACT,KAAKrB,GAAIsB,IACT,KAAKtB,GAAIuB,IACT,KAAKvB,GAAIwB,MACT,KAAKxB,GAAIyB,KACT,KAAKzB,GAAI0B,MACT,KAAK1B,GAAI2B,IACT,KAAK3B,GAAI4B,IACT,KAAK5B,GAAI6B,KACT,KAAK7B,GAAI8B,KACP,OAgKN,SAAkCmC,EAAYv8H,GAC5C,MAAMs9I,EAAK/gB,EAAWvE,SAChBhnI,EAASurI,EAAWxjH,KAAK/nB,OAEzB+nB,EAAO,IAAI7mB,MAAMlB,GACvB,IAAK,IAAIS,EAAI,EAAGA,EAAIT,IAAUS,EAC5BsnB,EAAKtnB,GAAKwrJ,GAAkB1gB,EAAWxjH,KAAKtnB,IAE9C,OAAQ6rJ,GACN,KAAKhlB,GAAIgB,SACP,OAAQt5H,IACN,IAAI9L,EAAQ,EACZ,IAAK,IAAIzC,EAAI,EAAGA,EAAIT,IAAUS,EAC5ByC,GAAS6kB,EAAKtnB,GAAGuO,GAEnB,OAAO9L,CAAK,EAGhB,KAAKokI,GAAIiB,OACP,OAAQv5H,GAAY+Y,EAAK,GAAG/Y,GAAW+Y,EAAK,GAAG/Y,GAEjD,KAAKs4H,GAAIkB,IACP,OAAQx5H,IACN,IAAI9L,EAAQ,EACZ,IAAK,IAAIzC,EAAI,EAAGA,EAAIT,IAAUS,EAC5ByC,GAAS6kB,EAAKtnB,GAAGuO,GAEnB,OAAO9L,CAAK,EAGhB,KAAKokI,GAAImB,SACP,OAAQz5H,GAAY+Y,EAAK,GAAG/Y,GAAW+Y,EAAK,GAAG/Y,GAEjD,KAAKs4H,GAAIoB,MACP,OAAQ15H,IACN,MAAM9L,EAAQ6kB,EAAK,GAAG/Y,GAChBsL,EAAMyN,EAAK,GAAG/Y,GACpB,GAAI9L,EAAQoX,EACV,OAAOA,EAET,MAAMC,EAAMwN,EAAK,GAAG/Y,GACpB,OAAI9L,EAAQqX,EACHA,EAEFrX,CAAK,EAGhB,KAAKokI,GAAIqB,IACP,OAAQ35H,GAAY+Y,EAAK,GAAG/Y,GAAW+Y,EAAK,GAAG/Y,GAEjD,KAAKs4H,GAAIsB,IACP,OAAQ55H,GAAYlE,KAAKC,IAAIgd,EAAK,GAAG/Y,GAAU+Y,EAAK,GAAG/Y,IAEzD,KAAKs4H,GAAIuB,IACP,OAAQ75H,GAAYlE,KAAKmP,IAAI8N,EAAK,GAAG/Y,IAEvC,KAAKs4H,GAAIwB,MACP,OAAQ95H,GAAYlE,KAAKuT,MAAM0J,EAAK,GAAG/Y,IAEzC,KAAKs4H,GAAIyB,KACP,OAAQ/5H,GAAYlE,KAAKkZ,KAAK+D,EAAK,GAAG/Y,IAExC,KAAKs4H,GAAI0B,MACP,OAAQh6H,GAAYlE,KAAKiZ,MAAMgE,EAAK,GAAG/Y,IAEzC,KAAKs4H,GAAI2B,IACP,OAAQj6H,GAAYlE,KAAKyL,IAAIwR,EAAK,GAAG/Y,IAEvC,KAAKs4H,GAAI4B,IACP,OAAQl6H,GAAYlE,KAAKwL,IAAIyR,EAAK,GAAG/Y,IAEvC,KAAKs4H,GAAI6B,KACP,OAAe,IAAXnpI,EACMgP,GAAYlE,KAAKoc,MAAMa,EAAK,GAAG/Y,GAAU+Y,EAAK,GAAG/Y,IAEnDA,GAAYlE,KAAKmX,KAAK8F,EAAK,GAAG/Y,IAExC,KAAKs4H,GAAI8B,KACP,OAAQp6H,GAAYlE,KAAKma,KAAK8C,EAAK,GAAG/Y,IAExC,QACE,MAAM,IAAI3H,MAAM,gCAAgCilJ,KAGtD,CApPaG,CAAyBlhB,GAElC,KAAKjE,GAAI+B,MACP,OAwPN,SAAgCkC,EAAYv8H,GAC1C,MAAMhP,EAASurI,EAAWxjH,KAAK/nB,OACzB+nB,EAAO,IAAI7mB,MAAMlB,GACvB,IAAK,IAAIS,EAAI,EAAGA,EAAIT,IAAUS,EAC5BsnB,EAAKtnB,GAAKwrJ,GAAkB1gB,EAAWxjH,KAAKtnB,IAE9C,OAAQuO,IACN,MAAM9L,EAAQ6kB,EAAK,GAAG/Y,GACtB,IAAK,IAAIvO,EAAI,EAAGA,EAAIT,EAAQS,GAAK,EAC/B,GAAIyC,IAAU6kB,EAAKtnB,GAAGuO,GACpB,OAAO+Y,EAAKtnB,EAAI,GAAGuO,GAGvB,OAAO+Y,EAAK/nB,EAAS,GAAGgP,EAAQ,CAEpC,CAvQa09I,CAAuBnhB,GAEhC,KAAKjE,GAAIiC,YACP,OA2QN,SAAsCgC,EAAYv8H,GAChD,MAAMhP,EAASurI,EAAWxjH,KAAK/nB,OACzB+nB,EAAO,IAAI7mB,MAAMlB,GACvB,IAAK,IAAIS,EAAI,EAAGA,EAAIT,IAAUS,EAC5BsnB,EAAKtnB,GAAKwrJ,GAAkB1gB,EAAWxjH,KAAKtnB,IAE9C,OAAQuO,IACN,MAAMu6B,EAAOxhB,EAAK,GAAG/Y,GACf9L,EAAQ6kB,EAAK,GAAG/Y,GAEtB,IAAI29I,EACAC,EACJ,IAAK,IAAInsJ,EAAI,EAAGA,EAAIT,EAAQS,GAAK,EAAG,CAClC,MAAMohB,EAAQkG,EAAKtnB,GAAGuO,GACtB,IAAI8S,EAASiG,EAAKtnB,EAAI,GAAGuO,GACzB,MAAM69I,EAAU3rJ,MAAMC,QAAQ2gB,GAI9B,GAHI+qI,IACF/qI,EAASqoB,GAAUroB,IAEjBD,GAAS3e,EACX,OAAU,IAANzC,EACKqhB,EAEL+qI,EACKC,GACLvjH,EACArmC,EACAypJ,EACAC,EACA/qI,EACAC,GAGGirI,GACLxjH,EACArmC,EACAypJ,EACAC,EACA/qI,EACAC,GAGJ6qI,EAAgB9qI,EAChB+qI,EAAiB9qI,CAClB,CACD,OAAO8qI,CAAc,CAEzB,CA1TaI,CAA6BzhB,GAEtC,QACE,MAAM,IAAIlkI,MAAM,wBAAwB2/H,KAc9C,CAoTA,SAAS+lB,GAAkBxjH,EAAMrmC,EAAO+pJ,EAAQ1W,EAAS2W,EAAQzW,GAC/D,MAAMjqI,EAAQ0gJ,EAASD,EACvB,GAAc,IAAVzgJ,EACF,OAAO+pI,EAET,MAAMnxH,EAAQliB,EAAQ+pJ,EAKtB,OAAO1W,GAHI,IAAThtG,EACInkB,EAAQ5Y,GACP1B,KAAKC,IAAIw+B,EAAMnkB,GAAS,IAAMta,KAAKC,IAAIw+B,EAAM/8B,GAAS,KAClCiqI,EAAUF,EACvC,CAWA,SAASuW,GAAiBvjH,EAAMrmC,EAAO+pJ,EAAQE,EAAOD,EAAQE,GAE5D,GAAc,IADAF,EAASD,EAErB,OAAOE,EAET,MAAME,EAAQjjH,GAAW+iH,GACnBG,EAAQljH,GAAWgjH,GACzB,IAAIG,EAAWD,EAAM,GAAKD,EAAM,GAC5BE,EAAW,IACbA,GAAY,IACHA,GAAY,MACrBA,GAAY,KASd,OAAO/iH,GAAUH,GANJ,CACX0iH,GAAkBxjH,EAAMrmC,EAAO+pJ,EAAQI,EAAM,GAAIH,EAAQI,EAAM,IAC/DP,GAAkBxjH,EAAMrmC,EAAO+pJ,EAAQI,EAAM,GAAIH,EAAQI,EAAM,IAC/DD,EAAM,GAAKN,GAAkBxjH,EAAMrmC,EAAO+pJ,EAAQ,EAAGC,EAAQK,GAC7DR,GAAkBxjH,EAAMrmC,EAAO+pJ,EAAQE,EAAM,GAAID,EAAQE,EAAM,MAGnE,CCheA,SAASv3F,GAAO7mD,GACd,OAAO,CACT,CAUO,SAASw+I,GAAqBC,GACnC,MAAMhY,EAAiBxO,KACjBgP,EAAYyX,GAAaD,EAAOhY,GAChCkY,EDlCC,CACLzmB,UAAW,CAAE,EACbvzH,WAAY,CAAE,EACd6H,WAAY0R,IACZ0vE,UAAW,MC+Bb,OAAO,SAAUp+C,EAAShjC,GAGxB,GAFAmyI,EAAkBh6I,WAAa6qC,EAAQl2C,wBACvCqlJ,EAAkBnyI,WAAaA,EAC3Bi6H,EAAe74C,UAAW,CAC5B,MAAMvwF,EAAKmyC,EAAQtqC,QAEjBy5I,EAAkB/wD,eADTv3F,IAAPgH,EAC4BA,EAEA,IAEjC,CACD,OAAO4pI,EAAU0X,EACrB,CACA,CAUO,SAASC,GAA0BC,GACxC,MAAMpY,EAAiBxO,KACjBjnI,EAAS6tJ,EAAW7tJ,OAKpB8tJ,EAAa,IAAI5sJ,MAAMlB,GAC7B,IAAK,IAAIS,EAAI,EAAGA,EAAIT,IAAUS,EAC5BqtJ,EAAWrtJ,GAAKstJ,GAAWF,EAAWptJ,GAAIg1I,GAE5C,MAAMkY,EDrEC,CACLzmB,UAAW,CAAE,EACbvzH,WAAY,CAAE,EACd6H,WAAY0R,IACZ0vE,UAAW,MCsEPpoF,EAAS,IAAItT,MAAMlB,GAEzB,OAAO,SAAUw+C,EAAShjC,GAGxB,GAFAmyI,EAAkBh6I,WAAa6qC,EAAQl2C,wBACvCqlJ,EAAkBnyI,WAAaA,EAC3Bi6H,EAAe74C,UAAW,CAC5B,MAAMvwF,EAAKmyC,EAAQtqC,QAEjBy5I,EAAkB/wD,eADTv3F,IAAPgH,EAC4BA,EAEA,IAEjC,CACD,IAAI2hJ,EAAe,EACnB,IAAK,IAAIvtJ,EAAI,EAAGA,EAAIT,IAAUS,EAAG,CAC/B,MAAM2O,EAAQ0+I,EAAWrtJ,GAAGktJ,GACxBv+I,IACFoF,EAAOw5I,GAAgB5+I,EACvB4+I,GAAgB,EAEnB,CAED,OADAx5I,EAAOxU,OAASguJ,EACTx5I,CACX,CACA,CAiBO,SAASk5I,GAAaD,EAAOz+I,GAClC,MAAMhP,EAASytJ,EAAMztJ,OAKfiuJ,EAAgB,IAAI/sJ,MAAMlB,GAEhC,IAAK,IAAIS,EAAI,EAAGA,EAAIT,IAAUS,EAAG,CAC/B,MAAMytJ,EAAOT,EAAMhtJ,GACb61C,EACJ,WAAY43G,EACR1Y,GAAgB0Y,EAAK53G,OAAQuvF,GAAa72H,GAC1C6mD,GAKN,IAAIrhD,EACJ,GAAItT,MAAMC,QAAQ+sJ,EAAK9+I,OAAQ,CAC7B,MAAM++I,EAAcD,EAAK9+I,MAAMpP,OAC/BwU,EAAS,IAAItT,MAAMitJ,GACnB,IAAK,IAAIhrI,EAAI,EAAGA,EAAIgrI,IAAehrI,EACjC3O,EAAO2O,GAAK4qI,GAAWG,EAAK9+I,MAAM+T,GAAInU,EAE9C,MACMwF,EAAS,CAACu5I,GAAWG,EAAK9+I,MAAOJ,IAGnCi/I,EAAcxtJ,GAAK,CAAC61C,SAAQ9hC,SAC7B,CAED,OAAO,SAAUxF,GAIf,MAAMwF,EAAS,GAEf,IAAI45I,GAAc,EAClB,IAAK,IAAI3tJ,EAAI,EAAGA,EAAIT,IAAUS,EAAG,CAE/B,IAAK4tJ,EADmBJ,EAAcxtJ,GAAG61C,QACpBtnC,MAGjBy+I,EAAMhtJ,GAAG6tJ,OAAQF,GAArB,CAGAA,GAAc,EACd,IAAK,MAAMG,KAAkBN,EAAcxtJ,GAAG+T,OAAQ,CACpD,MAAMpF,EAAQm/I,EAAev/I,GACxBI,GAGLoF,EAAOhQ,KAAK4K,EACb,CARA,CASF,CAED,OAAOoF,CACX,CACA,CAYO,SAASu5I,GAAWS,EAAWx/I,GACpC,MAAMy/I,EAAeC,GAAUF,EAAW,GAAIx/I,GACxC2/I,EAAiBC,GAAYJ,EAAW,GAAIx/I,GAC5C6/I,EA+MR,SAAmBL,EAAWx/I,GAC5B,MAAMiwI,EAAS,QAMT6P,EAAgBC,GAAgBP,EAAWvP,EAAS,QAASjwI,GACnE,IAAK8/I,EACH,OAAO,KAGT,MAAML,EAAeC,GAAUF,EAAWvP,EAAQjwI,GAE5CggJ,EAAyBN,GAC7BF,EACAvP,EAAS,cACTjwI,GAGI2/I,EAAiBC,GAAYJ,EAAWvP,EAAQjwI,GAEhDigJ,EAA2BL,GAC/BJ,EACAvP,EAAS,cACTjwI,GAGIkgJ,EAAeH,GAAgBP,EAAWvP,EAAS,OAAQjwI,GAE3DmgJ,EAAmBC,GACvBZ,EACAvP,EAAS,YACTjwI,GAGIqgJ,EAAkBD,GACtBZ,EACAvP,EAAS,WACTjwI,GAGIsgJ,EAAkBF,GACtBZ,EACAvP,EAAS,WACTjwI,GAGIugJ,EAAmBC,GACvBhB,EACAvP,EAAS,WACTjwI,GAGIygJ,EAAoBV,GACxBP,EACAvP,EAAS,YACTjwI,GAGI0gJ,EAAiBN,GAAgBZ,EAAWvP,EAAS,SAAUjwI,GAE/D2gJ,EAAgBC,GAAkBpB,EAAWvP,EAAS,QAASjwI,GAE/D6gJ,EAAyBL,GAC7BhB,EACAvP,EAAS,mBACTjwI,GAGI8gJ,EAAmBV,GACvBZ,EACAvP,EAAS,WACTjwI,GAGI+gJ,EAAgBhB,GAAgBP,EAAWvP,EAAS,QAASjwI,GAE7DghJ,EAAkBjB,GACtBP,EACAvP,EAAS,UACTjwI,GAGIihJ,EAAmBlB,GACvBP,EACAvP,EAAS,WACTjwI,GAGIkhJ,EAAkBC,GACtB3B,EACAvP,EAAS,UACTjwI,GAGIyyC,EAAO,IAAI8mG,GAAK,CAAA,GACtB,OAAO,SAAUv5I,GAuCf,GAtCAyyC,EAAKymG,QAAQ4G,EAAc9/I,IAEvBy/I,GACFhtG,EAAK2hG,QAAQqL,EAAaz/I,IAGxBggJ,GACFvtG,EAAKmpG,kBAAkBoE,EAAuBhgJ,IAG5C2/I,GACFltG,EAAK+hG,UAAUmL,EAAe3/I,IAG5BigJ,GACFxtG,EAAKopG,oBAAoBoE,EAAyBjgJ,IAGhDkgJ,GACFztG,EAAK0oG,QAAQ+E,EAAalgJ,IAGxBmgJ,GACF1tG,EAAK2oG,YAAY+E,EAAiBngJ,IAGhCqgJ,GACF5tG,EAAK4oG,WAAWgF,EAAgBrgJ,IAG9BsgJ,GACF7tG,EAAK6oG,WAAWgF,EAAgBtgJ,IAG9BugJ,GACF9tG,EAAKyoG,YAAYqF,EAAiBvgJ,IAGhCygJ,EAAmB,CACrB,MAAMvG,EAAYuG,EAAkBzgJ,GACpC,GAAkB,UAAdk6I,GAAuC,SAAdA,EAC3B,MAAM,IAAI7hJ,MAAM,6CAElBo6C,EAAK8oG,aAAarB,EACnB,CAkBD,GAhBIwG,GACFjuG,EAAK+oG,UAAUkF,EAAe1gJ,IAG5B2gJ,GACFluG,EAAK8gG,SAASoN,EAAc3gJ,IAG1B6gJ,GACFpuG,EAAK6gG,kBAAkBuN,EAAuB7gJ,IAG5C8gJ,GACFruG,EAAK1N,YAAY+7G,EAAiB9gJ,IAGhC+gJ,EAAe,CACjB,MAAMn6E,EAAYm6E,EAAc/gJ,GAChC,GACgB,SAAd4mE,GACc,WAAdA,GACc,UAAdA,GACc,QAAdA,GACc,UAAdA,EAEA,MAAM,IAAIvuE,MACR,8DAGJo6C,EAAKgpG,aAAa70E,EACnB,CAED,GAAIo6E,EAAiB,CACnB,MAAMrH,EAAUqH,EAAgBhhJ,GAChC,GAAgB,SAAZ25I,GAAkC,UAAZA,GAAmC,WAAZA,EAC/C,MAAM,IAAIthJ,MAAM,oDAElBo6C,EAAKipG,WAAW/B,EACjB,CAED,GAAIsH,EAAkB,CACpB,MAAMp6E,EAAeo6E,EAAiBjhJ,GACtC,GACmB,WAAjB6mE,GACiB,QAAjBA,GACiB,WAAjBA,GACiB,eAAjBA,GACiB,YAAjBA,EAEA,MAAM,IAAIxuE,MACR,0EAGJo6C,EAAKkpG,gBAAgB90E,EACtB,CAMD,OAJIq6E,GACFzuG,EAAKqpG,WAAWoF,EAAgBlhJ,IAG3ByyC,CACX,CACA,CA7ZuB2uG,CAAU5B,EAAWx/I,GACpCqhJ,EAuaR,SAAoB7B,EAAWx/I,GAC7B,GAAI,aAAcw/I,EAChB,OAmBJ,SAAmBA,EAAWx/I,GAC5B,MAAMiwI,EAAS,QAGTqR,EAAUrR,EAAS,MACnBvlH,EAAM62H,GAAc/B,EAAU8B,GAAUA,GAGxCE,EAAiBC,GACrBjC,EACAvP,EAAS,SACTjwI,GAGI2gJ,EAAgBC,GAAkBpB,EAAWvP,EAAS,QAASjwI,GAE/D0hJ,EAAkBtB,GACtBZ,EACAvP,EAAS,UACTjwI,GAGI2hJ,EAAuBF,GAC3BjC,EACAvP,EAAS,eACTjwI,GAGI8gJ,EAAmBV,GACvBZ,EACAvP,EAAS,WACTjwI,GAGI6gJ,EAAyBL,GAC7BhB,EACAvP,EAAS,mBACTjwI,GAIIg3I,EAAe4K,GAAmBpC,EAAWvP,EAAS,iBACtDiH,EAAe2K,GACnBrC,EACAvP,EAAS,kBAELmH,EAAeyK,GACnBrC,EACAvP,EAAS,kBAELn2G,EAwcR,SAA2B0lH,EAAW9qJ,GACpC,MAAMyjI,EAAUqnB,EAAU9qJ,GAC1B,QAAgB2B,IAAZ8hI,EACF,OAEF,OAAO2pB,GAAiB3pB,EAASzjI,EACnC,CA9cgBqtJ,CAAkBvC,EAAWvP,EAAS,SAC9C/jH,EAgXR,SAAwBszH,EAAW9qJ,GACjC,MAAMyjI,EAAUqnB,EAAU9qJ,GAC1B,QAAgB2B,IAAZ8hI,EACF,OAEF,GAAuB,iBAAZA,EACT,MAAM,IAAI9/H,MAAM,yBAAyB3D,KAE3C,OAAOyjI,CACT,CAzXsB6pB,CAAexC,EAAWvP,EAAS,gBACjDrlI,EAsaR,SAA6B40I,EAAW9qJ,GACtC,MAAMyjI,EAAUqnB,EAAU9qJ,GAC1B,QAAgB2B,IAAZ8hI,EACF,OAEF,OAAO8pB,GAAmB9pB,EAASzjI,EACrC,CA5aiBwtJ,CAAoB1C,EAAWvP,EAAS,UACjDwH,EAAemK,GAAmBpC,EAAWvP,EAAS,iBACtD3wI,EAAQ6iJ,GAAe3C,EAAWvP,EAAS,SAC3C1wI,EAAS4iJ,GAAe3C,EAAWvP,EAAS,UAC5C1sI,EAiVR,SAAsBi8I,EAAW9qJ,GAC/B,MAAMyjI,EAAUqnB,EAAU9qJ,GAC1B,QAAgB2B,IAAZ8hI,EACF,OAEF,GAAuB,iBAAZA,EACT,OAAOtpE,GAAOspE,GAEhB,IAAKjmI,MAAMC,QAAQgmI,GACjB,MAAM,IAAI9/H,MAAM,uCAAuC3D,KAEzD,GACqB,IAAnByjI,EAAQnnI,QACc,iBAAfmnI,EAAQ,IACO,iBAAfA,EAAQ,GAEf,MAAM,IAAI9/H,MAAM,uCAAuC3D,KAEzD,OAAOyjI,CACT,CApWeiqB,CAAa5C,EAAWvP,EAAS,QACxC7lE,EAAgBi4E,GAAsB7C,EAAWvP,EAAS,aAE1DqS,EAAO,IAAIzL,GAAK,CACpBnsH,MACAssH,eACAE,eACAE,eACAt9G,QACA5N,cACAthB,SACA6sI,eACAl4I,SACAD,QACAiE,OACA6mE,kBAGF,OAAO,SAAUpqE,GAwBf,OAvBI0hJ,GACFY,EAAK5jH,WAAWgjH,EAAgB1hJ,IAG9B2hJ,GACFW,EAAKjP,gBAAgBsO,EAAqB3hJ,IAGxC8gJ,GACFwB,EAAKv9G,YAAY+7G,EAAiB9gJ,IAGhC6gJ,GACFyB,EAAKhP,kBAAkBuN,EAAuB7gJ,IAG5C2gJ,GACF2B,EAAK/O,SAASoN,EAAc3gJ,IAG1BwhJ,GACFc,EAAK3K,UAAU6J,EAAexhJ,IAEzBsiJ,CACX,CACA,CAvHWC,CAAU/C,EAAWx/I,GAG9B,GAAI,iBAAkBw/I,EACpB,OA0HJ,SAAoBA,EAAWx/I,GAC7B,MAAMiwI,EAAS,SAGTuS,EAAavS,EAAS,SACtBrmD,EAAS64D,GAAcjD,EAAUgD,GAAaA,GAG9C/C,EAAeC,GAAUF,EAAWvP,EAAQjwI,GAC5C2/I,EAAiBC,GAAYJ,EAAWvP,EAAQjwI,GAChD2gJ,EAAgBC,GAAkBpB,EAAWvP,EAAS,QAASjwI,GAC/D2hJ,EAAuBF,GAC3BjC,EACAvP,EAAS,eACTjwI,GAEI8gJ,EAAmBV,GACvBZ,EACAvP,EAAS,WACTjwI,GAEI6gJ,EAAyBL,GAC7BhB,EACAvP,EAAS,mBACTjwI,GAII6X,EAASsqI,GAAe3C,EAAWvP,EAAS,UAC5C6D,EAAUqO,GAAe3C,EAAWvP,EAAS,WAC7C+D,EAAUmO,GAAe3C,EAAWvP,EAAS,WAC7C5oI,EAAQ86I,GAAe3C,EAAWvP,EAAS,SAC3C7lE,EAAgBi4E,GACpB7C,EACAvP,EAAS,kBAGLyS,EAAQ,IAAIjP,GAAa,CAC7B7pD,SACA/xE,SACAi8H,UACAE,UACA3sI,QACA+iE,kBAGF,OAAO,SAAUpqE,GAoBf,OAnBIy/I,GACFiD,EAAMtO,QAAQqL,EAAaz/I,IAEzB2/I,GACF+C,EAAMlO,UAAUmL,EAAe3/I,IAE7B2hJ,GACFe,EAAMrP,gBAAgBsO,EAAqB3hJ,IAEzC8gJ,GACF4B,EAAM39G,YAAY+7G,EAAiB9gJ,IAEjC6gJ,GACF6B,EAAMpP,kBAAkBuN,EAAuB7gJ,IAE7C2gJ,GACF+B,EAAMnP,SAASoN,EAAc3gJ,IAGxB0iJ,CACX,CACA,CA9LWC,CAAWnD,EAAWx/I,GAG/B,GAAI,kBAAmBw/I,EACrB,OAiMJ,SAAqBA,EAAWx/I,GAC9B,MAAMiwI,EAAS,UAGTwP,EAAeC,GAAUF,EAAWvP,EAAQjwI,GAC5C2/I,EAAiBC,GAAYJ,EAAWvP,EAAQjwI,GAChD4iJ,EAAiBxC,GAAgBZ,EAAWvP,EAAS,SAAUjwI,GAC/D2gJ,EAAgBC,GAAkBpB,EAAWvP,EAAS,QAASjwI,GAC/D2hJ,EAAuBF,GAC3BjC,EACAvP,EAAS,eACTjwI,GAEI8gJ,EAAmBV,GACvBZ,EACAvP,EAAS,WACTjwI,GAEI6gJ,EAAyBL,GAC7BhB,EACAvP,EAAS,mBACTjwI,GAIIoqE,EAAgBi4E,GACpB7C,EACAvP,EAAS,kBAGLl6H,EAAS,IAAIo1D,GAAO,CACxBtzD,OAAQ,EACRuyD,kBAGF,OAAO,SAAUpqE,GAuBf,OAtBI4iJ,GACF7sI,EAAOixE,UAAU47D,EAAe5iJ,IAE9By/I,GACF1pI,EAAOq+H,QAAQqL,EAAaz/I,IAE1B2/I,GACF5pI,EAAOy+H,UAAUmL,EAAe3/I,IAE9B2hJ,GACF5rI,EAAOs9H,gBAAgBsO,EAAqB3hJ,IAE1C8gJ,GACF/qI,EAAOgvB,YAAY+7G,EAAiB9gJ,IAElC6gJ,GACF9qI,EAAOu9H,kBAAkBuN,EAAuB7gJ,IAE9C2gJ,GACF5qI,EAAOw9H,SAASoN,EAAc3gJ,IAGzB+V,CACX,CACA,CA7PW8sI,CAAYrD,EAAWx/I,GAGhC,OAAO,IACT,CArbwB8iJ,CAAWtD,EAAWx/I,GACtC+iJ,EAAiB3C,GAAgBZ,EAAW,UAAWx/I,GAE7D,KACGy/I,GACAE,GACAE,GACAwB,GACA1sJ,EAAQ6qJ,IAIT,MAAM,IAAInnJ,MACR,mEACE6lE,KAAKmjB,UAAUm+D,IAIrB,MAAMp/I,EAAQ,IAAIu4I,GAClB,OAAO,SAAU34I,GACf,IAAI0rG,GAAQ,EACZ,GAAI+zC,EAAc,CAChB,MAAM36E,EAAO26E,EAAaz/I,GACtB8kE,IACF4mC,GAAQ,GAEVtrG,EAAMg0I,QAAQtvE,EACf,CACD,GAAI66E,EAAgB,CAClB,MAAM56E,EAAS46E,EAAe3/I,GAC1B+kE,IACF2mC,GAAQ,GAEVtrG,EAAMo0I,UAAUzvE,EACjB,CACD,GAAI86E,EAAc,CAChB,MAAMptG,EAAOotG,EAAa7/I,GACtByyC,IACFi5D,GAAQ,GAEVtrG,EAAM84I,QAAQzmG,EACf,CACD,GAAI4uG,EAAe,CACjB,MAAM1+I,EAAQ0+I,EAAcrhJ,GACxB2C,IACF+oG,GAAQ,GAEVtrG,EAAMurB,SAAShpB,EAChB,CAID,OAHIogJ,GACF3iJ,EAAMw+B,UAAUmkH,EAAe/iJ,IAE7B0rG,EACK,KAEFtrG,CACX,CACA,CAYA,SAASs/I,GAAUF,EAAWvP,EAAQjwI,GACpC,MAAMgjJ,EAAgBC,GACpBzD,EACAvP,EAAS,aACTjwI,GAEF,IAAKgjJ,EACH,OAAO,KAGT,MAAMl+E,EAAO,IAAI6wE,GACjB,OAAO,SAAU31I,GACf,MAAM85B,EAAQkpH,EAAchjJ,GAC5B,MAAc,SAAV85B,EACK,MAETgrC,EAAK+wE,SAAS/7G,GACPgrC,EACX,CACA,CAYA,SAAS86E,GAAYJ,EAAWvP,EAAQjwI,GACtC,MAAMkjJ,EAAgB9C,GACpBZ,EACAvP,EAAS,eACTjwI,GAGIgjJ,EAAgBC,GACpBzD,EACAvP,EAAS,eACTjwI,GAGF,IAAKkjJ,IAAkBF,EACrB,OAAO,KAGT,MAAMG,EAAkBpD,GACtBP,EACAvP,EAAS,kBACTjwI,GAGIojJ,EAAmBrD,GACvBP,EACAvP,EAAS,mBACTjwI,GAGIqjJ,EAAmBlC,GACvB3B,EACAvP,EAAS,mBACTjwI,GAGIsjJ,EAAyBlD,GAC7BZ,EACAvP,EAAS,0BACTjwI,GAGIujJ,EAAqBnD,GACzBZ,EACAvP,EAAS,qBACTjwI,GAGI+kE,EAAS,IAAI+yE,GACnB,OAAO,SAAU93I,GACf,GAAIgjJ,EAAe,CACjB,MAAMlpH,EAAQkpH,EAAchjJ,GAC5B,GAAc,SAAV85B,EACF,OAAO,KAETirC,EAAO8wE,SAAS/7G,EACjB,CAMD,GAJIopH,GACFn+E,EAAO0zE,SAASyK,EAAcljJ,IAG5BmjJ,EAAiB,CACnB,MAAM/8E,EAAU+8E,EAAgBnjJ,GAChC,GAAgB,SAAZomE,GAAkC,UAAZA,GAAmC,WAAZA,EAC/C,MAAM,IAAI/tE,MAAM,4CAElB0sE,EAAOszE,WAAWjyE,EACnB,CAED,GAAIg9E,EAAkB,CACpB,MAAM58E,EAAW48E,EAAiBpjJ,GAClC,GACe,UAAbwmE,GACa,UAAbA,GACa,UAAbA,EAEA,MAAM,IAAInuE,MAAM,6CAElB0sE,EAAOwzE,YAAY/xE,EACpB,CAcD,OAZI68E,GACFt+E,EAAOuB,YAAY+8E,EAAiBrjJ,IAGlCsjJ,GACFv+E,EAAOuzE,kBAAkBgL,EAAuBtjJ,IAG9CujJ,GACFx+E,EAAOyzE,cAAc+K,EAAmBvjJ,IAGnC+kE,CACX,CACA,CAmfA,SAASq7E,GAAgBZ,EAAWj6I,EAAMvF,GACxC,KAAMuF,KAAQi6I,GACZ,OAEF,MAAMvY,EAAYT,GAAgBgZ,EAAUj6I,GAAOuxH,GAAY92H,GAC/D,OAAO,SAAUA,GACf,OAAOyiJ,GAAcxb,EAAUjnI,GAAUuF,EAC7C,CACA,CAQA,SAASw6I,GAAgBP,EAAWj6I,EAAMvF,GACxC,KAAMuF,KAAQi6I,GACZ,OAAO,KAET,MAAMvY,EAAYT,GAAgBgZ,EAAUj6I,GAAOwxH,GAAY/2H,GAC/D,OAAO,SAAUA,GACf,OAAOuhJ,GAActa,EAAUjnI,GAAUuF,EAC7C,CACA,CAQA,SAASi7I,GAAiBhB,EAAWj6I,EAAMvF,GACzC,KAAMuF,KAAQi6I,GACZ,OAAO,KAET,MAAMvY,EAAYT,GAAgBgZ,EAAUj6I,GAAOsxH,GAAa72H,GAChE,OAAO,SAAUA,GACf,MAAM9L,EAAQ+yI,EAAUjnI,GACxB,GAAqB,kBAAV9L,EACT,MAAM,IAAImE,MAAM,0BAA0BkN,KAE5C,OAAOrR,CACX,CACA,CAQA,SAAS+uJ,GAAmBzD,EAAWj6I,EAAMvF,GAC3C,KAAMuF,KAAQi6I,GACZ,OAAO,KAET,MAAMvY,EAAYT,GAChBgZ,EAAUj6I,GACVyxH,GAAYD,GACZ/2H,GAEF,OAAO,SAAUA,GACf,OAAO8hJ,GAAiB7a,EAAUjnI,GAAUuF,EAChD,CACA,CAQA,SAAS47I,GAAqB3B,EAAWj6I,EAAMvF,GAC7C,KAAMuF,KAAQi6I,GACZ,OAAO,KAET,MAAMvY,EAAYT,GAAgBgZ,EAAUj6I,GAAO0xH,GAAiBj3H,GACpE,OAAO,SAAUA,GACf,OAAOiiJ,GAAmBhb,EAAUjnI,GAAUuF,EAClD,CACA,CAQA,SAASk8I,GAAoBjC,EAAWj6I,EAAMvF,GAC5C,KAAMuF,KAAQi6I,GACZ,OAAO,KAET,MAAMvY,EAAYT,GAAgBgZ,EAAUj6I,GAAO0xH,GAAiBj3H,GACpE,OAAO,SAAUA,GACf,MAAMzF,EAAQ0nJ,GAAmBhb,EAAUjnI,GAAUuF,GACrD,GAAqB,IAAjBhL,EAAMvJ,OACR,MAAM,IAAIqH,MAAM,4BAA4BkN,KAE9C,OAAOhL,CACX,CACA,CAQA,SAASqmJ,GAAkBpB,EAAWj6I,EAAMvF,GAC1C,KAAMuF,KAAQi6I,GACZ,OAAO,KAET,MAAMvY,EAAYT,GAChBgZ,EAAUj6I,GACV0xH,GAAkBH,GAClB92H,GAEF,OAAO,SAAUA,GACf,OAkNJ,SAAyB9L,EAAOQ,GAC9B,GAAqB,iBAAVR,EACT,OAAOA,EAET,MAAMqP,EAAO0+I,GAAmB/tJ,EAAOQ,GACvC,GAAoB,IAAhB6O,EAAKvS,OACP,MAAM,IAAIqH,MAAM,wCAAwC3D,KAE1D,OAAO6O,CACT,CA3NWigJ,CAAgBvc,EAAUjnI,GAAUuF,EAC/C,CACA,CAOA,SAAS48I,GAAe3C,EAAW9qJ,GACjC,MAAMR,EAAQsrJ,EAAU9qJ,GACxB,QAAc2B,IAAVnC,EAAJ,CAGA,GAAqB,iBAAVA,EACT,MAAM,IAAImE,MAAM,yBAAyB3D,KAE3C,OAAOR,CAJN,CAKH,CAiDA,SAAS0tJ,GAAmBpC,EAAW9qJ,GACrC,MAAMyjI,EAAUqnB,EAAU9qJ,GAC1B,QAAgB2B,IAAZ8hI,EAAJ,CAGA,GACc,gBAAZA,GACY,iBAAZA,GACY,aAAZA,GACY,cAAZA,EAEA,MAAM,IAAI9/H,MACR,kEAAkE3D,KAGtE,OAAOyjI,CAXN,CAYH,CAOA,SAAS0pB,GAAwBrC,EAAW9qJ,GAC1C,MAAMyjI,EAAUqnB,EAAU9qJ,GAC1B,QAAgB2B,IAAZ8hI,EAAJ,CAGA,GAAgB,WAAZA,GAAoC,aAAZA,EAC1B,MAAM,IAAI9/H,MAAM,mCAAmC3D,KAErD,OAAOyjI,CAJN,CAKH,CAoBA,SAASkqB,GAAsB7C,EAAW9qJ,GACxC,MAAMyjI,EAAUqnB,EAAU9qJ,GAC1B,QAAgB2B,IAAZ8hI,EAAJ,CAGA,GAAuB,iBAAZA,EACT,MAAM,IAAI9/H,MAAM,yBAAyB3D,KAE3C,GAAgB,cAAZyjI,GAAuC,aAAZA,GAAsC,SAAZA,EACvD,MAAM,IAAI9/H,MAAM,6CAA6C3D,KAE/D,OAAOyjI,CAPN,CAQH,CAoBA,SAAS8pB,GAAmB/tJ,EAAOQ,GACjC,IAAKxC,MAAMC,QAAQ+B,GACjB,MAAM,IAAImE,MAAM,yBAAyB3D,KAE3C,MAAM1D,EAASkD,EAAMlD,OACrB,IAAK,IAAIS,EAAI,EAAGA,EAAIT,IAAUS,EAC5B,GAAwB,iBAAbyC,EAAMzC,GACf,MAAM,IAAI4G,MAAM,oCAAoC3D,KAGxD,OAAOR,CACT,CAOA,SAASqtJ,GAAcrtJ,EAAOQ,GAC5B,GAAqB,iBAAVR,EACT,MAAM,IAAImE,MAAM,yBAAyB3D,KAE3C,OAAOR,CACT,CAOA,SAASuuJ,GAAcvuJ,EAAOQ,GAC5B,GAAqB,iBAAVR,EACT,MAAM,IAAImE,MAAM,yBAAyB3D,KAE3C,OAAOR,CACT,CAOA,SAAS4tJ,GAAiB5tJ,EAAOQ,GAC/B,GAAqB,iBAAVR,EACT,OAAOA,EAET,MAAMqG,EAAQ0nJ,GAAmB/tJ,EAAOQ,GAClC1D,EAASuJ,EAAMvJ,OACrB,GAAIA,EAAS,GAAKA,EAAS,EACzB,MAAM,IAAIqH,MAAM,2CAA2C3D,KAE7D,OAAO6F,CACT,CCppCA,MAAML,GACU,cA6QhB,IAAAupJ,GA9PA,cAA8B10F,GAI5B,WAAAp/D,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B,MAAM4xC,EAAc71C,OAAO8C,OAAO,CAAE,EAAEmB,UAE/B4xC,EAAYhsC,aACZgsC,EAAYs3G,oBACZt3G,EAAYu3G,4BACZv3G,EAAYw3G,uBACnB9uJ,MAAMs3C,GAMNv8C,KAAKg0J,gBACmBxtJ,IAAtBmE,EAAQspJ,WAA0BtpJ,EAAQspJ,UAM5Cj0J,KAAKk0J,mBACsB1tJ,IAAzBmE,EAAQkpJ,aAA6BlpJ,EAAQkpJ,aAAe,IAO9D7zJ,KAAKwU,OAAS,KAOdxU,KAAKyU,oBAAiBjO,EAEtBxG,KAAKoV,SAASzK,EAAQ4F,OAMtBvQ,KAAKm0J,2BAC8B3tJ,IAAjCmE,EAAQmpJ,sBACJnpJ,EAAQmpJ,qBAOd9zJ,KAAKo0J,6BACgC5tJ,IAAnCmE,EAAQopJ,wBACJppJ,EAAQopJ,sBAEf,CAKD,YAAAM,GACE,OAAOr0J,KAAKg0J,UACb,CAgBD,WAAA32G,CAAYC,GACV,OAAOr4C,MAAMo4C,YAAYC,EAC1B,CAKD,eAAAg3G,GACE,OAAOt0J,KAAKk0J,aACb,CAMD,cAAAK,GACE,OACEv0J,KAAKoJ,IAAIiB,GAEZ,CAQD,QAAA8K,GACE,OAAOnV,KAAKwU,MACb,CAOD,gBAAAc,GACE,OAAOtV,KAAKyU,cACb,CAMD,uBAAA+/I,GACE,OAAOx0J,KAAKm0J,qBACb,CAMD,yBAAAM,GACE,OAAOz0J,KAAKo0J,uBACb,CAMD,eAAAptG,CAAgBvJ,GACTA,EAAWyoB,gBACdzoB,EAAWyoB,cAAgB,IAAIs2B,GAAM,IAErBx8F,KAAKo+C,cAAe4I,gBAAgBvJ,EACvD,CAMD,cAAAi3G,CAAeC,GACb30J,KAAK+J,IAAIM,GAAuBsqJ,EACjC,CAuBD,QAAAv/I,CAAS7E,GACPvQ,KAAKwU,OAcT,SAAqBjE,GACnB,QAAc/J,IAAV+J,EACF,OAAOmoI,GAET,IAAKnoI,EACH,OAAO,KAET,GAAqB,mBAAVA,EACT,OAAOA,EAET,GAAIA,aAAiBu4I,GACnB,OAAOv4I,EAET,IAAKlO,MAAMC,QAAQiO,GACjB,OAAOw+I,GAA0B,CAACx+I,IAEpC,GAAqB,IAAjBA,EAAMpP,OACR,MAAO,GAGT,MAAMA,EAASoP,EAAMpP,OACf8wB,EAAQ1hB,EAAM,GAEpB,GAAI0hB,aAAiB62H,GAAO,CAI1B,MAAMnzI,EAAS,IAAItT,MAAMlB,GACzB,IAAK,IAAIS,EAAI,EAAGA,EAAIT,IAAUS,EAAG,CAC/B,MAAMC,EAAY0O,EAAM3O,GACxB,KAAMC,aAAqBinJ,IACzB,MAAM,IAAItgJ,MAAM,sCAElBmN,EAAO/T,GAAKC,CACb,CACD,OAAO8T,CACR,CAED,GAAI,UAAWsc,EAAO,CAIpB,MAAM28H,EAAQ,IAAIvsJ,MAAMlB,GACxB,IAAK,IAAIS,EAAI,EAAGA,EAAIT,IAAUS,EAAG,CAC/B,MAAMC,EAAY0O,EAAM3O,GACxB,KAAM,UAAWC,GACf,MAAM,IAAI2G,MAAM,kDAElBomJ,EAAMhtJ,GAAKC,CACZ,CACD,OAAO8sJ,GAAqBC,EAC7B,CAED,MAAMI,EACwD,EAC9D,OAAOD,GAA0BC,EACnC,CAtEkB4F,CAAYrkJ,GAC1BvQ,KAAKyU,eACO,OAAVlE,OAAiB/J,EAAYquJ,GAAgB70J,KAAKwU,QACpDxU,KAAK6H,SACN,GC5QI,MAAMitJ,GACe,2BADfA,GAEa,yBAFbA,GAGmB,+BCTjB,SAASh/I,KACd,MAAM5L,EAAS,+vUACf,OAAO,IAAIk6G,OAAuB,oBAATC,KACrB,sCAAwCC,OAAO5yD,KAAKxnD,EAAQ,UAAU0O,SAAS,UAC/Em3D,IAAIw0C,gBAAgB,IAAIF,KAAK,CAACn6G,GAAS,CAACnK,KAAM,4BAC5D,CCEO,SAASg1J,GAAmBt3G,EAAY7P,GAC7C,MAAMzuB,EAAas+B,EAAWjE,UAAUr6B,WAGlC0yB,EADejE,EAAMsP,YACKgD,YAAc/gC,EAAWG,WACnDF,EAAmBD,EAAWE,YAE9B7F,EAASikC,EAAWjkC,OACpB+F,EAAasyB,EAAaz1B,GAASgD,GAAoB,KACvD41I,EAAWnjH,EACb5lC,KAAKkZ,MAAM3L,EAAO,GAAK4F,EAAiB,IAAMG,GAAc,EAC5D,EAMJ,MAAO,CAJYsyB,EACf5lC,KAAKuT,OAAOhG,EAAO,GAAK4F,EAAiB,IAAMG,GAC/C,EAEgBy1I,EAAUz1I,EAChC,CCunBA,IAAA01I,GAthBA,cAAuCzlB,GAKrC,WAAA1vI,CAAY8tC,EAAOjjC,GACjB,MAAM0qH,EAAW1qH,EAAQ0qH,UAAY,GAC/B6/B,ElO9FD,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GkO+FrB7/B,EAAS+D,GAAeC,mBAAqB67B,EAE7CjwJ,MAAM2oC,EAAO,CACXynF,SAAUA,EACVsG,cAAehxH,EAAQgxH,gBAGzB37H,KAAKm1J,iBAAmB,EAExBn1J,KAAKo1J,gBAAkB,IAAIlnB,GAAiBrgB,GAAcG,IAC1DhuH,KAAKq1J,eAAiB,IAAInnB,GACxBpgB,GACAE,IAMFhuH,KAAK80I,cAAgBnqI,EAAQopH,aAK7B/zH,KAAK+0I,gBAAkBpqI,EAAQypH,eAM/Bp0H,KAAK60I,SAML70I,KAAKs1J,qBAAuB3qJ,EAAQ4qJ,sBAAuB,EAE3D,MAAMC,EAAmB7qJ,EAAQwjH,WAC7BxjH,EAAQwjH,WAAWrjF,KAAI,SAAUkxG,GAC/B,MAAO,CACLtmI,KAAM,UAAYsmI,EAAUtmI,KAC5BhC,KAAM,EACN3T,KAAM65H,GAAc3L,MAEhC,IACQ,GAOJjuH,KAAKmuH,WAAa,CAChB,CACEz4G,KAAM,aACNhC,KAAM,EACN3T,KAAM65H,GAAc3L,OAEtB,CACEv4G,KAAM,UACNhC,KAAM,EACN3T,KAAM65H,GAAc3L,QAIpBjuH,KAAKs1J,uBACPt1J,KAAKmuH,WAAWxoH,KAAK,CACnB+P,KAAM,aACNhC,KAAM,EACN3T,KAAM65H,GAAc3L,QAEtBjuH,KAAKmuH,WAAWxoH,KAAK,CACnB+P,KAAM,eACNhC,KAAM,EACN3T,KAAM65H,GAAc3L,SAGxBjuH,KAAKmuH,WAAWxoH,QAAQ6vJ,GAExBx1J,KAAKw1J,iBAAmB7qJ,EAAQwjH,WAAaxjH,EAAQwjH,WAAa,GAElEnuH,KAAKugE,gBhOhBA,CAAC9lD,IAAUA,KAAU,KAAW,KgOyBrCza,KAAKy1J,kBAAoBP,EAOzBl1J,KAAK01J,iBlOhMA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GkOsMrB11J,KAAK21J,uBlOtMA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GkO4MrB31J,KAAK41J,oBAAsB,IAAIljJ,aAAa,GAM5C1S,KAAK61J,iBAOL71J,KAAK81J,WAAa,EAKlB91J,KAAK+1J,QAAUC,KAEfh2J,KAAK+1J,QAAQzwJ,iBACX,WAICO,IACC,MAAMowJ,EAAWpwJ,EAAM1D,KACvB,GAAI8zJ,EAASl2J,OAAS+0J,GAA+C,CACnE,MAAMxX,EAAsB2Y,EAAS3Y,oBACrCt9I,KAAKo1J,gBAAgBriC,gBAAgBkjC,EAASC,cAC9Cl2J,KAAKoyH,OAAOgK,gBAAgBp8H,KAAKo1J,iBACjCp1J,KAAKq1J,eAAetiC,gBAAgBkjC,EAASE,aAC7Cn2J,KAAKoyH,OAAOgK,gBAAgBp8H,KAAKq1J,gBAEjCr1J,KAAK01J,iBAAmBpY,EACxB8Y,GACEp2J,KAAK21J,uBACL31J,KAAK01J,kBAEP11J,KAAK41J,oBAAsB,IAAIljJ,aAC7B7M,EAAM1D,KAAKk0J,oBAETJ,EAASzoJ,KAAOxN,KAAK81J,aACvB91J,KAAKmkE,OAAQ,GAEfnkE,KAAK28G,WAAW90G,SACjB,KASL7H,KAAKs2J,cAAgB,GAOrBt2J,KAAKu2J,cAAgB,EAErB,MAAMrsJ,EAASlK,KAAK28G,WAAWz/D,YAC/Bl9C,KAAKw2J,kBAAoB,CACvBzvJ,EACEmD,EACA4xF,GACA97F,KAAKy2J,0BACLz2J,MAEF+G,EACEmD,EACA4xF,GACA97F,KAAK02J,4BACL12J,MAEF+G,EACEmD,EACA4xF,GACA97F,KAAK22J,2BACL32J,MAEF+G,EACEmD,EACA4xF,GACA97F,KAAK42J,0BACL52J,OAGJkK,EAAOi0F,gBAAgBx+C,IACrB3/C,KAAKs2J,cAAc5tJ,EAAOi3C,IAAY,CACpCA,QAASA,EACT7qC,WAAY6qC,EAAQp2C,gBACpBqL,SAAU+qC,EAAQzqC,eAEpBlV,KAAKu2J,eAAe,GAEvB,CAED,kBAAAtmB,GACEjwI,KAAK60I,SAAW70I,KAAKoyH,OAAOmM,WAC1Bv+H,KAAK+0I,gBACL/0I,KAAK80I,eAGH90I,KAAKs1J,uBACPt1J,KAAK61J,iBAAmB,IAAIgB,GAAkB72J,KAAKoyH,QAEtD,CAMD,yBAAAqkC,CAA0B5wJ,GACxB,MAAM85C,EAAU95C,EAAM85C,QACtB3/C,KAAKs2J,cAAc5tJ,EAAOi3C,IAAY,CACpCA,QAASA,EACT7qC,WAAY6qC,EAAQp2C,gBACpBqL,SAAU+qC,EAAQzqC,eAEpBlV,KAAKu2J,eACN,CAMD,2BAAAG,CAA4B7wJ,GAC1B,MAAM85C,EAAU95C,EAAM85C,QACtB3/C,KAAKs2J,cAAc5tJ,EAAOi3C,IAAY,CACpCA,QAASA,EACT7qC,WAAY6qC,EAAQp2C,gBACpBqL,SAAU+qC,EAAQzqC,cAErB,CAMD,0BAAAyhJ,CAA2B9wJ,GACzB,MAAM85C,EAAU95C,EAAM85C,eACf3/C,KAAKs2J,cAAc5tJ,EAAOi3C,IACjC3/C,KAAKu2J,eACN,CAKD,yBAAAK,GACE52J,KAAKs2J,cAAgB,GACrBt2J,KAAKu2J,cAAgB,CACtB,CAOD,WAAAj4G,CAAYb,GACV,MAAM41E,EAAKrzH,KAAKoyH,OAAOmD,QACvBv1H,KAAKm+G,UAAUkV,EAAI51E,GACnB,MAAOq5G,EAAY9B,EAAUz1I,GAAcw1I,GACzCt3G,EACAz9C,KAAK28G,YAIP38G,KAAK+2J,aAAat5G,GAAY,EAAOq5G,EAAY9B,EAAUz1I,GAC3Dvf,KAAKoyH,OAAOyL,aACVpgF,EACAz9C,KAAK4vI,wBACL5vI,KAAK6vI,0BAGH7vI,KAAKs1J,uBAEPt1J,KAAK+2J,aAAat5G,GAAY,EAAMq5G,EAAY9B,EAAUz1I,GAC1Dvf,KAAK61J,iBAAiBv1B,mBAGxBtgI,KAAKo+G,WAAWiV,EAAI51E,GAGpB,OADez9C,KAAKoyH,OAAOyK,WAE5B,CAOD,oBAAAqT,CAAqBzyF,GACnB,MAAM7P,EAAQ5tC,KAAK28G,WACbq6C,EAAeppH,EAAMsP,YACrB1D,EAAYiE,EAAWjE,UACvBy9G,GACHx5G,EAAWqnB,UAAU71B,MACrBwO,EAAWqnB,UAAU71B,IAClBmxE,GAAiB79G,GAAOvC,KAAKugE,gBAAiB9iB,EAAWjkC,QACzD09I,EAAgBl3J,KAAKm1J,gBAAkB6B,EAAajvJ,cAM1D,GAJImvJ,IACFl3J,KAAKm1J,gBAAkB6B,EAAajvJ,eAGlCkvJ,IAAkB72C,GAAiB82C,GAAgB,CACrD,MAAM/3I,EAAaq6B,EAAUr6B,WACvBxC,EAAa68B,EAAU78B,WAEvBk3I,EACJjmH,aAAiBupH,GAAavpH,EAAM0mH,kBAAoB,EACpD96I,EAASG,GAAO8jC,EAAWjkC,OAAQq6I,EAAel3I,GACxDq6I,EAAa13D,aAAa9lF,EAAQmD,EAAYwC,GAE9Cnf,KAAKo3J,gBAAgB35G,GACrBz9C,KAAKugE,gBAAkB9iB,EAAWjkC,OAAO1V,OAC1C,CAUD,OARA9D,KAAKoyH,OAAOgG,WAAWp4H,KAAK60I,SAAUp3F,GACtCz9C,KAAKoyH,OAAOsK,YAAYj/E,GAGxBz9C,KAAKoyH,OAAOwC,WAAW50H,KAAKo1J,iBAC5Bp1J,KAAKoyH,OAAOwC,WAAW50H,KAAKq1J,gBAC5Br1J,KAAKoyH,OAAOsN,iBAAiB1/H,KAAKmuH,aAE3B,CACR,CAOD,eAAAipC,CAAgB35G,GAEd,MAAM6/F,ElO5bD,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GkO6brBt9I,KAAKoyH,OAAO+M,wBAAwB1hF,EAAY6/F,GAEhD,MAAMvxH,EAAiBE,KAGjBorI,GADwBr3J,KAAKs1J,qBAAuB,EAAI,GAEpCt1J,KAAKw1J,iBAAiBr0J,OAC1Cm2J,EAAYD,EAA0Br3J,KAAKu2J,cASjD,IAAIgB,EAAc3iJ,EAPf5U,KAAK41J,qBACN51J,KAAK41J,oBAAoBz0J,SAAWm2J,IAEpCt3J,KAAK41J,oBAAsB,IAAIljJ,aAAa4kJ,IAK9C,MAAME,EAAY,GACZC,EAAW,GACjB,IAAIC,GAAO,EACX,IAAK,MAAMvZ,KAAcn+I,KAAKs2J,cAK5B,GAJAiB,EAAev3J,KAAKs2J,cAAcnY,GAClCvpI,EACE2iJ,EACR,SACW3iJ,GAAmC,UAAvBA,EAAS8Z,UAA1B,CAGA,GAAI3C,EAAgB,CAClB,MAAM4rI,EAAaxrI,GACjBvX,EAAS2a,qBACTkuB,EAAWjE,UAAUr6B,YAEvBq4I,EAAU,GAAKG,EAAW,GAC1BH,EAAU,GAAKG,EAAW,EAClC,MACQH,EAAU,GAAK5iJ,EAAS2a,qBAAqB,GAC7CioI,EAAU,GAAK5iJ,EAAS2a,qBAAqB,GAS/C,GAPA5Q,GAAe2+H,EAAqBka,GAEpCx3J,KAAK41J,sBAAsB8B,GAAOF,EAAU,GAC5Cx3J,KAAK41J,sBAAsB8B,GAAOF,EAAU,GAIxCx3J,KAAKs1J,qBAAsB,CAC7B,MAAMsC,EAAWnxB,GAAcixB,EAAM,EAAGD,GACxCz3J,KAAK41J,sBAAsB8B,GAAOE,EAAS,GAC3C53J,KAAK41J,sBAAsB8B,GAAOE,EAAS,GAC3C53J,KAAK41J,sBAAsB8B,GAAOE,EAAS,GAC3C53J,KAAK41J,sBAAsB8B,GAAOE,EAAS,GAC3C53J,KAAK41J,sBAAsB8B,GAAOvtH,OAAOg0G,EAC1C,CAGD,IAAK,IAAI75H,EAAI,EAAGA,EAAItkB,KAAKw1J,iBAAiBr0J,OAAQmjB,IAAK,CACrD,MAAMjgB,EAAQrE,KAAKw1J,iBAAiBlxI,GAAG1I,SACrC27I,EAAa53G,QACb43G,EAAaziJ,YAEf9U,KAAK41J,sBAAsB8B,GAAOrzJ,CACnC,CAnCA,CAuCH,MAAM0zB,EAAU,CACdvqB,KAAMxN,KAAK81J,WACX/1J,KAAM+0J,GACNuB,mBAAoBr2J,KAAK41J,oBAAoBj8I,OAC7Ck+I,qBAAsBR,EAA0B,GAGlDt/H,EAA6B,oBAAIulH,EACjCt9I,KAAKmkE,OAAQ,EACbnkE,KAAK+1J,QAAQhxC,YAAYhtF,EAAS,CAAC/3B,KAAK41J,oBAAoBj8I,SAC5D3Z,KAAK41J,oBAAsB,IAC5B,CAWD,0BAAAt2G,CACEloC,EACAqmC,EACA8B,EACA3jC,EACAokC,GAMA,GAJA/rC,GACEjU,KAAKs1J,qBACL,4JAEGt1J,KAAK41J,sBAAwB51J,KAAKs1J,qBACrC,OAGF,MAAMh4G,EAAQ3+B,GACZ8+B,EAAW2B,2BACXhoC,EAAWtT,SAGP3B,EAAOnC,KAAK61J,iBAAiBp1B,UAAUnjF,EAAM,GAAK,EAAGA,EAAM,GAAK,GAEhEr6C,EAAQ2jI,GADA,CAACzkI,EAAK,GAAK,IAAKA,EAAK,GAAK,IAAKA,EAAK,GAAK,IAAKA,EAAK,GAAK,MAEhE2qC,EAAU9sC,KAAK41J,oBAAoB3yJ,GACnCkpF,EAAMlgF,KAAKuT,MAAMstB,GAASl0B,WAG1B+mC,EADS3/C,KAAK28G,WAAWz/D,YACR8hD,gBAAgB7S,GACvC,OAAIxsC,EACK/jC,EAAS+jC,EAAS3/C,KAAK28G,WAAY,WAD5C,CAID,CAUD,YAAAo6C,CAAat5G,EAAYq6G,EAAiBhB,EAAY9B,EAAUz1I,GAC9D,IAAIw4I,EAAQjB,EAEZ92J,KAAKoyH,OAAOgG,WAAWp4H,KAAK60I,SAAUp3F,GAElCq6G,IACF93J,KAAK61J,iBAAiBvpH,QAAQ,CAC5BrgC,KAAKuT,MAAMi+B,EAAW/pC,KAAK,GAAK,GAChCzH,KAAKuT,MAAMi+B,EAAW/pC,KAAK,GAAK,KAElC1T,KAAKoyH,OAAOgL,0BACV3/E,EACAz9C,KAAK61J,kBACL,IAIJ71J,KAAKoyH,OAAOwC,WAAW50H,KAAKo1J,iBAC5Bp1J,KAAKoyH,OAAOwC,WAAW50H,KAAKq1J,gBAC5Br1J,KAAKoyH,OAAOsN,iBAAiB1/H,KAAKmuH,YAElC,EAAG,CACDnuH,KAAKoyH,OAAO+M,wBAAwB1hF,EAAYz9C,KAAKy1J,mBACrD9hB,GAAmB3zI,KAAKy1J,kBAAmBsC,EAAQx4I,EAAY,GAC/Di9D,GAAkBx8E,KAAKy1J,kBAAmBz1J,KAAK21J,wBAC/C31J,KAAKoyH,OAAOsG,cAAcj7E,GAC1Bz9C,KAAKoyH,OAAO6L,yBAAyB65B,GACrC,MAAME,EAAch4J,KAAKq1J,eAAe1hJ,UACxC3T,KAAKoyH,OAAOqL,aAAa,EAAGu6B,EAClC,SAAeD,EAAQ/C,EACpB,CAKD,eAAAv0J,GACET,KAAK+1J,QAAQ/wC,YACbhlH,KAAKu8G,OAAS,KACdv8G,KAAKw2J,kBAAkBrrJ,SAAQ,SAAU5D,GACvCD,EAAcC,EACpB,IACIvH,KAAKw2J,kBAAoB,KACzBvxJ,MAAMxE,iBACP,GCjoBH,SAASw3J,GACP5B,EACAb,EACA0C,EACAC,GAEA,IAAIroJ,EAAQ,EACZ,IAAK,MAAMvI,KAAOiuJ,EAAkB,CAClC,MAAMr7B,EAAOq7B,EAAiBjuJ,GACxBlD,EAAQ81H,EAAKv+G,SAAS7X,KAAKm0J,EAAYA,EAAWv4G,SACxD02G,EAAmB8B,EAAeroJ,KAAWzL,EAAM,IAAMA,EACpD81H,EAAKzmH,MAAsB,IAAdymH,EAAKzmH,OAGvB2iJ,EAAmB8B,EAAeroJ,KAAWzL,EAAM,GAC/C81H,EAAKzmH,KAAO,IAGhB2iJ,EAAmB8B,EAAeroJ,KAAWzL,EAAM,GAC/C81H,EAAKzmH,KAAO,IAGhB2iJ,EAAmB8B,EAAeroJ,KAAWzL,EAAM,KACpD,CACD,OAAOyL,CACT,CAMO,SAASsoJ,GAAwB5C,GACtC,OAAO9uJ,OAAOC,KAAK6uJ,GAAkB9wG,QACnC,CAAC/4C,EAAMg5C,IAASh5C,GAAQ6pJ,EAAiB7wG,GAAMjxC,MAAQ,IACvD,EAEJ,CAWO,SAAS2kJ,GACdC,EACAjC,EACAb,EACAx/I,GAKA,MAAMuiJ,GACH,EAAIH,GAAwB5C,IAAqB8C,EAAMrb,gBAEvDoZ,GACDA,EAAmBl1J,SAAWo3J,IAE9BlC,EAAqB,IAAI3jJ,aAAa6lJ,IAIxC,MAAMf,EAAY,GAClB,IAAIgB,EAAc,EAClB,IAAK,MAAMra,KAAcma,EAAMtb,QAAS,CACtC,MAAMkb,EAAaI,EAAMtb,QAAQmB,GACjC,IAAK,IAAIv8I,EAAI,EAAGuE,EAAK+xJ,EAAWza,YAAYt8I,OAAQS,EAAIuE,EAAIvE,IAC1D41J,EAAU,GAAKU,EAAWza,YAAY77I,GAAG,GACzC41J,EAAU,GAAKU,EAAWza,YAAY77I,GAAG,GACzC+c,GAAe3I,EAAWwhJ,GAE1BnB,EAAmBmC,KAAiBhB,EAAU,GAC9CnB,EAAmBmC,KAAiBhB,EAAU,GAC9CgB,GAAeP,GACb5B,EACAb,EACA0C,EACAM,EAGL,CACD,OAAOnC,CACT,CAWO,SAASoC,GACdH,EACAjC,EACAb,EACAx/I,GAMA,MAAMuiJ,EACJ,EAAID,EAAMpb,eACT,EAAIkb,GAAwB5C,IAAqB8C,EAAMrb,gBAEvDoZ,GACDA,EAAmBl1J,SAAWo3J,IAE9BlC,EAAqB,IAAI3jJ,aAAa6lJ,IAIxC,MAAM/b,EAAa,GACnB,IAAIgc,EAAc,EAClB,IAAK,MAAMra,KAAcma,EAAMtb,QAAS,CACtC,MAAMkb,EAAaI,EAAMtb,QAAQmB,GACjC,IAAK,IAAIv8I,EAAI,EAAGuE,EAAK+xJ,EAAWza,YAAYt8I,OAAQS,EAAIuE,EAAIvE,IAAK,CAC/D46I,EAAWr7I,OAAS+2J,EAAWza,YAAY77I,GAAGT,OAC9CgsB,GACE+qI,EAAWza,YAAY77I,GACvB,EACA46I,EAAWr7I,OACX,EACA6U,EACAwmI,GAEFgc,GAAeP,GACb5B,EACAb,EACA0C,EACAM,GAIFnC,EAAmBmC,KAAiBhc,EAAWr7I,OAAS,EAGxD,IAAK,IAAImjB,EAAI,EAAG2G,EAAKuxH,EAAWr7I,OAAQmjB,EAAI2G,EAAI3G,GAAK,EACnD+xI,EAAmBmC,KAAiBhc,EAAWl4H,GAC/C+xI,EAAmBmC,KAAiBhc,EAAWl4H,EAAI,EAEtD,CACF,CACD,OAAO+xI,CACT,CAWO,SAASqC,GACdJ,EACAjC,EACAb,EACAx/I,GAOA,MAAMuiJ,EACJ,EAAID,EAAMpb,eACT,EAAIkb,GAAwB5C,IAAqB8C,EAAMrb,gBACxDqb,EAAMnb,WAELkZ,GACDA,EAAmBl1J,SAAWo3J,IAE9BlC,EAAqB,IAAI3jJ,aAAa6lJ,IAIxC,MAAM/b,EAAa,GACnB,IAAIgc,EAAc,EAClB,IAAK,MAAMra,KAAcma,EAAMtb,QAAS,CACtC,MAAMkb,EAAaI,EAAMtb,QAAQmB,GACjC,IAAK,IAAIv8I,EAAI,EAAGuE,EAAK+xJ,EAAWza,YAAYt8I,OAAQS,EAAIuE,EAAIvE,IAAK,CAC/D46I,EAAWr7I,OAAS+2J,EAAWza,YAAY77I,GAAGT,OAC9CgsB,GACE+qI,EAAWza,YAAY77I,GACvB,EACA46I,EAAWr7I,OACX,EACA6U,EACAwmI,GAEFgc,GAAeP,GACb5B,EACAb,EACA0C,EACAM,GAIFnC,EAAmBmC,KACjBN,EAAWvZ,oBAAoB/8I,GAAGT,OAGpC,IACE,IAAImjB,EAAI,EAAG2G,EAAKitI,EAAWvZ,oBAAoB/8I,GAAGT,OAClDmjB,EAAI2G,EACJ3G,IAEA+xI,EAAmBmC,KACjBN,EAAWvZ,oBAAoB/8I,GAAG0iB,GAItC,IAAK,IAAIA,EAAI,EAAG2G,EAAKuxH,EAAWr7I,OAAQmjB,EAAI2G,EAAI3G,GAAK,EACnD+xI,EAAmBmC,KAAiBhc,EAAWl4H,GAC/C+xI,EAAmBmC,KAAiBhc,EAAWl4H,EAAI,EAEtD,CACF,CACD,OAAO+xI,CACT,CC3NA,MAAMoB,GAAW,GACXkB,GAAe3C,KACrB,IAAI4C,GAAuB,EAOpB,MAAMpkB,GACD,aADCA,GAEJ,UAFIA,GAGI,iBAHJA,GAIE,eAJFA,GAKC,eALDA,GAME,eANFA,GAOD,aAkcZ,IAAAqkB,GAlYA,MAME,WAAA/4J,CAAYg5J,EAAgB1mC,EAAQ2mC,GAClC/4J,KAAKmyH,QAAUC,EAEfpyH,KAAKs1J,qBAAuByD,EAC5B,IAAIC,EAAuC,EAE3C,KADkB,YAAaF,GACf,CACd,MAAMG,EAAclY,GAC1B,GAIMiY,EAAU,CACR9Y,QAAS+Y,EAAY/Y,QACrB/xB,WAAY8qC,EAAY9qC,WACxBkH,SAAU4jC,EAAY5jC,SAEzB,CAMDr1H,KAAKg6I,WAAagf,EAAQ9Y,QAAQ7D,sBAC9Br8I,KAAKg6I,WACPh6I,KAAKk5J,kBAAoBF,EAAQ9Y,QAAQ7D,sBACzCr8I,KAAKm5J,oBAAsBH,EAAQ9Y,QAAQ5D,wBAC3Ct8I,KAAKo5J,aAAep5J,KAAKmyH,QAAQoM,WAC/Bv+H,KAAKm5J,oBACLn5J,KAAKk5J,oBAQTl5J,KAAKw5I,aAAewf,EAAQ9Y,QAAQ/D,wBAChCn8I,KAAKw5I,aACPx5I,KAAKq5J,oBAAsBL,EAAQ9Y,QAAQ/D,wBAC3Cn8I,KAAKs5J,sBAAwBN,EAAQ9Y,QAAQ9D,0BAC7Cp8I,KAAKu5J,eAAiBv5J,KAAKmyH,QAAQoM,WACjCv+H,KAAKs5J,sBACLt5J,KAAKq5J,sBAQTr5J,KAAKg5I,aAAeggB,EAAQ9Y,QAAQnE,wBAChC/7I,KAAKg5I,aACPh5I,KAAKw5J,oBAAsBR,EAAQ9Y,QAAQnE,wBAC3C/7I,KAAKy5J,sBAAwBT,EAAQ9Y,QAAQhE,0BAC7Cl8I,KAAK05J,eAAiB15J,KAAKmyH,QAAQoM,WACjCv+H,KAAKy5J,sBACLz5J,KAAKw5J,sBAIT,MAAMG,EAAyB35J,KAAKs1J,qBAChC,CACEsC,SAAU,CACR,QAAAh8I,GACE,OAAO6qH,GAAczmI,KAAK++I,IAAK0Y,GAChC,EACD/jJ,KAAM,IAGV,GAEJ1T,KAAK45J,kBAAoBlzJ,OAAO8C,OAC9B,CAAE,EACFmwJ,EACAX,EAAQ7qC,YAEVnuH,KAAKo1H,UAAY4jC,EAAQ3jC,SAEzB,MAAMwkC,EAAuBnzJ,OAAOs2I,QAAQh9I,KAAK45J,mBAAmB9uH,KAClE,EAAEp1B,EAAMrR,MAAY,CAClBqR,KAAM,UAAUA,IAChBhC,KAAMrP,EAAMqP,MAAQ,EACpB3T,KAAM65H,GAAc3L,UAOxBjuH,KAAK85J,uBAAyB,CAC5B,CACEpkJ,KAAM8+H,GACN9gI,KAAM,EACN3T,KAAM65H,GAAc3L,UAEnB4rC,GAML75J,KAAK+5J,0BAA4B,CAC/B,CACErkJ,KAAM8+H,GACN9gI,KAAM,EACN3T,KAAM65H,GAAc3L,OAEtB,CACEv4G,KAAM8+H,GACN9gI,KAAM,EACN3T,KAAM65H,GAAc3L,OAEtB,CACEv4G,KAAM8+H,GACN9gI,KAAM,EACN3T,KAAM65H,GAAc3L,OAEtB,CACEv4G,KAAM8+H,GACN9gI,KAAM,EACN3T,KAAM65H,GAAc3L,OAEtB,CACEv4G,KAAM8+H,GACN9gI,KAAM,EACN3T,KAAM65H,GAAc3L,UAEnB4rC,GAML75J,KAAKg6J,qBAAuB,CAC1B,CACEtkJ,KAAM8+H,GACN9gI,KAAM,EACN3T,KAAM65H,GAAc3L,OAEtB,CACEv4G,KAAM8+H,GACN9gI,KAAM,EACN3T,KAAM65H,GAAc3L,UAEnB4rC,GAGDb,EAAQ3jC,UACVr1H,KAAKmyH,QAAQ2J,YAAYk9B,EAAQ3jC,SAEpC,CAOD,qBAAMsqB,CAAgBsa,EAAejkJ,GACnC,MAAMqgJ,EAAqBr2J,KAAKk6J,4BAC9BD,EACAjkJ,IAEKmkJ,EAAgBC,EAAmBC,SAAsB91J,QAAQ2xD,IACtE,CACEl2D,KAAKs6J,wBACHjE,EAAmBkE,oBACnB,UACAvkJ,GAEFhW,KAAKs6J,wBACHjE,EAAmBmE,uBACnB,aACAxkJ,GAEFhW,KAAKs6J,wBACHjE,EAAmBoE,kBACnB,QACAzkJ,KASN,MAAO,CACLmkJ,eAAgBA,EAChBC,kBAAmBA,EACnBC,aAAcA,EACdK,wBAR8BtE,GpO9P3B,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GoOgQnBpgJ,GAQH,CAQD,2BAAAkkJ,CAA4BD,EAAejkJ,GA0BzC,MAAO,CACLukJ,oBA1B0Bv6J,KAAKg6I,SAC7B0e,GACEuB,EAAcld,aACd,IAAIrqI,aAAa,GACjB1S,KAAK45J,kBACL5jJ,GAEF,KAoBFwkJ,uBAnB6Bx6J,KAAKw5I,WAChCif,GACEwB,EAAc5c,gBACd,IAAI3qI,aAAa,GACjB1S,KAAK45J,kBACL5jJ,GAEF,KAaFykJ,kBAZwBz6J,KAAKg5I,WAC3Bqf,GACE4B,EAAc7c,WACd,IAAI1qI,aAAa,GACjB1S,KAAK45J,kBACL5jJ,GAEF,KAOL,CASD,uBAAAskJ,CAAwBjE,EAAoBz6D,EAAc5lF,GACxD,GAA2B,OAAvBqgJ,EACF,OAAO,KAGT,MAAMsE,EAAY/B,KAClB,IAAIgC,EACJ,OAAQh/D,GACN,IAAK,UACHg/D,EAAc9F,GACd,MACF,IAAK,aACH8F,EAAc9F,GACd,MACF,IAAK,QACH8F,EAAc9F,GAOlB,MAAM/8H,EAAU,CACdvqB,GAAImtJ,EACJ56J,KAAM66J,EACNvE,mBAAoBA,EAAmB18I,OACvCkhJ,4BAA6B7kJ,EAC7B6hJ,qBAAsBO,GAAwBp4J,KAAK45J,oBAOrD,OALAjB,GAAa5zC,YAAYhtF,EAAS,CAACs+H,EAAmB18I,SAGtD08I,EAAqB,KAEd,IAAI9xJ,SAASE,IAIlB,MAAMq2J,EAAiBj1J,IACrB,MAAMowJ,EAAWpwJ,EAAM1D,KAGvB,GAAI8zJ,EAASzoJ,KAAOmtJ,EAClB,OAOF,GAHAhC,GAAaryJ,oBAAoB,UAAWw0J,IAGvC96J,KAAKmyH,QAAQoD,QAChB,OAIF,MAAMwlC,EAAiB,IAAI7sB,GACzBrgB,GACAG,IACA+E,gBAAgBkjC,EAASC,cACrB8E,EAAgB,IAAI9sB,GACxBpgB,GACAE,IACA+E,gBAAgBkjC,EAASE,aAC3Bn2J,KAAKmyH,QAAQiK,gBAAgB2+B,GAC7B/6J,KAAKmyH,QAAQiK,gBAAgB4+B,GAE7Bv2J,EAAQ,CAACu2J,EAAeD,GAAgB,EAG1CpC,GAAarzJ,iBAAiB,UAAWw1J,EAAc,GAE1D,CAQD,MAAAh+G,CAAO0mE,EAAS/lE,EAAYw9G,GAC1Bj7J,KAAKg6I,UACHh6I,KAAKk7J,gBACH13C,EAAQ22C,eAAe,GACvB32C,EAAQ22C,eAAe,GACvBn6J,KAAKo5J,aACLp5J,KAAK85J,uBACLr8G,EACAw9G,GAEJj7J,KAAKw5I,YACHx5I,KAAKk7J,gBACH13C,EAAQ42C,kBAAkB,GAC1B52C,EAAQ42C,kBAAkB,GAC1Bp6J,KAAKu5J,eACLv5J,KAAK+5J,0BACLt8G,EACAw9G,GAEJj7J,KAAKg5I,YACHh5I,KAAKk7J,gBACH13C,EAAQ62C,aAAa,GACrB72C,EAAQ62C,aAAa,GACrBr6J,KAAK05J,eACL15J,KAAKg6J,qBACLv8G,EACAw9G,EAEL,CAWD,eAAAC,CACEF,EACAD,EACA18B,EACAlQ,EACA1wE,EACAw9G,GAEA,MAAMjD,EAAcgD,EAAcrnJ,UACd,IAAhBqkJ,IAGJh4J,KAAKmyH,QAAQiG,WAAWiG,EAAS5gF,GACjCz9C,KAAKmyH,QAAQyC,WAAWmmC,GACxB/6J,KAAKmyH,QAAQyC,WAAWomC,GACxBh7J,KAAKmyH,QAAQuN,iBAAiBvR,GAC9B8sC,IACAj7J,KAAKmyH,QAAQsL,aAAa,EAAGu6B,GAC9B,GCjcI,MAAM5nB,GAAW,IACnBhX,GACHoX,cAAe,iBACfC,eAAgB,kBAChBC,aAAc,iBAidhB,IAAAyqB,GA/aA,cAAuC3rB,GAKrC,WAAA1vI,CAAY8tC,EAAOjjC,GAOjB1F,MAAM2oC,EAAO,CACXynF,SAPe,CACf,CAAC+a,GAASI,eAAgB,CAAC,EAAG,EAAG,EAAG,GACpC,CAACJ,GAASK,gBAAiB,CAAC,EAAG,GAC/B,CAACL,GAASM,cAAe,GAKzB/U,cAAehxH,EAAQgxH,gBAOzB37H,KAAKs1J,sBAAwB3qJ,EAAQywJ,oBAMrCp7J,KAAK61J,iBAEL71J,KAAKm1J,iBAAmB,EAExBn1J,KAAKugE,gBnO4FA,CAAC9lD,IAAUA,KAAU,KAAW,KmOnFrCza,KAAKy1J,kBrO7EA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GqO+ErBz1J,KAAKq7J,WAAa,CAAC,EAAG,GACtBr7J,KAAKs7J,crOhFA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GqOiFrBt7J,KAAKs7H,SpC7GA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,GoCmHnDt7H,KAAKu7J,4BrOvFA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GqO6FrBv7J,KAAKw7J,QAAU,GAMfx7J,KAAKu/I,gBAAkB,GAMvBv/I,KAAKy7J,SAAW,GAEhBz7J,KAAKs0C,cAAc3pC,GAKnB3K,KAAKq/I,OAAS,IAAIC,GAMlBt/I,KAAK07J,uBAAwB,EAM7B17J,KAAKw2J,kBAAoB,IAC1B,CAMD,mBAAAmF,CAAoBl+G,GAClB,MAAMvzC,EAASlK,KAAK28G,WAAWz/D,YACzBnxB,EAAiBE,KACvB,IAAIqxH,EACAvxH,IACFuxH,EAAsBpzH,GACpB6B,EACA0xB,EAAWjE,UAAUr6B,aAGzBnf,KAAKq/I,OAAOtwE,YAAY7kE,EAAOmzC,cAAeigG,GAC9Ct9I,KAAKw2J,kBAAoB,CACvBzvJ,EACEmD,EACA4xF,GACA97F,KAAKy2J,0BAA0BvvJ,KAAKlH,KAAMs9I,GAC1Ct9I,MAEF+G,EACEmD,EACA4xF,GACA97F,KAAK02J,4BACL12J,MAEF+G,EACEmD,EACA4xF,GACA97F,KAAK22J,2BACL32J,MAEF+G,EACEmD,EACA4xF,GACA97F,KAAK42J,0BACL52J,MAGL,CAMD,aAAAs0C,CAAc3pC,GACZ3K,KAAKw7J,QAAUn5J,MAAMC,QAAQqI,EAAQ4F,OACjC5F,EAAQ4F,MACR,CAAC5F,EAAQ4F,MACd,CAKD,gBAAAqrJ,GACE57J,KAAKy7J,SAAW,GAChBz7J,KAAKu/I,gBAAkBv/I,KAAKw7J,QAAQ1wH,KACjCv6B,GACC,IAAIsrJ,GAAoBtrJ,EAAOvQ,KAAKoyH,OAAQpyH,KAAKs1J,uBAEtD,CAED,KAAAv/I,CAAMpL,GACJ3K,KAAKs0C,cAAc3pC,GACf3K,KAAKoyH,QACPpyH,KAAK47J,mBAEP32J,MAAM8Q,MAAMpL,EACb,CAED,kBAAAslI,GACEjwI,KAAK47J,mBACD57J,KAAKs1J,uBACPt1J,KAAK61J,iBAAmB,IAAIgB,GAAkB72J,KAAKoyH,QAEtD,CAOD,yBAAAqkC,CAA0BnZ,EAAqBz3I,GAC7C,MAAM85C,EAAU95C,EAAM85C,QACtB3/C,KAAKq/I,OAAOniD,WAAWv9C,EAAS29F,EACjC,CAMD,2BAAAoZ,CAA4B7wJ,GAC1B,MAAM85C,EAAU95C,EAAM85C,QACtB3/C,KAAKq/I,OAAOJ,cAAct/F,EAC3B,CAMD,0BAAAg3G,CAA2B9wJ,GACzB,MAAM85C,EAAU95C,EAAM85C,QACtB3/C,KAAKq/I,OAAOxhD,cAAcl+C,EAC3B,CAKD,yBAAAi3G,GACE52J,KAAKq/I,OAAO16I,OACb,CAMD,cAAAm3J,CAAeC,GAEbC,GAAiBh8J,KAAKs7J,cAAet7J,KAAKu7J,6BAC1C/+E,GAAkBx8E,KAAKs7J,cAAeS,GACtC/7J,KAAKoyH,OAAOgM,sBACVgS,GAAS/W,kBACTkc,GAAkBv1I,KAAKs7H,SAAUt7H,KAAKs7J,gBAIxClF,GAAqBp2J,KAAKs7J,cAAet7J,KAAKs7J,eAC9Ct7J,KAAKoyH,OAAOgM,sBACVgS,GAAS9W,uBACTic,GAAkBv1I,KAAKs7H,SAAUt7H,KAAKs7J,gBAIxCt7J,KAAKq7J,WAAW,GAAK,EACrBr7J,KAAKq7J,WAAW,GAAK,EACrBjF,GAAqBp2J,KAAKs7J,cAAeS,GACzCp9I,GAAe3e,KAAKs7J,cAAet7J,KAAKq7J,YACxCr7J,KAAKoyH,OAAO4L,oBAAoBoS,GAASK,eAAgBzwI,KAAKq7J,WAC/D,CAOD,WAAA/8G,CAAYb,GACV,MAAM41E,EAAKrzH,KAAKoyH,OAAOmD,QACvBv1H,KAAKm+G,UAAUkV,EAAI51E,GAEnB,MAAOq5G,EAAY9B,EAAUz1I,GAAcw1I,GACzCt3G,EACAz9C,KAAK28G,YAIP38G,KAAKoyH,OAAOsK,YAAYj/E,GACxBz9C,KAAK+2J,aAAat5G,GAAY,EAAOq5G,EAAY9B,EAAUz1I,GAC3Dvf,KAAKoyH,OAAOyL,aAAapgF,GAEzB,MAAM5tC,EAAS7P,KAAKoyH,OAAOyK,YAErB/vF,EADa2Q,EAAWI,iBAAiBJ,EAAWoJ,YAC/B/Z,QAY3B,OAXIA,IAAY/B,WAAWl7B,EAAOU,MAAMu8B,WACtCj9B,EAAOU,MAAMu8B,QAAUjkC,OAAOikC,IAG5B9sC,KAAKs1J,uBACPt1J,KAAK+2J,aAAat5G,GAAY,EAAMq5G,EAAY9B,EAAUz1I,GAC1Dvf,KAAK61J,iBAAiBv1B,mBAGxBtgI,KAAKo+G,WAAWiV,EAAI51E,GAEb5tC,CACR,CAOD,oBAAAqgI,CAAqBzyF,GACdz9C,KAAK07J,wBACR17J,KAAK27J,oBAAoBl+G,GACzBz9C,KAAK07J,uBAAwB,GAG/B,MAAM9tH,EAAQ5tC,KAAK28G,WACbq6C,EAAeppH,EAAMsP,YACrB1D,EAAYiE,EAAWjE,UACvBy9G,GACHx5G,EAAWqnB,UAAU71B,MACrBwO,EAAWqnB,UAAU71B,IAClBmxE,GAAiB79G,GAAOvC,KAAKugE,gBAAiB9iB,EAAWjkC,QACzD09I,EAAgBl3J,KAAKm1J,gBAAkB6B,EAAajvJ,cAM1D,GAJImvJ,IACFl3J,KAAKm1J,gBAAkB6B,EAAajvJ,eAGlCkvJ,IAAkB72C,GAAiB82C,GAAgB,CACrD,MAAM/3I,EAAaq6B,EAAUr6B,WACvBxC,EAAa68B,EAAU78B,WAEvBk3I,EACJjmH,aAAiBupH,GAAavpH,EAAM0mH,kBAAoB,EACpD96I,EAASG,GAAO8jC,EAAWjkC,OAAQq6I,EAAel3I,GAElDoP,EAAiBE,KACnBF,EACFirI,EAAa13D,aACXjzE,GAAa7S,EAAQuS,GACrBQ,GAAiB5P,EAAYwC,GAC7B4M,GAGFirI,EAAa13D,aAAa9lF,EAAQmD,EAAYwC,GAGhDnf,KAAKmkE,OAAQ,EAEb,MAAMnuD,EAAYhW,KAAKoyH,OAAO+M,wBAC5B1hF,ErO/VC,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IqOmWbiiG,EAAmB1/I,KAAKu/I,gBAAgBz0G,KAAI,CAACo5B,EAAUtiE,IAC3DsiE,EAASy7E,gBAAgB3/I,KAAKq/I,OAAQrpI,GAAWjC,MAAMyvG,IACrDxjH,KAAKy7J,SAAS75J,GAAK4hH,CAAO,MAG9Bj/G,QAAQ2xD,IAAIwpF,GAAkB3rI,MAAK,KACjC/T,KAAKmkE,OAAQ,EACbnkE,KAAK28G,WAAW90G,SAAS,IAG3B7H,KAAKugE,gBAAkB9iB,EAAWjkC,OAAO1V,OAC1C,CAED,OAAO,CACR,CAUD,YAAAizJ,CAAat5G,EAAYq6G,EAAiBhB,EAAY9B,EAAUz1I,GAC9D,IAAIw4I,EAAQjB,EAERgB,IACF93J,KAAK61J,iBAAiBvpH,QAAQ,CAC5BrgC,KAAKuT,MAAMi+B,EAAW/pC,KAAK,GAAK,GAChCzH,KAAKuT,MAAMi+B,EAAW/pC,KAAK,GAAK,KAElC1T,KAAKoyH,OAAOgL,0BACV3/E,EACAz9C,KAAK61J,kBACL,IAIJ71J,KAAKu7J,4BAA8Bv7J,KAAKoyH,OAAO+M,wBAC7C1hF,EACAz9C,KAAKu7J,6BAGP,EAAG,CACD,IAAK,IAAI35J,EAAI,EAAGuE,EAAKnG,KAAKu/I,gBAAgBp+I,OAAQS,EAAIuE,EAAIvE,IAAK,CAC7D,MAAMsiE,EAAWlkE,KAAKu/I,gBAAgB39I,GAChC4hH,EAAUxjH,KAAKy7J,SAAS75J,GACzB4hH,GAGLt/C,EAASpnB,OAAO0mE,EAAS/lE,GAAY,KACnCz9C,KAAK87J,eAAet4C,EAAQk3C,yBAC5B16J,KAAKoyH,OAAO6L,yBAAyB65B,EAAgB,GAExD,CACDnkB,GAAmB3zI,KAAKu7J,4BAA6Bh8I,EAAY,EACvE,SAAew4I,EAAQ/C,EACpB,CAWD,0BAAA11G,CACEloC,EACAqmC,EACA8B,EACA3jC,EACAokC,GAMA,GAJA/rC,GACEjU,KAAKs1J,qBACL,4JAEGt1J,KAAKu/I,gBAAgBp+I,SAAWnB,KAAKs1J,qBACxC,OAGF,MAAMh4G,EAAQ3+B,GACZ8+B,EAAW2B,2BACXhoC,EAAWtT,SAGP3B,EAAOnC,KAAK61J,iBAAiBp1B,UAAUnjF,EAAM,GAAK,EAAGA,EAAM,GAAK,GAEhEyhG,EAAMnY,GADE,CAACzkI,EAAK,GAAK,IAAKA,EAAK,GAAK,IAAKA,EAAK,GAAK,IAAKA,EAAK,GAAK,MAEhEw9C,EAAU3/C,KAAKq/I,OAAOH,kBAAkBH,GAC9C,OAAIp/F,EACK/jC,EAAS+jC,EAAS3/C,KAAK28G,WAAY,WAD5C,CAID,CAKD,eAAAl8G,GACMT,KAAKw2J,oBACPx2J,KAAKw2J,kBAAkBrrJ,SAAQ,SAAU5D,GACvCD,EAAcC,EACtB,IACMvH,KAAKw2J,kBAAoB,MAE3BvxJ,MAAMxE,iBACP,GC1dI,MAAM2vI,GAAW,IACnB6D,GACHgoB,kBAAmB,cACnBC,gBAAiB,mBAGN1nB,GAAa,CACxB2nB,SAAU,cAiVZ,IAAAC,GAzTA,cAA2CxnB,GAKzC,WAAA90I,CAAYqgH,EAAWx1G,GACrB1F,MAAMk7G,EAAW,CACf90E,UAAW1gC,EAAQ0gC,UACnBgqF,SAAU,CACR,CAAC+a,GAASK,gBAAiB,CAAC,EAAG,MAQnCzwI,KAAKs1J,sBAAwB3qJ,EAAQywJ,oBAMrCp7J,KAAKw7J,QAAU,GAMfx7J,KAAKu/I,gBAAkB,GASvBv/I,KAAKu7J,4BtO5DA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GsO8DrBv7J,KAAKs7J,ctO9DA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GsO+DrBt7J,KAAKs7H,SrC3FA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,EAAG,GqCiGnDt7H,KAAKq8J,gBAAkB,KAKvBr8J,KAAKs8J,iBAAmB,IAAIpuB,GAC1BpgB,GACAC,IAEF/tH,KAAKs8J,iBAAiBxpC,UAAU,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,IAMhD9yH,KAAKu8J,oBAAsB,CACzB,CACE7mJ,KAAM8+H,GAAW2nB,SACjBzoJ,KAAM,EACN3T,KAAM65H,GAAc3L,QAOxBjuH,KAAKw8J,iBAELx8J,KAAKs0C,cAAc3pC,EACpB,CAKD,KAAAoL,CAAMpL,GACJ1F,MAAM8Q,MAAMpL,GAEZ3K,KAAKs0C,cAAc3pC,GACf3K,KAAKoyH,SACPpyH,KAAK47J,mBACL57J,KAAKy8J,gBAER,CAMD,aAAAnoH,CAAc3pC,GACZ3K,KAAKw7J,QAAUn5J,MAAMC,QAAQqI,EAAQ4F,OACjC5F,EAAQ4F,MACR,CAAC5F,EAAQ4F,MACd,CAKD,gBAAAqrJ,GACE,SAASc,EAAiBxc,GACxB,MAAMyc,EAAmBzc,EAAQlF,+BAC3B4hB,EAAkB,aAAaxsB,GAAS6rB,mFAAmF7rB,GAAS8rB,wBAC1Ihc,EAAQnF,6BACe,UAArB4hB,EACI,IAAIA,UAAyBC,KAC7BA,GAEN1c,EAAQ9F,WAAW,aAAahK,GAAS6rB,qBACzC/b,EAAQ9F,WAAW,SAAShK,GAAS8rB,kBACtC,CAEDl8J,KAAKu/I,gBAAkBv/I,KAAKw7J,QAAQ1wH,KAAKv6B,IAEvC,IAAIyoJ,EACJ,GAFkB,YAAazoJ,EAa7BmsJ,EACkF,EAE9Exc,SAEJ8Y,EAAUzoJ,MAhBI,CACd,MAAM0oJ,EAAclY,GAC5B,GAEQ2b,EAAiBzD,EAAY/Y,SAC7B8Y,EAAU,CACR9Y,QAAS+Y,EAAY/Y,QACrB/xB,WAAY8qC,EAAY9qC,WACxBkH,SAAU4jC,EAAY5jC,SAEhC,CAQM,OAAO,IAAIwmC,GACT7C,EACAh5J,KAAKoyH,OACLpyH,KAAKs1J,qBACN,GAEJ,CAKD,aAAAmH,GACEz8J,KAAKq8J,gBAAkB,IAAIxF,GAAkB72J,KAAKoyH,QAClD,MAAM8tB,GAAU,IAAIrH,IACjB8C,uBACC,QAAQvL,GAAS8rB,sCAElB9hB,WAAW,SAAShK,GAAS8rB,mBAChCl8J,KAAKw8J,iBAAmBx8J,KAAKoyH,OAAOmM,WAClC2hB,EAAQ5D,wBACR4D,EAAQ7D,uBAEVr8I,KAAKoyH,OAAOgK,gBAAgBp8H,KAAKs8J,iBAClC,CAED,kBAAArsB,GACEjwI,KAAK47J,mBACL57J,KAAKy8J,eACN,CAED,wBAAAvqB,CAAyBvnI,GACvB,MAAMkyJ,EAAU,IAAIC,GAAanyJ,EAAS3K,KAAKu/I,iBAEzCh6I,EAAW,KACXs3J,EAAQ14F,QACVnkE,KAAK28G,WAAW90G,UAChBg1J,EAAQv2J,oBAAoBwB,EAAkBvC,GAC/C,EAGH,OADAs3J,EAAQv3J,iBAAiBwC,EAAkBvC,GACpCs3J,CACR,CAED,iBAAAvqB,CAAkB70F,EAAY80F,GAC5BttI,MAAMqtI,kBAAkB70F,GAAY,GACpCz9C,KAAKoyH,OAAO+M,wBACV1hF,EACAz9C,KAAKu7J,6BAEPv7J,KAAKoyH,OAAOgE,YACVp2H,KAAKq8J,gBAAgB7+B,aACrB,EACA4S,GAAS6rB,kBAEZ,CAED,qBAAAzpB,CAAsB/0F,GACpBz9C,KAAKoyH,OAAO+M,wBACV1hF,EACAz9C,KAAKu7J,6BAEP,MAAMngI,EAAaqiB,EAAWriB,WACxB1nB,EAAO+pC,EAAW/pC,KAmBxB,OAlBA1T,KAAKq8J,gBAAgB/vH,QAAQ,CAAC54B,EAAK,GAAK0nB,EAAY1nB,EAAK,GAAK0nB,IAC9Dp7B,KAAKoyH,OAAOgL,0BACV3/E,EACAz9C,KAAKq8J,iBACL,GACA,GAEFr8J,KAAKoyH,OAAOgG,WAAWp4H,KAAKw8J,iBAAkB/+G,GAC9Cu+G,GAAiBh8J,KAAKs7J,cAAet7J,KAAKu7J,6BAC1Cv7J,KAAKoyH,OAAOgM,sBACVgS,GAAS/W,kBACTkc,GAAkBv1I,KAAKs7H,SAAUt7H,KAAKs7J,gBAExClF,GAAqBp2J,KAAKs7J,cAAet7J,KAAKu7J,6BAC9Cv7J,KAAKoyH,OAAOgM,sBACVgS,GAAS9W,uBACTic,GAAkBv1I,KAAKs7H,SAAUt7H,KAAKs7J,iBAEjC,CACR,CAED,cAAAzoB,CAAe1B,EAAoB2B,EAAOt5H,EAAQo5H,GAChD,IAAKzB,EAAmBhtE,MACtB,OAEFnkE,KAAKoyH,OAAO2L,qBAAqBqS,GAASG,MAAOqC,GACjD5yI,KAAKoyH,OAAO2L,qBAAqBqS,GAAS8rB,gBAAiBppB,GAC3D9yI,KAAKoyH,OAAOiN,oBAAoB+Q,GAASI,cAAeh3H,GACxDxZ,KAAKoyH,OAAO2L,qBAAqBqS,GAASM,aAAc,GACxD1wI,KAAKoyH,OAAOwC,WACkB,EAAqB4qB,cAEnDx/I,KAAKoyH,OAAOwC,WAAW50H,KAAKs8J,kBAC5Bt8J,KAAKoyH,OAAOsN,iBAAiB1/H,KAAKu8J,qBAClC,MAAMvE,EAAch4J,KAAKs8J,iBAAiB3oJ,UAC1C3T,KAAKoyH,OAAOqL,aAAa,EAAGu6B,EAC7B,CAUD,cAAA8D,CAAetxH,EAAOmoG,EAAcopB,EAAsBjpB,EAAOF,GAE/DopB,GAAiBh8J,KAAKs7J,cAAet7J,KAAKu7J,6BAC1C/+E,GAAkBx8E,KAAKs7J,cAAeS,GACtC/7J,KAAKoyH,OAAOgM,sBACVgS,GAAS/W,kBACTkc,GAAkBv1I,KAAKs7H,SAAUt7H,KAAKs7J,gBAIxClF,GAAqBp2J,KAAKs7J,cAAet7J,KAAKu7J,6BAC9Cv7J,KAAKoyH,OAAOgM,sBACVgS,GAAS9W,uBACTic,GAAkBv1I,KAAKs7H,SAAUt7H,KAAKs7J,gBAGxCt7J,KAAKoyH,OAAO2L,qBAAqBqS,GAASM,aAAclmG,GACxDxqC,KAAKoyH,OAAO2L,qBAAqBqS,GAASG,MAAOqC,GACjD5yI,KAAKoyH,OAAO2L,qBAAqBqS,GAAS8rB,gBAAiBppB,GAC3D9yI,KAAKoyH,OAAOiN,oBAAoB+Q,GAASI,cAAemC,EACzD,CAED,UAAAF,CACEtB,EACAuB,EACAj1F,EACAk1F,EACAnjF,EACAs2B,EACA+6B,EACAjF,EACAg3B,EACAp1D,EACAhzC,GAEA,MAAMgrG,EAAe53H,GAAgBg+F,EAAY+2B,EAAc/2B,GACzDk3B,EAAQ3B,EAAmBjkI,KAAKG,eAAe,GACrD,IAAK,IAAIzL,EAAI,EAAGuE,EAAKnG,KAAKu/I,gBAAgBp+I,OAAQS,EAAIuE,EAAIvE,IAAK,CAC7D,MAAMsiE,EAAWlkE,KAAKu/I,gBAAgB39I,GAChC4hH,EAAU2tB,EAAmB3tB,QAAQ5hH,GAC3CsiE,EAASpnB,OAAO0mE,EAAS/lE,GAAY,KACnCz9C,KAAK87J,eACHtxH,EACAgrG,EACAhyB,EAAQk3C,wBACR5nB,EACAF,EACD,GAEJ,CACF,CAMD,eAAA5rF,CAAgBvJ,GAAc,CAK9B,eAAAh9C,GACEwE,MAAMxE,iBACP,GCzWH,MAAMs8J,GACY,EADZA,GAEQ,EAFRA,GAGI,EAHJA,GAIQ,EAJRA,GAKI,EALJA,GAMQ,EANRA,GAOQ,EAPRA,GAQU,EARVA,GASE,EATFA,GAUa,EAVbA,GAWY,GAXZA,GAYc,GAZdA,GAaI,GAMGC,GAAkB,CAACD,IAKnBE,GAAoB,CAACF,IAKrBG,GAAuB,CAACH,IAKxBI,GAAuB,CAACJ,ICimBrC,IAAAK,GA5mBA,cAA4BrrF,GAO1B,WAAAjyE,CAAYqb,EAAWg1B,EAAWxzB,EAAYye,GAC5Cn2B,QAMAjF,KAAKmb,UAAYA,EAOjBnb,KAAKmwC,UAAYA,EAMjBnwC,KAAKo7B,WAAaA,EAMlBp7B,KAAKq9J,aAAe,EAOpBr9J,KAAK2c,WAAaA,EAMlB3c,KAAKs9J,2BAA6B,KAMlCt9J,KAAKu9J,2BAA6B,KAMlCv9J,KAAKw9J,mBAAqB,KAM1Bx9J,KAAKy9J,aAAe,GAMpBz9J,KAAKuZ,YAAc,GAMnBvZ,KAAK09J,eAAiB,GAMtB19J,KAAK29J,yBAA2B,GAMhC39J,KAAKwM,MAA+D,CAAE,CACvE,CAOD,eAAAoxJ,CAAgBC,GACd,MAAMziI,EAAap7B,KAAKo7B,WACxB,OAAqB,GAAdA,EACHyiI,EACAA,EAAU/yH,KAAI,SAAUgzH,GACtB,OAAOA,EAAO1iI,CACxB,GACG,CAQD,0BAAA2iI,CAA2BjjJ,EAAiBE,GAC1C,MAAMxB,EAASxZ,KAAKg+J,uBACd/9G,EAAWjgD,KAAK09J,eAChBnkJ,EAAcvZ,KAAKuZ,YACzB,IAAI0kJ,EAAQ1kJ,EAAYpY,OACxB,IAAK,IAAIS,EAAI,EAAGuE,EAAK2U,EAAgB3Z,OAAQS,EAAIuE,EAAIvE,GAAKoZ,EACxDilC,EAAS,GAAKnlC,EAAgBlZ,GAC9Bq+C,EAAS,GAAKnlC,EAAgBlZ,EAAI,GAC9BkY,GAAmBN,EAAQymC,KAC7B1mC,EAAY0kJ,KAAWh+G,EAAS,GAChC1mC,EAAY0kJ,KAAWh+G,EAAS,IAGpC,OAAOg+G,CACR,CAYD,yBAAAC,CACEpjJ,EACAC,EACA/Y,EACAgZ,EACAmjJ,EACAC,GAEA,MAAM7kJ,EAAcvZ,KAAKuZ,YACzB,IAAI0kJ,EAAQ1kJ,EAAYpY,OACxB,MAAMqY,EAASxZ,KAAKg+J,uBAChBI,IACFrjJ,GAAUC,GAEZ,IAAIqjJ,EAAavjJ,EAAgBC,GAC7BujJ,EAAaxjJ,EAAgBC,EAAS,GAC1C,MAAMwjJ,EAAYv+J,KAAK09J,eACvB,IAEI97J,EAAG48J,EAASC,EAFZC,GAAU,EAGd,IAAK98J,EAAImZ,EAASC,EAAQpZ,EAAII,EAAKJ,GAAKoZ,EACtCujJ,EAAU,GAAKzjJ,EAAgBlZ,GAC/B28J,EAAU,GAAKzjJ,EAAgBlZ,EAAI,GACnC68J,EAAUtkJ,GAAuBX,EAAQ+kJ,GACrCE,IAAYD,GACVE,IACFnlJ,EAAY0kJ,KAAWI,EACvB9kJ,EAAY0kJ,KAAWK,EACvBI,GAAU,GAEZnlJ,EAAY0kJ,KAAWM,EAAU,GACjChlJ,EAAY0kJ,KAAWM,EAAU,IACxBE,IAAY1lJ,GAAaE,cAClCM,EAAY0kJ,KAAWM,EAAU,GACjChlJ,EAAY0kJ,KAAWM,EAAU,GACjCG,GAAU,GAEVA,GAAU,EAEZL,EAAaE,EAAU,GACvBD,EAAaC,EAAU,GACvBC,EAAUC,EAQZ,OAJKN,GAAUO,GAAY98J,IAAMmZ,EAASC,KACxCzB,EAAY0kJ,KAAWI,EACvB9kJ,EAAY0kJ,KAAWK,GAElBL,CACR,CAUD,sBAAAU,CAAuB7jJ,EAAiBC,EAAQ6V,EAAM5V,EAAQ4jJ,GAC5D,IAAK,IAAIh9J,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC7C,MAAMI,EAAM4uB,EAAKhvB,GACXi9J,EAAa7+J,KAAKk+J,0BACtBpjJ,EACAC,EACA/Y,EACAgZ,GACA,GACA,GAEF4jJ,EAAYj5J,KAAKk5J,GACjB9jJ,EAAS/Y,CACV,CACD,OAAO+Y,CACR,CAQD,UAAAm1D,CAAWt7D,EAAU+qC,EAASukB,EAAUiM,GACtCnwE,KAAK8+J,cAAclqJ,EAAU+qC,GAE7B,MAAM5/C,EAAO6U,EAAS8Z,UAChB1T,EAASpG,EAAS4a,YAClBuvI,EAAe/+J,KAAKuZ,YAAYpY,OAEtC,IAAI2Z,EAAiB+jJ,EAAYD,EAAaI,EAC1CjkJ,EAEJ,OAAQhb,GACN,IAAK,eACH+a,EAC8D,EAE1D2b,6BACJuoI,EAAe,GACf,MAAMluI,EACwD,EAE1DklD,WACJj7D,EAAS,EACT,IAAK,IAAInZ,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAMq9J,EAAS,GACflkJ,EAAS/a,KAAK2+J,uBACZ7jJ,EACAC,EACA+V,EAAMlvB,GACNoZ,EACAikJ,GAEFD,EAAar5J,KAAKs5J,EACnB,CACDj/J,KAAKy9J,aAAa93J,KAAK,CACrBu5J,GACAH,EACAC,EACApqJ,EACAsvD,EACArxC,KAEF7yB,KAAK29J,yBAAyBh4J,KAAK,CACjCu5J,GACAH,EACAC,EACApqJ,EACAu7D,GAAwBjM,EACxBrxC,KAEF,MACF,IAAK,UACL,IAAK,kBACH+rI,EAAc,GACd9jJ,EACU,WAAR/a,EAC2D,EAErD02B,6BACF7hB,EAAS2a,qBACfxU,EAAS/a,KAAK2+J,uBACZ7jJ,EACA,EACuG,EAErG6b,UACF3b,EACA4jJ,GAEF5+J,KAAKy9J,aAAa93J,KAAK,CACrBu5J,GACAH,EACAH,EACAhqJ,EACAsvD,EACAtxC,KAEF5yB,KAAK29J,yBAAyBh4J,KAAK,CACjCu5J,GACAH,EACAH,EACAhqJ,EACAu7D,GAAwBjM,EACxBtxC,KAEF,MACF,IAAK,aACL,IAAK,SACH9X,EAAkBlG,EAAS2a,qBAC3BsvI,EAAa7+J,KAAKk+J,0BAChBpjJ,EACA,EACAA,EAAgB3Z,OAChB6Z,GACA,GACA,GAEFhb,KAAKy9J,aAAa93J,KAAK,CACrBu5J,GACAH,EACAF,EACAjqJ,EACAsvD,EACAvxC,KAEF3yB,KAAK29J,yBAAyBh4J,KAAK,CACjCu5J,GACAH,EACAF,EACAjqJ,EACAu7D,GAAwBjM,EACxBvxC,KAEF,MACF,IAAK,aACH7X,EAAkBlG,EAAS2a,qBAC3BsvI,EAAa7+J,KAAK+9J,2BAA2BjjJ,EAAiBE,GAE1D6jJ,EAAaE,IACf/+J,KAAKy9J,aAAa93J,KAAK,CACrBu5J,GACAH,EACAF,EACAjqJ,EACAsvD,EACAvxC,KAEF3yB,KAAK29J,yBAAyBh4J,KAAK,CACjCu5J,GACAH,EACAF,EACAjqJ,EACAu7D,GAAwBjM,EACxBvxC,MAGJ,MACF,IAAK,QACH7X,EAAkBlG,EAAS2a,qBAC3BvvB,KAAKuZ,YAAY5T,KAAKmV,EAAgB,GAAIA,EAAgB,IAC1D+jJ,EAAa7+J,KAAKuZ,YAAYpY,OAE9BnB,KAAKy9J,aAAa93J,KAAK,CACrBu5J,GACAH,EACAF,EACAjqJ,EACAsvD,IAEFlkE,KAAK29J,yBAAyBh4J,KAAK,CACjCu5J,GACAH,EACAF,EACAjqJ,EACAu7D,GAAwBjM,IAK9BlkE,KAAKm/J,YAAYx/G,EAClB,CAOD,aAAAm/G,CAAclqJ,EAAU+qC,GACtB3/C,KAAKs9J,2BAA6B,CAChC4B,GACAv/G,EACA,EACA/qC,GAEF5U,KAAKy9J,aAAa93J,KAAK3F,KAAKs9J,4BAC5Bt9J,KAAKu9J,2BAA6B,CAChC2B,GACAv/G,EACA,EACA/qC,GAEF5U,KAAK29J,yBAAyBh4J,KAAK3F,KAAKu9J,2BACzC,CAKD,MAAA6B,GACE,MAAO,CACL3B,aAAcz9J,KAAKy9J,aACnBE,yBAA0B39J,KAAK29J,yBAC/BpkJ,YAAavZ,KAAKuZ,YAErB,CAKD,+BAAA8lJ,GACE,MAAM1B,EAA2B39J,KAAK29J,yBAItC,IAAI/7J,EAFJ+7J,EAAyBn0D,UAGzB,MAAM7nG,EAAIg8J,EAAyBx8J,OACnC,IAAIm+J,EACAv/J,EACAgC,GAAS,EACb,IAAKH,EAAI,EAAGA,EAAID,IAAKC,EACnB09J,EAAc3B,EAAyB/7J,GACvC7B,EAA0Du/J,EAAY,GAClEv/J,GAAQm/J,GACVn9J,EAAQH,EACC7B,GAAQm/J,KACjBI,EAAY,GAAK19J,EACjBE,EAAgB9B,KAAK29J,yBAA0B57J,EAAOH,GACtDG,GAAS,EAGd,CAMD,kBAAAwvE,CAAmBz0C,EAAW00C,GAC5B,MAAMhlE,EAAQxM,KAAKwM,MACnB,GAAIswB,EAAW,CACb,MAAMm6C,EAAiBn6C,EAAUo6C,WACjC1qE,EAAMswB,UAAY0wC,GAChByJ,GAAkCp1B,GAE1C,MACMr1C,EAAMswB,eAAYt2B,EAEpB,GAAIgrE,EAAa,CACf,MAAM2F,EAAmB3F,EAAY0F,WACrC1qE,EAAMglE,YAAchE,GAClB2J,GAAsCj1B,IAExC,MAAMk1B,EAAqB5F,EAAY6F,aACvC7qE,EAAM+pE,aACmB/vE,IAAvB4wE,EAAmCA,EAAqBt1B,GAC1D,MAAMw1B,EAAsB9F,EAAY+F,cACxC/qE,EAAMgqE,SAAWc,EACbA,EAAoBxzE,QACpBi+C,GACJ,MAAMy1B,EAA4BhG,EAAYiG,oBAC9CjrE,EAAMkqE,eAAiBc,G1K9XQ,E0KiY/B,MAAME,EAAsBlG,EAAYmG,cACxCnrE,EAAMmqE,cACoBnwE,IAAxBkxE,EACIA,EACA11B,GACN,MAAM41B,EAAmBpG,EAAYp1D,WACrC5P,EAAM04C,eACiB1+C,IAArBoxE,EAAiCA,E1K9VT,E0K+V1B,MAAMC,EAAwBrG,EAAYsG,gBAC1CtrE,EAAMoqE,gBACsBpwE,IAA1BqxE,EACIA,EACA51B,GAEFz1C,EAAM04C,UAAYllD,KAAKq9J,eACzBr9J,KAAKq9J,aAAe7wJ,EAAM04C,UAE1BllD,KAAKw9J,mBAAqB,KAElC,MACMhxJ,EAAMglE,iBAAchrE,EACpBgG,EAAM+pE,aAAU/vE,EAChBgG,EAAMgqE,SAAW,KACjBhqE,EAAMkqE,oBAAiBlwE,EACvBgG,EAAMmqE,cAAWnwE,EACjBgG,EAAM04C,eAAY1+C,EAClBgG,EAAMoqE,gBAAapwE,CAEtB,CAMD,UAAA+4J,CAAW/yJ,GACT,MAAMswB,EAAYtwB,EAAMswB,UAElBkgI,EAAkB,CAACkC,GAAkCpiI,GAK3D,MAJyB,iBAAdA,GAETkgI,EAAgBr3J,MAAK,GAEhBq3J,CACR,CAKD,WAAAwC,CAAYhzJ,GACVxM,KAAKy9J,aAAa93J,KAAK3F,KAAKy/J,aAAajzJ,GAC1C,CAMD,YAAAizJ,CAAajzJ,GACX,MAAO,CACL0yJ,GACA1yJ,EAAMglE,YACNhlE,EAAM04C,UAAYllD,KAAKo7B,WACvB5uB,EAAM+pE,QACN/pE,EAAMmqE,SACNnqE,EAAMoqE,WACN52E,KAAK49J,gBAAgBpxJ,EAAMgqE,UAC3BhqE,EAAMkqE,eAAiB12E,KAAKo7B,WAE/B,CAMD,eAAAskI,CAAgBlzJ,EAAO+yJ,GACrB,MAAMziI,EAAYtwB,EAAMswB,UACC,iBAAdA,GAA0BtwB,EAAMmzJ,kBAAoB7iI,SAC3Ct2B,IAAds2B,GACF98B,KAAKy9J,aAAa93J,KAAK45J,EAAWx7J,KAAK/D,KAAMwM,IAE/CA,EAAMmzJ,iBAAmB7iI,EAE5B,CAMD,iBAAA8iI,CAAkBpzJ,EAAOgzJ,GACvB,MAAMhuF,EAAchlE,EAAMglE,YACpB+E,EAAU/pE,EAAM+pE,QAChBC,EAAWhqE,EAAMgqE,SACjBE,EAAiBlqE,EAAMkqE,eACvBC,EAAWnqE,EAAMmqE,SACjBzxB,EAAY14C,EAAM04C,UAClB0xB,EAAapqE,EAAMoqE,YAEvBpqE,EAAMqzJ,oBAAsBruF,GAC5BhlE,EAAMszJ,gBAAkBvpF,GACvBC,GAAYhqE,EAAMuzJ,kBAChBx9J,EAAOiK,EAAMuzJ,gBAAiBvpF,IACjChqE,EAAMwzJ,uBAAyBtpF,GAC/BlqE,EAAMyzJ,iBAAmBtpF,GACzBnqE,EAAM0zJ,kBAAoBh7G,GAC1B14C,EAAM2zJ,mBAAqBvpF,UAEPpwE,IAAhBgrE,GACFguF,EAAYz7J,KAAK/D,KAAMwM,GAEzBA,EAAMqzJ,mBAAqBruF,EAC3BhlE,EAAMszJ,eAAiBvpF,EACvB/pE,EAAMuzJ,gBAAkBvpF,EACxBhqE,EAAMwzJ,sBAAwBtpF,EAC9BlqE,EAAMyzJ,gBAAkBtpF,EACxBnqE,EAAM0zJ,iBAAmBh7G,EACzB14C,EAAM2zJ,kBAAoBvpF,EAE7B,CAKD,WAAAuoF,CAAYx/G,GACV3/C,KAAKs9J,2BAA2B,GAAKt9J,KAAKy9J,aAAat8J,OACvDnB,KAAKs9J,2BAA6B,KAClCt9J,KAAKu9J,2BAA2B,GAAKv9J,KAAK29J,yBAAyBx8J,OACnEnB,KAAKu9J,2BAA6B,KAClC,MAAM6C,EAAyB,CAAClB,GAAgCv/G,GAChE3/C,KAAKy9J,aAAa93J,KAAKy6J,GACvBpgK,KAAK29J,yBAAyBh4J,KAAKy6J,EACpC,CASD,oBAAApC,GACE,IAAKh+J,KAAKw9J,qBACRx9J,KAAKw9J,mBAAqBzoJ,GAAM/U,KAAKmwC,WACjCnwC,KAAKq9J,aAAe,GAAG,CACzB,MAAM5tJ,EAASzP,KAAK2c,YAAc3c,KAAKq9J,aAAe,GAAM,EAC5D1jJ,GAAO3Z,KAAKw9J,mBAAoB/tJ,EAAOzP,KAAKw9J,mBAC7C,CAEH,OAAOx9J,KAAKw9J,kBACb,GCzXH,IAAA6C,GAxQA,cAAiCC,GAO/B,WAAAxgK,CAAYqb,EAAWg1B,EAAWxzB,EAAYye,GAC5Cn2B,MAAMkW,EAAWg1B,EAAWxzB,EAAYye,GAMxCp7B,KAAKomJ,mBAAqB,KAM1BpmJ,KAAKu7B,OAAS,KAMdv7B,KAAKugK,sBAAmB/5J,EAMxBxG,KAAKwgK,cAAWh6J,EAMhBxG,KAAKygK,cAAWj6J,EAMhBxG,KAAK0gK,aAAUl6J,EAMfxG,KAAK8iJ,cAAWt8I,EAMhBxG,KAAK2gK,cAAWn6J,EAMhBxG,KAAK4gK,cAAWp6J,EAMhBxG,KAAK+iJ,qBAAkBv8I,EAMvBxG,KAAK8yD,eAAYtsD,EAMjBxG,KAAKgjJ,YAASx8I,EAMdxG,KAAKuoJ,YAAS/hJ,EAMdxG,KAAKojJ,oBAAiB58I,EAOtBxG,KAAK6gK,6BAA0Br6J,CAChC,CAMD,SAAA0qE,CAAUC,EAAexxB,GACvB,IAAK3/C,KAAKu7B,OACR,OAEFv7B,KAAK8+J,cAAc3tF,EAAexxB,GAClC,MAAM7kC,EAAkBq2D,EAAc5hD,qBAChCvU,EAASm2D,EAAc3hD,YACvBsxI,EAAU9gK,KAAKuZ,YAAYpY,OAC3B88J,EAAQj+J,KAAK+9J,2BAA2BjjJ,EAAiBE,GAC/Dhb,KAAKy9J,aAAa93J,KAAK,CACrBu5J,GACA4B,EACA7C,EACAj+J,KAAKu7B,OAELv7B,KAAKwgK,SAAWxgK,KAAKugK,iBACrBvgK,KAAKygK,SAAWzgK,KAAKugK,iBACrBt0J,KAAKkZ,KAAKnlB,KAAK0gK,QAAU1gK,KAAKugK,kBAC9BvgK,KAAK8iJ,SACL9iJ,KAAK2gK,SAAW3gK,KAAKugK,iBACrBvgK,KAAK4gK,SAAW5gK,KAAKugK,iBACrBvgK,KAAK+iJ,gBACL/iJ,KAAK8yD,UACL,CACG9yD,KAAKgjJ,OAAO,GAAKhjJ,KAAKo7B,WAAcp7B,KAAKugK,iBACzCvgK,KAAKgjJ,OAAO,GAAKhjJ,KAAKo7B,WAAcp7B,KAAKugK,kBAE5Ct0J,KAAKkZ,KAAKnlB,KAAKuoJ,OAASvoJ,KAAKugK,kBAC7BvgK,KAAKojJ,eACLpjJ,KAAK6gK,0BAEP7gK,KAAK29J,yBAAyBh4J,KAAK,CACjCu5J,GACA4B,EACA7C,EACAj+J,KAAKomJ,mBAELpmJ,KAAKwgK,SACLxgK,KAAKygK,SACLzgK,KAAK0gK,QACL,EACA1gK,KAAK2gK,SACL3gK,KAAK4gK,SACL5gK,KAAK+iJ,gBACL/iJ,KAAK8yD,UACL9yD,KAAKgjJ,OACLhjJ,KAAKuoJ,OACLvoJ,KAAKojJ,eACLpjJ,KAAK6gK,0BAEP7gK,KAAKm/J,YAAYx/G,EAClB,CAMD,cAAAmxB,CAAeC,EAAoBpxB,GACjC,IAAK3/C,KAAKu7B,OACR,OAEFv7B,KAAK8+J,cAAc/tF,EAAoBpxB,GACvC,MAAM7kC,EAAkBi2D,EAAmBxhD,qBACrCvU,EAAS+1D,EAAmBvhD,YAC5BsxI,EAAU9gK,KAAKuZ,YAAYpY,OAC3B88J,EAAQj+J,KAAK+9J,2BAA2BjjJ,EAAiBE,GAC/Dhb,KAAKy9J,aAAa93J,KAAK,CACrBu5J,GACA4B,EACA7C,EACAj+J,KAAKu7B,OAELv7B,KAAKwgK,SAAWxgK,KAAKugK,iBACrBvgK,KAAKygK,SAAWzgK,KAAKugK,iBACrBt0J,KAAKkZ,KAAKnlB,KAAK0gK,QAAU1gK,KAAKugK,kBAC9BvgK,KAAK8iJ,SACL9iJ,KAAK2gK,SAAW3gK,KAAKugK,iBACrBvgK,KAAK4gK,SAAW5gK,KAAKugK,iBACrBvgK,KAAK+iJ,gBACL/iJ,KAAK8yD,UACL,CACG9yD,KAAKgjJ,OAAO,GAAKhjJ,KAAKo7B,WAAcp7B,KAAKugK,iBACzCvgK,KAAKgjJ,OAAO,GAAKhjJ,KAAKo7B,WAAcp7B,KAAKugK,kBAE5Ct0J,KAAKkZ,KAAKnlB,KAAKuoJ,OAASvoJ,KAAKugK,kBAC7BvgK,KAAKojJ,eACLpjJ,KAAK6gK,0BAEP7gK,KAAK29J,yBAAyBh4J,KAAK,CACjCu5J,GACA4B,EACA7C,EACAj+J,KAAKomJ,mBAELpmJ,KAAKwgK,SACLxgK,KAAKygK,SACLzgK,KAAK0gK,QACL,EACA1gK,KAAK2gK,SACL3gK,KAAK4gK,SACL5gK,KAAK+iJ,gBACL/iJ,KAAK8yD,UACL9yD,KAAKgjJ,OACLhjJ,KAAKuoJ,OACLvoJ,KAAKojJ,eACLpjJ,KAAK6gK,0BAEP7gK,KAAKm/J,YAAYx/G,EAClB,CAKD,MAAAy/G,GAgBE,OAfAp/J,KAAKq/J,kCAELr/J,KAAKwgK,cAAWh6J,EAChBxG,KAAKygK,cAAWj6J,EAChBxG,KAAKomJ,mBAAqB,KAC1BpmJ,KAAKu7B,OAAS,KACdv7B,KAAKugK,sBAAmB/5J,EACxBxG,KAAK0gK,aAAUl6J,EACfxG,KAAKgjJ,YAASx8I,EACdxG,KAAK8iJ,cAAWt8I,EAChBxG,KAAK2gK,cAAWn6J,EAChBxG,KAAK4gK,cAAWp6J,EAChBxG,KAAK+iJ,qBAAkBv8I,EACvBxG,KAAK8yD,eAAYtsD,EACjBxG,KAAKuoJ,YAAS/hJ,EACPvB,MAAMm6J,QACd,CAMD,aAAA3tF,CAAcC,EAAYqvF,GACxB,MAAM3zI,EAASskD,EAAWwG,YACpBxkE,EAAOg+D,EAAW/9D,UAClB8xE,EAAS/T,EAAW0G,YAC1Bp4E,KAAKugK,iBAAmB7uF,EAAWj2C,cAAcz7B,KAAKo7B,YACtDp7B,KAAKwgK,SAAWpzI,EAAO,GACvBptB,KAAKygK,SAAWrzI,EAAO,GACvBptB,KAAKomJ,mBAAqB10E,EAAW4xE,uBACrCtjJ,KAAKu7B,OAASm2C,EAAWl2C,SAASx7B,KAAKo7B,YACvCp7B,KAAK0gK,QAAUhtJ,EAAK,GACpB1T,KAAK8iJ,SAAWpxE,EAAW5jC,aAC3B9tC,KAAK2gK,SAAWl7E,EAAO,GACvBzlF,KAAK4gK,SAAWn7E,EAAO,GACvBzlF,KAAK+iJ,gBAAkBrxE,EAAW2G,oBAClCr4E,KAAK8yD,UAAY4e,EAAW57B,cAC5B91C,KAAKgjJ,OAAStxE,EAAW6G,gBACzBv4E,KAAKuoJ,OAAS70I,EAAK,GACnB1T,KAAKojJ,eAAiB1xE,EAAW8I,mBACjCx6E,KAAK6gK,wBAA0BE,CAChC,GCzGH,IAAAC,GAxJA,cAAsCV,GAOpC,WAAAxgK,CAAYqb,EAAWg1B,EAAWxzB,EAAYye,GAC5Cn2B,MAAMkW,EAAWg1B,EAAWxzB,EAAYye,EACzC,CAUD,oBAAA6lI,CAAqBnmJ,EAAiBC,EAAQ/Y,EAAKgZ,GACjD,MAAM8lJ,EAAU9gK,KAAKuZ,YAAYpY,OAC3B88J,EAAQj+J,KAAKk+J,0BACjBpjJ,EACAC,EACA/Y,EACAgZ,GACA,GACA,GAEIkmJ,EAA0B,CAC9BhC,GACA4B,EACA7C,GAIF,OAFAj+J,KAAKy9J,aAAa93J,KAAKu7J,GACvBlhK,KAAK29J,yBAAyBh4J,KAAKu7J,GAC5Bl/J,CACR,CAMD,cAAA0uE,CAAeC,EAAoBhxB,GACjC,MAAMnzC,EAAQxM,KAAKwM,MACbglE,EAAchlE,EAAMglE,YACpBtsB,EAAY14C,EAAM04C,UACxB,QAAoB1+C,IAAhBgrE,QAA2ChrE,IAAd0+C,EAC/B,OAEFllD,KAAK4/J,kBAAkBpzJ,EAAOxM,KAAKw/J,aACnCx/J,KAAK8+J,cAAcnuF,EAAoBhxB,GACvC3/C,KAAK29J,yBAAyBh4J,KAC5B,CACEu5J,GACA1yJ,EAAMglE,YACNhlE,EAAM04C,UACN14C,EAAM+pE,QACN/pE,EAAMmqE,SACNnqE,EAAMoqE,WACN70B,G5K6C6B,G4K1C/Bm7G,IAEF,MAAMpiJ,EAAkB61D,EAAmBphD,qBACrCvU,EAAS21D,EAAmBnhD,YAClCxvB,KAAKihK,qBACHnmJ,EACA,EACAA,EAAgB3Z,OAChB6Z,GAEFhb,KAAK29J,yBAAyBh4J,KAAKs3J,IACnCj9J,KAAKm/J,YAAYx/G,EAClB,CAMD,mBAAAixB,CAAoBC,EAAyBlxB,GAC3C,MAAMnzC,EAAQxM,KAAKwM,MACbglE,EAAchlE,EAAMglE,YACpBtsB,EAAY14C,EAAM04C,UACxB,QAAoB1+C,IAAhBgrE,QAA2ChrE,IAAd0+C,EAC/B,OAEFllD,KAAK4/J,kBAAkBpzJ,EAAOxM,KAAKw/J,aACnCx/J,KAAK8+J,cAAcjuF,EAAyBlxB,GAC5C3/C,KAAK29J,yBAAyBh4J,KAC5B,CACEu5J,GACA1yJ,EAAMglE,YACNhlE,EAAM04C,UACN14C,EAAM+pE,QACN/pE,EAAMmqE,SACNnqE,EAAMoqE,WACN70B,G5KO6B,G4KJ/Bm7G,IAEF,MAAMtsI,EAAOigD,EAAwBl6C,UAC/B7b,EAAkB+1D,EAAwBthD,qBAC1CvU,EAAS61D,EAAwBrhD,YACvC,IAAIzU,EAAS,EACb,IAAK,IAAInZ,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,IAAMvE,EAC1CmZ,EAAS/a,KAAKihK,qBACZnmJ,EACAC,EACuB6V,EAAKhvB,GAC5BoZ,GAGJhb,KAAK29J,yBAAyBh4J,KAAKs3J,IACnCj9J,KAAKm/J,YAAYx/G,EAClB,CAKD,MAAAy/G,GACE,MAAM5yJ,EAAQxM,KAAKwM,MASnB,OAPsBhG,MAApBgG,EAAM20J,YACN30J,EAAM20J,YAAcnhK,KAAKuZ,YAAYpY,QAErCnB,KAAKy9J,aAAa93J,KAAKs3J,IAEzBj9J,KAAKq/J,kCACLr/J,KAAKwM,MAAQ,KACNvH,MAAMm6J,QACd,CAKD,WAAAI,CAAYhzJ,GAEYhG,MAApBgG,EAAM20J,YACN30J,EAAM20J,YAAcnhK,KAAKuZ,YAAYpY,SAErCnB,KAAKy9J,aAAa93J,KAAKs3J,IACvBzwJ,EAAM20J,WAAanhK,KAAKuZ,YAAYpY,QAEtCqL,EAAM20J,WAAa,EACnBl8J,MAAMu6J,YAAYhzJ,GAClBxM,KAAKy9J,aAAa93J,KAAKu3J,GACxB,GCqGH,IAAAkE,GAnPA,cAAmCd,GAOjC,WAAAxgK,CAAYqb,EAAWg1B,EAAWxzB,EAAYye,GAC5Cn2B,MAAMkW,EAAWg1B,EAAWxzB,EAAYye,EACzC,CAUD,qBAAAimI,CAAsBvmJ,EAAiBC,EAAQ6V,EAAM5V,GACnD,MAAMxO,EAAQxM,KAAKwM,MACbyoE,OAA2BzuE,IAApBgG,EAAMswB,UACbo4C,OAA+B1uE,IAAtBgG,EAAMglE,YACf8vF,EAAU1wI,EAAKzvB,OACrBnB,KAAKy9J,aAAa93J,KAAKu3J,IACvBl9J,KAAK29J,yBAAyBh4J,KAAKu3J,IACnC,IAAK,IAAIt7J,EAAI,EAAGA,EAAI0/J,IAAW1/J,EAAG,CAChC,MAAMI,EAAM4uB,EAAKhvB,GACXk/J,EAAU9gK,KAAKuZ,YAAYpY,OAC3B88J,EAAQj+J,KAAKk+J,0BACjBpjJ,EACAC,EACA/Y,EACAgZ,GACA,GACCk6D,GAEGgsF,EAA0B,CAC9BhC,GACA4B,EACA7C,GAEFj+J,KAAKy9J,aAAa93J,KAAKu7J,GACvBlhK,KAAK29J,yBAAyBh4J,KAAKu7J,GAC/BhsF,IAGFl1E,KAAKy9J,aAAa93J,KAAKw3J,IACvBn9J,KAAK29J,yBAAyBh4J,KAAKw3J,KAErCpiJ,EAAS/Y,CACV,CASD,OARIizE,IACFj1E,KAAKy9J,aAAa93J,KAAKq3J,IACvBh9J,KAAK29J,yBAAyBh4J,KAAKq3J,KAEjC9nF,IACFl1E,KAAKy9J,aAAa93J,KAAKs3J,IACvBj9J,KAAK29J,yBAAyBh4J,KAAKs3J,KAE9BliJ,CACR,CAMD,UAAAs1D,CAAWC,EAAgB3wB,GACzB,MAAMnzC,EAAQxM,KAAKwM,MACbswB,EAAYtwB,EAAMswB,UAClB00C,EAAchlE,EAAMglE,YAC1B,QAAkBhrE,IAAds2B,QAA2Ct2B,IAAhBgrE,EAC7B,OAEFxxE,KAAKuhK,uBACLvhK,KAAK8+J,cAAcxuF,EAAgB3wB,QACXn5C,IAApBgG,EAAMswB,WACR98B,KAAK29J,yBAAyBh4J,KAAK,CACjCu5J,GACAr9G,UAGsBr7C,IAAtBgG,EAAMglE,aACRxxE,KAAK29J,yBAAyBh4J,KAAK,CACjCu5J,GACA1yJ,EAAMglE,YACNhlE,EAAM04C,UACN14C,EAAM+pE,QACN/pE,EAAMmqE,SACNnqE,EAAMoqE,WACN70B,G7KQ6B,I6KJjC,MAAMjnC,EAAkBw1D,EAAe/gD,qBACjCvU,EAASs1D,EAAe9gD,YACxBsxI,EAAU9gK,KAAKuZ,YAAYpY,OACjCnB,KAAKk+J,0BACHpjJ,EACA,EACAA,EAAgB3Z,OAChB6Z,GACA,GACA,GAEF,MAAMwmJ,EAAoB,CAACtC,GAA0B4B,GACrD9gK,KAAKy9J,aAAa93J,KAAKu3J,GAAsBsE,GAC7CxhK,KAAK29J,yBAAyBh4J,KAAKu3J,GAAsBsE,QACjCh7J,IAApBgG,EAAMswB,YACR98B,KAAKy9J,aAAa93J,KAAKq3J,IACvBh9J,KAAK29J,yBAAyBh4J,KAAKq3J,UAEXx2J,IAAtBgG,EAAMglE,cACRxxE,KAAKy9J,aAAa93J,KAAKs3J,IACvBj9J,KAAK29J,yBAAyBh4J,KAAKs3J,KAErCj9J,KAAKm/J,YAAYx/G,EAClB,CAMD,WAAAyxB,CAAYC,EAAiB1xB,GAC3B,MAAMnzC,EAAQxM,KAAKwM,MACbswB,EAAYtwB,EAAMswB,UAClB00C,EAAchlE,EAAMglE,YAC1B,QAAkBhrE,IAAds2B,QAA2Ct2B,IAAhBgrE,EAC7B,OAEFxxE,KAAKuhK,uBACLvhK,KAAK8+J,cAAcztF,EAAiB1xB,QACZn5C,IAApBgG,EAAMswB,WACR98B,KAAK29J,yBAAyBh4J,KAAK,CACjCu5J,GACAr9G,UAGsBr7C,IAAtBgG,EAAMglE,aACRxxE,KAAK29J,yBAAyBh4J,KAAK,CACjCu5J,GACA1yJ,EAAMglE,YACNhlE,EAAM04C,UACN14C,EAAM+pE,QACN/pE,EAAMmqE,SACNnqE,EAAMoqE,WACN70B,G7KhD6B,I6KoDjC,MAAMnxB,EAAOygD,EAAgB16C,UACvB7b,EAAkBu2D,EAAgB56C,6BAClCzb,EAASq2D,EAAgB7hD,YAC/BxvB,KAAKqhK,sBACHvmJ,EACA,EACN,EACME,GAEFhb,KAAKm/J,YAAYx/G,EAClB,CAMD,gBAAAqxB,CAAiBC,EAAsBtxB,GACrC,MAAMnzC,EAAQxM,KAAKwM,MACbswB,EAAYtwB,EAAMswB,UAClB00C,EAAchlE,EAAMglE,YAC1B,QAAkBhrE,IAAds2B,QAA2Ct2B,IAAhBgrE,EAC7B,OAEFxxE,KAAKuhK,uBACLvhK,KAAK8+J,cAAc7tF,EAAsBtxB,QACjBn5C,IAApBgG,EAAMswB,WACR98B,KAAK29J,yBAAyBh4J,KAAK,CACjCu5J,GACAr9G,UAGsBr7C,IAAtBgG,EAAMglE,aACRxxE,KAAK29J,yBAAyBh4J,KAAK,CACjCu5J,GACA1yJ,EAAMglE,YACNhlE,EAAM04C,UACN14C,EAAM+pE,QACN/pE,EAAMmqE,SACNnqE,EAAMoqE,WACN70B,G7K3F6B,I6K+FjC,MAAMjxB,EAAQmgD,EAAqB+E,WAC7Bl7D,EAAkBm2D,EAAqBx6C,6BACvCzb,EAASi2D,EAAqBzhD,YACpC,IAAIzU,EAAS,EACb,IAAK,IAAInZ,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAC3CmZ,EAAS/a,KAAKqhK,sBACZvmJ,EACAC,EACA+V,EAAMlvB,GACNoZ,GAGJhb,KAAKm/J,YAAYx/G,EAClB,CAKD,MAAAy/G,GACEp/J,KAAKq/J,kCACLr/J,KAAKwM,MAAQ,KAKb,MAAM2O,EAAYnb,KAAKmb,UACvB,GAAkB,IAAdA,EAAiB,CACnB,MAAM5B,EAAcvZ,KAAKuZ,YACzB,IAAK,IAAI3X,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAQS,EAAIuE,IAAMvE,EACjD2X,EAAY3X,GAAK0wB,GAAK/Y,EAAY3X,GAAIuZ,EAEzC,CACD,OAAOlW,MAAMm6J,QACd,CAKD,oBAAAmC,GACE,MAAM/0J,EAAQxM,KAAKwM,WAEDhG,IADAgG,EAAMswB,WAEtB98B,KAAK0/J,gBAAgBlzJ,EAAOxM,KAAKu/J,iBAET/4J,IAAtBgG,EAAMglE,aACRxxE,KAAK4/J,kBAAkBpzJ,EAAOxM,KAAKw/J,YAEtC,GCtPI,SAASiC,GAAUC,EAAa5mJ,EAAiBC,EAAQ/Y,EAAKgZ,GACnE,MAAM8pC,EAAS,GACf,IAAI68G,EAAS5mJ,EACT6mJ,EAAS,EACTC,EAAe/mJ,EAAgBhX,MAAMiX,EAAQ,GACjD,KAAO6mJ,EAASF,GAAeC,EAAS3mJ,EAAShZ,GAAK,CACpD,MAAO+a,EAAIC,GAAM6kJ,EAAa/9J,OAAO,GAC/BmZ,EAAKnC,EAAgB6mJ,EAAS3mJ,GAC9BkC,EAAKpC,EAAgB6mJ,EAAS3mJ,EAAS,GACvCuZ,EAAgBtoB,KAAKma,MACxBnJ,EAAKF,IAAOE,EAAKF,IAAOG,EAAKF,IAAOE,EAAKF,IAG5C,GADA4kJ,GAAUrtI,EACNqtI,GAAUF,EAAa,CACzB,MAAMvhJ,GAAKuhJ,EAAcE,EAASrtI,GAAiBA,EAC7Cld,EAAIyN,GAAK/H,EAAIE,EAAIkD,GACjB7I,EAAIwN,GAAK9H,EAAIE,EAAIiD,GACvB0hJ,EAAal8J,KAAK0R,EAAGC,GACrBwtC,EAAOn/C,KAAKk8J,GACZA,EAAe,CAACxqJ,EAAGC,GACfsqJ,GAAUF,IACZC,GAAU3mJ,GAEZ4mJ,EAAS,CACf,MAAW,GAAIA,EAASF,EAClBG,EAAal8J,KACXmV,EAAgB6mJ,EAAS3mJ,GACzBF,EAAgB6mJ,EAAS3mJ,EAAS,IAEpC2mJ,GAAU3mJ,MACL,CACL,MAAM8mJ,EAAUvtI,EAAgBqtI,EAC1BvqJ,EAAIyN,GAAK/H,EAAIE,EAAI6kJ,EAAUvtI,GAC3Bjd,EAAIwN,GAAK9H,EAAIE,EAAI4kJ,EAAUvtI,GACjCstI,EAAal8J,KAAK0R,EAAGC,GACrBwtC,EAAOn/C,KAAKk8J,GACZA,EAAe,CAACxqJ,EAAGC,GACnBsqJ,EAAS,EACTD,GAAU3mJ,CACX,CACF,CAID,OAHI4mJ,EAAS,GACX98G,EAAOn/C,KAAKk8J,GAEP/8G,CACT,CC3CO,SAASi9G,GAAc5X,EAAUrvI,EAAiBC,EAAQ/Y,EAAKgZ,GACpE,IAKIgnJ,EAAMpgK,EAAGqgK,EAAKC,EAAKnlJ,EAAIC,EAAImlJ,EAAKC,EAAKC,EAAKC,EAL1CC,EAAaxnJ,EACbynJ,EAAWznJ,EACX6mJ,EAAS,EACTzhJ,EAAI,EACJzS,EAAQqN,EAEZ,IAAKnZ,EAAImZ,EAAQnZ,EAAII,EAAKJ,GAAKoZ,EAAQ,CACrC,MAAMiC,EAAKnC,EAAgBlZ,GACrBsb,EAAKpC,EAAgBlZ,EAAI,QACpB4E,IAAPuW,IACFslJ,EAAMplJ,EAAKF,EACXulJ,EAAMplJ,EAAKF,EACXklJ,EAAMj2J,KAAKma,KAAKi8I,EAAMA,EAAMC,EAAMA,QACtB97J,IAAR27J,IACFhiJ,GAAK8hJ,EACLD,EAAO/1J,KAAK+1J,MAAMG,EAAME,EAAMD,EAAME,IAAQL,EAAMC,IAC9CF,EAAO7X,IACLhqI,EAAIyhJ,IACNA,EAASzhJ,EACToiJ,EAAa70J,EACb80J,EAAW5gK,GAEbue,EAAI,EACJzS,EAAQ9L,EAAIoZ,IAGhBinJ,EAAMC,EACNC,EAAME,EACND,EAAME,GAERvlJ,EAAKE,EACLD,EAAKE,CACN,CAED,OADAiD,GAAK+hJ,EACE/hJ,EAAIyhJ,EAAS,CAACl0J,EAAO9L,GAAK,CAAC2gK,EAAYC,EAChD,CCpBO,MAAMC,GAAa,CACxBl+G,KAAQ,EACR7nC,OAAU,GACV6Y,MAAS,EACTikC,IAAO,EACPkpG,OAAU,GACVC,QAAW,GACXC,WAAc,GACdC,YAAe,GACfC,OAAU,GA+mBZ,IAAAC,GA5mBA,cAAgCzC,GAO9B,WAAAxgK,CAAYqb,EAAWg1B,EAAWxzB,EAAYye,GAC5Cn2B,MAAMkW,EAAWg1B,EAAWxzB,EAAYye,GAMxCp7B,KAAKgjK,QAAU,KAMfhjK,KAAKqzE,MAAQ,GAMbrzE,KAAKszE,aAAe,EAMpBtzE,KAAKuzE,aAAe,EAMpBvzE,KAAKwzE,yBAAsBhtE,EAM3BxG,KAAKyzE,cAAgB,EAMrBzzE,KAAK2zE,eAAiB,KAKtB3zE,KAAKijK,WAAa,GAClBjjK,KAAKijK,WAAWphH,IAAoB,CAAC/kB,UAAW+kB,IAMhD7hD,KAAK4zE,iBAAmB,KAKxB5zE,KAAKkjK,aAAe,GAMpBljK,KAAK6zE,WAA8D,CAAE,EAKrE7zE,KAAKmjK,WAAa,GAMlBnjK,KAAKojK,SAAW,GAMhBpjK,KAAKqjK,SAAW,GAMhBrjK,KAAKsjK,WAAa,GAOlBtjK,KAAK6gK,6BAA0Br6J,CAChC,CAKD,MAAA44J,GACE,MAAM3B,EAAex4J,MAAMm6J,SAI3B,OAHA3B,EAAa0F,WAAanjK,KAAKmjK,WAC/B1F,EAAawF,WAAajjK,KAAKijK,WAC/BxF,EAAayF,aAAeljK,KAAKkjK,aAC1BzF,CACR,CAMD,QAAAnsF,CAAS18D,EAAU+qC,GACjB,MAAMw2B,EAAYn2E,KAAK2zE,eACjB0C,EAAcr2E,KAAK4zE,iBACnBiD,EAAY72E,KAAK6zE,WACvB,GAAmB,KAAf7zE,KAAKqzE,QAAiBwD,IAAeV,IAAcE,EACrD,OAGF,MAAM98D,EAAcvZ,KAAKuZ,YACzB,IAAIxX,EAAQwX,EAAYpY,OAExB,MAAMy6F,EAAehnF,EAAS8Z,UAC9B,IAAI5T,EAAkB,KAClBE,EAASpG,EAAS4a,YAEtB,GAC0B,SAAxBqnD,EAAUwzE,WACO,cAAhBzuD,GACiB,mBAAhBA,GACgB,WAAhBA,GACgB,gBAAhBA,EAsEG,CACL,IAAI2nE,EAAiB1sF,EAAUjW,SAAW,KAAO,GACjD,OAAQg7B,GACN,IAAK,QACL,IAAK,aACH9gF,EAC4D,EAExDyU,qBACJ,MACF,IAAK,aACHzU,EAC4D,EAExD66D,kBACJ,MACF,IAAK,SACH76D,EACwD,EAEpDwB,YACJ,MACF,IAAK,kBACHxB,EACiE,EAE7Dg7D,mBACJ96D,EAAS,EACT,MACF,IAAK,UACHF,EACyD,EAErD8b,uBACCigD,EAAUjW,UACb2iG,EAAe59J,KAAKmV,EAAgB,GAAK9a,KAAK2c,YAEhD3B,EAAS,EACT,MACF,IAAK,eACH,MAAMyZ,EACwD,EAE1DyhD,wBACJp7D,EAAkB,GAClB,IAAK,IAAIlZ,EAAI,EAAGuE,EAAKsuB,EAAetzB,OAAQS,EAAIuE,EAAIvE,GAAK,EAClDi1E,EAAUjW,UACb2iG,EAAe59J,KAAK8uB,EAAe7yB,EAAI,GAAK5B,KAAK2c,YAEnD7B,EAAgBnV,KAAK8uB,EAAe7yB,GAAI6yB,EAAe7yB,EAAI,IAE7D,GAA+B,IAA3BkZ,EAAgB3Z,OAClB,OAEF6Z,EAAS,EAIb,MAAMhZ,EAAMhC,KAAK+9J,2BAA2BjjJ,EAAiBE,GAC7D,GAAIhZ,IAAQD,EACV,OAEF,GACEwhK,IACCvhK,EAAMD,GAAS,GAAM+Y,EAAgB3Z,OAAS6Z,EAC/C,CACA,IAAIwoJ,EAAMzhK,EAAQ,EAClBwhK,EAAiBA,EAAe9rH,QAAO,CAACO,EAAGp2C,KACzC,MAAMioE,EACJtwD,EAAwB,GAAXiqJ,EAAM5hK,MAAYkZ,EAAgBlZ,EAAIoZ,IACnDzB,EAAwB,GAAXiqJ,EAAM5hK,GAAS,KAAOkZ,EAAgBlZ,EAAIoZ,EAAS,GAIlE,OAHK6uD,KACD25F,EAEG35F,CAAI,GAEd,CAED7pE,KAAKyjK,mBAED5sF,EAAU6zE,gBAAkB7zE,EAAU+zE,oBACxC5qJ,KAAKuxE,mBACHsF,EAAU6zE,eACV7zE,EAAU+zE,kBAER/zE,EAAU6zE,gBACZ1qJ,KAAK0/J,gBAAgB1/J,KAAKwM,MAAOxM,KAAKu/J,YAEpC1oF,EAAU+zE,mBACZ5qJ,KAAK4/J,kBAAkB5/J,KAAKwM,MAAOxM,KAAKw/J,aACxCx/J,KAAK29J,yBAAyBh4J,KAAK3F,KAAKy/J,aAAaz/J,KAAKwM,UAI9DxM,KAAK8+J,cAAclqJ,EAAU+qC,GAG7B,IAAI9K,EAAUgiC,EAAUhiC,QACxB,GACEA,GAAWwN,KACVw0B,EAAUl/D,MAAM,GAAK,GAAKk/D,EAAUl/D,MAAM,GAAK,GAChD,CACA,IAAI+rJ,EAAK7sF,EAAUhiC,QAAQ,GACvB+vF,EAAK/tD,EAAUhiC,QAAQ,GACvBgwF,EAAKhuD,EAAUhiC,QAAQ,GACvB8uH,EAAK9sF,EAAUhiC,QAAQ,GACvBgiC,EAAUl/D,MAAM,GAAK,IACvBitH,GAAMA,EACN++B,GAAMA,GAEJ9sF,EAAUl/D,MAAM,GAAK,IACvB+rJ,GAAMA,EACN7+B,GAAMA,GAERhwF,EAAU,CAAC6uH,EAAI9+B,EAAIC,EAAI8+B,EACxB,CAKD,MAAMvoI,EAAap7B,KAAKo7B,WACxBp7B,KAAKy9J,aAAa93J,KAAK,CACrBu5J,GACAn9J,EACAC,EACA,KACAqsB,IACAA,IACAA,IACA,EACA,EACA,EACAruB,KAAKwzE,oBACLxzE,KAAKyzE,cACL,CAAC,EAAG,GACJplD,SACA7nB,EACAxG,KAAK6gK,wBACLhsH,GAAWwN,GACPA,GACAxN,EAAQ/J,KAAI,SAAUsrD,GACpB,OAAOA,EAAIh7D,CACzB,MACUy7C,EAAU6zE,iBACV7zE,EAAU+zE,iBACZ5qJ,KAAKqzE,MACLrzE,KAAKojK,SACLpjK,KAAKsjK,WACLtjK,KAAKqjK,SACLrjK,KAAKszE,aACLtzE,KAAKuzE,aACLgwF,IAEF,MAAM5rJ,EAAQ,EAAIyjB,EAEZukI,EAAmB3/J,KAAKwM,MAAMswB,UAChC+5C,EAAU6zE,iBACZ1qJ,KAAKwM,MAAMswB,UAAY+kB,GACvB7hD,KAAK29J,yBAAyBh4J,KAAK3F,KAAKu/J,WAAWv/J,KAAKwM,SAE1DxM,KAAK29J,yBAAyBh4J,KAAK,CACjCu5J,GACAn9J,EACAC,EACA,KACAqsB,IACAA,IACAA,IACA,EACA,EACA,EACAruB,KAAKwzE,oBACLxzE,KAAKyzE,cACL,CAAC97D,EAAOA,GACR0W,SACA7nB,EACAxG,KAAK6gK,wBACLhsH,IACEgiC,EAAU6zE,iBACV7zE,EAAU+zE,iBACZ5qJ,KAAKqzE,MACLrzE,KAAKojK,SACLpjK,KAAKsjK,WACLtjK,KAAKqjK,SAAWxhH,GAAmB7hD,KAAKqjK,SACxCrjK,KAAKszE,aACLtzE,KAAKuzE,aACLgwF,IAGE1sF,EAAU6zE,iBACZ1qJ,KAAKwM,MAAMswB,UAAY6iI,EACvB3/J,KAAK29J,yBAAyBh4J,KAAK3F,KAAKu/J,WAAWv/J,KAAKwM,SAG1DxM,KAAKm/J,YAAYx/G,EAClB,KAxQC,CACA,IAAK7hC,GAAW9d,KAAKg+J,uBAAwBppJ,EAASyK,aACpD,OAEF,IAAIuR,EAEJ,GADA9V,EAAkBlG,EAAS2a,qBACP,cAAhBqsE,EACFhrE,EAAO,CAAC9V,EAAgB3Z,aACnB,GAAoB,mBAAhBy6F,EACThrE,EAAsE,EAEpE+F,eACG,GAAoB,WAAhBilE,EACThrE,EAA8D,EAC3D+F,UACA7yB,MAAM,EAAG,QACP,GAAoB,gBAAhB83F,EAAgC,CACzC,MAAM9qE,EACwD,EAE1DklD,WACJplD,EAAO,GACP,IAAK,IAAIhvB,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAC3CgvB,EAAKjrB,KAAKmrB,EAAMlvB,GAAG,GAEtB,CACD5B,KAAK8+J,cAAclqJ,EAAU+qC,GAC7B,MAAMqqG,EAASnzE,EAAUmzE,OACnBjzE,EAAYizE,OAASxjJ,EAAYqwE,EAAUE,UAEjD,IAAI6sF,EAAa,EACjB,IAAK,IAAIjkI,EAAI,EAAGkkI,EAAKjzI,EAAKzvB,OAAQw+B,EAAIkkI,IAAMlkI,EAAG,CAC7C,IAAImlB,EAEFA,EADEklG,EACOyX,GACPzX,EAAShqJ,KAAK2c,WACd7B,EACA8oJ,EACAhzI,EAAK+O,GACL3kB,GAGO,CAACF,EAAgBhX,MAAM8/J,EAAYhzI,EAAK+O,KAEnD,IAAK,IAAI3oB,EAAI,EAAG8sJ,EAAKh/G,EAAO3jD,OAAQ6V,EAAI8sJ,IAAM9sJ,EAAG,CAC/C,MAAM+sJ,EAAQj/G,EAAO9tC,GACrB,IAAIgtJ,EAAa,EACbxB,EAAWuB,EAAM5iK,OACrB,GAAiBqF,MAAbuwE,EAAwB,CAC1B,MAAM0T,EAAQs3E,GACZlrF,EAAUszE,SACV4Z,EACA,EACAA,EAAM5iK,OACN,GAEF6iK,EAAav5E,EAAM,GACnB+3E,EAAW/3E,EAAM,EAClB,CACD,IAAK,IAAI7oF,EAAIoiK,EAAYpiK,EAAI4gK,EAAU5gK,GAAKoZ,EAC1CzB,EAAY5T,KAAKo+J,EAAMniK,GAAImiK,EAAMniK,EAAI,IAEvC,MAAMI,EAAMuX,EAAYpY,OACxByiK,EAAahzI,EAAK+O,GAClB3/B,KAAKikK,WAAWliK,EAAOC,GACvBD,EAAQC,CACT,CACF,CACDhC,KAAKm/J,YAAYx/G,EACvB,CAoMG,CAKD,eAAA8jH,GACE,MAAMptF,EAAcr2E,KAAK4zE,iBACnBiD,EAAY72E,KAAK6zE,WACjBsC,EAAYn2E,KAAK2zE,eAEjBuwF,EAAYlkK,KAAKsjK,WACnBjtF,IACI6tF,KAAalkK,KAAKkjK,eACtBljK,KAAKkjK,aAAagB,GAAa,CAC7B1yF,YAAa6E,EAAY7E,YACzB+E,QAASF,EAAYE,QACrBG,eAAgBL,EAAYK,eAC5BxxB,UAAWmxB,EAAYnxB,UACvByxB,SAAUN,EAAYM,SACtBC,WAAYP,EAAYO,WACxBJ,SAAUH,EAAYG,YAI5B,MAAM2tF,EAAUnkK,KAAKojK,SACfe,KAAWnkK,KAAKmjK,aACpBnjK,KAAKmjK,WAAWgB,GAAW,CACzB1gH,KAAMozB,EAAUpzB,KAChBszB,UAAWF,EAAUE,WAAa50B,GAClC2nG,QAASjzE,EAAUizE,QACnB9yE,aAAcH,EAAUG,cAAgB50B,GACxCzqC,MAAOk/D,EAAUl/D,QAGrB,MAAMysJ,EAAUpkK,KAAKqjK,SACjBltF,IACIiuF,KAAWpkK,KAAKijK,aACpBjjK,KAAKijK,WAAWmB,GAAW,CACzBtnI,UAAWq5C,EAAUr5C,YAI5B,CAOD,UAAAmnI,CAAWliK,EAAOC,GAChB,MAAMq0E,EAAcr2E,KAAK4zE,iBACnBiD,EAAY72E,KAAK6zE,WAEjBqwF,EAAYlkK,KAAKsjK,WACjBa,EAAUnkK,KAAKojK,SACfgB,EAAUpkK,KAAKqjK,SACrBrjK,KAAKyjK,kBAEL,MAAMroI,EAAap7B,KAAKo7B,WAClBipI,EAAW5B,GAAW5rF,EAAUG,cAEhCthC,EAAU11C,KAAKuzE,aAAen4C,EAC9BwnB,EAAO5iD,KAAKqzE,MACZotE,EAAcpqE,EACfA,EAAYnxB,UAAYj5C,KAAKmP,IAAIy7D,EAAUl/D,MAAM,IAAO,EACzD,EAEJ3X,KAAKy9J,aAAa93J,KAAK,CACrBu5J,GACAn9J,EACAC,EACAqiK,EACAxtF,EAAUjW,SACVwjG,EACAvtF,EAAUszE,SACV/uH,EACAsa,EACAwuH,EACAzjB,EAAcrlH,EACdwnB,EACAuhH,EACA,IAEFnkK,KAAK29J,yBAAyBh4J,KAAK,CACjCu5J,GACAn9J,EACAC,EACAqiK,EACAxtF,EAAUjW,SACVwjG,EAAUviH,GAAmBuiH,EAC7BvtF,EAAUszE,SACV/uH,EACAsa,EACAwuH,EACAzjB,EAAcrlH,EACdwnB,EACAuhH,EACA,EAAI/oI,GAEP,CAMD,YAAAw2C,CAAaC,EAAWkvF,GACtB,IAAIlqF,EAAWV,EAAWE,EAC1B,GAAKxE,EAEE,CACL,MAAM2G,EAAgB3G,EAAUsD,UAC3BqD,GAIHrC,EAAYn2E,KAAK2zE,eACZwC,IACHA,EAAS,CAAsD,EAC/Dn2E,KAAK2zE,eAAiBwC,GAExBA,EAAUr5C,UAAY0wC,GACpBgL,EAActB,YAAcr1B,MAT9Bs0B,EAAY,KACZn2E,KAAK2zE,eAAiBwC,GAYxB,MAAMuC,EAAkB7G,EAAUuD,YAClC,GAAKsD,EAGE,CACLrC,EAAcr2E,KAAK4zE,iBACdyC,IACHA,EAAW,CAAwD,EACnEr2E,KAAK4zE,iBAAmByC,GAE1B,MAAMG,EAAWkC,EAAgBnB,cAC3Bb,EAAiBgC,EAAgBjB,oBACjCvyB,EAAYwzB,EAAgBt8D,WAC5Bw6D,EAAa8B,EAAgBZ,gBACnCzB,EAAYE,QAAUmC,EAAgBrB,cAAgBv1B,GACtDu0B,EAAYG,SAAWA,EAAWA,EAAS1yE,QAAUi+C,GACrDs0B,EAAYK,oBACSlwE,IAAnBkwE,EhL3d2B,EgL2d4BA,EACzDL,EAAYM,SAAW+B,EAAgBf,eAAiB31B,GACxDq0B,EAAYnxB,eACI1+C,IAAd0+C,EhLpbsB,EgLobuBA,EAC/CmxB,EAAYO,gBACKpwE,IAAfowE,EAA2B30B,GAAoB20B,EACjDP,EAAY7E,YAAchE,GACxBkL,EAAgBxB,YAAch1B,GAEjC,MAxBCm0B,EAAc,KACdr2E,KAAK4zE,iBAAmByC,EAyB1BQ,EAAY72E,KAAK6zE,WACjB,MAAMpwB,EAAOouB,EAAUsH,WAAav3B,GACpCc,GAAae,GACb,MAAMi2B,EAAY7H,EAAU0G,gBAC5B1B,EAAUjW,SAAWiR,EAAUm5E,cAC/Bn0E,EAAUpzB,KAAOA,EACjBozB,EAAUszE,SAAWt4E,EAAUk5E,cAC/Bl0E,EAAUwzE,UAAYx4E,EAAUg5E,eAChCh0E,EAAUE,UAAYlF,EAAUgI,eAChChD,EAAUmzE,OAASn4E,EAAUi5E,YAC7Bj0E,EAAUizE,QAAUj4E,EAAUo5E,aAC9Bp0E,EAAUG,aACRnF,EAAUkI,mBAAqB33B,GACjCy0B,EAAU6zE,eAAiB74E,EAAUq5E,oBACrCr0E,EAAU+zE,iBAAmB/4E,EAAUs5E,sBACvCt0E,EAAUhiC,QAAUg9B,EAAUu5E,cAAgB/oG,GAC9Cw0B,EAAUl/D,WAAsBnR,IAAdkzE,EAA0B,CAAC,EAAG,GAAKA,EAErD,MAAMN,EAAcvH,EAAUwH,aACxBC,EAAczH,EAAU0H,aACxBC,EAAqB3H,EAAUwG,oBAC/BoB,EAAe5H,EAAU/7B,cAC/B91C,KAAKqzE,MAAQxB,EAAUwD,WAAa,GACpCr1E,KAAKszE,kBAA+B9sE,IAAhB4yE,EAA4B,EAAIA,EACpDp5E,KAAKuzE,kBAA+B/sE,IAAhB8yE,EAA4B,EAAIA,EACpDt5E,KAAKwzE,yBACoBhtE,IAAvBgzE,GAA2CA,EAC7Cx5E,KAAKyzE,mBAAiCjtE,IAAjBizE,EAA6B,EAAIA,EAEtDz5E,KAAKsjK,WAAajtF,GACqB,iBAA3BA,EAAY7E,YAChB6E,EAAY7E,YACZ9oE,EAAO2tE,EAAY7E,cACvB6E,EAAYE,QACZF,EAAYK,eACZ,IACAL,EAAYnxB,UACZmxB,EAAYM,SACZN,EAAYO,WACZ,IACAP,EAAYG,SAAS19D,OACrB,IACA,GACJ9Y,KAAKojK,SACHvsF,EAAUpzB,KACVozB,EAAUl/D,OACTk/D,EAAUE,WAAa,MACvBF,EAAUmzE,QAAU,MACpBnzE,EAAUizE,SAAW,MACrBjzE,EAAUG,cAAgB,KAC7Bh3E,KAAKqjK,SAAWltF,EACkB,iBAAvBA,EAAUr5C,UACfq5C,EAAUr5C,UACV,IAAMp0B,EAAOytE,EAAUr5C,WACzB,EACL,MApGC98B,KAAKqzE,MAAQ,GAqGfrzE,KAAK6gK,wBAA0BE,CAChC,GCroBH,MAAMuD,GAAqB,CACzBhpF,OAAUipF,GACVC,QAAWC,GACX11J,MAAS21J,GACT7pF,WAAc8pF,GACd1uI,QAAWsuI,GACX7a,KAAQkb,IAqFV,IAAAC,GAlFA,MAOE,WAAA/kK,CAAYqb,EAAWg1B,EAAWxzB,EAAYye,GAK5Cp7B,KAAK8kK,WAAa3pJ,EAMlBnb,KAAK+kK,WAAa50H,EAMlBnwC,KAAKs7B,YAAcF,EAMnBp7B,KAAKglK,YAAcroJ,EAMnB3c,KAAKilK,kBAAoB,EAC1B,CAKD,MAAA7F,GACE,MAAM8F,EAAsB,CAAA,EAC5B,IAAK,MAAMC,KAAQnlK,KAAKilK,kBAAmB,CACzCC,EAAoBC,GAAQD,EAAoBC,IAAS,CAAA,EACzD,MAAMC,EAAWplK,KAAKilK,kBAAkBE,GACxC,IAAK,MAAME,KAAcD,EAAU,CACjC,MAAME,EAAqBF,EAASC,GAAYjG,SAChD8F,EAAoBC,GAAME,GAAcC,CACzC,CACF,CACD,OAAOJ,CACR,CAOD,UAAAxqF,CAAW1tC,EAAQu4H,GACjB,MAAMC,OAAuBh/J,IAAXwmC,EAAuBA,EAAOp0B,WAAa,IAC7D,IAAI6sJ,EAAUzlK,KAAKilK,kBAAkBO,QACrBh/J,IAAZi/J,IACFA,EAAU,CAAA,EACVzlK,KAAKilK,kBAAkBO,GAAaC,GAEtC,IAAIC,EAASD,EAAQF,GACrB,QAAe/+J,IAAXk/J,EAAsB,CAExBA,EAAS,IAAIC,EADOrB,GAAmBiB,IAErCvlK,KAAK8kK,WACL9kK,KAAK+kK,WACL/kK,KAAKglK,YACLhlK,KAAKs7B,aAEPmqI,EAAQF,GAAeG,CACxB,CACD,OAAOA,CACR,GC/EI,SAASE,GACd9qJ,EACAC,EACA/Y,EACAgZ,EACA4nC,EACAijH,EACA1b,EACAxyI,EACA8sC,EACAhB,EACAlgC,EACA3G,GAEA,IAAIK,EAAKnC,EAAgBC,GACrBmC,EAAKpC,EAAgBC,EAAS,GAC9BgC,EAAK,EACLC,EAAK,EACLuX,EAAgB,EAChBuxI,EAAW,EAEf,SAASC,IACPhpJ,EAAKE,EACLD,EAAKE,EAELD,EAAKnC,EADLC,GAAUC,GAEVkC,EAAKpC,EAAgBC,EAAS,GAC9B+qJ,GAAYvxI,EACZA,EAAgBtoB,KAAKma,MAAMnJ,EAAKF,IAAOE,EAAKF,IAAOG,EAAKF,IAAOE,EAAKF,GACrE,CACD,GACE+oJ,UACOhrJ,EAAS/Y,EAAMgZ,GAAU8qJ,EAAWvxI,EAAgBsxI,GAE7D,IAAIh5J,EACgB,IAAlB0nB,EAAsB,GAAKsxI,EAASC,GAAYvxI,EAClD,MAAMyxI,EAASlhJ,GAAK/H,EAAIE,EAAIpQ,GACtBo5J,EAASnhJ,GAAK9H,EAAIE,EAAIrQ,GAEtBq5J,EAAcnrJ,EAASC,EACvBmrJ,EAAcL,EACdM,EAAOP,EAASluJ,EAAQ8sC,EAAyBhB,EAAMb,EAAMr/B,GACnE,KAAOxI,EAAS/Y,EAAMgZ,GAAU8qJ,EAAWvxI,EAAgB6xI,GACzDL,IAEFl5J,EAAgC,IAAlB0nB,EAAsB,GAAK6xI,EAAON,GAAYvxI,EAC5D,MAAM/V,EAAOsG,GAAK/H,EAAIE,EAAIpQ,GACpB4R,EAAOqG,GAAK9H,EAAIE,EAAIrQ,GAG1B,IAAI28F,EACJ,GAAI5sF,EAAU,CACZ,MAAMypJ,EAAO,CAACL,EAAQC,EAAQznJ,EAAMC,GACpClH,GAAO8uJ,EAAM,EAAG,EAAG,EAAGzpJ,EAAUypJ,EAAMA,GACtC78D,EAAU68D,EAAK,GAAKA,EAAK,EAC7B,MACI78D,EAAUw8D,EAASxnJ,EAGrB,MAAMwB,EAAK/T,KAAK+T,GACVywB,EAAS,GACT61H,EAAgBJ,EAAclrJ,IAAWD,EAQ/C,IAAIwrJ,EAEJ,GAPAhyI,EAAgB,EAChBuxI,EAAWK,EACXlpJ,EAAKnC,EAHLC,EAASmrJ,GAIThpJ,EAAKpC,EAAgBC,EAAS,GAI1BurJ,EAAe,CACjBP,IAEAQ,EAAgBt6J,KAAKoc,MAAMnL,EAAKF,EAAIC,EAAKF,GACrCysF,IACF+8D,GAAiBA,EAAgB,GAAKvmJ,EAAKA,GAE7C,MAAM3I,GAAKmH,EAAOwnJ,GAAU,EACtB1uJ,GAAKmH,EAAOwnJ,GAAU,EAE5B,OADAx1H,EAAO,GAAK,CAACp5B,EAAGC,GAAI8uJ,EAAOP,GAAU,EAAGU,EAAe3jH,GAChDnS,CACR,CAKD,IAAK,IAAI7uC,EAAI,EAAGuE,GAFhBy8C,EAAOA,EAAKp/B,QAAQ,MAAO,MAEDriB,OAAQS,EAAIuE,GAAM,CAC1C4/J,IACA,IAAIvuJ,EAAQvL,KAAKoc,MAAMnL,EAAKF,EAAIC,EAAKF,GAIrC,GAHIysF,IACFhyF,GAASA,EAAQ,GAAKwI,EAAKA,QAEPxZ,IAAlB+/J,EAA6B,CAC/B,IAAI54J,EAAQ6J,EAAQ+uJ,EAEpB,GADA54J,GAASA,EAAQqS,GAAM,EAAIA,EAAKrS,GAASqS,EAAK,EAAIA,EAAK,EACnD/T,KAAKmP,IAAIzN,GAASw8I,EACpB,OAAO,IAEV,CACDoc,EAAgB/uJ,EAEhB,MAAMgvJ,EAAS5kK,EACf,IAAI6kK,EAAa,EACjB,KAAO7kK,EAAIuE,IAAMvE,EAAG,CAClB,MACMqG,EAAM0P,EAAQ8sC,EAAyBhB,EAAMb,EADrC4mD,EAAUrjG,EAAKvE,EAAI,EAAIA,GAC2B2hB,GAChE,GACExI,EAASC,EAAShZ,GAClB8jK,EAAWvxI,EAAgBsxI,EAASY,EAAax+J,EAAM,EAEvD,MAEFw+J,GAAcx+J,CACf,CACD,GAAIrG,IAAM4kK,EACR,SAEF,MAAME,EAAQl9D,EACV5mD,EAAK+nB,UAAUxkE,EAAKqgK,EAAQrgK,EAAKvE,GACjCghD,EAAK+nB,UAAU67F,EAAQ5kK,GAC3BiL,EACoB,IAAlB0nB,EACI,GACCsxI,EAASY,EAAa,EAAIX,GAAYvxI,EAC7C,MAAMld,EAAIyN,GAAK/H,EAAIE,EAAIpQ,GACjByK,EAAIwN,GAAK9H,EAAIE,EAAIrQ,GACvB4jC,EAAO9qC,KAAK,CAAC0R,EAAGC,EAAGmvJ,EAAa,EAAGjvJ,EAAOkvJ,IAC1Cb,GAAUY,CACX,CACD,OAAOh2H,CACT,CC9FA,MAAMiwE,G/OyIG,CAACjmG,IAAUA,KAAU,KAAW,K+OtInCmqH,GAAK,GAELC,GAAK,GAEL8+B,GAAK,GAELgD,GAAK,GAMX,SAASC,GAAgBC,GACvB,OAAOA,EAAuB,GAAGC,YACnC,CAEA,MAAMC,GAAW,IAAI5lH,OAEnB,IACEt4C,OAAOyiF,aAAa,MAAW,IAAMziF,OAAOyiF,aAAa,MACzDziF,OAAOyiF,aAAa,OAAW,IAAMziF,OAAOyiF,aAAa,OACzDziF,OAAOyiF,aAAa,OAAW,IAAMziF,OAAOyiF,aAAa,OACzDziF,OAAOyiF,aAAa,OAAW,IAAMziF,OAAOyiF,aAAa,OACzDziF,OAAOyiF,aAAa,QAAW,IAAMziF,OAAOyiF,aAAa,QAC3D,KASF,SAAS07E,GAAoBpkH,EAAMqkH,GAMjC,MALc,UAAVA,EACFA,EAAQF,GAAS14J,KAAKu0C,GAAQ,QAAU,OACrB,QAAVqkH,IACTA,EAAQF,GAAS14J,KAAKu0C,GAAQ,OAAS,SAElC6/G,GAAWwE,EACpB,CAQA,SAASC,GAAiBltF,EAAKmtF,EAAMvlK,GAKnC,OAJIA,EAAI,GACNo4E,EAAIr0E,KAAK,KAAM,IAEjBq0E,EAAIr0E,KAAKwhK,EAAM,IACRntF,CACT,CAsnCA,IAAAotF,GApnCA,MAOE,WAAAtnK,CAAY6c,EAAYye,EAAY8gE,EAAUuhE,GAK5Cz9J,KAAKk8F,SAAWA,EAMhBl8F,KAAKo7B,WAAaA,EAOlBp7B,KAAK2c,WAAaA,EAMlB3c,KAAKqnK,WAMLrnK,KAAKy9J,aAAeA,EAAaA,aAMjCz9J,KAAKuZ,YAAckkJ,EAAalkJ,YAMhCvZ,KAAKsnK,iBAAmB,GAMxBtnK,KAAKunK,mBjPzIA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GiP+IrBvnK,KAAK29J,yBAA2BF,EAAaE,yBAM7C39J,KAAK8zE,kBAAoB,KAMzB9zE,KAAKmyE,cAAgB,EAKrBnyE,KAAKijK,WAAaxF,EAAawF,YAAc,CAAA,EAK7CjjK,KAAKkjK,aAAezF,EAAayF,cAAgB,CAAA,EAKjDljK,KAAKmjK,WAAa1F,EAAa0F,YAAc,CAAA,EAM7CnjK,KAAKwnK,QAAU,GAMfxnK,KAAKgjK,QAAU,EAChB,CASD,WAAAyE,CAAY7kH,EAAMuhH,EAASC,EAASF,GAClC,MAAM38J,EAAMq7C,EAAOuhH,EAAUC,EAAUF,EACvC,GAAIlkK,KAAKgjK,QAAQz7J,GACf,OAAOvH,KAAKgjK,QAAQz7J,GAEtB,MAAM8uE,EAAc6tF,EAAYlkK,KAAKkjK,aAAagB,GAAa,KACzD/tF,EAAYiuF,EAAUpkK,KAAKijK,WAAWmB,GAAW,KACjDvtF,EAAY72E,KAAKmjK,WAAWgB,GAC5B/oI,EAAap7B,KAAKo7B,WAClBzjB,EAAQ,CACZk/D,EAAUl/D,MAAM,GAAKyjB,EACrBy7C,EAAUl/D,MAAM,GAAKyjB,GAEjBssI,EAAcrlK,MAAMC,QAAQsgD,GAC5BqkH,EAAQpwF,EAAUizE,QACpB2Y,GAAW5rF,EAAUizE,SACrBkd,GACE3kK,MAAMC,QAAQsgD,GAAQA,EAAK,GAAKA,EAChCi0B,EAAUE,WAAa50B,IAEvBs+F,EACJyjB,GAAa7tF,EAAYnxB,UAAYmxB,EAAYnxB,UAAY,EAEzDJ,EAAS4iH,EACX9kH,EACAA,EAAK/8B,MAAM,MAAM6+B,OAAOwiH,GAAkB,KAExCz3J,MAACA,EAAKC,OAAEA,EAAMq1C,OAAEA,EAAMC,QAAEA,EAAOC,WAAEA,GAAcL,GACnDiyB,EACA/xB,GAEI+pF,EAAcp/H,EAAQgxI,EACtB96F,EAAsB,GAEtB3N,GAAK62F,EAAc,GAAKl3H,EAAM,GAC9B4oB,GAAK7wB,EAAS+wI,GAAe9oI,EAAM,GAEnCiuC,EAAQ,CACZn2C,MAAOuoC,EAAI,EAAI/rC,KAAKuT,MAAMw4B,GAAK/rC,KAAKkZ,KAAK6yB,GACzCtoC,OAAQ6wB,EAAI,EAAIt0B,KAAKuT,MAAM+gB,GAAKt0B,KAAKkZ,KAAKob,GAC1ColB,oBAAqBA,GAEP,GAAZhuC,EAAM,IAAuB,GAAZA,EAAM,IACzBguC,EAAoBhgD,KAAK,QAASgS,GAEhCusJ,IACFv+G,EAAoBhgD,KAAK,cAAe0wE,EAAY7E,aACpD7rB,EAAoBhgD,KAAK,YAAa86I,GACtC96F,EAAoBhgD,KAAK,UAAW0wE,EAAYE,SAChD5wB,EAAoBhgD,KAAK,WAAY0wE,EAAYM,UACjDhxB,EAAoBhgD,KAAK,aAAc0wE,EAAYO,YACnDjxB,EAAoBhgD,KAAK,cAAe,CAAC0wE,EAAYG,WACrD7wB,EAAoBhgD,KAAK,iBAAkB0wE,EAAYK,iBAErD0tF,GACFz+G,EAAoBhgD,KAAK,YAAawwE,EAAUr5C,WAElD6oB,EAAoBhgD,KAAK,eAAgB,UACzCggD,EAAoBhgD,KAAK,YAAa,UACtC,MAAMgiK,EAAY,GAAMV,EACxB,IAAI5vJ,EAAI4vJ,EAAQp4B,EAAc84B,EAAYlnB,EAC1C,MAAMmnB,EAAqB,GACrBC,EAAmB,GACzB,IAIIC,EAJAvmH,EAAa,EACbwmH,EAAa,EACbC,EAAmB,EACnBC,EAAiB,EAErB,IAAK,IAAIrmK,EAAI,EAAGuE,EAAK2+C,EAAO3jD,OAAQS,EAAIuE,EAAIvE,GAAK,EAAG,CAClD,MAAMghD,EAAOkC,EAAOljD,GACpB,GAAa,OAATghD,EAAe,CACjBmlH,GAAcxmH,EACdA,EAAa,EACblqC,EAAI4vJ,EAAQp4B,EAAc84B,EAAYlnB,IACpCwnB,EACF,QACD,CACD,MAAMxkH,EAAOqB,EAAOljD,EAAI,IAAMi1E,EAAUpzB,KACpCA,IAASqkH,IACP5D,GACF0D,EAAmBjiK,KAAK,OAAQ89C,GAE9B2gH,GACFyD,EAAiBliK,KAAK,OAAQ89C,GAEhCqkH,EAAerkH,GAEjBlC,EAAat1C,KAAKyP,IAAI6lC,EAAYyD,EAAQgjH,IAC1C,MAAME,EAAiB,CACrBtlH,EACAvrC,EACEswJ,EAAY5iH,EAAOijH,GACnBf,GAASliH,EAAOijH,GAAoB/iH,EAAWgjH,IACjD,IAAOxnB,EAAcl/F,GAAcwmH,GAErC1wJ,GAAK0tC,EAAOijH,GACR9D,GACF0D,EAAmBjiK,KAAK,aAAcuiK,GAEpC9D,GACFyD,EAAiBliK,KAAK,WAAYuiK,KAElCF,CACH,CAID,OAHA3lK,MAAMwB,UAAU8B,KAAKzB,MAAMyhD,EAAqBiiH,GAChDvlK,MAAMwB,UAAU8B,KAAKzB,MAAMyhD,EAAqBkiH,GAChD7nK,KAAKgjK,QAAQz7J,GAAOq+C,EACbA,CACR,CAWD,qBAAAuiH,CACEh4J,EACAy0H,EACAC,EACA8+B,EACAgD,EACA3J,EACAC,GAEA9sJ,EAAQ4kE,YACR5kE,EAAQwkE,OAAOzwE,MAAMiM,EAASy0H,GAC9Bz0H,EAAQykE,OAAO1wE,MAAMiM,EAAS00H,GAC9B10H,EAAQykE,OAAO1wE,MAAMiM,EAASwzJ,GAC9BxzJ,EAAQykE,OAAO1wE,MAAMiM,EAASw2J,GAC9Bx2J,EAAQykE,OAAO1wE,MAAMiM,EAASy0H,GAC1Bo4B,IACFh9J,KAAKqnK,WAAqCrK,EAAgB,GAC1Dh9J,KAAK+jJ,MAAM5zI,IAET8sJ,IACFj9J,KAAKooK,gBACHj4J,EACR,GAEMA,EAAQ+kE,SAEX,CAsBD,gCAAAmzF,CACEC,EACAC,EACAjuH,EACAC,EACA9qC,EACAC,EACA2d,EACAC,EACAi4B,EACAC,EACA5oC,EACAjF,EACA6wJ,EACA3zH,EACA4zH,EACA9oH,GAIA,IAAItoC,EAAIijC,GAFRjtB,GAAW1V,EAAM,IAGbL,EAAIijC,GAFRjtB,GAAW3V,EAAM,IAIjB,MAAMqgC,EAAIvoC,EAAQ81C,EAAU+iH,EAAaA,EAAa/iH,EAAU91C,EAC1D8wB,EAAI7wB,EAAS81C,EAAU+iH,EAAcA,EAAc/iH,EAAU91C,EAC7Dg5J,EAAO7zH,EAAQ,GAAKmD,EAAIrgC,EAAM,GAAKk9B,EAAQ,GAC3C8zH,EAAO9zH,EAAQ,GAAKtU,EAAI5oB,EAAM,GAAKk9B,EAAQ,GAC3C+zH,EAAOvxJ,EAAIw9B,EAAQ,GACnBg0H,EAAOvxJ,EAAIu9B,EAAQ,GAazB,IAAI7+B,EAqCJ,OAhDIyyJ,GAA2B,IAAb7rJ,KAChBgoH,GAAG,GAAKgkC,EACRjC,GAAG,GAAKiC,EACRhkC,GAAG,GAAKikC,EACRhkC,GAAG,GAAKgkC,EACRhkC,GAAG,GAAK+jC,EAAOF,EACf/E,GAAG,GAAK9+B,GAAG,GACX8+B,GAAG,GAAKkF,EAAOF,EACfhC,GAAG,GAAKhD,GAAG,IAII,IAAb/mJ,GACF5G,EAAYiZ,GjPlZT,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GiPoZjBqrB,EACAC,EACA,EACA,EACA39B,GACC09B,GACAC,GAGH57B,GAAe3I,EAAW4uH,IAC1BjmH,GAAe3I,EAAW6uH,IAC1BlmH,GAAe3I,EAAW2tJ,IAC1BhlJ,GAAe3I,EAAW2wJ,IAC1BjsJ,GACEzO,KAAKwP,IAAImpH,GAAG,GAAIC,GAAG,GAAI8+B,GAAG,GAAIgD,GAAG,IACjC16J,KAAKwP,IAAImpH,GAAG,GAAIC,GAAG,GAAI8+B,GAAG,GAAIgD,GAAG,IACjC16J,KAAKyP,IAAIkpH,GAAG,GAAIC,GAAG,GAAI8+B,GAAG,GAAIgD,GAAG,IACjC16J,KAAKyP,IAAIkpH,GAAG,GAAIC,GAAG,GAAI8+B,GAAG,GAAIgD,GAAG,IACjCjmD,KAGFhmG,GACEzO,KAAKwP,IAAImtJ,EAAMA,EAAOF,GACtBz8J,KAAKwP,IAAIotJ,EAAMA,EAAOF,GACtB18J,KAAKyP,IAAIktJ,EAAMA,EAAOF,GACtBz8J,KAAKyP,IAAImtJ,EAAMA,EAAOF,GACtBjoD,IAGA8nD,IACFnxJ,EAAIpL,KAAKiZ,MAAM7N,GACfC,EAAIrL,KAAKiZ,MAAM5N,IAEV,CACLwxJ,WAAYzxJ,EACZ0xJ,WAAYzxJ,EACZ0xJ,WAAYhxH,EACZixH,WAAY1oI,EACZglB,QAASA,EACTC,QAASA,EACTshH,aAAc,CACZ1sJ,KAAMsmG,GAAU,GAChBrmG,KAAMqmG,GAAU,GAChBpmG,KAAMomG,GAAU,GAChBnmG,KAAMmmG,GAAU,GAChBr8G,MAAOs7C,GAETs/D,gBAAiBjpG,EACjB2B,MAAOA,EAEV,CAaD,mBAAAuxJ,CACE/4J,EACAg5J,EACAC,EACAz8C,EACA7/E,EACAkwH,EACAC,GAEA,MAAMwL,KAAgBzL,IAAmBC,GAEnCn0F,EAAM6jD,EAAWm6C,aACjBj3J,EAASM,EAAQN,OACjBw5J,EAAgBpM,EACjBA,EAAkB,GAAKtwC,EAAWh1G,MAAM,GAAM,EAC/C,EAiCJ,OA/BEmxD,EAAI1uD,KAAOivJ,GAAiBx5J,EAAOJ,MAAQ05J,GAC3CrgG,EAAIxuD,KAAO+uJ,GAAiB,GAC5BvgG,EAAIzuD,KAAOgvJ,GAAiBx5J,EAAOH,OAASy5J,GAC5CrgG,EAAIvuD,KAAO8uJ,GAAiB,IAGxBZ,GACFzoK,KAAKmoK,sBACHh4J,EACAy0H,GACAC,GACA8+B,GACAgD,GACV,EACA,GAGMthH,GACEl1C,EACAw8G,EAAW1N,gBACXnyE,EACAs8H,EACAz8C,EAAWpnE,QACXonE,EAAWnnE,QACXmnE,EAAWq8C,WACXr8C,EAAWs8C,WACXt8C,EAAWm8C,WACXn8C,EAAWo8C,WACXp8C,EAAWh1G,SAGR,CACR,CAMD,KAAAosI,CAAM5zI,GACJ,GAAInQ,KAAKqnK,WAAY,CACnB,MAAM5hF,EAAS9mE,GAAe3e,KAAKunK,mBAAoB,CAAC,EAAG,IACrD+B,EAAa,IAAMtpK,KAAKo7B,WAC9BjrB,EAAQs1C,OACRt1C,EAAQ0H,UAAU4tE,EAAO,GAAK6jF,EAAY7jF,EAAO,GAAK6jF,GACtDn5J,EAAQoH,OAAOvX,KAAKmyE,cACrB,CACDhiE,EAAQ8kE,OACJj1E,KAAKqnK,YACPl3J,EAAQ21C,SAEX,CAOD,eAAAsiH,CAAgBj4J,EAASmvJ,GACvBnvJ,EAAqB,YACoCmvJ,EAAY,GACrEnvJ,EAAQ+0C,UAAmCo6G,EAAY,GACvDnvJ,EAAQomE,QAAwC+oF,EAAY,GAC5DnvJ,EAAQwmE,SAA0C2oF,EAAY,GAC9DnvJ,EAAQymE,WAAoC0oF,EAAY,GACxDnvJ,EAAQumE,eAAwC4oF,EAAY,GAC5DnvJ,EAAQsmE,YAA0C6oF,EAAY,GAC/D,CAUD,4BAAAiK,CAA6B3mH,EAAMuhH,EAASD,EAAWE,GACrD,MAAMvtF,EAAY72E,KAAKmjK,WAAWgB,GAE5Bv+G,EAAQ5lD,KAAKynK,YAAY7kH,EAAMuhH,EAASC,EAASF,GAEjD7tF,EAAcr2E,KAAKkjK,aAAagB,GAChC9oI,EAAap7B,KAAKo7B,WAClB6rI,EAAQD,GACZ3kK,MAAMC,QAAQsgD,GAAQA,EAAK,GAAKA,EAChCi0B,EAAUE,WAAa50B,IAEnBkiH,EAAW5B,GAAW5rF,EAAUG,cAAgB50B,IAChDq+F,EACJpqE,GAAeA,EAAYnxB,UAAYmxB,EAAYnxB,UAAY,EASjE,MAAO,CACLU,MAAOA,EACPv4B,QAPc45I,GADFrhH,EAAMn2C,MAAQ2rB,EAAa,EAAIy7C,EAAUl/D,MAAM,IAC7B,GAAK,GAAMsvJ,GAASxmB,EAQlDnzH,QANC+2I,EAAWz+G,EAAMl2C,OAAU0rB,EAC5B,GAAK,GAAMipI,GAAY5jB,EAO1B,CAgBD,QAAA+oB,CACEr5J,EACAg5J,EACAnzJ,EACAynJ,EACA+K,EACAiB,EACAC,EACAxjG,GAGA,IAAI+N,EACAj0E,KAAK8zE,mBAAqBvxE,EAAOyT,EAAWhW,KAAKunK,oBACnDtzF,EAAmBj0E,KAAK8zE,mBAEnB9zE,KAAK8zE,oBACR9zE,KAAK8zE,kBAAoB,IAE3BG,EAAmB9mD,GACjBntB,KAAKuZ,YACL,EACAvZ,KAAKuZ,YAAYpY,OACjB,EACA6U,EACAhW,KAAK8zE,mBAEP61F,GAAsB3pK,KAAKunK,mBAAoBvxJ,IAEjD,IAAIpU,EAAI,EACR,MAAMuE,EAAKs3J,EAAat8J,OACxB,IACI+jJ,EACA73H,EACFC,EACAs8I,EACAC,EACAC,EACAC,EACAj3J,EACA8vC,EACAuhH,EACAD,EACAE,EAZEntJ,EAAI,EAaJ+yJ,EAAc,EACdC,EAAgB,EAChBC,EAAsB,KACtBC,EAAwB,KAC5B,MAAMC,EAAkBpqK,KAAKsnK,iBACvBt1F,EAAehyE,KAAKmyE,cACpBk4F,EACJp+J,KAAKiZ,MAAgD,KAA1CjZ,KAAKoc,OAAOrS,EAAU,GAAIA,EAAU,KAAc,KAEzDxJ,EAAwD,CAC5D2D,QAASA,EACTirB,WAAYp7B,KAAKo7B,WACjBze,WAAY3c,KAAK2c,WACjBC,SAAUo1D,GAKNs4F,EACJtqK,KAAKy9J,cAAgBA,GAAgBz9J,KAAKk8F,SAAW,EAAI,IAC3D,IAA0Dv8C,EACtDtoC,EAAGC,EAAGizJ,EACV,KAAO3oK,EAAIuE,GAAI,CACb,MAAMm5J,EAAc7B,EAAa77J,GAIjC,OAFE09J,EAAY,IAGZ,KAAKJ,GACHv/G,EACE2/G,EAAY,GAEdiL,EAAkBjL,EAAY,GACzB3/G,EAAQzqC,mBAGG1O,IAAdkjK,GACC5rJ,GAAW4rJ,EAAWa,EAAgBlrJ,eAIrCzd,EAFFA,EAA2B09J,EAAY,GAAM,EAL7C19J,EAA2B09J,EAAY,GASzC,MACF,KAAKJ,GACC8K,EAAcM,IAChBtqK,KAAK+jJ,MAAM5zI,GACX65J,EAAc,GAEZC,EAAgBK,IAClBn6J,EAAQ+kE,SACR+0F,EAAgB,GAEbD,GAAgBC,IACnB95J,EAAQ4kE,YACR60F,EAAQv7I,IACRw7I,EAAQx7I,OAERzsB,EACF,MACF,KAAKs9J,GACHjoJ,EAA2BqoJ,EAAY,GACvC,MAAMviJ,EAAKk3D,EAAiBh9D,GACtB+F,EAAKi3D,EAAiBh9D,EAAI,GAG1Ba,EAFKm8D,EAAiBh9D,EAAI,GAEhB8F,EACVhF,EAFKk8D,EAAiBh9D,EAAI,GAEhB+F,EACVoH,EAAInY,KAAKma,KAAKtO,EAAKA,EAAKC,EAAKA,GACnC5H,EAAQwkE,OAAO53D,EAAKqH,EAAGpH,GACvB7M,EAAQ6kE,IAAIj4D,EAAIC,EAAIoH,EAAG,EAAG,EAAInY,KAAK+T,IAAI,KACrCpe,EACF,MACF,KAAKs9J,GACH/uJ,EAAQ0kE,cACNjzE,EACF,MACF,KAAKs9J,GACHjoJ,EAA2BqoJ,EAAY,GACvCpa,EAAKoa,EAAY,GACjB,MAAM1qJ,EAEF0qJ,EAAY,GAEVp7F,EAAWo7F,EAAY,GACvB/7J,EAA2B,GAAtB+7J,EAAYn+J,OAAcm+J,EAAY,QAAK94J,EACtDgG,EAAMoI,SAAWA,EACjBpI,EAAMmzC,QAAUA,EACV/9C,KAAKwoK,IACTA,EAAgBxoK,GAAK,IAEvB,MAAMu3B,EAASixI,EAAgBxoK,GAC3B2B,EACFA,EAAG0wE,EAAkBh9D,EAAGiuI,EAAI,EAAG/rH,IAE/BA,EAAO,GAAK86C,EAAiBh9D,GAC7BkiB,EAAO,GAAK86C,EAAiBh9D,EAAI,GACjCkiB,EAAOh4B,OAAS,GAElB+iE,EAAS/qC,EAAQ3sB,KACf5K,EACF,MACF,KAAKs9J,GACHjoJ,EAA2BqoJ,EAAY,GACvCpa,EAA4Boa,EAAY,GACxCxsJ,EAEIwsJ,EAAY,GAIhBjyI,EAAiCiyI,EAAY,GAC7ChyI,EAAiCgyI,EAAY,GAC7C,IAAI5vJ,EAAgC4vJ,EAAY,GAChD,MAAMxyH,EAAiCwyH,EAAY,GAC7C/5G,EAAiC+5G,EAAY,GAC7C95G,EAAiC85G,EAAY,GAC7CpkB,EAAyCokB,EAAY,IAC3D,IAAI1iJ,EAAkC0iJ,EAAY,IAClD,MAAM3nJ,EACJ2nJ,EAAY,IAEd,IAAI7vJ,EAA+B6vJ,EAAY,IAC/C,MAAM/kF,EAEF+kF,EAAY,IAEV3tF,EAEF2tF,EAAY,IAGhB,IAAKxsJ,GAASwsJ,EAAYn+J,QAAU,GAAI,CAEtCyhD,EAA8B08G,EAAY,IAC1C6E,EAAiC7E,EAAY,IAC7C4E,EAAmC5E,EAAY,IAC/C8E,EAAiC9E,EAAY,IAC7C,MAAMkL,EAAkBxqK,KAAKupK,6BAC3B3mH,EACAuhH,EACAD,EACAE,GAEFtxJ,EAAQ03J,EAAgB5kH,MACxB05G,EAAY,GAAKxsJ,EACjB,MAAMsmE,EAAqCkmF,EAAY,IACvDjyI,GAAWm9I,EAAgBn9I,QAAU+rD,GAAep5E,KAAKo7B,WACzDkkI,EAAY,GAAKjyI,EACjB,MAAMisD,EAAqCgmF,EAAY,IACvDhyI,GAAWk9I,EAAgBl9I,QAAUgsD,GAAet5E,KAAKo7B,WACzDkkI,EAAY,GAAKhyI,EACjB5d,EAASoD,EAAMpD,OACf4vJ,EAAY,GAAK5vJ,EACjBD,EAAQqD,EAAMrD,MACd6vJ,EAAY,IAAM7vJ,CACnB,CAED,IAAI8zJ,GAKA1uH,GAAS61G,GAAgBE,GAJzB0U,EAAYn+J,OAAS,KACvBoiK,GAAwCjE,EAAY,KAIlDA,EAAYn+J,OAAS,IACvB0zC,GAAwCyqH,EAAY,IACpD5U,GAAyC4U,EAAY,IACrD1U,GAA2C0U,EAAY,MAEvDzqH,GAAUwN,GACVqoG,IAAiB,EACjBE,IAAmB,GAGjB1P,GAAkBmvB,EAEpBztJ,GAAYo1D,EACFkpE,GAAmBmvB,IAE7BztJ,GAAYo1D,GAEd,IAAIy4F,GAAa,EACjB,KAAOxzJ,EAAIiuI,EAAIjuI,GAAK,EAAG,CACrB,GACEssJ,IACAA,GAAekH,MAAgBh7J,EAAQzP,KAAKo7B,WAE5C,SAEF,MAAMuxF,EAAa3sH,KAAKqoK,iCACtBv1J,EAAMrD,MACNqD,EAAMpD,OACNukE,EAAiBh9D,GACjBg9D,EAAiBh9D,EAAI,GACrBxH,EACAC,EACA2d,EACAC,EACAi4B,EACAC,EACA5oC,EACAjF,EACA6wJ,EACA3zH,GACA61G,IAAkBE,GAClBjrG,GAGIz2B,EAAO,CACX/Y,EACAg5J,EACAr2J,EACA65G,EACA7/E,EACA49G,GACd,EACkB,KACJE,GACd,EACkB,MAEN,GAAI1kF,EAAe,CACjB,GAAsB,SAAlBqU,EAEF,SACK,GAAsB,aAAlBA,EAA8B,CAEvCrU,EAAcgtB,OAAOy5B,EAAWm6C,cAChC,QAChB,CAAqB,CACL,IAAI4D,EACAC,EACJ,GAAIh5F,EAAwB,CAC1B,MAAM1uE,EAAQiiJ,EAAKjuI,EACnB,IAAK06D,EAAuB1uE,GAAQ,CAElC0uE,EAAuB1uE,GAASimB,EAEhC,QACD,CAID,GAHAwhJ,EAAY/4F,EAAuB1uE,UAC5B0uE,EAAuB1uE,GAC9B0nK,EAAoB/D,GAAgB8D,GAChCxkG,EAAc+sB,SAAS03E,GACzB,QAEH,CACD,GAAIzkG,EAAc+sB,SAAS05B,EAAWm6C,cACpC,SAEE4D,IAEFxkG,EAAcgtB,OAAOy3E,GAErB3qK,KAAKkpK,oBAAoBhlK,MAAMlE,KAAM0qK,IAEvCxkG,EAAcgtB,OAAOy5B,EAAWm6C,aACjC,CACF,CACD9mK,KAAKkpK,oBAAoBhlK,MAAMlE,KAAMkpB,EACtC,GACCtnB,EACF,MACF,KAAKs9J,GACH,MAAMn9J,GAA+Bu9J,EAAY,GAC3Ct9J,GAA6Bs9J,EAAY,GACzC+E,GAAkC/E,EAAY,GAC9C1+F,GAAkC0+F,EAAY,GACpD8E,EAAiC9E,EAAY,GAC7C,MAAMnV,GAAkCmV,EAAY,GAC9CsL,GAA2CtL,EAAY,GACvD5pH,GAAiC4pH,EAAY,GACnD4E,EAAmC5E,EAAY,GAC/C,MAAM7e,GAAqC6e,EAAY,IACvD18G,EAA8B08G,EAAY,IAC1C6E,EAAiC7E,EAAY,IAC7C,MAAMuL,GAAkB,CACCvL,EAAY,IACZA,EAAY,KAG/BzoF,GAAY72E,KAAKmjK,WAAWgB,GAC5B1gH,GAAOozB,GAAUpzB,KACjBi2B,GAAY,CAChB7C,GAAUl/D,MAAM,GAAKizJ,GACrB/zF,GAAUl/D,MAAM,GAAKizJ,IAGvB,IAAIE,GACArnH,MAAQzjD,KAAKwnK,QACfsD,GAAe9qK,KAAKwnK,QAAQ/jH,KAE5BqnH,GAAe,CAAA,EACf9qK,KAAKwnK,QAAQ/jH,IAAQqnH,IAGvB,MAAMC,GAAanyE,GAAiB3kB,EAAkBlyE,GAAOC,GAAK,GAC5DgpK,GACJ/+J,KAAKmP,IAAIs+D,GAAU,IACnBj1B,GAAyBhB,GAAMb,EAAMkoH,IACvC,GAAIlqG,IAAYoqG,IAAcD,GAAY,CACxC,MAGMxgI,EAAQq7H,GACZ3xF,EACAlyE,GACAC,GACA,EACA4gD,GANCmoH,GAAaC,IAAchE,GAAoBpkH,EAFhC5iD,KAAKmjK,WAAWgB,GAASptF,WAUzCozE,GACAl+I,KAAKmP,IAAIs+D,GAAU,IACnBj1B,GACAhB,GACAqnH,GACAT,EAA4B,EAAIrqK,KAAKmyE,eAEvC84F,EAAW,GAAI1gI,EAAO,CAEpB,MAAMs8H,EAAyB,GAC/B,IAAI7vJ,EAAG8sJ,EAAI4C,EAAO9gH,EAAOslH,EACzB,GAAIhH,EACF,IAAKltJ,EAAI,EAAG8sJ,EAAKv5H,EAAMppC,OAAQ6V,EAAI8sJ,IAAM9sJ,EAAG,CAC1Ck0J,EAAO3gI,EAAMvzB,GACb0vJ,EAA+BwE,EAAK,GACpCtlH,EAAQ5lD,KAAKynK,YAAYf,EAAOvC,EAAS,GAAID,GAC7C72I,EACyB69I,EAAK,IAC3BxxF,GAAU,GAAK,GAAK+mE,GAAcA,IACrCnzH,EACE+2I,GAAWz+G,EAAMl2C,OACG,GAAlB,GAAM20J,IAAgB5jB,GAAc/mE,GAAU,GAC9CA,GAAU,GACZhkC,GACF,MAAMi3E,EAAa3sH,KAAKqoK,iCACtBziH,EAAMn2C,MACNm2C,EAAMl2C,OACNw7J,EAAK,GACLA,EAAK,GACLtlH,EAAMn2C,MACNm2C,EAAMl2C,OACN2d,EACAC,EACA,EACA,EACA49I,EAAK,GACLL,IACA,EACAxoH,IACA,EACA1C,GAEF,GACEumB,GACAA,EAAc+sB,SAAS05B,EAAWm6C,cAElC,MAAMmE,EAERpE,EAAuBlhK,KAAK,CAC1BwK,EACAg5J,EACAvjH,EACA+mE,EACA,EACA,KACA,MAEH,CAEH,GAAIy3C,EACF,IAAKptJ,EAAI,EAAG8sJ,EAAKv5H,EAAMppC,OAAQ6V,EAAI8sJ,IAAM9sJ,EAAG,CAC1Ck0J,EAAO3gI,EAAMvzB,GACb0vJ,EAA+BwE,EAAK,GACpCtlH,EAAQ5lD,KAAKynK,YAAYf,EAAOvC,EAASC,EAAS,IAClD/2I,EAAiC69I,EAAK,GACtC59I,EAAU+2I,GAAWz+G,EAAMl2C,OAASgmC,GACpC,MAAMi3E,EAAa3sH,KAAKqoK,iCACtBziH,EAAMn2C,MACNm2C,EAAMl2C,OACNw7J,EAAK,GACLA,EAAK,GACLtlH,EAAMn2C,MACNm2C,EAAMl2C,OACN2d,EACAC,EACA,EACA,EACA49I,EAAK,GACLL,IACA,EACAxoH,IACA,EACA1C,GAEF,GACEumB,GACAA,EAAc+sB,SAAS05B,EAAWm6C,cAElC,MAAMmE,EAERpE,EAAuBlhK,KAAK,CAC1BwK,EACAg5J,EACAvjH,EACA+mE,EACA,EACA,KACA,MAEH,CAECzmD,GACFA,EAAc54D,KAAKu5J,EAAuB/7H,IAAI87H,KAEhD,IAAK,IAAIhlK,EAAI,EAAGuE,EAAK0gK,EAAuB1lK,OAAQS,EAAIuE,IAAMvE,EAC5D5B,KAAKkpK,oBAAoBhlK,MAAMlE,KAAM6mK,EAAuBjlK,GAE/D,CACF,GACCA,EACF,MACF,KAAKs9J,GACH,QAAwB14J,IAApBijK,EAA+B,CACjC9pH,EACE2/G,EAAY,GAEd,MAAM7uH,EAASg5H,EAAgB9pH,EAAS4qH,GACxC,GAAI95H,EACF,OAAOA,CAEV,GACC7uC,EACF,MACF,KAAKs9J,GACCoL,EACFN,IAEAhqK,KAAK+jJ,MAAM5zI,KAEXvO,EACF,MACF,KAAKs9J,GAYH,IAXAjoJ,EAA2BqoJ,EAAY,GACvCpa,EAA4Boa,EAAY,GACxCjoJ,EAAI48D,EAAiBh9D,GACrBK,EAAI28D,EAAiBh9D,EAAI,GACzB6yJ,EAAUzyJ,EAAI,GAAO,EACrB0yJ,EAAUzyJ,EAAI,GAAO,EACjBwyJ,IAAWF,GAASG,IAAWF,IACjC15J,EAAQwkE,OAAOt9D,EAAGC,GAClBsyJ,EAAQE,EACRD,EAAQE,GAEL9yJ,GAAK,EAAGA,EAAIiuI,EAAIjuI,GAAK,EACxBI,EAAI48D,EAAiBh9D,GACrBK,EAAI28D,EAAiBh9D,EAAI,GACzB6yJ,EAAUzyJ,EAAI,GAAO,EACrB0yJ,EAAUzyJ,EAAI,GAAO,EACjBL,GAAKiuI,EAAK,GAAK4kB,IAAWF,GAASG,IAAWF,IAChD15J,EAAQykE,OAAOv9D,EAAGC,GAClBsyJ,EAAQE,EACRD,EAAQE,KAGVnoK,EACF,MACF,KAAKs9J,GACHgL,EAAsB5K,EACtBt/J,KAAKqnK,WAAa/H,EAAY,GAE1B0K,IACFhqK,KAAK+jJ,MAAM5zI,GACX65J,EAAc,EACVC,IACF95J,EAAQ+kE,SACR+0F,EAAgB,IAIpB95J,EAAQ2sB,UAEJwiI,EAAY,KAEd19J,EACF,MACF,KAAKs9J,GACHiL,EAAwB7K,EACpB2K,IACF95J,EAAQ+kE,SACR+0F,EAAgB,GAElBjqK,KAAKooK,gBAAgBj4J,EAAkC,KACrDvO,EACF,MACF,KAAKs9J,GACCoL,EACFL,IAEA95J,EAAQ+kE,WAERtzE,EACF,MACF,UACIA,EAGP,CACGooK,GACFhqK,KAAK+jJ,MAAM5zI,GAET85J,GACF95J,EAAQ+kE,QAGX,CAUD,OAAAi2F,CACEh7J,EACAg5J,EACAnzJ,EACAg8D,EACAw2F,EACAtiG,GAEAlmE,KAAKmyE,cAAgBH,EACrBhyE,KAAKwpK,SACHr5J,EACAg5J,EACAnzJ,EACAhW,KAAKy9J,aACL+K,OACAhiK,OACAA,EACA0/D,EAEH,CAYD,mBAAAklG,CACEj7J,EACA6F,EACAg8D,EACAy3F,EACAC,GAGA,OADA1pK,KAAKmyE,cAAgBH,EACdhyE,KAAKwpK,SACVr5J,EACA,EACA6F,EACAhW,KAAK29J,0BACL,EACA8L,EACAC,EAEH,GCptCH,MAAM2B,GAAQ,CAAC,UAAW,SAAU,aAAc,QAAS,OAAQ,WAgWnE,MAAMC,GAA6B,CAAA,EAS5B,SAASC,GAAmBvjJ,GACjC,QAA2CxhB,IAAvC8kK,GAA2BtjJ,GAC7B,OAAOsjJ,GAA2BtjJ,GAGpC,MAAMtU,EAAgB,EAATsU,EAAa,EACpBwjJ,EAAgBxjJ,EAASA,EACzByjJ,EAAY,IAAIppK,MAAMmpK,EAAgB,GAC5C,IAAK,IAAI5pK,EAAI,EAAGA,GAAKomB,IAAUpmB,EAC7B,IAAK,IAAI0iB,EAAI,EAAGA,GAAK0D,IAAU1D,EAAG,CAChC,MAAM87B,EAAax+C,EAAIA,EAAI0iB,EAAIA,EAC/B,GAAI87B,EAAaorH,EACf,MAEF,IAAIhkJ,EAAWikJ,EAAUrrH,GACpB54B,IACHA,EAAW,GACXikJ,EAAUrrH,GAAc54B,GAE1BA,EAAS7hB,KAA4C,IAArCqiB,EAASpmB,GAAK8R,GAAQsU,EAAS1D,IAAU,GACrD1iB,EAAI,GACN4lB,EAAS7hB,KAA4C,IAArCqiB,EAASpmB,GAAK8R,GAAQsU,EAAS1D,IAAU,GAEvDA,EAAI,IACNkD,EAAS7hB,KAA4C,IAArCqiB,EAASpmB,GAAK8R,GAAQsU,EAAS1D,IAAU,GACrD1iB,EAAI,GACN4lB,EAAS7hB,KAA4C,IAArCqiB,EAASpmB,GAAK8R,GAAQsU,EAAS1D,IAAU,GAG9D,CAGH,MAAMwmF,EAAa,GACnB,IAAK,IAAIlpG,EAAI,EAAGuE,EAAKslK,EAAUtqK,OAAQS,EAAIuE,IAAMvE,EAC3C6pK,EAAU7pK,IACZkpG,EAAWnlG,QAAQ8lK,EAAU7pK,IAKjC,OADA0pK,GAA2BtjJ,GAAU8iF,EAC9BA,CACT,CAEA,IAAA4gE,GAlZA,MAaE,WAAA5rK,CACEqwC,EACAxzB,EACAye,EACA8gE,EACAyvE,EACA9X,GAMA7zJ,KAAK+kK,WAAa50H,EAMlBnwC,KAAKi8F,UAAYC,EAMjBl8F,KAAKs7B,YAAcF,EAMnBp7B,KAAKglK,YAAcroJ,EAMnB3c,KAAKk0J,cAAgBL,EAMrB7zJ,KAAK4rK,mBAAqB,GAM1B5rK,KAAK6rK,qBAAuB,KAM5B7rK,KAAK8rK,uBlPpDA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GkPsDrB9rK,KAAK+rK,iBAAiBJ,EACvB,CAMD,IAAA7uF,CAAK3sE,EAAS6F,GACZ,MAAMg2J,EAAiBhsK,KAAKisK,cAAcj2J,GAC1C7F,EAAQ4kE,YACR5kE,EAAQwkE,OAAOq3F,EAAe,GAAIA,EAAe,IACjD77J,EAAQykE,OAAOo3F,EAAe,GAAIA,EAAe,IACjD77J,EAAQykE,OAAOo3F,EAAe,GAAIA,EAAe,IACjD77J,EAAQykE,OAAOo3F,EAAe,GAAIA,EAAe,IACjD77J,EAAQ2sE,MACT,CAOD,gBAAAivF,CAAiBJ,GACf,IAAK,MAAM3+H,KAAU2+H,EAAiB,CACpC,IAAIO,EAAYlsK,KAAK4rK,mBAAmB5+H,QACtBxmC,IAAd0lK,IACFA,EAAY,CAAA,EACZlsK,KAAK4rK,mBAAmB5+H,GAAUk/H,GAEpC,MAAMC,EAAsBR,EAAgB3+H,GAC5C,IAAK,MAAMu4H,KAAe4G,EAAqB,CAC7C,MAAM1O,EAAe0O,EAAoB5G,GACzC2G,EAAU3G,GAAe,IAAI6G,GAC3BpsK,KAAKglK,YACLhlK,KAAKs7B,YACLt7B,KAAKi8F,UACLwhE,EAEH,CACF,CACF,CAMD,YAAA4O,CAAaH,GACX,IAAK,MAAMl/H,KAAUhtC,KAAK4rK,mBAAoB,CAC5C,MAAMU,EAAatsK,KAAK4rK,mBAAmB5+H,GAC3C,IAAK,IAAIprC,EAAI,EAAGuE,EAAK+lK,EAAU/qK,OAAQS,EAAIuE,IAAMvE,EAC/C,GAAIsqK,EAAUtqK,KAAM0qK,EAClB,OAAO,CAGZ,CACD,OAAO,CACR,CAYD,0BAAAhtH,CACEloC,EACAuF,EACAC,EACA2iC,EACA3jC,EACA2wJ,GAGA,MAAMC,EAA6B,GADnCjtH,EAAetzC,KAAKiZ,MAAMq6B,IACa,EACjCvpC,EAAYiZ,GAChBjvB,KAAK8rK,uBACLvsH,EAAe,GACfA,EAAe,GACf,EAAI5iC,GACH,EAAIA,GACJC,GACAxF,EAAW,IACXA,EAAW,IAGRq1J,GAAczsK,KAAK6rK,qBACrBY,IACFzsK,KAAK6rK,qBAAuBr8J,GAC1Bg9J,EACAA,OACAhmK,EACA,CAACuM,oBAAoB,KAGzB,MAAM5C,EAAUnQ,KAAK6rK,qBAerB,IAAInC,EAZFv5J,EAAQN,OAAOJ,QAAU+8J,GACzBr8J,EAAQN,OAAOH,SAAW88J,GAE1Br8J,EAAQN,OAAOJ,MAAQ+8J,EACvBr8J,EAAQN,OAAOH,OAAS88J,GACdC,GACVt8J,EAAQC,UAAU,EAAG,EAAGo8J,EAAaA,QAOZhmK,IAAvBxG,KAAKk0J,gBACPwV,EhPTG,CAACjvJ,IAAUA,KAAU,KAAW,KgPUnCf,GAAiBgwJ,EAAWtyJ,GAC5BuC,GACE+vJ,EACA/sJ,GAAc3c,KAAKk0J,cAAgB30G,GACnCmqH,IAIJ,MAAMh2E,EAAU63E,GAAmBhsH,GAEnC,IAAIgmH,EAOJ,SAASkE,EAAgB9pH,EAAS/qC,GAChC,MAAMhB,EAAYzD,EAAQ8C,aACxB,EACA,EACAu5J,EACAA,GACArqK,KACF,IAAK,IAAIP,EAAI,EAAGuE,EAAKutF,EAAQvyF,OAAQS,EAAIuE,EAAIvE,IAC3C,GAAIgS,EAAU8/E,EAAQ9xF,IAAM,EAAG,CAC7B,IACG2qK,GACgB,UAAhBhH,GAA2C,SAAhBA,GAC5BgH,EAAoB7mK,SAASi6C,GAC7B,CACA,MAAM+3G,GAAOhkE,EAAQ9xF,GAAK,GAAK,EACzByV,EAAIkoC,EAAgBm4G,EAAM8U,EAC1Bl1J,EAAIioC,GAAiBm4G,EAAM8U,EAAe,GAC1C/7H,EAAS70B,EAAS+jC,EAAS/qC,EAAUyC,EAAIA,EAAIC,EAAIA,GACvD,GAAIm5B,EACF,OAAOA,CAEV,CACDtgC,EAAQC,UAAU,EAAG,EAAGo8J,EAAaA,GACrC,KACD,CAGJ,CAGD,MAAM/qD,EAAK/6G,OAAOC,KAAK3G,KAAK4rK,oBAAoB9gI,IAAIX,QAGpD,IAAIvoC,EAAG0iB,EAAG4nJ,EAAWQ,EAAUj8H,EAC/B,IAHAgxE,EAAGntF,KAAKtzB,GAGHY,EAAI6/G,EAAGtgH,OAAS,EAAGS,GAAK,IAAKA,EAAG,CACnC,MAAM4jK,EAAY/jD,EAAG7/G,GAAGgX,WAExB,IADAszJ,EAAYlsK,KAAK4rK,mBAAmBpG,GAC/BlhJ,EAAI+mJ,GAAMlqK,OAAS,EAAGmjB,GAAK,IAAKA,EAGnC,GAFAihJ,EAAc8F,GAAM/mJ,GACpBooJ,EAAWR,EAAU3G,QACJ/+J,IAAbkmK,IACFj8H,EAASi8H,EAAStB,oBAChBj7J,EACA6F,EACA4G,EACA6sJ,EACAC,GAEEj5H,GACF,OAAOA,CAId,CAEF,CAMD,aAAAw7H,CAAcj2J,GACZ,MAAMm6B,EAAYnwC,KAAK+kK,WACvB,IAAK50H,EACH,OAAO,KAET,MAAM/1B,EAAO+1B,EAAU,GACjB91B,EAAO81B,EAAU,GACjB71B,EAAO61B,EAAU,GACjB51B,EAAO41B,EAAU,GACjB67H,EAAiB,CAAC5xJ,EAAMC,EAAMD,EAAMG,EAAMD,EAAMC,EAAMD,EAAMD,GAElE,OADA8S,GAAY6+I,EAAgB,EAAG,EAAG,EAAGh2J,EAAWg2J,GACzCA,CACR,CAKD,OAAAlnK,GACE,OAAOA,EAAQ9E,KAAK4rK,mBACrB,CAYD,OAAAT,CACEh7J,EACAg5J,EACAnzJ,EACAg8D,EACAw2F,EACAmE,EACAzmG,GAGA,MAAMu7C,EAAK/6G,OAAOC,KAAK3G,KAAK4rK,oBAAoB9gI,IAAIX,QAWpD,IAAIvoC,EAAGuE,EAAIme,EAAG2G,EAAIw6I,EAASC,EAI3B,IAdAjkD,EAAGntF,KAAKtzB,GAIJhB,KAAK+kK,aACP50J,EAAQs1C,OACRzlD,KAAK88E,KAAK3sE,EAAS6F,IAGrB22J,EAAeA,GAA8BtB,GAEzCnlG,GACFu7C,EAAGjY,UAEA5nG,EAAI,EAAGuE,EAAKs7G,EAAGtgH,OAAQS,EAAIuE,IAAMvE,EAAG,CACvC,MAAM4jK,EAAY/jD,EAAG7/G,GAAGgX,WAExB,IADA6sJ,EAAUzlK,KAAK4rK,mBAAmBpG,GAC7BlhJ,EAAI,EAAG2G,EAAK0hJ,EAAaxrK,OAAQmjB,EAAI2G,IAAM3G,EAAG,CAEjDohJ,EAASD,EADWkH,EAAaroJ,SAElB9d,IAAXk/J,GACFA,EAAOyF,QACLh7J,EACAg5J,EACAnzJ,EACAg8D,EACAw2F,EACAtiG,EAGL,CACF,CAEGlmE,KAAK+kK,YACP50J,EAAQ21C,SAEX,GC/VI,MAAM8mH,GAAwB,GAgB9B,SAASC,GACdn5J,EACAgQ,EACAy/C,EACA+3B,EACA1hF,EACAmD,EACAC,GAEA,MAEMzM,EAAUX,GAFFkE,EAAK,GAAKk5J,GACTl5J,EAAK,GAAKk5J,IAEzBz8J,EAAQwtE,uBAAwB,EAChC,MAAM9tE,EAASM,EAAQN,OACjBq0D,EAAW,IAAIuY,GACnBtsE,EACAy8J,GACApzJ,EACA,KACAoD,GAEIkwJ,EAAe3pG,EAAShiE,OAExB4rK,EAAc9gK,KAAKuT,MAAM,SAAwBstJ,GACjDE,EAAmB,CAAA,EACzB,IAAK,IAAIprK,EAAI,EAAGA,GAAKkrK,IAAgBlrK,EAAG,CACtC,MAAM+9C,EAAUwjB,EAASvhE,EAAI,GACvBqrK,EAAuBttH,EAAQrqC,oBAAsB4lF,EAC3D,IAAK+xE,EACH,SAEF,IAAIt3J,EAASs3J,EAAqBttH,EAAShjC,GAC3C,IAAKhH,EACH,SAEGtT,MAAMC,QAAQqT,KACjBA,EAAS,CAACA,IAEZ,MACMs0B,GADQroC,EAAImrK,GACEn0J,SAAS,IAAIs0J,SAAS,EAAG,UAC7C,IAAK,IAAI5oJ,EAAI,EAAG2G,EAAKtV,EAAOxU,OAAQmjB,EAAI2G,IAAM3G,EAAG,CAC/C,MAAM6oJ,EAAgBx3J,EAAO2O,GACvB1P,EAAWu4J,EAAc53F,qBAAd43F,CAAoCxtH,GACrD,IAAK/qC,IAAakJ,GAAWtE,EAAQ5E,EAASyK,aAC5C,SAEF,MAAM9O,EAAQ48J,EAAcp4J,QACtBkgE,EAAO1kE,EAAM4kE,UACfF,GACFA,EAAK+wE,SAAS/7G,GAEhB,MAAMirC,EAAS3kE,EAAM6kE,YACjBF,IACFA,EAAO8wE,SAAS/7G,GAChBirC,EAAOuB,YAAY,OAErBlmE,EAAM84I,aAAQ7iJ,GACd,MAAMsM,EAAQq6J,EAAc3xI,WAC5B,GAAI1oB,EAAO,CACT,MAAMs6J,EAAUt6J,EAAMywI,eACtB,IAAK6pB,EACH,SAGF,MAAMC,EAAa79J,GACjB49J,EAAQ,GACRA,EAAQ,QACR5mK,EACA,CAACgkC,OAAO,IAEJhQ,EAAM6yI,EAAWx9J,OACvBw9J,EAAWvwI,UAAYmN,EACvBojI,EAAWtwI,SAAS,EAAG,EAAGvC,EAAI/qB,MAAO+qB,EAAI9qB,QACzCa,EAAMurB,SACJ,IAAIkrH,GAAK,CACPxsH,IAAKA,EACLpN,OAAQta,EAAMolE,YACdmvE,aAAc,SACdE,aAAc,SACdxsI,OAAQjI,EAAMslE,YACdtrC,QAAS,EACTp5B,KAAMZ,EAAMa,UACZgE,MAAO7E,EAAM+hG,WACbj4F,SAAU9J,EAAMgjC,cAChBolG,eAAgBpoI,EAAMulE,sBAG3B,CACD,MAAMrrC,EAASz8B,EAAMs9B,aAAe,EACpC,IAAIy/H,EAAiBN,EAAiBhgI,GACjCsgI,IACHA,EAAiB,CAAA,EACjBN,EAAiBhgI,GAAUsgI,EAC3BA,EAAwB,QAAI,GAC5BA,EAAuB,OAAI,GAC3BA,EAA2B,WAAI,GAC/BA,EAAsB,MAAI,IAE5B,MAAMvtK,EAAO6U,EAAS8Z,UACtB,GAAa,uBAAT3uB,EAA+B,CACjC,MAAMy1E,EAC8D,EAEhEoiB,8BACJ,IAAK,IAAIh2F,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAAG,CACnD,MAAMgT,EAAW4gE,EAAW5zE,GAC5B0rK,EAAe14J,EAAS8Z,UAAUlL,QAAQ,QAAS,KAAK7d,KACtDiP,EACArE,EAEH,CACT,MACQ+8J,EAAevtK,EAAKyjB,QAAQ,QAAS,KAAK7d,KAAKiP,EAAUrE,EAE5D,CACF,CAED,MAAMg9J,EAAa7mK,OAAOC,KAAKqmK,GAAkBliI,IAAIX,QAAQ7V,KAAKtzB,GAClE,IAAK,IAAIY,EAAI,EAAGuE,EAAKonK,EAAWpsK,OAAQS,EAAIuE,IAAMvE,EAAG,CACnD,MAAM0rK,EAAiBN,EAAiBO,EAAW3rK,IACnD,IAAK,MAAM7B,KAAQutK,EAAgB,CACjC,MAAME,EAAeF,EAAevtK,GACpC,IAAK,IAAIukB,EAAI,EAAG2G,EAAKuiJ,EAAarsK,OAAQmjB,EAAI2G,EAAI3G,GAAK,EAAG,CACxD4/C,EAAS9uD,SAASo4J,EAAalpJ,EAAI,IACnC,IAAK,IAAIE,EAAI,EAAGipJ,EAAK/pJ,EAAWviB,OAAQqjB,EAAIipJ,IAAMjpJ,EAChD0/C,EAASoR,aAAa5xD,EAAWc,IACjC0/C,EAASkM,aAAao9F,EAAalpJ,GAEtC,CACF,CACF,CACD,OAAOnU,EAAQ8C,aAAa,EAAG,EAAGpD,EAAOJ,MAAOI,EAAOH,OACzD,CAYO,SAASg+J,GAAUpwH,EAAO6lB,EAAUvvD,GAEzC,MAAM+5J,EAAiB,GACvB,GAAI/5J,EAAW,CACb,MAAMyD,EAAIpL,KAAKuT,MAAMvT,KAAKiZ,MAAMo4B,EAAM,IAAMsvH,IACtCt1J,EAAIrL,KAAKuT,MAAMvT,KAAKiZ,MAAMo4B,EAAM,IAAMsvH,IAItC3pK,EAGJ,GAFC6gB,GAAMzM,EAAG,EAAGzD,EAAUnE,MAAQ,GAC7BqU,GAAMxM,EAAG,EAAG1D,EAAUlE,OAAS,GAAKkE,EAAUnE,OAE5C2U,EAAIxQ,EAAUzR,KAAKc,GACnBq8B,EAAI1rB,EAAUzR,KAAKc,EAAQ,GAE3BrB,EADIgS,EAAUzR,KAAKc,EAAQ,GACnB,KAAOq8B,EAAI,IAAMlb,GACzB2oJ,EAAc9gK,KAAKuT,MAAM,SAAwB2jD,EAAShiE,QAC5DS,GAAKA,EAAImrK,GAAgB,GAC3BY,EAAehoK,KAAKw9D,EAASvhE,EAAImrK,EAAc,GAElD,CACD,OAAOY,CACT,CC4lBA,IAAAC,GA5uBA,cAAwCrvD,GAItC,WAAAz+G,CAAY+tK,GACV5oK,MAAM4oK,GAGN7tK,KAAK8tK,6BAA+B9tK,KAAK+tK,wBAAwB7mK,KAAKlH,MAKtEA,KAAKguK,wBAKLhuK,KAAKiuK,uBAAyB,KAK9BjuK,KAAKkuK,kBAAoB,KAMzBluK,KAAKyzG,mBAAqB,EAM1BzzG,KAAKmuK,oBAAsB9/I,IAM3BruB,KAAKqgH,gBlPyGA,CAAC5lG,IAAUA,KAAU,KAAW,KkPnGrCza,KAAKouK,uBlPmGA,CAAC3zJ,IAAUA,KAAU,KAAW,KkP7FrCza,KAAKquK,kBAMLruK,KAAKsuK,gBAAkB,KAMvBtuK,KAAKuuK,oBAAsB,KAM3BvuK,KAAKwuK,qBAAuB,KAM5BxuK,KAAKyuK,aAAe,KAMpBzuK,KAAK0uK,oBAAqB,EAK1B1uK,KAAKw8G,uBAAyB,KAM9Bx8G,KAAK2uK,UAAW,EAMhB3uK,KAAK4uK,oBAAsB,KAM3B5uK,KAAK8iJ,SAAW,CACjB,CAOD,YAAAiU,CAAa8X,EAAepxH,EAAYyoB,GACtC,MAAM1sD,EAASikC,EAAWjkC,OACpBggC,EAAYiE,EAAWjE,UACvB98B,EAAS88B,EAAU98B,OACnBC,EAAa68B,EAAU78B,WACvBwC,EAAaq6B,EAAUr6B,WACvBvC,EAAW48B,EAAU58B,SACrBwC,EAAmBD,EAAWE,YAC9B23I,EAAeh3J,KAAK28G,WAAWz/D,YAC/B9hB,EAAaqiB,EAAWriB,WACxB0pC,EAAYrnB,EAAWqnB,UACvB0jG,IACJ1jG,EAAU71B,KAAuB61B,EAAU71B,KAEvC9+B,EAAUnQ,KAAK4uK,oBACfn/J,EAAQxD,KAAKiZ,MAAMu4B,EAAW/pC,KAAK,GAAK0nB,GACxC1rB,EAASzD,KAAKiZ,MAAMu4B,EAAW/pC,KAAK,GAAK0nB,GAEzCyW,EAAamlH,EAAa92G,YAAc/gC,EAAWG,WACnDC,EAAasyB,EAAaz1B,GAASgD,GAAoB,KACvD41I,EAAWnjH,EACb5lC,KAAKkZ,MAAM3L,EAAO,GAAK4F,EAAiB,IAAMG,GAAc,EAC5D,EACJ,IAAIw4I,EAAQlmH,EACR5lC,KAAKuT,OAAOhG,EAAO,GAAK4F,EAAiB,IAAMG,GAC/C,EACJ,EAAG,CACD,MAAMvJ,EAAYhW,KAAKq+G,mBACrB3hG,EACAC,EACAC,EACAwe,EACA3rB,EACAC,EACAqoJ,EAAQx4I,GAEVsvJ,EAAc1D,QACZh7J,EACA,EACA6F,EACA4G,EACA4rJ,OACAhiK,EACA0/D,EAER,SAAe6xF,EAAQ/C,EACpB,CAED,wBAAA8Z,GACE,GAAsB,IAAlB9uK,KAAK8iJ,SAAgB,CACvB,MAAMisB,EAAqBv/J,GACzBxP,KAAKmQ,QAAQN,OAAOJ,MACpBzP,KAAKmQ,QAAQN,OAAOH,OACpBC,IAEF3P,KAAK4uK,oBAAsBG,CACjC,MACM/uK,KAAK4uK,oBAAsB5uK,KAAKmQ,OAEnC,CAED,0BAAA6+J,GACE,GAAsB,IAAlBhvK,KAAK8iJ,SAAgB,CACvB,MAAMt4G,EAAQxqC,KAAKmQ,QAAQu1C,YAC3B1lD,KAAKmQ,QAAQu1C,YAAc1lD,KAAK8iJ,SAChC9iJ,KAAKmQ,QAAQ6C,UAAUhT,KAAK4uK,oBAAoB/+J,OAAQ,EAAG,GAC3D7P,KAAKmQ,QAAQu1C,YAAclb,EAC3Bt6B,GAAclQ,KAAK4uK,qBACnBj/J,GAAWhK,KAAK3F,KAAK4uK,oBAAoB/+J,QACzC7P,KAAK4uK,oBAAsB,IAC5B,CACF,CAMD,eAAA5nH,CAAgBvJ,GACVz9C,KAAKw8G,yBACPx8G,KAAK8uK,2BACL9uK,KAAK+2J,aACH/2J,KAAKw8G,uBACL/+D,EACAA,EAAWyoB,eAEblmE,KAAKgvK,6BAER,CAQD,WAAA1wH,CAAYb,EAAYt9C,GACtB,MAAMi7B,EAAaqiB,EAAWriB,WACxBghB,EAAaqB,EAAWI,iBAAiBJ,EAAWoJ,YAG1DjvC,GAAU5X,KAAKk9G,eAAgB,EAAI9hF,EAAY,EAAIA,GACnD7iB,GAAYvY,KAAK2gD,sBAAuB3gD,KAAKk9G,gBAE7C,MAAM+B,EAAkBgwD,GAAkBjvK,KAAKk9G,gBAE/Cl9G,KAAKu9G,aAAap9G,EAAQ8+G,EAAiBj/G,KAAKwtC,cAAciQ,IAC9D,MAAMttC,EAAUnQ,KAAKmQ,QACfN,EAASM,EAAQN,OAEjBurE,EAAcp7E,KAAKyuK,aACnBjyD,EAAyBx8G,KAAKw8G,uBACpC,IAAI1/D,EACDs+B,IAAgBA,EAAYt2E,WAC5B03G,IAA2BA,EAAuB13G,UACrD,IAAKg4C,EAAQ,CAIX,KAFE98C,KAAK28G,WAAWl2G,YAAYg4C,KAC5Bz+C,KAAK28G,WAAWl2G,YAAYg4C,KAE5B,OAAO,IAEV,CAGD,MAAMhvC,EAAQxD,KAAKiZ,MAAMu4B,EAAW/pC,KAAK,GAAK0nB,GACxC1rB,EAASzD,KAAKiZ,MAAMu4B,EAAW/pC,KAAK,GAAK0nB,GAC3CvrB,EAAOJ,OAASA,GAASI,EAAOH,QAAUA,GAC5CG,EAAOJ,MAAQA,EACfI,EAAOH,OAASA,EACZG,EAAOU,MAAMyF,YAAcipG,IAC7BpvG,EAAOU,MAAMyF,UAAYipG,IAEjBj/G,KAAKm9G,iBACfhtG,EAAQC,UAAU,EAAG,EAAGX,EAAOC,GAGjC1P,KAAKm+G,UAAUhuG,EAASstC,GAExB,MAAMjE,EAAYiE,EAAWjE,UACvBr6B,EAAaq6B,EAAUr6B,WAE7Bnf,KAAK8iJ,SAAW1mG,EAAWtP,QAC3B9sC,KAAK8uK,2BAGL,IAAI3vD,GAAU,EACd,GAAIriE,GAAUV,EAAW5iC,QAAUxZ,KAAK2uK,SAAU,CAChD,MAAM3wH,EAAc1xB,GAAe8vB,EAAW5iC,OAAQ2F,GACtD29B,EAASnuB,GAAiBqvB,EAAaP,EAAWjkC,QAClD2lG,EAAUriE,IAAW9iC,GAAegkC,EAAaP,EAAWjkC,QACxD2lG,GACFn/G,KAAK49G,cAAc59G,KAAK4uK,oBAAqBnxH,EAAYO,EAE5D,CAkBD,OAhBIlB,GACF98C,KAAK+2J,aAAa37E,EAAa39B,GAG7B0hE,GACFn/G,KAAK4uK,oBAAoB9oH,UAG3B9lD,KAAKgvK,6BAELhvK,KAAKo+G,WAAWjuG,EAASstC,GAErBz9C,KAAKquK,oBAAsB70H,EAAU58B,WACvC5c,KAAKquK,kBAAoB70H,EAAU58B,SACnC5c,KAAKiuK,uBAAyB,MAEzBjuK,KAAKomD,SACb,CAQD,WAAA/I,CAAYC,GACV,OAAO,IAAI/4C,SAASE,IAClB,IAAKzE,KAAKiuK,yBAA2BjuK,KAAKguK,wBAAyB,CACjE,MAAMt6J,EAAO,CAAC1T,KAAKmQ,QAAQN,OAAOJ,MAAOzP,KAAKmQ,QAAQN,OAAOH,QAC7DxL,GAAMlE,KAAKk9G,eAAgBxpG,GAC3B,MAAMgJ,EAAS1c,KAAKsuK,gBACd3xJ,EAAa3c,KAAKmuK,oBAClBvxJ,EAAW5c,KAAKquK,kBAChBlvJ,EAAanf,KAAKuuK,oBAClB/0J,EAASxZ,KAAKouK,uBACdxgI,EAAQ5tC,KAAK28G,WACbj5F,EAAa,GACbjU,EAAQiE,EAAK,GAAKk5J,GAClBl9J,EAASgE,EAAK,GAAKk5J,GACzBlpJ,EAAW/d,KACT3F,KAAKq+G,mBACH3hG,EACAC,EACAC,EACAgwJ,GACAn9J,EACAC,EACA,GACA5L,SAEJ,MAAMoG,EAAS0jC,EAAMsP,YACf99B,EAAmBD,EAAWE,YACpC,GACEnV,EAAOg2C,YACP/gC,EAAWG,aACVtF,GAAeoF,EAAkB5F,GAClC,CACA,IAAI8E,EAAS9E,EAAO,GACpB,MAAM+F,EAAanD,GAASgD,GAC5B,IACIq2B,EADAsiH,EAAQ,EAEZ,KAAOz5I,EAASc,EAAiB,MAC7B24I,EACFtiH,EAAUl2B,EAAaw4I,EACvBr0I,EAAW/d,KACT3F,KAAKq+G,mBACH3hG,EACAC,EACAC,EACAgwJ,GACAn9J,EACAC,EACA+lC,GACA3xC,SAEJwa,GAAUiB,EAIZ,IAFAw4I,EAAQ,EACRz5I,EAAS9E,EAAO,GACT8E,EAASc,EAAiB,MAC7B24I,EACFtiH,EAAUl2B,EAAaw4I,EACvBr0I,EAAW/d,KACT3F,KAAKq+G,mBACH3hG,EACAC,EACAC,EACAgwJ,GACAn9J,EACAC,EACA+lC,GACA3xC,SAEJwa,GAAUiB,CAEb,CAEDvf,KAAKiuK,uBAAyBpB,GAC5Bn5J,EACAgQ,EACA1jB,KAAKkuK,kBACLtgI,EAAMt4B,mBACNkE,EACAmD,EACAC,EAEH,CACDnY,EACEipK,GAAUpwH,EAAOt9C,KAAKkuK,kBAAmBluK,KAAKiuK,wBAC/C,GAEJ,CAWD,0BAAA3uH,CACEloC,EACAqmC,EACA8B,EACA3jC,EACAokC,GAEA,IAAKhgD,KAAKyuK,aACR,OAEF,MAAM9xJ,EAAa8gC,EAAWjE,UAAU78B,WAClCC,EAAW6gC,EAAWjE,UAAU58B,SAChCgxB,EAAQ5tC,KAAK28G,WAGbx5C,EAAW,CAAA,EAQXsmG,EAAkB,SAAU9pH,EAAS/qC,EAAUwrC,GACnD,MAAM74C,EAAMmB,EAAOi3C,GACb1U,EAAQk4B,EAAS57D,GACvB,GAAK0jC,GAcE,IAAc,IAAVA,GAAkBmV,EAAanV,EAAMmV,WAAY,CAC1D,GAAmB,IAAfA,EAGF,OAFA+iB,EAAS57D,IAAO,EAChBy4C,EAAQn5C,OAAOm5C,EAAQ4qB,YAAY3/B,GAAQ,GACpCrvB,EAAS+jC,EAAS/R,EAAOh5B,GAElCq2B,EAAMr2B,SAAWA,EACjBq2B,EAAMmV,WAAaA,CACpB,MAtBW,CACV,GAAmB,IAAfA,EAEF,OADA+iB,EAAS57D,IAAO,EACTqU,EAAS+jC,EAAS/R,EAAOh5B,GAElCorC,EAAQr6C,KACLw9D,EAAS57D,GAAO,CACfo4C,QAASA,EACT/R,MAAOA,EACPh5B,SAAUA,EACVwrC,WAAYA,EACZxkC,SAAUA,GAGf,CAUP,EAEI,IAAI60B,EACJ,MAAMm7B,EAAiB,CAAC5rE,KAAKyuK,cAkB7B,OAjBIzuK,KAAKw8G,wBACP5wC,EAAejmE,KAAK3F,KAAKw8G,wBAE3B5wC,EAAeltB,MAAMmwH,GACXp+H,EAASo+H,EAAcvvH,2BAC7BloC,EACAuF,EACAC,EACA2iC,EACAkqH,EACAoF,IAAkB7uK,KAAKw8G,wBACrB/+D,EAAWyoB,cACTzoB,EAAWyoB,cAAchQ,MAAMprB,KAAKx/B,GAASA,EAAKjH,QAClD,QAIDosC,CACR,CAKD,kBAAAm1B,GACE,MAAMh4B,EAAQ5tC,KAAK28G,WACf/uE,EAAMG,cAAgB/tC,KAAKyuK,cAC7B7gI,EAAM/lC,SAET,CAOD,uBAAAkmK,CAAwBloK,GACtB7F,KAAK48G,yBACN,CAOD,YAAAv+D,CAAaZ,GACX,MAAMowH,EAAc7tK,KAAK28G,WACnBq6C,EAAe6W,EAAY3wH,YACjC,IAAK85G,EACH,OAAO,EAGT,MAAMkY,EAAYzxH,EAAWqnB,UAAU71B,IACjCkgI,EAAc1xH,EAAWqnB,UAAU71B,IACnC6kH,EAAuB+Z,EAAYrZ,0BACnCT,EAAyB8Z,EAAYpZ,4BAE3C,GACGz0J,KAAKmkE,QAAU2vF,GAAwBob,IACtCnb,GAA0Bob,EAG5B,OADAnvK,KAAKguK,yBAA0B,GACxB,EAEThuK,KAAKguK,yBAA0B,EAE/B,MAAMoB,EAAmB3xH,EAAWjkC,OAC9BggC,EAAYiE,EAAWjE,UACvBr6B,EAAaq6B,EAAUr6B,WACvBxC,EAAa68B,EAAU78B,WACvBye,EAAaqiB,EAAWriB,WACxBi0I,EAAsBxB,EAAY9lK,cAClCunK,EAA0BzB,EAAYvZ,kBAC5C,IAAIib,EAAyB1B,EAAYtZ,sBAEV/tJ,IAA3B+oK,IACFA,EAAyBC,IAG3B,MAAM9yJ,EAAS88B,EAAU98B,OAAO5Y,QAC1B0V,EAASG,GACby1J,EACAE,EAA0B3yJ,GAEtBgiG,EAAiBnlG,EAAO1V,QACxB2rK,EAAc,CAACj2J,EAAO1V,SACtBsb,EAAmBD,EAAWE,YAEpC,GACE23I,EAAa92G,YACb/gC,EAAWG,aACVtF,GAAeoF,EAAkBq+B,EAAWjkC,QAC7C,CAMA,MAAM+F,EAAanD,GAASgD,GACtBo+D,EAASvxE,KAAKyP,IAAIU,GAAS5C,GAAU,EAAG+F,GAC9C/F,EAAO,GAAK4F,EAAiB,GAAKo+D,EAClChkE,EAAO,GAAK4F,EAAiB,GAAKo+D,EAClCkyF,GAAgBhzJ,EAAQyC,GACxB,MAAMwwJ,EAAaC,GAAYH,EAAY,GAAItwJ,GAG7CwwJ,EAAW,GAAKvwJ,EAAiB,IACjCuwJ,EAAW,GAAKvwJ,EAAiB,GAEjCqwJ,EAAY9pK,KAAK,CACfgqK,EAAW,GAAKpwJ,EAChBowJ,EAAW,GACXA,EAAW,GAAKpwJ,EAChBowJ,EAAW,KAGbA,EAAW,GAAKvwJ,EAAiB,IACjCuwJ,EAAW,GAAKvwJ,EAAiB,IAEjCqwJ,EAAY9pK,KAAK,CACfgqK,EAAW,GAAKpwJ,EAChBowJ,EAAW,GACXA,EAAW,GAAKpwJ,EAChBowJ,EAAW,IAGhB,CAED,GACE3vK,KAAKmkE,OACLnkE,KAAKmuK,qBAAuBxxJ,GAC5B3c,KAAKyzG,mBAAqB47D,GAC1BrvK,KAAKwuK,sBAAwBe,GAC7Bv1J,GAAeha,KAAKouK,uBAAwB50J,GAQ5C,OANKjX,EAAOvC,KAAKqgH,gBAAiB1B,KAChC3+G,KAAKiuK,uBAAyB,KAC9BjuK,KAAKqgH,gBAAkB1B,GAEzB3+G,KAAKsuK,gBAAkB5xJ,EACvB1c,KAAK0uK,oBAAqB,GACnB,EAGT1uK,KAAKyuK,aAAe,KAEpB,MAAMrzF,EAAc,IAAIy0F,GACtBC,GAAmBnzJ,EAAYye,GAC/B5hB,EACAmD,EACAye,GAGF,IAAIg/C,EACAp6E,KAAK28G,WAAW03C,iBAClBj6E,EAAwB,IAAIy1F,GAC1BC,GAAmBnzJ,EAAYye,GAC/B5hB,EACAmD,EACAye,IAIJ,MAAMrP,EAAiBE,KACvB,IAAIgmD,EACJ,GAAIlmD,EAAgB,CAClB,IAAK,IAAInqB,EAAI,EAAGuE,EAAKspK,EAAYtuK,OAAQS,EAAIuE,IAAMvE,EAAG,CACpD,MACMmuK,EAAa1jJ,GADJojJ,EAAY7tK,GACaud,GACxC63I,EAAa13D,aACXywE,EACAxjJ,GAAiB5P,EAAYwC,GAC7B4M,EAEH,CACDkmD,EAAgB/nD,GAA4B6B,EAAgB5M,EAClE,MACM,IAAK,IAAIvd,EAAI,EAAGuE,EAAKspK,EAAYtuK,OAAQS,EAAIuE,IAAMvE,EACjDo1J,EAAa13D,aAAamwE,EAAY7tK,GAAI+a,EAAYwC,GAI1D,MAAM2O,EAAmBkiJ,GAA0BrzJ,EAAYye,GAC/D,IAAI+oC,GAAQ,EACZ,MAAMrnB,EAIH6C,IACC,IAAIhqC,EACJ,MAAMulF,EACJv7C,EAAQrqC,oBAAsBu4J,EAAYv4J,mBAI5C,GAHI4lF,IACFvlF,EAASulF,EAAcv7C,EAAShjC,IAE9BhH,EAAQ,CACV,MAAM42D,EAAQvsE,KAAK67E,cACjBl8B,EACA7xB,EACAnY,EACAylE,EACAnJ,EACAmI,GAEFjW,EAAQA,IAAUoI,CACnB,GAGCwjG,EAAa1jJ,GAAa7S,EAAQ2F,GAElCgkD,EAAW6zF,EAAav4D,oBAAoBsxE,GAC9CR,GACFpsG,EAAS7uC,KAAKi7I,GAEhB,IAAK,IAAI3tK,EAAI,EAAGuE,EAAKg9D,EAAShiE,OAAQS,EAAIuE,IAAMvE,EAC9Ck7C,EAAOqmB,EAASvhE,IAElB5B,KAAKkuK,kBAAoB/qG,EACzBnjE,KAAKmkE,MAAQA,EAEb,MAAM8rG,EAA0B70F,EAAYgkF,SACtCyP,EAAgB,IAAIqB,GACxB12J,EACAmD,EACAye,EACA47H,EAAa/3D,cACbgxE,EACApC,EAAYvZ,mBAyBd,OAtBIl6E,IACFp6E,KAAKw8G,uBAAyB,IAAI0zD,GAChC12J,EACAmD,EACAye,EACA47H,EAAa/3D,cACb7kB,EAAsBglF,SACtByO,EAAYvZ,oBAIhBt0J,KAAKmuK,oBAAsBxxJ,EAC3B3c,KAAKyzG,kBAAoB47D,EACzBrvK,KAAKwuK,qBAAuBe,EAC5BvvK,KAAKqgH,gBAAkB1B,EACvB3+G,KAAKouK,uBAAyB50J,EAC9BxZ,KAAKsuK,gBAAkB5xJ,EACvB1c,KAAKuuK,oBAAsBpvJ,EAC3Bnf,KAAKyuK,aAAeI,EACpB7uK,KAAKiuK,uBAAyB,KAE9BjuK,KAAK0uK,oBAAqB,GACnB,CACR,CAWD,aAAA7yF,CACEl8B,EACA7xB,EACAnY,EACAwkE,EACAnkE,EACAokE,GAEA,IAAKzkE,EACH,OAAO,EAET,IAAIyuD,GAAU,EACd,GAAI/hE,MAAMC,QAAQqT,GAChB,IAAK,IAAI/T,EAAI,EAAGuE,EAAKwP,EAAOxU,OAAQS,EAAIuE,IAAMvE,EAC5CwiE,EACEyX,GACE1B,EACAx6B,EACAhqC,EAAO/T,GACPksB,EACA9tB,KAAK8tK,6BACL93J,EACAokE,IACGhW,OAGTA,EAAUyX,GACR1B,EACAx6B,EACAhqC,EACAmY,EACA9tB,KAAK8tK,6BACL93J,EACAokE,GAGJ,OAAOhW,CACR,GC1jBH,IAAA+rG,GA9MA,cAA6C1wD,GAI3C,WAAA3/G,CAAY8tC,GACV3oC,MAAM2oC,GAMN5tC,KAAKowK,gBAAkB,IAAIC,GAA0BziI,GAMrD5tC,KAAKswK,iBAAmB1iI,EAAM2iI,gBAM9BvwK,KAAKwwK,kCrPNA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GqPYrBxwK,KAAKywK,oCAAsC,IAC5C,CAKD,eAAAhwK,GACET,KAAKowK,gBAAgB5vK,UACrByE,MAAMxE,iBACP,CAOD,WAAA48C,CAAYC,GACV,IAAKt9C,KAAKowK,gBACR,OAAO7rK,QAAQE,QAAQ,IAEzB,MAAMisK,EAAcxsK,GAClBlE,KAAKwwK,kCACLtsK,GAAMlE,KAAKywK,oCAAqCnzH,EAAMx5C,UAExD,OAAO9D,KAAKowK,gBAAgB/yH,YAAYqzH,EACzC,CAKD,kBAAA9qG,GACE5lE,KAAKowK,gBAAgBxqG,oBACtB,CAOD,YAAAvnB,CAAaZ,GACX,MAAMriB,EAAaqiB,EAAWriB,WACxBoe,EAAYiE,EAAWjE,UACvBilE,EAAiBjlE,EAAU78B,WAE3B07B,EAAQoF,EAAWqnB,UACnB6rG,EAAiB3wK,KAAKowK,gBAC5B,IAAIzxD,EAAiBlhE,EAAWjkC,OACF,IAA1BxZ,KAAKswK,mBACP3xD,EAAiBA,EAAe76G,MAAM,GACtCka,GAAgB2gG,EAAgB3+G,KAAKswK,mBAEvC,MAAM7gK,EAAQ2M,GAASuiG,GAAkBF,EACnC/uG,EAAS2M,GAAUsiG,GAAkBF,EAE3C,IACGpmE,EAAMpJ,MACNoJ,EAAMpJ,MACNnqC,GAAQ65G,GACT,CACAgyD,EAAepzD,aAAa,KAAM,MAClC,MAAMptG,EAAUwgK,EAAexgK,QACzBisC,EAAaqB,EAAWI,iBAAiBJ,EAAWoJ,YACpD+pH,EAAkBlqK,OAAO8C,OAAO,CAAA,EAAI4yC,EAAY,CAACtP,QAAS,IAC1D+jI,EACJnqK,OAAO8C,OAAO,CAAE,EAAEi0C,EAAY,CAC5ByoB,cAAe,IAAIs2B,GAAM,GACzBhjF,OAAQmlG,EACRjrG,KAAM,CAACjE,EAAOC,GACd8pC,UACE9yC,OAAO8C,OAAO,GAAIi0C,EAAWjE,UAAW,CACtC58B,SAAU,IAGdihC,iBAAkB,CAAC+yH,GACnB/pH,WAAY,IAGhB,IAAIiqH,GAAa,EACjB,MAAMh+J,EAAQ,IAAIshG,GAChBuK,EACAF,EACArjF,EACAjrB,EAAQN,QACR,SAAU+L,GAEN+0J,EAAetyH,aAAawyH,IAC5BF,EAAejC,qBAEfiC,EAAehC,UAAW,EACtBgC,EAAeryH,YAAYuyH,EAAiB,QAC9CF,EAAe3pH,gBAAgB6pH,GAC/BC,GAAa,GAEfl1J,IAEH,IAGH9I,EAAMxN,iBAAiBwC,GAAkB,KACvC,GAAIgL,EAAM3F,aAAeitB,GACvB,OAEFp6B,KAAKu7B,OAASu1I,EAAa,KAAOh+J,EAClC,MAAMklE,EAAkBllE,EAAM2oB,gBACxBgxC,EACH2S,GAAmBtsE,EAAM4oB,iBAAmBN,EAC7C48C,EACFh4E,KAAKysE,mBAAqBA,EAC1BzsE,KAAKwwK,kCAAoCx4J,GACvChY,KAAKwwK,kCACL/gK,EAAQ,EACRC,EAAS,EACT,EAAI+8D,GACH,EAAIA,EACL,GACCjzB,EAAU98B,OAAO,IACjB88B,EAAU98B,OAAO,GACnB,IAEH5J,EAAMxF,MACP,CAOD,OALItN,KAAKu7B,SACPv7B,KAAKywK,oCACHhzH,EAAW4B,2BAA2Bv7C,WAGjC9D,KAAKu7B,MACf,CAID,SAAA4iF,GAAc,CAId,UAAAC,GAAe,CAIf,eAAAp3D,GAAoB,CAWpB,0BAAA1H,CACEloC,EACAqmC,EACA8B,EACA3jC,EACAokC,GAEA,OAAIhgD,KAAKowK,gBACApwK,KAAKowK,gBAAgB9wH,2BAC1BloC,EACAqmC,EACA8B,EACA3jC,EACAokC,GAGG/6C,MAAMq6C,2BACXloC,EACAqmC,EACA8B,EACA3jC,EACAokC,EAEH,GCpLH,MAAM+wH,GAAgB,CACpBj+J,MAAS,CAAC,UAAW,SAAU,aAAc,QAAS,QACtDk+J,OAAU,CAAC,UAAW,cACtBC,OAAU,IAMNC,GAAiB,CACrBF,OAAU,CAAC,QAAS,OAAQ,WAC5BC,OAAU,CAAC,UAAW,SAAU,aAAc,QAAS,OAAQ,YAiyBjE,IAAAE,GAxxBA,cAA4CnuD,GAI1C,WAAAljH,CAAY8tC,GACV3oC,MAAM2oC,GAGN5tC,KAAK8tK,6BAA+B9tK,KAAK+tK,wBAAwB7mK,KAAKlH,MAMtEA,KAAKoxK,uBAMLpxK,KAAKywK,oCAAsC,KAM3CzwK,KAAKquK,kBAMLruK,KAAKs7J,ctP1DA,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,EsP2DtB,CAQD,WAAA+V,CAAYnkK,EAAMkuB,EAAYjc,GAC5B,IAAI29B,EACJ,MAAMtwC,EAAQU,EAAKC,WAOnB,OANIX,IAAUV,GAAoBU,IAAUV,IAC1C9L,KAAKsxK,qBAAqBpkK,EAAMkuB,EAAYjc,GACxCnf,KAAKuxK,sBAAsBrkK,KAC7B4vC,GAAS,IAGNA,CACR,CASD,OAAA6sC,CAAQpqD,EAAGloB,EAAGC,EAAGmmC,GACf,MAAMriB,EAAaqiB,EAAWriB,WACxBoe,EAAYiE,EAAWjE,UACvB78B,EAAa68B,EAAU78B,WACvBwC,EAAaq6B,EAAUr6B,WACvByuB,EAAQ5tC,KAAK28G,WACbzvG,EAAO0gC,EAAMsP,YAAYysC,QAAQpqD,EAAGloB,EAAGC,EAAG8jB,EAAYjc,GACtD2lD,EAAYrnB,EAAWqnB,UACvB0sG,IACJ1sG,EAAU71B,KAAuB61B,EAAU71B,MAEzCuiI,GAAStkK,EAAKi/D,mBAChBj/D,EAAKi/D,iBAAmBxvD,GAU1B,OARe3c,KAAKqxK,YAAYnkK,EAAMkuB,EAAYjc,KAG/CqyJ,GAAQzzI,KAAKC,MAAQyf,EAAWhwC,KAAO,IACd,WAA1BmgC,EAAM6jI,iBAENzxK,KAAK0xK,iBAAiBxkK,EAAMuwC,GAEvBx4C,MAAM0kF,QAAQpqD,EAAGloB,EAAGC,EAAGmmC,EAC/B,CAMD,cAAAmjE,CAAe1zG,GACb,MAAM0gC,EAAQ5tC,KAAK28G,WACnB,OACE13G,MAAM27G,eAAe1zG,KACM,WAA1B0gC,EAAM6jI,gBACH/oK,EAAOklC,KAAU1gC,EAAK0+D,eACtB1+D,EAAKm/D,WAAWz+B,GAEvB,CAKD,YAAA80E,CAAax1G,GACX,OAAOA,EAAKsuB,SAASx7B,KAAK28G,WAC3B,CAOD,YAAAt+D,CAAaZ,GACX,MAAMk0H,EAAgB3xK,KAAK28G,WAAW50G,cAKtC,OAJI/H,KAAKoxK,yBAA2BO,IAClC3xK,KAAKoxK,uBAAyBO,EAC9B3xK,KAAKwgH,cAAcr/G,OAAS,GAEvB8D,MAAMo5C,aAAaZ,EAC3B,CAQD,oBAAA6zH,CAAqBpkK,EAAMkuB,EAAYjc,GACrC,MAAMyuB,EACJ5tC,KAAK28G,WAED9uF,EAAW+f,EAAM7lC,cACjB4sJ,EAAc/mH,EAAM2mH,kBAAoB,KAExC53I,EAAazP,EAAKi/D,iBAClBylG,EAAe1kK,EAAKo/D,eAAe1+B,GACzC,IACGgkI,EAAarlG,OACdqlG,EAAanlG,qBAAuB9vD,GACpCi1J,EAAallG,kBAAoB7+C,GACjC+jJ,EAAaplG,qBAAuBmoF,EAEpC,OAGF,MAAMzqJ,EAAS0jC,EAAMsP,YACf+2G,EAAYrmH,EAAMymH,eAClB5xE,EAAiBv4E,EAAO0/E,cAExBgyB,EADW1xG,EAAOw/E,yBAAyBvqE,GACrBikE,mBAAmBl2E,EAAKk/D,kBAE9CH,EAAc/hE,EAAOwhE,eAAetwC,EAAYjc,EAAYjS,GAC5D2kK,EAAWnpK,EAAOklC,UACjB1gC,EAAK6+D,sBAAsB8lG,GAClC3kK,EAAK0+D,eAAeimG,GAAY,GAC5B5d,IACF/mJ,EAAK2+D,wBAAwBgmG,GAAY,IAE3CD,EAAarlG,OAAQ,EACrB,IAAK,IAAIvgE,EAAI,EAAG8lK,EAAK7lG,EAAY9qE,OAAQ6K,EAAI8lK,IAAM9lK,EAAG,CACpD,MAAMivG,EAAahvC,EAAYjgE,GAC/B,GAAIivG,EAAW9tG,YAAcrB,EAC3B,SAEF,MAAMyvG,EAAkBN,EAAW1uG,UAC7BwlK,EACJtvF,EAAeW,mBAAmBm4B,GAC9By2D,EAAep0J,GAAgBg+F,EAAYm2D,GAC3CE,EAAgBt4J,GACpBq4J,EACApkI,EAAM0mH,kBAAoB33I,EAC1B3c,KAAK0gH,WAEDwxD,EAAiB3vK,GAAOwvK,EAAkBC,GAC5C,KACAC,EACE93F,EAAe,IAAI01F,GACvB,EACAoC,EACAt1J,EACAye,GAEIg/C,EAAwB65E,EAC1B,IAAI4b,GAAmB,EAAGmC,EAAcr1J,EAAYye,QACpD50B,EACEsnB,EAAmBkiJ,GACvBrzJ,EACAye,GAOI0hB,EAAS,SAAU6C,GACvB,IAAIhqC,EACJ,MAAMulF,EACJv7C,EAAQrqC,oBAAsBs4B,EAAMt4B,mBAItC,GAHI4lF,IACFvlF,EAASulF,EAAcv7C,EAAShjC,IAE9BhH,EAAQ,CACV,MAAM42D,EAAQvsE,KAAK67E,cACjBl8B,EACA7xB,EACAnY,EACAwkE,EACAC,GAEFw3F,EAAarlG,MAAQqlG,EAAarlG,OAASA,CAC5C,CACT,EAEYpJ,EAAW83C,EAAW59D,cACxBs3G,GAAeA,IAAgBid,EAAaplG,qBAC9CrJ,EAAS7uC,KAAKqgI,GAEhB,IAAK,IAAI/yJ,EAAI,EAAGuE,EAAKg9D,EAAShiE,OAAQS,EAAIuE,IAAMvE,EAAG,CACjD,MAAM+9C,EAAUwjB,EAASvhE,GAEtBswK,IACDp0J,GAAWo0J,EAAgBvyH,EAAQzqC,cAAcmK,cAEjDy9B,EAAO/4C,KAAK/D,KAAM2/C,EAErB,CACD,MAAMwyH,EAA4Bh4F,EAAailF,SAEzCgT,EACsB,WAA1BxkI,EAAM6jI,iBACNxd,GACuB,IAAvBhoF,EAAY9qE,OACR,KACA6wK,EACAK,EAAuB,IAAIC,GAC/BF,EACAz1J,EACAye,EACAlxB,EAAO+0F,cACPkzE,EACAvkI,EAAM0mH,mBAGR,GADApnJ,EAAK0+D,eAAeimG,GAAUlsK,KAAK0sK,GAC/Bj4F,EAAuB,CACzB,MAAMoiC,EAAyB,IAAI81D,GACjC,KACA31J,EACAye,EACAlxB,EAAO+0F,cACP7kB,EAAsBglF,SACtBxxH,EAAM0mH,mBAERpnJ,EAAK2+D,wBAAwBgmG,GAAUlsK,KAAK62G,EAC7C,CACF,CACDo1D,EAAallG,iBAAmB7+C,EAChC+jJ,EAAaplG,oBAAsBmoF,EACnCid,EAAanlG,mBAAqB9vD,CACnC,CAWD,0BAAA2iC,CACEloC,EACAqmC,EACA8B,EACA3jC,EACAokC,GAEA,MAAMrjC,EAAa8gC,EAAWjE,UAAU78B,WAClCC,EAAW6gC,EAAWjE,UAAU58B,SACtC2iC,EAA+B/4C,MAAhB+4C,EAA4B,EAAIA,EAC/C,MAAM3R,EAAQ5tC,KAAK28G,WAEb96F,EADS+rB,EAAMsP,YACGwsC,yBACtBjsC,EAAWjE,UAAUr6B,YAGjBuqJ,EAAYpwJ,GAAe,CAAClC,IAClCuC,GAAO+vJ,EAAW/sJ,EAAa4iC,EAAcmqH,GAG7C,MAAMvmG,EAAW,CAAA,EAQXsmG,EAAkB,SAAU9pH,EAAS/qC,EAAUwrC,GACnD,IAAI74C,EAAMo4C,EAAQtqC,aACN7O,IAARe,IACFA,EAAMmB,EAAOi3C,IAEf,MAAM1U,EAAQk4B,EAAS57D,GACvB,GAAK0jC,GAcE,IAAc,IAAVA,GAAkBmV,EAAanV,EAAMmV,WAAY,CAC1D,GAAmB,IAAfA,EAGF,OAFA+iB,EAAS57D,IAAO,EAChBy4C,EAAQn5C,OAAOm5C,EAAQ4qB,YAAY3/B,GAAQ,GACpCrvB,EAAS+jC,EAAS/R,EAAOh5B,GAElCq2B,EAAMr2B,SAAWA,EACjBq2B,EAAMmV,WAAaA,CACpB,MAtBW,CACV,GAAmB,IAAfA,EAEF,OADA+iB,EAAS57D,IAAO,EACTqU,EAAS+jC,EAAS/R,EAAOh5B,GAElCorC,EAAQr6C,KACLw9D,EAAS57D,GAAO,CACfo4C,QAASA,EACT/R,MAAOA,EACPh5B,SAAUA,EACVwrC,WAAYA,EACZxkC,SAAUA,GAGf,CAUP,EAEU4kG,EAEFxgH,KACR,cAEI,IAAIoB,EACJ,IAAK,IAAIQ,EAAI,EAAGuE,EAAKq6G,EAAcr/G,QAASC,GAASQ,EAAIuE,IAAMvE,EAAG,CAChE,MAAMsL,EAAOszG,EAAc5+G,GAE3B,IAAKkc,GADc+D,EAASuhE,mBAAmBl2E,EAAKk/D,kBACxBs9F,GAC1B,SAGF,MAAMmI,EAAWnpK,EAAOklC,GAClBg+B,EAAiB,CAAC1+D,EAAK0+D,eAAeimG,IACtChmG,EAA0B3+D,EAAK2+D,wBAAwBgmG,GACzDhmG,GACFD,EAAejmE,KAAKkmE,GAEtBD,EAAeltB,MAAMktB,IACnB,MAAM2gG,EACJ3gG,IAAmBC,EACfpuB,EAAWyoB,cAAchQ,MAAMprB,KAAKx/B,GAASA,EAAKjH,QAClD,KACN,IAAK,IAAI2H,EAAI,EAAG8lK,EAAKlmG,EAAezqE,OAAQ6K,EAAI8lK,IAAM9lK,EAAG,CACvD,MAAM6iK,EAAgBjjG,EAAe5/D,GASrC,GARA5K,EAAQytK,EAAcvvH,2BACpBloC,EACAuF,EACAC,EACA2iC,EACAkqH,EACA8C,GAEEnrK,EACF,OAAO,CAEV,IAEJ,CACD,OAAOA,CACR,CAOD,WAAAi8C,CAAYC,GACV,OAAO,IAAI/4C,SAAQ,CAACE,EAASD,KAC3B,MAAMopC,EAAQ5tC,KAAK28G,WACbk1D,EAAWnpK,EAAOklC,GAClB1jC,EAAS0jC,EAAMsP,YACf/9B,EAAanf,KAAKugH,mBAClBnhG,EAAmBD,EAAWE,YAC9B1C,EAAa3c,KAAKysE,mBAClB5qD,EAAW3X,EAAOw/E,yBAAyBvqE,GAC3C/H,EAAauH,GACjB3e,KAAKywK,oCACLnzH,EAAMx5C,SAEFyI,EAAYsV,EAASqlE,kCACzB9vE,EACAuF,GAGF,IAAIzP,EACJ,IAAK,IAAItL,EAAI,EAAGuE,EAAKnG,KAAKwgH,cAAcr/G,OAAQS,EAAIuE,IAAMvE,EACxD,GACE2K,EAAUqM,aAAe5Y,KAAKwgH,cAAc5+G,GAAG2K,UAAUqM,WACzD,CAIA,GAHA1L,EACElN,KAAKwgH,cAAc5+G,GAEjBsL,EAAKC,aAAerB,EAAkB,CACxC,MAAM0N,EAASqI,EAASuhE,mBAAmBl2E,EAAKX,WAE9CrC,EAAOg2C,YACP/gC,EAAWG,aACVtF,GAAeoF,EAAkB5F,IAElC0F,GAAM9H,EAAY+H,GAEpB,KACD,CACDjS,OAAO1G,CACR,CAEH,IAAK0G,GAAQA,EAAK4+D,mBAAqB,EAErC,YADArnE,EAAQ,IAGV,MACM+X,EAASP,GADA4F,EAASuhE,mBAAmBl2E,EAAKk/D,mBAE1CmmG,EAAY,EACfn7J,EAAW,GAAKoF,EAAO,IAAMG,GAC7BH,EAAO,GAAKpF,EAAW,IAAMuF,GAG1BwmD,EAAWj2D,EACdw+D,iBACAhnB,QAAO,SAAUqqE,EAAa9T,GAC7B,OAAO8T,EAAYh4B,OAAOkkB,EAAW59D,cACtC,GAAE,IAEL,IAAI0uB,EAAwB7+D,EAAK6+D,sBAAsB8lG,GACvD,IAAK9lG,EAAuB,CAC1B,MAAM+Z,EAAW9mB,GACfn9C,EAASoiE,YACPpiE,EAAS8hE,kBAAkBhnE,EAAYzS,EAAOg/E,cAG5CtsE,EAAW5c,KAAKquK,kBAYtBtiG,EAAwB8gG,GACtB/mF,EAZiB,CACjB9lF,KAAKq+G,mBACHx8F,EAASolE,mBAAmB/5E,EAAKk/D,kBACjCzvD,EACA,EACAiwJ,GACA9mF,EAAS,GAAK8mF,GACd9mF,EAAS,GAAK8mF,GACd,IAMFzpG,EACAv1B,EAAMt4B,mBACNuM,EAASuhE,mBAAmBl2E,EAAKk/D,kBACjCl/D,EAAKo/D,eAAe1+B,GAAO6+B,mBAC3B7vD,GAEF1P,EAAK6+D,sBAAsB8lG,GAAY9lG,CACxC,CACDtnE,EAAQipK,GAAU6E,EAAWpvG,EAAU4I,GAAuB,GAEjE,CAKD,kBAAAnG,GACE,MAAMh4B,EAAQ5tC,KAAK28G,WACf/uE,EAAMG,mBAAgDvnC,IAAhCxG,KAAKoxK,wBAC7BxjI,EAAM/lC,SAET,CAOD,uBAAAkmK,CAAwBloK,GACtB7F,KAAK48G,yBACN,CAMD,eAAA51D,CAAgBvJ,GACd,MAAMttC,EAAUnQ,KAAKmQ,QACfq6B,EAAQr6B,EAAQu1C,YACtBv1C,EAAQu1C,YAAc1lD,KAAK28G,WAAW7uE,aACtC,MAAMg3B,EAAYrnB,EAAWqnB,UACvB0sG,IACJ1sG,EAAU71B,KAAuB61B,EAAU71B,KAEvC2+D,EAEF5tG,KACR,cACI,IAAK,IAAI4B,EAAI,EAAGuE,EAAKynG,EAAMzsG,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAMsL,EAAO0gG,EAAMhsG,GACbiqE,EACJ3+D,EAAK2+D,wBAAwBnjE,EAAO1I,KAAK28G,aAC3C,GAAI9wC,EACF,IAAK,IAAIvnD,EAAIunD,EAAwB1qE,OAAS,EAAGmjB,GAAK,IAAKA,EACzDunD,EAAwBvnD,GAAG6mJ,QACzBnrK,KAAKmQ,QACL,EACAnQ,KAAKwyK,uBAAuBtlK,EAAMuwC,GAClCA,EAAWjE,UAAU58B,SACrB40J,OACAhrK,EACAi3C,EAAWyoB,cAIlB,CACD/1D,EAAQu1C,YAAclb,CACvB,CAED,sBAAAgoI,CAAuBtlK,EAAMuwC,GAC3B,MAAMriB,EAAaqiB,EAAWriB,WACxBoe,EAAYiE,EAAWjE,UACvB98B,EAAS88B,EAAU98B,OACnBC,EAAa68B,EAAU78B,WACvBC,EAAW48B,EAAU58B,SACrBlJ,EAAO+pC,EAAW/pC,KAClBjE,EAAQxD,KAAKiZ,MAAMxR,EAAK,GAAK0nB,GAC7B1rB,EAASzD,KAAKiZ,MAAMxR,EAAK,GAAK0nB,GAG9BvZ,EADS7hB,KAAK28G,WAAWz/D,YACPwsC,yBACtBjsC,EAAWjE,UAAUr6B,YAEjB5S,EAAYW,EAAKX,UACjBqvG,EAAa/5F,EAASuhE,mBAAmBl2E,EAAKk/D,kBAC9CqmG,EACJ5wJ,EAASuhE,mBAAmB72E,EAAWvM,KAAK0gH,WAAW,GAAK9E,EAAW,GAazE,OAZkB3lG,GAChB0B,GAAM3X,KAAK2gD,sBAAsB78C,QAAS,EAAIs3B,EAAY,EAAIA,GAC9Dp7B,KAAKq+G,mBACH3hG,EACAC,EACAC,EACAwe,EACA3rB,EACAC,EACA+iK,GAIL,CAOD,UAAAr0D,CAAWjuG,EAASstC,GAClB,MAAMqnB,EAAYrnB,EAAWqnB,UACvB0sG,IACJ1sG,EAAU71B,KAAuB61B,EAAU71B,KAG7CjvC,KAAKywK,oCACHhzH,EAAW4B,2BAA2Bv7C,QACxC9D,KAAKquK,kBAAoB5wH,EAAWjE,UAAU58B,SAE9C,MAAMgxB,EACJ5tC,KAAK28G,WAED+1D,EAAa9kI,EAAM6jI,gBACnBjnI,EAAQr6B,EAAQu1C,YACtBv1C,EAAQu1C,YAAc9X,EAAME,aAC5B,MAAM6kI,EAAczB,GAAewB,GAC7Bl5H,EAAYiE,EAAWjE,UACvB58B,EAAW48B,EAAU58B,SACrBkkG,EAAalzE,EAAMsP,YAEnB3d,EADWuhF,EAAWp3B,yBAAyBlwC,EAAUr6B,YAC5CwkE,kBACjBnqC,EAAU78B,WACVmkG,EAAW53B,YAGP0kB,EAAQ5tG,KAAKwgH,cACbc,EAAQ,GACRC,EAAS,GACf,IAAIp9C,GAAQ,EACZ,IAAK,IAAIviE,EAAIgsG,EAAMzsG,OAAS,EAAGS,GAAK,IAAKA,EAAG,CAC1C,MAAMsL,EACJ0gG,EAAMhsG,GAERuiE,EAAQA,IAAUj3D,EAAKo/D,eAAe1+B,GAAO2+B,MAC7C,MAAMX,EAAiB1+D,EAAK0+D,eAAeljE,EAAOklC,IAAQ6J,QACvDusB,GAAUA,EAAMqoG,aAAasG,KAEhC,GAA8B,IAA1B/mG,EAAezqE,OACjB,SAEF,MAAM6U,EAAYhW,KAAKwyK,uBAAuBtlK,EAAMuwC,GAC9CikE,EAAWx0G,EAAKX,UAAU,GAChC,IAAI81G,GAAe,EAEnB,MAAMb,EAAc51C,EAAe,GAAGqgG,cAAcj2J,GACpD,GAAIwrG,EAAa,CACf,IAAK,IAAIl9F,EAAI,EAAG2G,EAAKq2F,EAAMngH,OAAQmjB,EAAI2G,IAAM3G,EAC3C,GAAIib,IAAMmiF,GAAYA,EAAWH,EAAOj9F,GAAI,CAC1C,MAAMw4D,EAAOwkC,EAAMh9F,GAEjBxG,GACE,CACE0jG,EAAY,GACZA,EAAY,GACZA,EAAY,GACZA,EAAY,IAEd,CAAC1kC,EAAK,GAAIA,EAAK,GAAIA,EAAK,GAAIA,EAAK,OAG9BulC,IACHlyG,EAAQs1C,OACR48D,GAAe,GAEjBlyG,EAAQ4kE,YAER5kE,EAAQwkE,OAAO6sC,EAAY,GAAIA,EAAY,IAC3CrxG,EAAQykE,OAAO4sC,EAAY,GAAIA,EAAY,IAC3CrxG,EAAQykE,OAAO4sC,EAAY,GAAIA,EAAY,IAC3CrxG,EAAQykE,OAAO4sC,EAAY,GAAIA,EAAY,IAE3CrxG,EAAQwkE,OAAOmI,EAAK,GAAIA,EAAK,IAC7B3sE,EAAQykE,OAAOkI,EAAK,GAAIA,EAAK,IAC7B3sE,EAAQykE,OAAOkI,EAAK,GAAIA,EAAK,IAC7B3sE,EAAQykE,OAAOkI,EAAK,GAAIA,EAAK,IAC7B3sE,EAAQ2sE,OAEX,CAEHwkC,EAAM37G,KAAK67G,GACXD,EAAO57G,KAAK+7G,EACb,CACD,IAAK,IAAI11G,EAAI,EAAG8lK,EAAKlmG,EAAezqE,OAAQ6K,EAAI8lK,IAAM9lK,EAAG,CACjC4/D,EAAe5/D,GACvBm/J,QACZh7J,EACA,EACA6F,EACA4G,EACA40J,EACAmB,EAEH,CACGtwD,GACFlyG,EAAQ21C,SAEX,CACD31C,EAAQu1C,YAAclb,EACtBxqC,KAAKmkE,MAAQA,EAEbl/D,MAAMm5G,WAAWjuG,EAASstC,EAC3B,CAUD,aAAAo+B,CACEl8B,EACA7xB,EACAnY,EACAwkE,EACAC,GAEA,IAAKzkE,EACH,OAAO,EAET,IAAIyuD,GAAU,EACd,GAAI/hE,MAAMC,QAAQqT,GAChB,IAAK,IAAI/T,EAAI,EAAGuE,EAAKwP,EAAOxU,OAAQS,EAAIuE,IAAMvE,EAC5CwiE,EACEyX,GACE1B,EACAx6B,EACAhqC,EAAO/T,GACPksB,EACA9tB,KAAK8tK,kCACLtnK,EACA4zE,IACGhW,OAGTA,EAAUyX,GACR1B,EACAx6B,EACAhqC,EACAmY,EACA9tB,KAAK8tK,kCACLtnK,EACA4zE,GAGJ,OAAOhW,CACR,CAOD,qBAAAmtG,CAAsBrkK,GACpB,MAAM0gC,EACJ5tC,KAAK28G,WAEP,GAA8B,WAA1B/uE,EAAM6jI,gBACR,OAAO,EAET,MAAMmB,EAAc1lK,EAAKo/D,eAAe1+B,GAClC/f,EAAW+f,EAAM7lC,cACjB4U,EAAazP,EAAKi/D,iBACxB,OACEymG,EAAYjmG,yBAA2BhwD,GACvCi2J,EAAYhmG,uBAAyB/+C,CAExC,CAOD,gBAAA6jJ,CAAiBxkK,EAAMuwC,GACrB,MAAM7P,EACJ5tC,KAAK28G,WAEDi2D,EAAc1lK,EAAKo/D,eAAe1+B,GAClC/f,EAAW+f,EAAM7lC,cACjB6jE,EAAiB1+D,EAAK0+D,eAAeljE,EAAOklC,IAClDglI,EAAYhmG,qBAAuB/+C,EAEnC,MAAMthB,EAAYW,EAAKk/D,iBACjB7sC,EAAIhzB,EAAU,GACdrC,EAAS0jC,EAAMsP,YACrB,IAAI9hB,EAAaqiB,EAAWriB,WAC5B,MACMjc,EADYs+B,EAAWjE,UACAr6B,WACvB0C,EAAW3X,EAAOw/E,yBAAyBvqE,GAC3CqwC,EAAiB3tC,EAAS6Z,cAAcxuB,EAAKX,UAAU,IACvDsmK,EACHp1H,EAAWriB,WAAaluB,EAAKi/D,iBAAoB3c,EAC9C7yC,EAAakF,EAAS6Z,cAAc6D,GACpCpvB,EAAUjD,EAAK+C,WAAW29B,GAGhCxS,EAAanvB,KAAKiZ,MAChBjZ,KAAKyP,IAAI0f,EAAYy3I,EAAmBz3I,IAE1C,MAAM1nB,EAAOxJ,EAAO4/E,iBAAiBvqD,EAAGnE,EAAYjc,GACpDhP,EAAQN,OAAOJ,MAAQiE,EAAK,GAC5BvD,EAAQN,OAAOH,OAASgE,EAAK,GAC7B,MAAMo/J,EAAc13I,EAAay3I,EACjC,GAAoB,IAAhBC,EAAmB,CACrB,MAAM7zD,EAAkBu0B,GAAexzI,KAAKs7J,eAC5C7nB,GAAex0B,EAAiB6zD,EAAaA,GAC7C3iK,EAAQmlE,aAAapxE,MAAMiM,EAAS8uG,EACrC,CACD,MAAMrD,EAAa/5F,EAASuhE,mBAAmB72E,EAAWvM,KAAK0gH,WACzDqyD,EAAaF,EAAmBl2J,EAChC3G,EAAYw9H,GAAexzI,KAAKs7J,eACtC7nB,GAAez9H,EAAW+8J,GAAaA,GACvCp/B,GAAmB39H,GAAY4lG,EAAW,IAAKA,EAAW,IAC1D,IAAK,IAAIh6G,EAAI,EAAGuE,EAAKylE,EAAezqE,OAAQS,EAAIuE,IAAMvE,EAAG,CACjCgqE,EAAehqE,GACvBupK,QACZh7J,EACA2iK,EACA98J,EACA,GACA,EACA+6J,GAAcnjI,EAAM6jI,iBAEvB,CACDmB,EAAYjmG,uBAAyBz/D,EAAKi/D,gBAC3C,GCn0BH,IAAI6mG,GAAa,KA2BV,SAASC,GAASC,GACvBF,GAAaE,EAEb,MAAMC,EAAYzsK,OAAOC,KAAKusK,EAAME,MAC9BnrK,EAAMkrK,EAAUhyK,OACtB,IAAIS,EAAG0iB,EACP,IAAK1iB,EAAI,EAAGA,EAAIqG,IAAOrG,EAAG,CACxB,MAAMie,EAAOszJ,EAAUvxK,GACvB,IAAKwH,GAAIyW,GAAO,CACd,MAAMwzJ,EAAMH,EAAME,KAAKvzJ,GACvB,IAAI8C,EAAmD0wJ,EAAS,MAC3D1wJ,GAA0B,YAAjB0wJ,EAAIC,WAChB3wJ,EAAQ,WAEV8G,GACE,IAAI/G,GAAW,CACb7C,KAAMA,EACNc,gBAAiB0yJ,EAAIE,KACrBpyJ,cAAekyJ,EAAIG,SACnB7wJ,UAGL,CACF,CACD,IAAK/gB,EAAI,EAAGA,EAAIqG,IAAOrG,EAAG,CACxB,MAAM6xK,EAAQN,EAAUvxK,GAClB8xK,EAAQtqK,GAAIqqK,GAClB,IAAKnvJ,EAAI,EAAGA,EAAIrc,IAAOqc,EAAG,CACxB,MAAMqvJ,EAAQR,EAAU7uJ,GAClBsvJ,EAAQxqK,GAAIuqK,GAClB,IAAK9nJ,GAAa4nJ,EAAOE,GACvB,GAAIT,EAAME,KAAKK,KAAWP,EAAME,KAAKO,GACnCvpJ,GAAyB,CAACspJ,EAAOE,QAC5B,CACL,MAAM59J,EAAYk9J,EAAMO,EAAOE,GAC/BzoJ,GACEwoJ,EACAE,EACAhnJ,GAA8B8mJ,EAAOE,EAAO59J,EAAUmV,SACtDyB,GAA8BgnJ,EAAOF,EAAO19J,EAAUoV,SAEzD,CAEJ,CACF,CACH,CAMA,IAAIyoJ,GAAaxkG,eAAgBxvD,GAC/B,MAAM4vD,QAAiBqf,MAAM,mBAAmBjvE,WAChD,IAAK4vD,EAASqkG,GACZ,MAAM,IAAItrK,MAAM,qCAAqCinE,EAASrB,UAEhE,OAAOqB,EAAS7sB,MAClB,EClEA,IAAAmxH,GAbA,cAA0BC,GAIxB,WAAAl0K,CAAY6K,GACV1F,MAAM0F,EACP,CAED,cAAAi0C,GACE,OAAO,IAAIyxH,GAA0BrwK,KACtC,GClBH,SAASmnK,GAAKt6J,EAAamJ,EAAW8X,GAKpC,MAAMhT,EAAkB,GAExB,IAAIm5J,EAAOpnK,EAAY,GACnBqnK,EAAOrnK,EAAY,GAEnBxL,EAAI2U,EAAUi+J,GACd3yK,EAAI0U,EAAUk+J,GAGlB,MAAMC,EAAW,CAACD,EAAMD,GAElBliJ,EAAQ,CAACzwB,EAAGD,GAEZ+yK,EAAgB,CAAC,EAAG,GAGpBC,EAAY,CAAA,EAElB,IACIC,EAAMn0J,EAAGo0J,EAAOC,EAAOC,EAAOltK,EAD9BmtK,EAAgB,IAGpB,OAASA,EAAgB,GAAKN,EAAcjzK,OAAS,GAEnDozK,EAAQH,EAAclpK,MACtB+oK,EAAOE,EAASjpK,MAChB7J,EAAI0wB,EAAM7mB,MAEV3D,EAAMgtK,EAAM37J,WACNrR,KAAO8sK,IACXv5J,EAAgBnV,KAAKtE,EAAE,GAAIA,EAAE,IAC7BgzK,EAAU9sK,IAAO,GAGnBitK,EAAQJ,EAAclpK,MACtBgpK,EAAOC,EAASjpK,MAChB5J,EAAIywB,EAAM7mB,MAEVupK,GAASF,EAAQC,GAAS,EAC1BF,EAAOznK,EAAY4nK,GACnBt0J,EAAInK,EAAUs+J,GAEZvwJ,GAAuB5D,EAAE,GAAIA,EAAE,GAAI9e,EAAE,GAAIA,EAAE,GAAIC,EAAE,GAAIA,EAAE,IACvDwsB,GAKAhT,EAAgBnV,KAAKrE,EAAE,GAAIA,EAAE,IAC7BiG,EAAMitK,EAAM57J,WACZy7J,EAAU9sK,IAAO,IAIjB6sK,EAAczuK,KAAK6uK,EAAOC,EAAOA,EAAOF,GACxCxiJ,EAAMpsB,KAAKrE,EAAG6e,EAAGA,EAAG9e,GACpB8yK,EAASxuK,KAAKuuK,EAAMI,EAAMA,EAAML,IAIpC,OAAOn5J,CACT,CAoEO,SAAS65J,GAASC,EAAK3sJ,EAAMC,EAAM/I,EAAY2O,GAEpD,OAAOq5I,IAKL,SAAU0N,GACR,MAAO,CAACD,EAAK3sJ,GAAQC,EAAOD,GAAQ4sJ,EACrC,GACDhpJ,GATyB+C,GAAc,aASNzP,GACjC2O,EAEJ,CAWO,SAASgnJ,GAASnsJ,EAAKF,EAAMssJ,EAAM51J,EAAY2O,GAEpD,OAAOq5I,IAKL,SAAU0N,GACR,MAAO,CAACpsJ,GAAQssJ,EAAOtsJ,GAAQosJ,EAAMlsJ,EACtC,GACDkD,GATyB+C,GAAc,aASNzP,GACjC2O,EAEJ,CC7IA,MAAMknJ,GAAuB,IAAI/sB,GAAO,CACtCh+G,MAAO,oBAOHgrI,GAAY,CAChB,GACA,GACA,GACA,GACA,GACA,EACA,EACA,EACA,GACA,GAAK,GACL,GAAK,GACL,EAAI,GACJ,EAAI,GACJ,EAAI,GACJ,GAAK,KACL,GAAK,KACL,GAAK,KACL,EAAI,KACJ,EAAI,KACJ,EAAI,MAmqCN,IAAAC,GAljCA,cAAwBC,GAItB,WAAAr1K,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B,MAAM4xC,EAAc71C,OAAO8C,OACzB,CACEsqJ,sBAAsB,EACtBC,wBAAwB,EACxBF,aAAc,GAEhBlpJ,UAGK4xC,EAAY64H,gBACZ74H,EAAYi1B,mBACZj1B,EAAY84H,kBACZ94H,EAAY+4H,kBACZ/4H,EAAYg5H,yBACZh5H,EAAYi5H,yBACZj5H,EAAYk5H,wBACZl5H,EAAYm5H,wBACZn5H,EAAYo5H,qBACZp5H,EAAYq5H,qBACZr5H,EAAYs5H,UACnB5wK,MAAMs3C,GAKNv8C,KAAK6zC,YAAc,KAMnB7zC,KAAK81K,QAAUr7J,IAMfza,KAAK+1K,QAAUt7J,IAMfza,KAAKg2K,SAAWv7J,IAMhBza,KAAKi2K,SAAWx7J,IAMhBza,KAAKk2K,MAAQz7J,IAMbza,KAAKm2K,MAAQ17J,IAMbza,KAAKo2K,OAAS37J,IAMdza,KAAKq2K,OAAS57J,IAMdza,KAAKs2K,iBACoB9vK,IAAvBmE,EAAQ0qK,WAA2B1qK,EAAQ0qK,WAAa,IAM1Dr1K,KAAKu2K,eAAiC/vK,IAArBmE,EAAQyqK,SAAyBzqK,EAAQyqK,SAAW,IAMrEp1K,KAAKw2K,WAAa,GAMlBx2K,KAAKy2K,WAAa,GAMlBz2K,KAAK02K,kBACqBlwK,IAAxBmE,EAAQ6mE,YACJ7mE,EAAQ6mE,YACRwjG,GAMNh1K,KAAK22K,0BAAuBnwK,EAM5BxG,KAAK42K,wBAAqBpwK,EAM1BxG,KAAK62K,wBAA0B,KAM/B72K,KAAK82K,YAAc,KAMnB92K,KAAK+2K,aAAe,KAMpB/2K,KAAKg3K,SAAW,KAMhBh3K,KAAKi3K,UAAY,KAMjBj3K,KAAKk3K,iBAAmB,KAMxBl3K,KAAKm3K,iBAAmB,KAEpBxsK,EAAQ2qK,aAKVt1K,KAAKo3K,mBAC0B5wK,MAA7BmE,EAAQ4qK,kBACJ/uJ,GAAoBtf,KAAKlH,KAAM,MAC/B2K,EAAQ4qK,kBAMdv1K,KAAKq3K,mBAC0B7wK,MAA7BmE,EAAQ6qK,kBACJhvJ,GAAoBtf,KAAKlH,KAAM,MAC/B2K,EAAQ6qK,kBAQdx1K,KAAKs3K,kBACyB9wK,MAA5BmE,EAAQ8qK,iBAAgC,EAAI9qK,EAAQ8qK,iBAQtDz1K,KAAKu3K,kBACyB/wK,MAA5BmE,EAAQ+qK,iBAAgC,EAAI/qK,EAAQ+qK,iBAMtD11K,KAAKw3K,mBAAqB,IAAI1uB,GAAM,CAClClmG,UAC4Bp8C,IAA1BmE,EAAQgrK,cACJhrK,EAAQgrK,cAAc5gK,QACtB,IAAI20I,GAAK,CACPjmG,KAAM,0BACNuzB,aAAc,SACd/B,KAAM,IAAI6wE,GAAK,CACb77G,MAAO,kBAETirC,OAAQ,IAAI+yE,GAAO,CACjBh+G,MAAO,sBACPx6B,MAAO,QAUnBzP,KAAKy3K,eAAkB93H,IACrB,MAAMiG,EAAQjG,EAAQv2C,IAAI,mBAE1B,OADApJ,KAAKw3K,mBAAmBniG,UAAUg0E,QAAQzjG,GACnC5lD,KAAKw3K,kBAAkB,EAOhCx3K,KAAK03K,mBAAqB,IAAI5uB,GAAM,CAClClmG,UAC4Bp8C,IAA1BmE,EAAQirK,cACJjrK,EAAQirK,cAAc7gK,QACtB,IAAI20I,GAAK,CACPjmG,KAAM,0BACNszB,UAAW,QACX9B,KAAM,IAAI6wE,GAAK,CACb77G,MAAO,kBAETirC,OAAQ,IAAI+yE,GAAO,CACjBh+G,MAAO,sBACPx6B,MAAO,QAUnBzP,KAAK23K,eAAkBh4H,IACrB,MAAMiG,EAAQjG,EAAQv2C,IAAI,mBAE1B,OADApJ,KAAK03K,mBAAmBriG,UAAUg0E,QAAQzjG,GACnC5lD,KAAK03K,kBAAkB,EAGhC13K,KAAKk3K,iBAAmB,GACxBl3K,KAAKm3K,iBAAmB,GAExBn3K,KAAKsF,iBAAiBwC,GAAsB9H,KAAK43K,YAAY1wK,KAAKlH,QAOpEA,KAAK63K,gBACmBrxK,IAAtBmE,EAAQkrK,UAA0BlrK,EAAQkrK,UAAYZ,GAGxDj1K,KAAKi9C,UACH,IAAI6iD,GAAa,CACfxsF,OAAQtT,KAAK83K,eAAe5wK,KAAKlH,MACjCo8F,SAAUp8F,KAAK+3K,iBAAiB7wK,KAAKlH,MACrCmjE,SAAU,IAAI34D,EACd0xF,UAAU,EACVI,iBAAiB,EACjBp9E,MAAOvU,EAAQuU,SASnBlf,KAAKg4K,aAAe,GAMpBh4K,KAAKi4K,WAAa,IAAInvB,GAAM,CAC1B5zE,OAAQl1E,KAAK02K,eAOf12K,KAAKk4K,cAAgB,KAMrBl4K,KAAKqgH,gBAAkB,KAMvBrgH,KAAKmuK,oBAAsB,KAE3BnuK,KAAK00J,eAAe,KACrB,CASD,gBAAAqjB,CAAiBv+J,EAAQmD,GAEvB,IAAIw7J,EAAkB3+J,EAAO1V,QAe7B,OAdI9D,KAAK6zC,aAAe7zC,KAAKk9C,YAAYgD,YACvC0vH,GAAYuI,EAAiBn4K,KAAK6zC,aAEhC7zC,KAAKk4K,gBAELh9J,GAAoBlb,KAAKk4K,cAAeC,EAAiBx7J,GAGzDw7J,EAAkBn4K,KAAKk4K,cAAcp0K,QAGrC9D,KAAKk9C,YAAYwiD,mBAAmB1/F,KAAKk4K,gBAGtC,CAACC,EACT,CAQD,cAAAL,CAAet+J,EAAQmD,EAAYwC,GACjCnf,KAAKk4K,cAAgB1+J,EACrB,MAAMtP,EAASlK,KAAKk9C,YASdy1F,EAAe/0H,GAND5d,KAAKqf,aAAe,EACrC5E,KACAA,IACDA,IACAA,KAEgDjB,GAElD,GACExZ,KAAKqgH,iBACL99G,GAAOvC,KAAKqgH,gBAAiBsyB,IAC7B3yI,KAAKmuK,sBAAwBxxJ,EAE7B,OAMF,GAJA3c,KAAKqgH,gBAAkBsyB,EACvB3yI,KAAKmuK,oBAAsBxxJ,EAGvB7X,GAAQ6tI,GACV,OAIF,MAAMj2H,EAASJ,GAAUq2H,GACnB7kH,EAAoBnR,EAAaA,EAAc,IAGlD3c,KAAK6zC,cAAgBukI,GAAqBp4K,KAAK6zC,YAAa10B,KAG7Dnf,KAAKq4K,sBAAsBl5J,GAG7Bnf,KAAKs4K,iBAAiB3lC,EAAcj2H,EAAQC,EAAYmR,GAGxD,IAQI6xB,EARAmtH,EAAe9sK,KAAKw2K,WAAWr1K,OAASnB,KAAKy2K,WAAWt1K,OAS5D,IARInB,KAAKk3K,mBACPpK,GAAgB9sK,KAAKw2K,WAAWr1K,QAE9BnB,KAAKm3K,mBACPrK,GAAgB9sK,KAAKy2K,WAAWt1K,QAI3B2rK,EAAe9sK,KAAKg4K,aAAa72K,QACtCw+C,EAAU,IAAIvrC,GACdpU,KAAKg4K,aAAaryK,KAAKg6C,GAGzB,MAAM44H,EAAeruK,EAAOq0F,wBAC5Bg6E,EAAa5zK,QACb,IAGI/C,EAAGod,EAHHw5J,EAAY,EAIhB,IAAK52K,EAAI,EAAGod,EAAIhf,KAAKw2K,WAAWr1K,OAAQS,EAAIod,IAAKpd,EAC/C+9C,EAAU3/C,KAAKg4K,aAAaQ,KAC5B74H,EAAQ9qC,YAAY7U,KAAKw2K,WAAW50K,IACpC+9C,EAAQvqC,SAASpV,KAAKi4K,YACtBM,EAAa5yK,KAAKg6C,GAEpB,IAAK/9C,EAAI,EAAGod,EAAIhf,KAAKy2K,WAAWt1K,OAAQS,EAAIod,IAAKpd,EAC/C+9C,EAAU3/C,KAAKg4K,aAAaQ,KAC5B74H,EAAQ9qC,YAAY7U,KAAKy2K,WAAW70K,IACpC+9C,EAAQvqC,SAASpV,KAAKi4K,YACtBM,EAAa5yK,KAAKg6C,EAErB,CAYD,YAAA84H,CAAa7D,EAAK8D,EAAQC,EAAQ7qJ,EAAkBtU,EAAQvW,GAC1D,MAAM+1F,EAAah5F,KAAK44K,aACtBhE,EACA8D,EACAC,EACA7qJ,EACA7qB,GAEF,GAAI6a,GAAWk7E,EAAW35E,YAAa7F,GAAS,CAC9C,GAAIxZ,KAAKk3K,iBAAkB,CACzB,MAAMt0H,EAAO5iD,KAAKo3K,mBAAmBxC,GACjC3xK,KAASjD,KAAKk3K,iBAChBl3K,KAAKk3K,iBAAiBj0K,GAAO2/C,KAAOA,EAEpC5iD,KAAKk3K,iBAAiBj0K,GAAS,CAC7B41K,KAAM,IAAIrlJ,GAAM,IAChBovB,KAAMA,EAGX,CACD5iD,KAAKw2K,WAAWvzK,KAAW+1F,CAC5B,CACD,OAAO/1F,CACR,CAYD,YAAA61K,CAAanwJ,EAAKowJ,EAAQC,EAAQlrJ,EAAkBtU,EAAQvW,GAC1D,MAAM+1F,EAAah5F,KAAKi5K,aACtBtwJ,EACAowJ,EACAC,EACAlrJ,EACA7qB,GAEF,GAAI6a,GAAWk7E,EAAW35E,YAAa7F,GAAS,CAC9C,GAAIxZ,KAAKm3K,iBAAkB,CACzB,MAAMv0H,EAAO5iD,KAAKq3K,mBAAmB1uJ,GACjC1lB,KAASjD,KAAKm3K,iBAChBn3K,KAAKm3K,iBAAiBl0K,GAAO2/C,KAAOA,EAEpC5iD,KAAKm3K,iBAAiBl0K,GAAS,CAC7B41K,KAAM,IAAIrlJ,GAAM,IAChBovB,KAAMA,EAGX,CACD5iD,KAAKy2K,WAAWxzK,KAAW+1F,CAC5B,CACD,OAAO/1F,CACR,CAMD,WAAA20K,CAAY/xK,GACV,MAAM+W,EAAW/W,EAAM43C,WAAWjE,UAAU58B,SACtCD,EAAa9W,EAAM43C,WAAWjE,UAAU78B,WACxCjJ,EAAO7N,EAAM43C,WAAW/pC,KACxB8F,EAAS3T,EAAM43C,WAAWjkC,OAC1B0/J,EAAiB58J,GAAU9C,GACjC,IAAI2/J,EAAiB3/J,EACrB,GAAIoD,EAAU,CACZ,MAAMw8J,EAAiB1lK,EAAK,GAAKiJ,EAC3B08J,EAAkB3lK,EAAK,GAAKiJ,EAClCw8J,EAAiB,CACfD,EAAe,GAAKE,EAAiB,EACrCF,EAAe,GAAKG,EAAkB,EACtCH,EAAe,GAAKE,EAAiB,EACrCF,EAAe,GAAKG,EAAkB,EAEzC,CAED,IAAIviB,EAAa,EACb9B,EAAW,EACXskB,EAAgBt5K,KAAKu3K,kBAAoB,GAC7C,MAAMn4J,EAAmBpf,KAAK6zC,YAAYx0B,YACpCE,EAAanD,GAASgD,GAC5B,GACEpf,KAAKk9C,YAAYgD,YACjBlgD,KAAK6zC,YAAYv0B,aAChBtF,GAAeoF,EAAkB5F,GAClC,CACAs9I,EAAa7qJ,KAAKuT,OAAOhG,EAAO,GAAK4F,EAAiB,IAAMG,GAC5Dy1I,EAAW/oJ,KAAKkZ,MAAM3L,EAAO,GAAK4F,EAAiB,IAAMG,GAEzD+5J,EAAgBA,IADCrtK,KAAKmP,IAAIwB,GAAY3Q,KAAK+T,GAAK,CAEjD,CACD,MAAMu5J,EAAgBl9F,GAAiBx2E,GAEvC,IAAK,IAAIkyJ,EAAQjB,EAAYiB,GAAS/C,IAAY+C,EAAO,CACvD,IACIp4G,EAAS18C,EAAO+b,EAAGw6J,EADnBhB,EAAYx4K,KAAKw2K,WAAWr1K,OAASnB,KAAKy2K,WAAWt1K,OAGzD,GAAInB,KAAKk3K,iBACP,IAAKj0K,EAAQ,EAAG+b,EAAIhf,KAAKk3K,iBAAiB/1K,OAAQ8B,EAAQ+b,IAAK/b,EAAO,CACpE,MAAM+1F,EAAah5F,KAAKw2K,WAAWvzK,GACnC,GAAK2Z,GAAsB,IAAVm7I,EAEV,CACL,MAAMhjJ,EAAQikF,EAAWjkF,QACzBA,EAAM8C,UAAUkgJ,EAAQx4I,EAAY,GACpCxK,EAAMwC,QAAQqF,EAAUs8J,GACxBM,EAAYx5K,KAAKy5K,kBAAkB1kK,EAAOokK,EAAgBl2K,GAC1Du2K,EAAUjiK,OAAOqF,EAAUs8J,EAC5B,MAPCM,EAAYx5K,KAAKy5K,kBAAkBzgF,EAAYx/E,EAAQvW,GAQzD08C,EAAU3/C,KAAKg4K,aAAaQ,KAC5B74H,EAAQ9qC,YAAY2kK,GACpB75H,EAAQ51C,IAAI,kBAAmB/J,KAAKk3K,iBAAiBj0K,GAAO2/C,MAC5D22H,EAAchpG,YAAY5wB,EAAS3/C,KAAKy3K,eAAe93H,GACxD,CAEH,GAAI3/C,KAAKm3K,mBAEJpf,IAAUjB,GAAcwiB,GACxBvhB,IAAU/C,IAAaskB,GAExB,IAAKr2K,EAAQ,EAAG+b,EAAIhf,KAAKy2K,WAAWt1K,OAAQ8B,EAAQ+b,IAAK/b,EAAO,CAC9D,MAAM+1F,EAAah5F,KAAKy2K,WAAWxzK,GACnC,GAAK2Z,GAAsB,IAAVm7I,EAEV,CACL,MAAMhjJ,EAAQikF,EAAWjkF,QACzBA,EAAM8C,UAAUkgJ,EAAQx4I,EAAY,GACpCxK,EAAMwC,QAAQqF,EAAUs8J,GACxBM,EAAYx5K,KAAK05K,kBAAkB3kK,EAAOokK,EAAgBl2K,GAC1Du2K,EAAUjiK,OAAOqF,EAAUs8J,EAC5B,MAPCM,EAAYx5K,KAAK05K,kBAAkB1gF,EAAYx/E,EAAQvW,GAQzD08C,EAAU3/C,KAAKg4K,aAAaQ,KAC5B74H,EAAQ9qC,YAAY2kK,GACpB75H,EAAQ51C,IAAI,kBAAmB/J,KAAKm3K,iBAAiBl0K,GAAO2/C,MAC5D22H,EAAchpG,YAAY5wB,EAAS3/C,KAAK23K,eAAeh4H,GACxD,CAGN,CACF,CASD,gBAAA24H,CAAiB9+J,EAAQkD,EAAQC,EAAYmR,GAC3C,MAAM+0B,EAAW7iD,KAAK25K,aAAah9J,GACnC,IAAiB,GAAbkmC,EASF,OARA7iD,KAAKw2K,WAAWr1K,OAAS,EACzBnB,KAAKy2K,WAAWt1K,OAAS,EACrBnB,KAAKk3K,mBACPl3K,KAAKk3K,iBAAiB/1K,OAAS,QAE7BnB,KAAKm3K,mBACPn3K,KAAKm3K,iBAAiBh2K,OAAS,IAKnC,IAAI+d,GAAQ,EACZ,MAAME,EAAmBpf,KAAK6zC,YAAYx0B,YACpCE,EAAanD,GAASgD,GAE1Bpf,KAAKk9C,YAAYgD,YACjBlgD,KAAK6zC,YAAYv0B,aAChBtF,GAAeoF,EAAkB5F,KAE9B4C,GAAS5C,IAAW+F,GACtB/F,EAAO,GAAK4F,EAAiB,GAC7B5F,EAAO,GAAK4F,EAAiB,IAE7BF,GAAQ,GAMZ,MAAM06J,EAAe,CACnB91J,GAAMpH,EAAO,GAAI1c,KAAKo2K,MAAOp2K,KAAKk2K,OAClCpyJ,GAAMpH,EAAO,GAAI1c,KAAKq2K,MAAOr2K,KAAKm2K,QAO9B0D,EAAe75K,KAAK42K,mBAAmBgD,GACzCprJ,MAAMqrJ,EAAa,MACrBA,EAAa,GACX5tK,KAAKmP,IAAIpb,KAAK81K,UAAY7pK,KAAKmP,IAAIpb,KAAKg2K,SACpCh2K,KAAK81K,QACL91K,KAAKg2K,SAEb,IAAI8D,EAAYh2J,GAAM+1J,EAAa,GAAI75K,KAAKi2K,QAASj2K,KAAK+1K,SACtDgE,EAAYj2J,GAAM+1J,EAAa,GAAI75K,KAAKg2K,QAASh2K,KAAK81K,SAC1D,MAAMV,EAAWp1K,KAAKu2K,UACtB,IAAIyD,EAAKtiB,EAAK/uI,EAAKisJ,EAIfqF,EAAezgK,EACd0F,IACH+6J,EAAe,CACbn2J,GAAMtK,EAAO,GAAIxZ,KAAKo2K,MAAOp2K,KAAKk2K,OAClCpyJ,GAAMtK,EAAO,GAAIxZ,KAAKq2K,MAAOr2K,KAAKm2K,OAClCryJ,GAAMtK,EAAO,GAAIxZ,KAAKo2K,MAAOp2K,KAAKk2K,OAClCpyJ,GAAMtK,EAAO,GAAIxZ,KAAKq2K,MAAOr2K,KAAKm2K,SAMtC,MAAM+D,EAAcv7J,GAClBs7J,EACAj6K,KAAK42K,wBACLpwK,EACA,GAGF,IAAImyK,EAASuB,EAAY,GACrBlB,EAASkB,EAAY,GACrBxB,EAASwB,EAAY,GACrBnB,EAASmB,EAAY,GAwCzB,GAtCKh7J,IAKCpF,GAAmBmgK,EAAcj6K,KAAK82K,eACxCiC,EAAS/4K,KAAKi2K,QACdyC,EAAS14K,KAAKg2K,SAEZl8J,GAAmBmgK,EAAcj6K,KAAK+2K,gBACxCiC,EAASh5K,KAAK+1K,QACd2C,EAAS14K,KAAKg2K,SAEZl8J,GAAmBmgK,EAAcj6K,KAAKg3K,YACxC+B,EAAS/4K,KAAKi2K,QACd0C,EAAS34K,KAAK81K,SAEZh8J,GAAmBmgK,EAAcj6K,KAAKi3K,aACxC+B,EAASh5K,KAAK+1K,QACd4C,EAAS34K,KAAK81K,SAKhB6C,EAAS70J,GAAM60J,EAAQoB,EAAW/5K,KAAK81K,SACvCkD,EAASl1J,GAAMk1J,EAAQc,EAAW95K,KAAK+1K,SACvC2C,EAAS50J,GAAM40J,EAAQ14K,KAAKg2K,QAAS+D,GACrChB,EAASj1J,GAAMi1J,EAAQ/4K,KAAKi2K,QAAS6D,IAKvCA,EAAY7tK,KAAKuT,MAAMs6J,EAAYj3H,GAAYA,EAC/C+xH,EAAM9wJ,GAAMg2J,EAAW95K,KAAKi2K,QAASj2K,KAAK+1K,SAE1Cre,EAAM13J,KAAKy4K,aAAa7D,EAAK8D,EAAQC,EAAQ7qJ,EAAkBtU,EAAQ,GAEvEwgK,EAAM,EACF96J,EACF,MAAQ01J,GAAO/xH,IAAak2H,GAAUiB,IAAQ5E,GAC5C1d,EAAM13J,KAAKy4K,aACT7D,EACA8D,EACAC,EACA7qJ,EACAtU,EACAk+I,QAIJ,KAAOkd,GAAO50K,KAAKi2K,SAAW+D,IAAQ5E,GACpCR,EAAM3oK,KAAKyP,IAAIk5J,EAAM/xH,EAAU7iD,KAAKi2K,SACpCve,EAAM13J,KAAKy4K,aACT7D,EACA8D,EACAC,EACA7qJ,EACAtU,EACAk+I,GAQN,GAHAkd,EAAM9wJ,GAAMg2J,EAAW95K,KAAKi2K,QAASj2K,KAAK+1K,SAE1CiE,EAAM,EACF96J,EACF,MAAQ01J,GAAO/xH,IAAam2H,GAAUgB,IAAQ5E,GAC5C1d,EAAM13J,KAAKy4K,aACT7D,EACA8D,EACAC,EACA7qJ,EACAtU,EACAk+I,QAIJ,KAAOkd,GAAO50K,KAAK+1K,SAAWiE,IAAQ5E,GACpCR,EAAM3oK,KAAKwP,IAAIm5J,EAAM/xH,EAAU7iD,KAAK+1K,SACpCre,EAAM13J,KAAKy4K,aACT7D,EACA8D,EACAC,EACA7qJ,EACAtU,EACAk+I,GAkBN,IAbA13J,KAAKw2K,WAAWr1K,OAASu2J,EACrB13J,KAAKk3K,mBACPl3K,KAAKk3K,iBAAiB/1K,OAASu2J,GAKjCqiB,EAAY9tK,KAAKuT,MAAMu6J,EAAYl3H,GAAYA,EAC/Cl6B,EAAM7E,GAAMi2J,EAAW/5K,KAAKg2K,QAASh2K,KAAK81K,SAE1Cpe,EAAM13J,KAAK84K,aAAanwJ,EAAKowJ,EAAQC,EAAQlrJ,EAAkBtU,EAAQ,GAEvEwgK,EAAM,EACCrxJ,GAAO3oB,KAAKg2K,SAAWgE,IAAQ5E,GACpCzsJ,EAAM1c,KAAKyP,IAAIiN,EAAMk6B,EAAU7iD,KAAKg2K,SACpCte,EAAM13J,KAAK84K,aACTnwJ,EACAowJ,EACAC,EACAlrJ,EACAtU,EACAk+I,GAOJ,IAHA/uI,EAAM7E,GAAMi2J,EAAW/5K,KAAKg2K,QAASh2K,KAAK81K,SAE1CkE,EAAM,EACCrxJ,GAAO3oB,KAAK81K,SAAWkE,IAAQ5E,GACpCzsJ,EAAM1c,KAAKwP,IAAIkN,EAAMk6B,EAAU7iD,KAAK81K,SACpCpe,EAAM13J,KAAK84K,aACTnwJ,EACAowJ,EACAC,EACAlrJ,EACAtU,EACAk+I,GAIJ13J,KAAKy2K,WAAWt1K,OAASu2J,EACrB13J,KAAKm3K,mBACPn3K,KAAKm3K,iBAAiBh2K,OAASu2J,EAElC,CAOD,YAAAiiB,CAAah9J,GACX,MAAMm9J,EAAY95K,KAAK62K,wBAAwB,GACzCkD,EAAY/5K,KAAK62K,wBAAwB,GAC/C,IAAIh0H,GAAY,EAChB,MAAM1iD,EAAS8L,KAAKC,IAAIlM,KAAKs2K,YAAc35J,EAAY,GAEjDioH,EAAK,GAELC,EAAK,GACX,IAAK,IAAIjjI,EAAI,EAAGuE,EAAKnG,KAAK63K,WAAW12K,OAAQS,EAAIuE,IAAMvE,EAAG,CACxD,MAAM+L,EAAQmW,GAAM9jB,KAAK63K,WAAWj2K,GAAK,EAAG,EAAG,IAEzCu4K,EAAar2J,GAAMi2J,GAAY,GAAKpsK,EAAO,GAAKA,GACtDi3H,EAAG,GAAKk1C,EAAYnsK,EACpBi3H,EAAG,GAAKu1C,EAAaxsK,EACrBk3H,EAAG,GAAKi1C,EAAYnsK,EACpBk3H,EAAG,GAAKs1C,EAAaxsK,EACrB3N,KAAK22K,qBAAqB/xC,EAAIA,GAC9B5kI,KAAK22K,qBAAqB9xC,EAAIA,GAE9B,GADa54H,KAAKC,IAAI24H,EAAG,GAAKD,EAAG,GAAI,GAAK34H,KAAKC,IAAI24H,EAAG,GAAKD,EAAG,GAAI,IACtDzkI,EACV,MAEF0iD,EAAW7iD,KAAK63K,WAAWj2K,EAC5B,CACD,OAAOihD,CACR,CAWD,YAAA+1H,CAAahE,EAAK8D,EAAQC,EAAQ7qJ,EAAkB7qB,GAClD,MAAM6X,EAAkB65J,GACtBC,EACA8D,EACAC,EACA34K,KAAK6zC,YACL/lB,GAEF,IAAIkrE,EAAah5F,KAAKw2K,WAAWvzK,GAQjC,OAPK+1F,GAIHA,EAAW/oE,mBAAmB,KAAMnV,GACpCk+E,EAAWnxF,YAJXmxF,EAAa,IAAIne,GAAW//D,EAAiB,MAC7C9a,KAAKw2K,WAAWvzK,GAAS+1F,GAKpBA,CACR,CASD,iBAAAygF,CAAkBzgF,EAAYx/E,EAAQvW,GACpC,MAAM6X,EAAkBk+E,EAAWzpE,qBACnC,IAAIuzI,EAAS,EACTtpG,EAAM1+C,EAAgB3Z,OAAS,EAC/B2Z,EAAgBgoJ,GAAUhoJ,EAAgB0+C,KAC5CspG,EAAStpG,EACTA,EAAM,GAER,MAAM4gH,EAAgBnuK,KAAKyP,IAAIlC,EAAO,GAAIsB,EAAgBgoJ,IACpDuX,EAAapuK,KAAKwP,IAAIjC,EAAO,GAAIsB,EAAgB0+C,IACjD7wC,EAAM7E,GACVtK,EAAO,GAAKvN,KAAKmP,IAAI5B,EAAO,GAAKA,EAAO,IAAMxZ,KAAKs3K,kBACnD8C,EACAC,GAOIjjK,EAAa,CAJjB0D,EAAgBgoJ,EAAS,IACvBhoJ,EAAgB0+C,EAAM,GAAK1+C,EAAgBgoJ,EAAS,KACnDn6I,EAAM7N,EAAgBgoJ,KACtBhoJ,EAAgB0+C,GAAO1+C,EAAgBgoJ,IACXn6I,GAC3B/F,EAAQ5iB,KAAKk3K,iBAAiBj0K,GAAO41K,KAE3C,OADAj2J,EAAMsN,eAAe9Y,GACdwL,CACR,CAOD,YAAA03J,GACE,OAAOt6K,KAAKw2K,UACb,CAWD,YAAAyC,CAAatwJ,EAAKowJ,EAAQC,EAAQlrJ,EAAkB7qB,GAClD,MAAM6X,EAAkBg6J,GACtBnsJ,EACAowJ,EACAC,EACAh5K,KAAK6zC,YACL/lB,GAEF,IAAIkrE,EAAah5F,KAAKy2K,WAAWxzK,GAOjC,OANK+1F,GAGHA,EAAW/oE,mBAAmB,KAAMnV,GACpCk+E,EAAWnxF,WAHXmxF,EAAa,IAAIne,GAAW//D,EAAiB,MAKxCk+E,CACR,CASD,iBAAA0gF,CAAkB1gF,EAAYx/E,EAAQvW,GACpC,MAAM6X,EAAkBk+E,EAAWzpE,qBACnC,IAAIg1B,EAAO,EACPhvB,EAAQza,EAAgB3Z,OAAS,EACjC2Z,EAAgBypC,GAAQzpC,EAAgBya,KAC1CgvB,EAAOhvB,EACPA,EAAQ,GAEV,MAAMglJ,EAActuK,KAAKyP,IAAIlC,EAAO,GAAIsB,EAAgBypC,IAClDi2H,EAAevuK,KAAKwP,IAAIjC,EAAO,GAAIsB,EAAgBya,IACnDq/I,EAAM9wJ,GACVtK,EAAO,GAAKvN,KAAKmP,IAAI5B,EAAO,GAAKA,EAAO,IAAMxZ,KAAKu3K,kBACnDgD,EACAC,GAOIpjK,EAAa,CAACw9J,EAJlB95J,EAAgBypC,EAAO,IACrBzpC,EAAgBya,EAAQ,GAAKza,EAAgBypC,EAAO,KACnDqwH,EAAM95J,EAAgBypC,KACtBzpC,EAAgBya,GAASza,EAAgBypC,KAExC3hC,EAAQ5iB,KAAKm3K,iBAAiBl0K,GAAO41K,KAE3C,OADAj2J,EAAMsN,eAAe9Y,GACdwL,CACR,CAOD,YAAA63J,GACE,OAAOz6K,KAAKy2K,UACb,CAMD,qBAAA4B,CAAsBl5J,GACpB,MAAM8qG,EAAqBr7F,GAAc,aAEnCnO,EAActB,EAAWoC,iBAE/BvhB,KAAK81K,QAAUr1J,EAAY,GAC3BzgB,KAAK+1K,QAAUt1J,EAAY,GAC3BzgB,KAAKg2K,QAAUv1J,EAAY,GAC3BzgB,KAAKi2K,QAAUx1J,EAAY,GAK3B,MAAMi6J,EAAoB7uJ,GAAa1M,EAAY8qG,GACnD,GAAIjqH,KAAKi2K,QAAUj2K,KAAK+1K,QACtB/1K,KAAK42K,mBAAqB8D,MACrB,CACL,MAAM70J,EAAQ7lB,KAAKi2K,QAAUj2K,KAAK+1K,QAAU,EAC5C/1K,KAAK+1K,SAAW,IAChB/1K,KAAK42K,mBAAqB,SAAUr9J,EAAa0J,EAAQC,GAEvD,MAAMy3J,EAAoBD,EACxBnhK,EACA0J,EAHFC,EAAYA,GAAa,GAMzB,IAAK,IAAIthB,EAAI,EAAGod,EAAI27J,EAAkBx5K,OAAQS,EAAIod,EAAGpd,GAAKshB,EACpDy3J,EAAkB/4K,GAAKikB,IACzB80J,EAAkB/4K,IAAM,KAG5B,OAAO+4K,CACf,CACK,CAKD36K,KAAK22K,qBAAuB9qJ,GAAao+F,EAAoB9qG,GAC7D,MAAMy7J,EAAej8J,GACnB,CAAC3e,KAAKi2K,QAASj2K,KAAKg2K,QAASh2K,KAAK+1K,QAAS/1K,KAAK81K,SAChD91K,KAAK22K,0BACLnwK,EACA,GAGFxG,KAAKo2K,MAAQwE,EAAa,GAC1B56K,KAAKk2K,MAAQ0E,EAAa,GAC1B56K,KAAKq2K,MAAQuE,EAAa,GAC1B56K,KAAKm2K,MAAQyE,EAAa,GAK1B56K,KAAK82K,YAAc92K,KAAK22K,qBAAqB,CAAC32K,KAAKi2K,QAASj2K,KAAKg2K,UACjEh2K,KAAK+2K,aAAe/2K,KAAK22K,qBAAqB,CAAC32K,KAAK+1K,QAAS/1K,KAAKg2K,UAClEh2K,KAAKg3K,SAAWh3K,KAAK22K,qBAAqB,CAAC32K,KAAKi2K,QAASj2K,KAAK81K,UAC9D91K,KAAKi3K,UAAYj3K,KAAK22K,qBAAqB,CAAC32K,KAAK+1K,QAAS/1K,KAAK81K,UAM/D91K,KAAK62K,wBAA0B72K,KAAK42K,mBAClCt6J,GAAU6C,EAAWE,cAEnBmP,MAAMxuB,KAAK62K,wBAAwB,MACrC72K,KAAK62K,wBAAwB,GAC3B5qK,KAAKmP,IAAIpb,KAAK81K,UAAY7pK,KAAKmP,IAAIpb,KAAKg2K,SACpCh2K,KAAK81K,QACL91K,KAAKg2K,SAGbh2K,KAAK6zC,YAAc10B,CACpB,GC3rCH,MAAM9U,GACE,OADFA,GAEM,WAFNA,GAGI,SAOJwwK,GAAmB,CAAC,OAAQ,OAAQ,OAAQ,OAAQ,QAgN1D,IAAAC,GAnMA,cAAsB3jB,GAIpB,WAAAr3J,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B,MAAM4xC,EAAc71C,OAAO8C,OAAO,CAAE,EAAEmB,UAE/B4xC,EAAYw+H,gBACZx+H,EAAYv0B,cACZu0B,EAAYy+H,YACZz+H,EAAYiF,OACnBv8C,MAAMs3C,GAMNv8C,KAAKi7K,UAAY,KAEjBj7K,KAAK6J,kBAAkBQ,GAAmBrK,KAAKk7K,wBAE/Cl7K,KAAKm7K,YAAYxwK,EAAQowK,SAAWpwK,EAAQowK,SAAWF,IAEvD76K,KAAKo7K,aAAyB50K,IAAjBmE,EAAQqwK,KAAqBrwK,EAAQqwK,KAAO,IAEzDh7K,KAAKm3F,eAA6B3wF,IAAnBmE,EAAQqd,OAAuBrd,EAAQqd,OAAS,GAE/D,MAAMw5B,EAAS72C,EAAQ62C,OAAS72C,EAAQ62C,OAAS,SAE/CxhD,KAAKq7K,gBADe,iBAAX75H,EACc,SAAU7B,GAC/B,OAAOA,EAAQv2C,IAAIo4C,EAC3B,EAE6BA,EAKzBxhD,KAAK00J,eAAe,KACrB,CAQD,OAAA4mB,GACE,OAA8Bt7K,KAAKoJ,IAAIiB,GACxC,CAQD,WAAAkxK,GACE,OAAqCv7K,KAAKoJ,IAAIiB,GAC/C,CAQD,SAAA8b,GACE,OAA8BnmB,KAAKoJ,IAAIiB,GACxC,CAKD,sBAAA6wK,GACEl7K,KAAKi7K,UAqGT,SAAwB5uC,GACtB,MAAM58H,EAAQ,EACRC,EAAS,IACTS,EAAUX,GAAsBC,EAAOC,GAEvCqrK,EAAW5qK,EAAQqrK,qBAAqB,EAAG,EAAG/rK,EAAOC,GACrDyvE,EAAO,GAAKktD,EAAOlrI,OAAS,GAClC,IAAK,IAAIS,EAAI,EAAGuE,EAAKkmI,EAAOlrI,OAAQS,EAAIuE,IAAMvE,EAC5Cm5K,EAASU,aAAa75K,EAAIu9E,EAAMktD,EAAOzqI,IAMzC,OAHAuO,EAAQ2sB,UAAYi+I,EACpB5qK,EAAQ4sB,SAAS,EAAG,EAAGttB,EAAOC,GAEvBS,EAAQN,MACjB,CApHqB6rK,CAAe17K,KAAKu7K,cACtC,CAQD,OAAAH,CAAQJ,GACNh7K,KAAK+J,IAAIM,GAAe2wK,EACzB,CAQD,WAAAG,CAAY9uC,GACVrsI,KAAK+J,IAAIM,GAAmBgiI,EAC7B,CAQD,SAAAl1C,CAAUnvE,GACRhoB,KAAK+J,IAAIM,GAAiB2d,EAC3B,CAED,cAAA42B,GACE,MAAMshG,GAAU,IAAIrH,IACjBwB,aAAa,uBACbC,WAAW,gBAAiB,QAAS,iBACrCF,WAAW,gBACXA,WAAW,qBACXG,wBAAwB,gBACxBK,yBACC,uGAGJ,OAAO,IAAI+gC,GAAyB37K,KAAM,CACxCstC,UAAWttC,KAAKytC,eAChB0gF,WAAY,CACV,CACEz4G,KAAM,SACNkG,SAAW+jC,IACT,MAAM6B,EAASxhD,KAAKq7K,gBAAgB17H,GACpC,YAAkBn5C,IAAXg7C,EAAuB19B,GAAM09B,EAAQ,EAAG,GAAK,CAAC,IAI3D6zE,SAAU,CACRumD,OAAQ,IACyD,GAAvD57K,KAAKoJ,IAAIiB,IAAmBrK,KAAKoJ,IAAIiB,KAE/CwxK,YAAa,IAET77K,KAAKoJ,IAAIiB,IAAmB4B,KAAKyP,IAAI,EAAG1b,KAAKoJ,IAAIiB,MAIvDkrJ,qBAAqB,EACrBxhC,aAAcmsB,EAAQnE,wBACtB3nB,eAAgB8rB,EAAQhE,0BACxBvgB,cAAe,CACb,CACEvH,eAAgB,2fAehBiB,SAAU,CACRymD,kBAAmB,IAAM97K,KAAKi7K,UAC9Bc,UAAW,IAAM/7K,KAAK8tC,iBAK/B,CAED,eAAAkZ,GAAoB,GC/ItB,IAAAg1H,GA/BA,cAA+BhI,GAI7B,WAAAl0K,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B,MAAM4xC,EAAc71C,OAAO8C,OAAO,CAAE,EAAEmB,UAC/B4xC,EAAY0/H,WACnBh3K,MAAMs3C,GAMNv8C,KAAKk8K,iBACoB11K,IAAvBmE,EAAQsxK,WAA2BtxK,EAAQsxK,WAAa,CAC3D,CAKD,aAAA1L,GACE,OAAOvwK,KAAKk8K,WACb,CAED,cAAAt9H,GACE,OAAO,IAAIu9H,GAA+Bn8K,KAC3C,GCkJH,IAAAo8K,GA1IA,cAA8BpI,GAI5B,WAAAl0K,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B,MAAM4xC,EAAqC71C,OAAO8C,OAAO,CAAA,EAAImB,UACtD4xC,EAAYqjE,eACZrjE,EAAYsjE,uBAEnB56G,MACJ,GAQIjF,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAEL,MAAM+qK,EAAa/nK,EAAQ+nK,YAAc,SACzCz+J,GACgB,UAAdy+J,GAAwC,UAAdA,EAC1B,iDAOF1yK,KAAKq8K,YAAc3J,EAEnB1yK,KAAK8/G,WAAWn1G,EAAQi1G,QAAUj1G,EAAQi1G,QAAU,GACpD5/G,KAAK+/G,+BACgCv5G,IAAnCmE,EAAQk1G,wBACJl1G,EAAQk1G,wBASd7/G,KAAKwtC,cAOLxtC,KAAKwuC,aACN,CAED,cAAAoQ,GACE,OAAO,IAAI09H,GAA8Bt8K,KAC1C,CAgBD,WAAAq9C,CAAYC,GACV,OAAOr4C,MAAMo4C,YAAYC,EAC1B,CAKD,aAAAm0H,GACE,OAAOzxK,KAAKq8K,WACb,CAQD,UAAAr8D,GACE,OAA8BhgH,KAAKoJ,IAAIs2G,GACxC,CAQD,yBAAAO,GACE,OACEjgH,KAAKoJ,IAAIs2G,GAEZ,CAQD,UAAAI,CAAWF,GACT5/G,KAAK+J,IAAI21G,GAAsBE,EAChC,CAQD,yBAAAG,CAA0BF,GACxB7/G,KAAK+J,IAAI21G,GAAyCG,EACnD,GC7GH,IAAA08D,GAzDA,cAA+Br9G,GAI7B,WAAAp/D,CAAY6K,GAGV1F,MAFoByB,OAAO8C,OAAO,CAAE,EAAEmB,IAQtC3K,KAAKw8K,aAAez7B,GAAkBp2I,EAAQ4F,OAM9CvQ,KAAKy8K,gBAAkB9xK,EAAQ4F,MAAM83H,WAAa,CAAA,EAMlDroI,KAAK08K,wBAA0B/xK,EAAQywJ,mBACxC,CAED,cAAAx8G,GACE,MAAMuvE,EAAaznH,OAAOC,KAAK3G,KAAKw8K,aAAaruD,YAAYrjF,KAC1Dp1B,IAAU,CACTA,UACG1V,KAAKw8K,aAAaruD,WAAWz4G,OAGpC,OAAO,IAAIimK,GAAyB37K,KAAM,CACxC+zH,aAAc/zH,KAAKw8K,aAAat8B,QAAQnE,wBACxC3nB,eAAgBp0H,KAAKw8K,aAAat8B,QAAQhE,0BAC1CqZ,qBAAsBv1J,KAAK08K,sBAC3BrnD,SAAUr1H,KAAKw8K,aAAannD,SAC5BlH,WACN,GAIG,CAMD,oBAAAwuD,CAAqBt0C,GACnB3hI,OAAO8C,OAAOxJ,KAAKy8K,gBAAiBp0C,GACpCroI,KAAK6H,SACN,GC5BH,SAAS+0K,GAAWrsK,EAAOyxF,GACzB,MAAM+xB,EAAe,wBACFygB,GAAWC,oCACbrE,GAASC,sCACRD,GAAS+D,2CACT/D,GAASgE,4CACThE,GAASiE,0CACTjE,GAASkE,wCACTlE,GAASmE,wCACTnE,GAASG,yHAMJiE,GAAWC,qDAE1BrE,GAASkE,sBAAsBlE,GAASiE,wBAAwBjE,GAAS+D,qDACzE/D,GAASmE,sBAAsBnE,GAASiE,wBAAwBjE,GAASgE,2EAE7DhE,GAASC,yBAAyBmE,GAAWC,kBAAkBrE,GAASG,0BAOtFpgI,EAAU,CnD8BdomI,kBAAkB,EAClBlO,UAAW,CAAE,EACbvzH,WAAY,CAAE,EACd0hI,UAAW,CAAE,EACbx0C,UAAW,EACXzxF,MAAO,CAAE,EmDjCTgmI,kBAAkB,EAClBv0C,UAAWA,EACXzxF,MAAOA,GAGHssK,EAAW,GAEjB,QAAoBr2K,IAAhB+J,EAAM05B,MAAqB,CAC7B,MAAMA,EAAQ21G,GAAiBzvI,EAASI,EAAM05B,MAAOk9F,IACrD01C,EAASl3K,KAAK,WAAWskC,KAC1B,CAED,QAAuBzjC,IAAnB+J,EAAMusK,SAAwB,CAChC,MAAMA,EAAWl9B,GAAiBzvI,EAASI,EAAMusK,SAAU71C,IAC3D41C,EAASl3K,KACP,sBAAsBm3K,2BAAkCA,uDAE3D,CAED,QAAuBt2K,IAAnB+J,EAAMwsK,SAAwB,CAChC,MAAMA,EAAWn9B,GAAiBzvI,EAASI,EAAMwsK,SAAU91C,IAC3D41C,EAASl3K,KACP,sBAAsBo3K,mEAEzB,CAED,QAAyBv2K,IAArB+J,EAAMysK,WAA0B,CAClC,MAAMA,EAAap9B,GAAiBzvI,EAASI,EAAMysK,WAAY/1C,IAC/D41C,EAASl3K,KAAK,8BACSq3K,oZAWxB,CAED,QAAoBx2K,IAAhB+J,EAAM0sK,MAAqB,CAC7B,MAAMA,EAAQr9B,GAAiBzvI,EAASI,EAAM0sK,MAAOh2C,IACrD41C,EAASl3K,KAAK,yCAAyCs3K,OACxD,CAED,QAAyBz2K,IAArB+J,EAAM2sK,WAA0B,CAClC,MAAMA,EAAat9B,GAAiBzvI,EAASI,EAAM2sK,WAAYj2C,IAC/D41C,EAASl3K,KACP,iCAAiCu3K,gDAEpC,CAGD,MAAM7nD,EAAW,CAAA,EAEX8nD,EAAez2K,OAAOC,KAAKwJ,EAAQk4H,WAAWlnI,OACpD,GAAIg8K,EAAe,IAAM5sK,EAAM83H,UAC7B,MAAM,IAAI7/H,MACR,wCAAwC2H,EAAQk4H,cAIpD,IAAK,IAAIzmI,EAAI,EAAGA,EAAIu7K,IAAgBv7K,EAAG,CACrC,MAAM+gJ,EAAWxyI,EAAQk4H,UAAU3hI,OAAOC,KAAKwJ,EAAQk4H,WAAWzmI,IAClE,KAAM+gJ,EAASjtI,QAAQnF,EAAM83H,WAC3B,MAAM,IAAI7/H,MAAM,YAAYm6I,EAASjtI,4BAGvC2/G,EADoB+gB,GAAuBuM,EAASjtI,OAC5B,WACtB,IAAIrR,EAAQkM,EAAM83H,UAAUsa,EAASjtI,MAIrC,MAHqB,iBAAVrR,IACTA,EAAQ4xI,GAA0B5xI,SAEnBmC,IAAVnC,EAAsBA,GAAS,OAC5C,CACG,CAED,MAAM+4K,EAAsB12K,OAAOC,KAAK0uH,GAAUvqF,KAAI,SAAUp1B,GAC9D,MAAO,iBAAiBA,IAC5B,IAEQ04H,EAAeniI,KAAKkZ,KAAK68E,EAAY,GAC3Co7E,EAAoBz3K,KAClB,qBAAqByqI,GAAS8D,sBAAsB9F,OAGlDj+H,EAAQ+kI,iBACVkoC,EAAoBz3K,KAClB,qBAAqB+wI,MAAyBvmI,EAAQ+kI,gBAAgB/zI,YAI1E,MAAMk8K,EAAqB32K,OAAOC,KAAKwJ,EAAQqmI,WAAW1rG,KAAI,SAC5Dp1B,GAEA,OAAOvF,EAAQqmI,UAAU9gI,EAC7B,IA2CE,MAAO,CACLq+G,aAAcA,EACdK,eA3CqB,gNASNgc,GAASI,qCACRJ,GAASE,wCACTF,GAAS+D,2CACT/D,GAASgE,4CACThE,GAAShhG,kCACTghG,GAAS5W,gBAEvB4jD,EAAoBtkK,KAAK,gBAEzBukK,EAAmBvkK,KAAK,mEAIJs3H,GAASI,gDACTJ,GAASI,gDACTJ,GAASI,gDACTJ,GAASI,0FAM3BJ,GAAS8D,qDAGT2oC,EAAS/jK,KAAK,0GAIEs3H,GAASE,2BAM7Bjb,SAAUA,EACV6f,gBAAiB/kI,EAAQ+kI,gBAE7B,CAcA,MAAMooC,WAAuBv6D,GAI3B,WAAAjjH,CAAY6K,GAGV,MAAM4F,GAFN5F,EAAUA,EAAUjE,OAAO8C,OAAO,CAAA,EAAImB,GAAW,IAE3B4F,OAAS,UACxB5F,EAAQ4F,MAEf,MAAM86B,EAAY1gC,EAAQ0gC,iBACnB1gC,EAAQ0gC,UAEfpmC,MAAM0F,GAMN3K,KAAKu9K,SAAW5yK,EAAQ4yE,QAMxBv9E,KAAKw9K,gBAAkB,KAMvBx9K,KAAKmuK,oBAAsB9/I,IAM3BruB,KAAKwU,OAASjE,EAMdvQ,KAAKisC,WAAaZ,EAMlBrrC,KAAKy8K,gBAAkBz8K,KAAKwU,OAAO6zH,WAAa,CAAA,EAEhDroI,KAAK6J,kBAAkB6iC,GAAsB1sC,KAAKy9K,oBACnD,CAQD,UAAAhoC,CAAWj8H,EAAQmD,GACjB,MAAMzS,EAASlK,KAAKk9C,YACpB,OAAOl9C,KAAKu9K,SACiB,mBAAlBv9K,KAAKu9K,SACVv9K,KAAKu9K,SAAS/jK,EAAQmD,GACtB3c,KAAKu9K,SACPrzK,EACA,CAACA,GACD,EACL,CAKD,eAAAizC,GACE,OAAOn9C,KAAKw9K,iBAAmBx9K,KAAKk9C,WACrC,CAKD,cAAA3O,GACE,MAAMrkC,EAASlK,KAAKm9C,kBACpB,OAAOjzC,EAASA,EAAOiD,WAAa,WACrC,CAKD,mBAAAswK,GACMz9K,KAAK6+C,eACP7+C,KAAKo+C,cAAc6zF,aAEjBjyI,KAAKk9C,aACPl9C,KAAKoV,SAASpV,KAAKwU,OAEtB,CAMD,mBAAAkpK,GACE,MAAMhiK,EAAMyuB,OAAOwzI,iBACbpgG,EAAUv9E,KAAKy1I,WAAW,EAAE/5H,GAAMA,EAAKA,EAAKA,GAAMA,GACxD,OAAO6hE,GAAWA,EAAQp8E,QAAU,cAAeo8E,EAAQ,GACvDA,EAAQ,GAAGykB,UACX,CACL,CAED,cAAApjD,GACE,MAAMg/H,EAAchB,GAAW58K,KAAKwU,OAAQxU,KAAK09K,uBAEjD,OAAO,IAAIG,GAAuB79K,KAAM,CACtC+zH,aAAc6pD,EAAY7pD,aAC1BK,eAAgBwpD,EAAYxpD,eAC5BiB,SAAUuoD,EAAYvoD,SACtBhqF,UAAWrrC,KAAKisC,WAChBipG,gBAAiB0oC,EAAY1oC,iBAEhC,CAOD,aAAA4oC,CAAcrgI,EAAY8/B,GACxB,MAAMp/B,EAAgBn+C,KAAKo+C,cAC3B,IAAIvuC,EACJ,IAAK,IAAIjO,EAAI,EAAGuE,EAAKo3E,EAAQp8E,OAAQS,EAAIuE,IAAMvE,EAC7C5B,KAAKw9K,gBAAkBjgG,EAAQ37E,GAC3Bu8C,EAAcE,aAAaZ,KAC7B5tC,EAASsuC,EAAcG,YAAYb,IAGvC,OAAO5tC,CACR,CAQD,MAAAitC,CAAOW,EAAYt9C,GACjBH,KAAK68C,UAAW,EAChB,MAAMrD,EAAYiE,EAAWjE,UACvB+jC,EAAUv9E,KAAKy1I,WAAWh4F,EAAWjkC,OAAQggC,EAAU78B,YAC7D,IAAIwnD,GAAQ,EACZ,IAAK,IAAIviE,EAAI,EAAGuE,EAAKo3E,EAAQp8E,OAAQS,EAAIuE,IAAMvE,EAAG,CAChD,MAAMsI,EAASqzE,EAAQ37E,GACjBklD,EAAc58C,EAAOiD,WAC3B,GAAmB,WAAf25C,EAA0B,CAC5B,MAAMi3H,EAAW,KACU,SAArB7zK,EAAOiD,aACTjD,EAAO5D,oBAAoB,SAAUy3K,GACrC/9K,KAAK6H,UACN,EAEHqC,EAAO5E,iBAAiB,SAAUy4K,EACnC,CACD55G,EAAQA,GAAwB,SAAfrd,CAClB,CACD,MAAMj3C,EAAS7P,KAAK89K,cAAcrgI,EAAY8/B,GAC9C,GAAIv9E,KAAKo+C,cAAcozF,gBAAkBrtE,EAGvC,OADAnkE,KAAKmuK,oBAAsB30H,EAAU78B,WAC9B9M,EAGT,GAAI7P,KAAKmuK,oBAAsB,GAAM30H,EAAU78B,WAAY,CACzD,MAAMqhK,EAAah+K,KAAKy1I,WACtBh4F,EAAWjkC,OACXxZ,KAAKmuK,qBACL12H,QAAQvtC,IAAYqzE,EAAQ73E,SAASwE,KACvC,GAAI8zK,EAAW78K,OAAS,EACtB,OAAOnB,KAAK89K,cAAcrgI,EAAYugI,EAEzC,CACD,OAAOnuK,CACR,CAUD,QAAAuF,CAAS7E,GACPvQ,KAAKy8K,gBAAkBlsK,EAAM83H,WAAa,CAAA,EAC1CroI,KAAKwU,OAASjE,EACd,MAAMqtK,EAAchB,GAAW58K,KAAKwU,OAAQxU,KAAK09K,uBAChC19K,KAAKo+C,cACbroC,MAAM,CACbg+G,aAAc6pD,EAAY7pD,aAC1BK,eAAgBwpD,EAAYxpD,eAC5BiB,SAAUuoD,EAAYvoD,SACtB6f,gBAAiB0oC,EAAY1oC,kBAE/Bl1I,KAAK6H,SACN,CAOD,oBAAA80K,CAAqBt0C,GACnB3hI,OAAO8C,OAAOxJ,KAAKy8K,gBAAiBp0C,GACpCroI,KAAK6H,SACN,EAQHy1K,GAAez5K,UAAUrD,QAEzB,IAAAy9K,GAAeX,GC1Pf,IAAAY,GA5OA,cAA+BlpH,GAI7B,WAAAl1D,CAAYq+K,GACV,MAAMxzK,EAAUwzK,GAA4B,GAE5Cl5K,MACJ,GAGQ0F,EAAQgrD,WACV31D,KAAK21D,SAAWhrD,EAAQgrD,UAO1B31D,KAAKo+K,mBAAqBzzK,EAAQgD,MAAQhD,EAAQgD,MAAQ,IAM1D3N,KAAK2yD,eAAiCnsD,IAArBmE,EAAQwzB,SAAyBxzB,EAAQwzB,SAAW,IAMrEn+B,KAAKq+K,yBAA0B,EAM/Br+K,KAAKs+K,6BAA8B,EAMnCt+K,KAAKu+K,yBAAsB/3K,EAM3BxG,KAAKw+K,iBAAmB,GAMxBx+K,KAAK61D,eAAiB,EACvB,CAUD,WAAAzvD,CAAYyuD,GACV,IAAKA,EAAgBpM,cACnB,OAAO,EAGT,IAAIyM,GAAY,EAEhB,GADAl1D,KAAK+1D,uBAAuBlB,GACxB70D,KAAKq+K,yBACP,GAAIxpH,EAAgB90D,MAAQipD,GAAoBI,YAC9CppD,KAAKw1D,gBAAgBX,GAErBA,EAAgBpM,cAAcroD,sBACzB,GAAIy0D,EAAgB90D,MAAQipD,GAAoBO,UAAW,CAChE,MAAMyM,EAAYh2D,KAAK01D,cAAcb,GACrC70D,KAAKq+K,wBAA0BroH,CAChC,OAED,GAAInB,EAAgB90D,MAAQipD,GAAoBM,YAC9C,GAAItpD,KAAKs+K,4BAA6B,CACpCt+K,KAAKs+K,6BAA8B,EACnC,MAAMroH,EAAUj2D,KAAKu1D,gBAAgBV,GACrC70D,KAAKq+K,wBAA0BpoH,EAC/Bf,EAAYl1D,KAAK21D,SAASM,EACpC,MACUf,EAAYl1D,KAAK21D,UAAS,GAC1B31D,KAAKy+K,iBAIX,OAAQvpH,CACT,CAMD,eAAAM,CAAgBX,GACd,IAAI4I,EAAa,EAEjB,MAAML,EAASp9D,KAAK61D,eAAe,GAC7BwH,EAASr9D,KAAKsqD,MAAM7B,cACpBjhC,EAAW41C,EAAOjR,QAAUkR,EAAOlR,aAEd3lD,IAAvBxG,KAAKu9D,gBACPE,EACE,GAAKz9D,KAAKu9D,cAAgB/1C,GAAYxnB,KAAKo+K,oBAE/Cp+K,KAAKu9D,cAAgB/1C,EAEH,GAAdi2C,IACFz9D,KAAKw9D,gBAAkBC,GAIzB,MAAM3yB,EAAM+pB,EAAgB/pB,IACtB0S,EAAO1S,EAAI6S,UACjB7S,EAAIgS,SACJU,EAAKtC,yBAAyBuiB,EAC/B,CAOD,eAAAlI,CAAgBV,GACd,GAAkC,GAA9B70D,KAAK61D,eAAe10D,OAAa,CACnC,MAAM2pC,EAAM+pB,EAAgB/pB,IAQ5B,OAPA9qC,KAAK88D,QAAU,KACf98D,KAAKu9D,mBAAgB/2D,EACrBxG,KAAKw9D,gBAAkB,EACvBx9D,KAAKsqD,MAAQuK,EACR70D,KAAKq+K,yBACRvzI,EAAI6S,UAAU9B,oBAET,CACR,CACD,OAAO,CACR,CAOD,aAAA6Z,CAAcb,GACZ,GAAkC,GAA9B70D,KAAK61D,eAAe10D,OAAa,CACnC,MACMq8C,EADMqX,EAAgB/pB,IACX6S,UACXj8C,EAAY1B,KAAKw9D,gBAAkB,EAAI,GAAK,EAIlD,OAHAhgB,EAAK1B,eAAe97C,KAAK2yD,UAAWjxD,GACpC1B,KAAKq+K,yBAA0B,EAC/Br+K,KAAKs+K,6BAA8B,GAC5B,CACR,CACD,OAAO,CACR,CAQD,QAAA3oH,CAASM,GACP,OAAOA,CACR,CAMD,sBAAAF,CAAuBlB,GACrB,GAgDJ,SAAgCA,GAC9B,MAAM90D,EAAO80D,EAAgB90D,KAC7B,OACEA,IAASipD,GAAoBM,aAC7BvpD,IAASipD,GAAoBI,aAC7BrpD,IAASipD,GAAoBO,SAEjC,CAvDQm1H,CAAuB7pH,GAAkB,CAC3C,MAAMhvD,EAAQgvD,EAAgBpM,cAExBj7C,EAAK3H,EAAMylD,UAAU1yC,WACvBi8C,EAAgB90D,MAAQipD,GAAoBO,iBACvCvpD,KAAKw+K,iBAAiBhxK,IACpBqnD,EAAgB90D,MAAQipD,GAAoBM,aAE5C97C,KAAMxN,KAAKw+K,oBADpBx+K,KAAKw+K,iBAAiBhxK,GAAM3H,GAK9B7F,KAAK61D,eAAiBnvD,OAAOuC,OAAOjJ,KAAKw+K,iBAC1C,CACF,CAMD,cAAAC,QACmCj4K,IAA7BxG,KAAKu+K,qBAEPnzH,aAAaprD,KAAKu+K,qBAClBv+K,KAAKu+K,yBAAsB/3K,IAE3BxG,KAAKs+K,6BAA8B,EACnCt+K,KAAKu+K,oBAAsB9sI,WACzBzxC,KAAKm8D,gBAAgBj1D,KAAKlH,MAC1B,KAGL,CAKD,eAAAm8D,GACEn8D,KAAKs+K,6BAA8B,EACnCt+K,KAAKu+K,yBAAsB/3K,CAC5B,GCpNH,MAAMm4K,GAMU,cAQT,MAAMC,WAAyB74K,EAOpC,WAAAjG,CAAYC,EAAM8+K,EAAM17G,EAAUhkD,GAChCla,MAAMlF,GAONC,KAAKmjE,SAAWA,EAOhBnjE,KAAK6+K,KAAOA,EAOZ7+K,KAAKmf,WAAaA,CACnB,EA2PH,IAAA2/J,GAtOA,cAA0B9pH,GAIxB,WAAAl1D,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B1F,MAAM,CACJmB,YAAajD,IAMfnD,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAML3H,KAAK++K,eAAgB,EAMrB/+K,KAAKg/K,SAAW,GAChB,MAAMC,EAAqBt0K,EAAQs0K,mBAC/Bt0K,EAAQs0K,mBACR,GACJ,IAAK,IAAIr9K,EAAI,EAAGuE,EAAK84K,EAAmB99K,OAAQS,EAAIuE,IAAMvE,EAAG,CAC3D,IAAIolB,EAASi4J,EAAmBr9K,GACV,mBAAXolB,IACTA,EAAS,IAAIA,GAEfhnB,KAAKg/K,SAASr5K,KAAKqhB,GACnBhnB,KAAK++K,cACH/+K,KAAK++K,eAAsC,gBAArB/3J,EAAO0H,SAChC,CAMD1uB,KAAK6zC,YAAclpC,EAAQwU,WACvByP,GAAcjkB,EAAQwU,YACtB,KAMJnf,KAAKk/K,gBAAkB,KAMvBl/K,KAAKm/K,QAAUx0K,EAAQT,QAAU,KAMjClK,KAAKG,OAASwK,EAAQxK,OAASwK,EAAQxK,OAAS,IACjD,CAOD,aAAAi/K,CAAcP,EAAMh5K,GAClB,MAAM4qC,EAAS5qC,EAAM1F,OAAOswC,OACtB3F,EAAM9qC,KAAKsgD,SACjB,IASIsC,EATAzjC,EAAanf,KAAK6zC,YACtB,IAAK10B,IACHA,EAAa8M,MACR9M,GAAY,CAEfA,EADa2rB,EAAI6S,UACC/uB,eACnB,CAIH,MAAM49E,EAAUxsG,KAAKg/K,SACrB,IAAK,IAAIp9K,EAAI,EAAGuE,EAAKqmG,EAAQrrG,OAAQS,EAAIuE,IAAMvE,EAAG,CAChD,MAAMolB,EAASwlF,EAAQ5qG,GACvB,IAAIohB,EAAQytB,EACRzwC,KAAK++K,eAAsC,gBAArB/3J,EAAO0H,iBAClBloB,IAATo8C,IACFA,GAAO,IAAIy8H,aAAcrwK,OAAOyhC,IAElCztB,EAAQ4/B,GAEV,MAAMugB,EAAWnjE,KAAKs/K,iBAAiBt4J,EAAQhE,EAAO,CACpD2rD,kBAAmBxvD,IAErB,GAAIgkD,GAAYA,EAAShiE,OAAS,EAAG,CAC/BnB,KAAKm/K,UACPn/K,KAAKm/K,QAAQx6K,QACb3E,KAAKm/K,QAAQpwG,YAAY5L,IAE3BnjE,KAAK4F,cACH,IAAIg5K,GACFD,GACAE,EACA17G,EACAhkD,IAGJ,KACD,CACF,CACF,CAKD,kBAAAogK,GACE,MAAMz0I,EAAM9qC,KAAKsgD,SACjB,GAAIxV,EAAK,CACP,MAAM00I,EAAWx/K,KAAKG,OAASH,KAAKG,OAAS2qC,EAAIub,cACjDrmD,KAAKk/K,gBAAkB,CACrBn4K,EAAOy4K,EAAU13K,EAAgB9H,KAAKy/K,WAAYz/K,MAClD+G,EAAOy4K,EAAU13K,EAAqB9H,KAAK0/K,WAAY1/K,MACvD+G,EAAOy4K,EAAU13K,EAAoB9H,KAAK0/K,WAAY1/K,MACtD+G,EAAOy4K,EAAU13K,EAAgB9H,KAAK0/K,WAAY1/K,MAErD,CACF,CAQD,SAAA20D,CAAUG,IACH90D,KAAK40D,aAAeE,GACvB90D,KAAKu/K,qBAEHv/K,KAAK40D,cAAgBE,GACvB90D,KAAK2/K,uBAEP16K,MAAM0vD,UAAUG,EACjB,CAQD,MAAA/X,CAAOjS,GACL9qC,KAAK2/K,uBACL16K,MAAM83C,OAAOjS,GACT9qC,KAAK40D,aACP50D,KAAKu/K,oBAER,CASD,gBAAAD,CAAiBt4J,EAAQ47B,EAAMj4C,GAC7B,IACE,OAEGqc,EAAO0nD,aAAa9rB,EAAMj4C,EAE9B,CAAC,MAAOuM,GACP,OAAO,IACR,CACF,CAKD,oBAAAyoK,GACM3/K,KAAKk/K,kBACPl/K,KAAKk/K,gBAAgB/zK,QAAQ7D,GAC7BtH,KAAKk/K,gBAAkB,KAE1B,CAKD,UAAAO,CAAW55K,GACT,MAAM+5K,EAAQ/5K,EAAMg6K,aAAaD,MACjC,IAAK,IAAIh+K,EAAI,EAAGuE,EAAKy5K,EAAMz+K,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAMi9K,EAAOe,EAAMt0K,KAAK1J,GAClBk+K,EAAS,IAAIC,WACnBD,EAAOx6K,iBACLwC,EACA9H,KAAKo/K,cAAcl4K,KAAKlH,KAAM6+K,IAE5B7+K,KAAK++K,cACPe,EAAOE,kBAAkBnB,GAEzBiB,EAAOG,WAAWpB,EAErB,CACF,CAKD,UAAAa,CAAW75K,GACTA,EAAMlG,kBACNkG,EAAMzF,iBACNyF,EAAMg6K,aAAaK,WAAa,MACjC,GCzLH,IAAAC,GA7GA,cAAgCpoH,GAI9B,WAAAj4D,CAAY6K,GAGV1F,MAFA0F,EAAUA,GAAoB,IAQ9B3K,KAAKs4D,WAAa3tD,EAAQ0tD,UAAY1tD,EAAQ0tD,UAAYf,GAM1Dt3D,KAAK+4D,gBAAavyD,EAMlBxG,KAAKogL,oBAAiB55K,EAMtBxG,KAAKw9D,gBAAkB,EAMvBx9D,KAAK2yD,eAAiCnsD,IAArBmE,EAAQwzB,SAAyBxzB,EAAQwzB,SAAW,GACtE,CAMD,eAAAq3B,CAAgBX,GACd,IAAK6C,GAAU7C,GACb,OAGF,MAAM/pB,EAAM+pB,EAAgB/pB,IACtBp3B,EAAOo3B,EAAIn3B,UACXoH,EAAS85C,EAAgBvX,MACzBr/B,EAASlD,EAAO,GAAKrH,EAAK,GAAK,EAC/BwK,EAASxK,EAAK,GAAK,EAAIqH,EAAO,GAC9Bs2B,EAAQplC,KAAKoc,MAAMnK,EAAQD,GAC3BoiK,EAAYp0K,KAAKma,KAAKnI,EAASA,EAASC,EAASA,GACjDs/B,EAAO1S,EAAI6S,UACjB,QAAwBn3C,IAApBxG,KAAK+4D,WAA0B,CACjC,MAAMunH,EAAatgL,KAAK+4D,WAAa1nB,EACrCmM,EAAKlC,uBAAuBglI,EAC7B,CACDtgL,KAAK+4D,WAAa1nB,OACU7qC,IAAxBxG,KAAKogL,gBACP5iI,EAAKtC,yBAAyBl7C,KAAKogL,eAAiBC,QAE1B75K,IAAxBxG,KAAKogL,iBACPpgL,KAAKw9D,gBAAkBx9D,KAAKogL,eAAiBC,GAE/CrgL,KAAKogL,eAAiBC,CACvB,CAOD,aAAA3qH,CAAcb,GACZ,IAAK6C,GAAU7C,GACb,OAAO,EAGT,MACMrX,EADMqX,EAAgB/pB,IACX6S,UACXj8C,EAAY1B,KAAKw9D,gBAAkB,EAAI,GAAK,EAGlD,OAFAhgB,EAAK1B,eAAe97C,KAAK2yD,UAAWjxD,GACpC1B,KAAKw9D,gBAAkB,GAChB,CACR,CAOD,eAAAjI,CAAgBV,GACd,QAAK6C,GAAU7C,OAIX70D,KAAKs4D,WAAWzD,KAClBA,EAAgB/pB,IAAI6S,UAAU9B,mBAC9B77C,KAAK+4D,gBAAavyD,EAClBxG,KAAKogL,oBAAiB55K,GACf,GAGV,GCoCH,MAAM+5K,GAMO,YANPA,GAYK,UAZLA,GAkBO,YAQN,MAAMC,WAAkBz6K,EAK7B,WAAAjG,CAAYC,EAAM4/C,GAChB16C,MAAMlF,GAONC,KAAK2/C,QAAUA,CAChB,EA4BH,SAAS8gI,GAAmBp/K,EAAGC,GAC7B,OAAO0iB,GAAgB3iB,EAAE,GAAIA,EAAE,GAAIC,EAAE,GAAIA,EAAE,GAC7C,CAOA,SAASo/K,GAAcnnK,EAAatW,GAClC,MAAM6qD,EAAQv0C,EAAYpY,OAC1B,OAAI8B,EAAQ,EACHsW,EAAYtW,EAAQ6qD,GAEzB7qD,GAAS6qD,EACJv0C,EAAYtW,EAAQ6qD,GAEtBv0C,EAAYtW,EACrB,CAWA,SAAS09K,GAA6BpnK,EAAaw0C,EAAYwwF,GAC7D,IAAIqiC,EAAUC,EACV9yH,EAAawwF,GACfqiC,EAAW7yH,EACX8yH,EAAYtiC,IAEZqiC,EAAWriC,EACXsiC,EAAY9yH,GAEd,MAAM+yH,EAAgB70K,KAAKkZ,KAAKy7J,GAC1BG,EAAiB90K,KAAKuT,MAAMqhK,GAElC,GAAIC,EAAgBC,EAAgB,CAIlC,OAAON,GAFOO,GAAsBznK,EAAaqnK,GACrCI,GAAsBznK,EAAasnK,GAEhD,CAED,IAAIzuF,EAAK,EAET,GAAIwuF,EAAWE,EAAe,CAG5B1uF,GAAMquF,GAFQO,GAAsBznK,EAAaqnK,GACrCF,GAAcnnK,EAAaunK,GAExC,CAED,GAAIC,EAAiBF,EAAW,CAG9BzuF,GAAMquF,GAFQC,GAAcnnK,EAAawnK,GAC7BC,GAAsBznK,EAAasnK,GAEhD,CAED,IAAK,IAAIj/K,EAAIk/K,EAAel/K,EAAIm/K,EAAiB,IAAKn/K,EAAG,CAGvDwwF,GAAMquF,GAFQC,GAAcnnK,EAAa3X,GAC7B8+K,GAAcnnK,EAAa3X,EAAI,GAE5C,CAED,OAAOwwF,CACT,CAOA,SAAS6uF,GAA2B7pK,EAAYxC,EAAUssK,GACxD,GAAItsK,aAAoBimE,GACtBsmG,GAAkB/pK,EAAYxC,EAAS+a,kBAAkB,EAAOuxJ,QAGlE,GAAItsK,aAAoBqmE,GAAxB,CACE,MAAM1hE,EAAc3E,EAAS+a,iBAC7B,IAAK,IAAI/tB,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAQS,EAAIuE,IAAMvE,EACjDu/K,GAAkB/pK,EAAYmC,EAAY3X,IAAI,EAAOs/K,EAGxD,MACD,GAAItsK,aAAoBqhB,GAAxB,CACE,MAAM1c,EAAc3E,EAAS+a,iBAC7B,IAAK,IAAI/tB,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAQS,EAAIuE,IAAMvE,EACjDu/K,GAAkB/pK,EAAYmC,EAAY3X,IAAI,EAAMs/K,EAGvD,MACD,GAAItsK,aAAoBsmE,GAAxB,CACE,MAAMkmG,EAAQxsK,EAAS+a,iBACvB,IAAK,IAAI/tB,EAAI,EAAGuE,EAAKi7K,EAAMjgL,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAM2X,EAAc6nK,EAAMx/K,GAC1B,IAAK,IAAI0iB,EAAI,EAAG2G,EAAK1R,EAAYpY,OAAQmjB,EAAI2G,IAAM3G,EACjD68J,GAAkB/pK,EAAYmC,EAAY+K,IAAI,EAAM48J,EAEvD,CAEF,MACD,GAAItsK,aAAoBumE,GAAxB,CACE,MAAM3F,EAAa5gE,EAASunE,gBAC5B,IAAK,IAAIv6E,EAAI,EAAGA,EAAI4zE,EAAWr0E,SAAUS,EACvCq/K,GAA2B7pK,EAAYo+D,EAAW5zE,GAAIs/K,EAGzD,MAEH,CAWA,MAAMG,GAAmB,CAACp+K,OAAQ,EAAGs7I,SAAUlwH,KA6H/C,SAAS8yJ,GAAkB/pK,EAAYmC,EAAa+nK,EAAMJ,GACxD,MAAM7pK,EAAID,EAAW,GACfE,EAAIF,EAAW,GACrB,IAAK,IAAIxV,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAS,EAAGS,EAAIuE,IAAMvE,EAAG,CACxD,MAEMm2G,EAAMwpE,GAA4BlqK,EAAGC,EAF7BiC,EAAY3X,GACd2X,EAAY3X,EAAI,IAE5B,GAA4B,IAAxBm2G,EAAI/zF,gBAAuB,CAC7B,MAAM/gB,EAAQrB,EAAIm2G,EAAIxxF,MAOtB,YANA26J,EAAQv7K,KAAK,CACX4T,YAAaA,EACb+nK,KAAMA,EACNvzH,WAAY9qD,EACZs7I,SAAUt7I,GAGb,CACF,CACH,CAWA,MAAMu+K,GAAY,CAACj7J,MAAO,EAAGvC,gBAAiB,GAU9C,SAASu9J,GAA4BlqK,EAAGC,EAAG5J,EAAO1L,GAChD,MAAM+a,EAAKrP,EAAM,GACXsP,EAAKtP,EAAM,GAGXoK,EAFK9V,EAAI,GAEC+a,EACVhF,EAFK/V,EAAI,GAECgb,EAChB,IAAIuJ,EAAQ,EACRgzC,EAAKx8C,EACLynH,EAAKxnH,EAST,OARW,IAAPlF,GAAmB,IAAPC,IACdwO,EAAQzC,KAAQzM,EAAI0F,GAAMjF,GAAMR,EAAI0F,GAAMjF,IAAOD,EAAKA,EAAKC,EAAKA,GAAK,EAAG,GACxEwhD,GAAMzhD,EAAKyO,EACXi+G,GAAMzsH,EAAKwO,GAGbi7J,GAAUj7J,MAAQA,EAClBi7J,GAAUx9J,gBAAkBe,GAAQf,GAAgB3M,EAAGC,EAAGiiD,EAAIirE,GAAK,IAC5Dg9C,EACT,CAOA,SAASR,GAAsBznK,EAAatW,GAC1C,MAAM6qD,EAAQv0C,EAAYpY,OAE1B,IAAI4sD,EAAa9hD,KAAKuT,MAAMvc,GAC5B,MAAMsjB,EAAQtjB,EAAQ8qD,EAClBA,GAAcD,EAChBC,GAAcD,EACLC,EAAa,IACtBA,GAAcD,GAGhB,IAAIywF,EAAWxwF,EAAa,EACxBwwF,GAAYzwF,IACdywF,GAAYzwF,GAGd,MAAMpgD,EAAQ6L,EAAYw0C,GACpBlxC,EAAKnP,EAAM,GACXoP,EAAKpP,EAAM,GACX1L,EAAMuX,EAAYglI,GAIxB,MAAO,CAAC1hI,GAHG7a,EAAI,GAAK6a,GAGF0J,EAAOzJ,GAFd9a,EAAI,GAAK8a,GAEeyJ,EACrC,CA8vCA,SAASk7J,KACP,MAAM9rK,EAAS6zI,KACf,OAAO,SAAU7pG,EAAShjC,GACxB,OAAOhH,EAAOgqC,EAAQzqC,cAAcwZ,UACxC,CACA,CAgHA,IAAAgzJ,GAh2CA,cAAmB3pH,GAIjB,WAAAj4D,CAAY6K,GACV,MAAMkyD,EAAc,EAGfA,EAAelH,WAClBkH,EAAelH,SAAWvyD,GAG5B6B,MAAM43D,GAKN78D,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAML3H,KAAK2hL,eAAgB,EAMrB3hL,KAAK4hL,QAAU,KAMf5hL,KAAK6hL,aAML7hL,KAAK8hL,cAOL9hL,KAAK+hL,aAML/hL,KAAKgiL,WAAY,EAOjBhiL,KAAKm/K,QAAUx0K,EAAQT,OAASS,EAAQT,OAAS,KAOjDlK,KAAKgtE,UAAYriE,EAAQw4D,SAAWx4D,EAAQw4D,SAAW,KAOvDnjE,KAAKiiL,eAAiBt3K,EAAQu3K,cAAgBv3K,EAAQu3K,cAAgB,GAOtEliL,KAAKm7F,MACHxwF,EACN,KAOI3K,KAAK+7D,MAyuCT,SAAiBh8D,GACf,OAAQA,GACN,IAAK,QACL,IAAK,aACH,MAAO,QACT,IAAK,aACL,IAAK,kBACH,MAAO,aACT,IAAK,UACL,IAAK,eACH,MAAO,UACT,IAAK,SACH,MAAO,SACT,QACE,MAAM,IAAIyI,MAAM,iBAAmBzI,GAEzC,CAzvCiBoiL,CAAQniL,KAAKm7F,OAQ1Bn7F,KAAKoiL,aAAez3K,EAAQ03K,UAS5BriL,KAAKsiL,WAAa33K,EAAQ43K,UACtB53K,EAAQ43K,UACO,YAAfviL,KAAK+7D,MACL,EACA,EAQJ/7D,KAAKwiL,WACY,WAAfxiL,KAAK+7D,MACD,EACApxD,EAAQ83K,UACR93K,EAAQ83K,UACRhoK,IAONza,KAAK0iL,iBAAmB/3K,EAAQg4K,gBAC5Bh4K,EAAQg4K,gBACRx/K,EAMJnD,KAAK4iL,gBAAkBj4K,EAAQk4K,eAC3Bl4K,EAAQk4K,eACR,KAEJ,IAAI7iF,EAAmBr1F,EAAQq1F,iBAC/B,IAAKA,EAAkB,CACrB,MAAM8iF,EAAO9iL,KAAK+7D,MAClB,GAAa,WAAT+mH,EAOF9iF,EAAmB,SAAUzmF,EAAa3E,EAAUuK,GAClD,MAAM+G,EAAStR,GAEX,IAAI0mE,GAAO,CAACjtD,IAAKA,MACf3R,EAASyP,GAAmB5S,EAAY,GAAI4F,GAC5C4jK,EAAgBC,GACpBtmK,EACAyP,GAAmB5S,EAAYA,EAAYpY,OAAS,GAAIge,IAE1D+G,EAAO+wE,mBACLv6E,EACAzQ,KAAKma,KAAK28J,GACV/iL,KAAK4iL,iBAEP,MAAM72J,EAAiBE,KAIvB,OAHIF,GACF7F,EAAOlQ,UAAUmJ,EAAY4M,GAExB7F,CACjB,MACa,CACL,IAAIy/I,EACS,UAATmd,EACFnd,EAAcnyI,GACI,eAATsvJ,EACTnd,EAAc9qF,GACI,YAATioG,IACTnd,EAAc1vI,IAQhB+pE,EAAmB,SAAUzmF,EAAa3E,EAAUuK,GAkBlD,OAjBIvK,EACW,YAATkuK,EACEvpK,EAAY,GAAGpY,OAEjByT,EAASsb,eACP,CAAC3W,EAAY,GAAGw9E,OAAO,CAACx9E,EAAY,GAAG,MACvCvZ,KAAK4iL,iBAGPhuK,EAASsb,eAAe,GAAIlwB,KAAK4iL,iBAGnChuK,EAASsb,eAAe3W,EAAavZ,KAAK4iL,iBAG5ChuK,EAAW,IAAI+wJ,EAAYpsJ,EAAavZ,KAAK4iL,iBAExChuK,CACjB,CACO,CACF,CAMD5U,KAAK+oJ,kBAAoB/oD,EAMzBhgG,KAAKijL,sBACyBz8K,IAA5BmE,EAAQu4K,gBAAgCv4K,EAAQu4K,gBAAkB,IAQpEljL,KAAKmjL,kBAAoB,KAOzBnjL,KAAKojL,eAAiB,KAOtBpjL,KAAKqjL,aAAe,KAOpBrjL,KAAKsjL,cAAgB,KAOrBtjL,KAAKujL,YAAc,KAOnBvjL,KAAKwjL,kBAAoB,KASzBxjL,KAAKyjL,uBAAyB94K,EAAQ+4K,eAClC/4K,EAAQ+4K,eAAiB/4K,EAAQ+4K,eACjC,GAOJ1jL,KAAK2jL,SAAW,IAAIxO,GAAY,CAC9BjrK,OAAQ,IAAI41F,GAAa,CACvBxD,iBAAiB,EACjBp9E,QAAOvU,EAAQuU,OAAQvU,EAAQuU,QAEjC3O,MAAO5F,EAAQ4F,MAAQ5F,EAAQ4F,MAAQkxK,KACvC1tB,wBAAwB,IAQ1B/zJ,KAAKuU,cAAgB5J,EAAQi5K,aAM7B5jL,KAAKs4D,WAAa3tD,EAAQ0tD,UAAY1tD,EAAQ0tD,UAAYjB,GAM1Dp3D,KAAK6jL,mBACDl5K,EAAQm5K,SACV9jL,KAAK6jL,mBAAqB7sH,GAE1Bh3D,KAAK6jL,mBAAqBl5K,EAAQo5K,kBAC9Bp5K,EAAQo5K,kBACRzsH,GAONt3D,KAAKgkL,gBACLhkL,KAAKikL,SAASt5K,EAAQu5K,QAAS,GAM/BlkL,KAAKmkL,YAAc,CAACrvH,QAAQ,GAM5B90D,KAAKokL,aAAez5K,EAAQ05K,aAAe15K,EAAQT,QAAU,KAE7DlK,KAAK6J,kBAAkB0qD,GAA4Bv0D,KAAKskL,aACzD,CAQD,QAAAL,CAASC,GACP,IAAI7rH,EAIFA,EAHG6rH,GAEgB,IAAVA,EACGltH,GAEAktH,EAJAhtH,GAMdl3D,KAAKgkL,gBAAkB3rH,CACxB,CAQD,MAAAtb,CAAOjS,GACL7lC,MAAM83C,OAAOjS,GACb9qC,KAAKskL,cACN,CAOD,UAAAC,GACE,OAAOvkL,KAAK2jL,QACb,CAQD,WAAAv9K,CAAYP,GACNA,EAAM4iD,cAAc1oD,OAAS+H,GAE/BjC,EAAM4iD,cAAcroD,iBAEtBJ,KAAKgiL,UAA2B,UAAfhiL,KAAK+7D,OAAqB/7D,KAAK6jL,mBAAmBh+K,GACnE,IAAI2+K,EAAO3+K,EAAM9F,OAASipD,GAAoBK,YAC1C+M,GAAO,EACX,IACGp2D,KAAKgiL,WACNhiL,KAAK8hL,eACLj8K,EAAM9F,OAASipD,GAAoBI,YACnC,CACYrrB,KAAKC,MACPh+B,KAAK8hL,eAAiB9hL,KAAKijL,kBACnCjjL,KAAK4hL,QAAU/7K,EAAMy3C,MACrBt9C,KAAK2hL,eAAiB3hL,KAAKgiL,UAC3BwC,GAAO,GAEPxkL,KAAK8hL,mBAAgBt7K,EAEnBxG,KAAK2hL,oBAAuCn7K,IAAtBxG,KAAK6hL,eAC7Bz2H,aAAaprD,KAAK6hL,cAClB7hL,KAAK6hL,kBAAer7K,EAEvB,CAgCD,OA9BExG,KAAKgiL,WACLn8K,EAAM9F,OAASipD,GAAoBI,aACX,OAAxBppD,KAAKojL,gBAELpjL,KAAKykL,cAAc5+K,EAAMuR,YACzBg/C,GAAO,GAEPp2D,KAAKgiL,WACLn8K,EAAM9F,OAASipD,GAAoBM,YAEnC8M,GAAO,EACEouH,GAAQxkL,KAAK81D,kBAAoB,GAC1CM,EAAOvwD,EAAM9F,OAASipD,GAAoBK,YACtC+M,GAAQp2D,KAAKgiL,WACfhiL,KAAK8rD,mBAAmBjmD,GACpB7F,KAAK2hL,eAEP97K,EAAM4iD,cAAcroD,mBAGc,UAApCyF,EAAM4iD,cAAckP,aACnB9xD,EAAM9F,OAASipD,GAAoBI,kBACZ5iD,IAAtBxG,KAAK6hL,eAEP7hL,KAAK8rD,mBAAmBjmD,IAEjBA,EAAM9F,OAASipD,GAAoBG,WAC5CiN,GAAO,GAGFnxD,MAAMmB,YAAYP,IAAUuwD,CACpC,CAOD,eAAAb,CAAgB1vD,GAGd,OAFA7F,KAAK2hL,eAAiB3hL,KAAKgiL,UAEvBhiL,KAAKgiL,WACPhiL,KAAK4hL,QAAU/7K,EAAMy3C,MAChBt9C,KAAKmjL,mBACRnjL,KAAK0kL,cAAc7+K,EAAMuR,aAEpB,GAGJpX,KAAKs4D,WAAWzyD,IAKrB7F,KAAK8hL,cAAgB/jJ,KAAKC,MAC1Bh+B,KAAK6hL,aAAepwI,YAAW,KAC7BzxC,KAAK8rD,mBACH,IAAIX,GACFnC,GAAoBK,YACpBxjD,EAAMilC,IACNjlC,EAAM4iD,eACN,EACA5iD,EAAM43C,YAET,GACAz9C,KAAKijL,kBACRjjL,KAAK4hL,QAAU/7K,EAAMy3C,OACd,IAjBLt9C,KAAK8hL,mBAAgBt7K,GACd,EAiBV,CAKD,gBAAAm+K,GACE3kL,KAAKmkL,YAAc,CAACrvH,QAAQ,EAC7B,CAOD,iBAAA8vH,CAAkB/+K,GAChB,IAAK7F,KAAKokL,eAAiBpkL,KAAKgkL,gBAAgBn+K,GAC9C,OAGF,GAAI7F,KAAKmkL,YAAYrvH,OAEnB,YADA90D,KAAK2kL,mBAIP,MAAM75I,EAAM9qC,KAAKsgD,SASX9mC,EAASF,GAAe,CARZwxB,EAAIie,uBAAuB,CAC3CljD,EAAMy3C,MAAM,GAAKt9C,KAAKiiL,eACtBp8K,EAAMy3C,MAAM,GAAKt9C,KAAKiiL,iBAELn3I,EAAIie,uBAAuB,CAC5CljD,EAAMy3C,MAAM,GAAKt9C,KAAKiiL,eACtBp8K,EAAMy3C,MAAM,GAAKt9C,KAAKiiL,mBAGlB9+G,EAAWnjE,KAAKokL,aAAa3lF,oBAAoBjlF,GACvD,GAAwB,IAApB2pD,EAAShiE,OACX,OAGF,MAAM+/K,EA14BV,SAAyB9pK,EAAY+rD,GAInC,MAAM+9G,EAAU,GAEhB,IAAK,IAAIt/K,EAAI,EAAGA,EAAIuhE,EAAShiE,SAAUS,EAGrCq/K,GAA2B7pK,EAFX+rD,EAASvhE,GACAsT,cACwBgsK,GAGnD,OAAOA,CACT,CA63BoB2D,CAAgBh/K,EAAMuR,WAAY+rD,GAC9C+9G,EAAQ//K,SACVnB,KAAKmkL,YAAc,CACjBrvH,QAAQ,EACRgwH,QAASj/K,EAAMy3C,MAAMx5C,QACrBo9K,QAASA,EACT6D,aAAc,GAGnB,CAOD,6BAAAC,CAA8B7kL,EAAQo+I,GAKpC,MAAM0mC,EAAoB9kL,EAAO4tD,YAAc5tD,EAAOo+I,SAElD0mC,IADqB9kL,EAAO4tD,YAAcwwF,EAIzC0mC,GAAqB1mC,EAAWp+I,EAAOo+I,WACtC0mC,GAAqB1mC,EAAWp+I,EAAOo+I,SAGzCv+I,KAAKklL,sBAAsB/kL,EAAQA,EAAOo+I,SAAUA,IAEnD0mC,GAAqB1mC,EAAWp+I,EAAOo+I,WACtC0mC,GAAqB1mC,EAAWp+I,EAAOo+I,WAGzCv+I,KAAKmlL,yBAAyB5mC,EAAUp+I,EAAOo+I,WAIjDv+I,KAAKmlL,yBAAyBhlL,EAAO4tD,WAAY5tD,EAAOo+I,UACxDv+I,KAAKklL,sBAAsB/kL,EAAQA,EAAO4tD,WAAYwwF,GAEzD,CAOD,wBAAA4mC,CAAyBC,EAAWC,GAClC,GAAID,IAAcC,EAChB,OAGF,IAAI35K,EAAS,EACb,GAAI05K,EAAYC,EAAS,CACvB,MAAM33K,EAAQzB,KAAKkZ,KAAKigK,GACxB,IAAIpjL,EAAMiK,KAAKuT,MAAM6lK,GACjBrjL,IAAQqjL,IACVrjL,GAAO,GAET0J,EAAS1J,EAAM0L,EAAQ,CAC7B,KAAW,CACL,MAAMA,EAAQzB,KAAKuT,MAAM4lK,GACzB,IAAIpjL,EAAMiK,KAAKkZ,KAAKkgK,GAChBrjL,IAAQqjL,IACVrjL,GAAO,GAET0J,EAASgC,EAAQ1L,EAAM,CACxB,CAEG0J,EAAS,GACX1L,KAAKslL,kBAAkB55K,EAE1B,CAQD,qBAAAw5K,CAAsB/kL,EAAQilL,EAAWC,GACvC,GAAID,IAAcC,EAChB,OAGF,MAAM9rK,EAAc,GACpB,GAAI6rK,EAAYC,EAAS,CAEvB,MAAM33K,EAAQzB,KAAKkZ,KAAKigK,GACxB,IAAIpjL,EAAMiK,KAAKuT,MAAM6lK,GACjBrjL,IAAQqjL,IAEVrjL,GAAO,GAET,IAAK,IAAIJ,EAAI8L,EAAO9L,GAAKI,IAAOJ,EAC9B2X,EAAY5T,KAAK+6K,GAAcvgL,EAAOoZ,YAAa3X,GAE3D,KAAW,CAEL,MAAM8L,EAAQzB,KAAKuT,MAAM4lK,GACzB,IAAIpjL,EAAMiK,KAAKkZ,KAAKkgK,GAChBrjL,IAAQqjL,IACVrjL,GAAO,GAET,IAAK,IAAIJ,EAAI8L,EAAO9L,GAAKI,IAAOJ,EAC9B2X,EAAY5T,KAAK+6K,GAAcvgL,EAAOoZ,YAAa3X,GAEtD,CACG2X,EAAYpY,QACdnB,KAAKulL,kBAAkBhsK,EAE1B,CAOD,YAAAisK,CAAa3/K,GACX,MAAM4/K,EAAazlL,KAAKmkL,YACxB,IAAKsB,EAAW3wH,OACd,OAGF,IAAgC,IAA5B2wH,EAAWV,aAETv9J,GAASi+J,EAAWX,QAASj/K,EAAMy3C,OAASt9C,KAAKiiL,eACnD,OAIJ,MAAMyD,EAt3BV,SAA8BtuK,EAAYquK,EAAY36I,EAAKo3I,GACzD,MAAM7qK,EAAID,EAAW,GACfE,EAAIF,EAAW,GAErB,IAAIuuK,EAAwBlrK,IAExBmrK,GAAkB,EAClBC,EAAcx3J,IAElB,IACE,IAAI02J,EAAc,EAClBA,EAAcU,EAAWvE,QAAQ//K,SAC/B4jL,EACF,CACA,MAAM5kL,EAASslL,EAAWvE,QAAQ6D,GAC5BxrK,EAAcpZ,EAAOoZ,YAE3B,IACIglI,EADAunC,EAAqBrrK,IAEzB,IACE,IAAIsrK,EAAkB,EACtBA,EAAkBxsK,EAAYpY,OAAS,IACrC4kL,EACF,CACA,MAEMhuE,EAAMwpE,GAA4BlqK,EAAGC,EAF7BiC,EAAYwsK,GACdxsK,EAAYwsK,EAAkB,IAEtChuE,EAAI/zF,gBAAkB8hK,IACxBA,EAAqB/tE,EAAI/zF,gBACzBu6H,EAAWwnC,EAAkBhuE,EAAIxxF,MAEpC,CAEGu/J,EAAqBH,IACvBA,EAAwBG,EACpB3lL,EAAOmhL,MAAQmE,EAAWV,cAAgBA,IAExC5kL,EAAOo+I,SAAWp+I,EAAO4tD,WAEvBwwF,EAAWp+I,EAAO4tD,aACpBwwF,GAAYhlI,EAAYpY,QAEjBhB,EAAOo+I,SAAWp+I,EAAO4tD,YAE9BwwF,EAAWp+I,EAAO4tD,aACpBwwF,GAAYhlI,EAAYpY,SAI9B0kL,EAActnC,EACdqnC,EAAiBb,EAEpB,CAED,MAAMiB,EAAYP,EAAWvE,QAAQ0E,GACrC,IAAIK,EAAyBD,EAAU1E,KACvC,GAAImE,EAAWV,cAAgBa,GAAkBK,EAAwB,CAEvE,MAAMC,EAAgBlF,GACpBgF,EAAUzsK,YACVssK,GAGEr+J,GADUsjB,EAAIu5B,uBAAuB6hH,GACrBT,EAAWX,SAAW5C,IACxC+D,GAAyB,EAE5B,CAED,GAAIA,EAAwB,CAC1B,MAAM1sK,EAAcysK,EAAUzsK,YACxBu0C,EAAQv0C,EAAYpY,OACpB4sD,EAAai4H,EAAUj4H,WACvBwwF,EAAWsnC,EACjB,GAAI93H,EAAawwF,EAAU,CACzB,MAAM4nC,EAAkBxF,GACtBpnK,EACAw0C,EACAwwF,GAEsBoiC,GACtBpnK,EACAw0C,EACAwwF,EAAWzwF,GAESq4H,IACpBN,GAAe/3H,EAEvB,KAAW,CACL,MAAMs4H,EAAkBzF,GACtBpnK,EACAw0C,EACAwwF,GAEsBoiC,GACtBpnK,EACAw0C,EACAwwF,EAAWzwF,GAESs4H,IACpBP,GAAe/3H,EAElB,CACF,CAID,OAFAuzH,GAAiBp+K,MAAQ2iL,EACzBvE,GAAiB9iC,SAAWsnC,EACrBxE,EACT,CA2wB+BgF,CACzBxgL,EAAMuR,WACNquK,EACAzlL,KAAKsgD,SACLtgD,KAAKiiL,gBAGP,GAAIwD,EAAWV,cAAgBW,EAAmBziL,MAAO,CAEvD,IAAgC,IAA5BwiL,EAAWV,YAAoB,CAEjC,MAAMuB,EAAYb,EAAWvE,QAAQuE,EAAWV,aAChD/kL,KAAKmlL,yBAAyBmB,EAAUv4H,WAAYu4H,EAAU/nC,SAC/D,CAED,MAAMynC,EAAYP,EAAWvE,QAAQwE,EAAmBziL,OACxDjD,KAAKklL,sBACHc,EACAA,EAAUj4H,WACV23H,EAAmBnnC,SAE3B,KAAW,CAEL,MAAMp+I,EAASslL,EAAWvE,QAAQuE,EAAWV,aAC7C/kL,KAAKglL,8BAA8B7kL,EAAQulL,EAAmBnnC,SAC/D,CAGDknC,EAAWV,YAAcW,EAAmBziL,MAC5C,MAAM9C,EAASslL,EAAWvE,QAAQuE,EAAWV,aAC7C5kL,EAAOo+I,SAAWmnC,EAAmBnnC,SAGrC,MAAMnnI,EAAa4pK,GACjB7gL,EAAOoZ,YACPpZ,EAAOo+I,UAEHjhG,EAAQt9C,KAAKsgD,SAAS+jB,uBAAuBjtD,GACnDvR,EAAMuR,WAAaA,EACnBvR,EAAMy3C,MAAQ,CAACrxC,KAAKiZ,MAAMo4B,EAAM,IAAKrxC,KAAKiZ,MAAMo4B,EAAM,IACvD,CAOD,aAAAoY,CAAc7vD,GACZ,IAAIuwD,GAAO,EAEX,GAA+B,IAA3Bp2D,KAAK81D,kBAAyB,CAC5B91D,KAAK6hL,eACPz2H,aAAaprD,KAAK6hL,cAClB7hL,KAAK6hL,kBAAer7K,GAGtBxG,KAAK8rD,mBAAmBjmD,GACxB,MAAM0gL,EAAUvmL,KAAKmkL,YAAYrvH,OAGjC,GAFA90D,KAAK4kL,kBAAkB/+K,GAEnB7F,KAAK2hL,cAAe,CACtB,MAAM6E,GAAkBxmL,KAAKmjL,kBACzBqD,GACFxmL,KAAK0kL,cAAc7+K,EAAMuR,aAEtBovK,GAAkBxmL,KAAKgiL,UAC1BhiL,KAAKymL,gBAEJzmL,KAAKgiL,WACJwE,GAAiC,UAAfxmL,KAAK+7D,QAErB/7D,KAAK0mL,UAAU7gL,EAAMy3C,MAAOipI,GAC1BvmL,KAAK0iL,iBAAiB78K,IACxB7F,KAAKymL,gBAGPzmL,KAAKykL,cAAc5+K,EAAMuR,aAG7Bg/C,GAAO,CACf,MAAiBp2D,KAAKgiL,WACdhiL,KAAK2mL,cAER,CAKD,OAHKvwH,GAAQp2D,KAAKoiL,YAChBv8K,EAAMzF,iBAEDg2D,CACR,CAOD,kBAAAtK,CAAmBjmD,GAEjB,GADA7F,KAAK+hL,aAAel8K,EAAM4iD,cAAckP,YAEtC33D,KAAK4hL,WACF5hL,KAAKgiL,WAAahiL,KAAK2hL,eACvB3hL,KAAKgiL,YAAchiL,KAAK2hL,eAC3B,CACA,MAAMiF,EAAS5mL,KAAK4hL,QACdiF,EAAUhhL,EAAMy3C,MAChBxlC,EAAK8uK,EAAO,GAAKC,EAAQ,GACzB9uK,EAAK6uK,EAAO,GAAKC,EAAQ,GACzB7iK,EAAkBlM,EAAKA,EAAKC,EAAKA,EAIvC,GAHA/X,KAAK2hL,cAAgB3hL,KAAKgiL,UACtBh+J,EAAkBhkB,KAAKyjL,uBACvBz/J,GAAmBhkB,KAAKyjL,wBACvBzjL,KAAK2hL,cACR,MAEH,CAEI3hL,KAAKmjL,mBAKVnjL,KAAKwlL,aAAa3/K,GAClB7F,KAAK8mL,eAAejhL,EAAMuR,aALxBpX,KAAK+mL,2BAA2BlhL,EAAMuR,WAAWtT,QAMpD,CASD,SAAA4iL,CAAUppI,EAAOipI,GACf,IAAIS,GAAK,EACT,GAAIhnL,KAAKojL,eAAgB,CACvB,IAAI6D,GAAkB,EAClBC,EAA+B,CAAClnL,KAAKmjL,mBACzC,MAAML,EAAO9iL,KAAK+7D,MAClB,GAAa,UAAT+mH,EACFkE,GAAK,OACA,GAAa,WAATlE,EACTkE,EAAmC,IAA9BhnL,KAAKsjL,cAAcniL,YACnB,GAAa,eAAT2hL,EACTmE,GACGV,GAAWvmL,KAAKsjL,cAAcniL,OAASnB,KAAKsiL,gBAC1C,GAAa,YAATQ,EAAoB,CAC7B,MAAMqE,EAA6CnnL,KAAkB,cACrEinL,EAAkBE,EAAa,GAAGhmL,OAASnB,KAAKsiL,WAChD4E,EAA+B,CAC7BC,EAAa,GAAG,GAChBA,EAAa,GAAGA,EAAa,GAAGhmL,OAAS,IAGzC+lL,EADEX,EAC6B,CAACY,EAAa,GAAG,IAEjB,CAC7BA,EAAa,GAAG,GAChBA,EAAa,GAAGA,EAAa,GAAGhmL,OAAS,GAG9C,CACD,GAAI8lL,EAAiB,CACnB,MAAMn8I,EAAM9qC,KAAKsgD,SACjB,IAAK,IAAI1+C,EAAI,EAAGuE,EAAK+gL,EAA6B/lL,OAAQS,EAAIuE,EAAIvE,IAAK,CACrE,MAAMwlL,EAAmBF,EAA6BtlL,GAChDylL,EAAcv8I,EAAIu5B,uBAAuB+iH,GACzCtvK,EAAKwlC,EAAM,GAAK+pI,EAAY,GAC5BtvK,EAAKulC,EAAM,GAAK+pI,EAAY,GAC5BnF,EAAgBliL,KAAKgiL,UAAY,EAAIhiL,KAAKiiL,eAEhD,GADA+E,EAAK/6K,KAAKma,KAAKtO,EAAKA,EAAKC,EAAKA,IAAOmqK,EACjC8E,EAAI,CACNhnL,KAAKmjL,kBAAoBiE,EACzB,KACD,CACF,CACF,CACF,CACD,OAAOJ,CACR,CAMD,0BAAAD,CAA2BxtK,GACzB,GAAKvZ,KAAKqjL,aAGH,CACmBrjL,KAAKqjL,aAAanuK,cAC1Bgb,eAAe3W,EAChC,MALCvZ,KAAKqjL,aAAe,IAAIjvK,GAAQ,IAAIof,GAAMja,IAC1CvZ,KAAKsnL,uBAKR,CAMD,+BAAAC,CAAgC3yK,GACzB5U,KAAKujL,cACRvjL,KAAKujL,YAAc,IAAInvK,IAEzB,MAAMktK,EAAO1sK,EAASoiB,cAAc,GACpC,IAAIwwJ,EAAiBxnL,KAAKujL,YAAYruK,cACjCsyK,GAOHA,EAAev3J,mBACbqxJ,EAAKxxJ,YACLwxJ,EAAK/xJ,sBAEPi4J,EAAe3/K,YAVf2/K,EAAiB,IAAI3sG,GACnBymG,EAAK/xJ,qBACL+xJ,EAAKxxJ,aAEP9vB,KAAKujL,YAAY1uK,YAAY2yK,GAQhC,CAOD,aAAA9C,CAAch3K,GACZ,MAAMyR,EAAanf,KAAKsgD,SAAS3C,UAAU/uB,gBACrC5T,EAASoU,GAAmBpvB,KAAK4iL,iBACvC,KAAOl1K,EAAMvM,OAAS6Z,GACpBtN,EAAM/H,KAAK,GAEb3F,KAAKmjL,kBAAoBz1K,EACN,UAAf1N,KAAK+7D,MACP/7D,KAAKsjL,cAAgB51K,EAAM5J,QACH,YAAf9D,KAAK+7D,OACd/7D,KAAKsjL,cAAgB,CAAC,CAAC51K,EAAM5J,QAAS4J,EAAM5J,UAC5C9D,KAAKwjL,kBAAoBxjL,KAAKsjL,cAAc,IAE5CtjL,KAAKsjL,cAAgB,CAAC51K,EAAM5J,QAAS4J,EAAM5J,SAEzC9D,KAAKwjL,oBACPxjL,KAAKujL,YAAc,IAAInvK,GAAQ,IAAIymE,GAAW76E,KAAKwjL,qBAErD,MAAM5uK,EAAW5U,KAAK+oJ,kBACpB/oJ,KAAKsjL,mBACL98K,EACA2Y,GAEFnf,KAAKojL,eAAiB,IAAIhvK,GACtBpU,KAAKuU,eACPvU,KAAKojL,eAAepuK,gBAAgBhV,KAAKuU,eAE3CvU,KAAKojL,eAAevuK,YAAYD,GAChC5U,KAAKsnL,wBACLtnL,KAAK4F,cACH,IAAI46K,GAAUD,GAAyBvgL,KAAKojL,gBAE/C,CAOD,cAAA0D,CAAe1vK,GACb,MAAM0zB,EAAM9qC,KAAKsgD,SACX1rC,EAAW5U,KAAKojL,eAAeluK,cAC/BiK,EAAa2rB,EAAI6S,UAAU/uB,gBAC3B5T,EAASoU,GAAmBpvB,KAAK4iL,iBACvC,IAAIrpK,EAAayY,EACjB,KAAO5a,EAAWjW,OAAS6Z,GACzB5D,EAAWzR,KAAK,GAsBlB,GApBmB,UAAf3F,KAAK+7D,MACP/pC,EAAOhyB,KAAKsjL,cACY,YAAftjL,KAAK+7D,OACdxiD,EAA4CvZ,KAAkB,cAAE,GAChEgyB,EAAOzY,EAAYA,EAAYpY,OAAS,GACpCnB,KAAK0mL,UAAU57I,EAAIu5B,uBAAuBjtD,MAE5CA,EAAapX,KAAKmjL,kBAAkBr/K,WAGtCyV,EAAcvZ,KAAKsjL,cACnBtxJ,EAAOzY,EAAYA,EAAYpY,OAAS,IAE1C6wB,EAAK,GAAK5a,EAAW,GACrB4a,EAAK,GAAK5a,EAAW,GACrBpX,KAAK+oJ,kBAC4B/oJ,KAAkB,cACjD4U,EACAuK,GAEEnf,KAAKqjL,aAAc,CACGrjL,KAAKqjL,aAAanuK,cAC1Bgb,eAAe9Y,EAChC,CACD,GAA2B,YAAvBxC,EAAS8Z,WAA0C,YAAf1uB,KAAK+7D,MAC3C/7D,KAAKunL,gCAAwD,QACxD,GAAIvnL,KAAKwjL,kBAAmB,CACVxjL,KAAKujL,YAAYruK,cACzBgb,eAAelwB,KAAKwjL,kBACpC,CACDxjL,KAAKsnL,uBACN,CAOD,aAAA7C,CAAcrtK,GACZ,MAAMxC,EAAW5U,KAAKojL,eAAeluK,cAC/BiK,EAAanf,KAAKsgD,SAAS3C,UAAU/uB,gBAC3C,IAAI20B,EACAhqC,EACJ,MAAMupK,EAAO9iL,KAAK+7D,MACL,eAAT+mH,GAAkC,WAATA,GAC3B9iL,KAAKmjL,kBAAoB/rK,EAAWtT,QACpCyV,EAA4CvZ,KAAkB,cAC1DuZ,EAAYpY,QAAUnB,KAAKwiL,aACzBxiL,KAAKgiL,UACPzoK,EAAYrO,MAEZq4C,GAAO,GAGXhqC,EAAY5T,KAAKyR,EAAWtT,SAC5B9D,KAAK+oJ,kBAAkBxvI,EAAa3E,EAAUuK,IAC5B,YAAT2jK,IACTvpK,EAA4CvZ,KAAkB,cAAE,GAC5DuZ,EAAYpY,QAAUnB,KAAKwiL,aACzBxiL,KAAKgiL,UACPzoK,EAAYrO,MAEZq4C,GAAO,GAGXhqC,EAAY5T,KAAKyR,EAAWtT,SACxBy/C,IACFvjD,KAAKmjL,kBAAoB5pK,EAAY,IAEvCvZ,KAAK+oJ,kBAAkB/oJ,KAAKsjL,cAAe1uK,EAAUuK,IAEvDnf,KAAK+mL,2BAA2B3vK,EAAWtT,SAC3C9D,KAAKsnL,wBACD/jI,GACFvjD,KAAKymL,eAER,CAKD,iBAAAnB,CAAkB3jL,GAChB,IAAK3B,KAAKojL,eACR,OAEF,MAAMxuK,EAAW5U,KAAKojL,eAAeluK,cAC/BiK,EAAanf,KAAKsgD,SAAS3C,UAAU/uB,gBACrCk0J,EAAO9iL,KAAK+7D,MAClB,IAAK,IAAIn6D,EAAI,EAAGA,EAAID,IAAKC,EAAG,CAC1B,IAAI2X,EACJ,GAAa,eAATupK,GAAkC,WAATA,EAAmB,CAG9C,GAFAvpK,EAA4CvZ,KAAkB,cAC9DuZ,EAAY1S,QAAQ,EAAG,GACnB0S,EAAYpY,QAAU,EAAG,CAC3BnB,KAAKmjL,kBAAoB5pK,EAAYA,EAAYpY,OAAS,GAAG2C,QAC7D,MAAMsjL,EAAmBpnL,KAAKmjL,kBAAkBr/K,QAChDyV,EAAYA,EAAYpY,OAAS,GAAKimL,EACtCpnL,KAAK+mL,2BAA2BK,EACjC,CACDpnL,KAAK+oJ,kBAAkBxvI,EAAa3E,EAAUuK,GACnB,YAAvBvK,EAAS8Z,WAA2B1uB,KAAKujL,aAC3CvjL,KAAKunL,gCACf,EAGA,MAAa,GAAa,YAATzE,EAAoB,CAC7BvpK,EAA4CvZ,KAAkB,cAAE,GAChEuZ,EAAY1S,QAAQ,EAAG,GACvB,MAAM2gL,EAAiBxnL,KAAKujL,YAAYruK,cACxC,GAAIqE,EAAYpY,QAAU,EAAG,CAC3B,MAAMimL,EAAmB7tK,EAAYA,EAAYpY,OAAS,GAAG2C,QAC7DyV,EAAYA,EAAYpY,OAAS,GAAKimL,EACtCpnL,KAAK+mL,2BAA2BK,EACjC,CACDI,EAAet3J,eAAe3W,GAC9BvZ,KAAK+oJ,kBAAkB/oJ,KAAKsjL,cAAe1uK,EAAUuK,EACtD,CAED,GAA2B,IAAvB5F,EAAYpY,OAAc,CAC5BnB,KAAK2mL,eACL,KACD,CACF,CAED3mL,KAAKsnL,uBACN,CAOD,eAAAG,GACEznL,KAAKslL,kBAAkB,EACxB,CAQD,aAAAmB,GACE,MAAMiB,EAAgB1nL,KAAK2nL,gBAC3B,IAAKD,EACH,OAEF,IAAInuK,EAAcvZ,KAAKsjL,cACvB,MAAM1uK,EAAW8yK,EAAcxyK,cACzBiK,EAAanf,KAAKsgD,SAAS3C,UAAU/uB,gBACxB,eAAf5uB,KAAK+7D,OAEPxiD,EAAYrO,MACZlL,KAAK+oJ,kBAAkBxvI,EAAa3E,EAAUuK,IACtB,YAAfnf,KAAK+7D,QAEe,EAAc,GAAG7wD,MAC9ClL,KAAK+oJ,kBAAkBxvI,EAAa3E,EAAUuK,GAC9C5F,EAAc3E,EAAS+a,kBAIN,eAAf3vB,KAAKm7F,MACPusF,EAAc7yK,YACZ,IAAImmE,GAAW,CAAgC,KAEzB,oBAAfh7E,KAAKm7F,MACdusF,EAAc7yK,YACZ,IAAIomE,GAAgB,CAA+B,KAE7B,iBAAfj7E,KAAKm7F,OACdusF,EAAc7yK,YACZ,IAAIqmE,GAAa,CAA+B,KAKpDl7E,KAAK4F,cAAc,IAAI46K,GAAUD,GAAuBmH,IAGpD1nL,KAAKgtE,WACPhtE,KAAKgtE,UAAUrnE,KAAK+hL,GAElB1nL,KAAKm/K,SACPn/K,KAAKm/K,QAAQjiF,WAAWwqF,EAE3B,CAOD,aAAAC,GACE3nL,KAAKmjL,kBAAoB,KACzB,MAAMuE,EAAgB1nL,KAAKojL,eAM3B,OALApjL,KAAKojL,eAAiB,KACtBpjL,KAAKqjL,aAAe,KACpBrjL,KAAKujL,YAAc,KACnBvjL,KAAK2jL,SAASzmI,YAAYv4C,OAAM,GAChC3E,KAAK2kL,mBACE+C,CACR,CAMD,YAAAf,GACE,MAAMe,EAAgB1nL,KAAK2nL,gBACvBD,GACF1nL,KAAK4F,cAAc,IAAI46K,GAAUD,GAAyBmH,GAE7D,CAWD,iBAAAnC,CAAkBhsK,GAChB,MAAMupK,EAAO9iL,KAAK+7D,MACZ6rH,GAAc5nL,KAAKojL,eAKzB,IAAI+D,EACJ,GALIS,GACF5nL,KAAK0kL,cAAcnrK,EAAY,IAIpB,eAATupK,GAAkC,WAATA,EAC3BqE,EAA6CnnL,KAAkB,kBAC1D,IAAa,YAAT8iL,EAMT,OALAqE,EACEnnL,KAAKsjL,eAAiBtjL,KAAKsjL,cAAcniL,OACPnB,KAAkB,cAAE,GAClD,EAGP,CAEG4nL,GACFT,EAAar3K,QAIfq3K,EAAaj8K,MAGb,IAAK,IAAItJ,EAAI,EAAGA,EAAI2X,EAAYpY,OAAQS,IACtC5B,KAAKykL,cAAclrK,EAAY3X,IAGjC,MAAMimL,EAAStuK,EAAYA,EAAYpY,OAAS,GAEhDnB,KAAKykL,cAAcoD,GACnB7nL,KAAK8mL,eAAee,EACrB,CAcD,MAAA3lL,CAAOy9C,GACL,MACMq5C,EADWr5C,EAAQzqC,cAEzBlV,KAAKojL,eAAiBzjI,EACtB3/C,KAAKsjL,cAAgBtqF,EAAWrpE,iBAChC,MAAMqC,EAAOhyB,KAAKsjL,cAActjL,KAAKsjL,cAAcniL,OAAS,GAC5DnB,KAAKmjL,kBAAoBnxJ,EAAKluB,QAC9B9D,KAAKsjL,cAAc39K,KAAKqsB,EAAKluB,SAC7B9D,KAAKqjL,aAAe,IAAIjvK,GAAQ,IAAIof,GAAMxB,IAC1ChyB,KAAKsnL,wBACLtnL,KAAK4F,cACH,IAAI46K,GAAUD,GAAyBvgL,KAAKojL,gBAE/C,CAMD,qBAAAkE,GACE,MAAMQ,EAAiB,GACnB9nL,KAAKojL,gBACP0E,EAAeniL,KAAK3F,KAAKojL,gBAEvBpjL,KAAKujL,aACPuE,EAAeniL,KAAK3F,KAAKujL,aAEvBvjL,KAAKqjL,cACPyE,EAAeniL,KAAK3F,KAAKqjL,cAE3B,MAAM0E,EAAgB/nL,KAAK2jL,SAASzmI,YACpC6qI,EAAcpjL,OAAM,GACpBojL,EAAch5G,YAAY+4G,EAC3B,CAKD,YAAAxD,GACE,MAAMx5I,EAAM9qC,KAAKsgD,SACXwU,EAAS90D,KAAK40D,YACf9pB,GAAQgqB,GACX90D,KAAK2mL,eAEP3mL,KAAK2jL,SAAS5mI,OAAO+X,EAAShqB,EAAM,KACrC,GCzwDH,MAAMk9I,GAMW,gBAQV,MAAMC,WAAoBliL,EAI/B,WAAAjG,CAAY0Z,GACVvU,MAAM+iL,IAONhoL,KAAKwZ,OAASA,CACf,EAoZH,SAAS0uK,KACP,MAAM33K,EAAQi5I,KACd,OAAO,SAAU7pG,EAAShjC,GACxB,OAAOpM,EAAe,OAC1B,CACA,CAOA,SAAS43K,KACP,MAAM53K,EAAQi5I,KACd,OAAO,SAAU7pG,EAAShjC,GACxB,OAAOpM,EAAa,KACxB,CACA,CAMA,SAAS63K,GAAgBC,GACvB,OAAO,SAAUzlK,GACf,OAAOtJ,GAAe,CAAC+uK,EAAYzlK,GACvC,CACA,CAOA,SAAS0lK,GAAeC,EAASC,GAC/B,OAAID,EAAQ,IAAMC,EAAQ,GACjB,SAAU5lK,GACf,OAAOtJ,GAAe,CAACivK,EAAS,CAAC3lK,EAAM,GAAI4lK,EAAQ,KACzD,EAEMD,EAAQ,IAAMC,EAAQ,GACjB,SAAU5lK,GACf,OAAOtJ,GAAe,CAACivK,EAAS,CAACC,EAAQ,GAAI5lK,EAAM,KACzD,EAES,IACT,CA2BA,IAAA6lK,GAvcA,cAAqB1wH,GAInB,WAAAj4D,CAAY6K,GAGV1F,MAFA0F,EAAUA,GAAW,IAOrB3K,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAOL3H,KAAKs4D,WAAa3tD,EAAQ0tD,UAAY1tD,EAAQ0tD,UAAYrB,GAO1Dh3D,KAAKugB,QAAU,KAOfvgB,KAAK0oL,gBAAkB,KAOvB1oL,KAAK2oL,qBACwBniL,IAA3BmE,EAAQi+K,eAA+Bj+K,EAAQi+K,eAAiB,GAOlE5oL,KAAK6oL,kBAAmB,EAOxB7oL,KAAK8oL,eAAiB,KAOtB9oL,KAAK+oL,eAAiB,KAEjBp+K,IACHA,EAAU,CAAA,GAQZ3K,KAAKgpL,eAAiB,IAAI7T,GAAY,CACpCjrK,OAAQ,IAAI41F,GAAa,CACvBxD,iBAAiB,EACjBp9E,QAASvU,EAAQuU,QAEnB3O,MAAO5F,EAAQs+K,SACXt+K,EAAQs+K,SACRf,KACJp0B,sBAAsB,EACtBC,wBAAwB,IAQ1B/zJ,KAAKkpL,eAAiB,IAAI/T,GAAY,CACpCjrK,OAAQ,IAAI41F,GAAa,CACvBxD,iBAAiB,EACjBp9E,QAASvU,EAAQuU,QAEnB3O,MAAO5F,EAAQw+K,aACXx+K,EAAQw+K,aACRhB,KACJr0B,sBAAsB,EACtBC,wBAAwB,IAGtBppJ,EAAQ6O,QACVxZ,KAAK8hB,UAAUnX,EAAQ6O,OAE1B,CAQD,aAAA4vK,CAAc9rI,EAAOxS,GACnB,MAAMu+I,EAAkBv+I,EAAI+tB,+BAA+Bvb,GACrDgsI,EAAiB,SAAUjoL,EAAGC,GAClC,OACEmmB,GAAyB4hK,EAAiBhoL,GAC1ComB,GAAyB4hK,EAAiB/nL,EAElD,EACUkY,EAASxZ,KAAKupL,oBACpB,GAAI/vK,EAAQ,CAEV,MAAMgwK,EA4SZ,SAAqBhwK,GACnB,MAAO,CACL,CACE,CAACA,EAAO,GAAIA,EAAO,IACnB,CAACA,EAAO,GAAIA,EAAO,KAErB,CACE,CAACA,EAAO,GAAIA,EAAO,IACnB,CAACA,EAAO,GAAIA,EAAO,KAErB,CACE,CAACA,EAAO,GAAIA,EAAO,IACnB,CAACA,EAAO,GAAIA,EAAO,KAErB,CACE,CAACA,EAAO,GAAIA,EAAO,IACnB,CAACA,EAAO,GAAIA,EAAO,KAGzB,CA/TuBiwK,CAAYjwK,GAC7BgwK,EAASl1J,KAAKg1J,GACd,MAAMI,EAAiBF,EAAS,GAEhC,IAAIG,EAAStjK,GAAiBgjK,EAAiBK,GAC/C,MAAME,EAAc9+I,EAAI8tB,+BAA+B+wH,GAGvD,GAAIE,GAAmBvsI,EAAOssI,IAAgB5pL,KAAK2oL,gBAAiB,CAElE,MAAMmB,EAASh/I,EAAI8tB,+BAA+B8wH,EAAe,IAC3DK,EAASj/I,EAAI8tB,+BAA+B8wH,EAAe,IAC3DM,EAAehH,GAA0B4G,EAAaE,GACtDG,EAAejH,GAA0B4G,EAAaG,GACtDG,EAAOj+K,KAAKma,KAAKna,KAAKwP,IAAIuuK,EAAcC,IAM9C,OALAjqL,KAAK6oL,iBAAmBqB,GAAQlqL,KAAK2oL,gBACjC3oL,KAAK6oL,mBACPc,EACEK,EAAeC,EAAeP,EAAe,GAAKA,EAAe,IAE9DC,CACR,CACF,CACD,OAAO,IACR,CAMD,kBAAA79H,CAAmB+I,GACjB,MAAMvX,EAAQuX,EAAgBvX,MACxBxS,EAAM+pB,EAAgB/pB,IAE5B,IAAI6+I,EAAS3pL,KAAKopL,cAAc9rI,EAAOxS,GAClC6+I,IACHA,EAAS7+I,EAAI+tB,+BAA+Bvb,IAE9Ct9C,KAAKmqL,8BAA8BR,EACpC,CAOD,4BAAAS,CAA6B5wK,GAC3B,IAAI6wK,EAAgBrqL,KAAK8oL,eAiBzB,OAfKuB,EASE7wK,EAGH6wK,EAAcx1K,YAAYglC,GAAkBrgC,IAF5C6wK,EAAcx1K,iBAAYrO,IAN1B6jL,EAAgB,IAAIj2K,GAHjBoF,EAGyBqgC,GAAkBrgC,GAFlB,CAAA,GAI9BxZ,KAAK8oL,eAAiBuB,EACtBrqL,KAAKgpL,eAAe9rI,YAAYggD,WAAWmtF,IAQtCA,CACR,CAOD,6BAAAF,CAA8BR,GAC5B,IAAIW,EAAgBtqL,KAAK+oL,eACzB,GAAKuB,EAIE,CACYA,EAAcp1K,cACtBgb,eAAey5J,EACzB,MANCW,EAAgB,IAAIl2K,GAAQ,IAAIof,GAAMm2J,IACtC3pL,KAAK+oL,eAAiBuB,EACtBtqL,KAAKkpL,eAAehsI,YAAYggD,WAAWotF,GAK7C,OAAOA,CACR,CAMD,WAAAlkL,CAAYyuD,GACV,OAAKA,EAAgBpM,gBAAkBzoD,KAAKs4D,WAAWzD,KAKrDA,EAAgB90D,MAAQipD,GAAoBK,aAC3CrpD,KAAK41D,wBAEN51D,KAAK8rD,mBAAmB+I,GAG1B5vD,MAAMmB,YAAYyuD,IAEX,EACR,CAOD,eAAAU,CAAgBV,GACd,MAAMvX,EAAQuX,EAAgBvX,MACxBxS,EAAM+pB,EAAgB/pB,IAEtBtxB,EAASxZ,KAAKupL,oBACpB,IAAII,EAAS3pL,KAAKopL,cAAc9rI,EAAOxS,GAGvC,MAAMy/I,EAAmB,SAAU3nK,GACjC,IAAI4nK,EAAK,KACLC,EAAK,KAWT,OAVI7nK,EAAM,IAAMpJ,EAAO,GACrBgxK,EAAKhxK,EAAO,GACHoJ,EAAM,IAAMpJ,EAAO,KAC5BgxK,EAAKhxK,EAAO,IAEVoJ,EAAM,IAAMpJ,EAAO,GACrBixK,EAAKjxK,EAAO,GACHoJ,EAAM,IAAMpJ,EAAO,KAC5BixK,EAAKjxK,EAAO,IAEH,OAAPgxK,GAAsB,OAAPC,EACV,CAACD,EAAIC,GAEP,IACb,EACI,GAAId,GAAUnwK,EAAQ,CACpB,MAAMnC,EACJsyK,EAAO,IAAMnwK,EAAO,IAAMmwK,EAAO,IAAMnwK,EAAO,GAAKmwK,EAAO,GAAK,KAC3DryK,EACJqyK,EAAO,IAAMnwK,EAAO,IAAMmwK,EAAO,IAAMnwK,EAAO,GAAKmwK,EAAO,GAAK,KAGvD,OAANtyK,GAAoB,OAANC,EAChBtX,KAAK0oL,gBAAkBN,GAAgBmC,EAAiBZ,IAEzC,OAANtyK,EACTrX,KAAK0oL,gBAAkBJ,GACrBiC,EAAiB,CAAClzK,EAAGmC,EAAO,KAC5B+wK,EAAiB,CAAClzK,EAAGmC,EAAO,MAEf,OAANlC,IACTtX,KAAK0oL,gBAAkBJ,GACrBiC,EAAiB,CAAC/wK,EAAO,GAAIlC,IAC7BizK,EAAiB,CAAC/wK,EAAO,GAAIlC,KAIvC,MACMqyK,EAAS7+I,EAAI+tB,+BAA+Bvb,GAC5Ct9C,KAAK8hB,UAAU,CAAC6nK,EAAO,GAAIA,EAAO,GAAIA,EAAO,GAAIA,EAAO,KACxD3pL,KAAK0oL,gBAAkBN,GAAgBuB,GAEzC,OAAO,CACR,CAMD,eAAAn0H,CAAgBX,GACd,GAAI70D,KAAK0oL,gBAAiB,CACxB,MAAMW,EAAkBx0H,EAAgBz9C,WACxCpX,KAAK8hB,UAAU9hB,KAAK0oL,gBAAgBW,IACpCrpL,KAAKmqL,8BAA8Bd,EACpC,CACF,CAOD,aAAA3zH,CAAcb,GACZ70D,KAAK0oL,gBAAkB,KAEvB,MAAMlvK,EAASxZ,KAAKupL,oBAIpB,OAHK/vK,GAA8B,IAApB0C,GAAQ1C,IACrBxZ,KAAK8hB,UAAU,OAEV,CACR,CAQD,MAAAi7B,CAAOjS,GACL9qC,KAAKgpL,eAAejsI,OAAOjS,GAC3B9qC,KAAKkpL,eAAensI,OAAOjS,GAC3B7lC,MAAM83C,OAAOjS,EACd,CAQD,SAAAzrB,GACE,OAAOgN,GACLrsB,KAAKupL,oBACLvpL,KAAKsgD,SAAS3C,UAAU/uB,gBAE3B,CAQD,iBAAA26J,GACE,OAAOvpL,KAAKugB,OACb,CAQD,SAAAuB,CAAUtI,GAERxZ,KAAKugB,QAAU/G,GAAkB,KACjCxZ,KAAKoqL,6BAA6B5wK,GAClCxZ,KAAK4F,cAAc,IAAIqiL,GAAYjoL,KAAKugB,SACzC,GC/bH,SAASmqK,GAAWx0C,GAClB,OAAOnrG,WAAWmrG,EACpB,CAMA,SAASy0C,GAAYtlK,GACnB,OAjBF,SAAaA,GACX,OAAON,GAAQM,EAAQ,EACzB,CAeSulK,CAAIvlK,GAAQzM,UACrB,CAOA,SAASiyK,GAAgBxpL,EAAGC,GAC1B,OAAIktB,MAAMntB,IAGHA,IAAMqpL,GAAWC,GAAYrpL,GACtC,CAkaA,IAAAwpL,GA/XA,cAAmB91H,GAIjB,WAAAl1D,CAAY6K,GAaV,IAAIogL,EAZJ9lL,QAcE8lL,GADsB,KAXxBpgL,EAAUjE,OAAO8C,OACf,CACEusC,SAAS,EACTk6C,OAAQ,CAAC,IAAK,IAAK,IAAK,IAAK,KAC7BzsE,SAAS,EACT48H,OAAQ,IAEVz1I,GAAW,CAAE,IAIHorC,QACS,CAAC5X,SAAU,KACpBxzB,EAAQorC,QAGCprC,EAAQorC,QAFR,KASrB/1C,KAAKgrL,kBAAoBD,EAMzB/qL,KAAKuzG,QAAU5oG,EAAQslF,OAAOvrC,QAAO,CAACs1B,EAAK31E,KACzC21E,EAAI31E,IAAS,EACN21E,IACN,CAAE,GAMLh6E,KAAKirL,SAAWtgL,EAAQ6Y,QAMxBxjB,KAAKkrL,QAAUvgL,EAAQy1I,OAMvBpgJ,KAAKonD,cAAgB,GAMrBpnD,KAAKmrL,UAAW,EAEhBnrL,KAAKskL,aAAetkL,KAAKskL,aAAap9K,KAAKlH,MAO3CA,KAAKorL,kBAAoB,GAOzBprL,KAAKqrL,eAAiB,EACvB,CAOD,aAAAC,CAAc51K,GACZ,OAAK1V,KAAKkrL,QAGHlrL,KAAKkrL,QAAUx1K,EAFbA,CAGV,CAQD,IAAA61K,CAAKt7F,EAAQv6E,GACX,OAAOu6E,EAAO7mF,IAAIpJ,KAAKsrL,cAAc51K,GACtC,CAQD,IAAA81K,CAAKv7F,EAAQv6E,EAAMrR,GACXqR,KAAQ1V,KAAKuzG,SAGnBtjB,EAAOlmF,IAAI/J,KAAKsrL,cAAc51K,GAAOrR,EACtC,CAOD,OAAAonL,CAAQx7F,EAAQv6E,GACRA,KAAQ1V,KAAKuzG,SAGnBtjB,EAAOE,OAAOnwF,KAAKsrL,cAAc51K,GAClC,CAKD,MAAAqnC,CAAOjS,GACL,MAAM4gJ,EAAS1rL,KAAKsgD,SACpBr7C,MAAM83C,OAAOjS,GACTA,IAAQ4gJ,IAGRA,GACF1rL,KAAK2/K,qBAAqB+L,GAExB5gJ,IACF9qC,KAAKmrL,UAAW,EAChBnrL,KAAKskL,eACLtkL,KAAKu/K,mBAAmBz0I,IAE3B,CAMD,kBAAAy0I,CAAmBz0I,GACjB9qC,KAAKonD,cAAczhD,KACjBoB,EAAO+jC,EAAKshB,GAAsBpsD,KAAK2rL,WAAY3rL,MACnD+G,EAAO+jC,EAAIgT,gBAAiBh2C,EAAkB9H,KAAK2rL,WAAY3rL,MAC/D+G,EAAO+jC,EAAK,oBAAqB9qC,KAAK4rL,wBAAyB5rL,OAG5DA,KAAKirL,UACR3lL,iBAAiB,WAAYtF,KAAKskL,aAErC,CAMD,oBAAA3E,CAAqB70I,GACnB,IAAK,IAAIlpC,EAAI,EAAGuE,EAAKnG,KAAKonD,cAAcjmD,OAAQS,EAAIuE,IAAMvE,EACxD0F,EAActH,KAAKonD,cAAcxlD,IAEnC5B,KAAKonD,cAAcjmD,OAAS,EAEvBnB,KAAKirL,UACR3kL,oBAAoB,WAAYtG,KAAKskL,cAGvC,MAAM12G,EAAM,IAAImC,IAAIzgE,OAAOgmH,SAAStlD,MAC9BigB,EAASriB,EAAIsiB,aACnBlwF,KAAKyrL,QAAQx7F,EAAQ,KACrBjwF,KAAKyrL,QAAQx7F,EAAQ,KACrBjwF,KAAKyrL,QAAQx7F,EAAQ,KACrBjwF,KAAKyrL,QAAQx7F,EAAQ,KACrBjwF,KAAKyrL,QAAQx7F,EAAQ,KACrB3gF,OAAOu8K,QAAQC,aAAa,KAAM,GAAIl+G,EACvC,CAKD,uBAAAg+G,GACE,MAAM9gJ,EAAM9qC,KAAKsgD,SACZxV,IAGL9qC,KAAK2/K,qBAAqB70I,GAC1B9qC,KAAKu/K,mBAAmBz0I,GACxB9qC,KAAKmrL,UAAW,EAChBnrL,KAAK2rL,aACN,CAKD,YAAArH,GACE,MACMr0F,EADM,IAAIlgB,IAAIzgE,OAAOgmH,SAAStlD,MACjBkgB,aACnB,IAAK,MAAM3oF,KAAOvH,KAAKorL,kBAAmB,CACxC,MAAM/mL,EAAQ4rF,EAAO7mF,IAAI7B,GACrBA,KAAOvH,KAAKorL,mBAAqB/mL,IAAUrE,KAAKqrL,eAAe9jL,KACjEvH,KAAKqrL,eAAe9jL,GAAOlD,EAC3BrE,KAAKorL,kBAAkB7jL,GAAKlD,GAE/B,CAED,MAAMymC,EAAM9qC,KAAKsgD,SACjB,IAAKxV,EACH,OAEF,MAAM0S,EAAO1S,EAAI6S,UACjB,IAAKH,EACH,OAGF,IAAIuuI,GAAa,EAKjB,MAAMC,EAAiB,CAAA,EAEjB52I,EAAOs1I,GAAW1qL,KAAKurL,KAAKt7F,EAAQ,MACtC,MAAOjwF,KAAKuzG,SAAWs3E,GAAgBz1I,EAAMoI,EAAK3H,aACpDk2I,GAAa,EACbC,EAAe52I,KAAOA,GAGxB,MAAMx4B,EAAW8tK,GAAW1qL,KAAKurL,KAAKt7F,EAAQ,MAC1C,MAAOjwF,KAAKuzG,SAAWs3E,GAAgBjuK,EAAU4gC,EAAK1H,iBACxDi2I,GAAa,EACbC,EAAepvK,SAAWA,GAG5B,MAAMF,EAAS,CACbguK,GAAW1qL,KAAKurL,KAAKt7F,EAAQ,MAC7By6F,GAAW1qL,KAAKurL,KAAKt7F,EAAQ,OAlRnC,IAAwB5uF,EAAGC,GAqRpB,MAAOtB,KAAKuzG,SAAW,MAAOvzG,KAAKuzG,WArRlBlyG,EAsRHqb,EAtRMpb,EAsREk8C,EAAKlhC,YArRzBuuK,GAAgBxpL,EAAE,GAAIC,EAAE,KAAOupL,GAAgBxpL,EAAE,GAAIC,EAAE,OAuR1DyqL,GAAa,EACbC,EAAetvK,OAASA,GAGtBqvK,KACG/rL,KAAKmrL,UAAYnrL,KAAKgrL,kBACzBxtI,EAAKzH,QAAQrvC,OAAO8C,OAAOwiL,EAAgBhsL,KAAKgrL,qBAE5CgB,EAAetvK,QACjB8gC,EAAKzC,UAAUixI,EAAetvK,QAE5B,SAAUsvK,GACZxuI,EAAKnI,QAAQ22I,EAAe52I,MAE1B,aAAc42I,GAChBxuI,EAAKtI,YAAY82I,EAAepvK,YAKtC,MAAMmqC,EAASjc,EAAI8mB,eACbq6H,EAAcjsL,KAAKurL,KAAKt7F,EAAQ,KACtC,GACE,MAAOjwF,KAAKuzG,SACZ04E,GACAA,EAAY9qL,SAAW4lD,EAAO5lD,OAE9B,IAAK,IAAIS,EAAI,EAAGuE,EAAK4gD,EAAO5lD,OAAQS,EAAIuE,IAAMvE,EAAG,CAC/C,MAAMyC,EAAQoM,SAASw7K,EAAYrqL,IACnC,IAAK4sB,MAAMnqB,GAAQ,CACjB,MAAM0oC,EAAU2K,QAAQrzC,GAClBupC,EAAQmZ,EAAOnlD,GACjBgsC,EAAMG,eAAiBhB,GACzBa,EAAMkB,WAAW/B,EAEpB,CACF,CAEJ,CAWD,KAAAm/I,CAAM3kL,EAAKqU,GACT5b,KAAKorL,kBAAkB7jL,GAAOqU,EAC9B,MAEMvX,EAFM,IAAI0rE,IAAIzgE,OAAOgmH,SAAStlD,MACjBkgB,aACE9mF,IAAI7B,GAEzB,OADAvH,KAAKqrL,eAAe9jL,GAAOlD,EACpBA,CACR,CAUD,MAAAy5B,CAAOv2B,EAAKlD,GACV,MAAMupE,EAAM,IAAImC,IAAIzgE,OAAOgmH,SAAStlD,MAC9BigB,EAASriB,EAAIsiB,aACL,OAAV7rF,EACF4rF,EAAOE,OAAO5oF,GAEd0oF,EAAOlmF,IAAIxC,EAAKlD,GAEdkD,KAAOvH,KAAKqrL,iBACdrrL,KAAKqrL,eAAe9jL,GAAOlD,GAE7BrE,KAAKmsL,eAAev+G,EACrB,CAKD,UAAA+9G,GACE,MAAM7gJ,EAAM9qC,KAAKsgD,SACjB,IAAKxV,EACH,OAEF,MAAM0S,EAAO1S,EAAI6S,UACjB,IAAKH,EACH,OAGF,MAAM9gC,EAAS8gC,EAAKlhC,YACd84B,EAAOoI,EAAK3H,UACZj5B,EAAW4gC,EAAK1H,cAEhBiR,EAASjc,EAAI8mB,eACbw6H,EAAe,IAAI/pL,MAAM0kD,EAAO5lD,QACtC,IAAK,IAAIS,EAAI,EAAGuE,EAAK4gD,EAAO5lD,OAAQS,EAAIuE,IAAMvE,EAC5CwqL,EAAaxqL,GAAKmlD,EAAOnlD,GAAGmsC,aAAe,IAAM,IAGnD,MAAM6/B,EAAM,IAAImC,IAAIzgE,OAAOgmH,SAAStlD,MAC9BigB,EAASriB,EAAIsiB,aAEnBlwF,KAAKwrL,KAAKv7F,EAAQ,IAAK06F,GAAYjuK,EAAO,KAC1C1c,KAAKwrL,KAAKv7F,EAAQ,IAAK06F,GAAYjuK,EAAO,KAC1C1c,KAAKwrL,KAAKv7F,EAAQ,IAAK06F,GAAYv1I,IACnCp1C,KAAKwrL,KAAKv7F,EAAQ,IAAK06F,GAAY/tK,IACnC5c,KAAKwrL,KAAKv7F,EAAQ,IAAKm8F,EAAatzK,KAAK,KAEzC9Y,KAAKmsL,eAAev+G,GACpB5tE,KAAKmrL,UAAW,CACjB,CAMD,cAAAgB,CAAev+G,GACTA,EAAIoC,OAAS1gE,OAAOgmH,SAAStlD,OAC3BhwE,KAAKmrL,UAAYnrL,KAAKirL,SACxB37K,OAAOu8K,QAAQC,aAAaD,QAAQr/K,MAAO,GAAIohE,GAE/Ct+D,OAAOu8K,QAAQQ,UAAU,KAAM,GAAIz+G,GAGxC,GCxZH,MASM4Y,GAAa,CAAC,EAAG,EAAG,EAAG,GACvB8lG,GAAc,GAKdC,GAMS,cANTA,GAYO,YA6DN,MAAMC,WAAoBzmL,EAQ/B,WAAAjG,CAAYC,EAAMojE,EAAUtO,GAC1B5vD,MAAMlF,GAONC,KAAKmjE,SAAWA,EAOhBnjE,KAAK60D,gBAAkBA,CACxB,EAq3CH,SAAS43H,GAAeprL,EAAGC,GACzB,OAAOD,EAAE4B,MAAQ3B,EAAE2B,KACrB,CAYA,SAASypL,GACPC,EACAC,EACAztK,GAEA,MAAMvK,EAAWg4K,EAAYh4K,SAE7B,GAA2B,WAAvBA,EAAS8Z,UAAwB,CACnC,IAAI4hD,EAAc,EAIlB,GAx/C+B,IAw/C3Bs8G,EAAY3pL,MAAsC,CACpD,MAAM8oB,EAAiBE,KACnBF,IACFukD,EACEA,EAAev7D,QAAQiB,UAAU+V,EAAgB5M,IAGrD,MAAM0tK,EAA0B7J,GAC9B1yG,EAAeh0D,YACf6P,GAAmBwgK,EAAkBxtK,IAEjC2tK,EACJ7gL,KAAKma,KAAKymK,GAA2Bv8G,EAAenqD,YACtD,OAAO2mK,EAA0BA,CAClC,CACF,CAED,MAAM11K,EAAa+U,GAAmBwgK,EAAkBxtK,GAGxD,OAFAmtK,GAAY,GAAKngK,GAAmBygK,EAAYtmK,QAAQ,GAAInH,GAC5DmtK,GAAY,GAAKngK,GAAmBygK,EAAYtmK,QAAQ,GAAInH,GACrDsI,GAAyBrQ,EAAYk1K,GAC9C,CAYA,SAASS,GAAqBJ,EAAkBC,EAAaztK,GAC3D,MAAMvK,EAAWg4K,EAAYh4K,SAE7B,GACyB,WAAvBA,EAAS8Z,WA7hDsB,IA8hD/Bk+J,EAAY3pL,MACZ,CACA,IAAIqtE,EAAc,EAGlB,MAAMvkD,EAAiBE,KAMvB,OALIF,IACFukD,EACEA,EAAev7D,QAAQiB,UAAU+V,EAAgB5M,IAG9C+M,GACLokD,EAAeliD,gBACbjC,GAAmBwgK,EAAkBxtK,IAEvCA,EAEH,CACD,MAAM/H,EAAa+U,GAAmBwgK,EAAkBxtK,GAGxD,OAFAmtK,GAAY,GAAKngK,GAAmBygK,EAAYtmK,QAAQ,GAAInH,GAC5DmtK,GAAY,GAAKngK,GAAmBygK,EAAYtmK,QAAQ,GAAInH,GACrD+M,GACL7F,GAAiBjP,EAAYk1K,IAC7BntK,EAEJ,CAKA,SAASsiK,KACP,MAAMlxK,EAAQi5I,KACd,OAAO,SAAU7pG,EAAShjC,GACxB,OAAOpM,EAAa,KACxB,CACA,CAEA,IAAAy8K,GAx7CA,cAAqBj1H,GAInB,WAAAj4D,CAAY6K,GAoKV,IAAIw4D,EAeJ,GAlLAl+D,MAAK,GAKLjF,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAGL3H,KAAKitL,0BAA4BjtL,KAAKu9F,qBAAqBr2F,KAAKlH,MAMhEA,KAAKs4D,WAAa3tD,EAAQ0tD,UAAY1tD,EAAQ0tD,UAAYT,GAO1D53D,KAAKktL,wBAA0B,SAAUr4H,GACvC,OAAOwB,GAAWxB,IAAoBsC,GAAYtC,EACxD,EAMI70D,KAAKmtL,iBAAmBxiL,EAAQyiL,gBAC5BziL,EAAQyiL,gBACRptL,KAAKktL,wBAMTltL,KAAKqtL,uBAAyB1iL,EAAQ2iL,sBAClC3iL,EAAQ2iL,sBACRt2H,GAOJh3D,KAAK+oL,eAAiB,KAOtB/oL,KAAKutL,gBAAkB,KAMvBvtL,KAAKwtL,WAAa,CAAC,EAAG,GAQtBxtL,KAAKytL,wBAAyB,EAM9BztL,KAAK0tL,uBAAyB,KAO9B1tL,KAAK2tL,OAAS,IAAInxF,GAMlBx8F,KAAK2oL,qBACwBniL,IAA3BmE,EAAQi+K,eAA+Bj+K,EAAQi+K,eAAiB,GAMlE5oL,KAAK6oL,kBAAmB,EAQxB7oL,KAAK4tL,kBAAmB,EAMxB5tL,KAAK6tL,cAAgB,GAOrB7tL,KAAK2jL,SAAW,IAAIxO,GAAY,CAC9BjrK,OAAQ,IAAI41F,GAAa,CACvBxD,iBAAiB,EACjBp9E,QAASvU,EAAQuU,QAEnB3O,MAAO5F,EAAQ4F,MAAQ5F,EAAQ4F,MAAQkxK,KACvC3tB,sBAAsB,EACtBC,wBAAwB,IAQ1B/zJ,KAAK8tL,iBAAmB,CACtBt6J,MAASxzB,KAAK+tL,oBAAoB7mL,KAAKlH,MACvC66E,WAAc76E,KAAKguL,yBAAyB9mL,KAAKlH,MACjDkzB,WAAclzB,KAAKguL,yBAAyB9mL,KAAKlH,MACjDi2B,QAAWj2B,KAAKiuL,sBAAsB/mL,KAAKlH,MAC3Cg7E,WAAch7E,KAAKkuL,yBAAyBhnL,KAAKlH,MACjDi7E,gBAAmBj7E,KAAKmuL,8BAA8BjnL,KAAKlH,MAC3Dk7E,aAAgBl7E,KAAKouL,2BAA2BlnL,KAAKlH,MACrDs7E,OAAUt7E,KAAKquL,qBAAqBnnL,KAAKlH,MACzCm7E,mBAAsBn7E,KAAKsuL,iCAAiCpnL,KAAKlH,OAOnEA,KAAKm/K,QAAU,KAKfn/K,KAAKuuL,cAAgB,KAIjB5jL,EAAQw4D,SACVA,EAAWx4D,EAAQw4D,SACVx4D,EAAQT,SACjBlK,KAAKm/K,QAAUx0K,EAAQT,OACvBi5D,EAAW,IAAI34D,EAAWxK,KAAKm/K,QAAQ9hI,eACvCr9C,KAAKm/K,QAAQ75K,iBACXw2F,GACA97F,KAAKwuL,iBAAiBtnL,KAAKlH,OAE7BA,KAAKm/K,QAAQ75K,iBACXw2F,GACA97F,KAAKyuL,oBAAoBvnL,KAAKlH,SAG7BmjE,EACH,MAAM,IAAI36D,MACR,iEAGAmC,EAAQ+jL,eACV1uL,KAAKuuL,cAAgB5jL,EAAQ+jL,cAO/B1uL,KAAKgtE,UAAY7J,EAEjBnjE,KAAKgtE,UAAU7hE,QAAQnL,KAAK2uL,YAAYznL,KAAKlH,OAC7CA,KAAKgtE,UAAU1nE,iBACb8E,EACApK,KAAK4uL,kBAAkB1nL,KAAKlH,OAE9BA,KAAKgtE,UAAU1nE,iBACb8E,EACApK,KAAK6uL,qBAAqB3nL,KAAKlH,OAOjCA,KAAK8uL,kBAAoB,KAMzB9uL,KAAKi1D,OAAS,CAAC,EAAG,GAKlBj1D,KAAK+uL,oBACuBvoL,IAA1BmE,EAAQqkL,eACHhvL,KAAKuuL,cACN5jL,EAAQqkL,aACf,CAMD,WAAAL,CAAYhvI,GACV,MAAM/qC,EAAW+qC,EAAQzqC,cACzB,GAAIN,EAAU,CACZ,MAAMq6K,EAASjvL,KAAK8tL,iBAAiBl5K,EAAS8Z,WAC1CugK,GACFA,EAAOtvI,EAAS/qC,EAEnB,CACD,MAAMk2B,EAAM9qC,KAAKsgD,SACbxV,GAAOA,EAAI26B,cAAgBzlE,KAAK40D,aAClC50D,KAAKkvL,sBAAsBlvL,KAAKwtL,WAAY1iJ,GAE9C6U,EAAQr6C,iBAAiBwC,EAAkB9H,KAAKitL,0BACjD,CAOD,mBAAAkC,CAAoBvvL,EAAK4pL,GACvB,IAAKxpL,KAAK0tL,uBAAwB,CAChC1tL,KAAK0tL,uBAAyB,IAAIljL,EAClC,MAAM24D,EAAWnjE,KAAK0tL,uBAAuBriL,WAC7C,IAAK,IAAIzJ,EAAI,EAAGuE,EAAKqjL,EAASroL,OAAQS,EAAIuE,IAAMvE,EAAG,CACjD,MAAM0kB,EAAUkjK,EAAS5nL,GACzB,IAAK,IAAImoC,EAAI,EAAGqlJ,EAAK9oK,EAAQnlB,OAAQ4oC,EAAIqlJ,IAAMrlJ,EAAG,CAChD,MAAM4V,EAAUr5B,EAAQyjB,GAAG4V,QACvBA,IAAYwjB,EAASz9D,SAASi6C,IAChC3/C,KAAK0tL,uBAAuB/nL,KAAKg6C,EAEpC,CACF,CAC+C,IAA5C3/C,KAAK0tL,uBAAuBziL,YAC9BjL,KAAK0tL,uBAAyB,KAE9B1tL,KAAK4F,cACH,IAAI4mL,GACFD,GACAvsL,KAAK0tL,uBACL9tL,GAIP,CACF,CAMD,cAAAyvL,CAAe1vI,GACb3/C,KAAKsvL,0BAA0B3vI,GAE3B3/C,KAAK+oL,gBAAiD,IAA/B/oL,KAAKgtE,UAAU/hE,cACxCjL,KAAK2jL,SAASzmI,YAAY2gD,cAAc79F,KAAK+oL,gBAC7C/oL,KAAK+oL,eAAiB,MAExBppI,EAAQr5C,oBACNwB,EACA9H,KAAKitL,0BAER,CAMD,yBAAAqC,CAA0B3vI,GACxB,MAAM4vI,EAAQvvL,KAAK2tL,OAEb6B,EAAgB,GACtBD,EAAMpkL,SAIJ,SAAUoG,GACJouC,IAAYpuC,EAAKouC,SACnB6vI,EAAc7pL,KAAK4L,EAEtB,IAEH,IAAK,IAAI3P,EAAI4tL,EAAcruL,OAAS,EAAGS,GAAK,IAAKA,EAAG,CAClD,MAAM6tL,EAAeD,EAAc5tL,GACnC,IAAK,IAAI0iB,EAAItkB,KAAK6tL,cAAc1sL,OAAS,EAAGmjB,GAAK,IAAKA,EAChDtkB,KAAK6tL,cAAcvpK,GAAG,KAAOmrK,GAC/BzvL,KAAK6tL,cAAchnL,OAAOyd,EAAG,GAGjCirK,EAAM7jL,OAAO+jL,EACd,CACF,CAQD,SAAA96H,CAAUG,GACJ90D,KAAK+oL,iBAAmBj0H,IAC1B90D,KAAK2jL,SAASzmI,YAAY2gD,cAAc79F,KAAK+oL,gBAC7C/oL,KAAK+oL,eAAiB,MAExB9jL,MAAM0vD,UAAUG,EACjB,CAQD,MAAA/X,CAAOjS,GACL9qC,KAAK2jL,SAAS5mI,OAAOjS,GACrB7lC,MAAM83C,OAAOjS,EACd,CAOD,UAAAy5I,GACE,OAAOvkL,KAAK2jL,QACb,CAMD,gBAAA6K,CAAiB3oL,GACXA,EAAM85C,SACR3/C,KAAKgtE,UAAUrnE,KAAKE,EAAM85C,QAE7B,CAMD,mBAAA8uI,CAAoB5oL,GACdA,EAAM85C,SACR3/C,KAAKgtE,UAAUthE,OAAO7F,EAAM85C,QAE/B,CAMD,iBAAAivI,CAAkBhvL,GAChBI,KAAK2uL,YAAY/uL,EAAI2K,QACtB,CAMD,oBAAAgzF,CAAqB39F,GACnB,IAAKI,KAAK4tL,iBAAkB,CAC1B,MAAMjuI,EAAkC//C,EAAU,OAClDI,KAAKqvL,eAAe1vI,GACpB3/C,KAAK2uL,YAAYhvI,EAClB,CACF,CAMD,oBAAAkvI,CAAqBjvL,GACnBI,KAAKqvL,eAAezvL,EAAI2K,QACzB,CAOD,mBAAAwjL,CAAoBpuI,EAAS/qC,GAC3B,MAAM2E,EAAc3E,EAAS+a,iBAGvBi9J,EAAc,CAClBjtI,QAASA,EACT/qC,SAAUA,EACV0R,QAAS,CAAC/M,EAAaA,IAGzBvZ,KAAK2tL,OAAOz6F,OAAOt+E,EAASyK,YAAautK,EAC1C,CAOD,wBAAAsB,CAAyBvuI,EAAS/qC,GAChC,MAAMmlF,EAASnlF,EAAS+a,iBACxB,IAAK,IAAI/tB,EAAI,EAAGuE,EAAK4zF,EAAO54F,OAAQS,EAAIuE,IAAMvE,EAAG,CAC/C,MAAM2X,EAAcwgF,EAAOn4F,GAGrBgrL,EAAc,CAClBjtI,QAASA,EACT/qC,SAAUA,EACVg+H,MAAO,CAAChxI,GACRqB,MAAOrB,EACP0kB,QAAS,CAAC/M,EAAaA,IAGzBvZ,KAAK2tL,OAAOz6F,OAAOt+E,EAASyK,YAAautK,EAC1C,CACF,CAOD,wBAAAoB,CAAyBruI,EAAS/qC,GAChC,MAAM2E,EAAc3E,EAAS+a,iBAC7B,IAAK,IAAI/tB,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAS,EAAGS,EAAIuE,IAAMvE,EAAG,CACxD,MAAM0kB,EAAU/M,EAAYzV,MAAMlC,EAAGA,EAAI,GAGnCgrL,EAAc,CAClBjtI,QAASA,EACT/qC,SAAUA,EACV3R,MAAOrB,EACP0kB,QAASA,GAGXtmB,KAAK2tL,OAAOz6F,OAAO55E,GAAegN,GAAUsmK,EAC7C,CACF,CAOD,6BAAAuB,CAA8BxuI,EAAS/qC,GACrC,MAAMqvG,EAAQrvG,EAAS+a,iBACvB,IAAK,IAAIrL,EAAI,EAAG2G,EAAKg5F,EAAM9iH,OAAQmjB,EAAI2G,IAAM3G,EAAG,CAC9C,MAAM/K,EAAc0qG,EAAM3/F,GAC1B,IAAK,IAAI1iB,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAS,EAAGS,EAAIuE,IAAMvE,EAAG,CACxD,MAAM0kB,EAAU/M,EAAYzV,MAAMlC,EAAGA,EAAI,GAGnCgrL,EAAc,CAClBjtI,QAASA,EACT/qC,SAAUA,EACVg+H,MAAO,CAACtuH,GACRrhB,MAAOrB,EACP0kB,QAASA,GAGXtmB,KAAK2tL,OAAOz6F,OAAO55E,GAAegN,GAAUsmK,EAC7C,CACF,CACF,CAOD,qBAAAqB,CAAsBtuI,EAAS/qC,GAC7B,MAAM4G,EAAQ5G,EAAS+a,iBACvB,IAAK,IAAIrL,EAAI,EAAG2G,EAAKzP,EAAMra,OAAQmjB,EAAI2G,IAAM3G,EAAG,CAC9C,MAAM/K,EAAciC,EAAM8I,GAC1B,IAAK,IAAI1iB,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAS,EAAGS,EAAIuE,IAAMvE,EAAG,CACxD,MAAM0kB,EAAU/M,EAAYzV,MAAMlC,EAAGA,EAAI,GAGnCgrL,EAAc,CAClBjtI,QAASA,EACT/qC,SAAUA,EACVg+H,MAAO,CAACtuH,GACRrhB,MAAOrB,EACP0kB,QAASA,GAGXtmB,KAAK2tL,OAAOz6F,OAAO55E,GAAegN,GAAUsmK,EAC7C,CACF,CACF,CAOD,0BAAAwB,CAA2BzuI,EAAS/qC,GAClC,MAAMwlF,EAAWxlF,EAAS+a,iBAC1B,IAAK,IAAInL,EAAI,EAAGipJ,EAAKrzE,EAASj5F,OAAQqjB,EAAIipJ,IAAMjpJ,EAAG,CACjD,MAAMhJ,EAAQ4+E,EAAS51E,GACvB,IAAK,IAAIF,EAAI,EAAG2G,EAAKzP,EAAMra,OAAQmjB,EAAI2G,IAAM3G,EAAG,CAC9C,MAAM/K,EAAciC,EAAM8I,GAC1B,IAAK,IAAI1iB,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAS,EAAGS,EAAIuE,IAAMvE,EAAG,CACxD,MAAM0kB,EAAU/M,EAAYzV,MAAMlC,EAAGA,EAAI,GAGnCgrL,EAAc,CAClBjtI,QAASA,EACT/qC,SAAUA,EACVg+H,MAAO,CAACtuH,EAAGE,GACXvhB,MAAOrB,EACP0kB,QAASA,GAGXtmB,KAAK2tL,OAAOz6F,OAAO55E,GAAegN,GAAUsmK,EAC7C,CACF,CACF,CACF,CAaD,oBAAAyB,CAAqB1uI,EAAS/qC,GAC5B,MAAM2E,EAAc3E,EAAS0H,YAGvBozK,EAAoB,CACxB/vI,QAASA,EACT/qC,SAAUA,EACV3R,MA5sBsB,EA6sBtBqjB,QAAS,CAAC/M,EAAaA,IAInBo2K,EAA2B,CAC/BhwI,QAASA,EACT/qC,SAAUA,EACV3R,MA7sB6B,EA8sB7BqjB,QAAS,CAAC/M,EAAaA,IAGnBq2K,EAAkB,CAACF,EAAmBC,GAC5CD,EAAkBE,gBAAkBA,EACpCD,EAAyBC,gBAAkBA,EAC3C5vL,KAAK2tL,OAAOz6F,OAAO1jD,GAAaj2B,GAAcm2K,GAC9C,IAAIp/G,EAAc,EAGlB,MAAMvkD,EAAiBE,KACvB,GAAIF,GAAkB/rB,KAAKsgD,SAAU,CACnC,MAAMnhC,EAAanf,KAAKsgD,SAAS3C,UAAU/uB,gBAC3C0hD,EAAiBA,EACdv7D,QACAiB,UAAU+V,EAAgB5M,GAC7BmxD,EAAiB/4C,GACvB,GACQvhB,UAAUmJ,EAAY4M,EACzB,CACD/rB,KAAK2tL,OAAOz6F,OAAO5iB,EAAejxD,YAAaswK,EAChD,CAOD,gCAAArB,CAAiC3uI,EAAS/qC,GACxC,MAAM4gE,EAAa5gE,EAAS6gE,qBAC5B,IAAK,IAAI7zE,EAAI,EAAGA,EAAI4zE,EAAWr0E,SAAUS,EAAG,CAC1C,MAAMgT,EAAW4gE,EAAW5zE,IAE5BqtL,EADejvL,KAAK8tL,iBAAiBl5K,EAAS8Z,YACvCixB,EAAS/qC,EACjB,CACF,CASD,4BAAAi7K,CAA6Bt2K,EAAa4pD,EAAUqS,GAClD,IAAI80G,EAAgBtqL,KAAK+oL,eACzB,GAAKuB,EAIE,CACYA,EAAcp1K,cACtBgb,eAAe3W,EACzB,MANC+wK,EAAgB,IAAIl2K,GAAQ,IAAIof,GAAMja,IACtCvZ,KAAK+oL,eAAiBuB,EACtBtqL,KAAK2jL,SAASzmI,YAAYggD,WAAWotF,GAOvC,OAFAA,EAAcvgL,IAAI,WAAYo5D,GAC9BmnH,EAAcvgL,IAAI,aAAcyrE,GACzB80G,CACR,CAOD,WAAAlkL,CAAYyuD,GACV,IAAKA,EAAgBpM,cACnB,OAAO,EAIT,IAAIwN,EAuBJ,OAzBAj2D,KAAK8uL,kBAAoBj6H,EAItBA,EAAgB/pB,IAAI6S,UAAUhH,kBAC/Bke,EAAgB90D,MAAQipD,GAAoBK,aAC3CrpD,KAAK41D,wBAEN51D,KAAK8rD,mBAAmB+I,GAEtB70D,KAAK+oL,gBAAkB/oL,KAAKmtL,iBAAiBt4H,KAO7CoB,IALApB,EAAgB90D,MAAQipD,GAAoBC,cAC3CjpD,KAAKytL,yBAEIztL,KAAK8vL,eAMfj7H,EAAgB90D,MAAQipD,GAAoBC,cAC9CjpD,KAAKytL,wBAAyB,GAGzBxoL,MAAMmB,YAAYyuD,KAAqBoB,CAC/C,CAMD,eAAAT,CAAgB51D,GACdI,KAAKytL,wBAAyB,EAC9BztL,KAAKmvL,oBAAoBvvL,EAAKI,KAAK6tL,eAEnC,MAAMlE,EAAS,CACb/pL,EAAIwX,WAAW,GAAKpX,KAAKi1D,OAAO,GAChCr1D,EAAIwX,WAAW,GAAKpX,KAAKi1D,OAAO,IAE5BkO,EAAW,GACXqS,EAAa,GACnB,IAAK,IAAI5zE,EAAI,EAAGuE,EAAKnG,KAAK6tL,cAAc1sL,OAAQS,EAAIuE,IAAMvE,EAAG,CAC3D,MAAMmuL,EAAc/vL,KAAK6tL,cAAcjsL,GACjCgrL,EAAcmD,EAAY,GAC1BpwI,EAAUitI,EAAYjtI,QACvBwjB,EAASz9D,SAASi6C,IACrBwjB,EAASx9D,KAAKg6C,GAEhB,MAAM/qC,EAAWg4K,EAAYh4K,SACxB4gE,EAAW9vE,SAASkP,IACvB4gE,EAAW7vE,KAAKiP,GAElB,MAAMg+H,EAAQg6C,EAAYh6C,MAC1B,IAAIr5H,EACJ,MAAM+M,EAAUsmK,EAAYtmK,QACtBrjB,EAAQ8sL,EAAY,GAE1B,KAAOpG,EAAOxoL,OAASyT,EAAS4a,aAC9Bm6J,EAAOhkL,KAAK2gB,EAAQrjB,GAAO0mL,EAAOxoL,SAGpC,OAAQyT,EAAS8Z,WACf,IAAK,QACHnV,EAAcowK,EACdrjK,EAAQ,GAAKqjK,EACbrjK,EAAQ,GAAKqjK,EACb,MACF,IAAK,aACHpwK,EAAc3E,EAAS+a,iBACvBpW,EAAYqzK,EAAY3pL,OAAS0mL,EACjCrjK,EAAQ,GAAKqjK,EACbrjK,EAAQ,GAAKqjK,EACb,MACF,IAAK,aACHpwK,EAAc3E,EAAS+a,iBACvBpW,EAAYqzK,EAAY3pL,MAAQA,GAAS0mL,EACzCrjK,EAAQrjB,GAAS0mL,EACjB,MACF,IAAK,kBAKL,IAAK,UACHpwK,EAAc3E,EAAS+a,iBACvBpW,EAAYq5H,EAAM,IAAIg6C,EAAY3pL,MAAQA,GAAS0mL,EACnDrjK,EAAQrjB,GAAS0mL,EACjB,MACF,IAAK,eACHpwK,EAAc3E,EAAS+a,iBACvBpW,EAAYq5H,EAAM,IAAIA,EAAM,IAAIg6C,EAAY3pL,MAAQA,GAAS0mL,EAC7DrjK,EAAQrjB,GAAS0mL,EACjB,MACF,IAAK,SAGH,GAFArjK,EAAQ,GAAKqjK,EACbrjK,EAAQ,GAAKqjK,EAz3BK,IA03BdiD,EAAY3pL,MACdjD,KAAK4tL,kBAAmB,EACxBh5K,EAASmmC,UAAU4uI,GACnB3pL,KAAK4tL,kBAAmB,MACnB,CAEL5tL,KAAK4tL,kBAAmB,EACxB,MAAMzuK,EAAavf,EAAIkrC,IAAI6S,UAAU/uB,gBACrC,IAAI5G,EAAS6hK,GACX19J,GAAmBvX,EAAS0H,YAAa6C,GACzCgN,GAAmBw9J,EAAQxqK,IAE7B,MAAM4M,EAAiBE,KACvB,GAAIF,EAAgB,CAClB,MAAMukD,EAAiB17D,EACpBG,QACAiB,UAAU+V,EAAgB5M,GAC7BmxD,EAAe6mB,UAAUnvE,GACzBA,EAASsoD,EACNt6D,UAAUmJ,EAAY4M,GACtB5F,WACJ,CACDvR,EAASuiF,UAAUnvE,GACnBhoB,KAAK4tL,kBAAmB,CACzB,EAMDr0K,GACFvZ,KAAKgwL,wBAAwBp7K,EAAU2E,EAE1C,CACDvZ,KAAK6vL,6BAA6BlG,EAAQxmH,EAAUqS,EACrD,CAOD,eAAAjgB,CAAgB31D,GACd,IAAKI,KAAKs4D,WAAW14D,GACnB,OAAO,EAET,MAAMypL,EAAkBzpL,EAAIwX,WAC5BpX,KAAKkvL,sBAAsBtvL,EAAI09C,MAAO19C,EAAIkrC,IAAKu+I,GAC/CrpL,KAAK6tL,cAAc1sL,OAAS,EAC5BnB,KAAK0tL,uBAAyB,KAC9B,MAAMpD,EAAgBtqL,KAAK+oL,eAC3B,GAAIuB,EAAe,CACjB,MAAMnrK,EAAavf,EAAIkrC,IAAI6S,UAAU/uB,gBAC/BqhK,EAAiB,GACjBtG,EAASW,EAAcp1K,cAAcya,iBACrCugK,EAAe52K,GAAe,CAACqwK,IAC/BwG,EAAqBnwL,KAAK2tL,OAAO/2F,YAAYs5F,GAC7CE,EAAoB,CAAA,EAC1BD,EAAmB77J,KAAKm4J,IACxB,IAAK,IAAI7qL,EAAI,EAAGuE,EAAKgqL,EAAmBhvL,OAAQS,EAAIuE,IAAMvE,EAAG,CAC3D,MAAMyuL,EAAmBF,EAAmBvuL,GACtC0kB,EAAU+pK,EAAiB/pK,QACjC,IAAI6lE,EAAMzjF,EAAO2nL,EAAiBz7K,UAClC,MAAMg+H,EAAQy9C,EAAiBz9C,MAQ/B,GAPIA,IACFzmD,GAAO,IAAMymD,EAAM95H,KAAK,MAErBs3K,EAAkBjkG,KACrBikG,EAAkBjkG,GAAO,IAAI9pF,MAAM,IAIK,WAAxCguL,EAAiBz7K,SAAS8Z,WA37BD,IA47BzB2hK,EAAiBptL,MAiBnB,IACEgwC,GAAiB3sB,EAAQ,GAAIqjK,IAC5ByG,EAAkBjkG,GAAK,GAO1B,IACEl5C,GAAiB3sB,EAAQ,GAAIqjK,IAC5ByG,EAAkBjkG,GAAK,GAoCxBzjF,EAAO4d,KAAYtmB,KAAKutL,kBACvB6C,EAAkBjkG,GAAK,KACvBikG,EAAkBjkG,GAAK,IACxBnsF,KAAKqtL,uBAAuBztL,IAE5BqwL,EAAetqL,KAAK0qL,OA3CtB,CAIE,GACED,EAAkBjkG,GAAK,IACa,IAApCikG,EAAkBjkG,GAAK,GAAGlpF,MAC1B,CACA,IAAIsW,EAAc82K,EAAiBz7K,SAAS+a,iBAC5C,OAAQ0gK,EAAiBz7K,SAAS8Z,WAEhC,IAAK,aACL,IAAK,kBACH,SAGF,IAAK,eACHnV,EAAcA,EAAYq5H,EAAM,IAElC,IAAK,UACH,GACEy9C,EAAiBptL,QACjBsW,EAAYq5H,EAAM,IAAIzxI,OAAS,EAE/B,SAMP,CAEDnB,KAAK6tL,cAAcloL,KAAK,CAAC0qL,EAAkB,IAC3CD,EAAkBjkG,GAAK,GAAKkkG,CAE7B,MAxCCrwL,KAAK6tL,cAAcloL,KAAK,CAAC0qL,EAAkB,IAC3CD,EAAkBjkG,GAAK,GAAKkkG,MAxB9B,CAUIp9I,GANoB85I,GACpB1D,EACAgH,EACAlxK,GAGgCwqK,KAC/ByG,EAAkBjkG,GAAK,KAExBnsF,KAAK6tL,cAAcloL,KAAK,CAAC0qL,EAAkB,IAC3CD,EAAkBjkG,GAAK,GAAKkkG,EAG/B,CAwDF,CAEGJ,EAAe9uL,QACjBnB,KAAKmvL,oBAAoBvvL,EAAK,CAACqwL,IAGjC,IAAK,IAAI3rK,EAAI2rK,EAAe9uL,OAAS,EAAGmjB,GAAK,IAAKA,EAChDtkB,KAAKswL,cAAcL,EAAe3rK,GAAIqlK,EAEzC,CACD,QAAS3pL,KAAK+oL,cACf,CAOD,aAAArzH,CAAc91D,GACZ,IAAK,IAAIgC,EAAI5B,KAAK6tL,cAAc1sL,OAAS,EAAGS,GAAK,IAAKA,EAAG,CACvD,MAAMgrL,EAAc5sL,KAAK6tL,cAAcjsL,GAAG,GACpCgT,EAAWg4K,EAAYh4K,SAC7B,GAA2B,WAAvBA,EAAS8Z,UAAwB,CAEnC,MAAMnV,EAAc3E,EAAS0H,YACvBozK,EAAoB9C,EAAYgD,gBAAgB,GAChDD,EAA2B/C,EAAYgD,gBAAgB,GAC7DF,EAAkBppK,QAAQ,GAAK/M,EAC/Bm2K,EAAkBppK,QAAQ,GAAK/M,EAC/Bo2K,EAAyBrpK,QAAQ,GAAK/M,EACtCo2K,EAAyBrpK,QAAQ,GAAK/M,EACtCvZ,KAAK2tL,OAAO7vJ,OAAO0R,GAAaj2B,GAAcm2K,GAC9C,IAAIp/G,EAAiB17D,EACrB,MAAMmX,EAAiBE,KACvB,GAAIF,EAAgB,CAClB,MAAM5M,EAAavf,EAAIkrC,IAAI6S,UAAU/uB,gBACrC0hD,EAAiBA,EACdv7D,QACAiB,UAAU+V,EAAgB5M,GAC7BmxD,EAAiB/4C,GAAW+4C,GAAgBt6D,UAC1CmJ,EACA4M,EAEH,CACD/rB,KAAK2tL,OAAO7vJ,OACVwyC,EAAejxD,YACfswK,EAEV,MACQ3vL,KAAK2tL,OAAO7vJ,OAAOxkB,GAAeszK,EAAYtmK,SAAUsmK,EAE3D,CAWD,OAVI5sL,KAAK0tL,yBACP1tL,KAAK4F,cACH,IAAI4mL,GACFD,GACAvsL,KAAK0tL,uBACL9tL,IAGJI,KAAK0tL,uBAAyB,OAEzB,CACR,CAMD,kBAAA5hI,CAAmBlsD,GACjBI,KAAKwtL,WAAa5tL,EAAI09C,MACtBt9C,KAAKkvL,sBAAsBtvL,EAAI09C,MAAO19C,EAAIkrC,IAAKlrC,EAAIwX,WACpD,CAQD,qBAAA83K,CAAsB5xI,EAAOxS,EAAK1zB,GAChC,MAAMiyK,EAAkBjyK,GAAc0zB,EAAIie,uBAAuBzL,GAC3Dn+B,EAAa2rB,EAAI6S,UAAU/uB,gBAC3B06J,EAAiB,SAAUjoL,EAAGC,GAClC,OACEorL,GAAsCrD,EAAiBhoL,EAAG8d,GAC1DutK,GAAsCrD,EAAiB/nL,EAAG6d,EAElE,EAGI,IAAIoxK,EAEAC,EACJ,GAAIxwL,KAAKuuL,cAAe,CACtB,MAAM9uI,EAC0B,iBAAvBz/C,KAAKuuL,cACP3gJ,GAAUA,IAAU5tC,KAAKuuL,mBAC1B/nL,EACNskC,EAAIm4B,sBACF3lB,GACA,CAACqC,EAAS/R,EAAOh5B,KACXA,GAAmC,UAAvBA,EAAS8Z,YACvB9Z,EAAW,IAAI4e,GACbtH,GAAiBtX,EAAS+a,iBAAkBxQ,KAGhD,MAAM05J,EAAOjkK,GAAY+qC,EAAQzqC,cACjC,GACEyqC,aAAmBvrC,IACnBpU,KAAKgtE,UAAU3hE,WAAW3F,SAASi6C,GACnC,CACA6wI,EAAgB,EAChB,MAAMp5K,EAAmCuoC,EAAQzqC,cAC9Cqa,qBACAzrB,MAAM,EAAG,GACZysL,EAAQ,CACN,CACE5wI,UACA/qC,SAAU47K,EACVlqK,QAAS,CAAClP,EAAYA,IAG3B,CACD,OAAO,CAAI,GAEb,CAACqoC,eAEJ,CACD,IAAK8wI,EAAO,CACV,MAKMznH,EAAMz8C,GACVgvF,GANiB/uF,GACjBkjB,GAAa65I,EAAiB7iG,IAC9BrnE,GAEa2rB,EAAI6S,UAAUjiB,gBAAkB17B,KAAK2oL,gBAEjBniG,IACjCrnE,GAEFoxK,EAAQvwL,KAAK2tL,OAAO/2F,YAAY9tB,EACjC,CAED,GAAIynH,GAASA,EAAMpvL,OAAS,EAAG,CAC7B,MAAMoQ,EAAOg/K,EAAMj8J,KAAKg1J,GAAgB,GAClCI,EAAiBn4K,EAAK+U,QAC5B,IAAIqjK,EAASoD,GAAqB1D,EAAiB93K,EAAM4N,GACzD,MAAMyqK,EAAc9+I,EAAIu5B,uBAAuBslH,GAC/C,IAAIO,EAAOL,GAAmBvsI,EAAOssI,GACrC,GAAI4G,GAAoBtG,GAAQlqL,KAAK2oL,gBAAiB,CAEpD,MAAM8H,EAAiB,CAAA,EAOvB,GANAA,EAAe/nL,EAAOghL,KAAmB,EAEpC1pL,KAAK+uL,iBACR/uL,KAAKi1D,OAAO,GAAK00H,EAAO,GAAKN,EAAgB,GAC7CrpL,KAAKi1D,OAAO,GAAK00H,EAAO,GAAKN,EAAgB,IAGjB,WAA5B93K,EAAKqD,SAAS8Z,WAjqCW,IAkqCzBnd,EAAKtO,MAELjD,KAAK6oL,kBAAmB,EACxB7oL,KAAK6vL,6BACHlG,EACA,CAACp4K,EAAKouC,SACN,CAACpuC,EAAKqD,eAEH,CACL,MAAMk1K,EAASh/I,EAAIu5B,uBAAuBqlH,EAAe,IACnDK,EAASj/I,EAAIu5B,uBAAuBqlH,EAAe,IACnDM,EAAehH,GAA0B4G,EAAaE,GACtDG,EAAejH,GAA0B4G,EAAaG,GAC5DG,EAAOj+K,KAAKma,KAAKna,KAAKwP,IAAIuuK,EAAcC,IACxCjqL,KAAK6oL,iBAAmBqB,GAAQlqL,KAAK2oL,gBACjC3oL,KAAK6oL,mBACPc,EACEK,EAAeC,EACXP,EAAe,GACfA,EAAe,IAEvB1pL,KAAK6vL,6BACHlG,EACA,CAACp4K,EAAKouC,SACN,CAACpuC,EAAKqD,WAER,MAAM4gE,EAAa,CAAA,EACnBA,EAAW9sE,EAAO6I,EAAKqD,YAAa,EACpC,IAAK,IAAIhT,EAAI,EAAGuE,EAAKoqL,EAAMpvL,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAM0kB,EAAUiqK,EAAM3uL,GAAG0kB,QACzB,KACG2sB,GAAiBy2I,EAAe,GAAIpjK,EAAQ,KAC3C2sB,GAAiBy2I,EAAe,GAAIpjK,EAAQ,KAC7C2sB,GAAiBy2I,EAAe,GAAIpjK,EAAQ,KAC3C2sB,GAAiBy2I,EAAe,GAAIpjK,EAAQ,KAQ9C,MAPA,CACA,MAAMoqK,EAAchoL,EAAO6nL,EAAM3uL,GAAGgT,UAC9B87K,KAAel7G,IACnBA,EAAWk7G,IAAe,EAC1BD,EAAe/nL,EAAO4d,KAAY,EAElD,CAGW,CACF,CAGD,YADAtmB,KAAKutL,gBAAkBkD,EAExB,CACF,CACGzwL,KAAK+oL,iBACP/oL,KAAK2jL,SAASzmI,YAAY2gD,cAAc79F,KAAK+oL,gBAC7C/oL,KAAK+oL,eAAiB,KAEzB,CAOD,aAAAuH,CAAc1D,EAAajD,GACzB,MAAMrjK,EAAUsmK,EAAYtmK,QACtBq5B,EAAUitI,EAAYjtI,QACtB/qC,EAAWg4K,EAAYh4K,SACvBg+H,EAAQg6C,EAAYh6C,MACpB3vI,EAAQ2pL,EAAY3pL,MAC1B,IAAIsW,EAEJ,KAAOowK,EAAOxoL,OAASyT,EAAS4a,aAC9Bm6J,EAAOhkL,KAAK,GAGd,OAAQiP,EAAS8Z,WACf,IAAK,kBAIL,IAAK,UACHnV,EAAc3E,EAAS+a,iBACvBpW,EAAYq5H,EAAM,IAAI/rI,OAAO5D,EAAQ,EAAG,EAAG0mL,GAC3C,MACF,IAAK,eACHpwK,EAAc3E,EAAS+a,iBACvBpW,EAAYq5H,EAAM,IAAIA,EAAM,IAAI/rI,OAAO5D,EAAQ,EAAG,EAAG0mL,GACrD,MACF,IAAK,aACHpwK,EAAc3E,EAAS+a,iBACvBpW,EAAY1S,OAAO5D,EAAQ,EAAG,EAAG0mL,GACjC,MACF,QACE,OAGJ3pL,KAAKgwL,wBAAwBp7K,EAAU2E,GACvC,MAAMo3K,EAAQ3wL,KAAK2tL,OACnBgD,EAAMjlL,OAAOkhL,GACb5sL,KAAK4wL,sBAAsBh8K,EAAU3R,EAAO2vI,EAAO,GAGnD,MAAMi+C,EAAiB,CACrBvqK,QAAS,CAACA,EAAQ,GAAIqjK,GACtBhqI,QAASA,EACT/qC,SAAUA,EACVg+H,MAAOA,EACP3vI,MAAOA,GAGT0tL,EAAMz9F,OAAO55E,GAAeu3K,EAAevqK,SAAUuqK,GACrD7wL,KAAK6tL,cAAcloL,KAAK,CAACkrL,EAAgB,IAGzC,MAAMC,EAAkB,CACtBxqK,QAAS,CAACqjK,EAAQrjK,EAAQ,IAC1Bq5B,QAASA,EACT/qC,SAAUA,EACVg+H,MAAOA,EACP3vI,MAAOA,EAAQ,GAGjB0tL,EAAMz9F,OAAO55E,GAAew3K,EAAgBxqK,SAAUwqK,GACtD9wL,KAAK6tL,cAAcloL,KAAK,CAACmrL,EAAiB,IAC1C9wL,KAAKytL,wBAAyB,CAC/B,CAOD,WAAAqC,GACE,GACE9vL,KAAK8uL,mBACL9uL,KAAK8uL,kBAAkB/uL,MAAQipD,GAAoBI,YACnD,CACA,MAAMxpD,EAAMI,KAAK8uL,kBACjB9uL,KAAKmvL,oBAAoBvvL,EAAKI,KAAK6tL,eACnC,MAAMjuF,EAAU5/F,KAAK+wL,gBAYrB,OAXI/wL,KAAK0tL,wBACP1tL,KAAK4F,cACH,IAAI4mL,GACFD,GACAvsL,KAAK0tL,uBACL9tL,IAKNI,KAAK0tL,uBAAyB,KACvB9tF,CACR,CACD,OAAO,CACR,CAOD,aAAAmxF,GACE,MAAMC,EAAehxL,KAAK6tL,cACpBoD,EAAoB,CAAA,EAC1B,IACIC,EAAW33K,EAAaw2K,EAAan7K,EAAUhT,EAAGqB,EAAOshD,EACzD4sI,EAAU57J,EAAOq3J,EAAazgG,EAF9BilG,GAAU,EAGd,IAAKxvL,EAAIovL,EAAa7vL,OAAS,EAAGS,GAAK,IAAKA,EAC1CmuL,EAAciB,EAAapvL,GAC3BgrL,EAAcmD,EAAY,GAC1B5jG,EAAMzjF,EAAOkkL,EAAYjtI,SACrBitI,EAAYh6C,QAEdzmD,GAAO,IAAMygG,EAAYh6C,MAAM95H,KAAK,MAEhCqzE,KAAO8kG,IACXA,EAAkB9kG,GAAO,IAEJ,IAAnB4jG,EAAY,IACdkB,EAAkB9kG,GAAK52D,MAAQq3J,EAC/BqE,EAAkB9kG,GAAKlpF,MAAQ2pL,EAAY3pL,OAChB,GAAlB8sL,EAAY,KACrBkB,EAAkB9kG,GAAK5nC,KAAOqoI,EAC9BqE,EAAkB9kG,GAAKlpF,MAAQ2pL,EAAY3pL,MAAQ,GAGvD,IAAKkpF,KAAO8kG,EAAmB,CAiB7B,OAhBA17J,EAAQ07J,EAAkB9kG,GAAK52D,MAC/BgvB,EAAO0sI,EAAkB9kG,GAAK5nC,KAC9BthD,EAAQguL,EAAkB9kG,GAAKlpF,MAC/BkuL,EAAWluL,EAAQ,EAEjB2pL,OADWpmL,IAAT+9C,EACYA,EAEAhvB,EAEZ47J,EAAW,IACbA,EAAW,GAEbv8K,EAAWg4K,EAAYh4K,SACvB2E,EAAc3E,EAAS+a,iBACvBuhK,EAAY33K,EACZ63K,GAAU,EACFx8K,EAAS8Z,WACf,IAAK,kBACCnV,EAAYqzK,EAAYh6C,MAAM,IAAIzxI,OAAS,IAC7CoY,EAAYqzK,EAAYh6C,MAAM,IAAI/rI,OAAO5D,EAAO,GAChDmuL,GAAU,GAEZ,MACF,IAAK,aACC73K,EAAYpY,OAAS,IACvBoY,EAAY1S,OAAO5D,EAAO,GAC1BmuL,GAAU,GAEZ,MACF,IAAK,eACHF,EAAYA,EAAUtE,EAAYh6C,MAAM,IAE1C,IAAK,UACHs+C,EAAYA,EAAUtE,EAAYh6C,MAAM,IACpCs+C,EAAU/vL,OAAS,IACjB8B,GAASiuL,EAAU/vL,OAAS,IAC9B8B,EAAQ,GAEViuL,EAAUrqL,OAAO5D,EAAO,GACxBmuL,GAAU,EACI,IAAVnuL,IAEFiuL,EAAUhmL,MACVgmL,EAAUvrL,KAAKurL,EAAU,IACzBC,EAAWD,EAAU/vL,OAAS,IAQtC,GAAIiwL,EAAS,CACXpxL,KAAKgwL,wBAAwBp7K,EAAU2E,GACvC,MAAMiwK,EAAW,GASjB,QARahjL,IAAT+9C,IACFvkD,KAAK2tL,OAAOjiL,OAAO64C,GACnBilI,EAAS7jL,KAAK4+C,EAAKj+B,QAAQ,UAEf9f,IAAV+uB,IACFv1B,KAAK2tL,OAAOjiL,OAAO6pB,GACnBi0J,EAAS7jL,KAAK4vB,EAAMjP,QAAQ,UAEjB9f,IAAT+9C,QAAgC/9C,IAAV+uB,EAAqB,CAE7C,MAAMs7J,EAAiB,CACrBj+C,MAAOg6C,EAAYh6C,MACnBjzF,QAASitI,EAAYjtI,QACrB/qC,SAAUg4K,EAAYh4K,SACtB3R,MAAOkuL,EACP7qK,QAASkjK,GAGXxpL,KAAK2tL,OAAOz6F,OACV55E,GAAeu3K,EAAevqK,SAC9BuqK,EAEH,CACD7wL,KAAK4wL,sBAAsBh8K,EAAU3R,EAAO2pL,EAAYh6C,OAAQ,GAC5D5yI,KAAK+oL,iBACP/oL,KAAK2jL,SAASzmI,YAAY2gD,cAAc79F,KAAK+oL,gBAC7C/oL,KAAK+oL,eAAiB,MAExBiI,EAAa7vL,OAAS,CACvB,CACF,CACD,OAAOiwL,CACR,CAOD,uBAAApB,CAAwBp7K,EAAU2E,GAChCvZ,KAAK4tL,kBAAmB,EACxBh5K,EAASsb,eAAe3W,GACxBvZ,KAAK4tL,kBAAmB,CACzB,CASD,qBAAAgD,CAAsBh8K,EAAU3R,EAAO2vI,EAAOjlI,GAC5C3N,KAAK2tL,OAAO72F,gBACVliF,EAASyK,aACT,SAAUgxK,GAENA,EAAiBz7K,WAAaA,SACnBpO,IAAVosI,QAC4BpsI,IAA3B6pL,EAAiBz9C,OACjBrwI,EAAO8tL,EAAiBz9C,MAAOA,KACjCy9C,EAAiBptL,MAAQA,IAEzBotL,EAAiBptL,OAAS0K,EAE7B,GAEJ,GC5/CH,MAAM0jL,GAMI,SAsEH,MAAMC,WAAoBvrL,EAQ/B,WAAAjG,CAAYC,EAAMwxL,EAAUC,EAAY38H,GACtC5vD,MAAMlF,GAONC,KAAKuxL,SAAWA,EAOhBvxL,KAAKwxL,WAAaA,EAOlBxxL,KAAK60D,gBAAkBA,CACxB,EAOH,MAAM48H,GAAwB,CAAA,EAyB9B,MAAMC,WAAe18H,GAInB,WAAAl1D,CAAY6K,GA0FV,IAAI80C,EACJ,GA1FAx6C,QAKAjF,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAELgD,EAAUA,GAAoB,GAK9B3K,KAAK2xL,iBAAmB3xL,KAAK2uL,YAAYznL,KAAKlH,MAK9CA,KAAK4xL,oBAAsB5xL,KAAKqvL,eAAenoL,KAAKlH,MAMpDA,KAAKs4D,WAAa3tD,EAAQ0tD,UAAY1tD,EAAQ0tD,UAAYlB,GAM1Dn3D,KAAK6xL,cAAgBlnL,EAAQmnL,aAAennL,EAAQmnL,aAAe56H,GAMnEl3D,KAAK+xL,iBAAmBpnL,EAAQqnL,gBAC5BrnL,EAAQqnL,gBACR96H,GAMJl3D,KAAKiyL,iBAAmBtnL,EAAQunL,gBAC5BvnL,EAAQunL,gBACR56H,GAMJt3D,KAAKmyL,SAASxnL,EAAQynL,OAAQznL,EAAQynL,MAMtCpyL,KAAKqyL,QAAU1nL,EAAQ8sC,OAAS9sC,EAAQ8sC,OAASt0C,EAMjDnD,KAAKsyL,cAAgB3nL,EAAQ40C,aAAe50C,EAAQ40C,aAAe,EAMnEv/C,KAAKwU,YACehO,IAAlBmE,EAAQ4F,MAAsB5F,EAAQ4F,MA6U5C,WACE,MAAMoF,EAAS6zI,KAIf,OAHAtnJ,EAAOyT,EAAgB,QAAGA,EAAmB,YAC7CzT,EAAOyT,EAA2B,mBAAGA,EAAmB,YAEjD,SAAUgqC,GACf,OAAKA,EAAQzqC,cAGNS,EAAOgqC,EAAQzqC,cAAcwZ,WAF3B,IAGb,CACA,CAxVoD+yJ,GAMhDzhL,KAAKgtE,UAAYriE,EAAQw4D,UAAY,IAAI34D,EAIrCG,EAAQo8C,OACV,GAA8B,mBAAnBp8C,EAAQo8C,OACjBtH,EAAc90C,EAAQo8C,WACjB,CACL,MAAMA,EAASp8C,EAAQo8C,OACvBtH,EAAc,SAAU7R,GACtB,OAAOmZ,EAAOrhD,SAASkoC,EACjC,CACO,MAED6R,EAAct8C,EAOhBnD,KAAKuyL,aAAe9yI,EAQpBz/C,KAAKwyL,yBAA2B,EACjC,CAOD,2BAAAC,CAA4B9yI,EAAS/R,GACnC5tC,KAAKwyL,yBAAyB9pL,EAAOi3C,IAAY/R,CAClD,CAOD,WAAAyP,GACE,OAAOr9C,KAAKgtE,SACb,CAOD,eAAA0lH,GACE,OAAO1yL,KAAKsyL,aACb,CASD,QAAA31E,CAASh9D,GACP,OACE3/C,KAAKwyL,yBAAyB9pL,EAAOi3C,GAExC,CAQD,eAAAgzI,CAAgBpzI,GACdv/C,KAAKsyL,cAAgB/yI,CACtB,CAQD,MAAAxC,CAAOjS,GACc9qC,KAAKsgD,UACNtgD,KAAKwU,QACrBxU,KAAKgtE,UAAU7hE,QAAQnL,KAAK4yL,sBAAsB1rL,KAAKlH,OAEzDiF,MAAM83C,OAAOjS,GACTA,GACF9qC,KAAKgtE,UAAU1nE,iBACb8E,EACApK,KAAK2xL,kBAEP3xL,KAAKgtE,UAAU1nE,iBACb8E,EACApK,KAAK4xL,qBAGH5xL,KAAKwU,QACPxU,KAAKgtE,UAAU7hE,QAAQnL,KAAK6yL,oBAAoB3rL,KAAKlH,SAGvDA,KAAKgtE,UAAU1mE,oBACb8D,EACApK,KAAK2xL,kBAEP3xL,KAAKgtE,UAAU1mE,oBACb8D,EACApK,KAAK4xL,qBAGV,CAMD,WAAAjD,CAAY/uL,GACV,MAAM+/C,EAAU//C,EAAI2K,QAIpB,GAHIvK,KAAKwU,QACPxU,KAAK6yL,oBAAoBlzI,IAEtB3/C,KAAK28G,SAASh9D,GAAU,CAC3B,MAAM/R,EACJ5tC,KAAKsgD,SACFsR,eACA7T,MAAK,SAAUnQ,GACd,GACEA,aAAiBunI,IACjBvnI,EAAMsP,aACNtP,EAAMsP,YAAYmiD,WAAW1/C,GAE7B,OAAO/R,CAErB,IAEUA,GACF5tC,KAAKyyL,4BAA4B9yI,EAAS/R,EAE7C,CACF,CAMD,cAAAyhJ,CAAezvL,GACTI,KAAKwU,QACPxU,KAAK4yL,sBAAsBhzL,EAAI2K,QAElC,CAKD,QAAA4K,GACE,OAAOnV,KAAKwU,MACb,CAMD,mBAAAq+K,CAAoBlzI,GAClB,MAAMp4C,EAAMmB,EAAOi3C,GACbp4C,KAAOkqL,KACXA,GAAsBlqL,GAAOo4C,EAAQxqC,YAEvCwqC,EAAQvqC,SAASpV,KAAKwU,OACvB,CAMD,qBAAAo+K,CAAsBjzI,GACpB,MAAM+d,EAAe19D,KAAKsgD,SAASoiB,kBAAkBr3D,WACrD,IAAK,IAAIzJ,EAAI87D,EAAav8D,OAAS,EAAGS,GAAK,IAAKA,EAAG,CACjD,MAAM0gE,EAAc5E,EAAa97D,GACjC,GACE0gE,IAAgBtiE,MAChBsiE,aAAuBovH,IACvBpvH,EAAYntD,aACmD,IAA/DmtD,EAAYjlB,cAAchyC,WAAWu/D,YAAYjrB,GAGjD,YADAA,EAAQvqC,SAASktD,EAAYntD,WAGhC,CAED,MAAM5N,EAAMmB,EAAOi3C,GACnBA,EAAQvqC,SAASq8K,GAAsBlqL,WAChCkqL,GAAsBlqL,EAC9B,CAMD,8BAAAurL,CAA+BnzI,UACtB3/C,KAAKwyL,yBAAyB9pL,EAAOi3C,GAC7C,CAQD,WAAAv5C,CAAYyuD,GACV,IAAK70D,KAAKs4D,WAAWzD,GACnB,OAAO,EAET,MAAMpxC,EAAMzjB,KAAK6xL,cAAch9H,GACzBnpD,EAAS1L,KAAK+xL,iBAAiBl9H,GAC/B1C,EAASnyD,KAAKiyL,iBAAiBp9H,GAC/B9qD,GAAO0Z,IAAQ/X,IAAWymD,EAC1BrnB,EAAM+pB,EAAgB/pB,IACtBq4B,EAAWnjE,KAAKq9C,cAKhBm0I,EAAa,GAKbD,EAAW,GAEjB,GAAIxnL,EAAK,CAIPpF,EAAM3E,KAAKwyL,0BACX1nJ,EAAIm4B,sBACFpO,EAAgBvX,OAMhB,CAACqC,EAAS/R,KACR,GAAM+R,aAAmBvrC,IAAapU,KAAKqyL,QAAQ1yI,EAAS/R,GAK5D,OAFA5tC,KAAKyyL,4BAA4B9yI,EAAS/R,GAC1C2jJ,EAAS5rL,KAAKg6C,IACN3/C,KAAKmyL,MAAM,GAErB,CACE1yI,YAAaz/C,KAAKuyL,aAClBhzI,aAAcv/C,KAAKsyL,gBAGvB,IAAK,IAAI1wL,EAAIuhE,EAASl4D,YAAc,EAAGrJ,GAAK,IAAKA,EAAG,CAClD,MAAM+9C,EAAUwjB,EAAS73D,KAAK1J,GACxBqB,EAAQsuL,EAAS3qL,QAAQ+4C,GAC3B18C,GAAS,EAEXsuL,EAAS1qL,OAAO5D,EAAO,IAEvBkgE,EAASz3D,OAAOi0C,GAChB6xI,EAAW7rL,KAAKg6C,GAEnB,CACuB,IAApB4xI,EAASpwL,QACXgiE,EAASjhE,OAAOqvL,EAExB,KAAW,CAELzmJ,EAAIm4B,sBACFpO,EAAgBvX,OAMhB,CAACqC,EAAS/R,KACR,GAAM+R,aAAmBvrC,IAAapU,KAAKqyL,QAAQ1yI,EAAS/R,GAa5D,OAVKnqB,IAAO0uC,GAAYgR,EAAS93D,WAAW3F,SAASi6C,IAIlDj0C,GAAUymD,IACXgR,EAAS93D,WAAW3F,SAASi6C,KAE7B6xI,EAAW7rL,KAAKg6C,GAChB3/C,KAAK8yL,+BAA+BnzI,KAPpC3/C,KAAKyyL,4BAA4B9yI,EAAS/R,GAC1C2jJ,EAAS5rL,KAAKg6C,KAQR3/C,KAAKmyL,MAAM,GAErB,CACE1yI,YAAaz/C,KAAKuyL,aAClBhzI,aAAcv/C,KAAKsyL,gBAGvB,IAAK,IAAIhuK,EAAIktK,EAAWrwL,OAAS,EAAGmjB,GAAK,IAAKA,EAC5C6+C,EAASz3D,OAAO8lL,EAAWltK,IAE7B6+C,EAASjhE,OAAOqvL,EACjB,CAWD,OAVIA,EAASpwL,OAAS,GAAKqwL,EAAWrwL,OAAS,IAC7CnB,KAAK4F,cACH,IAAI0rL,GACFD,GACAE,EACAC,EACA38H,KAIC,CACR,EAmBH,IAAAk+H,GAAerB,GCrkBR,MAAMsB,GAML,OAOD,MAAMC,WAAkBltL,EAQ7B,WAAAjG,CAAYC,EAAM4K,GAChB1F,MAAMlF,GAMNC,KAAK2pL,OAASh/K,EAAQg/K,OAMtB3pL,KAAK4pL,YAAcj/K,EAAQi/K,YAM3B5pL,KAAK2/C,QAAUh1C,EAAQg1C,OACxB,ECIH,SAASuzI,GAAoBtzL,GAC3B,OACiE,EAAM+/C,QAEC,EACnEA,QAGwF,EAEzFp1C,QAEgG,EAEhGA,QAEG,IACT,CAEA,MAAM+hL,GAAc,GA2mBpB,IAAA6G,GAvkBA,cAAmBp7H,GAIjB,WAAAj4D,CAAY6K,GAGV,MAAMkyD,EAFNlyD,EAAUA,GAAoB,GAMzBkyD,EAAetH,kBAClBsH,EAAetH,gBAAkBpyD,GAG9B05D,EAAelH,WAClBkH,EAAelH,SAAWvyD,GAG5B6B,MAAM43D,GAKN78D,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAML3H,KAAKm/K,QAAUx0K,EAAQT,OAASS,EAAQT,OAAS,KAMjDlK,KAAKozL,aAA6B5sL,IAAnBmE,EAAQg/K,QAAuBh/K,EAAQg/K,OAMtD3pL,KAAKqzL,WAAyB7sL,IAAjBmE,EAAQ0qB,MAAqB1qB,EAAQ0qB,KAMlDr1B,KAAKgtE,UAAYriE,EAAQw4D,SAAWx4D,EAAQw4D,SAAW,KAMvDnjE,KAAKszL,sBAAwB,GAM7BtzL,KAAKuzL,2BAA6B,GAQlCvzL,KAAKwzL,wBAA0B,GAS/BxzL,KAAKyzL,iBAAmB,GAMxBzzL,KAAK2oL,qBACwBniL,IAA3BmE,EAAQi+K,eAA+Bj+K,EAAQi+K,eAAiB,GAOlE5oL,KAAK2tL,OAAS,IAAInxF,GAOlBx8F,KAAK0zL,qBAAuB,CAC1BlgK,MAASxzB,KAAK2zL,sBAAsBzsL,KAAKlH,MACzC66E,WAAc76E,KAAK4zL,2BAA2B1sL,KAAKlH,MACnDkzB,WAAclzB,KAAK4zL,2BAA2B1sL,KAAKlH,MACnDi2B,QAAWj2B,KAAK6zL,wBAAwB3sL,KAAKlH,MAC7Cg7E,WAAch7E,KAAK8zL,2BAA2B5sL,KAAKlH,MACnDi7E,gBAAmBj7E,KAAK+zL,gCAAgC7sL,KAAKlH,MAC7Dk7E,aAAgBl7E,KAAKg0L,6BAA6B9sL,KAAKlH,MACvDm7E,mBAAsBn7E,KAAKi0L,mCAAmC/sL,KAAKlH,MACnEs7E,OAAUt7E,KAAKk0L,uBAAuBhtL,KAAKlH,MAE9C,CASD,UAAAk9F,CAAWv9C,EAASszH,GAClBA,OAAwBzsK,IAAbysK,GAAyBA,EACpC,MAAMkhB,EAAczrL,EAAOi3C,GACrB/qC,EAAW+qC,EAAQzqC,cACzB,GAAIN,EAAU,CACZ,MAAMw/K,EAAYp0L,KAAK0zL,qBAAqB9+K,EAAS8Z,WACrD,GAAI0lK,EAAW,CACbp0L,KAAKwzL,wBAAwBW,GAAev/K,EAASyK,UvQ/CpD,CAAC5E,IAAUA,KAAU,KAAW,MuQkDjC,MAAM+uK,EACgE,GAEtE,GADA4K,EAAU5K,EAAU50K,GACI,IAApB40K,EAASroL,OACXnB,KAAK2tL,OAAOz6F,OAAO55E,GAAekwK,EAAS,IAAK,CAC9C7pI,QAASA,EACTr5B,QAASkjK,EAAS,UAEf,GAAIA,EAASroL,OAAS,EAAG,CAC9B,MAAMu1F,EAAU8yF,EAAS1+I,KAAKf,GAAMzwB,GAAeywB,KAC7CsqJ,EAAe7K,EAAS1+I,KAAKxkB,IAAa,CAC9Cq5B,QAASA,EACTr5B,QAASA,MAEXtmB,KAAK2tL,OAAOrgL,KAAKopF,EAAS29F,EAC3B,CACF,CACF,CAEGphB,IACFjzK,KAAKuzL,2BAA2BY,GAAeptL,EAC7C44C,EACA73C,EACA9H,KAAKu9F,qBACLv9F,MAGL,CAMD,YAAAs0L,GAEE,IAAInxH,EAMJ,OALInjE,KAAKgtE,UACP7J,EAAWnjE,KAAKgtE,UACPhtE,KAAKm/K,UACdh8G,EAAWnjE,KAAKm/K,QAAQ9hI,eAEnB8lB,CACR,CAOD,WAAA/8D,CAAYxG,GACV,MAAM6wC,EAASzwC,KAAKu0L,OAAO30L,EAAI09C,MAAO19C,EAAIwX,WAAYxX,EAAIkrC,KAY1D,OAXI2F,IACF7wC,EAAIwX,WAAaq5B,EAAOk5I,OAAO7lL,MAAM,EAAG,GACxClE,EAAI09C,MAAQ7M,EAAOm5I,YACnB5pL,KAAK4F,cACH,IAAIqtL,GAAUD,GAAoB,CAChCrJ,OAAQ/pL,EAAIwX,WACZwyK,YAAahqL,EAAI09C,MACjBqC,QAASlP,EAAOkP,YAIf16C,MAAMmB,YAAYxG,EAC1B,CAMD,iBAAAgvL,CAAkBhvL,GAChB,MAAM+/C,EAAUuzI,GAAoBtzL,GAChC+/C,GACF3/C,KAAKk9F,WAAWv9C,EAEnB,CAMD,oBAAAkvI,CAAqBjvL,GACnB,MAAM+/C,EAAUuzI,GAAoBtzL,GAChC+/C,GACF3/C,KAAK69F,cAAcl+C,EAEtB,CAMD,oBAAA49C,CAAqB39F,GACnB,MAAM+/C,EAA0D//C,EAAU,OAC1E,GAAII,KAAK41D,uBAAwB,CAC/B,MAAMu2B,EAAMzjF,EAAOi3C,GACbwsC,KAAOnsF,KAAKyzL,mBAChBzzL,KAAKyzL,iBAAiBtnG,GAAOxsC,EAErC,MACM3/C,KAAKw0L,eAAe70I,EAEvB,CAOD,aAAA+V,CAAc91D,GACZ,MAAM60L,EAAmB/tL,OAAOuC,OAAOjJ,KAAKyzL,kBAK5C,OAJIgB,EAAiBtzL,SACnBszL,EAAiBtpL,QAAQnL,KAAKw0L,eAAettL,KAAKlH,OAClDA,KAAKyzL,iBAAmB,KAEnB,CACR,CASD,aAAA51F,CAAcl+C,EAAS5kB,GACrB,MAAM25J,OAA0BluL,IAAbu0B,GAAyBA,EACtCo5J,EAAczrL,EAAOi3C,GACrBnmC,EAASxZ,KAAKwzL,wBAAwBW,GAC5C,GAAI36K,EAAQ,CACV,MAAM+1K,EAAQvvL,KAAK2tL,OACb6B,EAAgB,GACtBD,EAAMz4F,gBAAgBt9E,GAAQ,SAAUjI,GAClCouC,IAAYpuC,EAAKouC,SACnB6vI,EAAc7pL,KAAK4L,EAE7B,IACM,IAAK,IAAI3P,EAAI4tL,EAAcruL,OAAS,EAAGS,GAAK,IAAKA,EAC/C2tL,EAAM7jL,OAAO8jL,EAAc5tL,GAE9B,CAEG8yL,IACFptL,EAActH,KAAKuzL,2BAA2BY,WACvCn0L,KAAKuzL,2BAA2BY,GAE1C,CAQD,MAAAp3I,CAAOjS,GACL,MAAM6pJ,EAAa30L,KAAKsgD,SAClB35C,EAAO3G,KAAKszL,sBACZnwH,EACJnjE,KAAKs0L,eAGHK,IACFhuL,EAAKwE,QAAQ7D,GACbX,EAAKxF,OAAS,EACdnB,KAAK2tL,OAAOhpL,QACZ+B,OAAOuC,OAAOjJ,KAAKuzL,4BAA4BpoL,QAAQ7D,GACvDtH,KAAKuzL,2BAA6B,IAEpCtuL,MAAM83C,OAAOjS,GAETA,IACE9qC,KAAKgtE,UACPrmE,EAAKhB,KACHoB,EACE/G,KAAKgtE,UACL5iE,EACApK,KAAK4uL,kBACL5uL,MAEF+G,EACE/G,KAAKgtE,UACL5iE,EACApK,KAAK6uL,qBACL7uL,OAGKA,KAAKm/K,SACdx4K,EAAKhB,KACHoB,EACE/G,KAAKm/K,QACLrjF,GACA97F,KAAK4uL,kBACL5uL,MAEF+G,EACE/G,KAAKm/K,QACLrjF,GACA97F,KAAK6uL,qBACL7uL,OAINmjE,EAASh4D,SAASw0C,GAAY3/C,KAAKk9F,WAAWv9C,KAEjD,CAQD,MAAA40I,CAAOj3I,EAAO+rI,EAAiBv+I,GAC7B,MAAM3rB,EAAa2rB,EAAI6S,UAAU/uB,gBAC3BgmK,EAAsBzoK,GAAmBk9J,EAAiBlqK,GAE1D2pD,EAAMz8C,GACV1S,GACEL,GAAe,CAACs7K,IAChB9pJ,EAAI6S,UAAUjiB,gBAAkB17B,KAAK2oL,iBAEvCxpK,GAGIqqK,EAAWxpL,KAAK2tL,OAAO/2F,YAAY9tB,GACnC+rH,EAAiBrL,EAASroL,OAChC,GAAuB,IAAnB0zL,EACF,OAAO,KAGT,IAAIC,EAEAl2F,EADAzwE,EAAqB1T,IAGzB,MAAMs6K,EAAwB/0L,KAAK2oL,gBAAkB3oL,KAAK2oL,gBACpDqM,EAAY,KAChB,GAAIF,EAAe,CACjB,MAAMlL,EAAc9+I,EAAIu5B,uBAAuBywH,GAE/C,GAD6B9wK,GAAgBs5B,EAAOssI,IACxBmL,EAC1B,MAAO,CACLpL,OAAQmL,EACRlL,YAAa,CACX39K,KAAKiZ,MAAM0kK,EAAY,IACvB39K,KAAKiZ,MAAM0kK,EAAY,KAEzBjqI,QAASi/C,EAGd,CACD,OAAO,IAAI,EAGb,GAAI5+F,KAAKozL,QAAS,CAChB,IAAK,IAAIxxL,EAAI,EAAGA,EAAIizL,IAAkBjzL,EAAG,CACvC,MAAMgrL,EAAcpD,EAAS5nL,GACuB,WAAhDgrL,EAAYjtI,QAAQzqC,cAAcwZ,WACpCk+J,EAAYtmK,QAAQnb,SAASw+K,IAC3B,MAAMsL,EAAkB9oK,GAAmBw9J,EAAQxqK,GAC7CxR,EAAQqW,GAAgB4wK,EAAqBK,GAC/CtnL,EAAQwgB,IACV2mK,EAAgBnL,EAChBx7J,EAAqBxgB,EACrBixF,EAAiBguF,EAAYjtI,QAC9B,GAGN,CACD,MAAMlP,EAASukJ,IACf,GAAIvkJ,EACF,OAAOA,CAEV,CAED,GAAIzwC,KAAKqzL,MAAO,CACd,IAAK,IAAIzxL,EAAI,EAAGA,EAAIizL,IAAkBjzL,EAAG,CACvC,IAAI+nL,EAAS,KACb,MAAMiD,EAAcpD,EAAS5nL,GAC7B,GAAoD,WAAhDgrL,EAAYjtI,QAAQzqC,cAAcwZ,UAAwB,CAC5D,IAAI4hD,EAAiBs8G,EAAYjtI,QAAQzqC,cACzC,MAAM6W,EAAiBE,KACnBF,IACFukD,EAAiBA,EACdv7D,QACAiB,UAAU+V,EAAgB5M,IAE/BwqK,EAAS1jK,GACP2uK,EACZ,EAEA,KAAe,CACL,MAAOM,EAAcC,GAAcvI,EAAYtmK,QAE3C6uK,IACF7I,GAAY,GAAKngK,GAAmB+oK,EAAc/1K,GAClDmtK,GAAY,GAAKngK,GAAmBgpK,EAAYh2K,GAChDwqK,EAAStjK,GAAiBuuK,EAAqBtI,IAElD,CACD,GAAI3C,EAAQ,CACV,MAAMh8K,EAAQqW,GAAgB4wK,EAAqBjL,GAC/Ch8K,EAAQwgB,IACV2mK,EAAgB5oK,GAAiBy9J,EAAQxqK,GACzCgP,EAAqBxgB,EAExB,CACF,CAED,MAAM8iC,EAASukJ,IACf,GAAIvkJ,EACF,OAAOA,CAEV,CAED,OAAO,IACR,CAMD,cAAA+jJ,CAAe70I,GACb3/C,KAAK69F,cAAcl+C,GAAS,GAC5B3/C,KAAKk9F,WAAWv9C,GAAS,EAC1B,CAOD,sBAAAu0I,CAAuB1K,EAAU50K,GAC/B,MAAMuK,EAAanf,KAAKsgD,SAAS3C,UAAU/uB,gBAC3C,IAAI0hD,EAAiB17D,EACrB,MAAMmX,EAAiBE,KACnBF,IACFukD,EACEA,EAAev7D,QAAQiB,UAAU+V,EAAgB5M,IAGrD,MAAMqX,EAAUe,GAAW+4C,GACvBvkD,GACFyK,EAAQxgB,UAAUmJ,EAAY4M,GAEhC,MAAMxS,EAAcid,EAAQ7G,iBAAiB,GAC7C,IAAK,IAAI/tB,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAS,EAAGS,EAAIuE,IAAMvE,EACrD4nL,EAAS7jL,KAAK4T,EAAYzV,MAAMlC,EAAGA,EAAI,GAE1C,CAOD,kCAAAqyL,CAAmCzK,EAAU50K,GAC3C,MAAM4gE,EAAa5gE,EAAS6gE,qBAC5B,IAAK,IAAI7zE,EAAI,EAAGA,EAAI4zE,EAAWr0E,SAAUS,EAAG,CAC1C,MAAMwyL,EAAYp0L,KAAK0zL,qBAAqBl+G,EAAW5zE,GAAG8sB,WACtD0lK,GACFA,EAAU5K,EAAUh0G,EAAW5zE,GAElC,CACF,CAOD,0BAAAgyL,CAA2BpK,EAAU50K,GACnC,MAAM2E,EAAc3E,EAAS+a,iBAC7B,IAAK,IAAI/tB,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAS,EAAGS,EAAIuE,IAAMvE,EACrD4nL,EAAS7jL,KAAK4T,EAAYzV,MAAMlC,EAAGA,EAAI,GAE1C,CAOD,+BAAAmyL,CAAgCvK,EAAU50K,GACxC,MAAMqvG,EAAQrvG,EAAS+a,iBACvB,IAAK,IAAIrL,EAAI,EAAG2G,EAAKg5F,EAAM9iH,OAAQmjB,EAAI2G,IAAM3G,EAAG,CAC9C,MAAM/K,EAAc0qG,EAAM3/F,GAC1B,IAAK,IAAI1iB,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAS,EAAGS,EAAIuE,IAAMvE,EACrD4nL,EAAS7jL,KAAK4T,EAAYzV,MAAMlC,EAAGA,EAAI,GAE1C,CACF,CAOD,0BAAAkyL,CAA2BtK,EAAU50K,GACnCA,EAAS+a,iBAAiBxkB,SAASyX,IACjC4mK,EAAS7jL,KAAK,CAACid,GAAO,GAEzB,CAOD,4BAAAoxK,CAA6BxK,EAAU50K,GACrC,MAAMwlF,EAAWxlF,EAAS+a,iBAC1B,IAAK,IAAInL,EAAI,EAAGipJ,EAAKrzE,EAASj5F,OAAQqjB,EAAIipJ,IAAMjpJ,EAAG,CACjD,MAAMhJ,EAAQ4+E,EAAS51E,GACvB,IAAK,IAAIF,EAAI,EAAG2G,EAAKzP,EAAMra,OAAQmjB,EAAI2G,IAAM3G,EAAG,CAC9C,MAAM/K,EAAciC,EAAM8I,GAC1B,IAAK,IAAI1iB,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAS,EAAGS,EAAIuE,IAAMvE,EACrD4nL,EAAS7jL,KAAK4T,EAAYzV,MAAMlC,EAAGA,EAAI,GAE1C,CACF,CACF,CAOD,qBAAA+xL,CAAsBnK,EAAU50K,GAC9B40K,EAAS7jL,KAAK,CAACiP,EAAS+a,kBACzB,CAOD,uBAAAkkK,CAAwBrK,EAAU50K,GAChC,MAAM4G,EAAQ5G,EAAS+a,iBACvB,IAAK,IAAIrL,EAAI,EAAG2G,EAAKzP,EAAMra,OAAQmjB,EAAI2G,IAAM3G,EAAG,CAC9C,MAAM/K,EAAciC,EAAM8I,GAC1B,IAAK,IAAI1iB,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAS,EAAGS,EAAIuE,IAAMvE,EACrD4nL,EAAS7jL,KAAK4T,EAAYzV,MAAMlC,EAAGA,EAAI,GAE1C,CACF,GCjqBH,MAAMwzL,GAMY,iBANZA,GAYS,cAZTA,GAkBU,eAqCT,MAAMC,WAAuBtvL,EAQlC,WAAAjG,CAAYC,EAAMojE,EAAU/rD,EAAYk+K,EAAiBzgI,GACvD5vD,MAAMlF,GAONC,KAAKmjE,SAAWA,EAQhBnjE,KAAKoX,WAAaA,EAQlBpX,KAAKs1L,gBAAkBA,EAOvBt1L,KAAK60D,gBAAkBA,CACxB,EAmUH,IAAA0gI,GA5SA,cAAwBx9H,GAItB,WAAAj4D,CAAY6K,GAyCV,IAAI80C,EACJ,GAvCAx6C,MAFA0F,EAAUA,GAAoB,IAO9B3K,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAOL3H,KAAKw1L,gBAAkB,KAOvBx1L,KAAKy1L,iBAAmB,KAMxBz1L,KAAKgtE,eAAiCxmE,IAArBmE,EAAQw4D,SAAyBx4D,EAAQw4D,SAAW,KAIjEx4D,EAAQo8C,SAAW/mD,KAAKgtE,UAC1B,GAA8B,mBAAnBriE,EAAQo8C,OACjBtH,EAAc90C,EAAQo8C,WACjB,CACL,MAAMA,EAASp8C,EAAQo8C,OACvBtH,EAAc,SAAU7R,GACtB,OAAOmZ,EAAOrhD,SAASkoC,EACjC,CACO,MAED6R,EAAct8C,EAOhBnD,KAAKuyL,aAAe9yI,EAMpBz/C,KAAKqyL,QAAU1nL,EAAQ8sC,SAAWz3C,KAAKgtE,UAAYriE,EAAQ8sC,OAASt0C,EAMpEnD,KAAKsyL,cAAgB3nL,EAAQ40C,aAAe50C,EAAQ40C,aAAe,EAMnEv/C,KAAKs4D,WAAa3tD,EAAQ0tD,UAAY1tD,EAAQ0tD,UAAYrB,GAM1Dh3D,KAAK01L,aAAe,KAEpB11L,KAAK6J,kBACH0qD,GACAv0D,KAAK21L,qBAER,CAOD,eAAApgI,CAAgB1vD,GACd,IAAKA,EAAM4iD,gBAAkBzoD,KAAKs4D,WAAWzyD,GAC3C,OAAO,EAGT,GADA7F,KAAK01L,aAAe11L,KAAK41L,iBAAiB/vL,EAAMy3C,MAAOz3C,EAAMilC,MACxD9qC,KAAKw1L,iBAAmBx1L,KAAK01L,aAAc,CAC9C11L,KAAKy1L,iBAAmB5vL,EAAMuR,WAC9BpX,KAAKw1L,gBAAkB3vL,EAAMuR,WAC7BpX,KAAKy1D,gBAAgB5vD,GAErB,MAAMs9D,EAAWnjE,KAAKgtE,WAAa,IAAIxiE,EAAW,CAACxK,KAAK01L,eAWxD,OATA11L,KAAK4F,cACH,IAAIyvL,GACFD,GACAjyH,EACAt9D,EAAMuR,WACNpX,KAAKy1L,iBACL5vL,KAGG,CACR,CACD,OAAO,CACR,CAOD,aAAA6vD,CAAc7vD,GACZ,GAAI7F,KAAKw1L,gBAAiB,CACxBx1L,KAAKw1L,gBAAkB,KACvBx1L,KAAKy1D,gBAAgB5vD,GAErB,MAAMs9D,EAAWnjE,KAAKgtE,WAAa,IAAIxiE,EAAW,CAACxK,KAAK01L,eAaxD,OAXA11L,KAAK4F,cACH,IAAIyvL,GACFD,GACAjyH,EACAt9D,EAAMuR,WACNpX,KAAKy1L,iBACL5vL,IAIJ7F,KAAKy1L,iBAAmB,MACjB,CACR,CACD,OAAO,CACR,CAMD,eAAAjgI,CAAgB3vD,GACd,GAAI7F,KAAKw1L,gBAAiB,CACxB,MAAMtP,EAAgBrgL,EAAMuR,WACtB+H,EAAatZ,EAAMilC,IAAI6S,UAAU/uB,gBAEjCinK,EAAoB1pK,GAAmB+5J,EAAe/mK,GACtD22K,EAAqB3pK,GACzBnsB,KAAKw1L,gBACLr2K,GAEIlB,EAAS43K,EAAkB,GAAKC,EAAmB,GACnD53K,EAAS23K,EAAkB,GAAKC,EAAmB,GAEnD3yH,EAAWnjE,KAAKgtE,WAAa,IAAIxiE,EAAW,CAACxK,KAAK01L,eAClD3pK,EAAiBE,KAEvBk3C,EAASh4D,SAAQ,SAAUw0C,GACzB,MAAMk5H,EAAOl5H,EAAQzqC,cACjB6W,GACF8sJ,EAAK7iK,UAAU+V,EAAgB5M,GAC/B05J,EAAKhhK,UAAUoG,EAAQC,GACvB26J,EAAK7iK,UAAUmJ,EAAY4M,IAE3B8sJ,EAAKhhK,UAAUoG,EAAQC,GAEzByhC,EAAQ9qC,YAAYgkK,EAC5B,IAEM74K,KAAKw1L,gBAAkBtP,EAEvBlmL,KAAK4F,cACH,IAAIyvL,GACFD,GACAjyH,EACA+iH,EACAlmL,KAAKy1L,iBACL5vL,GAGL,CACF,CAMD,eAAA4vD,CAAgB5vD,GACd,MAAM2F,EAAO3F,EAAMilC,IAAIub,cAInBrmD,KAAK41L,iBAAiB/vL,EAAMy3C,MAAOz3C,EAAMilC,MAC3Ct/B,EAAK0mD,UAAUxmD,OAAO1L,KAAKw1L,gBAAkB,UAAY,eACzDhqL,EAAK0mD,UAAUzuC,IAAIzjB,KAAKw1L,gBAAkB,cAAgB,YAE1DhqL,EAAK0mD,UAAUxmD,OAAO,UAAW,cAEpC,CAWD,gBAAAkqL,CAAiBt4I,EAAOxS,GACtB,OAAOA,EAAIm4B,sBACT3lB,GACA,CAACqC,EAAS/R,KACR,GAAM+R,aAAmBvrC,IAAapU,KAAKqyL,QAAQ1yI,EAAS/R,MAGxD5tC,KAAKgtE,WAAchtE,KAAKgtE,UAAU3hE,WAAW3F,SAASi6C,IAG1D,OAAOA,CAAO,GAEhB,CACEF,YAAaz/C,KAAKuyL,aAClBhzI,aAAcv/C,KAAKsyL,eAGxB,CAOD,eAAAI,GACE,OAAO1yL,KAAKsyL,aACb,CAQD,eAAAK,CAAgBpzI,GACdv/C,KAAKsyL,cAAgB/yI,CACtB,CAQD,MAAAxC,CAAOjS,GACL,MAAM4gJ,EAAS1rL,KAAKsgD,SACpBr7C,MAAM83C,OAAOjS,GACb9qC,KAAKskL,aAAaoH,EACnB,CAKD,oBAAAiK,GACE31L,KAAKskL,aAAa,KACnB,CAMD,YAAAA,CAAaoH,GACX,IAAI5gJ,EAAM9qC,KAAKsgD,SACf,MAAMwU,EAAS90D,KAAK40D,YACpB,KAAK9pB,IAAQgqB,KACXhqB,EAAMA,GAAO4gJ,EACT5gJ,GAAK,CACMA,EAAIub,cACZ6L,UAAUxmD,OAAO,UAAW,cAClC,CAEJ,GCjaI,SAASqqL,GAAOj7K,EAAiBC,EAAQ/Y,EAAKgZ,EAAQpB,EAAMo8K,QACpDxvL,IAAToT,EAEFo8K,OAA4BxvL,IAAfwvL,EAA2BA,EAAa,GAErDp8K,EAAO,GACPo8K,EAAa,GAEf,IAAI1xK,EAAIvJ,EACR,KAAOuJ,EAAItiB,GAAK,CACd,MAAMqV,EAAIyD,EAAgBwJ,KAC1B1K,EAAKo8K,KAAgBl7K,EAAgBwJ,KACrC1K,EAAKo8K,KAAgB3+K,EACrB,IAAK,IAAImN,EAAI,EAAGA,EAAIxJ,IAAUwJ,EAC5B5K,EAAKo8K,KAAgBl7K,EAAgBwJ,IAExC,CAED,OADA1K,EAAKzY,OAAS60L,EACPp8K,CACT,CCmPA,IAAAq8K,GAvKA,MACE,WAAAn2L,GAKEE,KAAKotE,oBAAiB5mE,EAMtBxG,KAAKk2L,8BAA2B1vL,EAMhCxG,KAAKm2L,aAAe/hL,GAMpBpU,KAAKk4G,oBAAsB,IAC5B,CASD,cAAAk+E,CAAelsL,EAAQS,GACrB,GAAIA,EAAS,CACX,IAAIyiE,EAAiBziE,EAAQyiE,eACzBx+C,GAAcjkB,EAAQyiE,gBACtBptE,KAAK4uE,eAAe1kE,GAEtBS,EAAQ6O,QACR4zD,GAC8B,gBAA9BA,EAAe/rD,aAEf+rD,EAAiBx+C,GAAcw+C,GAC/BA,EAAerrD,eAAepX,EAAQ6O,SAExC7O,EAAU,CACRyiE,eAAgBA,EAChBuB,kBAAmBhkE,EAAQgkE,kBAE9B,CACD,OAAO3uE,KAAKq2L,aAAa1rL,EAC1B,CAWD,YAAA0rL,CAAa1rL,GACX,OAAOjE,OAAO8C,OACZ,CACE4jE,eAAgBptE,KAAKotE,eACrBuB,kBAAmB3uE,KAAKk2L,yBACxBC,aAAcn2L,KAAKm2L,cAErBxrL,EAEH,CAMD,OAAA+jB,GACE,OAAOnmB,GACR,CAUD,WAAA+tL,CAAYpsL,EAAQS,GAClB,OAAOpC,GACR,CAUD,YAAAmmE,CAAaxkE,EAAQS,GACnB,OAAOpC,GACR,CAUD,YAAAguL,CAAarsL,EAAQS,GACnB,OAAOpC,GACR,CASD,cAAAqmE,CAAe1kE,GACb,OAAO3B,GACR,CAUD,YAAAiuL,CAAa72I,EAASh1C,GACpB,OAAOpC,GACR,CAUD,aAAAkuL,CAActzH,EAAUx4D,GACtB,OAAOpC,GACR,CAUD,aAAAmuL,CAAc9hL,EAAUjK,GACtB,OAAOpC,GACR,GAYI,SAASouL,GAA6B/hL,EAAUgiL,EAAOjsL,GAC5D,MAAMgkE,EAAoBhkE,EACtBikB,GAAcjkB,EAAQgkE,mBACtB,KACEvB,EAAiBziE,EAAUikB,GAAcjkB,EAAQyiE,gBAAkB,KAEzE,IAAItgD,EAAclY,EAClB,GACE+5D,GACAvB,IACCgrG,GAAqBzpG,EAAmBvB,GACzC,CACIwpH,IACF9pK,EAAgClY,EAASG,SAE3C,MAAM8hL,EAAiBD,EAAQjoH,EAAoBvB,EAC7C0pH,EAAeF,EAAQxpH,EAAiBuB,EACZ,gBAA9BkoH,EAAex1K,WACjByL,EAAY9W,UAAU6gL,EAAgBC,GAEtChqK,EAAYnO,eAAekN,GAAagrK,EAAgBC,GAE3D,CACD,GACEF,GACAjsL,QACmDnE,IAAvB,EAAUwe,SACtC,CACA,MAAM+rB,EAAQ9kC,KAAKC,IAAI,GAAgC,EAAU8Y,UAM3DhP,EAAY,SAAUuD,GAC1B,IAAK,IAAI3X,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAQS,EAAIuE,IAAMvE,EACjD2X,EAAY3X,GAAKqK,KAAKiZ,MAAM3L,EAAY3X,GAAKmvC,GAASA,EAExD,OAAOx3B,CACb,EACQuT,IAAgBlY,IAClBkY,EAAgClY,EAASG,SAE3C+X,EAAYnO,eAAe3I,EAC5B,CACD,OAAO8W,CACT,CAOO,SAASiqK,GAA2Bv9K,EAAQ7O,GACjD,MAAMgkE,EAAoBhkE,EACtBikB,GAAcjkB,EAAQgkE,mBACtB,KACEvB,EAAiBziE,EAAUikB,GAAcjkB,EAAQyiE,gBAAkB,KAEzE,OACEuB,GACAvB,IACCgrG,GAAqBzpG,EAAmBvB,GAElCthD,GAAgBtS,EAAQ4zD,EAAgBuB,GAE1Cn1D,CACT,CAEA,MAAMw9K,GAAsB,CAC1BxjK,MAAOA,GACPqnD,WAAYA,GACZ5kD,QAASA,GACT+kD,WAAYA,GACZC,gBAAiBA,GACjBC,aAAcA,IAwBT,SAAS+7G,GAAoBryL,EAAQ+F,GAC1C,MAAMiK,EAAWhQ,EAAOgQ,SACxB,IAAKA,EACH,MAAO,GAET,GAAIvS,MAAMC,QAAQsS,GAChB,OAAOA,EACJk2B,KAAKl2B,GAAaqiL,GAAoB,IAAIryL,EAAQgQ,eAClDyxJ,OAGL,MAAMzqE,EACc,iBAAlBhnF,EAAS7U,KAA0B,UAAY6U,EAAS7U,KAC1D,GAAqB,uBAAjB67F,GAA0D,WAAjBA,EAC3C,MAAM,IAAIpzF,MAAM,8BAAgCozF,GAGlD,MAAM5gF,EAASpG,EAASua,OAAOhuB,OAC/B,OAAOw1L,GACL,IAAI17F,GACFW,EACiB,YAAjBA,EA1CN,SAA+B9gF,EAAiB8V,EAAM5V,GACpD,OAAI3Y,MAAMC,QAAQsuB,EAAK,KAEhB6E,GAAwB3a,EAAiB,EAAG8V,EAAM5V,IAErD4a,GADA9a,EAAkBA,EAAgBhX,QACM,EAAG8sB,EAAM5V,GAE5CF,IAEJwa,GAAuBxa,EAAiB,EAAG8V,EAAM5V,IAEpD0a,GADA5a,EAAkBA,EAAgBhX,QACC,EAAG8sB,EAAM5V,GAEvCF,EACT,CA6BUo8K,CAAsBtiL,EAASkG,gBAAiBlG,EAASgc,KAAM5V,GAC/DpG,EAASkG,gBACblG,EAASgc,MAAMy1I,OACfrrJ,EACApW,EAAOkQ,YAAc,CAAE,EACvBlQ,EAAO4I,IACPkuF,6BACF,EACA/wF,EAEJ,CAOO,SAASwsL,GAAevyL,EAAQ+F,GACrC,IAAK/F,EACH,OAAO,KAET,GAAIvC,MAAMC,QAAQsC,GAAS,CACzB,MAAM4wE,EAAa5wE,EAAOkmC,KAAKl2B,GAC7BuiL,GAAeviL,EAAUjK,KAE3B,OAAO,IAAIwwE,GAAmB3F,EAC/B,CAED,OAAOmhH,GACL,IAAIjnK,EAFWsnK,GAAoBpyL,EAAO7E,OAE7B6E,EAAOkW,gBAAiBlW,EAAOuqB,OAAQvqB,EAAOgsB,OAC3D,EACAjmB,EAEJ,CChPA,SAASysL,GAAUltL,GACjB,GAAsB,iBAAXA,EAAqB,CAC9B,MAAMtF,EAASypE,KAAKnjC,MAAMhhC,GAC1B,OAAOtF,GAA0C,IAClD,CACD,OAAe,OAAXsF,EACKA,EAEF,IACT,CAEA,IAAAmtL,GAnMA,cAA0BC,GACxB,WAAAx3L,GACEmF,OACD,CAKD,OAAAypB,GACE,MAAO,MACR,CAWD,WAAA4nK,CAAYpsL,EAAQS,GAClB,OAAO3K,KAAKu3L,sBACVH,GAAUltL,GACVlK,KAAKo2L,eAAelsL,EAAQS,GAE/B,CAWD,YAAA+jE,CAAaxkE,EAAQS,GACnB,OAAO3K,KAAKw3L,uBACVJ,GAAUltL,GACVlK,KAAKo2L,eAAelsL,EAAQS,GAE/B,CASD,qBAAA4sL,CAAsB3yL,EAAQ+F,GAC5B,OAAOpC,GACR,CASD,sBAAAivL,CAAuB5yL,EAAQ+F,GAC7B,OAAOpC,GACR,CAUD,YAAAguL,CAAarsL,EAAQS,GACnB,OAAO3K,KAAKy3L,uBACVL,GAAUltL,GACVlK,KAAKo2L,eAAelsL,EAAQS,GAE/B,CASD,sBAAA8sL,CAAuB7yL,EAAQ+F,GAC7B,OAAOpC,GACR,CASD,cAAAqmE,CAAe1kE,GACb,OAAOlK,KAAK03L,yBAAyBN,GAAUltL,GAChD,CAQD,wBAAAwtL,CAAyB9yL,GACvB,OAAO2D,GACR,CAUD,YAAAiuL,CAAa72I,EAASh1C,GACpB,OAAO0jE,KAAKmjB,UAAUxxF,KAAK23L,mBAAmBh4I,EAASh1C,GACxD,CAQD,kBAAAgtL,CAAmBh4I,EAASh1C,GAC1B,OAAOpC,GACR,CAUD,aAAAkuL,CAActzH,EAAUx4D,GACtB,OAAO0jE,KAAKmjB,UAAUxxF,KAAK43L,oBAAoBz0H,EAAUx4D,GAC1D,CAQD,mBAAAitL,CAAoBz0H,EAAUx4D,GAC5B,OAAOpC,GACR,CAUD,aAAAmuL,CAAc9hL,EAAUjK,GACtB,OAAO0jE,KAAKmjB,UAAUxxF,KAAK63L,oBAAoBjjL,EAAUjK,GAC1D,CAQD,mBAAAktL,CAAoBjjL,EAAUjK,GAC5B,OAAOpC,GACR,GCnJH,MAAMuvL,GAAmB,CACvBtkK,MAySF,SAA2B5uB,GACzB,IAAIge,EAEFA,OADepc,IAAb5B,EAAOub,QAAgC3Z,IAAb5B,EAAO26B,EAC3B,IAAI/L,GAAM,CAAC5uB,EAAOyS,EAAGzS,EAAO0S,EAAG1S,EAAO26B,EAAG36B,EAAOub,GAAI,aACtC3Z,IAAb5B,EAAO26B,EACR,IAAI/L,GAAM,CAAC5uB,EAAOyS,EAAGzS,EAAO0S,EAAG1S,EAAO26B,GAAI,YAC5B/4B,IAAb5B,EAAOub,EACR,IAAIqT,GAAM,CAAC5uB,EAAOyS,EAAGzS,EAAO0S,EAAG1S,EAAOub,GAAI,OAE1C,IAAIqT,GAAM,CAAC5uB,EAAOyS,EAAGzS,EAAO0S,IAEtC,OAAOsL,CACT,EApTEi4D,WA0TF,SAAgCj2E,GAC9B,MAAMuqB,EAAS4oK,GAAkBnzL,GACjC,OAAO,IAAIi2E,GAAWj2E,EAAOozL,MAAM,GAAI7oK,EACzC,EA5TE8G,QA8WF,SAA6BrxB,GAC3B,MAAMuqB,EAAS4oK,GAAkBnzL,GACjC,OAAO,IAAIqxB,GAAQrxB,EAAO4W,MAAO2T,EACnC,EAhXE6rD,WA2VF,SAAgCp2E,GAC9B,MAAMuqB,EAAS4oK,GAAkBnzL,GACjC,OAAO,IAAIo2E,GAAWp2E,EAAOm1F,OAAQ5qE,EACvC,EA7VE8rD,gBAgUF,SAAqCr2E,GACnC,MAAMuqB,EAAS4oK,GAAkBnzL,GACjC,OAAO,IAAIq2E,GAAgBr2E,EAAOozL,MAAO7oK,EAC3C,EAlUE+rD,aAkWF,SAAkCt2E,GAChC,MAAMuqB,EAAS4oK,GAAkBnzL,GACjC,OAAO,IAAIs2E,GAAat2E,EAAO4W,MAAO2T,EACxC,GA9VM8oK,GAAmB,CACvBzkK,MA6WF,SAA4B5e,EAAUjK,GACpC,MAAM4O,EAAc3E,EAAS+a,iBAE7B,IAAIuoK,EACJ,MAAM/oK,EAASva,EAASkb,YACxB,GAAe,QAAXX,EACF+oK,EAAW,CACT7gL,EAAGkC,EAAY,GACfjC,EAAGiC,EAAY,GACfgmB,EAAGhmB,EAAY,SAEZ,GAAe,QAAX4V,EACT+oK,EAAW,CACT7gL,EAAGkC,EAAY,GACfjC,EAAGiC,EAAY,GACf4G,EAAG5G,EAAY,SAEZ,GAAe,SAAX4V,EACT+oK,EAAW,CACT7gL,EAAGkC,EAAY,GACfjC,EAAGiC,EAAY,GACfgmB,EAAGhmB,EAAY,GACf4G,EAAG5G,EAAY,QAEZ,IAAe,OAAX4V,EAMT,MAAM,IAAI3mB,MAAM,2BALhB0vL,EAAW,CACT7gL,EAAGkC,EAAY,GACfjC,EAAGiC,EAAY,GAIlB,CACD,OAAO2+K,CACT,EA7YEr9G,WAgaF,SAAiCme,EAAYruF,GAC3C,MAAMwtL,EAAQC,GAASp/F,GACvB,MAAO,CACLq/F,KAAMF,EAAME,KACZC,KAAMH,EAAMG,KACZN,MAAO,CACmCh/F,EAAWrpE,kBAGzD,EAxaEsG,QA+aF,SAA8BO,EAAS7rB,GAErC,MAAMwtL,EAAQC,GAAS5hK,GACvB,MAAO,CACL6hK,KAAMF,EAAME,KACZC,KAAMH,EAAMG,KACZ98K,MACEgb,EAAQ7G,gBAAe,GAG7B,EAxbEqrD,WA+cF,SAAiC4e,EAAYjvF,GAC3C,MAAMwtL,EAAQC,GAASx+F,GACvB,MAAO,CACLy+F,KAAMF,EAAME,KACZC,KAAMH,EAAMG,KACZv+F,OACEH,EAAWjqE,iBAGjB,EAvdEsrD,gBA8bF,SAAsCqe,EAAiB3uF,GACrD,MAAMwtL,EAAQC,GAAS9+F,GACvB,MAAO,CACL++F,KAAMF,EAAME,KACZC,KAAMH,EAAMG,KACZN,MACE1+F,EAAgB3pE,iBAGtB,EAtcEurD,aA6dF,SAAmCtmE,EAAUjK,GAC3C,MAAMwtL,EAAQC,GAASxjL,GACjB2E,EAAc3E,EAAS+a,gBAAe,GACtC1M,EAAS,GACf,IAAK,IAAIrhB,EAAI,EAAGA,EAAI2X,EAAYpY,OAAQS,IACtC,IAAK,IAAIyV,EAAIkC,EAAY3X,GAAGT,OAAS,EAAGkW,GAAK,EAAGA,IAC9C4L,EAAOtd,KAAK4T,EAAY3X,GAAGyV,IAG/B,MAAO,CACLghL,KAAMF,EAAME,KACZC,KAAMH,EAAMG,KACZ98K,MAAsD,EAE1D,GAjTA,SAAS+6K,GAAa3xL,EAAQ+F,GAC5B,IAAK/F,EACH,OAAO,KAGT,IAAI7E,EACJ,GAA2B,iBAAhB6E,EAAU,GAAyC,iBAAhBA,EAAU,EACtD7E,EAAO,aACF,GAAI6E,EAAe,OACxB7E,EAAO,kBACF,GAAI6E,EAAc,MAAG,CAGxB7E,EADoC,IADoB,EACrCi4L,MAAM72L,OAClB,aAEA,iBAEb,MAAS,GAAIyD,EAAc,MAAG,CAC1B,MAAM2zL,EAAkD,EAClDppK,EAAS4oK,GAAkBQ,GAC3B/8K,EAsBV,SAAsBA,EAAO2T,GAC3B,MAAMqpK,EAAW,GACXC,EAAa,GACbxyD,EAAQ,GACd,IAAIrkI,EAAGuE,EACP,IAAKvE,EAAI,EAAGuE,EAAKqV,EAAMra,OAAQS,EAAIuE,IAAMvE,EAAG,CAC1C42L,EAASr3L,OAAS,EAClBmwB,GAAmBknK,EAAU,EAAGh9K,EAAM5Z,GAAIutB,EAAOhuB,QAE/Bi0B,GAChBojK,EACA,EACAA,EAASr3L,OACTguB,EAAOhuB,QAGPs3L,EAAW9yL,KAAK,CAAC6V,EAAM5Z,KAEvBqkI,EAAMtgI,KAAK6V,EAAM5Z,GAEpB,CACD,KAAOqkI,EAAM9kI,QAAQ,CACnB,MAAMyiI,EAAOqC,EAAMn2H,QACnB,IAAI4oL,GAAU,EAEd,IAAK92L,EAAI62L,EAAWt3L,OAAS,EAAGS,GAAK,EAAGA,IAAK,CAC3C,MAAM+2L,EAAYF,EAAW72L,GAAG,GAKhC,GAJqBoY,GACnB,IAAIkZ,GAAWylK,GAAWt5K,YAC1B,IAAI6T,GAAW0wG,GAAMvkH,aAEL,CAEhBo5K,EAAW72L,GAAG+D,KAAKi+H,GACnB80D,GAAU,EACV,KACD,CACF,CACIA,GAGHD,EAAW9yL,KAAK,CAACi+H,EAAKp6B,WAEzB,CACD,OAAOivF,CACT,CAnEkBG,CAAaL,EAAgB/8K,MAAO2T,GAC7B,IAAjB3T,EAAMra,QACRpB,EAAO,UACP6E,EAAS8B,OAAO8C,OAAO,CAAA,EAAI5E,EAAQ,CAAC4W,MAAWA,EAAM,OAErDzb,EAAO,eACP6E,EAAS8B,OAAO8C,OAAO,CAAE,EAAE5E,EAAQ,CAAC4W,MAAWA,IAElD,CAED,OAAOm7K,IAA6BkC,EADbf,GAAiB/3L,IACW6E,IAAS,EAAO+F,EACrE,CAkGA,SAASotL,GAAkBnzL,GAEzB,IAAIuqB,EAAS,KAQb,OAPoB,IAAhBvqB,EAAOyzL,OAAiC,IAAhBzzL,EAAO0zL,KACjCnpK,EAAS,QACgB,IAAhBvqB,EAAOyzL,KAChBlpK,EAAS,OACgB,IAAhBvqB,EAAO0zL,OAChBnpK,EAAS,OAEJA,CACT,CAyEA,SAASipK,GAASxjL,GAChB,MAAMua,EAASva,EAASkb,YACxB,MAAO,CACLuoK,KAAiB,QAAXlpK,GAA+B,SAAXA,EAC1BmpK,KAAiB,QAAXnpK,GAA+B,SAAXA,EAE9B,CA6FA,SAASunK,GAAc9hL,EAAUjK,GAE/B,OAAOmuL,EADgBb,GAAiBrjL,EAAS8Z,YAE/CioK,GAA6B/hL,GAAU,EAAMjK,GAC7CA,EAEJ,CAEA,IAAAouL,GA5eA,cAAuBC,GAIrB,WAAAl5L,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B1F,QAOAjF,KAAKuU,cAAgB5J,EAAQi5K,YAC9B,CASD,qBAAA2T,CAAsB3yL,EAAQ+F,EAASsuL,GACrC,MAAMC,EAAkD,EAClDtkL,EAAW2hL,GAAa2C,EAAgBtkL,SAAUjK,GAClDg1C,EAAU,IAAIvrC,GAKpB,GAJIpU,KAAKuU,eACPorC,EAAQ3qC,gBAAgBhV,KAAKuU,eAE/BorC,EAAQ9qC,YAAYD,GAChBskL,EAAgB/qE,WAAY,CAC9BxuE,EAAQx2C,cAAc+vL,EAAgB/qE,YAAY,GAClD,MAAM3gH,EAAK0rL,EAAgB/qE,WAAW8qE,QAC3BzyL,IAAPgH,GACFmyC,EAAQlqC,MAA6B,EAExC,CACD,OAAOkqC,CACR,CAQD,sBAAA63I,CAAuB5yL,EAAQ+F,GAE7B,GADAA,EAAUA,GAAoB,GAC1B/F,EAAiB,SAAG,CACtB,MAEMu+D,EAAW,GACXg2H,EAHwD,EAGlBh2H,SAC5C,IAAK,IAAIvhE,EAAI,EAAGuE,EAAKgzL,EAAiBh4L,OAAQS,EAAIuE,IAAMvE,EACtDuhE,EAASx9D,KACP3F,KAAKu3L,sBACH4B,EAAiBv3L,GACjB+I,EACA/F,EAAOw0L,oBAIb,OAAOj2H,CACR,CACD,MAAO,CAACnjE,KAAKu3L,sBAAsB3yL,EAAQ+F,GAC5C,CAQD,sBAAA8sL,CAAuB7yL,EAAQ+F,GAC7B,OAAO4rL,GAAa3xL,EAAQ+F,EAC7B,CAOD,wBAAA+sL,CAAyB9yL,GACvB,GACEA,EAAyB,uBACc4B,IAAvC5B,EAAyB,iBAAQ,KACjC,CAKA,OAAOgqB,GAAc,QAHnBhqB,EACR,iBACmCy0L,KAE9B,CACD,OAAO,IACR,CAUD,mBAAAxB,CAAoBjjL,EAAUjK,GAC5B,OAAO+rL,GAAc9hL,EAAU5U,KAAKq2L,aAAa1rL,GAClD,CAUD,kBAAAgtL,CAAmBh4I,EAASh1C,GAC1BA,EAAU3K,KAAKq2L,aAAa1rL,GAC5B,MAAM/F,EAAS,CAAA,EACf,IAAK+6C,EAAQj2C,gBAEX,OADA9E,EAAmB,WAAI,GAChBA,EAET,MAAMkQ,EAAa6qC,EAAQp2C,gBACrBqL,EAAW+qC,EAAQzqC,cACzB,GAAIN,EAAU,CACZhQ,EAAiB,SAAI8xL,GAAc9hL,EAAUjK,GAC7C,MAAMwU,EACJxU,IAAYA,EAAQyiE,gBAAkBziE,EAAQgkE,mBAC5CxvD,IACFva,EAAiB,SAAoB,iBACU,CAC3Cy0L,KAAMlvJ,OAAOvb,GAAczP,GAAYiC,UAAUyE,MAAM,KAAK3a,gBAG3D4J,EAAW6qC,EAAQ1qC,kBAC3B,CAMD,OALKnQ,EAAQgQ,GAGXlQ,EAAmB,WAAI,GAFvBA,EAAmB,WAAIkQ,EAIlBlQ,CACR,CAUD,mBAAAgzL,CAAoBz0H,EAAUx4D,GAC5BA,EAAU3K,KAAKq2L,aAAa1rL,GAC5B,MAAM2uL,EAAU,GAChB,IAAK,IAAI13L,EAAI,EAAGuE,EAAKg9D,EAAShiE,OAAQS,EAAIuE,IAAMvE,EAC9C03L,EAAQ3zL,KAAK3F,KAAK23L,mBAAmBx0H,EAASvhE,GAAI+I,IAEpD,MAAO,CACLw4D,SAAYm2H,EAEf,GC6CH,IAAAC,GA9QA,cAAyBjC,GACvB,WAAAx3L,GACEmF,QAMAjF,KAAK4xH,eAAiBE,IACvB,CAKD,OAAApjG,GACE,MAAO,KACR,CAUD,WAAA4nK,CAAYpsL,EAAQS,GAClB,IAAKT,EACH,OAAO,KAET,GAAsB,iBAAXA,EAAqB,CAC9B,MAAM0hD,EAAM1gB,GAAMhhC,GAClB,OAAOlK,KAAKw5L,wBAAwB5tI,EAAKjhD,EAC1C,CACD,OAAI2kH,GAAWplH,GACNlK,KAAKw5L,wBAClB,EACQ7uL,GAGG3K,KAAKy5L,sBAAqD9uL,EAClE,CAOD,uBAAA6uL,CAAwB5tI,EAAKjhD,GAC3B,MAAMw4D,EAAWnjE,KAAK05L,yBAAyB9tI,EAAKjhD,GACpD,OAAIw4D,EAAShiE,OAAS,EACbgiE,EAAS,GAEX,IACR,CAOD,mBAAAs2H,CAAoBloL,EAAM5G,GACxB,OAAO,IACR,CAUD,YAAA+jE,CAAaxkE,EAAQS,GACnB,IAAKT,EACH,MAAO,GAET,GAAsB,iBAAXA,EAAqB,CAC9B,MAAM0hD,EAAM1gB,GAAMhhC,GAClB,OAAOlK,KAAK05L,yBAAyB9tI,EAAKjhD,EAC3C,CACD,OAAI2kH,GAAWplH,GACNlK,KAAK05L,yBAClB,EACQ/uL,GAGG3K,KAAK25L,uBAAsDhvL,EACnE,CAQD,wBAAA+uL,CAAyB9tI,EAAKjhD,GAE5B,MAAMw4D,EAAW,GACjB,IAAK,IAAIxhE,EAAIiqD,EAAItF,WAAY3kD,EAAGA,EAAIA,EAAE0tH,YAChC1tH,EAAEqtH,UAAYC,KAAK2qE,cACrB13L,EACEihE,EACAnjE,KAAK25L,uBAAiDhvL,IAI5D,OAAOw4D,CACR,CASD,oBAAAw2H,CAAqBpoL,EAAM5G,GACzB,OAAOpC,GACR,CASD,YAAAguL,CAAarsL,EAAQS,GACnB,IAAKT,EACH,OAAO,KAET,GAAsB,iBAAXA,EAAqB,CAC9B,MAAM0hD,EAAM1gB,GAAMhhC,GAClB,OAAOlK,KAAK65L,yBAAyBjuI,EAAKjhD,EAC3C,CACD,OAAI2kH,GAAWplH,GACNlK,KAAK65L,yBAClB,EACQlvL,GAGG3K,KAAK85L,uBAAsDnvL,EACnE,CAQD,wBAAAkvL,CAAyBjuI,EAAKjhD,GAC5B,OAAO,IACR,CAQD,oBAAAmvL,CAAqBvoL,EAAM5G,GACzB,OAAO,IACR,CASD,cAAAikE,CAAe1kE,GACb,IAAKA,EACH,OAAO,KAET,GAAsB,iBAAXA,EAAqB,CAC9B,MAAM0hD,EAAM1gB,GAAMhhC,GAClB,OAAOlK,KAAK+5L,2BAA2BnuI,EACxC,CACD,OAAI0jE,GAAWplH,GACNlK,KAAK+5L,2BAAoD,GAE3D/5L,KAAKg6L,uBAA+C,EAC5D,CAOD,0BAAAD,CAA2BnuI,GACzB,OAAO5rD,KAAKotE,cACb,CAOD,sBAAA4sH,CAAuBzoL,GACrB,OAAOvR,KAAKotE,cACb,CASD,YAAAopH,CAAa72I,EAASh1C,GACpB,MAAM4G,EAAOvR,KAAKi6L,iBAAiBt6I,EAASh1C,GAC5C,OAAO3K,KAAK4xH,eAAesoE,kBAAkB3oL,EAC9C,CAQD,gBAAA0oL,CAAiBt6I,EAASh1C,GACxB,OAAO,IACR,CAUD,aAAA8rL,CAActzH,EAAUx4D,GACtB,MAAM4G,EAAOvR,KAAKm6L,kBAAkBh3H,EAAUx4D,GAC9C,OAAO3K,KAAK4xH,eAAesoE,kBAAkB3oL,EAC9C,CAOD,iBAAA4oL,CAAkBh3H,EAAUx4D,GAC1B,OAAO,IACR,CASD,aAAA+rL,CAAc9hL,EAAUjK,GACtB,MAAM4G,EAAOvR,KAAKo6L,kBAAkBxlL,EAAUjK,GAC9C,OAAO3K,KAAK4xH,eAAesoE,kBAAkB3oL,EAC9C,CAOD,iBAAA6oL,CAAkBxlL,EAAUjK,GAC1B,OAAO,IACR,GCxPI,MAAM0vL,GAAQ,6BASfC,GAAqB,QA6C3B,MAAMC,WAAgBC,GAIpB,WAAA16L,CAAY6K,GACV1F,QAEA0F,EAAUA,GAAoB,GAM9B3K,KAAKy6L,YAAc9vL,EAAQ8vL,YAM3Bz6L,KAAK06L,UAAY/vL,EAAQ+vL,UAMzB16L,KAAK26L,QAAUhwL,EAAQgwL,QAMvB36L,KAAK46L,eAAiB,GAKtB56L,KAAK66L,2BAA6B,GAClC76L,KAAK66L,2BAA2B76L,KAAK86L,WAAa,CAChDC,cAAiBnrE,GAAgB5vH,KAAKg7L,sBACtCC,eAAkBprE,GAAa7vH,KAAKg7L,uBAGtCh7L,KAAKk4G,oBAAsB,CAAC,sBAC7B,CAOD,oBAAA8iF,CAAqBzpL,EAAMo+G,GACzB,MAAMI,EAAYx+G,EAAKw+G,UACvB,IAAI5sD,EAAW,KACf,GAAiB,qBAAb4sD,EACF5sD,EAAWuuD,GACT,GACA1xH,KAAK66L,2BACLtpL,EACAo+G,EACA3vH,WAEG,GACQ,kBAAb+vH,GACa,iBAAbA,GACa,UAAbA,EACA,CACA,MAAM5/G,EAAUw/G,EAAY,GAC5B,IAAI8qE,EAActqL,EAAqB,YACnCuqL,EAAYvqL,EAAmB,UACnC,MAAMiwI,EAAS,IACT86C,EAAgB,KACtB,IAAKT,GAAelpL,EAAKO,WAAY,CAClC2oL,EAAc,GAAMC,EAAY,CAAE,EACnC,IAAK,IAAI94L,EAAI,EAAGuE,EAAKoL,EAAKO,WAAW3Q,OAAQS,EAAIuE,IAAMvE,EAAG,CACxD,MAAMkxF,EAAgCvhF,EAAKO,WAAWlQ,GACtD,GAAuB,IAAnBkxF,EAAMk8B,SAAgB,CACxB,MAAM9uG,EAAK4yE,EAAM89B,SAAS/qG,MAAM,KAAK3a,MACrC,IAAKuvL,EAAY/0L,SAASwa,GAAK,CAC7B,IAAI3Y,EAAM,GACNumD,EAAQ,EACZ,MAAM0kD,EAAM1f,EAAM27B,aAClB,IAAK,MAAM5sH,KAAa64L,EAAW,CACjC,GAAIA,EAAU74L,KAAe2wG,EAAK,CAChCjrG,EAAM1F,EACN,KACD,GACCisD,CACH,CACIvmD,IACHA,EAAM64I,EAAStyF,EACf4sI,EAAUnzL,GAAOirG,GAEnBioF,EAAY90L,KAAK4B,EAAM,IAAM2Y,EAC9B,CACF,CACF,CACgB,iBAAb6vG,IAEF5/G,EAAqB,YAAIsqL,EACzBtqL,EAAmB,UAAIuqL,EAE1B,CACD,GAAyB,iBAAdA,EAAwB,CACjC,MAAMS,EAAKT,EACXA,EAAY,CAAA,EACZA,EAAUQ,GAAiBC,CAC5B,CAED,MAAM7pE,EAAY,CAAA,EACZ8pE,EAAe/4L,MAAMC,QAAQm4L,GAC/BA,EACA,CAACA,GACL,IAAK,MAAMrkG,KAAKskG,EAAW,CAEzB,MAAMlpE,EAAU,CAAA,EAChB,IAAK,IAAI5vH,EAAI,EAAGuE,EAAKi1L,EAAaj6L,OAAQS,EAAIuE,IAAMvE,EAAG,EAC/Bw5L,EAAax5L,GAAG8D,SAAS,KAC3C01L,EAAax5L,GAAGikB,MAAM,KAAK,GAC3Bq1K,KACkB9kG,IACpBo7B,EAAQ4pE,EAAax5L,GAAGikB,MAAM,KAAK3a,OACpB,kBAAb6kH,EACIH,GAAgB5vH,KAAKq7L,mBAAoBr7L,MACzC6vH,GAAa7vH,KAAKq7L,mBAAoBr7L,MAE/C,CACDsxH,EAAUopE,EAAUtkG,IAAMo7B,CAC3B,CAECruD,EAAWuuD,GADI,iBAAb3B,GAA6C,UAAbA,OACPvpH,EAEA,GAFW8qH,EAAW//G,EAAMo+G,EAI1D,CAID,OAHiB,OAAbxsD,IACFA,EAAW,IAENA,CACR,CAOD,oBAAAm4H,CAAqB/pL,EAAMo+G,GACzB,MAAMx/G,EAAiCw/G,EAAY,GAInD,OAHAx/G,EAAiB,QAAIoB,EAAKmsG,kBAAkB69E,aAAa,WACzDprL,EAAsB,aACpBoB,EAAKmsG,kBAAkB69E,aAAa,gBAC/B7pE,GACL,KACA1xH,KAAKw7L,iBACLjqL,EACAo+G,EACA3vH,KAEH,CAOD,iBAAAy7L,CAAkBlqL,EAAMo+G,GACtB,MAAMx/G,EAAiCw/G,EAAY,GAC7Cn2G,EACJxZ,KAAKs7L,qBAAqB/pL,EAAMo+G,GAElC,OAAOn2G,EAASu9K,GAA2Bv9K,EAAQrJ,QAAW3J,CAC/D,CAOD,mBAAAk1L,CAAoBnqL,EAAMo+G,GACxB,MAAMx/G,EAAiCw/G,EAAY,GAC7C/6G,EACJ5U,KAAKs7L,qBAAqB/pL,EAAMo+G,GAElC,OAAO/6G,EACH+hL,GAA6B/hL,GAAU,EAAOzE,QAC9C3J,CACL,CAQD,0BAAAm1L,CAA2BpqL,EAAMo+G,EAAaisE,GAC5C,IAAIhY,EACJ,MAAM36K,EAAS,CAAA,EACf,IAAK,IAAItH,EAAI4P,EAAKmsG,kBAAmB/7G,EAAGA,EAAIA,EAAE4vH,mBAAoB,CAChE,IAAIltH,EACJ,MAAM0rH,EAAYpuH,EAAEouH,UAGM,IAAxBpuH,EAAEmQ,WAAW3Q,QACY,IAAxBQ,EAAEmQ,WAAW3Q,SACe,IAA1BQ,EAAE2kD,WAAW0oE,UAA4C,IAA1BrtH,EAAE2kD,WAAW0oE,WAE/C3qH,EAAQuqH,GAAkBjtH,GAAG,GACzB24L,GAAmBjsL,KAAKhK,KAC1BA,OAAQmC,KAGNo1L,IAEFv3L,EACgB,cAAd0rH,EACI/vH,KAAKy7L,kBAAkB95L,EAAGguH,GAC1B3vH,KAAK07L,oBAAoB/5L,EAAGguH,IAE/BtrH,EAGoB,cAAd0rH,IAET6zD,EAAe7zD,GAHf1rH,EAAQrE,KAAK27L,2BAA2Bh6L,EAAGguH,GAAa,IAO5D,MAAM1nH,EAAMtG,EAAEwsH,WAAWhtH,OACzB,GAAI8G,EAAM,KAAO5D,aAAiBqrB,IAAW,CAC3CrrB,EAAQ,CAACw3L,UAAWx3L,GACpB,IAAK,IAAIzC,EAAI,EAAGA,EAAIqG,EAAKrG,IAAK,CAE5ByC,EADgB1C,EAAEwsH,WAAWvsH,GAAG8T,MACf/T,EAAEwsH,WAAWvsH,GAAGyC,KAClC,CACF,CAEG4E,EAAO8mH,IACH9mH,EAAO8mH,aAAsB1tH,QACjC4G,EAAO8mH,GAAa,CAAC9mH,EAAO8mH,KAE9B9mH,EAAO8mH,GAAWpqH,KAAKtB,IAEvB4E,EAAO8mH,GAAa1rH,CAEvB,CACD,IAAKu3L,EACH,OAAO3yL,EAET,MAAM02C,EAAU,IAAIvrC,GAAQnL,GACxB26K,GACFjkI,EAAQ3qC,gBAAgB4uK,GAE1B,MAAMkY,EACJvqL,EAAKgqL,aAAa,QAAUhsE,GAAeh+G,EAAMvR,KAAK86L,UAAW,MAInE,OAHIgB,GACFn8I,EAAQlqC,MAAMqmL,GAETn8I,CACR,CAOD,kBAAA07I,CAAmB9pL,EAAMo+G,GACvB,OAAO3vH,KAAK27L,2BAA2BpqL,EAAMo+G,GAAa,EAC3D,CAOD,SAAAosE,CAAUxqL,EAAMo+G,GACd,MAAM70G,EAAkB9a,KAAKg8L,4BAA4BzqL,EAAMo+G,GAC/D,GAAI70G,EACF,OAAO,IAAI0Y,GAAM1Y,EAAiB,MAErC,CAOD,cAAAmhL,CAAe1qL,EAAMo+G,GAEnB,MAAMp2G,EAAcm4G,GAClB,GACA1xH,KAAKk8L,mBACL3qL,EACAo+G,EACA3vH,MAEF,GAAIuZ,EACF,OAAO,IAAIyhE,GAAWzhE,EAGzB,CAOD,mBAAA4iL,CAAoB5qL,EAAMo+G,GAExB,MAAMv2B,EAAcs4B,GAClB,GACA1xH,KAAKo8L,wBACL7qL,EACAo+G,EACA3vH,MAEF,GAAIo5F,EACF,OAAO,IAAIne,GAAgBme,EAE9B,CAOD,gBAAAijG,CAAiB9qL,EAAMo+G,GAErB,MAAMv1B,EAAWs3B,GACf,GACA1xH,KAAKs8L,qBACL/qL,EACAo+G,EACA3vH,MAEF,GAAIo6F,EACF,OAAO,IAAIlf,GAAakf,EAE3B,CAMD,iBAAAmiG,CAAkBhrL,EAAMo+G,GACtB0B,GAAUrxH,KAAKw8L,oBAAqBjrL,EAAMo+G,EAAa3vH,KACxD,CAMD,sBAAAy8L,CAAuBlrL,EAAMo+G,GAC3B0B,GAAUrxH,KAAK08L,yBAA0BnrL,EAAMo+G,EAAa3vH,KAC7D,CAMD,mBAAA28L,CAAoBprL,EAAMo+G,GACxB0B,GAAUrxH,KAAK48L,sBAAuBrrL,EAAMo+G,EAAa3vH,KAC1D,CAOD,cAAA68L,CAAetrL,EAAMo+G,GACnB,MAAM70G,EAAkB9a,KAAKg8L,4BAA4BzqL,EAAMo+G,GAC/D,GAAI70G,EAAiB,CAEnB,OADmB,IAAI+/D,GAAW//D,EAAiB,MAEpD,CAEF,CAOD,kBAAAgiL,CAAmBvrL,EAAMo+G,GACvB,MAAM2xD,EAAO5vD,GACX,KACA1xH,KAAK+8L,kCACLxrL,EACAo+G,EACA3vH,MAEF,GAAIshL,EACF,OAAOA,CAGV,CAOD,cAAA0b,CAAezrL,EAAMo+G,GACnB,MAAM70G,EAAkB9a,KAAKg8L,4BAA4BzqL,EAAMo+G,GAC/D,GAAI70G,EACF,OAAO,IAAIoY,GAAWpY,EAAiB,MAE1C,CAOD,WAAAmiL,CAAY1rL,EAAMo+G,GAEhB,MAAMutE,EAAkBxrE,GACtB,CAAC,MACD1xH,KAAKm9L,0BACL5rL,EACAo+G,EACA3vH,MAEF,GAAIk9L,GAAmBA,EAAgB,GAAI,CACzC,MAAMpiL,EAAkBoiL,EAAgB,GAClCtsK,EAAO,CAAC9V,EAAgB3Z,QAC9B,IAAIS,EAAGuE,EACP,IAAKvE,EAAI,EAAGuE,EAAK+2L,EAAgB/7L,OAAQS,EAAIuE,IAAMvE,EACjDM,EAAO4Y,EAAiBoiL,EAAgBt7L,IACxCgvB,EAAKjrB,KAAKmV,EAAgB3Z,QAE5B,OAAO,IAAI80B,GAAQnb,EAAiB,MAAO8V,EAC5C,CAEF,CAOD,2BAAAorK,CAA4BzqL,EAAMo+G,GAChC,OAAO+B,GACL,KACA1xH,KAAK+8L,kCACLxrL,EACAo+G,EACA3vH,KAEH,CAQD,oBAAA85L,CAAqBvoL,EAAM5G,GACzB,MAAMiK,EAAW5U,KAAK07L,oBAAoBnqL,EAAM,CAC9CvR,KAAKo2L,eAAe7kL,EAAM5G,GAAoB,CAAA,KAEhD,OAAOiK,GAAsB,IAC9B,CAOD,oBAAA+kL,CAAqBpoL,EAAM5G,GACzB,MAAMyyL,EAAkB,CACtB3C,YAAaz6L,KAAKy6L,YAClBC,UAAW16L,KAAK06L,WAEd0C,GACF12L,OAAO8C,OAAO4zL,EAAiBp9L,KAAKo2L,eAAe7kL,EAAM5G,IAG3D,OADiB3K,KAAKg7L,qBAAqBzpL,EAAM,CAAC6rL,KAC/B,EACpB,CAMD,sBAAApD,CAAuBzoL,GACrB,OAAOqd,GACL5uB,KAAK26L,QACD36L,KAAK26L,QACLppL,EAAKmsG,kBAAkB69E,aAAa,WAE3C,EAGHhB,GAAQ12L,UAAUi3L,UAAYT,GAM9BE,GAAQ12L,UAAUs5L,0BAA4B,CAC5C,6BAA8B,CAAE,GAOlC5C,GAAQ12L,UAAUk5L,kCAAoC,CACpD,6BAA8B,CAAE,GAOlCxC,GAAQ12L,UAAU23L,iBAAmB,CACnC,6BAA8B,CAAE,GAOlCjB,GAAQ12L,UAAUq4L,mBAAqB,CACrC,6BAA8B,CAC5BmB,YAAeztE,GAAgB2qE,GAAQ12L,UAAU04L,mBACjDe,aAAgB1tE,GAAgB2qE,GAAQ12L,UAAU04L,qBAQtDhC,GAAQ12L,UAAUu4L,wBAA0B,CAC1C,6BAA8B,CAC5BmB,iBAAoB3tE,GAClB2qE,GAAQ12L,UAAU44L,wBAEpBe,kBAAqB5tE,GACnB2qE,GAAQ12L,UAAU44L,0BASxBlC,GAAQ12L,UAAUy4L,qBAAuB,CACvC,6BAA8B,CAC5BmB,cAAiB7tE,GAAgB2qE,GAAQ12L,UAAU84L,qBACnDe,eAAkB9tE,GAAgB2qE,GAAQ12L,UAAU84L,uBAQxDpC,GAAQ12L,UAAU24L,oBAAsB,CACtC,6BAA8B,CAC5BhpK,MAASo8F,GAAgB2qE,GAAQ12L,UAAUm4L,+BAQ/CzB,GAAQ12L,UAAU64L,yBAA2B,CAC3C,6BAA8B,CAC5B7hH,WAAc+0C,GAAgB2qE,GAAQ12L,UAAUg5L,kBAQpDtC,GAAQ12L,UAAU+4L,sBAAwB,CACxC,6BAA8B,CAC5B3mK,QAAW25F,GAAgB2qE,GAAQ12L,UAAUo5L,eAQjD1C,GAAQ12L,UAAU85L,aAAe,CAC/B,6BAA8B,CAC5BzqK,WAAc28F,GAAa0qE,GAAQ12L,UAAUi5L,sBAIjD,IAAAc,GAAerD,GClqBR,SAASsD,GAAYtsL,GAE1B,OAAOusL,GADGlvE,GAAkBr9G,GAAM,GAEpC,CAMO,SAASusL,GAAkB5nD,GAChC,MAAM/1H,EAAI,6BAA6BwqB,KAAKurG,GAC5C,GAAI/1H,EACF,YAAgB3Z,IAAT2Z,EAAE,KAAoB,CAGjC,CAMO,SAAS49K,GAAaxsL,GAC3B,MAAMw4B,EAAI6kF,GAAkBr9G,GAAM,GAC5BysL,EAAWjgK,KAAKmN,MAAMnB,GAC5B,OAAOvb,MAAMwvK,QAAYx3L,EAAYw3L,EAAW,GAClD,CAMO,SAASC,GAAY1sL,GAE1B,OAAO2sL,GADGtvE,GAAkBr9G,GAAM,GAEpC,CAMO,SAAS2sL,GAAkBhoD,GAEhC,MAAM/1H,EAAI,4CAA4CwqB,KAAKurG,GAC3D,GAAI/1H,EACF,OAAO4qB,WAAW5qB,EAAE,GAGxB,CAMO,SAASg+K,GAAoB5sL,GAElC,OAAO6sL,GADGxvE,GAAkBr9G,GAAM,GAEpC,CAMO,SAAS6sL,GAA6BloD,GAC3C,MAAM/1H,EAAI,gBAAgBwqB,KAAKurG,GAC/B,GAAI/1H,EACF,OAAO1P,SAAS0P,EAAE,GAAI,GAG1B,CAMO,SAASk+K,GAAW9sL,GACzB,OAAOq9G,GAAkBr9G,GAAM,GAAOs5B,MACxC,CAMO,SAASyzJ,GAAqB/sL,EAAMgtL,GACzCC,GAAoBjtL,EAAMgtL,EAAO,IAAM,IACzC,CAMO,SAASE,GAAkBltL,EAAM2kI,GACtC3kI,EAAKW,YAAYy8G,KAAc+vE,mBAAmBxoD,GACpD,CAMO,SAASyoD,GAAsBptL,EAAMysL,GAC1C,MAAMY,EAAO,IAAI7gK,KAAgB,IAAXigK,GAChB9nD,EACJ0oD,EAAKC,iBACL,IACAz5K,GAAUw5K,EAAKE,cAAgB,EAAG,GAClC,IACA15K,GAAUw5K,EAAKG,aAAc,GAC7B,IACA35K,GAAUw5K,EAAKI,cAAe,GAC9B,IACA55K,GAAUw5K,EAAKK,gBAAiB,GAChC,IACA75K,GAAUw5K,EAAKM,gBAAiB,GAChC,IACF3tL,EAAKW,YAAYy8G,KAAcl7D,eAAeyiF,GAChD,CAMO,SAASipD,GAAqB5tL,EAAMiU,GACzC,MAAM0wH,EAAS1wH,EAAQ45K,cACvB7tL,EAAKW,YAAYy8G,KAAcl7D,eAAeyiF,GAChD,CAMO,SAASmpD,GAAgC9tL,EAAM+tL,GACpD,MAAMppD,EAASopD,EAAmB1mL,WAClCrH,EAAKW,YAAYy8G,KAAcl7D,eAAeyiF,GAChD,CAMO,SAASsoD,GAAoBjtL,EAAM2kI,GACxC3kI,EAAKW,YAAYy8G,KAAcl7D,eAAeyiF,GAChD,CC3HA,MAAM0kD,GACJP,GAAQ,oDAMJkF,GAAmC,CACvCtkH,gBAAmB,mBACnBukH,WAAc,cACdtkH,aAAgB,gBAChBukH,aAAgB,iBAUlB,MAAMC,WAAanF,GAIjB,WAAAz6L,CAAY6K,GAGV1F,MAFA0F,EAAUA,GAAoB,IAI9B3K,KAAK66L,2BAA2BR,IAAsB,cAAIzqE,GACxD5vH,KAAKg7L,sBAMPh7L,KAAK46L,eAAiBjwL,EAAQiwL,eAC1BjwL,EAAQiwL,eACRA,EACL,CAOD,mBAAA+E,CAAoBpuL,EAAMo+G,GACxB,MAAM5lF,EAAI6kF,GAAkBr9G,GAAM,GAAOiS,QAAQ,aAAc,IAIzDo8K,EAFJjwE,EAAY,GAEwB,QACtC,IAAIhvG,EAAkB,MACtB,GAAIi/K,EAAc,CAChB,MAAM9xG,EAAOl/D,GAAcgxK,GACvB9xG,IACFntE,EAAkBmtE,EAAKtsE,qBAE1B,CACD,MAAMq+K,EAAe91J,EAAEc,OAAOhlB,MAAM,OAC9B/K,EAAkB,GACxB,IAAK,IAAIlZ,EAAI,EAAGuE,EAAK05L,EAAa1+L,OAAQS,EAAIuE,EAAIvE,IAAK,CACrD,MAAMu3B,EAAS0mK,EAAaj+L,GAAGikB,MAAM,MAC/BxO,EAAI0zB,WAAW5R,EAAO,IACtB7hB,EAAIyzB,WAAW5R,EAAO,IACtBoG,EAAsB,IAAlBpG,EAAOh4B,OAAe4pC,WAAW5R,EAAO,IAAM,EACnB,OAAjCxY,EAAgB21F,OAAO,EAAG,GAC5Bx7F,EAAgBnV,KAAK0R,EAAGC,EAAGioB,GAE3BzkB,EAAgBnV,KAAK2R,EAAGD,EAAGkoB,EAE9B,CACD,OAAOzkB,CACR,CAOD,OAAAglL,CAAQvuL,EAAMo+G,GAEZ,MAAM70G,EAAkB42G,GACtB,CAAC,MACD1xH,KAAK+/L,aACLxuL,EACAo+G,EACA3vH,MAEF,OAAO0a,GACLI,EAAgB,GAAG,GACnBA,EAAgB,GAAG,GACnBA,EAAgB,GAAG,GACnBA,EAAgB,GAAG,GAEtB,CAMD,qBAAAklL,CAAsBzuL,EAAMo+G,GAE1B,MAAMswE,EAAiBvuE,QACrBlrH,EACAxG,KAAK29L,aACLpsL,EACAo+G,EACA3vH,MAEF,GAAIigM,EAAgB,CAGftwE,EAAYA,EAAYxuH,OAAS,GACpBwE,KAAKs6L,EACtB,CACF,CAMD,qBAAAC,CAAsB3uL,EAAMo+G,GAE1B,MAAMswE,EAAiBvuE,QACrBlrH,EACAxG,KAAK29L,aACLpsL,EACAo+G,EACA3vH,MAEF,GAAIigM,EAAgB,CAGftwE,EAAYA,EAAYxuH,OAAS,GACpB,GAAK8+L,CACtB,CACF,CAUD,sBAAAE,CAAuB97L,EAAOsrH,EAAaiB,GACzC,MAAMzgH,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3Ci/L,EAAejwL,EAAsB,aACrCkwL,EAAUlwL,EAAiB,QAC3BmwL,EAAanwL,EAAoB,WAevC,OAdK9N,MAAMC,QAAQ+B,GAYjBusH,EAAW,WARM,kBAHjBA,EAAgE,EAE9DliG,aACkD,IAAjB0xK,EACjCxvE,EAAW,eACW,YAAbA,IAAsC,IAAZyvE,EACnCzvE,EAAW,UACW,oBAAbA,IAAiD,IAAf0vE,IAC3C1vE,EAAW,cAKRpC,GAAgB,6BAA8BoC,EACtD,CAOD,mBAAA2vE,CAAoBhvL,EAAMouC,EAASgwE,GACjC,MAAMmsE,EAAMn8I,EAAQtqC,QAChBymL,GACFvqL,EAAK4/C,aAAa,MAA8B,GAElD,MAAMhhD,EAAiCw/G,EAAYA,EAAYxuH,OAAS,GAClEu5L,EAAYvqL,EAAmB,UAC/ByzK,EAAejkI,EAAQ1qC,kBACxB9E,EAAQmgH,cACXngH,EAAQmgH,YAAc,GACtBngH,EAAQmgH,YAAYoqE,GAAa,IAEnC,MAAM/zL,EAAO,GACPsC,EAAS,GACf,GAAI02C,EAAQj2C,gBAAiB,CAC3B,MAAMoL,EAAa6qC,EAAQp2C,gBAC3B,IAAK,MAAMhC,KAAOuN,EAAY,CAC5B,MAAMzQ,EAAQyQ,EAAWvN,GACX,OAAVlD,IACFsC,EAAKhB,KAAK4B,GACV0B,EAAOtD,KAAKtB,GAEVkD,GAAOq8K,GAEL,mBADuB,EAA6B,sBAGhDr8K,KAAO4I,EAAQmgH,YAAYoqE,KAC/BvqL,EAAQmgH,YAAYoqE,GAAWnzL,GAAO0oH,GACpCjwH,KAAKwgM,qBACLxgM,OAIEuH,KAAO4I,EAAQmgH,YAAYoqE,KAC/BvqL,EAAQmgH,YAAYoqE,GAAWnzL,GAC7B0oH,GAAkBuuE,KAI3B,CACF,CACD,MAAMlzL,EAAO5E,OAAO8C,OAAO,CAAE,EAAE2G,GAC/B7E,EAAKiG,KAAOA,EACZogH,GAEJ,EACMxhH,EAAQmgH,YACRC,QAAsB/pH,EAAWk0L,GACjCzxL,EACA0mH,EACAhpH,EAEH,CAOD,sBAAA85L,CAAuBlvL,EAAMqD,EAAU+6G,GACrC,MACMgrE,EADUhrE,EAAYA,EAAYxuH,OAAS,GAChB,QAIjC,GAHsB,sBAAlBoQ,EAAKq/G,UAAoC+pE,GAC3CppL,EAAK4/C,aAAa,UAAWwpI,GAGX,eAAlBppL,EAAKq/G,UACa,sBAAlBr/G,EAAKq/G,SACL,CACA,MAAMr3G,EAAcvZ,KAAK0gM,uBAAuBnvL,EAAKk9G,cACrDl9G,EAAKW,YAAYqH,GACjBvZ,KAAK2gM,kBAAkBpnL,EAAa3E,EAAU+6G,EACpD,MAAW,GAAsB,UAAlBp+G,EAAKq/G,SAAsB,CACpC,MAAM44D,EAAWh7D,GAAgBj9G,EAAKk9G,aAAc,YACpDl9G,EAAKW,YAAYs3K,GACjBxpL,KAAK4gM,oBAAoBpX,EAAU50K,EAAU+6G,EAC9C,CACF,CAOD,4BAAAkxE,CAA6BtvL,EAAM41J,EAAMx3C,GACvC,MAAM78B,EAAQ9yF,KAAKmgM,uBAAuBh5B,EAAMx3C,GAC5C78B,IACFvhF,EAAKW,YAAY4gF,GACjB9yF,KAAKygM,uBAAuB3tG,EAAOq0E,EAAMx3C,GAE5C,CAOD,2BAAAmxE,CAA4BvvL,EAAMqD,EAAU+6G,GAC1C,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3Ck3L,EAAOloL,EAAc,KACrBwqL,EAAUxqL,EAAiB,QAC3B4wL,EAAQ5wL,EAAe,MACzBwqL,GACFppL,EAAK4/C,aAAa,UAAWwpI,GAE/B,MAAM12E,EAAQrvG,EAAS4kF,iBACvBm4B,GACE,CAACpgH,KAAMA,EAAM8mL,KAAMA,EAAMsC,QAASA,EAASoG,MAAOA,GAClD/gM,KAAKghM,oCACLhhM,KAAKihM,mCACLh9E,EACA0L,OACAnpH,EACAxG,KAEH,CAOD,oBAAAwgM,CAAqBjvL,EAAMqD,EAAU+6G,GACnC,MAAMx/G,EACJw/G,EAAYA,EAAYxuH,OAAS,GAE7BmK,EAAO5E,OAAO8C,OAAO,CAAE,EAAE2G,GAE/B,IAAI9L,EADJiH,EAAW,KAAIiG,EAGblN,EADEhC,MAAMC,QAAQsS,GACRmiL,GACd,EACQ5mL,GAGMwmL,GACd,GACQ,EACAxmL,GAGJwhH,GAEJ,EACM3xH,KAAKkhM,qBACLlhM,KAAKmgM,uBACL,CAAC97L,GACDsrH,OACAnpH,EACAxG,KAEH,CAOD,sBAAA0gM,CAAuBjyE,GACrB,MAAMl1G,EAAci1G,GAAgBC,EAAc,eAKlD,OAJAl1G,EAAY43C,aAAa,UAAW,KACpC53C,EAAY43C,aAAa,KAAM,KAC/B53C,EAAY43C,aAAa,KAAM,KAExB53C,CACR,CAQD,iBAAAonL,CAAkBpvL,EAAMlN,EAAOsrH,GAC7B,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3Ck3L,EAAOloL,EAAc,KACrBwqL,EAAUxqL,EAAiB,QAE3B4pF,EAAS11F,EAAMsrB,iBACf1nB,EAAM8xF,EAAO54F,OACbopC,EAAQ,IAAIloC,MAAM4F,GACxB,IAAK,IAAIrG,EAAI,EAAGA,EAAIqG,IAAOrG,EAAG,CAC5B,MAAMghB,EAAQm3E,EAAOn4F,GACrB2oC,EAAM3oC,GAAK5B,KAAKmhM,WAAWv+K,EAAO+3K,EAAStC,EAC5C,CACDmG,GAAoBjtL,EAAMg5B,EAAMzxB,KAAK,KACtC,CAQD,mBAAA8nL,CAAoBrvL,EAAM41J,EAAMx3C,GAC9B,MAAM78B,EAAQ07B,GAAgBj9G,EAAKk9G,aAAc,qBACjDl9G,EAAKW,YAAY4gF,GACjB9yF,KAAKygM,uBAAuB3tG,EAAOq0E,EAAMx3C,EAC1C,CAOD,qBAAAyxE,CAAsB7vL,EAAMqD,EAAU+6G,GACpC,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3Ck3L,EAAOloL,EAAc,KACrBwqL,EAAUxqL,EAAiB,QAIjC,GAHsB,iBAAlBoB,EAAKq/G,UAA+B+pE,GACtCppL,EAAK4/C,aAAa,UAAWwpI,GAET,YAAlBppL,EAAKq/G,UAA4C,iBAAlBr/G,EAAKq/G,SAA6B,CACnE,MAAMp1G,EAAQ5G,EAASqiB,iBACvB06F,GACE,CAACpgH,KAAMA,EAAM8mL,KAAMA,EAAMsC,QAASA,GAClC36L,KAAKqhM,iBACLrhM,KAAKshM,mBACL9lL,EACAm0G,OACAnpH,EACAxG,KAER,MAAW,GAAsB,YAAlBuR,EAAKq/G,SAAwB,CACtC,MAAM2wE,EAAU/yE,GAAgBj9G,EAAKk9G,aAAc,WACnDl9G,EAAKW,YAAYqvL,GACjBvhM,KAAKwhM,qBAAqBD,EAAS3sL,EAAU+6G,EAC9C,CACF,CASD,kBAAA2xE,CAAmBj9L,EAAOsrH,EAAaiB,GACrC,MAAMzgH,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3CiQ,EAAajB,EAAQoB,KACrBkwL,EAAkBtxL,EAAyB,gBAIjD,YAHwB3J,IAApBi7L,IACFtxL,EAAyB,iBAAI,GAExBq+G,GACLp9G,EAAWq9G,kBACSjoH,IAApBi7L,EAAgC,kBAAoB,kBAEvD,CAQD,oBAAAD,CAAqBjwL,EAAMilB,EAASm5F,GAClC,MAAM78B,EAAQ07B,GAAgBj9G,EAAKk9G,aAAc,gBACjDl9G,EAAKW,YAAY4gF,GACjB9yF,KAAKohM,sBAAsBtuG,EAAOt8D,EAASm5F,EAC5C,CAOD,SAAA+xE,CAAUnwL,EAAM+vK,EAAM3xD,GACpB,MAAM78F,EAAa07F,GAAgBj9G,EAAKk9G,aAAc,cACtDl9G,EAAKW,YAAY4gB,GACjB9yB,KAAK2hM,gBAAgB7uK,EAAYwuJ,EAAM3xD,EACxC,CASD,UAAAwxE,CAAWv+K,EAAO+3K,EAAStC,GACzB,IAAI13K,EAAkB,MAClBg6K,IACFh6K,EAAkBiO,GAAc+rK,GAASn5K,sBAE3C,IAAI2X,EAC+B,OAAjCxY,EAAgB21F,OAAO,EAAG,GACtB1zF,EAAM,GAAK,IAAMA,EAAM,GACvBA,EAAM,GAAK,IAAMA,EAAM,GAC7B,GAAIy1K,EAAM,CAGRl/J,GAAU,KADAvW,EAAM,IAAM,EAEvB,CAED,OAAOuW,CACR,CAOD,UAAAyoK,CAAWrwL,EAAMqD,EAAU+6G,GACzB,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3Ck3L,EAAOloL,EAAc,KACrBwqL,EAAUxqL,EAAiB,QAC7BwqL,GACFppL,EAAK4/C,aAAa,UAAWwpI,GAE/B,MAAMphL,EAAcvZ,KAAK0gM,uBAAuBnvL,EAAKk9G,cACrDl9G,EAAKW,YAAYqH,GACjB,MAAMqJ,EAAQhO,EAAS+a,iBAEvB6uK,GAAoBjlL,EADNvZ,KAAKmhM,WAAWv+K,EAAO+3K,EAAStC,GAE/C,CAOD,eAAAwJ,CAAgBtwL,EAAMqD,EAAU+6G,GAC9B,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3Ck3L,EAAOloL,EAAc,KACrBwqL,EAAUxqL,EAAiB,QAC7BwqL,GACFppL,EAAK4/C,aAAa,UAAWwpI,GAE/B,MAAM5gG,EAASnlF,EAASklF,YACxB63B,GACE,CAACpgH,KAAMA,EAAM8mL,KAAMA,EAAMsC,QAASA,GAClC36L,KAAK8hM,wBACLvxE,GAAsB,eACtBx2B,EACA41B,OACAnpH,EACAxG,KAEH,CAOD,gBAAA+hM,CAAiBxwL,EAAMqR,EAAO+sG,GAC5B,MAAM78B,EAAQ07B,GAAgBj9G,EAAKk9G,aAAc,SACjDl9G,EAAKW,YAAY4gF,GACjB9yF,KAAK4hM,WAAW9uG,EAAOlwE,EAAO+sG,EAC/B,CAOD,eAAAgyE,CAAgBpwL,EAAMqD,EAAU+6G,GAC9B,MACMgrE,EADUhrE,EAAYA,EAAYxuH,OAAS,GAChB,QAC7Bw5L,GACFppL,EAAK4/C,aAAa,UAAWwpI,GAE/B,MAAMphL,EAAcvZ,KAAK0gM,uBAAuBnvL,EAAKk9G,cACrDl9G,EAAKW,YAAYqH,GACjBvZ,KAAK2gM,kBAAkBpnL,EAAa3E,EAAU+6G,EAC/C,CAOD,0BAAAqyE,CAA2BzwL,EAAMqD,EAAU+6G,GACzC,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3Ck3L,EAAOloL,EAAc,KACrBwqL,EAAUxqL,EAAiB,QAC3BkwL,EAAUlwL,EAAiB,QAC7BwqL,GACFppL,EAAK4/C,aAAa,UAAWwpI,GAE/B,MAAMvgG,EAAWxlF,EAASkmF,cAC1B62B,GACE,CAACpgH,KAAMA,EAAM8mL,KAAMA,EAAMsC,QAASA,EAAS0F,QAASA,GACpDrgM,KAAKiiM,mCACLjiM,KAAKihM,mCACL7mG,EACAu1B,OACAnpH,EACAxG,KAEH,CAOD,2BAAAkiM,CAA4B3wL,EAAMilB,EAASm5F,GACzC,MAAM78B,EAAQ9yF,KAAKmgM,uBAAuB3pK,EAASm5F,GAC/C78B,IACFvhF,EAAKW,YAAY4gF,GACjB9yF,KAAKohM,sBAAsBtuG,EAAOt8D,EAASm5F,GAE9C,CAOD,aAAAwyE,CAAc5wL,EAAMiI,EAAQm2G,GAC1B,MACMgrE,EADUhrE,EAAYA,EAAYxuH,OAAS,GAChB,QAC7Bw5L,GACFppL,EAAK4/C,aAAa,UAAWwpI,GAE/B,MACM1xL,EAAS,CAACuQ,EAAO,GAAK,IAAMA,EAAO,GAAIA,EAAO,GAAK,IAAMA,EAAO,IACtEm4G,GAEJ,CAAQpgH,KAAMA,GACRvR,KAAKoiM,qBACLvxE,GACA5nH,EACA0mH,EARW,CAAC,cAAe,eAU3B3vH,KAEH,CAUD,kCAAAihM,CAAmC58L,EAAOsrH,EAAaiB,GACrD,MAAMx/G,EAAau+G,EAAYA,EAAYxuH,OAAS,GAAGoQ,KACvD,OAAOi9G,GACL,6BACA+wE,GAAiCnuL,EAAWw/G,UAE/C,EAOH8uE,GAAK77L,UAAUk5L,kCAAoC,CACjD,6BAA8B,CAC5BxjL,YAAes2G,GAAa6vE,GAAK77L,UAAU87L,uBAQ/CD,GAAK77L,UAAUs5L,0BAA4B,CACzC,6BAA8B,CAC5BkF,gBAAmB3C,GAAK77L,UAAUm8L,sBAClCsC,gBAAmB5C,GAAK77L,UAAUq8L,wBAQtCR,GAAK77L,UAAUk8L,aAAe,CAC5B,6BAA8B,CAC5BxmL,YAAeq2G,GAAgB8vE,GAAK77L,UAAU87L,uBAQlDD,GAAK77L,UAAU23L,iBAAmB,CAChC,6BAA8B,CAC5BhoK,MAASq8F,GAAa0qE,GAAQ12L,UAAUk4L,WACxC/gH,WAAc60C,GAAa0qE,GAAQ12L,UAAUo4L,gBAC7CphH,WAAcg1C,GAAa0qE,GAAQ12L,UAAUg5L,gBAC7C5hH,gBAAmB40C,GAAa0qE,GAAQ12L,UAAUs4L,qBAClDjpK,WAAc28F,GAAa0qE,GAAQ12L,UAAUm5L,gBAC7C/mK,QAAW45F,GAAa0qE,GAAQ12L,UAAUo5L,aAC1C/hH,aAAgB20C,GAAa0qE,GAAQ12L,UAAUw4L,kBAC/CkG,IAAO1yE,GAAa6vE,GAAK77L,UAAUi8L,WAQvCJ,GAAK77L,UAAUq9L,qBAAuB,CACpC,6BAA8B,CAC5BsB,MAASvyE,GAAkByvE,GAAK77L,UAAU48L,wBAC1CjB,WAAcvvE,GAAkByvE,GAAK77L,UAAUi9L,6BAC/CttK,MAASy8F,GAAkByvE,GAAK77L,UAAU+9L,YAC1C5mH,WAAci1C,GAAkByvE,GAAK77L,UAAUg+L,iBAC/ChnH,WAAco1C,GAAkByvE,GAAK77L,UAAU48L,wBAC/CxlH,gBAAmBg1C,GACjByvE,GAAK77L,UAAUi9L,6BAEjB5tK,WAAc+8F,GAAkByvE,GAAK77L,UAAU89L,iBAC/C1rK,QAAWg6F,GAAkByvE,GAAK77L,UAAUu9L,uBAC5ClmH,aAAgB+0C,GACdyvE,GAAK77L,UAAUm+L,4BAEjBS,QAAWxyE,GAAkByvE,GAAK77L,UAAUu9L,uBAC5C3B,aAAgBxvE,GACdyvE,GAAK77L,UAAUm+L,4BAEjBU,SAAYzyE,GAAkByvE,GAAK77L,UAAUs+L,iBAOjDzC,GAAK77L,UAAUm9L,oCAAsC,CACnD,6BAA8B,CAC5BzD,iBAAoBttE,GAClByvE,GAAK77L,UAAUg9L,8BAEjB8B,YAAe1yE,GACbyvE,GAAK77L,UAAUg9L,gCAQrBnB,GAAK77L,UAAUw9L,iBAAmB,CAChC,6BAA8B,CAC5BiB,gBAAmBryE,GAAkByvE,GAAK77L,UAAU69L,WACpDW,gBAAmBpyE,GAAkByvE,GAAK77L,UAAU69L,aAOxDhC,GAAK77L,UAAUi+L,wBAA0B,CACvC,6BAA8B,CAC5BzE,YAAeptE,GAAkByvE,GAAK77L,UAAUk+L,oBAQpDrC,GAAK77L,UAAUo+L,mCAAqC,CAClD,6BAA8B,CAC5BW,cAAiB3yE,GACfyvE,GAAK77L,UAAUq+L,6BAEjBzE,cAAiBxtE,GACfyvE,GAAK77L,UAAUq+L,+BAQrBxC,GAAK77L,UAAUu+L,qBAAuB,CACpC,6BAA8B,CAC5BS,YAAe5yE,GAAkBuuE,IACjCsE,YAAe7yE,GAAkBuuE,MAIrC,IAAAuE,GAAerD,GC1uBf,MAAM9E,GACJP,iFAQIkF,GAAmC,CACvCtkH,gBAAmB,mBACnBukH,WAAc,cACdtkH,aAAgB,gBAChBukH,aAAgB,iBAWlB,MAAMuD,WAAazI,GAIjB,WAAAz6L,CAAY6K,GAGV1F,MAFA0F,EAAUA,GAAoB,IAQ9B3K,KAAKijM,cAA+Bz8L,IAApBmE,EAAQ01L,SAAwB11L,EAAQ01L,QAMxDrgM,KAAKkjM,YAA2B18L,IAAlBmE,EAAQo2L,OAAsBp2L,EAAQo2L,MAMpD/gM,KAAKmjM,iBACoB38L,IAAvBmE,EAAQ21L,YAA2B31L,EAAQ21L,WAM7CtgM,KAAKojM,mBACsB58L,IAAzBmE,EAAQy1L,cAA6Bz1L,EAAQy1L,aAK/CpgM,KAAK46L,eAAiBjwL,EAAQiwL,eAC1BjwL,EAAQiwL,eACRA,GAMJ56L,KAAKq4L,UAAwB7xL,IAAjBmE,EAAQ0tL,MAAqB1tL,EAAQ0tL,IAClD,CAOD,cAAAgL,CAAe9xL,EAAMo+G,GAEnB,MAAMv2B,EAAcs4B,GAClB,GACA1xH,KAAKsjM,mBACL/xL,EACAo+G,EACA3vH,MAEF,GAAIo5F,EAAa,CAEf,OADwB,IAAIne,GAAgBme,EAE7C,CAEF,CAOD,iBAAAmqG,CAAkBhyL,EAAMo+G,GAEtB,MAAMv2B,EAAcs4B,GAClB,GACA1xH,KAAKsjM,mBACL/xL,EACAo+G,EACA3vH,MAEI8a,EAAkB,GACxB,IAAK,IAAIlZ,EAAI,EAAGuE,EAAKizF,EAAYj4F,OAAQS,EAAIuE,IAAMvE,EACjDM,EAAO4Y,EAAiBs+E,EAAYx3F,GAAG2tB,sBAEzC,OAAOzU,CACR,CAOD,gBAAA0oL,CAAiBjyL,EAAMo+G,GAErB,MAAMv1B,EAAWs3B,GACf,GACA1xH,KAAKyjM,qBACLlyL,EACAo+G,EACA3vH,MAEF,GAAIo6F,EACF,OAAO,IAAIlf,GAAakf,EAE3B,CAMD,iBAAAspG,CAAkBnyL,EAAMo+G,GACtB0B,GAAUrxH,KAAK2jM,oBAAqBpyL,EAAMo+G,EAAa3vH,KACxD,CAMD,mBAAA4jM,CAAoBryL,EAAMo+G,GACxB0B,GAAUrxH,KAAK6jM,sBAAuBtyL,EAAMo+G,EAAa3vH,KAC1D,CAOD,SAAA8jM,CAAUvyL,EAAMo+G,GACd,OAAO+B,GACL,CAAC,MACD1xH,KAAK+jM,gBACLxyL,EACAo+G,EACA3vH,KAEH,CAOD,WAAAgkM,CAAYzyL,EAAMo+G,GAChB,OAAO+B,GAAgB,GAAI1xH,KAAKikM,iBAAkB1yL,EAAMo+G,EAAa3vH,KACtE,CAOD,gBAAAkkM,CAAiB3yL,EAAMo+G,GACrB,OAAO+B,GACL,CAAC,MACD1xH,KAAKm9L,0BACL5rL,EACAo+G,EACA3vH,KAEH,CAOD,qBAAAmkM,CAAsB5yL,EAAMo+G,GAC1B,OAAO+B,GACL,CAAC,MACD1xH,KAAK+8L,kCACLxrL,EACAo+G,EACA3vH,KAEH,CAMD,cAAAokM,CAAe7yL,EAAMo+G,GAEnB,MAAMswE,EAAiBvuE,QACrBlrH,EACAxG,KAAK29L,aACLpsL,EACAo+G,EACA3vH,MAEF,GAAIigM,EAAgB,CAGftwE,EAAYA,EAAYxuH,OAAS,GACpBwE,KAAKs6L,EACtB,CACF,CAMD,cAAAoE,CAAe9yL,EAAMo+G,GAEnB,MAAMswE,EAAiBvuE,QACrBlrH,EACAxG,KAAK29L,aACLpsL,EACAo+G,EACA3vH,MAEF,GAAIigM,EAAgB,CAGftwE,EAAYA,EAAYxuH,OAAS,GACpB,GAAK8+L,CACtB,CACF,CAOD,WAAAqE,CAAY/yL,EAAMo+G,GAEhB,MAAMutE,EAAkBxrE,GACtB,CAAC,MACD1xH,KAAKukM,gBACLhzL,EACAo+G,EACA3vH,MAEF,GAAIk9L,GAAmBA,EAAgB,GAAI,CACzC,MAAMpiL,EAAkBoiL,EAAgB,GAClCtsK,EAAO,CAAC9V,EAAgB3Z,QAC9B,IAAIS,EAAGuE,EACP,IAAKvE,EAAI,EAAGuE,EAAK+2L,EAAgB/7L,OAAQS,EAAIuE,IAAMvE,EACjDM,EAAO4Y,EAAiBoiL,EAAgBt7L,IACxCgvB,EAAKjrB,KAAKmV,EAAgB3Z,QAE5B,OAAO,IAAI80B,GAAQnb,EAAiB,MAAO8V,EAC5C,CAEF,CAOD,SAAA4zK,CAAUjzL,EAAMo+G,GAEd,MAAM70G,EAAkB42G,GACtB,CAAC,MACD1xH,KAAKykM,cACLlzL,EACAo+G,EACA3vH,MAEF,GAAI8a,EAAiB,CAEnB,OADmB,IAAI+/D,GAAW//D,EAAiB,MAEpD,CAEF,CAOD,YAAA4pL,CAAanzL,EAAMo+G,GAEjB,MAAM70G,EAAkB42G,GACtB,CAAC,MACD1xH,KAAK2kM,iBACLpzL,EACAo+G,EACA3vH,MAEF,OAAO0a,GACLI,EAAgB,GAAG,GACnBA,EAAgB,GAAG,GACnBA,EAAgB,GAAG,GACnBA,EAAgB,GAAG,GAEtB,CAOD,WAAA8pL,CAAYrzL,EAAMo+G,GAChB,IAAI5lF,EAAI6kF,GAAkBr9G,GAAM,GAChC,MAAMszL,EAAK,6CAEL/pL,EAAkB,GACxB,IAAIqF,EACJ,KAAQA,EAAI0kL,EAAGl6J,KAAKZ,IAClBjvB,EAAgBnV,KAAKolC,WAAW5qB,EAAE,KAClC4pB,EAAIA,EAAEusE,OAAOn2F,EAAE,GAAGhf,QAEpB,GAAU,KAAN4oC,EACF,OAEF,MACM61J,EADUjwE,EAAY,GACU,QACtC,IAAIhvG,EAAkB,MACtB,GAAIi/K,EAAc,CAEhBj/K,EADaiO,GAAcgxK,GACJp+K,oBACxB,CACD,GAAwB,QAApBb,EAA2B,CAC7B,IAAI/e,EAAGuE,EACP,IAAKvE,EAAI,EAAGuE,EAAK2U,EAAgB3Z,OAAQS,EAAIuE,EAAIvE,GAAK,EAAG,CACvD,MAAM0V,EAAIwD,EAAgBlZ,GACpByV,EAAIyD,EAAgBlZ,EAAI,GAC9BkZ,EAAgBlZ,GAAKyV,EACrByD,EAAgBlZ,EAAI,GAAK0V,CAC1B,CACF,CACD,MAAMrP,EAAM6S,EAAgB3Z,OAI5B,OAHW,GAAP8G,GACF6S,EAAgBnV,KAAK,GAEX,IAARsC,EAGG6S,OAHP,CAID,CAOD,eAAAgqL,CAAgBvzL,EAAMo+G,GACpB,MAAM5lF,EAAI6kF,GAAkBr9G,GAAM,GAAOiS,QAAQ,aAAc,IACzDrT,EAAUw/G,EAAY,GACtBiwE,EAAezvL,EAAiB,QAChC40L,EAAmB50L,EAAsB,aAC/C,IAAIwQ,EAAkB,MACtB,GAAIi/K,EAAc,CAEhBj/K,EADaiO,GAAcgxK,GACJp+K,oBACxB,CACD,MAAM2X,EAAS4Q,EAAElkB,MAAM,OAEvB,IAcIxO,EAAGC,EAAGioB,EAdNqhG,EAAM,EACNrvH,EAAKgqL,aAAa,gBACpB36D,EAAMw9D,GAA6B7sL,EAAKgqL,aAAa,iBAC5ChqL,EAAKgqL,aAAa,aAC3B36D,EAAMw9D,GAA6B7sL,EAAKgqL,aAAa,cAE7BhqL,EAAe,WAAEgqL,aAAa,gBAEtD36D,EAAMw9D,GACoB7sL,EAAe,WAAEgqL,aAAa,iBAE/CwJ,IACTnkE,EAAMw9D,GAA6B2G,IAGrC,MAAMjqL,EAAkB,GACxB,IAAK,IAAIlZ,EAAI,EAAGuE,EAAKgzB,EAAOh4B,OAAQS,EAAIuE,EAAIvE,GAAKg/H,EAC/CvpH,EAAI0zB,WAAW5R,EAAOv3B,IACtB0V,EAAIyzB,WAAW5R,EAAOv3B,EAAI,IAC1B29B,EAAY,IAARqhG,EAAY71F,WAAW5R,EAAOv3B,EAAI,IAAM,EACP,OAAjC+e,EAAgB21F,OAAO,EAAG,GAC5Bx7F,EAAgBnV,KAAK0R,EAAGC,EAAGioB,GAE3BzkB,EAAgBnV,KAAK2R,EAAGD,EAAGkoB,GAG/B,OAAOzkB,CACR,CAQD,SAAAkqL,CAAUzzL,EAAMlN,EAAOsrH,GACrB,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3Ck3L,EAAOloL,EAAc,KACrB80L,EAAe5M,EAAO,IAAM,IAClC9mL,EAAK4/C,aAAa,eAAgB8zI,GAClC,MAAMtK,EAAUxqL,EAAiB,QACjC,IAAIwQ,EAAkB,MAClBg6K,IACFh6K,EAAkBiO,GAAc+rK,GAASn5K,sBAE3C,MAAMoB,EAAQve,EAAMsrB,iBACpB,IAAIwJ,EAOJ,GAJEA,EADmC,OAAjCxY,EAAgB21F,OAAO,EAAG,GACnB1zF,EAAM,GAAK,IAAMA,EAAM,GAEvBA,EAAM,GAAK,IAAMA,EAAM,GAE9By1K,EAAM,CAGRl/J,GAAU,KADAvW,EAAM,IAAM,EAEvB,CACD47K,GAAoBjtL,EAAM4nB,EAC3B,CASD,UAAAgoK,CAAWv+K,EAAO+3K,EAAStC,GACzB,IAAI13K,EAAkB,MAClBg6K,IACFh6K,EAAkBiO,GAAc+rK,GAASn5K,sBAE3C,IAAI2X,EAC+B,OAAjCxY,EAAgB21F,OAAO,EAAG,GACtB1zF,EAAM,GAAK,IAAMA,EAAM,GACvBA,EAAM,GAAK,IAAMA,EAAM,GAC7B,GAAIy1K,EAAM,CAGRl/J,GAAU,KADAvW,EAAM,IAAM,EAEvB,CAED,OAAOuW,CACR,CAQD,aAAA+rK,CAAc3zL,EAAMlN,EAAOsrH,GACzB,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3Ck3L,EAAOloL,EAAc,KACrB80L,EAAe5M,EAAO,IAAM,IAClC9mL,EAAK4/C,aAAa,eAAgB8zI,GAClC,MAAMtK,EAAUxqL,EAAiB,QAE3B4pF,EAAS11F,EAAMsrB,iBACf1nB,EAAM8xF,EAAO54F,OACbopC,EAAQ,IAAIloC,MAAM4F,GACxB,IAAI2a,EACJ,IAAK,IAAIhhB,EAAI,EAAGA,EAAIqG,IAAOrG,EACzBghB,EAAQm3E,EAAOn4F,GACf2oC,EAAM3oC,GAAK5B,KAAKmhM,WAAWv+K,EAAO+3K,EAAStC,GAE7CmG,GAAoBjtL,EAAMg5B,EAAMzxB,KAAK,KACtC,CAOD,UAAA8oL,CAAWrwL,EAAMqD,EAAU+6G,GACzB,MACMgrE,EADUhrE,EAAYA,EAAYxuH,OAAS,GAChB,QAC7Bw5L,GACFppL,EAAK4/C,aAAa,UAAWwpI,GAE/B,MAAMzyI,EAAMsmE,GAAgBj9G,EAAKk9G,aAAc,OAC/Cl9G,EAAKW,YAAYg2C,GACjBloD,KAAKglM,UAAU98I,EAAKtzC,EAAU+6G,EAC/B,CAOD,aAAAwyE,CAAc5wL,EAAMiI,EAAQm2G,GAC1B,MACMgrE,EADUhrE,EAAYA,EAAYxuH,OAAS,GAChB,QAC7Bw5L,GACFppL,EAAK4/C,aAAa,UAAWwpI,GAE/B,MACM1xL,EAAS,CAACuQ,EAAO,GAAK,IAAMA,EAAO,GAAIA,EAAO,GAAK,IAAMA,EAAO,IACtEm4G,GAEJ,CAAQpgH,KAAMA,GACRvR,KAAKoiM,qBACLvxE,GACA5nH,EACA0mH,EARW,CAAC,cAAe,eAU3B3vH,KAEH,CAOD,eAAA2hM,CAAgBpwL,EAAMqD,EAAU+6G,GAC9B,MACMgrE,EADUhrE,EAAYA,EAAYxuH,OAAS,GAChB,QAC7Bw5L,GACFppL,EAAK4/C,aAAa,UAAWwpI,GAE/B,MAAMwK,EAAU32E,GAAgBj9G,EAAKk9G,aAAc,WACnDl9G,EAAKW,YAAYizL,GACjBnlM,KAAKklM,cAAcC,EAASvwL,EAAU+6G,EACvC,CASD,kBAAA2xE,CAAmBj9L,EAAOsrH,EAAaiB,GACrC,MAAMzgH,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3CiQ,EAAajB,EAAQoB,KACrBkwL,EAAkBtxL,EAAyB,gBAIjD,YAHwB3J,IAApBi7L,IACFtxL,EAAyB,iBAAI,GAExBq+G,GACLp9G,EAAWq9G,kBACSjoH,IAApBi7L,EAAgC,WAAa,WAEhD,CAOD,qBAAAL,CAAsB7vL,EAAMqD,EAAU+6G,GACpC,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3Ck3L,EAAOloL,EAAc,KACrBwqL,EAAUxqL,EAAiB,QAIjC,GAHsB,iBAAlBoB,EAAKq/G,UAA+B+pE,GACtCppL,EAAK4/C,aAAa,UAAWwpI,GAET,YAAlBppL,EAAKq/G,UAA4C,iBAAlBr/G,EAAKq/G,SAA6B,CACnE,MAAMp1G,EAAQ5G,EAASqiB,iBACvB06F,GACE,CAACpgH,KAAMA,EAAM8mL,KAAMA,EAAMsC,QAASA,GAClC36L,KAAKqhM,iBACLrhM,KAAKshM,mBACL9lL,EACAm0G,OACAnpH,EACAxG,KAER,MAAW,GAAsB,YAAlBuR,EAAKq/G,SAAwB,CACtC,MAAM2wE,EAAU/yE,GAAgBj9G,EAAKk9G,aAAc,WACnDl9G,EAAKW,YAAYqvL,GACjBvhM,KAAKwhM,qBAAqBD,EAAS3sL,EAAU+6G,EAC9C,CACF,CAOD,sBAAA8wE,CAAuBlvL,EAAMqD,EAAU+6G,GACrC,MACMgrE,EADUhrE,EAAYA,EAAYxuH,OAAS,GAChB,QAIjC,GAHsB,sBAAlBoQ,EAAKq/G,UAAoC+pE,GAC3CppL,EAAK4/C,aAAa,UAAWwpI,GAGX,eAAlBppL,EAAKq/G,UACa,sBAAlBr/G,EAAKq/G,SACL,CACA,MAAMu0E,EAAU32E,GAAgBj9G,EAAKk9G,aAAc,WACnDl9G,EAAKW,YAAYizL,GACjBnlM,KAAKklM,cAAcC,EAASvwL,EAAU+6G,EAC5C,MAAW,GAAsB,UAAlBp+G,EAAKq/G,SAAsB,CACpC,MAAM44D,EAAWh7D,GAAgBj9G,EAAKk9G,aAAc,YACpDl9G,EAAKW,YAAYs3K,GACjBxpL,KAAK4gM,oBAAoBpX,EAAU50K,EAAU+6G,EAC9C,CACF,CAOD,0BAAAqyE,CAA2BzwL,EAAMqD,EAAU+6G,GACzC,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3Ck3L,EAAOloL,EAAc,KACrBwqL,EAAUxqL,EAAiB,QAC3BkwL,EAAUlwL,EAAiB,QAC7BwqL,GACFppL,EAAK4/C,aAAa,UAAWwpI,GAE/B,MAAMvgG,EAAWxlF,EAASkmF,cAC1B62B,GACE,CAACpgH,KAAMA,EAAM8mL,KAAMA,EAAMsC,QAASA,EAAS0F,QAASA,GACpDrgM,KAAKiiM,mCACLjiM,KAAKihM,mCACL7mG,EACAu1B,OACAnpH,EACAxG,KAEH,CAOD,eAAA6hM,CAAgBtwL,EAAMqD,EAAU+6G,GAC9B,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3Cw5L,EAAUxqL,EAAiB,QAC3BkoL,EAAOloL,EAAc,KACvBwqL,GACFppL,EAAK4/C,aAAa,UAAWwpI,GAE/B,MAAM5gG,EAASnlF,EAASklF,YACxB63B,GACE,CAACpgH,KAAMA,EAAM8mL,KAAMA,EAAMsC,QAASA,GAClC36L,KAAK8hM,wBACLvxE,GAAsB,eACtBx2B,EACA41B,OACAnpH,EACAxG,KAEH,CAOD,2BAAA8gM,CAA4BvvL,EAAMqD,EAAU+6G,GAC1C,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3Ck3L,EAAOloL,EAAc,KACrBwqL,EAAUxqL,EAAiB,QAC3B4wL,EAAQ5wL,EAAe,MACzBwqL,GACFppL,EAAK4/C,aAAa,UAAWwpI,GAE/B,MAAM12E,EAAQrvG,EAAS4kF,iBACvBm4B,GACE,CAACpgH,KAAMA,EAAM8mL,KAAMA,EAAMsC,QAASA,EAASoG,MAAOA,GAClD/gM,KAAKghM,oCACLhhM,KAAKihM,mCACLh9E,EACA0L,OACAnpH,EACAxG,KAEH,CAOD,SAAA0hM,CAAUnwL,EAAM+vK,EAAM3xD,GACpB,MAAM78F,EAAa07F,GAAgBj9G,EAAKk9G,aAAc,cACtDl9G,EAAKW,YAAY4gB,GACjB9yB,KAAK2hM,gBAAgB7uK,EAAYwuJ,EAAM3xD,EACxC,CAOD,2BAAAuyE,CAA4B3wL,EAAMilB,EAASm5F,GACzC,MAAM78B,EAAQ9yF,KAAKmgM,uBAAuB3pK,EAASm5F,GAC/C78B,IACFvhF,EAAKW,YAAY4gF,GACjB9yF,KAAKohM,sBAAsBtuG,EAAOt8D,EAASm5F,GAE9C,CAOD,gBAAAoyE,CAAiBxwL,EAAMqR,EAAO+sG,GAC5B,MAAM78B,EAAQ07B,GAAgBj9G,EAAKk9G,aAAc,SACjDl9G,EAAKW,YAAY4gF,GACjB9yF,KAAK4hM,WAAW9uG,EAAOlwE,EAAO+sG,EAC/B,CAOD,4BAAAkxE,CAA6BtvL,EAAM41J,EAAMx3C,GACvC,MAAM78B,EAAQ9yF,KAAKmgM,uBAAuBh5B,EAAMx3C,GAC5C78B,IACFvhF,EAAKW,YAAY4gF,GACjB9yF,KAAKygM,uBAAuB3tG,EAAOq0E,EAAMx3C,GAE5C,CAQD,oBAAA6xE,CAAqBjwL,EAAMilB,EAASm5F,GAClC,MAAM78B,EAAQ07B,GAAgBj9G,EAAKk9G,aAAc,gBACjDl9G,EAAKW,YAAY4gF,GACjB9yF,KAAKohM,sBAAsBtuG,EAAOt8D,EAASm5F,EAC5C,CAQD,mBAAAixE,CAAoBrvL,EAAM41J,EAAMx3C,GAC9B,MAAM78B,EAAQ07B,GAAgBj9G,EAAKk9G,aAAc,qBACjDl9G,EAAKW,YAAY4gF,GACjB9yF,KAAKygM,uBAAuB3tG,EAAOq0E,EAAMx3C,EAC1C,CAOD,oBAAA6wE,CAAqBjvL,EAAMqD,EAAU+6G,GACnC,MAAMx/G,EACJw/G,EAAYA,EAAYxuH,OAAS,GAE7BmK,EAAO5E,OAAO8C,OAAO,CAAE,EAAE2G,GAE/B,IAAI9L,EADJiH,EAAW,KAAIiG,EAGblN,EADEhC,MAAMC,QAAQsS,GACRmiL,GACd,EACQ5mL,GAGMwmL,GACd,GACQ,EACAxmL,GAGJwhH,GAEJ,EACM3xH,KAAKkhM,qBACLlhM,KAAKmgM,uBACL,CAAC97L,GACDsrH,OACAnpH,EACAxG,KAEH,CAOD,mBAAAugM,CAAoBhvL,EAAMouC,EAASgwE,GACjC,MAAMmsE,EAAMn8I,EAAQtqC,QAChBymL,GACFvqL,EAAK4/C,aAAa,MAA8B,GAElD,MAAMhhD,EAAiCw/G,EAAYA,EAAYxuH,OAAS,GAClEu5L,EAAYvqL,EAAmB,UAC/ByzK,EAAejkI,EAAQ1qC,kBACxB9E,EAAQmgH,cACXngH,EAAQmgH,YAAc,GACtBngH,EAAQmgH,YAAYoqE,GAAa,IAEnC,MAAM/zL,EAAO,GACPsC,EAAS,GACf,GAAI02C,EAAQj2C,gBAAiB,CAC3B,MAAMoL,EAAa6qC,EAAQp2C,gBAC3B,IAAK,MAAMhC,KAAOuN,EAAY,CAC5B,MAAMzQ,EAAQyQ,EAAWvN,GACX,OAAVlD,IACFsC,EAAKhB,KAAK4B,GACV0B,EAAOtD,KAAKtB,GAEVkD,GAAOq8K,GAEL,mBADuB,EAA6B,sBAGhDr8K,KAAO4I,EAAQmgH,YAAYoqE,KAC/BvqL,EAAQmgH,YAAYoqE,GAAWnzL,GAAO0oH,GACpCjwH,KAAKwgM,qBACLxgM,OAIEuH,KAAO4I,EAAQmgH,YAAYoqE,KAC/BvqL,EAAQmgH,YAAYoqE,GAAWnzL,GAC7B0oH,GAAkBuuE,KAI3B,CACF,CACD,MAAMlzL,EAAO5E,OAAO8C,OAAO,CAAE,EAAE2G,GAC/B7E,EAAKiG,KAAOA,EACZogH,GAEJ,EACMxhH,EAAQmgH,YACRC,QAAsB/pH,EAAWk0L,GACjCzxL,EACA0mH,EACAhpH,EAEH,CAQD,oBAAAy+L,CAAqB7zL,EAAM4xD,EAAUwsD,GACnC,MAAMx/G,EAAiCw/G,EAAYA,EAAYxuH,OAAS,GAClEs5L,EAActqL,EAAqB,YACnCuqL,EAAYvqL,EAAmB,UAE/BmgH,EAAc,CAAA,EACpBA,EAAYoqE,GAAa,GACzBpqE,EAAYoqE,GAAWD,GAAexqE,GACpCjwH,KAAKugM,oBACLvgM,MAEF,MAAMsL,EAAO5E,OAAO8C,OAAO,CAAE,EAAE2G,GAC/B7E,EAAKiG,KAAOA,EACZogH,GAEJ,EACMrB,EACAC,GAAsBkqE,EAAaC,GACnCv3H,EACAwsD,EAEH,CAUD,kCAAAsxE,CAAmC58L,EAAOsrH,EAAaiB,GACrD,MAAMx/G,EAAau+G,EAAYA,EAAYxuH,OAAS,GAAGoQ,KACvD,OAAOi9G,GACLxuH,KAAK86L,UACLyE,GAAiCnuL,EAAWw/G,UAE/C,CAUD,sBAAAuvE,CAAuB97L,EAAOsrH,EAAaiB,GACzC,MAAMzgH,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3Ci/L,EAAejwL,EAAsB,aACrCkwL,EAAUlwL,EAAiB,QAC3B4wL,EAAQ5wL,EAAe,MACvBmwL,EAAanwL,EAAoB,WAiBvC,OAhBK9N,MAAMC,QAAQ+B,GAcjBusH,EAAW,WAVM,kBAHjBA,EAAgE,EAE9DliG,aACkD,IAAjB0xK,EACjCxvE,EAAW,eACW,YAAbA,IAAsC,IAAZyvE,EACnCzvE,EAAW,UACW,eAAbA,IAAuC,IAAVmwE,EACtCnwE,EAAW,QACW,oBAAbA,IAAiD,IAAf0vE,IAC3C1vE,EAAW,cAKRpC,GAAgBxuH,KAAK86L,UAAWlqE,EACxC,CAUD,iBAAAwpE,CAAkBxlL,EAAUjK,GAC1BA,EAAU3K,KAAKq2L,aAAa1rL,GAC5B,MAAMkuK,EAAOrqD,GAAgBxuH,KAAK86L,UAAW,QACvC3qL,EAAU,CACdoB,KAAMsnK,EACNwf,KAAMr4L,KAAKq4L,KACXsC,QAAS36L,KAAK26L,QACdoG,MAAO/gM,KAAKkjM,OACZ7C,QAASrgM,KAAKijM,SACd7C,aAAcpgM,KAAKojM,cACnB9C,WAAYtgM,KAAKmjM,aAMnB,OAJIx4L,GACFjE,OAAO8C,OAAO2G,EAASxF,GAEzB3K,KAAKwgM,qBAAqB3nB,EAAMjkK,EAAU,CAACzE,IACpC0oK,CACR,CAUD,iBAAAshB,CAAkBh3H,EAAUx4D,GAC1BA,EAAU3K,KAAKq2L,aAAa1rL,GAC5B,MAAM4G,EAAOi9G,GAAgBxuH,KAAK86L,UAAW,kBAC7CvpL,EAAK8zL,eACH92E,GACA,qBACAvuH,KAAK46L,gBAEP,MAAMzqL,EAAU,CACdwqL,QAAS36L,KAAK26L,QACdtC,KAAMr4L,KAAKq4L,KACX0I,MAAO/gM,KAAKkjM,OACZ7C,QAASrgM,KAAKijM,SACd7C,aAAcpgM,KAAKojM,cACnB9C,WAAYtgM,KAAKmjM,YACjBzI,UAAW16L,KAAK06L,UAChBD,YAAaz6L,KAAKy6L,aAMpB,OAJI9vL,GACFjE,OAAO8C,OAAO2G,EAASxF,GAEzB3K,KAAKolM,qBAAqB7zL,EAAM4xD,EAAU,CAAChzD,IACpCoB,CACR,EAOHyxL,GAAKn/L,UAAUk5L,kCAAoC,CACjD,6BAA8B,CAC5B70I,IAAO2nE,GAAamzE,GAAKn/L,UAAU+gM,aACnCO,QAAWt1E,GAAamzE,GAAKn/L,UAAUihM,iBACvCvrL,YAAes2G,GAAa6vE,GAAK77L,UAAU87L,uBAQ/CqD,GAAKn/L,UAAUs5L,0BAA4B,CACzC,6BAA8B,CAC5BmI,SAAYtC,GAAKn/L,UAAUugM,eAC3BmB,SAAYvC,GAAKn/L,UAAUwgM,iBAQ/BrB,GAAKn/L,UAAU23L,iBAAmB,CAChC,6BAA8B,CAC5BhoK,MAASq8F,GAAa0qE,GAAQ12L,UAAUk4L,WACxC/gH,WAAc60C,GAAa0qE,GAAQ12L,UAAUo4L,gBAC7CphH,WAAcg1C,GAAa0qE,GAAQ12L,UAAUg5L,gBAC7C5hH,gBAAmB40C,GAAa0qE,GAAQ12L,UAAUs4L,qBAClDjpK,WAAc28F,GAAa0qE,GAAQ12L,UAAUm5L,gBAC7C/mK,QAAW45F,GAAa0qE,GAAQ12L,UAAUo5L,aAC1C/hH,aAAgB20C,GAAa0qE,GAAQ12L,UAAUw4L,kBAC/CoG,QAAW5yE,GAAamzE,GAAKn/L,UAAUygM,aACvC7E,aAAgB5vE,GAAamzE,GAAKn/L,UAAU2/L,kBAC5ChB,MAAS3yE,GAAamzE,GAAKn/L,UAAU2gM,WACrChF,WAAc3vE,GAAamzE,GAAKn/L,UAAUw/L,gBAC1CX,SAAY7yE,GAAamzE,GAAKn/L,UAAU6gM,gBAQ5C1B,GAAKn/L,UAAUy/L,mBAAqB,CAClC,6BAA8B,CAC5BX,YAAe/yE,GAAgBozE,GAAKn/L,UAAU6/L,mBAC9C8B,aAAgB51E,GAAgBozE,GAAKn/L,UAAU6/L,qBAQnDV,GAAKn/L,UAAU4/L,qBAAuB,CACpC,6BAA8B,CAC5Bb,cAAiBhzE,GAAgBozE,GAAKn/L,UAAU+/L,qBAChD6B,eAAkB71E,GAAgBozE,GAAKn/L,UAAU+/L,uBAQrDZ,GAAKn/L,UAAU8/L,oBAAsB,CACnC,6BAA8B,CAC5B9oH,WAAc+0C,GAAgB2qE,GAAQ12L,UAAUg5L,gBAChD2F,MAAS5yE,GAAgBozE,GAAKn/L,UAAU2gM,aAQ5CxB,GAAKn/L,UAAUggM,sBAAwB,CACrC,6BAA8B,CAC5B5tK,QAAW25F,GAAgB2qE,GAAQ12L,UAAUo5L,aAC7CwF,QAAW7yE,GAAgBozE,GAAKn/L,UAAUygM,eAQ9CtB,GAAKn/L,UAAU0gM,gBAAkB,CAC/B,6BAA8B,CAC5BhD,QAAW1xE,GAAamzE,GAAKn/L,UAAUigM,aAQ3Cd,GAAKn/L,UAAU4gM,cAAgB,CAC7B,6BAA8B,CAC5Bjb,SAAY35D,GAAamzE,GAAKn/L,UAAUmgM,eAQ5ChB,GAAKn/L,UAAU8gM,iBAAmB,CAChC,6BAA8B,CAC5B9B,YAAejzE,GAAgBozE,GAAKn/L,UAAUihM,iBAC9ChC,YAAelzE,GAAgBozE,GAAKn/L,UAAUihM,mBAQlD9B,GAAKn/L,UAAUkgM,gBAAkB,CAC/B,6BAA8B,CAC5B2B,aAAgB71E,GAAamzE,GAAKn/L,UAAUqgM,oBAQhDlB,GAAKn/L,UAAUogM,iBAAmB,CAChC,6BAA8B,CAC5B0B,kBAAqBl2E,GACnBuzE,GAAKn/L,UAAUsgM,yBASrB5J,GAAQ12L,UAAU85L,aAAe,CAC/B,6BAA8B,CAC5BzqK,WAAc28F,GAAa0qE,GAAQ12L,UAAUi5L,oBAC7C8I,KAAQ/1E,GAAamzE,GAAKn/L,UAAU0/L,qBAaxCP,GAAKn/L,UAAU4yL,cAKfuM,GAAKn/L,UAAUw9L,iBAAmB,CAChC,6BAA8B,CAC5BkE,SAAYt1E,GAAkB+yE,GAAKn/L,UAAU69L,WAC7C4D,SAAYr1E,GAAkB+yE,GAAKn/L,UAAU69L,aAOjDsB,GAAKn/L,UAAUu+L,qBAAuB,CACpC,6BAA8B,CAC5BS,YAAe5yE,GAAkBuuE,IACjCsE,YAAe7yE,GAAkBuuE,MAOrCwE,GAAKn/L,UAAUo+L,mCAAqC,CAClD,6BAA8B,CAC5BW,cAAiB3yE,GACf+yE,GAAKn/L,UAAUq+L,6BAEjBzE,cAAiBxtE,GACf+yE,GAAKn/L,UAAUq+L,+BAQrBc,GAAKn/L,UAAUi+L,wBAA0B,CACvC,6BAA8B,CAC5BzE,YAAeptE,GAAkB+yE,GAAKn/L,UAAUk+L,oBAOpDiB,GAAKn/L,UAAUm9L,oCAAsC,CACnD,6BAA8B,CAC5BzD,iBAAoBttE,GAClB+yE,GAAKn/L,UAAUg9L,8BAEjB8B,YAAe1yE,GACb+yE,GAAKn/L,UAAUg9L,gCAQrBmC,GAAKn/L,UAAUq9L,qBAAuB,CACpC,6BAA8B,CAC5BsB,MAASvyE,GAAkB+yE,GAAKn/L,UAAU48L,wBAC1CjB,WAAcvvE,GAAkB+yE,GAAKn/L,UAAUi9L,6BAC/CttK,MAASy8F,GAAkB+yE,GAAKn/L,UAAU+9L,YAC1C5mH,WAAci1C,GAAkB+yE,GAAKn/L,UAAUg+L,iBAC/ChnH,WAAco1C,GAAkB+yE,GAAKn/L,UAAU48L,wBAC/CxlH,gBAAmBg1C,GACjB+yE,GAAKn/L,UAAUi9L,6BAEjB5tK,WAAc+8F,GAAkB+yE,GAAKn/L,UAAU89L,iBAC/C1rK,QAAWg6F,GAAkB+yE,GAAKn/L,UAAUu9L,uBAC5ClmH,aAAgB+0C,GACd+yE,GAAKn/L,UAAUm+L,4BAEjBS,QAAWxyE,GAAkB+yE,GAAKn/L,UAAUu9L,uBAC5C3B,aAAgBxvE,GACd+yE,GAAKn/L,UAAUm+L,4BAEjBU,SAAYzyE,GAAkB+yE,GAAKn/L,UAAUs+L,iBAIjD,IAAA0D,GAAe7C,GCnvCf,MAAM8C,GAAM9C,GAWZ8C,GAAIjiM,UAAU4yL,cAWdqP,GAAIjiM,UAAUs2L,kBAEd,IAAA4L,GAAeD,GCpBf,MAAME,WAAchD,GAIlB,WAAAljM,CAAY6K,GAGV1F,MAFA0F,EAAUA,GAAoB,IAO9B3K,KAAK46L,eAAiBjwL,EAAQiwL,eAC1BjwL,EAAQiwL,eACR56L,KAAK86L,UAAY,+CACtB,CAOD,oBAAA0F,CAAqBjvL,EAAMqD,EAAU+6G,GACnC,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GACjDwuH,EAAYA,EAAYxuH,OAAS,GAAKuF,OAAO8C,OAC3C,CAAC82L,YAAY,EAAMF,cAAc,GACjCjwL,GAEFlL,MAAMu7L,qBAAqBjvL,EAAMqD,EAAU+6G,EAC5C,EAGHq2E,GAAMniM,UAAUi3L,UAAY,iCAM5BkL,GAAMniM,UAAUk5L,kCAAoC,CAClD,iCAAkC,CAChC70I,IAAO2nE,GAAamzE,GAAKn/L,UAAU+gM,aACnCO,QAAWt1E,GAAamzE,GAAKn/L,UAAUihM,iBACvCvrL,YAAes2G,GAAa6vE,GAAK77L,UAAU87L,uBAQ/CqG,GAAMniM,UAAUs5L,0BAA4B,CAC1C,iCAAkC,CAChCmI,SAAYtC,GAAKn/L,UAAUugM,eAC3BmB,SAAYvC,GAAKn/L,UAAUwgM,iBAQ/B2B,GAAMniM,UAAU23L,iBAAmB,CACjC,iCAAkC,CAChChoK,MAASq8F,GAAa0qE,GAAQ12L,UAAUk4L,WACxC/gH,WAAc60C,GAAa0qE,GAAQ12L,UAAUo4L,gBAC7CphH,WAAcg1C,GAAa0qE,GAAQ12L,UAAUg5L,gBAC7C5hH,gBAAmB40C,GAAa0qE,GAAQ12L,UAAUs4L,qBAClDjpK,WAAc28F,GAAa0qE,GAAQ12L,UAAUm5L,gBAC7C/mK,QAAW45F,GAAa0qE,GAAQ12L,UAAUo5L,aAC1C/hH,aAAgB20C,GAAa0qE,GAAQ12L,UAAUw4L,kBAC/CoG,QAAW5yE,GAAam2E,GAAMniM,UAAUygM,aACxC7E,aAAgB5vE,GAAamzE,GAAKn/L,UAAU2/L,kBAC5ChB,MAAS3yE,GAAam2E,GAAMniM,UAAU2gM,WACtChF,WAAc3vE,GAAamzE,GAAKn/L,UAAUw/L,gBAC1CX,SAAY7yE,GAAam2E,GAAMniM,UAAU6gM,gBAQ7CsB,GAAMniM,UAAUy/L,mBAAqB,CACnC,iCAAkC,CAChCX,YAAe/yE,GAAgBozE,GAAKn/L,UAAU6/L,mBAC9C8B,aAAgB51E,GAAgBozE,GAAKn/L,UAAU6/L,qBAQnDsC,GAAMniM,UAAU4/L,qBAAuB,CACrC,iCAAkC,CAChCb,cAAiBhzE,GAAgBozE,GAAKn/L,UAAU+/L,qBAChD6B,eAAkB71E,GAAgBozE,GAAKn/L,UAAU+/L,uBAQrDoC,GAAMniM,UAAU8/L,oBAAsB,CACpC,iCAAkC,CAChC9oH,WAAc+0C,GAAgB2qE,GAAQ12L,UAAUg5L,gBAChD2F,MAAS5yE,GAAgBozE,GAAKn/L,UAAU2gM,aAQ5CwB,GAAMniM,UAAUggM,sBAAwB,CACtC,iCAAkC,CAChC5tK,QAAW25F,GAAgB2qE,GAAQ12L,UAAUo5L,aAC7CwF,QAAW7yE,GAAgBozE,GAAKn/L,UAAUygM,eAQ9C0B,GAAMniM,UAAU0gM,gBAAkB,CAChC,iCAAkC,CAChChD,QAAW1xE,GAAamzE,GAAKn/L,UAAUigM,aAQ3CkC,GAAMniM,UAAU4gM,cAAgB,CAC9B,iCAAkC,CAChCjb,SAAY35D,GAAamzE,GAAKn/L,UAAUmgM,eAQ5CgC,GAAMniM,UAAU8gM,iBAAmB,CACjC,iCAAkC,CAChC9B,YAAejzE,GAAgBozE,GAAKn/L,UAAUihM,iBAC9ChC,YAAelzE,GAAgBozE,GAAKn/L,UAAUihM,mBAQlDkB,GAAMniM,UAAUkgM,gBAAkB,CAChC,iCAAkC,CAChC2B,aAAgB71E,GAAamzE,GAAKn/L,UAAUqgM,oBAQhD8B,GAAMniM,UAAUogM,iBAAmB,CACjC,iCAAkC,CAChC0B,kBAAqBl2E,GACnBuzE,GAAKn/L,UAAUsgM,yBASrB6B,GAAMniM,UAAUq4L,mBAAqB,CACnC,iCAAkC,CAChCmB,YAAeztE,GAAgB2qE,GAAQ12L,UAAU04L,mBACjDe,aAAgB1tE,GAAgB2qE,GAAQ12L,UAAU04L,qBAQtDyJ,GAAMniM,UAAUu4L,wBAA0B,CACxC,iCAAkC,CAChCmB,iBAAoB3tE,GAClB2qE,GAAQ12L,UAAU44L,wBAEpBe,kBAAqB5tE,GACnB2qE,GAAQ12L,UAAU44L,0BASxBuJ,GAAMniM,UAAUy4L,qBAAuB,CACrC,iCAAkC,CAChCmB,cAAiB7tE,GAAgB2qE,GAAQ12L,UAAU84L,qBACnDe,eAAkB9tE,GAAgB2qE,GAAQ12L,UAAU84L,uBAQxDqJ,GAAMniM,UAAU24L,oBAAsB,CACpC,iCAAkC,CAChChpK,MAASo8F,GAAgB2qE,GAAQ12L,UAAUm4L,+BAQ/CgK,GAAMniM,UAAU64L,yBAA2B,CACzC,iCAAkC,CAChC7hH,WAAc+0C,GAAgB2qE,GAAQ12L,UAAUg5L,kBAQpDmJ,GAAMniM,UAAU+4L,sBAAwB,CACtC,iCAAkC,CAChC3mK,QAAW25F,GAAgB2qE,GAAQ12L,UAAUo5L,eAQjD+I,GAAMniM,UAAU85L,aAAe,CAC7B,iCAAkC,CAChCzqK,WAAc28F,GAAa0qE,GAAQ12L,UAAUi5L,oBAC7C8I,KAAQ/1E,GAAam2E,GAAMniM,UAAU0/L,qBAOzCyC,GAAMniM,UAAUw9L,iBAAmB,CACjC,iCAAkC,CAChCkE,SAAYt1E,GAAkB+yE,GAAKn/L,UAAU69L,WAC7C4D,SAAYr1E,GAAkB+yE,GAAKn/L,UAAU69L,aAOjDsE,GAAMniM,UAAUu+L,qBAAuB,CACrC,iCAAkC,CAChCS,YAAe5yE,GAAkBuuE,IACjCsE,YAAe7yE,GAAkBuuE,MAOrCwH,GAAMniM,UAAUo+L,mCAAqC,CACnD,iCAAkC,CAChCW,cAAiB3yE,GACf+yE,GAAKn/L,UAAUq+L,6BAEjBzE,cAAiBxtE,GACf+yE,GAAKn/L,UAAUq+L,+BAQrB8D,GAAMniM,UAAUi+L,wBAA0B,CACxC,iCAAkC,CAChCzE,YAAeptE,GAAkB+yE,GAAKn/L,UAAUk+L,oBAOpDiE,GAAMniM,UAAUm9L,oCAAsC,CACpD,iCAAkC,CAChCzD,iBAAoBttE,GAClB+yE,GAAKn/L,UAAUg9L,8BAEjB8B,YAAe1yE,GACb+yE,GAAKn/L,UAAUg9L,gCAQrBmF,GAAMniM,UAAUq9L,qBAAuB,CACrC,iCAAkC,CAChCsB,MAASvyE,GAAkB+yE,GAAKn/L,UAAU48L,wBAC1CjB,WAAcvvE,GAAkB+yE,GAAKn/L,UAAUi9L,6BAC/CttK,MAASy8F,GAAkB+1E,GAAMniM,UAAU+9L,YAC3C5mH,WAAci1C,GAAkB+yE,GAAKn/L,UAAUg+L,iBAC/ChnH,WAAco1C,GAAkB+yE,GAAKn/L,UAAU48L,wBAC/CxlH,gBAAmBg1C,GACjB+yE,GAAKn/L,UAAUi9L,6BAEjB5tK,WAAc+8F,GAAkB+yE,GAAKn/L,UAAU89L,iBAC/C1rK,QAAWg6F,GAAkB+yE,GAAKn/L,UAAUu9L,uBAC5ClmH,aAAgB+0C,GACd+yE,GAAKn/L,UAAUm+L,4BAEjBS,QAAWxyE,GAAkB+yE,GAAKn/L,UAAUu9L,uBAC5C3B,aAAgBxvE,GACd+yE,GAAKn/L,UAAUm+L,4BAEjBU,SAAYzyE,GAAkB+yE,GAAKn/L,UAAUs+L,iBAIjD,IAAA8D,GAAeD,GC3Tf,MAAME,GAAiB,CACrB,KACA,oCACA,qCAeIC,GAAiB,CACrBC,IAAOC,GACPC,IAAOC,GACPC,IAAOC,IAQHC,GAAcz1E,GAAgBi1E,GAAgB,CAClDE,IAAOx2E,GAAgBy2E,IACvBC,IAAO12E,GAAgB22E,IACvBC,IAAO52E,GAAgB62E,MAQnBE,GAAe11E,GAAgBi1E,GAAgB,CACnDtjJ,KAAQotE,GAAyBquE,GAAY,YAC7Ct+L,KAAQiwH,GAAyBquE,GAAY,cAQzCuI,GAAkB31E,GAAgBi1E,GAAgB,CACtDE,IAAOn2E,IA0uBT,SAAkB1+G,EAAMouC,EAASgwE,GAC/B,MAAMhlH,EACJglH,EAAY,GAER76G,EAAa6qC,EAAQp2C,gBACrB4G,EAAU,CAACoB,KAAMA,GACvBpB,EAAoB,WAAI2E,EACxB,MAAMF,EAAW+qC,EAAQzqC,cACzB,GAA0B,cAAtBN,EAAS8Z,UAA2B,CACtC,MAAMsqE,EACJ29F,GAA6B/hL,GAAU,EAAMjK,GAE/CwF,EAAwB,eAAI6oF,EAAWlpE,YACvChb,EAAkB,MAAIkkF,EAAWrpE,gBAClC,CACD,MAAMve,EAAau+G,EAAYA,EAAYxuH,OAAS,GAAGoQ,KACjDw/G,EAAc81E,GAAaz1L,EAAWq9G,cACtCxlH,EAAS6nH,GAAah8G,EAAYi8G,GACxCY,GACExhH,EACA22L,GACAj2E,GACA5nH,EACA0mH,EACAoB,EAEJ,IAnwBEu1E,IAAOr2E,IA0wBT,SAAkB1+G,EAAMouC,EAASgwE,GAC/B,MAAMhlH,EACJglH,EAAY,GAER76G,EAAa6qC,EAAQp2C,gBAErB4G,EAAU,CAACoB,KAAMA,GACvBpB,EAAoB,WAAI2E,EACxB,MAAMF,EAAW+qC,EAAQzqC,cACzB,GAA0B,mBAAtBN,EAAS8Z,UAAgC,CAC3C,MAAM4qE,EACJq9F,GAA6B/hL,GAAU,EAAMjK,GAE/CmK,EAAmB,OAAIwkF,EAAgBE,gBACxC,CACD,MAAMpoF,EAAau+G,EAAYA,EAAYxuH,OAAS,GAAGoQ,KACjDw/G,EAAcg2E,GAAa31L,EAAWq9G,cACtCxlH,EAAS6nH,GAAah8G,EAAYi8G,GACxCY,GACExhH,EACA62L,GACAn2E,GACA5nH,EACA0mH,EACAoB,EAEJ,IAnyBEy1E,IAAOv2E,IA6zBT,SAAkB1+G,EAAMouC,EAASgwE,GAC/B,MAAMhlH,EACJglH,EAAY,GAERx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GACjDgP,EAAoB,WAAIwvC,EAAQp2C,gBAChC,MAAMqL,EAAW+qC,EAAQzqC,cACzB,GAA0B,SAAtBN,EAAS8Z,UAAsB,CACjC,MAAM9L,EACJ+zK,GAA6B/hL,GAAU,EAAMjK,GAE/CwF,EAAwB,eAAIyS,EAAMkN,YAClCm3K,GAAa11L,EAAMqR,EAAM+M,iBAAkBggG,EAC5C,CACH,MA5qBA,MAAMu3E,GAAcj2E,GAAgBi1E,GAAgB,CAClDxwL,KAAQs6G,GAAyBquE,IACjC8I,IAAOn3E,GAAyBquE,IAChC+I,KAAQp3E,GAAyBquE,IACjCxjK,IAAOm1F,GAAyBquE,IAChCvmF,KAAQuvF,GACRhiL,OAAU2qG,GAAyBmuE,IACnCmJ,WAAcC,GACdxnM,KAAQiwH,GAAyBquE,IACjCmJ,MAoWF,SAAoBj2L,EAAMo+G,GACxB,MAAM1mH,EAASyoH,GAAgB,CAAA,EAAI+1E,GAAel2L,EAAMo+G,GACxD,GAAI1mH,EAAQ,CACV,MAAMy+L,EACJ/3E,EAAYA,EAAYxuH,OAAS,GAQnC43F,GALE2uG,EACN,gBAEMA,EACN,cACqDn2L,EAAMtI,EACxD,CACH,IA1WMw+L,GAAgBx2E,GAAgBi1E,GAAgB,CACpDyB,IAAO33E,GAAyBiuE,IAChCxwL,KAAQuiH,GAAyB+tE,MAQ7B6J,GAAc32E,GAAgBi1E,GAAgB,CAClDxwL,KAAQs6G,GAAyBquE,IACjC8I,IAAOn3E,GAAyBquE,IAChC+I,KAAQp3E,GAAyBquE,IACjCxjK,IAAOm1F,GAAyBquE,IAChCvmF,KAAQuvF,GACRhiL,OAAU2qG,GAAyBmuE,IACnCp+L,KAAQiwH,GAAyBquE,IACjCiJ,WAAcC,GACdM,OAiXF,SAAqBt2L,EAAMo+G,GACzB,MAAM1mH,EAAgC0mH,EAAYA,EAAYxuH,OAAS,GACvEkwH,GAAUy2E,GAAgBv2L,EAAMo+G,GAChC,MAAM70G,EAEH7R,EAAyB,gBACeA,EAAc,KACpDtD,KAAKmV,EAAgB3Z,OAC5B,IAjXM2mM,GAAiB72E,GAAgBi1E,GAAgB,CACrD6B,MAoVF,SAAoBx2L,EAAMo+G,GACxB,MAAM1mH,EAASyoH,GAAgB,CAAA,EAAIs2E,GAAez2L,EAAMo+G,GACxD,GAAI1mH,EAAQ,CACV,MAAMg/L,EACJt4E,EAAYA,EAAYxuH,OAAS,GAQnC43F,GALEkvG,EACN,gBAEMA,EACN,cACqD12L,EAAMtI,EACxD,CACH,IA1VM++L,GAAgB/2E,GAAgBi1E,GAAgB,CACpDyB,IAAO33E,GAAyBiuE,IAChCxwL,KAAQuiH,GAAyB+tE,MAQ7BmK,GAAcj3E,GAAgBi1E,GAAgB,CAClDyB,IAAO33E,GAAyBiuE,IAChCxwL,KAAQuiH,GAAyB+tE,IACjCoK,OAAUn4E,GAAyBiuE,IACnCmK,YAAep4E,GAAyBiuE,IACxCvoL,KAAQs6G,GAAyBquE,IACjC8I,IAAOn3E,GAAyBquE,IAChC+I,KAAQp3E,GAAyBquE,IACjCxjK,IAAOm1F,GAAyBquE,IAChCvmF,KAAQuvF,GACRgB,IAAOr4E,GAAyBquE,IAChCt+L,KAAQiwH,GAAyBquE,IACjCiK,IAAOt4E,GAAyBquE,IAChCkK,IAAOv4E,GAAyBmuE,IAChCqK,KAAQx4E,GAAyBiuE,IACjCwK,KAAQz4E,GAAyBiuE,IACjCyK,KAAQ14E,GAAyBiuE,IACjC0K,cAAiB34E,GAAyBiuE,IAC1C2K,OAAU54E,GAAyBmuE,IACnCmJ,WAAcC,KAOVsB,GAAgB,CAAC,OAAQ,QAOzBC,GAAmB73E,GAAgBi1E,GAAgB,CACvDtjJ,KAAQqtE,GAAkBuuE,IAC1Bz+L,KAAQkwH,GAAkBuuE,MAQtBqI,GAAe51E,GAAgBi1E,GAAgB,CACnD,OACA,MACA,OACA,MACA,OACA,SACA,OACA,UAQIY,GAAkB71E,GAAgBi1E,GAAgB,CACtDxwL,KAAQu6G,GAAkBuuE,IAC1B2I,IAAOl3E,GAAkBuuE,IACzB4I,KAAQn3E,GAAkBuuE,IAC1B3jK,IAAOo1F,GAAkBuuE,IACzB1mF,KAAQmY,GAAkB84E,IAC1B1jL,OAAU4qG,GAAkBovE,IAC5Bt/L,KAAQkwH,GAAkBuuE,IAC1BgJ,MAASr3E,GAAoBF,GAAkBg3E,OAQ3C+B,GAAsB/3E,GAAgBi1E,GAAgB,CAAC,MAAO,SAO9Da,GAAe91E,GAAgBi1E,GAAgB,CACnD,OACA,MACA,OACA,MACA,OACA,SACA,OACA,WAQIc,GAAkB/1E,GAAgBi1E,GAAgB,CACtDxwL,KAAQu6G,GAAkBuuE,IAC1B2I,IAAOl3E,GAAkBuuE,IACzB4I,KAAQn3E,GAAkBuuE,IAC1B3jK,IAAOo1F,GAAkBuuE,IACzB1mF,KAAQmY,GAAkB84E,IAC1B1jL,OAAU4qG,GAAkBovE,IAC5Bt/L,KAAQkwH,GAAkBuuE,IAC1BqJ,OAAU13E,GAAoBF,IAkehC,SAAqB1+G,EAAMynF,EAAY22B,GAErC,MAAMx/G,EAAU,CAACoB,KAAMA,GACvBpB,EAAwB,eAAI6oF,EAAWlpE,YACvC3f,EAAoB,WAAI,GACxBwhH,GACExhH,EACA84L,GACAC,GACAlwG,EAAWrpE,iBACXggG,EAEJ,OAveMu5E,GAAsB34E,GAAsB,SAO5C04E,GAAqBh4E,GAAgBi1E,GAAgB,CACzD6B,MAAS93E,GAAkBg3E,MAQvBkC,GAAoBl4E,GAAgBi1E,GAAgB,CACxD,MACA,OACA,SACA,cACA,OACA,MACA,OACA,MACA,OACA,MACA,OACA,MACA,MACA,OACA,OACA,OACA,gBACA,WAQIkD,GAAuBn4E,GAAgBi1E,GAAgB,CAC3DyB,IAAO13E,GAAkBkvE,IACzB1xL,KAAQwiH,GAAkB0uE,IAC1BwJ,OAAUl4E,GAAkBkvE,IAC5BiJ,YAAen4E,GAAkBkvE,IACjCzpL,KAAQu6G,GAAkBuuE,IAC1B2I,IAAOl3E,GAAkBuuE,IACzB4I,KAAQn3E,GAAkBuuE,IAC1B3jK,IAAOo1F,GAAkBuuE,IACzB1mF,KAAQmY,GAAkB84E,IAC1BV,IAAOp4E,GAAkBuuE,IACzBz+L,KAAQkwH,GAAkBuuE,IAC1B8J,IAAOr4E,GAAkBuuE,IACzB+J,IAAOt4E,GAAkBovE,IACzBmJ,KAAQv4E,GAAkBkvE,IAC1BsJ,KAAQx4E,GAAkBkvE,IAC1BuJ,KAAQz4E,GAAkBkvE,IAC1BwJ,cAAiB14E,GAAkBkvE,IACnCyJ,OAAU34E,GAAkBovE,MAOxBgK,GAA4B,CAChC71K,MAAS,MACTqnD,WAAc,MACdI,gBAAmB,OASrB,SAASquH,GAAiBjlM,EAAOsrH,EAAaiB,GAC5C,MAAMh8G,EAAkC,EAAQM,cAChD,GAAIN,EAAU,CACZ,MAAMg8G,EAAWy4E,GAA0Bz0L,EAAS8Z,WACpD,GAAIkiG,EAAU,CAEZ,OAAOpC,GADYmB,EAAYA,EAAYxuH,OAAS,GAAGoQ,KACrBk9G,aAAcmC,EACjD,CACF,CACH,CASA,SAAS73B,GAAiBj+E,EAAiByuL,EAAeh4L,EAAMtI,GAmB9D,OAlBA6R,EAAgBnV,KACdolC,WAAWx5B,EAAKgqL,aAAa,QAC7BxwJ,WAAWx5B,EAAKgqL,aAAa,SAE3B,QAAStyL,GACX6R,EAAgBnV,KAA4BsD,EAAa,YAClDA,EAAY,IACnBsgM,EAAclR,MAAO,GAErBv9K,EAAgBnV,KAAK,GAEnB,SAAUsD,GACZ6R,EAAgBnV,KAA4BsD,EAAc,aACnDA,EAAa,KACpBsgM,EAAcjR,MAAO,GAErBx9K,EAAgBnV,KAAK,GAEhBmV,CACT,CAWA,SAAS0uL,GAAmBD,EAAezuL,EAAiB8V,GAE1D,IAAIzB,EAAS,KACTnU,EAAS,EAWb,GAVIuuL,EAAclR,MAAQkR,EAAcjR,MACtCnpK,EAAS,OACTnU,EAAS,GACAuuL,EAAclR,MACvBlpK,EAAS,MACTnU,EAAS,GACAuuL,EAAcjR,OACvBnpK,EAAS,MACTnU,EAAS,GAEI,IAAXA,EAAc,CAChB,IAAK,IAAIpZ,EAAI,EAAGuE,EAAK2U,EAAgB3Z,OAAS,EAAGS,EAAIuE,EAAIvE,IACvDkZ,EAAgBlZ,EAAIoZ,GAAUF,EAAoB,EAAJlZ,GAC9CkZ,EAAgBlZ,EAAIoZ,EAAS,GAAKF,EAAoB,EAAJlZ,EAAQ,GACtD2nM,EAAclR,OAChBv9K,EAAgBlZ,EAAIoZ,EAAS,GAAKF,EAAoB,EAAJlZ,EAAQ,IAExD2nM,EAAcjR,OAChBx9K,EAAgBlZ,EAAIoZ,EAAS,GAAKF,EAAoB,EAAJlZ,EAAQ,IAI9D,GADAkZ,EAAgB3Z,OAAU2Z,EAAgB3Z,OAAS,EAAK6Z,EACpD4V,EACF,IAAK,IAAIhvB,EAAI,EAAGuE,EAAKyqB,EAAKzvB,OAAQS,EAAIuE,EAAIvE,IACxCgvB,EAAKhvB,GAAMgvB,EAAKhvB,GAAK,EAAKoZ,CAG/B,CACD,OAAOmU,CACT,CAMA,SAASk4K,GAAU91L,EAAMo+G,GACvB,MAAM1mH,EAAgC0mH,EAAYA,EAAYxuH,OAAS,GACjE6uE,EAAOz+D,EAAKgqL,aAAa,QAClB,OAATvrH,IACF/mE,EAAa,KAAI+mE,GAEnBqhD,GAAUs1E,GAAcp1L,EAAMo+G,EAChC,CAMA,SAAS43E,GAAgBh2L,EAAMo+G,GACSA,EAAYA,EAAYxuH,OAAS,GAC/C,gBAAIoQ,CAC9B,CA6DA,SAAS80L,GAAQ90L,EAAMo+G,GACrB,MAAMhlH,EACJglH,EAAY,GAER1mH,EAASyoH,GACb,CACE52G,gBAAmB,GACnByuL,cAAiB,CAAE,GAErBrC,GACA31L,EACAo+G,GAEF,IAAK1mH,EACH,OAEF,MAAM6R,EAEH7R,EAAyB,uBACrBA,EAAwB,gBAC/B,MAAMsgM,EAA8CtgM,EAAuB,qBACpEA,EAAsB,cAC7B,MAAMkmB,EAASq6K,GAAmBD,EAAezuL,GAC3ClG,EAAW,IAAIimE,GAAW//D,EAAiBqU,GACjDwnK,GAA6B/hL,GAAU,EAAOjK,GAC9C,MAAMg1C,EAAU,IAAIvrC,GAAQQ,GAE5B,OADA+qC,EAAQx2C,cAAcF,GAAQ,GACvB02C,CACT,CAOA,SAAS4mJ,GAAQh1L,EAAMo+G,GACrB,MAAMhlH,EACJglH,EAAY,GAER1mH,EAASyoH,GACb,CACE52G,gBAAmB,GACnB8V,KAAQ,GACR24K,cAAiB,CAAE,GAErB3B,GACAr2L,EACAo+G,GAEF,IAAK1mH,EACH,OAEF,MAAM6R,EAEH7R,EAAyB,uBACrBA,EAAwB,gBAC/B,MAAM2nB,EAAqC3nB,EAAc,YAClDA,EAAa,KACpB,MAAMsgM,EAA8CtgM,EAAuB,qBACpEA,EAAsB,cAC7B,MAAMkmB,EAASq6K,GAAmBD,EAAezuL,EAAiB8V,GAC5Dhc,EAAW,IAAIqmE,GAAgBngE,EAAiBqU,EAAQyB,GAC9D+lK,GAA6B/hL,GAAU,EAAOjK,GAC9C,MAAMg1C,EAAU,IAAIvrC,GAAQQ,GAE5B,OADA+qC,EAAQx2C,cAAcF,GAAQ,GACvB02C,CACT,CAOA,SAAS8mJ,GAAQl1L,EAAMo+G,GACrB,MAAMhlH,EACJglH,EAAY,GAER1mH,EAASyoH,GAAgB,CAAA,EAAIw2E,GAAa32L,EAAMo+G,GACtD,IAAK1mH,EACH,OAEF,MAAMsgM,EAA8C,CAAE,EAChDhwL,EAAcw/E,GAAiB,GAAIwwG,EAAeh4L,EAAMtI,GACxDkmB,EAASq6K,GAAmBD,EAAehwL,GAC3C3E,EAAW,IAAI4e,GAAMja,EAAa4V,GACxCwnK,GAA6B/hL,GAAU,EAAOjK,GAC9C,MAAMg1C,EAAU,IAAIvrC,GAAQQ,GAE5B,OADA+qC,EAAQx2C,cAAcF,GAAQ,GACvB02C,CACT,CAOA,SAASopJ,GAAUx3L,EAAMlN,EAAOsrH,GAC9Bp+G,EAAK4/C,aAAa,OAAQ9sD,GAC1B,MACMyQ,EADU66G,EAAYA,EAAYxuH,OAAS,GACV,WACjC22G,EAAO,CAAChjG,EAAqB,SAAGA,EAAqB,UAC3D68G,GACF,CAAuDpgH,KAAMA,GACzDu3L,GACAj4E,GACA/Y,EACA6X,EACAk5E,GAEJ,CAOA,SAAS5B,GAAa11L,EAAM6F,EAAYu4G,GACtC,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAE3CstH,EADat+G,EAAQoB,KACKk9G,aAC1B35G,EAAa3E,EAAoB,WAEvCoB,EAAK8zL,eAAe,KAAM,MAAOx8L,OAAOuO,EAAW,KACnD7F,EAAK8zL,eAAe,KAAM,MAAOx8L,OAAOuO,EAAW,KAEnD,OADuBjH,EAAwB,gBAE7C,IAAK,OACmB,IAAlBiH,EAAW,KACbtC,EAAiB,KAAIsC,EAAW,IAGpC,IAAK,MACmB,IAAlBA,EAAW,KACbtC,EAAgB,IAAIsC,EAAW,IAEjC,MACF,IAAK,MACmB,IAAlBA,EAAW,KACbtC,EAAiB,KAAIsC,EAAW,IAMtC,MAAM25G,EACa,SAAjBx/G,EAAKq/G,SACDo4E,GAAoBv6E,GACpB06E,GAAkB16E,GAClBxlH,EAAS6nH,GAAah8G,EAAYi8G,GACxCY,GAEG,CAACpgH,KAAMA,EAAMuD,WAAcA,GAC5Bs0L,GACAv4E,GACA5nH,EACA0mH,EACAoB,EAEJ,CA4GA,IAAA04E,GA1yBA,cAAkBjP,GAIhB,WAAA16L,CAAY6K,GACV1F,QAEA0F,EAAUA,GAAoB,GAK9B3K,KAAKotE,eAAiBx+C,GAAc,aAMpC5uB,KAAK0pM,gBAAkB/+L,EAAQg/L,cAChC,CAMD,qBAAAC,CAAsBzmI,GACfA,IACHA,EAAW,IAEb,IAAK,IAAIvhE,EAAI,EAAGuE,EAAKg9D,EAAShiE,OAAQS,EAAIuE,IAAMvE,EAAG,CACjD,MAAM+9C,EAAUwjB,EAASvhE,GACzB,GAAI5B,KAAK0pM,gBAAiB,CACxB,MAAMG,EAAiBlqJ,EAAQv2C,IAAI,oBAAsB,KACzDpJ,KAAK0pM,gBAAgB/pJ,EAASkqJ,EAC/B,CACDlqJ,EAAQ51C,IAAI,uBAAmBvD,EAChC,CACF,CAOD,mBAAAizL,CAAoBloL,EAAM5G,GACxB,IAAKu7L,GAAexgM,SAAS6L,EAAKk9G,cAChC,OAAO,KAET,MAAMq7E,EAAgB3D,GAAe50L,EAAKw+G,WAC1C,IAAK+5E,EACH,OAAO,KAET,MAAMnqJ,EAAUmqJ,EAAcv4L,EAAM,CAACvR,KAAKo2L,eAAe7kL,EAAM5G,KAC/D,OAAKg1C,GAGL3/C,KAAK4pM,sBAAsB,CAACjqJ,IACrBA,GAHE,IAIV,CAOD,oBAAAg6I,CAAqBpoL,EAAM5G,GACzB,IAAKu7L,GAAexgM,SAAS6L,EAAKk9G,cAChC,MAAO,GAET,GAAsB,OAAlBl9G,EAAKw+G,UAAoB,CAE3B,MAAM5sD,EAAWuuD,GAAgB,GAAIg1E,GAAan1L,EAAM,CACtDvR,KAAKo2L,eAAe7kL,EAAM5G,KAE5B,OAAIw4D,GACFnjE,KAAK4pM,sBAAsBzmI,GACpBA,GAEF,EACR,CACD,MAAO,EACR,CAYD,iBAAAg3H,CAAkBh3H,EAAUx4D,GAC1BA,EAAU3K,KAAKq2L,aAAa1rL,GAE5B,MAAMo/L,EAAMv7E,GAAgB,oCAAqC,OAmBjE,OAjBAu7E,EAAI1E,eADa,gCACY,YAAa92E,IAC1Cw7E,EAAI1E,eACF92E,GACA,qBAlLJ,+EAqLEw7E,EAAI54I,aAAa,UAAW,OAC5B44I,EAAI54I,aAAa,UAAW,cAE5BwgE,GAEJ,CAAQpgH,KAAMw4L,GACRnD,GACA0C,GACAnmI,EACA,CAACx4D,IAEIo/L,CACR,GCyDH,SAASC,GAAqBplM,EAAQ+F,GACpC,IAAK/F,EACH,OAAO,KAIT,IAAIgQ,EACJ,OAAQhQ,EAAa,MACnB,IAAK,QACHgQ,EA4EN,SAA2BhQ,GACzB,MAAMkW,EAAkBlW,EAAoB,YAC5C,MAAO,CACL7E,KAAM,QACN+a,kBACAqU,OAAQD,GAAmBpU,EAAgB3Z,QAE/C,CAnFiB8oM,CAA+C,GAC1D,MAEF,IAAK,aACHr1L,EAqFN,SAAgChQ,GAC9B,MAAM2U,EAAc3U,EAAoB,YAClCkW,EAAkBvB,EAAY8sJ,OACpC,MAAO,CACLtmK,KAAM,aACN+a,kBACA8V,KAAM,CAAC9V,EAAgB3Z,QACvBguB,OAAQD,GAAmB3V,EAAY,GAAGpY,QAE9C,CA9FiB+oM,CACjB,GAEM,MAEF,IAAK,UACHt1L,EAkJN,SAA6BhQ,GAC3B,MAAM2U,EAAc3U,EAAoB,YAClCkW,EAAkB,GAClBE,EAASzB,EAAY,GAAG,GAAGpY,OAC3ByvB,EAAOW,GAAwBzW,EAAiB,EAAGvB,EAAayB,GACtE,MAAO,CACLjb,KAAM,UACN+a,kBACA8V,OACAzB,OAAQD,GAAmBlU,GAE/B,CA7JiBmvL,CAAmD,GAC9D,MAEF,IAAK,aACHv1L,EA2GN,SAAgChQ,GAC9B,MAAM2U,EAAc3U,EAAoB,YACxC,MAAO,CACL7E,KAAM,aACN+a,gBAAiBvB,EAAY8sJ,OAC7Bl3I,OAAQD,GAAmB3V,EAAY,GAAGpY,QAE9C,CAlHiBipM,CACjB,GAEM,MAEF,IAAK,kBACHx1L,EAoFN,SAAqChQ,GACnC,MAAM2U,EAAc3U,EAAoB,YAClCoW,EAASzB,EAAY,GAAG,GAAGpY,OAC3B2Z,EAAkB,GAClB8V,EAAOW,GAAwBzW,EAAiB,EAAGvB,EAAayB,GACtE,MAAO,CACLjb,KAAM,kBACN+a,kBACA8V,OACAzB,OAAQD,GAAmBlU,GAE/B,CA/FiBqvL,CACjB,GAEM,MAEF,IAAK,eACHz1L,EA4GN,SAAkChQ,GAChC,MAAM2U,EAAc3U,EAAoB,YAClCkW,EAAkB,GAClBE,EAASzB,EAAY,GAAG,GAAG,GAAGpY,OAC9B2vB,EAAQW,GACZ3W,EACA,EACAvB,EACAyB,GAEF,MAAO,CACLjb,KAAM,eACN+a,kBACA8V,KAAME,EACN3B,OAAQD,GAAmBlU,GAE/B,CA5HiBsvL,CACjB,GAEM,MAEF,IAAK,qBACH11L,EA2BN,SAAwChQ,EAAQ+F,GAC9C,MAAM6qE,EAAa5wE,EAAmB,WAAEkmC,KAKtC,SAAUl2B,GACR,OAAOo1L,GAAqBp1L,EAC7B,IAEH,OAAO4gE,CACT,CAtCiB+0H,CACjB,GAEM,MAEF,QACE,MAAM,IAAI/hM,MAAM,6BAA+B5D,EAAa,MAGhE,OAAOgQ,CACT,CAoIA,SAAS8hL,GAAc9hL,EAAUjK,GAG/B,MAAM5K,GAFN6U,EAAW+hL,GAA6B/hL,GAAU,EAAMjK,IAElC+jB,UAGtB,IAAI87K,EACJ,OAAQzqM,GACN,IAAK,QACHyqM,EA0IN,SAA4B51L,EAAUjK,GACpC,MAAO,CACL5K,KAAM,QACNwZ,YAAa3E,EAAS+a,iBAE1B,CA/IgB86K,CAC2C,GAGrD,MAEF,IAAK,aACHD,EA+EN,SAAiC51L,EAAUjK,GACzC,MAAO,CACL5K,KAAM,aACNwZ,YAAa3E,EAAS+a,iBAE1B,CApFgB+6K,CACgD,GAG1D,MAEF,IAAK,UACHF,EAwIN,SAA8B51L,EAAUjK,GACtC,IAAI4qB,EACA5qB,IACF4qB,EAAQ5qB,EAAQggM,aAElB,MAAO,CACL5qM,KAAM,UACNwZ,YAAa3E,EAAS+a,eAAe4F,GAEzC,CAjJgBq1K,CAChB,EACQjgM,GAEF,MAEF,IAAK,aACH6/L,EAyFN,SAAiC51L,EAAUjK,GACzC,MAAO,CACL5K,KAAM,aACNwZ,YAAa3E,EAAS+a,iBAE1B,CA9FgBk7K,CACgD,GAG1D,MAEF,IAAK,kBACHL,EAsEN,SAAsC51L,EAAUjK,GAC9C,MAAO,CACL5K,KAAM,kBACNwZ,YAAa3E,EAAS+a,iBAE1B,CA3EgBm7K,CACqD,GAG/D,MAEF,IAAK,eACHN,EAuFN,SAAmC51L,EAAUjK,GAC3C,IAAI4qB,EACA5qB,IACF4qB,EAAQ5qB,EAAQggM,aAElB,MAAO,CACL5qM,KAAM,eACNwZ,YAAa3E,EAAS+a,eAAe4F,GAEzC,CAhGgBw1K,CAChB,EACQpgM,GAEF,MAEF,IAAK,qBACH6/L,EA2BN,SAAyC51L,EAAUjK,GACjDA,EAAUjE,OAAO8C,OAAO,CAAE,EAAEmB,UACrBA,EAAQgkE,kBACf,MAAM6G,EAAa5gE,EAAS6gE,qBAAqB3qC,KAAI,SAAUl2B,GAC7D,OAAO8hL,GAAc9hL,EAAUjK,EACnC,IACE,MAAO,CACL5K,KAAM,qBACNy1E,WAAYA,EAEhB,CArCgBw1H,CAChB,EAGQrgM,GAEF,MAEF,IAAK,SACH6/L,EAAU,CACRzqM,KAAM,qBACNy1E,WAAY,IAEd,MAEF,QACE,MAAM,IAAIhtE,MAAM,8BAAgCzI,GAGpD,OAAOyqM,CACT,CAmGA,IAAAS,GAtlBA,cAAsBjS,GAIpB,WAAAl5L,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B1F,QAKAjF,KAAKotE,eAAiBx+C,GACpBjkB,EAAQyiE,eAAiBziE,EAAQyiE,eAAiB,aAGhDziE,EAAQgkE,oBAIV3uE,KAAKk2L,yBAA2BtnK,GAAcjkB,EAAQgkE,oBAGpDhkE,EAAQwrL,eACVn2L,KAAKm2L,aAAexrL,EAAQwrL,cAQ9Bn2L,KAAKuU,cAAgB5J,EAAQi5K,aAO7B5jL,KAAKkrM,qBAAuBvgM,EAAQwgM,oBAEpCnrM,KAAKk4G,oBAAsB,CACzB,uBACA,2BAEH,CAQD,qBAAAq/E,CAAsB3yL,EAAQ+F,GAI5B,IAAIygM,EAAiB,KAEnBA,EADqB,YAAnBxmM,EAAa,KACD,EAEG,CACf7E,KAAQ,UACR6U,SAA4C,EAC5CE,WAAc,MAIlB,MAAMF,EAAWo1L,GAAqBoB,EAAyB,UAC/D,GAAIprM,KAAKm2L,eAAiBl7F,GACxB,OAAOg8F,GACL,CACEriL,WACApH,GAAI49L,EAAmB,GACvBt2L,WAAYs2L,EAA2B,YAEzCzgM,GAIJ,MAAMg1C,EAAU,IAAIvrC,GAkBpB,OAjBIpU,KAAKuU,cACPorC,EAAQ3qC,gBAAgBhV,KAAKuU,eAE7BvU,KAAKkrM,sBACL,kBAAmBE,SAAmB5kM,GAEtCm5C,EAAQ3qC,gBAAgBo2L,EAA8B,eAExDzrJ,EAAQ9qC,YAAYsiL,GAAeviL,EAAUjK,IAEzC,OAAQygM,GACVzrJ,EAAQlqC,MAAM21L,EAAmB,IAG/BA,EAA2B,YAC7BzrJ,EAAQx2C,cAAciiM,EAA2B,YAAG,GAE/CzrJ,CACR,CAQD,sBAAA63I,CAAuB5yL,EAAQ+F,GAG7B,IAAIw4D,EAAW,KACf,GAA8B,sBAHsB,EAG5B,KAA2B,CAIjDA,EAAW,GACX,MAAMkoI,EAJwB,EAI6B,SAC3D,IAAK,IAAIzpM,EAAI,EAAGuE,EAAKklM,EAAgBlqM,OAAQS,EAAIuE,IAAMvE,EAAG,CACxD,MAAM0pM,EAAgBtrM,KAAKu3L,sBACzB8T,EAAgBzpM,GAChB+I,GAEG2gM,GAGLnoI,EAASx9D,KAAK2lM,EACf,CACP,MACMnoI,EAAW,CAACnjE,KAAKu3L,sBAAsB3yL,EAAQ+F,IAEjD,OAAOw4D,EAASkjG,MACjB,CAQD,sBAAAoxB,CAAuB7yL,EAAQ+F,GAC7B,OAmKJ,SAAsB/F,EAAQ+F,GAC5B,MAAM4gM,EAAiBvB,GAAqBplM,GAC5C,OAAOuyL,GAAeoU,EAAgB5gM,EACxC,CAtKW4rL,CAAa3xL,EAAQ+F,EAC7B,CAOD,wBAAA+sL,CAAyB9yL,GACvB,MAAM4zG,EAAM5zG,EAAY,IACxB,IAAIua,EACJ,GAAIq5F,EACF,GAAmB,QAAfA,EAAU,KACZr5F,EAAayP,GAAc4pF,EAAgB,WAAQ,UAC9C,IAAoB,SAAhBA,EAAU,KAGnB,MAAM,IAAIhwG,MAAM,oBAFhB2W,EAAayP,GAAc,QAAU4pF,EAAgB,WAAQ,KAG9D,MAEDr5F,EAAanf,KAAKotE,eAEpB,OAAA,CACD,CAUD,kBAAAuqH,CAAmBh4I,EAASh1C,GAC1BA,EAAU3K,KAAKq2L,aAAa1rL,GAG5B,MAAM/F,EAAS,CACb7E,KAAQ,UACR6U,SAAU,KACVE,WAAY,MAGRtH,EAAKmyC,EAAQtqC,QAKnB,QAJW7O,IAAPgH,IACF5I,EAAO4I,GAAKA,IAGTmyC,EAAQj2C,gBACX,OAAO9E,EAGT,MAAMkQ,EAAa6qC,EAAQp2C,gBACrBqL,EAAW+qC,EAAQzqC,cAWzB,OAVIN,IACFhQ,EAAOgQ,SAAW8hL,GAAc9hL,EAAUjK,UAEnCmK,EAAW6qC,EAAQ1qC,oBAGvBnQ,EAAQgQ,KACXlQ,EAAOkQ,WAAaA,GAGflQ,CACR,CAUD,mBAAAgzL,CAAoBz0H,EAAUx4D,GAC5BA,EAAU3K,KAAKq2L,aAAa1rL,GAC5B,MAAM2uL,EAAU,GAChB,IAAK,IAAI13L,EAAI,EAAGuE,EAAKg9D,EAAShiE,OAAQS,EAAIuE,IAAMvE,EAC9C03L,EAAQ3zL,KAAK3F,KAAK23L,mBAAmBx0H,EAASvhE,GAAI+I,IAEpD,MAAO,CACL5K,KAAM,oBACNojE,SAAUm2H,EAEb,CAUD,mBAAAzB,CAAoBjjL,EAAUjK,GAC5B,OAAO+rL,GAAc9hL,EAAU5U,KAAKq2L,aAAa1rL,GAClD,GC/FH,SAAS0qE,GAAQnrE,GACf,MAAsB,iBAAXA,EACFA,EAEF,EACT,CAEA,IAAAshM,GA/LA,cAA0BlU,GACxB,WAAAx3L,GACEmF,OACD,CAKD,OAAAypB,GACE,MAAO,MACR,CAUD,WAAA4nK,CAAYpsL,EAAQS,GAClB,OAAO3K,KAAKyrM,oBACVp2H,GAAQnrE,GACRlK,KAAKq2L,aAAa1rL,GAErB,CASD,mBAAA8gM,CAAoB7oJ,EAAMj4C,GACxB,OAAOpC,GACR,CAUD,YAAAmmE,CAAaxkE,EAAQS,GACnB,OAAO3K,KAAK0rM,qBACVr2H,GAAQnrE,GACRlK,KAAKq2L,aAAa1rL,GAErB,CASD,oBAAA+gM,CAAqB9oJ,EAAMj4C,GACzB,OAAOpC,GACR,CAUD,YAAAguL,CAAarsL,EAAQS,GACnB,OAAO3K,KAAK2rM,qBACVt2H,GAAQnrE,GACRlK,KAAKq2L,aAAa1rL,GAErB,CASD,oBAAAghM,CAAqB/oJ,EAAMj4C,GACzB,OAAOpC,GACR,CASD,cAAAqmE,CAAe1kE,GACb,OAAOlK,KAAK4rM,uBAAuBv2H,GAAQnrE,GAC5C,CAOD,sBAAA0hM,CAAuBhpJ,GACrB,OAAO5iD,KAAKotE,cACb,CAUD,YAAAopH,CAAa72I,EAASh1C,GACpB,OAAO3K,KAAK6rM,iBAAiBlsJ,EAAS3/C,KAAKq2L,aAAa1rL,GACzD,CASD,gBAAAkhM,CAAiBlsJ,EAASh1C,GACxB,OAAOpC,GACR,CAUD,aAAAkuL,CAActzH,EAAUx4D,GACtB,OAAO3K,KAAK8rM,kBAAkB3oI,EAAUnjE,KAAKq2L,aAAa1rL,GAC3D,CASD,iBAAAmhM,CAAkB3oI,EAAUx4D,GAC1B,OAAOpC,GACR,CAUD,aAAAmuL,CAAc9hL,EAAUjK,GACtB,OAAO3K,KAAK+rM,kBAAkBn3L,EAAU5U,KAAKq2L,aAAa1rL,GAC3D,CASD,iBAAAohM,CAAkBn3L,EAAUjK,GAC1B,OAAOpC,GACR,GC7KH,MAAMyjM,GACJ,sFAMIC,GAAc,wBAMdC,GAAkB,8BAQlBC,GAAa,aAsInB,IAAAC,GApHA,cAAkBC,GAIhB,WAAAvsM,CAAY6K,GACV1F,QAEA0F,EAAUA,GAAoB,GAK9B3K,KAAKotE,eAAiBx+C,GAAc,aAMpC5uB,KAAKssM,cAAgB3hM,EAAQ4hM,aAAe5hM,EAAQ4hM,aAAe,MACpE,CAQD,mBAAAd,CAAoB7oJ,EAAMj4C,GACxB,MAAM4hM,EAAevsM,KAAKssM,cACpBroF,EAAQrhE,EAAK/8B,MAAMsmL,IAEnBr3L,EAAa,CAAA,EACbgG,EAAkB,GACxB,IAIIlZ,EAAGuE,EAJHqmM,EAAO,IACPC,EAAQ,EACRC,EAAM,EACNC,GAAgB,EAEpB,IAAK/qM,EAAI,EAAGuE,EAAK89G,EAAM9iH,OAAQS,EAAIuE,IAAMvE,EAAG,CAC1C,MAAMulK,EAAOljD,EAAMriH,GACnB,IAAIue,EACJ,GAAsB,KAAlBgnJ,EAAKpgJ,OAAO,IAEd,GADA5G,EAAI6rL,GAAYrhK,KAAKw8H,GACjBhnJ,EAAG,CACL,MAAMysL,EAAOn8L,SAAS0P,EAAE,GAAI,IACtB0sL,EAASp8L,SAAS0P,EAAE,GAAI,IACxB2sL,EAASr8L,SAAS0P,EAAE,GAAI,IAC9B,IAAI7I,EAAI7G,SAAS0P,EAAE,GAAI,IAAM1P,SAAS0P,EAAE,GAAI,IAAM,IACtC,KAARA,EAAE,KACJ7I,GAAKA,GAEP,IAAID,EAAI5G,SAAS0P,EAAE,GAAI,IAAM1P,SAAS0P,EAAE,GAAI,IAAM,IAKlD,GAJY,KAARA,EAAE,KACJ9I,GAAKA,GAEPyD,EAAgBnV,KAAK0R,EAAGC,GACJ,QAAhBi1L,EAAwB,CAC1B,IAAIhtK,EAEFA,EADkB,OAAhBgtK,EACE97L,SAAS0P,EAAE,IAAK,IACK,cAAhBosL,EACL97L,SAAS0P,EAAE,IAAK,IAEhB,EAENrF,EAAgBnV,KAAK45B,EACtB,CACD,IAAIy+J,EAAWjgK,KAAKgvK,IAAIP,EAAMC,EAAOC,EAAKE,EAAMC,EAAQC,GAEpD9O,EAAW2O,IACb3O,EAAWjgK,KAAKgvK,IAAIP,EAAMC,EAAOC,EAAM,EAAGE,EAAMC,EAAQC,IAE1DhyL,EAAgBnV,KAAKq4L,EAAW,KAChC2O,EAAe3O,CAChB,MAC0B,KAAlB72B,EAAKpgJ,OAAO,KACrB5G,EAAI+rL,GAAgBvhK,KAAKw8H,GACrBhnJ,GACFusL,EAAMj8L,SAAS0P,EAAE,GAAI,IACrBssL,EAAQh8L,SAAS0P,EAAE,GAAI,IAAM,EAC7BqsL,EAAO,IAAO/7L,SAAS0P,EAAE,GAAI,MAE7BA,EAAI8rL,GAAYthK,KAAKw8H,GACjBhnJ,IACFrL,EAAWqL,EAAE,IAAMA,EAAE,GAAG0qB,SAI/B,CACD,GAA+B,IAA3B/vB,EAAgB3Z,OAClB,OAAO,KAET,MACM63F,EAAa,IAAIne,GAAW//D,EADH,QAAhByxL,EAAyB,MAAQ,QAE1C5sJ,EAAU,IAAIvrC,GAClBuiL,GAA6B39F,GAAY,EAAOruF,IAGlD,OADAg1C,EAAQx2C,cAAc2L,GAAY,GAC3B6qC,CACR,CAQD,oBAAA+rJ,CAAqB9oJ,EAAMj4C,GACzB,MAAMg1C,EAAU3/C,KAAKyrM,oBAAoB7oJ,EAAMj4C,GAC/C,OAAIg1C,EACK,CAACA,GAEH,EACR,GCnGH,MAAMqtJ,GAAoB,CAAC,qCAMrB9G,GAAiB,CACrB,KACA,kCACA,kCACA,kCACA,kCAcI+G,GAAwB,CAC5Bh2J,SAAY,WACZ6sE,OAAU,SACVopF,YAAe,UAQXC,GAAoBl8E,GACxBi1E,GACA,CACEkH,aAAgBC,GAChBC,OAAUC,GACVC,cAAiBx9E,GAAyBy9E,GAAmB,YAC7D5yH,WAAcm1C,GAAyB6sE,GAAgB,YACvD3pK,WAAc88F,GAAyBgtE,GAAgB,YACvDxpK,MAASw8F,GAAyB+rE,GAAW,YAC7C9lK,QAAW+5F,GAAyBitE,GAAa,YACjDn0C,MAAS94B,GAAyB09E,IAClCC,SA2hEJ,SAAiCp8L,EAAMo+G,GACrC,MAAMi+E,EAAgBC,GAAkB9pM,KAAK/D,KAAMuR,EAAMo+G,GACzD,IAAKi+E,EACH,OAEF,MAAME,EAAkBn+E,EAAYA,EAAYxuH,OAAS,GACzD,GAAIkB,MAAMC,QAAQsrM,GAChBE,EAAuB,MAAIF,MACtB,IAA6B,iBAAlBA,EAGhB,MAAM,IAAIplM,MAAM,uCAFhBslM,EAA0B,SAAIF,CAG/B,CACH,EAviEIG,QAAW/9E,GAAyBquE,IACpC2P,YAAeh+E,GAAyBquE,IACxC3oL,KAAQs6G,GAAyBquE,IACjCpwH,KAAQ+hD,GAAyB6tE,IACjCoQ,YAAej+E,GAAyBquE,IACxC6P,SAAYl+E,GAAyBm+E,IACrCC,WAAcp+E,GAAyB6tE,KAEzC5sE,GAAgB+7E,GAAmB,CACjCqB,WAAcr+E,IA+8ClB,SAA0Bz+G,EAAMo+G,GAC9B,MAAMv2B,EAAcs4B,GAClB,GACA48E,GACA/8L,EACAo+G,GAEF,IAAKv2B,EACH,OAEF,OAAO,IAAIne,GAAgBme,EAC7B,GA19C6D,YACzDm1G,MAASv+E,GAAyBw+E,GAAa,eAS7CC,GAAuBx9E,GAAgBi1E,GAAgB,CAC3DkH,aAAgBC,GAChBC,OAAUC,GACVmB,KA0rEF,SAAoBn9L,EAAMo+G,GACxB0B,GAAUs1E,GAAcp1L,EAAMo+G,EAChC,EA3rEEo+E,QAAW/9E,GAAyBquE,IACpC2P,YAAeh+E,GAAyBquE,IACxC3oL,KAAQs6G,GAAyBquE,IACjCpwH,KAAQ+hD,GAAyB6tE,IACjCoQ,YAAej+E,GAAyBquE,IACxC+P,WAAcp+E,GAAyB6tE,MAQnC8I,GAAe11E,GAAgBi1E,GAAgB,CACnDl2H,KAAQggD,GAAyB2+E,MAQ7BC,GAAiB39E,GAAgBi1E,GAAgB,CACrD2I,SAAU7+E,GAAyBiuE,IACnC6Q,UAAW9+E,GAAyBiuE,IACpC8Q,SAAU/+E,GAAyBiuE,IACnC+Q,KAAMh/E,GAAyBiuE,IAC/BgR,aAAcj/E,GAAyBquE,IACvC6Q,QAASl/E,GAAyBiuE,IAClCkR,KAAMn/E,GAAyBiuE,MAQ3BmR,GAAiBn+E,GAAgBi1E,GAAgB,CACrDmJ,aA+hEF,SAA4B99L,EAAMo+G,GAChC,MAAM/qH,EAAS8sH,GACb,CAAE,EACF49E,GACA/9L,EACAo+G,GAEF,IAAK/qH,EACH,OAEF,MAAM2qM,EACJ5/E,EAAYA,EAAYxuH,OAAS,GAE7BqY,EAAS,CACbuxB,WAAWnmC,EAAa,MACxBmmC,WAAWnmC,EAAc,OACzBmmC,WAAWnmC,EAAa,MACxBmmC,WAAWnmC,EAAc,QAE3B2qM,EAAqB,OAAI/1L,EACzB+1L,EAA2B,aAAI3qM,EAAqB,aACpD2qM,EAA0B,YAAIxkK,WAAWnmC,EAAoB,aAC7D2qM,EAA0B,YAAIxkK,WAAWnmC,EAAoB,YAC/D,EArjEE4qM,IAukEF,SAAmBj+L,EAAMo+G,GACvB,MAAM/qH,EAAS8sH,GAAgB,CAAA,EAAI+9E,GAAal+L,EAAMo+G,GACtD,IAAK/qH,EACH,OAEF,MAAM8qM,EAAmC//E,EAAYA,EAAYxuH,OAAS,GAC1EuuM,EAAwB,aAAI3kK,WAAWnmC,EAAqB,cAC5D8qM,EAAwB,aAAI3kK,WAAWnmC,EAAqB,cAC5D8qM,EAAyB,cAAI3kK,WAAWnmC,EAAsB,eAC9D8qM,EAAyB,cAAI3kK,WAAWnmC,EAAsB,cAChE,IAzkEM+qM,GAAe1+E,GAAgBi1E,GAAgB,CAAC,WAAY,cAO5D0J,GAAkB3+E,GAAgBi1E,GAAgB,CACtD2J,SAAY5/E,IA2yEd,SAAuB1+G,EAAM4xD,EAAUwsD,GACrC,MAAuDx/G,EAAU,CAACoB,KAAMA,GACxEogH,GACExhH,EACA2/L,GACAC,GACA5sI,EACAwsD,OACAnpH,EACAxG,KAEJ,IArzEEgwM,UAAa//E,GAAkBggF,MAMjC,IAAIC,GAkBAC,GAKAC,GAKAC,GAKAC,GAKAC,GAjCAC,GAAqB,KAsCzB,IAaIC,GAbAC,GAAsB,KAkB1B,IAaIC,GAbA37B,GAAuB,KAkB3B,IAAI47B,GAAqB,KAazB,IAAIh4D,GAAgB,KAapB,IAkFIi4D,GAlFAC,GAAsB,KAe1B,SAASC,GAAar9L,GACpB,OAAO,GAAKzH,KAAKwP,IAAI/H,EAAK,GAAIA,EAAK,GACrC,CAiFA,SAASs9L,GAAuBhhI,GAC9B,OAAOA,CACT,CA0uBA,SAASihI,GAAUC,EAAYC,EAAcC,GAC3C,OAAI/uM,MAAMC,QAAQ4uM,GACTA,EAEiB,iBAAfA,EACFD,GAAUG,EAAaF,GAAaC,EAAcC,GAEpDD,CACT,CAMA,SAASE,GAAU9/L,GACjB,MAAMw4B,EAAI6kF,GAAkBr9G,GAAM,GAG5B4O,EAAI,gCAAgCwqB,KAAKZ,GAC/C,GAAI5pB,EAAG,CACL,MAAMmxL,EAAWnxL,EAAE,GACnB,MAAO,CACL1P,SAAS6gM,EAASh7F,OAAO,EAAG,GAAI,IAChC7lG,SAAS6gM,EAASh7F,OAAO,EAAG,GAAI,IAChC7lG,SAAS6gM,EAASh7F,OAAO,EAAG,GAAI,IAChC7lG,SAAS6gM,EAASh7F,OAAO,EAAG,GAAI,IAAM,IAEzC,CAEH,CAMO,SAASqpF,GAAoBpuL,GAClC,IAAIw4B,EAAI6kF,GAAkBr9G,GAAM,GAChC,MAAMuJ,EAAkB,GAGxBivB,EAAIA,EAAEvmB,QAAQ,WAAY,KAC1B,MAAMqhL,EACJ,qIACF,IAAI1kL,EACJ,KAAQA,EAAI0kL,EAAGl6J,KAAKZ,IAAK,CACvB,MAAM1yB,EAAI0zB,WAAW5qB,EAAE,IACjB7I,EAAIyzB,WAAW5qB,EAAE,IACjBof,EAAIpf,EAAE,GAAK4qB,WAAW5qB,EAAE,IAAM,EACpCrF,EAAgBnV,KAAK0R,EAAGC,EAAGioB,GAC3BwK,EAAIA,EAAEusE,OAAOn2F,EAAE,GAAGhf,OACnB,CACD,GAAU,KAAN4oC,EAGJ,OAAOjvB,CACT,CAMA,SAAS6zL,GAAQp9L,GACf,MAAMw4B,EAAI6kF,GAAkBr9G,GAAM,GAAOs5B,OACzC,IAAI0mK,EAAUhgM,EAAKggM,QAInB,GAHKA,GAAsB,eAAXA,IACdA,EAAUjiM,OAAOgmH,SAAStlD,MAExBuhI,EAAS,CAEX,OADY,IAAIxhI,IAAIhmC,EAAGwnK,GACZvhI,IACZ,CACD,OAAOjmC,CACT,CAMA,SAASokK,GAAa58L,GAGpB,MAAMw4B,EAAI6kF,GAAkBr9G,GAAM,GAC/Bs5B,OACArnB,QAAQ,WAAY,KACvB,IAAI+tL,EAAUhgM,EAAKggM,QAInB,GAHKA,GAAsB,eAAXA,IACdA,EAAUjiM,OAAOgmH,SAAStlD,MAExBuhI,EAAS,CAEX,OADY,IAAIxhI,IAAIhmC,EAAGwnK,GACZvhI,IACZ,CACD,OAAOjmC,CACT,CAqCA,SAASynK,GAAUjgM,GACjB,OAAO0sL,GAAY1sL,EACrB,CAOA,MAAMkgM,GAAoBxgF,GAAgBi1E,GAAgB,CACxDwL,KA22BF,SAAwBngM,EAAMo+G,GAC5B,MAAMgiF,EAAajgF,GAAgB,CAAE,EAAEkgF,GAAcrgM,EAAMo+G,EAAa3vH,MACxE,IAAK2xM,EACH,OAEF,MAAMpqM,EAAuCoqM,EAAiB,IAC9D,GAAIpqM,GAAc,UAAPA,EAAiB,CAC1B,MAAM2mM,EAA4CyD,EAAsB,SACpEzD,IACFv+E,EAAYA,EAAYxuH,OAAS,GAAK+sM,GAExC,MAAM39L,EAA8BohM,EAAmB,MACnDphM,IACFo/G,EAAYA,EAAYxuH,OAAS,GAAKoP,EAEzC,CACH,IAl3BA,SAASs9L,GAAkBt8L,EAAMo+G,GAC/B,OAAO+B,QAAgBlrH,EAAWirM,GAAmBlgM,EAAMo+G,EAAa3vH,KAC1E,CAOA,MAAM6xM,GAAqB5gF,GAAgBi1E,GAAgB,CACzDl/C,KAAQh3B,IAsYV,SAAkBz+G,EAAMo+G,GACtB,MAAMmiF,EAAapgF,GAAgB,CAAA,EAAIqgF,GAAcxgM,EAAMo+G,GAC3D,GAAImiF,EACF,OAAOA,EAET,OAAO,IACT,IA3YE7nK,MAAS+lF,GAAyBqhF,IAClC93K,QAAWy2F,GAAyBiuE,IACpC+T,QAAWhiF,IA/Db,SAAkBz+G,GAChB,MAAM0gM,EAAS1gM,EAAKgqL,aAAa,UAC3B2W,EAAS3gM,EAAKgqL,aAAa,UAEjC,IAAI91G,EAcJ,OAXIA,EAFW,gBAAXwsH,EACa,gBAAXC,EACO,cAEA,WAGI,gBAAXA,EACO,eAEA,YAGN,CACL76L,EAAG0zB,WAAWx5B,EAAKgqL,aAAa,MAChC0W,OAAQhF,GAAsBgF,GAC9B36L,EAAGyzB,WAAWx5B,EAAKgqL,aAAa,MAChC2W,OAAQjF,GAAsBiF,GAC9BzsH,OAAQA,EAEZ,IAuCE9tE,MAASq4G,GAAyBwhF,MA+IpC,MAAMW,GAAsBlhF,GAAgBi1E,GAAgB,CAC1Dj8J,MAAS+lF,GAAyBqhF,IAClC15L,MAASq4G,GAAyBwhF,MA8BpC,MAAMY,GAAqBnhF,GAAgBi1E,GAAgB,CACzDj8J,MAAS+lF,GAAyBqhF,IAClC5hM,MAASugH,GAAyBiuE,MAgCpC,MAAMoU,GAAqBphF,GAAgBi1E,GAAgB,CACzDj8J,MAAS+lF,GAAyBqhF,IAClCp8H,KAAQ+6C,GAAyB6tE,IACjCyU,QAAWtiF,GAAyB6tE,MAmCtC,MAAM0U,GAA2BthF,GAAgBi1E,GAAgB,CAC/D3sL,YAAes2G,GAAa8vE,MAQ9B,SAAS7C,GAAmBvrL,EAAMo+G,GAChC,OAAO+B,GAAgB,KAAM6gF,GAA0BhhM,EAAMo+G,EAC/D,CA8BA,MAAM2+E,GAAiCr9E,GAAgB+7E,GAAmB,CACxEuB,MAAS3+E,GAAgB4+E,MA0B3B,MAAMgE,GAAmBvhF,GACvBi1E,GACA,CACEuM,KA2uBJ,SAAoBlhM,EAAMo+G,GACxB,MAGM+iF,EADH/iF,EAAYA,EAAYxuH,OAAS,GACRuxM,MACtB3oK,EAAI6kF,GAAkBr9G,GAAM,GAC5BkhM,EAAO10K,KAAKmN,MAAMnB,GACxB2oK,EAAM/sM,KAAK6oB,MAAMikL,GAAQ,EAAIA,EAC/B,GAjvBExhF,GAAgB+7E,GAAmB,CACjCngL,MAzDJ,SAAuBtb,EAAMo+G,GAC3B,MAGMp2G,EADHo2G,EAAYA,EAAYxuH,OAAS,GACFoY,YAC5BwwB,EAAI6kF,GAAkBr9G,GAAM,GAG5B4O,EADJ,8HACWwqB,KAAKZ,GAClB,GAAI5pB,EAAG,CACL,MAAM9I,EAAI0zB,WAAW5qB,EAAE,IACjB7I,EAAIyzB,WAAW5qB,EAAE,IACjBof,EAAIwL,WAAW5qB,EAAE,IACvB5G,EAAY5T,KAAK,CAAC0R,EAAGC,EAAGioB,GAC5B,MACIhmB,EAAY5T,KAAK,GAErB,KAiDA,SAAS6oM,GAAYj9L,EAAMo+G,GACzB,MAAMgjF,EAAgBjhF,GACU,CAC5Bn4G,YAAa,GACbm5L,MAAO,IAETF,GACAjhM,EACAo+G,GAEF,IAAKgjF,EACH,OAEF,MAAM73L,EAAkB,GAClBvB,EAAco5L,EAAcp5L,YAC5Bm5L,EAAQC,EAAcD,MAC5B,IACE,IAAI9wM,EAAI,EAAGuE,EAAK8F,KAAKwP,IAAIlC,EAAYpY,OAAQuxM,EAAMvxM,QACnDS,EAAIuE,IACFvE,EAE2B,GAAzB2X,EAAY3X,GAAGT,QACjB2Z,EAAgBnV,KACd4T,EAAY3X,GAAG,GACf2X,EAAY3X,GAAG,GACf2X,EAAY3X,GAAG,GACf8wM,EAAM9wM,IAIZ,OAAO,IAAIi5E,GAAW//D,EAAiB,OACzC,CAOA,MAAMi3L,GAAe9gF,GACnBi1E,GACA,CACEl2H,KAAQggD,GAAyB2+E,KAEnC19E,GAAgB+7E,GAAmB,CACjC31L,EAAK24G,GAAyBiuE,IAC9B3mL,EAAK04G,GAAyBiuE,IAC9BjmJ,EAAKg4E,GAAyBiuE,IAC9B19J,EAAKyvF,GAAyBiuE,OAsBlC,MAAMlB,GAAoC9rE,GAAgBi1E,GAAgB,CACxE3sL,YAAes2G,GAAa8vE,MAQ9B,SAAS3D,GAA4BzqL,EAAMo+G,GACzC,OAAO+B,GACL,KACAqrE,GACAxrL,EACAo+G,EAEJ,CAOA,MAAMijF,GAAoC3hF,GAAgBi1E,GAAgB,CACxE2M,QAAW7iF,GAAyB6tE,IACpCiV,WAAc9iF,GAAyB6tE,IACvC0O,aAAgBv8E,GAAyBquE,MAQ3C,SAASxB,GAAetrL,EAAMo+G,GAC5B,MAAM76G,EAAa48G,GACjB,CAAE,EACFkhF,GACArhM,EACAo+G,GAEI70G,EAAkBkhL,GAA4BzqL,EAAMo+G,GAC1D,GAAI70G,EAAiB,CACnB,MAAMk+E,EAAa,IAAIne,GAAW//D,EAAiB,OAEnD,OADAk+E,EAAW7vF,cAAc2L,GAAY,GAC9BkkF,CACR,CAEH,CAOA,SAASgkG,GAAezrL,EAAMo+G,GAC5B,MAAM76G,EAAa48G,GACjB,CAAE,EACFkhF,GACArhM,EACAo+G,GAEI70G,EAAkBkhL,GAA4BzqL,EAAMo+G,GAC1D,GAAI70G,EAAiB,CACnB,MAAM0b,EAAU,IAAIP,GAAQnb,EAAiB,MAAO,CAClDA,EAAgB3Z,SAGlB,OADAq1B,EAAQrtB,cAAc2L,GAAY,GAC3B0hB,CACR,CAEH,CAOA,MAAMu8K,GAAyB9hF,GAAgBi1E,GAAgB,CAC7DrrH,WAAc+0C,GAAgBitE,IAC9B3pK,WAAc08F,GAAgBotE,IAC9BwQ,cAAiB59E,GAAgB69E,IACjCj6K,MAASo8F,GAAgBmsE,IACzB9lK,QAAW25F,GAAgBqtE,MAQ7B,SAASwQ,GAAkBl8L,EAAMo+G,GAC/B,MAAMn6C,EAAak8C,GACjB,GACAqhF,GACAxhM,EACAo+G,GAEF,IAAKn6C,EACH,OAAO,KAET,GAA0B,IAAtBA,EAAWr0E,OACb,OAAO,IAAIg6E,GAAmB3F,GAEhC,IAAIw9H,EACAC,GAAc,EAClB,MAAMlzM,EAAOy1E,EAAW,GAAG9mD,UAC3B,IAAI9Z,EACJ,IAAK,IAAIhT,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAEhD,GADAgT,EAAW4gE,EAAW5zE,GAClBgT,EAAS8Z,WAAa3uB,EAAM,CAC9BkzM,GAAc,EACd,KACD,CAEH,GAAIA,EAAa,CACf,IAAI9jL,EACArU,EACJ,GAAY,SAAR/a,EAAiB,CACnB,MAAM6iB,EAAQ4yD,EAAW,GACzBrmD,EAASvM,EAAMkN,YACfhV,EAAkB8H,EAAM2M,qBACxB,IAAK,IAAI3tB,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAChDgT,EAAW4gE,EAAW5zE,GACtBM,EAAO4Y,EAAiBlG,EAAS2a,sBAEnCyjL,EAAgB,IAAIh4H,GAAWlgE,EAAiBqU,GAChD+jL,GAA4BF,EAAex9H,EACjD,MAAW,GAAY,cAARz1E,EACTizM,EAAgB,IAAI/3H,GAAgBzF,GACpC09H,GAA4BF,EAAex9H,QACtC,GAAY,WAARz1E,EACTizM,EAAgB,IAAI93H,GAAa1F,GACjC09H,GAA4BF,EAAex9H,OACtC,IAAY,sBAARz1E,EAGT,MAAM,IAAIyI,MAAM,+BAFhBwqM,EAAgB,IAAI73H,GAAmB3F,EAGxC,CACL,MACIw9H,EAAgB,IAAI73H,GAAmB3F,GAEzC,OAAA,CACF,CAOA,SAASumH,GAAUxqL,EAAMo+G,GACvB,MAAM76G,EAAa48G,GACjB,CAAE,EACFkhF,GACArhM,EACAo+G,GAEI70G,EAAkBkhL,GAA4BzqL,EAAMo+G,GAC1D,GAAI70G,EAAiB,CACnB,MAAM8H,EAAQ,IAAI4Q,GAAM1Y,EAAiB,OAEzC,OADA8H,EAAMzZ,cAAc2L,GAAY,GACzB8N,CACR,CAEH,CAOA,MAAMu6K,GAA4BlsE,GAAgBi1E,GAAgB,CAChE7D,gBAsbF,SAA+B9wL,EAAMo+G,GACnC,MAAMwjF,EAA+BzhF,GACvC,GACI0hF,GACA7hM,EACAo+G,GAEF,GAAIwjF,EAA6BhyM,OAAS,EAAG,CAGxCwuH,EAAYA,EAAYxuH,OAAS,GACpBwE,QAAQwtM,EACzB,CACH,EAlcE7Q,gBAidF,SAA+B/wL,EAAMo+G,GAEnC,MAAMswE,EAAiBvuE,QACrBlrH,EACA6sM,GACA9hM,EACAo+G,GAEF,GAAIswE,EAAgB,CAGftwE,EAAYA,EAAYxuH,OAAS,GACpB,GAAK8+L,CACtB,CACH,IAvdA,SAAShD,GAAY1rL,EAAMo+G,GACzB,MAAM76G,EAAa48G,GACrB,CAAuC,EACnCkhF,GACArhM,EACAo+G,GAEIutE,EAAkBxrE,GACtB,CAAC,MACDyrE,GACA5rL,EACAo+G,GAEF,GAAIutE,GAAmBA,EAAgB,GAAI,CACzC,MAAMpiL,EAAkBoiL,EAAgB,GAClCtsK,EAAO,CAAC9V,EAAgB3Z,QAC9B,IAAK,IAAIS,EAAI,EAAGuE,EAAK+2L,EAAgB/7L,OAAQS,EAAIuE,IAAMvE,EACrDM,EAAO4Y,EAAiBoiL,EAAgBt7L,IACxCgvB,EAAKjrB,KAAKmV,EAAgB3Z,QAE5B,MAAMq1B,EAAU,IAAIP,GAAQnb,EAAiB,MAAO8V,GAEpD,OADA4F,EAAQrtB,cAAc2L,GAAY,GAC3B0hB,CACR,CAEH,CAOA,MAAM88K,GAAgBriF,GAAgBi1E,GAAgB,CACpDqN,UA7lBF,SAAyBhiM,EAAMo+G,GAO7B,MAAM/qH,EAAS8sH,GAAgB,CAAA,EAAImgF,GAAoBtgM,EAAMo+G,GAC7D,IAAK/qH,EACH,OAEF,MAAM4uM,EACJ7jF,EAAYA,EAAYxuH,OAAS,GAE7BsyM,EAAa,SAAU7uM,EAASA,EAAa,KAAI,GACjD8uM,IAAa,SAAU9uM,IAAW8B,OAAOC,KAAK8sM,GAAYtyM,OAAS,EACzE,IAAI05B,EACJ,MAAMm1C,EAAwCyjI,EAAkB,KAMhE,IAAIrmL,EAAQi6H,EAAcE,EALtBv3E,EACFn1C,EAAMm1C,EACG0jI,IACT74K,EAAM01K,IAIR,IAAIppD,EAAe,cACnB,MAAM6qD,EAAyCptM,EAAiB,QAuBhE,IAAImW,EAtBAi3L,GACF5kL,EAAS,CAAC4kL,EAAQ36L,EAAG26L,EAAQ16L,GAC7B+vI,EAAe2qD,EAAQC,OACvB1qD,EAAeyqD,EAAQE,OACvB/qD,EAAe6qD,EAAQvsH,QACd,8CAA8Cp3E,KAAKwsB,KAExDA,EAAIn1B,SAAS,YACf0nB,EAAS+iL,GACT9oD,EAAe+oD,GACf7oD,EAAe8oD,IACNx1K,EAAIn1B,SAAS,kBACtB0nB,EAAS,CAAC,GAAI,IACdi6H,EAAe+oD,GACf7oD,EAAe8oD,IACNx1K,EAAIn1B,SAAS,YACtB0nB,EAAS,CAAC,GAAI,GACdi6H,EAAe+oD,GACf7oD,EAAe8oD,KAKnB,MAAMh5L,EAAqCo8L,EAAe,EACpDn8L,EAAqCm8L,EAAe,EAK1D,IAAI//L,OAJMlN,IAAN6Q,QAAyB7Q,IAAN8Q,IACrByD,EAAS,CAAC1D,EAAGC,IAIf,MAAM0gC,EAAqCy7J,EAAe,EACpDlzK,EAAqCkzK,EAAe,EAK1D,IAAI72L,OAJMpW,IAANwxC,QAAyBxxC,IAAN+5B,IACrB7sB,EAAO,CAACskC,EAAGzX,IAIb,MAAMhH,EAAiC30B,EAAiB,aACxC4B,IAAZ+yB,IACF3c,EAAW+H,GAAU4U,IAGvB,MAAM5hB,EAAyC/S,EAAe,MAExDqlC,EAAgDrlC,EAAe,MAErE,GAAI8uM,EAAU,CACR74K,GAAO01K,KACT78L,EAAO48L,IAGT,MAAM5+H,EAAa,IAAIs1E,GAAK,CAC1B55H,OAAQA,EACR+5H,aAAcA,EACdE,aAAcA,EACdE,aAAcA,EACdlrH,YAAar8B,KAAKu8B,aAClBxhB,OAAQA,EACR6sI,aAAc,cACdhrI,SAAUA,EACVjF,MAAOA,EACPjE,KAAMA,EACNmnB,IAAK76B,KAAK2zM,iBAAiB94K,GAC3BoP,MAAOA,IAGHquC,EAAa5G,EAAW6G,gBAAgB,GACxCR,EAAYrG,EAAW/9D,UAC7B,GAAkB,OAAdokE,EAAoB,CACtB,MAAM+D,EAAapK,EAAW2I,gBAC9B,GAAIyB,IAAe1hD,IAAmB0hD,IAAe1hD,GAAoB,CACvE,MAAM70B,EAAW,WACf,MAAMu2E,EAAapK,EAAW2I,gBAC9B,GAEIyB,IAAe1hD,IACf0hD,IAAe1hD,GAEjB,CACA,MAAM29C,EAAYrG,EAAW/9D,UAC7B,GAAIokE,GAAiC,GAApBA,EAAU52E,OAAa,CACtC,MAAMyyM,EAAc7C,GAAah5H,GACjCrG,EAAWgyE,SAASprE,EAAas7H,EAClC,CACDliI,EAAWqK,oBAAoBx2E,EAChC,CACX,EACQmsE,EAAWsK,kBAAkBz2E,GACzBu2E,IAAe1hD,IACjBs3C,EAAWpkE,MAEd,CACP,MAAW,GAAwB,GAApByqE,EAAU52E,OAAa,CAChC,MAAMyyM,EAAc7C,GAAah5H,GACjCrG,EAAWgyE,SAASprE,EAAas7H,EAClC,CACDJ,EAAwB,WAAI9hI,CAChC,MAEI8hI,EAAwB,WAAI/C,EAEhC,EA8dEoD,WA9cF,SAA0BtiM,EAAMo+G,GAE9B,MAAM/qH,EAAS8sH,GAAgB,CAAA,EAAIygF,GAAqB5gM,EAAMo+G,GAC9D,IAAK/qH,EACH,OAEF,MAAM4uM,EAAc7jF,EAAYA,EAAYxuH,OAAS,GAC/C0wE,EAAY,IAAI63E,GAAK,CACzBz0E,KAAM,IAAI6wE,GAAK,CACb77G,MAEG,UAAWrlC,EAASA,EAAc,MAAIsrM,KAE3Cv4L,MAAwC/S,EAAe,QAEzD4uM,EAAuB,UAAI3hI,CAC7B,EA+bEiiI,UA/aF,SAAyBviM,EAAMo+G,GAM7B,MAAM/qH,EAAS8sH,GAAgB,CAAA,EAAI0gF,GAAoB7gM,EAAMo+G,GAC7D,IAAK/qH,EACH,OAEF,MAAM4uM,EAAc7jF,EAAYA,EAAYxuH,OAAS,GAC/CqwE,EAAc,IAAIy2E,GAAO,CAC7Bh+G,MAEG,UAAWrlC,EAASA,EAAc,MAAIsrM,GACzCzgM,MAA8B,UAAW7K,EAASA,EAAc,MAAI,IAEtE4uM,EAAyB,YAAIhiI,CAC/B,EA8ZEuiI,UA7YF,SAAyBxiM,EAAMo+G,GAE7B,MAAM/qH,EAAS8sH,GAAgB,CAAA,EAAI2gF,GAAoB9gM,EAAMo+G,GAC7D,IAAK/qH,EACH,OAEF,MAAM4uM,EAAc7jF,EAAYA,EAAYxuH,OAAS,GAC/C27B,EAAY,IAAIgpH,GAAK,CACzB77G,MAEG,UAAWrlC,EAASA,EAAc,MAAIsrM,KAE3CsD,EAAuB,UAAI12K,EAC3B,MAAMm4C,EAAyCrwE,EAAc,UAChD4B,IAATyuE,IACFu+H,EAAkB,KAAIv+H,GAExB,MAAMq9H,EAA4C1tM,EAAiB,aACnD4B,IAAZ8rM,IACFkB,EAAqB,QAAIlB,EAE7B,IAiYA,SAAS5E,GAAUn8L,EAAMo+G,GACvB,MAAM6jF,EAAc9hF,GAClB,CAAE,EACF4hF,GACA/hM,EACAo+G,EACA3vH,MAEF,IAAKwzM,EACH,OAAO,KAET,IAAI12K,EAGA,cAAe02K,EAAcA,EAAuB,UAAIhD,GAE5D,MAAMv7H,EAAyCu+H,EAAmB,KAIlE,IAAI9hI,OAHSlrE,IAATyuE,GAAuBA,IACzBn4C,EAAY,MAGV,eAAgB02K,EACdA,EAAwB,YAAK/C,KAC/B/+H,EACE8hI,EACR,YAGI9hI,EAAag/H,GAEf,MAAM7+H,EAGF,cAAe2hI,EAAcA,EAAuB,UAAI5C,GAEtDp/H,EAGF,gBAAiBgiI,EACbA,EAAyB,YACzBx+B,GAEFs9B,EAA4CkB,EAAsB,QACxE,YAAgBhtM,IAAZ8rM,GAA0BA,EA6DvB,CACL,IAAIxpD,GAAM,CACR7zE,KAAMn4C,EACNhqB,MAAO4+D,EACPwD,OAAQ1D,EACR5uB,KAAMivB,EACN7kC,YAAQxmC,KA/DH,CACL,IAAIsiJ,GAAM,CACRl0I,SAAU,SAAU+qC,GAClB,MAAM/qC,EAAW+qC,EAAQzqC,cACnBnV,EAAO6U,EAAS8Z,UACtB,GAAa,uBAAT3uB,EAA+B,CAKjC,OAAO,IAAIo7E,GAHvB,EAKiByc,8BACAngD,QAAO,SAAU7iC,GAChB,MAAM7U,EAAO6U,EAAS8Z,UACtB,MAAgB,YAAT3uB,GAA+B,iBAATA,CAC/C,IAEW,CACD,GAAa,YAATA,GAA+B,iBAATA,EACxB,OAAO6U,CAEV,EACDqgE,KAAMn4C,EACNhqB,MAAO4+D,EACPwD,OAAQ1D,EACR5uB,KAAMivB,EACN7kC,YAAQxmC,IAEV,IAAIsiJ,GAAM,CACRl0I,SAAU,SAAU+qC,GAClB,MAAM/qC,EAAW+qC,EAAQzqC,cACnBnV,EAAO6U,EAAS8Z,UACtB,GAAa,uBAAT3uB,EAA+B,CAKjC,OAAO,IAAIo7E,GAHvB,EAKiByc,8BACAngD,QAAO,SAAU7iC,GAChB,MAAM7U,EAAO6U,EAAS8Z,UACtB,MAAgB,YAAT3uB,GAA+B,iBAATA,CAC/C,IAEW,CACD,GAAa,YAATA,GAA+B,iBAATA,EACxB,OAAO6U,CAEV,EACDqgE,KAAMn4C,EACNo4C,OAAQ,KACRloC,YAAQxmC,IAahB,CAQA,SAAS0sM,GAA4BF,EAAex9H,GAClD,MAAMrvE,EAAKqvE,EAAWr0E,OAChB6yM,EAAW,IAAI3xM,MAAMmzE,EAAWr0E,QAChC8yM,EAAc,IAAI5xM,MAAMmzE,EAAWr0E,QACnC+yM,EAAgB,IAAI7xM,MAAMmzE,EAAWr0E,QAC3C,IAAIgzM,EAAYC,EAAeC,EAC/BF,GAAa,EACbC,GAAgB,EAChBC,GAAkB,EAClB,IAAK,IAAIzyM,EAAI,EAAGA,EAAIuE,IAAMvE,EAAG,CAC3B,MAAMgT,EAAW4gE,EAAW5zE,GAC5BoyM,EAASpyM,GAAKgT,EAASxL,IAAI,WAC3B6qM,EAAYryM,GAAKgT,EAASxL,IAAI,cAC9B8qM,EAActyM,GAAKgT,EAASxL,IAAI,gBAChC+qM,EAAaA,QAA8B3tM,IAAhBwtM,EAASpyM,GACpCwyM,EAAgBA,QAAoC5tM,IAAnBytM,EAAYryM,GAC7CyyM,EAAkBA,GAAmBH,EAActyM,EACpD,CACGuyM,GACFnB,EAAcjpM,IAAI,UAAWiqM,GAE3BI,GACFpB,EAAcjpM,IAAI,aAAckqM,GAE9BI,GACFrB,EAAcjpM,IAAI,eAAgBmqM,EAEtC,CAOA,MAAMI,GAAerjF,GAAgBi1E,GAAgB,CACnDqO,YAAevkF,GAAyBquE,IACxCh6L,MAAS2rH,GAAyBquE,MAkCpC,MAAMmW,GAAwBvjF,GAAgBi1E,GAAgB,CAC5DuO,KA5BF,SAAoBljM,EAAMo+G,GACxB,MAAMj6G,EAAOnE,EAAKgqL,aAAa,QAC/BlqE,GAAUijF,GAAc/iM,EAAMo+G,GAC9B,MAAM27E,EACJ37E,EAAYA,EAAYxuH,OAAS,GAE/BuU,GAAQ41L,EAAciJ,YACxBjJ,EAAc51L,GAAQ,CACpBrR,MAAOinM,EAAcjnM,MACrBkwM,YAAajJ,EAAciJ,YAC3B37L,SAAU,WACR,OAAO0yL,EAAcjnM,KACtB,GAEe,OAATqR,EACT41L,EAAc51L,GAAQ41L,EAAcjnM,MACG,OAA9BinM,EAAciJ,cACvBjJ,EAAcA,EAAciJ,aAAejJ,EAAcjnM,cAEpDinM,EAAqB,KAC9B,EASEoJ,WAqFF,SAA0BnjM,EAAMo+G,GAC9B0B,GAAUsjF,GAAqBpjM,EAAMo+G,EACvC,IAhFA,SAAS09E,GAAmB97L,EAAMo+G,GAChC0B,GAAUmjF,GAAuBjjM,EAAMo+G,EACzC,CAMA,SAAS49E,GAAah8L,EAAMo+G,GAC1B0B,GAAU+9E,GAAgB79L,EAAMo+G,EAClC,CAOA,MAAMiiF,GAAe3gF,GAAgBi1E,GAAgB,CACnDp9C,MAAS94B,GAAyB09E,IAClCnmM,IAAOyoH,GAAyBquE,IAChC6P,SAAYl+E,GAAyBm+E,MAkDvC,MAAMwG,GAAsB1jF,GAAgBi1E,GAAgB,CAC1D0O,WAeF,SAA0BrjM,EAAMo+G,GAC9B,MAAMj6G,EAAOnE,EAAKgqL,aAAa,QAC/B,GAAa,OAAT7lL,EAAe,CACjB,MAAMvT,EAAOk8L,GAAW9sL,GAEtBo+G,EAAYA,EAAYxuH,OAAS,GAErBuU,GAAQvT,CACvB,CACH,IAOA,MAAMmtM,GAA0Br+E,GAAgBi1E,GAAgB,CAC9DqG,aAAgBv8E,GAAyBquE,IACzCwW,YAAe7kF,GAAyBiuE,IACxC6W,YAAe9kF,GAAyBiuE,IACxC8W,MAAS/kF,GAAyBiuE,IAClC+W,MAAShlF,GAAyBiuE,IAClCgX,KAAQjlF,GAAyBiuE,IACjCiX,KAAQllF,GAAyBiuE,MAqCnC,MAAMwR,GAAcx+E,GAAgBi1E,GAAgB,CAClDiP,aAAgBnlF,GAAyBiuE,IACzCmX,aAAgBplF,GAAyBiuE,IACzCoX,cAAiBrlF,GAAyBiuE,IAC1CqX,cAAiBtlF,GAAyBiuE,MAwB5C,MAAMmV,GAA4BniF,GAAgBi1E,GAAgB,CAGhEhzK,WAAc08F,GAAgBktE,MA2BhC,MAAMuW,GAA4BpiF,GAAgBi1E,GAAgB,CAChEhzK,WAAc28F,GAAaitE,MAiD7B,SAASyY,GAAmBhkM,EAAM04B,GAChC,MAAMD,EAAO4B,GAAQ3B,GAGfurK,EAAO,CAAW,KAFO,GAAfxrK,EAAK7oC,OAAc6oC,EAAK,GAAK,GAEhBA,EAAK,GAAIA,EAAK,GAAIA,EAAK,IACpD,IAAK,IAAIpoC,EAAI,EAAGA,EAAI,IAAKA,EAAG,CAC1B,MAAM6zM,EAAMxpM,KAAKuT,MAA6Bg2L,EAAK5zM,IAAKgX,SAAS,IACjE48L,EAAK5zM,GAAmB,GAAd6zM,EAAIt0M,OAAc,IAAMs0M,EAAMA,CACzC,CACDjX,GAAoBjtL,EAAMikM,EAAK18L,KAAK,IACtC,CA4CA,MAAM48L,GAAgCzkF,GAAgBi1E,GAAgB,CACpEuO,KAAQxkF,IAUV,SAAuB1+G,EAAMokM,EAAMhmF,GACjCp+G,EAAK4/C,aAAa,OAAQwkJ,EAAKjgM,MAC/B,MAAuDvF,EAAU,CAACoB,KAAMA,GAClElN,EAAQsxM,EAAKtxM,MAEC,iBAATA,GACK,OAAVA,GAAkBA,EAAMkwM,aAC1B5iF,GACExhH,EACAulM,GACA7kF,GACA,CAACxsH,EAAMkwM,aACP5kF,EACA,CAAC,gBAIS,OAAVtrH,GAAkBA,EAAMA,OAC1BstH,GACExhH,EACAulM,GACA7kF,GACA,CAACxsH,EAAMA,OACPsrH,EACA,CAAC,WAILgC,GACExhH,EACAulM,GACA7kF,GACA,CAACxsH,GACDsrH,EACA,CAAC,SAGP,IA9CEtrH,MAAS4rH,IA4DX,SAA4B1+G,EAAMlN,GAChCm6L,GAAoBjtL,EAAMlN,EAC5B,IA7DEkwM,YAAetkF,IAmDjB,SAA2B1+G,EAAMmE,GAC/B+oL,GAAkBltL,EAAMmE,EAC1B,MAeA,MAAMo6L,GAAuB7+E,GAAgBi1E,GAAgB,CAC3D8J,UAAa//E,GAAkBggF,MAU3BF,GAAwB,SAAU1rM,EAAOsrH,EAAaiB,GAE1D,OAAOpC,GADYmB,EAAYA,EAAYxuH,OAAS,GAAGoQ,KACrBk9G,aAAc,YAClD,EA0BA,MAAMmnF,GAAoBrlF,GAAsB,QA6BhD,MAAMslF,GAAgB5kF,GACpBi1E,GACA,CAAC,QACDj1E,GAAgB+7E,GAAmB,CAAC,IAAK,IAAK,IAAK,OAQ/C8I,GAAmB7kF,GACvBi1E,GACA,CACEl2H,KAAQigD,GAAkBuuE,KAE5BvtE,GAAgB+7E,GAAmB,CACjC31L,EAAK44G,GAAkBkvE,IACvB7nL,EAAK24G,GAAkBkvE,IACvBnnJ,EAAKi4E,GAAkBkvE,IACvB5+J,EAAK0vF,GAAkBkvE,OAWrB4W,GAAkB,SAAU1xM,EAAOsrH,EAAaiB,GACpD,OAAOpC,GAAgBw+E,GAAkB,GAAI,MAAQp8E,EACvD,EAqCA,MAAMolF,GAAsB/kF,GAAgBi1E,GAAgB,CAC1D,QACA,UACA,OACA,QACA,YAQI+P,GAAyBhlF,GAAgBi1E,GAAgB,CAC7Dl/C,KAAQ/2B,IA5CV,SAAmB1+G,EAAMkhJ,EAAM9iC,GAC7B,MAAuDx/G,EAAU,CAACoB,KAAMA,GAClEH,EAAau+G,EAAYA,EAAYxuH,OAAS,GAAGoQ,KACvD,IAAIw/G,EAAc8kF,GAAczkM,EAAWq9G,cACvCxlH,EAAS6nH,GAAa2hC,EAAM1hC,GAChCY,GACExhH,EACA2lM,GACAjlF,GACA5nH,EACA0mH,EACAoB,GAEFA,EAAc8kF,GAAc7I,GAAkB,IAC9C/jM,EAAS6nH,GAAa2hC,EAAM1hC,GAC5BY,GACExhH,EACA2lM,GACAC,GACA9sM,EACA0mH,EACAoB,EAEJ,IAsBE9mF,MAASgmF,GAAkBslF,IAC3Bh8K,QAAW02F,GAAkBkvE,IAC7B6S,QAAW/hF,IA2vBb,SAAmB1+G,EAAM2kM,GACvB3kM,EAAK4/C,aAAa,IAAKtoD,OAAOqtM,EAAK7+L,IACnC9F,EAAK4/C,aAAa,IAAKtoD,OAAOqtM,EAAK5+L,IACnC/F,EAAK4/C,aAAa,SAAU+kJ,EAAKjE,QACjC1gM,EAAK4/C,aAAa,SAAU+kJ,EAAKhE,OACnC,IA/vBEv6L,MAASs4G,GAAkBkmF,MAmF7B,MAAMC,GAAuBnlF,GAAgBi1E,GAAgB,CAC3D,QACA,UAQImQ,GAA0BplF,GAAgBi1E,GAAgB,CAC9Dj8J,MAASgmF,GAAkBslF,IAC3B59L,MAASs4G,GAAkBkmF,MAqC7B,MAAMG,GAAsBrlF,GAAgBi1E,GAAgB,CAAC,QAAS,UAOhEqQ,GAAyBtlF,GAAgBi1E,GAAgB,CAC7Dj8J,MAASgmF,GAAkBslF,IAC3B9lM,MAASwgH,GAAkBkvE,MA+B7B,MAAMkK,GAA4B,CAChC71K,MAAS,QACTqnD,WAAc,aACd3nD,WAAc,aACd+C,QAAW,UACX+kD,WAAc,gBACdC,gBAAmB,gBACnBC,aAAgB,gBAChBC,mBAAsB,iBAUlBq7H,GAAwB,SAAUnyM,EAAOsrH,EAAaiB,GAC1D,GAAIvsH,EAAO,CAET,OAAOmqH,GADYmB,EAAYA,EAAYxuH,OAAS,GAAGoQ,KAE1Ck9G,aACX46E,GACuD,EAAQ36K,WAGlE,CACH,EAOM+nL,GAAqBlmF,GAAsB,SAO3CmmF,GAA2BnmF,GAAsB,cAOjDomF,GAA2BpmF,GAAsB,cAOjDqmF,GAAuBrmF,GAAsB,WAO7CsmF,GAA6B5lF,GAAgBi1E,GAAgB,CACjErrH,WAAco1C,GAAkB6mF,IAChCtjL,MAASy8F,GAAkB6mF,IAC3B7gL,QAAWg6F,GAAkB8mF,IAC7B57H,mBAAsB80C,GAAkB+mF,MAQ1C,SAASA,GAAmBzlM,EAAMqD,EAAU+6G,GAE1C,MAAMx/G,EAAU,CAACoB,KAAMA,GACjBxR,EAAO6U,EAAS8Z,UAEtB,IAEIuoL,EAFAzhI,EAAa,GAGjB,GAAa,uBAATz1E,EACgC,EAC/B63F,8BACAzsF,SAAQ,SAAUyJ,GACjB,MAAM7U,EAAO6U,EAAS8Z,UACtB,GAAa,eAAT3uB,EACFy1E,EAAaA,EAAWuhB,OACI,EAAW+C,kBAElC,GAAa,oBAAT/5F,EACTy1E,EAAaA,EAAWuhB,OACS,EAAWyC,uBAEvC,GAAa,iBAATz5F,EACTy1E,EAAaA,EAAWuhB,OACM,EAAW+D,mBAEpC,IACI,UAAT/6F,GACS,eAATA,GACS,YAATA,EAIA,MAAM,IAAIyI,MAAM,yBAFhBgtE,EAAW7vE,KAAKiP,EAGjB,CACT,IACIqiM,EAAUT,QACL,GAAa,eAATz2M,EACTy1E,EAAuC,EAAWskB,YAClDm9G,EAAUR,QACL,GAAa,oBAAT12M,EACTy1E,EAA4C,EAAWgkB,iBACvDy9G,EAAUP,OACL,IAAa,iBAAT32M,EAIT,MAAM,IAAIyI,MAAM,yBAHhBgtE,EAAyC,EAAWslB,cACpDm8G,EAAUL,EAGX,CACDjlF,GACExhH,EACA0mM,GACAI,EACAzhI,EACAm6C,EAEJ,CAOA,MAAMunF,GAA0BjmF,GAAgBi1E,GAAgB,CAC9DhzK,WAAc+8F,GAAkB6mF,MAQlC,SAASK,GAAgB5lM,EAAMuhB,EAAY68F,GAEzCgC,GADiE,CAACpgH,KAAMA,GAGtE2lM,GACAP,GACA,CAAC7jL,GACD68F,EAEJ,CAOA,MAAMynF,GAAwBnmF,GAAgBi1E,GAAgB,CAC5DkH,aAAgBn9E,IA7blB,SAA2B1+G,EAAM8lM,EAAgB1nF,GAC/C,MAAuDx/G,EAAU,CAACoB,KAAMA,GAClEk5B,EAAQ4sK,EAAe5sK,MACvBxhC,EAASouM,EAAepuM,OACxB9H,EAASspC,EAAMtpC,OAErB,IAAK,IAAIS,EAAI,EAAGA,EAAIT,EAAQS,IAC1B+vH,GACExhH,EACAulM,GACAE,GACA,CAAC,CAAClgM,KAAM+0B,EAAM7oC,GAAIyC,MAAO4E,EAAOrH,KAChC+tH,EAGN,IA+aE69E,cAAiBv9E,GAAkB+mF,IACnCn8H,WAAco1C,GAAkB6mF,IAChC5jL,WAAc+8F,GAAkB6mF,IAChCtjL,MAASy8F,GAAkB6mF,IAC3B7gL,QAAWg6F,GAAkB8mF,IAC7BjuD,MAAS74B,IAuXX,SAAoB1+G,EAAMoE,EAAQg6G,GAChC,MAAuDx/G,EAAU,CAACoB,KAAMA,GAClEuD,EAAa,CAAA,EACnB,GAAIa,EAAO2hM,YAAYn2M,OAAQ,CAC7B,MAAM0wE,EAAYl8D,EAAO2hM,YAAY,GAAGjiI,UACpCxD,IACF/8D,EAAuB,WAAI+8D,GAE7B,MAAMH,EAAa/7D,EAAO2hM,YAAY,GAAG97K,WAEvCk2C,GACkD,mBAAzB,EAAmB,SAE5C58D,EAAsB,UAAI48D,EAE7B,CACD,GAAI/7D,EAAO4hM,WAAWp2M,OAAQ,CAC5B,MAAMqwE,EAAc77D,EAAO4hM,WAAW,GAAGniI,YACrC5D,IACF18D,EAAsB,UAAI08D,EAE7B,CACD,GAAI77D,EAAO6hM,WAAWr2M,OAAQ,CAC5B,MAAMqwE,EAAc77D,EAAO6hM,WAAW,GAAGpiI,YACrC5D,IAAgB18D,EAAsB,YACxCA,EAAsB,UAAI08D,GAE5B18D,EAAsB,UAAIa,EAAO6hM,WAAW,EAC7C,CACD,MAAMpmM,EAAau+G,EAAYA,EAAYxuH,OAAS,GAAGoQ,KACjDw/G,EAAc0mF,GAAermM,EAAWq9G,cACxCxlH,EAAS6nH,GAAah8G,EAAYi8G,GACxCY,GACExhH,EACAunM,GACA7mF,GACA5nH,EACA0mH,EACAoB,EAEJ,IA9ZEg9E,QAAW99E,GAAkBuuE,IAC7BwP,YAAe/9E,GAAkBuuE,IACjC9oL,KAAQu6G,GAAkBuuE,IAC1BvwH,KAAQgiD,GAAkBquE,IAC1B2P,YAAeh+E,GAAkBuuE,IACjC0P,SAAYj+E,GAAkBuuE,IAC9B4P,WAAcn+E,GAAkBquE,MAQ5BqZ,GAAqB1mF,GAAgBi1E,GAAgB,CACzD,OACA,OACA,aACA,UACA,cACA,cACA,WACA,UAQI0R,GAA4BrnF,GAAsB,gBAUxD,SAAS0/E,GAAe1+L,EAAMouC,EAASgwE,GACrC,MAAuDx/G,EAAU,CAACoB,KAAMA,GAGpEouC,EAAQtqC,SACV9D,EAAK4/C,aAAa,KAA6BxR,EAAQtqC,SAIzD,MAAMP,EAAa6qC,EAAQp2C,gBAGrBkuC,EAAS,CACbs2J,QAAW,EACXC,YAAe,EACft4L,KAAQ,EACRu4D,KAAQ,EACRggI,YAAe,EACfC,SAAY,EACZE,WAAc,GAEhB32J,EAAOkI,EAAQ1qC,mBAAqB,EACpC,MAAMtO,EAAOD,OAAOC,KAAKmO,GAAc,CAAA,GACpCwf,OACAmjB,QAAO,SAAU1X,GAChB,OAAQ0X,EAAO1X,EACrB,IAEQm7D,EAAgBv7C,EAAQrqC,mBAC9B,GAAI4lF,EAAe,CAGjB,MAAMvlF,EAASulF,EAAcv7C,EAAS,GACtC,GAAIhqC,EAAQ,CACV,MAAMkiM,EAAax1M,MAAMC,QAAQqT,GAAUA,EAAS,CAACA,GACrD,IAAI2hM,EAAcO,EAmBlB,GAlBIl4J,EAAQzqC,gBACVoiM,EAAcO,EAAWpgK,QAAO,SAAUlnC,GACxC,MAAMqE,EAAWrE,EAAMglE,qBAANhlE,CAA4BovC,GAC7C,GAAI/qC,EAAU,CACZ,MAAM7U,EAAO6U,EAAS8Z,UACtB,MAAa,uBAAT3uB,EACuC,EACtC63F,8BACAngD,QAAO,SAAU7iC,GAChB,MAAM7U,EAAO6U,EAAS8Z,UACtB,MAAgB,UAAT3uB,GAA6B,eAATA,CAC5B,IAAEoB,OAES,UAATpB,GAA6B,eAATA,CAC5B,CACX,KAGUC,KAAK83M,aAAc,CACrB,IAAIP,EAAaM,EACbL,EAAaK,EACbl4J,EAAQzqC,gBACVqiM,EAAaM,EAAWpgK,QAAO,SAAUlnC,GACvC,MAAMqE,EAAWrE,EAAMglE,qBAANhlE,CAA4BovC,GAC7C,GAAI/qC,EAAU,CACZ,MAAM7U,EAAO6U,EAAS8Z,UACtB,MAAa,uBAAT3uB,EACuC,EACtC63F,8BACAngD,QAAO,SAAU7iC,GAChB,MAAM7U,EAAO6U,EAAS8Z,UACtB,MAAgB,eAAT3uB,GAAkC,oBAATA,CACjC,IAAEoB,OAES,eAATpB,GAAkC,oBAATA,CACjC,CACb,IACUy3M,EAAaK,EAAWpgK,QAAO,SAAUlnC,GACvC,MAAMqE,EAAWrE,EAAMglE,qBAANhlE,CAA4BovC,GAC7C,GAAI/qC,EAAU,CACZ,MAAM7U,EAAO6U,EAAS8Z,UACtB,MAAa,uBAAT3uB,EACuC,EACtC63F,8BACAngD,QAAO,SAAU7iC,GAChB,MAAM7U,EAAO6U,EAAS8Z,UACtB,MAAgB,YAAT3uB,GAA+B,iBAATA,CAC9B,IAAEoB,OAES,YAATpB,GAA+B,iBAATA,CAC9B,CACb,KAEQ+U,EAAkB,MAAI,CACpBwiM,YAAaA,EACbC,WAAYA,EACZC,WAAYA,EAEf,CACD,GAAIF,EAAYn2M,aAAiCqF,IAAvBsO,EAAiB,KAAiB,CAC1D,MAAM+8D,EAAYylI,EAAY,GAAGjiI,UAC7BxD,IACF/8D,EAAiB,KAAI+8D,EAAUwD,UAElC,CACF,CACF,CACD,MAAMjkE,EAAau+G,EAAYA,EAAYxuH,OAAS,GAAGoQ,KACjDw/G,EAAc4mF,GAAmBvmM,EAAWq9G,cAC5CxlH,EAAS6nH,GAAah8G,EAAYi8G,GAUxC,GATAY,GACExhH,EACAinM,GACAvmF,GACA5nH,EACA0mH,EACAoB,GAGEpqH,EAAKxF,OAAS,EAAG,CACnB,MAAM6vH,EAAWF,GAAah8G,EAAYnO,GAE1CgrH,GACExhH,EACAinM,GACAQ,GACA,CALqB,CAACntK,MAAO9jC,EAAMsC,OAAQ+nH,IAM3CrB,EAEH,CAGD,MAAMhlH,EACJglH,EAAY,GAEd,IAAI/6G,EAAW+qC,EAAQzqC,cACnBN,IACFA,EAAW+hL,GAA6B/hL,GAAU,EAAMjK,IAE1DgnH,GACExhH,EACAinM,GACAZ,GACA,CAAC5hM,GACD+6G,EAEJ,CAOA,MAAMooF,GAA8B9mF,GAAgBi1E,GAAgB,CAClE,UACA,aACA,eACA,gBAQI8R,GAAiC/mF,GAAgBi1E,GAAgB,CACrE2M,QAAW5iF,GAAkBquE,IAC7BwU,WAAc7iF,GAAkBquE,IAChCiO,aAAgBt8E,GAAkBuuE,IAClCjlL,YAAe02G,IA5yBjB,SAAkC1+G,EAAMgI,EAAao2G,GACnD,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAE3CguB,EAAShf,EAAgB,OACzB6K,EAAS7K,EAAgB,OAE/B,IAAI+S,EACJ,GAAc,MAAViM,GAA4B,OAAVA,EACpBjM,EAAY,MACP,IAAc,OAAViM,GAA6B,QAAVA,EAG5B,MAAM,IAAI3mB,MAAM,2BAFhB0a,EAAY,CAGb,CAED,MAAM/c,EAAKoT,EAAYpY,OACvB,IAAIyhD,EAAO,GACX,GAAIz8C,EAAK,EAAG,CACVy8C,GAAQrpC,EAAY,GACpB,IAAK,IAAItC,EAAI,EAAGA,EAAIiM,IAAajM,EAC/B2rC,GAAQ,IAAMrpC,EAAYtC,GAE5B,IAAK,IAAIrV,EAAIoZ,EAAQpZ,EAAIuE,EAAIvE,GAAKoZ,EAAQ,CACxC4nC,GAAQ,IAAMrpC,EAAY3X,GAC1B,IAAK,IAAIqV,EAAI,EAAGA,EAAIiM,IAAajM,EAC/B2rC,GAAQ,IAAMrpC,EAAY3X,EAAIqV,EAEjC,CACF,CACDunL,GAAoBjtL,EAAMqxC,EAC5B,MAsxBA,SAASk0J,GAAuBvlM,EAAMqD,EAAU+6G,GAC9C,MAAM70G,EAAkBlG,EAAS2a,qBACsBpf,EAAU,CAACoB,KAAMA,GACxEpB,EAAgB,OAAIyE,EAASkb,YAC7B3f,EAAgB,OAAIyE,EAAS4a,YAG7B,MAAM1a,EAAaF,EAASrL,gBAC5BuL,EAAWyE,YAAcuB,EAEzB,MAAM1J,EAAau+G,EAAYA,EAAYxuH,OAAS,GAAGoQ,KACjDw/G,EAAcgnF,GAA4B3mM,EAAWq9G,cACrDxlH,EAAS6nH,GAAah8G,EAAYi8G,GACxCY,GACExhH,EACA6nM,GACAnnF,GACA5nH,EACA0mH,EACAoB,EAEJ,CAOA,MAAMknF,GAAsBhnF,GAAgBi1E,GAAgB,CAC1D,QACA,OACA,YAQIgS,GAAsBjnF,GAAgBi1E,GAAgB,CAC1D5D,gBAAmBryE,GAAkBknF,IACrC9U,gBAAmBpyE,GAAkBknF,MAQjCgB,GAA8B5nF,GAAsB,mBAOpD6nF,GAA8B7nF,GAAsB,mBAO1D,SAASwmF,GAAaxlM,EAAMilB,EAASm5F,GACnC,MAAM38F,EAAcwD,EAAQS,iBACtB0hK,EAAY3lK,EAAYljB,QACyBK,EAAU,CAACoB,KAAMA,GAExEogH,GACExhH,EACA+nM,GACAC,GACAnlL,EACA28F,GAGFgC,GACExhH,EACA+nM,GACAE,GACA,CAACzf,GACDhpE,EAEJ,CAOA,MAAM0oF,GAAyBpnF,GAAgBi1E,GAAgB,CAC7Dj8J,MAASgmF,GAAkBslF,IAC3BtgI,KAAQg7C,GAAkBquE,IAC1BgU,QAAWriF,GAAkBquE,MAkC/B,SAAS6X,GAAmB5kM,EAAMoG,GAEhCwnL,GAAqB5tL,EAAMtF,KAAKiZ,MAAc,IAARvN,GAAe,IACvD,CAOA,MAAM8/L,GAAiBxmF,GAAgBi1E,GAAgB,CACrD,YACA,aACA,YACA,cAQIwR,GAAoBzmF,GAAgBi1E,GAAgB,CACxDqN,UAAatjF,IAzrBf,SAAwB1+G,EAAMhB,EAAOo/G,GACnC,MAAuDx/G,EAAU,CAACoB,KAAMA,GAC/BuD,EAAa,CAAA,EAChD+lB,EAAMtqB,EAAMo2I,SACZjzI,EAAOnD,EAAMoD,UACbo0I,EAAgBx3I,EAAMgzI,eACtB+0D,EAAiB,CACrBtoI,KAAQn1C,GAGV,GAAInnB,EAAM,CACR4kM,EAAkB,EAAI5kM,EAAK,GAC3B4kM,EAAkB,EAAI5kM,EAAK,GAC3B,MAAM0Z,EAAS7c,EAAM2nE,YACfuN,EAASl1E,EAAM6nE,YAOrB,GALIqN,GAAUsiE,GAA+B,IAAdtiE,EAAO,IAAYA,EAAO,KAAO/xE,EAAK,KACnE4kM,EAAkB,EAAI7yH,EAAO,GAC7B6yH,EAAkB,EAAIvwD,EAAc,IAAMtiE,EAAO,GAAK/xE,EAAK,KAGzD0Z,IAAWA,EAAO,KAAO1Z,EAAK,GAAK,GAAK0Z,EAAO,KAAO1Z,EAAK,GAAK,GAAI,CACtE,MAA0Bs+L,EAAU,CAChC36L,EAAG+V,EAAO,GACV6kL,OAAQ,SACR36L,EAAG5D,EAAK,GAAK0Z,EAAO,GACpB8kL,OAAQ,UAEZp9L,EAAoB,QAAIk9L,CACzB,CACF,CAEDl9L,EAAiB,KAAIwjM,EAErB,IAAI3gM,EAAQpH,EAAMgoE,gBAAgB,GAC9BR,EAAYrkE,EAIhB,GAHkB,OAAdqkE,IACFA,EAAYu4H,IAEU,GAApBv4H,EAAU52E,OAAa,CAEzBwW,GADoBo5L,GAAah5H,EAElC,CACa,IAAVpgE,IACF7C,EAAkB,MAAI6C,GAGxB,MAAMiF,EAAWrM,EAAMulC,cACN,IAAbl5B,IACF9H,EAAoB,QAAI8H,GAG1B,MAAMqtB,EAAQ15B,EAAM2mE,WAChBjtC,IACFn1B,EAAkB,MAAIm1B,GAGxB,MAAM74B,EAAau+G,EAAYA,EAAYxuH,OAAS,GAAGoQ,KACjDw/G,EAAcilF,GAAoB5kM,EAAWq9G,cAC7CxlH,EAAS6nH,GAAah8G,EAAYi8G,GACxCY,GACExhH,EACA8lM,GACAplF,GACA5nH,EACA0mH,EACAoB,EAEJ,IAsnBE8iF,WAAc5jF,IA3lBhB,SAAyB1+G,EAAMhB,EAAOo/G,GACpC,MAAuDx/G,EAAU,CAACoB,KAAMA,GAClEuD,EAAa,CAAA,EACbmgE,EAAO1kE,EAAM4kE,UACfF,IACFngE,EAAkB,MAAImgE,EAAKiC,YAE7B,MAAMv/D,EAAQpH,EAAMskG,WAChBl9F,GAAmB,IAAVA,IACX7C,EAAkB,MAAI6C,GAExB,MAAMvG,EAAau+G,EAAYA,EAAYxuH,OAAS,GAAGoQ,KACjDw/G,EAAcqlF,GAAqBhlM,EAAWq9G,cAC9CxlH,EAAS6nH,GAAah8G,EAAYi8G,GACxCY,GACExhH,EACAkmM,GACAxlF,GACA5nH,EACA0mH,EACAoB,EAEJ,IAskBE+iF,UAAa7jF,IA9iBf,SAAwB1+G,EAAMhB,EAAOo/G,GACnC,MAAuDx/G,EAAU,CAACoB,KAAMA,GAClEuD,EAAa,CACjBm1B,MAAS15B,EAAM2mE,WACfznE,MAAS06B,OAAO55B,EAAM6L,aAAe,GAEjChL,EAAau+G,EAAYA,EAAYxuH,OAAS,GAAGoQ,KACjDw/G,EAAculF,GAAoBllM,EAAWq9G,cAC7CxlH,EAAS6nH,GAAah8G,EAAYi8G,GACxCY,GACExhH,EACAomM,GACA1lF,GACA5nH,EACA0mH,EACAoB,EAEJ,IA8hBEgjF,UAAa9jF,IApDf,SAAwB1+G,EAAMhB,EAAOo/G,GACnC,MAAuDx/G,EAAU,CAACoB,KAAMA,GAClE0jE,EAAO1kE,EAAM4kE,UACbD,EAAS3kE,EAAM6kE,YACftgE,EAAa,CACjBm1B,MAASgrC,EAAOA,EAAKiC,gBAAa1wE,EAClCyuE,OAAQA,QAAOzuE,EACf8rM,UAAWp9H,QAAS1uE,GAEhB4K,EAAau+G,EAAYA,EAAYxuH,OAAS,GAAGoQ,KACjDw/G,EAAcknF,GAAoB7mM,EAAWq9G,cAC7CxlH,EAAS6nH,GAAah8G,EAAYi8G,GACxCY,GACExhH,EACAkoM,GACAxnF,GACA5nH,EACA0mH,EACAoB,EAEJ,MA6FA,IAAAwnF,GAn8FA,cAAkB/d,GAIhB,WAAA16L,CAAY6K,GACV1F,QAEA0F,EAAUA,GAAoB,GAEzBmmM,KArHPZ,GAAgB,CAAC,IAAK,IAAK,IAAK,GAEhCM,GAAqB,IAAI1qD,GAAK,CAC5B77G,MAAOimK,KAGTC,GAA6B,CAAC,GAAI,GAElCC,GAAqC,SAErCC,GAAqC,SAErCC,GAA2B,CAAC,GAAI,IAEhCC,GACE,+DAEFG,GAAsB,IAAI1pD,GAAK,CAC7B55H,OAAQ+iL,GACRhpD,aAAc,cACdE,aAAc+oD,GACd7oD,aAAc8oD,GACdh0K,YAAa,YACbzf,SAAU,EACVjF,MAAOo5L,GAAaT,IACpB58L,KAAM48L,GACNz1K,IAAK01K,KAGPE,GAAyB,WAEzBz7B,GAAuB,IAAI/sB,GAAO,CAChCh+G,MAAOimK,GACPzgM,MAAO,IAGTkhM,GAA4B,IAAI1oD,GAAO,CACrCh+G,MAAO,CAAC,GAAI,GAAI,GAAI,GACpBx6B,MAAO,IAGTmhM,GAAqB,IAAIlnD,GAAK,CAC5BjmG,KAAM,sBACNwxB,KAAMu7H,GACNt7H,OAAQy7H,GACRh5L,MAAO,KAGTihI,GAAgB,IAAIkQ,GAAM,CACxB7zE,KAAMu7H,GACN19L,MAAO49L,GACP9tJ,KAAMguJ,GACN17H,OAAQ8/F,GACRhoI,OAAQ,IAGV8jK,GAAsB,CAACl4D,KAoErB54I,KAAKotE,eAAiBx+C,GAAc,aAMpC5uB,KAAKw4M,cAAgB7tM,EAAQwmM,aACzBxmM,EAAQwmM,aACRL,GAMJ9wM,KAAKy4M,oBACuBjyM,IAA1BmE,EAAQ+tM,eAA8B/tM,EAAQ+tM,cAKhD14M,KAAK83M,kBACqBtxM,IAAxBmE,EAAQguM,aAA4BhuM,EAAQguM,YAM9C34M,KAAK44M,cAAgB,GAMrB54M,KAAK64M,qBACwBryM,IAA3BmE,EAAQmuM,gBAA+BnuM,EAAQmuM,eAKjD94M,KAAKu8B,kBACqB/1B,IAAxBmE,EAAQ0xB,YAA4B1xB,EAAQ0xB,YAAc,YAK5Dr8B,KAAK2zM,iBAAmBhpM,EAAQouM,gBAC5BpuM,EAAQouM,gBACR/H,GAEJhxM,KAAKk4G,oBAAsB,CAAC,uCAC7B,CAQD,qBAAA8gG,CAAsBznM,EAAMo+G,GAE1B,MASMxsD,EAAWuuD,GAAgB,GATfT,GAAgBi1E,GAAgB,CAChD2J,SAAYpgF,GAAkBzvH,KAAKg5M,sBAAuBh5M,MAC1Di5M,OAAUxpF,GAAkBzvH,KAAKg5M,sBAAuBh5M,MACxDgwM,UAAapgF,GAAgB5vH,KAAKk5M,eAAgBl5M,MAClD8oJ,MAAS9oJ,KAAKm5M,iBAAiBjyM,KAAKlH,MACpC2tM,SAAY3tM,KAAKo5M,oBAAoBlyM,KAAKlH,QAIIuR,EAAMo+G,EAAa3vH,MACnE,GAAImjE,EACF,OAAOA,CAGV,CAQD,cAAA+1I,CAAe3nM,EAAMo+G,GACnB,MAAM/qH,EAAS8sH,GACb,CAAC98G,SAAY,MACbu4L,GACA57L,EACAo+G,EACA3vH,MAEF,IAAK4E,EACH,OAEF,MAAM+6C,EAAU,IAAIvrC,GACd5G,EAAK+D,EAAKgqL,aAAa,MAClB,OAAP/tL,GACFmyC,EAAQlqC,MAAMjI,GAEhB,MAAM7C,EACJglH,EAAY,GAGR/6G,EAAWhQ,EAAiB,SAOlC,GANIgQ,GACF+hL,GAA6B/hL,GAAU,EAAOjK,GAEhDg1C,EAAQ9qC,YAAYD,UACbhQ,EAAiB,SAEpB5E,KAAKy4M,eAAgB,CACvB,MAEMv9G,EA0fZ,SACE3qF,EACA29L,EACAiD,EACAC,EACA0H,GAEA,OAAA,SAMYn5J,EAAShjC,GACjB,IAAI08L,EAAWP,EACXpjM,EAAO,GACP4jM,EAAsB,GAC1B,GAAID,EAAU,CACZ,MAAMzkM,EAAW+qC,EAAQzqC,cACzB,GAAIN,EACF,GAAIA,aAAoBumE,GACtBm+H,EAAsB1kM,EACnBgjF,8BACAngD,QAAO,SAAU7iC,GAChB,MAAM7U,EAAO6U,EAAS8Z,UACtB,MAAgB,UAAT3uB,GAA6B,eAATA,CAC3C,IACYs5M,EAAWC,EAAoBn4M,OAAS,MACnC,CACL,MAAMpB,EAAO6U,EAAS8Z,UACtB2qL,EAAoB,UAATt5M,GAA6B,eAATA,CAChC,CAEJ,CAEGs5M,IACF3jM,EAA8BiqC,EAAQv2C,IAAI,QAC1CiwM,EAAWA,KAAc3jM,EAErB2jM,GAAY,UAAUhrM,KAAKqH,KACxBm7L,KACHA,GAAW9gM,SAASC,cAAc,aAEpC6gM,GAAS3sJ,UAAYxuC,EACrBA,EAAOm7L,GAASxsM,QAIpB,IAAIk1M,EAAepI,EAMnB,GALI5gM,EACFgpM,EAAehpM,EACN29L,IACTqL,EAAetI,GAAU/C,EAAUiD,EAAcC,IAE/CiI,EAAU,CACZ,MAAMG,EAxGd,SAAiCC,EAAY/jM,GAC3C,MAAMgkM,EAAa,CAAC,EAAG,GAEvB,IAAI3iI,EAAY,QAChB,MAAMrF,EAAa+nI,EAAWj+K,WAC9B,GAAIk2C,EAAY,CACd,MAAMqG,EAAYrG,EAAW/9D,UAC7B,GAAIokE,GAAiC,GAApBA,EAAU52E,OAAa,CACtC,MAAMm3E,EAAa5G,EAAW6G,gBACxBnrD,EAASskD,EAAWwG,YAG1BwhI,EAAW,GAAKphI,EAAW,IAAMP,EAAU,GAAK3qD,EAAO,IACvDssL,EAAW,GAAKphI,EAAW,IAAMP,EAAU,GAAK,EAAI3qD,EAAO,IAC3D2pD,EAAY,MACb,CACF,CACD,IAAIlF,EAAY4nI,EAAWpkI,UACvBxD,GAGFA,EAAYA,EAAU98D,QACtB88D,EAAUy5E,QAAQz5E,EAAUsH,WAAay3H,GAAmBz3H,WAC5DtH,EAAU6xE,SAAS7xE,EAAUgjC,YAAc+7F,GAAmB/7F,YAC9DhjC,EAAU0yE,QAAQ1yE,EAAUsD,WAAay7H,GAAmBz7H,WAC5DtD,EAAU8yE,UAAU9yE,EAAUuD,aAAeu7H,KAE7C9+H,EAAY++H,GAAmB77L,QAEjC88D,EAAUw3E,QAAQ3zI,GAClBm8D,EAAU25E,WAAWkuD,EAAW,IAChC7nI,EAAU45E,WAAWiuD,EAAW,IAChC7nI,EAAU+5E,aAAa70E,GAEvB,MAAMyiI,EAAY,IAAI1wD,GAAM,CAC1Bh2I,MAAO4+D,EACP9uB,KAAMivB,IAER,OAAO2nI,CACT,CAiE0BG,CAAwBJ,EAAa,GAAI7jM,GAC3D,GAAI4jM,EAAoBn4M,OAAS,EAAG,CAIlCq4M,EAAU3kM,YAAY,IAAIsmE,GAAmBm+H,IAQ7C,MAAO,CAACE,EAPU,IAAI1wD,GAAM,CAC1Bl0I,SAAU2kM,EAAa,GAAGrkM,cAC1BpC,MAAO,KACPmiE,KAAMskI,EAAa,GAAGpkI,UACtBD,OAAQqkI,EAAa,GAAGnkI,YACxBxyB,KAAM,QAEsBm0C,OAAOwiH,EAAaz1M,MAAM,GACzD,CACD,OAAO01M,CACR,CACD,OAAOD,CAET,CACJ,CArkB4BK,CAFRh1M,EAAc,MACXA,EAAiB,SAIhC5E,KAAKw4M,cACLx4M,KAAK44M,cACL54M,KAAK64M,iBAEPl5J,EAAQvqC,SAAS8lF,EAClB,CAOD,cANOt2F,EAAc,MAIrB+6C,EAAQx2C,cAAcvE,GAAQ,GAEvB+6C,CACR,CAOD,gBAAAw5J,CAAiB5nM,EAAMo+G,GACrB,MAAMniH,EAAK+D,EAAKgqL,aAAa,MAC7B,GAAW,OAAP/tL,EAAa,CACf,MAAM+C,EAAQm9L,GAAU3pM,KAAK/D,KAAMuR,EAAMo+G,GACzC,GAAIp/G,EAAO,CACT,IAAIspM,EACAtI,EAAUhgM,EAAKggM,QAInB,GAHKA,GAAsB,eAAXA,IACdA,EAAUjiM,OAAOgmH,SAAStlD,MAExBuhI,EAAS,CAEXsI,EADY,IAAI9pI,IAAI,IAAMviE,EAAI+jM,GACfvhI,IACzB,MACU6pI,EAAW,IAAMrsM,EAEnBxN,KAAK44M,cAAciB,GAAYtpM,CAChC,CACF,CACF,CAOD,mBAAA6oM,CAAoB7nM,EAAMo+G,GACxB,MAAMniH,EAAK+D,EAAKgqL,aAAa,MAC7B,GAAW,OAAP/tL,EACF,OAEF,MAAMogM,EAAgBC,GAAkB9pM,KAAK/D,KAAMuR,EAAMo+G,GACzD,IAAKi+E,EACH,OAEF,IAAIiM,EACAtI,EAAUhgM,EAAKggM,QAInB,GAHKA,GAAsB,eAAXA,IACdA,EAAUjiM,OAAOgmH,SAAStlD,MAExBuhI,EAAS,CAEXsI,EADY,IAAI9pI,IAAI,IAAMviE,EAAI+jM,GACfvhI,IACrB,MACM6pI,EAAW,IAAMrsM,EAEnBxN,KAAK44M,cAAciB,GAAYjM,CAChC,CAOD,mBAAAnU,CAAoBloL,EAAM5G,GACxB,IAAKu7L,GAAexgM,SAAS6L,EAAKk9G,cAChC,OAAO,KAET,MAAM9uE,EAAU3/C,KAAKk5M,eAAe3nM,EAAM,CACxCvR,KAAKo2L,eAAe7kL,EAAM5G,KAE5B,OAAIg1C,GAGG,IACR,CAQD,oBAAAg6I,CAAqBpoL,EAAM5G,GACzB,IAAKu7L,GAAexgM,SAAS6L,EAAKk9G,cAChC,MAAO,GAET,IAAItrD,EACJ,MAAM4sD,EAAYx+G,EAAKw+G,UACvB,GAAiB,YAAbA,GAAwC,UAAbA,EAI7B,OAHA5sD,EAAWnjE,KAAKg5M,sBAAsBznM,EAAM,CAC1CvR,KAAKo2L,eAAe7kL,EAAM5G,KAExBw4D,GAGG,GAET,GAAiB,aAAb4sD,EAA0B,CAC5B,MAAMpwE,EAAU3/C,KAAKk5M,eAAe3nM,EAAM,CACxCvR,KAAKo2L,eAAe7kL,EAAM5G,KAE5B,OAAIg1C,EACK,CAACA,GAEH,EACR,CACD,GAAiB,OAAbowE,EAAoB,CACtB5sD,EAAW,GACX,IAAK,IAAIxhE,EAAI4P,EAAKmsG,kBAAmB/7G,EAAGA,EAAIA,EAAE4vH,mBAAoB,CAChE,MAAMuoF,EAAK95M,KAAK25L,qBAAqBh4L,EAAGgJ,GACpCmvM,GACF53M,EAAOihE,EAAU22I,EAEpB,CACD,OAAO32I,CACR,CACD,MAAO,EACR,CASD,QAAA42I,CAAS7vM,GACP,GAAKA,EAAL,CAGA,GAAsB,iBAAXA,EAAqB,CAC9B,MAAM0hD,EAAM1gB,GAAMhhC,GAClB,OAAOlK,KAAKg6M,qBAAqBpuJ,EAClC,CACD,OAAI0jE,GAAWplH,GACNlK,KAAKg6M,qBAA8C,GAErDh6M,KAAKi6M,iBAAyC,EARpD,CASF,CAMD,oBAAAD,CAAqBpuJ,GACnB,IAAK,IAAIjqD,EAAyBiqD,EAAc,WAAGjqD,EAAGA,EAAIA,EAAE0tH,YAC1D,GAAI1tH,EAAEqtH,UAAYC,KAAK2qE,aAAc,CACnC,MAAMlkL,EAAO1V,KAAKi6M,iBAAgB,GAClC,GAAIvkM,EACF,OAAOA,CAEV,CAGJ,CAMD,gBAAAukM,CAAiB1oM,GACf,IAAK,IAAI5P,EAAI4P,EAAKmsG,kBAAmB/7G,EAAGA,EAAIA,EAAE4vH,mBAC5C,GAAI20E,GAAexgM,SAAS/D,EAAE8sH,eAAgC,QAAf9sH,EAAEouH,UAC/C,OAAOsuE,GAAW18L,GAGtB,IAAK,IAAIA,EAAI4P,EAAKmsG,kBAAmB/7G,EAAGA,EAAIA,EAAE4vH,mBAAoB,CAChE,MAAMxB,EAAYpuH,EAAEouH,UACpB,GACEm2E,GAAexgM,SAAS/D,EAAE8sH,gBACZ,YAAbsB,GACc,UAAbA,GACa,aAAbA,GACa,OAAbA,GACF,CACA,MAAMr6G,EAAO1V,KAAKi6M,iBAAiBt4M,GACnC,GAAI+T,EACF,OAAOA,CAEV,CACF,CAEF,CASD,gBAAAwkM,CAAiBhwM,GACf,MAAMiwM,EAAe,GACrB,GAAsB,iBAAXjwM,EAAqB,CAC9B,MAAM0hD,EAAM1gB,GAAMhhC,GAClBhI,EAAOi4M,EAAcn6M,KAAKo6M,6BAA6BxuJ,GAC7D,MAAe0jE,GAAWplH,GACpBhI,EACEi4M,EACAn6M,KAAKo6M,6BAA4B,IAGnCl4M,EACEi4M,EACAn6M,KAAKq6M,yBAAwB,IAGjC,OAAOF,CACR,CAMD,4BAAAC,CAA6BxuJ,GAC3B,MAAMuuJ,EAAe,GACrB,IAAK,IAAIx4M,EAAyBiqD,EAAc,WAAGjqD,EAAGA,EAAIA,EAAE0tH,YACtD1tH,EAAEqtH,UAAYC,KAAK2qE,cACrB13L,EACEi4M,EACAn6M,KAAKq6M,yBAAwB,IAInC,OAAOF,CACR,CAMD,wBAAAE,CAAyB9oM,GACvB,MAAM4oM,EAAe,GACrB,IAAK,IAAIx4M,EAAI4P,EAAKmsG,kBAAmB/7G,EAAGA,EAAIA,EAAE4vH,mBAC5C,GACE20E,GAAexgM,SAAS/D,EAAE8sH,eACX,eAAf9sH,EAAEouH,UACF,CACA,MAAMpnH,EAAM+oH,GAAgB,CAAA,EAAI+8E,GAAsB9sM,EAAG,IACzDw4M,EAAax0M,KAAKgD,EACnB,CAEH,IAAK,IAAIhH,EAAI4P,EAAKmsG,kBAAmB/7G,EAAGA,EAAIA,EAAE4vH,mBAAoB,CAChE,MAAMxB,EAAYpuH,EAAEouH,WAElBm2E,GAAexgM,SAAS/D,EAAE8sH,eACZ,YAAbsB,GAAwC,UAAbA,GAAsC,OAAbA,GAErD7tH,EAAOi4M,EAAcn6M,KAAKq6M,yBAAyB14M,GAEtD,CACD,OAAOw4M,CACR,CASD,UAAAG,CAAWpwM,GACT,MAAMqwM,EAAU,GAChB,GAAsB,iBAAXrwM,EAAqB,CAC9B,MAAM0hD,EAAM1gB,GAAMhhC,GAClBhI,EAAOq4M,EAASv6M,KAAKw6M,uBAAuB5uJ,GAClD,MAAe0jE,GAAWplH,GACpBhI,EACEq4M,EACAv6M,KAAKw6M,uBAAsB,IAG7Bt4M,EAAOq4M,EAASv6M,KAAKy6M,mBAA2C,IAElE,OAAOF,CACR,CAMD,sBAAAC,CAAuB5uJ,GACrB,MAAM2uJ,EAAU,GAChB,IAAK,IAAI54M,EAAyBiqD,EAAc,WAAGjqD,EAAGA,EAAIA,EAAE0tH,YACtD1tH,EAAEqtH,UAAYC,KAAK2qE,cACrB13L,EAAOq4M,EAASv6M,KAAKy6M,mBAA2C,IAGpE,OAAOF,CACR,CAOD,kBAAAE,CAAmBlpM,GACjB,MAAMgpM,EAAU,GAChB,IAAK,IAAI54M,EAAI4P,EAAKmsG,kBAAmB/7G,EAAGA,EAAIA,EAAE4vH,mBAC5C,GAAI20E,GAAexgM,SAAS/D,EAAE8sH,eAAgC,UAAf9sH,EAAEouH,UAAuB,CACtE,MAAMpnH,EAAM+oH,GAAgB,CAAA,EAAI09E,GAAgBztM,EAAG,IACnD44M,EAAQ50M,KAAKgD,EACd,CAEH,IAAK,IAAIhH,EAAI4P,EAAKmsG,kBAAmB/7G,EAAGA,EAAIA,EAAE4vH,mBAAoB,CAChE,MAAMxB,EAAYpuH,EAAEouH,WAElBm2E,GAAexgM,SAAS/D,EAAE8sH,eACZ,YAAbsB,GAAwC,UAAbA,GAAsC,OAAbA,GAErD7tH,EAAOq4M,EAASv6M,KAAKy6M,mBAAmB94M,GAE3C,CACD,OAAO44M,CACR,CAoBD,UAAAG,CAAWxwM,GACT,MAAMywM,EAAU,GAChB,GAAsB,iBAAXzwM,EAAqB,CAC9B,MAAM0hD,EAAM1gB,GAAMhhC,GAClBhI,EAAOy4M,EAAS36M,KAAK46M,uBAAuBhvJ,GAClD,MAAe0jE,GAAWplH,GACpBhI,EACEy4M,EACA36M,KAAK46M,uBAAsB,IAG7B14M,EAAOy4M,EAAS36M,KAAK66M,mBAA2C,IAElE,OAAOF,CACR,CAMD,sBAAAC,CAAuBhvJ,GACrB,MAAM+uJ,EAAU,GAChB,IAAK,IAAIh5M,EAAyBiqD,EAAc,WAAGjqD,EAAGA,EAAIA,EAAE0tH,YACtD1tH,EAAEqtH,WAAaC,KAAK2qE,cACtB13L,EAAOy4M,EAAS36M,KAAK66M,mBAA2C,IAGpE,OAAOF,CACR,CAOD,kBAAAE,CAAmBtpM,GACjB,MAAMopM,EAAU,GAChB,IAAK,IAAIh5M,EAAI4P,EAAKmsG,kBAAmB/7G,EAAGA,EAAIA,EAAE4vH,mBAC5C,GAAI20E,GAAexgM,SAAS/D,EAAE8sH,eAAiC,WAAhB9sH,EAAEouH,UAAwB,CACvE,MAAMpnH,EAAM+oH,GAAgB,CAAA,EAAIk9E,GAAgBjtM,EAAG,IACnDg5M,EAAQh1M,KAAKgD,EACd,CAEH,IAAK,IAAIhH,EAAI4P,EAAKmsG,kBAAmB/7G,EAAGA,EAAIA,EAAE4vH,mBAAoB,CAChE,MAAMxB,EAAYpuH,EAAEouH,WAElBm2E,GAAexgM,SAAS/D,EAAE8sH,eACX,aAAdsB,GACe,WAAdA,GACc,cAAdA,GACc,QAAdA,GAEF7tH,EAAOy4M,EAAS36M,KAAK66M,mBAAmBl5M,GAE3C,CACD,OAAOg5M,CACR,CAWD,iBAAAxgB,CAAkBh3H,EAAUx4D,GAC1BA,EAAU3K,KAAKq2L,aAAa1rL,GAC5B,MAAMmwM,EAAMtsF,GAAgB03E,GAAe,GAAI,OACzC6U,EAAW,gCACjBD,EAAIzV,eAAe0V,EAAU,WAAY/N,GAAkB,IAC3D8N,EAAIzV,eAAe0V,EAAU,YAAaxsF,IAC1CusF,EAAIzV,eACF92E,GACA,qBAl4BJ,uFAs4BE,MAAuDp+G,EAAU,CAC7DoB,KAAMupM,GAGJhmM,EAAa,CAAA,EACfquD,EAAShiE,OAAS,EACpB2T,EAAqB,SAAIquD,EACG,GAAnBA,EAAShiE,SAClB2T,EAAsB,UAAIquD,EAAS,IAErC,MAAM4tD,EAAc4+E,GAAamL,EAAIrsF,cAC/BxlH,EAAS6nH,GAAah8G,EAAYi8G,GAUxC,OATAY,GACExhH,EACAy/L,GACA/+E,GACA5nH,EACA,CAAC0B,GACDomH,EACA/wH,MAEK86M,CACR;;ACr/BSE,KAAG,SAAUrhM,EAAQoB,EAAQkgM,EAAMC,EAAMC,GACnD,IAAIjkM,EAAGiJ,EACHi7L,EAAiB,EAATD,EAAcD,EAAO,EAC7BG,GAAQ,GAAKD,GAAQ,EACrBE,EAAQD,GAAQ,EAChBE,GAAS,EACT35M,EAAIq5M,EAAQE,EAAS,EAAK,EAC1BlkM,EAAIgkM,GAAQ,EAAI,EAChBlxK,EAAIpwB,EAAOoB,EAASnZ,GAOxB,IALAA,GAAKqV,EAELC,EAAI6yB,GAAM,IAAOwxK,GAAU,EAC3BxxK,KAAQwxK,EACRA,GAASH,EACFG,EAAQ,EAAGrkM,EAAS,IAAJA,EAAWyC,EAAOoB,EAASnZ,GAAIA,GAAKqV,EAAGskM,GAAS,GAKvE,IAHAp7L,EAAIjJ,GAAM,IAAOqkM,GAAU,EAC3BrkM,KAAQqkM,EACRA,GAASL,EACFK,EAAQ,EAAGp7L,EAAS,IAAJA,EAAWxG,EAAOoB,EAASnZ,GAAIA,GAAKqV,EAAGskM,GAAS,GAEvE,GAAU,IAANrkM,EACFA,EAAI,EAAIokM,MACH,IAAIpkM,IAAMmkM,EACf,OAAOl7L,EAAIkO,IAAsB5T,KAAdsvB,GAAK,EAAI,GAE5B5pB,GAAQlU,KAAKC,IAAI,EAAGgvM,GACpBhkM,GAAQokM,CACT,CACD,OAAQvxK,GAAK,EAAI,GAAK5pB,EAAIlU,KAAKC,IAAI,EAAGgL,EAAIgkM,EAC5C,EAEAF,MAAgB,SAAUrhM,EAAQtV,EAAO0W,EAAQkgM,EAAMC,EAAMC,GAC3D,IAAIjkM,EAAGiJ,EAAGnJ,EACNokM,EAAiB,EAATD,EAAcD,EAAO,EAC7BG,GAAQ,GAAKD,GAAQ,EACrBE,EAAQD,GAAQ,EAChBG,EAAe,KAATN,EAAcjvM,KAAKC,IAAI,GAAI,IAAMD,KAAKC,IAAI,GAAI,IAAM,EAC1DtK,EAAIq5M,EAAO,EAAKE,EAAS,EACzBlkM,EAAIgkM,EAAO,GAAK,EAChBlxK,EAAI1lC,EAAQ,GAAgB,IAAVA,GAAe,EAAIA,EAAQ,EAAK,EAAI,EAmC1D,IAjCAA,EAAQ4H,KAAKmP,IAAI/W,GAEbmqB,MAAMnqB,IAAUA,IAAUoW,KAC5B0F,EAAIqO,MAAMnqB,GAAS,EAAI,EACvB6S,EAAImkM,IAEJnkM,EAAIjL,KAAKuT,MAAMvT,KAAKsW,IAAIle,GAAS4H,KAAK0jG,KAClCtrG,GAAS2S,EAAI/K,KAAKC,IAAI,GAAIgL,IAAM,IAClCA,IACAF,GAAK,IAGL3S,GADE6S,EAAIokM,GAAS,EACNE,EAAKxkM,EAELwkM,EAAKvvM,KAAKC,IAAI,EAAG,EAAIovM,IAEpBtkM,GAAK,IACfE,IACAF,GAAK,GAGHE,EAAIokM,GAASD,GACfl7L,EAAI,EACJjJ,EAAImkM,GACKnkM,EAAIokM,GAAS,GACtBn7L,GAAM9b,EAAQ2S,EAAK,GAAK/K,KAAKC,IAAI,EAAGgvM,GACpChkM,GAAQokM,IAERn7L,EAAI9b,EAAQ4H,KAAKC,IAAI,EAAGovM,EAAQ,GAAKrvM,KAAKC,IAAI,EAAGgvM,GACjDhkM,EAAI,IAIDgkM,GAAQ,EAAGvhM,EAAOoB,EAASnZ,GAAS,IAAJue,EAAUve,GAAKqV,EAAGkJ,GAAK,IAAK+6L,GAAQ,GAI3E,IAFAhkM,EAAKA,GAAKgkM,EAAQ/6L,EAClBi7L,GAAQF,EACDE,EAAO,EAAGzhM,EAAOoB,EAASnZ,GAAS,IAAJsV,EAAUtV,GAAKqV,EAAGC,GAAK,IAAKkkM,GAAQ,GAE1EzhM,EAAOoB,EAASnZ,EAAIqV,IAAU,IAAJ8yB,CAC5B,GClFA0xK,GAAiBC,GAEbV,GAAUW,GAEd,SAASD,GAAIp/E,GACTt8H,KAAKs8H,IAAMs/E,YAAYC,QAAUD,YAAYC,OAAOv/E,GAAOA,EAAM,IAAI9pH,WAAW8pH,GAAO,GACvFt8H,KAAKkoD,IAAM,EACXloD,KAAKD,KAAO,EACZC,KAAKmB,OAASnB,KAAKs8H,IAAIn7H,MAC3B,CAEAu6M,GAAII,OAAU,EACdJ,GAAIK,QAAU,EACdL,GAAIM,MAAU,EACdN,GAAIO,QAAU,EAEd,IAAIC,GAAgB,WAChBC,GAAiB,EAAID,GAKrBE,GAAyC,oBAAhB/8B,YAA8B,KAAO,IAAIA,YAAY,QAwYlF,SAASg9B,GAAcZ,GACnB,OAAOA,EAAI17M,OAAS27M,GAAIM,MACpBP,EAAIa,aAAeb,EAAIvzJ,IAAMuzJ,EAAIvzJ,IAAM,CAC/C,CAEA,SAASq0J,GAAMt7M,EAAKC,EAAMs7M,GACtB,OAAIA,EACc,WAAPt7M,GAAsBD,IAAQ,GAGlB,YAAdC,IAAS,IAAqBD,IAAQ,EACnD,CAiDA,SAASw7M,GAAuBC,EAAUz0M,EAAKwzM,GAC3C,IAAIkB,EACA10M,GAAO,MAAS,EAChBA,GAAO,QAAW,EAClBA,GAAO,UAAY,EAAIgE,KAAKuT,MAAMvT,KAAKsW,IAAIta,IAAmB,EAAXgE,KAAK0jG,MAG5D8rG,EAAImB,QAAQD,GACZ,IAAK,IAAI/6M,EAAI65M,EAAIvzJ,IAAM,EAAGtmD,GAAK86M,EAAU96M,IAAK65M,EAAIn/E,IAAI16H,EAAI+6M,GAAYlB,EAAIn/E,IAAI16H,EAClF,CAEA,SAASi7M,GAAkBp7M,EAAKg6M,GAAS,IAAK,IAAI75M,EAAI,EAAGA,EAAIH,EAAIN,OAAQS,IAAK65M,EAAIqB,YAAYr7M,EAAIG,GAAQ,CAC1G,SAASm7M,GAAmBt7M,EAAKg6M,GAAQ,IAAK,IAAI75M,EAAI,EAAGA,EAAIH,EAAIN,OAAQS,IAAK65M,EAAIuB,aAAav7M,EAAIG,GAAO,CAC1G,SAASq7M,GAAiBx7M,EAAKg6M,GAAU,IAAK,IAAI75M,EAAI,EAAGA,EAAIH,EAAIN,OAAQS,IAAK65M,EAAIyB,WAAWz7M,EAAIG,GAAS,CAC1G,SAASu7M,GAAkB17M,EAAKg6M,GAAS,IAAK,IAAI75M,EAAI,EAAGA,EAAIH,EAAIN,OAAQS,IAAK65M,EAAI2B,YAAY37M,EAAIG,GAAQ,CAC1G,SAASy7M,GAAmB57M,EAAKg6M,GAAQ,IAAK,IAAI75M,EAAI,EAAGA,EAAIH,EAAIN,OAAQS,IAAK65M,EAAI6B,aAAa77M,EAAIG,GAAO,CAC1G,SAAS27M,GAAmB97M,EAAKg6M,GAAQ,IAAK,IAAI75M,EAAI,EAAGA,EAAIH,EAAIN,OAAQS,IAAK65M,EAAI+B,aAAa/7M,EAAIG,GAAO,CAC1G,SAAS67M,GAAoBh8M,EAAKg6M,GAAO,IAAK,IAAI75M,EAAI,EAAGA,EAAIH,EAAIN,OAAQS,IAAK65M,EAAIiC,cAAcj8M,EAAIG,GAAM,CAC1G,SAAS+7M,GAAmBl8M,EAAKg6M,GAAQ,IAAK,IAAI75M,EAAI,EAAGA,EAAIH,EAAIN,OAAQS,IAAK65M,EAAImC,aAAan8M,EAAIG,GAAO,CAC1G,SAASi8M,GAAoBp8M,EAAKg6M,GAAO,IAAK,IAAI75M,EAAI,EAAGA,EAAIH,EAAIN,OAAQS,IAAK65M,EAAIqC,cAAcr8M,EAAIG,GAAM,CAI1G,SAASm8M,GAAWzhF,EAAKp0E,GACrB,OAASo0E,EAAIp0E,GACRo0E,EAAIp0E,EAAM,IAAM,EAChBo0E,EAAIp0E,EAAM,IAAM,IACD,SAAfo0E,EAAIp0E,EAAM,EACnB,CAEA,SAAS81J,GAAW1hF,EAAKzgH,EAAKqsC,GAC1Bo0E,EAAIp0E,GAAOrsC,EACXygH,EAAIp0E,EAAM,GAAMrsC,IAAQ,EACxBygH,EAAIp0E,EAAM,GAAMrsC,IAAQ,GACxBygH,EAAIp0E,EAAM,GAAMrsC,IAAQ,EAC5B,CAEA,SAASoiM,GAAU3hF,EAAKp0E,GACpB,OAASo0E,EAAIp0E,GACRo0E,EAAIp0E,EAAM,IAAM,EAChBo0E,EAAIp0E,EAAM,IAAM,KAChBo0E,EAAIp0E,EAAM,IAAM,GACzB,CA5eAwzJ,GAAI73M,UAAY,CAEZq6M,QAAS,WACLl+M,KAAKs8H,IAAM,IACd,EAID6hF,WAAY,SAASC,EAAW3tK,EAAQzuC,GAGpC,IAFAA,EAAMA,GAAOhC,KAAKmB,OAEXnB,KAAKkoD,IAAMlmD,GAAK,CACnB,IAAI6Z,EAAM7b,KAAKs8M,aACX+B,EAAMxiM,GAAO,EACb6gM,EAAW18M,KAAKkoD,IAEpBloD,KAAKD,KAAa,EAAN8b,EACZuiM,EAAUC,EAAK5tK,EAAQzwC,MAEnBA,KAAKkoD,MAAQw0J,GAAU18M,KAAKs+M,KAAKziM,EACxC,CACD,OAAO40B,CACV,EAED8tK,YAAa,SAASH,EAAW3tK,GAC7B,OAAOzwC,KAAKm+M,WAAWC,EAAW3tK,EAAQzwC,KAAKs8M,aAAet8M,KAAKkoD,IACtE,EAEDs2J,YAAa,WACT,IAAI3iM,EAAMkiM,GAAW/9M,KAAKs8H,IAAKt8H,KAAKkoD,KAEpC,OADAloD,KAAKkoD,KAAO,EACLrsC,CACV,EAED4iM,aAAc,WACV,IAAI5iM,EAAMoiM,GAAUj+M,KAAKs8H,IAAKt8H,KAAKkoD,KAEnC,OADAloD,KAAKkoD,KAAO,EACLrsC,CACV,EAID6iM,YAAa,WACT,IAAI7iM,EAAMkiM,GAAW/9M,KAAKs8H,IAAKt8H,KAAKkoD,KAAO61J,GAAW/9M,KAAKs8H,IAAKt8H,KAAKkoD,IAAM,GAAKg0J,GAEhF,OADAl8M,KAAKkoD,KAAO,EACLrsC,CACV,EAED8iM,aAAc,WACV,IAAI9iM,EAAMkiM,GAAW/9M,KAAKs8H,IAAKt8H,KAAKkoD,KAAO+1J,GAAUj+M,KAAKs8H,IAAKt8H,KAAKkoD,IAAM,GAAKg0J,GAE/E,OADAl8M,KAAKkoD,KAAO,EACLrsC,CACV,EAED+iM,UAAW,WACP,IAAI/iM,EAAMm/L,GAAQ6D,KAAK7+M,KAAKs8H,IAAKt8H,KAAKkoD,KAAK,EAAM,GAAI,GAErD,OADAloD,KAAKkoD,KAAO,EACLrsC,CACV,EAEDijM,WAAY,WACR,IAAIjjM,EAAMm/L,GAAQ6D,KAAK7+M,KAAKs8H,IAAKt8H,KAAKkoD,KAAK,EAAM,GAAI,GAErD,OADAloD,KAAKkoD,KAAO,EACLrsC,CACV,EAEDygM,WAAY,SAASE,GACjB,IACI3gM,EAAKva,EADLg7H,EAAMt8H,KAAKs8H,IAG+B,OAAzBzgH,EAAY,KAAjCva,EAAIg7H,EAAIt8H,KAAKkoD,QAAqC5mD,EAAI,IAAaua,GAC9CA,IAAY,KAAjCva,EAAIg7H,EAAIt8H,KAAKkoD,UAA6B,EAAQ5mD,EAAI,IAAaua,GAC9CA,IAAY,KAAjCva,EAAIg7H,EAAIt8H,KAAKkoD,UAA6B,GAAQ5mD,EAAI,IAAaua,GAC9CA,IAAY,KAAjCva,EAAIg7H,EAAIt8H,KAAKkoD,UAA6B,GAAQ5mD,EAAI,IAAaua,EA+S3E,SAA6BmD,EAAG+qB,EAAGqsD,GAC/B,IACI71D,EAAGj/B,EADHg7H,EAAMlmC,EAAEkmC,IAG6B,GAAzCh7H,EAAIg7H,EAAIlmC,EAAEluC,OAAQ3nB,GAAU,IAAJj/B,IAAa,EAAQA,EAAI,IAAM,OAAOi7M,GAAMv9L,EAAGuhB,EAAGwJ,GACjC,GAAzCzoC,EAAIg7H,EAAIlmC,EAAEluC,OAAQ3nB,IAAU,IAAJj/B,IAAa,EAAQA,EAAI,IAAM,OAAOi7M,GAAMv9L,EAAGuhB,EAAGwJ,GACjC,GAAzCzoC,EAAIg7H,EAAIlmC,EAAEluC,OAAQ3nB,IAAU,IAAJj/B,IAAa,GAAQA,EAAI,IAAM,OAAOi7M,GAAMv9L,EAAGuhB,EAAGwJ,GACjC,GAAzCzoC,EAAIg7H,EAAIlmC,EAAEluC,OAAQ3nB,IAAU,IAAJj/B,IAAa,GAAQA,EAAI,IAAM,OAAOi7M,GAAMv9L,EAAGuhB,EAAGwJ,GACjC,GAAzCzoC,EAAIg7H,EAAIlmC,EAAEluC,OAAQ3nB,IAAU,IAAJj/B,IAAa,GAAQA,EAAI,IAAM,OAAOi7M,GAAMv9L,EAAGuhB,EAAGwJ,GACjC,GAAzCzoC,EAAIg7H,EAAIlmC,EAAEluC,OAAQ3nB,IAAU,EAAJj/B,IAAa,GAAQA,EAAI,IAAM,OAAOi7M,GAAMv9L,EAAGuhB,EAAGwJ,GAE1E,MAAM,IAAIvhC,MAAM,yCACpB,CAxTeu2M,CAFcljM,IAAY,IAAjCva,EAAIg7H,EAAIt8H,KAAKkoD,QAA6B,GAEVs0J,EAAUx8M,QAC7C,EAEDg/M,aAAc,WACV,OAAOh/M,KAAKs8M,YAAW,EAC1B,EAED2C,YAAa,WACT,IAAI35E,EAAMtlI,KAAKs8M,aACf,OAAOh3E,EAAM,GAAM,GAAKA,EAAM,IAAM,EAAIA,EAAM,CACjD,EAEDu4D,YAAa,WACT,OAAOnmJ,QAAQ13C,KAAKs8M,aACvB,EAEDje,WAAY,WACR,IAAIr8L,EAAMhC,KAAKs8M,aAAet8M,KAAKkoD,IAC/BA,EAAMloD,KAAKkoD,IAGf,OAFAloD,KAAKkoD,IAAMlmD,EAEPA,EAAMkmD,GApGY,IAoGsBk0J,GA+cpD,SAA6B9/E,EAAKp0E,EAAKlmD,GACnC,OAAOo6M,GAAgBptM,OAAOstH,EAAI4iF,SAASh3J,EAAKlmD,GACpD,CA/cmBm9M,CAAoBn/M,KAAKs8H,IAAKp0E,EAAKlmD,GA2YtD,SAAkBs6H,EAAKp0E,EAAKlmD,GACxB,IAAIo9M,EAAM,GACNx9M,EAAIsmD,EAER,KAAOtmD,EAAII,GAAK,CACZ,IASIqU,EAAIM,EAAI0oM,EATRC,EAAKhjF,EAAI16H,GACToV,EAAI,KACJuoM,EACAD,EAAK,IAAO,EACZA,EAAK,IAAO,EACZA,EAAK,IAAO,EAAI,EAEpB,GAAI19M,EAAI29M,EAAmBv9M,EAAK,MAIP,IAArBu9M,EACID,EAAK,MACLtoM,EAAIsoM,GAEoB,IAArBC,EAEa,MAAV,KADVlpM,EAAKimH,EAAI16H,EAAI,OAEToV,GAAU,GAALsoM,IAAc,EAAY,GAALjpM,IACjB,MACLW,EAAI,MAGgB,IAArBuoM,GACPlpM,EAAKimH,EAAI16H,EAAI,GACb+U,EAAK2lH,EAAI16H,EAAI,GACO,MAAV,IAALyU,IAAuC,MAAV,IAALM,MACzBK,GAAU,GAALsoM,IAAa,IAAY,GAALjpM,IAAc,EAAY,GAALM,IACrC,MAAUK,GAAK,OAAUA,GAAK,SACnCA,EAAI,OAGgB,IAArBuoM,IACPlpM,EAAKimH,EAAI16H,EAAI,GACb+U,EAAK2lH,EAAI16H,EAAI,GACby9M,EAAK/iF,EAAI16H,EAAI,GACO,MAAV,IAALyU,IAAuC,MAAV,IAALM,IAAuC,MAAV,IAAL0oM,MACjDroM,GAAU,GAALsoM,IAAa,IAAa,GAALjpM,IAAc,IAAY,GAALM,IAAc,EAAY,GAAL0oM,IAC3D,OAAUroM,GAAK,WACpBA,EAAI,OAKN,OAANA,GACAA,EAAI,MACJuoM,EAAmB,GAEZvoM,EAAI,QACXA,GAAK,MACLooM,GAAOv2M,OAAOyiF,aAAat0E,IAAM,GAAK,KAAQ,OAC9CA,EAAI,MAAa,KAAJA,GAGjBooM,GAAOv2M,OAAOyiF,aAAat0E,GAC3BpV,GAAK29M,CACR,CAED,OAAOH,CACX,CAxceI,CAASx/M,KAAKs8H,IAAKp0E,EAAKlmD,EAClC,EAEDy9M,UAAW,WACP,IAAIz9M,EAAMhC,KAAKs8M,aAAet8M,KAAKkoD,IAC/BvuC,EAAS3Z,KAAKs8H,IAAI4iF,SAASl/M,KAAKkoD,IAAKlmD,GAEzC,OADAhC,KAAKkoD,IAAMlmD,EACJ2X,CACV,EAID+lM,iBAAkB,SAASj+M,EAAK+6M,GAC5B,GAAIx8M,KAAKD,OAAS27M,GAAIM,MAAO,OAAOv6M,EAAIkE,KAAK3F,KAAKs8M,WAAWE,IAC7D,IAAIx6M,EAAMq6M,GAAcr8M,MAExB,IADAyB,EAAMA,GAAO,GACNzB,KAAKkoD,IAAMlmD,GAAKP,EAAIkE,KAAK3F,KAAKs8M,WAAWE,IAChD,OAAO/6M,CACV,EACDk+M,kBAAmB,SAASl+M,GACxB,GAAIzB,KAAKD,OAAS27M,GAAIM,MAAO,OAAOv6M,EAAIkE,KAAK3F,KAAKi/M,eAClD,IAAIj9M,EAAMq6M,GAAcr8M,MAExB,IADAyB,EAAMA,GAAO,GACNzB,KAAKkoD,IAAMlmD,GAAKP,EAAIkE,KAAK3F,KAAKi/M,eACrC,OAAOx9M,CACV,EACDm+M,kBAAmB,SAASn+M,GACxB,GAAIzB,KAAKD,OAAS27M,GAAIM,MAAO,OAAOv6M,EAAIkE,KAAK3F,KAAK69L,eAClD,IAAI77L,EAAMq6M,GAAcr8M,MAExB,IADAyB,EAAMA,GAAO,GACNzB,KAAKkoD,IAAMlmD,GAAKP,EAAIkE,KAAK3F,KAAK69L,eACrC,OAAOp8L,CACV,EACDo+M,gBAAiB,SAASp+M,GACtB,GAAIzB,KAAKD,OAAS27M,GAAIM,MAAO,OAAOv6M,EAAIkE,KAAK3F,KAAK4+M,aAClD,IAAI58M,EAAMq6M,GAAcr8M,MAExB,IADAyB,EAAMA,GAAO,GACNzB,KAAKkoD,IAAMlmD,GAAKP,EAAIkE,KAAK3F,KAAK4+M,aACrC,OAAOn9M,CACV,EACDq+M,iBAAkB,SAASr+M,GACvB,GAAIzB,KAAKD,OAAS27M,GAAIM,MAAO,OAAOv6M,EAAIkE,KAAK3F,KAAK8+M,cAClD,IAAI98M,EAAMq6M,GAAcr8M,MAExB,IADAyB,EAAMA,GAAO,GACNzB,KAAKkoD,IAAMlmD,GAAKP,EAAIkE,KAAK3F,KAAK8+M,cACrC,OAAOr9M,CACV,EACDs+M,kBAAmB,SAASt+M,GACxB,GAAIzB,KAAKD,OAAS27M,GAAIM,MAAO,OAAOv6M,EAAIkE,KAAK3F,KAAKw+M,eAClD,IAAIx8M,EAAMq6M,GAAcr8M,MAExB,IADAyB,EAAMA,GAAO,GACNzB,KAAKkoD,IAAMlmD,GAAKP,EAAIkE,KAAK3F,KAAKw+M,eACrC,OAAO/8M,CACV,EACDu+M,mBAAoB,SAASv+M,GACzB,GAAIzB,KAAKD,OAAS27M,GAAIM,MAAO,OAAOv6M,EAAIkE,KAAK3F,KAAKy+M,gBAClD,IAAIz8M,EAAMq6M,GAAcr8M,MAExB,IADAyB,EAAMA,GAAO,GACNzB,KAAKkoD,IAAMlmD,GAAKP,EAAIkE,KAAK3F,KAAKy+M,gBACrC,OAAOh9M,CACV,EACDw+M,kBAAmB,SAASx+M,GACxB,GAAIzB,KAAKD,OAAS27M,GAAIM,MAAO,OAAOv6M,EAAIkE,KAAK3F,KAAK0+M,eAClD,IAAI18M,EAAMq6M,GAAcr8M,MAExB,IADAyB,EAAMA,GAAO,GACNzB,KAAKkoD,IAAMlmD,GAAKP,EAAIkE,KAAK3F,KAAK0+M,eACrC,OAAOj9M,CACV,EACDy+M,mBAAoB,SAASz+M,GACzB,GAAIzB,KAAKD,OAAS27M,GAAIM,MAAO,OAAOv6M,EAAIkE,KAAK3F,KAAK2+M,gBAClD,IAAI38M,EAAMq6M,GAAcr8M,MAExB,IADAyB,EAAMA,GAAO,GACNzB,KAAKkoD,IAAMlmD,GAAKP,EAAIkE,KAAK3F,KAAK2+M,gBACrC,OAAOl9M,CACV,EAED68M,KAAM,SAASziM,GACX,IAAI9b,EAAa,EAAN8b,EACX,GAAI9b,IAAS27M,GAAII,OAAQ,KAAO97M,KAAKs8H,IAAIt8H,KAAKkoD,OAAS,WAClD,GAAInoD,IAAS27M,GAAIM,MAAOh8M,KAAKkoD,IAAMloD,KAAKs8M,aAAet8M,KAAKkoD,SAC5D,GAAInoD,IAAS27M,GAAIO,QAASj8M,KAAKkoD,KAAO,MACtC,IAAInoD,IAAS27M,GAAIK,QACjB,MAAM,IAAIvzM,MAAM,uBAAyBzI,GADfC,KAAKkoD,KAAO,CACQ,CACtD,EAIDi4J,SAAU,SAAS9B,EAAKt+M,GACpBC,KAAK88M,YAAauB,GAAO,EAAKt+M,EACjC,EAED68M,QAAS,SAASnhM,GAGd,IAFA,IAAIta,EAASnB,KAAKmB,QAAU,GAErBA,EAASnB,KAAKkoD,IAAMzsC,GAAKta,GAAU,EAE1C,GAAIA,IAAWnB,KAAKmB,OAAQ,CACxB,IAAIm7H,EAAM,IAAI9pH,WAAWrR,GACzBm7H,EAAIvyH,IAAI/J,KAAKs8H,KACbt8H,KAAKs8H,IAAMA,EACXt8H,KAAKmB,OAASA,CACjB,CACJ,EAEDi+J,OAAQ,WAGJ,OAFAp/J,KAAKmB,OAASnB,KAAKkoD,IACnBloD,KAAKkoD,IAAM,EACJloD,KAAKs8H,IAAI4iF,SAAS,EAAGl/M,KAAKmB,OACpC,EAEDq8M,aAAc,SAAS3hM,GACnB7b,KAAK48M,QAAQ,GACboB,GAAWh+M,KAAKs8H,IAAKzgH,EAAK7b,KAAKkoD,KAC/BloD,KAAKkoD,KAAO,CACf,EAEDw1J,cAAe,SAAS7hM,GACpB7b,KAAK48M,QAAQ,GACboB,GAAWh+M,KAAKs8H,IAAKzgH,EAAK7b,KAAKkoD,KAC/BloD,KAAKkoD,KAAO,CACf,EAED01J,aAAc,SAAS/hM,GACnB7b,KAAK48M,QAAQ,GACboB,GAAWh+M,KAAKs8H,KAAY,EAAPzgH,EAAU7b,KAAKkoD,KACpC81J,GAAWh+M,KAAKs8H,IAAKrwH,KAAKuT,MAAM3D,EAAMsgM,IAAiBn8M,KAAKkoD,IAAM,GAClEloD,KAAKkoD,KAAO,CACf,EAED41J,cAAe,SAASjiM,GACpB7b,KAAK48M,QAAQ,GACboB,GAAWh+M,KAAKs8H,KAAY,EAAPzgH,EAAU7b,KAAKkoD,KACpC81J,GAAWh+M,KAAKs8H,IAAKrwH,KAAKuT,MAAM3D,EAAMsgM,IAAiBn8M,KAAKkoD,IAAM,GAClEloD,KAAKkoD,KAAO,CACf,EAED40J,YAAa,SAASjhM,IAClBA,GAAOA,GAAO,GAEJ,WAAaA,EAAM,EAkKrC,SAAwBA,EAAK4/L,GACzB,IAAIx6M,EAAKC,EAEL2a,GAAO,GACP5a,EAAQ4a,EAAM,WAAe,EAC7B3a,EAAQ2a,EAAM,WAAe,IAG7B3a,KAAU2a,EAAM,YAEN,YAHV5a,KAAU4a,EAAM,aAIZ5a,EAAOA,EAAM,EAAK,GAElBA,EAAM,EACNC,EAAQA,EAAO,EAAK,IAI5B,GAAI2a,GAAO,qBAAuBA,GAAO,oBACrC,MAAM,IAAIrT,MAAM,0CAGpBizM,EAAImB,QAAQ,IAMhB,SAA2B37M,EAAKC,EAAMu6M,GAClCA,EAAIn/E,IAAIm/E,EAAIvzJ,OAAe,IAANjnD,EAAa,IAAMA,KAAS,EACjDw6M,EAAIn/E,IAAIm/E,EAAIvzJ,OAAe,IAANjnD,EAAa,IAAMA,KAAS,EACjDw6M,EAAIn/E,IAAIm/E,EAAIvzJ,OAAe,IAANjnD,EAAa,IAAMA,KAAS,EACjDw6M,EAAIn/E,IAAIm/E,EAAIvzJ,OAAe,IAANjnD,EAAa,IAAMA,KAAS,EACjDw6M,EAAIn/E,IAAIm/E,EAAIvzJ,KAAe,IAANjnD,CACzB,CAVIm/M,CAAkBn/M,EAAKC,EAAMu6M,GAYjC,SAA4Bv6M,EAAMu6M,GAC9B,IAAI4E,GAAc,EAAPn/M,IAAgB,EAEqC,GAAhEu6M,EAAIn/E,IAAIm/E,EAAIvzJ,QAAUm4J,IAAgBn/M,KAAU,GAAK,IAAO,IAASA,EAAM,OACX,GAAhEu6M,EAAIn/E,IAAIm/E,EAAIvzJ,OAAiB,IAAPhnD,IAAgBA,KAAU,GAAK,IAAO,IAASA,EAAM,OACX,GAAhEu6M,EAAIn/E,IAAIm/E,EAAIvzJ,OAAiB,IAAPhnD,IAAgBA,KAAU,GAAK,IAAO,IAASA,EAAM,OACX,GAAhEu6M,EAAIn/E,IAAIm/E,EAAIvzJ,OAAiB,IAAPhnD,IAAgBA,KAAU,GAAK,IAAO,IAASA,EAAM,OACX,GAAhEu6M,EAAIn/E,IAAIm/E,EAAIvzJ,OAAiB,IAAPhnD,IAAgBA,KAAU,GAAK,IAAO,IAASA,EAAM,OAC3Eu6M,EAAIn/E,IAAIm/E,EAAIvzJ,OAAiB,IAAPhnD,CAC1B,CApBIo/M,CAAmBp/M,EAAMu6M,EAC7B,CA3LY8E,CAAe1kM,EAAK7b,OAIxBA,KAAK48M,QAAQ,GAEb58M,KAAKs8H,IAAIt8H,KAAKkoD,OAAyB,IAANrsC,GAAeA,EAAM,IAAO,IAAO,GAAQA,GAAO,MACnF7b,KAAKs8H,IAAIt8H,KAAKkoD,OAAyB,KAAdrsC,KAAS,IAAcA,EAAM,IAAO,IAAO,GAAQA,GAAO,MACnF7b,KAAKs8H,IAAIt8H,KAAKkoD,OAAyB,KAAdrsC,KAAS,IAAcA,EAAM,IAAO,IAAO,GAAQA,GAAO,MACnF7b,KAAKs8H,IAAIt8H,KAAKkoD,OAAYrsC,IAAQ,EAAK,OAC1C,EAEDmhM,aAAc,SAASnhM,GACnB7b,KAAK88M,YAAYjhM,EAAM,EAAW,GAANA,EAAU,EAAU,EAANA,EAC7C,EAEDyhM,aAAc,SAASzhM,GACnB7b,KAAK88M,YAAYplK,QAAQ77B,GAC5B,EAED2kM,YAAa,SAASpB,GAClBA,EAAMv2M,OAAOu2M,GACbp/M,KAAK48M,QAAqB,EAAbwC,EAAIj+M,QAEjBnB,KAAKkoD,MAEL,IAAIw0J,EAAW18M,KAAKkoD,IAEpBloD,KAAKkoD,IAsSb,SAAmBo0E,EAAK8iF,EAAKl3J,GACzB,IAAK,IAAWlxC,EAAGypM,EAAV7+M,EAAI,EAAYA,EAAIw9M,EAAIj+M,OAAQS,IAAK,CAG1C,IAFAoV,EAAIooM,EAAIj0H,WAAWvpF,IAEX,OAAUoV,EAAI,MAAQ,CAC1B,IAAIypM,EAWG,CACCzpM,EAAI,OAAWpV,EAAI,IAAMw9M,EAAIj+M,QAC7Bm7H,EAAIp0E,KAAS,IACbo0E,EAAIp0E,KAAS,IACbo0E,EAAIp0E,KAAS,KAEbu4J,EAAOzpM,EAEX,QACH,CAnBG,GAAIA,EAAI,MAAQ,CACZslH,EAAIp0E,KAAS,IACbo0E,EAAIp0E,KAAS,IACbo0E,EAAIp0E,KAAS,IACbu4J,EAAOzpM,EACP,QACpB,CACoBA,EAAIypM,EAAO,OAAU,GAAKzpM,EAAI,MAAS,MACvCypM,EAAO,IAYlB,MAAUA,IACPnkF,EAAIp0E,KAAS,IACbo0E,EAAIp0E,KAAS,IACbo0E,EAAIp0E,KAAS,IACbu4J,EAAO,MAGPzpM,EAAI,IACJslH,EAAIp0E,KAASlxC,GAETA,EAAI,KACJslH,EAAIp0E,KAASlxC,GAAK,EAAM,KAEpBA,EAAI,MACJslH,EAAIp0E,KAASlxC,GAAK,GAAM,KAExBslH,EAAIp0E,KAASlxC,GAAK,GAAO,IACzBslH,EAAIp0E,KAASlxC,GAAK,GAAM,GAAO,KAEnCslH,EAAIp0E,KAASlxC,GAAK,EAAM,GAAO,KAEnCslH,EAAIp0E,KAAa,GAAJlxC,EAAW,IAE/B,CACD,OAAOkxC,CACX,CAzVmBw4J,CAAU1gN,KAAKs8H,IAAK8iF,EAAKp/M,KAAKkoD,KACzC,IAAIjgD,EAAMjI,KAAKkoD,IAAMw0J,EAEjBz0M,GAAO,KAAMw0M,GAAuBC,EAAUz0M,EAAKjI,MAGvDA,KAAKkoD,IAAMw0J,EAAW,EACtB18M,KAAK88M,YAAY70M,GACjBjI,KAAKkoD,KAAOjgD,CACf,EAEDi1M,WAAY,SAASrhM,GACjB7b,KAAK48M,QAAQ,GACb5B,GAAQpkB,MAAM52L,KAAKs8H,IAAKzgH,EAAK7b,KAAKkoD,KAAK,EAAM,GAAI,GACjDloD,KAAKkoD,KAAO,CACf,EAEDk1J,YAAa,SAASvhM,GAClB7b,KAAK48M,QAAQ,GACb5B,GAAQpkB,MAAM52L,KAAKs8H,IAAKzgH,EAAK7b,KAAKkoD,KAAK,EAAM,GAAI,GACjDloD,KAAKkoD,KAAO,CACf,EAEDy4J,WAAY,SAAShnM,GACjB,IAAI1R,EAAM0R,EAAOxY,OACjBnB,KAAK88M,YAAY70M,GACjBjI,KAAK48M,QAAQ30M,GACb,IAAK,IAAIrG,EAAI,EAAGA,EAAIqG,EAAKrG,IAAK5B,KAAKs8H,IAAIt8H,KAAKkoD,OAASvuC,EAAO/X,EAC/D,EAEDg/M,gBAAiB,SAASr9M,EAAIoF,GAC1B3I,KAAKkoD,MAGL,IAAIw0J,EAAW18M,KAAKkoD,IACpB3kD,EAAGoF,EAAK3I,MACR,IAAIiI,EAAMjI,KAAKkoD,IAAMw0J,EAEjBz0M,GAAO,KAAMw0M,GAAuBC,EAAUz0M,EAAKjI,MAGvDA,KAAKkoD,IAAMw0J,EAAW,EACtB18M,KAAK88M,YAAY70M,GACjBjI,KAAKkoD,KAAOjgD,CACf,EAED44M,aAAc,SAASxC,EAAK96M,EAAIoF,GAC5B3I,KAAKmgN,SAAS9B,EAAK3C,GAAIM,OACvBh8M,KAAK4gN,gBAAgBr9M,EAAIoF,EAC5B,EAEDk0M,kBAAqB,SAASwB,EAAK58M,GAAWA,EAAIN,QAAQnB,KAAK6gN,aAAaxC,EAAKxB,GAAmBp7M,EAAS,EAC7Gs7M,mBAAqB,SAASsB,EAAK58M,GAAWA,EAAIN,QAAQnB,KAAK6gN,aAAaxC,EAAKtB,GAAoBt7M,EAAQ,EAC7G47M,mBAAqB,SAASgB,EAAK58M,GAAWA,EAAIN,QAAQnB,KAAK6gN,aAAaxC,EAAKhB,GAAoB57M,EAAQ,EAC7Gw7M,iBAAqB,SAASoB,EAAK58M,GAAWA,EAAIN,QAAQnB,KAAK6gN,aAAaxC,EAAKpB,GAAkBx7M,EAAU,EAC7G07M,kBAAqB,SAASkB,EAAK58M,GAAWA,EAAIN,QAAQnB,KAAK6gN,aAAaxC,EAAKlB,GAAmB17M,EAAS,EAC7G87M,mBAAqB,SAASc,EAAK58M,GAAWA,EAAIN,QAAQnB,KAAK6gN,aAAaxC,EAAKd,GAAoB97M,EAAQ,EAC7Gg8M,oBAAqB,SAASY,EAAK58M,GAAWA,EAAIN,QAAQnB,KAAK6gN,aAAaxC,EAAKZ,GAAqBh8M,EAAO,EAC7Gk8M,mBAAqB,SAASU,EAAK58M,GAAWA,EAAIN,QAAQnB,KAAK6gN,aAAaxC,EAAKV,GAAoBl8M,EAAQ,EAC7Go8M,oBAAqB,SAASQ,EAAK58M,GAAWA,EAAIN,QAAQnB,KAAK6gN,aAAaxC,EAAKR,GAAqBp8M,EAAO,EAE7Gq/M,gBAAiB,SAASzC,EAAK1kM,GAC3B3Z,KAAKmgN,SAAS9B,EAAK3C,GAAIM,OACvBh8M,KAAK2gN,WAAWhnM,EACnB,EACDonM,kBAAmB,SAAS1C,EAAKxiM,GAC7B7b,KAAKmgN,SAAS9B,EAAK3C,GAAIO,SACvBj8M,KAAKw9M,aAAa3hM,EACrB,EACDmlM,mBAAoB,SAAS3C,EAAKxiM,GAC9B7b,KAAKmgN,SAAS9B,EAAK3C,GAAIO,SACvBj8M,KAAK09M,cAAc7hM,EACtB,EACDolM,kBAAmB,SAAS5C,EAAKxiM,GAC7B7b,KAAKmgN,SAAS9B,EAAK3C,GAAIK,SACvB/7M,KAAK49M,aAAa/hM,EACrB,EACDqlM,mBAAoB,SAAS7C,EAAKxiM,GAC9B7b,KAAKmgN,SAAS9B,EAAK3C,GAAIK,SACvB/7M,KAAK89M,cAAcjiM,EACtB,EACDslM,iBAAkB,SAAS9C,EAAKxiM,GAC5B7b,KAAKmgN,SAAS9B,EAAK3C,GAAII,QACvB97M,KAAK88M,YAAYjhM,EACpB,EACDulM,kBAAmB,SAAS/C,EAAKxiM,GAC7B7b,KAAKmgN,SAAS9B,EAAK3C,GAAII,QACvB97M,KAAKg9M,aAAanhM,EACrB,EACDwlM,iBAAkB,SAAShD,EAAKe,GAC5Bp/M,KAAKmgN,SAAS9B,EAAK3C,GAAIM,OACvBh8M,KAAKwgN,YAAYpB,EACpB,EACDkC,gBAAiB,SAASjD,EAAKxiM,GAC3B7b,KAAKmgN,SAAS9B,EAAK3C,GAAIO,SACvBj8M,KAAKk9M,WAAWrhM,EACnB,EACD0lM,iBAAkB,SAASlD,EAAKxiM,GAC5B7b,KAAKmgN,SAAS9B,EAAK3C,GAAIK,SACvB/7M,KAAKo9M,YAAYvhM,EACpB,EACD2lM,kBAAmB,SAASnD,EAAKxiM,GAC7B7b,KAAKmhN,iBAAiB9C,EAAK3mK,QAAQ77B,GACtC,iBC1FL,SAAS4lM,GAAgBpD,EAAKt3J,EAAQ00J,GACpC,GAAY,IAAR4C,EAAW,CACb,MAAMzwK,EAAQ,CACZjnC,KAAM,GACNsC,OAAQ,GACRk6D,SAAU,IAENnhE,EAAMy5M,EAAIa,aAAeb,EAAIvzJ,IACnCuzJ,EAAI0C,WAAWuD,GAAgB9zK,EAAO5rC,GACtC4rC,EAAMzsC,OAASysC,EAAMu1B,SAAShiE,OAC1BysC,EAAMzsC,SACR4lD,EAAOnZ,EAAMl4B,MAAQk4B,EAExB,CACH,CAQA,SAAS8zK,GAAerD,EAAKzwK,EAAO6tK,GAClC,GAAY,KAAR4C,EACFzwK,EAAM4gE,QAAUitG,EAAIa,kBACf,GAAY,IAAR+B,EACTzwK,EAAMl4B,KAAO+lM,EAAIpd,kBACZ,GAAY,IAARggB,EACTzwK,EAAMp0B,OAASiiM,EAAIa,kBACd,GAAY,IAAR+B,EACTzwK,EAAMu1B,SAASx9D,KAAK81M,EAAIvzJ,UACnB,GAAY,IAARm2J,EACTzwK,EAAMjnC,KAAKhB,KAAK81M,EAAIpd,mBACf,GAAY,IAARggB,EAAW,CACpB,IAAIh6M,EAAQ,KACZ,MAAMrC,EAAMy5M,EAAIa,aAAeb,EAAIvzJ,IACnC,KAAOuzJ,EAAIvzJ,IAAMlmD,GAEfqC,EACU,KAFVg6M,EAAM5C,EAAIa,cAAgB,GAGpBb,EAAIpd,aACI,IAARggB,EACA5C,EAAImD,YACI,IAARP,EACA5C,EAAIqD,aACI,IAART,EACA5C,EAAIuD,eACI,IAARX,EACA5C,EAAIa,aACI,IAAR+B,EACA5C,EAAIwD,cACI,IAARZ,EACA5C,EAAI5d,cACJ,KAERjwJ,EAAM3kC,OAAOtD,KAAKtB,EACnB,CACH,CAQA,SAASs9M,GAAiBtD,EAAK1+J,EAAS87J,GACtC,GAAW,GAAP4C,EACF1+J,EAAQnyC,GAAKiuM,EAAIa,kBACZ,GAAW,GAAP+B,EAAU,CACnB,MAAMr8M,EAAMy5M,EAAIa,aAAeb,EAAIvzJ,IACnC,KAAOuzJ,EAAIvzJ,IAAMlmD,GAAK,CACpB,MAAMuF,EAAMo4C,EAAQ/R,MAAMjnC,KAAK80M,EAAIa,cAC7Bj4M,EAAQs7C,EAAQ/R,MAAM3kC,OAAOwyM,EAAIa,cACvC38J,EAAQ7qC,WAAWvN,GAAOlD,CAC3B,CACL,MAAoB,GAAPg6M,EACT1+J,EAAQ5/C,KAAO07M,EAAIa,aACH,GAAP+B,IACT1+J,EAAQ/qC,SAAW6mM,EAAIvzJ,IAE3B,CASA,SAAS05J,GAAenG,EAAK7tK,EAAOhsC,GAClC65M,EAAIvzJ,IAAMta,EAAMu1B,SAASvhE,GACzB,MAAMI,EAAMy5M,EAAIa,aAAeb,EAAIvzJ,IAE7BvI,EAAU,CACd/R,MAAOA,EACP7tC,KAAM,EACN+U,WAAY,CAAE,GAGhB,OADA2mM,EAAI0C,WAAWwD,GAAkBhiK,EAAS39C,GACnC29C,CACT,CAuBA,IAAAkiK,GA1YA,cAAkBvqB,GAIhB,WAAAx3L,CAAY6K,GACV1F,QAEA0F,EAAUA,GAAoB,GAK9B3K,KAAKotE,eAAiB,IAAI1qD,GAAW,CACnC7C,KAAM,GACN8C,MAAO,gBAOT3iB,KAAK8hN,cAAgBn3M,EAAQwrL,aACzBxrL,EAAQwrL,aACRl7F,GAMJj7F,KAAKuU,cAAgB5J,EAAQi5K,aAM7B5jL,KAAK+hN,WAAap3M,EAAQq3M,UAAYr3M,EAAQq3M,UAAY,QAM1DhiN,KAAKumH,QAAU57G,EAAQo8C,OAASp8C,EAAQo8C,OAAS,KAMjD/mD,KAAKiiN,YAAct3M,EAAQu3M,WAE3BliN,KAAKk4G,oBAAsB,CACzB,qCACA,yBAEH,CAWD,gBAAAiqG,CAAiB1G,EAAK97J,EAAS7kC,EAAiB8V,GAC9C6qL,EAAIvzJ,IAAMvI,EAAQ/qC,SAElB,MAAM5S,EAAMy5M,EAAIa,aAAeb,EAAIvzJ,IACnC,IAAIk6J,EAAM,EACNjhN,EAAS,EACTkW,EAAI,EACJC,EAAI,EACJ+qM,EAAY,EACZC,EAAa,EAEjB,KAAO7G,EAAIvzJ,IAAMlmD,GAAK,CACpB,IAAKb,EAAQ,CACX,MAAMohN,EAAS9G,EAAIa,aACnB8F,EAAe,EAATG,EACNphN,EAASohN,GAAU,CACpB,CAID,GAFAphN,IAEY,IAARihN,GAAqB,IAARA,EACf/qM,GAAKokM,EAAIwD,cACT3nM,GAAKmkM,EAAIwD,cAEG,IAARmD,GAEEC,EAAYC,IACd1xL,EAAKjrB,KAAK08M,GACVC,EAAaD,GAIjBvnM,EAAgBnV,KAAK0R,EAAGC,GACxB+qM,GAAa,MACR,IAAY,IAARD,EAUT,MAAM,IAAI55M,MAAM,oCATZ65M,EAAYC,IAEdxnM,EAAgBnV,KACdmV,EAAgBwnM,GAChBxnM,EAAgBwnM,EAAa,IAE/BD,GAAa,EAIhB,CACF,CAEGA,EAAYC,IACd1xL,EAAKjrB,KAAK08M,GACVC,EAAaD,EAEhB,CASD,cAAAG,CAAe/G,EAAKgH,EAAY93M,GAC9B,MAAM5K,EAAO0iN,EAAW1iN,KACxB,GAAa,IAATA,EACF,OAAO,KAGT,IAAI4/C,EACJ,MAAM12C,EAASw5M,EAAW3tM,WAE1B,IAAItH,EACCxN,KAAKiiN,aAGRz0M,EAAKvE,EAAOjJ,KAAKiiN,oBACVh5M,EAAOjJ,KAAKiiN,cAHnBz0M,EAAKi1M,EAAWj1M,GAMlBvE,EAAOjJ,KAAK+hN,YAAcU,EAAW70K,MAAMl4B,KAE3C,MAAMoF,EAAgD,GAChD8V,EAAqC,GAC3C5wB,KAAKmiN,iBAAiB1G,EAAKgH,EAAY3nM,EAAiB8V,GAExD,MAAMgrE,EAuOV,SAAyB77F,EAAMuhK,GAE7B,IAAI1lE,EACS,IAAT77F,EACF67F,EAA2B,IAAZ0lE,EAAgB,QAAU,aACvB,IAATvhK,EACT67F,EAA2B,IAAZ0lE,EAAgB,aAAe,kBAC5B,IAATvhK,IACT67F,EAAe,WAIjB,OAAOA,CACT,CApPyB8mH,CAAgB3iN,EAAM6wB,EAAKzvB,QAEhD,GAAInB,KAAK8hN,gBAAkB7mH,GACzBt7C,EAAU,IAAI3/C,KAAK8hN,cACjBlmH,EACA9gF,EACA8V,EACA,EACA3nB,EACAuE,GAEFmyC,EAAQ3pC,UAAUrL,EAAQyiE,oBACrB,CACL,IAAIyrG,EACJ,GAAoB,WAAhBj9E,EAA2B,CAC7B,MAAM9qE,EAAQ+E,GAAY/a,EAAiB8V,GAC3CioJ,EACE/nJ,EAAM3vB,OAAS,EACX,IAAI+5E,GAAapgE,EAAiB,KAAMgW,GACxC,IAAImF,GAAQnb,EAAiB,KAAM8V,EACjD,MACQioJ,EACmB,UAAjBj9E,EACI,IAAIpoE,GAAM1Y,EAAiB,MACV,eAAjB8gF,EACA,IAAI/gB,GAAW//D,EAAiB,MACf,eAAjB8gF,EACA,IAAI5gB,GAAWlgE,EAAiB,MACf,oBAAjB8gF,EACA,IAAI3gB,GAAgBngE,EAAiB,KAAM8V,GAC3C,KAKR+uB,EAAU,IAAIgjK,EAFZ3iN,KACR,eAEUA,KAAKuU,eACPorC,EAAQ3qC,gBAAgBhV,KAAKuU,eAE/B,MAAMK,EAAW+hL,GAA6B9d,GAAM,EAAOluK,GAC3Dg1C,EAAQ9qC,YAAYD,QACTpO,IAAPgH,GACFmyC,EAAQlqC,MAAMjI,GAEhBmyC,EAAQx2C,cAAcF,GAAQ,EAC/B,CAED,OAAO02C,CACR,CAKD,OAAAjxB,GACE,MAAO,aACR,CAUD,YAAAggD,CAAaxkE,EAAQS,GACnB,MAAMo8C,EAAS/mD,KAAKumH,QAEdn5C,EAAiBhkE,IADvBuB,EAAU3K,KAAKq2L,aAAa1rL,IACOyiE,gBACnCA,EAAerrD,eAAepX,EAAQ6O,QACtC7O,EAAQyiE,eAAiBA,EAEzB,MAAMquI,EAAM,IAAImH,GAAgC,GAC1CC,EAAYpH,EAAI0C,WAAWsD,GAAiB,CAAE,GAC9Ct+I,EAAW,GACjB,IAAK,MAAMztD,KAAQmtM,EAAW,CAC5B,GAAI97J,IAAWA,EAAOrhD,SAASgQ,GAC7B,SAEF,MAAMotM,EAAWD,EAAUntM,GAErB8D,EAASspM,EAAW,CAAC,EAAG,EAAGA,EAAStpM,OAAQspM,EAAStpM,QAAU,KACrE4zD,EAAetrD,UAAUtI,GAEzB,IAAK,IAAI5X,EAAI,EAAGuE,EAAK28M,EAAS3hN,OAAQS,EAAIuE,IAAMvE,EAAG,CACjD,MAAM6gN,EAAab,GAAenG,EAAKqH,EAAUlhN,GAC3C+9C,EAAU3/C,KAAKwiN,eAAe/G,EAAKgH,EAAY93M,GACrC,OAAZg1C,GACFwjB,EAASx9D,KAAKg6C,EAEjB,CACF,CAED,OAAOwjB,CACR,CASD,cAAAyL,CAAe1kE,GACb,OAAOlK,KAAKotE,cACb,CAOD,SAAA9lB,CAAUP,GACR/mD,KAAKumH,QAAUx/D,CAChB,GCzRH,MAAMm/I,GAAiB,CAAC,MAOlB6c,GAAc9xF,GAAgBi1E,GAAgB,CAClD8c,GA6JF,SAAgBzxM,EAAMo+G,GACpB,MAAM1mH,EAAgC0mH,EAAYA,EAAYxuH,OAAS,GACvE8H,EAAOg6M,OAAOt9M,KAAK4L,EAAKgqL,aAAa,QACjChqL,EAAKwlD,aAAa,QAAUxlD,EAAKwlD,aAAa,SAChD9tD,EAAO6R,gBAAgBnV,KAAKolC,WAAWx5B,EAAKgqL,aAAa,SACzDtyL,EAAO6R,gBAAgBnV,KAAKolC,WAAWx5B,EAAKgqL,aAAa,SAE7D,EAnKE8iB,IAAO6E,KAQHC,GAAUlyF,GAAgBi1E,GAAgB,CAC9C30L,KAyFF,SAAkBA,EAAMo+G,GACtB,MAAMhlH,EACJglH,EAAY,GAERnjH,EAA+BmjH,EAAYA,EAAYxuH,OAAS,GAChEqM,EAAK+D,EAAKgqL,aAAa,MAEvBhiL,EAAc,CAClBwxB,WAAWx5B,EAAKgqL,aAAa,QAC7BxwJ,WAAWx5B,EAAKgqL,aAAa,SAE/B/uL,EAAM+jL,MAAM/iL,GAAM+L,EAElB,MAAMtQ,EAASyoH,GACb,CACE0xF,KAAM,CAAE,GAEVC,GACA9xM,EACAo+G,GAEF,IAAK7qH,EAAQmE,EAAOm6M,MAAO,CACzB,MAAMxuM,EAAW,IAAI4e,GAAMja,GAC3Bo9K,GAA6B/hL,GAAU,EAAOjK,GAC9C,MAAMg1C,EAAU,IAAIvrC,GAAQQ,QACjBpO,IAAPgH,GACFmyC,EAAQlqC,MAAMjI,GAEhBmyC,EAAQx2C,cAAcF,EAAOm6M,MAAM,GACnC52M,EAAM22D,SAASx9D,KAAKg6C,EACrB,CACH,EAvHE2jK,IA6HF,SAAiB/xM,EAAMo+G,GACrB,MACM1mH,EAASyoH,GACb,CACElkH,GAHO+D,EAAKgqL,aAAa,MAIzB0nB,OAAQ,GACRnoM,gBAAiB,GACjBsoM,KAAM,CAAE,GAEVL,GACAxxM,EACAo+G,GAEmCA,EAAYA,EAAYxuH,OAAS,GAChEoiN,KAAK59M,KAAKsD,EAClB,IA5DA,MAAMo6M,GAAepyF,GAAgBi1E,GAAgB,CACnDmY,IAAO6E,KA8ET,SAASA,GAAQ3xM,EAAMo+G,GACiBA,EAAYA,EAAYxuH,OAAS,GAChEiiN,KAAK7xM,EAAKgqL,aAAa,MAAQhqL,EAAKgqL,aAAa,IAC1D,CAEA,IAAAioB,GA1JA,cAAqBhpB,GACnB,WAAA16L,GACEmF,QAKAjF,KAAKotE,eAAiBx+C,GAAc,YACrC,CAQD,oBAAA+qK,CAAqBpoL,EAAM5G,GAEzB,GADAA,EAAU3K,KAAKo2L,eAAe7kL,EAAM5G,GACd,OAAlB4G,EAAKw+G,UAAoB,CAC3B,MAAMvjH,EAAQklH,GACZ,CACE6+D,MAAO,CAAE,EACTgzB,KAAM,GACNpgJ,SAAU,IAEZggJ,GACA5xM,EACA,CAAC5G,IAGH,IAAK,IAAI2Z,EAAI,EAAGA,EAAI9X,EAAM+2M,KAAKpiN,OAAQmjB,IAAK,CAC1C,MAAMrb,EAAgCuD,EAAM+2M,KAAKj/L,GAE3CxJ,EAAkB7R,EAAO6R,gBAC/B,IAAKA,EAAgB3Z,OACnB,IAAK,IAAIS,EAAI,EAAGuE,EAAK8C,EAAOg6M,OAAO9hN,OAAQS,EAAIuE,EAAIvE,IAAK,CAEtDM,EAAO4Y,EADOtO,EAAM+jL,MAAMtnL,EAAOg6M,OAAOrhN,IAEzC,CAEH,IAAIgT,EAGFA,EAFE3L,EAAOg6M,OAAO,IAAMh6M,EAAOg6M,OAAOh6M,EAAOg6M,OAAO9hN,OAAS,GAEhD,IAAI80B,GAAQnb,EAAiB,KAAM,CAC5CA,EAAgB3Z,SAGP,IAAI05E,GAAW//D,EAAiB,MAE7C67K,GAA6B/hL,GAAU,EAAOjK,GAC9C,MAAMg1C,EAAU,IAAIvrC,GAAQQ,QACVpO,IAAdyC,EAAOuE,IACTmyC,EAAQlqC,MAAMxM,EAAOuE,IAEvBmyC,EAAQx2C,cAAcF,EAAOm6M,MAAM,GACnC52M,EAAM22D,SAASx9D,KAAKg6C,EACrB,CACD,GAAInzC,EAAM22D,SACR,OAAO32D,EAAM22D,QAEhB,CACD,MAAO,EACR,GCrDH,IAAAsgJ,GA7CA,MAQE,IAAA5E,CAAK30M,GACH,IAAKA,EACH,OAAO,KAET,GAAsB,iBAAXA,EAAqB,CAC9B,MAAM0hD,EAAM1gB,GAAMhhC,GAClB,OAAOlK,KAAK0jN,iBAAiB93J,EAC9B,CACD,OAAI0jE,GAAWplH,GACNlK,KAAK0jN,iBAA0C,GAEjD1jN,KAAK2jN,aAAqC,EAClD,CAMD,gBAAAD,CAAiB93J,GACf,IAAK,IAAIjqD,EAAIiqD,EAAItF,WAAY3kD,EAAGA,EAAIA,EAAE0tH,YACpC,GAAI1tH,EAAEqtH,UAAYC,KAAK2qE,aACrB,OAAO55L,KAAK2jN,aAAqC,GAGrD,OAAO,IACR,CAOD,YAAAA,CAAapyM,GACXhJ,GACD,GC9CH,MAAMq7M,GAAgB,+BAMf,SAASC,GAAStyM,GACvB,OAAOA,EAAKg+G,eAAeq0F,GAAe,OAC5C,CCCA,MAAM1d,GAAiB,CAAC,KAAM,kCAOxBid,GAAUlyF,GAAgBi1E,GAAgB,CAC9C4d,sBAAyB9zF,IA4Q3B,SAAmCz+G,EAAMo+G,GACvC,OAAO+B,GAAgB,CAAE,EAAEqyF,GAAgCxyM,EAAMo+G,EACnE,IA7QEq0F,gBAAmBh0F,IA6RrB,SAA6Bz+G,EAAMo+G,GACjC,OAAO+B,GAAgB,CAAE,EAAEuyF,GAA0B1yM,EAAMo+G,EAC7D,IA9REu0F,mBAAsBl0F,IAwPxB,SAAgCz+G,EAAMo+G,GACpC,OAAO+B,GAAgB,CAAE,EAAEyyF,GAA6B5yM,EAAMo+G,EAChE,MAnOA,MAAMy0F,GAAkBnzF,GAAgBi1E,GAAgB,CACtDme,cAAiBr0F,GAAyBquE,IAC1CimB,KAAQt0F,GAAyBquE,IACjCkmB,mBAAsBv0F,GAAyBquE,IAC/CmmB,WAAcx0F,GAAyBquE,IACvComB,QAAWz0F,GAAyBquE,IACpCqmB,sBAAyB10F,GAAyBquE,MAQ9CsmB,GAAyB1zF,GAAgBi1E,GAAgB,CAC7D0e,MAAS90F,IA+PX,SAAmBv+G,EAAMo+G,GACvB,OAAO0uE,GAAW9sL,EACpB,MAzPMszM,GAAqB5zF,GAAgBi1E,GAAgB,CACzD4e,cAAiB90F,IAuHnB,SAA2Bz+G,EAAMo+G,GAC/B,OAAO+B,GAAgB,CAAE,EAAEizF,GAAwBpzM,EAAMo+G,EAC3D,MAjHMo1F,GAAuB9zF,GAAgBi1E,GAAgB,CAC3D8e,MAASh1F,IAyMX,SAAmBz+G,EAAMo+G,GACvB,OAAO+B,GAAgB,CAAE,EAAEuzF,GAAe1zM,EAAMo+G,EAClD,IA1MEu1F,QAAWl1F,IAoGb,SAAqBz+G,EAAMo+G,GACzB,OAAO+B,GAAgB,CAAE,EAAE0yF,GAAiB7yM,EAAMo+G,EACpD,MA9FMw1F,GAAcl0F,GAAgBi1E,GAAgB,CAClDkf,KAAQp1F,IA8JV,SAAkBz+G,EAAMo+G,GACtB,OAAO+B,GAAgB,CAAE,EAAE2zF,GAAc9zM,EAAMo+G,EACjD,MAxJM01F,GAAep0F,GAAgBi1E,GAAgB,CACnDx9D,IAAO5Y,IAmIT,SAAiBv+G,EAAMo+G,GACrB,MAAM3/C,EAAO6zI,GAAStyM,GACtB,IAAKy+D,EACH,OAEF,OAAO0hD,GACL,CAAC1hD,KAAQA,GACTs1I,GACA/zM,EACAo+G,EAEJ,IA7IE41F,UAAQ/+M,IAQJg/M,GAAoBv0F,GAAgBi1E,GAAgB,CACxDuf,IAAOz1F,IAgHT,SAAiBz+G,EAAMo+G,GACrB,OAAO+B,GAAgB,CAAE,EAAEyzF,GAAa5zM,EAAMo+G,EAChD,MA1GMw0F,GAA8BlzF,GAAgBi1E,GAAgB,CAClEwf,UA2IF,SAAuBn0M,EAAMo+G,GAC3B,MAAMj6G,EAAOnE,EAAKgqL,aAAa,QACzBl3L,EAAQqtH,GAAgB,CAAA,EAAI8zF,GAAmBj0M,EAAMo+G,GAC3D,IAAKtrH,EACH,OAEoCsrH,EAAYA,EAAYxuH,OAAS,GAChEuU,GAAQrR,CACjB,IA3IM4gN,GAAgBh0F,GAAgBi1E,GAAgB,CACpDyf,MAAS31F,GAAyBquE,IAClCunB,UAAa51F,GAAyBquE,MAQlCinB,GAAyBr0F,GAAgBi1E,GAAgB,CAC7D2f,WAAc/1F,IA8DhB,SAAwBv+G,EAAMo+G,GAC5B,MAAMj6G,EAAOnE,EAAKgqL,aAAa,QAC/B,IAAK7lL,EACH,OAEF,OAAOg8G,GAAgB,CAACh8G,KAAQA,GAAOmvM,GAAoBtzM,EAAMo+G,EACnE,MA5DMm2F,GAA0B70F,GAAgBi1E,GAAgB,CAC9D6f,eAAkB/1F,GAAyBquE,IAC3C2nB,aAAgBh2F,GAAyBquE,IACzC4nB,YAAej2F,IAgEjB,SAAyBz+G,EAAMo+G,GAC7B,OAAO+B,GAAgB,CAAE,EAAEqzF,GAAsBxzM,EAAMo+G,EACzD,MA1DMo0F,GAAiC9yF,GAAgBi1E,GAAgB,CACrEggB,SAAYl2F,GAAyBquE,IACrC8nB,kBAAqBn2F,GAAyBquE,IAC9C+nB,KAAQp2F,GAAyBquE,IACjCgoB,MAASr2F,GAAyBquE,IAClCioB,mBAAsBt2F,GAAyBquE,IAC/CkoB,YAAev2F,GAAyBquE,MAQpC4lB,GAA2BhzF,GAAgBi1E,GAAgB,CAC/DsgB,aAAgBx2F,GAAyBquE,IACzCooB,aAAgBz2F,GAAyB6zF,IACzC6C,eAAkB12F,IA8HpB,SAA4Bz+G,EAAMo+G,GAChC,OAAO+B,GAAgB,CAAE,EAAEo0F,GAAyBv0M,EAAMo+G,EAC5D,MAoBA,IAAAg3F,GAtSA,cAAkBC,GAChB,WAAA9mN,GACEmF,OACD,CAMD,YAAA0+M,CAAapyM,GACX,MAAMs1M,EAAYn1F,GAAgB,CAAA,EAAIyxF,GAAS5xM,EAAM,IACrD,OAAOs1M,GAAwB,IAChC,GC2HI,SAASC,GAAaC,EAAS/rM,EAAQiK,GAE5C,IAAIhO,EADJgO,EAASA,GAAkB,IAG3B,MAAM+hM,EAAc,IAAI3kN,MAAM2Y,GAC9B,IAAK/D,EAAI,EAAGA,EAAI+D,IAAU/D,EACxB+vM,EAAY/vM,GAAK,EAGnB,IAAK,IAAIrV,EAAI,EAAGuE,EAAK4gN,EAAQ5lN,OAAQS,EAAIuE,GACvC,IAAK8Q,EAAI,EAAGA,EAAI+D,IAAU/D,IAAKrV,EAAG,CAChC,MAAM0jI,EAAMyhF,EAAQnlN,GACd+L,EAAQ23H,EAAM0hF,EAAY/vM,GAChC+vM,EAAY/vM,GAAKquH,EAEjByhF,EAAQnlN,GAAK+L,CACd,CAGH,OAAOs5M,GAAaF,EAAS9hM,EAC/B,CAaO,SAASiiM,GAAa5+E,EAASttH,EAAQiK,GAE5C,IAAIhO,EADJgO,EAASA,GAAkB,IAI3B,MAAM+hM,EAAc,IAAI3kN,MAAM2Y,GAC9B,IAAK/D,EAAI,EAAGA,EAAI+D,IAAU/D,EACxB+vM,EAAY/vM,GAAK,EAGnB,MAAM8vM,EAAUI,GAAa7+E,EAASrjH,GAEtC,IAAK,IAAIrjB,EAAI,EAAGuE,EAAK4gN,EAAQ5lN,OAAQS,EAAIuE,GACvC,IAAK8Q,EAAI,EAAGA,EAAI+D,IAAU/D,IAAKrV,EAC7BolN,EAAY/vM,IAAM8vM,EAAQnlN,GAE1BmlN,EAAQnlN,GAAKolN,EAAY/vM,GAI7B,OAAO8vM,CACT,CAcO,SAASE,GAAaF,EAAS9hM,GACpCA,EAASA,GAAkB,IAC3B,IAAK,IAAIrjB,EAAI,EAAGuE,EAAK4gN,EAAQ5lN,OAAQS,EAAIuE,IAAMvE,EAC7CmlN,EAAQnlN,GAAKqK,KAAKiZ,MAAM6hM,EAAQnlN,GAAKqjB,GAGvC,OAAOmiM,GAAqBL,EAC9B,CAWO,SAASI,GAAa7+E,EAASrjH,GACpCA,EAASA,GAAkB,IAC3B,MAAM8hM,EAAUM,GAAqB/+E,GACrC,IAAK,IAAI1mI,EAAI,EAAGuE,EAAK4gN,EAAQ5lN,OAAQS,EAAIuE,IAAMvE,EAC7CmlN,EAAQnlN,IAAMqjB,EAEhB,OAAO8hM,CACT,CAUO,SAASK,GAAqBL,GACnC,IAAK,IAAInlN,EAAI,EAAGuE,EAAK4gN,EAAQ5lN,OAAQS,EAAIuE,IAAMvE,EAAG,CAChD,MAAM0jI,EAAMyhF,EAAQnlN,GACpBmlN,EAAQnlN,GAAK0jI,EAAM,IAAMA,GAAO,GAAKA,GAAO,CAC7C,CACD,OAAOgiF,GAAuBP,EAChC,CAQO,SAASM,GAAqB/+E,GACnC,MAAMy+E,EAAUQ,GAAuBj/E,GACvC,IAAK,IAAI1mI,EAAI,EAAGuE,EAAK4gN,EAAQ5lN,OAAQS,EAAIuE,IAAMvE,EAAG,CAChD,MAAM0jI,EAAMyhF,EAAQnlN,GACpBmlN,EAAQnlN,GAAW,EAAN0jI,IAAYA,GAAO,GAAKA,GAAO,CAC7C,CACD,OAAOyhF,CACT,CAQO,SAASO,GAAuBP,GACrC,IAAIz+E,EAAU,GACd,IAAK,IAAI1mI,EAAI,EAAGuE,EAAK4gN,EAAQ5lN,OAAQS,EAAIuE,IAAMvE,EAC7C0mI,GAAWk/E,GAAsBT,EAAQnlN,IAE3C,OAAO0mI,CACT,CAQO,SAASi/E,GAAuBj/E,GACrC,MAAMy+E,EAAU,GAChB,IAAIU,EAAU,EACV33M,EAAQ,EACZ,IAAK,IAAIlO,EAAI,EAAGuE,EAAKmiI,EAAQnnI,OAAQS,EAAIuE,IAAMvE,EAAG,CAChD,MAAMN,EAAIgnI,EAAQn9C,WAAWvpF,GAAK,GAClC6lN,IAAgB,GAAJnmN,IAAawO,EACrBxO,EAAI,IACNylN,EAAQphN,KAAK8hN,GACbA,EAAU,EACV33M,EAAQ,GAERA,GAAS,CAEZ,CACD,OAAOi3M,CACT,CAQO,SAASS,GAAsBliF,GACpC,IAAIjhI,EACFikI,EAAU,GACZ,KAAOhD,GAAO,IACZjhI,EAAgC,IAAvB,GAAc,GAANihI,GACjBgD,GAAWz/H,OAAOyiF,aAAajnF,GAC/BihI,IAAQ,EAIV,OAFAjhI,EAAQihI,EAAM,GACdgD,GAAWz/H,OAAOyiF,aAAajnF,GACxBikI,CACT,CAEA,IAAAo/E,GA3TA,cAAuBrb,GAIrB,WAAAvsM,CAAY6K,GACV1F,QAEA0F,EAAUA,GAAoB,GAK9B3K,KAAKotE,eAAiBx+C,GAAc,aAMpC5uB,KAAK2nN,QAAUh9M,EAAQsa,OAASta,EAAQsa,OAAS,IAMjDjlB,KAAK4iL,gBAAkBj4K,EAAQk4K,eAC3Bl4K,EAAQk4K,eACR,IACL,CAQD,mBAAA4oB,CAAoB7oJ,EAAMj4C,GACxB,MAAMiK,EAAW5U,KAAK2rM,qBAAqB/oJ,EAAMj4C,GACjD,OAAO,IAAIyJ,GAAQQ,EACpB,CAQD,oBAAA82L,CAAqB9oJ,EAAMj4C,GAEzB,MAAO,CADS3K,KAAKyrM,oBAAoB7oJ,EAAMj4C,GAEhD,CAQD,oBAAAghM,CAAqB/oJ,EAAMj4C,GACzB,MAAMqQ,EAASoU,GAAmBpvB,KAAK4iL,iBACjC9nK,EAAkBosM,GAAatkK,EAAM5nC,EAAQhb,KAAK2nN,SACxD5xB,GAAOj7K,EAAiB,EAAGA,EAAgB3Z,OAAQ6Z,EAAQF,GAC3D,MAAMvB,EAAcoZ,GAClB7X,EACA,EACAA,EAAgB3Z,OAChB6Z,GAIF,OAAO27K,GAFY,IAAI97G,GAAWthE,EAAavZ,KAAK4iL,kBAIlD,EACA5iL,KAAKq2L,aAAa1rL,GAErB,CAQD,gBAAAkhM,CAAiBlsJ,EAASh1C,GACxB,MAAMiK,EAAW+qC,EAAQzqC,cACzB,GAAIN,EACF,OAAO5U,KAAK+rM,kBAAkBn3L,EAAUjK,GAE1C,MAAM,IAAInC,MAAM,wCACjB,CAQD,iBAAAsjM,CAAkB3oI,EAAUx4D,GAC1B,OAAO3K,KAAK6rM,iBAAiB1oI,EAAS,GAAIx4D,EAC3C,CAQD,iBAAAohM,CAAkBn3L,EAAUjK,GAM1B,MAAMmQ,GALNlG,EAGI+hL,GAA6B/hL,GAAU,EAAM5U,KAAKq2L,aAAa1rL,KAElC4kB,qBAC3BvU,EAASpG,EAAS4a,YAExB,OADAumK,GAAOj7K,EAAiB,EAAGA,EAAgB3Z,OAAQ6Z,EAAQF,GACpDgsM,GAAahsM,EAAiBE,EAAQhb,KAAK2nN,QACnD,GCkBH,MAAM7vB,GAAmB,CACvBtkK,MAmDF,SAA2B5uB,EAAQ+S,EAAOE,GACxC,MAAM0B,EAAc3U,EAAoB,YACpC+S,GAASE,GACX+vM,GAAgBruM,EAAa5B,EAAOE,GAEtC,OAAO,IAAI2b,GAAMja,EACnB,EAxDEshE,WAmFF,SAAgCj2E,EAAQijN,GACtC,MAAMtuM,EAAcuuM,GAAgBljN,EAAa,KAAGijN,GACpD,OAAO,IAAIhtI,GAAWthE,EACxB,EArFE0c,QA6GF,SAA6BrxB,EAAQijN,GACnC,MAAMtuM,EAAc,GACpB,IAAK,IAAI3X,EAAI,EAAGuE,EAAKvB,EAAa,KAAEzD,OAAQS,EAAIuE,IAAMvE,EACpD2X,EAAY3X,GAAKkmN,GAAgBljN,EAAa,KAAEhD,GAAIimN,GAEtD,OAAO,IAAI5xL,GAAQ1c,EACrB,EAlHEyhE,WAgEF,SAAgCp2E,EAAQ+S,EAAOE,GAC7C,MAAM0B,EAAc3U,EAAoB,YACxC,GAAI+S,GAASE,EACX,IAAK,IAAIjW,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAQS,EAAIuE,IAAMvE,EACjDgmN,GAAgBruM,EAAY3X,GAAI+V,EAAOE,GAG3C,OAAO,IAAImjE,GAAWzhE,EACxB,EAvEE0hE,gBA4FF,SAAqCr2E,EAAQijN,GAC3C,MAAMtuM,EAAc,GACpB,IAAK,IAAI3X,EAAI,EAAGuE,EAAKvB,EAAa,KAAEzD,OAAQS,EAAIuE,IAAMvE,EACpD2X,EAAY3X,GAAKkmN,GAAgBljN,EAAa,KAAEhD,GAAIimN,GAEtD,OAAO,IAAI5sI,GAAgB1hE,EAC7B,EAjGE2hE,aAyHF,SAAkCt2E,EAAQijN,GACxC,MAAMtuM,EAAc,GACpB,IAAK,IAAI3X,EAAI,EAAGuE,EAAKvB,EAAa,KAAEzD,OAAQS,EAAIuE,IAAMvE,EAAG,CAEvD,MAAMmmN,EAAYnjN,EAAa,KAAEhD,GAC3BomN,EAAa,GACnB,IAAK,IAAI1jM,EAAI,EAAG2G,EAAK88L,EAAU5mN,OAAQmjB,EAAI2G,IAAM3G,EAE/C0jM,EAAW1jM,GAAKwjM,GAAgBC,EAAUzjM,GAAIujM,GAEhDtuM,EAAY3X,GAAKomN,CAClB,CACD,OAAO,IAAI9sI,GAAa3hE,EAC1B,GA3HA,SAASuuM,GAAgBG,EAASJ,GAEhC,MAAMtuM,EAAc,GACpB,IAAItW,EACJ,IAAK,IAAIrB,EAAI,EAAGuE,EAAK8hN,EAAQ9mN,OAAQS,EAAIuE,IAAMvE,EAM7C,GALAqB,EAAQglN,EAAQrmN,GACZA,EAAI,GAEN2X,EAAYrO,MAEVjI,GAAS,EAAG,CAEd,MAAM+xE,EAAM6yI,EAAK5kN,GACjB,IAAK,IAAIqhB,EAAI,EAAG2G,EAAK+pD,EAAI7zE,OAAQmjB,EAAI2G,IAAM3G,EACzC/K,EAAY5T,KAAKqvE,EAAI1wD,GAAGxgB,MAAM,GAEtC,KAAW,CAEL,MAAMkxE,EAAM6yI,GAAM5kN,GAClB,IAAK,IAAIqhB,EAAI0wD,EAAI7zE,OAAS,EAAGmjB,GAAK,IAAKA,EACrC/K,EAAY5T,KAAKqvE,EAAI1wD,GAAGxgB,MAAM,GAEjC,CAEH,OAAOyV,CACT,CAkHA,SAAS2uM,GACPlgK,EACA6/J,EACAlwM,EACAE,EACAhT,EACA6Q,EACA/K,GAEA,MAAM6qE,EAAaxtB,EAAuB,WACpCmb,EAAW,GACjB,IAAK,IAAIvhE,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAChDuhE,EAASvhE,GAAKumN,GACZ3yI,EAAW5zE,GACXimN,EACAlwM,EACAE,EACAhT,EACA6Q,EACA/K,GAGJ,OAAOw4D,CACT,CAeA,SAASglJ,GACPvjN,EACAijN,EACAlwM,EACAE,EACAhT,EACA6Q,EACA/K,GAEA,IAAIiK,EAAW,KACf,MAAM7U,EAAO6E,EAAO7E,KACpB,GAAIA,EAAM,CACR,MAAM84L,EAAiBf,GAAiB/3L,GAEtC6U,EADW,UAAT7U,GAA6B,eAATA,EACX84L,EAAej0L,EAAQ+S,EAAOE,GAE9BghL,EAAej0L,EAAQijN,GAEpCjzM,EAAW+hL,GAA6B/hL,GAAU,EAAOjK,EAC1D,CACD,MAAMg1C,EAAU,IAAIvrC,GAAQ,CAACQ,SAAUA,SACrBpO,IAAd5B,EAAO4I,IACTmyC,EAAQlqC,MAAM7Q,EAAO4I,IAEvB,IAAIsH,EAAalQ,EAAOkQ,WAUxB,OATIjQ,IACGiQ,IACHA,EAAa,CAAA,GAEfA,EAAWjQ,GAAY6Q,GAErBZ,GACF6qC,EAAQx2C,cAAc2L,GAAY,GAE7B6qC,CACT,CAuBA,SAASyoK,GAAapzI,EAAKr9D,EAAOE,GAChC,IAAIR,EAAI,EACJC,EAAI,EACR,IAAK,IAAI1V,EAAI,EAAGuE,EAAK6uE,EAAI7zE,OAAQS,EAAIuE,IAAMvE,EAAG,CAC5C,MAAM+nL,EAAS30G,EAAIpzE,GACnByV,GAAKsyK,EAAO,GACZryK,GAAKqyK,EAAO,GACZA,EAAO,GAAKtyK,EACZsyK,EAAO,GAAKryK,EACZswM,GAAgBj+B,EAAQhyK,EAAOE,EAChC,CACH,CAUA,SAAS+vM,GAAgBj+B,EAAQhyK,EAAOE,GACtC8xK,EAAO,GAAKA,EAAO,GAAKhyK,EAAM,GAAKE,EAAU,GAC7C8xK,EAAO,GAAKA,EAAO,GAAKhyK,EAAM,GAAKE,EAAU,EAC/C,CAEA,IAAAwwM,GArYA,cAAuBrvB,GAIrB,WAAAl5L,CAAY6K,GACV1F,QAEA0F,EAAUA,GAAoB,GAM9B3K,KAAK+hN,WAAap3M,EAAQq3M,UAM1BhiN,KAAKumH,QAAU57G,EAAQo8C,OAASp8C,EAAQo8C,OAAS,KAKjD/mD,KAAKotE,eAAiBx+C,GACpBjkB,EAAQyiE,eAAiBziE,EAAQyiE,eAAiB,YAErD,CAQD,sBAAAoqH,CAAuB5yL,EAAQ+F,GAC7B,GAAmB,YAAf/F,EAAO7E,KAAoB,CAC7B,MAAMuoN,EAAoD,EAC1D,IAAItyM,EACF2B,EAAQ,KACRE,EAAY,KACVywM,EAA4B,YAC9BtyM,EAAYsyM,EAA4B,UACxC3wM,EAAQ3B,EAAiB,MACzB6B,EAAY7B,EAAqB,WAEnC,MAAM6xM,EAAOS,EAAuB,KAChCtyM,GA+SV,SAAuB6xM,EAAMlwM,EAAOE,GAClC,IAAK,IAAIjW,EAAI,EAAGuE,EAAK0hN,EAAK1mN,OAAQS,EAAIuE,IAAMvE,EAC1CwmN,GAAaP,EAAKjmN,GAAI+V,EAAOE,EAEjC,CAlTQ0wM,CAAcV,EAAMlwM,EAAOE,GAG7B,MAAMsrD,EAAW,GACXqlJ,EAAmBF,EAA0B,QAC7CzjN,EAAW7E,KAAK+hN,WACtB,IAAIpiK,EACJ,IAAK,MAAM8oK,KAAcD,EACnBxoN,KAAKumH,UAAYvmH,KAAKumH,QAAQ7gH,SAAS+iN,KAGD,uBAAtCD,EAAiBC,GAAY1oN,MAC/B4/C,EACE6oK,EAAiBC,GAEnBtlJ,EAASx9D,KAAKzB,MACZi/D,EACA+kJ,GACEvoK,EACAkoK,EACAlwM,EACAE,EACAhT,EACA4jN,EACA99M,MAIJg1C,EACE6oK,EAAiBC,GAEnBtlJ,EAASx9D,KACPwiN,GACExoK,EACAkoK,EACAlwM,EACAE,EACAhT,EACA4jN,EACA99M,MAKR,OAAOw4D,CACR,CACD,MAAO,EACR,CAOD,wBAAAu0H,CAAyB9yL,GACvB,OAAO5E,KAAKotE,cACb,GChIH,IAAAs7I,GArBA,MAIE,WAAA5oN,CAAY03D,GAKVx3D,KAAK2oN,SAAWnxJ,CACjB,CAMD,UAAAoxJ,GACE,OAAO5oN,KAAK2oN,QACb,GCAH,IAAAE,GAhBA,cAA0BC,GAKxB,WAAAhpN,CAAY03D,EAASrB,GACnBlxD,MAAMuyD,GAKNx3D,KAAKm2D,WAAaA,EAClBliD,GAAOjU,KAAKm2D,WAAWh1D,QAAU,EAAG,qCACrC,GCNH,IAAA4nN,GATA,cAAkBC,GAIhB,WAAAlpN,CAAYq2D,GACVlxD,MAAM,MAAO5C,MAAMwB,UAAUC,MAAMC,KAAKC,WACzC,GC2BH,IAAAilN,GAhCA,cAAmBH,GAOjB,WAAAhpN,CAAY8jL,EAAcpqK,EAAQmhL,GAYhC,GAXA11L,MAAM,QAKNjF,KAAK4jL,aAAeA,EAKpB5jL,KAAKwZ,OAASA,EACQ,IAAlBA,EAAOrY,OACT,MAAM,IAAIqH,MACR,kEAOJxI,KAAK26L,QAAUA,CAChB,GCAH,IAAAuuB,GA5BA,cAAsBJ,GAQpB,WAAAhpN,CAAY03D,EAASosH,EAAchvK,EAAU+lL,GAC3C11L,MAAMuyD,GAKNx3D,KAAK4jL,aAAeA,GAAgB,WAKpC5jL,KAAK4U,SAAWA,EAKhB5U,KAAK26L,QAAUA,CAChB,GCfH,IAAAwuB,GAZA,cAAuBC,GAOrB,WAAAtpN,CAAY8jL,EAAchvK,EAAU+lL,GAClC11L,MAAM,WAAY2+K,EAAchvK,EAAU+lL,EAC3C,GCiBH,IAAA0uB,GA1BA,cAAsBD,GASpB,WAAAtpN,CAAY8jL,EAAchvK,EAAU4S,EAAU8hM,EAAM3uB,GAClD11L,MAAM,UAAW2+K,EAAchvK,EAAU+lL,GAMzC36L,KAAKwnB,SAAWA,EAMhBxnB,KAAKspN,KAAOA,CACb,GCXH,IAAAC,GAZA,cAAuBH,GAOrB,WAAAtpN,CAAY8jL,EAAchvK,EAAU+lL,GAClC11L,MAAM,WAAY2+K,EAAchvK,EAAU+lL,EAC3C,GCOH,IAAA6uB,GAfA,cAAyBV,GAKvB,WAAAhpN,CAAY03D,EAASiyJ,GACnBxkN,MAAMuyD,GAKNx3D,KAAKypN,aAAeA,CACrB,GCOH,IAAAC,GArBA,cAAqBC,GAMnB,WAAA7pN,CAAY2pN,EAAc1nN,EAAOC,GAC/BiD,MAAM,SAAUwkN,GAKhBzpN,KAAK+B,MAAQA,EAKb/B,KAAKgC,IAAMA,CACZ,GCMH,IAAA4nN,GAtBA,cAA+BD,GAO7B,WAAA7pN,CAAY03D,EAASiyJ,EAAc/8E,EAAYm9E,GAC7C5kN,MAAMuyD,EAASiyJ,GAKfzpN,KAAK0sI,WAAaA,EAKlB1sI,KAAK6pN,UAAYA,CAClB,GCVH,IAAAC,GAXA,cAAsBC,GAMpB,WAAAjqN,CAAY2pN,EAAc/8E,EAAYm9E,GACpC5kN,MAAM,oBAAqBwkN,EAAc/8E,EAAYm9E,EACtD,GCEH,IAAAG,GAVA,cAA0BD,GAKxB,WAAAjqN,CAAY2pN,EAAc/8E,GACxBznI,MAAM,wBAAyBwkN,EAAc/8E,EAC9C,GCGH,IAAAu9E,GAVA,cAAmCF,GAKjC,WAAAjqN,CAAY2pN,EAAc/8E,GACxBznI,MAAM,iCAAkCwkN,EAAc/8E,EACvD,GCMH,IAAAw9E,GAZA,cAAyBd,GAOvB,WAAAtpN,CAAY8jL,EAAchvK,EAAU+lL,GAClC11L,MAAM,aAAc2+K,EAAchvK,EAAU+lL,EAC7C,GCWH,IAAAwvB,GArBA,cAAwBR,GAMtB,WAAA7pN,CAAY2pN,EAAcW,EAAeC,GACvCplN,MAAM,oBAAqBwkN,GAK3BzpN,KAAKoqN,cAAgBA,EAKrBpqN,KAAKqqN,cAAgBA,CACtB,GCgCH,IAAAC,GAlDA,cAAqBX,GAanB,WAAA7pN,CACE2pN,EACAc,EACAC,EACAC,EACAC,EACAb,GAEA5kN,MAAM,iBAAkBwkN,GAKxBzpN,KAAKuqN,QAAUA,EAKfvqN,KAAKwqN,cAAwBhkN,IAAbgkN,EAAyBA,EAAW,IAKpDxqN,KAAKyqN,gBAA4BjkN,IAAfikN,EAA2BA,EAAa,IAK1DzqN,KAAK0qN,gBAA4BlkN,IAAfkkN,EAA2BA,EAAa,IAK1D1qN,KAAK6pN,UAAYA,CAClB,GCtCH,IAAAc,GATA,cAAqBhB,GAInB,WAAA7pN,CAAY2pN,GACVxkN,MAAM,iBAAkBwkN,EACzB,GCIH,IAAAmB,GAVA,cAAuBb,GAKrB,WAAAjqN,CAAY2pN,EAAc/8E,GACxBznI,MAAM,qBAAsBwkN,EAAc/8E,EAC3C,GCGH,IAAAm+E,GAVA,cAAgCd,GAK9B,WAAAjqN,CAAY2pN,EAAc/8E,GACxBznI,MAAM,8BAA+BwkN,EAAc/8E,EACpD,GCOH,IAAAo+E,GAdA,cAAkBhC,GAIhB,WAAAhpN,CAAYu4D,GACVpzD,MAAM,OAKNjF,KAAKq4D,UAAYA,CAClB,GCAH,IAAA0yJ,GAXA,cAAyBhB,GAMvB,WAAAjqN,CAAY2pN,EAAc/8E,EAAYm9E,GACpC5kN,MAAM,uBAAwBwkN,EAAc/8E,EAAYm9E,EACzD,GCCH,IAAAmB,GATA,cAAiBhC,GAIf,WAAAlpN,CAAYq2D,GACVlxD,MAAM,KAAM5C,MAAMwB,UAAUC,MAAMC,KAAKC,WACxC,GCQH,IAAAinN,GAdA,cAAyBnC,GAIvB,WAAAhpN,CAAYorN,GACVjmN,MAAM,cAKNjF,KAAKkrN,IAAMA,CACZ,GCEH,IAAAC,GAZA,cAAqB/B,GAOnB,WAAAtpN,CAAY8jL,EAAchvK,EAAU+lL,GAClC11L,MAAM,SAAU2+K,EAAchvK,EAAU+lL,EACzC,GCWI,SAASywB,GAAIj1J,GAClB,MAAM85B,EAAS,CAAC,MAAM8G,OAAO10F,MAAMwB,UAAUC,MAAMC,KAAKC,YACxD,OAAO,IAAKqnN,SAASxnN,UAAUqD,KAAKhD,MAAMonN,GAAKr7H,GACjD,CAoCO,SAASQ,GAAKmzF,EAAcpqK,EAAQmhL,GACzC,OAAO,IAAI4wB,GAAK3nC,EAAcpqK,EAAQmhL,EACxC,CCtCA,MAAME,GAA6B,CACjC,6BAA8B,CAC5B2wB,UAAax7F,GACXuqE,GAAQ12L,UAAU43L,kBAClB,WAGJ,iCAAkC,CAChCgwB,OAAU77F,GAAgB2qE,GAAQ12L,UAAUm3L,wBAQ1C0wB,GAA8B,CAClC,6BAA8B,CAC5BC,cAAiB37F,GAAyBmuE,IAC1CytB,aAAgB57F,GAAyBmuE,IACzC0tB,aAAgB77F,GAAyBmuE,KAE3C,iCAAkC,CAChCwtB,cAAiB37F,GAAyBmuE,IAC1CytB,aAAgB57F,GAAyBmuE,IACzC0tB,aAAgB77F,GAAyBmuE,MAQvC2tB,GAA+B,CACnC,6BAA8B,CAC5BC,mBAAsB/7F,GACpBg8F,GACA,sBAEFC,cAAiBj8F,GAAyBk8F,GAAmB,cAE/D,iCAAkC,CAChCH,mBAAsB/7F,GACpBg8F,GACA,sBAEFC,cAAiBj8F,GAAyBk8F,GAAmB,eAO3DC,GAAoB,CACxB,6BAA8B,CAC5BC,aAAgBn8F,GAAkBuuE,KAEpC,iCAAkC,CAChC4tB,aAAgBn8F,GAAkBuuE,MAOhC6tB,GAA0B,CAC9B,6BAA8B,CAC5BC,OAAUr8F,GAAkBumE,IAC5B+1B,OAAUt8F,GAAkBu8F,IAC5BC,OAAUx8F,GAAkBy8F,IAC5BriN,SAAY4lH,GAAkB08F,IAC9BC,OAAU38F,GAAkB48F,KAE9B,iCAAkC,CAChCP,OAAUr8F,GAAkBumE,IAC5B+1B,OAAUt8F,GAAkBu8F,IAC5BC,OAAUx8F,GAAkBy8F,IAC5BriN,SAAY4lH,GAAkB08F,IAC9BC,OAAU38F,GAAkB48F,MAmF1BC,GAAiB,UAKjBC,GAAQ,gCAKRC,GAAQ,CACZ,QAAS,iCACT,QAAS,6BACT,QAAS,8BAMLC,GAAQ,CACZ,QAAS,iCACT,QAAS,6BACT,QAAS,8BAMLC,GAAQ,CACZ,QAAS,iCACT,QAAS,6BACT,QAAS,8BAMLC,GAAmB,CACvB,QACE,4EACF,QACE,0EACF,QACE,2EAMEC,GAAc,CAClB,QAASpnB,GACT,QAAShD,GACT,QAAStD,IAsdX,SAAS2tB,GAA4BttN,EAAMojE,EAAUwsD,EAAalqB,GAChEksB,GACElsB,EACA4mH,GACA97F,GAAsBxwH,GACtBojE,EACAwsD,EAEJ,CAOA,SAASq8F,GAAuBz6M,EAAMo+G,GACpC,OAAO+B,GAAgB,CAAE,EAAEg6F,GAA6Bn6M,EAAMo+G,EAChE,CAMA,MAAM29F,GAAkB,CACtB,6BAA8B,CAC5BC,UAAa39F,IAAgB,SAAUr+G,EAAMo+G,GAC3C,OAAOp+G,EAAKgqL,aAAa,MAC/B,KAEE,iCAAkC,CAChCgyB,UAAa39F,IAAgB,SAAUr+G,EAAMo+G,GAC3C,OAAOp+G,EAAKgqL,aAAa,MAC/B,MAQA,SAASiyB,GAAUj8M,EAAMo+G,GACvB0B,GAAUi8F,GAAiB/7M,EAAMo+G,EACnC,CAMA,MAAM89F,GAAyB,CAC7B,6BAA8B,CAC5Br5M,QAAWo5M,IAEb,iCAAkC,CAChCp5M,QAAWo5M,KASf,SAAStB,GAAkB36M,EAAMo+G,GAC/B,OAAO+B,GAAgB,GAAI+7F,GAAwBl8M,EAAMo+G,EAC3D,CAOA,SAAS6mE,GAAajlL,EAAMouC,EAASgwE,GACnC,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3Cs5L,EAActqL,EAAqB,YACnCuqL,EAAYvqL,EAAmB,UAC/Bu9M,EAAav9M,EAAoB,WACjC2iF,EAAQ07B,GAAgBksE,EAAWD,GACzClpL,EAAKW,YAAY4gF,GACE,IAAf46H,EACFhuB,GAAK77L,UAAU08L,oBAAoBztG,EAAOnzC,EAASgwE,GAC3B,IAAf+9F,EACT1qB,GAAKn/L,UAAU08L,oBAAoBztG,EAAOnzC,EAASgwE,GAEnDq2E,GAAMniM,UAAU08L,oBAAoBztG,EAAOnzC,EAASgwE,EAExD,CAOA,SAASg+F,GAAkBp8M,EAAMuqL,EAAKnsE,GACpC,MACMnhB,EADUmhB,EAAYA,EAAYxuH,OAAS,GAChB,QAC3Bg6L,EAAK6xB,GAAMx+G,GACX/2D,EAAS+2E,GAAgB2sE,EAAI,UAC7BroG,EAAQ07B,GAAgB2sE,EAAI,aAClC1jJ,EAAOvlC,YAAY4gF,GACnBA,EAAM3hC,aAAa,MAA8B,GACjD5/C,EAAKW,YAAYulC,EACnB,CAOA,SAASm2K,GAAYC,EAAepzB,GAElC,MAAMr6C,GADNytE,EAAgBA,GAAgCf,IACjB,IAE/B,OAAIryB,EAAYziF,WAAWooC,GAClBq6C,EAEFr6C,EAASq6C,CAClB,CAOA,SAASiyB,GAAYn7M,EAAMouC,EAASgwE,GAClC,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GACjD8S,QAA2BzN,IAApBm5C,EAAQtqC,QAAuB,gCACtC,MAAMolL,EAActqL,EAAqB,YACnC09M,EAAgB19M,EAAuB,cACvCuqL,EAAYvqL,EAAmB,UAC/Bq3H,EAAWomF,GAAYC,EAAepzB,GAC5ClpL,EAAK4/C,aAAa,WAAYq2E,GAC9Bj2H,EAAK8zL,eAAe0nB,GAAO,SAAWc,EAAenzB,GACrD,MAAMoB,EAAMn8I,EAAQtqC,aACR7O,IAARs1L,GACF6xB,GAAkBp8M,EAAMuqL,EAAKnsE,EAEjC,CAOA,SAAS68F,GAAYj7M,EAAMouC,EAASgwE,GAClC,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GACjD8S,QAA2BzN,IAApBm5C,EAAQtqC,QAAuB,gCACtC,MAAMm5F,EAAUr+F,EAAiB,QAC3BsqL,EAActqL,EAAqB,YACnC09M,EAAgB19M,EAAuB,cACvCuqL,EAAYvqL,EAAmB,UAC/Bq3H,EAAWomF,GAAYC,EAAepzB,GACtC7W,EAAejkI,EAAQ1qC,kBAC7B1D,EAAK4/C,aAAa,WAAYq2E,GAC9Bj2H,EAAK8zL,eAAe0nB,GAAO,SAAWc,EAAenzB,GACrD,MAAMoB,EAAMn8I,EAAQtqC,QACpB,QAAY7O,IAARs1L,EAAmB,CACrB,MAAMn1L,EAAOg5C,EAAQr2C,UACfL,EAAS,GACf,IAAK,IAAIrH,EAAI,EAAGuE,EAAKQ,EAAKxF,OAAQS,EAAIuE,EAAIvE,IAAK,CAC7C,MAAMyC,EAAQs7C,EAAQv2C,IAAIzC,EAAK/E,IAC/B,QAAc4E,IAAVnC,EAAqB,CACvB,IAAIqR,EAAO/O,EAAK/E,GAEdyC,GAC4D,mBAAnC,EAA6B,wBAEtDqR,EAAOkuK,GAET36K,EAAOtD,KAAK,CAAC+P,KAAMA,EAAMrR,MAAOA,GACjC,CACF,CACDstH,GACoD,CAChDnjB,UACAk/G,WAAcv9M,EAAoB,WAClCoB,OACA8mL,KAAQloL,EAAc,KACtBwqL,QAAWxqL,EAAiB,SAE9Bk8M,GACA97F,GAAsB,YACtBtnH,EACA0mH,GAEFg+F,GAAkBp8M,EAAMuqL,EAAKnsE,EAC9B,CACH,CAOA,SAASg9F,GAAcp7M,EAAMokM,EAAMhmF,GACjC,MAAMx/G,EAAUw/G,EAAYA,EAAYxuH,OAAS,GAC3CqtG,EAAUr+F,EAAiB,QAC3BgrL,EAAK8xB,GAAMz+G,GAEX94F,EAAO84G,GAAgB2sE,EADD,UAAZ3sF,EAAsB,iBAAmB,QAEnDk/G,EAAav9M,EAAoB,WAGvC,GAFAoB,EAAKW,YAAYwD,GACjB8oL,GAAoB9oL,EAAMigM,EAAKjgM,WACZlP,IAAfmvM,EAAKtxM,OAAsC,OAAfsxM,EAAKtxM,MAAgB,CACnD,MAAMA,EAAQmqH,GAAgB2sE,EAAI,SAClC5pL,EAAKW,YAAY7N,GAEfsxM,EAAKtxM,OAEH,mBADwBsxM,EAAU,MAAuB,sBAGxC,IAAf+X,EACFhuB,GAAK77L,UAAU28L,qBAAqBn8L,EAAOsxM,EAAKtxM,MAAOsrH,GAC/B,IAAf+9F,EACT1qB,GAAKn/L,UAAU28L,qBAAqBn8L,EAAOsxM,EAAKtxM,MAAOsrH,GAEvDq2E,GAAMniM,UAAU28L,qBAAqBn8L,EAAOsxM,EAAKtxM,MAAOsrH,GAG1D6uE,GAAoBn6L,EAAOsxM,EAAKtxM,MAEnC,CACH,CAOA,SAASwoN,GAAYt7M,EAAMu8M,EAAen+F,GACpCm+F,EAAcC,UAChBx8M,EAAK4/C,aAAa,WAAY28J,EAAcC,eAEXvnN,IAA/BsnN,EAAcE,cAChBz8M,EAAK4/C,aAAa,eAAgBtoD,OAAOilN,EAAcE,oBAE7BxnN,IAAxBsnN,EAAczpN,OAChBm6L,GAAoBjtL,EAAMu8M,EAAczpN,MAE5C,CAKA,MAAM4pN,GAAyB,CAC7B,6BAA8B,CAC5BC,MAASj+F,GAAkBk+F,KAE7B,iCAAkC,CAChCD,MAASj+F,GAAkBk+F,KAE7B,6BAA8B,CAC5BC,OAAUn+F,GAAkBo+F,IAC5B/C,IAAOr7F,GAAkBq+F,IACzBC,GAAMt+F,GAAkBq+F,IACxBtlF,IAAO/Y,GAAkBu+F,IACzBC,KAAQx+F,GAAkBy+F,IAC1BC,SAAY1+F,GAAkB2+F,IAC9BC,WAAc5+F,GAAkB2+F,IAChCE,OAAU7+F,GAAkB2+F,IAC5BG,QAAW9+F,GAAkB++F,IAC7BC,kBAAqBh/F,GAAkBi/F,IACvCC,qBAAwBl/F,GAAkBi/F,IAC1CE,mBAAsBn/F,GAAkBi/F,IACxCG,4BAA+Bp/F,GAAkBi/F,IACjDI,sBAAyBr/F,GAAkBi/F,IAC3CK,+BAAkCt/F,GAAkBi/F,IACpDM,eAAkBv/F,GAAkBw/F,IACpCC,kBAAqBz/F,GAAkB0/F,IACvCC,eAAkB3/F,GAAkB4/F,KAEtC,iCAAkC,CAChCzB,OAAUn+F,GAAkBo+F,IAC5B/C,IAAOr7F,GAAkBq+F,IACzBC,GAAMt+F,GAAkBq+F,IACxBtlF,IAAO/Y,GAAkBu+F,IACzBC,KAAQx+F,GAAkBy+F,IAC1BC,SAAY1+F,GAAkB2+F,IAC9BkB,SAAY7/F,GAAkB2+F,IAC9BC,WAAc5+F,GAAkB2+F,IAChCmB,WAAc9/F,IA0GlB,SAA+B1+G,EAAMkmC,EAAQk4E,GAC3Cp+G,EAAK4/C,aAAa,MAA8B1Z,EAAU,IAC5D,IA3GIq3K,OAAU7+F,GAAkB2+F,IAC5BG,QAAW9+F,GAAkB++F,IAC7BC,kBAAqBh/F,GAAkBi/F,IACvCC,qBAAwBl/F,GAAkBi/F,IAC1CE,mBAAsBn/F,GAAkBi/F,IACxCG,4BAA+Bp/F,GAAkBi/F,IACjDI,sBAAyBr/F,GAAkBi/F,IAC3CK,+BAAkCt/F,GAAkBi/F,IACpDM,eAAkBv/F,GAAkBw/F,IACpCC,kBAAqBz/F,GAAkB0/F,IACvCC,eAAkB3/F,GAAkB4/F,MASxC,SAAS1B,GAAW58M,EAAMkpL,EAAa9qE,GACrC,MAAMx/G,EAAiCw/G,EAAYA,EAAYxuH,OAAS,GAClEqtG,EAAUr+F,EAAiB,QAC3B09M,EAAgB19M,EAAuB,cACvCuqL,EAAYvqL,EAAmB,UAC/B6/M,EAAgB7/M,EAAuB,cACvCwqL,EAAUxqL,EAAiB,QACjC,IAAIq3H,EAOAyoF,EAJFzoF,EADEqmF,EACSD,GAAYC,EAAepzB,GAE3BA,EAIXw1B,EADc,UAAZzhH,EACa,YAEA,WAEjBj9F,EAAK4/C,aAAa8+J,EAAczoF,GAC5BmzD,GACFppL,EAAK4/C,aAAa,UAAWwpI,GAE3BD,GACFnpL,EAAK8zL,eAAe0nB,GAAO,SAAWc,EAAenzB,GAEvD,MAAMpvL,EACJ5E,OAAO8C,OAAO,CAAE,EAAE2G,GAEpB7E,EAAKiG,KAAOA,EACZogH,GACErmH,EACA6gN,GACA57F,GAAsB,gBACtBy/F,EACArgG,GAEF,MAAMl4E,EAAStnC,EAAgB,OAC/B,GAAIsnC,EAAQ,CACV,MAAMq7C,EAAQ07B,GAAgB0hG,GAAY1hH,GAAU,UACpDj9F,EAAKW,YAAY4gF,GACjBq9H,GAAqBr9H,EAAOr7C,EAAQk4E,EACrC,CACH,CAOA,SAASwgG,GAAqB5+M,EAAMkmC,EAAQk4E,GAC1C,MAAMx/G,EAAiCw/G,EAAYA,EAAYxuH,OAAS,GAElEmK,EAAO,CAACiG,QACd7K,OAAO8C,OAAO8B,EAAM,CAAC6E,YACrBwhH,GACErmH,EACA2iN,GACA19F,GAAsB94E,EAAOmxK,cAC7B,CAACnxK,GACDk4E,EAEJ,CAOA,SAAS++F,GAAgBn9M,EAAMkmC,EAAQk4E,GACrC,MAAMx+G,EAAgCw+G,EAAYA,EAAYxuH,OAAS,GAEjEqtG,EADUr9F,EAAgB,QACC,QACjCA,EAAgB,QAAIsmC,EAAOkjJ,QAC3B,MAAM3zK,EAASomM,GAAY5+G,GAE3B4hH,GAAkB5hH,EAASj9F,EAAMkmC,EAAOmsI,cACxC58J,EAAOnjB,UAAU28L,qBAAqBjvL,EAAMkmC,EAAOj+B,OAAQm2G,EAC7D,CAgBA,SAASi/F,GAAmBr9M,EAAMkmC,EAAQk4E,GACxC,MAAMx+G,EAAgCw+G,EAAYA,EAAYxuH,OAAS,GAEjEqtG,EADUr9F,EAAgB,QACC,QACjCA,EAAgB,QAAIsmC,EAAOkjJ,QAC3B,MAAM3zK,EAASomM,GAAY5+G,GAE3B4hH,GAAkB5hH,EAASj9F,EAAMkmC,EAAOmsI,cACxC58J,EAAOnjB,UAAU28L,qBAAqBjvL,EAAMkmC,EAAO7iC,SAAU+6G,EAC/D,CAOA,SAASq/F,GAAmBz9M,EAAMkmC,EAAQk4E,GACxC,MAEMnhB,EAFgCmhB,EAAYA,EAAYxuH,OAAS,GACvC,QACC,QACjCytN,GAAmBr9M,EAAMkmC,EAAQk4E,GACjC,MAAMnoG,EAAWgnG,GAAgB0hG,GAAY1hH,GAAU,YACvDgwF,GAAoBh3K,EAAUiwB,EAAOjwB,SAAS5O,YAC9B,UAAZ41F,EACFhnF,EAAS2pC,aAAa,MAAO1Z,EAAO6xK,MAEpC9hM,EAAS2pC,aAAa,QAAS1Z,EAAO6xK,MAExC/3M,EAAKW,YAAYsV,EACnB,CAOA,SAAS6mM,GAAkB98M,EAAMkmC,EAAQk4E,GACvC,MAEMnhB,EAFgCmhB,EAAYA,EAAYxuH,OAAS,GACvC,QACC,QAEjCkvN,GAAgBnD,GAAM1+G,GAAU,iBAAkBj9F,EAAMkmC,EAAOgyK,cAC/D,MAAM6G,EAAa9hG,GAAgB6rE,GAAO,cAE1C9oL,EAAKW,YAAYo+M,GAEjB,MAAMvuN,EAAQysH,GAAgB6rE,GAAO,SACrCi2B,EAAWp+M,YAAYnQ,GACvBwuN,GAAiBxuN,EAAO01C,EAAO11C,OAE/B,MAAMC,EAAMwsH,GAAgB6rE,GAAO,OACnCi2B,EAAWp+M,YAAYlQ,GACvBuuN,GAAiBvuN,EAAKy1C,EAAOz1C,IAC/B,CAOA,SAASssN,GAAmB/8M,EAAMkmC,EAAQk4E,GACxC,MACMx/G,EADgCw/G,EAAYA,EAAYxuH,OAAS,GACvC,QAE1BmK,EAAO,CAACiG,QACd7K,OAAO8C,OAAO8B,EAAM,CAAC6E,YACrB,MAAMgmD,EAAa1e,EAAO0e,WAC1B,IAAK,IAAIv0D,EAAI,EAAGuE,EAAKgwD,EAAWh1D,OAAQS,EAAIuE,IAAMvE,EAAG,CACnD,MAAMy2D,EAAYlC,EAAWv0D,GAC7B+vH,GACErmH,EACA2iN,GACA19F,GAAsBl4D,EAAUuwJ,cAChC,CAACvwJ,GACDs3D,EAEH,CACH,CAOA,SAAS6+F,GAAej9M,EAAMkmC,EAAQk4E,GACpC,MACMx/G,EADgCw/G,EAAYA,EAAYxuH,OAAS,GACvC,QAE1BmK,EAAO,CAACiG,QACd7K,OAAO8C,OAAO8B,EAAM,CAAC6E,YACrB,MAAMkoD,EAAY5gB,EAAO4gB,UACzBs5D,GACErmH,EACA2iN,GACA19F,GAAsBl4D,EAAUuwJ,cAChC,CAACvwJ,GACDs3D,EAEJ,CAOA,SAASu/F,GAAsB39M,EAAMkmC,EAAQk4E,GAC3C,MAEMnhB,EAFgCmhB,EAAYA,EAAYxuH,OAAS,GACvC,QACC,aACRqF,IAArBixC,EAAOoyK,WACTt4M,EAAK4/C,aAAa,YAAa1Z,EAAOoyK,UAAUjxM,YAElDw3M,GAAkB5hH,EAASj9F,EAAMkmC,EAAOgyK,cACxC+G,GAAahiH,EAASj9F,EAAM,GAAKkmC,EAAOi1F,WAC1C,CAOA,SAAS+iF,GAAkBl+M,EAAMkmC,EAAQk4E,GAIvCygG,GAHsCzgG,EAAYA,EAAYxuH,OAAS,GACvC,QACC,QACNoQ,EAAMkmC,EAAOgyK,aAC1C,CAOA,SAASkG,GAAqBp+M,EAAMkmC,EAAQk4E,GAC1C,MAEMnhB,EAFgCmhB,EAAYA,EAAYxuH,OAAS,GACvC,QACC,QAC3Bg6L,EAAK+0B,GAAY1hH,GAEvB4hH,GAAkB5hH,EAASj9F,EAAMkmC,EAAOgyK,cAExC,MAAMW,EAAgB57F,GAAgB2sE,EAAI,iBAC1C5pL,EAAKW,YAAYk4M,GACjBoG,GAAahiH,EAAS47G,EAAe,GAAK3yK,EAAO2yK,eAEjD,MAAMC,EAAgB77F,GAAgB2sE,EAAI,iBAC1C5pL,EAAKW,YAAYm4M,GACjBmG,GAAahiH,EAAS67G,EAAe,GAAK5yK,EAAO4yK,cACnD,CAOA,SAASwF,GAAkBt+M,EAAMkmC,EAAQk4E,GACvC,MAEMnhB,EAFgCmhB,EAAYA,EAAYxuH,OAAS,GACvC,QACC,QACjCoQ,EAAK4/C,aAAa,WAAY1Z,EAAO+yK,UACrCj5M,EAAK4/C,aAAa,aAAc1Z,EAAOgzK,YACvCl5M,EAAK4/C,aAAa,aAAc1Z,EAAOizK,iBACdlkN,IAArBixC,EAAOoyK,WACTt4M,EAAK4/C,aAAa,YAAa1Z,EAAOoyK,UAAUjxM,YAElDw3M,GAAkB5hH,EAASj9F,EAAMkmC,EAAOgyK,cACxC+G,GAAahiH,EAASj9F,EAAM,GAAKkmC,EAAO8yK,QAC1C,CAQA,SAAS8F,GAAgBl1B,EAAI3jI,EAASjmD,EAAMlN,GAC1C,MAAMQ,EAAW2pH,GAAgB2sE,EAAI3jI,GACrCgnI,GAAoB35L,EAAUR,GAC9BkN,EAAKW,YAAYrN,EACnB,CAOA,SAAS2rN,GAAahiH,EAASj9F,EAAMlN,GACnCgsN,GAAgBH,GAAY1hH,GAAU,UAAWj9F,EAAMlN,EACzD,CAOA,SAAS+rN,GAAkB5hH,EAASj9F,EAAMlN,GACxB,UAAZmqG,EACF6hH,GAAgBnD,GAAM1+G,GAAU,iBAAkBj9F,EAAMlN,GAExDgsN,GAAgBrD,GAAMx+G,GAAU,eAAgBj9F,EAAMlN,EAE1D,CAMA,SAASksN,GAAiBh/M,EAAM9D,GAC9B,MAAMgjN,EAAcjiG,GAAgB6rE,GAAO,eAC3C9oL,EAAKW,YAAYu+M,GAEjB,MAAMC,EAAeliG,GAAgB6rE,GAAO,gBAC5Co2B,EAAYv+M,YAAYw+M,GACxBlyB,GAAoBkyB,EAAcjjN,EACpC,CA6BA,SAASkjN,GAAgBp/M,EAAM6pL,EAAczrE,GAC3C,MAAMx/G,EAAiCw/G,EAAYA,EAAYxuH,OAAS,GAClEmK,EACJ5E,OAAO8C,OAAO,CAAE,EAAE2G,GAEpB7E,EAAKiG,KAAOA,EACZogH,GACErmH,EACA2iN,GACA19F,GAAsB,SACtB6qE,EACAzrE,EAEJ,CAEA,SAASugG,GAAY1hH,GACnB,IAAI2sF,EAMJ,OAJEA,EADc,UAAZ3sF,EACG0+G,GAAM1+G,GAENw+G,GAAMx+G,GAEN2sF,CACT,CAEA,IAAAy1B,GA1lCA,cAAkBp2B,GAIhB,WAAA16L,CAAY6K,GACV1F,QAEA0F,EAAUA,GAAoB,GAM9B3K,KAAKysH,SAAW9hH,EAAQ6jG,QAAU7jG,EAAQ6jG,QAxBtB,QA8BpBxuG,KAAK6wN,aAAelmN,EAAQ8vL,YAM5Bz6L,KAAK8wN,WAAanmN,EAAQ+vL,UAM1B16L,KAAK+wN,WAAapmN,EAAQqmN,UACtBrmN,EAAQqmN,UACR,IAAI5D,GAAYptN,KAAKysH,UAMzBzsH,KAAKixN,gBAAkBtmN,EAAQiwL,eAC3BjwL,EAAQiwL,eACRuyB,GAAiBntN,KAAKysH,SAC3B,CAKD,cAAAykG,GACE,OAAOlxN,KAAK6wN,YACb,CAKD,cAAAM,CAAe12B,GACbz6L,KAAK6wN,aAAep2B,CACrB,CAQD,oBAAAd,CAAqBpoL,EAAM5G,GAEzB,MAAMwF,EAAU,CACdoB,QAEF7K,OAAO8C,OAAO2G,EAAS,CACrBsqL,YAAez6L,KAAK6wN,aACpBn2B,UAAa16L,KAAK8wN,aAGpBpqN,OAAO8C,OAAO2G,EAASnQ,KAAKo2L,eAAe7kL,EAAM5G,GAAoB,CAAE,IACvE,MAAMglH,EAAc,CAACx/G,GACrB,IAAIihN,EAEFA,EADoB,UAAlBpxN,KAAKysH,SACMouE,GAEA76L,KAAK+wN,WAAWl2B,2BAE/B,IAAI13H,EAAWuuD,GACb,GACA0/F,EACA7/M,EACAo+G,EACA3vH,KAAK+wN,YAKP,OAHK5tJ,IACHA,EAAW,IAENA,CACR,CASD,uBAAAkuJ,CAAwBnnN,GACtB,GAAKA,EAAL,CAGA,GAAsB,iBAAXA,EAAqB,CAC9B,MAAM0hD,EAAM1gB,GAAMhhC,GAClB,OAAOlK,KAAKsxN,oCAAoC1lK,EACjD,CACD,OAAI0jE,GAAWplH,GACNlK,KAAKsxN,oCAClB,GAGWtxN,KAAKuxN,gCAChB,EAXK,CAaF,CAUD,6BAAAC,CAA8BtnN,GAC5B,GAAKA,EAAL,CAGA,GAAsB,iBAAXA,EAAqB,CAC9B,MAAM0hD,EAAM1gB,GAAMhhC,GAClB,OAAOlK,KAAKyxN,0CAA0C7lK,EACvD,CACD,OAAI0jE,GAAWplH,GACNlK,KAAKyxN,0CAClB,GAGWzxN,KAAK0xN,sCAChB,EAXK,CAaF,CAOD,yCAAAD,CAA0C7lK,GACxC,IAAK,IAAIjqD,EAAyBiqD,EAAc,WAAGjqD,EAAGA,EAAIA,EAAE0tH,YAC1D,GAAI1tH,EAAEqtH,UAAYC,KAAK2qE,aACrB,OAAO55L,KAAK0xN,sCACpB,EAKG,CAOD,qCAAAA,CAAsCngN,GACpC,MAAMk/B,EAAS,CAAA,EACTpsC,EAAQ+5L,GACZ7sL,EAAKgqL,aAAa,qBAGpB,OADA9qJ,EAAyB,iBAAIpsC,EACtBqtH,GACX,EACMmpE,GACAtpL,EACA,GACAvR,KAAK+wN,WAER,CAMD,mCAAAO,CAAoC1lK,GAClC,IAAK,IAAIjqD,EAAyBiqD,EAAc,WAAGjqD,EAAGA,EAAIA,EAAE0tH,YAC1D,GAAI1tH,EAAEqtH,UAAYC,KAAK2qE,aACrB,OAAO55L,KAAKuxN,gCAAwD,EAIzE,CAMD,+BAAAA,CAAgChgN,GAC9B,OAAOmgH,GACX,CAA4C,EACtCo6F,GACAv6M,EACA,GAEH,CASD,eAAAo/M,CAAgBhmN,GACd,MAAM4G,EAAOi9G,GAAgBy+F,GAAMjtN,KAAKysH,UAAW,cACnDl7G,EAAK4/C,aAAa,UAAW,OAC7B5/C,EAAK4/C,aAAa,UAAWnxD,KAAKysH,UAC9B9hH,EAAQgnN,QACVpgN,EAAK4/C,aAAa,SAAUxmD,EAAQgnN,QAElChnN,EAAQinN,cACVrgN,EAAK4/C,aAAa,eAAgBxmD,EAAQinN,mBAEhBprN,IAAxBmE,EAAQknN,aACVtgN,EAAK4/C,aAAa,cAAetoD,OAAO8B,EAAQknN,cAE9ClnN,EAAQmnN,YACVvgN,EAAK4/C,aAAa,aAAcxmD,EAAQmnN,iBAEftrN,IAAvBmE,EAAQojD,YACVx8C,EAAK4/C,aAAa,aAActoD,OAAO8B,EAAQojD,kBAE3BvnD,IAAlBmE,EAAQmjD,OACVv8C,EAAK4/C,aAAa,QAAStoD,OAAO8B,EAAQmjD,aAEjBtnD,IAAvBmE,EAAQonN,YACVxgN,EAAK4/C,aAAa,aAAcxmD,EAAQonN,YAE1CxgN,EAAK8zL,eACH92E,GACA,qBACAvuH,KAAKixN,iBAGP,MAAM9gN,EAAU,CACdoB,QAaF,GAXA7K,OAAO8C,OAAO2G,EAAS,CACrBq+F,QAAWxuG,KAAKysH,SAChBkuE,QAAWhwL,EAAQgwL,QACnBD,UAAa/vL,EAAQ+vL,UAAY/vL,EAAQ+vL,UAAY16L,KAAK8wN,WAC1DjD,cAAiBljN,EAAQkjN,cACzBmC,cAAiBrlN,EAAQqlN,cAAgBrlN,EAAQqlN,cAAgB,KAEnE/7M,GACE5R,MAAMC,QAAQqI,EAAQywL,cACtB,2CAEqC,iBAA5BzwL,EAAQywL,aAAa,GAAiB,CAC/C,IAAI3jJ,EAAS9sC,EAAQ8sC,OACjB9sC,EAAQ8lF,OACVx8E,GACEtJ,EAAQi5K,aACR,2EAEFnsI,EAASz3C,KAAKgyN,qBACZrnN,EAAQi5K,aACRj5K,EAAQ8lF,KACR9lF,EAAQgwL,QACRljJ,IAGJ/wC,OAAO8C,OAAO2G,EAAS,CACrByzK,aAAgBj5K,EAAQi5K,aACxBnsI,OAAUA,IAEZk5K,GACEp/M,EAC+B5G,EAAoB,aACnD,CAACwF,GAET,MAEMxF,EAAQywL,aAAajwL,SAAoCsvL,IACvD,MAAMw3B,EAAiBjyN,KAAKgyN,qBAC1Bv3B,EAAY7W,aACZ6W,EAAYhqG,KACZ9lF,EAAQgwL,QACRhwL,EAAQ8sC,QAEV/wC,OAAO8C,OAAO2G,EAAS,CACrByzK,aAAgB6W,EAAY7W,aAC5BnsI,OAAUw6K,IAEZtB,GAAgBp/M,EAAM,CAACkpL,EAAY/kL,MAAO,CAACvF,GAAS,IAGxD,OAAOoB,CACR,CAYD,oBAAAygN,CAAqBpuC,EAAcpqK,EAAQmhL,EAASljJ,GAClD,MAAMy6K,EAAaC,GAAavuC,EAAcpqK,EAAQmhL,GACtD,OAAIljJ,EAEK26K,GAAY36K,EAAQy6K,GAEtBA,CACR,CAYD,gBAAAG,CAAiBC,EAASC,EAASC,EAAS7nN,GAC1C,MAAMglH,EAAc,GACdnhB,EAAU7jG,EAAQ6jG,QAAU7jG,EAAQ6jG,QAAUxuG,KAAKysH,SACnDl7G,EAAOi9G,GAAgBy+F,GAAMz+G,GAAU,eAI7C,IAAIikH,EAFJlhN,EAAK4/C,aAAa,UAAW,OAC7B5/C,EAAK4/C,aAAa,UAAWq9C,GAGzB7jG,IACF8nN,EAAU9nN,EAAQ+nN,WAAa/nN,EAAQ+nN,WAAa,CAAA,EAChD/nN,EAAQgnN,QACVpgN,EAAK4/C,aAAa,SAAUxmD,EAAQgnN,SAGxCpgN,EAAK8zL,eACH92E,GACA,qBACA4+F,GAAiB3+G,IAGnB,MAAM/I,EAkEV,SAAkCl0F,EAAMkhN,EAASjkH,EAAS7jG,GACxD,MAAMkjN,EAAgBljN,EAAQkjN,cAC1BljN,EAAQkjN,cACRf,GACJ,IAAIY,EACY,UAAZl/G,EACFk/G,EAAa,EACQ,UAAZl/G,EACTk/G,EAAa,EACQ,UAAZl/G,IACTk/G,EAAa,KAEf,MAAM/kN,EAAMjC,OAAO8C,OACjB,CAAC+H,QACD,CACEi9F,UACAksF,UAAa/vL,EAAQ+vL,UACrBD,YAAe9vL,EAAQ8vL,YACvBozB,cAAiBA,EACjBH,WAAcA,EACdr1B,KAAQ1tL,EAAQ0tL,KAChBsC,QAAWhwL,EAAQgwL,SAErB83B,GAEF,OAAO9pN,CACT,CA5FoBgqN,CAAyBphN,EAAMkhN,EAASjkH,EAAS7jG,GAkBjE,OAjBI2nN,GACFjF,GAA4B,SAAUiF,EAAS3iG,EAAalqB,GAE1D8sH,GACFlF,GAA4B,SAAUkF,EAAS5iG,EAAalqB,GAE1D+sH,GACFnF,GAA4B,SAAUmF,EAAS7iG,EAAalqB,GAE1D96F,EAAQioN,gBACVvF,GACE,SACA1iN,EAAQioN,eACRjjG,EACAlqB,GAGGl0F,CACR,CAMD,0BAAAwoL,CAA2BnuI,GACzB,IAAK,IAAIjqD,EAAIiqD,EAAItF,WAAY3kD,EAAGA,EAAIA,EAAE0tH,YACpC,GAAI1tH,EAAEqtH,UAAYC,KAAK2qE,aACrB,OAAO55L,KAAKg6L,uBAA+C,GAG/D,OAAO,IACR,CAMD,sBAAAA,CAAuBzoL,GACrB,GAAIA,EAAKmsG,mBAAqBnsG,EAAKmsG,kBAAkBA,kBAEnD,IAAK,IAAI/7G,GADT4P,EAAOA,EAAKmsG,kBAAkBA,mBACZA,kBAAmB/7G,EAAGA,EAAIA,EAAE4vH,mBAC5C,GAE4B,IAAxB5vH,EAAEmQ,WAAW3Q,SACY,IAAxBQ,EAAEmQ,WAAW3Q,QAA0C,IAA1BQ,EAAE2kD,WAAW0oE,UAE7C,CACA,MAAMW,EAAc,CAAC,CAAA,GAErB,OADA3vH,KAAK+wN,WAAWr1B,oBAAoB/5L,EAAGguH,GAChC/gG,GAAc+gG,EAAYzkH,MAAMyvL,QACxC,CAIL,OAAO,IACR,GC1oBH,MAAMk4B,GACG,EADHA,GAES,EAFTA,GAGK,EAHLA,GAIS,EAJTA,GAKe,EALfA,GAMW,EANXA,GAOiB,EAPjBA,GAoBgB,GApBhBA,GAqBC,GArBDA,GAsBM,GAGZ,MAAMC,GAIJ,WAAAhzN,CAAY09C,GAEVx9C,KAAK+yN,MAAQv1K,EAMbx9C,KAAKgzN,KAAO,EAMZhzN,KAAKizN,cAAe,EAMpBjzN,KAAKkzN,iBAAkB,EAMvBlzN,KAAKmzN,OAAQ,EAMbnzN,KAAKozN,OAAQ,EAMbpzN,KAAKqzN,MAAQ,KAMbrzN,KAAKszN,QAAU,IAChB,CAKD,SAAAC,GACE,OAAOvzN,KAAK+yN,MAAMS,SAASxzN,KAAKgzN,OACjC,CAMD,UAAAS,CAAWC,GACT,OAAO1zN,KAAK+yN,MAAMY,WACf3zN,KAAKgzN,MAAQ,GAAK,OACAxsN,IAAnBktN,EAA+BA,EAAiB1zN,KAAKkzN,gBAExD,CAMD,UAAApU,CAAW4U,GACT,OAAO1zN,KAAK+yN,MAAMa,YACf5zN,KAAKgzN,MAAQ,GAAK,OACAxsN,IAAnBktN,EAA+BA,EAAiB1zN,KAAKkzN,gBAExD,CAKD,SAAAn3B,GAEE,MAAM5iK,EAAS,GAWf,OATAA,EAAOxzB,KAAK3F,KAAK8+M,cACjB3lL,EAAOxzB,KAAK3F,KAAK8+M,cACb9+M,KAAKmzN,OACPh6L,EAAOxzB,KAAK3F,KAAK8+M,cAEf9+M,KAAKozN,OACPj6L,EAAOxzB,KAAK3F,KAAK8+M,cAGZ3lL,CACR,CAKD,cAAA0jK,GACE,MAAMt7C,EAAYvhJ,KAAKyzN,aAGjBt6L,EAAS,GACf,IAAK,IAAIv3B,EAAI,EAAGA,EAAI2/I,EAAW3/I,IAC7Bu3B,EAAOxzB,KAAK3F,KAAK+7L,aAGnB,OAAO5iK,CACR,CAKD,WAAA8jK,GACE,MAAM42B,EAAW7zN,KAAKyzN,aAGhBj4M,EAAQ,GACd,IAAK,IAAI5Z,EAAI,EAAGA,EAAIiyN,EAAUjyN,IAC5B4Z,EAAM7V,KAAK3F,KAAK68L,kBAGlB,OAAOrhL,CACR,CAMD,aAAAs4M,CAAcC,GACZ,MACML,EADY1zN,KAAKuzN,YACY,EAE7BS,EAAUh0N,KAAKyzN,WAAWC,GAC1BO,EAAoBhoN,KAAKuT,OAAiB,UAAVw0M,GAAwB,KACxD37B,EACJ3gJ,QAAkB,WAAVs8K,IACc,IAAtBC,GACsB,IAAtBA,EACI37B,EACJ5gJ,QAAkB,WAAVs8K,IACc,IAAtBC,GACsB,IAAtBA,EACIC,EAAUx8K,QAAkB,UAAVs8K,GAClBG,GAAoB,UAAVH,GAAwB,IAClC7kM,EACJ,CAAC,KAAMkpK,EAAO,IAAM,GAAIC,EAAO,IAAM,IAAIx/K,KAAK,IAG1C+5F,EAAOqhH,EAAUl0N,KAAKyzN,WAAWC,GAAkB,KAEzD,QAAuBltN,IAAnButN,GAAgCA,IAAmBI,EACrD,MAAM,IAAI3rN,MAAM,gCAAkC2rN,GAGpD,GAAIn0N,KAAKizN,aAAc,CAErB,GAAIjzN,KAAKkzN,kBAAoBQ,EAC3B,MAAM,IAAIlrN,MAAM,uBAElB,GAAIxI,KAAKszN,UAAYnkM,EACnB,MAAM,IAAI3mB,MAAM,gCAElB,GAAIqqG,GAAQ7yG,KAAKqzN,QAAUxgH,EACzB,MAAM,IAAIrqG,MAAM,wCAExB,MACMxI,KAAKkzN,gBAAkBQ,EACvB1zN,KAAKmzN,MAAQ96B,EACbr4L,KAAKozN,MAAQ96B,EACbt4L,KAAKszN,QAAUnkM,EACfnvB,KAAKqzN,MAAQxgH,EACb7yG,KAAKizN,cAAe,EAGtB,OAAOkB,CACR,CAMD,cAAAC,CAAeD,GACb,OAAQA,GACN,KAAKtB,GACH,OAAO7yN,KAAK+7L,YAEd,KAAK82B,GACH,OAAO7yN,KAAK68L,iBAEd,KAAKg2B,GACL,KAAKA,GACH,OAAO7yN,KAAKi9L,cAEd,KAAK41B,GACH,OAAO7yN,KAAKi8L,iBAEd,KAAK42B,GACH,OAAO7yN,KAAKm8L,sBAEd,KAAK02B,GACL,KAAKA,GACL,KAAKA,GACH,OAAO7yN,KAAKq8L,mBAEd,KAAKw2B,GACH,OAAO7yN,KAAKq0N,yBAEd,QACE,MAAM,IAAI7rN,MACR,iCAAmC2rN,EAAS,aAGnD,CAMD,YAAAG,CAAaP,GACX,OAAO/zN,KAAKo0N,eAAep0N,KAAK8zN,cAAcC,GAC/C,CAOD,iBAAAQ,CAAkBz0C,EAAQi0C,GACxB,MAAMzuF,EAAMtlI,KAAKyzN,aAEXv/H,EAAQ,GACd,IAAK,IAAItyF,EAAI,EAAGA,EAAI0jI,EAAK1jI,IAAK,CAC5B,MAAM6uC,EAASqvI,EAAO/7K,KAAK/D,KAAM+zN,GAC7BtjL,GACFyjD,EAAMvuF,KAAK8qC,EAEd,CAED,OAAOyjD,CACR,CAKD,cAAA+nG,GACE,OAAOj8L,KAAKu0N,kBAAkBv0N,KAAKs0N,aAAczB,GAClD,CAKD,mBAAA12B,GACE,OAAOn8L,KAAKu0N,kBACVv0N,KAAKs0N,aACLzB,GAEH,CAKD,gBAAAx2B,GACE,OAAOr8L,KAAKu0N,kBAAkBv0N,KAAKs0N,aAAczB,GAClD,CAKD,sBAAAwB,GACE,OAAOr0N,KAAKu0N,kBAAkBv0N,KAAKu2L,aACpC,CAKD,YAAAA,GACE,MAAM49B,EAASn0N,KAAK8zN,gBACdrjL,EAASzwC,KAAKo0N,eAAeD,GAEnC,OAAQA,GACN,KAAKtB,GACH,OAAO,IAAIr/L,GACnB,EACUxzB,KAAKszN,SAGT,KAAKT,GACH,OAAO,IAAIh4I,GACnB,EACU76E,KAAKszN,SAGT,KAAKT,GACL,KAAKA,GACH,OAAO,IAAI58L,GACnB,EAGUj2B,KAAKszN,SAGT,KAAKT,GACH,OAAO,IAAI73I,GACnB,EACUh7E,KAAKszN,SAGT,KAAKT,GACH,OAAO,IAAI53I,GACnB,EAGUj7E,KAAKszN,SAGT,KAAKT,GACL,KAAKA,GACL,KAAKA,GACH,OAAO,IAAI33I,GACnB,EAGUl7E,KAAKszN,SAGT,KAAKT,GACH,OAAO,IAAI13I,GACnB,GAGM,QACE,OAAO,KAEZ,CAKD,OAAAq5I,GACE,OAAOx0N,KAAKqzN,KACb,EAGH,MAAMoB,GASJ,WAAA30N,CAAY40N,GACVA,EAAOA,GAAQ,GAGf10N,KAAKszN,QAAUoB,EAAKvlM,OACpBnvB,KAAKkzN,iBAAwC,IAAtBwB,EAAKC,aAE5B30N,KAAK40N,SAAwB,IAAdF,EAAKG,KAGpB70N,KAAK80N,YAAc,GASnB90N,KAAK+0N,QAAUruN,OAAO8C,OAAO,CAACwrN,EAAG,EAAGC,EAAG,EAAGC,EAAG,EAAG9gI,EAAG,GAAIsgI,EAAK9qH,OAC7D,CAKD,UAAAurH,CAAW9wN,GACTrE,KAAK80N,YAAYnvN,KAAK,CAAC,EAAGtB,GAC3B,CAKD,WAAA+wN,CAAY/wN,GACVrE,KAAK80N,YAAYnvN,KAAK,CAAC,EAAGtB,GAC3B,CAKD,WAAA+4M,CAAY/4M,GACVrE,KAAK80N,YAAYnvN,KAAK,CAAC,EAAGtB,GAC3B,CAMD,UAAAu9L,CAAWzoK,EAAQhK,GAQjB,MAAMkmM,EAAY3uN,OAAO8C,OAAOtF,MAC9B,KACAirB,EAAOtJ,MAAM,IAAIilB,KAAI,CAACyoI,EAAM7b,KAAS,CAAC6b,CAACA,GAAOp6I,EAAOu+H,QAGvD,IAAK,MAAM6b,KAAQvzK,KAAKszN,QACtBtzN,KAAKo9M,YACH7pC,KAAQ8hD,EAAYA,EAAU9hD,GAAQvzK,KAAK+0N,QAAQxhD,GAGxD,CAMD,eAAA+hD,CAAgBn8L,EAAQhK,GACtBnvB,KAAKo1N,YAAYj8L,EAAOh4B,QACxB,IAAK,IAAIS,EAAI,EAAGA,EAAIu3B,EAAOh4B,OAAQS,IACjC5B,KAAK4hM,WAAWzoK,EAAOv3B,GAAIutB,EAE9B,CAMD,YAAA4nL,CAAav7L,EAAO2T,GAClBnvB,KAAKo1N,YAAY55M,EAAMra,QACvB,IAAK,IAAIS,EAAI,EAAGA,EAAI4Z,EAAMra,OAAQS,IAChC5B,KAAKs1N,gBAAgB95M,EAAM5Z,GAAIutB,EAElC,CAMD,cAAAomM,CAAevB,EAASnhH,GACtBmhH,GAAW,IACPh0N,KAAKszN,QAAQ5tN,SAAS,OACxBsuN,GAAWh0N,KAAK40N,QAAU,WAAa,KAErC50N,KAAKszN,QAAQ5tN,SAAS,OACxBsuN,GAAWh0N,KAAK40N,QAAU,WAAa,KAErC50N,KAAK40N,SAAWzqL,OAAOqlE,UAAUqD,KACnCmhH,GAAW,WAGbh0N,KAAKm1N,WAAWn1N,KAAKkzN,gBAAkB,EAAI,GAC3ClzN,KAAKo1N,YAAYpB,GACbh0N,KAAK40N,SAAWzqL,OAAOqlE,UAAUqD,IACnC7yG,KAAKo1N,YAAYviH,EAEpB,CAMD,eAAAgvF,CAAgB1oK,EAAQhK,GACtBnvB,KAAKo1N,YAAYj8L,EAAOh4B,QACxB,IAAK,IAAIS,EAAI,EAAGA,EAAIu3B,EAAOh4B,OAAQS,IACjC5B,KAAKu1N,eAAe,GACpBv1N,KAAK4hM,WAAWzoK,EAAOv3B,GAAIutB,EAE9B,CAMD,oBAAAqmM,CAAqBr8L,EAAQhK,GAC3BnvB,KAAKo1N,YAAYj8L,EAAOh4B,QACxB,IAAK,IAAIS,EAAI,EAAGA,EAAIu3B,EAAOh4B,OAAQS,IACjC5B,KAAKu1N,eAAe,GACpBv1N,KAAKs1N,gBAAgBn8L,EAAOv3B,GAAIutB,EAEnC,CAMD,iBAAAsmM,CAAkBt8L,EAAQhK,GACxBnvB,KAAKo1N,YAAYj8L,EAAOh4B,QACxB,IAAK,IAAIS,EAAI,EAAGA,EAAIu3B,EAAOh4B,OAAQS,IACjC5B,KAAKu1N,eAAe,GACpBv1N,KAAK+2M,aAAa59K,EAAOv3B,GAAIutB,EAEhC,CAKD,uBAAAumM,CAAwBlgJ,GACtBx1E,KAAKo1N,YAAY5/I,EAAWr0E,QAE5B,IAAK,IAAIS,EAAI,EAAGA,EAAI4zE,EAAWr0E,OAAQS,IACrC5B,KAAK02L,cAAclhH,EAAW5zE,GAEjC,CAOD,iBAAA+zN,CAAkB98C,EAAM1pJ,EAAS,QAwB/B,GAAI0pJ,aAAgB1lJ,GAClB,OAnB0B9xB,EAmBAw3K,EAAK/oJ,gBAnBFxuB,EAmBe6tB,GAjBnC9tB,EAGC,SAANA,EAEKC,EAEC,SAANA,EAEKD,EAIF,KAfkB,IAACA,EAAGC,EAsB/B,GAAIu3K,aAAgB19F,GAAoB,CACtC,MAAMy6I,EAAQ/8C,EAAKpjG,qBACnB,IAAK,IAAI7zE,EAAI,EAAGA,EAAIg0N,EAAMz0N,QAAqB,OAAXguB,EAAiBvtB,IACnDutB,EAASnvB,KAAK21N,kBAAkBC,EAAMh0N,GAAIutB,EAE7C,CAED,OAAOA,CACR,CAMD,aAAAunK,CAAc7d,EAAMhmE,GAIlB,MAAMgjH,EAAS,CACbriM,MAAOq/L,GACPh4I,WAAYg4I,GACZ58L,QAAS48L,GACT73I,WAAY63I,GACZ53I,gBAAiB43I,GACjB33I,aAAc23I,GACd13I,mBAAoB03I,IAEhBiD,EAAWj9C,EAAKnqJ,UAChBylM,EAAS0B,EAAOC,GAEtB,IAAK3B,EACH,MAAM,IAAI3rN,MAAM,gBAAkBstN,EAAW,qBAU/C,GANK91N,KAAKszN,UACRtzN,KAAKszN,QAAUtzN,KAAK21N,kBAAkB98C,IAGxC74K,KAAKu1N,eAAepB,EAAQthH,GAExBgmE,aAAgB1lJ,GAAgB,EAChB,CAChBK,MAAOxzB,KAAK4hM,WACZ/mH,WAAY76E,KAAKs1N,gBACjBr/L,QAASj2B,KAAK+2M,aACd/7H,WAAYh7E,KAAK6hM,gBACjB5mH,gBAAiBj7E,KAAKw1N,qBACtBt6I,aAAcl7E,KAAKy1N,oBAEXK,GAAU/xN,KAAK/D,KAAM64K,EAAKlpJ,iBAAkBkpJ,EAAK/oJ,YACjE,MAAe+oJ,aAAgB19F,IACzBn7E,KAAK01N,wBAAwB78C,EAAKpjG,qBAErC,CAED,SAAAsgJ,GACE,MAAMh0H,EAAa/hG,KAAK80N,YAAYpwK,QAAO,CAACs1B,EAAK1uE,IAAS0uE,EAAM1uE,EAAK,IAAI,GACnEqO,EAAS,IAAIiiM,YAAY75G,GACzBvkD,EAAO,IAAI7qC,SAASgH,GAE1B,IAAIuuC,EAAM,EAmBV,OAlBAloD,KAAK80N,YAAY3pN,SAASG,IACxB,OAAQA,EAAK,IACX,KAAK,EACHkyC,EAAKw4K,SAAS9tK,EAAK58C,EAAK,IACxB,MACF,KAAK,EACHkyC,EAAKy4K,UAAU/tK,EAAK58C,EAAK,GAAItL,KAAKkzN,iBAClC,MACF,KAAK,EACH11K,EAAK04K,WAAWhuK,EAAK58C,EAAK,GAAItL,KAAKkzN,iBAMvChrK,GAAO58C,EAAK,EAAE,IAGTqO,CACR,EAuOH,SAASw8M,GAAYjsN,GACnB,MAAsB,iBAAXA,EAbb,SAAyB04C,GACvB,MAAMjpC,EAAS,IAAInH,WAAWowC,EAAKzhD,OAAS,GAC5C,IAAK,IAAIS,EAAI,EAAGA,EAAIghD,EAAKzhD,OAAS,EAAGS,IACnC+X,EAAO/X,GAAK6O,SAASmyC,EAAK0zD,OAAW,EAAJ10G,EAAO,GAAI,IAE9C,OAAO,IAAI+Q,SAASgH,EAAOA,OAC7B,CAQWy8M,CAAgBlsN,GAErB0xM,YAAYC,OAAO3xM,GACjBA,aAAkByI,SACbzI,EAEF,IAAIyI,SAASzI,EAAOyP,OAAQzP,EAAOmsN,WAAYnsN,EAAO63F,YAE3D73F,aAAkB0xM,YACb,IAAIjpM,SAASzI,GAEf,IACT,CAEA,IAAAosN,GAjOA,cAAkBh/B,GAIhB,WAAAx3L,CAAY6K,GACV1F,QAEA0F,EAAUA,GAAoB,GAE9B3K,KAAKu2N,gBAAkB7+K,QAAQ/sC,EAAQ4rN,iBAEvCv2N,KAAKw2N,WAAa,KAElBx2N,KAAKy2N,MAAuB,IAAhB9rN,EAAQ8qM,IACpBz1M,KAAK02N,eAAyC,IAAzB/rN,EAAQgqN,aAC7B30N,KAAK22N,OAAyB,IAAjBhsN,EAAQkqN,KAErB70N,KAAKszN,QAAU3oN,EAAQk4K,eACvB7iL,KAAK42N,SAAWjsN,EAAQksN,SAAW,EACnC72N,KAAK82N,SAAWnsN,EAAQosN,SAAW,EAEnC/2N,KAAKqzN,MAAQ1oN,EAAQkoG,IACtB,CAKD,OAAAnkF,GACE,OAAO1uB,KAAKy2N,KAAO,OAAS,aAC7B,CAUD,WAAAngC,CAAYpsL,EAAQS,GAClB,OAAO,IAAIyJ,GAAQ,CACjBQ,SAAU5U,KAAKu2L,aAAarsL,EAAQS,IAEvC,CAUD,YAAA+jE,CAAaxkE,EAAQS,GACnB,IAAI6qE,EAAa,GACjB,MAAM5gE,EAAW5U,KAAKu2L,aAAarsL,EAAQS,GAM3C,OAJE6qE,EADEx1E,KAAKu2N,iBAAmB3hN,aAAoBumE,GACjCvmE,EAAS6gE,qBAET,CAAC7gE,GAET4gE,EAAW1qC,KAAKl2B,GAAa,IAAIR,GAAQ,CAACQ,cAClD,CAUD,YAAA2hL,CAAarsL,EAAQS,GACnB,MAAM6yC,EAAO24K,GAAYjsN,GACzB,IAAKszC,EACH,OAAO,KAGT,MACM5oC,EADS,IAAIk+M,GAAUt1K,GACL+4I,eAMxB,OAJAv2L,KAAKw2N,WAAah5K,EAClB7yC,EAAU3K,KAAKo2L,eAAelsL,EAAQS,GACtC3K,KAAKw2N,WAAa,KAEX7/B,GAA6B/hL,GAAU,EAAOjK,EACtD,CASD,cAAAikE,CAAe1kE,GACb,MAAMszC,EAAOx9C,KAAKw2N,YAAcL,GAAYjsN,GAC5C,IAAKszC,EACH,OAGF,MAAMsiI,EAAS,IAAIgzC,GAAUt1K,GAG7B,OAFAsiI,EAAOg0C,gBAGJh0C,EAAO00C,WAAa5lM,GAAc,QAAUkxJ,EAAO00C,iBACpDhuN,CAEH,CAUD,YAAAgwL,CAAa72I,EAASh1C,GACpB,OAAO3K,KAAK02L,cAAc/2I,EAAQzqC,cAAevK,EAClD,CAUD,aAAA8rL,CAActzH,EAAUx4D,GACtB,OAAO3K,KAAK02L,cACV,IAAIv7G,GAAmBhY,EAASr4B,KAAK1/B,GAAMA,EAAE8J,iBAC7CvK,EAEH,CAUD,aAAA+rL,CAAc9hL,EAAUjK,GACtBA,EAAU3K,KAAKq2L,aAAa1rL,GAE5B,MAAMskL,EAAS,IAAIwlC,GAAU,CAC3BtlM,OAAQnvB,KAAKszN,QACbqB,aAAc30N,KAAK02N,cACnB7B,KAAM70N,KAAK22N,MAEX/sH,OAAQ,CACNsrH,EAAGl1N,KAAK42N,SACRxiI,EAAGp0F,KAAK82N,YAKZ,IAAIjkH,EAAO1oE,OAAOqlE,UAAUxvG,KAAKqzN,OAASlpL,OAAOnqC,KAAKqzN,OAAS,KAC/D,IAAmB,IAAfrzN,KAAKqzN,QAAoBlpL,OAAOqlE,UAAUxvG,KAAKqzN,OAAQ,CACzD,MAAMjmJ,EACJziE,EAAQyiE,gBAAkBx+C,GAAcjkB,EAAQyiE,gBAClD,GAAIA,EAAgB,CAClB,MAAMvtD,EAAOutD,EAAehsD,UACxBvB,EAAKm4F,WAAW,WAClBnF,EAAO1oE,OAAOtqB,EAAK8qD,UAAU,IAEhC,CACF,CAEDskH,EAAOyH,cACLC,GAA6B/hL,GAAU,EAAMjK,GAC7CkoG,GAEF,MAAMl5F,EAASs1K,EAAO8mC,YAEtB,OAAO/1N,KAAKy2N,KAQhB,SAAyB98M,GACvB,MAAM6jC,EAAO,IAAIhrC,WAAWmH,GAC5B,OAAOtX,MAAMqvD,KAAKlU,EAAKv0C,UACpB6hC,KAAKzzB,IAAOA,EAAI,GAAK,IAAM,IAAM8yB,OAAO9yB,GAAGuB,SAAS,IAAIo+M,gBACxDl+M,KAAK,GACV,CAbuBm+M,CAAgBt9M,GAAUA,CAC9C,GC71BH,MAAMq9K,GAAsB,CAC1BkgC,MAAS1jM,GACT2jM,WAAct8I,GACdu8I,QAAWnhM,GACXohM,WAAcr8I,GACds8I,gBAAmBr8I,GACnBs8I,aAAgBr8I,IAoBZs8I,GAAQ,QAMRtC,GAAI,IAMJ9gI,GAAI,IAYJqjI,GACG,EADHA,GAEE,EAFFA,GAGQ,EAHRA,GAIS,EAJTA,GAKI,EALJA,GAMG,EANHA,GAOC,EAMDC,GAAgB,CACpBlkM,MAAO,QACPqnD,WAAY,aACZ5kD,QAAS,UACT+kD,WAAY,aACZC,gBAAiB,kBACjBC,aAAc,eACdC,mBAAoB,qBACpBG,OAAQ,UAMV,MAAMq8I,GAIJ,WAAA73N,CAAY83N,GAIV53N,KAAK43N,IAAMA,EAMX53N,KAAK63N,QAAU,CAChB,CAOD,QAAAC,CAAS9gN,GACP,OAAQA,GAAK,KAAOA,GAAK,KAASA,GAAK,KAAOA,GAAK,GACpD,CASD,UAAA+gN,CAAW/gN,EAAGwO,GAEZ,OADAA,OAAsBhf,IAAZgf,GAAwBA,EAC1BxO,GAAK,KAAOA,GAAK,KAAc,KAALA,IAAawO,CAChD,CAOD,aAAAwyM,CAAchhN,GACZ,MAAY,KAALA,GAAiB,MAALA,GAAkB,MAALA,GAAkB,MAALA,CAC9C,CAMD,SAAAihN,GACE,OAAOj4N,KAAK43N,IAAI7wM,SAAS/mB,KAAK63N,OAC/B,CAMD,SAAAK,GACE,MAAMlhN,EAAIhX,KAAKi4N,YACT/+L,EAAWl5B,KAAK63N,OAEtB,IACI93N,EADAsE,EAAQ2S,EAGZ,GAAS,KAALA,EACFjX,EAAO03N,QACF,GAAS,KAALzgN,EACTjX,EAAO03N,QACF,GAAS,KAALzgN,EACTjX,EAAO03N,QACF,GAAIz3N,KAAK+3N,WAAW/gN,IAAW,KAALA,EAC/BjX,EAAO03N,GACPpzN,EAAQrE,KAAKm4N,mBACR,GAAIn4N,KAAK83N,SAAS9gN,GACvBjX,EAAO03N,GACPpzN,EAAQrE,KAAKo4N,gBACR,IAAIp4N,KAAKg4N,cAAchhN,GAC5B,OAAOhX,KAAKk4N,YACP,GAAU,KAANlhN,EAGT,MAAM,IAAIxO,MAAM,yBAA2BwO,GAF3CjX,EAAO03N,EAGR,CAED,MAAO,CAACv+L,SAAUA,EAAU70B,MAAOA,EAAOtE,KAAMA,EACjD,CAMD,WAAAo4N,GACE,IAAInhN,EACJ,MAAM/T,EAAQjD,KAAK63N,OACnB,IAAIryM,GAAU,EACV6yM,GAAqB,EACzB,GACW,KAALrhN,EACFwO,GAAU,EACI,KAALxO,GAAiB,KAALA,IACrBqhN,GAAqB,GAEvBrhN,EAAIhX,KAAKi4N,kBAETj4N,KAAK+3N,WAAW/gN,EAAGwO,KAGjB6yM,IAA4B,KAALrhN,GAAiB,KAALA,IAGpCqhN,IAA4B,KAALrhN,GAAiB,KAALA,IAEtC,OAAO+zB,WAAW/qC,KAAK43N,IAAIjtJ,UAAU1nE,EAAOjD,KAAK63N,UAClD,CAMD,SAAAO,GACE,IAAIphN,EACJ,MAAM/T,EAAQjD,KAAK63N,OACnB,GACE7gN,EAAIhX,KAAKi4N,kBACFj4N,KAAK83N,SAAS9gN,IACvB,OAAOhX,KAAK43N,IAAIjtJ,UAAU1nE,EAAOjD,KAAK63N,UAAUb,aACjD,EAMH,MAAMsB,GAIJ,WAAAx4N,CAAYy4N,GAKVv4N,KAAKw4N,OAASD,EAMdv4N,KAAKy4N,OAAS,CACZv/L,SAAU,EACVn5B,KAAM03N,IAORz3N,KAAKszN,QAAU,IAChB,CAMD,QAAAoF,GACE14N,KAAKy4N,OAASz4N,KAAKw4N,OAAON,WAC3B,CAOD,WAAAS,CAAY54N,GACV,OAAOC,KAAKy4N,OAAO14N,MAAQA,CAC5B,CAOD,KAAAkrC,CAAMlrC,GACJ,MAAM64N,EAAU54N,KAAK24N,YAAY54N,GAIjC,OAHI64N,GACF54N,KAAK04N,WAEAE,CACR,CAMD,KAAA1tL,GAEE,OADAlrC,KAAK04N,WACE14N,KAAK64N,gBACb,CAOD,oBAAAC,GAEE,IAAI3pM,EAAS,KACb,MAAM4pM,EAAW/4N,KAAKy4N,OACtB,GAAIz4N,KAAK24N,YAAYlB,IAAiB,CACpC,MAAMuB,EAAUD,EAAS10N,MACrB20N,IAAY9D,GACd/lM,EAAS,MACA6pM,IAAY5kI,GACrBjlE,EAAS,MAvPN,OAwPM6pM,IACT7pM,EAAS,QAEI,OAAXA,GACFnvB,KAAK04N,UAER,CACD,OAAOvpM,CACR,CAMD,4BAAA8pM,GACE,GAAIj5N,KAAKirC,MAAMwsL,IAAuB,CACpC,MAAMjiJ,EAAa,GACnB,GACEA,EAAW7vE,KAAK3F,KAAK64N,wBACd74N,KAAKirC,MAAMwsL,KACpB,GAAIz3N,KAAKirC,MAAMwsL,IACb,OAAOjiJ,CAEV,CACD,MAAM,IAAIhtE,MAAMxI,KAAKk5N,sBACtB,CAMD,eAAAC,GACE,GAAIn5N,KAAKirC,MAAMwsL,IAAuB,CACpC,MAAMl+M,EAAcvZ,KAAKo5N,cACzB,GAAIp5N,KAAKirC,MAAMwsL,IACb,OAAOl+M,CAEV,CACD,MAAM,IAAI/Q,MAAMxI,KAAKk5N,sBACtB,CAMD,oBAAAG,GACE,GAAIr5N,KAAKirC,MAAMwsL,IAAuB,CACpC,MAAMl+M,EAAcvZ,KAAKs5N,kBACzB,GAAIt5N,KAAKirC,MAAMwsL,IACb,OAAOl+M,CAEV,CACD,MAAM,IAAI/Q,MAAMxI,KAAKk5N,sBACtB,CAMD,iBAAAK,GACE,GAAIv5N,KAAKirC,MAAMwsL,IAAuB,CACpC,MAAMl+M,EAAcvZ,KAAKw5N,2BACzB,GAAIx5N,KAAKirC,MAAMwsL,IACb,OAAOl+M,CAEV,CACD,MAAM,IAAI/Q,MAAMxI,KAAKk5N,sBACtB,CAMD,oBAAAO,GACE,GAAIz5N,KAAKirC,MAAMwsL,IAAuB,CACpC,IAAIl+M,EAMJ,GAJEA,EADEvZ,KAAKy4N,OAAO14N,MAAQ03N,GACRz3N,KAAK05N,sBAEL15N,KAAKs5N,kBAEjBt5N,KAAKirC,MAAMwsL,IACb,OAAOl+M,CAEV,CACD,MAAM,IAAI/Q,MAAMxI,KAAKk5N,sBACtB,CAOD,yBAAAS,GACE,GAAI35N,KAAKirC,MAAMwsL,IAAuB,CACpC,MAAMl+M,EAAcvZ,KAAKw5N,2BACzB,GAAIx5N,KAAKirC,MAAMwsL,IACb,OAAOl+M,CAEV,CACD,MAAM,IAAI/Q,MAAMxI,KAAKk5N,sBACtB,CAMD,sBAAAU,GACE,GAAI55N,KAAKirC,MAAMwsL,IAAuB,CACpC,MAAMl+M,EAAcvZ,KAAK65N,wBACzB,GAAI75N,KAAKirC,MAAMwsL,IACb,OAAOl+M,CAEV,CACD,MAAM,IAAI/Q,MAAMxI,KAAKk5N,sBACtB,CAMD,WAAAE,GACE,MAAM7/M,EAAc,GACdozG,EAAa3sH,KAAKszN,QAAQnyN,OAChC,IAAK,IAAIS,EAAI,EAAGA,EAAI+qH,IAAc/qH,EAAG,CACnC,MAAMk4N,EAAQ95N,KAAKy4N,OACnB,IAAIz4N,KAAKirC,MAAMwsL,IAGb,MAFAl+M,EAAY5T,KAA4Bm0N,EAAW,MAItD,CACD,GAAIvgN,EAAYpY,QAAUwrH,EACxB,OAAOpzG,EAET,MAAM,IAAI/Q,MAAMxI,KAAKk5N,sBACtB,CAMD,eAAAI,GACE,MAAM//M,EAAc,CAACvZ,KAAKo5N,eAC1B,KAAOp5N,KAAKirC,MAAMwsL,KAChBl+M,EAAY5T,KAAK3F,KAAKo5N,eAExB,OAAO7/M,CACR,CAMD,mBAAAmgN,GACE,MAAMngN,EAAc,CAACvZ,KAAKm5N,mBAC1B,KAAOn5N,KAAKirC,MAAMwsL,KAChBl+M,EAAY5T,KAAK3F,KAAKm5N,mBAExB,OAAO5/M,CACR,CAMD,wBAAAigN,GACE,MAAMjgN,EAAc,CAACvZ,KAAKq5N,wBAC1B,KAAOr5N,KAAKirC,MAAMwsL,KAChBl+M,EAAY5T,KAAK3F,KAAKq5N,wBAExB,OAAO9/M,CACR,CAMD,qBAAAsgN,GACE,MAAMtgN,EAAc,CAACvZ,KAAKu5N,qBAC1B,KAAOv5N,KAAKirC,MAAMwsL,KAChBl+M,EAAY5T,KAAK3F,KAAKu5N,qBAExB,OAAOhgN,CACR,CAMD,gBAAAwgN,GACE,MAAMj1N,EACJ9E,KAAK24N,YAAYlB,KAAmBz3N,KAAKy4N,OAAOp0N,OAASmzN,GAI3D,OAHI1yN,GACF9E,KAAK04N,WAEA5zN,CACR,CAOD,mBAAAo0N,GACE,MACE,eACAl5N,KAAKy4N,OAAOp0N,MACZ,iBACArE,KAAKy4N,OAAOv/L,SACZ,QACAl5B,KAAKw4N,OAAOZ,IACZ,GAEH,CAMD,cAAAiB,GACE,MAAMiB,EAAQ95N,KAAKy4N,OACnB,GAAIz4N,KAAKirC,MAAMwsL,IAAiB,CAC9B,MAAM3B,EAAkCgE,EAAW,MACnD95N,KAAKszN,QAAUtzN,KAAK84N,uBACpB,MAAMh0N,EAAU9E,KAAK+5N,mBACrB,GAAgB,sBAAZjE,EAAkC,CACpC,GAAIhxN,EACF,OAAO,IAAIq2E,GAAmB,IAEhC,MAAM3F,EAAax1E,KAAKi5N,+BACxB,OAAO,IAAI99I,GAAmB3F,EAC/B,CACD,MAAMmtI,EAAO3rB,GAAoB8+B,GACjC,IAAKnT,EACH,MAAM,IAAIn6M,MAAM,0BAA4BstN,GAG9C,IAAIv8M,EAEJ,GAAIzU,EAEAyU,EADc,SAAZu8M,EACY,CAACznM,IAAKA,KAEN,QAGhB,OAAQynM,GACN,IAAK,QACHv8M,EAAcvZ,KAAKm5N,kBACnB,MAEF,IAAK,aACH5/M,EAAcvZ,KAAKq5N,uBACnB,MAEF,IAAK,UACH9/M,EAAcvZ,KAAKu5N,oBACnB,MAEF,IAAK,aACHhgN,EAAcvZ,KAAKy5N,uBACnB,MAEF,IAAK,kBACHlgN,EAAcvZ,KAAK25N,4BACnB,MAEF,IAAK,eACHpgN,EAAcvZ,KAAK45N,yBAQzB,OAAO,IAAIjX,EAAKppM,EAAavZ,KAAKszN,QACnC,CACD,MAAM,IAAI9qN,MAAMxI,KAAKk5N,sBACtB,EAyIH,SAASc,GAAoBnhD,GAC3B,MAAMt/J,EAAcs/J,EAAKlpJ,iBACzB,OAA2B,IAAvBpW,EAAYpY,OACP,GAEFoY,EAAYT,KAAK,IAC1B,CAgCA,SAASmhN,GAAyBphD,GAChC,MAAMt/J,EAAcs/J,EAAKlpJ,iBACnBjlB,EAAQ,GACd,IAAK,IAAI9I,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAQS,EAAIuE,IAAMvE,EACjD8I,EAAM/E,KAAK4T,EAAY3X,GAAGkX,KAAK,MAEjC,OAAOpO,EAAMoO,KAAK,IACpB,CAmBA,SAASohN,GAAsBrhD,GAC7B,MAAMnuK,EAAQ,GACR8Q,EAAQq9J,EAAK5hJ,iBACnB,IAAK,IAAIr1B,EAAI,EAAGuE,EAAKqV,EAAMra,OAAQS,EAAIuE,IAAMvE,EAC3C8I,EAAM/E,KAAK,IAAMs0N,GAAyBz+M,EAAM5Z,IAAM,KAExD,OAAO8I,EAAMoO,KAAK,IACpB,CAmCA,MAAMqhN,GAAkB,CACtB3mM,MAASwmM,GACTn/I,WAAco/I,GACdhkM,QAAWikM,GACXl/I,WAlGF,SAAkC69F,GAChC,MAAMnuK,EAAQ,GACR0vN,EAAavhD,EAAK/+E,YACxB,IAAK,IAAIl4F,EAAI,EAAGuE,EAAKi0N,EAAWj5N,OAAQS,EAAIuE,IAAMvE,EAChD8I,EAAM/E,KAAK,IAAMq0N,GAAoBI,EAAWx4N,IAAM,KAExD,OAAO8I,EAAMoO,KAAK,IACpB,EA4FEmiE,gBA5DF,SAAuC49F,GACrC,MAAMnuK,EAAQ,GACR0vN,EAAavhD,EAAKr/E,iBACxB,IAAK,IAAI53F,EAAI,EAAGuE,EAAKi0N,EAAWj5N,OAAQS,EAAIuE,IAAMvE,EAChD8I,EAAM/E,KAAK,IAAMs0N,GAAyBG,EAAWx4N,IAAM,KAE7D,OAAO8I,EAAMoO,KAAK,IACpB,EAsDEoiE,aAnCF,SAAoC29F,GAClC,MAAMnuK,EAAQ,GACR0vN,EAAavhD,EAAK/9E,cACxB,IAAK,IAAIl5F,EAAI,EAAGuE,EAAKi0N,EAAWj5N,OAAQS,EAAIuE,IAAMvE,EAChD8I,EAAM/E,KAAK,IAAMu0N,GAAsBE,EAAWx4N,IAAM,KAE1D,OAAO8I,EAAMoO,KAAK,IACpB,EA6BEqiE,mBAxFF,SAA0C09F,GACxC,MAAMnuK,EAAQ,GACRkrN,EAAQ/8C,EAAK18F,gBACnB,IAAK,IAAIv6E,EAAI,EAAGuE,EAAKyvN,EAAMz0N,OAAQS,EAAIuE,IAAMvE,EAC3C8I,EAAM/E,KAAK00N,GAAOzE,EAAMh0N,KAE1B,OAAO8I,EAAMoO,KAAK,IACpB,GAyFA,SAASuhN,GAAOxhD,GACd,MAAM94K,EAAO84K,EAAKnqJ,UAEZ4rM,GAAMC,EADYJ,GAAgBp6N,IACZ84K,GAC5B,IAAI2hD,EAAU9C,GAAc33N,GAC5B,GAA4D,mBAA/B,EAAyB,mBAAkB,CACtE,MAAMi5N,EArCV,SAA8BngD,GAC5B,MAAM1pJ,EAAS0pJ,EAAK/oJ,YACpB,IAAIkpM,EAAU,GAOd,MANe,QAAX7pM,GAA+B,SAAXA,IACtB6pM,GAAW9D,IAEE,QAAX/lM,GAA+B,SAAXA,IACtB6pM,GAAW5kI,IAEN4kI,CACT,CA2BoByB,CACpB,GAEQzB,EAAQ73N,OAAS,IACnBq5N,GAAW,IAAMxB,EAEpB,CACD,OAAmB,IAAfsB,EAAIn5N,OACCq5N,EAAU,IAAMhD,GAElBgD,EAAU,IAAMF,EAAM,GAC/B,CAEA,IAAAI,GA3QA,cAAkBruB,GAIhB,WAAAvsM,CAAY6K,GACV1F,QAEA0F,EAAUA,GAAoB,GAO9B3K,KAAK26N,sBACyBn0N,IAA5BmE,EAAQ4rN,iBAAgC5rN,EAAQ4rN,eACnD,CASD,MAAAqE,CAAOhD,GACL,MAAMW,EAAQ,IAAIZ,GAAMC,GAExB,OADe,IAAIU,GAAOC,GACZrtL,OACf,CAQD,mBAAAugK,CAAoB7oJ,EAAMj4C,GACxB,MAAMkuK,EAAO74K,KAAK2rM,qBAAqB/oJ,EAAMj4C,GACvCg1C,EAAU,IAAIvrC,GAEpB,OADAurC,EAAQ9qC,YAAYgkK,GACbl5H,CACR,CAQD,oBAAA+rJ,CAAqB9oJ,EAAMj4C,GACzB,IAAI6qE,EAAa,GACjB,MAAM5gE,EAAW5U,KAAK2rM,qBAAqB/oJ,EAAMj4C,GAE/C6qE,EADEx1E,KAAK26N,kBAA0C,sBAAtB/lN,EAAS8Z,UACW,EAE7C+mD,qBAEW,CAAC7gE,GAEhB,MAAMuuD,EAAW,GACjB,IAAK,IAAIvhE,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAAG,CACnD,MAAM+9C,EAAU,IAAIvrC,GACpBurC,EAAQ9qC,YAAY2gE,EAAW5zE,IAC/BuhE,EAASx9D,KAAKg6C,EACf,CACD,OAAOwjB,CACR,CAQD,oBAAAwoI,CAAqB/oJ,EAAMj4C,GAEzB,OAAOgsL,GADU32L,KAAK46N,OAAOh4K,IACiB,EAAOj4C,EACtD,CAQD,gBAAAkhM,CAAiBlsJ,EAASh1C,GACxB,MAAMiK,EAAW+qC,EAAQzqC,cACzB,OAAIN,EACK5U,KAAK+rM,kBAAkBn3L,EAAUjK,GAEnC,EACR,CAQD,iBAAAmhM,CAAkB3oI,EAAUx4D,GAC1B,GAAuB,GAAnBw4D,EAAShiE,OACX,OAAOnB,KAAK6rM,iBAAiB1oI,EAAS,GAAIx4D,GAE5C,MAAM6qE,EAAa,GACnB,IAAK,IAAI5zE,EAAI,EAAGuE,EAAKg9D,EAAShiE,OAAQS,EAAIuE,IAAMvE,EAC9C4zE,EAAW7vE,KAAKw9D,EAASvhE,GAAGsT,eAE9B,MAAM8yC,EAAa,IAAImzB,GAAmB3F,GAC1C,OAAOx1E,KAAK+rM,kBAAkB/jJ,EAAYr9C,EAC3C,CAQD,iBAAAohM,CAAkBn3L,EAAUjK,GAC1B,OAAO0vN,GAAO1jC,GAA6B/hL,GAAU,EAAMjK,GAC5D,GCvrBH,MAAMu7L,GAAiB,CAAC,KAAM,8BAOxBid,GAAUlyF,GAAgBi1E,GAAgB,CAC9C54E,QAAW0C,IA0Ub,SAAqBz+G,EAAMo+G,GACzB,OAAO+B,GAAgB,CAAE,EAAEmpG,GAAiBtpN,EAAMo+G,EACpD,IA3UEmrG,WAAc9qG,IAgUhB,SAAwBz+G,EAAMo+G,GAC5B,OAAO+B,GAAgB,CAAE,EAAEqpG,GAAoBxpN,EAAMo+G,EACvD,MA1TMorG,GAAqB9pG,GAAgBi1E,GAAgB,CACzD34E,QAAWyC,IAseb,SAAqBz+G,EAAMo+G,GACzB,OAAO+B,GAAgB,CAAE,EAAEspG,GAAiBzpN,EAAMo+G,EACpD,IAveEsrG,UAAajrG,IAmWf,SAAuBz+G,EAAMo+G,GAC3B,OAAO+B,GAAgB,GAAIwpG,GAAmB3pN,EAAMo+G,EACtD,IApWEzwD,MAAS8wD,IA2WX,SAA6Bz+G,EAAMo+G,GACjC,MAAMwrG,EAAczpG,GAAgB,CAAA,EAAI0pG,GAAe7pN,EAAMo+G,GAE7D,QAA6BnpH,IAAzB20N,EAAmB,MACrB,OAAOz0N,OAAO8C,OAAO2xN,EAAaE,GAAU9pN,EAAMo+G,IAGpD,OAAOwrG,CACT,MAzUA,MAAMN,GAAkB5pG,GAAgBi1E,GAAgB,CACtDo1B,KAAQtrG,GAAyBquE,IACjCgoB,MAASr2F,GAAyBquE,IAClC6nB,SAAYl2F,GAAyBquE,IACrCk9B,YAAevrG,GAAyBwrG,IACxCC,eAAkBzrG,GAAyB6zF,IAC3C6X,mBAAsB1rG,IAuRxB,SAAgCz+G,EAAMo+G,GACpC,OAAO+B,GAAgB,CAAE,EAAEiqG,GAA6BpqN,EAAMo+G,EAChE,IAxREy2F,KAAQp2F,GAAyBquE,IACjC8nB,kBAAqBn2F,GAAyBquE,IAC9Cu9B,WAAc5rG,GAAyBmuE,IACvC09B,SAAY7rG,GAAyBmuE,IACrC29B,UAAa9rG,GAAyBmuE,MAQlCw9B,GAA8B1qG,GAAgBi1E,GAAgB,CAClE61B,qBAAwB/rG,IAkR1B,SAAkCz+G,EAAMo+G,GACtC,OAAO+B,GAAgB,CAAE,EAAEsqG,GAAwBzqN,EAAMo+G,EAC3D,IAnREssG,gBAAmBjsG,GAAyBquE,IAC5C69B,eAAkBlsG,IAyRpB,SAA4Bz+G,EAAMo+G,GAChC,OAAO+B,GAAgB,CAAE,EAAEyqG,GAAyB5qN,EAAMo+G,EAC5D,IA1REysG,sBAAyBpsG,GAAyBquE,IAClDg+B,0BAA6BrsG,GAAyBquE,IACtDi+B,6BAAgCtsG,GAAyBquE,MAQrD29B,GAAyB/qG,GAAgBi1E,GAAgB,CAC7Dq2B,cAAiBvsG,GAAyBquE,IAC1Cm+B,oBAAuBxsG,GAAyBquE,MAQ5C89B,GAA0BlrG,GAAgBi1E,GAAgB,CAC9Du2B,YAAezsG,GAAyBquE,IACxC6mB,QAAWl1F,GAAyBquE,IACpCimB,KAAQt0F,GAAyBquE,IACjCq+B,gBAAmB1sG,GAAyBquE,IAC5Cs+B,SAAY3sG,GAAyBquE,IACrComB,QAAWz0F,GAAyBquE,MAQhC68B,GAAoBjqG,GAAgBi1E,GAAgB,CACxDz4E,OAAUmC,GAAgByuE,MAQtB+8B,GAAgBnqG,GAAgBi1E,GAAgB,CACpDo1B,KAAQtrG,GAAyBquE,IACjCgoB,MAASr2F,GAAyBquE,IAClC6nB,SAAYl2F,GAAyBquE,IACrCk9B,YAAevrG,GAAyBwrG,IACxCoB,IAAO9sG,GAAyBuuE,IAChCw+B,yBAA4B7sG,IAwJ9B,SAAqCz+G,EAAMo+G,GACzC,MAAMmtG,EAAwBprG,GAC5B,CAAE,EACFqrG,GACAxrN,EACAo+G,GAEF,IAAKmtG,EACH,OAEF,MAAME,EAEHF,EAA2C,mBACxCG,EAEHH,EAA2C,mBACxCI,EAEHJ,EAA2C,mBACxCK,EAEHL,EAA2C,mBAC9C,QACyBt2N,IAAvBw2N,QACuBx2N,IAAvBy2N,QACuBz2N,IAAvB02N,QACuB12N,IAAvB22N,EAEA,OAEF,MAAO,CACLH,EACAC,EACAC,EACAC,EAEJ,IAzLEC,YAAettG,IA4HjB,SAAyBv+G,EAAMo+G,GAC7B,MAAMn2G,EAAS,CACb0kL,GAAkB3sL,EAAKgqL,aAAa,SACpC2C,GAAkB3sL,EAAKgqL,aAAa,SACpC2C,GAAkB3sL,EAAKgqL,aAAa,SACpC2C,GAAkB3sL,EAAKgqL,aAAa,UAGhC5qJ,EAAc,CAClButJ,GAAkB3sL,EAAKgqL,aAAa,SACpC2C,GAAkB3sL,EAAKgqL,aAAa,UAGtC,MAAO,CACL/iF,IAAOjnG,EAAKgqL,aAAa,OACzB/hL,OAAUA,EACVtW,IAAOytC,EAEX,IA7IE0sL,UAAavtG,IAkVf,SAAuBv+G,EAAMo+G,GAW3B,MAVwB,CACtBj6G,KAAQnE,EAAKgqL,aAAa,QAC1B54K,MAASpR,EAAKgqL,aAAa,SAC3B+hC,WAAc/rN,EAAKgqL,aAAa,cAChC31D,QAAWr0H,EAAKgqL,aAAa,WAC7BgiC,eAAkBz/B,GAAkBvsL,EAAKgqL,aAAa,mBACtDiiC,aAAgB1/B,GAAkBvsL,EAAKgqL,aAAa,iBACpDksB,QAAW3pB,GAAkBvsL,EAAKgqL,aAAa,YAC/CtyL,OAAUo1L,GAAW9sL,GAGzB,IA7VE8iD,YAAe27D,IAiHjB,SAAyBz+G,EAAMo+G,GAC7B,OAAO+B,GAAgB,CAAE,EAAE+rG,GAAqBlsN,EAAMo+G,EACxD,IAlHE+tG,aAAgB5tG,IAkalB,SAA0Bv+G,EAAMo+G,GAC9B,MAAMguG,EAAkBC,GAAyBrsN,EAAMo+G,GACvD,GAAIguG,EAEF,OADAA,EAAsB,KAAIpsN,EAAKgqL,aAAa,QACrCoiC,EAET,MACF,IAxaEE,WAAc/tG,GAAyBuuE,IACvCy/B,YAAehuG,IA8ajB,SAAyBv+G,EAAMo+G,GAC7B,MAAMouG,EAAiBH,GAAyBrsN,EAAMo+G,GACtD,GAAIouG,EAEF,OADAA,EAAqB,KAAIxsN,EAAKgqL,aAAa,QACpCwiC,EAET,MACF,IApbEC,QAAWluG,GAAyB8tG,IACpCK,eAAkBnuG,GAAyB8tG,IAC3C90E,MAASh5B,IAybX,SAAmBv+G,EAAMo+G,GACvB,OAAO+B,GAAgB,CAAE,EAAE4hF,GAAe/hM,EAAMo+G,EAClD,IA1bEuuG,oBAAuBluG,GAAyBiuE,IAChDkgC,oBAAuBnuG,GAAyBiuE,IAChD/+H,MAAS4wD,GAAyBurG,MAQ9BoC,GAAsBxsG,GAAgBi1E,GAAgB,CAC1DmgB,MAASr2F,GAAyBquE,IAClCo9B,eAAkBzrG,GAAyB6zF,IAC3Cua,QAAWpuG,GAAyBquG,MAQhCtB,GAAqC9rG,GAAgBi1E,GAAgB,CACzE82B,mBAAsBhtG,GAAyBiuE,IAC/Ci/B,mBAAsBltG,GAAyBiuE,IAC/Cg/B,mBAAsBjtG,GAAyBiuE,IAC/Ck/B,mBAAsBntG,GAAyBiuE,MAQ3C+8B,GAAkB/pG,GAAgBi1E,GAAgB,CACtDo4B,gBAAmBtuG,GAAyBuuG,IAC5CC,OAAUxuG,GAAyBuuG,IACnCE,eAAkBzuG,GAAyBuuG,MAQvCG,GAAwBztG,GAAgBi1E,GAAgB,CAC5Dz4E,OAAUqC,GAAyBuuE,IACnCsgC,QAAW7uG,IAiUb,SAAqBv+G,EAAMo+G,GACzB,OAAO+B,GAAgB,CAAE,EAAEktG,GAAiBrtN,EAAMo+G,EACpD,MA3TMivG,GAAkB3tG,GAAgBi1E,GAAgB,CACtDkf,KAAQp1F,IAiUV,SAAkBz+G,EAAMo+G,GACtB,OAAO+B,GAAgB,CAAE,EAAE2zF,GAAc9zM,EAAMo+G,EACjD,MA3TM01F,GAAep0F,GAAgBi1E,GAAgB,CACnDx9D,IAAO1Y,GAAyB4tG,IAChCrY,KAAQv1F,GAAyB4tG,MAQ7BtqB,GAAgBriF,GAAgBi1E,GAAgB,CACpDo1B,KAAQtrG,GAAyBquE,IACjCgoB,MAASr2F,GAAyBquE,IAClC6nB,SAAYl2F,GAAyBquE,IACrCwgC,UAAa/uG,GAAyBuuG,IACtCS,cAAiB9uG,GAAyB4tG,IAC1CmB,SAAY/uG,GAAyB4tG,MAQjCoB,GAAgC/tG,GAAgBi1E,GAAgB,CACpEz4E,OAAUuC,GAAyBquE,IACnCo9B,eAAkBzrG,GAAyB6zF,MAQvCob,GAAsBhuG,GAAgBi1E,GAAgB,CAC1Dg5B,QAAWtvG,GAAgByuE,MA0J7B,SAASg9B,GAAU9pN,EAAMo+G,GACvB,MAAMwvG,EACJxvG,EAAYA,EAAYxuH,OAAS,GAG7Bg6N,EAAczpG,GAAgB,CAAA,EAAI0pG,GAAe7pN,EAAMo+G,GAE7D,IAAKwrG,EACH,OAEF,IAAIiE,EAAYthC,GAAkBvsL,EAAKgqL,aAAa,mBAClC/0L,IAAd44N,IACFA,EAAYD,EAA6B,WAE3ChE,EAAuB,eAAkB30N,IAAd44N,GAA0BA,EAErD,IAAIC,EAAWjhC,GAA6B7sL,EAAKgqL,aAAa,kBAC7C/0L,IAAb64N,IACFA,EAAWF,EAA4B,UAEzChE,EAAsB,SAAIkE,EAE1B,IAAI12I,EAASm1G,GAAkBvsL,EAAKgqL,aAAa,gBAClC/0L,IAAXmiF,IACFA,EAASw2I,EAA0B,QAErChE,EAAoB,YAAe30N,IAAXmiF,GAAuBA,EAE/C,IAAI22I,EAAYxhC,GAAkBvsL,EAAKgqL,aAAa,mBAClC/0L,IAAd84N,IACFA,EAAYH,EAA6B,WAE3ChE,EAAuB,eAAkB30N,IAAd84N,GAA0BA,EAErD,IAAIC,EAAarhC,GAAkB3sL,EAAKgqL,aAAa,eAChDgkC,IACHA,EAAaJ,EAA8B,YAE7ChE,EAAwB,WAAIoE,EAE5B,IAAIC,EAActhC,GAAkB3sL,EAAKgqL,aAAa,gBACjDikC,IACHA,EAAcL,EAA+B,aAE/ChE,EAAyB,YAAIqE,EAGb,CAAC,QAAS,MAAO,gBACzBr0N,SAAQ,SAAU5D,GACxB,GAAIA,KAAO43N,EAAmB,CAC5B,MAAMM,EAAatE,EAAY5zN,IAAQ,GACvC4zN,EAAY5zN,GAAOk4N,EAAW1oI,OAAOooI,EAAkB53N,GACxD,CACL,IAiBE,MAfoB,CAClB,2BACA,cACA,YACA,cACA,sBACA,uBAEU4D,SAAQ,SAAU5D,GAC5B,KAAMA,KAAO4zN,GAAc,CACzB,MAAMuE,EAAcP,EAAkB53N,GACtC4zN,EAAY5zN,GAAOm4N,CACpB,CACL,IAESvE,CACT,CA0BA,SAASyC,GAAyBrsN,EAAMo+G,GACtC,OAAO+B,GAAgB,CAAE,EAAEstG,GAA+BztN,EAAMo+G,EAClE,CAkCA,SAAS4uG,GAAkBhtN,EAAMo+G,GAC/B,OAAO+B,GAAgB,CAAE,EAAEgtG,GAAuBntN,EAAMo+G,EAC1D,CAOA,SAAS0uG,GAA8B9sN,EAAMo+G,GAC3C,MAAMgwG,EAAuB/B,GAAyBrsN,EAAMo+G,GAC5D,GAAIgwG,EAAsB,CACxB,MAAMjsN,EAAO,CACX0qL,GAA6B7sL,EAAKgqL,aAAa,UAC/C6C,GAA6B7sL,EAAKgqL,aAAa,YAGjD,OADAokC,EAA2B,KAAIjsN,EACxBisN,CACR,CAEH,CA4CA,SAASnE,GAAgBjqN,EAAMo+G,GAC7B,OAAO+B,GAAgB,GAAIutG,GAAqB1tN,EAAMo+G,EACxD,CAEA,IAAAiwG,GA1jBA,cAA8BhZ,GAC5B,WAAA9mN,GACEmF,QAKAjF,KAAKwuG,aAAUhoG,CAChB,CAMD,YAAAm9M,CAAapyM,GACXvR,KAAKwuG,QAAUj9F,EAAKgqL,aAAa,WAAW1wJ,OAC5C,MAAMg1L,EAAsBnuG,GAC1B,CACEljB,QAAWxuG,KAAKwuG,SAElB20G,GACA5xM,EACA,IAEF,OAAOsuN,GAA4C,IACpD,GCqFH,IAAAC,GApIA,cAAgCtlC,GAI9B,WAAA16L,CAAY6K,GACV1F,QAEA0F,EAAUA,GAAoB,GAM9B3K,KAAK8wN,WAAa,yCAMlB9wN,KAAK+wN,WAAa,IAAIrxB,GAMtB1/L,KAAKumH,QAAU57G,EAAQo8C,OAASp8C,EAAQo8C,OAAS,IAClD,CAKD,SAAAS,GACE,OAAOxnD,KAAKumH,OACb,CAKD,SAAAj/D,CAAUP,GACR/mD,KAAKumH,QAAUx/D,CAChB,CAQD,aAAAg5K,CAAcxuN,EAAMo+G,GAClBp+G,EAAK4/C,aAAa,eAAgBnxD,KAAK8wN,YACvC,MAAM/gG,EAAYx+G,EAAKw+G,UAEvB,IAAI5sD,EAAW,GACf,GAA+B,IAA3B5xD,EAAKO,WAAW3Q,OAClB,OAAOgiE,EAET,GAAiB,eAAb4sD,EACF,IAAK,IAAInuH,EAAI,EAAGuE,EAAKoL,EAAKO,WAAW3Q,OAAQS,EAAIuE,EAAIvE,IAAK,CACxD,MAAMgsC,EAAQr8B,EAAKO,WAAWlQ,GAC9B,GAAIgsC,EAAMohF,WAAaC,KAAK2qE,aAC1B,SAGF,MAAMomC,EAAuC,EACvC7vN,EAAUw/G,EAAY,GAEtBswG,EA3EU,SA4EVje,EAAYge,EAAajwG,UAAUvsG,QAAQy8M,EAAU,IAE3D,GAAIjgO,KAAKumH,UAAYvmH,KAAKumH,QAAQ7gH,SAASs8M,GACzC,SAGF,MAAMvnB,EAAcunB,EAxFF,WA0FlB7xM,EAAqB,YAAIsqL,EACzBtqL,EAAmB,UAAInQ,KAAK8wN,WAG5B,MAAMt/F,EAAU,CAAA,EAChBA,EAAQipE,GAAe7qE,GACrB5vH,KAAK+wN,WAAW11B,mBAChBr7L,KAAK+wN,YAEP,MAAMz/F,EAAYL,GAChB,CAAC9gH,EAAmB,UAAG,MACvBqhH,GAEFwuG,EAAa7uK,aAAa,eAAgBnxD,KAAK8wN,YAC/C,MAAMoP,EAAgBxuG,GACpB,GAEAJ,EACA0uG,EACArwG,EACA3vH,KAAK+wN,YAEHmP,GACFh+N,EAAOihE,EAAU+8J,EAEpB,CAEH,GAAiB,qBAAbnwG,EAAkC,CACpC,MAAMowG,EAAczuG,GAClB,GACA1xH,KAAK+wN,WAAWl2B,2BAChBtpL,EACA,CAAC,IACDvR,KAAK+wN,YAEHoP,IACFh9J,EAAWg9J,EAEd,CACD,OAAOh9J,CACR,CAQD,oBAAAw2H,CAAqBpoL,EAAM5G,GACzB,MAAMyyL,EAAkB,CAAA,EAIxB,OAHIzyL,GACFjE,OAAO8C,OAAO4zL,EAAiBp9L,KAAKo2L,eAAe7kL,EAAM5G,IAEpD3K,KAAK+/N,cAAcxuN,EAAM,CAAC6rL,GAClC,GC7IH,MAAM8I,GAAiB,CAAC,KAAM,mCAMxBk6B,GAAqB,CAAC,KAAM,kCAO5Bjd,GAAUlyF,GAAgBi1E,GAAgB,CAC9Cm6B,SAAYrwG,IAiMd,SAAsBz+G,EAAMo+G,GAC1B,OAAO+B,GAAgB,CAAE,EAAE4uG,GAAkB/uN,EAAMo+G,EACrD,MAlJA,MAAM2wG,GAAmBrvG,GAAgBi1E,GAAgB,CACvDhnI,MAAS4wD,IAwJX,SAAmBv+G,EAAMo+G,GACvB,OAAO+B,GAAgB,CAAE,EAAE0pG,GAAe7pN,EAAMo+G,EAClD,IAzJE4wG,cAAiBzwG,IAgKnB,SAA2Bv+G,EAAMo+G,GAC/B,OAAO+B,GAAgB,CAAE,EAAE8uG,GAAajvN,EAAMo+G,EAChD,MA1JMyrG,GAAgBnqG,GACpBi1E,GACA,CACEp9C,MAASh5B,IA8Jb,SAAmBv+G,EAAMo+G,GACvB,MAAMp/G,EAAQmhH,GAAgB,CAAA,EAAI4hF,GAAe/hM,EAAMo+G,GACvD,IAAKp/G,EACH,OAEF,MAAMkwN,EAA+C,SAAnClvN,EAAKgqL,aAAa,aAEpC,OADAhrL,EAAiB,UAAIkwN,EACdlwN,CACT,IArKIk9G,OAAUqC,GAAyBuuE,IACnCqiC,kBAAqB5wG,IA2KzB,SAA+Bv+G,EAAMo+G,GACnC,OAAO+B,GAAgB,CAAE,EAAEivG,GAAmBpvN,EAAMo+G,EACtD,IA5KI0tG,UAAavtG,IAmLjB,SAAwBv+G,EAAMo+G,GAC5B,OAAO+B,GAAgB,CAAE,EAAEkvG,GAAmBrvN,EAAMo+G,EACtD,IApLIkxG,YAAe/wG,IA2LnB,SAAyBv+G,EAAMo+G,GAC7B,MAAM3oG,EAASzV,EAAKgqL,aAAa,UAC3Bt0K,EAAW1V,EAAKgqL,aAAa,YAC7BulC,EAAevvN,EAAKgqL,aAAa,gBACjC/rG,EAAW,CAAA,EACbxoE,IACFwoE,EAAiB,OAAIxoE,GAEnBC,IACFuoE,EAAmB,SAAIvoE,GAErB65M,IACFtxI,EAAuB,aAAIsxI,GAE7B,OAAOtxI,CACT,KAxMEyhC,GAAgBmvG,GAAoB,CAClC/Z,MAASr2F,GAAyBquE,IAClC6nB,SAAYl2F,GAAyBquE,IACrC0iC,iBAAoB/wG,GAAyBgxG,IAC7CnD,WAAc7tG,GAAyBquE,OASrCiV,GAAgBriF,GACpBi1E,GACA,CACE24B,UAAa/uG,IAiNjB,SAAuBv+G,EAAMo+G,GAC3B,MAAMsxG,EAAS,CAAA,EAGf,OAFAA,EAAe,OAAI1vN,EAAKgqL,aAAa,UACrC0lC,EAAa,KAAIpd,GAAStyM,GACnB0vN,CACT,KApNEhwG,GAAgBmvG,GAAoB,CAClC/Z,MAASr2F,GAAyBquE,IAClCw/B,WAAc7tG,GAAyBquE,OASrCsiC,GAAoB1vG,GAAgBi1E,GAAgB,CACxDq6B,cAAiBvwG,GAAyBquE,IAC1C6iC,oBAAuBlxG,IAyOzB,SAAkCz+G,EAAMo+G,GACtC,OAAO+B,GAAgB,GAAIyvG,GAAyB5vN,EAAMo+G,EAC5D,MAnOMwxG,GAA0BlwG,GAAgBi1E,GAAgB,CAC9Dk7B,iBAAoBxxG,IAyOtB,SAA8Br+G,EAAMo+G,GAClC,OAAO+B,GAAgB,CAAE,EAAE2vG,GAAoB9vN,EAAMo+G,EACvD,MAnOM0xG,GAAqBpwG,GAAgBi1E,GAAgB,CACzDx4E,WAAcsC,GAAyBquE,IACvCijC,WAActxG,GAAyBmuE,IACvCojC,WAAcvxG,GAAyBmuE,IACvCqjC,WAAcxxG,GAAyBmuE,IACvCsjC,WAAczxG,GAAyBmuE,MAQnCyiC,GAAoB3vG,GACxBi1E,GACA,CACE1hC,QAAWx0C,GAAyBquE,IACpCumB,MAAS90F,GAAyBuuE,KAEpCptE,GAAgBmvG,GAAoB,CAClCvC,WAAc7tG,GAAyBquE,OASrCqjC,GAAqBzwG,GAAgBmvG,GAAoB,CAC7DuB,YAAe/xG,GAAgBgyG,IAC/BC,YAAejyG,GAAgBgyG,MAQ3BpB,GAAcvvG,GAClBi1E,GACA,CACE47B,kBAAqB9xG,GAAyBquE,IAC9C3wE,WAAcoC,IAoKlB,SAAwBv+G,EAAMo+G,GAC5B,OAAO+B,GAAgB,CAAE,EAAEqwG,GAAYxwN,EAAMo+G,EAC/C,KApKEsB,GAAgBmvG,GAAoB,CAClC4B,aAAgBhyG,GAAyBquE,IACzCw/B,WAAc7tG,GAAyBquE,IACvC++B,YAAeptG,GAAyBgxG,OAStCe,GAAa9wG,GACjBi1E,GACA,CACE+7B,cAAiBjyG,GAAyB4xG,IAC1CM,iBAAoBlyG,GAAyBiuE,IAC7CkkC,UAAanyG,GAAyBmuE,IACtCikC,WAAcpyG,GAAyBmuE,IACvCkkC,YAAeryG,GAAyBmuE,IACxCmkC,aAAgBtyG,GAAyBmuE,KAE3CltE,GAAgBmvG,GAAoB,CAClCvC,WAAc7tG,GAAyBquE,OA2F3C,SAAS2iC,GAAgBzvN,EAAMo+G,GAC7B,MAAMp2G,EAAcm4G,GAClB,GACAgwG,GACAnwN,EACAo+G,GAEF,GAA0B,GAAtBp2G,EAAYpY,OAGhB,OAAOmY,GAAeC,EACxB,CAmBA,SAASqoN,GAAgBrwN,EAAMo+G,GAC7B,MAAMp2G,EAAc8kL,GAAW9sL,GAAMsU,MAAM,OAC3C,IAAKtM,GAAqC,GAAtBA,EAAYpY,OAC9B,OAEF,MAAMkW,GAAKkC,EAAY,GACjBjC,GAAKiC,EAAY,GACvB,OAAIiV,MAAMnX,IAAMmX,MAAMlX,QAAtB,EAGO,CAACD,EAAGC,EACb,CA6BA,IAAAirN,GAhVA,cAA+B3b,GAC7B,WAAA9mN,GACEmF,QAMAjF,KAAKwiO,WAAa,IAAIC,EACvB,CAMD,YAAA9e,CAAapyM,GACX,IAAIi9F,EAAUj9F,EAAKgqL,aAAa,WAC5B/sF,IACFA,EAAUA,EAAQ3jE,QAEpB,IAAI63L,EAAuB1iO,KAAKwiO,WAAW7e,aAAapyM,GACxD,OAAKmxN,GAGLA,EAA8B,QAAIl0H,EAClCk0H,EAAuBhxG,GACrBgxG,EACAvf,GACA5xM,EACA,IAEKmxN,GAA8C,MAT5C,IAUV,GCjEH,MAAMC,GAAS,CACb,mBACA,yBACA,sBAMIC,GAMa,kBANbA,GAaa,kBAuTnB,SAASC,GAAsBj3K,GAC7B,MAAMpH,EAAOoH,EAAIpH,KACjB,SACEA,EAA8B,yBAC7BA,EAAKs+K,mBAAqBl3K,EAAIm3K,kBAEnC,CAMA,SAASC,GAAap3K,GACpB,SAAUA,EAAwB,qBAAKA,EAAIq3K,kBAC7C,CAMA,SAASC,GAAkB34N,GACrBA,EAAQu4N,kBACVv4N,EAAQu4N,oBACCv4N,EAAiC,yBAC1CA,EAAiC,yBAErC,CA0BA,IAAA44N,GA3TA,cAAyBjzK,GAIvB,WAAApwD,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B1F,MAAM,CACJsF,QAASwF,SAASC,cAAc,OAChC7P,OAAQwK,EAAQxK,SAMlBH,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAML3H,KAAK2qH,WAAyBnkH,IAAjBmE,EAAQhE,MAAqBgE,EAAQhE,KAMlD3G,KAAKm/K,QAAUx0K,EAAQT,OAMvBlK,KAAKojO,iBAAkB,EAKvBpjO,KAAKqjO,4BAA8BrjO,KAAKsjO,uBAAuBp8N,KAAKlH,MAMpEA,KAAKujO,mBACmB/8N,IAAtBmE,EAAQ2iC,UAA0B3iC,EAAQ2iC,UAAY,iBAMxDttC,KAAKwjO,mBAAqB,GAM1BxjO,KAAKyjO,sBACyBj9N,IAA5BmE,EAAQ+4N,gBACJ/4N,EAAQ+4N,gBAAgB79M,MAAM,KAC9B,CAAC7lB,KAAKujO,cAAgB,SAM5BvjO,KAAK2jO,wBAC2Bn9N,IAA9BmE,EAAQi5N,kBACJj5N,EAAQi5N,kBAAkB/9M,MAAM,KAChC,CAAC7lB,KAAKujO,cAAgB,UAE5B,MAAM39K,OAA0Bp/C,IAAlBmE,EAAQi7C,MAAsBj7C,EAAQi7C,MAAQ,IAM5D5lD,KAAK6jO,WACc,iBAAVj+K,EAAqB71C,SAAS0jD,eAAe7N,GAASA,EAE/D,MAAMk+K,OACoBt9N,IAAxBmE,EAAQm5N,YAA4Bn5N,EAAQm5N,YAAc,IAM5D9jO,KAAK+jO,iBACoB,iBAAhBD,EACH/zN,SAAS0jD,eAAeqwK,GACxBA,EAEN,MAAMpzK,EAAW/lD,EAAQ+lD,SAAW/lD,EAAQ+lD,SAAW,qBAMvD1wD,KAAKgkO,QAAUj0N,SAASC,cAAc,UACtChQ,KAAKgkO,QAAQ5yK,MAAQV,EACrB1wD,KAAKgkO,QAAQ7yK,aAAa,OAAQ,UAClCnxD,KAAKgkO,QAAQ9xN,YAAYlS,KAAK6jO,YAC9B7jO,KAAKgkO,QAAQ1+N,iBACXwC,EACA9H,KAAKqxD,aAAanqD,KAAKlH,OACvB,GAEFA,KAAKikO,cAAcjkO,KAAKgkO,QAAShkO,KAAKojO,iBAEtCpjO,KAAKuK,QAAQ+iC,UAAY,GAAGttC,KAAKujO,iBAAiBziL,MAAsBE,KACxEhhD,KAAKuK,QAAQ2H,YAAYlS,KAAKgkO,QAC/B,CAMD,YAAA3yK,CAAaxrD,GACXA,EAAMzF,iBACNJ,KAAKkkO,mBACN,CAKD,iBAAAA,GACE,MAAMp5L,EAAM9qC,KAAKsgD,SACjB,IAAKxV,EACH,OAEF,MAAM8gB,EAAM9gB,EAAI+gB,mBAChB,GAAKg3K,GAAsBj3K,GAG3B,GAAIo3K,GAAap3K,IAmKrB,SAAwBA,GAClBA,EAAIu4K,eACNv4K,EAAIu4K,iBACKv4K,EAA0B,sBACnCA,EAA0B,sBAE9B,CAxKMw4K,CAAex4K,OACV,CACL,IAAIrhD,EAEFA,EADEvK,KAAKm/K,QAEmB,iBAAjBn/K,KAAKm/K,QACRvzH,EAAIoE,eAAehwD,KAAKm/K,SACxBn/K,KAAKm/K,QAEDr0I,EAAI8rB,mBAEZ52D,KAAK2qH,MA2If,SAAmCpgH,GAC7BA,EAAiC,wBACnCA,EAAiC,0BAEjC24N,GAAkB34N,EAEtB,CAhJQ85N,CAA0B95N,GAE1B24N,GAAkB34N,EAErB,CACF,CAKD,uBAAA+5N,GACE,MAAMx5L,EAAM9qC,KAAKsgD,SACjB,IAAKxV,EACH,OAEF,MAAMy5L,EAAkBvkO,KAAKojO,gBAC7BpjO,KAAKojO,gBAAkBJ,GAAal4L,EAAI+gB,oBACpC04K,IAAoBvkO,KAAKojO,kBAC3BpjO,KAAKikO,cAAcjkO,KAAKgkO,QAAShkO,KAAKojO,iBAClCpjO,KAAKojO,iBACPpyN,GAAYhR,KAAK+jO,iBAAkB/jO,KAAK6jO,YACxC7jO,KAAK4F,cAAcg9N,MAEnB5xN,GAAYhR,KAAK6jO,WAAY7jO,KAAK+jO,kBAClC/jO,KAAK4F,cAAcg9N,KAErB93L,EAAIu2B,aAEP,CAOD,aAAA4iK,CAAc15N,EAASi6N,GACjBA,GACFj6N,EAAQ2nD,UAAUxmD,UAAU1L,KAAK2jO,oBACjCp5N,EAAQ2nD,UAAUzuC,OAAOzjB,KAAKyjO,oBAE9Bl5N,EAAQ2nD,UAAUxmD,UAAU1L,KAAKyjO,kBACjCl5N,EAAQ2nD,UAAUzuC,OAAOzjB,KAAK2jO,oBAEjC,CAUD,MAAA5mL,CAAOjS,GACL,MAAM4gJ,EAAS1rL,KAAKsgD,SAChBorI,GACFA,EAAO5hL,qBACLuiD,GACArsD,KAAKqjO,6BAITp+N,MAAM83C,OAAOjS,GAEb9qC,KAAKsjO,yBACDx4L,GACFA,EAAIjhC,kBACFwiD,GACArsD,KAAKqjO,4BAGV,CAKD,sBAAAC,GACE,MAAM99N,EAAYxF,KAAKwjO,mBACvB,IAAK,IAAI5hO,EAAI,EAAGuE,EAAKX,EAAUrE,OAAQS,EAAIuE,IAAMvE,EAC/C0F,EAAc9B,EAAU5D,IAE1B4D,EAAUrE,OAAS,EAEnB,MAAM2pC,EAAM9qC,KAAKsgD,SACjB,GAAIxV,EAAK,CACP,MAAM8gB,EAAM9gB,EAAI+gB,mBACZg3K,GAAsBj3K,GACxB5rD,KAAKuK,QAAQ2nD,UAAUxmD,OAAOq1C,IAE9B/gD,KAAKuK,QAAQ2nD,UAAUzuC,IAAIs9B,IAG7B,IAAK,IAAIn/C,EAAI,EAAGuE,EAAKw8N,GAAOxhO,OAAQS,EAAIuE,IAAMvE,EAC5C4D,EAAUG,KACRoB,EAAO6kD,EAAK+2K,GAAO/gO,GAAI5B,KAAKskO,wBAAyBtkO,OAGzDA,KAAKskO,yBACN,CACF,GC9TH,MAAMG,GAAa,aAKbC,GAAoB,mBA4R1B,IAAAC,GAlPA,cAA4Bz0K,GAI1B,WAAApwD,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B,MAAMJ,EAAUwF,SAASC,cAAc,OACvCzF,EAAQ+iC,eACgB9mC,IAAtBmE,EAAQ2iC,UAA0B3iC,EAAQ2iC,UAAY,oBAExDroC,MAAM,CACJsF,QAASA,EACTuyC,OAAQnyC,EAAQmyC,OAChB38C,OAAQwK,EAAQxK,SAMlBH,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAEL3H,KAAK6J,kBAAkB46N,GAAYzkO,KAAKo4B,0BAEpCztB,EAAQi6N,kBACV5kO,KAAK6kO,oBAAoBl6N,EAAQi6N,kBAE/Bj6N,EAAQwU,YACVnf,KAAKs4B,cAAc3tB,EAAQwU,YAO7Bnf,KAAK8kO,uBAA4Ct+N,IAAxBmE,EAAQo6N,YAMjC/kO,KAAKglO,aAAehlO,KAAK8kO,kBAAoBn6N,EAAQo6N,YAAc,SAMnE/kO,KAAKilO,cAAgB16N,EAAQ25C,UAM7BlkD,KAAKklO,eAAiB,KAMtBllO,KAAKk4B,WAAa,KAMlBl4B,KAAK6kF,QAA2B,IAAlBl6E,EAAQuU,KACvB,CAKD,wBAAAkZ,GACEp4B,KAAKk4B,WAAa,IACnB,CAUD,mBAAAitM,GACE,OACEnlO,KAAKoJ,IAAIs7N,GAEZ,CASD,aAAA91M,GACE,OACE5uB,KAAKoJ,IAAIq7N,GAEZ,CAMD,eAAAW,CAAgBv/N,GACd,MAAMilC,EAAM9qC,KAAKsgD,SACjBtgD,KAAKqlO,YAAYv6L,EAAIge,cAAcjjD,GACpC,CAMD,cAAAy/N,CAAez/N,GACb7F,KAAKqlO,YAAY,KAClB,CAUD,MAAAtoL,CAAOjS,GAEL,GADA7lC,MAAM83C,OAAOjS,GACTA,EAAK,CACP,MAAM68C,EAAW78C,EAAIub,cACrBrmD,KAAK46B,aAAaj1B,KAChBoB,EAAO4gF,EAAU7/E,GAAuB9H,KAAKolO,gBAAiBplO,OAE5DA,KAAK8kO,mBACP9kO,KAAK46B,aAAaj1B,KAChBoB,EAAO4gF,EAAU7/E,GAAsB9H,KAAKslO,eAAgBtlO,OAGhEA,KAAKqlO,YAAY,KAClB,CACF,CASD,mBAAAR,CAAoB79M,GAClBhnB,KAAK+J,IAAI26N,GAAmB19M,EAC7B,CASD,aAAAsR,CAAcnZ,GACZnf,KAAK+J,IAAI06N,GAAY71M,GAAczP,GACpC,CAMD,WAAAkmN,CAAY/nL,GACV,IAAIioL,EAAOvlO,KAAKglO,aAChB,GAAI1nL,GAASt9C,KAAKklO,eAAgB,CAChC,IAAKllO,KAAKk4B,WAAY,CACpB,MAAM/Y,EAAanf,KAAK4uB,gBAEtB5uB,KAAKk4B,WADH/Y,EACgB+K,GAChBlqB,KAAKklO,eACL/lN,GAGgBqK,EAErB,CACD,MACMpS,EADMpX,KAAKsgD,SACMuY,+BAA+Bvb,GACtD,GAAIlmC,EAAY,CACd,MAAM2U,EAAiBE,KAQvB,GAPIF,IACF/rB,KAAKk4B,WAAahO,GAChBlqB,KAAKklO,eACLn5M,IAGJ/rB,KAAKk4B,WAAW9gB,EAAYA,GACxBpX,KAAK6kF,OAAQ,CAGf3lE,GAAM9H,EADJ2U,GAAkB/rB,KAAK4uB,iBAAmB5uB,KAAKklO,eAElD,CACD,MAAMN,EAAmB5kO,KAAKmlO,sBAE5BI,EADEX,EACKA,EAAiBxtN,GAEjBA,EAAWwB,UAErB,CACF,CACI5Y,KAAKilO,eAAiBM,IAASvlO,KAAKilO,gBACvCjlO,KAAKuK,QAAQ25C,UAAYqhL,EACzBvlO,KAAKilO,cAAgBM,EAExB,CAQD,MAAAzoL,CAAOiT,GACL,MAAMtS,EAAasS,EAAStS,WACvBA,EAGCz9C,KAAKklO,gBAAkBznL,EAAWjE,UAAUr6B,aAC9Cnf,KAAKklO,eAAiBznL,EAAWjE,UAAUr6B,WAC3Cnf,KAAKk4B,WAAa,MAJpBl4B,KAAKklO,eAAiB,IAOzB,GClRH,MAAMM,GAAY,IAOZC,GAAY,GAioBlB,IAAAC,GApmBA,cAA0Bx1K,GAIxB,WAAApwD,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B1F,MAAM,CACJsF,QAASwF,SAASC,cAAc,OAChC8sC,OAAQnyC,EAAQmyC,OAChB38C,OAAQwK,EAAQxK,SAMlBH,KAAK2lO,4BAA8B3lO,KAAK4lO,uBAAuB1+N,KAAKlH,MAMpEA,KAAKowD,gBACmB5pD,IAAtBmE,EAAQ0lD,WAA0B1lD,EAAQ0lD,UAM5CrwD,KAAKywD,kBACqBjqD,IAAxBmE,EAAQ6lD,aAA4B7lD,EAAQ6lD,YAEzCxwD,KAAKywD,eACRzwD,KAAKowD,YAAa,GAOpBpwD,KAAK+iJ,qBACwBv8I,IAA3BmE,EAAQuwI,gBAA+BvwI,EAAQuwI,eAMjDl7I,KAAK6lO,iBAAcr/N,EAEnB,MAAM8mC,OACkB9mC,IAAtBmE,EAAQ2iC,UAA0B3iC,EAAQ2iC,UAAY,iBAElDojB,OACiBlqD,IAArBmE,EAAQ+lD,SAAyB/lD,EAAQ+lD,SAAW,eAEhDE,OACsBpqD,IAA1BmE,EAAQimD,cAA8BjmD,EAAQimD,cAAgB,IAEnC,iBAAlBA,GAKT5wD,KAAK8wD,eAAiB/gD,SAASC,cAAc,QAC7ChQ,KAAK8wD,eAAeC,YAAcH,GAElC5wD,KAAK8wD,eAAiBF,EAGxB,MAAMhL,OAA0Bp/C,IAAlBmE,EAAQi7C,MAAsBj7C,EAAQi7C,MAAQ,IAEvC,iBAAVA,GAKT5lD,KAAKgxD,OAASjhD,SAASC,cAAc,QACrChQ,KAAKgxD,OAAOD,YAAcnL,GAE1B5lD,KAAKgxD,OAASpL,EAGhB,MAAMqL,EACJjxD,KAAKywD,eAAiBzwD,KAAKowD,WAAapwD,KAAK8wD,eAAiB9wD,KAAKgxD,OAC/DvF,EAAS17C,SAASC,cAAc,UACtCy7C,EAAO0F,aAAa,OAAQ,UAC5B1F,EAAO2F,MAAQV,EACfjF,EAAOv5C,YAAY++C,GAEnBxF,EAAOnmD,iBACLwC,EACA9H,KAAKqxD,aAAanqD,KAAKlH,OACvB,GAOFA,KAAK8lO,UAAY/1N,SAASC,cAAc,OACxChQ,KAAK8lO,UAAUx4L,UAAY,qBAO3BttC,KAAK+yN,MAAQpoN,EAAQ6yC,KAErB,MAAMuoL,EAAQ,IAAInpF,GAAI,CACpBp/F,KAAM7yC,EAAQ6yC,KACduW,SAAU,IAAIvpD,EACdkzD,aAAc,IAAIlzD,IAOpBxK,KAAKgmO,OAASD,EAEVp7N,EAAQo8C,QACVp8C,EAAQo8C,OAAO57C,SAAQ,SAAUyiC,GAC/Bm4L,EAAMpjK,SAAS/0B,EACvB,IAGI,MAAMk7B,EAAM/4D,SAASC,cAAc,OACnC84D,EAAIx7B,UAAY,qBAChBw7B,EAAIv4D,MAAM01N,UAAY,aAMtBjmO,KAAKkmO,YAAc,IAAIC,GAAQ,CAC7BjtM,SAAU,CAAC,EAAG,GACduuC,YAAa,gBACbl9D,QAASu+D,IAEX9oE,KAAKgmO,OAAOnjK,WAAW7iE,KAAKkmO,aAE5B,MAAM50K,EACJhkB,EACA,IACAwT,GACA,IACAE,IACChhD,KAAKowD,YAAcpwD,KAAKywD,aAAe,IAAMxP,GAAkB,KAC/DjhD,KAAKywD,aAAe,GAAK,qBACtBlmD,EAAUvK,KAAKuK,QACrBA,EAAQ+iC,UAAYgkB,EACpB/mD,EAAQ2H,YAAYlS,KAAK8lO,WACzBv7N,EAAQ2H,YAAYu5C,GAIpB,MAAM26K,EAAQpmO,KAER8iE,EAAU9iE,KAAKkmO,YACfG,EAAarmO,KAAKkmO,YAAYv+J,aAW9B68G,EAAO,SAAU3+K,GACrB,MAAMqzB,EAPC,CACLgzB,SAF0Co6K,EAQmBzgO,GANtCqmD,QACvBC,QAASm6K,EAAcn6K,SAHS,IAAUm6K,EAS5C,MAAM/sN,EAAcwsN,EAAMxiK,2BAChC,GAGMT,EAAQ4E,YAAYnuD,EAC1B,EAEUgtN,EAAY,SAAU1gO,GAC1B,MAAM0T,EAAcwsN,EAAMxiK,2BAA2B19D,GAErDugO,EAAM9lL,SAAS3C,UAAUxI,kBAAkB57B,GAE3CjK,OAAOhJ,oBAAoB,YAAak+K,GACxCl1K,OAAOhJ,oBAAoB,UAAWigO,EAC5C,EAIIF,EAAW/gO,iBAAiB,aAAa,WACvCgK,OAAOhK,iBAAiB,YAAak/K,GACrCl1K,OAAOhK,iBAAiB,UAAWihO,EACzC,GACG,CAUD,MAAAxpL,CAAOjS,GACL,MAAM4gJ,EAAS1rL,KAAKsgD,SACpB,GAAIxV,IAAQ4gJ,EAAZ,CAGA,GAAIA,EAAQ,CACV,MAAM86C,EAAU96C,EAAO/tI,UACnB6oL,GACFxmO,KAAKymO,YAAYD,GAEnBxmO,KAAKgmO,OAAOn2K,UAAU,KACvB,CAGD,GAFA5qD,MAAM83C,OAAOjS,GAETA,EAAK,CACP9qC,KAAKgmO,OAAOn2K,UAAU7vD,KAAK8lO,WAC3B9lO,KAAK46B,aAAaj1B,KAChBoB,EACE+jC,EACAzqC,EACAL,KAAK0mO,yBACL1mO,OAIJ,MAAMw9C,EAAO1S,EAAI6S,UACbH,IACFx9C,KAAK2mO,UAAUnpL,GACXA,EAAKvH,UACPj2C,KAAKgmO,OAAO3kK,aACZrhE,KAAK4mO,iBAIJ5mO,KAAKgmO,OAAOvgK,cACfzlE,KAAK6mO,gCAER,CAjCA,CAkCF,CAOD,wBAAAH,CAAyB7gO,GACvB,GAAIA,EAAM0B,MAAQ8kD,GAAkB,CAClC,MAAMm6K,EACJ3gO,EACR,SACU2gO,GACFxmO,KAAKymO,YAAYD,GAEnB,MAAMM,EAAU9mO,KAAKsgD,SAAS3C,UAC9B39C,KAAK2mO,UAAUG,EACrB,MACO9mO,KAAKgmO,OAAOvgK,cACZ5/D,EAAM0B,MAAQ8kD,IAAsBxmD,EAAM0B,MAAQ8kD,IAEnDrsD,KAAKgmO,OAAO3kK,YAEf,CAOD,SAAAslK,CAAUnpL,GACR,IAAKx9C,KAAK+yN,MAAO,CAEf,MAAM+T,EAAU,IAAIlpL,GAAK,CACvBz+B,WAAYq+B,EAAK5uB,kBAEnB5uB,KAAKgmO,OAAO7jK,QAAQ2kK,EACrB,CAEDtpL,EAAK3zC,kBACHqlC,GAAaG,SACbrvC,KAAK2lO,6BAGP3lO,KAAK4lO,wBACN,CAOD,WAAAa,CAAYjpL,GACVA,EAAK1zC,qBACHolC,GAAaG,SACbrvC,KAAK2lO,4BAER,CAMD,sBAAAC,GACM5lO,KAAK+iJ,iBACP/iJ,KAAKgmO,OAAOroL,UAAUzI,YAAYl1C,KAAKsgD,SAAS3C,UAAU7H,cAE7D,CAaD,eAAAixL,GACE,MAAMj8L,EAAM9qC,KAAKsgD,SACXylL,EAAQ/lO,KAAKgmO,OAEnB,IAAKl7L,EAAI26B,eAAiBsgK,EAAMtgK,aAC9B,OAGF,MAAMwD,EAAoDn+B,EAAIn3B,UAGxD6F,EADOsxB,EAAI6S,UACGpF,wBAAwB0wB,GAE5C,GAAIjpE,KAAK6lO,aAAet/J,GAAa/sD,EAAQxZ,KAAK6lO,aAEhD,OAEF7lO,KAAK6lO,YAAcrsN,EAEnB,MAAMwtN,EACJjB,EAAMpyN,UAIFszN,EADSlB,EAAMpoL,UACGpF,wBAAwByuL,GAE1CE,EAAenB,EAAMntK,+BACzB38C,GAAWzC,IAEP2tN,EAAmBpB,EAAMntK,+BAC7B78C,GAAevC,IAGX4tN,EAAWn7N,KAAKmP,IAAI8rN,EAAa,GAAKC,EAAiB,IACvDE,EAAYp7N,KAAKmP,IAAI8rN,EAAa,GAAKC,EAAiB,IAExDG,EAAaN,EAAU,GACvBO,EAAcP,EAAU,GAG5BI,EAAWE,EAAa7B,IACxB4B,EAAYE,EAAc9B,IAC1B2B,EAAWE,EAAa9B,IACxB6B,EAAYE,EAAc/B,GAE1BxlO,KAAK4mO,eACK5sN,GAAeitN,EAAUztN,IACnCxZ,KAAKwnO,WAER,CAOD,YAAAZ,GAKE,MAAM97L,EAAM9qC,KAAKsgD,SACXylL,EAAQ/lO,KAAKgmO,OAEb/8J,EAAoDn+B,EAAIn3B,UAGxD6F,EADOsxB,EAAI6S,UACGpF,wBAAwB0wB,GAEtCw+J,EAAS1B,EAAMpoL,UAKfqhC,EAAQ/yE,KAAKsW,IAAIijN,KAAyBv5N,KAAK0jG,IAErD3xF,GAAgBxE,EADF,GAAKvN,KAAKC,IAAI,EAAG8yE,EAAQ,GAAKymJ,KAE5CgC,EAAO3tL,YAAYD,GAAkBrgC,GACtC,CAOD,SAAAguN,GACE,MAAM18L,EAAM9qC,KAAKsgD,SACXylL,EAAQ/lO,KAAKgmO,OAEbxoL,EAAO1S,EAAI6S,UAEFooL,EAAMpoL,UAEdxI,kBAAkBqI,EAAKjI,oBAC/B,CAMD,UAAAmyL,GACE,MAAM58L,EAAM9qC,KAAKsgD,SACXylL,EAAQ/lO,KAAKgmO,OAEnB,IAAKl7L,EAAI26B,eAAiBsgK,EAAMtgK,aAC9B,OAGF,MAAMwD,EAAoDn+B,EAAIn3B,UAExD6pC,EAAO1S,EAAI6S,UAEX8pL,EAAS1B,EAAMpoL,UAEf/gC,EAAW5c,KAAK+iJ,gBAAkB,GAAKvlG,EAAK1H,cAE5CgtB,EAAU9iE,KAAKkmO,YACfp9J,EAAM9oE,KAAKkmO,YAAYv+J,aACvBjrD,EAAS8gC,EAAKjI,oBACd54B,EAAa6gC,EAAK9hB,gBAClBisM,EAAeF,EAAO/rM,gBACtBjsB,EAASw5D,EAAQ,GAAKtsD,EAAcgrN,EACpCj4N,EAAUu5D,EAAQ,GAAKtsD,EAAcgrN,EAM3C,GAHA7kK,EAAQ4E,YAAYhrD,GAGhBosD,EAAK,CACPA,EAAIv4D,MAAMd,MAAQA,EAAQ,KAC1Bq5D,EAAIv4D,MAAMb,OAASA,EAAS,KAC5B,MAAMsG,EAAY,UAAY4G,EAAW,OACzCksD,EAAIv4D,MAAMyF,UAAYA,CACvB,CACF,CAKD,8BAAA6wN,GACM7mO,KAAK4nO,sBAGT5nO,KAAK4nO,oBAAsBvgO,EACzBrH,KAAKgmO,OACL55K,IACA,SAAUvmD,UACD7F,KAAK4nO,oBACZ5nO,KAAK0nO,YACN,GACD1nO,MAEH,CAMD,YAAAqxD,CAAaxrD,GACXA,EAAMzF,iBACNJ,KAAKiyD,eACN,CAKD,aAAAA,GACEjyD,KAAKuK,QAAQ2nD,UAAUC,OAAOlR,IAC1BjhD,KAAKowD,WACPp/C,GAAYhR,KAAK8wD,eAAgB9wD,KAAKgxD,QAEtChgD,GAAYhR,KAAKgxD,OAAQhxD,KAAK8wD,gBAEhC9wD,KAAKowD,YAAcpwD,KAAKowD,WAIxB,MAAM21K,EAAQ/lO,KAAKgmO,OACnB,IAAKhmO,KAAKowD,WAAY,CACpB,GAAI21K,EAAMtgK,aAGR,OAFAzlE,KAAK6lO,iBAAcr/N,OACnBu/N,EAAMjpL,SAGRipL,EAAM1kK,aACNrhE,KAAK4mO,eACL5mO,KAAK6mO,gCACN,CACF,CAOD,cAAAz0K,GACE,OAAOpyD,KAAKywD,YACb,CAOD,cAAAsB,CAAevB,GACTxwD,KAAKywD,eAAiBD,IAG1BxwD,KAAKywD,aAAeD,EACpBxwD,KAAKuK,QAAQ2nD,UAAUC,OAAO,qBACzB3B,GAAexwD,KAAKowD,YACvBpwD,KAAKiyD,gBAER,CASD,YAAAI,CAAahC,GACNrwD,KAAKywD,cAAgBzwD,KAAKowD,aAAeC,GAG9CrwD,KAAKiyD,eACN,CAOD,YAAAK,GACE,OAAOtyD,KAAKowD,UACb,CAOD,iBAAAioB,GACE,OAAOr4E,KAAK+iJ,eACb,CAOD,iBAAAU,CAAkBvI,GACZl7I,KAAK+iJ,kBAAoB7H,IAG7Bl7I,KAAK+iJ,gBAAkB7H,EACuB,IAA1Cl7I,KAAKsgD,SAAS3C,UAAU7H,gBACtB91C,KAAK+iJ,gBACP/iJ,KAAK4lO,yBAEL5lO,KAAKgmO,OAAOroL,UAAUzI,YAAY,GAEpCl1C,KAAK6lO,iBAAcr/N,EACnBxG,KAAK+mO,kBACL/mO,KAAK0nO,cAER,CAOD,cAAAG,GACE,OAAO7nO,KAAKgmO,MACb,CAOD,MAAAlpL,CAAOiT,GACL/vD,KAAK+mO,kBACL/mO,KAAK0nO,YACN,GCzpBH,MAAMI,GAAa,QAWbC,GAAiB,CAAC,EAAG,EAAG,GAMxBC,GAAc,KAAO,IAqc3B,IAAAC,GAtZA,cAAwB/3K,GAItB,WAAApwD,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B,MAAMJ,EAAUwF,SAASC,cAAc,OACvCzF,EAAQgG,MAAMo/C,cAAgB,OAE9B1qD,MAAM,CACJsF,QAASA,EACTuyC,OAAQnyC,EAAQmyC,OAChB38C,OAAQwK,EAAQxK,SAMlBH,KAAK0H,GAKL1H,KAAKiH,KAKLjH,KAAK2H,GAEL,MAAM2lC,OACkB9mC,IAAtBmE,EAAQ2iC,UACJ3iC,EAAQ2iC,UACR3iC,EAAQu9N,IACR,eACA,gBAMNloO,KAAKmoO,cAAgBp4N,SAASC,cAAc,OAC5ChQ,KAAKmoO,cAAc76L,UAAYA,EAAY,SAE3CttC,KAAKuK,QAAQ+iC,UAAYA,EAAY,IAAMwT,GAC3C9gD,KAAKuK,QAAQ2H,YAAYlS,KAAKmoO,eAM9BnoO,KAAKooO,WAAa,KAMlBpoO,KAAKqoO,eAAiC7hO,IAArBmE,EAAQ29N,SAAyB39N,EAAQ29N,SAAW,GAMrEtoO,KAAKuoO,UAAY59N,EAAQ69N,SAMzBxoO,KAAKwmD,kBAAmB,EAMxBxmD,KAAKyoO,oBAAiBjiO,EAMtBxG,KAAKilO,cAAgB,GAErBjlO,KAAK6J,kBAAkBi+N,GAAY9nO,KAAK0oO,qBAExC1oO,KAAK2oO,SAASh+N,EAAQgY,OAAS,UAM/B3iB,KAAK4oO,UAAYj+N,EAAQu9N,MAAO,EAMhCloO,KAAK6oO,eAAiBl+N,EAAQq0E,OAAS,EAMvCh/E,KAAK8oO,cAAgBn+N,EAAQi4C,OAAQ,EAMrC5iD,KAAK+oO,KAAOp+N,EAAQ4pG,UAAO/tG,CAC5B,CASD,QAAA6a,GACE,OAAOrhB,KAAKoJ,IAAI0+N,GACjB,CAKD,mBAAAY,GACE1oO,KAAKgyD,gBACN,CAQD,QAAA22K,CAAShmN,GACP3iB,KAAK+J,IAAI+9N,GAAYnlN,EACtB,CAOD,MAAAqmN,CAAOz0H,GACLv0G,KAAK+oO,KAAOx0H,CACb,CAKD,cAAAviD,GACE,MAAMxY,EAAYx5C,KAAKooO,WAEvB,IAAK5uL,EAKH,YAJIx5C,KAAKwmD,mBACPxmD,KAAKuK,QAAQgG,MAAM+zC,QAAU,OAC7BtkD,KAAKwmD,kBAAmB,IAK5B,MAAM9pC,EAAS88B,EAAU98B,OACnByC,EAAaq6B,EAAUr6B,WACvBwD,EAAQ3iB,KAAKqhB,WACb4nN,EAAgC,WAATtmN,EAAqB,UAAY,IAC9D,IAAIqH,EAAkBhJ,GACpB7B,EACAq6B,EAAU78B,WACVD,EACAusN,GAGF,MAAMX,EACHtoO,KAAKqoO,WAAaroO,KAAK+oO,MAAQf,IAAgBA,GAE5CQ,OACehiO,IAAnBxG,KAAKuoO,UACAvoO,KAAKuoO,WAAavoO,KAAK+oO,MAAQf,IAAgBA,QAChDxhO,EAEN,IAAI0iO,EAAeZ,EAAWt+M,EAC1Bm/M,EAAS,GACb,GAAa,WAATxmN,EAAoB,CACtB,MAAMymN,EAAkBtpN,GAAgBG,QACxCipN,GAAgBE,EACZF,EAAeE,EAAkB,IACnCD,EAAS,IACTn/M,GAAmB,MACVk/M,EAAeE,GACxBD,EAAS,IACTn/M,GAAmB,IAEnBm/M,EAAS,GAEjB,MAAW,GAAa,YAATxmN,EACLumN,EAAe,OACjBC,EAAS,KACTn/M,GAAmB,OACVk/M,EAAe,UACxBC,EAAS,KACTn/M,GAAmB,QAEnBm/M,EAAS,KACTn/M,GAAmB,eAEhB,GAAa,YAATrH,EACTqH,GAAmB,KACnBm/M,EAAS,UACJ,GAAa,UAATxmN,EACLumN,EAAe,MACjBC,EAAS,KACTn/M,GAAmB,KACVk/M,EAAe,GACxBC,EAAS,KACTn/M,GAAmB,KACVk/M,EAAe,IACxBC,EAAS,KAETA,EAAS,KACTn/M,GAAmB,SAEhB,IAAa,MAATrH,EAYT,MAAM,IAAIna,MAAM,iBAXZ0gO,EAAe,OACjBC,EAAS,KACTn/M,GAAmB,OACVk/M,EAAe,UACxBC,EAAS,KACTn/M,GAAmB,YAEnBm/M,EAAS,KACTn/M,GAAmB,UAItB,CAED,IACI8jC,EAAOr+C,EAAO45N,EACdC,EAAeC,EAAeC,EAF9B5nO,EAAI,EAAIqK,KAAKuT,MAAMvT,KAAKsW,IAAI+lN,EAAWt+M,GAAmB/d,KAAKsW,IAAI,KAGvE,OAAa,CACX8mN,EAAep9N,KAAKuT,MAAM5d,EAAI,GAC9B,MAAM4jB,EAAUvZ,KAAKC,IAAI,GAAIm9N,GAG7B,GAFAv7K,EAAQi6K,IAAiBnmO,EAAI,EAAK,GAAK,GAAK4jB,EAC5C/V,EAAQxD,KAAKiZ,MAAM4oC,EAAQ9jC,GACvBwE,MAAM/e,GAGR,OAFAzP,KAAKuK,QAAQgG,MAAM+zC,QAAU,YAC7BtkD,KAAKwmD,kBAAmB,GAG1B,QAAiBhgD,IAAbgiO,GAA0B/4N,GAAS+4N,EAAU,CAC/C16K,EAAQw7K,EACR75N,EAAQ85N,EACRF,EAAeG,EACf,KACR,CAAa,GAAI/5N,GAAS64N,EAClB,MAEFgB,EAAgBx7K,EAChBy7K,EAAgB95N,EAChB+5N,EAAuBH,IACrBznO,CACH,CACD,MAAM2jO,EAAOvlO,KAAK4oO,UACd5oO,KAAKypO,eAAeh6N,EAAOq+C,EAAOq7K,GAClCr7K,EAAM/oC,QAAQskN,EAAe,GAAKA,EAAe,GAAK,IAAMF,EAE5DnpO,KAAKilO,eAAiBM,IACxBvlO,KAAKmoO,cAAcjkL,UAAYqhL,EAC/BvlO,KAAKilO,cAAgBM,GAGnBvlO,KAAKyoO,gBAAkBh5N,IACzBzP,KAAKmoO,cAAc53N,MAAMd,MAAQA,EAAQ,KACzCzP,KAAKyoO,eAAiBh5N,GAGnBzP,KAAKwmD,mBACRxmD,KAAKuK,QAAQgG,MAAM+zC,QAAU,GAC7BtkD,KAAKwmD,kBAAmB,EAE3B,CASD,cAAAijL,CAAeh6N,EAAOkI,EAAOwxN,GAC3B,MAAMO,EAAkB1pO,KAAK2pO,wBACvBC,EACJF,EAAkB,EACdz9N,KAAKiZ,MAAM,EAAIwkN,GAAiBz6H,iBAAmB,OACnD,OAAShjG,KAAKiZ,MAAMwkN,GAAiBz6H,iBACrCjwB,EAAQh/E,KAAK6oO,eACbgB,EAAYp6N,EAAQuvE,EACpB8qJ,EAAa,CAAC9pO,KAAK+pO,aAAa,aACtC,IAAK,IAAInoO,EAAI,EAAGA,EAAIo9E,IAASp9E,EAAG,CAC9B,MAAMooO,EACJpoO,EAAI,GAAM,EAAI,yBAA2B,0BAC3CkoO,EAAWnkO,KAGP,uCAA6BqkO,oBACZH,eAGjB7pO,KAAK+pO,aAAa,aAEjBnoO,EAAI,GAAM,GAAe,IAAVo9E,EACZh/E,KAAKiqO,eAAeroO,EAAG6N,GAAO,EAAOkI,EAAOwxN,GAC5C,IACJ,SAEL,CAEDW,EAAWnkO,KAAK3F,KAAKiqO,eAAejrJ,EAAOvvE,GAAO,EAAMkI,EAAOwxN,IAO/D,OALqBnpO,KAAK8oO,cACtB,4CAA4Cr5N,SAC5Cm6N,EACA,SACA,IACkBE,EAAWhxN,KAAK,GACvC,CAOD,YAAAixN,CAAa7wM,GAEX,MAGE,sDAAoBA,WAJG,aAAbA,EAA0B,GAAK,eAO5C,CAWD,cAAA+wM,CAAeroO,EAAG6N,EAAOy6N,EAAQvyN,EAAOwxN,GACtC,MAEMgB,GADE,IAANvoO,EAAU,EAAIqK,KAAKiZ,MAAOvN,EAAQ3X,KAAK6oO,eAAkBjnO,EAAI,KAAO,MACjC,IAANA,EAAU,GAAK,IAAMunO,GAGpD,MAIE,uDANmB,IAANvnO,GAAW,EAAK6N,EAAQzP,KAAK6oO,gBAAmB,mBAOxC,IAANjnO,EAAU,OAAS,uBANb,IAANA,EAAU,EAAK6N,EAAQzP,KAAK6oO,eAAkB,aAQpDqB,EAASz6N,EAAQ,KAAO,aAEjC06N,EACA,QAEH,CAMD,qBAAAR,GASE,OARmB3oN,GACjBhhB,KAAKooO,WAAWjpN,WAChBnf,KAAKooO,WAAWzrN,WAChB3c,KAAKooO,WAAW1rN,OAChB,MAGqB,IAAO,OADlB1c,KAAK+oO,MAAQf,GAG1B,CAOD,MAAAlrL,CAAOiT,GACL,MAAMtS,EAAasS,EAAStS,WAI1Bz9C,KAAKooO,WAHF3qL,EAGeA,EAAWjE,UAFX,KAIpBx5C,KAAKgyD,gBACN,GC3cH,MAAMo4K,GACM,EADNA,GAEQ,EAkXd,IAAAC,GA3VA,cAAyBn6K,GAIvB,WAAApwD,CAAY6K,GAGV1F,MAAM,CACJ9E,QAHFwK,EAAUA,GAAoB,IAGZxK,OAChBoK,QAASwF,SAASC,cAAc,OAChC8sC,OAAQnyC,EAAQmyC,SAOlB98C,KAAKoqD,kBAAoB,GAQzBpqD,KAAKsqO,wBAAqB9jO,EAS1BxG,KAAKuqO,WAAaH,GAMlBpqO,KAAKmqD,UAMLnqD,KAAKwqO,aAAe,EAMpBxqO,KAAKyqO,YAAc,EAMnBzqO,KAAK0qO,QAML1qO,KAAK2qO,QAQL3qO,KAAK4qO,WAAa,KAOlB5qO,KAAK6qO,oBAAqB,EAM1B7qO,KAAK2yD,eAAiCnsD,IAArBmE,EAAQwzB,SAAyBxzB,EAAQwzB,SAAW,IAErE,MAAMmP,OACkB9mC,IAAtBmE,EAAQ2iC,UAA0B3iC,EAAQ2iC,UAAY,gBAClDw9L,EAAe/6N,SAASC,cAAc,UAC5C86N,EAAa35K,aAAa,OAAQ,UAClC25K,EAAax9L,UAAYA,EAAY,UAAYwT,GACjD,MAAMiqL,EAAmB/qO,KAAKuK,QAC9BwgO,EAAiBz9L,UACfA,EAAY,IAAMwT,GAAqB,IAAME,GAC/C+pL,EAAiB74N,YAAY44N,GAE7BC,EAAiBzlO,iBACfukD,GACA7pD,KAAKgrO,oBAAoB9jO,KAAKlH,OAC9B,GAEF+qO,EAAiBzlO,iBACfukD,GACA7pD,KAAKirO,mBAAmB/jO,KAAKlH,OAC7B,GAEF+qO,EAAiBzlO,iBACfukD,GACA7pD,KAAKkrO,kBAAkBhkO,KAAKlH,OAC5B,GAGF+qO,EAAiBzlO,iBACfwC,EACA9H,KAAKmrO,sBAAsBjkO,KAAKlH,OAChC,GAEF8qO,EAAaxlO,iBAAiBwC,EAAiBnI,GAAiB,EACjE,CAUD,MAAAo9C,CAAOjS,GACL7lC,MAAM83C,OAAOjS,GACTA,GACFA,EAAIgS,QAEP,CAUD,WAAAsuL,GACE,MAAMhlL,EAAYpmD,KAAKuK,QACvB,IAAI8gO,EAAiBjlL,EAAU91C,YAC3Bg7N,EAAkBllL,EAAUv1C,aAChC,GAAuB,IAAnBw6N,GAA4C,IAApBC,EAC1B,OAAQtrO,KAAK6qO,oBAAqB,EAGpC,MAAMU,EAAiB/6N,iBAAiB41C,GACxCilL,GACEtgM,WAAWwgM,EAA6B,cACxCxgM,WAAWwgM,EAA4B,aACzCD,GACEvgM,WAAWwgM,EAA2B,YACtCxgM,WAAWwgM,EAA8B,eAC3C,MAAMC,EAAoCplL,EAA2B,kBAC/DqlL,EAAaj7N,iBAAiBg7N,GAC9BE,EACJF,EAAMl7N,YACNy6B,WAAW0gM,EAAwB,aACnC1gM,WAAW0gM,EAAuB,YAC9BE,EACJH,EAAM36N,aACNk6B,WAAW0gM,EAAsB,WACjC1gM,WAAW0gM,EAAyB,cAUtC,OATAzrO,KAAK4qO,WAAa,CAACc,EAAYC,GAE3BN,EAAiBC,GACnBtrO,KAAKuqO,WAAaH,GAClBpqO,KAAKyqO,YAAcY,EAAiBK,IAEpC1rO,KAAKuqO,WAAaH,GAClBpqO,KAAKwqO,aAAec,EAAkBK,GAEhC3rO,KAAK6qO,oBAAqB,CACnC,CAMD,qBAAAM,CAAsBtlO,GACpB,MAAM23C,EAAOx9C,KAAKsgD,SAAS3C,UAErBiuL,EAAmB5rO,KAAK6rO,qBAC5BhmO,EAAM4vC,QAAUz1C,KAAK4qO,WAAW,GAAK,EACrC/kO,EAAM6vC,QAAU11C,KAAK4qO,WAAW,GAAK,GAGjCjuN,EAAa3c,KAAK8rO,0BAA0BF,GAC5Cx2L,EAAOoI,EAAKxB,mBAAmBwB,EAAK/E,qBAAqB97B,IAE/D6gC,EAAKpH,gBAAgB,CACnBhB,KAAMA,EACNjX,SAAUn+B,KAAK2yD,UACfpc,OAAQpqC,IAEX,CAOD,mBAAA6+N,CAAoBnlO,GAClB,IAAK7F,KAAKmqD,WAAatkD,EAAM1F,SAAWH,KAAKuK,QAAQmzG,kBAAmB,CACtE,MAAMnzG,EACJvK,KAAKuK,QACb,kBAMM,GALAvK,KAAKsgD,SAAS3C,UAAU9B,mBACxB77C,KAAK0qO,QAAU7kO,EAAMqmD,QAAUnhB,WAAWxgC,EAAQgG,MAAMg0C,MACxDvkD,KAAK2qO,QAAU9kO,EAAMsmD,QAAUphB,WAAWxgC,EAAQgG,MAAMipD,KACxDx5D,KAAKmqD,WAAY,EAEqB,IAAlCnqD,KAAKoqD,kBAAkBjpD,OAAc,CACvC,MAAM4qO,EAAO/rO,KAAKirO,mBACZjpO,EAAMhC,KAAKkrO,kBACXt/K,EAAM5rD,KAAKsgD,SAASuL,mBAC1B7rD,KAAKoqD,kBAAkBzkD,KACrBoB,EAAO6kD,EAAK/B,GAA8BkiL,EAAM/rO,MAChD+G,EAAO6kD,EAAK/B,GAA4B7nD,EAAKhC,MAEhD,CACF,CACF,CAQD,kBAAAirO,CAAmBplO,GACjB,GAAI7F,KAAKmqD,UAAW,CAClB,MAAMlsC,EAASpY,EAAMqmD,QAAUlsD,KAAK0qO,QAC9BxsN,EAASrY,EAAMsmD,QAAUnsD,KAAK2qO,QAC9BiB,EAAmB5rO,KAAK6rO,qBAAqB5tN,EAAQC,GAC3Dle,KAAKsqO,mBACHtqO,KAAK8rO,0BAA0BF,GACjC5rO,KAAKsgD,SAAS3C,UAAU5hB,cAAc/7B,KAAKsqO,mBAC5C,CACF,CAOD,iBAAAY,CAAkBrlO,GAChB,GAAI7F,KAAKmqD,UAAW,CACLnqD,KAAKsgD,SAAS3C,UACtB7B,iBAEL97C,KAAKmqD,WAAY,EACjBnqD,KAAK0qO,aAAUlkO,EACfxG,KAAK2qO,aAAUnkO,EACfxG,KAAKoqD,kBAAkBj/C,QAAQ7D,GAC/BtH,KAAKoqD,kBAAkBjpD,OAAS,CACjC,CACF,CAQD,iBAAA6qO,CAAkB9oO,GAChB,MAAMg2B,EAAWl5B,KAAKisO,0BAA0B/oO,GAC1CsoO,EAAoCxrO,KAAKuK,QAAyB,kBAEpEvK,KAAKuqO,YAAcH,GACrBoB,EAAMj7N,MAAMg0C,KAAOvkD,KAAKyqO,YAAcvxM,EAAW,KAEjDsyM,EAAMj7N,MAAMipD,IAAMx5D,KAAKwqO,aAAetxM,EAAW,IAEpD,CAYD,oBAAA2yM,CAAqBx0N,EAAGC,GACtB,IAAI40N,EAMJ,OAJEA,EADElsO,KAAKuqO,aAAeH,GACb/yN,EAAIrX,KAAKyqO,YAETnzN,EAAItX,KAAKwqO,aAEb1mN,GAAMooN,EAAQ,EAAG,EACzB,CAUD,yBAAAJ,CAA0B5yM,GAExB,OADWl5B,KAAKsgD,SAAS3C,UAAU5E,+BAC5Bx1C,CAAG,EAAI21B,EACf,CAWD,yBAAA+yM,CAA0B/oO,GAExB,OAAO4gB,GAAM,EADF9jB,KAAKsgD,SAAS3C,UAAU1E,+BAClB11C,CAAGL,GAAM,EAAG,EAC9B,CAOD,MAAA45C,CAAOiT,GACL,IAAKA,EAAStS,WACZ,OAEF,IAAKz9C,KAAK6qO,qBAAuB7qO,KAAKorO,cACpC,OAEF,MAAMloO,EAAM6sD,EAAStS,WAAWjE,UAAU78B,WAC1C3c,KAAKsqO,mBAAqBpnO,EAC1BlD,KAAKgsO,kBAAkB9oO,EACxB,GCtSH,IAAAipO,GAlEA,cAA2Bj8K,GAIzB,WAAApwD,CAAY6K,GACVA,EAAUA,GAAoB,GAE9B1F,MAAM,CACJsF,QAASwF,SAASC,cAAc,OAChC7P,OAAQwK,EAAQxK,SAOlBH,KAAKwZ,OAAS7O,EAAQ6O,OAAS7O,EAAQ6O,OAAS,KAEhD,MAAM8zB,OACkB9mC,IAAtBmE,EAAQ2iC,UAA0B3iC,EAAQ2iC,UAAY,iBAElDsY,OAA0Bp/C,IAAlBmE,EAAQi7C,MAAsBj7C,EAAQi7C,MAAQ,IACtD8K,OACiBlqD,IAArBmE,EAAQ+lD,SAAyB/lD,EAAQ+lD,SAAW,gBAChDjF,EAAS17C,SAASC,cAAc,UACtCy7C,EAAO0F,aAAa,OAAQ,UAC5B1F,EAAO2F,MAAQV,EACfjF,EAAOv5C,YACY,iBAAV0zC,EAAqB71C,SAAS0jD,eAAe7N,GAASA,GAG/D6F,EAAOnmD,iBACLwC,EACA9H,KAAKqxD,aAAanqD,KAAKlH,OACvB,GAGF,MAAMsxD,EACJhkB,EAAY,IAAMwT,GAAqB,IAAME,GACzCz2C,EAAUvK,KAAKuK,QACrBA,EAAQ+iC,UAAYgkB,EACpB/mD,EAAQ2H,YAAYu5C,EACrB,CAMD,YAAA4F,CAAaxrD,GACXA,EAAMzF,iBACNJ,KAAKosO,oBACN,CAKD,kBAAAA,GACE,MACM5uL,EADMx9C,KAAKsgD,SACA3C,UACXnkC,EAAUxZ,KAAKwZ,OAEjBxZ,KAAKwZ,OADLgkC,EAAK5uB,gBAAgBvP,YAEzBm+B,EAAK1D,YAAYD,GAAkBrgC,GACpC,GCwwBC6yN,GAAK,CAAG,SACZA,GAAG7hO,WAAa8hO,EAChBD,GAAG7hO,WAAWF,gBAAkBiiO,EAChCF,GAAGtrI,SAAW5tF,GACdk5N,GAAGtrI,SAASxuF,YAAci6N,GAC1BH,GAAGtrI,SAAS5uF,YAAcs6N,GAC1BJ,GAAGtrI,SAASluF,QAAU65N,GACtBL,GAAGrnO,WAAa1E,EAChB+rO,GAAGj4N,QAAUwB,GACby2N,GAAGj4N,QAAQoB,oBAAsBm3N,GACjCN,GAAGO,YAAc50M,GACjBq0M,GAAGO,YAAY/0M,iBAAmBg1M,GAClCR,GAAGt9N,MAAQosB,GACXkxM,GAAGt9N,MAAMC,OAAS89N,GAClBT,GAAGt9N,MAAMksB,eAAiB8xM,GAC1BV,GAAGt9N,MAAMsrB,YAAc2yM,GACvBX,GAAGt9N,MAAMzB,KAAO2/N,GAChBZ,GAAGj4H,YAAcp4E,GACjBqwM,GAAGz/I,UAAYxwD,GACfiwM,GAAG1uK,QAAUvgC,GACbivM,GAAGzvF,IAAMx9E,GACTitK,GAAGlhL,gBAAkB5C,GACrB8jL,GAAGjnK,uBAAyBtb,GAC5BuiL,GAAG7jL,SAAWF,GACd+jL,GAAG3lO,OAASsC,EACZqjO,GAAG3lO,OAAOoC,YAAcokO,EACxBb,GAAG7kO,WAAac,EAChB+jO,GAAG7kO,WAAWa,QAAU8kO,EACxBd,GAAGlG,QAAUt/J,GACbwlK,GAAGj5N,KAAO9G,GACV+/N,GAAGtjJ,UAAY7d,GACfmhK,GAAGzqK,UAAYvT,GACfg+K,GAAGzqK,UAAUvS,gBAAkB+9K,GAC/Bf,GAAGhhK,UAAYE,GACf8gK,GAAGhhK,UAAU3wD,eAAiB2yN,GAC9BhB,GAAGvwH,iBAAmBtwC,GACtB6gK,GAAGiB,WAAaxgK,GAChBu/J,GAAGzuL,KAAOnK,GACV44L,GAAGzuL,KAAKlM,uBAAyB67L,GACjClB,GAAGzuL,KAAK7L,2BAA6By7L,GACrCnB,GAAGzuL,KAAKnL,yBAA2Bg7L,GACnCpB,GAAGzuL,KAAK/K,gBAAkB66L,GAC1BrB,GAAG3hO,MAAQ,CAAA,EACX2hO,GAAG3hO,MAAM1J,UAAY2sO,EACrBtB,GAAG3hO,MAAMhK,aAAektO,EACxBvB,GAAG3hO,MAAMnJ,WAAassO,EACtBxB,GAAG3hO,MAAMnI,OAASurO,EAClBzB,GAAG3hO,MAAMxI,OAAS6rO,EAClB1B,GAAG3hO,MAAM/H,SAAWqrO,EACpB3B,GAAG3hO,MAAMlJ,kBAAoBysO,EAC7B5B,GAAG3hO,MAAMgB,O7VnuBF,SAAgBjK,EAAKkH,GAC1B,MAAM/G,EAAIH,EAAImF,QAAQ+B,GAChBvH,EAAQQ,GAAK,EAInB,OAHIR,GACFK,EAAIoF,OAAOjF,EAAG,GAETR,CACT,E6V6tBAirO,GAAG3hO,MAAM5I,gBAAkBosO,EAC3B7B,GAAG3hO,MAAMyjO,W7VnsBF,SAAoB1sO,EAAK2sO,GAC9B,MAAMjtO,EAASM,EAAIN,OACbc,EAAMI,MAAMZ,EAAIN,QACtB,IAAIS,EACJ,IAAKA,EAAI,EAAGA,EAAIT,EAAQS,IACtBK,EAAIL,GAAK,CAACqB,MAAOrB,EAAGyC,MAAO5C,EAAIG,IAKjC,IAHAK,EAAIqyB,MAAK,SAAUjzB,EAAGC,GACpB,OAAO8sO,EAAW/sO,EAAEgD,MAAO/C,EAAE+C,QAAUhD,EAAE4B,MAAQ3B,EAAE2B,KACvD,IACOrB,EAAI,EAAGA,EAAIH,EAAIN,OAAQS,IAC1BH,EAAIG,GAAKK,EAAIL,GAAGyC,KAEpB,E6VurBAgoO,GAAGgC,QAAU,CAAA,EACbhC,GAAGgC,QAAQp6N,OAASq6N,GACpBjC,GAAGkC,iBAAmB,CAAA,EACtBlC,GAAGkC,iBAAiB/+L,aAAeg/L,GACnCnC,GAAGkC,iBAAiBvlN,KAAOylN,GAC3BpC,GAAGpiM,MAAQ,CAAA,EACXoiM,GAAGpiM,MAAM2B,QAAU8iM,GACnBrC,GAAGpiM,MAAMkB,SAAWwjM,GACpBtC,GAAGpiM,MAAMwB,WAAamjM,GACtBvC,GAAGpiM,MAAM4B,cAAgBgjM,GACzBxC,GAAGpiM,MAAMuB,WAAasjM,GACtBzC,GAAGpiM,MAAM0B,UAAYojM,GACrB1C,GAAGpiM,MAAMsB,WAAayjM,GACtB3C,GAAGpiM,MAAMrxB,SAAWq2N,GACpB5C,GAAGpiM,MAAMqB,UAAY4jM,GACrB7C,GAAG8C,UAAY,CAAA,EACf9C,GAAG8C,UAAU3hK,YAAc4hK,GAC3B/C,GAAGljN,QAAU,CAAA,EACbkjN,GAAGljN,QAAQ5Z,MAAQ8/N,GACnBhD,GAAGljN,QAAQ5G,I7Tr4BJ,YAAgB2G,GACjBD,GAAQJ,GAAOC,MAGnBK,QAAQ5G,OAAO2G,EACjB,E6Ti4BAmjN,GAAGljN,QAAQmmN,S7T74BJ,SAAkBtwN,GACvBiK,GAAQJ,GAAO7J,EACjB,E6T44BAqtN,GAAGljN,QAAQJ,KAAOwmN,GAClBlD,GAAGhqK,QAAU,CAAA,EACbgqK,GAAGhqK,QAAQhO,YAAcpE,GACzBo8K,GAAGhqK,QAAQnS,QAAUR,GACrB28K,GAAGhqK,QAAQmtK,WAAarM,GACxBkJ,GAAGhqK,QAAQotK,cAAgB9K,GAC3B0H,GAAGhqK,QAAQqtK,YAAchK,GACzB2G,GAAGhqK,QAAQnO,OAAS3B,GACpB85K,GAAGhqK,QAAQstK,UAAY1H,GACvBoE,GAAGhqK,QAAQrO,KAAOf,GAClBo5K,GAAGhqK,QAAQutK,WAAavF,GACxBgC,GAAGhqK,QAAQwtK,aAAe1D,GAC1BE,GAAGhqK,QAAQvO,SAAW,GACtBu4K,GAAGhqK,QAAQvO,SAASA,SAAWg8K,GAC/BzD,GAAGj1N,WAAa,CAAA,EAChBi1N,GAAGj1N,WAAWqM,IAAMssN,GACpB1D,GAAGj1N,WAAW6O,gBAAkB+pN,GAChC3D,GAAGj1N,WAAWiP,iBAAmB4pN,GACjC5D,GAAGj1N,WAAW84N,e/T/yBP,SAAwBxpN,GAC7B,OAAA,SAKYtP,GACR,OAAOsQ,GAAWtQ,EAAYsP,EAEhC,CACJ,E+TsyBA2lN,GAAGj1N,WAAWoP,oBAAsB2pN,GACpC9D,GAAGj1N,WAAWoQ,SAAW4oN,GACzB/D,GAAGj1N,WAAW7U,OAAS8tO,GACvBhE,GAAGj1N,WAAW4P,OAASspN,GACvBjE,GAAGj1N,WAAWwQ,cAAgB2oN,GAC9BlE,GAAGj1N,WAAWG,OAASi5N,GACvBnE,GAAGj1N,WAAWO,MAAQ84N,GACtBpE,GAAGj1N,WAAW4M,gBAAkB0sN,GAChCrE,GAAGj1N,WAAWqQ,yBAA2BkpN,GACzCtE,GAAGj1N,WAAWw5N,a/ThmBP,SAAsBx5N,EAAYsP,GACvC,OAAItP,EAEAoP,GAAoB,KAAMpP,EAAW,GAAIsP,GACzC,IACAF,GAAoB,KAAMpP,EAAW,GAAIsP,GAGtC,EACT,E+TwlBA2lN,GAAGj1N,WAAWsQ,WAAampN,GAC3BxE,GAAGj1N,WAAW8H,MAAQ4xN,GACtBzE,GAAG0E,IAAM,CAAA,EACT1E,GAAG0E,IAAI9vL,gBAAkB+vL,GACzB3E,GAAG0E,IAAI/vL,cAAgBiwL,GACvB5E,GAAG0E,IAAInwL,aAAeswL,GACtB7E,GAAG0E,IAAIlwL,iBAAmBswL,GAC1B9E,GAAG0E,IAAIjwL,mBAAqBswL,GAC5B/E,GAAG0E,IAAIhwL,kBAAoBswL,GAC3BhF,GAAG0E,IAAI1vL,kBAAoBiwL,GAC3BjF,GAAGkF,IAAM,CAAA,EACTlF,GAAGkF,IAAI/hO,sBAAwBgiO,GAC/BnF,GAAGkF,IAAI3gO,YAAc6gO,GACrBpF,GAAGkF,IAAIlhO,WAAaqhO,GACpBrF,GAAGkF,IAAIrhO,cAAgByhO,GACvBtF,GAAGkF,IAAI9/N,eAAiBmgO,GACxBvF,GAAGkF,IAAIjgO,WAAaugO,GACpBxF,GAAGkF,IAAI5/N,gBAAkBmgO,GACzBzF,GAAGkF,IAAIvgO,YAAc+gO,GACrB1F,GAAG91L,OAAS,CAAA,EACZ81L,GAAG91L,OAAOxqC,OAASimO,GACnB3F,GAAG91L,OAAOpqC,QAAU8lO,GACpB5F,GAAG91L,OAAOnqC,SAAW8lO,GACrB7F,GAAG91L,OAAOlqC,OAAS8lO,GACnB9F,GAAG91L,OAAO67L,UjV76BH,SAAmBpmO,GACxB,OAAIA,EAAI,GACCI,GAAS,EAAIJ,GAEf,EAAII,GAAS,GAAKJ,EAAI,IAC/B,EiVy6BAqgO,GAAG1J,OAAS,CAAA,EACZ0J,GAAG1J,OAAO58N,MAAQlG,EAClBwsO,GAAG1J,OAAO58N,MAAM3F,ehW55BT,SAAwBR,GAC7BA,EAAIQ,gBACN,EgW25BAisO,GAAG1J,OAAO58N,MAAMpG,gBAAkB0yO,EAClChG,GAAG1J,OAAO1vC,UAAY,GACtBo5C,GAAG1J,OAAO1vC,UAAUA,UAAYq/C,GAChCjG,GAAG1J,OAAO54K,OAAShlD,EACnBsnO,GAAG1J,OAAOtqK,UAAY,GACtBg0K,GAAG1J,OAAOtqK,UAAUnC,IAAMq8K,GAC1BlG,GAAG1J,OAAOtqK,UAAUhC,WAAam8K,GACjCnG,GAAG1J,OAAOtqK,UAAU5B,iBAAmBg8K,GACvCpG,GAAG1J,OAAOtqK,UAAUrB,OAAS07K,GAC7BrG,GAAG1J,OAAOtqK,UAAUs6K,MvPx3BC,SAAU99K,GAC7B,OAAOA,EAAgB90D,MAAQipD,GAAoBE,KACrD,EuPu3BAmjL,GAAG1J,OAAOtqK,UAAUu6K,YvP9zBO,SAAU/9K,GACnC,OAAOA,EAAgB90D,MAAQipD,GAAoBG,QACrD,EuP6zBAkjL,GAAG1J,OAAOtqK,UAAU3B,MAAQm8K,GAC5BxG,GAAG1J,OAAOtqK,UAAUvB,kBAAoBg8K,GACxCzG,GAAG1J,OAAOtqK,UAAUpB,kBAAoB87K,GACxC1G,GAAG1J,OAAOtqK,UAAUX,UAAYs7K,GAChC3G,GAAG1J,OAAOtqK,UAAUnB,MAAQ+7K,GAC5B5G,GAAG1J,OAAOtqK,UAAUjB,eAAiB87K,GACrC7G,GAAG1J,OAAOtqK,UAAU86K,QvPlrBG,SAAUt+K,GAC/B,MAAMu+K,EAAiE,EAErE3qL,cAMF,OALAx0C,QACiBzN,IAAf4sO,EACA,uDAGgC,QAA3BA,EAAWz7K,WACpB,EuPyqBA00K,GAAG1J,OAAOtqK,UAAUhB,oBAAsBg8K,GAC1ChH,GAAG1J,OAAOtqK,UAAUi7K,wBvPvyBmB,SAAUz+K,GAC/C,MAAMpM,EACJoM,EACJ,cACE,OACGpM,EAAc6N,SACd/nD,GAAMk6C,EAAc8N,QAAU9N,EAAc+N,WAC5C/N,EAAc2M,QAEnB,EuP+xBAi3K,GAAG1J,OAAOtqK,UAAUk7K,YvP91BO,SAAU1+K,GACnC,MAA+B,eAAxBA,EAAgB90D,IACzB,EuP61BAssO,GAAG1J,OAAOtqK,UAAUT,cAAgB47K,GACpCnH,GAAG1J,OAAOtqK,UAAUf,aAAem8K,GACnCpH,GAAG1J,OAAOtqK,UAAUlB,YAAcu8K,GAClCrH,GAAG1J,OAAOtqK,UAAUd,kBAAoBo8K,GACxCtH,GAAG1J,OAAOtqK,UAAUu7K,UvP7sBK,SAAU/+K,GACjC,MAAMu+K,EAAiE,EAErE3qL,cAMF,OALAx0C,QACiBzN,IAAf4sO,EACA,uDAGgC,UAA3BA,EAAWz7K,WACpB,EuPosBA00K,GAAG1J,OAAO57N,OAAS8sO,EACnBxH,GAAG1J,OAAOt7N,WAAaysO,EACvBzH,GAAG1J,OAAOr7N,cAAgBysO,EAC1B1H,GAAG2H,KAAO,CAAA,EACV3H,GAAG2H,KAAKC,IAAM,GACd5H,GAAG2H,KAAKC,IAAIt9F,gBAAkBu9F,GAC9B7H,GAAG2H,KAAKC,IAAI9mF,qBAAuBgnF,GACnC9H,GAAG2H,KAAKtnG,WAAa,GACrB2/F,GAAG2H,KAAKtnG,WAAWrF,QAAU+sG,GAC7B/H,GAAG2H,KAAKtnG,WAAW1F,YAAcqtG,GACjChI,GAAG2H,KAAKtnG,WAAWxE,eAAiBosG,GACpCjI,GAAG2H,KAAKtnG,WAAWvF,UAAYotG,GAC/BlI,GAAG2H,KAAKtnG,WAAWzE,kBAAoBusG,GACvCnI,GAAG2H,KAAKtnG,WAAW3F,SAAW0tG,GAC9BpI,GAAG2H,KAAKtnG,WAAWtF,gBAAkBstG,GACrCrI,GAAG2H,KAAKtnG,WAAWzF,WAAa0tG,GAChCtI,GAAG2H,KAAKtnG,WAAWjE,IAAMmsG,GACzBvI,GAAG2H,KAAKtnG,WAAWxF,WAAa2tG,GAChCxI,GAAG2H,KAAKtnG,WAAWhF,aAAeotG,GAClCzI,GAAG2H,KAAKtnG,WAAW1E,OAAS+sG,GAC5B1I,GAAG2H,KAAKtnG,WAAWtE,kBAAoB4sG,GACvC3I,GAAG2H,KAAKtnG,WAAW7E,aAAeotG,GAClC5I,GAAG2H,KAAKtnG,WAAWxhG,MAAQgqM,GAC3B7I,GAAG2H,KAAKtnG,WAAWlF,SAAW2tG,GAC9B9I,GAAG2H,KAAKoB,IAAM,GACd/I,GAAG2H,KAAKoB,IAAI1+F,sBAAwB2+F,GACpChJ,GAAG2H,KAAKoB,IAAIv/F,YAAcy/F,GAC1BjJ,GAAG2H,KAAKoB,IAAIz+F,gBAAkB4+F,GAC9BlJ,GAAG2H,KAAKoB,IAAIt/F,YAAc0/F,GAC1BnJ,GAAG2H,KAAKoB,IAAIn/F,0BAA4Bw/F,GACxCpJ,GAAG2H,KAAKoB,IAAI9+F,sBAAwBo/F,GACpCrJ,GAAG2H,KAAKoB,IAAIx/F,aAAe+/F,GAC3BtJ,GAAG2H,KAAKoB,IAAIj/F,aAAey/F,GAC3BvJ,GAAG2H,KAAKoB,IAAIh/F,uBAAyBy/F,GACrCxJ,GAAG7yN,OAAS,CAAA,EACZ6yN,GAAG7yN,OAAOmF,eAAiBm3N,GAC3BzJ,GAAG7yN,OAAO0B,oBAAsB66N,GAChC1J,GAAG7yN,OAAOF,eAAiB08N,GAC3B3J,GAAG7yN,OAAOG,OAASs8N,GACnB5J,GAAG7yN,OAAOzE,MAAQmhO,GAClB7J,GAAG7yN,OAAOK,yBAA2Bs8N,GACrC9J,GAAG7yN,OAAOM,mBAAqBs8N,GAC/B/J,GAAG7yN,OAAOQ,eAAiBq8N,GAC3BhK,GAAG7yN,OAAOO,WAAau8N,GACvBjK,GAAG7yN,OAAOW,uBAAyBo8N,GACnClK,GAAG7yN,OAAOC,YAAc+8N,GACxBnK,GAAG7yN,OAAOkB,eAAiB+7N,GAC3BpK,GAAG7yN,OAAOmB,oBAAsB+7N,GAChCrK,GAAG7yN,OAAOoB,6BAA+B+7N,GACzCtK,GAAG7yN,OAAOo9N,8BxU5zBH,SAAuCr9N,EAAaK,GAEzD,OAAOyB,GADQV,GAAoBf,GACFL,EACnC,EwU0zBA8yN,GAAG7yN,OAAOqB,kCAAoCg8N,GAC9CxK,GAAG7yN,OAAOs9N,wBxUjyBH,SAAiCt7N,EAAO5B,GAE7C,OAAO2B,GADQZ,GAAoBf,GACR4B,EAC7B,EwU+xBA6wN,GAAG7yN,OAAOjX,OAASw0O,GACnB1K,GAAG7yN,OAAOtX,OAAS80O,GACnB3K,GAAG7yN,OAAOE,iBAAmBu9N,GAC7B5K,GAAG7yN,OAAO6B,kBAAoB67N,GAC9B7K,GAAG7yN,OAAOyB,sBAAwBk8N,GAClC9K,GAAG7yN,OAAO+B,YAAc67N,GACxB/K,GAAG7yN,OAAO8B,SAAW+7N,GACrBhL,GAAG7yN,OAAOmC,cAAgB27N,GAC1BjL,GAAG7yN,OAAO0C,QAAUq7N,GACpBlL,GAAG7yN,OAAOsC,cAAgB07N,GAC1BnL,GAAG7yN,OAAOuC,eAAiB07N,GAC3BpL,GAAG7yN,OAAO8C,UAAYo7N,GACtBrL,GAAG7yN,OAAO+C,UAAYo7N,GACtBtL,GAAG7yN,OAAOo+N,gBxUlkBH,SAAyB39N,EAASC,GACvC,MAAME,EAAOnO,KAAKwP,IAAIxB,EAAQ,GAAIC,EAAQ,IACpCG,EAAOpO,KAAKwP,IAAIxB,EAAQ,GAAIC,EAAQ,IAG1C,OAFajO,KAAKyP,IAAIzB,EAAQ,GAAIC,EAAQ,IAE3BE,IADFnO,KAAKyP,IAAIzB,EAAQ,GAAIC,EAAQ,IACXG,EACjC,EwU6jBAgyN,GAAG7yN,OAAOiD,kBAAoBo7N,GAC9BxL,GAAG7yN,OAAO6C,UAAYy7N,GACtBzL,GAAG7yN,OAAOoE,gBAAkBm6N,GAC5B1L,GAAG7yN,OAAOw+N,oBxUvfH,SAA6B/9N,EAASC,GAE3C,OAAOgC,GADc0B,GAAgB3D,EAASC,GAEhD,EwUqfAmyN,GAAG7yN,OAAOy+N,UxU1cH,SAAmBz+N,GACxB,OAAO4C,GAAS5C,GAAU6C,GAAU7C,EACtC,EwUycA6yN,GAAG7yN,OAAO6D,mBAAqB66N,GAC/B7L,GAAG7yN,OAAO7F,QxUlcH,SAAiB6F,GACtB,MAAO,CAACA,EAAO,GAAKA,EAAO,GAAIA,EAAO,GAAKA,EAAO,GACpD,EwUicA6yN,GAAG7yN,OAAOyC,WAAak8N,GACvB9L,GAAG7yN,OAAOwC,YAAco8N,GACxB/L,GAAG7yN,OAAO4C,SAAWi8N,GACrBhM,GAAG7yN,OAAOsE,WAAaw6N,GACvBjM,GAAG7yN,OAAO2E,kBAAoBo6N,GAC9BlM,GAAG7yN,OAAO1U,QAAU0zO,GACpBnM,GAAG7yN,OAAOuE,eAAiB06N,GAC3BpM,GAAG7yN,OAAOwE,gBAAkB06N,GAC5BrM,GAAG7yN,OAAOiG,cAAgBk5N,GAC1BtM,GAAG7yN,OAAO0F,MAAQ05N,GAClBvM,GAAGwM,cAAgB,CAAA,EACnBxM,GAAGwM,cAAclrK,gBAAkBmrK,GACnCzM,GAAGwM,cAAcE,mBhOn6BV,SAA4BC,GACjCtrK,GAAkBsrK,CACpB,EgOk6BA3M,GAAGwM,cAAc9qK,IAAMkrK,GACvB5M,GAAGrlN,OAAS,CAAA,EACZqlN,GAAGrlN,OAAOkyN,SAAWngD,GACrBszC,GAAGrlN,OAAO5S,QAAU6hL,GACpBo2C,GAAGrlN,OAAO5S,QAAQ+iL,eAAiBgiD,GACnC9M,GAAGrlN,OAAO5S,QAAQ6iL,oBAAsBmiD,GACxC/M,GAAGrlN,OAAO5S,QAAQ2iL,2BAA6BsiD,GAC/ChN,GAAGrlN,OAAO5S,QAAQuiL,6BAA+B2iD,GACjDjN,GAAGrlN,OAAO8+K,IAAMC,GAChBsmC,GAAGrlN,OAAO04K,KAAOqD,GACjBspC,GAAGrlN,OAAOg8K,KAAO6C,GACjBwmC,GAAGrlN,OAAOg/K,MAAQC,GAClBomC,GAAGrlN,OAAOuzK,QAAUqD,GACpByuC,GAAGrlN,OAAOuzK,QAAQF,MAAQk/C,GAC1BlN,GAAGrlN,OAAOwyN,IAAM/vC,GAChB4iC,GAAGrlN,OAAOyyN,QAAUxuC,GACpBohC,GAAGrlN,OAAO0yN,IAAMttC,GAChBigC,GAAGrlN,OAAO2yN,SAAWxrI,GACrBk+H,GAAGrlN,OAAOgyK,YAAc3B,GACxBg1C,GAAGrlN,OAAO4yN,IAAMrhC,GAChB8zB,GAAGrlN,OAAO4yN,IAAIC,oBhDl5BP,WACL,OAAOrpC,EACT,EgDi5BA67B,GAAGrlN,OAAO4yN,IAAIE,qBhD72BP,WACL,OAAOppC,EACT,EgD42BA27B,GAAGrlN,OAAO4yN,IAAIG,sBhD51BP,WACL,OAAO/kE,EACT,EgD21BAq3D,GAAGrlN,OAAO4yN,IAAII,gBhD9zBP,WACL,OAAOphG,EACT,EgD6zBAyzF,GAAGrlN,OAAO4yN,IAAIK,qBhDlzBP,WACL,OAAOnpC,EACT,EgDizBAu7B,GAAGrlN,OAAO4yN,IAAIM,oBhD70BP,WACL,OAAOtpC,EACT,EgD40BAy7B,GAAGrlN,OAAO4yN,IAAIj6C,oBAAsBw6C,GACpC9N,GAAGrlN,OAAOozN,IAAMv4B,GAChBwqB,GAAGrlN,OAAOqzN,OAAS72B,GACnB6oB,GAAGrlN,OAAOy7M,IAAM9b,GAChB0lB,GAAGrlN,OAAOszN,SAAW5yB,GACrB2kB,GAAGrlN,OAAOszN,SAASpzB,aAAeqzB,GAClClO,GAAGrlN,OAAOszN,SAASnzB,aAAeqzB,GAClCnO,GAAGrlN,OAAOszN,SAASjzB,qBAAuBozB,GAC1CpO,GAAGrlN,OAAOszN,SAAS/yB,uBAAyBmzB,GAC5CrO,GAAGrlN,OAAOszN,SAASxzB,aAAe6zB,GAClCtO,GAAGrlN,OAAOszN,SAASrzB,aAAe2zB,GAClCvO,GAAGrlN,OAAOszN,SAASlzB,qBAAuByzB,GAC1CxO,GAAGrlN,OAAOszN,SAAS9yB,sBAAwBszB,GAC3CzO,GAAGrlN,OAAOszN,SAAShzB,uBAAyByzB,GAC5C1O,GAAGrlN,OAAOqlL,YAAcb,GACxB6gC,GAAGrlN,OAAOg0N,SAAW3yB,GACrBgkB,GAAGrlN,OAAOi0N,IAAMrqB,GAChByb,GAAGrlN,OAAOi0N,IAAIC,YZuLP,SAAqBzjM,EAAQ+2D,GAElC,MAAM1b,EAAQ07B,GAAgB0hG,GAD9B1hH,EAAUA,GAAW,SAC+B,UAC9Cr+F,EAAU,CACdoB,KAAMuhF,GAOR,OALApsF,OAAO8C,OAAO2G,EAAS,CACrBq+F,QAAWA,EACX/2D,OAAUA,IAEZ04K,GAAqBr9H,EAAOr7C,EAAQ,CAACtnC,IAC9B2iF,CACT,EYlMAu5I,GAAGrlN,OAAOm0N,IAAM7kB,GAChB+V,GAAGrlN,OAAOo0N,IAAM1gB,GAChB2R,GAAGrlN,OAAOq0N,gBAAkBzb,GAC5ByM,GAAGrlN,OAAOs0N,kBAAoBxb,GAC9BuM,GAAGrlN,OAAOu0N,iBAAmBhZ,GAC7B8J,GAAGrlN,OAAO4/L,IAAMnD,GAChB4oB,GAAGrlN,OAAOwzK,WAAajB,GACvB8yC,GAAGrlN,OAAOywB,OAAS,GACnB40L,GAAGrlN,OAAOywB,OAAO6zK,IAAMvC,GACvBsjB,GAAGrlN,OAAOywB,OAAO8zK,KAAOtC,GACxBojB,GAAGrlN,OAAOywB,OAAOkyK,WAAaH,GAC9B6iB,GAAGrlN,OAAOywB,OAAOsyK,iBAAmBH,GACpCyiB,GAAGrlN,OAAOywB,OAAOk3K,SAAWxF,GAC5BkjB,GAAGrlN,OAAOywB,OAAOs3K,QAAU1F,GAC3BgjB,GAAGrlN,OAAOywB,OAAOq4K,SAAWvG,GAC5B8iB,GAAGrlN,OAAOywB,OAAO22K,OAAS1E,GAC1B2iB,GAAGrlN,OAAOywB,OAAO+jM,QAAU1xB,GAC3BuiB,GAAGrlN,OAAOywB,OAAOqxK,OAASJ,GAC1B2jB,GAAGrlN,OAAOywB,OAAO4xF,YAAc2gF,GAC/BqiB,GAAGrlN,OAAOywB,OAAO6xF,qBAAuB2gF,GACxCoiB,GAAGrlN,OAAOywB,OAAOo3K,WAAa3E,GAC9BmiB,GAAGrlN,OAAOywB,OAAOgkM,UAAYtxB,GAC7BkiB,GAAGrlN,OAAOywB,OAAOikM,OAASpxB,GAC1B+hB,GAAGrlN,OAAOywB,OAAOkkM,OAAShxB,GAC1B0hB,GAAGrlN,OAAOywB,OAAO8xF,SAAWqhF,GAC5ByhB,GAAGrlN,OAAOywB,OAAO+xF,kBAAoBqhF,GACrCwhB,GAAGrlN,OAAOywB,OAAOuxK,YAAcH,GAC/BwjB,GAAGrlN,OAAOywB,OAAOuxF,IAAM8hF,GACvBuhB,GAAGrlN,OAAOywB,OAAOmkM,WAAa7wB,GAC9BshB,GAAGrlN,OAAOywB,OAAO82K,GAAKvD,GACtBqhB,GAAGrlN,OAAOywB,OAAOs4K,WAAa9E,GAC9BohB,GAAGrlN,OAAOywB,OAAO2xK,QAAUF,GAC3BmjB,GAAGrlN,OAAOywB,OAAOq3K,OAAS3D,GAC1BkhB,GAAGrlN,OAAOywB,OAAO2zK,IAAMywB,GACvBxP,GAAGrlN,OAAOywB,OAAOg5C,KAAOqrJ,GACxBzP,GAAGrlN,OAAOywB,OAAOskM,Qb76BV,SAAiBtyB,EAAcW,EAAeC,GACnD,OAAO,IAAIoxB,GAAUhyB,EAAcW,EAAeC,EACpD,Ea46BAgiB,GAAGrlN,OAAOywB,OAAOub,SbhlCV,SAAkB4wH,EAAchvK,EAAU+lL,GAC/C,OAAO,IAAIg0B,GAAS/qC,EAAchvK,EAAU+lL,EAC9C,Ea+kCA0xC,GAAGrlN,OAAOywB,OAAOukM,SbnjCV,SAAkBp4D,EAAchvK,EAAU+lL,GAC/C,OAAO,IAAIm1B,GAASlsC,EAAchvK,EAAU+lL,EAC9C,EakjCA0xC,GAAGrlN,OAAOywB,OAAOwkM,Obj4BV,SAAgBxyB,EAAc1nN,EAAOC,GAC1C,OAAO,IAAIosN,GAAO3E,EAAc1nN,EAAOC,EACzC,Eag4BAqqO,GAAGrlN,OAAOywB,OAAOykM,QbrhCV,SAAiBt4D,EAAchvK,EAAU4S,EAAU8hM,EAAM3uB,GAC9D,OAAO,IAAIo0B,GAAQnrC,EAAchvK,EAAU4S,EAAU8hM,EAAM3uB,EAC7D,EaohCA0xC,GAAGrlN,OAAOywB,OAAO0kM,QbzgCV,SAAiB1yB,EAAc/8E,EAAYm9E,GAChD,OAAO,IAAI2xB,GAAQ/xB,EAAc/8E,EAAYm9E,EAC/C,EawgCAwiB,GAAGrlN,OAAOywB,OAAO2kM,Ybz9BV,SAAqB3yB,EAAc/8E,GACxC,OAAO,IAAIrD,GAAYogF,EAAc/8E,EACvC,Eaw9BA2/F,GAAGrlN,OAAOywB,OAAO4kM,qBb98BV,SAA8B5yB,EAAc/8E,GACjD,OAAO,IAAIpD,GAAqBmgF,EAAc/8E,EAChD,Ea68BA2/F,GAAGrlN,OAAOywB,OAAO35B,WbxkCV,SAAoB8lK,EAAchvK,EAAU+lL,GACjD,OAAO,IAAIk0B,GAAWjrC,EAAchvK,EAAU+lL,EAChD,EaukCA0xC,GAAGrlN,OAAOywB,OAAO6kM,Obp8BV,SAAgB7yB,GACrB,OAAO,IAAIkyB,GAAOlyB,EACpB,Eam8BA4iB,GAAGrlN,OAAOywB,OAAO8kM,Sbr/BV,SAAkB9yB,EAAc/8E,GACrC,OAAO,IAAInD,GAASkgF,EAAc/8E,EACpC,Eao/BA2/F,GAAGrlN,OAAOywB,OAAO+kM,kBb1+BV,SAA2B/yB,EAAc/8E,GAC9C,OAAO,IAAIlD,GAAkBigF,EAAc/8E,EAC7C,Eay+BA2/F,GAAGrlN,OAAOywB,OAAOglM,Kbr6BV,SACLhzB,EACAc,EACAC,EACAC,EACAC,EACAb,GAEA,OAAO,IAAI6xB,GACTjyB,EACAc,EACAC,EACAC,EACAC,EACAb,EAEJ,Eas5BAwiB,GAAGrlN,OAAOywB,OAAOilM,Ib1nCV,SAAarkL,GAClB,OAAO,IAAI2wE,GAAI3wE,EACjB,EaynCAg0K,GAAGrlN,OAAOywB,OAAOklM,WbrgCV,SAAoBlzB,EAAc/8E,EAAYm9E,GACnD,OAAO,IAAI+xB,GAAWnyB,EAAc/8E,EAAYm9E,EAClD,EaogCAwiB,GAAGrlN,OAAOywB,OAAOmlM,GbxoCV,SAAYzmL,GACjB,MAAM85B,EAAS,CAAC,MAAM8G,OAAO10F,MAAMwB,UAAUC,MAAMC,KAAKC,YACxD,OAAO,IAAKqnN,SAASxnN,UAAUqD,KAAKhD,MAAMqqN,GAAIt+H,GAChD,EasoCAo8I,GAAGrlN,OAAOywB,OAAOolM,Wb14BV,SAAoB3xB,GACzB,OAAO,IAAI6E,GAAW7E,EACxB,Eay4BAmhB,GAAGrlN,OAAOywB,OAAOqlM,ObnjCV,SAAgBl5D,EAAchvK,EAAU+lL,GAC7C,OAAO,IAAIm0B,GAAOlrC,EAAchvK,EAAU+lL,EAC5C,EakjCA0xC,GAAGrlN,OAAO+1N,MAAQ,GAClB1Q,GAAGrlN,OAAO+1N,MAAMl5B,SAAWm5B,GAC3B3Q,GAAGrlN,OAAOi2N,IAAM,GAChB5Q,GAAGrlN,OAAOi2N,IAAIp/C,YAAcq/C,GAC5B7Q,GAAGrlN,OAAOi2N,IAAIn/C,kBAAoBq/C,GAClC9Q,GAAGrlN,OAAOi2N,IAAIl/C,aAAeq/C,GAC7B/Q,GAAGrlN,OAAOi2N,IAAIh/C,YAAco/C,GAC5BhR,GAAGrlN,OAAOi2N,IAAI/+C,kBAAoBo/C,GAClCjR,GAAGrlN,OAAOi2N,IAAI7+C,6BAA+Bm/C,GAC7ClR,GAAGrlN,OAAOi2N,IAAI9+C,oBAAsBq/C,GACpCnR,GAAGrlN,OAAOi2N,IAAI5+C,WAAao/C,GAC3BpR,GAAGrlN,OAAOi2N,IAAI3+C,qBAAuBo/C,GACrCrR,GAAGrlN,OAAOi2N,IAAIx+C,kBAAoBk/C,GAClCtR,GAAGrlN,OAAOi2N,IAAIt+C,sBAAwBi/C,GACtCvR,GAAGrlN,OAAOi2N,IAAI99C,qBAAuB0+C,GACrCxR,GAAGrlN,OAAOi2N,IAAI59C,gCAAkCy+C,GAChDzR,GAAGrlN,OAAOi2N,IAAIz+C,oBAAsBu/C,GACpC1R,GAAG71F,UAAY,CAAA,EACf61F,GAAG71F,UAAUpzI,MAAQ46O,EACrB3R,GAAG71F,UAAUrzI,KAAO86O,EACpB5R,GAAG71F,UAAUnzI,KAAO66O,EACpB7R,GAAG71F,UAAUlzI,WAAa66O,EAC1B9R,GAAG71F,UAAUryI,UAAYi6O,EACzB/R,GAAGxzD,KAAO,CAAA,EACVwzD,GAAGxzD,KAAKv9F,OAAS8b,GACjBi1I,GAAGxzD,KAAKnpJ,SAAWlC,GACnB6+M,GAAGxzD,KAAK19F,mBAAqBgd,GAC7Bk0I,GAAGxzD,KAAKh+F,WAAase,GACrBkzI,GAAGxzD,KAAK3lJ,WAAaK,GACrB84M,GAAGxzD,KAAK59F,gBAAkBye,GAC1B2yI,GAAGxzD,KAAK79F,WAAagf,GACrBqyI,GAAGxzD,KAAK39F,aAAe8f,GACvBqxI,GAAGxzD,KAAKrlJ,MAAQC,GAChB44M,GAAGxzD,KAAK5iJ,QAAUiB,GAClBm1M,GAAGxzD,KAAK5iJ,QAAQkB,SAAWknN,GAC3BhS,GAAGxzD,KAAK5iJ,QAAQsB,WAAa+mN,GAC7BjS,GAAGxzD,KAAK5iJ,QAAQqB,WAAainN,GAC7BlS,GAAGxzD,KAAK5iJ,QAAQyB,YAAc8mN,GAC9BnS,GAAGxzD,KAAK1lJ,eAAiB1D,GACzB48M,GAAGxzD,KAAK1lJ,eAAejE,mBAAqBuvN,GAC5CpS,GAAGxzD,KAAK1lJ,eAAe/D,mBAAqBsvN,GAC5CrS,GAAGxzD,KAAK1lJ,eAAe9D,gBAAkBsvN,GACzCtS,GAAGxzD,KAAKxS,KAAO,GACfgmE,GAAGxzD,KAAKxS,KAAKlqJ,KAAO,GACpBkwN,GAAGxzD,KAAKxS,KAAKlqJ,KAAK2W,WAAa8rN,GAC/BvS,GAAGxzD,KAAKxS,KAAKlqJ,KAAK6W,YAAc6rN,GAChCxS,GAAGxzD,KAAKxS,KAAKlqJ,KAAK8W,aAAe6rN,GACjCzS,GAAGxzD,KAAKxS,KAAK3pJ,OAAS,GACtB2vN,GAAGxzD,KAAKxS,KAAK3pJ,OAAOuW,aAAe8rN,GACnC1S,GAAGxzD,KAAKxS,KAAK24E,QAAU,GACvB3S,GAAGxzD,KAAKxS,KAAK24E,QAAQruN,qBAAuBsuN,GAC5C5S,GAAGxzD,KAAKxS,KAAK24E,QAAQ7tN,wBAA0B+tN,GAC/C7S,GAAGxzD,KAAKxS,KAAK24E,QAAQ5tN,6BAA+B+tN,GACpD9S,GAAGxzD,KAAKxS,KAAK24E,QAAQjuN,mBAAqBquN,GAC1C/S,GAAGxzD,KAAKxS,KAAK24E,QAAQxuN,gBAAkB6uN,GACvChT,GAAGxzD,KAAKxS,KAAK24E,QAAQnuN,0BAA4ByuN,GACjDjT,GAAGxzD,KAAKxS,KAAKrzG,SAAW,GACxBq5K,GAAGxzD,KAAKxS,KAAKrzG,SAASt/B,yBAA2B6rN,GACjDlT,GAAGxzD,KAAKxS,KAAKrzG,SAASr/B,qBAAuB6rN,GAC7CnT,GAAGxzD,KAAKxS,KAAKrzG,SAASn/B,sBAAwB4rN,GAC9CpT,GAAGxzD,KAAKxS,KAAKrzG,SAASl/B,uBAAyB4rN,GAC/CrT,GAAGxzD,KAAKxS,KAAKs5E,QAAU,GACvBtT,GAAGxzD,KAAKxS,KAAKs5E,QAAQtuN,kBAAoBuuN,GACzCvT,GAAGxzD,KAAKxS,KAAKs5E,QAAQruN,mBAAqBuuN,GAC1CxT,GAAGxzD,KAAKxS,KAAKs5E,QAAQpuN,wBAA0BuuN,GAC/CzT,GAAGxzD,KAAKxS,KAAKs5E,QAAQluN,6BAA+BsuN,GACpD1T,GAAGxzD,KAAKxS,KAAK25E,KAAO,GACpB3T,GAAGxzD,KAAKxS,KAAK25E,KAAKjqD,OAASkqD,GAC3B5T,GAAGxzD,KAAKxS,KAAK65E,SAAW,GACxB7T,GAAGxzD,KAAKxS,KAAK65E,SAASC,ejFjqCf,SACL13N,EACAR,EACA8sJ,EACA7sJ,EACA/I,EACA2O,GAEA,MAAMsyN,EAAgBxxN,GAAc,aAE9ByxN,EAAUp0O,KAAKwL,IAAIkN,GAAUsD,IAC7Bq4N,EAAUr0O,KAAKyL,IAAIiN,GAAUsD,IAC7Bs4N,EAAUt0O,KAAKwL,IAAIkN,GAAUuD,IAC7Bs4N,EAAUv0O,KAAKyL,IAAIiN,GAAUuD,IAC7Bu4N,EAAcx0O,KAAKwL,IAAIkN,GAAUowJ,EAAOtsJ,IACxCi4N,EAAcz0O,KAAKyL,IAAIiN,GAAUowJ,EAAOtsJ,IACxCxR,EAAIqpO,EAAUE,EAAUH,EAAUE,EAAUE,EAElD,OAAOt5E,IAKL,SAAU0N,GACR,GAAI,GAAK59J,EACP,MAAO,CAAC89J,EAAM7sJ,GAEhB,MAAMy4N,EAAI9rE,EAAO5oK,KAAK+1J,KAAK/qJ,GACrB2pO,EAAO30O,KAAKwL,IAAIkpO,GAChBE,EAAO50O,KAAKyL,IAAIipO,GAChBrpO,EAAIopO,EAAcH,EAClBlpO,EAAIgpO,EAAUG,EAAUF,EAAUC,EAAUE,EAC5CpvM,EAAQplC,KAAKoc,MAAM/Q,EAAGD,GACtBsR,EAAM1c,KAAK2c,KAAK03N,EAAUM,EAAOP,EAAUQ,EAAO50O,KAAKwL,IAAI45B,IAOjE,MAAO,CAAC5sB,GALNE,GAAU8D,GACVxc,KAAKoc,MACHpc,KAAKyL,IAAI25B,GAASwvM,EAAOR,EACzBO,EAAON,EAAUr0O,KAAKyL,IAAIiR,KAENlE,GAAUkE,GACnC,GACDkD,GAAau0N,EAAejhO,GAC5B2O,EAEJ,EiFqnCAu+M,GAAGxzD,KAAKxS,KAAK65E,SAASvrE,SAAWmsE,GACjCzU,GAAGxzD,KAAKxS,KAAK65E,SAASprE,SAAWisE,GACjC1U,GAAGxzD,KAAKxS,KAAK26E,QAAU,GACvB3U,GAAGxzD,KAAKxS,KAAK26E,QAAQruN,mBAAqBsuN,GAC1C5U,GAAGxzD,KAAKxS,KAAK26E,QAAQpuN,wBAA0BsuN,GAC/C7U,GAAGxzD,KAAKxS,KAAK26E,QAAQnuN,6BAA+BsuN,GACpD9U,GAAGxzD,KAAKxS,KAAK+6E,cAAgB,GAC7B/U,GAAGxzD,KAAKxS,KAAK+6E,cAAcrtN,wBAA0BstN,GACrDhV,GAAGxzD,KAAKxS,KAAK+6E,cAAc5sN,8BAAgC8sN,GAC3DjV,GAAGxzD,KAAKxS,KAAKx5J,YAAc,GAC3Bw/N,GAAGxzD,KAAKxS,KAAKx5J,YAAYurF,iBAAmBmpJ,GAC5ClV,GAAGxzD,KAAKxS,KAAKx5J,YAAYyrF,wBAA0BkpJ,GACnDnV,GAAGxzD,KAAKxS,KAAKx5J,YAAY8rF,yBAA2B8oJ,GACpDpV,GAAGxzD,KAAKxS,KAAKq7E,iBAAmB,GAChCrV,GAAGxzD,KAAKxS,KAAKq7E,iBAAiB/sN,qBAAuBgtN,GACrDtV,GAAGxzD,KAAKxS,KAAKq7E,iBAAiB1sN,0BAA4B4sN,GAC1DvV,GAAGxzD,KAAKxS,KAAKq7E,iBAAiBzsN,qBAAuB4sN,GACrDxV,GAAGxzD,KAAKxS,KAAKq7E,iBAAiBxsN,0BAA4B4sN,GAC1DzV,GAAGxzD,KAAKxS,KAAKq7E,iBAAiBvsN,+BAAiC4sN,GAC/D1V,GAAGxzD,KAAKxS,KAAKllK,OAAS,GACtBkrO,GAAGxzD,KAAKxS,KAAKllK,OAAOy3F,iBAAmBopJ,GACvC3V,GAAGxzD,KAAKxS,KAAKllK,OAAO8gP,iBnMjvCb,SAA0BnnO,EAAiBC,EAAQ/Y,EAAKgZ,GAC7D,IAAIknO,EAAYtpJ,GAAiB99E,EAAiBC,EAAQ/Y,EAAKgZ,GAC/D,MAAMlD,EAAKgD,EAAgB9Y,EAAMgZ,GAAUF,EAAgBC,GACrDhD,EAAK+C,EAAgB9Y,EAAMgZ,EAAS,GAAKF,EAAgBC,EAAS,GAExE,OADAmnO,GAAaj2O,KAAKma,KAAKtO,EAAKA,EAAKC,EAAKA,GAC/BmqO,CACT,EmM4uCA7V,GAAGxzD,KAAKxS,KAAK87E,OAAS,GACtB9V,GAAGxzD,KAAKxS,KAAK87E,OAAOtsN,YAAcusN,GAClC/V,GAAGxzD,KAAKxS,KAAK87E,OAAO/sN,sBAAwBitN,GAC5ChW,GAAGxzD,KAAKxS,KAAK87E,OAAO7sN,uBAAyBgtN,GAC7CjW,GAAGxzD,KAAKxS,KAAK87E,OAAO1sN,wBAA0B8sN,GAC9ClW,GAAGxzD,KAAKxS,KAAK87E,OAAOzsN,kBAAoB8sN,GACxCnW,GAAGxzD,KAAKxS,KAAK87E,OAAOvsN,uBAAyB6sN,GAC7CpW,GAAGxzD,KAAKxS,KAAK78D,QAAU,GACvB6iI,GAAGxzD,KAAKxS,KAAK78D,QAAQjwF,YAAcmpO,GACnCrW,GAAGxzD,KAAKxS,KAAKmjB,SAAW,GACxB6iD,GAAGxzD,KAAKxS,KAAKmjB,SAASr+K,QAAUw3O,GAChCtW,GAAGxzD,KAAKxS,KAAK53I,SAAW,GACxB49M,GAAGxzD,KAAKxS,KAAK53I,SAASkD,eAAiBixN,GACvCvW,GAAGxzD,KAAKxS,KAAK53I,SAAS0D,oBAAsB0wN,GAC5CxW,GAAGxzD,KAAKxS,KAAK53I,SAASq0N,yBtTplCf,SACLhoO,EACAC,EACA+V,EACA9V,EACA8S,EACA8D,EACAC,EACAa,GAEA,IAAK,IAAI9wB,EAAI,EAAGuE,EAAK2qB,EAAM3vB,OAAQS,EAAIuE,IAAMvE,EAAG,CAC9C,MAAMgvB,EAAOE,EAAMlvB,GAEbwwB,EAAiB,GACvBP,EAAmBM,GACjBrX,EACAC,EACA6V,EACA5V,EACA8S,EACA8D,EACAC,EACAO,GAEFM,EAAgB/sB,KAAKysB,GACrBrX,EAAS6V,EAAKA,EAAKzvB,OAAS,EAC7B,CACD,OAAO0wB,CACT,EsTyjCAw6M,GAAGxzD,KAAKxS,KAAK53I,SAAS8D,SAAWwwN,GACjC1W,GAAGxzD,KAAKxS,KAAK53I,SAAS+D,cAAgBwwN,GACtC3W,GAAGxzD,KAAKxS,KAAK53I,SAASgE,mBAAqBwwN,GAC3C5W,GAAGxzD,KAAKxS,KAAK53I,SAAS4D,eAAiB6wN,GACvC7W,GAAGxzD,KAAKxS,KAAK53I,SAAS00N,mBtT3vCf,SACLroO,EACAC,EACA/Y,EACAgZ,EACA8S,EACAs1N,EACAxxN,GA2BA,OAzBAA,OACgCprB,IAA9BorB,EAA0CA,EAA4B,GACnEwxN,IACHphP,EAAMqwB,GACJvX,EACAC,EACA/Y,EACAgZ,EACA8S,EACA8D,EACA,GAEF9W,EAAkB8W,EAClB7W,EAAS,EACTC,EAAS,GAEX4W,EAA0BzwB,OAASwwB,GACjC7W,EACAC,EACA/Y,EACAgZ,EACA8S,EACA8D,EACA,GAEKA,CACT,EsTytCAy6M,GAAGxzD,KAAKxS,KAAK53I,SAAS6D,KAAO+wN,GAC7BhX,GAAGxzD,KAAKxS,KAAKi9E,cAAgB,GAC7BjX,GAAGxzD,KAAKxS,KAAKi9E,cAAcvhF,cAAgBwhF,GAC3ClX,GAAGxzD,KAAKxS,KAAKm9E,SAAW,GACxBnX,GAAGxzD,KAAKxS,KAAKm9E,SAAS59E,eAAiB69E,GACvCpX,GAAGxzD,KAAKxS,KAAKq9E,SAAW,GACxBrX,GAAGxzD,KAAKxS,KAAKq9E,SAASC,mBC/xCf,SAA4B7oO,EAAiBC,EAAQ/Y,EAAKgZ,GAC/D,MAAM4oO,EAAY5hP,EAAMgZ,EACxB,OACEF,EAAgBC,KAAYD,EAAgB8oO,IAC5C9oO,EAAgBC,EAAS,KAAOD,EAAgB8oO,EAAY,KAC3D5hP,EAAM+Y,GAAUC,EAAS,KAEjBsY,GAAexY,EAAiBC,EAAQ/Y,EAAKgZ,EAG1D,EDsxCAqxN,GAAGxzD,KAAKxS,KAAKrwJ,UAAY,GACzBq2N,GAAGxzD,KAAKxS,KAAKrwJ,UAAUuB,OAASssO,GAChCxX,GAAGxzD,KAAKxS,KAAKrwJ,UAAU2B,MAAQmsO,GAC/BzX,GAAGxzD,KAAKxS,KAAKrwJ,UAAUmX,YAAc42N,GACrC1X,GAAGxzD,KAAKxS,KAAKrwJ,UAAU6B,UAAYmsO,GACnC3X,GAAGp7F,IAAM,CAAA,EACTo7F,GAAGp7F,IAAIhiI,oBAAsBg1O,GAC7B5X,GAAGp7F,IAAIziI,mBAAqB01O,GAC5B7X,GAAGp7F,IAAI/iI,QAAUi2O,GACjB9X,GAAGp7F,IAAIniI,aAAes1O,GACtB/X,GAAGp7F,IAAI1iI,IAAM81O,GACbhY,GAAGp7F,IAAI9hI,wBAA0Bm1O,GACjCjY,GAAGp7F,IAAI9iI,OAASo2O,GAChBlY,GAAGp7F,IAAI7iI,kBAAoBo2O,GAC3BnY,GAAGp7F,IAAI3iI,OAASm2O,GAChBpY,GAAGp7F,IAAIviI,wBAA0Bg2O,GACjCrY,GAAG/pK,YAAc,CAAA,EACjB+pK,GAAG/pK,YAAYqiL,iBAAmBzmE,GAClCmuD,GAAG/pK,YAAYvE,gBAAkBhJ,GACjCs3K,GAAG/pK,YAAYsiL,YAAc9lE,GAC7ButD,GAAG/pK,YAAYsiL,YAAYhmE,iBAAmBimE,GAC9CxY,GAAG/pK,YAAY7H,QAAUX,GACzBuyK,GAAG/pK,YAAY7H,QAAQZ,aAAeirL,GACtCzY,GAAG/pK,YAAYnE,QAAUrG,GACzBu0K,GAAG/pK,YAAYzE,WAAa/E,GAC5BuzK,GAAG/pK,YAAYyiL,kBAAoB5kE,GACnCksD,GAAG/pK,YAAYxD,SAAWtE,GAC1B6xK,GAAG/pK,YAAY0iL,KAAOtjE,GACtB2qD,GAAG/pK,YAAY0iL,KAAKxkE,UAAYykE,GAChC5Y,GAAG/pK,YAAY0iL,KAAKE,UvE+iBb,WACL,OAAO,SAAU3rO,EAAa3E,EAAUuK,GACtC,MAAM3F,EAASF,GACgB,CAC3BC,EAAY,GACZA,EAAYA,EAAYpY,OAAS,IAChC2pC,KAAI,SAAU1zB,GACf,OAAO+U,GAAmB/U,EAAY+H,EAC9C,KAEUgmO,EAAiB,CACrB,CACErpO,GAActC,GACduC,GAAevC,GACfwC,GAAYxC,GACZyC,GAAWzC,GACXsC,GAActC,KAGd5E,EACFA,EAASsb,eAAei1N,GAExBvwO,EAAW,IAAIqhB,GAAQkvN,GAEzB,MAAMp5N,EAAiBE,KAIvB,OAHIF,GACFnX,EAASoB,UAAUmJ,EAAY4M,GAE1BnX,CACX,CACA,EuE5kBAy3N,GAAG/pK,YAAY0iL,KAAKI,qBvEqgBb,SAA8B5tN,EAAOhgB,GAC1C,OAAO,SAAU+B,EAAa3E,EAAUuK,GACtC,MAAMzC,EAASyP,GACgB,EAAc,GAC3ChN,GAEInd,EAAMmqB,GACmB,EAAc5S,EAAYpY,OAAS,GAChEge,GAEI6I,EAAS/b,KAAKma,KAAK48J,GAA0BtmK,EAAQ1a,IAC3D4S,EAAWA,GAAY2iB,GAAW,IAAI+jD,GAAO5+D,GAAS8a,GAEtD,IAAI6tN,EAAgB7tO,EACpB,IAAKA,GAAmB,IAAVA,EAAa,CACzB,MAAMH,EAAIrV,EAAI,GAAK0a,EAAO,GACpBpF,EAAItV,EAAI,GAAK0a,EAAO,GAC1B2oO,EAAgBp5O,KAAKoc,MAAM/Q,EAAGD,EAC/B,CACDqgB,GACJ,EACMhb,EACAsL,EACAq9N,GAGF,MAAMt5N,EAAiBE,KAIvB,OAHIF,GACFnX,EAASoB,UAAUmJ,EAAY4M,GAE1BnX,CACX,CACA,EuEpiBAy3N,GAAG/pK,YAAYgjL,OAAS78D,GACxB4jD,GAAG/pK,YAAYgjL,OAAOr9D,YAAcs9D,GACpClZ,GAAG/pK,YAAYtN,YAAcN,GAC7B23K,GAAG/pK,YAAYtN,YAAYR,IAAMgxL,GACjCnZ,GAAG/pK,YAAYtN,YAAYP,YAAcgxL,GACzCpZ,GAAG/pK,YAAY7D,YAAc5D,GAC7BwxK,GAAG/pK,YAAY5D,aAAevD,GAC9BkxK,GAAG/pK,YAAYosI,KAAO5jB,GACtBuhD,GAAG/pK,YAAYojL,OAAS14D,GACxBq/C,GAAG/pK,YAAYojL,OAAOl5D,YAAcm5D,GACpCtZ,GAAG/pK,YAAY1D,eAAiBxD,GAChCixK,GAAG/pK,YAAYjE,YAAczB,GAC7ByvK,GAAG/pK,YAAY/D,UAAYjB,GAC3B+uK,GAAG/pK,YAAYsjL,QAAUtwL,GACzB+2K,GAAG/pK,YAAYsjL,QAAQvwL,SAAWwwL,GAClCxZ,GAAG/pK,YAAYovH,OAASqB,GACxBs5C,GAAG/pK,YAAYovH,OAAOJ,YAAcw0D,GACpCzZ,GAAG/pK,YAAYyjL,KAAO5yD,GACtBk5C,GAAG/pK,YAAY0jL,UAAYzwD,GAC3B82C,GAAG/pK,YAAY0jL,UAAU3wD,eAAiB4wD,GAC1C5Z,GAAG/pK,YAAYxO,SAAW,GAC1Bu4K,GAAG/pK,YAAYxO,SAASA,SAAWoyL,GACnC7Z,GAAGz+L,MAAQ,CAAA,EACXy+L,GAAGz+L,MAAMu4M,KAAOx5M,GAChB0/L,GAAGz+L,MAAMw4M,UAAYjqI,GACrBkwH,GAAGz+L,MAAMy4M,SAAW1mI,GACpB0sH,GAAGz+L,MAAMupH,WAAavD,GACtBy4E,GAAGz+L,MAAM04M,UAAYpxE,GACrBm3D,GAAGz+L,MAAM24M,MAAQl+L,GACjBgkL,GAAGz+L,MAAM24M,MAAMt/L,WAAau/L,GAC5Bna,GAAGz+L,MAAM64M,QAAU3rE,GACnBuxD,GAAGz+L,MAAM7+B,MAAQwwG,GACjB8sH,GAAGz+L,MAAMsxB,MAAQ7iB,GACjBgwL,GAAGz+L,MAAMsxB,MAAM/iB,OAASuqM,GACxBra,GAAGz+L,MAAMx6B,KAAO0vG,GAChBupH,GAAGz+L,MAAM+4M,OAAS5yE,GAClBs4D,GAAGz+L,MAAMg5M,YAAc5qE,GACvBqwD,GAAGz+L,MAAM0/L,WAAalxD,GACtBiwD,GAAGz+L,MAAMi5M,YAActqE,GACvB8vD,GAAGz+L,MAAMk5M,UAAY7oE,GACrBouD,GAAG0a,gBAAkB,CAAA,EACrB1a,GAAG0a,gBAAgB7wL,IAAM8wL,GACzB3a,GAAG0a,gBAAgBt2J,K9N71CZ,SAAcj3E,EAAQmD,GAC3B,MAAO,CAACnD,EACV,E8N41CA6yN,GAAG0a,gBAAgB75O,K9Np1CZ,SAAc2U,GACnB,OAAA,SAOYrI,EAAQmD,EAAYwC,GAC5B,MAAMogB,EAAI1d,EAAS8hE,kBACjBj3D,GAAmB/P,EAAYwC,IAE3B6rD,EAAYnpD,EAASgiE,0BACzBv3D,GAAe9S,EAAQ2F,GACvBogB,GAGIm3D,EAAU,GAEVnqF,EAAY,CAACgzB,EAAG,EAAG,GACzB,IACEhzB,EAAU,GAAKy+D,EAAU5wD,KACzB7N,EAAU,IAAMy+D,EAAU1wD,OACxB/N,EAAU,GAEZ,IACEA,EAAU,GAAKy+D,EAAU3wD,KACzB9N,EAAU,IAAMy+D,EAAUzwD,OACxBhO,EAAU,GAEZmqF,EAAQ/wF,KACN0mB,GAAaxK,EAASuhE,mBAAmB72E,GAAY4S,IAI3D,OAAOu3E,CAET,CACJ,E8N+yCA21I,GAAG4a,KAAO,CAAA,EACV5a,GAAG4a,KAAK9hO,KAAO+hO,GACf7a,GAAG4a,KAAKnjO,MAAQqjO,GAChB9a,GAAG4a,KAAKznO,MAAQ4nO,GAChB/a,GAAG4a,KAAKniO,KAAOuiO,GACfhb,GAAG4a,KAAKpiO,OAASyiO,GACjBjb,GAAG4a,KAAK/hO,MAAQqiO,GAChBlb,GAAG4a,KAAKhjO,kBAAoBujO,GAC5Bnb,GAAG4a,KAAKjjO,gBAAkByjO,GAC1Bpb,GAAG4a,KAAKljO,uBAAyB2jO,GACjCrb,GAAG4a,KAAKxiO,UAAYkjO,GACpBtb,GAAG4a,KAAKliO,QAAU6iO,GAClBvb,GAAG4a,KAAKtiO,UAAYkjO,GACpBxb,GAAGyb,IAAM,CAAA,EACTzb,GAAGyb,IAAIp4K,YAAcq4K,GACrB1b,GAAGyb,IAAIt4K,cAAgBw4K,GACvB3b,GAAGyb,IAAIl4K,QAAUq4K,GACjB5b,GAAGyb,IAAI94K,MAAQk5K,GACf7b,GAAGyb,IAAIK,Y/N9vCA,SAAqBp6K,GACI,oBAAnBC,iBACTP,GAAcO,gBAEhBntD,OAAOmtD,eAAiBD,CAC1B,E+N0vCAs+J,GAAGyb,IAAIh4K,WAAas4K,GACpB/b,GAAGyb,IAAIO,W/NzvCA,WACLxnO,OAAOmtD,eAAiBP,EAC1B,E+NwvCA4+J,GAAG1jO,IAAM,CAAA,EACT0jO,GAAG1jO,IAAIhE,MAAQ2jP,EACfjc,GAAG1jO,IAAI7D,QAAUyjP,EACjBlc,GAAGv+I,KAAO,CAAA,EACVu+I,GAAGv+I,KAAKprE,WAAatC,GACrBisN,GAAGv+I,KAAK06J,MAAQ,GAChBnc,GAAGv+I,KAAK06J,MAAM1oO,gBAAkB2oO,GAChCpc,GAAGv+I,KAAK06J,MAAM5oO,SAAW8oO,GACzBrc,GAAGv+I,KAAK9gE,UAAY27N,GACpBtc,GAAGv+I,KAAK5iE,wBAA0B09N,GAClCvc,GAAGv+I,KAAK1jE,yBAA2By+N,GACnCxc,GAAGv+I,KAAKzjE,wBAA0By+N,GAClCzc,GAAGv+I,KAAKrkE,cAAgBs/N,GACxB1c,GAAGv+I,KAAKlkE,eAAiBo/N,GACzB3c,GAAGv+I,KAAKm7J,oB5T/mCD,WACLC,KACAC,IACF,E4T6mCA9c,GAAGv+I,KAAKs7J,oB5Tx2BD,WACLr9N,GAAiB,IACnB,E4Tu2BAsgN,GAAGv+I,KAAKvkE,eAAiB8/N,GACzBhd,GAAGv+I,KAAKljE,iBAAmB0+N,GAC3Bjd,GAAGv+I,KAAKlhE,8BAAgC28N,GACxCld,GAAGv+I,KAAKhjE,uCAAyC0+N,GACjDnd,GAAGv+I,KAAKzkE,yBAA2BogO,GACnCpd,GAAGv+I,KAAK47J,SAAW,GACnBrd,GAAGv+I,KAAK47J,SAAStnO,OAASunO,GAC1Btd,GAAGv+I,KAAK47J,SAASvnO,UAAYynO,GAC7Bvd,GAAGv+I,KAAK47J,SAASpnO,WAAaunO,GAC9Bxd,GAAGv+I,KAAK47J,SAAS5mO,YAAcgnO,GAC/Bzd,GAAGv+I,KAAK47J,SAASxnO,OAAS6nO,GAC1B1d,GAAGv+I,KAAK47J,SAASrnO,aAAe2nO,GAChC3d,GAAGv+I,KAAK47J,SAAS3mO,aAAeknO,GAChC5d,GAAGv+I,KAAK47J,SAASvmO,WAAa+mO,GAC9B7d,GAAGv+I,KAAKq8J,SAAW,GACnB9d,GAAGv+I,KAAKq8J,SAAS/nO,OAASgoO,GAC1B/d,GAAGv+I,KAAKq8J,SAASrqO,gBAAkBuqO,GACnChe,GAAGv+I,KAAKq8J,SAASrnO,YAAcwnO,GAC/Bje,GAAGv+I,KAAKq8J,SAASjoO,OAASqoO,GAC1Ble,GAAGv+I,KAAKviE,WAAai/N,GACrBne,GAAGv+I,KAAK28J,W5TpiCD,SAAoBrzO,EAAY+H,GAErC,OADAkK,KACOrT,GACLoB,EACA,iBACe5Q,IAAf2Y,EAA2BA,EAAa,YAE5C,E4T8hCAktN,GAAGv+I,KAAK3hE,mBAAqBu+N,GAC7Bre,GAAGv+I,KAAKxhE,eAAiBq+N,GACzBte,GAAGv+I,KAAKphE,mBAAqBk+N,GAC7Bve,GAAGv+I,KAAK1kF,IAAMyhP,GACdxe,GAAGv+I,KAAK9sE,mBAAqB8pO,GAC7Bze,GAAGv+I,KAAKjiE,aAAek/N,GACvB1e,GAAGv+I,KAAK5jE,4BAA8B8gO,GACtC3e,GAAGv+I,KAAK7hE,kBAAoBg/N,GAC5B5e,GAAGv+I,KAAKtkE,kBAAoB0hO,GAC5B7e,GAAGv+I,KAAKolF,MAAQ,GAChBm5D,GAAGv+I,KAAKolF,MAAMi4E,mBnFnxCP,SAA4B5jP,GACjC,OAAO8nE,eAAgBxvD,GACrB,MAAM4vD,QAAiBqf,MACrB,oDAAoDjvE,gDAAmDtY,KAEzG,IAAKkoE,EAASqkG,GACZ,MAAM,IAAItrK,MACR,0CAA0CinE,EAASrB,UAGvD,OAAOqB,EAASsf,OAAOh7E,MAAMg7E,IAC3B,MAAMq8J,EAAUr8J,EAAc,QAC9B,GAAIq8J,GAASjqP,OAAS,EAAG,CACvB,MAAMsvC,EAAS26M,EAAQ3zM,QACpBrzB,GAAiC,SAA3BA,EAAM,IAAe,WAAgBA,EAAM,IAAU,OAAMvE,IAClE,GACF,GAAI4wB,EAAQ,CACV,MAAM/sB,EAAa+sB,EAAwB,gBAC3C,GAAI/sB,GAAYviB,OAAS,EAAG,CAE1B,MAAMkqP,EAAmB56M,EAA+B,uBACxD,GACE/sB,EAAW+zB,QACRzrC,GACCA,EAAM,IAAe,YAAMq/O,GAA8B,WACzDr/O,EAAM,IAAU,OAAMq/O,GAAyB,MACxB,IAAvBr/O,EAAS,OAAG7K,SACdA,OAAS,EAEX,OAAOsvC,EAAgB,SAAW,MAGpC,MAAMz6B,EAAY0N,EACf+zB,QACEzrC,GACwB,IAAvBA,EAAS,OAAG7K,QACuB,SAAnC6K,EAAc,YAAe,WACC,OAA9BA,EAAc,YAAU,OACJ,IAApBA,EAAc,aACE,IAAhBA,EAAU,SAEbsoB,MAAK,CAACsV,EAAIC,IAAOD,EAAa,SAAIC,EAAa,WAAG,IAEpD,SAAU,MACX,GAAI7zB,EACF,OAAOA,CAEV,CAED,OAAOy6B,EAAgB,SAAW,KACnC,CACF,IAEP,CACA,EmF8tCA47L,GAAGv+I,KAAKolF,MAAMo4E,anFnzCPj8K,eAA4BxvD,GACb,iBAATA,IACTA,EAAOpP,SAASoP,EAAKgG,MAAM,KAAK3a,MAAO,KAGzC,MAAMgoK,EAAQF,GACd,IAAKE,EACH,MAAM,IAAI1qK,MAAM,uDAGlB,MAAM+iP,EAAW,QAAU1rO,EAC3B,OAAIqzJ,EAAME,KAAKm4E,KAIfr4E,EAAME,KAAKm4E,QAAgB13E,GAAWh0J,IACtCozJ,GAASC,IAJA9pK,GAAImiP,EAOf,EmFiyCAlf,GAAGv+I,KAAKolF,MAAMs4E,cnFt0CP,WACL,OAAO33E,EACT,EmFq0CAw4D,GAAGv+I,KAAKolF,MAAMu4E,anF16CP,WACL,QAASz4E,EACX,EmFy6CAq5D,GAAGv+I,KAAKolF,MAAMD,SAAWy4E,GACzBrf,GAAGv+I,KAAKolF,MAAMy4E,cnFl1CP,SAAuB/oP,GAC5BixK,GAAajxK,CACf,EmFi1CAypO,GAAGv+I,KAAKolF,MAAMwhB,WnFt6CP,WACL1hB,GAAa,IACf,EmFq6CAq5D,GAAGv+I,KAAKjkE,YAAc,GACtBwiN,GAAGv+I,KAAKjkE,YAAYpG,IAAMmoO,GAC1Bvf,GAAGv+I,KAAKjkE,YAAYllB,MAAQknP,GAC5Bxf,GAAGv+I,KAAKjkE,YAAYzgB,IAAM0iP,GAC1Bzf,GAAGv+I,KAAK9hE,kBAAoB+/N,GAC5B1f,GAAGv+I,KAAKk+J,S5TziCD,SAAkB50O,EAAY+H,GACnC,MAAM8sO,EAASj2O,GACboB,OACe5Q,IAAf2Y,EAA2BA,EAAa,YACxC,aAEIy1J,EAAMq3E,EAAO,GAInB,OAHIr3E,GAAO,KAAOA,EAAM,OACtBq3E,EAAO,GAAKpnO,GAAO+vJ,EAAM,IAAK,KAAO,KAEhCq3E,CACT,E4T+hCA5f,GAAGv+I,KAAK5hE,iBAAmBggO,GAC3B7f,GAAGv+I,KAAKzhE,aAAe8/N,GACvB9f,GAAGv+I,KAAKvhE,iBAAmB6/N,GAC3B/f,GAAGv+I,KAAK93E,UAAYq2O,GACpBhgB,GAAGv+I,KAAKhiE,gBAAkBwgO,GAC1BjgB,GAAGv+I,KAAKy+J,yB5T17BD,SACL3pO,EACA6I,EACAC,GAMA,OAJsBxB,GACpBuB,EACAC,EAEKC,CAAc/I,EACvB,E4Ti7BAypN,GAAGv+I,KAAKpqE,WAAa,GACrB2oN,GAAGv+I,KAAKpqE,WAAWD,IAAM+oO,GACzBngB,GAAGv+I,KAAKpqE,WAAW/e,MAAQ8nP,GAC3BpgB,GAAGv+I,KAAKpqE,WAAWta,IAAMsjP,GACzBrgB,GAAGv+I,KAAKpqE,WAAWhY,OlUv6CZ,SAAgBxB,EAAQyZ,GAC7B,MAAMC,EAAa1Z,EAAOkX,UACpByC,EAAkBF,EAAYvC,UAC9BpL,EAAY0N,GAAWE,GAAYC,GAKzC,cAJOH,GAAWE,GAAYC,GAC1B/e,EAAQ4e,GAAWE,YACdF,GAAWE,GAEb5N,CACT,EkU+5CAq2N,GAAGv+I,KAAK6+J,c5T74BD,WACL3gO,GAAkB,YACpB,E4T44BAqgN,GAAGvvL,OAAS,CAAA,EACZuvL,GAAGvvL,OAAOylJ,IAAMvpI,GAChBqzK,GAAGvvL,OAAO/2C,MAAQ26C,GAClB2rL,GAAGvvL,OAAO1oC,QAAUynF,GACpBwwI,GAAGvvL,OAAO1oC,QAAQw4O,U7L19BX,SAAmB/wK,EAAe+nG,GACvC,MAAMp2K,EAAKquE,EAAcxmE,QACnBT,EAAW+mF,GAAW9f,GACtB/mE,EAAa+mE,EAActyE,gBAC3Bo2C,EAAU,IAAIvrC,GASpB,YARqB5N,IAAjBo9K,GACFjkI,EAAQ3qC,gBAAgB4uK,GAE1BjkI,EAAQ9qC,YAAYD,QACTpO,IAAPgH,GACFmyC,EAAQlqC,MAAMjI,GAEhBmyC,EAAQx2C,cAAc2L,GAAY,GAC3B6qC,CACT,E6L68BA0sL,GAAGvvL,OAAO1oC,QAAQunF,WAAakxJ,GAC/BxgB,GAAGvvL,OAAOi1B,cAAgB9B,GAC1Bo8J,GAAGvvL,OAAOjtC,OAAS,GACnBw8N,GAAGvvL,OAAOjtC,OAAO40J,QAAUrH,GAC3BivE,GAAGvvL,OAAOjtC,OAAOi9O,aAAejoF,GAChCwnE,GAAGvvL,OAAOjtC,OAAOu8J,SAAWhF,GAC5BilE,GAAGvvL,OAAOjtC,OAAOqgK,cAAgBxE,GACjC2gE,GAAGvvL,OAAOjtC,OAAOqgK,cAAc3E,mBAAqBwhF,GACpD1gB,GAAGvvL,OAAOjtC,OAAO60J,aAAerE,GAChCgsE,GAAGvvL,OAAOjtC,OAAOm9O,UAAYl7K,GAC7Bu6J,GAAGvvL,OAAOjtC,OAAOktJ,YAAc,GAC/BsvE,GAAGvvL,OAAOjtC,OAAOktJ,YAAYG,qBAAuB+vF,GACpD5gB,GAAGvvL,OAAOjtC,OAAOktJ,YAAYI,qBAAuB+vF,GACpD7gB,GAAGvvL,OAAOjtC,OAAOktJ,YAAYC,gBAAkBmwF,GAC/C9gB,GAAGvvL,OAAOjtC,OAAOktJ,YAAYE,kBAAoBmwF,GACjD/gB,GAAGvvL,OAAOjtC,OAAO80J,kBAAoB3D,GACrCqrE,GAAGvvL,OAAOjtC,OAAO00J,eAAiBnD,GAClCirE,GAAGvvL,OAAOjtC,OAAO+0J,YAAc7B,GAC/BspE,GAAGvvL,OAAOjtC,OAAO+0J,YAAYnC,WAAa4qF,GAC1ChhB,GAAGvvL,OAAOjtC,OAAOyyC,aAAegrM,GAChCjhB,GAAGvvL,OAAOjtC,OAAOgyC,iBAAmB0rM,GACpClhB,GAAGvvL,OAAOjtC,OAAO+xC,YAAc4rM,GAC/BnhB,GAAGvvL,OAAOjtC,OAAOiyC,eAAiB2rM,GAClCphB,GAAGvvL,OAAOjtC,OAAOkyC,gBAAkB2rM,GACnCrhB,GAAGvvL,OAAOjtC,OAAO89O,sB5Q/3CoB,E4Qg4CrCthB,GAAGvvL,OAAOjtC,OAAOmyC,gBAAkB4rM,GACnCvhB,GAAGvvL,OAAOjtC,OAAOg+O,iB5Qv1Ce,E4Qw1ChCxhB,GAAGvvL,OAAOjtC,OAAOoyC,kBAAoB6rM,GACrCzhB,GAAGvvL,OAAOjtC,OAAOwyC,eAAiB0rM,GAClC1hB,GAAGvvL,OAAOjtC,OAAOqyC,mBAAqB8rM,GACtC3hB,GAAGvvL,OAAOjtC,OAAOsyC,iBAAmB8rM,GACpC5hB,GAAGvvL,OAAOjtC,OAAOuyC,oBAAsB8rM,GACvC7hB,GAAGvvL,OAAOjtC,OAAOw1C,iBAAmB8oM,GACpC9hB,GAAGvvL,OAAOjtC,OAAO+0C,kBAAoBwpM,GACrC/hB,GAAGvvL,OAAOjtC,OAAOw+O,UAAY,GAC7BhiB,GAAGvvL,OAAOjtC,OAAOw+O,UAAUzhF,sBAAwB0hF,GACnDjiB,GAAGvvL,OAAOjtC,OAAOw+O,UAAUxhF,4BAA8B0hF,GACzDliB,GAAGvvL,OAAOjtC,OAAOw+O,UAAU3gF,UAAY8gF,GACvCniB,GAAGvvL,OAAOjtC,OAAO40C,yBAA2BgqM,GAC5CpiB,GAAGvvL,OAAOjtC,OAAO+zC,kBAAoB8qM,GACrCriB,GAAGvvL,OAAOjtC,OAAOwzC,iBAAmBsrM,GACpCtiB,GAAGvvL,OAAOjtC,OAAO6yC,aAAeksM,GAChCviB,GAAGvvL,OAAOjtC,OAAOg/O,e5QnnCV,SAAwB1+O,EAASyM,EAAU64B,EAASC,GACxC,IAAb94B,IACFzM,EAAQ0H,UAAU49B,EAASC,GAC3BvlC,EAAQoH,OAAOqF,GACfzM,EAAQ0H,WAAW49B,GAAUC,GAEjC,E4Q8mCA22L,GAAGvvL,OAAOjtC,OAAOU,MAAQ,GACzB87N,GAAGvvL,OAAOjtC,OAAOU,MAAMs+I,aAAeigG,GACtCziB,GAAGvvL,OAAOjtC,OAAOU,MAAM2+I,WAAa6/F,GACpC1iB,GAAGvvL,OAAOjtC,OAAOU,MAAMw+I,0BAA4BigG,GACnD3iB,GAAGvvL,OAAOjtC,OAAOU,MAAMo+I,qBAAuBsgG,GAC9C5iB,GAAGvvL,OAAOjtC,OAAO4yC,YAAcysM,GAC/B7iB,GAAGvvL,OAAOqyM,e1Nj4CH,SAAwBtpP,EAAOy3C,GACpC,OAAO3+B,GAAe9Y,EAAM86C,sBAAuBrD,EAAMx5C,MAAM,GACjE,E0Ng4CAuoO,GAAGvvL,OAAOu/B,iBAAmB+yK,GAC7B/iB,GAAGvvL,OAAOuyM,U1Nv8CH,SAAmBl/O,EAASxF,GACjC,MAAMkF,EAASM,EAAQN,OAEjBurB,GADNzwB,EAAUA,GAAoB,IACHywB,YAAc5sB,GACnCkF,EAAO/I,EAAQ+I,KACjBA,IACF7D,EAAOJ,MAAQiE,EAAK,GAAK0nB,EACzBvrB,EAAOH,OAASgE,EAAK,GAAK0nB,EAC1BvrB,EAAOU,MAAMd,MAAQiE,EAAK,GAAK,KAC/B7D,EAAOU,MAAMb,OAASgE,EAAK,GAAK,MAElC,MAAM8F,EAAS,CAAC,EAAG,EAAG3J,EAAOJ,MAAOI,EAAOH,QACrCsG,EAAYy9H,GhH9CX,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GgH8C6Br4G,EAAYA,GAChE,OAAO,IAAIqhD,GAAwBtsE,EAASirB,EAAY5hB,EAAQxD,EAAW,EAC7E,E0N07CAq2N,GAAGvvL,OAAOwyM,MAAQ,GAClBjjB,GAAGvvL,OAAOwyM,MAAMhwG,mBAAqB7C,GACrC4vF,GAAGvvL,OAAOwyM,MAAMzzF,oBAAsBhD,GACtCwzE,GAAGvvL,OAAOwyM,MAAMC,mBAAqB,GACrCljB,GAAGvvL,OAAOwyM,MAAMC,mBAAmB92F,qCAAuC+2F,GAC1EnjB,GAAGvvL,OAAOwyM,MAAMC,mBAAmBl3F,gCAAkCo3F,GACrEpjB,GAAGvvL,OAAOwyM,MAAMC,mBAAmB72F,kCAAoCg3F,GACvErjB,GAAGvvL,OAAOwyM,MAAMC,mBAAmBn3F,wBAA0Bu3F,GAC7DtjB,GAAGvvL,OAAOwyM,MAAMM,MAAQ,GACxBvjB,GAAGvvL,OAAOwyM,MAAMM,MAAMzpH,+BAAiC0pH,GACvDxjB,GAAGvvL,OAAOwyM,MAAMM,MAAMhpH,cAAgBkpH,GACtCzjB,GAAGvvL,OAAOwyM,MAAMM,MAAMnpH,cAAgBspH,GACtC1jB,GAAGvvL,OAAOwyM,MAAMM,MAAMI,kBpIjqCf,WACL,MACMl9O,EADS/C,SAASC,cAAc,UACjBC,WAAW,MAAM8yF,gBAAgB,EAAG,GAKzD,OAJAjwF,EAAM3Q,KAAK,GAAK,IAChB2Q,EAAM3Q,KAAK,GAAK,IAChB2Q,EAAM3Q,KAAK,GAAK,IAChB2Q,EAAM3Q,KAAK,GAAK,IACT2Q,CACT,EoI0pCAu5N,GAAGvvL,OAAOwyM,MAAMM,MAAMK,0BpI94Cf,SACLxyF,EACAyyF,EACAC,EACAC,EACAC,EACAC,EACAC,EACA/6F,EACAg7F,EACAC,EACAC,GAGA,MACM11O,EADuB,EACSw6I,EAAiBr0J,OACjDwvP,EAAYL,EAAYnvP,OAAS6Z,EAKjC0oJ,EAAK,CACTjG,EAAayyF,EAAoB,GACjCzyF,EAAayyF,EAAoB,IAE7BtrH,EAAK,CAAC64B,EAAa0yF,GAAkB1yF,EAAa0yF,EAAkB,IAGpES,EAAUjyO,GAAe6xO,EAAkB,IAAI9sF,IAC/CmtF,EAAUlyO,GAAe6xO,EAAkB,IAAI5rH,IASrD,SAASksH,EAAaptF,EAAIqtF,EAAIC,GAC5B,MAAMC,EAAOhlP,KAAKma,MACf2qO,EAAG,GAAKrtF,EAAG,KAAOqtF,EAAG,GAAKrtF,EAAG,KAAOqtF,EAAG,GAAKrtF,EAAG,KAAOqtF,EAAG,GAAKrtF,EAAG,KAE9DwtF,EAAW,EAAEH,EAAG,GAAKrtF,EAAG,IAAMutF,GAAOF,EAAG,GAAKrtF,EAAG,IAAMutF,GACtDE,EAAS,EAAED,EAAS,GAAIA,EAAS,IACjCE,EAAOnlP,KAAKma,MACf4qO,EAAG,GAAKttF,EAAG,KAAOstF,EAAG,GAAKttF,EAAG,KAAOstF,EAAG,GAAKttF,EAAG,KAAOstF,EAAG,GAAKttF,EAAG,KAE9D2tF,EAAW,EAAEL,EAAG,GAAKttF,EAAG,IAAM0tF,GAAOJ,EAAG,GAAKttF,EAAG,IAAM0tF,GAGtD55O,EACK,IAATy5O,GAAuB,IAATG,EACV,EACAnlP,KAAK+1J,KACHl+I,GAAMutO,EAAS,GAAKH,EAAS,GAAKG,EAAS,GAAKH,EAAS,IAAK,EAAG,IAGzE,OADoBG,EAAS,GAAKF,EAAO,GAAKE,EAAS,GAAKF,EAAO,GAAK,EAC5B35O,EAAZ,EAAVvL,KAAK+T,GAASxI,CACrC,CAGD,IAAIiuI,GAAU,EACV6rG,GAAU,EACVC,EAAqBb,EAEzB,MACMc,EAAkC,OAAtBnB,EAGlB,GAJ0C,OAAvBD,EAIH,CAOd3qG,EAASqrG,EAAaF,EAASC,EADflyO,GAAe6xO,EAAkB,IAJtC,CACT/yF,EAAa2yF,GACb3yF,EAAa2yF,EAAqB,OAMhCnkP,KAAKwL,IAAIguI,IAAWtf,KACtBorH,GAAsBtlP,KAAKuW,KAAKijI,EAASx5I,KAAK+T,IAAM,GAEvD,CAED,GAAIwxO,EAAW,CAObF,EAASR,EAAaD,EAASD,EADfjyO,GAAe6xO,EAAkB,IAJtC,CACT/yF,EAAa4yF,GACb5yF,EAAa4yF,EAAoB,OAM/BpkP,KAAKwL,IAAI65O,IAAWnrH,KACtBorH,GAAsBtlP,KAAKuW,KAAKvW,KAAK+T,GAAKsxO,GAAU,GAEvD,CAOD,SAASG,EAAkBC,EAAaC,GACtC,OAAiB,IAAbA,EACmB,IAAdD,EAEFzlP,KAAKg5H,KAAK0sH,IAA2B,IAAdD,EAAsBzlP,KAAKmP,IAAIu2O,GAC9D,CA4DD,OAzDArB,EAAY3qP,KACV+9J,EAAG,GACHA,EAAG,GACH9+B,EAAG,GACHA,EAAG,GACH6gB,EACA6rG,EACAb,EACAgB,EAAkB,EAAGf,IAEvBJ,EAAY3qP,QAAQ6vJ,GAEpB86F,EAAY3qP,KACV+9J,EAAG,GACHA,EAAG,GACH9+B,EAAG,GACHA,EAAG,GACH6gB,EACA6rG,EACAb,EACAgB,EAAkB,EAAGf,IAEvBJ,EAAY3qP,QAAQ6vJ,GAEpB86F,EAAY3qP,KACV+9J,EAAG,GACHA,EAAG,GACH9+B,EAAG,GACHA,EAAG,GACH6gB,EACA6rG,EACAb,EACAgB,EAAkB,EAAGf,IAEvBJ,EAAY3qP,QAAQ6vJ,GAEpB86F,EAAY3qP,KACV+9J,EAAG,GACHA,EAAG,GACH9+B,EAAG,GACHA,EAAG,GACH6gB,EACA6rG,EACAb,EACAgB,EAAkB,EAAGf,IAEvBJ,EAAY3qP,QAAQ6vJ,GAEpB+6F,EAAW5qP,KACTgrP,EACAA,EAAY,EACZA,EAAY,EACZA,EAAY,EACZA,EAAY,EACZA,EAAY,GAGP,CACLxvP,OACEsvP,EACAxkP,KAAKma,MACFyqO,EAAQ,GAAKD,EAAQ,KAAOC,EAAQ,GAAKD,EAAQ,KAC/CC,EAAQ,GAAKD,EAAQ,KAAOC,EAAQ,GAAKD,EAAQ,KAExDp5O,MAAO+5O,EAEX,EoI6tCAllB,GAAGvvL,OAAOwyM,MAAMM,MAAMgC,2BpI9+Cf,SACLn0F,EACAo0F,EACA37F,EACAC,EACA0B,EACAi6F,GAGA,MAEM92O,EAFuB,EAES68I,EAEhCxgJ,EAAIomJ,EAAao0F,EAAe,GAChCv6O,EAAImmJ,EAAao0F,EAAe,GAGhCE,EAAc3rH,GACpB2rH,EAAY5wP,OAAS02J,EACrB,IAAK,IAAIj2J,EAAI,EAAGA,EAAImwP,EAAY5wP,OAAQS,IACtCmwP,EAAYnwP,GAAK67J,EAAao0F,EAVF,EAUyCjwP,GAGvE,IAAIowP,EAAOF,EAAkBA,EAAgBxrH,eAAiB,EAC1D2rH,EAAOH,EAAkBA,EAAgBvrH,cAAgB,EAC7D,MAAMoqH,EAAYqB,EAAOh3O,EAiCzB,OA9BAwrH,GAAiB0vB,EAAc87F,EAAM36O,EAAGC,EAAG,GAC3Cy6O,EAAY5wP,QACV+0J,EAAansJ,IAAIgoP,EAAaC,EArBH,GAsB7BA,GAAQh3O,EAERwrH,GAAiB0vB,EAAc87F,EAAM36O,EAAGC,EAAG,GAC3Cy6O,EAAY5wP,QACV+0J,EAAansJ,IAAIgoP,EAAaC,EA1BH,GA2B7BA,GAAQh3O,EAERwrH,GAAiB0vB,EAAc87F,EAAM36O,EAAGC,EAAG,GAC3Cy6O,EAAY5wP,QACV+0J,EAAansJ,IAAIgoP,EAAaC,EA/BH,GAgC7BA,GAAQh3O,EAERwrH,GAAiB0vB,EAAc87F,EAAM36O,EAAGC,EAAG,GAC3Cy6O,EAAY5wP,QACV+0J,EAAansJ,IAAIgoP,EAAaC,EApCH,GAqC7BA,GAAQh3O,EAERm7I,EAAY87F,KAAUtB,EACtBx6F,EAAY87F,KAAUtB,EAAY,EAClCx6F,EAAY87F,KAAUtB,EAAY,EAClCx6F,EAAY87F,KAAUtB,EAAY,EAClCx6F,EAAY87F,KAAUtB,EAAY,EAClCx6F,EAAY87F,KAAUtB,EAAY,EAElCtqH,GAAiBC,eAAiB0rH,EAClC3rH,GAAiBE,cAAgB0rH,EAE1B5rH,EACT,EoIo7CAgmG,GAAGvvL,OAAOwyM,MAAMM,MAAMsC,+BpIltCf,SACLz0F,EACA00F,EACA7B,EACAC,EACA14F,GAEA,MACMu6F,EAAsB,EAAIv6F,EAChC,IAAIw6F,EAAoBF,EACxB,MAAM38F,EAAmBiI,EAAa35J,MACpCuuP,EACAA,EAAoBx6F,GAEtBw6F,GAAqBx6F,EACrB,MAAM1a,EAAasgB,EAAa40F,KAChC,IAAIn1G,EAAgB,EACpB,MAAMjX,EAAQ,IAAI5jI,MAAM86I,EAAa,GACrC,IAAK,IAAIv7I,EAAI,EAAGA,EAAIu7I,EAAYv7I,IAC9Bs7I,GAAiBugB,EAAa40F,KAC1BzwP,EAAIu7I,EAAa,IACnBlX,EAAMrkI,GAAKs7I,GAGf,MAAMV,EAAaihB,EAAa35J,MAC9BuuP,EACAA,EAnB4B,EAmBRn1G,GAIhBzsG,EAASiwF,GAAO8b,EAAYvW,EAvBJ,GAwB9B,IAAK,IAAIrkI,EAAI,EAAGA,EAAI6uC,EAAOtvC,OAAQS,IACjC2uP,EAAW5qP,KAAK8qC,EAAO7uC,GAAK0uP,EAAYnvP,OAASixP,GAEnD,IAAK,IAAIxwP,EAAI,EAAGA,EAAI46I,EAAWr7I,OAAQS,GAAK,EAC1C0uP,EAAY3qP,KAAK62I,EAAW56I,GAAI46I,EAAW56I,EAAI,MAAO4zJ,GAGxD,OAAO68F,EA/BuB,EA+BHn1G,CAC7B,EoI4qCAmvF,GAAGnoK,SAAW,CAAA,EACdmoK,GAAGnoK,SAASouL,UAAYvsM,GACxBsmL,GAAGnoK,SAAShF,MAAQk9C,GACpBiwH,GAAGnoK,SAAS04E,IAAM59F,GAClBqtL,GAAGnoK,SAASr0D,OAAS,GACrBw8N,GAAGnoK,SAASr0D,OAAO43G,WAAanJ,GAChC+tH,GAAGnoK,SAASr0D,OAAOqvD,MAAQ69C,GAC3BsvH,GAAGnoK,SAASr0D,OAAOqvD,MAAMvvD,WAAa4iP,GACtClmB,GAAGnoK,SAASr0D,OAAO23G,UAAYtH,GAC/BmsH,GAAGnoK,SAASr0D,OAAO2iP,iBAAmBriF,GACtCk8D,GAAGnoK,SAASr0D,OAAOslK,YAAcvH,GACjCy+D,GAAGnoK,SAASr0D,OAAO4iP,gBAAkBthF,GACrCk7D,GAAGnoK,SAAS+sG,OAAS,GACrBo7D,GAAGnoK,SAAS+sG,OAAOz1F,aAAek3K,GAClCrmB,GAAGnoK,SAAS+sG,OAAOt1F,oBAAsBg3K,GACzCtmB,GAAGnoK,SAAS+sG,OAAOr1F,aAAeg3K,GAClCvmB,GAAGnoK,SAAS+sG,OAAOp1F,cAAgBg3K,GACnCxmB,GAAGnoK,SAASorL,MAAQ,GACpBjjB,GAAGnoK,SAASorL,MAAMpwL,MAAQixE,GAC1Bk8F,GAAGnoK,SAASorL,MAAMwD,YAAc79F,GAChCo3E,GAAGnoK,SAASorL,MAAM9nI,UAAYmtB,GAC9B03F,GAAGnoK,SAASorL,MAAM9nI,UAAUgtB,WAAau+G,GACzC1mB,GAAGnoK,SAASorL,MAAM9nI,UAAU4oB,SAAW4iH,GACvC3mB,GAAGnoK,SAASorL,MAAM2D,cAAgB1hH,GAClC86F,GAAGnoK,SAASorL,MAAM2D,cAAc7iH,SAAW8iH,GAC3C7mB,GAAGnoK,SAASorL,MAAM2D,cAAc5hH,YAAc8hH,GAC9C9mB,GAAGnoK,SAASorL,MAAM2D,cAAcriH,4BAA8BwiH,GAC9D/mB,GAAGnoK,SAASorL,MAAMn6E,YAAcha,GAChCkxE,GAAGnoK,SAASorL,MAAMn6E,YAAY/kC,SAAWijH,GACzChnB,GAAGnoK,SAASorL,MAAMmD,gBAAkBr2F,GACpCiwE,GAAGnoK,SAASorL,MAAMmD,gBAAgBj+G,WAAa8+G,GAC/CjnB,GAAGnoK,SAASorL,MAAMmD,gBAAgBriH,SAAWmjH,GAC7ClnB,GAAGxpI,OAAS,CAAA,EACZwpI,GAAGxpI,OAAO9B,SAAWD,GACrBurI,GAAGxpI,OAAO9zF,MAAQ4hG,GAClB07H,GAAGxpI,OAAOzvF,KAAOovE,GACjB6pJ,GAAGxpI,OAAOnf,cAAgBpE,GAC1B+sJ,GAAGxpI,OAAOzlB,gCAAkCo2K,GAC5CnnB,GAAGxpI,OAAO7lB,0BAA4By2K,GACtCpnB,GAAGxpI,OAAOlzF,WAAa+jP,GACvBrnB,GAAGxpI,OAAO8wJ,OAAS,GACnBtnB,GAAGxpI,OAAO8wJ,OAAOt0K,gBAAkBu0K,GACnCvnB,GAAGxpI,OAAO/lD,OAAS+2M,GACnBxnB,GAAG1vN,WAAa,CAAA,EAChB0vN,GAAG1vN,WAAWyiE,mBAAqB00K,GACnCznB,GAAG0nB,qBAAuB,CAAA,EAC1B1nB,GAAG0nB,qBAAqB5iN,uBAAyB6iN,GACjD3nB,GAAG0nB,qBAAqBjjN,kBAAoBmjN,GAC5C5nB,GAAG0nB,qBAAqBrjN,wBAA0BwjN,GAClD7nB,GAAG8nB,mBAAqB,CAAA,EACxB9nB,GAAG8nB,mBAAmB/iN,cAAgBgjN,GACtC/nB,GAAG8nB,mBAAmB7iN,iBAAmB+iN,GACzChoB,GAAG8nB,mBAAmB7qO,QAAUgrO,GAChCjoB,GAAG8nB,mBAAmBnrO,KAAOurO,GAC7BloB,GAAG34N,KAAO,CAAA,EACV24N,GAAG34N,KAAKiG,O1OpkDD,SAAgBjG,EAAM4xH,EAAK1rH,GAMhC,YALapT,IAAToT,IACFA,EAAO,CAAC,EAAG,IAEbA,EAAK,GAAKlG,EAAK,GAAK,EAAI4xH,EACxB1rH,EAAK,GAAKlG,EAAK,GAAK,EAAI4xH,EACjB1rH,CACT,E0O8jDAyyN,GAAG34N,KAAKqrD,QAAUy1L,GAClBnoB,GAAG34N,KAAKiE,MAAQ88O,GAChBpoB,GAAG34N,KAAKsrD,OAAS01L,GACjBroB,GAAGniO,OAAS,CAAA,EACZmiO,GAAGniO,OAAOyqP,SAAWzmK,GACrBm+I,GAAGniO,OAAOyqP,SAAS5mK,QAAU6mK,GAC7BvoB,GAAGniO,OAAO2qP,QAAUlkK,GACpB07I,GAAGniO,OAAO4qP,QAAUj1J,GACpBwsI,GAAGniO,OAAO62F,SAAWkC,GACrBopI,GAAGniO,OAAO+5F,QAAUqH,GACpB+gI,GAAGniO,OAAO6qP,KAAO5lJ,GACjBk9H,GAAGniO,OAAO6E,MAAQ2iG,GAClB26H,GAAGniO,OAAO6E,MAAMuiG,iBAAmB0jJ,GACnC3oB,GAAGniO,OAAO6E,MAAMwiG,yBAA2B0jJ,GAC3C5oB,GAAGniO,OAAO6E,MAAMyiG,iBAAmB0jJ,GACnC7oB,GAAGniO,OAAOirP,gBAAkBhiJ,GAC5Bk5H,GAAGniO,OAAOkqG,YAAcJ,GACxBq4H,GAAGniO,OAAOkrP,cAAgB1/I,GAC1B22H,GAAGniO,OAAOmrP,YAAcr/I,GACxBq2H,GAAGniO,OAAOorP,SAAWl+I,GACrBi1H,GAAGniO,OAAOqrP,WAAa96I,GACvB4xH,GAAGniO,OAAOsrP,cAAgBz5I,GAC1BswH,GAAGniO,OAAOurP,IAAMv5I,GAChBmwH,GAAGniO,OAAOurP,IAAIx5I,YAAcy5I,GAC5BrpB,GAAGniO,OAAOyrP,OAASjuI,GACnB2kH,GAAGniO,OAAOyrP,OAAOnxI,UAAYoxI,GAC7BvpB,GAAGniO,OAAOyrP,OAAO1vI,kBAAoB4vI,GACrCxpB,GAAGniO,OAAOyrP,OAAOxyI,aAAe2yI,GAChCzpB,GAAGniO,OAAOu+E,OAAShE,GACnB4nJ,GAAGniO,OAAO6rP,WAAantI,GACvByjH,GAAGniO,OAAOkJ,KAAOo1E,GACjB6jJ,GAAGniO,OAAOkJ,KAAKm1E,gBAAkBytK,GACjC3pB,GAAGniO,OAAO+rP,eAAiB9sI,GAC3BkjH,GAAGniO,OAAOgsP,UAAY5sI,GACtB+iH,GAAGniO,OAAOikF,UAAYzB,GACtB2/I,GAAGniO,OAAOisP,SAAW3sI,GACrB6iH,GAAGniO,OAAOksP,QAAUhsI,GACpBiiH,GAAGniO,OAAOmsP,QAAUprI,GACpBohH,GAAGniO,OAAOmsP,QAAQnqJ,WAAaoqJ,GAC/BjqB,GAAGniO,OAAOshF,QAAUe,GACpB8/I,GAAGniO,OAAOy8O,OAAS3qJ,GACnBqwI,GAAGniO,OAAOy8O,OAAO5qJ,kBAAoBw6J,GACrClqB,GAAGniO,OAAOojO,WAAazyH,GACvBwxH,GAAGniO,OAAOojO,WAAWxyH,oBAAsB07I,GAC3CnqB,GAAGniO,OAAOusP,KAAOlqI,GACjB8/G,GAAGniO,OAAOusP,KAAKC,wBhJ1xCR,SAAiCC,EAAS1lK,GAC/C,MACMjyE,EADS23O,EAAkB,SAAS,MACzB54M,MAAK,SAAUquE,GAC9B,OAAOA,EAAgB,YAAKn7B,EAAc,KAC9C,IACE,IAAKjyE,EACH,OAAO,KAET,MAAM43O,EAAiBD,EAAkB,SAAiB,cAC1D,IAAIj/F,EAGAA,EAFA14I,EAAqB,kBAAE7d,OAAS,EAC9B,eAAgB8vF,EACZjyE,EAAqB,kBAAE63O,WAAU,SAAUzqI,GAC/C,MAGM0qI,EAHgBF,EAAe74M,MAAK,SAAUg5M,GAClD,OAAOA,EAAe,YAAK3qI,EAAmB,aACxD,IACyD,aAC3CsnD,EAAQ9kJ,GAAckoO,GACtBljF,EAAQhlJ,GAAcqiE,EAAmB,YAC/C,OAAIyiF,GAASE,EACJroJ,GAAWmoJ,EAAOE,GAEpBkjF,GAAgB7lK,EAAmB,UAClD,IAEYjyE,EAAqB,kBAAE63O,WAAU,SAAUzqI,GAC/C,OAAOA,EAAmB,eAAKn7B,EAAkB,SACzD,IAGU,EAEJymE,EAAM,IACRA,EAAM,GAER,MAAM7rC,EAEH7sG,EAAqB,kBAAE04I,GAAqB,cACzC5rC,EAEH9sG,EAAqB,kBAAE04I,GAA2B,oBAErD,IAAI1wI,EAAgChI,EAAU,OAAE,GAC5C,WAAYiyE,IACdjqE,EAASiqE,EAAe,QAE1BymE,EAAM14I,EAAS,MAAE63O,WAAU,SAAUzqI,GACnC,MAAI,UAAWn7B,EACNm7B,EAAW,OAAKn7B,EAAc,MAEhCm7B,EAAe,SAC1B,IACMsrC,EAAM,IACRA,EAAM,GAER,MAAMnnJ,EAA+ByO,EAAS,MAAE04I,GAAkB,WAE5D/qC,EAAa,CAAA,EACf,cAAe3tG,GACjBA,EAAa,UAAE7T,SAAQ,SAAUihH,EAAKnpH,EAAOyH,GAC3C,MAAMnD,EAAM6kH,EAAgB,WAC5B,IAAI/nH,EAAQ+nH,EAAa,aACX5lH,IAAVnC,IACFA,EAAQ+nH,EAAW,MAAE,IAEvBO,EAAWplH,GAAOlD,CACxB,IAGE,MACM2yP,EADaL,EAAkB,SAAiB,cACtB54M,MAAK,SAAUquE,GAC7C,OAAOA,EAAgB,YAAKP,CAChC,IAEE,IAAI1sG,EACJ,MAAMU,EAAOm3O,EAA2B,aAIxC,GAHIn3O,IACFV,EAAayP,GAAc/O,IAEzB,eAAgBoxE,EAAQ,CAC1B,MAAMgmK,EAAaroO,GAAcqiE,EAAmB,YAChDgmK,IACG93O,IAAcoM,GAAW0rO,EAAY93O,KACxCA,EAAa83O,GAGlB,CAED,IAAI/3O,GAAQ,EACZ,MAAMg4O,EAA2D,MAAhD/3O,EAAWqC,qBAAqB80F,OAAO,EAAG,GAE3D,IAAIuC,EAASm+I,EAAatpI,WAAW,GAGjCypI,EAAsB,CACxB31B,WAAY,EACZF,WAAY,EAEZG,WAAY5oH,EAAOwpH,YAAc,EACjCd,WAAY1oH,EAAOypH,aAAe,GAIpC,GAAIx2G,EAAc,CAChBqrI,EAAsBrrI,EAAaA,EAAa3qH,OAAS,GACzD,MAAMgf,EAAI62O,EAAatpI,WAAW3vE,MAC/Bq5M,GACCA,EAAgBv5B,aAAes5B,EAAoBzpI,YACnDspI,EAAan5B,WAAa,IAAMu5B,EAAgBv5B,aAC9Cs5B,EAAoBzpI,aAEtBvtG,IACF04F,EAAS14F,EAEZ,CAED,MAAMxD,EACuB,MAA1Bk8F,EAAOqpH,iBAA8B/iN,EAAWmC,mBAC7CmkE,EAASyxK,EACX,CAACr+I,EAAOopH,cAAc,GAAIppH,EAAOopH,cAAc,IAC/CppH,EAAOopH,cACLo1B,EAAYx+I,EAAOspH,UAAYxlN,EAC/B26O,EAAYz+I,EAAOupH,WAAazlN,EACtC,IAAI46O,EAAkBP,EAA0B,YAC5CO,GAAmBL,IACrBK,EAAkB,CAChBA,EAAgB,GAChBA,EAAgB,GAChBA,EAAgB,GAChBA,EAAgB,KAGpB,IAAI/9O,EAAS,CACXisE,EAAO,GAAK4xK,EAAYF,EAAoB31B,WAE5C/7I,EAAO,GAAK6xK,GAAa,EAAIH,EAAoB51B,YACjD97I,EAAO,GAAK4xK,GAAa,EAAIF,EAAoB11B,YACjDh8I,EAAO,GAAK6xK,EAAYH,EAAoB71B,YAG9C,QACsB96N,IAApB+wP,IACCv9O,GAAeu9O,EAAiB/9O,GACjC,CACA,MAAMg+O,EAAmBx4O,EAAoB,iBACvCy4O,EAAwB7oO,GAAc,aAAavP,YAEzD,GADA7F,EAAS+9O,EACLC,EACFt4O,EACEs4O,EAAiB,KAAOC,EAAsB,IAC9CD,EAAiB,KAAOC,EAAsB,OAC3C,CACL,MAAMC,EAAuB5rO,GAC3ByrO,EACAP,EAA2B,aAC3B,aAGF93O,EACEw4O,EAAqB,GAAK,OAASD,EAAsB,IACzDC,EAAqB,GAAK,OAASD,EAAsB,EAC5D,CACF,CAED,MAAM51O,EAAW+pG,GACforI,EACAx9O,EACAsyG,GAII7gC,EAAO,GACb,IAAIuhC,EAAkBv7B,EAAwB,gBAG9C,GAFAu7B,OAAsChmH,IAApBgmH,EAAgCA,EAAkB,GAGlE,uBAAwBmqI,GACxB,YAAaA,EAA4B,mBACzC,CACA,MAAMgB,EAAOhB,EAA4B,mBAAW,QAAO,IAAQ,KAAO,IAE1E,IAAK,IAAI/0P,EAAI,EAAGuE,EAAKwxP,EAAKx2P,OAAQS,EAAIuE,IAAMvE,EAC1C,GAAI+1P,EAAK/1P,GAAe,WAAG,CACzB,MAGMg2P,EAHaD,EAAK/1P,GAAe,WAAEm8C,MAAK,SAAUxzC,GACtD,MAA0B,eAAnBA,EAAc,IAC/B,IACoD,cAAS,MAMrD,GAJwB,KAApBiiH,IAEFA,EAAkBorI,EAAU,IAEN,QAApBprI,EAKF,MAJIorI,EAAUlyP,SAAS,QACrBulF,EAAKtlF,KAA4BgyP,EAAK/1P,GAAU,KAKrD,MAAU+1P,EAAK/1P,GAAS,OACvB4qH,EAAkB,MAClBvhC,EAAKtlF,KAA4BgyP,EAAK/1P,GAAU,MAGrD,CAWD,OAVoB,IAAhBqpF,EAAK9pF,SACPqrH,EAAkB,OAClBxtG,EAAe,YAAE7T,SAAQ,SAAUZ,GACD,SAA5BA,EAAsB,eACxByc,EAASzc,EAAgB,OACzB0gF,EAAKtlF,KAA4B4E,EAAmB,UAE5D,KAGS,CACL0gF,KAAMA,EACNr9C,MAAOqjD,EAAc,MACrB46B,UAAWA,EACX7kG,OAAQA,EACR7H,WAAYA,EACZqtG,gBAAiBA,EACjB3qG,SAAUA,EACVtR,MAAOA,EACPo8G,WAAYA,EACZztG,MAAOA,EACPmd,YAAa40D,EAAoB,YAErC,EgJujCAo7I,GAAGniO,OAAO0mF,IAAMF,GAChB27I,GAAGniO,OAAO2tP,QAAUrsJ,GACpB6gI,GAAGniO,OAAO2tP,QAAQ3rJ,WAAa4rJ,GAC/BzrB,GAAGniO,OAAO6tP,WAAa,GACvB1rB,GAAGniO,OAAO6tP,WAAWhlJ,aAAeilJ,GACpC3rB,GAAGniO,OAAO6tP,WAAWnlJ,cAAgBqlJ,GACrC5rB,GAAGniO,OAAOypP,OAAS,GACnBtnB,GAAGniO,OAAOypP,OAAOviJ,SAAW8mJ,GAC5B7rB,GAAGniO,OAAOypP,OAAOwE,oBlLpoDkB,QkLqoDnC9rB,GAAGniO,OAAOkuP,SAAW,GACrB/rB,GAAGniO,OAAOkuP,SAASrlJ,aAAeslJ,GAClChsB,GAAGniO,OAAOouP,YAAc,GACxBjsB,GAAGniO,OAAOouP,YAAY7gJ,sBAAwB8gJ,GAC9ClsB,GAAGniO,OAAOouP,YAAYl+I,eAAiBo+I,GACvCnsB,GAAGniO,OAAOouP,YAAYrgJ,yBAA2BwgJ,GACjDpsB,GAAGniO,OAAOwuP,oBE5lDH,SAA6B72O,EAAUo1L,GAC5C,MAAM0hD,EAAc,IAAIxtL,GAAS,IAC3BytL,EAAiB/2O,EAASxC,YAChC,OAAO,SAAU7F,EAAQmD,GACvBg8O,EAAY/uL,cACRgvL,IACFp/O,EAASoE,GAAgBg7O,EAAgBp/O,IAE3C,MAAM+lB,EAAI1d,EAAS8hE,kBAAkBhnE,GAC/Bk8O,EAAgB,GAStB,OARAh3O,EAASwkE,iBAAiB7sE,EAAQ+lB,GAAIhzB,IACpC,MAAMhF,EAAMgF,EAAUqM,WACtB,IAAK+/O,EAAY7uL,YAAYviE,GAAM,CACjC,MAAM2C,EAAS+sM,EAAQ1qM,GACvBosP,EAAY5uP,IAAIxC,EAAK2C,EACtB,CACD2uP,EAAclzP,KAAKgzP,EAAYvvP,IAAI7B,GAAK,IAEnCsxP,CACX,CACA,EFykDAxsB,GAAGniO,OAAO4uP,OAAS,GACnBzsB,GAAGniO,OAAO4uP,OAAO/lJ,aAAegmJ,GAChC1sB,GAAGniO,OAAO8uP,IAAM,GAChB3sB,GAAGniO,OAAO8uP,IAAI7iJ,gBAAkB8iJ,GAChC5sB,GAAGniO,OAAO8uP,IAAIjmJ,aAAemmJ,GAC7B7sB,GAAGniO,OAAO8uP,IAAIniJ,kBAAoBsiJ,GAClC9sB,GAAGniO,OAAO8uP,IAAIziJ,YAAc6iJ,GAC5B/sB,GAAGniO,OAAO8uP,IAAI/hJ,aAAeoiJ,GAC7BhtB,GAAGniO,OAAO8uP,IAAItiJ,iBAAmB4iJ,GACjCjtB,GAAGniO,OAAO8uP,IAAIpmJ,cAAgB2mJ,GAC9BltB,GAAGmtB,OAAS,CAAA,EACZntB,GAAGmtB,OAAO1xO,eAAiB2xO,GAC3BptB,GAAGmtB,OAAOt9O,Q9T/+CH,SAASA,EAAQtH,EAAUjK,GAEhC,MAAMqd,GADNrd,EAAUA,GAAW,IACEqd,QAAUF,GAC3B3I,EAAaxU,EAAQwU,YAAc,YACnCpf,EAAO6U,EAAS8Z,UACT,uBAAT3uB,IACF6U,EAAWA,EAASG,QAAQiB,UAAUmJ,EAAY,cAEpD,IACI5F,EAAa4f,EAAQv3B,EAAGuE,EAAIme,EAAG2G,EAD/B9O,EAAO,EAEX,OAAQpc,GACN,IAAK,QACL,IAAK,aACL,IAAK,aACL,IAAK,kBACL,IAAK,aACH,MAEF,IAAK,UAKH,IAJAwZ,EAAiE,EAE/DoW,iBACFxT,EAAOlQ,KAAKmP,IAAImN,GAAgBhP,EAAY,GAAIyO,IAC3CpmB,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAQS,EAAIuE,IAAMvE,EAC7Cua,GAAQlQ,KAAKmP,IAAImN,GAAgBhP,EAAY3X,GAAIomB,IAEnD,MAEF,IAAK,eAIH,IAHAzO,EAAwE,EAEtEoW,iBACG/tB,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAQS,EAAIuE,IAAMvE,EAG7C,IAFAu3B,EAAS5f,EAAY3X,GACrBua,GAAQlQ,KAAKmP,IAAImN,GAAgB4Q,EAAO,GAAInR,IACvC1D,EAAI,EAAG2G,EAAKkO,EAAOh4B,OAAQmjB,EAAI2G,IAAM3G,EACxCnI,GAAQlQ,KAAKmP,IAAImN,GAAgB4Q,EAAO7U,GAAI0D,IAGhD,MAEF,IAAK,qBAAsB,CACzB,MAAMwtD,EAC0D,EAE5D2G,gBACJ,IAAKv6E,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAC5Cua,GAAQD,EAAQs5D,EAAW5zE,GAAI+I,GAEjC,KACD,CACD,QACE,MAAM,IAAInC,MAAM,8BAAgCzI,GAGpD,OAAOoc,CACT,E8Tw7CAkwN,GAAGmtB,OAAOzxO,YAAc2xO,GACxBrtB,GAAGmtB,OAAOvuP,U9TxlDH,SAASA,EAAU2J,EAAUjK,GAElC,MAAMqd,GADNrd,EAAUA,GAAW,IACEqd,QAAUF,GAC3B3I,EAAaxU,EAAQwU,YAAc,YACnCpf,EAAO6U,EAAS8Z,UACT,uBAAT3uB,IACF6U,EAAWA,EAASG,QAAQiB,UAAUmJ,EAAY,cAEpD,IACI5F,EAAa4f,EAAQv3B,EAAGuE,EAAIme,EAAG2G,EAD/B9pB,EAAS,EAEb,OAAQpB,GACN,IAAK,QACL,IAAK,aACH,MAEF,IAAK,aACL,IAAK,aACHwZ,EAAwE,EAEtEoW,iBACFxuB,EAASmnB,GAAkB/O,EAAayO,GACxC,MAEF,IAAK,kBACL,IAAK,UAIH,IAHAzO,EAAwE,EAEtEoW,iBACG/tB,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAQS,EAAIuE,IAAMvE,EAC7CT,GAAUmnB,GAAkB/O,EAAY3X,GAAIomB,GAE9C,MAEF,IAAK,eAIH,IAHAzO,EAAwE,EAEtEoW,iBACG/tB,EAAI,EAAGuE,EAAKoT,EAAYpY,OAAQS,EAAIuE,IAAMvE,EAE7C,IADAu3B,EAAS5f,EAAY3X,GAChB0iB,EAAI,EAAG2G,EAAKkO,EAAOh4B,OAAQmjB,EAAI2G,IAAM3G,EACxCnjB,GAAUmnB,GAAkB6Q,EAAO7U,GAAI0D,GAG3C,MAEF,IAAK,qBAAsB,CACzB,MAAMwtD,EAC0D,EAE5D2G,gBACJ,IAAKv6E,EAAI,EAAGuE,EAAKqvE,EAAWr0E,OAAQS,EAAIuE,IAAMvE,EAC5CT,GAAU8J,EAAUuqE,EAAW5zE,GAAI+I,GAErC,KACD,CACD,QACE,MAAM,IAAInC,MAAM,8BAAgCzI,GAGpD,OAAOoB,CACT,E8T6hDAkrO,GAAGmtB,OAAOz+O,OAAS4+O,GACnBttB,GAAGn2F,OAAS,CAAA,EACZm2F,GAAGn2F,OAAOzwH,gBAAkBm0O,GAC5BvtB,GAAGn2F,OAAO9wH,UAAYy0O,GACtBxtB,GAAGytB,QAAU,CAAA,EACbztB,GAAGytB,QAAQ3uL,SAAW7B,GACtB+iK,GAAGytB,QAAQC,WAAa5tG,GACxBkgF,GAAGytB,QAAQxrM,cAAgB/B,GAC3B8/K,GAAGytB,QAAQxrM,cAAchC,KAAO0tM,GAChC3tB,GAAGytB,QAAQt9J,MAAQlG,GACnB+1I,GAAG97N,MAAQ,CAAA,EACX87N,GAAG97N,MAAM+qE,OAASuqE,GAClBwmF,GAAG97N,MAAMu1I,KAAOG,GAChBomF,GAAG97N,MAAMy2I,KAAOgB,GAChBqkF,GAAG97N,MAAM41I,UAAYS,GACrBylF,GAAG97N,MAAM41I,UAAU/8I,IAAM6wP,GACzB5tB,GAAG97N,MAAMw7B,eAAiBS,GAC1B6/L,GAAG97N,MAAMw7B,eAAeU,OAASytN,GACjC7tB,GAAG97N,MAAMxB,MAAQ40I,GACjB0oF,GAAG97N,MAAMqzI,aAAe+B,GACxB0mF,GAAG97N,MAAM03I,OAASY,GAClBwjF,GAAG97N,MAAMu4I,MAAQW,GACjB4iF,GAAG97N,MAAMu4I,MAAMpQ,mBAAqByhH,GACpC9tB,GAAG97N,MAAMu4I,MAAMU,mBAAqB4wG,GACpC/tB,GAAG97N,MAAMu4I,MAAMQ,WAAa+wG,GAC5BhuB,GAAG97N,MAAMm5I,KAAOwC,GAChBmgF,GAAG97N,MAAM81J,KAAO,GAChBgmE,GAAG97N,MAAM81J,KAAK3tB,mBAAqB4hH,GACnCjuB,GAAGkuB,UAAY,CAAA,EACfluB,GAAGkuB,UAAU7/O,eAAiB8/O,GAC9BnuB,GAAGkuB,UAAU1vL,QAAU4vL,GACvBpuB,GAAGkuB,UAAU7vL,sBAAwBgwL,GACrCruB,GAAGkuB,UAAUvtP,OAAS2tP,GACtBtuB,GAAGkuB,UAAU9vL,UAAYmwL,GACzBvuB,GAAGkuB,UAAUzvL,KAAO+vL,GACpBxuB,GAAGkuB,UAAUxvL,iBAAmB+vL,GAChCzuB,GAAGx+I,SAAW,CAAA,EACdw+I,GAAGx+I,SAAS3F,SAAW5C,GACvB+mJ,GAAGx+I,SAAS4oK,KAAO9qI,GACnB0gH,GAAGx+I,SAAS4oK,KAAK7qI,gCAAkCmvI,GACnD1uB,GAAGx+I,SAAS8lK,OAAS,GACrBtnB,GAAGx+I,SAAS8lK,OAAOrkN,iBAAmB0rN,GACtC3uB,GAAGx+I,SAAS8lK,OAAOpkN,kBAAoB0rN,GACvC5uB,GAAGx+I,SAAS7F,gBAAkBkzK,GAC9B7uB,GAAGx+I,SAAS/F,oBAAsBqzK,GAClC9uB,GAAGx+I,SAAS1F,UAAYizK,GACxB/uB,GAAGx+I,SAAS9F,qBAAuBszK,GACnChvB,GAAGx+I,SAAShG,iBAAmByzK,GAC/BjvB,GAAGx+I,SAAS3uE,MAAQq8O,GACpBlvB,GAAGmvB,gBAAkB,CAAA,EACrBnvB,GAAGmvB,gBAAgBpxK,mBAAqBqxK,GACxCpvB,GAAGmvB,gBAAgB9wK,oBAAsBgxK,GACzCrvB,GAAGmvB,gBAAgB3wK,2BAA6B8wK,GAChDtvB,GAAGmvB,gBAAgBxwK,UAAY4wK,GAC/BvvB,GAAGmvB,gBAAgBzwK,oBAAsB8wK,GACzCxvB,GAAGr2N,UAAY,CAAA,EACfq2N,GAAGr2N,UAAU9R,MAAQ43P,GACrBzvB,GAAGr2N,UAAUgC,QAAU+jP,GACvB1vB,GAAGr2N,UAAUgmP,oB1UpgDN,SAA6B/jP,EAAKC,EAAKC,EAAIC,EAAIZ,EAAOa,EAAKC,GAChE,OAAOM,GAASZ,GAtLT,CAAC,EAAG,EAAG,EAAG,EAAG,EAAG,GAsLWC,EAAKC,EAAKC,EAAIC,EAAIZ,EAAOa,EAAKC,GAClE,E0UmgDA+zN,GAAGr2N,UAAUF,OAASmmP,GACtB5vB,GAAGr2N,UAAUyC,YAAcyjP,GAC3B7vB,GAAGr2N,UAAUmmP,O1U9/CN,SAAgBjyP,GACrB,OAAOqO,GAAYrO,EAAQA,EAC7B,E0U6/CAmiO,GAAGr2N,UAAUuC,YAAc6jP,GAC3B/vB,GAAGr2N,UAAU4B,UAAYykP,GACzBhwB,GAAGr2N,UAAUC,SAAWqmP,GACxBjwB,GAAGr2N,UAAUD,MAAQwmP,GACrBlwB,GAAGr2N,UAAUuB,OAASilP,GACtBnwB,GAAGr2N,UAAU2B,MAAQ8kP,GACrBpwB,GAAGr2N,UAAUjM,IAAM2yP,GACnBrwB,GAAGr2N,UAAUmB,aAAewlP,GAC5BtwB,GAAGr2N,UAAU4C,SAAWgkP,GACxBvwB,GAAGr2N,UAAU6B,UAAYglP,GACzBxwB,GAAG75H,IAAM,CAAA,EACT65H,GAAG75H,IAAID,aAAeuqJ,GACtBzwB,GAAG0wB,KAAO,CAAA,EACV1wB,GAAG0wB,KAAK/nJ,QtV3sDe,0BsV4sDvBq3H,GAAG0wB,KAAKx0P,SAAWy0P,EACnB3wB,GAAG0wB,KAAKr0P,OAASu0P,EACjB5wB,GAAG6wB,IAAM,CAAA,EACT7wB,GAAG6wB,IAAI/jI,KAAO,GACdkzG,GAAG6wB,IAAI/jI,KAAKrjH,OAASqnP,GACrB9wB,GAAG6wB,IAAI/jI,KAAKD,cAAgBkkI,GAC5B/wB,GAAGijB,MAAQ,CAAA,EACXjjB,GAAGijB,MAAMzhI,aAAewvI,GACxBhxB,GAAGijB,MAAMvhH,uBAAyB7b,GAClCm6G,GAAGijB,MAAMhrI,OAASoO,GAClB25G,GAAGijB,MAAMhrI,OAAOmO,qBAAuB6qI,GACvCjxB,GAAGijB,MAAMthI,aAAeuvI,GACxBlxB,GAAGijB,MAAMxhI,qBAAuB0vI,GAChCnxB,GAAGijB,MAAMrhI,MAAQwvI,GACjBpxB,GAAGijB,MAAMoO,OAASrjI,GAClBgyG,GAAGijB,MAAMoO,OAAOxjI,wBAA0ByjI,GAC1CtxB,GAAGijB,MAAM92G,eAAiB5Y,GAC1BysG,GAAGijB,MAAMsO,mBAAqB1qI,GAC9Bm5G,GAAGijB,MAAMuO,aAAe59H,GACxBosG,GAAGijB,MAAMvhI,YAAc+vI,GACvBzxB,GAAGijB,MAAMyO,Y/I/tDkB,M+IguD3B1xB,GAAGijB,MAAMz2G,cAAgB,GACzBwzF,GAAGijB,MAAMz2G,cAAcF,cAAgBqlH,GACvC3xB,GAAGijB,MAAMz2G,cAAcA,cAAgBolH,GACvC5xB,GAAGijB,MAAMxyF,aAAe3d,GACxBktF,GAAGijB,MAAMn6G,YAAcrH,GACvBu+F,GAAGijB,MAAMn5H,c/I/sDoB,K+IgtD7Bk2G,GAAGijB,MAAMx1H,a/IpsDmB,K+IqsD5BuyG,GAAGijB,MAAMz1H,e/I3sDqB,K+I4sD9BwyG,GAAGijB,MAAMr/O,WAAaiuP,GACtB7xB,GAAGijB,MAAM6O,uB/InpDF,WACL,IAAK7vI,GAAqB,CACxB,MACM+E,EAAKpjH,GADIF,SAASC,cAAc,WAElCqjH,IACF/E,GAAsB+E,EAAG8qI,yBAE5B,CACD,OAAO7vI,EACT,E+I2oDA+9G,GAAGijB,MAAM8O,YAAc,GACvB/xB,GAAGijB,MAAM8O,YAAYp+G,YAAcq+G,GACnChyB,GAAGijB,MAAM8O,YAAYx+G,iBAAmB0+G,GACxCjyB,GAAGijB,MAAM8O,YAAYv+G,UAAY0+G,GACjClyB,GAAGijB,MAAM8O,YAAYr9G,kBAAoBy9G,GACzCnyB,GAAG78G,IAAM,CAAA,EACT68G,GAAG78G,IAAIqB,6BAA+B4tI,GACtCpyB,GAAG78G,IAAIjB,wBAA0BmwI,GACjCryB,GAAG78G,IAAIhB,gBAAkBmwI,GACzBtyB,GAAG78G,IAAIZ,kBAAoBgwI,GAC3BvyB,GAAG78G,IAAIV,mBAAqB+vI,GAC5BxyB,GAAG78G,IAAID,eAAiBuvI,GACxBzyB,GAAG78G,IAAIb,YAAcowI,GACrB1yB,GAAG78G,IAAIsC,iBAAmBktI,GAC1B3yB,GAAG78G,IAAIF,WAAa2vI,GACpB5yB,GAAG78G,IAAIC,kBAAoByvI,GAC3B7yB,GAAG78G,IAAII,gBAAkBuvI,GACzB9yB,GAAG78G,IAAIW,oBAAsBivI,GAC7B/yB,GAAG78G,IAAIS,kBAAoBovI,GAC3BhzB,GAAG78G,IAAIM,yBAA2BwvI,GAClCjzB,GAAG78G,IAAIQ,yBAA2BuvI,GAClClzB,GAAG78G,IAAIK,aAAe2vI,GACtBnzB,GAAG78G,IAAIsB,aAAe2uI,GACtBpzB,GAAG78G,IAAIe,sBAAwBmvI,GAC/BrzB,GAAG78G,IAAIyB,gBAAkB0uI,GACzBtzB,GAAG78G,IAAItkF,MAAQ00N,GACfvzB,GAAG78G,IAAI6B,UAAYwuI,GACnBxzB,GAAG78G,IAAIkC,gBAAkBouI,GACzBzzB,GAAG78G,IAAImC,oBAAsBouI,GAC7B1zB,GAAG78G,IAAIwwI,iB9I7vCA,SAA0BjwP,GAC/B8hH,GAAY9hH,CACd,E8I4vCAs8N,GAAG78G,IAAIywI,sB9IrxCA,SAA+BC,GACpCtuI,GAAiBsuI,CACnB,E8IoxCA7zB,GAAG78G,IAAIgB,UAAY2vI","x_google_ignoreList":[60,61,62,63,64,65,66,67,151,152,219,305,306]}