geoproject-app/public/site/plugins/map-editor/index.js
isUnknown 5531aebc04
All checks were successful
Deploy / Build and Deploy to Production (push) Successful in 17s
feat: add map framing save button and prevent initial load save
- Add "Définir le cadrage" button in multi mode to save current map
  center and zoom as default framing
- Add getCurrentZoom() method in MapPreview to retrieve current zoom level
- Fix: prevent automatic save on initial load with isInitialLoad flag
  to avoid marking page as modified when loading existing data
- Style: dark button theme for save framing button

Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
2026-02-06 09:20:12 +01:00

20235 lines
1.2 MiB
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

(function() {
"use strict";
function getDefaultExportFromCjs(x) {
return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, "default") ? x["default"] : x;
}
var maplibreGl$1 = { exports: {} };
var maplibreGl = maplibreGl$1.exports;
var hasRequiredMaplibreGl;
function requireMaplibreGl() {
if (hasRequiredMaplibreGl) return maplibreGl$1.exports;
hasRequiredMaplibreGl = 1;
(function(module, exports$1) {
(function(global, factory) {
module.exports = factory();
})(maplibreGl, (function() {
var shared, worker, maplibregl2;
function define(_, chunk) {
if (!shared) {
shared = chunk;
} else if (!worker) {
worker = chunk;
} else {
var workerBundleString = "var sharedChunk = {}; (" + shared + ")(sharedChunk); (" + worker + ")(sharedChunk);";
var sharedChunk = {};
shared(sharedChunk);
maplibregl2 = chunk(sharedChunk);
if (typeof window !== "undefined") {
maplibregl2.workerUrl = window.URL.createObjectURL(new Blob([workerBundleString], { type: "text/javascript" }));
}
}
}
define(["exports"], (function(t) {
function e(t2, e2, r2, n2) {
return new (r2 || (r2 = Promise))((function(i3, a2) {
function s2(t3) {
try {
l2(n2.next(t3));
} catch (t4) {
a2(t4);
}
}
function o2(t3) {
try {
l2(n2.throw(t3));
} catch (t4) {
a2(t4);
}
}
function l2(t3) {
var e3;
t3.done ? i3(t3.value) : (e3 = t3.value, e3 instanceof r2 ? e3 : new r2((function(t4) {
t4(e3);
}))).then(s2, o2);
}
l2((n2 = n2.apply(t2, e2 || [])).next());
}));
}
function r(t2) {
return t2 && t2.__esModule && Object.prototype.hasOwnProperty.call(t2, "default") ? t2.default : t2;
}
"function" == typeof SuppressedError && SuppressedError;
var n = i2;
function i2(t2, e2) {
this.x = t2, this.y = e2;
}
i2.prototype = { clone: function() {
return new i2(this.x, this.y);
}, add: function(t2) {
return this.clone()._add(t2);
}, sub: function(t2) {
return this.clone()._sub(t2);
}, multByPoint: function(t2) {
return this.clone()._multByPoint(t2);
}, divByPoint: function(t2) {
return this.clone()._divByPoint(t2);
}, mult: function(t2) {
return this.clone()._mult(t2);
}, div: function(t2) {
return this.clone()._div(t2);
}, rotate: function(t2) {
return this.clone()._rotate(t2);
}, rotateAround: function(t2, e2) {
return this.clone()._rotateAround(t2, e2);
}, matMult: function(t2) {
return this.clone()._matMult(t2);
}, unit: function() {
return this.clone()._unit();
}, perp: function() {
return this.clone()._perp();
}, round: function() {
return this.clone()._round();
}, mag: function() {
return Math.sqrt(this.x * this.x + this.y * this.y);
}, equals: function(t2) {
return this.x === t2.x && this.y === t2.y;
}, dist: function(t2) {
return Math.sqrt(this.distSqr(t2));
}, distSqr: function(t2) {
var e2 = t2.x - this.x, r2 = t2.y - this.y;
return e2 * e2 + r2 * r2;
}, angle: function() {
return Math.atan2(this.y, this.x);
}, angleTo: function(t2) {
return Math.atan2(this.y - t2.y, this.x - t2.x);
}, angleWith: function(t2) {
return this.angleWithSep(t2.x, t2.y);
}, angleWithSep: function(t2, e2) {
return Math.atan2(this.x * e2 - this.y * t2, this.x * t2 + this.y * e2);
}, _matMult: function(t2) {
var e2 = t2[2] * this.x + t2[3] * this.y;
return this.x = t2[0] * this.x + t2[1] * this.y, this.y = e2, this;
}, _add: function(t2) {
return this.x += t2.x, this.y += t2.y, this;
}, _sub: function(t2) {
return this.x -= t2.x, this.y -= t2.y, this;
}, _mult: function(t2) {
return this.x *= t2, this.y *= t2, this;
}, _div: function(t2) {
return this.x /= t2, this.y /= t2, this;
}, _multByPoint: function(t2) {
return this.x *= t2.x, this.y *= t2.y, this;
}, _divByPoint: function(t2) {
return this.x /= t2.x, this.y /= t2.y, this;
}, _unit: function() {
return this._div(this.mag()), this;
}, _perp: function() {
var t2 = this.y;
return this.y = this.x, this.x = -t2, this;
}, _rotate: function(t2) {
var e2 = Math.cos(t2), r2 = Math.sin(t2), n2 = r2 * this.x + e2 * this.y;
return this.x = e2 * this.x - r2 * this.y, this.y = n2, this;
}, _rotateAround: function(t2, e2) {
var r2 = Math.cos(t2), n2 = Math.sin(t2), i3 = e2.y + n2 * (this.x - e2.x) + r2 * (this.y - e2.y);
return this.x = e2.x + r2 * (this.x - e2.x) - n2 * (this.y - e2.y), this.y = i3, this;
}, _round: function() {
return this.x = Math.round(this.x), this.y = Math.round(this.y), this;
} }, i2.convert = function(t2) {
return t2 instanceof i2 ? t2 : Array.isArray(t2) ? new i2(t2[0], t2[1]) : t2;
};
var a = r(n), s = o;
function o(t2, e2, r2, n2) {
this.cx = 3 * t2, this.bx = 3 * (r2 - t2) - this.cx, this.ax = 1 - this.cx - this.bx, this.cy = 3 * e2, this.by = 3 * (n2 - e2) - this.cy, this.ay = 1 - this.cy - this.by, this.p1x = t2, this.p1y = e2, this.p2x = r2, this.p2y = n2;
}
o.prototype = { sampleCurveX: function(t2) {
return ((this.ax * t2 + this.bx) * t2 + this.cx) * t2;
}, sampleCurveY: function(t2) {
return ((this.ay * t2 + this.by) * t2 + this.cy) * t2;
}, sampleCurveDerivativeX: function(t2) {
return (3 * this.ax * t2 + 2 * this.bx) * t2 + this.cx;
}, solveCurveX: function(t2, e2) {
if (void 0 === e2 && (e2 = 1e-6), t2 < 0) return 0;
if (t2 > 1) return 1;
for (var r2 = t2, n2 = 0; n2 < 8; n2++) {
var i3 = this.sampleCurveX(r2) - t2;
if (Math.abs(i3) < e2) return r2;
var a2 = this.sampleCurveDerivativeX(r2);
if (Math.abs(a2) < 1e-6) break;
r2 -= i3 / a2;
}
var s2 = 0, o2 = 1;
for (r2 = t2, n2 = 0; n2 < 20 && (i3 = this.sampleCurveX(r2), !(Math.abs(i3 - t2) < e2)); n2++) t2 > i3 ? s2 = r2 : o2 = r2, r2 = 0.5 * (o2 - s2) + s2;
return r2;
}, solve: function(t2, e2) {
return this.sampleCurveY(this.solveCurveX(t2, e2));
} };
var l = r(s);
let u, c;
function h() {
return null == u && (u = "undefined" != typeof OffscreenCanvas && new OffscreenCanvas(1, 1).getContext("2d") && "function" == typeof createImageBitmap), u;
}
function p() {
if (null == c && (c = false, h())) {
const t2 = 5, e2 = new OffscreenCanvas(t2, t2).getContext("2d", { willReadFrequently: true });
if (e2) {
for (let r3 = 0; r3 < t2 * t2; r3++) {
const n2 = 4 * r3;
e2.fillStyle = `rgb(${n2},${n2 + 1},${n2 + 2})`, e2.fillRect(r3 % t2, Math.floor(r3 / t2), 1, 1);
}
const r2 = e2.getImageData(0, 0, t2, t2).data;
for (let e3 = 0; e3 < t2 * t2 * 4; e3++) if (e3 % 4 != 3 && r2[e3] !== e3) {
c = true;
break;
}
}
}
return c || false;
}
function f(t2, e2, r2, n2) {
const i3 = new l(t2, e2, r2, n2);
return function(t3) {
return i3.solve(t3);
};
}
const d = f(0.25, 0.1, 0.25, 1);
function y(t2, e2, r2) {
return Math.min(r2, Math.max(e2, t2));
}
function m(t2, e2, r2) {
const n2 = r2 - e2, i3 = ((t2 - e2) % n2 + n2) % n2 + e2;
return i3 === e2 ? r2 : i3;
}
function g(t2, ...e2) {
for (const r2 of e2) for (const e3 in r2) t2[e3] = r2[e3];
return t2;
}
let x = 1;
function v(t2, e2, r2) {
const n2 = {};
for (const i3 in t2) n2[i3] = e2.call(r2 || this, t2[i3], i3, t2);
return n2;
}
function b(t2, e2, r2) {
const n2 = {};
for (const i3 in t2) e2.call(r2 || this, t2[i3], i3, t2) && (n2[i3] = t2[i3]);
return n2;
}
function w(t2) {
return Array.isArray(t2) ? t2.map(w) : "object" == typeof t2 && t2 ? v(t2, w) : t2;
}
const _ = {};
function A(t2) {
_[t2] || ("undefined" != typeof console && console.warn(t2), _[t2] = true);
}
function S(t2, e2, r2) {
return (r2.y - t2.y) * (e2.x - t2.x) > (e2.y - t2.y) * (r2.x - t2.x);
}
function k(t2) {
let e2 = 0;
for (let r2, n2, i3 = 0, a2 = t2.length, s2 = a2 - 1; i3 < a2; s2 = i3++) r2 = t2[i3], n2 = t2[s2], e2 += (n2.x - r2.x) * (r2.y + n2.y);
return e2;
}
function I() {
return "undefined" != typeof WorkerGlobalScope && "undefined" != typeof self && self instanceof WorkerGlobalScope;
}
let z = null;
function M(t2) {
return "undefined" != typeof ImageBitmap && t2 instanceof ImageBitmap;
}
const C = "";
function B(t2, r2, n2, i3, a2) {
return e(this, void 0, void 0, (function* () {
if ("undefined" == typeof VideoFrame) throw new Error("VideoFrame not supported");
const e2 = new VideoFrame(t2, { timestamp: 0 });
try {
const s2 = null == e2 ? void 0 : e2.format;
if (!s2 || !s2.startsWith("BGR") && !s2.startsWith("RGB")) throw new Error(`Unrecognized format ${s2}`);
const o2 = s2.startsWith("BGR"), l2 = new Uint8ClampedArray(i3 * a2 * 4);
if (yield e2.copyTo(l2, (function(t3, e3, r3, n3, i4) {
const a3 = 4 * Math.max(-e3, 0), s3 = (Math.max(0, r3) - r3) * n3 * 4 + a3, o3 = 4 * n3, l3 = Math.max(0, e3), u2 = Math.max(0, r3);
return { rect: { x: l3, y: u2, width: Math.min(t3.width, e3 + n3) - l3, height: Math.min(t3.height, r3 + i4) - u2 }, layout: [{ offset: s3, stride: o3 }] };
})(t2, r2, n2, i3, a2)), o2) for (let t3 = 0; t3 < l2.length; t3 += 4) {
const e3 = l2[t3];
l2[t3] = l2[t3 + 2], l2[t3 + 2] = e3;
}
return l2;
} finally {
e2.close();
}
}));
}
let P, V, E, F;
const T = { now: "undefined" != typeof performance && performance && performance.now ? performance.now.bind(performance) : Date.now.bind(Date), frame(t2) {
const e2 = requestAnimationFrame(t2);
return { cancel: () => cancelAnimationFrame(e2) };
}, getImageData(t2, e2 = 0) {
return this.getImageCanvasContext(t2).getImageData(-e2, -e2, t2.width + 2 * e2, t2.height + 2 * e2);
}, getImageCanvasContext(t2) {
const e2 = window.document.createElement("canvas"), r2 = e2.getContext("2d", { willReadFrequently: true });
if (!r2) throw new Error("failed to create canvas 2d context");
return e2.width = t2.width, e2.height = t2.height, r2.drawImage(t2, 0, 0, t2.width, t2.height), r2;
}, resolveURL: (t2) => (E || (E = document.createElement("a")), E.href = t2, E.href), hardwareConcurrency: "undefined" != typeof navigator && navigator.hardwareConcurrency || 4, get prefersReducedMotion() {
return !!matchMedia && (null == F && (F = matchMedia("(prefers-reduced-motion: reduce)")), F.matches);
} }, $ = { MAX_PARALLEL_IMAGE_REQUESTS: 16, MAX_PARALLEL_IMAGE_REQUESTS_PER_FRAME: 8, MAX_TILE_CACHE_ZOOM_LEVELS: 5, REGISTERED_PROTOCOLS: {}, WORKER_URL: "" };
class L extends Error {
constructor(t2, e2, r2, n2) {
super(`AJAXError: ${e2} (${t2}): ${r2}`), this.status = t2, this.statusText = e2, this.url = r2, this.body = n2;
}
}
const D = I() ? () => self.worker && self.worker.referrer : () => ("blob:" === window.location.protocol ? window.parent : window).location.href, O = (t2) => $.REGISTERED_PROTOCOLS[t2.substring(0, t2.indexOf("://"))];
function U(t2, e2) {
const r2 = new AbortController(), n2 = new Request(t2.url, { method: t2.method || "GET", body: t2.body, credentials: t2.credentials, headers: t2.headers, cache: t2.cache, referrer: D(), signal: r2.signal });
let i3 = false, a2 = false;
"json" === t2.type && n2.headers.set("Accept", "application/json");
return a2 || fetch(n2).then(((r3) => r3.ok ? ((r4) => {
("arrayBuffer" === t2.type || "image" === t2.type ? r4.arrayBuffer() : "json" === t2.type ? r4.json() : r4.text()).then(((t3) => {
a2 || (i3 = true, e2(null, t3, r4.headers.get("Cache-Control"), r4.headers.get("Expires")));
})).catch(((t3) => {
a2 || e2(new Error(t3.message));
}));
})(r3) : r3.blob().then(((n3) => e2(new L(r3.status, r3.statusText, t2.url, n3)))))).catch(((t3) => {
20 !== t3.code && e2(new Error(t3.message));
})), { cancel: () => {
a2 = true, i3 || r2.abort();
} };
}
const R = function(t2, e2) {
if (/:\/\//.test(t2.url) && !/^https?:|^file:/.test(t2.url)) {
if (I() && self.worker && self.worker.actor) return self.worker.actor.send("getResource", t2, e2);
if (!I()) return (O(t2.url) || U)(t2, e2);
}
if (!(/^file:/.test(r2 = t2.url) || /^file:/.test(D()) && !/^\w+:/.test(r2))) {
if (fetch && Request && AbortController && Object.prototype.hasOwnProperty.call(Request.prototype, "signal")) return U(t2, e2);
if (I() && self.worker && self.worker.actor) return self.worker.actor.send("getResource", t2, e2, void 0, true);
}
var r2;
return (function(t3, e3) {
const r3 = new XMLHttpRequest();
r3.open(t3.method || "GET", t3.url, true), "arrayBuffer" !== t3.type && "image" !== t3.type || (r3.responseType = "arraybuffer");
for (const e4 in t3.headers) r3.setRequestHeader(e4, t3.headers[e4]);
return "json" === t3.type && (r3.responseType = "text", r3.setRequestHeader("Accept", "application/json")), r3.withCredentials = "include" === t3.credentials, r3.onerror = () => {
e3(new Error(r3.statusText));
}, r3.onload = () => {
if ((r3.status >= 200 && r3.status < 300 || 0 === r3.status) && null !== r3.response) {
let n2 = r3.response;
if ("json" === t3.type) try {
n2 = JSON.parse(r3.response);
} catch (t4) {
return e3(t4);
}
e3(null, n2, r3.getResponseHeader("Cache-Control"), r3.getResponseHeader("Expires"));
} else {
const n2 = new Blob([r3.response], { type: r3.getResponseHeader("Content-Type") });
e3(new L(r3.status, r3.statusText, t3.url, n2));
}
}, r3.send(t3.body), { cancel: () => r3.abort() };
})(t2, e2);
}, q = function(t2, e2) {
return R(g(t2, { type: "arrayBuffer" }), e2);
};
function j(t2) {
if (!t2 || t2.indexOf("://") <= 0 || 0 === t2.indexOf("data:image/") || 0 === t2.indexOf("blob:")) return true;
const e2 = new URL(t2), r2 = window.location;
return e2.protocol === r2.protocol && e2.host === r2.host;
}
function N(t2, e2, r2) {
r2[t2] && -1 !== r2[t2].indexOf(e2) || (r2[t2] = r2[t2] || [], r2[t2].push(e2));
}
function Z(t2, e2, r2) {
if (r2 && r2[t2]) {
const n2 = r2[t2].indexOf(e2);
-1 !== n2 && r2[t2].splice(n2, 1);
}
}
class K {
constructor(t2, e2 = {}) {
g(this, e2), this.type = t2;
}
}
class G extends K {
constructor(t2, e2 = {}) {
super("error", g({ error: t2 }, e2));
}
}
class J {
on(t2, e2) {
return this._listeners = this._listeners || {}, N(t2, e2, this._listeners), this;
}
off(t2, e2) {
return Z(t2, e2, this._listeners), Z(t2, e2, this._oneTimeListeners), this;
}
once(t2, e2) {
return e2 ? (this._oneTimeListeners = this._oneTimeListeners || {}, N(t2, e2, this._oneTimeListeners), this) : new Promise(((e3) => this.once(t2, e3)));
}
fire(t2, e2) {
"string" == typeof t2 && (t2 = new K(t2, e2 || {}));
const r2 = t2.type;
if (this.listens(r2)) {
t2.target = this;
const e3 = this._listeners && this._listeners[r2] ? this._listeners[r2].slice() : [];
for (const r3 of e3) r3.call(this, t2);
const n2 = this._oneTimeListeners && this._oneTimeListeners[r2] ? this._oneTimeListeners[r2].slice() : [];
for (const e4 of n2) Z(r2, e4, this._oneTimeListeners), e4.call(this, t2);
const i3 = this._eventedParent;
i3 && (g(t2, "function" == typeof this._eventedParentData ? this._eventedParentData() : this._eventedParentData), i3.fire(t2));
} else t2 instanceof G && console.error(t2.error);
return this;
}
listens(t2) {
return this._listeners && this._listeners[t2] && this._listeners[t2].length > 0 || this._oneTimeListeners && this._oneTimeListeners[t2] && this._oneTimeListeners[t2].length > 0 || this._eventedParent && this._eventedParent.listens(t2);
}
setEventedParent(t2, e2) {
return this._eventedParent = t2, this._eventedParentData = e2, this;
}
}
var X = { $version: 8, $root: { version: { required: true, type: "enum", values: [8] }, name: { type: "string" }, metadata: { type: "*" }, center: { type: "array", value: "number" }, zoom: { type: "number" }, bearing: { type: "number", default: 0, period: 360, units: "degrees" }, pitch: { type: "number", default: 0, units: "degrees" }, light: { type: "light" }, terrain: { type: "terrain" }, sources: { required: true, type: "sources" }, sprite: { type: "sprite" }, glyphs: { type: "string" }, transition: { type: "transition" }, layers: { required: true, type: "array", value: "layer" } }, sources: { "*": { type: "source" } }, source: ["source_vector", "source_raster", "source_raster_dem", "source_geojson", "source_video", "source_image"], source_vector: { type: { required: true, type: "enum", values: { vector: {} } }, url: { type: "string" }, tiles: { type: "array", value: "string" }, bounds: { type: "array", value: "number", length: 4, default: [-180, -85.051129, 180, 85.051129] }, scheme: { type: "enum", values: { xyz: {}, tms: {} }, default: "xyz" }, minzoom: { type: "number", default: 0 }, maxzoom: { type: "number", default: 22 }, attribution: { type: "string" }, promoteId: { type: "promoteId" }, volatile: { type: "boolean", default: false }, "*": { type: "*" } }, source_raster: { type: { required: true, type: "enum", values: { raster: {} } }, url: { type: "string" }, tiles: { type: "array", value: "string" }, bounds: { type: "array", value: "number", length: 4, default: [-180, -85.051129, 180, 85.051129] }, minzoom: { type: "number", default: 0 }, maxzoom: { type: "number", default: 22 }, tileSize: { type: "number", default: 512, units: "pixels" }, scheme: { type: "enum", values: { xyz: {}, tms: {} }, default: "xyz" }, attribution: { type: "string" }, volatile: { type: "boolean", default: false }, "*": { type: "*" } }, source_raster_dem: { type: { required: true, type: "enum", values: { "raster-dem": {} } }, url: { type: "string" }, tiles: { type: "array", value: "string" }, bounds: { type: "array", value: "number", length: 4, default: [-180, -85.051129, 180, 85.051129] }, minzoom: { type: "number", default: 0 }, maxzoom: { type: "number", default: 22 }, tileSize: { type: "number", default: 512, units: "pixels" }, attribution: { type: "string" }, encoding: { type: "enum", values: { terrarium: {}, mapbox: {}, custom: {} }, default: "mapbox" }, redFactor: { type: "number", default: 1 }, blueFactor: { type: "number", default: 1 }, greenFactor: { type: "number", default: 1 }, baseShift: { type: "number", default: 0 }, volatile: { type: "boolean", default: false }, "*": { type: "*" } }, source_geojson: { type: { required: true, type: "enum", values: { geojson: {} } }, data: { required: true, type: "*" }, maxzoom: { type: "number", default: 18 }, attribution: { type: "string" }, buffer: { type: "number", default: 128, maximum: 512, minimum: 0 }, filter: { type: "*" }, tolerance: { type: "number", default: 0.375 }, cluster: { type: "boolean", default: false }, clusterRadius: { type: "number", default: 50, minimum: 0 }, clusterMaxZoom: { type: "number" }, clusterMinPoints: { type: "number" }, clusterProperties: { type: "*" }, lineMetrics: { type: "boolean", default: false }, generateId: { type: "boolean", default: false }, promoteId: { type: "promoteId" } }, source_video: { type: { required: true, type: "enum", values: { video: {} } }, urls: { required: true, type: "array", value: "string" }, coordinates: { required: true, type: "array", length: 4, value: { type: "array", length: 2, value: "number" } } }, source_image: { type: { required: true, type: "enum", values: { image: {} } }, url: { required: true, type: "string" }, coordinates: { required: true, type: "array", length: 4, value: { type: "array", length: 2, value: "number" } } }, layer: { id: { type: "string", required: true }, type: { type: "enum", values: { fill: {}, line: {}, symbol: {}, circle: {}, heatmap: {}, "fill-extrusion": {}, raster: {}, hillshade: {}, background: {} }, required: true }, metadata: { type: "*" }, source: { type: "string" }, "source-layer": { type: "string" }, minzoom: { type: "number", minimum: 0, maximum: 24 }, maxzoom: { type: "number", minimum: 0, maximum: 24 }, filter: { type: "filter" }, layout: { type: "layout" }, paint: { type: "paint" } }, layout: ["layout_fill", "layout_line", "layout_circle", "layout_heatmap", "layout_fill-extrusion", "layout_symbol", "layout_raster", "layout_hillshade", "layout_background"], layout_background: { visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, layout_fill: { "fill-sort-key": { type: "number", expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, layout_circle: { "circle-sort-key": { type: "number", expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, layout_heatmap: { visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, "layout_fill-extrusion": { visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, layout_line: { "line-cap": { type: "enum", values: { butt: {}, round: {}, square: {} }, default: "butt", expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "line-join": { type: "enum", values: { bevel: {}, round: {}, miter: {} }, default: "miter", expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "line-miter-limit": { type: "number", default: 2, requires: [{ "line-join": "miter" }], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "line-round-limit": { type: "number", default: 1.05, requires: [{ "line-join": "round" }], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "line-sort-key": { type: "number", expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, layout_symbol: { "symbol-placement": { type: "enum", values: { point: {}, line: {}, "line-center": {} }, default: "point", expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "symbol-spacing": { type: "number", default: 250, minimum: 1, units: "pixels", requires: [{ "symbol-placement": "line" }], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "symbol-avoid-edges": { type: "boolean", default: false, expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "symbol-sort-key": { type: "number", expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "symbol-z-order": { type: "enum", values: { auto: {}, "viewport-y": {}, source: {} }, default: "auto", expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-allow-overlap": { type: "boolean", default: false, requires: ["icon-image", { "!": "icon-overlap" }], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-overlap": { type: "enum", values: { never: {}, always: {}, cooperative: {} }, requires: ["icon-image"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-ignore-placement": { type: "boolean", default: false, requires: ["icon-image"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-optional": { type: "boolean", default: false, requires: ["icon-image", "text-field"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-rotation-alignment": { type: "enum", values: { map: {}, viewport: {}, auto: {} }, default: "auto", requires: ["icon-image"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-size": { type: "number", default: 1, minimum: 0, units: "factor of the original icon size", requires: ["icon-image"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "icon-text-fit": { type: "enum", values: { none: {}, width: {}, height: {}, both: {} }, default: "none", requires: ["icon-image", "text-field"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-text-fit-padding": { type: "array", value: "number", length: 4, default: [0, 0, 0, 0], units: "pixels", requires: ["icon-image", "text-field", { "icon-text-fit": ["both", "width", "height"] }], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-image": { type: "resolvedImage", tokens: true, expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "icon-rotate": { type: "number", default: 0, period: 360, units: "degrees", requires: ["icon-image"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "icon-padding": { type: "padding", default: [2], units: "pixels", requires: ["icon-image"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "icon-keep-upright": { type: "boolean", default: false, requires: ["icon-image", { "icon-rotation-alignment": "map" }, { "symbol-placement": ["line", "line-center"] }], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-offset": { type: "array", value: "number", length: 2, default: [0, 0], requires: ["icon-image"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "icon-anchor": { type: "enum", values: { center: {}, left: {}, right: {}, top: {}, bottom: {}, "top-left": {}, "top-right": {}, "bottom-left": {}, "bottom-right": {} }, default: "center", requires: ["icon-image"], expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "icon-pitch-alignment": { type: "enum", values: { map: {}, viewport: {}, auto: {} }, default: "auto", requires: ["icon-image"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-pitch-alignment": { type: "enum", values: { map: {}, viewport: {}, auto: {} }, default: "auto", requires: ["text-field"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-rotation-alignment": { type: "enum", values: { map: {}, viewport: {}, "viewport-glyph": {}, auto: {} }, default: "auto", requires: ["text-field"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-field": { type: "formatted", default: "", tokens: true, expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-font": { type: "array", value: "string", default: ["Open Sans Regular", "Arial Unicode MS Regular"], requires: ["text-field"], expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-size": { type: "number", default: 16, minimum: 0, units: "pixels", requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-max-width": { type: "number", default: 10, minimum: 0, units: "ems", requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-line-height": { type: "number", default: 1.2, units: "ems", requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-letter-spacing": { type: "number", default: 0, units: "ems", requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-justify": { type: "enum", values: { auto: {}, left: {}, center: {}, right: {} }, default: "center", requires: ["text-field"], expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-radial-offset": { type: "number", units: "ems", default: 0, requires: ["text-field"], "property-type": "data-driven", expression: { interpolated: true, parameters: ["zoom", "feature"] } }, "text-variable-anchor": { type: "array", value: "enum", values: { center: {}, left: {}, right: {}, top: {}, bottom: {}, "top-left": {}, "top-right": {}, "bottom-left": {}, "bottom-right": {} }, requires: ["text-field", { "symbol-placement": ["point"] }], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-variable-anchor-offset": { type: "variableAnchorOffsetCollection", requires: ["text-field", { "symbol-placement": ["point"] }], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-anchor": { type: "enum", values: { center: {}, left: {}, right: {}, top: {}, bottom: {}, "top-left": {}, "top-right": {}, "bottom-left": {}, "bottom-right": {} }, default: "center", requires: ["text-field", { "!": "text-variable-anchor" }], expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-max-angle": { type: "number", default: 45, units: "degrees", requires: ["text-field", { "symbol-placement": ["line", "line-center"] }], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-writing-mode": { type: "array", value: "enum", values: { horizontal: {}, vertical: {} }, requires: ["text-field", { "symbol-placement": ["point"] }], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-rotate": { type: "number", default: 0, period: 360, units: "degrees", requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-padding": { type: "number", default: 2, minimum: 0, units: "pixels", requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-keep-upright": { type: "boolean", default: true, requires: ["text-field", { "text-rotation-alignment": "map" }, { "symbol-placement": ["line", "line-center"] }], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-transform": { type: "enum", values: { none: {}, uppercase: {}, lowercase: {} }, default: "none", requires: ["text-field"], expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-offset": { type: "array", value: "number", units: "ems", length: 2, default: [0, 0], requires: ["text-field", { "!": "text-radial-offset" }], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-allow-overlap": { type: "boolean", default: false, requires: ["text-field", { "!": "text-overlap" }], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-overlap": { type: "enum", values: { never: {}, always: {}, cooperative: {} }, requires: ["text-field"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-ignore-placement": { type: "boolean", default: false, requires: ["text-field"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-optional": { type: "boolean", default: false, requires: ["text-field", "icon-image"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, layout_raster: { visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, layout_hillshade: { visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, filter: { type: "array", value: "*" }, filter_operator: { type: "enum", values: { "==": {}, "!=": {}, ">": {}, ">=": {}, "<": {}, "<=": {}, in: {}, "!in": {}, all: {}, any: {}, none: {}, has: {}, "!has": {}, within: {} } }, geometry_type: { type: "enum", values: { Point: {}, LineString: {}, Polygon: {} } }, function: { expression: { type: "expression" }, stops: { type: "array", value: "function_stop" }, base: { type: "number", default: 1, minimum: 0 }, property: { type: "string", default: "$zoom" }, type: { type: "enum", values: { identity: {}, exponential: {}, interval: {}, categorical: {} }, default: "exponential" }, colorSpace: { type: "enum", values: { rgb: {}, lab: {}, hcl: {} }, default: "rgb" }, default: { type: "*", required: false } }, function_stop: { type: "array", minimum: 0, maximum: 24, value: ["number", "color"], length: 2 }, expression: { type: "array", value: "*", minimum: 1 }, light: { anchor: { type: "enum", default: "viewport", values: { map: {}, viewport: {} }, "property-type": "data-constant", transition: false, expression: { interpolated: false, parameters: ["zoom"] } }, position: { type: "array", default: [1.15, 210, 30], length: 3, value: "number", "property-type": "data-constant", transition: true, expression: { interpolated: true, parameters: ["zoom"] } }, color: { type: "color", "property-type": "data-constant", default: "#ffffff", expression: { interpolated: true, parameters: ["zoom"] }, transition: true }, intensity: { type: "number", "property-type": "data-constant", default: 0.5, minimum: 0, maximum: 1, expression: { interpolated: true, parameters: ["zoom"] }, transition: true } }, terrain: { source: { type: "string", required: true }, exaggeration: { type: "number", minimum: 0, default: 1 } }, paint: ["paint_fill", "paint_line", "paint_circle", "paint_heatmap", "paint_fill-extrusion", "paint_symbol", "paint_raster", "paint_hillshade", "paint_background"], paint_fill: { "fill-antialias": { type: "boolean", default: true, expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "fill-opacity": { type: "number", default: 1, minimum: 0, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "fill-color": { type: "color", default: "#000000", transition: true, requires: [{ "!": "fill-pattern" }], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "fill-outline-color": { type: "color", transition: true, requires: [{ "!": "fill-pattern" }, { "fill-antialias": true }], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "fill-translate": { type: "array", value: "number", length: 2, default: [0, 0], transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "fill-translate-anchor": { type: "enum", values: { map: {}, viewport: {} }, default: "map", requires: ["fill-translate"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "fill-pattern": { type: "resolvedImage", transition: true, expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "cross-faded-data-driven" } }, "paint_fill-extrusion": { "fill-extrusion-opacity": { type: "number", default: 1, minimum: 0, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "fill-extrusion-color": { type: "color", default: "#000000", transition: true, requires: [{ "!": "fill-extrusion-pattern" }], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "fill-extrusion-translate": { type: "array", value: "number", length: 2, default: [0, 0], transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "fill-extrusion-translate-anchor": { type: "enum", values: { map: {}, viewport: {} }, default: "map", requires: ["fill-extrusion-translate"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "fill-extrusion-pattern": { type: "resolvedImage", transition: true, expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "cross-faded-data-driven" }, "fill-extrusion-height": { type: "number", default: 0, minimum: 0, units: "meters", transition: true, expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "fill-extrusion-base": { type: "number", default: 0, minimum: 0, units: "meters", transition: true, requires: ["fill-extrusion-height"], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "fill-extrusion-vertical-gradient": { type: "boolean", default: true, transition: false, expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" } }, paint_line: { "line-opacity": { type: "number", default: 1, minimum: 0, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "line-color": { type: "color", default: "#000000", transition: true, requires: [{ "!": "line-pattern" }], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "line-translate": { type: "array", value: "number", length: 2, default: [0, 0], transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "line-translate-anchor": { type: "enum", values: { map: {}, viewport: {} }, default: "map", requires: ["line-translate"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "line-width": { type: "number", default: 1, minimum: 0, transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "line-gap-width": { type: "number", default: 0, minimum: 0, transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "line-offset": { type: "number", default: 0, transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "line-blur": { type: "number", default: 0, minimum: 0, transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "line-dasharray": { type: "array", value: "number", minimum: 0, transition: true, units: "line widths", requires: [{ "!": "line-pattern" }], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "cross-faded" }, "line-pattern": { type: "resolvedImage", transition: true, expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "cross-faded-data-driven" }, "line-gradient": { type: "color", transition: false, requires: [{ "!": "line-dasharray" }, { "!": "line-pattern" }, { source: "geojson", has: { lineMetrics: true } }], expression: { interpolated: true, parameters: ["line-progress"] }, "property-type": "color-ramp" } }, paint_circle: { "circle-radius": { type: "number", default: 5, minimum: 0, transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "circle-color": { type: "color", default: "#000000", transition: true, expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "circle-blur": { type: "number", default: 0, transition: true, expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "circle-opacity": { type: "number", default: 1, minimum: 0, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "circle-translate": { type: "array", value: "number", length: 2, default: [0, 0], transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "circle-translate-anchor": { type: "enum", values: { map: {}, viewport: {} }, default: "map", requires: ["circle-translate"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "circle-pitch-scale": { type: "enum", values: { map: {}, viewport: {} }, default: "map", expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "circle-pitch-alignment": { type: "enum", values: { map: {}, viewport: {} }, default: "viewport", expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "circle-stroke-width": { type: "number", default: 0, minimum: 0, transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "circle-stroke-color": { type: "color", default: "#000000", transition: true, expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "circle-stroke-opacity": { type: "number", default: 1, minimum: 0, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" } }, paint_heatmap: { "heatmap-radius": { type: "number", default: 30, minimum: 1, transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "heatmap-weight": { type: "number", default: 1, minimum: 0, transition: false, expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "heatmap-intensity": { type: "number", default: 1, minimum: 0, transition: true, expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "heatmap-color": { type: "color", default: ["interpolate", ["linear"], ["heatmap-density"], 0, "rgba(0, 0, 255, 0)", 0.1, "royalblue", 0.3, "cyan", 0.5, "lime", 0.7, "yellow", 1, "red"], transition: false, expression: { interpolated: true, parameters: ["heatmap-density"] }, "property-type": "color-ramp" }, "heatmap-opacity": { type: "number", default: 1, minimum: 0, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" } }, paint_symbol: { "icon-opacity": { type: "number", default: 1, minimum: 0, maximum: 1, transition: true, requires: ["icon-image"], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "icon-color": { type: "color", default: "#000000", transition: true, requires: ["icon-image"], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "icon-halo-color": { type: "color", default: "rgba(0, 0, 0, 0)", transition: true, requires: ["icon-image"], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "icon-halo-width": { type: "number", default: 0, minimum: 0, transition: true, units: "pixels", requires: ["icon-image"], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "icon-halo-blur": { type: "number", default: 0, minimum: 0, transition: true, units: "pixels", requires: ["icon-image"], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "icon-translate": { type: "array", value: "number", length: 2, default: [0, 0], transition: true, units: "pixels", requires: ["icon-image"], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-translate-anchor": { type: "enum", values: { map: {}, viewport: {} }, default: "map", requires: ["icon-image", "icon-translate"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-opacity": { type: "number", default: 1, minimum: 0, maximum: 1, transition: true, requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "text-color": { type: "color", default: "#000000", transition: true, overridable: true, requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "text-halo-color": { type: "color", default: "rgba(0, 0, 0, 0)", transition: true, requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "text-halo-width": { type: "number", default: 0, minimum: 0, transition: true, units: "pixels", requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "text-halo-blur": { type: "number", default: 0, minimum: 0, transition: true, units: "pixels", requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "text-translate": { type: "array", value: "number", length: 2, default: [0, 0], transition: true, units: "pixels", requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-translate-anchor": { type: "enum", values: { map: {}, viewport: {} }, default: "map", requires: ["text-field", "text-translate"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" } }, paint_raster: { "raster-opacity": { type: "number", default: 1, minimum: 0, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "raster-hue-rotate": { type: "number", default: 0, period: 360, transition: true, units: "degrees", expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "raster-brightness-min": { type: "number", default: 0, minimum: 0, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "raster-brightness-max": { type: "number", default: 1, minimum: 0, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "raster-saturation": { type: "number", default: 0, minimum: -1, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "raster-contrast": { type: "number", default: 0, minimum: -1, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "raster-resampling": { type: "enum", values: { linear: {}, nearest: {} }, default: "linear", expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "raster-fade-duration": { type: "number", default: 300, minimum: 0, transition: false, units: "milliseconds", expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" } }, paint_hillshade: { "hillshade-illumination-direction": { type: "number", default: 335, minimum: 0, maximum: 359, transition: false, expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "hillshade-illumination-anchor": { type: "enum", values: { map: {}, viewport: {} }, default: "viewport", expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "hillshade-exaggeration": { type: "number", default: 0.5, minimum: 0, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "hillshade-shadow-color": { type: "color", default: "#000000", transition: true, expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "hillshade-highlight-color": { type: "color", default: "#FFFFFF", transition: true, expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "hillshade-accent-color": { type: "color", default: "#000000", transition: true, expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" } }, paint_background: { "background-color": { type: "color", default: "#000000", transition: true, requires: [{ "!": "background-pattern" }], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "background-pattern": { type: "resolvedImage", transition: true, expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "cross-faded" }, "background-opacity": { type: "number", default: 1, minimum: 0, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" } }, transition: { duration: { type: "number", default: 300, minimum: 0, units: "milliseconds" }, delay: { type: "number", default: 0, minimum: 0, units: "milliseconds" } }, "property-type": { "data-driven": { type: "property-type" }, "cross-faded": { type: "property-type" }, "cross-faded-data-driven": { type: "property-type" }, "color-ramp": { type: "property-type" }, "data-constant": { type: "property-type" }, constant: { type: "property-type" } }, promoteId: { "*": { type: "string" } } };
const Y = ["type", "source", "source-layer", "minzoom", "maxzoom", "filter", "layout"];
function H(t2, e2) {
const r2 = {};
for (const e3 in t2) "ref" !== e3 && (r2[e3] = t2[e3]);
return Y.forEach(((t3) => {
t3 in e2 && (r2[t3] = e2[t3]);
})), r2;
}
function W(t2, e2) {
if (Array.isArray(t2)) {
if (!Array.isArray(e2) || t2.length !== e2.length) return false;
for (let r2 = 0; r2 < t2.length; r2++) if (!W(t2[r2], e2[r2])) return false;
return true;
}
if ("object" == typeof t2 && null !== t2 && null !== e2) {
if ("object" != typeof e2) return false;
if (Object.keys(t2).length !== Object.keys(e2).length) return false;
for (const r2 in t2) if (!W(t2[r2], e2[r2])) return false;
return true;
}
return t2 === e2;
}
const Q = { setStyle: "setStyle", addLayer: "addLayer", removeLayer: "removeLayer", setPaintProperty: "setPaintProperty", setLayoutProperty: "setLayoutProperty", setFilter: "setFilter", addSource: "addSource", removeSource: "removeSource", setGeoJSONSourceData: "setGeoJSONSourceData", setLayerZoomRange: "setLayerZoomRange", setLayerProperty: "setLayerProperty", setCenter: "setCenter", setZoom: "setZoom", setBearing: "setBearing", setPitch: "setPitch", setSprite: "setSprite", setGlyphs: "setGlyphs", setTransition: "setTransition", setLight: "setLight" };
function tt(t2, e2, r2) {
r2.push({ command: Q.addSource, args: [t2, e2[t2]] });
}
function et(t2, e2, r2) {
e2.push({ command: Q.removeSource, args: [t2] }), r2[t2] = true;
}
function rt(t2, e2, r2, n2) {
et(t2, r2, n2), tt(t2, e2, r2);
}
function nt(t2, e2, r2) {
let n2;
for (n2 in t2[r2]) if (Object.prototype.hasOwnProperty.call(t2[r2], n2) && "data" !== n2 && !W(t2[r2][n2], e2[r2][n2])) return false;
for (n2 in e2[r2]) if (Object.prototype.hasOwnProperty.call(e2[r2], n2) && "data" !== n2 && !W(t2[r2][n2], e2[r2][n2])) return false;
return true;
}
function it(t2, e2, r2, n2, i3, a2) {
let s2;
for (s2 in e2 = e2 || {}, t2 = t2 || {}) Object.prototype.hasOwnProperty.call(t2, s2) && (W(t2[s2], e2[s2]) || r2.push({ command: a2, args: [n2, s2, e2[s2], i3] }));
for (s2 in e2) Object.prototype.hasOwnProperty.call(e2, s2) && !Object.prototype.hasOwnProperty.call(t2, s2) && (W(t2[s2], e2[s2]) || r2.push({ command: a2, args: [n2, s2, e2[s2], i3] }));
}
function at(t2) {
return t2.id;
}
function st(t2, e2) {
return t2[e2.id] = e2, t2;
}
class ot {
constructor(t2, e2, r2, n2) {
this.message = (t2 ? `${t2}: ` : "") + r2, n2 && (this.identifier = n2), null != e2 && e2.__line__ && (this.line = e2.__line__);
}
}
function lt(t2, ...e2) {
for (const r2 of e2) for (const e3 in r2) t2[e3] = r2[e3];
return t2;
}
class ut extends Error {
constructor(t2, e2) {
super(e2), this.message = e2, this.key = t2;
}
}
class ct {
constructor(t2, e2 = []) {
this.parent = t2, this.bindings = {};
for (const [t3, r2] of e2) this.bindings[t3] = r2;
}
concat(t2) {
return new ct(this, t2);
}
get(t2) {
if (this.bindings[t2]) return this.bindings[t2];
if (this.parent) return this.parent.get(t2);
throw new Error(`${t2} not found in scope.`);
}
has(t2) {
return !!this.bindings[t2] || !!this.parent && this.parent.has(t2);
}
}
const ht = { kind: "null" }, pt = { kind: "number" }, ft = { kind: "string" }, dt = { kind: "boolean" }, yt = { kind: "color" }, mt = { kind: "object" }, gt = { kind: "value" }, xt = { kind: "collator" }, vt = { kind: "formatted" }, bt = { kind: "padding" }, wt = { kind: "resolvedImage" }, _t = { kind: "variableAnchorOffsetCollection" };
function At(t2, e2) {
return { kind: "array", itemType: t2, N: e2 };
}
function St(t2) {
if ("array" === t2.kind) {
const e2 = St(t2.itemType);
return "number" == typeof t2.N ? `array<${e2}, ${t2.N}>` : "value" === t2.itemType.kind ? "array" : `array<${e2}>`;
}
return t2.kind;
}
const kt = [ht, pt, ft, dt, yt, vt, mt, At(gt), bt, wt, _t];
function It(t2, e2) {
if ("error" === e2.kind) return null;
if ("array" === t2.kind) {
if ("array" === e2.kind && (0 === e2.N && "value" === e2.itemType.kind || !It(t2.itemType, e2.itemType)) && ("number" != typeof t2.N || t2.N === e2.N)) return null;
} else {
if (t2.kind === e2.kind) return null;
if ("value" === t2.kind) {
for (const t3 of kt) if (!It(t3, e2)) return null;
}
}
return `Expected ${St(t2)} but found ${St(e2)} instead.`;
}
function zt(t2, e2) {
return e2.some(((e3) => e3.kind === t2.kind));
}
function Mt(t2, e2) {
return e2.some(((e3) => "null" === e3 ? null === t2 : "array" === e3 ? Array.isArray(t2) : "object" === e3 ? t2 && !Array.isArray(t2) && "object" == typeof t2 : e3 === typeof t2));
}
function Ct(t2, e2) {
return "array" === t2.kind && "array" === e2.kind ? t2.itemType.kind === e2.itemType.kind && "number" == typeof t2.N : t2.kind === e2.kind;
}
const Bt = 0.96422, Pt = 0.82521, Vt = 4 / 29, Et = 6 / 29, Ft = 3 * Et * Et, Tt = Et * Et * Et, $t = Math.PI / 180, Lt = 180 / Math.PI;
function Dt(t2) {
return (t2 %= 360) < 0 && (t2 += 360), t2;
}
function Ot([t2, e2, r2, n2]) {
let i3, a2;
const s2 = Rt((0.2225045 * (t2 = Ut(t2)) + 0.7168786 * (e2 = Ut(e2)) + 0.0606169 * (r2 = Ut(r2))) / 1);
t2 === e2 && e2 === r2 ? i3 = a2 = s2 : (i3 = Rt((0.4360747 * t2 + 0.3850649 * e2 + 0.1430804 * r2) / Bt), a2 = Rt((0.0139322 * t2 + 0.0971045 * e2 + 0.7141733 * r2) / Pt));
const o2 = 116 * s2 - 16;
return [o2 < 0 ? 0 : o2, 500 * (i3 - s2), 200 * (s2 - a2), n2];
}
function Ut(t2) {
return t2 <= 0.04045 ? t2 / 12.92 : Math.pow((t2 + 0.055) / 1.055, 2.4);
}
function Rt(t2) {
return t2 > Tt ? Math.pow(t2, 1 / 3) : t2 / Ft + Vt;
}
function qt([t2, e2, r2, n2]) {
let i3 = (t2 + 16) / 116, a2 = isNaN(e2) ? i3 : i3 + e2 / 500, s2 = isNaN(r2) ? i3 : i3 - r2 / 200;
return i3 = 1 * Nt(i3), a2 = Bt * Nt(a2), s2 = Pt * Nt(s2), [jt(3.1338561 * a2 - 1.6168667 * i3 - 0.4906146 * s2), jt(-0.9787684 * a2 + 1.9161415 * i3 + 0.033454 * s2), jt(0.0719453 * a2 - 0.2289914 * i3 + 1.4052427 * s2), n2];
}
function jt(t2) {
return (t2 = t2 <= 304e-5 ? 12.92 * t2 : 1.055 * Math.pow(t2, 1 / 2.4) - 0.055) < 0 ? 0 : t2 > 1 ? 1 : t2;
}
function Nt(t2) {
return t2 > Et ? t2 * t2 * t2 : Ft * (t2 - Vt);
}
function Zt(t2) {
return parseInt(t2.padEnd(2, t2), 16) / 255;
}
function Kt(t2, e2) {
return Gt(e2 ? t2 / 100 : t2, 0, 1);
}
function Gt(t2, e2, r2) {
return Math.min(Math.max(e2, t2), r2);
}
function Jt(t2) {
return !t2.some(Number.isNaN);
}
const Xt = { aliceblue: [240, 248, 255], antiquewhite: [250, 235, 215], aqua: [0, 255, 255], aquamarine: [127, 255, 212], azure: [240, 255, 255], beige: [245, 245, 220], bisque: [255, 228, 196], black: [0, 0, 0], blanchedalmond: [255, 235, 205], blue: [0, 0, 255], blueviolet: [138, 43, 226], brown: [165, 42, 42], burlywood: [222, 184, 135], cadetblue: [95, 158, 160], chartreuse: [127, 255, 0], chocolate: [210, 105, 30], coral: [255, 127, 80], cornflowerblue: [100, 149, 237], cornsilk: [255, 248, 220], crimson: [220, 20, 60], cyan: [0, 255, 255], darkblue: [0, 0, 139], darkcyan: [0, 139, 139], darkgoldenrod: [184, 134, 11], darkgray: [169, 169, 169], darkgreen: [0, 100, 0], darkgrey: [169, 169, 169], darkkhaki: [189, 183, 107], darkmagenta: [139, 0, 139], darkolivegreen: [85, 107, 47], darkorange: [255, 140, 0], darkorchid: [153, 50, 204], darkred: [139, 0, 0], darksalmon: [233, 150, 122], darkseagreen: [143, 188, 143], darkslateblue: [72, 61, 139], darkslategray: [47, 79, 79], darkslategrey: [47, 79, 79], darkturquoise: [0, 206, 209], darkviolet: [148, 0, 211], deeppink: [255, 20, 147], deepskyblue: [0, 191, 255], dimgray: [105, 105, 105], dimgrey: [105, 105, 105], dodgerblue: [30, 144, 255], firebrick: [178, 34, 34], floralwhite: [255, 250, 240], forestgreen: [34, 139, 34], fuchsia: [255, 0, 255], gainsboro: [220, 220, 220], ghostwhite: [248, 248, 255], gold: [255, 215, 0], goldenrod: [218, 165, 32], gray: [128, 128, 128], green: [0, 128, 0], greenyellow: [173, 255, 47], grey: [128, 128, 128], honeydew: [240, 255, 240], hotpink: [255, 105, 180], indianred: [205, 92, 92], indigo: [75, 0, 130], ivory: [255, 255, 240], khaki: [240, 230, 140], lavender: [230, 230, 250], lavenderblush: [255, 240, 245], lawngreen: [124, 252, 0], lemonchiffon: [255, 250, 205], lightblue: [173, 216, 230], lightcoral: [240, 128, 128], lightcyan: [224, 255, 255], lightgoldenrodyellow: [250, 250, 210], lightgray: [211, 211, 211], lightgreen: [144, 238, 144], lightgrey: [211, 211, 211], lightpink: [255, 182, 193], lightsalmon: [255, 160, 122], lightseagreen: [32, 178, 170], lightskyblue: [135, 206, 250], lightslategray: [119, 136, 153], lightslategrey: [119, 136, 153], lightsteelblue: [176, 196, 222], lightyellow: [255, 255, 224], lime: [0, 255, 0], limegreen: [50, 205, 50], linen: [250, 240, 230], magenta: [255, 0, 255], maroon: [128, 0, 0], mediumaquamarine: [102, 205, 170], mediumblue: [0, 0, 205], mediumorchid: [186, 85, 211], mediumpurple: [147, 112, 219], mediumseagreen: [60, 179, 113], mediumslateblue: [123, 104, 238], mediumspringgreen: [0, 250, 154], mediumturquoise: [72, 209, 204], mediumvioletred: [199, 21, 133], midnightblue: [25, 25, 112], mintcream: [245, 255, 250], mistyrose: [255, 228, 225], moccasin: [255, 228, 181], navajowhite: [255, 222, 173], navy: [0, 0, 128], oldlace: [253, 245, 230], olive: [128, 128, 0], olivedrab: [107, 142, 35], orange: [255, 165, 0], orangered: [255, 69, 0], orchid: [218, 112, 214], palegoldenrod: [238, 232, 170], palegreen: [152, 251, 152], paleturquoise: [175, 238, 238], palevioletred: [219, 112, 147], papayawhip: [255, 239, 213], peachpuff: [255, 218, 185], peru: [205, 133, 63], pink: [255, 192, 203], plum: [221, 160, 221], powderblue: [176, 224, 230], purple: [128, 0, 128], rebeccapurple: [102, 51, 153], red: [255, 0, 0], rosybrown: [188, 143, 143], royalblue: [65, 105, 225], saddlebrown: [139, 69, 19], salmon: [250, 128, 114], sandybrown: [244, 164, 96], seagreen: [46, 139, 87], seashell: [255, 245, 238], sienna: [160, 82, 45], silver: [192, 192, 192], skyblue: [135, 206, 235], slateblue: [106, 90, 205], slategray: [112, 128, 144], slategrey: [112, 128, 144], snow: [255, 250, 250], springgreen: [0, 255, 127], steelblue: [70, 130, 180], tan: [210, 180, 140], teal: [0, 128, 128], thistle: [216, 191, 216], tomato: [255, 99, 71], turquoise: [64, 224, 208], violet: [238, 130, 238], wheat: [245, 222, 179], white: [255, 255, 255], whitesmoke: [245, 245, 245], yellow: [255, 255, 0], yellowgreen: [154, 205, 50] };
class Yt {
constructor(t2, e2, r2, n2 = 1, i3 = true) {
this.r = t2, this.g = e2, this.b = r2, this.a = n2, i3 || (this.r *= n2, this.g *= n2, this.b *= n2, n2 || this.overwriteGetter("rgb", [t2, e2, r2, n2]));
}
static parse(t2) {
if (t2 instanceof Yt) return t2;
if ("string" != typeof t2) return;
const e2 = (function(t3) {
if ("transparent" === (t3 = t3.toLowerCase().trim())) return [0, 0, 0, 0];
const e3 = Xt[t3];
if (e3) {
const [t4, r3, n2] = e3;
return [t4 / 255, r3 / 255, n2 / 255, 1];
}
if (t3.startsWith("#") && /^#(?:[0-9a-f]{3,4}|[0-9a-f]{6}|[0-9a-f]{8})$/.test(t3)) {
const e4 = t3.length < 6 ? 1 : 2;
let r3 = 1;
return [Zt(t3.slice(r3, r3 += e4)), Zt(t3.slice(r3, r3 += e4)), Zt(t3.slice(r3, r3 += e4)), Zt(t3.slice(r3, r3 + e4) || "ff")];
}
if (t3.startsWith("rgb")) {
const e4 = t3.match(/^rgba?\(\s*([\de.+-]+)(%)?(?:\s+|\s*(,)\s*)([\de.+-]+)(%)?(?:\s+|\s*(,)\s*)([\de.+-]+)(%)?(?:\s*([,\/])\s*([\de.+-]+)(%)?)?\s*\)$/);
if (e4) {
const [t4, r3, n2, i3, a2, s2, o2, l2, u2, c2, h2, p2] = e4, f2 = [i3 || " ", o2 || " ", c2].join("");
if (" " === f2 || " /" === f2 || ",," === f2 || ",,," === f2) {
const t5 = [n2, s2, u2].join(""), e5 = "%%%" === t5 ? 100 : "" === t5 ? 255 : 0;
if (e5) {
const t6 = [Gt(+r3 / e5, 0, 1), Gt(+a2 / e5, 0, 1), Gt(+l2 / e5, 0, 1), h2 ? Kt(+h2, p2) : 1];
if (Jt(t6)) return t6;
}
}
return;
}
}
const r2 = t3.match(/^hsla?\(\s*([\de.+-]+)(?:deg)?(?:\s+|\s*(,)\s*)([\de.+-]+)%(?:\s+|\s*(,)\s*)([\de.+-]+)%(?:\s*([,\/])\s*([\de.+-]+)(%)?)?\s*\)$/);
if (r2) {
const [t4, e4, n2, i3, a2, s2, o2, l2, u2] = r2, c2 = [n2 || " ", a2 || " ", o2].join("");
if (" " === c2 || " /" === c2 || ",," === c2 || ",,," === c2) {
const t5 = [+e4, Gt(+i3, 0, 100), Gt(+s2, 0, 100), l2 ? Kt(+l2, u2) : 1];
if (Jt(t5)) return (function([t6, e5, r3, n3]) {
function i4(n4) {
const i5 = (n4 + t6 / 30) % 12, a3 = e5 * Math.min(r3, 1 - r3);
return r3 - a3 * Math.max(-1, Math.min(i5 - 3, 9 - i5, 1));
}
return t6 = Dt(t6), e5 /= 100, r3 /= 100, [i4(0), i4(8), i4(4), n3];
})(t5);
}
}
})(t2);
return e2 ? new Yt(...e2, false) : void 0;
}
get rgb() {
const { r: t2, g: e2, b: r2, a: n2 } = this, i3 = n2 || 1 / 0;
return this.overwriteGetter("rgb", [t2 / i3, e2 / i3, r2 / i3, n2]);
}
get hcl() {
return this.overwriteGetter("hcl", (function(t2) {
const [e2, r2, n2, i3] = Ot(t2), a2 = Math.sqrt(r2 * r2 + n2 * n2);
return [Math.round(1e4 * a2) ? Dt(Math.atan2(n2, r2) * Lt) : NaN, a2, e2, i3];
})(this.rgb));
}
get lab() {
return this.overwriteGetter("lab", Ot(this.rgb));
}
overwriteGetter(t2, e2) {
return Object.defineProperty(this, t2, { value: e2 }), e2;
}
toString() {
const [t2, e2, r2, n2] = this.rgb;
return `rgba(${[t2, e2, r2].map(((t3) => Math.round(255 * t3))).join(",")},${n2})`;
}
}
Yt.black = new Yt(0, 0, 0, 1), Yt.white = new Yt(1, 1, 1, 1), Yt.transparent = new Yt(0, 0, 0, 0), Yt.red = new Yt(1, 0, 0, 1);
class Ht {
constructor(t2, e2, r2) {
this.sensitivity = t2 ? e2 ? "variant" : "case" : e2 ? "accent" : "base", this.locale = r2, this.collator = new Intl.Collator(this.locale ? this.locale : [], { sensitivity: this.sensitivity, usage: "search" });
}
compare(t2, e2) {
return this.collator.compare(t2, e2);
}
resolvedLocale() {
return new Intl.Collator(this.locale ? this.locale : []).resolvedOptions().locale;
}
}
class Wt {
constructor(t2, e2, r2, n2, i3) {
this.text = t2, this.image = e2, this.scale = r2, this.fontStack = n2, this.textColor = i3;
}
}
class Qt {
constructor(t2) {
this.sections = t2;
}
static fromString(t2) {
return new Qt([new Wt(t2, null, null, null, null)]);
}
isEmpty() {
return 0 === this.sections.length || !this.sections.some(((t2) => 0 !== t2.text.length || t2.image && 0 !== t2.image.name.length));
}
static factory(t2) {
return t2 instanceof Qt ? t2 : Qt.fromString(t2);
}
toString() {
return 0 === this.sections.length ? "" : this.sections.map(((t2) => t2.text)).join("");
}
}
class te {
constructor(t2) {
this.values = t2.slice();
}
static parse(t2) {
if (t2 instanceof te) return t2;
if ("number" == typeof t2) return new te([t2, t2, t2, t2]);
if (Array.isArray(t2) && !(t2.length < 1 || t2.length > 4)) {
for (const e2 of t2) if ("number" != typeof e2) return;
switch (t2.length) {
case 1:
t2 = [t2[0], t2[0], t2[0], t2[0]];
break;
case 2:
t2 = [t2[0], t2[1], t2[0], t2[1]];
break;
case 3:
t2 = [t2[0], t2[1], t2[2], t2[1]];
}
return new te(t2);
}
}
toString() {
return JSON.stringify(this.values);
}
}
const ee = /* @__PURE__ */ new Set(["center", "left", "right", "top", "bottom", "top-left", "top-right", "bottom-left", "bottom-right"]);
class re {
constructor(t2) {
this.values = t2.slice();
}
static parse(t2) {
if (t2 instanceof re) return t2;
if (Array.isArray(t2) && !(t2.length < 1) && t2.length % 2 == 0) {
for (let e2 = 0; e2 < t2.length; e2 += 2) {
const r2 = t2[e2], n2 = t2[e2 + 1];
if ("string" != typeof r2 || !ee.has(r2)) return;
if (!Array.isArray(n2) || 2 !== n2.length || "number" != typeof n2[0] || "number" != typeof n2[1]) return;
}
return new re(t2);
}
}
toString() {
return JSON.stringify(this.values);
}
}
class ne {
constructor(t2) {
this.name = t2.name, this.available = t2.available;
}
toString() {
return this.name;
}
static fromString(t2) {
return t2 ? new ne({ name: t2, available: false }) : null;
}
}
function ie(t2, e2, r2, n2) {
return "number" == typeof t2 && t2 >= 0 && t2 <= 255 && "number" == typeof e2 && e2 >= 0 && e2 <= 255 && "number" == typeof r2 && r2 >= 0 && r2 <= 255 ? void 0 === n2 || "number" == typeof n2 && n2 >= 0 && n2 <= 1 ? null : `Invalid rgba value [${[t2, e2, r2, n2].join(", ")}]: 'a' must be between 0 and 1.` : `Invalid rgba value [${("number" == typeof n2 ? [t2, e2, r2, n2] : [t2, e2, r2]).join(", ")}]: 'r', 'g', and 'b' must be between 0 and 255.`;
}
function ae(t2) {
if (null === t2 || "string" == typeof t2 || "boolean" == typeof t2 || "number" == typeof t2 || t2 instanceof Yt || t2 instanceof Ht || t2 instanceof Qt || t2 instanceof te || t2 instanceof re || t2 instanceof ne) return true;
if (Array.isArray(t2)) {
for (const e2 of t2) if (!ae(e2)) return false;
return true;
}
if ("object" == typeof t2) {
for (const e2 in t2) if (!ae(t2[e2])) return false;
return true;
}
return false;
}
function se(t2) {
if (null === t2) return ht;
if ("string" == typeof t2) return ft;
if ("boolean" == typeof t2) return dt;
if ("number" == typeof t2) return pt;
if (t2 instanceof Yt) return yt;
if (t2 instanceof Ht) return xt;
if (t2 instanceof Qt) return vt;
if (t2 instanceof te) return bt;
if (t2 instanceof re) return _t;
if (t2 instanceof ne) return wt;
if (Array.isArray(t2)) {
const e2 = t2.length;
let r2;
for (const e3 of t2) {
const t3 = se(e3);
if (r2) {
if (r2 === t3) continue;
r2 = gt;
break;
}
r2 = t3;
}
return At(r2 || gt, e2);
}
return mt;
}
function oe(t2) {
const e2 = typeof t2;
return null === t2 ? "" : "string" === e2 || "number" === e2 || "boolean" === e2 ? String(t2) : t2 instanceof Yt || t2 instanceof Qt || t2 instanceof te || t2 instanceof re || t2 instanceof ne ? t2.toString() : JSON.stringify(t2);
}
class le {
constructor(t2, e2) {
this.type = t2, this.value = e2;
}
static parse(t2, e2) {
if (2 !== t2.length) return e2.error(`'literal' expression requires exactly one argument, but found ${t2.length - 1} instead.`);
if (!ae(t2[1])) return e2.error("invalid value");
const r2 = t2[1];
let n2 = se(r2);
const i3 = e2.expectedType;
return "array" !== n2.kind || 0 !== n2.N || !i3 || "array" !== i3.kind || "number" == typeof i3.N && 0 !== i3.N || (n2 = i3), new le(n2, r2);
}
evaluate() {
return this.value;
}
eachChild() {
}
outputDefined() {
return true;
}
}
class ue {
constructor(t2) {
this.name = "ExpressionEvaluationError", this.message = t2;
}
toJSON() {
return this.message;
}
}
const ce = { string: ft, number: pt, boolean: dt, object: mt };
class he {
constructor(t2, e2) {
this.type = t2, this.args = e2;
}
static parse(t2, e2) {
if (t2.length < 2) return e2.error("Expected at least one argument.");
let r2, n2 = 1;
const i3 = t2[0];
if ("array" === i3) {
let i4, a3;
if (t2.length > 2) {
const r3 = t2[1];
if ("string" != typeof r3 || !(r3 in ce) || "object" === r3) return e2.error('The item type argument of "array" must be one of string, number, boolean', 1);
i4 = ce[r3], n2++;
} else i4 = gt;
if (t2.length > 3) {
if (null !== t2[2] && ("number" != typeof t2[2] || t2[2] < 0 || t2[2] !== Math.floor(t2[2]))) return e2.error('The length argument to "array" must be a positive integer literal', 2);
a3 = t2[2], n2++;
}
r2 = At(i4, a3);
} else {
if (!ce[i3]) throw new Error(`Types doesn't contain name = ${i3}`);
r2 = ce[i3];
}
const a2 = [];
for (; n2 < t2.length; n2++) {
const r3 = e2.parse(t2[n2], n2, gt);
if (!r3) return null;
a2.push(r3);
}
return new he(r2, a2);
}
evaluate(t2) {
for (let e2 = 0; e2 < this.args.length; e2++) {
const r2 = this.args[e2].evaluate(t2);
if (!It(this.type, se(r2))) return r2;
if (e2 === this.args.length - 1) throw new ue(`Expected value to be of type ${St(this.type)}, but found ${St(se(r2))} instead.`);
}
throw new Error();
}
eachChild(t2) {
this.args.forEach(t2);
}
outputDefined() {
return this.args.every(((t2) => t2.outputDefined()));
}
}
const pe = { "to-boolean": dt, "to-color": yt, "to-number": pt, "to-string": ft };
class fe {
constructor(t2, e2) {
this.type = t2, this.args = e2;
}
static parse(t2, e2) {
if (t2.length < 2) return e2.error("Expected at least one argument.");
const r2 = t2[0];
if (!pe[r2]) throw new Error(`Can't parse ${r2} as it is not part of the known types`);
if (("to-boolean" === r2 || "to-string" === r2) && 2 !== t2.length) return e2.error("Expected one argument.");
const n2 = pe[r2], i3 = [];
for (let r3 = 1; r3 < t2.length; r3++) {
const n3 = e2.parse(t2[r3], r3, gt);
if (!n3) return null;
i3.push(n3);
}
return new fe(n2, i3);
}
evaluate(t2) {
switch (this.type.kind) {
case "boolean":
return Boolean(this.args[0].evaluate(t2));
case "color": {
let e2, r2;
for (const n2 of this.args) {
if (e2 = n2.evaluate(t2), r2 = null, e2 instanceof Yt) return e2;
if ("string" == typeof e2) {
const r3 = t2.parseColor(e2);
if (r3) return r3;
} else if (Array.isArray(e2) && (r2 = e2.length < 3 || e2.length > 4 ? `Invalid rbga value ${JSON.stringify(e2)}: expected an array containing either three or four numeric values.` : ie(e2[0], e2[1], e2[2], e2[3]), !r2)) return new Yt(e2[0] / 255, e2[1] / 255, e2[2] / 255, e2[3]);
}
throw new ue(r2 || `Could not parse color from value '${"string" == typeof e2 ? e2 : JSON.stringify(e2)}'`);
}
case "padding": {
let e2;
for (const r2 of this.args) {
e2 = r2.evaluate(t2);
const n2 = te.parse(e2);
if (n2) return n2;
}
throw new ue(`Could not parse padding from value '${"string" == typeof e2 ? e2 : JSON.stringify(e2)}'`);
}
case "variableAnchorOffsetCollection": {
let e2;
for (const r2 of this.args) {
e2 = r2.evaluate(t2);
const n2 = re.parse(e2);
if (n2) return n2;
}
throw new ue(`Could not parse variableAnchorOffsetCollection from value '${"string" == typeof e2 ? e2 : JSON.stringify(e2)}'`);
}
case "number": {
let e2 = null;
for (const r2 of this.args) {
if (e2 = r2.evaluate(t2), null === e2) return 0;
const n2 = Number(e2);
if (!isNaN(n2)) return n2;
}
throw new ue(`Could not convert ${JSON.stringify(e2)} to number.`);
}
case "formatted":
return Qt.fromString(oe(this.args[0].evaluate(t2)));
case "resolvedImage":
return ne.fromString(oe(this.args[0].evaluate(t2)));
default:
return oe(this.args[0].evaluate(t2));
}
}
eachChild(t2) {
this.args.forEach(t2);
}
outputDefined() {
return this.args.every(((t2) => t2.outputDefined()));
}
}
const de = ["Unknown", "Point", "LineString", "Polygon"];
class ye {
constructor() {
this.globals = null, this.feature = null, this.featureState = null, this.formattedSection = null, this._parseColorCache = {}, this.availableImages = null, this.canonical = null;
}
id() {
return this.feature && "id" in this.feature ? this.feature.id : null;
}
geometryType() {
return this.feature ? "number" == typeof this.feature.type ? de[this.feature.type] : this.feature.type : null;
}
geometry() {
return this.feature && "geometry" in this.feature ? this.feature.geometry : null;
}
canonicalID() {
return this.canonical;
}
properties() {
return this.feature && this.feature.properties || {};
}
parseColor(t2) {
let e2 = this._parseColorCache[t2];
return e2 || (e2 = this._parseColorCache[t2] = Yt.parse(t2)), e2;
}
}
class me {
constructor(t2, e2, r2 = [], n2, i3 = new ct(), a2 = []) {
this.registry = t2, this.path = r2, this.key = r2.map(((t3) => `[${t3}]`)).join(""), this.scope = i3, this.errors = a2, this.expectedType = n2, this._isConstant = e2;
}
parse(t2, e2, r2, n2, i3 = {}) {
return e2 ? this.concat(e2, r2, n2)._parse(t2, i3) : this._parse(t2, i3);
}
_parse(t2, e2) {
function r2(t3, e3, r3) {
return "assert" === r3 ? new he(e3, [t3]) : "coerce" === r3 ? new fe(e3, [t3]) : t3;
}
if (null !== t2 && "string" != typeof t2 && "boolean" != typeof t2 && "number" != typeof t2 || (t2 = ["literal", t2]), Array.isArray(t2)) {
if (0 === t2.length) return this.error('Expected an array with at least one element. If you wanted a literal array, use ["literal", []].');
const n2 = t2[0];
if ("string" != typeof n2) return this.error(`Expression name must be a string, but found ${typeof n2} instead. If you wanted a literal array, use ["literal", [...]].`, 0), null;
const i3 = this.registry[n2];
if (i3) {
let n3 = i3.parse(t2, this);
if (!n3) return null;
if (this.expectedType) {
const t3 = this.expectedType, i4 = n3.type;
if ("string" !== t3.kind && "number" !== t3.kind && "boolean" !== t3.kind && "object" !== t3.kind && "array" !== t3.kind || "value" !== i4.kind) if ("color" !== t3.kind && "formatted" !== t3.kind && "resolvedImage" !== t3.kind || "value" !== i4.kind && "string" !== i4.kind) if ("padding" !== t3.kind || "value" !== i4.kind && "number" !== i4.kind && "array" !== i4.kind) if ("variableAnchorOffsetCollection" !== t3.kind || "value" !== i4.kind && "array" !== i4.kind) {
if (this.checkSubtype(t3, i4)) return null;
} else n3 = r2(n3, t3, e2.typeAnnotation || "coerce");
else n3 = r2(n3, t3, e2.typeAnnotation || "coerce");
else n3 = r2(n3, t3, e2.typeAnnotation || "coerce");
else n3 = r2(n3, t3, e2.typeAnnotation || "assert");
}
if (!(n3 instanceof le) && "resolvedImage" !== n3.type.kind && this._isConstant(n3)) {
const t3 = new ye();
try {
n3 = new le(n3.type, n3.evaluate(t3));
} catch (t4) {
return this.error(t4.message), null;
}
}
return n3;
}
return this.error(`Unknown expression "${n2}". If you wanted a literal array, use ["literal", [...]].`, 0);
}
return this.error(void 0 === t2 ? "'undefined' value invalid. Use null instead." : "object" == typeof t2 ? 'Bare objects invalid. Use ["literal", {...}] instead.' : `Expected an array, but found ${typeof t2} instead.`);
}
concat(t2, e2, r2) {
const n2 = "number" == typeof t2 ? this.path.concat(t2) : this.path, i3 = r2 ? this.scope.concat(r2) : this.scope;
return new me(this.registry, this._isConstant, n2, e2 || null, i3, this.errors);
}
error(t2, ...e2) {
const r2 = `${this.key}${e2.map(((t3) => `[${t3}]`)).join("")}`;
this.errors.push(new ut(r2, t2));
}
checkSubtype(t2, e2) {
const r2 = It(t2, e2);
return r2 && this.error(r2), r2;
}
}
class ge {
constructor(t2, e2, r2) {
this.type = xt, this.locale = r2, this.caseSensitive = t2, this.diacriticSensitive = e2;
}
static parse(t2, e2) {
if (2 !== t2.length) return e2.error("Expected one argument.");
const r2 = t2[1];
if ("object" != typeof r2 || Array.isArray(r2)) return e2.error("Collator options argument must be an object.");
const n2 = e2.parse(void 0 !== r2["case-sensitive"] && r2["case-sensitive"], 1, dt);
if (!n2) return null;
const i3 = e2.parse(void 0 !== r2["diacritic-sensitive"] && r2["diacritic-sensitive"], 1, dt);
if (!i3) return null;
let a2 = null;
return r2.locale && (a2 = e2.parse(r2.locale, 1, ft), !a2) ? null : new ge(n2, i3, a2);
}
evaluate(t2) {
return new Ht(this.caseSensitive.evaluate(t2), this.diacriticSensitive.evaluate(t2), this.locale ? this.locale.evaluate(t2) : null);
}
eachChild(t2) {
t2(this.caseSensitive), t2(this.diacriticSensitive), this.locale && t2(this.locale);
}
outputDefined() {
return false;
}
}
const xe = 8192;
function ve(t2, e2) {
t2[0] = Math.min(t2[0], e2[0]), t2[1] = Math.min(t2[1], e2[1]), t2[2] = Math.max(t2[2], e2[0]), t2[3] = Math.max(t2[3], e2[1]);
}
function be(t2, e2) {
return !(t2[0] <= e2[0] || t2[2] >= e2[2] || t2[1] <= e2[1] || t2[3] >= e2[3]);
}
function we(t2, e2) {
const r2 = (180 + t2[0]) / 360, n2 = (180 - 180 / Math.PI * Math.log(Math.tan(Math.PI / 4 + t2[1] * Math.PI / 360))) / 360, i3 = Math.pow(2, e2.z);
return [Math.round(r2 * i3 * xe), Math.round(n2 * i3 * xe)];
}
function _e(t2, e2, r2) {
const n2 = t2[0] - e2[0], i3 = t2[1] - e2[1], a2 = t2[0] - r2[0], s2 = t2[1] - r2[1];
return n2 * s2 - a2 * i3 == 0 && n2 * a2 <= 0 && i3 * s2 <= 0;
}
function Ae(t2, e2) {
let r2 = false;
for (let s2 = 0, o2 = e2.length; s2 < o2; s2++) {
const o3 = e2[s2];
for (let e3 = 0, s3 = o3.length; e3 < s3 - 1; e3++) {
if (_e(t2, o3[e3], o3[e3 + 1])) return false;
(i3 = o3[e3])[1] > (n2 = t2)[1] != (a2 = o3[e3 + 1])[1] > n2[1] && n2[0] < (a2[0] - i3[0]) * (n2[1] - i3[1]) / (a2[1] - i3[1]) + i3[0] && (r2 = !r2);
}
}
var n2, i3, a2;
return r2;
}
function Se(t2, e2) {
for (let r2 = 0; r2 < e2.length; r2++) if (Ae(t2, e2[r2])) return true;
return false;
}
function ke(t2, e2, r2, n2) {
const i3 = n2[0] - r2[0], a2 = n2[1] - r2[1], s2 = (t2[0] - r2[0]) * a2 - i3 * (t2[1] - r2[1]), o2 = (e2[0] - r2[0]) * a2 - i3 * (e2[1] - r2[1]);
return s2 > 0 && o2 < 0 || s2 < 0 && o2 > 0;
}
function Ie(t2, e2, r2) {
for (const u2 of r2) for (let r3 = 0; r3 < u2.length - 1; ++r3) if (0 != (o2 = [(s2 = u2[r3 + 1])[0] - (a2 = u2[r3])[0], s2[1] - a2[1]])[0] * (l2 = [(i3 = e2)[0] - (n2 = t2)[0], i3[1] - n2[1]])[1] - o2[1] * l2[0] && ke(n2, i3, a2, s2) && ke(a2, s2, n2, i3)) return true;
var n2, i3, a2, s2, o2, l2;
return false;
}
function ze(t2, e2) {
for (let r2 = 0; r2 < t2.length; ++r2) if (!Ae(t2[r2], e2)) return false;
for (let r2 = 0; r2 < t2.length - 1; ++r2) if (Ie(t2[r2], t2[r2 + 1], e2)) return false;
return true;
}
function Me(t2, e2) {
for (let r2 = 0; r2 < e2.length; r2++) if (ze(t2, e2[r2])) return true;
return false;
}
function Ce(t2, e2, r2) {
const n2 = [];
for (let i3 = 0; i3 < t2.length; i3++) {
const a2 = [];
for (let n3 = 0; n3 < t2[i3].length; n3++) {
const s2 = we(t2[i3][n3], r2);
ve(e2, s2), a2.push(s2);
}
n2.push(a2);
}
return n2;
}
function Be(t2, e2, r2) {
const n2 = [];
for (let i3 = 0; i3 < t2.length; i3++) {
const a2 = Ce(t2[i3], e2, r2);
n2.push(a2);
}
return n2;
}
function Pe(t2, e2, r2, n2) {
if (t2[0] < r2[0] || t2[0] > r2[2]) {
const e3 = 0.5 * n2;
let i3 = t2[0] - r2[0] > e3 ? -n2 : r2[0] - t2[0] > e3 ? n2 : 0;
0 === i3 && (i3 = t2[0] - r2[2] > e3 ? -n2 : r2[2] - t2[0] > e3 ? n2 : 0), t2[0] += i3;
}
ve(e2, t2);
}
function Ve(t2, e2, r2, n2) {
const i3 = Math.pow(2, n2.z) * xe, a2 = [n2.x * xe, n2.y * xe], s2 = [];
for (const n3 of t2) for (const t3 of n3) {
const n4 = [t3.x + a2[0], t3.y + a2[1]];
Pe(n4, e2, r2, i3), s2.push(n4);
}
return s2;
}
function Ee(t2, e2, r2, n2) {
const i3 = Math.pow(2, n2.z) * xe, a2 = [n2.x * xe, n2.y * xe], s2 = [];
for (const r3 of t2) {
const t3 = [];
for (const n3 of r3) {
const r4 = [n3.x + a2[0], n3.y + a2[1]];
ve(e2, r4), t3.push(r4);
}
s2.push(t3);
}
if (e2[2] - e2[0] <= i3 / 2) {
(o2 = e2)[0] = o2[1] = 1 / 0, o2[2] = o2[3] = -1 / 0;
for (const t3 of s2) for (const n3 of t3) Pe(n3, e2, r2, i3);
}
var o2;
return s2;
}
class Fe {
constructor(t2, e2) {
this.type = dt, this.geojson = t2, this.geometries = e2;
}
static parse(t2, e2) {
if (2 !== t2.length) return e2.error(`'within' expression requires exactly one argument, but found ${t2.length - 1} instead.`);
if (ae(t2[1])) {
const e3 = t2[1];
if ("FeatureCollection" === e3.type) for (let t3 = 0; t3 < e3.features.length; ++t3) {
const r2 = e3.features[t3].geometry.type;
if ("Polygon" === r2 || "MultiPolygon" === r2) return new Fe(e3, e3.features[t3].geometry);
}
else if ("Feature" === e3.type) {
const t3 = e3.geometry.type;
if ("Polygon" === t3 || "MultiPolygon" === t3) return new Fe(e3, e3.geometry);
} else if ("Polygon" === e3.type || "MultiPolygon" === e3.type) return new Fe(e3, e3);
}
return e2.error("'within' expression requires valid geojson object that contains polygon geometry type.");
}
evaluate(t2) {
if (null != t2.geometry() && null != t2.canonicalID()) {
if ("Point" === t2.geometryType()) return (function(t3, e2) {
const r2 = [1 / 0, 1 / 0, -1 / 0, -1 / 0], n2 = [1 / 0, 1 / 0, -1 / 0, -1 / 0], i3 = t3.canonicalID();
if ("Polygon" === e2.type) {
const a2 = Ce(e2.coordinates, n2, i3), s2 = Ve(t3.geometry(), r2, n2, i3);
if (!be(r2, n2)) return false;
for (const t4 of s2) if (!Ae(t4, a2)) return false;
}
if ("MultiPolygon" === e2.type) {
const a2 = Be(e2.coordinates, n2, i3), s2 = Ve(t3.geometry(), r2, n2, i3);
if (!be(r2, n2)) return false;
for (const t4 of s2) if (!Se(t4, a2)) return false;
}
return true;
})(t2, this.geometries);
if ("LineString" === t2.geometryType()) return (function(t3, e2) {
const r2 = [1 / 0, 1 / 0, -1 / 0, -1 / 0], n2 = [1 / 0, 1 / 0, -1 / 0, -1 / 0], i3 = t3.canonicalID();
if ("Polygon" === e2.type) {
const a2 = Ce(e2.coordinates, n2, i3), s2 = Ee(t3.geometry(), r2, n2, i3);
if (!be(r2, n2)) return false;
for (const t4 of s2) if (!ze(t4, a2)) return false;
}
if ("MultiPolygon" === e2.type) {
const a2 = Be(e2.coordinates, n2, i3), s2 = Ee(t3.geometry(), r2, n2, i3);
if (!be(r2, n2)) return false;
for (const t4 of s2) if (!Me(t4, a2)) return false;
}
return true;
})(t2, this.geometries);
}
return false;
}
eachChild() {
}
outputDefined() {
return true;
}
}
class Te {
constructor(t2, e2) {
this.type = e2.type, this.name = t2, this.boundExpression = e2;
}
static parse(t2, e2) {
if (2 !== t2.length || "string" != typeof t2[1]) return e2.error("'var' expression requires exactly one string literal argument.");
const r2 = t2[1];
return e2.scope.has(r2) ? new Te(r2, e2.scope.get(r2)) : e2.error(`Unknown variable "${r2}". Make sure "${r2}" has been bound in an enclosing "let" expression before using it.`, 1);
}
evaluate(t2) {
return this.boundExpression.evaluate(t2);
}
eachChild() {
}
outputDefined() {
return false;
}
}
class $e {
constructor(t2, e2, r2, n2) {
this.name = t2, this.type = e2, this._evaluate = r2, this.args = n2;
}
evaluate(t2) {
return this._evaluate(t2, this.args);
}
eachChild(t2) {
this.args.forEach(t2);
}
outputDefined() {
return false;
}
static parse(t2, e2) {
const r2 = t2[0], n2 = $e.definitions[r2];
if (!n2) return e2.error(`Unknown expression "${r2}". If you wanted a literal array, use ["literal", [...]].`, 0);
const i3 = Array.isArray(n2) ? n2[0] : n2.type, a2 = Array.isArray(n2) ? [[n2[1], n2[2]]] : n2.overloads, s2 = a2.filter((([e3]) => !Array.isArray(e3) || e3.length === t2.length - 1));
let o2 = null;
for (const [n3, a3] of s2) {
o2 = new me(e2.registry, Le, e2.path, null, e2.scope);
const s3 = [];
let l2 = false;
for (let e3 = 1; e3 < t2.length; e3++) {
const r3 = t2[e3], i4 = Array.isArray(n3) ? n3[e3 - 1] : n3.type, a4 = o2.parse(r3, 1 + s3.length, i4);
if (!a4) {
l2 = true;
break;
}
s3.push(a4);
}
if (!l2) if (Array.isArray(n3) && n3.length !== s3.length) o2.error(`Expected ${n3.length} arguments, but found ${s3.length} instead.`);
else {
for (let t3 = 0; t3 < s3.length; t3++) {
const e3 = Array.isArray(n3) ? n3[t3] : n3.type, r3 = s3[t3];
o2.concat(t3 + 1).checkSubtype(e3, r3.type);
}
if (0 === o2.errors.length) return new $e(r2, i3, a3, s3);
}
}
if (1 === s2.length) e2.errors.push(...o2.errors);
else {
const r3 = (s2.length ? s2 : a2).map((([t3]) => {
return e3 = t3, Array.isArray(e3) ? `(${e3.map(St).join(", ")})` : `(${St(e3.type)}...)`;
var e3;
})).join(" | "), n3 = [];
for (let r4 = 1; r4 < t2.length; r4++) {
const i4 = e2.parse(t2[r4], 1 + n3.length);
if (!i4) return null;
n3.push(St(i4.type));
}
e2.error(`Expected arguments of type ${r3}, but found (${n3.join(", ")}) instead.`);
}
return null;
}
static register(t2, e2) {
$e.definitions = e2;
for (const r2 in e2) t2[r2] = $e;
}
}
function Le(t2) {
if (t2 instanceof Te) return Le(t2.boundExpression);
if (t2 instanceof $e && "error" === t2.name) return false;
if (t2 instanceof ge) return false;
if (t2 instanceof Fe) return false;
const e2 = t2 instanceof fe || t2 instanceof he;
let r2 = true;
return t2.eachChild(((t3) => {
r2 = e2 ? r2 && Le(t3) : r2 && t3 instanceof le;
})), !!r2 && De(t2) && Ue(t2, ["zoom", "heatmap-density", "line-progress", "accumulated", "is-supported-script"]);
}
function De(t2) {
if (t2 instanceof $e) {
if ("get" === t2.name && 1 === t2.args.length) return false;
if ("feature-state" === t2.name) return false;
if ("has" === t2.name && 1 === t2.args.length) return false;
if ("properties" === t2.name || "geometry-type" === t2.name || "id" === t2.name) return false;
if (/^filter-/.test(t2.name)) return false;
}
if (t2 instanceof Fe) return false;
let e2 = true;
return t2.eachChild(((t3) => {
e2 && !De(t3) && (e2 = false);
})), e2;
}
function Oe(t2) {
if (t2 instanceof $e && "feature-state" === t2.name) return false;
let e2 = true;
return t2.eachChild(((t3) => {
e2 && !Oe(t3) && (e2 = false);
})), e2;
}
function Ue(t2, e2) {
if (t2 instanceof $e && e2.indexOf(t2.name) >= 0) return false;
let r2 = true;
return t2.eachChild(((t3) => {
r2 && !Ue(t3, e2) && (r2 = false);
})), r2;
}
function Re(t2, e2) {
const r2 = t2.length - 1;
let n2, i3, a2 = 0, s2 = r2, o2 = 0;
for (; a2 <= s2; ) if (o2 = Math.floor((a2 + s2) / 2), n2 = t2[o2], i3 = t2[o2 + 1], n2 <= e2) {
if (o2 === r2 || e2 < i3) return o2;
a2 = o2 + 1;
} else {
if (!(n2 > e2)) throw new ue("Input is not a number.");
s2 = o2 - 1;
}
return 0;
}
class qe {
constructor(t2, e2, r2) {
this.type = t2, this.input = e2, this.labels = [], this.outputs = [];
for (const [t3, e3] of r2) this.labels.push(t3), this.outputs.push(e3);
}
static parse(t2, e2) {
if (t2.length - 1 < 4) return e2.error(`Expected at least 4 arguments, but found only ${t2.length - 1}.`);
if ((t2.length - 1) % 2 != 0) return e2.error("Expected an even number of arguments.");
const r2 = e2.parse(t2[1], 1, pt);
if (!r2) return null;
const n2 = [];
let i3 = null;
e2.expectedType && "value" !== e2.expectedType.kind && (i3 = e2.expectedType);
for (let r3 = 1; r3 < t2.length; r3 += 2) {
const a2 = 1 === r3 ? -1 / 0 : t2[r3], s2 = t2[r3 + 1], o2 = r3, l2 = r3 + 1;
if ("number" != typeof a2) return e2.error('Input/output pairs for "step" expressions must be defined using literal numeric values (not computed expressions) for the input values.', o2);
if (n2.length && n2[n2.length - 1][0] >= a2) return e2.error('Input/output pairs for "step" expressions must be arranged with input values in strictly ascending order.', o2);
const u2 = e2.parse(s2, l2, i3);
if (!u2) return null;
i3 = i3 || u2.type, n2.push([a2, u2]);
}
return new qe(i3, r2, n2);
}
evaluate(t2) {
const e2 = this.labels, r2 = this.outputs;
if (1 === e2.length) return r2[0].evaluate(t2);
const n2 = this.input.evaluate(t2);
if (n2 <= e2[0]) return r2[0].evaluate(t2);
const i3 = e2.length;
return n2 >= e2[i3 - 1] ? r2[i3 - 1].evaluate(t2) : r2[Re(e2, n2)].evaluate(t2);
}
eachChild(t2) {
t2(this.input);
for (const e2 of this.outputs) t2(e2);
}
outputDefined() {
return this.outputs.every(((t2) => t2.outputDefined()));
}
}
function je(t2, e2, r2) {
return t2 + r2 * (e2 - t2);
}
function Ne(t2, e2, r2) {
return t2.map(((t3, n2) => je(t3, e2[n2], r2)));
}
const Ze = { number: je, color: function(t2, e2, r2, n2 = "rgb") {
switch (n2) {
case "rgb": {
const [n3, i3, a2, s2] = Ne(t2.rgb, e2.rgb, r2);
return new Yt(n3, i3, a2, s2, false);
}
case "hcl": {
const [n3, i3, a2, s2] = t2.hcl, [o2, l2, u2, c2] = e2.hcl;
let h2, p2;
if (isNaN(n3) || isNaN(o2)) isNaN(n3) ? isNaN(o2) ? h2 = NaN : (h2 = o2, 1 !== a2 && 0 !== a2 || (p2 = l2)) : (h2 = n3, 1 !== u2 && 0 !== u2 || (p2 = i3));
else {
let t3 = o2 - n3;
o2 > n3 && t3 > 180 ? t3 -= 360 : o2 < n3 && n3 - o2 > 180 && (t3 += 360), h2 = n3 + r2 * t3;
}
const [f2, d2, y2, m2] = (function([t3, e3, r3, n4]) {
return t3 = isNaN(t3) ? 0 : t3 * $t, qt([r3, Math.cos(t3) * e3, Math.sin(t3) * e3, n4]);
})([h2, null != p2 ? p2 : je(i3, l2, r2), je(a2, u2, r2), je(s2, c2, r2)]);
return new Yt(f2, d2, y2, m2, false);
}
case "lab": {
const [n3, i3, a2, s2] = qt(Ne(t2.lab, e2.lab, r2));
return new Yt(n3, i3, a2, s2, false);
}
}
}, array: Ne, padding: function(t2, e2, r2) {
return new te(Ne(t2.values, e2.values, r2));
}, variableAnchorOffsetCollection: function(t2, e2, r2) {
const n2 = t2.values, i3 = e2.values;
if (n2.length !== i3.length) throw new ue(`Cannot interpolate values of different length. from: ${t2.toString()}, to: ${e2.toString()}`);
const a2 = [];
for (let t3 = 0; t3 < n2.length; t3 += 2) {
if (n2[t3] !== i3[t3]) throw new ue(`Cannot interpolate values containing mismatched anchors. from[${t3}]: ${n2[t3]}, to[${t3}]: ${i3[t3]}`);
a2.push(n2[t3]);
const [e3, s2] = n2[t3 + 1], [o2, l2] = i3[t3 + 1];
a2.push([je(e3, o2, r2), je(s2, l2, r2)]);
}
return new re(a2);
} };
class Ke {
constructor(t2, e2, r2, n2, i3) {
this.type = t2, this.operator = e2, this.interpolation = r2, this.input = n2, this.labels = [], this.outputs = [];
for (const [t3, e3] of i3) this.labels.push(t3), this.outputs.push(e3);
}
static interpolationFactor(t2, e2, r2, n2) {
let i3 = 0;
if ("exponential" === t2.name) i3 = Ge(e2, t2.base, r2, n2);
else if ("linear" === t2.name) i3 = Ge(e2, 1, r2, n2);
else if ("cubic-bezier" === t2.name) {
const a2 = t2.controlPoints;
i3 = new l(a2[0], a2[1], a2[2], a2[3]).solve(Ge(e2, 1, r2, n2));
}
return i3;
}
static parse(t2, e2) {
let [r2, n2, i3, ...a2] = t2;
if (!Array.isArray(n2) || 0 === n2.length) return e2.error("Expected an interpolation type expression.", 1);
if ("linear" === n2[0]) n2 = { name: "linear" };
else if ("exponential" === n2[0]) {
const t3 = n2[1];
if ("number" != typeof t3) return e2.error("Exponential interpolation requires a numeric base.", 1, 1);
n2 = { name: "exponential", base: t3 };
} else {
if ("cubic-bezier" !== n2[0]) return e2.error(`Unknown interpolation type ${String(n2[0])}`, 1, 0);
{
const t3 = n2.slice(1);
if (4 !== t3.length || t3.some(((t4) => "number" != typeof t4 || t4 < 0 || t4 > 1))) return e2.error("Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.", 1);
n2 = { name: "cubic-bezier", controlPoints: t3 };
}
}
if (t2.length - 1 < 4) return e2.error(`Expected at least 4 arguments, but found only ${t2.length - 1}.`);
if ((t2.length - 1) % 2 != 0) return e2.error("Expected an even number of arguments.");
if (i3 = e2.parse(i3, 2, pt), !i3) return null;
const s2 = [];
let o2 = null;
"interpolate-hcl" === r2 || "interpolate-lab" === r2 ? o2 = yt : e2.expectedType && "value" !== e2.expectedType.kind && (o2 = e2.expectedType);
for (let t3 = 0; t3 < a2.length; t3 += 2) {
const r3 = a2[t3], n3 = a2[t3 + 1], i4 = t3 + 3, l2 = t3 + 4;
if ("number" != typeof r3) return e2.error('Input/output pairs for "interpolate" expressions must be defined using literal numeric values (not computed expressions) for the input values.', i4);
if (s2.length && s2[s2.length - 1][0] >= r3) return e2.error('Input/output pairs for "interpolate" expressions must be arranged with input values in strictly ascending order.', i4);
const u2 = e2.parse(n3, l2, o2);
if (!u2) return null;
o2 = o2 || u2.type, s2.push([r3, u2]);
}
return Ct(o2, pt) || Ct(o2, yt) || Ct(o2, bt) || Ct(o2, _t) || Ct(o2, At(pt)) ? new Ke(o2, r2, n2, i3, s2) : e2.error(`Type ${St(o2)} is not interpolatable.`);
}
evaluate(t2) {
const e2 = this.labels, r2 = this.outputs;
if (1 === e2.length) return r2[0].evaluate(t2);
const n2 = this.input.evaluate(t2);
if (n2 <= e2[0]) return r2[0].evaluate(t2);
const i3 = e2.length;
if (n2 >= e2[i3 - 1]) return r2[i3 - 1].evaluate(t2);
const a2 = Re(e2, n2), s2 = Ke.interpolationFactor(this.interpolation, n2, e2[a2], e2[a2 + 1]), o2 = r2[a2].evaluate(t2), l2 = r2[a2 + 1].evaluate(t2);
switch (this.operator) {
case "interpolate":
return Ze[this.type.kind](o2, l2, s2);
case "interpolate-hcl":
return Ze.color(o2, l2, s2, "hcl");
case "interpolate-lab":
return Ze.color(o2, l2, s2, "lab");
}
}
eachChild(t2) {
t2(this.input);
for (const e2 of this.outputs) t2(e2);
}
outputDefined() {
return this.outputs.every(((t2) => t2.outputDefined()));
}
}
function Ge(t2, e2, r2, n2) {
const i3 = n2 - r2, a2 = t2 - r2;
return 0 === i3 ? 0 : 1 === e2 ? a2 / i3 : (Math.pow(e2, a2) - 1) / (Math.pow(e2, i3) - 1);
}
class Je {
constructor(t2, e2) {
this.type = t2, this.args = e2;
}
static parse(t2, e2) {
if (t2.length < 2) return e2.error("Expectected at least one argument.");
let r2 = null;
const n2 = e2.expectedType;
n2 && "value" !== n2.kind && (r2 = n2);
const i3 = [];
for (const n3 of t2.slice(1)) {
const t3 = e2.parse(n3, 1 + i3.length, r2, void 0, { typeAnnotation: "omit" });
if (!t3) return null;
r2 = r2 || t3.type, i3.push(t3);
}
if (!r2) throw new Error("No output type");
const a2 = n2 && i3.some(((t3) => It(n2, t3.type)));
return new Je(a2 ? gt : r2, i3);
}
evaluate(t2) {
let e2, r2 = null, n2 = 0;
for (const i3 of this.args) if (n2++, r2 = i3.evaluate(t2), r2 && r2 instanceof ne && !r2.available && (e2 || (e2 = r2.name), r2 = null, n2 === this.args.length && (r2 = e2)), null !== r2) break;
return r2;
}
eachChild(t2) {
this.args.forEach(t2);
}
outputDefined() {
return this.args.every(((t2) => t2.outputDefined()));
}
}
class Xe {
constructor(t2, e2) {
this.type = e2.type, this.bindings = [].concat(t2), this.result = e2;
}
evaluate(t2) {
return this.result.evaluate(t2);
}
eachChild(t2) {
for (const e2 of this.bindings) t2(e2[1]);
t2(this.result);
}
static parse(t2, e2) {
if (t2.length < 4) return e2.error(`Expected at least 3 arguments, but found ${t2.length - 1} instead.`);
const r2 = [];
for (let n3 = 1; n3 < t2.length - 1; n3 += 2) {
const i3 = t2[n3];
if ("string" != typeof i3) return e2.error(`Expected string, but found ${typeof i3} instead.`, n3);
if (/[^a-zA-Z0-9_]/.test(i3)) return e2.error("Variable names must contain only alphanumeric characters or '_'.", n3);
const a2 = e2.parse(t2[n3 + 1], n3 + 1);
if (!a2) return null;
r2.push([i3, a2]);
}
const n2 = e2.parse(t2[t2.length - 1], t2.length - 1, e2.expectedType, r2);
return n2 ? new Xe(r2, n2) : null;
}
outputDefined() {
return this.result.outputDefined();
}
}
class Ye {
constructor(t2, e2, r2) {
this.type = t2, this.index = e2, this.input = r2;
}
static parse(t2, e2) {
if (3 !== t2.length) return e2.error(`Expected 2 arguments, but found ${t2.length - 1} instead.`);
const r2 = e2.parse(t2[1], 1, pt), n2 = e2.parse(t2[2], 2, At(e2.expectedType || gt));
return r2 && n2 ? new Ye(n2.type.itemType, r2, n2) : null;
}
evaluate(t2) {
const e2 = this.index.evaluate(t2), r2 = this.input.evaluate(t2);
if (e2 < 0) throw new ue(`Array index out of bounds: ${e2} < 0.`);
if (e2 >= r2.length) throw new ue(`Array index out of bounds: ${e2} > ${r2.length - 1}.`);
if (e2 !== Math.floor(e2)) throw new ue(`Array index must be an integer, but found ${e2} instead.`);
return r2[e2];
}
eachChild(t2) {
t2(this.index), t2(this.input);
}
outputDefined() {
return false;
}
}
class He {
constructor(t2, e2) {
this.type = dt, this.needle = t2, this.haystack = e2;
}
static parse(t2, e2) {
if (3 !== t2.length) return e2.error(`Expected 2 arguments, but found ${t2.length - 1} instead.`);
const r2 = e2.parse(t2[1], 1, gt), n2 = e2.parse(t2[2], 2, gt);
return r2 && n2 ? zt(r2.type, [dt, ft, pt, ht, gt]) ? new He(r2, n2) : e2.error(`Expected first argument to be of type boolean, string, number or null, but found ${St(r2.type)} instead`) : null;
}
evaluate(t2) {
const e2 = this.needle.evaluate(t2), r2 = this.haystack.evaluate(t2);
if (!r2) return false;
if (!Mt(e2, ["boolean", "string", "number", "null"])) throw new ue(`Expected first argument to be of type boolean, string, number or null, but found ${St(se(e2))} instead.`);
if (!Mt(r2, ["string", "array"])) throw new ue(`Expected second argument to be of type array or string, but found ${St(se(r2))} instead.`);
return r2.indexOf(e2) >= 0;
}
eachChild(t2) {
t2(this.needle), t2(this.haystack);
}
outputDefined() {
return true;
}
}
class We {
constructor(t2, e2, r2) {
this.type = pt, this.needle = t2, this.haystack = e2, this.fromIndex = r2;
}
static parse(t2, e2) {
if (t2.length <= 2 || t2.length >= 5) return e2.error(`Expected 3 or 4 arguments, but found ${t2.length - 1} instead.`);
const r2 = e2.parse(t2[1], 1, gt), n2 = e2.parse(t2[2], 2, gt);
if (!r2 || !n2) return null;
if (!zt(r2.type, [dt, ft, pt, ht, gt])) return e2.error(`Expected first argument to be of type boolean, string, number or null, but found ${St(r2.type)} instead`);
if (4 === t2.length) {
const i3 = e2.parse(t2[3], 3, pt);
return i3 ? new We(r2, n2, i3) : null;
}
return new We(r2, n2);
}
evaluate(t2) {
const e2 = this.needle.evaluate(t2), r2 = this.haystack.evaluate(t2);
if (!Mt(e2, ["boolean", "string", "number", "null"])) throw new ue(`Expected first argument to be of type boolean, string, number or null, but found ${St(se(e2))} instead.`);
if (!Mt(r2, ["string", "array"])) throw new ue(`Expected second argument to be of type array or string, but found ${St(se(r2))} instead.`);
if (this.fromIndex) {
const n2 = this.fromIndex.evaluate(t2);
return r2.indexOf(e2, n2);
}
return r2.indexOf(e2);
}
eachChild(t2) {
t2(this.needle), t2(this.haystack), this.fromIndex && t2(this.fromIndex);
}
outputDefined() {
return false;
}
}
class Qe {
constructor(t2, e2, r2, n2, i3, a2) {
this.inputType = t2, this.type = e2, this.input = r2, this.cases = n2, this.outputs = i3, this.otherwise = a2;
}
static parse(t2, e2) {
if (t2.length < 5) return e2.error(`Expected at least 4 arguments, but found only ${t2.length - 1}.`);
if (t2.length % 2 != 1) return e2.error("Expected an even number of arguments.");
let r2, n2;
e2.expectedType && "value" !== e2.expectedType.kind && (n2 = e2.expectedType);
const i3 = {}, a2 = [];
for (let s3 = 2; s3 < t2.length - 1; s3 += 2) {
let o3 = t2[s3];
const l2 = t2[s3 + 1];
Array.isArray(o3) || (o3 = [o3]);
const u2 = e2.concat(s3);
if (0 === o3.length) return u2.error("Expected at least one branch label.");
for (const t3 of o3) {
if ("number" != typeof t3 && "string" != typeof t3) return u2.error("Branch labels must be numbers or strings.");
if ("number" == typeof t3 && Math.abs(t3) > Number.MAX_SAFE_INTEGER) return u2.error(`Branch labels must be integers no larger than ${Number.MAX_SAFE_INTEGER}.`);
if ("number" == typeof t3 && Math.floor(t3) !== t3) return u2.error("Numeric branch labels must be integer values.");
if (r2) {
if (u2.checkSubtype(r2, se(t3))) return null;
} else r2 = se(t3);
if (void 0 !== i3[String(t3)]) return u2.error("Branch labels must be unique.");
i3[String(t3)] = a2.length;
}
const c2 = e2.parse(l2, s3, n2);
if (!c2) return null;
n2 = n2 || c2.type, a2.push(c2);
}
const s2 = e2.parse(t2[1], 1, gt);
if (!s2) return null;
const o2 = e2.parse(t2[t2.length - 1], t2.length - 1, n2);
return o2 ? "value" !== s2.type.kind && e2.concat(1).checkSubtype(r2, s2.type) ? null : new Qe(r2, n2, s2, i3, a2, o2) : null;
}
evaluate(t2) {
const e2 = this.input.evaluate(t2);
return (se(e2) === this.inputType && this.outputs[this.cases[e2]] || this.otherwise).evaluate(t2);
}
eachChild(t2) {
t2(this.input), this.outputs.forEach(t2), t2(this.otherwise);
}
outputDefined() {
return this.outputs.every(((t2) => t2.outputDefined())) && this.otherwise.outputDefined();
}
}
class tr {
constructor(t2, e2, r2) {
this.type = t2, this.branches = e2, this.otherwise = r2;
}
static parse(t2, e2) {
if (t2.length < 4) return e2.error(`Expected at least 3 arguments, but found only ${t2.length - 1}.`);
if (t2.length % 2 != 0) return e2.error("Expected an odd number of arguments.");
let r2;
e2.expectedType && "value" !== e2.expectedType.kind && (r2 = e2.expectedType);
const n2 = [];
for (let i4 = 1; i4 < t2.length - 1; i4 += 2) {
const a2 = e2.parse(t2[i4], i4, dt);
if (!a2) return null;
const s2 = e2.parse(t2[i4 + 1], i4 + 1, r2);
if (!s2) return null;
n2.push([a2, s2]), r2 = r2 || s2.type;
}
const i3 = e2.parse(t2[t2.length - 1], t2.length - 1, r2);
if (!i3) return null;
if (!r2) throw new Error("Can't infer output type");
return new tr(r2, n2, i3);
}
evaluate(t2) {
for (const [e2, r2] of this.branches) if (e2.evaluate(t2)) return r2.evaluate(t2);
return this.otherwise.evaluate(t2);
}
eachChild(t2) {
for (const [e2, r2] of this.branches) t2(e2), t2(r2);
t2(this.otherwise);
}
outputDefined() {
return this.branches.every((([t2, e2]) => e2.outputDefined())) && this.otherwise.outputDefined();
}
}
class er {
constructor(t2, e2, r2, n2) {
this.type = t2, this.input = e2, this.beginIndex = r2, this.endIndex = n2;
}
static parse(t2, e2) {
if (t2.length <= 2 || t2.length >= 5) return e2.error(`Expected 3 or 4 arguments, but found ${t2.length - 1} instead.`);
const r2 = e2.parse(t2[1], 1, gt), n2 = e2.parse(t2[2], 2, pt);
if (!r2 || !n2) return null;
if (!zt(r2.type, [At(gt), ft, gt])) return e2.error(`Expected first argument to be of type array or string, but found ${St(r2.type)} instead`);
if (4 === t2.length) {
const i3 = e2.parse(t2[3], 3, pt);
return i3 ? new er(r2.type, r2, n2, i3) : null;
}
return new er(r2.type, r2, n2);
}
evaluate(t2) {
const e2 = this.input.evaluate(t2), r2 = this.beginIndex.evaluate(t2);
if (!Mt(e2, ["string", "array"])) throw new ue(`Expected first argument to be of type array or string, but found ${St(se(e2))} instead.`);
if (this.endIndex) {
const n2 = this.endIndex.evaluate(t2);
return e2.slice(r2, n2);
}
return e2.slice(r2);
}
eachChild(t2) {
t2(this.input), t2(this.beginIndex), this.endIndex && t2(this.endIndex);
}
outputDefined() {
return false;
}
}
function rr(t2, e2) {
return "==" === t2 || "!=" === t2 ? "boolean" === e2.kind || "string" === e2.kind || "number" === e2.kind || "null" === e2.kind || "value" === e2.kind : "string" === e2.kind || "number" === e2.kind || "value" === e2.kind;
}
function nr(t2, e2, r2, n2) {
return 0 === n2.compare(e2, r2);
}
function ir(t2, e2, r2) {
const n2 = "==" !== t2 && "!=" !== t2;
return class i3 {
constructor(t3, e3, r3) {
this.type = dt, this.lhs = t3, this.rhs = e3, this.collator = r3, this.hasUntypedArgument = "value" === t3.type.kind || "value" === e3.type.kind;
}
static parse(t3, e3) {
if (3 !== t3.length && 4 !== t3.length) return e3.error("Expected two or three arguments.");
const r3 = t3[0];
let a2 = e3.parse(t3[1], 1, gt);
if (!a2) return null;
if (!rr(r3, a2.type)) return e3.concat(1).error(`"${r3}" comparisons are not supported for type '${St(a2.type)}'.`);
let s2 = e3.parse(t3[2], 2, gt);
if (!s2) return null;
if (!rr(r3, s2.type)) return e3.concat(2).error(`"${r3}" comparisons are not supported for type '${St(s2.type)}'.`);
if (a2.type.kind !== s2.type.kind && "value" !== a2.type.kind && "value" !== s2.type.kind) return e3.error(`Cannot compare types '${St(a2.type)}' and '${St(s2.type)}'.`);
n2 && ("value" === a2.type.kind && "value" !== s2.type.kind ? a2 = new he(s2.type, [a2]) : "value" !== a2.type.kind && "value" === s2.type.kind && (s2 = new he(a2.type, [s2])));
let o2 = null;
if (4 === t3.length) {
if ("string" !== a2.type.kind && "string" !== s2.type.kind && "value" !== a2.type.kind && "value" !== s2.type.kind) return e3.error("Cannot use collator to compare non-string types.");
if (o2 = e3.parse(t3[3], 3, xt), !o2) return null;
}
return new i3(a2, s2, o2);
}
evaluate(i4) {
const a2 = this.lhs.evaluate(i4), s2 = this.rhs.evaluate(i4);
if (n2 && this.hasUntypedArgument) {
const e3 = se(a2), r3 = se(s2);
if (e3.kind !== r3.kind || "string" !== e3.kind && "number" !== e3.kind) throw new ue(`Expected arguments for "${t2}" to be (string, string) or (number, number), but found (${e3.kind}, ${r3.kind}) instead.`);
}
if (this.collator && !n2 && this.hasUntypedArgument) {
const t3 = se(a2), r3 = se(s2);
if ("string" !== t3.kind || "string" !== r3.kind) return e2(i4, a2, s2);
}
return this.collator ? r2(i4, a2, s2, this.collator.evaluate(i4)) : e2(i4, a2, s2);
}
eachChild(t3) {
t3(this.lhs), t3(this.rhs), this.collator && t3(this.collator);
}
outputDefined() {
return true;
}
};
}
const ar = ir("==", (function(t2, e2, r2) {
return e2 === r2;
}), nr), sr = ir("!=", (function(t2, e2, r2) {
return e2 !== r2;
}), (function(t2, e2, r2, n2) {
return !nr(0, e2, r2, n2);
})), or = ir("<", (function(t2, e2, r2) {
return e2 < r2;
}), (function(t2, e2, r2, n2) {
return n2.compare(e2, r2) < 0;
})), lr = ir(">", (function(t2, e2, r2) {
return e2 > r2;
}), (function(t2, e2, r2, n2) {
return n2.compare(e2, r2) > 0;
})), ur = ir("<=", (function(t2, e2, r2) {
return e2 <= r2;
}), (function(t2, e2, r2, n2) {
return n2.compare(e2, r2) <= 0;
})), cr = ir(">=", (function(t2, e2, r2) {
return e2 >= r2;
}), (function(t2, e2, r2, n2) {
return n2.compare(e2, r2) >= 0;
}));
class hr {
constructor(t2, e2, r2, n2, i3) {
this.type = ft, this.number = t2, this.locale = e2, this.currency = r2, this.minFractionDigits = n2, this.maxFractionDigits = i3;
}
static parse(t2, e2) {
if (3 !== t2.length) return e2.error("Expected two arguments.");
const r2 = e2.parse(t2[1], 1, pt);
if (!r2) return null;
const n2 = t2[2];
if ("object" != typeof n2 || Array.isArray(n2)) return e2.error("NumberFormat options argument must be an object.");
let i3 = null;
if (n2.locale && (i3 = e2.parse(n2.locale, 1, ft), !i3)) return null;
let a2 = null;
if (n2.currency && (a2 = e2.parse(n2.currency, 1, ft), !a2)) return null;
let s2 = null;
if (n2["min-fraction-digits"] && (s2 = e2.parse(n2["min-fraction-digits"], 1, pt), !s2)) return null;
let o2 = null;
return n2["max-fraction-digits"] && (o2 = e2.parse(n2["max-fraction-digits"], 1, pt), !o2) ? null : new hr(r2, i3, a2, s2, o2);
}
evaluate(t2) {
return new Intl.NumberFormat(this.locale ? this.locale.evaluate(t2) : [], { style: this.currency ? "currency" : "decimal", currency: this.currency ? this.currency.evaluate(t2) : void 0, minimumFractionDigits: this.minFractionDigits ? this.minFractionDigits.evaluate(t2) : void 0, maximumFractionDigits: this.maxFractionDigits ? this.maxFractionDigits.evaluate(t2) : void 0 }).format(this.number.evaluate(t2));
}
eachChild(t2) {
t2(this.number), this.locale && t2(this.locale), this.currency && t2(this.currency), this.minFractionDigits && t2(this.minFractionDigits), this.maxFractionDigits && t2(this.maxFractionDigits);
}
outputDefined() {
return false;
}
}
class pr {
constructor(t2) {
this.type = vt, this.sections = t2;
}
static parse(t2, e2) {
if (t2.length < 2) return e2.error("Expected at least one argument.");
const r2 = t2[1];
if (!Array.isArray(r2) && "object" == typeof r2) return e2.error("First argument must be an image or text section.");
const n2 = [];
let i3 = false;
for (let r3 = 1; r3 <= t2.length - 1; ++r3) {
const a2 = t2[r3];
if (i3 && "object" == typeof a2 && !Array.isArray(a2)) {
i3 = false;
let t3 = null;
if (a2["font-scale"] && (t3 = e2.parse(a2["font-scale"], 1, pt), !t3)) return null;
let r4 = null;
if (a2["text-font"] && (r4 = e2.parse(a2["text-font"], 1, At(ft)), !r4)) return null;
let s2 = null;
if (a2["text-color"] && (s2 = e2.parse(a2["text-color"], 1, yt), !s2)) return null;
const o2 = n2[n2.length - 1];
o2.scale = t3, o2.font = r4, o2.textColor = s2;
} else {
const a3 = e2.parse(t2[r3], 1, gt);
if (!a3) return null;
const s2 = a3.type.kind;
if ("string" !== s2 && "value" !== s2 && "null" !== s2 && "resolvedImage" !== s2) return e2.error("Formatted text type must be 'string', 'value', 'image' or 'null'.");
i3 = true, n2.push({ content: a3, scale: null, font: null, textColor: null });
}
}
return new pr(n2);
}
evaluate(t2) {
return new Qt(this.sections.map(((e2) => {
const r2 = e2.content.evaluate(t2);
return se(r2) === wt ? new Wt("", r2, null, null, null) : new Wt(oe(r2), null, e2.scale ? e2.scale.evaluate(t2) : null, e2.font ? e2.font.evaluate(t2).join(",") : null, e2.textColor ? e2.textColor.evaluate(t2) : null);
})));
}
eachChild(t2) {
for (const e2 of this.sections) t2(e2.content), e2.scale && t2(e2.scale), e2.font && t2(e2.font), e2.textColor && t2(e2.textColor);
}
outputDefined() {
return false;
}
}
class fr {
constructor(t2) {
this.type = wt, this.input = t2;
}
static parse(t2, e2) {
if (2 !== t2.length) return e2.error("Expected two arguments.");
const r2 = e2.parse(t2[1], 1, ft);
return r2 ? new fr(r2) : e2.error("No image name provided.");
}
evaluate(t2) {
const e2 = this.input.evaluate(t2), r2 = ne.fromString(e2);
return r2 && t2.availableImages && (r2.available = t2.availableImages.indexOf(e2) > -1), r2;
}
eachChild(t2) {
t2(this.input);
}
outputDefined() {
return false;
}
}
class dr {
constructor(t2) {
this.type = pt, this.input = t2;
}
static parse(t2, e2) {
if (2 !== t2.length) return e2.error(`Expected 1 argument, but found ${t2.length - 1} instead.`);
const r2 = e2.parse(t2[1], 1);
return r2 ? "array" !== r2.type.kind && "string" !== r2.type.kind && "value" !== r2.type.kind ? e2.error(`Expected argument of type string or array, but found ${St(r2.type)} instead.`) : new dr(r2) : null;
}
evaluate(t2) {
const e2 = this.input.evaluate(t2);
if ("string" == typeof e2) return e2.length;
if (Array.isArray(e2)) return e2.length;
throw new ue(`Expected value to be of type string or array, but found ${St(se(e2))} instead.`);
}
eachChild(t2) {
t2(this.input);
}
outputDefined() {
return false;
}
}
const yr = { "==": ar, "!=": sr, ">": lr, "<": or, ">=": cr, "<=": ur, array: he, at: Ye, boolean: he, case: tr, coalesce: Je, collator: ge, format: pr, image: fr, in: He, "index-of": We, interpolate: Ke, "interpolate-hcl": Ke, "interpolate-lab": Ke, length: dr, let: Xe, literal: le, match: Qe, number: he, "number-format": hr, object: he, slice: er, step: qe, string: he, "to-boolean": fe, "to-color": fe, "to-number": fe, "to-string": fe, var: Te, within: Fe };
function mr(t2, [e2, r2, n2, i3]) {
e2 = e2.evaluate(t2), r2 = r2.evaluate(t2), n2 = n2.evaluate(t2);
const a2 = i3 ? i3.evaluate(t2) : 1, s2 = ie(e2, r2, n2, a2);
if (s2) throw new ue(s2);
return new Yt(e2 / 255, r2 / 255, n2 / 255, a2, false);
}
function gr(t2, e2) {
return t2 in e2;
}
function xr(t2, e2) {
const r2 = e2[t2];
return void 0 === r2 ? null : r2;
}
function vr(t2) {
return { type: t2 };
}
function br(t2) {
return { result: "success", value: t2 };
}
function wr(t2) {
return { result: "error", value: t2 };
}
function _r(t2) {
return "data-driven" === t2["property-type"] || "cross-faded-data-driven" === t2["property-type"];
}
function Ar(t2) {
return !!t2.expression && t2.expression.parameters.indexOf("zoom") > -1;
}
function Sr(t2) {
return !!t2.expression && t2.expression.interpolated;
}
function kr(t2) {
return t2 instanceof Number ? "number" : t2 instanceof String ? "string" : t2 instanceof Boolean ? "boolean" : Array.isArray(t2) ? "array" : null === t2 ? "null" : typeof t2;
}
function Ir(t2) {
return "object" == typeof t2 && null !== t2 && !Array.isArray(t2);
}
function zr(t2) {
return t2;
}
function Mr(t2, e2) {
const r2 = "color" === e2.type, n2 = t2.stops && "object" == typeof t2.stops[0][0], i3 = n2 || !(n2 || void 0 !== t2.property), a2 = t2.type || (Sr(e2) ? "exponential" : "interval");
if (r2 || "padding" === e2.type) {
const n3 = r2 ? Yt.parse : te.parse;
(t2 = lt({}, t2)).stops && (t2.stops = t2.stops.map(((t3) => [t3[0], n3(t3[1])]))), t2.default = n3(t2.default ? t2.default : e2.default);
}
if (t2.colorSpace && "rgb" !== (s2 = t2.colorSpace) && "hcl" !== s2 && "lab" !== s2) throw new Error(`Unknown color space: "${t2.colorSpace}"`);
var s2;
let o2, l2, u2;
if ("exponential" === a2) o2 = Vr;
else if ("interval" === a2) o2 = Pr;
else if ("categorical" === a2) {
o2 = Br, l2 = /* @__PURE__ */ Object.create(null);
for (const e3 of t2.stops) l2[e3[0]] = e3[1];
u2 = typeof t2.stops[0][0];
} else {
if ("identity" !== a2) throw new Error(`Unknown function type "${a2}"`);
o2 = Er;
}
if (n2) {
const r3 = {}, n3 = [];
for (let e3 = 0; e3 < t2.stops.length; e3++) {
const i5 = t2.stops[e3], a4 = i5[0].zoom;
void 0 === r3[a4] && (r3[a4] = { zoom: a4, type: t2.type, property: t2.property, default: t2.default, stops: [] }, n3.push(a4)), r3[a4].stops.push([i5[0].value, i5[1]]);
}
const i4 = [];
for (const t3 of n3) i4.push([r3[t3].zoom, Mr(r3[t3], e2)]);
const a3 = { name: "linear" };
return { kind: "composite", interpolationType: a3, interpolationFactor: Ke.interpolationFactor.bind(void 0, a3), zoomStops: i4.map(((t3) => t3[0])), evaluate: ({ zoom: r4 }, n4) => Vr({ stops: i4, base: t2.base }, e2, r4).evaluate(r4, n4) };
}
if (i3) {
const r3 = "exponential" === a2 ? { name: "exponential", base: void 0 !== t2.base ? t2.base : 1 } : null;
return { kind: "camera", interpolationType: r3, interpolationFactor: Ke.interpolationFactor.bind(void 0, r3), zoomStops: t2.stops.map(((t3) => t3[0])), evaluate: ({ zoom: r4 }) => o2(t2, e2, r4, l2, u2) };
}
return { kind: "source", evaluate(r3, n3) {
const i4 = n3 && n3.properties ? n3.properties[t2.property] : void 0;
return void 0 === i4 ? Cr(t2.default, e2.default) : o2(t2, e2, i4, l2, u2);
} };
}
function Cr(t2, e2, r2) {
return void 0 !== t2 ? t2 : void 0 !== e2 ? e2 : void 0 !== r2 ? r2 : void 0;
}
function Br(t2, e2, r2, n2, i3) {
return Cr(typeof r2 === i3 ? n2[r2] : void 0, t2.default, e2.default);
}
function Pr(t2, e2, r2) {
if ("number" !== kr(r2)) return Cr(t2.default, e2.default);
const n2 = t2.stops.length;
if (1 === n2) return t2.stops[0][1];
if (r2 <= t2.stops[0][0]) return t2.stops[0][1];
if (r2 >= t2.stops[n2 - 1][0]) return t2.stops[n2 - 1][1];
const i3 = Re(t2.stops.map(((t3) => t3[0])), r2);
return t2.stops[i3][1];
}
function Vr(t2, e2, r2) {
const n2 = void 0 !== t2.base ? t2.base : 1;
if ("number" !== kr(r2)) return Cr(t2.default, e2.default);
const i3 = t2.stops.length;
if (1 === i3) return t2.stops[0][1];
if (r2 <= t2.stops[0][0]) return t2.stops[0][1];
if (r2 >= t2.stops[i3 - 1][0]) return t2.stops[i3 - 1][1];
const a2 = Re(t2.stops.map(((t3) => t3[0])), r2), s2 = (function(t3, e3, r3, n3) {
const i4 = n3 - r3, a3 = t3 - r3;
return 0 === i4 ? 0 : 1 === e3 ? a3 / i4 : (Math.pow(e3, a3) - 1) / (Math.pow(e3, i4) - 1);
})(r2, n2, t2.stops[a2][0], t2.stops[a2 + 1][0]), o2 = t2.stops[a2][1], l2 = t2.stops[a2 + 1][1], u2 = Ze[e2.type] || zr;
return "function" == typeof o2.evaluate ? { evaluate(...e3) {
const r3 = o2.evaluate.apply(void 0, e3), n3 = l2.evaluate.apply(void 0, e3);
if (void 0 !== r3 && void 0 !== n3) return u2(r3, n3, s2, t2.colorSpace);
} } : u2(o2, l2, s2, t2.colorSpace);
}
function Er(t2, e2, r2) {
switch (e2.type) {
case "color":
r2 = Yt.parse(r2);
break;
case "formatted":
r2 = Qt.fromString(r2.toString());
break;
case "resolvedImage":
r2 = ne.fromString(r2.toString());
break;
case "padding":
r2 = te.parse(r2);
break;
default:
kr(r2) === e2.type || "enum" === e2.type && e2.values[r2] || (r2 = void 0);
}
return Cr(r2, t2.default, e2.default);
}
$e.register(yr, { error: [{ kind: "error" }, [ft], (t2, [e2]) => {
throw new ue(e2.evaluate(t2));
}], typeof: [ft, [gt], (t2, [e2]) => St(se(e2.evaluate(t2)))], "to-rgba": [At(pt, 4), [yt], (t2, [e2]) => {
const [r2, n2, i3, a2] = e2.evaluate(t2).rgb;
return [255 * r2, 255 * n2, 255 * i3, a2];
}], rgb: [yt, [pt, pt, pt], mr], rgba: [yt, [pt, pt, pt, pt], mr], has: { type: dt, overloads: [[[ft], (t2, [e2]) => gr(e2.evaluate(t2), t2.properties())], [[ft, mt], (t2, [e2, r2]) => gr(e2.evaluate(t2), r2.evaluate(t2))]] }, get: { type: gt, overloads: [[[ft], (t2, [e2]) => xr(e2.evaluate(t2), t2.properties())], [[ft, mt], (t2, [e2, r2]) => xr(e2.evaluate(t2), r2.evaluate(t2))]] }, "feature-state": [gt, [ft], (t2, [e2]) => xr(e2.evaluate(t2), t2.featureState || {})], properties: [mt, [], (t2) => t2.properties()], "geometry-type": [ft, [], (t2) => t2.geometryType()], id: [gt, [], (t2) => t2.id()], zoom: [pt, [], (t2) => t2.globals.zoom], "heatmap-density": [pt, [], (t2) => t2.globals.heatmapDensity || 0], "line-progress": [pt, [], (t2) => t2.globals.lineProgress || 0], accumulated: [gt, [], (t2) => void 0 === t2.globals.accumulated ? null : t2.globals.accumulated], "+": [pt, vr(pt), (t2, e2) => {
let r2 = 0;
for (const n2 of e2) r2 += n2.evaluate(t2);
return r2;
}], "*": [pt, vr(pt), (t2, e2) => {
let r2 = 1;
for (const n2 of e2) r2 *= n2.evaluate(t2);
return r2;
}], "-": { type: pt, overloads: [[[pt, pt], (t2, [e2, r2]) => e2.evaluate(t2) - r2.evaluate(t2)], [[pt], (t2, [e2]) => -e2.evaluate(t2)]] }, "/": [pt, [pt, pt], (t2, [e2, r2]) => e2.evaluate(t2) / r2.evaluate(t2)], "%": [pt, [pt, pt], (t2, [e2, r2]) => e2.evaluate(t2) % r2.evaluate(t2)], ln2: [pt, [], () => Math.LN2], pi: [pt, [], () => Math.PI], e: [pt, [], () => Math.E], "^": [pt, [pt, pt], (t2, [e2, r2]) => Math.pow(e2.evaluate(t2), r2.evaluate(t2))], sqrt: [pt, [pt], (t2, [e2]) => Math.sqrt(e2.evaluate(t2))], log10: [pt, [pt], (t2, [e2]) => Math.log(e2.evaluate(t2)) / Math.LN10], ln: [pt, [pt], (t2, [e2]) => Math.log(e2.evaluate(t2))], log2: [pt, [pt], (t2, [e2]) => Math.log(e2.evaluate(t2)) / Math.LN2], sin: [pt, [pt], (t2, [e2]) => Math.sin(e2.evaluate(t2))], cos: [pt, [pt], (t2, [e2]) => Math.cos(e2.evaluate(t2))], tan: [pt, [pt], (t2, [e2]) => Math.tan(e2.evaluate(t2))], asin: [pt, [pt], (t2, [e2]) => Math.asin(e2.evaluate(t2))], acos: [pt, [pt], (t2, [e2]) => Math.acos(e2.evaluate(t2))], atan: [pt, [pt], (t2, [e2]) => Math.atan(e2.evaluate(t2))], min: [pt, vr(pt), (t2, e2) => Math.min(...e2.map(((e3) => e3.evaluate(t2))))], max: [pt, vr(pt), (t2, e2) => Math.max(...e2.map(((e3) => e3.evaluate(t2))))], abs: [pt, [pt], (t2, [e2]) => Math.abs(e2.evaluate(t2))], round: [pt, [pt], (t2, [e2]) => {
const r2 = e2.evaluate(t2);
return r2 < 0 ? -Math.round(-r2) : Math.round(r2);
}], floor: [pt, [pt], (t2, [e2]) => Math.floor(e2.evaluate(t2))], ceil: [pt, [pt], (t2, [e2]) => Math.ceil(e2.evaluate(t2))], "filter-==": [dt, [ft, gt], (t2, [e2, r2]) => t2.properties()[e2.value] === r2.value], "filter-id-==": [dt, [gt], (t2, [e2]) => t2.id() === e2.value], "filter-type-==": [dt, [ft], (t2, [e2]) => t2.geometryType() === e2.value], "filter-<": [dt, [ft, gt], (t2, [e2, r2]) => {
const n2 = t2.properties()[e2.value], i3 = r2.value;
return typeof n2 == typeof i3 && n2 < i3;
}], "filter-id-<": [dt, [gt], (t2, [e2]) => {
const r2 = t2.id(), n2 = e2.value;
return typeof r2 == typeof n2 && r2 < n2;
}], "filter->": [dt, [ft, gt], (t2, [e2, r2]) => {
const n2 = t2.properties()[e2.value], i3 = r2.value;
return typeof n2 == typeof i3 && n2 > i3;
}], "filter-id->": [dt, [gt], (t2, [e2]) => {
const r2 = t2.id(), n2 = e2.value;
return typeof r2 == typeof n2 && r2 > n2;
}], "filter-<=": [dt, [ft, gt], (t2, [e2, r2]) => {
const n2 = t2.properties()[e2.value], i3 = r2.value;
return typeof n2 == typeof i3 && n2 <= i3;
}], "filter-id-<=": [dt, [gt], (t2, [e2]) => {
const r2 = t2.id(), n2 = e2.value;
return typeof r2 == typeof n2 && r2 <= n2;
}], "filter->=": [dt, [ft, gt], (t2, [e2, r2]) => {
const n2 = t2.properties()[e2.value], i3 = r2.value;
return typeof n2 == typeof i3 && n2 >= i3;
}], "filter-id->=": [dt, [gt], (t2, [e2]) => {
const r2 = t2.id(), n2 = e2.value;
return typeof r2 == typeof n2 && r2 >= n2;
}], "filter-has": [dt, [gt], (t2, [e2]) => e2.value in t2.properties()], "filter-has-id": [dt, [], (t2) => null !== t2.id() && void 0 !== t2.id()], "filter-type-in": [dt, [At(ft)], (t2, [e2]) => e2.value.indexOf(t2.geometryType()) >= 0], "filter-id-in": [dt, [At(gt)], (t2, [e2]) => e2.value.indexOf(t2.id()) >= 0], "filter-in-small": [dt, [ft, At(gt)], (t2, [e2, r2]) => r2.value.indexOf(t2.properties()[e2.value]) >= 0], "filter-in-large": [dt, [ft, At(gt)], (t2, [e2, r2]) => (function(t3, e3, r3, n2) {
for (; r3 <= n2; ) {
const i3 = r3 + n2 >> 1;
if (e3[i3] === t3) return true;
e3[i3] > t3 ? n2 = i3 - 1 : r3 = i3 + 1;
}
return false;
})(t2.properties()[e2.value], r2.value, 0, r2.value.length - 1)], all: { type: dt, overloads: [[[dt, dt], (t2, [e2, r2]) => e2.evaluate(t2) && r2.evaluate(t2)], [vr(dt), (t2, e2) => {
for (const r2 of e2) if (!r2.evaluate(t2)) return false;
return true;
}]] }, any: { type: dt, overloads: [[[dt, dt], (t2, [e2, r2]) => e2.evaluate(t2) || r2.evaluate(t2)], [vr(dt), (t2, e2) => {
for (const r2 of e2) if (r2.evaluate(t2)) return true;
return false;
}]] }, "!": [dt, [dt], (t2, [e2]) => !e2.evaluate(t2)], "is-supported-script": [dt, [ft], (t2, [e2]) => {
const r2 = t2.globals && t2.globals.isSupportedScript;
return !r2 || r2(e2.evaluate(t2));
}], upcase: [ft, [ft], (t2, [e2]) => e2.evaluate(t2).toUpperCase()], downcase: [ft, [ft], (t2, [e2]) => e2.evaluate(t2).toLowerCase()], concat: [ft, vr(gt), (t2, e2) => e2.map(((e3) => oe(e3.evaluate(t2)))).join("")], "resolved-locale": [ft, [xt], (t2, [e2]) => e2.evaluate(t2).resolvedLocale()] });
class Fr {
constructor(t2, e2) {
var r2;
this.expression = t2, this._warningHistory = {}, this._evaluator = new ye(), this._defaultValue = e2 ? "color" === (r2 = e2).type && Ir(r2.default) ? new Yt(0, 0, 0, 0) : "color" === r2.type ? Yt.parse(r2.default) || null : "padding" === r2.type ? te.parse(r2.default) || null : "variableAnchorOffsetCollection" === r2.type ? re.parse(r2.default) || null : void 0 === r2.default ? null : r2.default : null, this._enumValues = e2 && "enum" === e2.type ? e2.values : null;
}
evaluateWithoutErrorHandling(t2, e2, r2, n2, i3, a2) {
return this._evaluator.globals = t2, this._evaluator.feature = e2, this._evaluator.featureState = r2, this._evaluator.canonical = n2, this._evaluator.availableImages = i3 || null, this._evaluator.formattedSection = a2, this.expression.evaluate(this._evaluator);
}
evaluate(t2, e2, r2, n2, i3, a2) {
this._evaluator.globals = t2, this._evaluator.feature = e2 || null, this._evaluator.featureState = r2 || null, this._evaluator.canonical = n2, this._evaluator.availableImages = i3 || null, this._evaluator.formattedSection = a2 || null;
try {
const t3 = this.expression.evaluate(this._evaluator);
if (null == t3 || "number" == typeof t3 && t3 != t3) return this._defaultValue;
if (this._enumValues && !(t3 in this._enumValues)) throw new ue(`Expected value to be one of ${Object.keys(this._enumValues).map(((t4) => JSON.stringify(t4))).join(", ")}, but found ${JSON.stringify(t3)} instead.`);
return t3;
} catch (t3) {
return this._warningHistory[t3.message] || (this._warningHistory[t3.message] = true, "undefined" != typeof console && console.warn(t3.message)), this._defaultValue;
}
}
}
function Tr(t2) {
return Array.isArray(t2) && t2.length > 0 && "string" == typeof t2[0] && t2[0] in yr;
}
function $r(t2, e2) {
const r2 = new me(yr, Le, [], e2 ? (function(t3) {
const e3 = { color: yt, string: ft, number: pt, enum: ft, boolean: dt, formatted: vt, padding: bt, resolvedImage: wt, variableAnchorOffsetCollection: _t };
return "array" === t3.type ? At(e3[t3.value] || gt, t3.length) : e3[t3.type];
})(e2) : void 0), n2 = r2.parse(t2, void 0, void 0, void 0, e2 && "string" === e2.type ? { typeAnnotation: "coerce" } : void 0);
return n2 ? br(new Fr(n2, e2)) : wr(r2.errors);
}
class Lr {
constructor(t2, e2) {
this.kind = t2, this._styleExpression = e2, this.isStateDependent = "constant" !== t2 && !Oe(e2.expression);
}
evaluateWithoutErrorHandling(t2, e2, r2, n2, i3, a2) {
return this._styleExpression.evaluateWithoutErrorHandling(t2, e2, r2, n2, i3, a2);
}
evaluate(t2, e2, r2, n2, i3, a2) {
return this._styleExpression.evaluate(t2, e2, r2, n2, i3, a2);
}
}
class Dr {
constructor(t2, e2, r2, n2) {
this.kind = t2, this.zoomStops = r2, this._styleExpression = e2, this.isStateDependent = "camera" !== t2 && !Oe(e2.expression), this.interpolationType = n2;
}
evaluateWithoutErrorHandling(t2, e2, r2, n2, i3, a2) {
return this._styleExpression.evaluateWithoutErrorHandling(t2, e2, r2, n2, i3, a2);
}
evaluate(t2, e2, r2, n2, i3, a2) {
return this._styleExpression.evaluate(t2, e2, r2, n2, i3, a2);
}
interpolationFactor(t2, e2, r2) {
return this.interpolationType ? Ke.interpolationFactor(this.interpolationType, t2, e2, r2) : 0;
}
}
function Or(t2, e2) {
const r2 = $r(t2, e2);
if ("error" === r2.result) return r2;
const n2 = r2.value.expression, i3 = De(n2);
if (!i3 && !_r(e2)) return wr([new ut("", "data expressions not supported")]);
const a2 = Ue(n2, ["zoom"]);
if (!a2 && !Ar(e2)) return wr([new ut("", "zoom expressions not supported")]);
const s2 = Rr(n2);
return s2 || a2 ? s2 instanceof ut ? wr([s2]) : s2 instanceof Ke && !Sr(e2) ? wr([new ut("", '"interpolate" expressions cannot be used with this property')]) : br(s2 ? new Dr(i3 ? "camera" : "composite", r2.value, s2.labels, s2 instanceof Ke ? s2.interpolation : void 0) : new Lr(i3 ? "constant" : "source", r2.value)) : wr([new ut("", '"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.')]);
}
class Ur {
constructor(t2, e2) {
this._parameters = t2, this._specification = e2, lt(this, Mr(this._parameters, this._specification));
}
static deserialize(t2) {
return new Ur(t2._parameters, t2._specification);
}
static serialize(t2) {
return { _parameters: t2._parameters, _specification: t2._specification };
}
}
function Rr(t2) {
let e2 = null;
if (t2 instanceof Xe) e2 = Rr(t2.result);
else if (t2 instanceof Je) {
for (const r2 of t2.args) if (e2 = Rr(r2), e2) break;
} else (t2 instanceof qe || t2 instanceof Ke) && t2.input instanceof $e && "zoom" === t2.input.name && (e2 = t2);
return e2 instanceof ut || t2.eachChild(((t3) => {
const r2 = Rr(t3);
r2 instanceof ut ? e2 = r2 : !e2 && r2 ? e2 = new ut("", '"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.') : e2 && r2 && e2 !== r2 && (e2 = new ut("", 'Only one zoom-based "step" or "interpolate" subexpression may be used in an expression.'));
})), e2;
}
function qr(t2) {
if (true === t2 || false === t2) return true;
if (!Array.isArray(t2) || 0 === t2.length) return false;
switch (t2[0]) {
case "has":
return t2.length >= 2 && "$id" !== t2[1] && "$type" !== t2[1];
case "in":
return t2.length >= 3 && ("string" != typeof t2[1] || Array.isArray(t2[2]));
case "!in":
case "!has":
case "none":
return false;
case "==":
case "!=":
case ">":
case ">=":
case "<":
case "<=":
return 3 !== t2.length || Array.isArray(t2[1]) || Array.isArray(t2[2]);
case "any":
case "all":
for (const e2 of t2.slice(1)) if (!qr(e2) && "boolean" != typeof e2) return false;
return true;
default:
return true;
}
}
const jr = { type: "boolean", default: false, transition: false, "property-type": "data-driven", expression: { interpolated: false, parameters: ["zoom", "feature"] } };
function Nr(t2) {
if (null == t2) return { filter: () => true, needGeometry: false };
qr(t2) || (t2 = Gr(t2));
const e2 = $r(t2, jr);
if ("error" === e2.result) throw new Error(e2.value.map(((t3) => `${t3.key}: ${t3.message}`)).join(", "));
return { filter: (t3, r2, n2) => e2.value.evaluate(t3, r2, {}, n2), needGeometry: Kr(t2) };
}
function Zr(t2, e2) {
return t2 < e2 ? -1 : t2 > e2 ? 1 : 0;
}
function Kr(t2) {
if (!Array.isArray(t2)) return false;
if ("within" === t2[0]) return true;
for (let e2 = 1; e2 < t2.length; e2++) if (Kr(t2[e2])) return true;
return false;
}
function Gr(t2) {
if (!t2) return true;
const e2 = t2[0];
return t2.length <= 1 ? "any" !== e2 : "==" === e2 ? Jr(t2[1], t2[2], "==") : "!=" === e2 ? Hr(Jr(t2[1], t2[2], "==")) : "<" === e2 || ">" === e2 || "<=" === e2 || ">=" === e2 ? Jr(t2[1], t2[2], e2) : "any" === e2 ? (r2 = t2.slice(1), ["any"].concat(r2.map(Gr))) : "all" === e2 ? ["all"].concat(t2.slice(1).map(Gr)) : "none" === e2 ? ["all"].concat(t2.slice(1).map(Gr).map(Hr)) : "in" === e2 ? Xr(t2[1], t2.slice(2)) : "!in" === e2 ? Hr(Xr(t2[1], t2.slice(2))) : "has" === e2 ? Yr(t2[1]) : "!has" === e2 ? Hr(Yr(t2[1])) : "within" !== e2 || t2;
var r2;
}
function Jr(t2, e2, r2) {
switch (t2) {
case "$type":
return [`filter-type-${r2}`, e2];
case "$id":
return [`filter-id-${r2}`, e2];
default:
return [`filter-${r2}`, t2, e2];
}
}
function Xr(t2, e2) {
if (0 === e2.length) return false;
switch (t2) {
case "$type":
return ["filter-type-in", ["literal", e2]];
case "$id":
return ["filter-id-in", ["literal", e2]];
default:
return e2.length > 200 && !e2.some(((t3) => typeof t3 != typeof e2[0])) ? ["filter-in-large", t2, ["literal", e2.sort(Zr)]] : ["filter-in-small", t2, ["literal", e2]];
}
}
function Yr(t2) {
switch (t2) {
case "$type":
return true;
case "$id":
return ["filter-has-id"];
default:
return ["filter-has", t2];
}
}
function Hr(t2) {
return ["!", t2];
}
function Wr(t2) {
const e2 = typeof t2;
if ("number" === e2 || "boolean" === e2 || "string" === e2 || null == t2) return JSON.stringify(t2);
if (Array.isArray(t2)) {
let e3 = "[";
for (const r3 of t2) e3 += `${Wr(r3)},`;
return `${e3}]`;
}
const r2 = Object.keys(t2).sort();
let n2 = "{";
for (let e3 = 0; e3 < r2.length; e3++) n2 += `${JSON.stringify(r2[e3])}:${Wr(t2[r2[e3]])},`;
return `${n2}}`;
}
function Qr(t2) {
let e2 = "";
for (const r2 of Y) e2 += `/${Wr(t2[r2])}`;
return e2;
}
function tn(t2) {
const e2 = t2.value;
return e2 ? [new ot(t2.key, e2, "constants have been deprecated as of v8")] : [];
}
function en(t2) {
return t2 instanceof Number || t2 instanceof String || t2 instanceof Boolean ? t2.valueOf() : t2;
}
function rn(t2) {
if (Array.isArray(t2)) return t2.map(rn);
if (t2 instanceof Object && !(t2 instanceof Number || t2 instanceof String || t2 instanceof Boolean)) {
const e2 = {};
for (const r2 in t2) e2[r2] = rn(t2[r2]);
return e2;
}
return en(t2);
}
function nn(t2) {
const e2 = t2.key, r2 = t2.value, n2 = t2.valueSpec || {}, i3 = t2.objectElementValidators || {}, a2 = t2.style, s2 = t2.styleSpec, o2 = t2.validateSpec;
let l2 = [];
const u2 = kr(r2);
if ("object" !== u2) return [new ot(e2, r2, `object expected, ${u2} found`)];
for (const t3 in r2) {
const u3 = t3.split(".")[0], c2 = n2[u3] || n2["*"];
let h2;
if (i3[u3]) h2 = i3[u3];
else if (n2[u3]) h2 = o2;
else if (i3["*"]) h2 = i3["*"];
else {
if (!n2["*"]) {
l2.push(new ot(e2, r2[t3], `unknown property "${t3}"`));
continue;
}
h2 = o2;
}
l2 = l2.concat(h2({ key: (e2 ? `${e2}.` : e2) + t3, value: r2[t3], valueSpec: c2, style: a2, styleSpec: s2, object: r2, objectKey: t3, validateSpec: o2 }, r2));
}
for (const t3 in n2) i3[t3] || n2[t3].required && void 0 === n2[t3].default && void 0 === r2[t3] && l2.push(new ot(e2, r2, `missing required property "${t3}"`));
return l2;
}
function an(t2) {
const e2 = t2.value, r2 = t2.valueSpec, n2 = t2.style, i3 = t2.styleSpec, a2 = t2.key, s2 = t2.arrayElementValidator || t2.validateSpec;
if ("array" !== kr(e2)) return [new ot(a2, e2, `array expected, ${kr(e2)} found`)];
if (r2.length && e2.length !== r2.length) return [new ot(a2, e2, `array length ${r2.length} expected, length ${e2.length} found`)];
if (r2["min-length"] && e2.length < r2["min-length"]) return [new ot(a2, e2, `array length at least ${r2["min-length"]} expected, length ${e2.length} found`)];
let o2 = { type: r2.value, values: r2.values };
i3.$version < 7 && (o2.function = r2.function), "object" === kr(r2.value) && (o2 = r2.value);
let l2 = [];
for (let r3 = 0; r3 < e2.length; r3++) l2 = l2.concat(s2({ array: e2, arrayIndex: r3, value: e2[r3], valueSpec: o2, validateSpec: t2.validateSpec, style: n2, styleSpec: i3, key: `${a2}[${r3}]` }));
return l2;
}
function sn(t2) {
const e2 = t2.key, r2 = t2.value, n2 = t2.valueSpec;
let i3 = kr(r2);
return "number" === i3 && r2 != r2 && (i3 = "NaN"), "number" !== i3 ? [new ot(e2, r2, `number expected, ${i3} found`)] : "minimum" in n2 && r2 < n2.minimum ? [new ot(e2, r2, `${r2} is less than the minimum value ${n2.minimum}`)] : "maximum" in n2 && r2 > n2.maximum ? [new ot(e2, r2, `${r2} is greater than the maximum value ${n2.maximum}`)] : [];
}
function on(t2) {
const e2 = t2.valueSpec, r2 = en(t2.value.type);
let n2, i3, a2, s2 = {};
const o2 = "categorical" !== r2 && void 0 === t2.value.property, l2 = !o2, u2 = "array" === kr(t2.value.stops) && "array" === kr(t2.value.stops[0]) && "object" === kr(t2.value.stops[0][0]), c2 = nn({ key: t2.key, value: t2.value, valueSpec: t2.styleSpec.function, validateSpec: t2.validateSpec, style: t2.style, styleSpec: t2.styleSpec, objectElementValidators: { stops: function(t3) {
if ("identity" === r2) return [new ot(t3.key, t3.value, 'identity function may not have a "stops" property')];
let e3 = [];
const n3 = t3.value;
return e3 = e3.concat(an({ key: t3.key, value: n3, valueSpec: t3.valueSpec, validateSpec: t3.validateSpec, style: t3.style, styleSpec: t3.styleSpec, arrayElementValidator: h2 })), "array" === kr(n3) && 0 === n3.length && e3.push(new ot(t3.key, n3, "array must have at least one stop")), e3;
}, default: function(t3) {
return t3.validateSpec({ key: t3.key, value: t3.value, valueSpec: e2, validateSpec: t3.validateSpec, style: t3.style, styleSpec: t3.styleSpec });
} } });
return "identity" === r2 && o2 && c2.push(new ot(t2.key, t2.value, 'missing required property "property"')), "identity" === r2 || t2.value.stops || c2.push(new ot(t2.key, t2.value, 'missing required property "stops"')), "exponential" === r2 && t2.valueSpec.expression && !Sr(t2.valueSpec) && c2.push(new ot(t2.key, t2.value, "exponential functions not supported")), t2.styleSpec.$version >= 8 && (l2 && !_r(t2.valueSpec) ? c2.push(new ot(t2.key, t2.value, "property functions not supported")) : o2 && !Ar(t2.valueSpec) && c2.push(new ot(t2.key, t2.value, "zoom functions not supported"))), "categorical" !== r2 && !u2 || void 0 !== t2.value.property || c2.push(new ot(t2.key, t2.value, '"property" property is required')), c2;
function h2(t3) {
let r3 = [];
const n3 = t3.value, o3 = t3.key;
if ("array" !== kr(n3)) return [new ot(o3, n3, `array expected, ${kr(n3)} found`)];
if (2 !== n3.length) return [new ot(o3, n3, `array length 2 expected, length ${n3.length} found`)];
if (u2) {
if ("object" !== kr(n3[0])) return [new ot(o3, n3, `object expected, ${kr(n3[0])} found`)];
if (void 0 === n3[0].zoom) return [new ot(o3, n3, "object stop key must have zoom")];
if (void 0 === n3[0].value) return [new ot(o3, n3, "object stop key must have value")];
if (a2 && a2 > en(n3[0].zoom)) return [new ot(o3, n3[0].zoom, "stop zoom values must appear in ascending order")];
en(n3[0].zoom) !== a2 && (a2 = en(n3[0].zoom), i3 = void 0, s2 = {}), r3 = r3.concat(nn({ key: `${o3}[0]`, value: n3[0], valueSpec: { zoom: {} }, validateSpec: t3.validateSpec, style: t3.style, styleSpec: t3.styleSpec, objectElementValidators: { zoom: sn, value: p2 } }));
} else r3 = r3.concat(p2({ key: `${o3}[0]`, value: n3[0], validateSpec: t3.validateSpec, style: t3.style, styleSpec: t3.styleSpec }, n3));
return Tr(rn(n3[1])) ? r3.concat([new ot(`${o3}[1]`, n3[1], "expressions are not allowed in function stops.")]) : r3.concat(t3.validateSpec({ key: `${o3}[1]`, value: n3[1], valueSpec: e2, validateSpec: t3.validateSpec, style: t3.style, styleSpec: t3.styleSpec }));
}
function p2(t3, a3) {
const o3 = kr(t3.value), l3 = en(t3.value), u3 = null !== t3.value ? t3.value : a3;
if (n2) {
if (o3 !== n2) return [new ot(t3.key, u3, `${o3} stop domain type must match previous stop domain type ${n2}`)];
} else n2 = o3;
if ("number" !== o3 && "string" !== o3 && "boolean" !== o3) return [new ot(t3.key, u3, "stop domain value must be a number, string, or boolean")];
if ("number" !== o3 && "categorical" !== r2) {
let n3 = `number expected, ${o3} found`;
return _r(e2) && void 0 === r2 && (n3 += '\nIf you intended to use a categorical function, specify `"type": "categorical"`.'), [new ot(t3.key, u3, n3)];
}
return "categorical" !== r2 || "number" !== o3 || isFinite(l3) && Math.floor(l3) === l3 ? "categorical" !== r2 && "number" === o3 && void 0 !== i3 && l3 < i3 ? [new ot(t3.key, u3, "stop domain values must appear in ascending order")] : (i3 = l3, "categorical" === r2 && l3 in s2 ? [new ot(t3.key, u3, "stop domain values must be unique")] : (s2[l3] = true, [])) : [new ot(t3.key, u3, `integer expected, found ${l3}`)];
}
}
function ln(t2) {
const e2 = ("property" === t2.expressionContext ? Or : $r)(rn(t2.value), t2.valueSpec);
if ("error" === e2.result) return e2.value.map(((e3) => new ot(`${t2.key}${e3.key}`, t2.value, e3.message)));
const r2 = e2.value.expression || e2.value._styleExpression.expression;
if ("property" === t2.expressionContext && "text-font" === t2.propertyKey && !r2.outputDefined()) return [new ot(t2.key, t2.value, `Invalid data expression for "${t2.propertyKey}". Output values must be contained as literals within the expression.`)];
if ("property" === t2.expressionContext && "layout" === t2.propertyType && !Oe(r2)) return [new ot(t2.key, t2.value, '"feature-state" data expressions are not supported with layout properties.')];
if ("filter" === t2.expressionContext && !Oe(r2)) return [new ot(t2.key, t2.value, '"feature-state" data expressions are not supported with filters.')];
if (t2.expressionContext && 0 === t2.expressionContext.indexOf("cluster")) {
if (!Ue(r2, ["zoom", "feature-state"])) return [new ot(t2.key, t2.value, '"zoom" and "feature-state" expressions are not supported with cluster properties.')];
if ("cluster-initial" === t2.expressionContext && !De(r2)) return [new ot(t2.key, t2.value, "Feature data expressions are not supported with initial expression part of cluster properties.")];
}
return [];
}
function un(t2) {
const e2 = t2.key, r2 = t2.value, n2 = t2.valueSpec, i3 = [];
return Array.isArray(n2.values) ? -1 === n2.values.indexOf(en(r2)) && i3.push(new ot(e2, r2, `expected one of [${n2.values.join(", ")}], ${JSON.stringify(r2)} found`)) : -1 === Object.keys(n2.values).indexOf(en(r2)) && i3.push(new ot(e2, r2, `expected one of [${Object.keys(n2.values).join(", ")}], ${JSON.stringify(r2)} found`)), i3;
}
function cn(t2) {
return qr(rn(t2.value)) ? ln(lt({}, t2, { expressionContext: "filter", valueSpec: { value: "boolean" } })) : hn(t2);
}
function hn(t2) {
const e2 = t2.value, r2 = t2.key;
if ("array" !== kr(e2)) return [new ot(r2, e2, `array expected, ${kr(e2)} found`)];
const n2 = t2.styleSpec;
let i3, a2 = [];
if (e2.length < 1) return [new ot(r2, e2, "filter array must have at least 1 element")];
switch (a2 = a2.concat(un({ key: `${r2}[0]`, value: e2[0], valueSpec: n2.filter_operator, style: t2.style, styleSpec: t2.styleSpec })), en(e2[0])) {
case "<":
case "<=":
case ">":
case ">=":
e2.length >= 2 && "$type" === en(e2[1]) && a2.push(new ot(r2, e2, `"$type" cannot be use with operator "${e2[0]}"`));
case "==":
case "!=":
3 !== e2.length && a2.push(new ot(r2, e2, `filter array for operator "${e2[0]}" must have 3 elements`));
case "in":
case "!in":
e2.length >= 2 && (i3 = kr(e2[1]), "string" !== i3 && a2.push(new ot(`${r2}[1]`, e2[1], `string expected, ${i3} found`)));
for (let s2 = 2; s2 < e2.length; s2++) i3 = kr(e2[s2]), "$type" === en(e2[1]) ? a2 = a2.concat(un({ key: `${r2}[${s2}]`, value: e2[s2], valueSpec: n2.geometry_type, style: t2.style, styleSpec: t2.styleSpec })) : "string" !== i3 && "number" !== i3 && "boolean" !== i3 && a2.push(new ot(`${r2}[${s2}]`, e2[s2], `string, number, or boolean expected, ${i3} found`));
break;
case "any":
case "all":
case "none":
for (let n3 = 1; n3 < e2.length; n3++) a2 = a2.concat(hn({ key: `${r2}[${n3}]`, value: e2[n3], style: t2.style, styleSpec: t2.styleSpec }));
break;
case "has":
case "!has":
i3 = kr(e2[1]), 2 !== e2.length ? a2.push(new ot(r2, e2, `filter array for "${e2[0]}" operator must have 2 elements`)) : "string" !== i3 && a2.push(new ot(`${r2}[1]`, e2[1], `string expected, ${i3} found`));
break;
case "within":
i3 = kr(e2[1]), 2 !== e2.length ? a2.push(new ot(r2, e2, `filter array for "${e2[0]}" operator must have 2 elements`)) : "object" !== i3 && a2.push(new ot(`${r2}[1]`, e2[1], `object expected, ${i3} found`));
}
return a2;
}
function pn(t2, e2) {
const r2 = t2.key, n2 = t2.validateSpec, i3 = t2.style, a2 = t2.styleSpec, s2 = t2.value, o2 = t2.objectKey, l2 = a2[`${e2}_${t2.layerType}`];
if (!l2) return [];
const u2 = o2.match(/^(.*)-transition$/);
if ("paint" === e2 && u2 && l2[u2[1]] && l2[u2[1]].transition) return n2({ key: r2, value: s2, valueSpec: a2.transition, style: i3, styleSpec: a2 });
const c2 = t2.valueSpec || l2[o2];
if (!c2) return [new ot(r2, s2, `unknown property "${o2}"`)];
let h2;
if ("string" === kr(s2) && _r(c2) && !c2.tokens && (h2 = /^{([^}]+)}$/.exec(s2))) return [new ot(r2, s2, `"${o2}" does not support interpolation syntax
Use an identity property function instead: \`{ "type": "identity", "property": ${JSON.stringify(h2[1])} }\`.`)];
const p2 = [];
return "symbol" === t2.layerType && ("text-field" === o2 && i3 && !i3.glyphs && p2.push(new ot(r2, s2, 'use of "text-field" requires a style "glyphs" property')), "text-font" === o2 && Ir(rn(s2)) && "identity" === en(s2.type) && p2.push(new ot(r2, s2, '"text-font" does not support identity functions'))), p2.concat(n2({ key: t2.key, value: s2, valueSpec: c2, style: i3, styleSpec: a2, expressionContext: "property", propertyType: e2, propertyKey: o2 }));
}
function fn(t2) {
return pn(t2, "paint");
}
function dn(t2) {
return pn(t2, "layout");
}
function yn(t2) {
let e2 = [];
const r2 = t2.value, n2 = t2.key, i3 = t2.style, a2 = t2.styleSpec;
r2.type || r2.ref || e2.push(new ot(n2, r2, 'either "type" or "ref" is required'));
let s2 = en(r2.type);
const o2 = en(r2.ref);
if (r2.id) {
const a3 = en(r2.id);
for (let s3 = 0; s3 < t2.arrayIndex; s3++) {
const t3 = i3.layers[s3];
en(t3.id) === a3 && e2.push(new ot(n2, r2.id, `duplicate layer id "${r2.id}", previously used at line ${t3.id.__line__}`));
}
}
if ("ref" in r2) {
let t3;
["type", "source", "source-layer", "filter", "layout"].forEach(((t4) => {
t4 in r2 && e2.push(new ot(n2, r2[t4], `"${t4}" is prohibited for ref layers`));
})), i3.layers.forEach(((e3) => {
en(e3.id) === o2 && (t3 = e3);
})), t3 ? t3.ref ? e2.push(new ot(n2, r2.ref, "ref cannot reference another ref layer")) : s2 = en(t3.type) : e2.push(new ot(n2, r2.ref, `ref layer "${o2}" not found`));
} else if ("background" !== s2) if (r2.source) {
const t3 = i3.sources && i3.sources[r2.source], a3 = t3 && en(t3.type);
t3 ? "vector" === a3 && "raster" === s2 ? e2.push(new ot(n2, r2.source, `layer "${r2.id}" requires a raster source`)) : "raster-dem" !== a3 && "hillshade" === s2 ? e2.push(new ot(n2, r2.source, `layer "${r2.id}" requires a raster-dem source`)) : "raster" === a3 && "raster" !== s2 ? e2.push(new ot(n2, r2.source, `layer "${r2.id}" requires a vector source`)) : "vector" !== a3 || r2["source-layer"] ? "raster-dem" === a3 && "hillshade" !== s2 ? e2.push(new ot(n2, r2.source, "raster-dem source can only be used with layer type 'hillshade'.")) : "line" !== s2 || !r2.paint || !r2.paint["line-gradient"] || "geojson" === a3 && t3.lineMetrics || e2.push(new ot(n2, r2, `layer "${r2.id}" specifies a line-gradient, which requires a GeoJSON source with \`lineMetrics\` enabled.`)) : e2.push(new ot(n2, r2, `layer "${r2.id}" must specify a "source-layer"`)) : e2.push(new ot(n2, r2.source, `source "${r2.source}" not found`));
} else e2.push(new ot(n2, r2, 'missing required property "source"'));
return e2 = e2.concat(nn({ key: n2, value: r2, valueSpec: a2.layer, style: t2.style, styleSpec: t2.styleSpec, validateSpec: t2.validateSpec, objectElementValidators: { "*": () => [], type: () => t2.validateSpec({ key: `${n2}.type`, value: r2.type, valueSpec: a2.layer.type, style: t2.style, styleSpec: t2.styleSpec, validateSpec: t2.validateSpec, object: r2, objectKey: "type" }), filter: cn, layout: (t3) => nn({ layer: r2, key: t3.key, value: t3.value, style: t3.style, styleSpec: t3.styleSpec, validateSpec: t3.validateSpec, objectElementValidators: { "*": (t4) => dn(lt({ layerType: s2 }, t4)) } }), paint: (t3) => nn({ layer: r2, key: t3.key, value: t3.value, style: t3.style, styleSpec: t3.styleSpec, validateSpec: t3.validateSpec, objectElementValidators: { "*": (t4) => fn(lt({ layerType: s2 }, t4)) } }) } })), e2;
}
function mn(t2) {
const e2 = t2.value, r2 = t2.key, n2 = kr(e2);
return "string" !== n2 ? [new ot(r2, e2, `string expected, ${n2} found`)] : [];
}
const gn = { promoteId: function({ key: t2, value: e2 }) {
if ("string" === kr(e2)) return mn({ key: t2, value: e2 });
{
const r2 = [];
for (const n2 in e2) r2.push(...mn({ key: `${t2}.${n2}`, value: e2[n2] }));
return r2;
}
} };
function xn(t2) {
const e2 = t2.value, r2 = t2.key, n2 = t2.styleSpec, i3 = t2.style, a2 = t2.validateSpec;
if (!e2.type) return [new ot(r2, e2, '"type" is required')];
const s2 = en(e2.type);
let o2;
switch (s2) {
case "vector":
case "raster":
return o2 = nn({ key: r2, value: e2, valueSpec: n2[`source_${s2.replace("-", "_")}`], style: t2.style, styleSpec: n2, objectElementValidators: gn, validateSpec: a2 }), o2;
case "raster-dem":
return o2 = (function(t3) {
var e3;
const r3 = null !== (e3 = t3.sourceName) && void 0 !== e3 ? e3 : "", n3 = t3.value, i4 = t3.styleSpec, a3 = i4.source_raster_dem, s3 = t3.style;
let o3 = [];
const l2 = kr(n3);
if (void 0 === n3) return o3;
if ("object" !== l2) return o3.push(new ot("source_raster_dem", n3, `object expected, ${l2} found`)), o3;
const u2 = "custom" === en(n3.encoding), c2 = ["redFactor", "greenFactor", "blueFactor", "baseShift"], h2 = t3.value.encoding ? `"${t3.value.encoding}"` : "Default";
for (const e4 in n3) !u2 && c2.includes(e4) ? o3.push(new ot(e4, n3[e4], `In "${r3}": "${e4}" is only valid when "encoding" is set to "custom". ${h2} encoding found`)) : a3[e4] ? o3 = o3.concat(t3.validateSpec({ key: e4, value: n3[e4], valueSpec: a3[e4], validateSpec: t3.validateSpec, style: s3, styleSpec: i4 })) : o3.push(new ot(e4, n3[e4], `unknown property "${e4}"`));
return o3;
})({ sourceName: r2, value: e2, style: t2.style, styleSpec: n2, validateSpec: a2 }), o2;
case "geojson":
if (o2 = nn({ key: r2, value: e2, valueSpec: n2.source_geojson, style: i3, styleSpec: n2, validateSpec: a2, objectElementValidators: gn }), e2.cluster) for (const t3 in e2.clusterProperties) {
const [n3, i4] = e2.clusterProperties[t3], s3 = "string" == typeof n3 ? [n3, ["accumulated"], ["get", t3]] : n3;
o2.push(...ln({ key: `${r2}.${t3}.map`, value: i4, expressionContext: "cluster-map" })), o2.push(...ln({ key: `${r2}.${t3}.reduce`, value: s3, expressionContext: "cluster-reduce" }));
}
return o2;
case "video":
return nn({ key: r2, value: e2, valueSpec: n2.source_video, style: i3, validateSpec: a2, styleSpec: n2 });
case "image":
return nn({ key: r2, value: e2, valueSpec: n2.source_image, style: i3, validateSpec: a2, styleSpec: n2 });
case "canvas":
return [new ot(r2, null, "Please use runtime APIs to add canvas sources, rather than including them in stylesheets.", "source.canvas")];
default:
return un({ key: `${r2}.type`, value: e2.type, valueSpec: { values: ["vector", "raster", "raster-dem", "geojson", "video", "image"] } });
}
}
function vn(t2) {
const e2 = t2.value, r2 = t2.styleSpec, n2 = r2.light, i3 = t2.style;
let a2 = [];
const s2 = kr(e2);
if (void 0 === e2) return a2;
if ("object" !== s2) return a2 = a2.concat([new ot("light", e2, `object expected, ${s2} found`)]), a2;
for (const s3 in e2) {
const o2 = s3.match(/^(.*)-transition$/);
a2 = a2.concat(o2 && n2[o2[1]] && n2[o2[1]].transition ? t2.validateSpec({ key: s3, value: e2[s3], valueSpec: r2.transition, validateSpec: t2.validateSpec, style: i3, styleSpec: r2 }) : n2[s3] ? t2.validateSpec({ key: s3, value: e2[s3], valueSpec: n2[s3], validateSpec: t2.validateSpec, style: i3, styleSpec: r2 }) : [new ot(s3, e2[s3], `unknown property "${s3}"`)]);
}
return a2;
}
function bn(t2) {
const e2 = t2.value, r2 = t2.styleSpec, n2 = r2.terrain, i3 = t2.style;
let a2 = [];
const s2 = kr(e2);
if (void 0 === e2) return a2;
if ("object" !== s2) return a2 = a2.concat([new ot("terrain", e2, `object expected, ${s2} found`)]), a2;
for (const s3 in e2) a2 = a2.concat(n2[s3] ? t2.validateSpec({ key: s3, value: e2[s3], valueSpec: n2[s3], validateSpec: t2.validateSpec, style: i3, styleSpec: r2 }) : [new ot(s3, e2[s3], `unknown property "${s3}"`)]);
return a2;
}
function wn(t2) {
let e2 = [];
const r2 = t2.value, n2 = t2.key;
if (Array.isArray(r2)) {
const i3 = [], a2 = [];
for (const s2 in r2) r2[s2].id && i3.includes(r2[s2].id) && e2.push(new ot(n2, r2, `all the sprites' ids must be unique, but ${r2[s2].id} is duplicated`)), i3.push(r2[s2].id), r2[s2].url && a2.includes(r2[s2].url) && e2.push(new ot(n2, r2, `all the sprites' URLs must be unique, but ${r2[s2].url} is duplicated`)), a2.push(r2[s2].url), e2 = e2.concat(nn({ key: `${n2}[${s2}]`, value: r2[s2], valueSpec: { id: { type: "string", required: true }, url: { type: "string", required: true } }, validateSpec: t2.validateSpec }));
return e2;
}
return mn({ key: n2, value: r2 });
}
const _n = { "*": () => [], array: an, boolean: function(t2) {
const e2 = t2.value, r2 = t2.key, n2 = kr(e2);
return "boolean" !== n2 ? [new ot(r2, e2, `boolean expected, ${n2} found`)] : [];
}, number: sn, color: function(t2) {
const e2 = t2.key, r2 = t2.value, n2 = kr(r2);
return "string" !== n2 ? [new ot(e2, r2, `color expected, ${n2} found`)] : Yt.parse(String(r2)) ? [] : [new ot(e2, r2, `color expected, "${r2}" found`)];
}, constants: tn, enum: un, filter: cn, function: on, layer: yn, object: nn, source: xn, light: vn, terrain: bn, string: mn, formatted: function(t2) {
return 0 === mn(t2).length ? [] : ln(t2);
}, resolvedImage: function(t2) {
return 0 === mn(t2).length ? [] : ln(t2);
}, padding: function(t2) {
const e2 = t2.key, r2 = t2.value;
if ("array" === kr(r2)) {
if (r2.length < 1 || r2.length > 4) return [new ot(e2, r2, `padding requires 1 to 4 values; ${r2.length} values found`)];
const n2 = { type: "number" };
let i3 = [];
for (let a2 = 0; a2 < r2.length; a2++) i3 = i3.concat(t2.validateSpec({ key: `${e2}[${a2}]`, value: r2[a2], validateSpec: t2.validateSpec, valueSpec: n2 }));
return i3;
}
return sn({ key: e2, value: r2, valueSpec: {} });
}, variableAnchorOffsetCollection: function(t2) {
const e2 = t2.key, r2 = t2.value, n2 = kr(r2), i3 = t2.styleSpec;
if ("array" !== n2 || r2.length < 1 || r2.length % 2 != 0) return [new ot(e2, r2, "variableAnchorOffsetCollection requires a non-empty array of even length")];
let a2 = [];
for (let n3 = 0; n3 < r2.length; n3 += 2) a2 = a2.concat(un({ key: `${e2}[${n3}]`, value: r2[n3], valueSpec: i3.layout_symbol["text-anchor"] })), a2 = a2.concat(an({ key: `${e2}[${n3 + 1}]`, value: r2[n3 + 1], valueSpec: { length: 2, value: "number" }, validateSpec: t2.validateSpec, style: t2.style, styleSpec: i3 }));
return a2;
}, sprite: wn };
function An(t2) {
const e2 = t2.value, r2 = t2.valueSpec, n2 = t2.styleSpec;
return t2.validateSpec = An, r2.expression && Ir(en(e2)) ? on(t2) : r2.expression && Tr(rn(e2)) ? ln(t2) : r2.type && _n[r2.type] ? _n[r2.type](t2) : nn(lt({}, t2, { valueSpec: r2.type ? n2[r2.type] : r2 }));
}
function Sn(t2) {
const e2 = t2.value, r2 = t2.key, n2 = mn(t2);
return n2.length || (-1 === e2.indexOf("{fontstack}") && n2.push(new ot(r2, e2, '"glyphs" url must include a "{fontstack}" token')), -1 === e2.indexOf("{range}") && n2.push(new ot(r2, e2, '"glyphs" url must include a "{range}" token'))), n2;
}
function kn(t2, e2 = X) {
let r2 = [];
return r2 = r2.concat(An({ key: "", value: t2, valueSpec: e2.$root, styleSpec: e2, style: t2, validateSpec: An, objectElementValidators: { glyphs: Sn, "*": () => [] } })), t2.constants && (r2 = r2.concat(tn({ key: "constants", value: t2.constants }))), zn(r2);
}
function In(t2) {
return function(e2) {
return t2({ ...e2, validateSpec: An });
};
}
function zn(t2) {
return [].concat(t2).sort(((t3, e2) => t3.line - e2.line));
}
function Mn(t2) {
return function(...e2) {
return zn(t2.apply(this, e2));
};
}
kn.source = Mn(In(xn)), kn.sprite = Mn(In(wn)), kn.glyphs = Mn(In(Sn)), kn.light = Mn(In(vn)), kn.terrain = Mn(In(bn)), kn.layer = Mn(In(yn)), kn.filter = Mn(In(cn)), kn.paintProperty = Mn(In(fn)), kn.layoutProperty = Mn(In(dn));
const Cn = kn, Bn = Cn.light, Pn = Cn.paintProperty, Vn = Cn.layoutProperty;
function En(t2, e2) {
let r2 = false;
if (e2 && e2.length) for (const n2 of e2) t2.fire(new G(new Error(n2.message))), r2 = true;
return r2;
}
class Fn {
constructor(t2, e2, r2) {
const n2 = this.cells = [];
if (t2 instanceof ArrayBuffer) {
this.arrayBuffer = t2;
const i4 = new Int32Array(this.arrayBuffer);
t2 = i4[0], this.d = (e2 = i4[1]) + 2 * (r2 = i4[2]);
for (let t3 = 0; t3 < this.d * this.d; t3++) {
const e3 = i4[3 + t3], r3 = i4[3 + t3 + 1];
n2.push(e3 === r3 ? null : i4.subarray(e3, r3));
}
const a2 = i4[3 + n2.length + 1];
this.keys = i4.subarray(i4[3 + n2.length], a2), this.bboxes = i4.subarray(a2), this.insert = this._insertReadonly;
} else {
this.d = e2 + 2 * r2;
for (let t3 = 0; t3 < this.d * this.d; t3++) n2.push([]);
this.keys = [], this.bboxes = [];
}
this.n = e2, this.extent = t2, this.padding = r2, this.scale = e2 / t2, this.uid = 0;
const i3 = r2 / e2 * t2;
this.min = -i3, this.max = t2 + i3;
}
insert(t2, e2, r2, n2, i3) {
this._forEachCell(e2, r2, n2, i3, this._insertCell, this.uid++, void 0, void 0), this.keys.push(t2), this.bboxes.push(e2), this.bboxes.push(r2), this.bboxes.push(n2), this.bboxes.push(i3);
}
_insertReadonly() {
throw new Error("Cannot insert into a GridIndex created from an ArrayBuffer.");
}
_insertCell(t2, e2, r2, n2, i3, a2) {
this.cells[i3].push(a2);
}
query(t2, e2, r2, n2, i3) {
const a2 = this.min, s2 = this.max;
if (t2 <= a2 && e2 <= a2 && s2 <= r2 && s2 <= n2 && !i3) return Array.prototype.slice.call(this.keys);
{
const a3 = [];
return this._forEachCell(t2, e2, r2, n2, this._queryCell, a3, {}, i3), a3;
}
}
_queryCell(t2, e2, r2, n2, i3, a2, s2, o2) {
const l2 = this.cells[i3];
if (null !== l2) {
const i4 = this.keys, u2 = this.bboxes;
for (let c2 = 0; c2 < l2.length; c2++) {
const h2 = l2[c2];
if (void 0 === s2[h2]) {
const l3 = 4 * h2;
(o2 ? o2(u2[l3 + 0], u2[l3 + 1], u2[l3 + 2], u2[l3 + 3]) : t2 <= u2[l3 + 2] && e2 <= u2[l3 + 3] && r2 >= u2[l3 + 0] && n2 >= u2[l3 + 1]) ? (s2[h2] = true, a2.push(i4[h2])) : s2[h2] = false;
}
}
}
}
_forEachCell(t2, e2, r2, n2, i3, a2, s2, o2) {
const l2 = this._convertToCellCoord(t2), u2 = this._convertToCellCoord(e2), c2 = this._convertToCellCoord(r2), h2 = this._convertToCellCoord(n2);
for (let p2 = l2; p2 <= c2; p2++) for (let l3 = u2; l3 <= h2; l3++) {
const u3 = this.d * l3 + p2;
if ((!o2 || o2(this._convertFromCellCoord(p2), this._convertFromCellCoord(l3), this._convertFromCellCoord(p2 + 1), this._convertFromCellCoord(l3 + 1))) && i3.call(this, t2, e2, r2, n2, u3, a2, s2, o2)) return;
}
}
_convertFromCellCoord(t2) {
return (t2 - this.padding) / this.scale;
}
_convertToCellCoord(t2) {
return Math.max(0, Math.min(this.d - 1, Math.floor(t2 * this.scale) + this.padding));
}
toArrayBuffer() {
if (this.arrayBuffer) return this.arrayBuffer;
const t2 = this.cells, e2 = 3 + this.cells.length + 1 + 1;
let r2 = 0;
for (let t3 = 0; t3 < this.cells.length; t3++) r2 += this.cells[t3].length;
const n2 = new Int32Array(e2 + r2 + this.keys.length + this.bboxes.length);
n2[0] = this.extent, n2[1] = this.n, n2[2] = this.padding;
let i3 = e2;
for (let e3 = 0; e3 < t2.length; e3++) {
const r3 = t2[e3];
n2[3 + e3] = i3, n2.set(r3, i3), i3 += r3.length;
}
return n2[3 + t2.length] = i3, n2.set(this.keys, i3), i3 += this.keys.length, n2[3 + t2.length + 1] = i3, n2.set(this.bboxes, i3), i3 += this.bboxes.length, n2.buffer;
}
static serialize(t2, e2) {
const r2 = t2.toArrayBuffer();
return e2 && e2.push(r2), { buffer: r2 };
}
static deserialize(t2) {
return new Fn(t2.buffer);
}
}
const Tn = {};
function $n(t2, e2, r2 = {}) {
if (Tn[t2]) throw new Error(`${t2} is already registered.`);
Object.defineProperty(e2, "_classRegistryKey", { value: t2, writeable: false }), Tn[t2] = { klass: e2, omit: r2.omit || [], shallow: r2.shallow || [] };
}
$n("Object", Object), $n("TransferableGridIndex", Fn), $n("Color", Yt), $n("Error", Error), $n("AJAXError", L), $n("ResolvedImage", ne), $n("StylePropertyFunction", Ur), $n("StyleExpression", Fr, { omit: ["_evaluator"] }), $n("ZoomDependentExpression", Dr), $n("ZoomConstantExpression", Lr), $n("CompoundExpression", $e, { omit: ["_evaluate"] });
for (const t2 in yr) yr[t2]._classRegistryKey || $n(`Expression_${t2}`, yr[t2]);
function Ln(t2) {
return t2 && "undefined" != typeof ArrayBuffer && (t2 instanceof ArrayBuffer || t2.constructor && "ArrayBuffer" === t2.constructor.name);
}
function Dn(t2, e2) {
if (null == t2 || "boolean" == typeof t2 || "number" == typeof t2 || "string" == typeof t2 || t2 instanceof Boolean || t2 instanceof Number || t2 instanceof String || t2 instanceof Date || t2 instanceof RegExp || t2 instanceof Blob) return t2;
if (Ln(t2)) return e2 && e2.push(t2), t2;
if (M(t2)) return e2 && e2.push(t2), t2;
if (ArrayBuffer.isView(t2)) {
const r2 = t2;
return e2 && e2.push(r2.buffer), r2;
}
if (t2 instanceof ImageData) return e2 && e2.push(t2.data.buffer), t2;
if (Array.isArray(t2)) {
const r2 = [];
for (const n2 of t2) r2.push(Dn(n2, e2));
return r2;
}
if ("object" == typeof t2) {
const r2 = t2.constructor, n2 = r2._classRegistryKey;
if (!n2) throw new Error("can't serialize object of unregistered class");
if (!Tn[n2]) throw new Error(`${n2} is not registered.`);
const i3 = r2.serialize ? r2.serialize(t2, e2) : {};
if (r2.serialize) {
if (e2 && i3 === e2[e2.length - 1]) throw new Error("statically serialized object won't survive transfer of $name property");
} else {
for (const r3 in t2) {
if (!t2.hasOwnProperty(r3)) continue;
if (Tn[n2].omit.indexOf(r3) >= 0) continue;
const a2 = t2[r3];
i3[r3] = Tn[n2].shallow.indexOf(r3) >= 0 ? a2 : Dn(a2, e2);
}
t2 instanceof Error && (i3.message = t2.message);
}
if (i3.$name) throw new Error("$name property is reserved for worker serialization logic.");
return "Object" !== n2 && (i3.$name = n2), i3;
}
throw new Error("can't serialize object of type " + typeof t2);
}
function On(t2) {
if (null == t2 || "boolean" == typeof t2 || "number" == typeof t2 || "string" == typeof t2 || t2 instanceof Boolean || t2 instanceof Number || t2 instanceof String || t2 instanceof Date || t2 instanceof RegExp || t2 instanceof Blob || Ln(t2) || M(t2) || ArrayBuffer.isView(t2) || t2 instanceof ImageData) return t2;
if (Array.isArray(t2)) return t2.map(On);
if ("object" == typeof t2) {
const e2 = t2.$name || "Object";
if (!Tn[e2]) throw new Error(`can't deserialize unregistered class ${e2}`);
const { klass: r2 } = Tn[e2];
if (!r2) throw new Error(`can't deserialize unregistered class ${e2}`);
if (r2.deserialize) return r2.deserialize(t2);
const n2 = Object.create(r2.prototype);
for (const r3 of Object.keys(t2)) {
if ("$name" === r3) continue;
const i3 = t2[r3];
n2[r3] = Tn[e2].shallow.indexOf(r3) >= 0 ? i3 : On(i3);
}
return n2;
}
throw new Error("can't deserialize object of type " + typeof t2);
}
class Un {
constructor() {
this.first = true;
}
update(t2, e2) {
const r2 = Math.floor(t2);
return this.first ? (this.first = false, this.lastIntegerZoom = r2, this.lastIntegerZoomTime = 0, this.lastZoom = t2, this.lastFloorZoom = r2, true) : (this.lastFloorZoom > r2 ? (this.lastIntegerZoom = r2 + 1, this.lastIntegerZoomTime = e2) : this.lastFloorZoom < r2 && (this.lastIntegerZoom = r2, this.lastIntegerZoomTime = e2), t2 !== this.lastZoom && (this.lastZoom = t2, this.lastFloorZoom = r2, true));
}
}
const Rn = { "Latin-1 Supplement": (t2) => t2 >= 128 && t2 <= 255, Arabic: (t2) => t2 >= 1536 && t2 <= 1791, "Arabic Supplement": (t2) => t2 >= 1872 && t2 <= 1919, "Arabic Extended-A": (t2) => t2 >= 2208 && t2 <= 2303, "Hangul Jamo": (t2) => t2 >= 4352 && t2 <= 4607, "Unified Canadian Aboriginal Syllabics": (t2) => t2 >= 5120 && t2 <= 5759, Khmer: (t2) => t2 >= 6016 && t2 <= 6143, "Unified Canadian Aboriginal Syllabics Extended": (t2) => t2 >= 6320 && t2 <= 6399, "General Punctuation": (t2) => t2 >= 8192 && t2 <= 8303, "Letterlike Symbols": (t2) => t2 >= 8448 && t2 <= 8527, "Number Forms": (t2) => t2 >= 8528 && t2 <= 8591, "Miscellaneous Technical": (t2) => t2 >= 8960 && t2 <= 9215, "Control Pictures": (t2) => t2 >= 9216 && t2 <= 9279, "Optical Character Recognition": (t2) => t2 >= 9280 && t2 <= 9311, "Enclosed Alphanumerics": (t2) => t2 >= 9312 && t2 <= 9471, "Geometric Shapes": (t2) => t2 >= 9632 && t2 <= 9727, "Miscellaneous Symbols": (t2) => t2 >= 9728 && t2 <= 9983, "Miscellaneous Symbols and Arrows": (t2) => t2 >= 11008 && t2 <= 11263, "CJK Radicals Supplement": (t2) => t2 >= 11904 && t2 <= 12031, "Kangxi Radicals": (t2) => t2 >= 12032 && t2 <= 12255, "Ideographic Description Characters": (t2) => t2 >= 12272 && t2 <= 12287, "CJK Symbols and Punctuation": (t2) => t2 >= 12288 && t2 <= 12351, Hiragana: (t2) => t2 >= 12352 && t2 <= 12447, Katakana: (t2) => t2 >= 12448 && t2 <= 12543, Bopomofo: (t2) => t2 >= 12544 && t2 <= 12591, "Hangul Compatibility Jamo": (t2) => t2 >= 12592 && t2 <= 12687, Kanbun: (t2) => t2 >= 12688 && t2 <= 12703, "Bopomofo Extended": (t2) => t2 >= 12704 && t2 <= 12735, "CJK Strokes": (t2) => t2 >= 12736 && t2 <= 12783, "Katakana Phonetic Extensions": (t2) => t2 >= 12784 && t2 <= 12799, "Enclosed CJK Letters and Months": (t2) => t2 >= 12800 && t2 <= 13055, "CJK Compatibility": (t2) => t2 >= 13056 && t2 <= 13311, "CJK Unified Ideographs Extension A": (t2) => t2 >= 13312 && t2 <= 19903, "Yijing Hexagram Symbols": (t2) => t2 >= 19904 && t2 <= 19967, "CJK Unified Ideographs": (t2) => t2 >= 19968 && t2 <= 40959, "Yi Syllables": (t2) => t2 >= 40960 && t2 <= 42127, "Yi Radicals": (t2) => t2 >= 42128 && t2 <= 42191, "Hangul Jamo Extended-A": (t2) => t2 >= 43360 && t2 <= 43391, "Hangul Syllables": (t2) => t2 >= 44032 && t2 <= 55215, "Hangul Jamo Extended-B": (t2) => t2 >= 55216 && t2 <= 55295, "Private Use Area": (t2) => t2 >= 57344 && t2 <= 63743, "CJK Compatibility Ideographs": (t2) => t2 >= 63744 && t2 <= 64255, "Arabic Presentation Forms-A": (t2) => t2 >= 64336 && t2 <= 65023, "Vertical Forms": (t2) => t2 >= 65040 && t2 <= 65055, "CJK Compatibility Forms": (t2) => t2 >= 65072 && t2 <= 65103, "Small Form Variants": (t2) => t2 >= 65104 && t2 <= 65135, "Arabic Presentation Forms-B": (t2) => t2 >= 65136 && t2 <= 65279, "Halfwidth and Fullwidth Forms": (t2) => t2 >= 65280 && t2 <= 65519 };
function qn(t2) {
for (const e2 of t2) if (Zn(e2.charCodeAt(0))) return true;
return false;
}
function jn(t2) {
for (const e2 of t2) if (!Nn(e2.charCodeAt(0))) return false;
return true;
}
function Nn(t2) {
return !(Rn.Arabic(t2) || Rn["Arabic Supplement"](t2) || Rn["Arabic Extended-A"](t2) || Rn["Arabic Presentation Forms-A"](t2) || Rn["Arabic Presentation Forms-B"](t2));
}
function Zn(t2) {
return !(746 !== t2 && 747 !== t2 && (t2 < 4352 || !(Rn["Bopomofo Extended"](t2) || Rn.Bopomofo(t2) || Rn["CJK Compatibility Forms"](t2) && !(t2 >= 65097 && t2 <= 65103) || Rn["CJK Compatibility Ideographs"](t2) || Rn["CJK Compatibility"](t2) || Rn["CJK Radicals Supplement"](t2) || Rn["CJK Strokes"](t2) || !(!Rn["CJK Symbols and Punctuation"](t2) || t2 >= 12296 && t2 <= 12305 || t2 >= 12308 && t2 <= 12319 || 12336 === t2) || Rn["CJK Unified Ideographs Extension A"](t2) || Rn["CJK Unified Ideographs"](t2) || Rn["Enclosed CJK Letters and Months"](t2) || Rn["Hangul Compatibility Jamo"](t2) || Rn["Hangul Jamo Extended-A"](t2) || Rn["Hangul Jamo Extended-B"](t2) || Rn["Hangul Jamo"](t2) || Rn["Hangul Syllables"](t2) || Rn.Hiragana(t2) || Rn["Ideographic Description Characters"](t2) || Rn.Kanbun(t2) || Rn["Kangxi Radicals"](t2) || Rn["Katakana Phonetic Extensions"](t2) || Rn.Katakana(t2) && 12540 !== t2 || !(!Rn["Halfwidth and Fullwidth Forms"](t2) || 65288 === t2 || 65289 === t2 || 65293 === t2 || t2 >= 65306 && t2 <= 65310 || 65339 === t2 || 65341 === t2 || 65343 === t2 || t2 >= 65371 && t2 <= 65503 || 65507 === t2 || t2 >= 65512 && t2 <= 65519) || !(!Rn["Small Form Variants"](t2) || t2 >= 65112 && t2 <= 65118 || t2 >= 65123 && t2 <= 65126) || Rn["Unified Canadian Aboriginal Syllabics"](t2) || Rn["Unified Canadian Aboriginal Syllabics Extended"](t2) || Rn["Vertical Forms"](t2) || Rn["Yijing Hexagram Symbols"](t2) || Rn["Yi Syllables"](t2) || Rn["Yi Radicals"](t2))));
}
function Kn(t2) {
return !(Zn(t2) || (function(t3) {
return !!(Rn["Latin-1 Supplement"](t3) && (167 === t3 || 169 === t3 || 174 === t3 || 177 === t3 || 188 === t3 || 189 === t3 || 190 === t3 || 215 === t3 || 247 === t3) || Rn["General Punctuation"](t3) && (8214 === t3 || 8224 === t3 || 8225 === t3 || 8240 === t3 || 8241 === t3 || 8251 === t3 || 8252 === t3 || 8258 === t3 || 8263 === t3 || 8264 === t3 || 8265 === t3 || 8273 === t3) || Rn["Letterlike Symbols"](t3) || Rn["Number Forms"](t3) || Rn["Miscellaneous Technical"](t3) && (t3 >= 8960 && t3 <= 8967 || t3 >= 8972 && t3 <= 8991 || t3 >= 8996 && t3 <= 9e3 || 9003 === t3 || t3 >= 9085 && t3 <= 9114 || t3 >= 9150 && t3 <= 9165 || 9167 === t3 || t3 >= 9169 && t3 <= 9179 || t3 >= 9186 && t3 <= 9215) || Rn["Control Pictures"](t3) && 9251 !== t3 || Rn["Optical Character Recognition"](t3) || Rn["Enclosed Alphanumerics"](t3) || Rn["Geometric Shapes"](t3) || Rn["Miscellaneous Symbols"](t3) && !(t3 >= 9754 && t3 <= 9759) || Rn["Miscellaneous Symbols and Arrows"](t3) && (t3 >= 11026 && t3 <= 11055 || t3 >= 11088 && t3 <= 11097 || t3 >= 11192 && t3 <= 11243) || Rn["CJK Symbols and Punctuation"](t3) || Rn.Katakana(t3) || Rn["Private Use Area"](t3) || Rn["CJK Compatibility Forms"](t3) || Rn["Small Form Variants"](t3) || Rn["Halfwidth and Fullwidth Forms"](t3) || 8734 === t3 || 8756 === t3 || 8757 === t3 || t3 >= 9984 && t3 <= 10087 || t3 >= 10102 && t3 <= 10131 || 65532 === t3 || 65533 === t3);
})(t2));
}
function Gn(t2) {
return t2 >= 1424 && t2 <= 2303 || Rn["Arabic Presentation Forms-A"](t2) || Rn["Arabic Presentation Forms-B"](t2);
}
function Jn(t2, e2) {
return !(!e2 && Gn(t2) || t2 >= 2304 && t2 <= 3583 || t2 >= 3840 && t2 <= 4255 || Rn.Khmer(t2));
}
function Xn(t2) {
for (const e2 of t2) if (Gn(e2.charCodeAt(0))) return true;
return false;
}
const Yn = "deferred", Hn = "loading", Wn = "loaded";
let Qn = null, ti = "unavailable", ei = null;
const ri = function(t2) {
t2 && "string" == typeof t2 && t2.indexOf("NetworkError") > -1 && (ti = "error"), Qn && Qn(t2);
};
function ni() {
ii.fire(new K("pluginStateChange", { pluginStatus: ti, pluginURL: ei }));
}
const ii = new J(), ai = function() {
return ti;
}, si = function() {
if (ti !== Yn || !ei) throw new Error("rtl-text-plugin cannot be downloaded unless a pluginURL is specified");
ti = Hn, ni(), ei && q({ url: ei }, ((t2) => {
t2 ? ri(t2) : (ti = Wn, ni());
}));
}, oi = { applyArabicShaping: null, processBidirectionalText: null, processStyledBidirectionalText: null, isLoaded: () => ti === Wn || null != oi.applyArabicShaping, isLoading: () => ti === Hn, setState(t2) {
if (!I()) throw new Error("Cannot set the state of the rtl-text-plugin when not in the web-worker context");
ti = t2.pluginStatus, ei = t2.pluginURL;
}, isParsed() {
if (!I()) throw new Error("rtl-text-plugin is only parsed on the worker-threads");
return null != oi.applyArabicShaping && null != oi.processBidirectionalText && null != oi.processStyledBidirectionalText;
}, getPluginURL() {
if (!I()) throw new Error("rtl-text-plugin url can only be queried from the worker threads");
return ei;
} };
class li {
constructor(t2, e2) {
this.zoom = t2, e2 ? (this.now = e2.now, this.fadeDuration = e2.fadeDuration, this.zoomHistory = e2.zoomHistory, this.transition = e2.transition) : (this.now = 0, this.fadeDuration = 0, this.zoomHistory = new Un(), this.transition = {});
}
isSupportedScript(t2) {
return (function(t3, e2) {
for (const r2 of t3) if (!Jn(r2.charCodeAt(0), e2)) return false;
return true;
})(t2, oi.isLoaded());
}
crossFadingFactor() {
return 0 === this.fadeDuration ? 1 : Math.min((this.now - this.zoomHistory.lastIntegerZoomTime) / this.fadeDuration, 1);
}
getCrossfadeParameters() {
const t2 = this.zoom, e2 = t2 - Math.floor(t2), r2 = this.crossFadingFactor();
return t2 > this.zoomHistory.lastIntegerZoom ? { fromScale: 2, toScale: 1, t: e2 + (1 - e2) * r2 } : { fromScale: 0.5, toScale: 1, t: 1 - (1 - r2) * e2 };
}
}
class ui {
constructor(t2, e2) {
this.property = t2, this.value = e2, this.expression = (function(t3, e3) {
if (Ir(t3)) return new Ur(t3, e3);
if (Tr(t3)) {
const r2 = Or(t3, e3);
if ("error" === r2.result) throw new Error(r2.value.map(((t4) => `${t4.key}: ${t4.message}`)).join(", "));
return r2.value;
}
{
let r2 = t3;
return "color" === e3.type && "string" == typeof t3 ? r2 = Yt.parse(t3) : "padding" !== e3.type || "number" != typeof t3 && !Array.isArray(t3) ? "variableAnchorOffsetCollection" === e3.type && Array.isArray(t3) && (r2 = re.parse(t3)) : r2 = te.parse(t3), { kind: "constant", evaluate: () => r2 };
}
})(void 0 === e2 ? t2.specification.default : e2, t2.specification);
}
isDataDriven() {
return "source" === this.expression.kind || "composite" === this.expression.kind;
}
possiblyEvaluate(t2, e2, r2) {
return this.property.possiblyEvaluate(this, t2, e2, r2);
}
}
class ci {
constructor(t2) {
this.property = t2, this.value = new ui(t2, void 0);
}
transitioned(t2, e2) {
return new pi(this.property, this.value, e2, g({}, t2.transition, this.transition), t2.now);
}
untransitioned() {
return new pi(this.property, this.value, null, {}, 0);
}
}
class hi {
constructor(t2) {
this._properties = t2, this._values = Object.create(t2.defaultTransitionablePropertyValues);
}
getValue(t2) {
return w(this._values[t2].value.value);
}
setValue(t2, e2) {
Object.prototype.hasOwnProperty.call(this._values, t2) || (this._values[t2] = new ci(this._values[t2].property)), this._values[t2].value = new ui(this._values[t2].property, null === e2 ? void 0 : w(e2));
}
getTransition(t2) {
return w(this._values[t2].transition);
}
setTransition(t2, e2) {
Object.prototype.hasOwnProperty.call(this._values, t2) || (this._values[t2] = new ci(this._values[t2].property)), this._values[t2].transition = w(e2) || void 0;
}
serialize() {
const t2 = {};
for (const e2 of Object.keys(this._values)) {
const r2 = this.getValue(e2);
void 0 !== r2 && (t2[e2] = r2);
const n2 = this.getTransition(e2);
void 0 !== n2 && (t2[`${e2}-transition`] = n2);
}
return t2;
}
transitioned(t2, e2) {
const r2 = new fi(this._properties);
for (const n2 of Object.keys(this._values)) r2._values[n2] = this._values[n2].transitioned(t2, e2._values[n2]);
return r2;
}
untransitioned() {
const t2 = new fi(this._properties);
for (const e2 of Object.keys(this._values)) t2._values[e2] = this._values[e2].untransitioned();
return t2;
}
}
class pi {
constructor(t2, e2, r2, n2, i3) {
this.property = t2, this.value = e2, this.begin = i3 + n2.delay || 0, this.end = this.begin + n2.duration || 0, t2.specification.transition && (n2.delay || n2.duration) && (this.prior = r2);
}
possiblyEvaluate(t2, e2, r2) {
const n2 = t2.now || 0, i3 = this.value.possiblyEvaluate(t2, e2, r2), a2 = this.prior;
if (a2) {
if (n2 > this.end) return this.prior = null, i3;
if (this.value.isDataDriven()) return this.prior = null, i3;
if (n2 < this.begin) return a2.possiblyEvaluate(t2, e2, r2);
{
const s2 = (n2 - this.begin) / (this.end - this.begin);
return this.property.interpolate(a2.possiblyEvaluate(t2, e2, r2), i3, (function(t3) {
if (t3 <= 0) return 0;
if (t3 >= 1) return 1;
const e3 = t3 * t3, r3 = e3 * t3;
return 4 * (t3 < 0.5 ? r3 : 3 * (t3 - e3) + r3 - 0.75);
})(s2));
}
}
return i3;
}
}
class fi {
constructor(t2) {
this._properties = t2, this._values = Object.create(t2.defaultTransitioningPropertyValues);
}
possiblyEvaluate(t2, e2, r2) {
const n2 = new mi(this._properties);
for (const i3 of Object.keys(this._values)) n2._values[i3] = this._values[i3].possiblyEvaluate(t2, e2, r2);
return n2;
}
hasTransition() {
for (const t2 of Object.keys(this._values)) if (this._values[t2].prior) return true;
return false;
}
}
class di {
constructor(t2) {
this._properties = t2, this._values = Object.create(t2.defaultPropertyValues);
}
hasValue(t2) {
return void 0 !== this._values[t2].value;
}
getValue(t2) {
return w(this._values[t2].value);
}
setValue(t2, e2) {
this._values[t2] = new ui(this._values[t2].property, null === e2 ? void 0 : w(e2));
}
serialize() {
const t2 = {};
for (const e2 of Object.keys(this._values)) {
const r2 = this.getValue(e2);
void 0 !== r2 && (t2[e2] = r2);
}
return t2;
}
possiblyEvaluate(t2, e2, r2) {
const n2 = new mi(this._properties);
for (const i3 of Object.keys(this._values)) n2._values[i3] = this._values[i3].possiblyEvaluate(t2, e2, r2);
return n2;
}
}
class yi {
constructor(t2, e2, r2) {
this.property = t2, this.value = e2, this.parameters = r2;
}
isConstant() {
return "constant" === this.value.kind;
}
constantOr(t2) {
return "constant" === this.value.kind ? this.value.value : t2;
}
evaluate(t2, e2, r2, n2) {
return this.property.evaluate(this.value, this.parameters, t2, e2, r2, n2);
}
}
class mi {
constructor(t2) {
this._properties = t2, this._values = Object.create(t2.defaultPossiblyEvaluatedValues);
}
get(t2) {
return this._values[t2];
}
}
class gi {
constructor(t2) {
this.specification = t2;
}
possiblyEvaluate(t2, e2) {
if (t2.isDataDriven()) throw new Error("Value should not be data driven");
return t2.expression.evaluate(e2);
}
interpolate(t2, e2, r2) {
const n2 = Ze[this.specification.type];
return n2 ? n2(t2, e2, r2) : t2;
}
}
class xi {
constructor(t2, e2) {
this.specification = t2, this.overrides = e2;
}
possiblyEvaluate(t2, e2, r2, n2) {
return new yi(this, "constant" === t2.expression.kind || "camera" === t2.expression.kind ? { kind: "constant", value: t2.expression.evaluate(e2, null, {}, r2, n2) } : t2.expression, e2);
}
interpolate(t2, e2, r2) {
if ("constant" !== t2.value.kind || "constant" !== e2.value.kind) return t2;
if (void 0 === t2.value.value || void 0 === e2.value.value) return new yi(this, { kind: "constant", value: void 0 }, t2.parameters);
const n2 = Ze[this.specification.type];
if (n2) {
const i3 = n2(t2.value.value, e2.value.value, r2);
return new yi(this, { kind: "constant", value: i3 }, t2.parameters);
}
return t2;
}
evaluate(t2, e2, r2, n2, i3, a2) {
return "constant" === t2.kind ? t2.value : t2.evaluate(e2, r2, n2, i3, a2);
}
}
class vi extends xi {
possiblyEvaluate(t2, e2, r2, n2) {
if (void 0 === t2.value) return new yi(this, { kind: "constant", value: void 0 }, e2);
if ("constant" === t2.expression.kind) {
const i3 = t2.expression.evaluate(e2, null, {}, r2, n2), a2 = "resolvedImage" === t2.property.specification.type && "string" != typeof i3 ? i3.name : i3, s2 = this._calculate(a2, a2, a2, e2);
return new yi(this, { kind: "constant", value: s2 }, e2);
}
if ("camera" === t2.expression.kind) {
const r3 = this._calculate(t2.expression.evaluate({ zoom: e2.zoom - 1 }), t2.expression.evaluate({ zoom: e2.zoom }), t2.expression.evaluate({ zoom: e2.zoom + 1 }), e2);
return new yi(this, { kind: "constant", value: r3 }, e2);
}
return new yi(this, t2.expression, e2);
}
evaluate(t2, e2, r2, n2, i3, a2) {
if ("source" === t2.kind) {
const s2 = t2.evaluate(e2, r2, n2, i3, a2);
return this._calculate(s2, s2, s2, e2);
}
return "composite" === t2.kind ? this._calculate(t2.evaluate({ zoom: Math.floor(e2.zoom) - 1 }, r2, n2), t2.evaluate({ zoom: Math.floor(e2.zoom) }, r2, n2), t2.evaluate({ zoom: Math.floor(e2.zoom) + 1 }, r2, n2), e2) : t2.value;
}
_calculate(t2, e2, r2, n2) {
return n2.zoom > n2.zoomHistory.lastIntegerZoom ? { from: t2, to: e2 } : { from: r2, to: e2 };
}
interpolate(t2) {
return t2;
}
}
class bi {
constructor(t2) {
this.specification = t2;
}
possiblyEvaluate(t2, e2, r2, n2) {
if (void 0 !== t2.value) {
if ("constant" === t2.expression.kind) {
const i3 = t2.expression.evaluate(e2, null, {}, r2, n2);
return this._calculate(i3, i3, i3, e2);
}
return this._calculate(t2.expression.evaluate(new li(Math.floor(e2.zoom - 1), e2)), t2.expression.evaluate(new li(Math.floor(e2.zoom), e2)), t2.expression.evaluate(new li(Math.floor(e2.zoom + 1), e2)), e2);
}
}
_calculate(t2, e2, r2, n2) {
return n2.zoom > n2.zoomHistory.lastIntegerZoom ? { from: t2, to: e2 } : { from: r2, to: e2 };
}
interpolate(t2) {
return t2;
}
}
class wi {
constructor(t2) {
this.specification = t2;
}
possiblyEvaluate(t2, e2, r2, n2) {
return !!t2.expression.evaluate(e2, null, {}, r2, n2);
}
interpolate() {
return false;
}
}
class _i {
constructor(t2) {
this.properties = t2, this.defaultPropertyValues = {}, this.defaultTransitionablePropertyValues = {}, this.defaultTransitioningPropertyValues = {}, this.defaultPossiblyEvaluatedValues = {}, this.overridableProperties = [];
for (const e2 in t2) {
const r2 = t2[e2];
r2.specification.overridable && this.overridableProperties.push(e2);
const n2 = this.defaultPropertyValues[e2] = new ui(r2, void 0), i3 = this.defaultTransitionablePropertyValues[e2] = new ci(r2);
this.defaultTransitioningPropertyValues[e2] = i3.untransitioned(), this.defaultPossiblyEvaluatedValues[e2] = n2.possiblyEvaluate({});
}
}
}
$n("DataDrivenProperty", xi), $n("DataConstantProperty", gi), $n("CrossFadedDataDrivenProperty", vi), $n("CrossFadedProperty", bi), $n("ColorRampProperty", wi);
const Ai = "-transition";
class Si extends J {
constructor(t2, e2) {
if (super(), this.id = t2.id, this.type = t2.type, this._featureFilter = { filter: () => true, needGeometry: false }, "custom" !== t2.type && (this.metadata = t2.metadata, this.minzoom = t2.minzoom, this.maxzoom = t2.maxzoom, "background" !== t2.type && (this.source = t2.source, this.sourceLayer = t2["source-layer"], this.filter = t2.filter), e2.layout && (this._unevaluatedLayout = new di(e2.layout)), e2.paint)) {
this._transitionablePaint = new hi(e2.paint);
for (const e3 in t2.paint) this.setPaintProperty(e3, t2.paint[e3], { validate: false });
for (const e3 in t2.layout) this.setLayoutProperty(e3, t2.layout[e3], { validate: false });
this._transitioningPaint = this._transitionablePaint.untransitioned(), this.paint = new mi(e2.paint);
}
}
getCrossfadeParameters() {
return this._crossfadeParameters;
}
getLayoutProperty(t2) {
return "visibility" === t2 ? this.visibility : this._unevaluatedLayout.getValue(t2);
}
setLayoutProperty(t2, e2, r2 = {}) {
null != e2 && this._validate(Vn, `layers.${this.id}.layout.${t2}`, t2, e2, r2) || ("visibility" !== t2 ? this._unevaluatedLayout.setValue(t2, e2) : this.visibility = e2);
}
getPaintProperty(t2) {
return t2.endsWith(Ai) ? this._transitionablePaint.getTransition(t2.slice(0, -11)) : this._transitionablePaint.getValue(t2);
}
setPaintProperty(t2, e2, r2 = {}) {
if (null != e2 && this._validate(Pn, `layers.${this.id}.paint.${t2}`, t2, e2, r2)) return false;
if (t2.endsWith(Ai)) return this._transitionablePaint.setTransition(t2.slice(0, -11), e2 || void 0), false;
{
const r3 = this._transitionablePaint._values[t2], n2 = "cross-faded-data-driven" === r3.property.specification["property-type"], i3 = r3.value.isDataDriven(), a2 = r3.value;
this._transitionablePaint.setValue(t2, e2), this._handleSpecialPaintPropertyUpdate(t2);
const s2 = this._transitionablePaint._values[t2].value;
return s2.isDataDriven() || i3 || n2 || this._handleOverridablePaintPropertyUpdate(t2, a2, s2);
}
}
_handleSpecialPaintPropertyUpdate(t2) {
}
_handleOverridablePaintPropertyUpdate(t2, e2, r2) {
return false;
}
isHidden(t2) {
return !!(this.minzoom && t2 < this.minzoom) || !!(this.maxzoom && t2 >= this.maxzoom) || "none" === this.visibility;
}
updateTransitions(t2) {
this._transitioningPaint = this._transitionablePaint.transitioned(t2, this._transitioningPaint);
}
hasTransition() {
return this._transitioningPaint.hasTransition();
}
recalculate(t2, e2) {
t2.getCrossfadeParameters && (this._crossfadeParameters = t2.getCrossfadeParameters()), this._unevaluatedLayout && (this.layout = this._unevaluatedLayout.possiblyEvaluate(t2, void 0, e2)), this.paint = this._transitioningPaint.possiblyEvaluate(t2, void 0, e2);
}
serialize() {
const t2 = { id: this.id, type: this.type, source: this.source, "source-layer": this.sourceLayer, metadata: this.metadata, minzoom: this.minzoom, maxzoom: this.maxzoom, filter: this.filter, layout: this._unevaluatedLayout && this._unevaluatedLayout.serialize(), paint: this._transitionablePaint && this._transitionablePaint.serialize() };
return this.visibility && (t2.layout = t2.layout || {}, t2.layout.visibility = this.visibility), b(t2, ((t3, e2) => !(void 0 === t3 || "layout" === e2 && !Object.keys(t3).length || "paint" === e2 && !Object.keys(t3).length)));
}
_validate(t2, e2, r2, n2, i3 = {}) {
return (!i3 || false !== i3.validate) && En(this, t2.call(Cn, { key: e2, layerType: this.type, objectKey: r2, value: n2, styleSpec: X, style: { glyphs: true, sprite: true } }));
}
is3D() {
return false;
}
isTileClipped() {
return false;
}
hasOffscreenPass() {
return false;
}
resize() {
}
isStateDependent() {
for (const t2 in this.paint._values) {
const e2 = this.paint.get(t2);
if (e2 instanceof yi && _r(e2.property.specification) && ("source" === e2.value.kind || "composite" === e2.value.kind) && e2.value.isStateDependent) return true;
}
return false;
}
}
const ki = { Int8: Int8Array, Uint8: Uint8Array, Int16: Int16Array, Uint16: Uint16Array, Int32: Int32Array, Uint32: Uint32Array, Float32: Float32Array };
class Ii {
constructor(t2, e2) {
this._structArray = t2, this._pos1 = e2 * this.size, this._pos2 = this._pos1 / 2, this._pos4 = this._pos1 / 4, this._pos8 = this._pos1 / 8;
}
}
class zi {
constructor() {
this.isTransferred = false, this.capacity = -1, this.resize(0);
}
static serialize(t2, e2) {
return t2._trim(), e2 && (t2.isTransferred = true, e2.push(t2.arrayBuffer)), { length: t2.length, arrayBuffer: t2.arrayBuffer };
}
static deserialize(t2) {
const e2 = Object.create(this.prototype);
return e2.arrayBuffer = t2.arrayBuffer, e2.length = t2.length, e2.capacity = t2.arrayBuffer.byteLength / e2.bytesPerElement, e2._refreshViews(), e2;
}
_trim() {
this.length !== this.capacity && (this.capacity = this.length, this.arrayBuffer = this.arrayBuffer.slice(0, this.length * this.bytesPerElement), this._refreshViews());
}
clear() {
this.length = 0;
}
resize(t2) {
this.reserve(t2), this.length = t2;
}
reserve(t2) {
if (t2 > this.capacity) {
this.capacity = Math.max(t2, Math.floor(5 * this.capacity), 128), this.arrayBuffer = new ArrayBuffer(this.capacity * this.bytesPerElement);
const e2 = this.uint8;
this._refreshViews(), e2 && this.uint8.set(e2);
}
}
_refreshViews() {
throw new Error("_refreshViews() must be implemented by each concrete StructArray layout");
}
}
function Mi(t2, e2 = 1) {
let r2 = 0, n2 = 0;
return { members: t2.map(((t3) => {
const i3 = ki[t3.type].BYTES_PER_ELEMENT, a2 = r2 = Ci(r2, Math.max(e2, i3)), s2 = t3.components || 1;
return n2 = Math.max(n2, i3), r2 += i3 * s2, { name: t3.name, type: t3.type, components: s2, offset: a2 };
})), size: Ci(r2, Math.max(n2, e2)), alignment: e2 };
}
function Ci(t2, e2) {
return Math.ceil(t2 / e2) * e2;
}
class Bi extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer);
}
emplaceBack(t2, e2) {
const r2 = this.length;
return this.resize(r2 + 1), this.emplace(r2, t2, e2);
}
emplace(t2, e2, r2) {
const n2 = 2 * t2;
return this.int16[n2 + 0] = e2, this.int16[n2 + 1] = r2, t2;
}
}
Bi.prototype.bytesPerElement = 4, $n("StructArrayLayout2i4", Bi);
class Pi extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2) {
const n2 = this.length;
return this.resize(n2 + 1), this.emplace(n2, t2, e2, r2);
}
emplace(t2, e2, r2, n2) {
const i3 = 3 * t2;
return this.int16[i3 + 0] = e2, this.int16[i3 + 1] = r2, this.int16[i3 + 2] = n2, t2;
}
}
Pi.prototype.bytesPerElement = 6, $n("StructArrayLayout3i6", Pi);
class Vi extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2, n2) {
const i3 = this.length;
return this.resize(i3 + 1), this.emplace(i3, t2, e2, r2, n2);
}
emplace(t2, e2, r2, n2, i3) {
const a2 = 4 * t2;
return this.int16[a2 + 0] = e2, this.int16[a2 + 1] = r2, this.int16[a2 + 2] = n2, this.int16[a2 + 3] = i3, t2;
}
}
Vi.prototype.bytesPerElement = 8, $n("StructArrayLayout4i8", Vi);
class Ei extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2, n2, i3, a2) {
const s2 = this.length;
return this.resize(s2 + 1), this.emplace(s2, t2, e2, r2, n2, i3, a2);
}
emplace(t2, e2, r2, n2, i3, a2, s2) {
const o2 = 6 * t2;
return this.int16[o2 + 0] = e2, this.int16[o2 + 1] = r2, this.int16[o2 + 2] = n2, this.int16[o2 + 3] = i3, this.int16[o2 + 4] = a2, this.int16[o2 + 5] = s2, t2;
}
}
Ei.prototype.bytesPerElement = 12, $n("StructArrayLayout2i4i12", Ei);
class Fi extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2, n2, i3, a2) {
const s2 = this.length;
return this.resize(s2 + 1), this.emplace(s2, t2, e2, r2, n2, i3, a2);
}
emplace(t2, e2, r2, n2, i3, a2, s2) {
const o2 = 4 * t2, l2 = 8 * t2;
return this.int16[o2 + 0] = e2, this.int16[o2 + 1] = r2, this.uint8[l2 + 4] = n2, this.uint8[l2 + 5] = i3, this.uint8[l2 + 6] = a2, this.uint8[l2 + 7] = s2, t2;
}
}
Fi.prototype.bytesPerElement = 8, $n("StructArrayLayout2i4ub8", Fi);
class Ti extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer);
}
emplaceBack(t2, e2) {
const r2 = this.length;
return this.resize(r2 + 1), this.emplace(r2, t2, e2);
}
emplace(t2, e2, r2) {
const n2 = 2 * t2;
return this.float32[n2 + 0] = e2, this.float32[n2 + 1] = r2, t2;
}
}
Ti.prototype.bytesPerElement = 8, $n("StructArrayLayout2f8", Ti);
class $i extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2, n2, i3, a2, s2, o2, l2, u2) {
const c2 = this.length;
return this.resize(c2 + 1), this.emplace(c2, t2, e2, r2, n2, i3, a2, s2, o2, l2, u2);
}
emplace(t2, e2, r2, n2, i3, a2, s2, o2, l2, u2, c2) {
const h2 = 10 * t2;
return this.uint16[h2 + 0] = e2, this.uint16[h2 + 1] = r2, this.uint16[h2 + 2] = n2, this.uint16[h2 + 3] = i3, this.uint16[h2 + 4] = a2, this.uint16[h2 + 5] = s2, this.uint16[h2 + 6] = o2, this.uint16[h2 + 7] = l2, this.uint16[h2 + 8] = u2, this.uint16[h2 + 9] = c2, t2;
}
}
$i.prototype.bytesPerElement = 20, $n("StructArrayLayout10ui20", $i);
class Li extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2, n2, i3, a2, s2, o2, l2, u2, c2, h2) {
const p2 = this.length;
return this.resize(p2 + 1), this.emplace(p2, t2, e2, r2, n2, i3, a2, s2, o2, l2, u2, c2, h2);
}
emplace(t2, e2, r2, n2, i3, a2, s2, o2, l2, u2, c2, h2, p2) {
const f2 = 12 * t2;
return this.int16[f2 + 0] = e2, this.int16[f2 + 1] = r2, this.int16[f2 + 2] = n2, this.int16[f2 + 3] = i3, this.uint16[f2 + 4] = a2, this.uint16[f2 + 5] = s2, this.uint16[f2 + 6] = o2, this.uint16[f2 + 7] = l2, this.int16[f2 + 8] = u2, this.int16[f2 + 9] = c2, this.int16[f2 + 10] = h2, this.int16[f2 + 11] = p2, t2;
}
}
Li.prototype.bytesPerElement = 24, $n("StructArrayLayout4i4ui4i24", Li);
class Di extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2) {
const n2 = this.length;
return this.resize(n2 + 1), this.emplace(n2, t2, e2, r2);
}
emplace(t2, e2, r2, n2) {
const i3 = 3 * t2;
return this.float32[i3 + 0] = e2, this.float32[i3 + 1] = r2, this.float32[i3 + 2] = n2, t2;
}
}
Di.prototype.bytesPerElement = 12, $n("StructArrayLayout3f12", Di);
class Oi extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.uint32 = new Uint32Array(this.arrayBuffer);
}
emplaceBack(t2) {
const e2 = this.length;
return this.resize(e2 + 1), this.emplace(e2, t2);
}
emplace(t2, e2) {
return this.uint32[1 * t2 + 0] = e2, t2;
}
}
Oi.prototype.bytesPerElement = 4, $n("StructArrayLayout1ul4", Oi);
class Ui extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer), this.uint32 = new Uint32Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2, n2, i3, a2, s2, o2, l2) {
const u2 = this.length;
return this.resize(u2 + 1), this.emplace(u2, t2, e2, r2, n2, i3, a2, s2, o2, l2);
}
emplace(t2, e2, r2, n2, i3, a2, s2, o2, l2, u2) {
const c2 = 10 * t2, h2 = 5 * t2;
return this.int16[c2 + 0] = e2, this.int16[c2 + 1] = r2, this.int16[c2 + 2] = n2, this.int16[c2 + 3] = i3, this.int16[c2 + 4] = a2, this.int16[c2 + 5] = s2, this.uint32[h2 + 3] = o2, this.uint16[c2 + 8] = l2, this.uint16[c2 + 9] = u2, t2;
}
}
Ui.prototype.bytesPerElement = 20, $n("StructArrayLayout6i1ul2ui20", Ui);
class Ri extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2, n2, i3, a2) {
const s2 = this.length;
return this.resize(s2 + 1), this.emplace(s2, t2, e2, r2, n2, i3, a2);
}
emplace(t2, e2, r2, n2, i3, a2, s2) {
const o2 = 6 * t2;
return this.int16[o2 + 0] = e2, this.int16[o2 + 1] = r2, this.int16[o2 + 2] = n2, this.int16[o2 + 3] = i3, this.int16[o2 + 4] = a2, this.int16[o2 + 5] = s2, t2;
}
}
Ri.prototype.bytesPerElement = 12, $n("StructArrayLayout2i2i2i12", Ri);
class qi extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2, n2, i3) {
const a2 = this.length;
return this.resize(a2 + 1), this.emplace(a2, t2, e2, r2, n2, i3);
}
emplace(t2, e2, r2, n2, i3, a2) {
const s2 = 4 * t2, o2 = 8 * t2;
return this.float32[s2 + 0] = e2, this.float32[s2 + 1] = r2, this.float32[s2 + 2] = n2, this.int16[o2 + 6] = i3, this.int16[o2 + 7] = a2, t2;
}
}
qi.prototype.bytesPerElement = 16, $n("StructArrayLayout2f1f2i16", qi);
class ji extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2, n2) {
const i3 = this.length;
return this.resize(i3 + 1), this.emplace(i3, t2, e2, r2, n2);
}
emplace(t2, e2, r2, n2, i3) {
const a2 = 12 * t2, s2 = 3 * t2;
return this.uint8[a2 + 0] = e2, this.uint8[a2 + 1] = r2, this.float32[s2 + 1] = n2, this.float32[s2 + 2] = i3, t2;
}
}
ji.prototype.bytesPerElement = 12, $n("StructArrayLayout2ub2f12", ji);
class Ni extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2) {
const n2 = this.length;
return this.resize(n2 + 1), this.emplace(n2, t2, e2, r2);
}
emplace(t2, e2, r2, n2) {
const i3 = 3 * t2;
return this.uint16[i3 + 0] = e2, this.uint16[i3 + 1] = r2, this.uint16[i3 + 2] = n2, t2;
}
}
Ni.prototype.bytesPerElement = 6, $n("StructArrayLayout3ui6", Ni);
class Zi extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer), this.uint32 = new Uint32Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2, n2, i3, a2, s2, o2, l2, u2, c2, h2, p2, f2, d2, y2, m2) {
const g2 = this.length;
return this.resize(g2 + 1), this.emplace(g2, t2, e2, r2, n2, i3, a2, s2, o2, l2, u2, c2, h2, p2, f2, d2, y2, m2);
}
emplace(t2, e2, r2, n2, i3, a2, s2, o2, l2, u2, c2, h2, p2, f2, d2, y2, m2, g2) {
const x2 = 24 * t2, v2 = 12 * t2, b2 = 48 * t2;
return this.int16[x2 + 0] = e2, this.int16[x2 + 1] = r2, this.uint16[x2 + 2] = n2, this.uint16[x2 + 3] = i3, this.uint32[v2 + 2] = a2, this.uint32[v2 + 3] = s2, this.uint32[v2 + 4] = o2, this.uint16[x2 + 10] = l2, this.uint16[x2 + 11] = u2, this.uint16[x2 + 12] = c2, this.float32[v2 + 7] = h2, this.float32[v2 + 8] = p2, this.uint8[b2 + 36] = f2, this.uint8[b2 + 37] = d2, this.uint8[b2 + 38] = y2, this.uint32[v2 + 10] = m2, this.int16[x2 + 22] = g2, t2;
}
}
Zi.prototype.bytesPerElement = 48, $n("StructArrayLayout2i2ui3ul3ui2f3ub1ul1i48", Zi);
class Ki extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer), this.uint32 = new Uint32Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2, n2, i3, a2, s2, o2, l2, u2, c2, h2, p2, f2, d2, y2, m2, g2, x2, v2, b2, w2, _2, A2, S2, k2, I2, z2) {
const M2 = this.length;
return this.resize(M2 + 1), this.emplace(M2, t2, e2, r2, n2, i3, a2, s2, o2, l2, u2, c2, h2, p2, f2, d2, y2, m2, g2, x2, v2, b2, w2, _2, A2, S2, k2, I2, z2);
}
emplace(t2, e2, r2, n2, i3, a2, s2, o2, l2, u2, c2, h2, p2, f2, d2, y2, m2, g2, x2, v2, b2, w2, _2, A2, S2, k2, I2, z2, M2) {
const C2 = 32 * t2, B2 = 16 * t2;
return this.int16[C2 + 0] = e2, this.int16[C2 + 1] = r2, this.int16[C2 + 2] = n2, this.int16[C2 + 3] = i3, this.int16[C2 + 4] = a2, this.int16[C2 + 5] = s2, this.int16[C2 + 6] = o2, this.int16[C2 + 7] = l2, this.uint16[C2 + 8] = u2, this.uint16[C2 + 9] = c2, this.uint16[C2 + 10] = h2, this.uint16[C2 + 11] = p2, this.uint16[C2 + 12] = f2, this.uint16[C2 + 13] = d2, this.uint16[C2 + 14] = y2, this.uint16[C2 + 15] = m2, this.uint16[C2 + 16] = g2, this.uint16[C2 + 17] = x2, this.uint16[C2 + 18] = v2, this.uint16[C2 + 19] = b2, this.uint16[C2 + 20] = w2, this.uint16[C2 + 21] = _2, this.uint16[C2 + 22] = A2, this.uint32[B2 + 12] = S2, this.float32[B2 + 13] = k2, this.float32[B2 + 14] = I2, this.uint16[C2 + 30] = z2, this.uint16[C2 + 31] = M2, t2;
}
}
Ki.prototype.bytesPerElement = 64, $n("StructArrayLayout8i15ui1ul2f2ui64", Ki);
class Gi extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer);
}
emplaceBack(t2) {
const e2 = this.length;
return this.resize(e2 + 1), this.emplace(e2, t2);
}
emplace(t2, e2) {
return this.float32[1 * t2 + 0] = e2, t2;
}
}
Gi.prototype.bytesPerElement = 4, $n("StructArrayLayout1f4", Gi);
class Ji extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2) {
const n2 = this.length;
return this.resize(n2 + 1), this.emplace(n2, t2, e2, r2);
}
emplace(t2, e2, r2, n2) {
const i3 = 3 * t2;
return this.uint16[6 * t2 + 0] = e2, this.float32[i3 + 1] = r2, this.float32[i3 + 2] = n2, t2;
}
}
Ji.prototype.bytesPerElement = 12, $n("StructArrayLayout1ui2f12", Ji);
class Xi extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.uint32 = new Uint32Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2) {
const n2 = this.length;
return this.resize(n2 + 1), this.emplace(n2, t2, e2, r2);
}
emplace(t2, e2, r2, n2) {
const i3 = 4 * t2;
return this.uint32[2 * t2 + 0] = e2, this.uint16[i3 + 2] = r2, this.uint16[i3 + 3] = n2, t2;
}
}
Xi.prototype.bytesPerElement = 8, $n("StructArrayLayout1ul2ui8", Xi);
class Yi extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer);
}
emplaceBack(t2, e2) {
const r2 = this.length;
return this.resize(r2 + 1), this.emplace(r2, t2, e2);
}
emplace(t2, e2, r2) {
const n2 = 2 * t2;
return this.uint16[n2 + 0] = e2, this.uint16[n2 + 1] = r2, t2;
}
}
Yi.prototype.bytesPerElement = 4, $n("StructArrayLayout2ui4", Yi);
class Hi extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer);
}
emplaceBack(t2) {
const e2 = this.length;
return this.resize(e2 + 1), this.emplace(e2, t2);
}
emplace(t2, e2) {
return this.uint16[1 * t2 + 0] = e2, t2;
}
}
Hi.prototype.bytesPerElement = 2, $n("StructArrayLayout1ui2", Hi);
class Wi extends zi {
_refreshViews() {
this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer);
}
emplaceBack(t2, e2, r2, n2) {
const i3 = this.length;
return this.resize(i3 + 1), this.emplace(i3, t2, e2, r2, n2);
}
emplace(t2, e2, r2, n2, i3) {
const a2 = 4 * t2;
return this.float32[a2 + 0] = e2, this.float32[a2 + 1] = r2, this.float32[a2 + 2] = n2, this.float32[a2 + 3] = i3, t2;
}
}
Wi.prototype.bytesPerElement = 16, $n("StructArrayLayout4f16", Wi);
class Qi extends Ii {
get anchorPointX() {
return this._structArray.int16[this._pos2 + 0];
}
get anchorPointY() {
return this._structArray.int16[this._pos2 + 1];
}
get x1() {
return this._structArray.int16[this._pos2 + 2];
}
get y1() {
return this._structArray.int16[this._pos2 + 3];
}
get x2() {
return this._structArray.int16[this._pos2 + 4];
}
get y2() {
return this._structArray.int16[this._pos2 + 5];
}
get featureIndex() {
return this._structArray.uint32[this._pos4 + 3];
}
get sourceLayerIndex() {
return this._structArray.uint16[this._pos2 + 8];
}
get bucketIndex() {
return this._structArray.uint16[this._pos2 + 9];
}
get anchorPoint() {
return new a(this.anchorPointX, this.anchorPointY);
}
}
Qi.prototype.size = 20;
class ta extends Ui {
get(t2) {
return new Qi(this, t2);
}
}
$n("CollisionBoxArray", ta);
class ea extends Ii {
get anchorX() {
return this._structArray.int16[this._pos2 + 0];
}
get anchorY() {
return this._structArray.int16[this._pos2 + 1];
}
get glyphStartIndex() {
return this._structArray.uint16[this._pos2 + 2];
}
get numGlyphs() {
return this._structArray.uint16[this._pos2 + 3];
}
get vertexStartIndex() {
return this._structArray.uint32[this._pos4 + 2];
}
get lineStartIndex() {
return this._structArray.uint32[this._pos4 + 3];
}
get lineLength() {
return this._structArray.uint32[this._pos4 + 4];
}
get segment() {
return this._structArray.uint16[this._pos2 + 10];
}
get lowerSize() {
return this._structArray.uint16[this._pos2 + 11];
}
get upperSize() {
return this._structArray.uint16[this._pos2 + 12];
}
get lineOffsetX() {
return this._structArray.float32[this._pos4 + 7];
}
get lineOffsetY() {
return this._structArray.float32[this._pos4 + 8];
}
get writingMode() {
return this._structArray.uint8[this._pos1 + 36];
}
get placedOrientation() {
return this._structArray.uint8[this._pos1 + 37];
}
set placedOrientation(t2) {
this._structArray.uint8[this._pos1 + 37] = t2;
}
get hidden() {
return this._structArray.uint8[this._pos1 + 38];
}
set hidden(t2) {
this._structArray.uint8[this._pos1 + 38] = t2;
}
get crossTileID() {
return this._structArray.uint32[this._pos4 + 10];
}
set crossTileID(t2) {
this._structArray.uint32[this._pos4 + 10] = t2;
}
get associatedIconIndex() {
return this._structArray.int16[this._pos2 + 22];
}
}
ea.prototype.size = 48;
class ra extends Zi {
get(t2) {
return new ea(this, t2);
}
}
$n("PlacedSymbolArray", ra);
class na extends Ii {
get anchorX() {
return this._structArray.int16[this._pos2 + 0];
}
get anchorY() {
return this._structArray.int16[this._pos2 + 1];
}
get rightJustifiedTextSymbolIndex() {
return this._structArray.int16[this._pos2 + 2];
}
get centerJustifiedTextSymbolIndex() {
return this._structArray.int16[this._pos2 + 3];
}
get leftJustifiedTextSymbolIndex() {
return this._structArray.int16[this._pos2 + 4];
}
get verticalPlacedTextSymbolIndex() {
return this._structArray.int16[this._pos2 + 5];
}
get placedIconSymbolIndex() {
return this._structArray.int16[this._pos2 + 6];
}
get verticalPlacedIconSymbolIndex() {
return this._structArray.int16[this._pos2 + 7];
}
get key() {
return this._structArray.uint16[this._pos2 + 8];
}
get textBoxStartIndex() {
return this._structArray.uint16[this._pos2 + 9];
}
get textBoxEndIndex() {
return this._structArray.uint16[this._pos2 + 10];
}
get verticalTextBoxStartIndex() {
return this._structArray.uint16[this._pos2 + 11];
}
get verticalTextBoxEndIndex() {
return this._structArray.uint16[this._pos2 + 12];
}
get iconBoxStartIndex() {
return this._structArray.uint16[this._pos2 + 13];
}
get iconBoxEndIndex() {
return this._structArray.uint16[this._pos2 + 14];
}
get verticalIconBoxStartIndex() {
return this._structArray.uint16[this._pos2 + 15];
}
get verticalIconBoxEndIndex() {
return this._structArray.uint16[this._pos2 + 16];
}
get featureIndex() {
return this._structArray.uint16[this._pos2 + 17];
}
get numHorizontalGlyphVertices() {
return this._structArray.uint16[this._pos2 + 18];
}
get numVerticalGlyphVertices() {
return this._structArray.uint16[this._pos2 + 19];
}
get numIconVertices() {
return this._structArray.uint16[this._pos2 + 20];
}
get numVerticalIconVertices() {
return this._structArray.uint16[this._pos2 + 21];
}
get useRuntimeCollisionCircles() {
return this._structArray.uint16[this._pos2 + 22];
}
get crossTileID() {
return this._structArray.uint32[this._pos4 + 12];
}
set crossTileID(t2) {
this._structArray.uint32[this._pos4 + 12] = t2;
}
get textBoxScale() {
return this._structArray.float32[this._pos4 + 13];
}
get collisionCircleDiameter() {
return this._structArray.float32[this._pos4 + 14];
}
get textAnchorOffsetStartIndex() {
return this._structArray.uint16[this._pos2 + 30];
}
get textAnchorOffsetEndIndex() {
return this._structArray.uint16[this._pos2 + 31];
}
}
na.prototype.size = 64;
class ia extends Ki {
get(t2) {
return new na(this, t2);
}
}
$n("SymbolInstanceArray", ia);
class aa extends Gi {
getoffsetX(t2) {
return this.float32[1 * t2 + 0];
}
}
$n("GlyphOffsetArray", aa);
class sa extends Pi {
getx(t2) {
return this.int16[3 * t2 + 0];
}
gety(t2) {
return this.int16[3 * t2 + 1];
}
gettileUnitDistanceFromAnchor(t2) {
return this.int16[3 * t2 + 2];
}
}
$n("SymbolLineVertexArray", sa);
class oa extends Ii {
get textAnchor() {
return this._structArray.uint16[this._pos2 + 0];
}
get textOffset0() {
return this._structArray.float32[this._pos4 + 1];
}
get textOffset1() {
return this._structArray.float32[this._pos4 + 2];
}
}
oa.prototype.size = 12;
class la extends Ji {
get(t2) {
return new oa(this, t2);
}
}
$n("TextAnchorOffsetArray", la);
class ua extends Ii {
get featureIndex() {
return this._structArray.uint32[this._pos4 + 0];
}
get sourceLayerIndex() {
return this._structArray.uint16[this._pos2 + 2];
}
get bucketIndex() {
return this._structArray.uint16[this._pos2 + 3];
}
}
ua.prototype.size = 8;
class ca extends Xi {
get(t2) {
return new ua(this, t2);
}
}
$n("FeatureIndexArray", ca);
class ha extends Bi {
}
class pa extends Bi {
}
class fa extends Bi {
}
class da extends Ei {
}
class ya extends Fi {
}
class ma extends Ti {
}
class ga extends $i {
}
class xa extends Li {
}
class va extends Di {
}
class ba extends Oi {
}
class wa extends Ri {
}
class _a extends ji {
}
class Aa extends Ni {
}
class Sa extends Yi {
}
const ka = Mi([{ name: "a_pos", components: 2, type: "Int16" }], 4), { members: Ia } = ka;
class za {
constructor(t2 = []) {
this.segments = t2;
}
prepareSegment(t2, e2, r2, n2) {
let i3 = this.segments[this.segments.length - 1];
return t2 > za.MAX_VERTEX_ARRAY_LENGTH && A(`Max vertices per segment is ${za.MAX_VERTEX_ARRAY_LENGTH}: bucket requested ${t2}`), (!i3 || i3.vertexLength + t2 > za.MAX_VERTEX_ARRAY_LENGTH || i3.sortKey !== n2) && (i3 = { vertexOffset: e2.length, primitiveOffset: r2.length, vertexLength: 0, primitiveLength: 0 }, void 0 !== n2 && (i3.sortKey = n2), this.segments.push(i3)), i3;
}
get() {
return this.segments;
}
destroy() {
for (const t2 of this.segments) for (const e2 in t2.vaos) t2.vaos[e2].destroy();
}
static simpleSegment(t2, e2, r2, n2) {
return new za([{ vertexOffset: t2, primitiveOffset: e2, vertexLength: r2, primitiveLength: n2, vaos: {}, sortKey: 0 }]);
}
}
function Ma(t2, e2) {
return 256 * (t2 = y(Math.floor(t2), 0, 255)) + y(Math.floor(e2), 0, 255);
}
za.MAX_VERTEX_ARRAY_LENGTH = Math.pow(2, 16) - 1, $n("SegmentVector", za);
const Ca = Mi([{ name: "a_pattern_from", components: 4, type: "Uint16" }, { name: "a_pattern_to", components: 4, type: "Uint16" }, { name: "a_pixel_ratio_from", components: 1, type: "Uint16" }, { name: "a_pixel_ratio_to", components: 1, type: "Uint16" }]);
var Ba = { exports: {} }, Pa = { exports: {} };
Pa.exports = function(t2, e2) {
var r2, n2, i3, a2, s2, o2, l2, u2;
for (n2 = t2.length - (r2 = 3 & t2.length), i3 = e2, s2 = 3432918353, o2 = 461845907, u2 = 0; u2 < n2; ) l2 = 255 & t2.charCodeAt(u2) | (255 & t2.charCodeAt(++u2)) << 8 | (255 & t2.charCodeAt(++u2)) << 16 | (255 & t2.charCodeAt(++u2)) << 24, ++u2, i3 = 27492 + (65535 & (a2 = 5 * (65535 & (i3 = (i3 ^= l2 = (65535 & (l2 = (l2 = (65535 & l2) * s2 + (((l2 >>> 16) * s2 & 65535) << 16) & 4294967295) << 15 | l2 >>> 17)) * o2 + (((l2 >>> 16) * o2 & 65535) << 16) & 4294967295) << 13 | i3 >>> 19)) + ((5 * (i3 >>> 16) & 65535) << 16) & 4294967295)) + ((58964 + (a2 >>> 16) & 65535) << 16);
switch (l2 = 0, r2) {
case 3:
l2 ^= (255 & t2.charCodeAt(u2 + 2)) << 16;
case 2:
l2 ^= (255 & t2.charCodeAt(u2 + 1)) << 8;
case 1:
i3 ^= l2 = (65535 & (l2 = (l2 = (65535 & (l2 ^= 255 & t2.charCodeAt(u2))) * s2 + (((l2 >>> 16) * s2 & 65535) << 16) & 4294967295) << 15 | l2 >>> 17)) * o2 + (((l2 >>> 16) * o2 & 65535) << 16) & 4294967295;
}
return i3 ^= t2.length, i3 = 2246822507 * (65535 & (i3 ^= i3 >>> 16)) + ((2246822507 * (i3 >>> 16) & 65535) << 16) & 4294967295, i3 = 3266489909 * (65535 & (i3 ^= i3 >>> 13)) + ((3266489909 * (i3 >>> 16) & 65535) << 16) & 4294967295, (i3 ^= i3 >>> 16) >>> 0;
};
var Va = Pa.exports, Ea = { exports: {} };
Ea.exports = function(t2, e2) {
for (var r2, n2 = t2.length, i3 = e2 ^ n2, a2 = 0; n2 >= 4; ) r2 = 1540483477 * (65535 & (r2 = 255 & t2.charCodeAt(a2) | (255 & t2.charCodeAt(++a2)) << 8 | (255 & t2.charCodeAt(++a2)) << 16 | (255 & t2.charCodeAt(++a2)) << 24)) + ((1540483477 * (r2 >>> 16) & 65535) << 16), i3 = 1540483477 * (65535 & i3) + ((1540483477 * (i3 >>> 16) & 65535) << 16) ^ (r2 = 1540483477 * (65535 & (r2 ^= r2 >>> 24)) + ((1540483477 * (r2 >>> 16) & 65535) << 16)), n2 -= 4, ++a2;
switch (n2) {
case 3:
i3 ^= (255 & t2.charCodeAt(a2 + 2)) << 16;
case 2:
i3 ^= (255 & t2.charCodeAt(a2 + 1)) << 8;
case 1:
i3 = 1540483477 * (65535 & (i3 ^= 255 & t2.charCodeAt(a2))) + ((1540483477 * (i3 >>> 16) & 65535) << 16);
}
return i3 = 1540483477 * (65535 & (i3 ^= i3 >>> 13)) + ((1540483477 * (i3 >>> 16) & 65535) << 16), (i3 ^= i3 >>> 15) >>> 0;
};
var Fa = Va, Ta = Ea.exports;
Ba.exports = Fa, Ba.exports.murmur3 = Fa, Ba.exports.murmur2 = Ta;
var $a = r(Ba.exports);
class La {
constructor() {
this.ids = [], this.positions = [], this.indexed = false;
}
add(t2, e2, r2, n2) {
this.ids.push(Da(t2)), this.positions.push(e2, r2, n2);
}
getPositions(t2) {
if (!this.indexed) throw new Error("Trying to get index, but feature positions are not indexed");
const e2 = Da(t2);
let r2 = 0, n2 = this.ids.length - 1;
for (; r2 < n2; ) {
const t3 = r2 + n2 >> 1;
this.ids[t3] >= e2 ? n2 = t3 : r2 = t3 + 1;
}
const i3 = [];
for (; this.ids[r2] === e2; ) i3.push({ index: this.positions[3 * r2], start: this.positions[3 * r2 + 1], end: this.positions[3 * r2 + 2] }), r2++;
return i3;
}
static serialize(t2, e2) {
const r2 = new Float64Array(t2.ids), n2 = new Uint32Array(t2.positions);
return Oa(r2, n2, 0, r2.length - 1), e2 && e2.push(r2.buffer, n2.buffer), { ids: r2, positions: n2 };
}
static deserialize(t2) {
const e2 = new La();
return e2.ids = t2.ids, e2.positions = t2.positions, e2.indexed = true, e2;
}
}
function Da(t2) {
const e2 = +t2;
return !isNaN(e2) && e2 <= Number.MAX_SAFE_INTEGER ? e2 : $a(String(t2));
}
function Oa(t2, e2, r2, n2) {
for (; r2 < n2; ) {
const i3 = t2[r2 + n2 >> 1];
let a2 = r2 - 1, s2 = n2 + 1;
for (; ; ) {
do {
a2++;
} while (t2[a2] < i3);
do {
s2--;
} while (t2[s2] > i3);
if (a2 >= s2) break;
Ua(t2, a2, s2), Ua(e2, 3 * a2, 3 * s2), Ua(e2, 3 * a2 + 1, 3 * s2 + 1), Ua(e2, 3 * a2 + 2, 3 * s2 + 2);
}
s2 - r2 < n2 - s2 ? (Oa(t2, e2, r2, s2), r2 = s2 + 1) : (Oa(t2, e2, s2 + 1, n2), n2 = s2);
}
}
function Ua(t2, e2, r2) {
const n2 = t2[e2];
t2[e2] = t2[r2], t2[r2] = n2;
}
$n("FeaturePositionMap", La);
class Ra {
constructor(t2, e2) {
this.gl = t2.gl, this.location = e2;
}
}
class qa extends Ra {
constructor(t2, e2) {
super(t2, e2), this.current = 0;
}
set(t2) {
this.current !== t2 && (this.current = t2, this.gl.uniform1f(this.location, t2));
}
}
class ja extends Ra {
constructor(t2, e2) {
super(t2, e2), this.current = [0, 0, 0, 0];
}
set(t2) {
t2[0] === this.current[0] && t2[1] === this.current[1] && t2[2] === this.current[2] && t2[3] === this.current[3] || (this.current = t2, this.gl.uniform4f(this.location, t2[0], t2[1], t2[2], t2[3]));
}
}
class Na extends Ra {
constructor(t2, e2) {
super(t2, e2), this.current = Yt.transparent;
}
set(t2) {
t2.r === this.current.r && t2.g === this.current.g && t2.b === this.current.b && t2.a === this.current.a || (this.current = t2, this.gl.uniform4f(this.location, t2.r, t2.g, t2.b, t2.a));
}
}
const Za = new Float32Array(16);
function Ka(t2) {
return [Ma(255 * t2.r, 255 * t2.g), Ma(255 * t2.b, 255 * t2.a)];
}
class Ga {
constructor(t2, e2, r2) {
this.value = t2, this.uniformNames = e2.map(((t3) => `u_${t3}`)), this.type = r2;
}
setUniform(t2, e2, r2) {
t2.set(r2.constantOr(this.value));
}
getBinding(t2, e2, r2) {
return "color" === this.type ? new Na(t2, e2) : new qa(t2, e2);
}
}
class Ja {
constructor(t2, e2) {
this.uniformNames = e2.map(((t3) => `u_${t3}`)), this.patternFrom = null, this.patternTo = null, this.pixelRatioFrom = 1, this.pixelRatioTo = 1;
}
setConstantPatternPositions(t2, e2) {
this.pixelRatioFrom = e2.pixelRatio, this.pixelRatioTo = t2.pixelRatio, this.patternFrom = e2.tlbr, this.patternTo = t2.tlbr;
}
setUniform(t2, e2, r2, n2) {
const i3 = "u_pattern_to" === n2 ? this.patternTo : "u_pattern_from" === n2 ? this.patternFrom : "u_pixel_ratio_to" === n2 ? this.pixelRatioTo : "u_pixel_ratio_from" === n2 ? this.pixelRatioFrom : null;
i3 && t2.set(i3);
}
getBinding(t2, e2, r2) {
return "u_pattern" === r2.substr(0, 9) ? new ja(t2, e2) : new qa(t2, e2);
}
}
class Xa {
constructor(t2, e2, r2, n2) {
this.expression = t2, this.type = r2, this.maxValue = 0, this.paintVertexAttributes = e2.map(((t3) => ({ name: `a_${t3}`, type: "Float32", components: "color" === r2 ? 2 : 1, offset: 0 }))), this.paintVertexArray = new n2();
}
populatePaintArray(t2, e2, r2, n2, i3) {
const a2 = this.paintVertexArray.length, s2 = this.expression.evaluate(new li(0), e2, {}, n2, [], i3);
this.paintVertexArray.resize(t2), this._setPaintValue(a2, t2, s2);
}
updatePaintArray(t2, e2, r2, n2) {
const i3 = this.expression.evaluate({ zoom: 0 }, r2, n2);
this._setPaintValue(t2, e2, i3);
}
_setPaintValue(t2, e2, r2) {
if ("color" === this.type) {
const n2 = Ka(r2);
for (let r3 = t2; r3 < e2; r3++) this.paintVertexArray.emplace(r3, n2[0], n2[1]);
} else {
for (let n2 = t2; n2 < e2; n2++) this.paintVertexArray.emplace(n2, r2);
this.maxValue = Math.max(this.maxValue, Math.abs(r2));
}
}
upload(t2) {
this.paintVertexArray && this.paintVertexArray.arrayBuffer && (this.paintVertexBuffer && this.paintVertexBuffer.buffer ? this.paintVertexBuffer.updateData(this.paintVertexArray) : this.paintVertexBuffer = t2.createVertexBuffer(this.paintVertexArray, this.paintVertexAttributes, this.expression.isStateDependent));
}
destroy() {
this.paintVertexBuffer && this.paintVertexBuffer.destroy();
}
}
class Ya {
constructor(t2, e2, r2, n2, i3, a2) {
this.expression = t2, this.uniformNames = e2.map(((t3) => `u_${t3}_t`)), this.type = r2, this.useIntegerZoom = n2, this.zoom = i3, this.maxValue = 0, this.paintVertexAttributes = e2.map(((t3) => ({ name: `a_${t3}`, type: "Float32", components: "color" === r2 ? 4 : 2, offset: 0 }))), this.paintVertexArray = new a2();
}
populatePaintArray(t2, e2, r2, n2, i3) {
const a2 = this.expression.evaluate(new li(this.zoom), e2, {}, n2, [], i3), s2 = this.expression.evaluate(new li(this.zoom + 1), e2, {}, n2, [], i3), o2 = this.paintVertexArray.length;
this.paintVertexArray.resize(t2), this._setPaintValue(o2, t2, a2, s2);
}
updatePaintArray(t2, e2, r2, n2) {
const i3 = this.expression.evaluate({ zoom: this.zoom }, r2, n2), a2 = this.expression.evaluate({ zoom: this.zoom + 1 }, r2, n2);
this._setPaintValue(t2, e2, i3, a2);
}
_setPaintValue(t2, e2, r2, n2) {
if ("color" === this.type) {
const i3 = Ka(r2), a2 = Ka(n2);
for (let r3 = t2; r3 < e2; r3++) this.paintVertexArray.emplace(r3, i3[0], i3[1], a2[0], a2[1]);
} else {
for (let i3 = t2; i3 < e2; i3++) this.paintVertexArray.emplace(i3, r2, n2);
this.maxValue = Math.max(this.maxValue, Math.abs(r2), Math.abs(n2));
}
}
upload(t2) {
this.paintVertexArray && this.paintVertexArray.arrayBuffer && (this.paintVertexBuffer && this.paintVertexBuffer.buffer ? this.paintVertexBuffer.updateData(this.paintVertexArray) : this.paintVertexBuffer = t2.createVertexBuffer(this.paintVertexArray, this.paintVertexAttributes, this.expression.isStateDependent));
}
destroy() {
this.paintVertexBuffer && this.paintVertexBuffer.destroy();
}
setUniform(t2, e2) {
const r2 = this.useIntegerZoom ? Math.floor(e2.zoom) : e2.zoom, n2 = y(this.expression.interpolationFactor(r2, this.zoom, this.zoom + 1), 0, 1);
t2.set(n2);
}
getBinding(t2, e2, r2) {
return new qa(t2, e2);
}
}
class Ha {
constructor(t2, e2, r2, n2, i3, a2) {
this.expression = t2, this.type = e2, this.useIntegerZoom = r2, this.zoom = n2, this.layerId = a2, this.zoomInPaintVertexArray = new i3(), this.zoomOutPaintVertexArray = new i3();
}
populatePaintArray(t2, e2, r2) {
const n2 = this.zoomInPaintVertexArray.length;
this.zoomInPaintVertexArray.resize(t2), this.zoomOutPaintVertexArray.resize(t2), this._setPaintValues(n2, t2, e2.patterns && e2.patterns[this.layerId], r2);
}
updatePaintArray(t2, e2, r2, n2, i3) {
this._setPaintValues(t2, e2, r2.patterns && r2.patterns[this.layerId], i3);
}
_setPaintValues(t2, e2, r2, n2) {
if (!n2 || !r2) return;
const { min: i3, mid: a2, max: s2 } = r2, o2 = n2[i3], l2 = n2[a2], u2 = n2[s2];
if (o2 && l2 && u2) for (let r3 = t2; r3 < e2; r3++) this.zoomInPaintVertexArray.emplace(r3, l2.tl[0], l2.tl[1], l2.br[0], l2.br[1], o2.tl[0], o2.tl[1], o2.br[0], o2.br[1], l2.pixelRatio, o2.pixelRatio), this.zoomOutPaintVertexArray.emplace(r3, l2.tl[0], l2.tl[1], l2.br[0], l2.br[1], u2.tl[0], u2.tl[1], u2.br[0], u2.br[1], l2.pixelRatio, u2.pixelRatio);
}
upload(t2) {
this.zoomInPaintVertexArray && this.zoomInPaintVertexArray.arrayBuffer && this.zoomOutPaintVertexArray && this.zoomOutPaintVertexArray.arrayBuffer && (this.zoomInPaintVertexBuffer = t2.createVertexBuffer(this.zoomInPaintVertexArray, Ca.members, this.expression.isStateDependent), this.zoomOutPaintVertexBuffer = t2.createVertexBuffer(this.zoomOutPaintVertexArray, Ca.members, this.expression.isStateDependent));
}
destroy() {
this.zoomOutPaintVertexBuffer && this.zoomOutPaintVertexBuffer.destroy(), this.zoomInPaintVertexBuffer && this.zoomInPaintVertexBuffer.destroy();
}
}
class Wa {
constructor(t2, e2, r2) {
this.binders = {}, this._buffers = [];
const n2 = [];
for (const i3 in t2.paint._values) {
if (!r2(i3)) continue;
const a2 = t2.paint.get(i3);
if (!(a2 instanceof yi && _r(a2.property.specification))) continue;
const s2 = ts(i3, t2.type), o2 = a2.value, l2 = a2.property.specification.type, u2 = a2.property.useIntegerZoom, c2 = a2.property.specification["property-type"], h2 = "cross-faded" === c2 || "cross-faded-data-driven" === c2;
if ("constant" === o2.kind) this.binders[i3] = h2 ? new Ja(o2.value, s2) : new Ga(o2.value, s2, l2), n2.push(`/u_${i3}`);
else if ("source" === o2.kind || h2) {
const r3 = es(i3, l2, "source");
this.binders[i3] = h2 ? new Ha(o2, l2, u2, e2, r3, t2.id) : new Xa(o2, s2, l2, r3), n2.push(`/a_${i3}`);
} else {
const t3 = es(i3, l2, "composite");
this.binders[i3] = new Ya(o2, s2, l2, u2, e2, t3), n2.push(`/z_${i3}`);
}
}
this.cacheKey = n2.sort().join("");
}
getMaxValue(t2) {
const e2 = this.binders[t2];
return e2 instanceof Xa || e2 instanceof Ya ? e2.maxValue : 0;
}
populatePaintArrays(t2, e2, r2, n2, i3) {
for (const a2 in this.binders) {
const s2 = this.binders[a2];
(s2 instanceof Xa || s2 instanceof Ya || s2 instanceof Ha) && s2.populatePaintArray(t2, e2, r2, n2, i3);
}
}
setConstantPatternPositions(t2, e2) {
for (const r2 in this.binders) {
const n2 = this.binders[r2];
n2 instanceof Ja && n2.setConstantPatternPositions(t2, e2);
}
}
updatePaintArrays(t2, e2, r2, n2, i3) {
let a2 = false;
for (const s2 in t2) {
const o2 = e2.getPositions(s2);
for (const e3 of o2) {
const o3 = r2.feature(e3.index);
for (const r3 in this.binders) {
const l2 = this.binders[r3];
if ((l2 instanceof Xa || l2 instanceof Ya || l2 instanceof Ha) && true === l2.expression.isStateDependent) {
const u2 = n2.paint.get(r3);
l2.expression = u2.value, l2.updatePaintArray(e3.start, e3.end, o3, t2[s2], i3), a2 = true;
}
}
}
}
return a2;
}
defines() {
const t2 = [];
for (const e2 in this.binders) {
const r2 = this.binders[e2];
(r2 instanceof Ga || r2 instanceof Ja) && t2.push(...r2.uniformNames.map(((t3) => `#define HAS_UNIFORM_${t3}`)));
}
return t2;
}
getBinderAttributes() {
const t2 = [];
for (const e2 in this.binders) {
const r2 = this.binders[e2];
if (r2 instanceof Xa || r2 instanceof Ya) for (let e3 = 0; e3 < r2.paintVertexAttributes.length; e3++) t2.push(r2.paintVertexAttributes[e3].name);
else if (r2 instanceof Ha) for (let e3 = 0; e3 < Ca.members.length; e3++) t2.push(Ca.members[e3].name);
}
return t2;
}
getBinderUniforms() {
const t2 = [];
for (const e2 in this.binders) {
const r2 = this.binders[e2];
if (r2 instanceof Ga || r2 instanceof Ja || r2 instanceof Ya) for (const e3 of r2.uniformNames) t2.push(e3);
}
return t2;
}
getPaintVertexBuffers() {
return this._buffers;
}
getUniforms(t2, e2) {
const r2 = [];
for (const n2 in this.binders) {
const i3 = this.binders[n2];
if (i3 instanceof Ga || i3 instanceof Ja || i3 instanceof Ya) {
for (const a2 of i3.uniformNames) if (e2[a2]) {
const s2 = i3.getBinding(t2, e2[a2], a2);
r2.push({ name: a2, property: n2, binding: s2 });
}
}
}
return r2;
}
setUniforms(t2, e2, r2, n2) {
for (const { name: t3, property: i3, binding: a2 } of e2) this.binders[i3].setUniform(a2, n2, r2.get(i3), t3);
}
updatePaintBuffers(t2) {
this._buffers = [];
for (const e2 in this.binders) {
const r2 = this.binders[e2];
if (t2 && r2 instanceof Ha) {
const e3 = 2 === t2.fromScale ? r2.zoomInPaintVertexBuffer : r2.zoomOutPaintVertexBuffer;
e3 && this._buffers.push(e3);
} else (r2 instanceof Xa || r2 instanceof Ya) && r2.paintVertexBuffer && this._buffers.push(r2.paintVertexBuffer);
}
}
upload(t2) {
for (const e2 in this.binders) {
const r2 = this.binders[e2];
(r2 instanceof Xa || r2 instanceof Ya || r2 instanceof Ha) && r2.upload(t2);
}
this.updatePaintBuffers();
}
destroy() {
for (const t2 in this.binders) {
const e2 = this.binders[t2];
(e2 instanceof Xa || e2 instanceof Ya || e2 instanceof Ha) && e2.destroy();
}
}
}
class Qa {
constructor(t2, e2, r2 = (() => true)) {
this.programConfigurations = {};
for (const n2 of t2) this.programConfigurations[n2.id] = new Wa(n2, e2, r2);
this.needsUpload = false, this._featureMap = new La(), this._bufferOffset = 0;
}
populatePaintArrays(t2, e2, r2, n2, i3, a2) {
for (const r3 in this.programConfigurations) this.programConfigurations[r3].populatePaintArrays(t2, e2, n2, i3, a2);
void 0 !== e2.id && this._featureMap.add(e2.id, r2, this._bufferOffset, t2), this._bufferOffset = t2, this.needsUpload = true;
}
updatePaintArrays(t2, e2, r2, n2) {
for (const i3 of r2) this.needsUpload = this.programConfigurations[i3.id].updatePaintArrays(t2, this._featureMap, e2, i3, n2) || this.needsUpload;
}
get(t2) {
return this.programConfigurations[t2];
}
upload(t2) {
if (this.needsUpload) {
for (const e2 in this.programConfigurations) this.programConfigurations[e2].upload(t2);
this.needsUpload = false;
}
}
destroy() {
for (const t2 in this.programConfigurations) this.programConfigurations[t2].destroy();
}
}
function ts(t2, e2) {
return { "text-opacity": ["opacity"], "icon-opacity": ["opacity"], "text-color": ["fill_color"], "icon-color": ["fill_color"], "text-halo-color": ["halo_color"], "icon-halo-color": ["halo_color"], "text-halo-blur": ["halo_blur"], "icon-halo-blur": ["halo_blur"], "text-halo-width": ["halo_width"], "icon-halo-width": ["halo_width"], "line-gap-width": ["gapwidth"], "line-pattern": ["pattern_to", "pattern_from", "pixel_ratio_to", "pixel_ratio_from"], "fill-pattern": ["pattern_to", "pattern_from", "pixel_ratio_to", "pixel_ratio_from"], "fill-extrusion-pattern": ["pattern_to", "pattern_from", "pixel_ratio_to", "pixel_ratio_from"] }[t2] || [t2.replace(`${e2}-`, "").replace(/-/g, "_")];
}
function es(t2, e2, r2) {
const n2 = { color: { source: Ti, composite: Wi }, number: { source: Gi, composite: Ti } }, i3 = (function(t3) {
return { "line-pattern": { source: ga, composite: ga }, "fill-pattern": { source: ga, composite: ga }, "fill-extrusion-pattern": { source: ga, composite: ga } }[t3];
})(t2);
return i3 && i3[r2] || n2[e2][r2];
}
$n("ConstantBinder", Ga), $n("CrossFadedConstantBinder", Ja), $n("SourceExpressionBinder", Xa), $n("CrossFadedCompositeBinder", Ha), $n("CompositeExpressionBinder", Ya), $n("ProgramConfiguration", Wa, { omit: ["_buffers"] }), $n("ProgramConfigurationSet", Qa);
const rs = 8192, ns = Math.pow(2, 14) - 1, is = -ns - 1;
function as(t2) {
const e2 = rs / t2.extent, r2 = t2.loadGeometry();
for (let t3 = 0; t3 < r2.length; t3++) {
const n2 = r2[t3];
for (let t4 = 0; t4 < n2.length; t4++) {
const r3 = n2[t4], i3 = Math.round(r3.x * e2), a2 = Math.round(r3.y * e2);
r3.x = y(i3, is, ns), r3.y = y(a2, is, ns), (i3 < r3.x || i3 > r3.x + 1 || a2 < r3.y || a2 > r3.y + 1) && A("Geometry exceeds allowed extent, reduce your vector tile buffer size");
}
}
return r2;
}
function ss(t2, e2) {
return { type: t2.type, id: t2.id, properties: t2.properties, geometry: e2 ? as(t2) : [] };
}
function os(t2, e2, r2, n2, i3) {
t2.emplaceBack(2 * e2 + (n2 + 1) / 2, 2 * r2 + (i3 + 1) / 2);
}
class ls {
constructor(t2) {
this.zoom = t2.zoom, this.overscaling = t2.overscaling, this.layers = t2.layers, this.layerIds = this.layers.map(((t3) => t3.id)), this.index = t2.index, this.hasPattern = false, this.layoutVertexArray = new pa(), this.indexArray = new Aa(), this.segments = new za(), this.programConfigurations = new Qa(t2.layers, t2.zoom), this.stateDependentLayerIds = this.layers.filter(((t3) => t3.isStateDependent())).map(((t3) => t3.id));
}
populate(t2, e2, r2) {
const n2 = this.layers[0], i3 = [];
let a2 = null, s2 = false;
"circle" === n2.type && (a2 = n2.layout.get("circle-sort-key"), s2 = !a2.isConstant());
for (const { feature: e3, id: n3, index: o2, sourceLayerIndex: l2 } of t2) {
const t3 = this.layers[0]._featureFilter.needGeometry, u2 = ss(e3, t3);
if (!this.layers[0]._featureFilter.filter(new li(this.zoom), u2, r2)) continue;
const c2 = s2 ? a2.evaluate(u2, {}, r2) : void 0, h2 = { id: n3, properties: e3.properties, type: e3.type, sourceLayerIndex: l2, index: o2, geometry: t3 ? u2.geometry : as(e3), patterns: {}, sortKey: c2 };
i3.push(h2);
}
s2 && i3.sort(((t3, e3) => t3.sortKey - e3.sortKey));
for (const n3 of i3) {
const { geometry: i4, index: a3, sourceLayerIndex: s3 } = n3, o2 = t2[a3].feature;
this.addFeature(n3, i4, a3, r2), e2.featureIndex.insert(o2, i4, a3, s3, this.index);
}
}
update(t2, e2, r2) {
this.stateDependentLayers.length && this.programConfigurations.updatePaintArrays(t2, e2, this.stateDependentLayers, r2);
}
isEmpty() {
return 0 === this.layoutVertexArray.length;
}
uploadPending() {
return !this.uploaded || this.programConfigurations.needsUpload;
}
upload(t2) {
this.uploaded || (this.layoutVertexBuffer = t2.createVertexBuffer(this.layoutVertexArray, Ia), this.indexBuffer = t2.createIndexBuffer(this.indexArray)), this.programConfigurations.upload(t2), this.uploaded = true;
}
destroy() {
this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.indexBuffer.destroy(), this.programConfigurations.destroy(), this.segments.destroy());
}
addFeature(t2, e2, r2, n2) {
for (const r3 of e2) for (const e3 of r3) {
const r4 = e3.x, n3 = e3.y;
if (r4 < 0 || r4 >= rs || n3 < 0 || n3 >= rs) continue;
const i3 = this.segments.prepareSegment(4, this.layoutVertexArray, this.indexArray, t2.sortKey), a2 = i3.vertexLength;
os(this.layoutVertexArray, r4, n3, -1, -1), os(this.layoutVertexArray, r4, n3, 1, -1), os(this.layoutVertexArray, r4, n3, 1, 1), os(this.layoutVertexArray, r4, n3, -1, 1), this.indexArray.emplaceBack(a2, a2 + 1, a2 + 2), this.indexArray.emplaceBack(a2, a2 + 3, a2 + 2), i3.vertexLength += 4, i3.primitiveLength += 2;
}
this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, t2, r2, {}, n2);
}
}
function us(t2, e2) {
for (let r2 = 0; r2 < t2.length; r2++) if (xs(e2, t2[r2])) return true;
for (let r2 = 0; r2 < e2.length; r2++) if (xs(t2, e2[r2])) return true;
return !!fs(t2, e2);
}
function cs(t2, e2, r2) {
return !!xs(t2, e2) || !!ys(e2, t2, r2);
}
function hs(t2, e2) {
if (1 === t2.length) return gs(e2, t2[0]);
for (let r2 = 0; r2 < e2.length; r2++) {
const n2 = e2[r2];
for (let e3 = 0; e3 < n2.length; e3++) if (xs(t2, n2[e3])) return true;
}
for (let r2 = 0; r2 < t2.length; r2++) if (gs(e2, t2[r2])) return true;
for (let r2 = 0; r2 < e2.length; r2++) if (fs(t2, e2[r2])) return true;
return false;
}
function ps(t2, e2, r2) {
if (t2.length > 1) {
if (fs(t2, e2)) return true;
for (let n2 = 0; n2 < e2.length; n2++) if (ys(e2[n2], t2, r2)) return true;
}
for (let n2 = 0; n2 < t2.length; n2++) if (ys(t2[n2], e2, r2)) return true;
return false;
}
function fs(t2, e2) {
if (0 === t2.length || 0 === e2.length) return false;
for (let r2 = 0; r2 < t2.length - 1; r2++) {
const n2 = t2[r2], i3 = t2[r2 + 1];
for (let t3 = 0; t3 < e2.length - 1; t3++) if (ds(n2, i3, e2[t3], e2[t3 + 1])) return true;
}
return false;
}
function ds(t2, e2, r2, n2) {
return S(t2, r2, n2) !== S(e2, r2, n2) && S(t2, e2, r2) !== S(t2, e2, n2);
}
function ys(t2, e2, r2) {
const n2 = r2 * r2;
if (1 === e2.length) return t2.distSqr(e2[0]) < n2;
for (let r3 = 1; r3 < e2.length; r3++) if (ms(t2, e2[r3 - 1], e2[r3]) < n2) return true;
return false;
}
function ms(t2, e2, r2) {
const n2 = e2.distSqr(r2);
if (0 === n2) return t2.distSqr(e2);
const i3 = ((t2.x - e2.x) * (r2.x - e2.x) + (t2.y - e2.y) * (r2.y - e2.y)) / n2;
return t2.distSqr(i3 < 0 ? e2 : i3 > 1 ? r2 : r2.sub(e2)._mult(i3)._add(e2));
}
function gs(t2, e2) {
let r2, n2, i3, a2 = false;
for (let s2 = 0; s2 < t2.length; s2++) {
r2 = t2[s2];
for (let t3 = 0, s3 = r2.length - 1; t3 < r2.length; s3 = t3++) n2 = r2[t3], i3 = r2[s3], n2.y > e2.y != i3.y > e2.y && e2.x < (i3.x - n2.x) * (e2.y - n2.y) / (i3.y - n2.y) + n2.x && (a2 = !a2);
}
return a2;
}
function xs(t2, e2) {
let r2 = false;
for (let n2 = 0, i3 = t2.length - 1; n2 < t2.length; i3 = n2++) {
const a2 = t2[n2], s2 = t2[i3];
a2.y > e2.y != s2.y > e2.y && e2.x < (s2.x - a2.x) * (e2.y - a2.y) / (s2.y - a2.y) + a2.x && (r2 = !r2);
}
return r2;
}
function vs(t2, e2, r2) {
const n2 = r2[0], i3 = r2[2];
if (t2.x < n2.x && e2.x < n2.x || t2.x > i3.x && e2.x > i3.x || t2.y < n2.y && e2.y < n2.y || t2.y > i3.y && e2.y > i3.y) return false;
const a2 = S(t2, e2, r2[0]);
return a2 !== S(t2, e2, r2[1]) || a2 !== S(t2, e2, r2[2]) || a2 !== S(t2, e2, r2[3]);
}
function bs(t2, e2, r2) {
const n2 = e2.paint.get(t2).value;
return "constant" === n2.kind ? n2.value : r2.programConfigurations.get(e2.id).getMaxValue(t2);
}
function ws(t2) {
return Math.sqrt(t2[0] * t2[0] + t2[1] * t2[1]);
}
function _s(t2, e2, r2, n2, i3) {
if (!e2[0] && !e2[1]) return t2;
const s2 = a.convert(e2)._mult(i3);
"viewport" === r2 && s2._rotate(-n2);
const o2 = [];
for (let e3 = 0; e3 < t2.length; e3++) o2.push(t2[e3].sub(s2));
return o2;
}
let As, Ss;
$n("CircleBucket", ls, { omit: ["layers"] });
var ks = { get paint() {
return Ss = Ss || new _i({ "circle-radius": new xi(X.paint_circle["circle-radius"]), "circle-color": new xi(X.paint_circle["circle-color"]), "circle-blur": new xi(X.paint_circle["circle-blur"]), "circle-opacity": new xi(X.paint_circle["circle-opacity"]), "circle-translate": new gi(X.paint_circle["circle-translate"]), "circle-translate-anchor": new gi(X.paint_circle["circle-translate-anchor"]), "circle-pitch-scale": new gi(X.paint_circle["circle-pitch-scale"]), "circle-pitch-alignment": new gi(X.paint_circle["circle-pitch-alignment"]), "circle-stroke-width": new xi(X.paint_circle["circle-stroke-width"]), "circle-stroke-color": new xi(X.paint_circle["circle-stroke-color"]), "circle-stroke-opacity": new xi(X.paint_circle["circle-stroke-opacity"]) });
}, get layout() {
return As = As || new _i({ "circle-sort-key": new xi(X.layout_circle["circle-sort-key"]) });
} }, Is = 1e-6, zs = "undefined" != typeof Float32Array ? Float32Array : Array;
function Ms(t2) {
return t2[0] = 1, t2[1] = 0, t2[2] = 0, t2[3] = 0, t2[4] = 0, t2[5] = 1, t2[6] = 0, t2[7] = 0, t2[8] = 0, t2[9] = 0, t2[10] = 1, t2[11] = 0, t2[12] = 0, t2[13] = 0, t2[14] = 0, t2[15] = 1, t2;
}
function Cs(t2, e2, r2) {
var n2 = e2[0], i3 = e2[1], a2 = e2[2], s2 = e2[3], o2 = e2[4], l2 = e2[5], u2 = e2[6], c2 = e2[7], h2 = e2[8], p2 = e2[9], f2 = e2[10], d2 = e2[11], y2 = e2[12], m2 = e2[13], g2 = e2[14], x2 = e2[15], v2 = r2[0], b2 = r2[1], w2 = r2[2], _2 = r2[3];
return t2[0] = v2 * n2 + b2 * o2 + w2 * h2 + _2 * y2, t2[1] = v2 * i3 + b2 * l2 + w2 * p2 + _2 * m2, t2[2] = v2 * a2 + b2 * u2 + w2 * f2 + _2 * g2, t2[3] = v2 * s2 + b2 * c2 + w2 * d2 + _2 * x2, t2[4] = (v2 = r2[4]) * n2 + (b2 = r2[5]) * o2 + (w2 = r2[6]) * h2 + (_2 = r2[7]) * y2, t2[5] = v2 * i3 + b2 * l2 + w2 * p2 + _2 * m2, t2[6] = v2 * a2 + b2 * u2 + w2 * f2 + _2 * g2, t2[7] = v2 * s2 + b2 * c2 + w2 * d2 + _2 * x2, t2[8] = (v2 = r2[8]) * n2 + (b2 = r2[9]) * o2 + (w2 = r2[10]) * h2 + (_2 = r2[11]) * y2, t2[9] = v2 * i3 + b2 * l2 + w2 * p2 + _2 * m2, t2[10] = v2 * a2 + b2 * u2 + w2 * f2 + _2 * g2, t2[11] = v2 * s2 + b2 * c2 + w2 * d2 + _2 * x2, t2[12] = (v2 = r2[12]) * n2 + (b2 = r2[13]) * o2 + (w2 = r2[14]) * h2 + (_2 = r2[15]) * y2, t2[13] = v2 * i3 + b2 * l2 + w2 * p2 + _2 * m2, t2[14] = v2 * a2 + b2 * u2 + w2 * f2 + _2 * g2, t2[15] = v2 * s2 + b2 * c2 + w2 * d2 + _2 * x2, t2;
}
Math.hypot || (Math.hypot = function() {
for (var t2 = 0, e2 = arguments.length; e2--; ) t2 += arguments[e2] * arguments[e2];
return Math.sqrt(t2);
});
var Bs, Ps = Cs;
function Vs(t2, e2, r2) {
var n2 = e2[0], i3 = e2[1], a2 = e2[2], s2 = e2[3];
return t2[0] = r2[0] * n2 + r2[4] * i3 + r2[8] * a2 + r2[12] * s2, t2[1] = r2[1] * n2 + r2[5] * i3 + r2[9] * a2 + r2[13] * s2, t2[2] = r2[2] * n2 + r2[6] * i3 + r2[10] * a2 + r2[14] * s2, t2[3] = r2[3] * n2 + r2[7] * i3 + r2[11] * a2 + r2[15] * s2, t2;
}
Bs = new zs(4), zs != Float32Array && (Bs[0] = 0, Bs[1] = 0, Bs[2] = 0, Bs[3] = 0);
class Es extends Si {
constructor(t2) {
super(t2, ks);
}
createBucket(t2) {
return new ls(t2);
}
queryRadius(t2) {
const e2 = t2;
return bs("circle-radius", this, e2) + bs("circle-stroke-width", this, e2) + ws(this.paint.get("circle-translate"));
}
queryIntersectsFeature(t2, e2, r2, n2, i3, a2, s2, o2) {
const l2 = _s(t2, this.paint.get("circle-translate"), this.paint.get("circle-translate-anchor"), a2.angle, s2), u2 = this.paint.get("circle-radius").evaluate(e2, r2) + this.paint.get("circle-stroke-width").evaluate(e2, r2), c2 = "map" === this.paint.get("circle-pitch-alignment"), h2 = c2 ? l2 : (function(t3, e3) {
return t3.map(((t4) => Fs(t4, e3)));
})(l2, o2), p2 = c2 ? u2 * s2 : u2;
for (const t3 of n2) for (const e3 of t3) {
const t4 = c2 ? e3 : Fs(e3, o2);
let r3 = p2;
const n3 = Vs([], [e3.x, e3.y, 0, 1], o2);
if ("viewport" === this.paint.get("circle-pitch-scale") && "map" === this.paint.get("circle-pitch-alignment") ? r3 *= n3[3] / a2.cameraToCenterDistance : "map" === this.paint.get("circle-pitch-scale") && "viewport" === this.paint.get("circle-pitch-alignment") && (r3 *= a2.cameraToCenterDistance / n3[3]), cs(h2, t4, r3)) return true;
}
return false;
}
}
function Fs(t2, e2) {
const r2 = Vs([], [t2.x, t2.y, 0, 1], e2);
return new a(r2[0] / r2[3], r2[1] / r2[3]);
}
class Ts extends ls {
}
let $s;
$n("HeatmapBucket", Ts, { omit: ["layers"] });
var Ls = { get paint() {
return $s = $s || new _i({ "heatmap-radius": new xi(X.paint_heatmap["heatmap-radius"]), "heatmap-weight": new xi(X.paint_heatmap["heatmap-weight"]), "heatmap-intensity": new gi(X.paint_heatmap["heatmap-intensity"]), "heatmap-color": new wi(X.paint_heatmap["heatmap-color"]), "heatmap-opacity": new gi(X.paint_heatmap["heatmap-opacity"]) });
} };
function Ds(t2, { width: e2, height: r2 }, n2, i3) {
if (i3) {
if (i3 instanceof Uint8ClampedArray) i3 = new Uint8Array(i3.buffer);
else if (i3.length !== e2 * r2 * n2) throw new RangeError(`mismatched image size. expected: ${i3.length} but got: ${e2 * r2 * n2}`);
} else i3 = new Uint8Array(e2 * r2 * n2);
return t2.width = e2, t2.height = r2, t2.data = i3, t2;
}
function Os(t2, { width: e2, height: r2 }, n2) {
if (e2 === t2.width && r2 === t2.height) return;
const i3 = Ds({}, { width: e2, height: r2 }, n2);
Us(t2, i3, { x: 0, y: 0 }, { x: 0, y: 0 }, { width: Math.min(t2.width, e2), height: Math.min(t2.height, r2) }, n2), t2.width = e2, t2.height = r2, t2.data = i3.data;
}
function Us(t2, e2, r2, n2, i3, a2) {
if (0 === i3.width || 0 === i3.height) return e2;
if (i3.width > t2.width || i3.height > t2.height || r2.x > t2.width - i3.width || r2.y > t2.height - i3.height) throw new RangeError("out of range source coordinates for image copy");
if (i3.width > e2.width || i3.height > e2.height || n2.x > e2.width - i3.width || n2.y > e2.height - i3.height) throw new RangeError("out of range destination coordinates for image copy");
const s2 = t2.data, o2 = e2.data;
if (s2 === o2) throw new Error("srcData equals dstData, so image is already copied");
for (let l2 = 0; l2 < i3.height; l2++) {
const u2 = ((r2.y + l2) * t2.width + r2.x) * a2, c2 = ((n2.y + l2) * e2.width + n2.x) * a2;
for (let t3 = 0; t3 < i3.width * a2; t3++) o2[c2 + t3] = s2[u2 + t3];
}
return e2;
}
class Rs {
constructor(t2, e2) {
Ds(this, t2, 1, e2);
}
resize(t2) {
Os(this, t2, 1);
}
clone() {
return new Rs({ width: this.width, height: this.height }, new Uint8Array(this.data));
}
static copy(t2, e2, r2, n2, i3) {
Us(t2, e2, r2, n2, i3, 1);
}
}
class qs {
constructor(t2, e2) {
Ds(this, t2, 4, e2);
}
resize(t2) {
Os(this, t2, 4);
}
replace(t2, e2) {
e2 ? this.data.set(t2) : this.data = t2 instanceof Uint8ClampedArray ? new Uint8Array(t2.buffer) : t2;
}
clone() {
return new qs({ width: this.width, height: this.height }, new Uint8Array(this.data));
}
static copy(t2, e2, r2, n2, i3) {
Us(t2, e2, r2, n2, i3, 4);
}
}
function js(t2) {
const e2 = {}, r2 = t2.resolution || 256, n2 = t2.clips ? t2.clips.length : 1, i3 = t2.image || new qs({ width: r2, height: n2 });
if (Math.log(r2) / Math.LN2 % 1 != 0) throw new Error(`width is not a power of 2 - ${r2}`);
const a2 = (r3, n3, a3) => {
e2[t2.evaluationKey] = a3;
const s2 = t2.expression.evaluate(e2);
i3.data[r3 + n3 + 0] = Math.floor(255 * s2.r / s2.a), i3.data[r3 + n3 + 1] = Math.floor(255 * s2.g / s2.a), i3.data[r3 + n3 + 2] = Math.floor(255 * s2.b / s2.a), i3.data[r3 + n3 + 3] = Math.floor(255 * s2.a);
};
if (t2.clips) for (let e3 = 0, i4 = 0; e3 < n2; ++e3, i4 += 4 * r2) for (let n3 = 0, s2 = 0; n3 < r2; n3++, s2 += 4) {
const o2 = n3 / (r2 - 1), { start: l2, end: u2 } = t2.clips[e3];
a2(i4, s2, l2 * (1 - o2) + u2 * o2);
}
else for (let t3 = 0, e3 = 0; t3 < r2; t3++, e3 += 4) a2(0, e3, t3 / (r2 - 1));
return i3;
}
$n("AlphaImage", Rs), $n("RGBAImage", qs);
class Ns extends Si {
createBucket(t2) {
return new Ts(t2);
}
constructor(t2) {
super(t2, Ls), this._updateColorRamp();
}
_handleSpecialPaintPropertyUpdate(t2) {
"heatmap-color" === t2 && this._updateColorRamp();
}
_updateColorRamp() {
this.colorRamp = js({ expression: this._transitionablePaint._values["heatmap-color"].value.expression, evaluationKey: "heatmapDensity", image: this.colorRamp }), this.colorRampTexture = null;
}
resize() {
this.heatmapFbo && (this.heatmapFbo.destroy(), this.heatmapFbo = null);
}
queryRadius() {
return 0;
}
queryIntersectsFeature() {
return false;
}
hasOffscreenPass() {
return 0 !== this.paint.get("heatmap-opacity") && "none" !== this.visibility;
}
}
let Zs;
var Ks = { get paint() {
return Zs = Zs || new _i({ "hillshade-illumination-direction": new gi(X.paint_hillshade["hillshade-illumination-direction"]), "hillshade-illumination-anchor": new gi(X.paint_hillshade["hillshade-illumination-anchor"]), "hillshade-exaggeration": new gi(X.paint_hillshade["hillshade-exaggeration"]), "hillshade-shadow-color": new gi(X.paint_hillshade["hillshade-shadow-color"]), "hillshade-highlight-color": new gi(X.paint_hillshade["hillshade-highlight-color"]), "hillshade-accent-color": new gi(X.paint_hillshade["hillshade-accent-color"]) });
} };
class Gs extends Si {
constructor(t2) {
super(t2, Ks);
}
hasOffscreenPass() {
return 0 !== this.paint.get("hillshade-exaggeration") && "none" !== this.visibility;
}
}
const Js = Mi([{ name: "a_pos", components: 2, type: "Int16" }], 4), { members: Xs } = Js;
var Ys = { exports: {} };
function Hs(t2, e2, r2) {
r2 = r2 || 2;
var n2, i3, a2, s2, o2, l2, u2, c2 = e2 && e2.length, h2 = c2 ? e2[0] * r2 : t2.length, p2 = Ws(t2, 0, h2, r2, true), f2 = [];
if (!p2 || p2.next === p2.prev) return f2;
if (c2 && (p2 = (function(t3, e3, r3, n3) {
var i4, a3, s3, o3 = [];
for (i4 = 0, a3 = e3.length; i4 < a3; i4++) (s3 = Ws(t3, e3[i4] * n3, i4 < a3 - 1 ? e3[i4 + 1] * n3 : t3.length, n3, false)) === s3.next && (s3.steiner = true), o3.push(uo(s3));
for (o3.sort(ao), i4 = 0; i4 < o3.length; i4++) r3 = so(o3[i4], r3);
return r3;
})(t2, e2, p2, r2)), t2.length > 80 * r2) {
n2 = a2 = t2[0], i3 = s2 = t2[1];
for (var d2 = r2; d2 < h2; d2 += r2) (o2 = t2[d2]) < n2 && (n2 = o2), (l2 = t2[d2 + 1]) < i3 && (i3 = l2), o2 > a2 && (a2 = o2), l2 > s2 && (s2 = l2);
u2 = 0 !== (u2 = Math.max(a2 - n2, s2 - i3)) ? 32767 / u2 : 0;
}
return to(p2, f2, r2, n2, i3, u2, 0), f2;
}
function Ws(t2, e2, r2, n2, i3) {
var a2, s2;
if (i3 === Ao(t2, e2, r2, n2) > 0) for (a2 = e2; a2 < r2; a2 += n2) s2 = bo(a2, t2[a2], t2[a2 + 1], s2);
else for (a2 = r2 - n2; a2 >= e2; a2 -= n2) s2 = bo(a2, t2[a2], t2[a2 + 1], s2);
return s2 && fo(s2, s2.next) && (wo(s2), s2 = s2.next), s2;
}
function Qs(t2, e2) {
if (!t2) return t2;
e2 || (e2 = t2);
var r2, n2 = t2;
do {
if (r2 = false, n2.steiner || !fo(n2, n2.next) && 0 !== po(n2.prev, n2, n2.next)) n2 = n2.next;
else {
if (wo(n2), (n2 = e2 = n2.prev) === n2.next) break;
r2 = true;
}
} while (r2 || n2 !== e2);
return e2;
}
function to(t2, e2, r2, n2, i3, a2, s2) {
if (t2) {
!s2 && a2 && (function(t3, e3, r3, n3) {
var i4 = t3;
do {
0 === i4.z && (i4.z = lo(i4.x, i4.y, e3, r3, n3)), i4.prevZ = i4.prev, i4.nextZ = i4.next, i4 = i4.next;
} while (i4 !== t3);
i4.prevZ.nextZ = null, i4.prevZ = null, (function(t4) {
var e4, r4, n4, i5, a3, s3, o3, l3, u3 = 1;
do {
for (r4 = t4, t4 = null, a3 = null, s3 = 0; r4; ) {
for (s3++, n4 = r4, o3 = 0, e4 = 0; e4 < u3 && (o3++, n4 = n4.nextZ); e4++) ;
for (l3 = u3; o3 > 0 || l3 > 0 && n4; ) 0 !== o3 && (0 === l3 || !n4 || r4.z <= n4.z) ? (i5 = r4, r4 = r4.nextZ, o3--) : (i5 = n4, n4 = n4.nextZ, l3--), a3 ? a3.nextZ = i5 : t4 = i5, i5.prevZ = a3, a3 = i5;
r4 = n4;
}
a3.nextZ = null, u3 *= 2;
} while (s3 > 1);
})(i4);
})(t2, n2, i3, a2);
for (var o2, l2, u2 = t2; t2.prev !== t2.next; ) if (o2 = t2.prev, l2 = t2.next, a2 ? ro(t2, n2, i3, a2) : eo(t2)) e2.push(o2.i / r2 | 0), e2.push(t2.i / r2 | 0), e2.push(l2.i / r2 | 0), wo(t2), t2 = l2.next, u2 = l2.next;
else if ((t2 = l2) === u2) {
s2 ? 1 === s2 ? to(t2 = no(Qs(t2), e2, r2), e2, r2, n2, i3, a2, 2) : 2 === s2 && io(t2, e2, r2, n2, i3, a2) : to(Qs(t2), e2, r2, n2, i3, a2, 1);
break;
}
}
}
function eo(t2) {
var e2 = t2.prev, r2 = t2, n2 = t2.next;
if (po(e2, r2, n2) >= 0) return false;
for (var i3 = e2.x, a2 = r2.x, s2 = n2.x, o2 = e2.y, l2 = r2.y, u2 = n2.y, c2 = i3 < a2 ? i3 < s2 ? i3 : s2 : a2 < s2 ? a2 : s2, h2 = o2 < l2 ? o2 < u2 ? o2 : u2 : l2 < u2 ? l2 : u2, p2 = i3 > a2 ? i3 > s2 ? i3 : s2 : a2 > s2 ? a2 : s2, f2 = o2 > l2 ? o2 > u2 ? o2 : u2 : l2 > u2 ? l2 : u2, d2 = n2.next; d2 !== e2; ) {
if (d2.x >= c2 && d2.x <= p2 && d2.y >= h2 && d2.y <= f2 && co(i3, o2, a2, l2, s2, u2, d2.x, d2.y) && po(d2.prev, d2, d2.next) >= 0) return false;
d2 = d2.next;
}
return true;
}
function ro(t2, e2, r2, n2) {
var i3 = t2.prev, a2 = t2, s2 = t2.next;
if (po(i3, a2, s2) >= 0) return false;
for (var o2 = i3.x, l2 = a2.x, u2 = s2.x, c2 = i3.y, h2 = a2.y, p2 = s2.y, f2 = o2 < l2 ? o2 < u2 ? o2 : u2 : l2 < u2 ? l2 : u2, d2 = c2 < h2 ? c2 < p2 ? c2 : p2 : h2 < p2 ? h2 : p2, y2 = o2 > l2 ? o2 > u2 ? o2 : u2 : l2 > u2 ? l2 : u2, m2 = c2 > h2 ? c2 > p2 ? c2 : p2 : h2 > p2 ? h2 : p2, g2 = lo(f2, d2, e2, r2, n2), x2 = lo(y2, m2, e2, r2, n2), v2 = t2.prevZ, b2 = t2.nextZ; v2 && v2.z >= g2 && b2 && b2.z <= x2; ) {
if (v2.x >= f2 && v2.x <= y2 && v2.y >= d2 && v2.y <= m2 && v2 !== i3 && v2 !== s2 && co(o2, c2, l2, h2, u2, p2, v2.x, v2.y) && po(v2.prev, v2, v2.next) >= 0) return false;
if (v2 = v2.prevZ, b2.x >= f2 && b2.x <= y2 && b2.y >= d2 && b2.y <= m2 && b2 !== i3 && b2 !== s2 && co(o2, c2, l2, h2, u2, p2, b2.x, b2.y) && po(b2.prev, b2, b2.next) >= 0) return false;
b2 = b2.nextZ;
}
for (; v2 && v2.z >= g2; ) {
if (v2.x >= f2 && v2.x <= y2 && v2.y >= d2 && v2.y <= m2 && v2 !== i3 && v2 !== s2 && co(o2, c2, l2, h2, u2, p2, v2.x, v2.y) && po(v2.prev, v2, v2.next) >= 0) return false;
v2 = v2.prevZ;
}
for (; b2 && b2.z <= x2; ) {
if (b2.x >= f2 && b2.x <= y2 && b2.y >= d2 && b2.y <= m2 && b2 !== i3 && b2 !== s2 && co(o2, c2, l2, h2, u2, p2, b2.x, b2.y) && po(b2.prev, b2, b2.next) >= 0) return false;
b2 = b2.nextZ;
}
return true;
}
function no(t2, e2, r2) {
var n2 = t2;
do {
var i3 = n2.prev, a2 = n2.next.next;
!fo(i3, a2) && yo(i3, n2, n2.next, a2) && xo(i3, a2) && xo(a2, i3) && (e2.push(i3.i / r2 | 0), e2.push(n2.i / r2 | 0), e2.push(a2.i / r2 | 0), wo(n2), wo(n2.next), n2 = t2 = a2), n2 = n2.next;
} while (n2 !== t2);
return Qs(n2);
}
function io(t2, e2, r2, n2, i3, a2) {
var s2 = t2;
do {
for (var o2 = s2.next.next; o2 !== s2.prev; ) {
if (s2.i !== o2.i && ho(s2, o2)) {
var l2 = vo(s2, o2);
return s2 = Qs(s2, s2.next), l2 = Qs(l2, l2.next), to(s2, e2, r2, n2, i3, a2, 0), void to(l2, e2, r2, n2, i3, a2, 0);
}
o2 = o2.next;
}
s2 = s2.next;
} while (s2 !== t2);
}
function ao(t2, e2) {
return t2.x - e2.x;
}
function so(t2, e2) {
var r2 = (function(t3, e3) {
var r3, n3 = e3, i3 = t3.x, a2 = t3.y, s2 = -1 / 0;
do {
if (a2 <= n3.y && a2 >= n3.next.y && n3.next.y !== n3.y) {
var o2 = n3.x + (a2 - n3.y) * (n3.next.x - n3.x) / (n3.next.y - n3.y);
if (o2 <= i3 && o2 > s2 && (s2 = o2, r3 = n3.x < n3.next.x ? n3 : n3.next, o2 === i3)) return r3;
}
n3 = n3.next;
} while (n3 !== e3);
if (!r3) return null;
var l2, u2 = r3, c2 = r3.x, h2 = r3.y, p2 = 1 / 0;
n3 = r3;
do {
i3 >= n3.x && n3.x >= c2 && i3 !== n3.x && co(a2 < h2 ? i3 : s2, a2, c2, h2, a2 < h2 ? s2 : i3, a2, n3.x, n3.y) && (l2 = Math.abs(a2 - n3.y) / (i3 - n3.x), xo(n3, t3) && (l2 < p2 || l2 === p2 && (n3.x > r3.x || n3.x === r3.x && oo(r3, n3))) && (r3 = n3, p2 = l2)), n3 = n3.next;
} while (n3 !== u2);
return r3;
})(t2, e2);
if (!r2) return e2;
var n2 = vo(r2, t2);
return Qs(n2, n2.next), Qs(r2, r2.next);
}
function oo(t2, e2) {
return po(t2.prev, t2, e2.prev) < 0 && po(e2.next, t2, t2.next) < 0;
}
function lo(t2, e2, r2, n2, i3) {
return (t2 = 1431655765 & ((t2 = 858993459 & ((t2 = 252645135 & ((t2 = 16711935 & ((t2 = (t2 - r2) * i3 | 0) | t2 << 8)) | t2 << 4)) | t2 << 2)) | t2 << 1)) | (e2 = 1431655765 & ((e2 = 858993459 & ((e2 = 252645135 & ((e2 = 16711935 & ((e2 = (e2 - n2) * i3 | 0) | e2 << 8)) | e2 << 4)) | e2 << 2)) | e2 << 1)) << 1;
}
function uo(t2) {
var e2 = t2, r2 = t2;
do {
(e2.x < r2.x || e2.x === r2.x && e2.y < r2.y) && (r2 = e2), e2 = e2.next;
} while (e2 !== t2);
return r2;
}
function co(t2, e2, r2, n2, i3, a2, s2, o2) {
return (i3 - s2) * (e2 - o2) >= (t2 - s2) * (a2 - o2) && (t2 - s2) * (n2 - o2) >= (r2 - s2) * (e2 - o2) && (r2 - s2) * (a2 - o2) >= (i3 - s2) * (n2 - o2);
}
function ho(t2, e2) {
return t2.next.i !== e2.i && t2.prev.i !== e2.i && !(function(t3, e3) {
var r2 = t3;
do {
if (r2.i !== t3.i && r2.next.i !== t3.i && r2.i !== e3.i && r2.next.i !== e3.i && yo(r2, r2.next, t3, e3)) return true;
r2 = r2.next;
} while (r2 !== t3);
return false;
})(t2, e2) && (xo(t2, e2) && xo(e2, t2) && (function(t3, e3) {
var r2 = t3, n2 = false, i3 = (t3.x + e3.x) / 2, a2 = (t3.y + e3.y) / 2;
do {
r2.y > a2 != r2.next.y > a2 && r2.next.y !== r2.y && i3 < (r2.next.x - r2.x) * (a2 - r2.y) / (r2.next.y - r2.y) + r2.x && (n2 = !n2), r2 = r2.next;
} while (r2 !== t3);
return n2;
})(t2, e2) && (po(t2.prev, t2, e2.prev) || po(t2, e2.prev, e2)) || fo(t2, e2) && po(t2.prev, t2, t2.next) > 0 && po(e2.prev, e2, e2.next) > 0);
}
function po(t2, e2, r2) {
return (e2.y - t2.y) * (r2.x - e2.x) - (e2.x - t2.x) * (r2.y - e2.y);
}
function fo(t2, e2) {
return t2.x === e2.x && t2.y === e2.y;
}
function yo(t2, e2, r2, n2) {
var i3 = go(po(t2, e2, r2)), a2 = go(po(t2, e2, n2)), s2 = go(po(r2, n2, t2)), o2 = go(po(r2, n2, e2));
return i3 !== a2 && s2 !== o2 || !(0 !== i3 || !mo(t2, r2, e2)) || !(0 !== a2 || !mo(t2, n2, e2)) || !(0 !== s2 || !mo(r2, t2, n2)) || !(0 !== o2 || !mo(r2, e2, n2));
}
function mo(t2, e2, r2) {
return e2.x <= Math.max(t2.x, r2.x) && e2.x >= Math.min(t2.x, r2.x) && e2.y <= Math.max(t2.y, r2.y) && e2.y >= Math.min(t2.y, r2.y);
}
function go(t2) {
return t2 > 0 ? 1 : t2 < 0 ? -1 : 0;
}
function xo(t2, e2) {
return po(t2.prev, t2, t2.next) < 0 ? po(t2, e2, t2.next) >= 0 && po(t2, t2.prev, e2) >= 0 : po(t2, e2, t2.prev) < 0 || po(t2, t2.next, e2) < 0;
}
function vo(t2, e2) {
var r2 = new _o(t2.i, t2.x, t2.y), n2 = new _o(e2.i, e2.x, e2.y), i3 = t2.next, a2 = e2.prev;
return t2.next = e2, e2.prev = t2, r2.next = i3, i3.prev = r2, n2.next = r2, r2.prev = n2, a2.next = n2, n2.prev = a2, n2;
}
function bo(t2, e2, r2, n2) {
var i3 = new _o(t2, e2, r2);
return n2 ? (i3.next = n2.next, i3.prev = n2, n2.next.prev = i3, n2.next = i3) : (i3.prev = i3, i3.next = i3), i3;
}
function wo(t2) {
t2.next.prev = t2.prev, t2.prev.next = t2.next, t2.prevZ && (t2.prevZ.nextZ = t2.nextZ), t2.nextZ && (t2.nextZ.prevZ = t2.prevZ);
}
function _o(t2, e2, r2) {
this.i = t2, this.x = e2, this.y = r2, this.prev = null, this.next = null, this.z = 0, this.prevZ = null, this.nextZ = null, this.steiner = false;
}
function Ao(t2, e2, r2, n2) {
for (var i3 = 0, a2 = e2, s2 = r2 - n2; a2 < r2; a2 += n2) i3 += (t2[s2] - t2[a2]) * (t2[a2 + 1] + t2[s2 + 1]), s2 = a2;
return i3;
}
Ys.exports = Hs, Ys.exports.default = Hs, Hs.deviation = function(t2, e2, r2, n2) {
var i3 = e2 && e2.length, a2 = Math.abs(Ao(t2, 0, i3 ? e2[0] * r2 : t2.length, r2));
if (i3) for (var s2 = 0, o2 = e2.length; s2 < o2; s2++) a2 -= Math.abs(Ao(t2, e2[s2] * r2, s2 < o2 - 1 ? e2[s2 + 1] * r2 : t2.length, r2));
var l2 = 0;
for (s2 = 0; s2 < n2.length; s2 += 3) {
var u2 = n2[s2] * r2, c2 = n2[s2 + 1] * r2, h2 = n2[s2 + 2] * r2;
l2 += Math.abs((t2[u2] - t2[h2]) * (t2[c2 + 1] - t2[u2 + 1]) - (t2[u2] - t2[c2]) * (t2[h2 + 1] - t2[u2 + 1]));
}
return 0 === a2 && 0 === l2 ? 0 : Math.abs((l2 - a2) / a2);
}, Hs.flatten = function(t2) {
for (var e2 = t2[0][0].length, r2 = { vertices: [], holes: [], dimensions: e2 }, n2 = 0, i3 = 0; i3 < t2.length; i3++) {
for (var a2 = 0; a2 < t2[i3].length; a2++) for (var s2 = 0; s2 < e2; s2++) r2.vertices.push(t2[i3][a2][s2]);
i3 > 0 && r2.holes.push(n2 += t2[i3 - 1].length);
}
return r2;
};
var So = r(Ys.exports);
function ko(t2, e2, r2, n2, i3) {
Io(t2, e2, r2, n2 || t2.length - 1, i3 || Mo);
}
function Io(t2, e2, r2, n2, i3) {
for (; n2 > r2; ) {
if (n2 - r2 > 600) {
var a2 = n2 - r2 + 1, s2 = e2 - r2 + 1, o2 = Math.log(a2), l2 = 0.5 * Math.exp(2 * o2 / 3), u2 = 0.5 * Math.sqrt(o2 * l2 * (a2 - l2) / a2) * (s2 - a2 / 2 < 0 ? -1 : 1);
Io(t2, e2, Math.max(r2, Math.floor(e2 - s2 * l2 / a2 + u2)), Math.min(n2, Math.floor(e2 + (a2 - s2) * l2 / a2 + u2)), i3);
}
var c2 = t2[e2], h2 = r2, p2 = n2;
for (zo(t2, r2, e2), i3(t2[n2], c2) > 0 && zo(t2, r2, n2); h2 < p2; ) {
for (zo(t2, h2, p2), h2++, p2--; i3(t2[h2], c2) < 0; ) h2++;
for (; i3(t2[p2], c2) > 0; ) p2--;
}
0 === i3(t2[r2], c2) ? zo(t2, r2, p2) : zo(t2, ++p2, n2), p2 <= e2 && (r2 = p2 + 1), e2 <= p2 && (n2 = p2 - 1);
}
}
function zo(t2, e2, r2) {
var n2 = t2[e2];
t2[e2] = t2[r2], t2[r2] = n2;
}
function Mo(t2, e2) {
return t2 < e2 ? -1 : t2 > e2 ? 1 : 0;
}
function Co(t2, e2) {
const r2 = t2.length;
if (r2 <= 1) return [t2];
const n2 = [];
let i3, a2;
for (let e3 = 0; e3 < r2; e3++) {
const r3 = k(t2[e3]);
0 !== r3 && (t2[e3].area = Math.abs(r3), void 0 === a2 && (a2 = r3 < 0), a2 === r3 < 0 ? (i3 && n2.push(i3), i3 = [t2[e3]]) : i3.push(t2[e3]));
}
if (i3 && n2.push(i3), e2 > 1) for (let t3 = 0; t3 < n2.length; t3++) n2[t3].length <= e2 || (ko(n2[t3], e2, 1, n2[t3].length - 1, Bo), n2[t3] = n2[t3].slice(0, e2));
return n2;
}
function Bo(t2, e2) {
return e2.area - t2.area;
}
function Po(t2, e2, r2) {
const n2 = r2.patternDependencies;
let i3 = false;
for (const r3 of e2) {
const e3 = r3.paint.get(`${t2}-pattern`);
e3.isConstant() || (i3 = true);
const a2 = e3.constantOr(null);
a2 && (i3 = true, n2[a2.to] = true, n2[a2.from] = true);
}
return i3;
}
function Vo(t2, e2, r2, n2, i3) {
const a2 = i3.patternDependencies;
for (const s2 of e2) {
const e3 = s2.paint.get(`${t2}-pattern`).value;
if ("constant" !== e3.kind) {
let t3 = e3.evaluate({ zoom: n2 - 1 }, r2, {}, i3.availableImages), o2 = e3.evaluate({ zoom: n2 }, r2, {}, i3.availableImages), l2 = e3.evaluate({ zoom: n2 + 1 }, r2, {}, i3.availableImages);
t3 = t3 && t3.name ? t3.name : t3, o2 = o2 && o2.name ? o2.name : o2, l2 = l2 && l2.name ? l2.name : l2, a2[t3] = true, a2[o2] = true, a2[l2] = true, r2.patterns[s2.id] = { min: t3, mid: o2, max: l2 };
}
}
return r2;
}
class Eo {
constructor(t2) {
this.zoom = t2.zoom, this.overscaling = t2.overscaling, this.layers = t2.layers, this.layerIds = this.layers.map(((t3) => t3.id)), this.index = t2.index, this.hasPattern = false, this.patternFeatures = [], this.layoutVertexArray = new fa(), this.indexArray = new Aa(), this.indexArray2 = new Sa(), this.programConfigurations = new Qa(t2.layers, t2.zoom), this.segments = new za(), this.segments2 = new za(), this.stateDependentLayerIds = this.layers.filter(((t3) => t3.isStateDependent())).map(((t3) => t3.id));
}
populate(t2, e2, r2) {
this.hasPattern = Po("fill", this.layers, e2);
const n2 = this.layers[0].layout.get("fill-sort-key"), i3 = !n2.isConstant(), a2 = [];
for (const { feature: s2, id: o2, index: l2, sourceLayerIndex: u2 } of t2) {
const t3 = this.layers[0]._featureFilter.needGeometry, c2 = ss(s2, t3);
if (!this.layers[0]._featureFilter.filter(new li(this.zoom), c2, r2)) continue;
const h2 = i3 ? n2.evaluate(c2, {}, r2, e2.availableImages) : void 0, p2 = { id: o2, properties: s2.properties, type: s2.type, sourceLayerIndex: u2, index: l2, geometry: t3 ? c2.geometry : as(s2), patterns: {}, sortKey: h2 };
a2.push(p2);
}
i3 && a2.sort(((t3, e3) => t3.sortKey - e3.sortKey));
for (const n3 of a2) {
const { geometry: i4, index: a3, sourceLayerIndex: s2 } = n3;
if (this.hasPattern) {
const t3 = Vo("fill", this.layers, n3, this.zoom, e2);
this.patternFeatures.push(t3);
} else this.addFeature(n3, i4, a3, r2, {});
e2.featureIndex.insert(t2[a3].feature, i4, a3, s2, this.index);
}
}
update(t2, e2, r2) {
this.stateDependentLayers.length && this.programConfigurations.updatePaintArrays(t2, e2, this.stateDependentLayers, r2);
}
addFeatures(t2, e2, r2) {
for (const t3 of this.patternFeatures) this.addFeature(t3, t3.geometry, t3.index, e2, r2);
}
isEmpty() {
return 0 === this.layoutVertexArray.length;
}
uploadPending() {
return !this.uploaded || this.programConfigurations.needsUpload;
}
upload(t2) {
this.uploaded || (this.layoutVertexBuffer = t2.createVertexBuffer(this.layoutVertexArray, Xs), this.indexBuffer = t2.createIndexBuffer(this.indexArray), this.indexBuffer2 = t2.createIndexBuffer(this.indexArray2)), this.programConfigurations.upload(t2), this.uploaded = true;
}
destroy() {
this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.indexBuffer.destroy(), this.indexBuffer2.destroy(), this.programConfigurations.destroy(), this.segments.destroy(), this.segments2.destroy());
}
addFeature(t2, e2, r2, n2, i3) {
for (const t3 of Co(e2, 500)) {
let e3 = 0;
for (const r4 of t3) e3 += r4.length;
const r3 = this.segments.prepareSegment(e3, this.layoutVertexArray, this.indexArray), n3 = r3.vertexLength, i4 = [], a2 = [];
for (const e4 of t3) {
if (0 === e4.length) continue;
e4 !== t3[0] && a2.push(i4.length / 2);
const r4 = this.segments2.prepareSegment(e4.length, this.layoutVertexArray, this.indexArray2), n4 = r4.vertexLength;
this.layoutVertexArray.emplaceBack(e4[0].x, e4[0].y), this.indexArray2.emplaceBack(n4 + e4.length - 1, n4), i4.push(e4[0].x), i4.push(e4[0].y);
for (let t4 = 1; t4 < e4.length; t4++) this.layoutVertexArray.emplaceBack(e4[t4].x, e4[t4].y), this.indexArray2.emplaceBack(n4 + t4 - 1, n4 + t4), i4.push(e4[t4].x), i4.push(e4[t4].y);
r4.vertexLength += e4.length, r4.primitiveLength += e4.length;
}
const s2 = So(i4, a2);
for (let t4 = 0; t4 < s2.length; t4 += 3) this.indexArray.emplaceBack(n3 + s2[t4], n3 + s2[t4 + 1], n3 + s2[t4 + 2]);
r3.vertexLength += e3, r3.primitiveLength += s2.length / 3;
}
this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, t2, r2, i3, n2);
}
}
let Fo, To;
$n("FillBucket", Eo, { omit: ["layers", "patternFeatures"] });
var $o = { get paint() {
return To = To || new _i({ "fill-antialias": new gi(X.paint_fill["fill-antialias"]), "fill-opacity": new xi(X.paint_fill["fill-opacity"]), "fill-color": new xi(X.paint_fill["fill-color"]), "fill-outline-color": new xi(X.paint_fill["fill-outline-color"]), "fill-translate": new gi(X.paint_fill["fill-translate"]), "fill-translate-anchor": new gi(X.paint_fill["fill-translate-anchor"]), "fill-pattern": new vi(X.paint_fill["fill-pattern"]) });
}, get layout() {
return Fo = Fo || new _i({ "fill-sort-key": new xi(X.layout_fill["fill-sort-key"]) });
} };
class Lo extends Si {
constructor(t2) {
super(t2, $o);
}
recalculate(t2, e2) {
super.recalculate(t2, e2);
const r2 = this.paint._values["fill-outline-color"];
"constant" === r2.value.kind && void 0 === r2.value.value && (this.paint._values["fill-outline-color"] = this.paint._values["fill-color"]);
}
createBucket(t2) {
return new Eo(t2);
}
queryRadius() {
return ws(this.paint.get("fill-translate"));
}
queryIntersectsFeature(t2, e2, r2, n2, i3, a2, s2) {
return hs(_s(t2, this.paint.get("fill-translate"), this.paint.get("fill-translate-anchor"), a2.angle, s2), n2);
}
isTileClipped() {
return true;
}
}
const Do = Mi([{ name: "a_pos", components: 2, type: "Int16" }, { name: "a_normal_ed", components: 4, type: "Int16" }], 4), Oo = Mi([{ name: "a_centroid", components: 2, type: "Int16" }], 4), { members: Uo } = Do;
var Ro = {}, qo = n, jo = No;
function No(t2, e2, r2, n2, i3) {
this.properties = {}, this.extent = r2, this.type = 0, this._pbf = t2, this._geometry = -1, this._keys = n2, this._values = i3, t2.readFields(Zo, this, e2);
}
function Zo(t2, e2, r2) {
1 == t2 ? e2.id = r2.readVarint() : 2 == t2 ? (function(t3, e3) {
for (var r3 = t3.readVarint() + t3.pos; t3.pos < r3; ) {
var n2 = e3._keys[t3.readVarint()], i3 = e3._values[t3.readVarint()];
e3.properties[n2] = i3;
}
})(r2, e2) : 3 == t2 ? e2.type = r2.readVarint() : 4 == t2 && (e2._geometry = r2.pos);
}
function Ko(t2) {
for (var e2, r2, n2 = 0, i3 = 0, a2 = t2.length, s2 = a2 - 1; i3 < a2; s2 = i3++) n2 += ((r2 = t2[s2]).x - (e2 = t2[i3]).x) * (e2.y + r2.y);
return n2;
}
No.types = ["Unknown", "Point", "LineString", "Polygon"], No.prototype.loadGeometry = function() {
var t2 = this._pbf;
t2.pos = this._geometry;
for (var e2, r2 = t2.readVarint() + t2.pos, n2 = 1, i3 = 0, a2 = 0, s2 = 0, o2 = []; t2.pos < r2; ) {
if (i3 <= 0) {
var l2 = t2.readVarint();
n2 = 7 & l2, i3 = l2 >> 3;
}
if (i3--, 1 === n2 || 2 === n2) a2 += t2.readSVarint(), s2 += t2.readSVarint(), 1 === n2 && (e2 && o2.push(e2), e2 = []), e2.push(new qo(a2, s2));
else {
if (7 !== n2) throw new Error("unknown command " + n2);
e2 && e2.push(e2[0].clone());
}
}
return e2 && o2.push(e2), o2;
}, No.prototype.bbox = function() {
var t2 = this._pbf;
t2.pos = this._geometry;
for (var e2 = t2.readVarint() + t2.pos, r2 = 1, n2 = 0, i3 = 0, a2 = 0, s2 = 1 / 0, o2 = -1 / 0, l2 = 1 / 0, u2 = -1 / 0; t2.pos < e2; ) {
if (n2 <= 0) {
var c2 = t2.readVarint();
r2 = 7 & c2, n2 = c2 >> 3;
}
if (n2--, 1 === r2 || 2 === r2) (i3 += t2.readSVarint()) < s2 && (s2 = i3), i3 > o2 && (o2 = i3), (a2 += t2.readSVarint()) < l2 && (l2 = a2), a2 > u2 && (u2 = a2);
else if (7 !== r2) throw new Error("unknown command " + r2);
}
return [s2, l2, o2, u2];
}, No.prototype.toGeoJSON = function(t2, e2, r2) {
var n2, i3, a2 = this.extent * Math.pow(2, r2), s2 = this.extent * t2, o2 = this.extent * e2, l2 = this.loadGeometry(), u2 = No.types[this.type];
function c2(t3) {
for (var e3 = 0; e3 < t3.length; e3++) {
var r3 = t3[e3];
t3[e3] = [360 * (r3.x + s2) / a2 - 180, 360 / Math.PI * Math.atan(Math.exp((180 - 360 * (r3.y + o2) / a2) * Math.PI / 180)) - 90];
}
}
switch (this.type) {
case 1:
var h2 = [];
for (n2 = 0; n2 < l2.length; n2++) h2[n2] = l2[n2][0];
c2(l2 = h2);
break;
case 2:
for (n2 = 0; n2 < l2.length; n2++) c2(l2[n2]);
break;
case 3:
for (l2 = (function(t3) {
var e3 = t3.length;
if (e3 <= 1) return [t3];
for (var r3, n3, i4 = [], a3 = 0; a3 < e3; a3++) {
var s3 = Ko(t3[a3]);
0 !== s3 && (void 0 === n3 && (n3 = s3 < 0), n3 === s3 < 0 ? (r3 && i4.push(r3), r3 = [t3[a3]]) : r3.push(t3[a3]));
}
return r3 && i4.push(r3), i4;
})(l2), n2 = 0; n2 < l2.length; n2++) for (i3 = 0; i3 < l2[n2].length; i3++) c2(l2[n2][i3]);
}
1 === l2.length ? l2 = l2[0] : u2 = "Multi" + u2;
var p2 = { type: "Feature", geometry: { type: u2, coordinates: l2 }, properties: this.properties };
return "id" in this && (p2.id = this.id), p2;
};
var Go = jo, Jo = Xo;
function Xo(t2, e2) {
this.version = 1, this.name = null, this.extent = 4096, this.length = 0, this._pbf = t2, this._keys = [], this._values = [], this._features = [], t2.readFields(Yo, this, e2), this.length = this._features.length;
}
function Yo(t2, e2, r2) {
15 === t2 ? e2.version = r2.readVarint() : 1 === t2 ? e2.name = r2.readString() : 5 === t2 ? e2.extent = r2.readVarint() : 2 === t2 ? e2._features.push(r2.pos) : 3 === t2 ? e2._keys.push(r2.readString()) : 4 === t2 && e2._values.push((function(t3) {
for (var e3 = null, r3 = t3.readVarint() + t3.pos; t3.pos < r3; ) {
var n2 = t3.readVarint() >> 3;
e3 = 1 === n2 ? t3.readString() : 2 === n2 ? t3.readFloat() : 3 === n2 ? t3.readDouble() : 4 === n2 ? t3.readVarint64() : 5 === n2 ? t3.readVarint() : 6 === n2 ? t3.readSVarint() : 7 === n2 ? t3.readBoolean() : null;
}
return e3;
})(r2));
}
Xo.prototype.feature = function(t2) {
if (t2 < 0 || t2 >= this._features.length) throw new Error("feature index out of bounds");
this._pbf.pos = this._features[t2];
var e2 = this._pbf.readVarint() + this._pbf.pos;
return new Go(this._pbf, e2, this.extent, this._keys, this._values);
};
var Ho = Jo;
function Wo(t2, e2, r2) {
if (3 === t2) {
var n2 = new Ho(r2, r2.readVarint() + r2.pos);
n2.length && (e2[n2.name] = n2);
}
}
Ro.VectorTile = function(t2, e2) {
this.layers = t2.readFields(Wo, {}, e2);
}, Ro.VectorTileFeature = jo, Ro.VectorTileLayer = Jo;
const Qo = Ro.VectorTileFeature.types, tl = Math.pow(2, 13);
function el(t2, e2, r2, n2, i3, a2, s2, o2) {
t2.emplaceBack(e2, r2, 2 * Math.floor(n2 * tl) + s2, i3 * tl * 2, a2 * tl * 2, Math.round(o2));
}
class rl {
constructor(t2) {
this.zoom = t2.zoom, this.overscaling = t2.overscaling, this.layers = t2.layers, this.layerIds = this.layers.map(((t3) => t3.id)), this.index = t2.index, this.hasPattern = false, this.layoutVertexArray = new da(), this.centroidVertexArray = new ha(), this.indexArray = new Aa(), this.programConfigurations = new Qa(t2.layers, t2.zoom), this.segments = new za(), this.stateDependentLayerIds = this.layers.filter(((t3) => t3.isStateDependent())).map(((t3) => t3.id));
}
populate(t2, e2, r2) {
this.features = [], this.hasPattern = Po("fill-extrusion", this.layers, e2);
for (const { feature: n2, id: i3, index: a2, sourceLayerIndex: s2 } of t2) {
const t3 = this.layers[0]._featureFilter.needGeometry, o2 = ss(n2, t3);
if (!this.layers[0]._featureFilter.filter(new li(this.zoom), o2, r2)) continue;
const l2 = { id: i3, sourceLayerIndex: s2, index: a2, geometry: t3 ? o2.geometry : as(n2), properties: n2.properties, type: n2.type, patterns: {} };
this.hasPattern ? this.features.push(Vo("fill-extrusion", this.layers, l2, this.zoom, e2)) : this.addFeature(l2, l2.geometry, a2, r2, {}), e2.featureIndex.insert(n2, l2.geometry, a2, s2, this.index, true);
}
}
addFeatures(t2, e2, r2) {
for (const t3 of this.features) {
const { geometry: n2 } = t3;
this.addFeature(t3, n2, t3.index, e2, r2);
}
}
update(t2, e2, r2) {
this.stateDependentLayers.length && this.programConfigurations.updatePaintArrays(t2, e2, this.stateDependentLayers, r2);
}
isEmpty() {
return 0 === this.layoutVertexArray.length && 0 === this.centroidVertexArray.length;
}
uploadPending() {
return !this.uploaded || this.programConfigurations.needsUpload;
}
upload(t2) {
this.uploaded || (this.layoutVertexBuffer = t2.createVertexBuffer(this.layoutVertexArray, Uo), this.centroidVertexBuffer = t2.createVertexBuffer(this.centroidVertexArray, Oo.members, true), this.indexBuffer = t2.createIndexBuffer(this.indexArray)), this.programConfigurations.upload(t2), this.uploaded = true;
}
destroy() {
this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.indexBuffer.destroy(), this.programConfigurations.destroy(), this.segments.destroy(), this.centroidVertexBuffer.destroy());
}
addFeature(t2, e2, r2, n2, i3) {
const a2 = { x: 0, y: 0, vertexCount: 0 };
for (const r3 of Co(e2, 500)) {
let e3 = 0;
for (const t3 of r3) e3 += t3.length;
let n3 = this.segments.prepareSegment(4, this.layoutVertexArray, this.indexArray);
for (const t3 of r3) {
if (0 === t3.length) continue;
if (il(t3)) continue;
let e4 = 0;
for (let r4 = 0; r4 < t3.length; r4++) {
const i5 = t3[r4];
if (r4 >= 1) {
const s3 = t3[r4 - 1];
if (!nl(i5, s3)) {
n3.vertexLength + 4 > za.MAX_VERTEX_ARRAY_LENGTH && (n3 = this.segments.prepareSegment(4, this.layoutVertexArray, this.indexArray));
const t4 = i5.sub(s3)._perp()._unit(), r5 = s3.dist(i5);
e4 + r5 > 32768 && (e4 = 0), el(this.layoutVertexArray, i5.x, i5.y, t4.x, t4.y, 0, 0, e4), el(this.layoutVertexArray, i5.x, i5.y, t4.x, t4.y, 0, 1, e4), a2.x += 2 * i5.x, a2.y += 2 * i5.y, a2.vertexCount += 2, e4 += r5, el(this.layoutVertexArray, s3.x, s3.y, t4.x, t4.y, 0, 0, e4), el(this.layoutVertexArray, s3.x, s3.y, t4.x, t4.y, 0, 1, e4), a2.x += 2 * s3.x, a2.y += 2 * s3.y, a2.vertexCount += 2;
const o3 = n3.vertexLength;
this.indexArray.emplaceBack(o3, o3 + 2, o3 + 1), this.indexArray.emplaceBack(o3 + 1, o3 + 2, o3 + 3), n3.vertexLength += 4, n3.primitiveLength += 2;
}
}
}
}
if (n3.vertexLength + e3 > za.MAX_VERTEX_ARRAY_LENGTH && (n3 = this.segments.prepareSegment(e3, this.layoutVertexArray, this.indexArray)), "Polygon" !== Qo[t2.type]) continue;
const i4 = [], s2 = [], o2 = n3.vertexLength;
for (const t3 of r3) if (0 !== t3.length) {
t3 !== r3[0] && s2.push(i4.length / 2);
for (let e4 = 0; e4 < t3.length; e4++) {
const r4 = t3[e4];
el(this.layoutVertexArray, r4.x, r4.y, 0, 0, 1, 1, 0), a2.x += r4.x, a2.y += r4.y, a2.vertexCount += 1, i4.push(r4.x), i4.push(r4.y);
}
}
const l2 = So(i4, s2);
for (let t3 = 0; t3 < l2.length; t3 += 3) this.indexArray.emplaceBack(o2 + l2[t3], o2 + l2[t3 + 2], o2 + l2[t3 + 1]);
n3.primitiveLength += l2.length / 3, n3.vertexLength += e3;
}
for (let t3 = 0; t3 < a2.vertexCount; t3++) this.centroidVertexArray.emplaceBack(Math.floor(a2.x / a2.vertexCount), Math.floor(a2.y / a2.vertexCount));
this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, t2, r2, i3, n2);
}
}
function nl(t2, e2) {
return t2.x === e2.x && (t2.x < 0 || t2.x > rs) || t2.y === e2.y && (t2.y < 0 || t2.y > rs);
}
function il(t2) {
return t2.every(((t3) => t3.x < 0)) || t2.every(((t3) => t3.x > rs)) || t2.every(((t3) => t3.y < 0)) || t2.every(((t3) => t3.y > rs));
}
let al;
$n("FillExtrusionBucket", rl, { omit: ["layers", "features"] });
var sl = { get paint() {
return al = al || new _i({ "fill-extrusion-opacity": new gi(X["paint_fill-extrusion"]["fill-extrusion-opacity"]), "fill-extrusion-color": new xi(X["paint_fill-extrusion"]["fill-extrusion-color"]), "fill-extrusion-translate": new gi(X["paint_fill-extrusion"]["fill-extrusion-translate"]), "fill-extrusion-translate-anchor": new gi(X["paint_fill-extrusion"]["fill-extrusion-translate-anchor"]), "fill-extrusion-pattern": new vi(X["paint_fill-extrusion"]["fill-extrusion-pattern"]), "fill-extrusion-height": new xi(X["paint_fill-extrusion"]["fill-extrusion-height"]), "fill-extrusion-base": new xi(X["paint_fill-extrusion"]["fill-extrusion-base"]), "fill-extrusion-vertical-gradient": new gi(X["paint_fill-extrusion"]["fill-extrusion-vertical-gradient"]) });
} };
class ol extends Si {
constructor(t2) {
super(t2, sl);
}
createBucket(t2) {
return new rl(t2);
}
queryRadius() {
return ws(this.paint.get("fill-extrusion-translate"));
}
is3D() {
return true;
}
queryIntersectsFeature(t2, e2, r2, n2, i3, s2, o2, l2) {
const u2 = _s(t2, this.paint.get("fill-extrusion-translate"), this.paint.get("fill-extrusion-translate-anchor"), s2.angle, o2), c2 = this.paint.get("fill-extrusion-height").evaluate(e2, r2), h2 = this.paint.get("fill-extrusion-base").evaluate(e2, r2), p2 = (function(t3, e3, r3, n3) {
const i4 = [];
for (const r4 of t3) {
const t4 = [r4.x, r4.y, 0, 1];
Vs(t4, t4, e3), i4.push(new a(t4[0] / t4[3], t4[1] / t4[3]));
}
return i4;
})(u2, l2), f2 = (function(t3, e3, r3, n3) {
const i4 = [], s3 = [], o3 = n3[8] * e3, l3 = n3[9] * e3, u3 = n3[10] * e3, c3 = n3[11] * e3, h3 = n3[8] * r3, p3 = n3[9] * r3, f3 = n3[10] * r3, d2 = n3[11] * r3;
for (const e4 of t3) {
const t4 = [], r4 = [];
for (const i5 of e4) {
const e5 = i5.x, s4 = i5.y, y2 = n3[0] * e5 + n3[4] * s4 + n3[12], m2 = n3[1] * e5 + n3[5] * s4 + n3[13], g2 = n3[2] * e5 + n3[6] * s4 + n3[14], x2 = n3[3] * e5 + n3[7] * s4 + n3[15], v2 = g2 + u3, b2 = x2 + c3, w2 = y2 + h3, _2 = m2 + p3, A2 = g2 + f3, S2 = x2 + d2, k2 = new a((y2 + o3) / b2, (m2 + l3) / b2);
k2.z = v2 / b2, t4.push(k2);
const I2 = new a(w2 / S2, _2 / S2);
I2.z = A2 / S2, r4.push(I2);
}
i4.push(t4), s3.push(r4);
}
return [i4, s3];
})(n2, h2, c2, l2);
return (function(t3, e3, r3) {
let n3 = 1 / 0;
hs(r3, e3) && (n3 = ul(r3, e3[0]));
for (let i4 = 0; i4 < e3.length; i4++) {
const a2 = e3[i4], s3 = t3[i4];
for (let t4 = 0; t4 < a2.length - 1; t4++) {
const e4 = a2[t4], i5 = [e4, a2[t4 + 1], s3[t4 + 1], s3[t4], e4];
us(r3, i5) && (n3 = Math.min(n3, ul(r3, i5)));
}
}
return n3 !== 1 / 0 && n3;
})(f2[0], f2[1], p2);
}
}
function ll(t2, e2) {
return t2.x * e2.x + t2.y * e2.y;
}
function ul(t2, e2) {
if (1 === t2.length) {
let r2 = 0;
const n2 = e2[r2++];
let i3;
for (; !i3 || n2.equals(i3); ) if (i3 = e2[r2++], !i3) return 1 / 0;
for (; r2 < e2.length; r2++) {
const a2 = e2[r2], s2 = t2[0], o2 = i3.sub(n2), l2 = a2.sub(n2), u2 = s2.sub(n2), c2 = ll(o2, o2), h2 = ll(o2, l2), p2 = ll(l2, l2), f2 = ll(u2, o2), d2 = ll(u2, l2), y2 = c2 * p2 - h2 * h2, m2 = (p2 * f2 - h2 * d2) / y2, g2 = (c2 * d2 - h2 * f2) / y2, x2 = n2.z * (1 - m2 - g2) + i3.z * m2 + a2.z * g2;
if (isFinite(x2)) return x2;
}
return 1 / 0;
}
{
let t3 = 1 / 0;
for (const r2 of e2) t3 = Math.min(t3, r2.z);
return t3;
}
}
const cl = Mi([{ name: "a_pos_normal", components: 2, type: "Int16" }, { name: "a_data", components: 4, type: "Uint8" }], 4), { members: hl } = cl, pl = Mi([{ name: "a_uv_x", components: 1, type: "Float32" }, { name: "a_split_index", components: 1, type: "Float32" }]), { members: fl } = pl, dl = Ro.VectorTileFeature.types, yl = Math.cos(Math.PI / 180 * 37.5), ml = Math.pow(2, 14) / 0.5;
class gl {
constructor(t2) {
this.zoom = t2.zoom, this.overscaling = t2.overscaling, this.layers = t2.layers, this.layerIds = this.layers.map(((t3) => t3.id)), this.index = t2.index, this.hasPattern = false, this.patternFeatures = [], this.lineClipsArray = [], this.gradients = {}, this.layers.forEach(((t3) => {
this.gradients[t3.id] = {};
})), this.layoutVertexArray = new ya(), this.layoutVertexArray2 = new ma(), this.indexArray = new Aa(), this.programConfigurations = new Qa(t2.layers, t2.zoom), this.segments = new za(), this.maxLineLength = 0, this.stateDependentLayerIds = this.layers.filter(((t3) => t3.isStateDependent())).map(((t3) => t3.id));
}
populate(t2, e2, r2) {
this.hasPattern = Po("line", this.layers, e2);
const n2 = this.layers[0].layout.get("line-sort-key"), i3 = !n2.isConstant(), a2 = [];
for (const { feature: e3, id: s2, index: o2, sourceLayerIndex: l2 } of t2) {
const t3 = this.layers[0]._featureFilter.needGeometry, u2 = ss(e3, t3);
if (!this.layers[0]._featureFilter.filter(new li(this.zoom), u2, r2)) continue;
const c2 = i3 ? n2.evaluate(u2, {}, r2) : void 0, h2 = { id: s2, properties: e3.properties, type: e3.type, sourceLayerIndex: l2, index: o2, geometry: t3 ? u2.geometry : as(e3), patterns: {}, sortKey: c2 };
a2.push(h2);
}
i3 && a2.sort(((t3, e3) => t3.sortKey - e3.sortKey));
for (const n3 of a2) {
const { geometry: i4, index: a3, sourceLayerIndex: s2 } = n3;
if (this.hasPattern) {
const t3 = Vo("line", this.layers, n3, this.zoom, e2);
this.patternFeatures.push(t3);
} else this.addFeature(n3, i4, a3, r2, {});
e2.featureIndex.insert(t2[a3].feature, i4, a3, s2, this.index);
}
}
update(t2, e2, r2) {
this.stateDependentLayers.length && this.programConfigurations.updatePaintArrays(t2, e2, this.stateDependentLayers, r2);
}
addFeatures(t2, e2, r2) {
for (const t3 of this.patternFeatures) this.addFeature(t3, t3.geometry, t3.index, e2, r2);
}
isEmpty() {
return 0 === this.layoutVertexArray.length;
}
uploadPending() {
return !this.uploaded || this.programConfigurations.needsUpload;
}
upload(t2) {
this.uploaded || (0 !== this.layoutVertexArray2.length && (this.layoutVertexBuffer2 = t2.createVertexBuffer(this.layoutVertexArray2, fl)), this.layoutVertexBuffer = t2.createVertexBuffer(this.layoutVertexArray, hl), this.indexBuffer = t2.createIndexBuffer(this.indexArray)), this.programConfigurations.upload(t2), this.uploaded = true;
}
destroy() {
this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.indexBuffer.destroy(), this.programConfigurations.destroy(), this.segments.destroy());
}
lineFeatureClips(t2) {
if (t2.properties && Object.prototype.hasOwnProperty.call(t2.properties, "mapbox_clip_start") && Object.prototype.hasOwnProperty.call(t2.properties, "mapbox_clip_end")) return { start: +t2.properties.mapbox_clip_start, end: +t2.properties.mapbox_clip_end };
}
addFeature(t2, e2, r2, n2, i3) {
const a2 = this.layers[0].layout, s2 = a2.get("line-join").evaluate(t2, {}), o2 = a2.get("line-cap"), l2 = a2.get("line-miter-limit"), u2 = a2.get("line-round-limit");
this.lineClips = this.lineFeatureClips(t2);
for (const r3 of e2) this.addLine(r3, t2, s2, o2, l2, u2);
this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, t2, r2, i3, n2);
}
addLine(t2, e2, r2, n2, i3, a2) {
if (this.distance = 0, this.scaledDistance = 0, this.totalDistance = 0, this.lineClips) {
this.lineClipsArray.push(this.lineClips);
for (let e3 = 0; e3 < t2.length - 1; e3++) this.totalDistance += t2[e3].dist(t2[e3 + 1]);
this.updateScaledDistance(), this.maxLineLength = Math.max(this.maxLineLength, this.totalDistance);
}
const s2 = "Polygon" === dl[e2.type];
let o2 = t2.length;
for (; o2 >= 2 && t2[o2 - 1].equals(t2[o2 - 2]); ) o2--;
let l2 = 0;
for (; l2 < o2 - 1 && t2[l2].equals(t2[l2 + 1]); ) l2++;
if (o2 < (s2 ? 3 : 2)) return;
"bevel" === r2 && (i3 = 1.05);
const u2 = this.overscaling <= 16 ? 15 * rs / (512 * this.overscaling) : 0, c2 = this.segments.prepareSegment(10 * o2, this.layoutVertexArray, this.indexArray);
let h2, p2, f2, d2, y2;
this.e1 = this.e2 = -1, s2 && (h2 = t2[o2 - 2], y2 = t2[l2].sub(h2)._unit()._perp());
for (let e3 = l2; e3 < o2; e3++) {
if (f2 = e3 === o2 - 1 ? s2 ? t2[l2 + 1] : void 0 : t2[e3 + 1], f2 && t2[e3].equals(f2)) continue;
y2 && (d2 = y2), h2 && (p2 = h2), h2 = t2[e3], y2 = f2 ? f2.sub(h2)._unit()._perp() : d2, d2 = d2 || y2;
let m2 = d2.add(y2);
0 === m2.x && 0 === m2.y || m2._unit();
const g2 = d2.x * y2.x + d2.y * y2.y, x2 = m2.x * y2.x + m2.y * y2.y, v2 = 0 !== x2 ? 1 / x2 : 1 / 0, b2 = 2 * Math.sqrt(2 - 2 * x2), w2 = x2 < yl && p2 && f2, _2 = d2.x * y2.y - d2.y * y2.x > 0;
if (w2 && e3 > l2) {
const t3 = h2.dist(p2);
if (t3 > 2 * u2) {
const e4 = h2.sub(h2.sub(p2)._mult(u2 / t3)._round());
this.updateDistance(p2, e4), this.addCurrentVertex(e4, d2, 0, 0, c2), p2 = e4;
}
}
const A2 = p2 && f2;
let S2 = A2 ? r2 : s2 ? "butt" : n2;
if (A2 && "round" === S2 && (v2 < a2 ? S2 = "miter" : v2 <= 2 && (S2 = "fakeround")), "miter" === S2 && v2 > i3 && (S2 = "bevel"), "bevel" === S2 && (v2 > 2 && (S2 = "flipbevel"), v2 < i3 && (S2 = "miter")), p2 && this.updateDistance(p2, h2), "miter" === S2) m2._mult(v2), this.addCurrentVertex(h2, m2, 0, 0, c2);
else if ("flipbevel" === S2) {
if (v2 > 100) m2 = y2.mult(-1);
else {
const t3 = v2 * d2.add(y2).mag() / d2.sub(y2).mag();
m2._perp()._mult(t3 * (_2 ? -1 : 1));
}
this.addCurrentVertex(h2, m2, 0, 0, c2), this.addCurrentVertex(h2, m2.mult(-1), 0, 0, c2);
} else if ("bevel" === S2 || "fakeround" === S2) {
const t3 = -Math.sqrt(v2 * v2 - 1), e4 = _2 ? t3 : 0, r3 = _2 ? 0 : t3;
if (p2 && this.addCurrentVertex(h2, d2, e4, r3, c2), "fakeround" === S2) {
const t4 = Math.round(180 * b2 / Math.PI / 20);
for (let e5 = 1; e5 < t4; e5++) {
let r4 = e5 / t4;
if (0.5 !== r4) {
const t5 = r4 - 0.5;
r4 += r4 * t5 * (r4 - 1) * ((1.0904 + g2 * (g2 * (3.55645 - 1.43519 * g2) - 3.2452)) * t5 * t5 + (0.848013 + g2 * (0.215638 * g2 - 1.06021)));
}
const n3 = y2.sub(d2)._mult(r4)._add(d2)._unit()._mult(_2 ? -1 : 1);
this.addHalfVertex(h2, n3.x, n3.y, false, _2, 0, c2);
}
}
f2 && this.addCurrentVertex(h2, y2, -e4, -r3, c2);
} else if ("butt" === S2) this.addCurrentVertex(h2, m2, 0, 0, c2);
else if ("square" === S2) {
const t3 = p2 ? 1 : -1;
this.addCurrentVertex(h2, m2, t3, t3, c2);
} else "round" === S2 && (p2 && (this.addCurrentVertex(h2, d2, 0, 0, c2), this.addCurrentVertex(h2, d2, 1, 1, c2, true)), f2 && (this.addCurrentVertex(h2, y2, -1, -1, c2, true), this.addCurrentVertex(h2, y2, 0, 0, c2)));
if (w2 && e3 < o2 - 1) {
const t3 = h2.dist(f2);
if (t3 > 2 * u2) {
const e4 = h2.add(f2.sub(h2)._mult(u2 / t3)._round());
this.updateDistance(h2, e4), this.addCurrentVertex(e4, y2, 0, 0, c2), h2 = e4;
}
}
}
}
addCurrentVertex(t2, e2, r2, n2, i3, a2 = false) {
const s2 = e2.y * n2 - e2.x, o2 = -e2.y - e2.x * n2;
this.addHalfVertex(t2, e2.x + e2.y * r2, e2.y - e2.x * r2, a2, false, r2, i3), this.addHalfVertex(t2, s2, o2, a2, true, -n2, i3), this.distance > ml / 2 && 0 === this.totalDistance && (this.distance = 0, this.updateScaledDistance(), this.addCurrentVertex(t2, e2, r2, n2, i3, a2));
}
addHalfVertex({ x: t2, y: e2 }, r2, n2, i3, a2, s2, o2) {
const l2 = 0.5 * (this.lineClips ? this.scaledDistance * (ml - 1) : this.scaledDistance);
this.layoutVertexArray.emplaceBack((t2 << 1) + (i3 ? 1 : 0), (e2 << 1) + (a2 ? 1 : 0), Math.round(63 * r2) + 128, Math.round(63 * n2) + 128, 1 + (0 === s2 ? 0 : s2 < 0 ? -1 : 1) | (63 & l2) << 2, l2 >> 6), this.lineClips && this.layoutVertexArray2.emplaceBack((this.scaledDistance - this.lineClips.start) / (this.lineClips.end - this.lineClips.start), this.lineClipsArray.length);
const u2 = o2.vertexLength++;
this.e1 >= 0 && this.e2 >= 0 && (this.indexArray.emplaceBack(this.e1, this.e2, u2), o2.primitiveLength++), a2 ? this.e2 = u2 : this.e1 = u2;
}
updateScaledDistance() {
this.scaledDistance = this.lineClips ? this.lineClips.start + (this.lineClips.end - this.lineClips.start) * this.distance / this.totalDistance : this.distance;
}
updateDistance(t2, e2) {
this.distance += t2.dist(e2), this.updateScaledDistance();
}
}
let xl, vl;
$n("LineBucket", gl, { omit: ["layers", "patternFeatures"] });
var bl = { get paint() {
return vl = vl || new _i({ "line-opacity": new xi(X.paint_line["line-opacity"]), "line-color": new xi(X.paint_line["line-color"]), "line-translate": new gi(X.paint_line["line-translate"]), "line-translate-anchor": new gi(X.paint_line["line-translate-anchor"]), "line-width": new xi(X.paint_line["line-width"]), "line-gap-width": new xi(X.paint_line["line-gap-width"]), "line-offset": new xi(X.paint_line["line-offset"]), "line-blur": new xi(X.paint_line["line-blur"]), "line-dasharray": new bi(X.paint_line["line-dasharray"]), "line-pattern": new vi(X.paint_line["line-pattern"]), "line-gradient": new wi(X.paint_line["line-gradient"]) });
}, get layout() {
return xl = xl || new _i({ "line-cap": new gi(X.layout_line["line-cap"]), "line-join": new xi(X.layout_line["line-join"]), "line-miter-limit": new gi(X.layout_line["line-miter-limit"]), "line-round-limit": new gi(X.layout_line["line-round-limit"]), "line-sort-key": new xi(X.layout_line["line-sort-key"]) });
} };
class wl extends xi {
possiblyEvaluate(t2, e2) {
return e2 = new li(Math.floor(e2.zoom), { now: e2.now, fadeDuration: e2.fadeDuration, zoomHistory: e2.zoomHistory, transition: e2.transition }), super.possiblyEvaluate(t2, e2);
}
evaluate(t2, e2, r2, n2) {
return e2 = g({}, e2, { zoom: Math.floor(e2.zoom) }), super.evaluate(t2, e2, r2, n2);
}
}
let _l;
class Al extends Si {
constructor(t2) {
super(t2, bl), this.gradientVersion = 0, _l || (_l = new wl(bl.paint.properties["line-width"].specification), _l.useIntegerZoom = true);
}
_handleSpecialPaintPropertyUpdate(t2) {
if ("line-gradient" === t2) {
const t3 = this.gradientExpression();
this.stepInterpolant = !!(function(t4) {
return void 0 !== t4._styleExpression;
})(t3) && t3._styleExpression.expression instanceof qe, this.gradientVersion = (this.gradientVersion + 1) % Number.MAX_SAFE_INTEGER;
}
}
gradientExpression() {
return this._transitionablePaint._values["line-gradient"].value.expression;
}
recalculate(t2, e2) {
super.recalculate(t2, e2), this.paint._values["line-floorwidth"] = _l.possiblyEvaluate(this._transitioningPaint._values["line-width"].value, t2);
}
createBucket(t2) {
return new gl(t2);
}
queryRadius(t2) {
const e2 = t2, r2 = Sl(bs("line-width", this, e2), bs("line-gap-width", this, e2)), n2 = bs("line-offset", this, e2);
return r2 / 2 + Math.abs(n2) + ws(this.paint.get("line-translate"));
}
queryIntersectsFeature(t2, e2, r2, n2, i3, s2, o2) {
const l2 = _s(t2, this.paint.get("line-translate"), this.paint.get("line-translate-anchor"), s2.angle, o2), u2 = o2 / 2 * Sl(this.paint.get("line-width").evaluate(e2, r2), this.paint.get("line-gap-width").evaluate(e2, r2)), c2 = this.paint.get("line-offset").evaluate(e2, r2);
return c2 && (n2 = (function(t3, e3) {
const r3 = [];
for (let n3 = 0; n3 < t3.length; n3++) {
const i4 = t3[n3], s3 = [];
for (let t4 = 0; t4 < i4.length; t4++) {
const r4 = i4[t4 - 1], n4 = i4[t4], o3 = i4[t4 + 1], l3 = 0 === t4 ? new a(0, 0) : n4.sub(r4)._unit()._perp(), u3 = t4 === i4.length - 1 ? new a(0, 0) : o3.sub(n4)._unit()._perp(), c3 = l3._add(u3)._unit(), h2 = c3.x * u3.x + c3.y * u3.y;
0 !== h2 && c3._mult(1 / h2), s3.push(c3._mult(e3)._add(n4));
}
r3.push(s3);
}
return r3;
})(n2, c2 * o2)), (function(t3, e3, r3) {
for (let n3 = 0; n3 < e3.length; n3++) {
const i4 = e3[n3];
if (t3.length >= 3) {
for (let e4 = 0; e4 < i4.length; e4++) if (xs(t3, i4[e4])) return true;
}
if (ps(t3, i4, r3)) return true;
}
return false;
})(l2, n2, u2);
}
isTileClipped() {
return true;
}
}
function Sl(t2, e2) {
return e2 > 0 ? e2 + 2 * t2 : t2;
}
const kl = Mi([{ name: "a_pos_offset", components: 4, type: "Int16" }, { name: "a_data", components: 4, type: "Uint16" }, { name: "a_pixeloffset", components: 4, type: "Int16" }], 4), Il = Mi([{ name: "a_projected_pos", components: 3, type: "Float32" }], 4);
Mi([{ name: "a_fade_opacity", components: 1, type: "Uint32" }], 4);
const zl = Mi([{ name: "a_placed", components: 2, type: "Uint8" }, { name: "a_shift", components: 2, type: "Float32" }]);
Mi([{ type: "Int16", name: "anchorPointX" }, { type: "Int16", name: "anchorPointY" }, { type: "Int16", name: "x1" }, { type: "Int16", name: "y1" }, { type: "Int16", name: "x2" }, { type: "Int16", name: "y2" }, { type: "Uint32", name: "featureIndex" }, { type: "Uint16", name: "sourceLayerIndex" }, { type: "Uint16", name: "bucketIndex" }]);
const Ml = Mi([{ name: "a_pos", components: 2, type: "Int16" }, { name: "a_anchor_pos", components: 2, type: "Int16" }, { name: "a_extrude", components: 2, type: "Int16" }], 4), Cl = Mi([{ name: "a_pos", components: 2, type: "Float32" }, { name: "a_radius", components: 1, type: "Float32" }, { name: "a_flags", components: 2, type: "Int16" }], 4);
function Bl(t2, e2, r2) {
return t2.sections.forEach(((t3) => {
t3.text = (function(t4, e3, r3) {
const n2 = e3.layout.get("text-transform").evaluate(r3, {});
return "uppercase" === n2 ? t4 = t4.toLocaleUpperCase() : "lowercase" === n2 && (t4 = t4.toLocaleLowerCase()), oi.applyArabicShaping && (t4 = oi.applyArabicShaping(t4)), t4;
})(t3.text, e2, r2);
})), t2;
}
Mi([{ name: "triangle", components: 3, type: "Uint16" }]), Mi([{ type: "Int16", name: "anchorX" }, { type: "Int16", name: "anchorY" }, { type: "Uint16", name: "glyphStartIndex" }, { type: "Uint16", name: "numGlyphs" }, { type: "Uint32", name: "vertexStartIndex" }, { type: "Uint32", name: "lineStartIndex" }, { type: "Uint32", name: "lineLength" }, { type: "Uint16", name: "segment" }, { type: "Uint16", name: "lowerSize" }, { type: "Uint16", name: "upperSize" }, { type: "Float32", name: "lineOffsetX" }, { type: "Float32", name: "lineOffsetY" }, { type: "Uint8", name: "writingMode" }, { type: "Uint8", name: "placedOrientation" }, { type: "Uint8", name: "hidden" }, { type: "Uint32", name: "crossTileID" }, { type: "Int16", name: "associatedIconIndex" }]), Mi([{ type: "Int16", name: "anchorX" }, { type: "Int16", name: "anchorY" }, { type: "Int16", name: "rightJustifiedTextSymbolIndex" }, { type: "Int16", name: "centerJustifiedTextSymbolIndex" }, { type: "Int16", name: "leftJustifiedTextSymbolIndex" }, { type: "Int16", name: "verticalPlacedTextSymbolIndex" }, { type: "Int16", name: "placedIconSymbolIndex" }, { type: "Int16", name: "verticalPlacedIconSymbolIndex" }, { type: "Uint16", name: "key" }, { type: "Uint16", name: "textBoxStartIndex" }, { type: "Uint16", name: "textBoxEndIndex" }, { type: "Uint16", name: "verticalTextBoxStartIndex" }, { type: "Uint16", name: "verticalTextBoxEndIndex" }, { type: "Uint16", name: "iconBoxStartIndex" }, { type: "Uint16", name: "iconBoxEndIndex" }, { type: "Uint16", name: "verticalIconBoxStartIndex" }, { type: "Uint16", name: "verticalIconBoxEndIndex" }, { type: "Uint16", name: "featureIndex" }, { type: "Uint16", name: "numHorizontalGlyphVertices" }, { type: "Uint16", name: "numVerticalGlyphVertices" }, { type: "Uint16", name: "numIconVertices" }, { type: "Uint16", name: "numVerticalIconVertices" }, { type: "Uint16", name: "useRuntimeCollisionCircles" }, { type: "Uint32", name: "crossTileID" }, { type: "Float32", name: "textBoxScale" }, { type: "Float32", name: "collisionCircleDiameter" }, { type: "Uint16", name: "textAnchorOffsetStartIndex" }, { type: "Uint16", name: "textAnchorOffsetEndIndex" }]), Mi([{ type: "Float32", name: "offsetX" }]), Mi([{ type: "Int16", name: "x" }, { type: "Int16", name: "y" }, { type: "Int16", name: "tileUnitDistanceFromAnchor" }]), Mi([{ type: "Uint16", name: "textAnchor" }, { type: "Float32", components: 2, name: "textOffset" }]);
const Pl = { "!": "︕", "#": "", $: "", "%": "", "&": "", "(": "︵", ")": "︶", "*": "", "+": "", ",": "︐", "-": "︲", ".": "・", "/": "", ":": "︓", ";": "︔", "<": "︿", "=": "", ">": "﹀", "?": "︖", "@": "", "[": "﹇", "\\": "", "]": "﹈", "^": "", _: "︳", "`": "", "{": "︷", "|": "―", "}": "︸", "~": "", "¢": "¢", "£": "£", "¥": "¥", "¦": "¦", "¬": "¬", "¯": " ̄", "": "︲", "—": "︱", "": "﹃", "": "﹄", "“": "﹁", "”": "﹂", "…": "︙", "‧": "・", "₩": "₩", "、": "︑", "。": "︒", "〈": "︿", "〉": "﹀", "《": "︽", "》": "︾", "「": "﹁", "」": "﹂", "『": "﹃", "』": "﹄", "【": "︻", "】": "︼", "": "︹", "": "︺", "〖": "︗", "〗": "︘", "": "︕", "": "︵", "": "︶", "": "︐", "": "︲", "": "・", "": "︓", "": "︔", "": "︿", "": "﹀", "": "︖", "": "﹇", "": "﹈", "_": "︳", "": "︷", "": "―", "": "︸", "⦅": "︵", "⦆": "︶", "。": "︒", "「": "﹁", "」": "﹂" };
var Vl = 24, El = $l, Fl = function(t2, e2, r2, n2, i3) {
var a2, s2, o2 = 8 * i3 - n2 - 1, l2 = (1 << o2) - 1, u2 = l2 >> 1, c2 = -7, h2 = i3 - 1, p2 = -1, f2 = t2[e2 + h2];
for (h2 += p2, a2 = f2 & (1 << -c2) - 1, f2 >>= -c2, c2 += o2; c2 > 0; a2 = 256 * a2 + t2[e2 + h2], h2 += p2, c2 -= 8) ;
for (s2 = a2 & (1 << -c2) - 1, a2 >>= -c2, c2 += n2; c2 > 0; s2 = 256 * s2 + t2[e2 + h2], h2 += p2, c2 -= 8) ;
if (0 === a2) a2 = 1 - u2;
else {
if (a2 === l2) return s2 ? NaN : 1 / 0 * (f2 ? -1 : 1);
s2 += Math.pow(2, n2), a2 -= u2;
}
return (f2 ? -1 : 1) * s2 * Math.pow(2, a2 - n2);
}, Tl = function(t2, e2, r2, n2, i3, a2) {
var s2, o2, l2, u2 = 8 * a2 - i3 - 1, c2 = (1 << u2) - 1, h2 = c2 >> 1, p2 = 23 === i3 ? Math.pow(2, -24) - Math.pow(2, -77) : 0, f2 = 0, d2 = 1, y2 = e2 < 0 || 0 === e2 && 1 / e2 < 0 ? 1 : 0;
for (e2 = Math.abs(e2), isNaN(e2) || e2 === 1 / 0 ? (o2 = isNaN(e2) ? 1 : 0, s2 = c2) : (s2 = Math.floor(Math.log(e2) / Math.LN2), e2 * (l2 = Math.pow(2, -s2)) < 1 && (s2--, l2 *= 2), (e2 += s2 + h2 >= 1 ? p2 / l2 : p2 * Math.pow(2, 1 - h2)) * l2 >= 2 && (s2++, l2 /= 2), s2 + h2 >= c2 ? (o2 = 0, s2 = c2) : s2 + h2 >= 1 ? (o2 = (e2 * l2 - 1) * Math.pow(2, i3), s2 += h2) : (o2 = e2 * Math.pow(2, h2 - 1) * Math.pow(2, i3), s2 = 0)); i3 >= 8; t2[r2 + f2] = 255 & o2, f2 += d2, o2 /= 256, i3 -= 8) ;
for (s2 = s2 << i3 | o2, u2 += i3; u2 > 0; t2[r2 + f2] = 255 & s2, f2 += d2, s2 /= 256, u2 -= 8) ;
t2[r2 + f2 - d2] |= 128 * y2;
};
function $l(t2) {
this.buf = ArrayBuffer.isView && ArrayBuffer.isView(t2) ? t2 : new Uint8Array(t2 || 0), this.pos = 0, this.type = 0, this.length = this.buf.length;
}
$l.Varint = 0, $l.Fixed64 = 1, $l.Bytes = 2, $l.Fixed32 = 5;
var Ll = 4294967296, Dl = 1 / Ll, Ol = "undefined" == typeof TextDecoder ? null : new TextDecoder("utf8");
function Ul(t2) {
return t2.type === $l.Bytes ? t2.readVarint() + t2.pos : t2.pos + 1;
}
function Rl(t2, e2, r2) {
return r2 ? 4294967296 * e2 + (t2 >>> 0) : 4294967296 * (e2 >>> 0) + (t2 >>> 0);
}
function ql(t2, e2, r2) {
var n2 = e2 <= 16383 ? 1 : e2 <= 2097151 ? 2 : e2 <= 268435455 ? 3 : Math.floor(Math.log(e2) / (7 * Math.LN2));
r2.realloc(n2);
for (var i3 = r2.pos - 1; i3 >= t2; i3--) r2.buf[i3 + n2] = r2.buf[i3];
}
function jl(t2, e2) {
for (var r2 = 0; r2 < t2.length; r2++) e2.writeVarint(t2[r2]);
}
function Nl(t2, e2) {
for (var r2 = 0; r2 < t2.length; r2++) e2.writeSVarint(t2[r2]);
}
function Zl(t2, e2) {
for (var r2 = 0; r2 < t2.length; r2++) e2.writeFloat(t2[r2]);
}
function Kl(t2, e2) {
for (var r2 = 0; r2 < t2.length; r2++) e2.writeDouble(t2[r2]);
}
function Gl(t2, e2) {
for (var r2 = 0; r2 < t2.length; r2++) e2.writeBoolean(t2[r2]);
}
function Jl(t2, e2) {
for (var r2 = 0; r2 < t2.length; r2++) e2.writeFixed32(t2[r2]);
}
function Xl(t2, e2) {
for (var r2 = 0; r2 < t2.length; r2++) e2.writeSFixed32(t2[r2]);
}
function Yl(t2, e2) {
for (var r2 = 0; r2 < t2.length; r2++) e2.writeFixed64(t2[r2]);
}
function Hl(t2, e2) {
for (var r2 = 0; r2 < t2.length; r2++) e2.writeSFixed64(t2[r2]);
}
function Wl(t2, e2) {
return (t2[e2] | t2[e2 + 1] << 8 | t2[e2 + 2] << 16) + 16777216 * t2[e2 + 3];
}
function Ql(t2, e2, r2) {
t2[r2] = e2, t2[r2 + 1] = e2 >>> 8, t2[r2 + 2] = e2 >>> 16, t2[r2 + 3] = e2 >>> 24;
}
function tu(t2, e2) {
return (t2[e2] | t2[e2 + 1] << 8 | t2[e2 + 2] << 16) + (t2[e2 + 3] << 24);
}
$l.prototype = { destroy: function() {
this.buf = null;
}, readFields: function(t2, e2, r2) {
for (r2 = r2 || this.length; this.pos < r2; ) {
var n2 = this.readVarint(), i3 = n2 >> 3, a2 = this.pos;
this.type = 7 & n2, t2(i3, e2, this), this.pos === a2 && this.skip(n2);
}
return e2;
}, readMessage: function(t2, e2) {
return this.readFields(t2, e2, this.readVarint() + this.pos);
}, readFixed32: function() {
var t2 = Wl(this.buf, this.pos);
return this.pos += 4, t2;
}, readSFixed32: function() {
var t2 = tu(this.buf, this.pos);
return this.pos += 4, t2;
}, readFixed64: function() {
var t2 = Wl(this.buf, this.pos) + Wl(this.buf, this.pos + 4) * Ll;
return this.pos += 8, t2;
}, readSFixed64: function() {
var t2 = Wl(this.buf, this.pos) + tu(this.buf, this.pos + 4) * Ll;
return this.pos += 8, t2;
}, readFloat: function() {
var t2 = Fl(this.buf, this.pos, true, 23, 4);
return this.pos += 4, t2;
}, readDouble: function() {
var t2 = Fl(this.buf, this.pos, true, 52, 8);
return this.pos += 8, t2;
}, readVarint: function(t2) {
var e2, r2, n2 = this.buf;
return e2 = 127 & (r2 = n2[this.pos++]), r2 < 128 ? e2 : (e2 |= (127 & (r2 = n2[this.pos++])) << 7, r2 < 128 ? e2 : (e2 |= (127 & (r2 = n2[this.pos++])) << 14, r2 < 128 ? e2 : (e2 |= (127 & (r2 = n2[this.pos++])) << 21, r2 < 128 ? e2 : (function(t3, e3, r3) {
var n3, i3, a2 = r3.buf;
if (n3 = (112 & (i3 = a2[r3.pos++])) >> 4, i3 < 128) return Rl(t3, n3, e3);
if (n3 |= (127 & (i3 = a2[r3.pos++])) << 3, i3 < 128) return Rl(t3, n3, e3);
if (n3 |= (127 & (i3 = a2[r3.pos++])) << 10, i3 < 128) return Rl(t3, n3, e3);
if (n3 |= (127 & (i3 = a2[r3.pos++])) << 17, i3 < 128) return Rl(t3, n3, e3);
if (n3 |= (127 & (i3 = a2[r3.pos++])) << 24, i3 < 128) return Rl(t3, n3, e3);
if (n3 |= (1 & (i3 = a2[r3.pos++])) << 31, i3 < 128) return Rl(t3, n3, e3);
throw new Error("Expected varint not more than 10 bytes");
})(e2 |= (15 & (r2 = n2[this.pos])) << 28, t2, this))));
}, readVarint64: function() {
return this.readVarint(true);
}, readSVarint: function() {
var t2 = this.readVarint();
return t2 % 2 == 1 ? (t2 + 1) / -2 : t2 / 2;
}, readBoolean: function() {
return Boolean(this.readVarint());
}, readString: function() {
var t2 = this.readVarint() + this.pos, e2 = this.pos;
return this.pos = t2, t2 - e2 >= 12 && Ol ? (function(t3, e3, r2) {
return Ol.decode(t3.subarray(e3, r2));
})(this.buf, e2, t2) : (function(t3, e3, r2) {
for (var n2 = "", i3 = e3; i3 < r2; ) {
var a2, s2, o2, l2 = t3[i3], u2 = null, c2 = l2 > 239 ? 4 : l2 > 223 ? 3 : l2 > 191 ? 2 : 1;
if (i3 + c2 > r2) break;
1 === c2 ? l2 < 128 && (u2 = l2) : 2 === c2 ? 128 == (192 & (a2 = t3[i3 + 1])) && (u2 = (31 & l2) << 6 | 63 & a2) <= 127 && (u2 = null) : 3 === c2 ? (s2 = t3[i3 + 2], 128 == (192 & (a2 = t3[i3 + 1])) && 128 == (192 & s2) && ((u2 = (15 & l2) << 12 | (63 & a2) << 6 | 63 & s2) <= 2047 || u2 >= 55296 && u2 <= 57343) && (u2 = null)) : 4 === c2 && (s2 = t3[i3 + 2], o2 = t3[i3 + 3], 128 == (192 & (a2 = t3[i3 + 1])) && 128 == (192 & s2) && 128 == (192 & o2) && ((u2 = (15 & l2) << 18 | (63 & a2) << 12 | (63 & s2) << 6 | 63 & o2) <= 65535 || u2 >= 1114112) && (u2 = null)), null === u2 ? (u2 = 65533, c2 = 1) : u2 > 65535 && (u2 -= 65536, n2 += String.fromCharCode(u2 >>> 10 & 1023 | 55296), u2 = 56320 | 1023 & u2), n2 += String.fromCharCode(u2), i3 += c2;
}
return n2;
})(this.buf, e2, t2);
}, readBytes: function() {
var t2 = this.readVarint() + this.pos, e2 = this.buf.subarray(this.pos, t2);
return this.pos = t2, e2;
}, readPackedVarint: function(t2, e2) {
if (this.type !== $l.Bytes) return t2.push(this.readVarint(e2));
var r2 = Ul(this);
for (t2 = t2 || []; this.pos < r2; ) t2.push(this.readVarint(e2));
return t2;
}, readPackedSVarint: function(t2) {
if (this.type !== $l.Bytes) return t2.push(this.readSVarint());
var e2 = Ul(this);
for (t2 = t2 || []; this.pos < e2; ) t2.push(this.readSVarint());
return t2;
}, readPackedBoolean: function(t2) {
if (this.type !== $l.Bytes) return t2.push(this.readBoolean());
var e2 = Ul(this);
for (t2 = t2 || []; this.pos < e2; ) t2.push(this.readBoolean());
return t2;
}, readPackedFloat: function(t2) {
if (this.type !== $l.Bytes) return t2.push(this.readFloat());
var e2 = Ul(this);
for (t2 = t2 || []; this.pos < e2; ) t2.push(this.readFloat());
return t2;
}, readPackedDouble: function(t2) {
if (this.type !== $l.Bytes) return t2.push(this.readDouble());
var e2 = Ul(this);
for (t2 = t2 || []; this.pos < e2; ) t2.push(this.readDouble());
return t2;
}, readPackedFixed32: function(t2) {
if (this.type !== $l.Bytes) return t2.push(this.readFixed32());
var e2 = Ul(this);
for (t2 = t2 || []; this.pos < e2; ) t2.push(this.readFixed32());
return t2;
}, readPackedSFixed32: function(t2) {
if (this.type !== $l.Bytes) return t2.push(this.readSFixed32());
var e2 = Ul(this);
for (t2 = t2 || []; this.pos < e2; ) t2.push(this.readSFixed32());
return t2;
}, readPackedFixed64: function(t2) {
if (this.type !== $l.Bytes) return t2.push(this.readFixed64());
var e2 = Ul(this);
for (t2 = t2 || []; this.pos < e2; ) t2.push(this.readFixed64());
return t2;
}, readPackedSFixed64: function(t2) {
if (this.type !== $l.Bytes) return t2.push(this.readSFixed64());
var e2 = Ul(this);
for (t2 = t2 || []; this.pos < e2; ) t2.push(this.readSFixed64());
return t2;
}, skip: function(t2) {
var e2 = 7 & t2;
if (e2 === $l.Varint) for (; this.buf[this.pos++] > 127; ) ;
else if (e2 === $l.Bytes) this.pos = this.readVarint() + this.pos;
else if (e2 === $l.Fixed32) this.pos += 4;
else {
if (e2 !== $l.Fixed64) throw new Error("Unimplemented type: " + e2);
this.pos += 8;
}
}, writeTag: function(t2, e2) {
this.writeVarint(t2 << 3 | e2);
}, realloc: function(t2) {
for (var e2 = this.length || 16; e2 < this.pos + t2; ) e2 *= 2;
if (e2 !== this.length) {
var r2 = new Uint8Array(e2);
r2.set(this.buf), this.buf = r2, this.length = e2;
}
}, finish: function() {
return this.length = this.pos, this.pos = 0, this.buf.subarray(0, this.length);
}, writeFixed32: function(t2) {
this.realloc(4), Ql(this.buf, t2, this.pos), this.pos += 4;
}, writeSFixed32: function(t2) {
this.realloc(4), Ql(this.buf, t2, this.pos), this.pos += 4;
}, writeFixed64: function(t2) {
this.realloc(8), Ql(this.buf, -1 & t2, this.pos), Ql(this.buf, Math.floor(t2 * Dl), this.pos + 4), this.pos += 8;
}, writeSFixed64: function(t2) {
this.realloc(8), Ql(this.buf, -1 & t2, this.pos), Ql(this.buf, Math.floor(t2 * Dl), this.pos + 4), this.pos += 8;
}, writeVarint: function(t2) {
(t2 = +t2 || 0) > 268435455 || t2 < 0 ? (function(t3, e2) {
var r2, n2;
if (t3 >= 0 ? (r2 = t3 % 4294967296 | 0, n2 = t3 / 4294967296 | 0) : (n2 = ~(-t3 / 4294967296), 4294967295 ^ (r2 = ~(-t3 % 4294967296)) ? r2 = r2 + 1 | 0 : (r2 = 0, n2 = n2 + 1 | 0)), t3 >= 18446744073709552e3 || t3 < -18446744073709552e3) throw new Error("Given varint doesn't fit into 10 bytes");
e2.realloc(10), (function(t4, e3, r3) {
r3.buf[r3.pos++] = 127 & t4 | 128, t4 >>>= 7, r3.buf[r3.pos++] = 127 & t4 | 128, t4 >>>= 7, r3.buf[r3.pos++] = 127 & t4 | 128, t4 >>>= 7, r3.buf[r3.pos++] = 127 & t4 | 128, r3.buf[r3.pos] = 127 & (t4 >>>= 7);
})(r2, 0, e2), (function(t4, e3) {
var r3 = (7 & t4) << 4;
e3.buf[e3.pos++] |= r3 | ((t4 >>>= 3) ? 128 : 0), t4 && (e3.buf[e3.pos++] = 127 & t4 | ((t4 >>>= 7) ? 128 : 0), t4 && (e3.buf[e3.pos++] = 127 & t4 | ((t4 >>>= 7) ? 128 : 0), t4 && (e3.buf[e3.pos++] = 127 & t4 | ((t4 >>>= 7) ? 128 : 0), t4 && (e3.buf[e3.pos++] = 127 & t4 | ((t4 >>>= 7) ? 128 : 0), t4 && (e3.buf[e3.pos++] = 127 & t4)))));
})(n2, e2);
})(t2, this) : (this.realloc(4), this.buf[this.pos++] = 127 & t2 | (t2 > 127 ? 128 : 0), t2 <= 127 || (this.buf[this.pos++] = 127 & (t2 >>>= 7) | (t2 > 127 ? 128 : 0), t2 <= 127 || (this.buf[this.pos++] = 127 & (t2 >>>= 7) | (t2 > 127 ? 128 : 0), t2 <= 127 || (this.buf[this.pos++] = t2 >>> 7 & 127))));
}, writeSVarint: function(t2) {
this.writeVarint(t2 < 0 ? 2 * -t2 - 1 : 2 * t2);
}, writeBoolean: function(t2) {
this.writeVarint(Boolean(t2));
}, writeString: function(t2) {
t2 = String(t2), this.realloc(4 * t2.length), this.pos++;
var e2 = this.pos;
this.pos = (function(t3, e3, r3) {
for (var n2, i3, a2 = 0; a2 < e3.length; a2++) {
if ((n2 = e3.charCodeAt(a2)) > 55295 && n2 < 57344) {
if (!i3) {
n2 > 56319 || a2 + 1 === e3.length ? (t3[r3++] = 239, t3[r3++] = 191, t3[r3++] = 189) : i3 = n2;
continue;
}
if (n2 < 56320) {
t3[r3++] = 239, t3[r3++] = 191, t3[r3++] = 189, i3 = n2;
continue;
}
n2 = i3 - 55296 << 10 | n2 - 56320 | 65536, i3 = null;
} else i3 && (t3[r3++] = 239, t3[r3++] = 191, t3[r3++] = 189, i3 = null);
n2 < 128 ? t3[r3++] = n2 : (n2 < 2048 ? t3[r3++] = n2 >> 6 | 192 : (n2 < 65536 ? t3[r3++] = n2 >> 12 | 224 : (t3[r3++] = n2 >> 18 | 240, t3[r3++] = n2 >> 12 & 63 | 128), t3[r3++] = n2 >> 6 & 63 | 128), t3[r3++] = 63 & n2 | 128);
}
return r3;
})(this.buf, t2, this.pos);
var r2 = this.pos - e2;
r2 >= 128 && ql(e2, r2, this), this.pos = e2 - 1, this.writeVarint(r2), this.pos += r2;
}, writeFloat: function(t2) {
this.realloc(4), Tl(this.buf, t2, this.pos, true, 23, 4), this.pos += 4;
}, writeDouble: function(t2) {
this.realloc(8), Tl(this.buf, t2, this.pos, true, 52, 8), this.pos += 8;
}, writeBytes: function(t2) {
var e2 = t2.length;
this.writeVarint(e2), this.realloc(e2);
for (var r2 = 0; r2 < e2; r2++) this.buf[this.pos++] = t2[r2];
}, writeRawMessage: function(t2, e2) {
this.pos++;
var r2 = this.pos;
t2(e2, this);
var n2 = this.pos - r2;
n2 >= 128 && ql(r2, n2, this), this.pos = r2 - 1, this.writeVarint(n2), this.pos += n2;
}, writeMessage: function(t2, e2, r2) {
this.writeTag(t2, $l.Bytes), this.writeRawMessage(e2, r2);
}, writePackedVarint: function(t2, e2) {
e2.length && this.writeMessage(t2, jl, e2);
}, writePackedSVarint: function(t2, e2) {
e2.length && this.writeMessage(t2, Nl, e2);
}, writePackedBoolean: function(t2, e2) {
e2.length && this.writeMessage(t2, Gl, e2);
}, writePackedFloat: function(t2, e2) {
e2.length && this.writeMessage(t2, Zl, e2);
}, writePackedDouble: function(t2, e2) {
e2.length && this.writeMessage(t2, Kl, e2);
}, writePackedFixed32: function(t2, e2) {
e2.length && this.writeMessage(t2, Jl, e2);
}, writePackedSFixed32: function(t2, e2) {
e2.length && this.writeMessage(t2, Xl, e2);
}, writePackedFixed64: function(t2, e2) {
e2.length && this.writeMessage(t2, Yl, e2);
}, writePackedSFixed64: function(t2, e2) {
e2.length && this.writeMessage(t2, Hl, e2);
}, writeBytesField: function(t2, e2) {
this.writeTag(t2, $l.Bytes), this.writeBytes(e2);
}, writeFixed32Field: function(t2, e2) {
this.writeTag(t2, $l.Fixed32), this.writeFixed32(e2);
}, writeSFixed32Field: function(t2, e2) {
this.writeTag(t2, $l.Fixed32), this.writeSFixed32(e2);
}, writeFixed64Field: function(t2, e2) {
this.writeTag(t2, $l.Fixed64), this.writeFixed64(e2);
}, writeSFixed64Field: function(t2, e2) {
this.writeTag(t2, $l.Fixed64), this.writeSFixed64(e2);
}, writeVarintField: function(t2, e2) {
this.writeTag(t2, $l.Varint), this.writeVarint(e2);
}, writeSVarintField: function(t2, e2) {
this.writeTag(t2, $l.Varint), this.writeSVarint(e2);
}, writeStringField: function(t2, e2) {
this.writeTag(t2, $l.Bytes), this.writeString(e2);
}, writeFloatField: function(t2, e2) {
this.writeTag(t2, $l.Fixed32), this.writeFloat(e2);
}, writeDoubleField: function(t2, e2) {
this.writeTag(t2, $l.Fixed64), this.writeDouble(e2);
}, writeBooleanField: function(t2, e2) {
this.writeVarintField(t2, Boolean(e2));
} };
var eu = r(El);
const ru = 3;
function nu(t2, e2, r2) {
1 === t2 && r2.readMessage(iu, e2);
}
function iu(t2, e2, r2) {
if (3 === t2) {
const { id: t3, bitmap: n2, width: i3, height: a2, left: s2, top: o2, advance: l2 } = r2.readMessage(au, {});
e2.push({ id: t3, bitmap: new Rs({ width: i3 + 2 * ru, height: a2 + 2 * ru }, n2), metrics: { width: i3, height: a2, left: s2, top: o2, advance: l2 } });
}
}
function au(t2, e2, r2) {
1 === t2 ? e2.id = r2.readVarint() : 2 === t2 ? e2.bitmap = r2.readBytes() : 3 === t2 ? e2.width = r2.readVarint() : 4 === t2 ? e2.height = r2.readVarint() : 5 === t2 ? e2.left = r2.readSVarint() : 6 === t2 ? e2.top = r2.readSVarint() : 7 === t2 && (e2.advance = r2.readVarint());
}
const su = ru;
function ou(t2) {
let e2 = 0, r2 = 0;
for (const n3 of t2) e2 += n3.w * n3.h, r2 = Math.max(r2, n3.w);
t2.sort(((t3, e3) => e3.h - t3.h));
const n2 = [{ x: 0, y: 0, w: Math.max(Math.ceil(Math.sqrt(e2 / 0.95)), r2), h: 1 / 0 }];
let i3 = 0, a2 = 0;
for (const e3 of t2) for (let t3 = n2.length - 1; t3 >= 0; t3--) {
const r3 = n2[t3];
if (!(e3.w > r3.w || e3.h > r3.h)) {
if (e3.x = r3.x, e3.y = r3.y, a2 = Math.max(a2, e3.y + e3.h), i3 = Math.max(i3, e3.x + e3.w), e3.w === r3.w && e3.h === r3.h) {
const e4 = n2.pop();
t3 < n2.length && (n2[t3] = e4);
} else e3.h === r3.h ? (r3.x += e3.w, r3.w -= e3.w) : e3.w === r3.w ? (r3.y += e3.h, r3.h -= e3.h) : (n2.push({ x: r3.x + e3.w, y: r3.y, w: r3.w - e3.w, h: e3.h }), r3.y += e3.h, r3.h -= e3.h);
break;
}
}
return { w: i3, h: a2, fill: e2 / (i3 * a2) || 0 };
}
const lu = 1;
class uu {
constructor(t2, { pixelRatio: e2, version: r2, stretchX: n2, stretchY: i3, content: a2 }) {
this.paddedRect = t2, this.pixelRatio = e2, this.stretchX = n2, this.stretchY = i3, this.content = a2, this.version = r2;
}
get tl() {
return [this.paddedRect.x + lu, this.paddedRect.y + lu];
}
get br() {
return [this.paddedRect.x + this.paddedRect.w - lu, this.paddedRect.y + this.paddedRect.h - lu];
}
get tlbr() {
return this.tl.concat(this.br);
}
get displaySize() {
return [(this.paddedRect.w - 2 * lu) / this.pixelRatio, (this.paddedRect.h - 2 * lu) / this.pixelRatio];
}
}
class cu {
constructor(t2, e2) {
const r2 = {}, n2 = {};
this.haveRenderCallbacks = [];
const i3 = [];
this.addImages(t2, r2, i3), this.addImages(e2, n2, i3);
const { w: a2, h: s2 } = ou(i3), o2 = new qs({ width: a2 || 1, height: s2 || 1 });
for (const e3 in t2) {
const n3 = t2[e3], i4 = r2[e3].paddedRect;
qs.copy(n3.data, o2, { x: 0, y: 0 }, { x: i4.x + lu, y: i4.y + lu }, n3.data);
}
for (const t3 in e2) {
const r3 = e2[t3], i4 = n2[t3].paddedRect, a3 = i4.x + lu, s3 = i4.y + lu, l2 = r3.data.width, u2 = r3.data.height;
qs.copy(r3.data, o2, { x: 0, y: 0 }, { x: a3, y: s3 }, r3.data), qs.copy(r3.data, o2, { x: 0, y: u2 - 1 }, { x: a3, y: s3 - 1 }, { width: l2, height: 1 }), qs.copy(r3.data, o2, { x: 0, y: 0 }, { x: a3, y: s3 + u2 }, { width: l2, height: 1 }), qs.copy(r3.data, o2, { x: l2 - 1, y: 0 }, { x: a3 - 1, y: s3 }, { width: 1, height: u2 }), qs.copy(r3.data, o2, { x: 0, y: 0 }, { x: a3 + l2, y: s3 }, { width: 1, height: u2 });
}
this.image = o2, this.iconPositions = r2, this.patternPositions = n2;
}
addImages(t2, e2, r2) {
for (const n2 in t2) {
const i3 = t2[n2], a2 = { x: 0, y: 0, w: i3.data.width + 2 * lu, h: i3.data.height + 2 * lu };
r2.push(a2), e2[n2] = new uu(a2, i3), i3.hasRenderCallback && this.haveRenderCallbacks.push(n2);
}
}
patchUpdatedImages(t2, e2) {
t2.dispatchRenderCallbacks(this.haveRenderCallbacks);
for (const r2 in t2.updatedImages) this.patchUpdatedImage(this.iconPositions[r2], t2.getImage(r2), e2), this.patchUpdatedImage(this.patternPositions[r2], t2.getImage(r2), e2);
}
patchUpdatedImage(t2, e2, r2) {
if (!t2 || !e2) return;
if (t2.version === e2.version) return;
t2.version = e2.version;
const [n2, i3] = t2.tl;
r2.update(e2.data, void 0, { x: n2, y: i3 });
}
}
var hu;
$n("ImagePosition", uu), $n("ImageAtlas", cu), t.ai = void 0, (hu = t.ai || (t.ai = {}))[hu.none = 0] = "none", hu[hu.horizontal = 1] = "horizontal", hu[hu.vertical = 2] = "vertical", hu[hu.horizontalOnly = 3] = "horizontalOnly";
const pu = -17;
class fu {
constructor() {
this.scale = 1, this.fontStack = "", this.imageName = null;
}
static forText(t2, e2) {
const r2 = new fu();
return r2.scale = t2 || 1, r2.fontStack = e2, r2;
}
static forImage(t2) {
const e2 = new fu();
return e2.imageName = t2, e2;
}
}
class du {
constructor() {
this.text = "", this.sectionIndex = [], this.sections = [], this.imageSectionID = null;
}
static fromFeature(t2, e2) {
const r2 = new du();
for (let n2 = 0; n2 < t2.sections.length; n2++) {
const i3 = t2.sections[n2];
i3.image ? r2.addImageSection(i3) : r2.addTextSection(i3, e2);
}
return r2;
}
length() {
return this.text.length;
}
getSection(t2) {
return this.sections[this.sectionIndex[t2]];
}
getSectionIndex(t2) {
return this.sectionIndex[t2];
}
getCharCode(t2) {
return this.text.charCodeAt(t2);
}
verticalizePunctuation() {
this.text = (function(t2) {
let e2 = "";
for (let r2 = 0; r2 < t2.length; r2++) {
const n2 = t2.charCodeAt(r2 + 1) || null, i3 = t2.charCodeAt(r2 - 1) || null;
e2 += n2 && Kn(n2) && !Pl[t2[r2 + 1]] || i3 && Kn(i3) && !Pl[t2[r2 - 1]] || !Pl[t2[r2]] ? t2[r2] : Pl[t2[r2]];
}
return e2;
})(this.text);
}
trim() {
let t2 = 0;
for (let e3 = 0; e3 < this.text.length && mu[this.text.charCodeAt(e3)]; e3++) t2++;
let e2 = this.text.length;
for (let r2 = this.text.length - 1; r2 >= 0 && r2 >= t2 && mu[this.text.charCodeAt(r2)]; r2--) e2--;
this.text = this.text.substring(t2, e2), this.sectionIndex = this.sectionIndex.slice(t2, e2);
}
substring(t2, e2) {
const r2 = new du();
return r2.text = this.text.substring(t2, e2), r2.sectionIndex = this.sectionIndex.slice(t2, e2), r2.sections = this.sections, r2;
}
toString() {
return this.text;
}
getMaxScale() {
return this.sectionIndex.reduce(((t2, e2) => Math.max(t2, this.sections[e2].scale)), 0);
}
addTextSection(t2, e2) {
this.text += t2.text, this.sections.push(fu.forText(t2.scale, t2.fontStack || e2));
const r2 = this.sections.length - 1;
for (let e3 = 0; e3 < t2.text.length; ++e3) this.sectionIndex.push(r2);
}
addImageSection(t2) {
const e2 = t2.image ? t2.image.name : "";
if (0 === e2.length) return void A("Can't add FormattedSection with an empty image.");
const r2 = this.getNextImageSectionCharCode();
r2 ? (this.text += String.fromCharCode(r2), this.sections.push(fu.forImage(e2)), this.sectionIndex.push(this.sections.length - 1)) : A("Reached maximum number of images 6401");
}
getNextImageSectionCharCode() {
return this.imageSectionID ? this.imageSectionID >= 63743 ? null : ++this.imageSectionID : (this.imageSectionID = 57344, this.imageSectionID);
}
}
function yu(e2, r2, n2, i3, a2, s2, o2, l2, u2, c2, h2, p2, f2, d2, y2, m2) {
const g2 = du.fromFeature(e2, a2);
let x2;
p2 === t.ai.vertical && g2.verticalizePunctuation();
const { processBidirectionalText: v2, processStyledBidirectionalText: b2 } = oi;
if (v2 && 1 === g2.sections.length) {
x2 = [];
const t2 = v2(g2.toString(), Au(g2, c2, s2, r2, i3, d2, y2));
for (const e3 of t2) {
const t3 = new du();
t3.text = e3, t3.sections = g2.sections;
for (let r3 = 0; r3 < e3.length; r3++) t3.sectionIndex.push(0);
x2.push(t3);
}
} else if (b2) {
x2 = [];
const t2 = b2(g2.text, g2.sectionIndex, Au(g2, c2, s2, r2, i3, d2, y2));
for (const e3 of t2) {
const t3 = new du();
t3.text = e3[0], t3.sectionIndex = e3[1], t3.sections = g2.sections, x2.push(t3);
}
} else x2 = (function(t2, e3) {
const r3 = [], n3 = t2.text;
let i4 = 0;
for (const n4 of e3) r3.push(t2.substring(i4, n4)), i4 = n4;
return i4 < n3.length && r3.push(t2.substring(i4, n3.length)), r3;
})(g2, Au(g2, c2, s2, r2, i3, d2, y2));
const w2 = [], _2 = { positionedLines: w2, text: g2.toString(), top: h2[1], bottom: h2[1], left: h2[0], right: h2[0], writingMode: p2, iconsInText: false, verticalizable: false };
return (function(e3, r3, n3, i4, a3, s3, o3, l3, u3, c3, h3, p3) {
let f3 = 0, d3 = pu, y3 = 0, m3 = 0;
const g3 = "right" === l3 ? 1 : "left" === l3 ? 0 : 0.5;
let x3 = 0;
for (const o4 of a3) {
o4.trim();
const a4 = o4.getMaxScale(), l4 = (a4 - 1) * Vl, b4 = { positionedGlyphs: [], lineOffset: 0 };
e3.positionedLines[x3] = b4;
const w4 = b4.positionedGlyphs;
let _4 = 0;
if (!o4.length()) {
d3 += s3, ++x3;
continue;
}
for (let s4 = 0; s4 < o4.length(); s4++) {
const y4 = o4.getSection(s4), m4 = o4.getSectionIndex(s4), g4 = o4.getCharCode(s4);
let x4 = 0, b5 = null, A3 = null, S2 = null, k2 = Vl;
const I2 = !(u3 === t.ai.horizontal || !h3 && !Zn(g4) || h3 && (mu[g4] || (v3 = g4, Rn.Arabic(v3) || Rn["Arabic Supplement"](v3) || Rn["Arabic Extended-A"](v3) || Rn["Arabic Presentation Forms-A"](v3) || Rn["Arabic Presentation Forms-B"](v3))));
if (y4.imageName) {
const t2 = i4[y4.imageName];
if (!t2) continue;
S2 = y4.imageName, e3.iconsInText = e3.iconsInText || true, A3 = t2.paddedRect;
const r4 = t2.displaySize;
y4.scale = y4.scale * Vl / p3, b5 = { width: r4[0], height: r4[1], left: lu, top: -su, advance: I2 ? r4[1] : r4[0] }, x4 = l4 + (Vl - r4[1] * y4.scale), k2 = b5.advance;
const n4 = I2 ? r4[0] * y4.scale - Vl * a4 : r4[1] * y4.scale - Vl * a4;
n4 > 0 && n4 > _4 && (_4 = n4);
} else {
const t2 = n3[y4.fontStack], e4 = t2 && t2[g4];
if (e4 && e4.rect) A3 = e4.rect, b5 = e4.metrics;
else {
const t3 = r3[y4.fontStack], e5 = t3 && t3[g4];
if (!e5) continue;
b5 = e5.metrics;
}
x4 = (a4 - y4.scale) * Vl;
}
I2 ? (e3.verticalizable = true, w4.push({ glyph: g4, imageName: S2, x: f3, y: d3 + x4, vertical: I2, scale: y4.scale, fontStack: y4.fontStack, sectionIndex: m4, metrics: b5, rect: A3 }), f3 += k2 * y4.scale + c3) : (w4.push({ glyph: g4, imageName: S2, x: f3, y: d3 + x4, vertical: I2, scale: y4.scale, fontStack: y4.fontStack, sectionIndex: m4, metrics: b5, rect: A3 }), f3 += b5.advance * y4.scale + c3);
}
0 !== w4.length && (y3 = Math.max(f3 - c3, y3), ku(w4, 0, w4.length - 1, g3, _4)), f3 = 0;
const A2 = s3 * a4 + _4;
b4.lineOffset = Math.max(_4, l4), d3 += A2, m3 = Math.max(A2, m3), ++x3;
}
var v3;
const b3 = d3 - pu, { horizontalAlign: w3, verticalAlign: _3 } = Su(o3);
(function(t2, e4, r4, n4, i5, a4, s4, o4, l4) {
const u4 = (e4 - r4) * i5;
let c4 = 0;
c4 = a4 !== s4 ? -o4 * n4 - pu : (-n4 * l4 + 0.5) * s4;
for (const e5 of t2) for (const t3 of e5.positionedGlyphs) t3.x += u4, t3.y += c4;
})(e3.positionedLines, g3, w3, _3, y3, m3, s3, b3, a3.length), e3.top += -_3 * b3, e3.bottom = e3.top + b3, e3.left += -w3 * y3, e3.right = e3.left + y3;
})(_2, r2, n2, i3, x2, o2, l2, u2, p2, c2, f2, m2), !(function(t2) {
for (const e3 of t2) if (0 !== e3.positionedGlyphs.length) return false;
return true;
})(w2) && _2;
}
const mu = { 9: true, 10: true, 11: true, 12: true, 13: true, 32: true }, gu = { 10: true, 32: true, 38: true, 40: true, 41: true, 43: true, 45: true, 47: true, 173: true, 183: true, 8203: true, 8208: true, 8211: true, 8231: true };
function xu(t2, e2, r2, n2, i3, a2) {
if (e2.imageName) {
const t3 = n2[e2.imageName];
return t3 ? t3.displaySize[0] * e2.scale * Vl / a2 + i3 : 0;
}
{
const n3 = r2[e2.fontStack], a3 = n3 && n3[t2];
return a3 ? a3.metrics.advance * e2.scale + i3 : 0;
}
}
function vu(t2, e2, r2, n2) {
const i3 = Math.pow(t2 - e2, 2);
return n2 ? t2 < e2 ? i3 / 2 : 2 * i3 : i3 + Math.abs(r2) * r2;
}
function bu(t2, e2, r2) {
let n2 = 0;
return 10 === t2 && (n2 -= 1e4), r2 && (n2 += 150), 40 !== t2 && 65288 !== t2 || (n2 += 50), 41 !== e2 && 65289 !== e2 || (n2 += 50), n2;
}
function wu(t2, e2, r2, n2, i3, a2) {
let s2 = null, o2 = vu(e2, r2, i3, a2);
for (const t3 of n2) {
const n3 = vu(e2 - t3.x, r2, i3, a2) + t3.badness;
n3 <= o2 && (s2 = t3, o2 = n3);
}
return { index: t2, x: e2, priorBreak: s2, badness: o2 };
}
function _u(t2) {
return t2 ? _u(t2.priorBreak).concat(t2.index) : [];
}
function Au(t2, e2, r2, n2, i3, a2, s2) {
if ("point" !== a2) return [];
if (!t2) return [];
const o2 = [], l2 = (function(t3, e3, r3, n3, i4, a3) {
let s3 = 0;
for (let r4 = 0; r4 < t3.length(); r4++) {
const o3 = t3.getSection(r4);
s3 += xu(t3.getCharCode(r4), o3, n3, i4, e3, a3);
}
return s3 / Math.max(1, Math.ceil(s3 / r3));
})(t2, e2, r2, n2, i3, s2), u2 = t2.text.indexOf("") >= 0;
let c2 = 0;
for (let r3 = 0; r3 < t2.length(); r3++) {
const a3 = t2.getSection(r3), p2 = t2.getCharCode(r3);
if (mu[p2] || (c2 += xu(p2, a3, n2, i3, e2, s2)), r3 < t2.length() - 1) {
const e3 = !((h2 = p2) < 11904 || !(Rn["Bopomofo Extended"](h2) || Rn.Bopomofo(h2) || Rn["CJK Compatibility Forms"](h2) || Rn["CJK Compatibility Ideographs"](h2) || Rn["CJK Compatibility"](h2) || Rn["CJK Radicals Supplement"](h2) || Rn["CJK Strokes"](h2) || Rn["CJK Symbols and Punctuation"](h2) || Rn["CJK Unified Ideographs Extension A"](h2) || Rn["CJK Unified Ideographs"](h2) || Rn["Enclosed CJK Letters and Months"](h2) || Rn["Halfwidth and Fullwidth Forms"](h2) || Rn.Hiragana(h2) || Rn["Ideographic Description Characters"](h2) || Rn["Kangxi Radicals"](h2) || Rn["Katakana Phonetic Extensions"](h2) || Rn.Katakana(h2) || Rn["Vertical Forms"](h2) || Rn["Yi Radicals"](h2) || Rn["Yi Syllables"](h2)));
(gu[p2] || e3 || a3.imageName) && o2.push(wu(r3 + 1, c2, l2, o2, bu(p2, t2.getCharCode(r3 + 1), e3 && u2), false));
}
}
var h2;
return _u(wu(t2.length(), c2, l2, o2, 0, true));
}
function Su(t2) {
let e2 = 0.5, r2 = 0.5;
switch (t2) {
case "right":
case "top-right":
case "bottom-right":
e2 = 1;
break;
case "left":
case "top-left":
case "bottom-left":
e2 = 0;
}
switch (t2) {
case "bottom":
case "bottom-right":
case "bottom-left":
r2 = 1;
break;
case "top":
case "top-right":
case "top-left":
r2 = 0;
}
return { horizontalAlign: e2, verticalAlign: r2 };
}
function ku(t2, e2, r2, n2, i3) {
if (!n2 && !i3) return;
const a2 = t2[r2], s2 = (t2[r2].x + a2.metrics.advance * a2.scale) * n2;
for (let n3 = e2; n3 <= r2; n3++) t2[n3].x -= s2, t2[n3].y += i3;
}
function Iu(t2, e2, r2) {
const { horizontalAlign: n2, verticalAlign: i3 } = Su(r2), a2 = e2[0] - t2.displaySize[0] * n2, s2 = e2[1] - t2.displaySize[1] * i3;
return { image: t2, top: s2, bottom: s2 + t2.displaySize[1], left: a2, right: a2 + t2.displaySize[0] };
}
function zu(t2, e2, r2, n2, i3, a2) {
const s2 = t2.image;
let o2;
if (s2.content) {
const t3 = s2.content, e3 = s2.pixelRatio || 1;
o2 = [t3[0] / e3, t3[1] / e3, s2.displaySize[0] - t3[2] / e3, s2.displaySize[1] - t3[3] / e3];
}
const l2 = e2.left * a2, u2 = e2.right * a2;
let c2, h2, p2, f2;
"width" === r2 || "both" === r2 ? (f2 = i3[0] + l2 - n2[3], h2 = i3[0] + u2 + n2[1]) : (f2 = i3[0] + (l2 + u2 - s2.displaySize[0]) / 2, h2 = f2 + s2.displaySize[0]);
const d2 = e2.top * a2, y2 = e2.bottom * a2;
return "height" === r2 || "both" === r2 ? (c2 = i3[1] + d2 - n2[0], p2 = i3[1] + y2 + n2[2]) : (c2 = i3[1] + (d2 + y2 - s2.displaySize[1]) / 2, p2 = c2 + s2.displaySize[1]), { image: s2, top: c2, right: h2, bottom: p2, left: f2, collisionPadding: o2 };
}
const Mu = 255, Cu = 128, Bu = Mu * Cu;
function Pu(t2, e2) {
const { expression: r2 } = e2;
if ("constant" === r2.kind) return { kind: "constant", layoutSize: r2.evaluate(new li(t2 + 1)) };
if ("source" === r2.kind) return { kind: "source" };
{
const { zoomStops: e3, interpolationType: n2 } = r2;
let i3 = 0;
for (; i3 < e3.length && e3[i3] <= t2; ) i3++;
i3 = Math.max(0, i3 - 1);
let a2 = i3;
for (; a2 < e3.length && e3[a2] < t2 + 1; ) a2++;
a2 = Math.min(e3.length - 1, a2);
const s2 = e3[i3], o2 = e3[a2];
return "composite" === r2.kind ? { kind: "composite", minZoom: s2, maxZoom: o2, interpolationType: n2 } : { kind: "camera", minZoom: s2, maxZoom: o2, minSize: r2.evaluate(new li(s2)), maxSize: r2.evaluate(new li(o2)), interpolationType: n2 };
}
}
function Vu(t2, e2, r2) {
let n2 = "never";
const i3 = t2.get(e2);
return i3 ? n2 = i3 : t2.get(r2) && (n2 = "always"), n2;
}
const Eu = Ro.VectorTileFeature.types, Fu = [{ name: "a_fade_opacity", components: 1, type: "Uint8", offset: 0 }];
function Tu(t2, e2, r2, n2, i3, a2, s2, o2, l2, u2, c2, h2, p2) {
const f2 = o2 ? Math.min(Bu, Math.round(o2[0])) : 0, d2 = o2 ? Math.min(Bu, Math.round(o2[1])) : 0;
t2.emplaceBack(e2, r2, Math.round(32 * n2), Math.round(32 * i3), a2, s2, (f2 << 1) + (l2 ? 1 : 0), d2, 16 * u2, 16 * c2, 256 * h2, 256 * p2);
}
function $u(t2, e2, r2) {
t2.emplaceBack(e2.x, e2.y, r2), t2.emplaceBack(e2.x, e2.y, r2), t2.emplaceBack(e2.x, e2.y, r2), t2.emplaceBack(e2.x, e2.y, r2);
}
function Lu(t2) {
for (const e2 of t2.sections) if (Xn(e2.text)) return true;
return false;
}
class Du {
constructor(t2) {
this.layoutVertexArray = new xa(), this.indexArray = new Aa(), this.programConfigurations = t2, this.segments = new za(), this.dynamicLayoutVertexArray = new va(), this.opacityVertexArray = new ba(), this.hasVisibleVertices = false, this.placedSymbolArray = new ra();
}
isEmpty() {
return 0 === this.layoutVertexArray.length && 0 === this.indexArray.length && 0 === this.dynamicLayoutVertexArray.length && 0 === this.opacityVertexArray.length;
}
upload(t2, e2, r2, n2) {
this.isEmpty() || (r2 && (this.layoutVertexBuffer = t2.createVertexBuffer(this.layoutVertexArray, kl.members), this.indexBuffer = t2.createIndexBuffer(this.indexArray, e2), this.dynamicLayoutVertexBuffer = t2.createVertexBuffer(this.dynamicLayoutVertexArray, Il.members, true), this.opacityVertexBuffer = t2.createVertexBuffer(this.opacityVertexArray, Fu, true), this.opacityVertexBuffer.itemSize = 1), (r2 || n2) && this.programConfigurations.upload(t2));
}
destroy() {
this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.indexBuffer.destroy(), this.programConfigurations.destroy(), this.segments.destroy(), this.dynamicLayoutVertexBuffer.destroy(), this.opacityVertexBuffer.destroy());
}
}
$n("SymbolBuffers", Du);
class Ou {
constructor(t2, e2, r2) {
this.layoutVertexArray = new t2(), this.layoutAttributes = e2, this.indexArray = new r2(), this.segments = new za(), this.collisionVertexArray = new _a();
}
upload(t2) {
this.layoutVertexBuffer = t2.createVertexBuffer(this.layoutVertexArray, this.layoutAttributes), this.indexBuffer = t2.createIndexBuffer(this.indexArray), this.collisionVertexBuffer = t2.createVertexBuffer(this.collisionVertexArray, zl.members, true);
}
destroy() {
this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.indexBuffer.destroy(), this.segments.destroy(), this.collisionVertexBuffer.destroy());
}
}
$n("CollisionBuffers", Ou);
class Uu {
constructor(e2) {
this.collisionBoxArray = e2.collisionBoxArray, this.zoom = e2.zoom, this.overscaling = e2.overscaling, this.layers = e2.layers, this.layerIds = this.layers.map(((t2) => t2.id)), this.index = e2.index, this.pixelRatio = e2.pixelRatio, this.sourceLayerIndex = e2.sourceLayerIndex, this.hasPattern = false, this.hasRTLText = false, this.sortKeyRanges = [], this.collisionCircleArray = [], this.placementInvProjMatrix = Ms([]), this.placementViewportMatrix = Ms([]);
const r2 = this.layers[0]._unevaluatedLayout._values;
this.textSizeData = Pu(this.zoom, r2["text-size"]), this.iconSizeData = Pu(this.zoom, r2["icon-size"]);
const n2 = this.layers[0].layout, i3 = n2.get("symbol-sort-key"), a2 = n2.get("symbol-z-order");
this.canOverlap = "never" !== Vu(n2, "text-overlap", "text-allow-overlap") || "never" !== Vu(n2, "icon-overlap", "icon-allow-overlap") || n2.get("text-ignore-placement") || n2.get("icon-ignore-placement"), this.sortFeaturesByKey = "viewport-y" !== a2 && !i3.isConstant(), this.sortFeaturesByY = ("viewport-y" === a2 || "auto" === a2 && !this.sortFeaturesByKey) && this.canOverlap, "point" === n2.get("symbol-placement") && (this.writingModes = n2.get("text-writing-mode").map(((e3) => t.ai[e3]))), this.stateDependentLayerIds = this.layers.filter(((t2) => t2.isStateDependent())).map(((t2) => t2.id)), this.sourceID = e2.sourceID;
}
createArrays() {
this.text = new Du(new Qa(this.layers, this.zoom, ((t2) => /^text/.test(t2)))), this.icon = new Du(new Qa(this.layers, this.zoom, ((t2) => /^icon/.test(t2)))), this.glyphOffsetArray = new aa(), this.lineVertexArray = new sa(), this.symbolInstances = new ia(), this.textAnchorOffsets = new la();
}
calculateGlyphDependencies(t2, e2, r2, n2, i3) {
for (let a2 = 0; a2 < t2.length; a2++) if (e2[t2.charCodeAt(a2)] = true, (r2 || n2) && i3) {
const r3 = Pl[t2.charAt(a2)];
r3 && (e2[r3.charCodeAt(0)] = true);
}
}
populate(e2, r2, n2) {
const i3 = this.layers[0], a2 = i3.layout, s2 = a2.get("text-font"), o2 = a2.get("text-field"), l2 = a2.get("icon-image"), u2 = ("constant" !== o2.value.kind || o2.value.value instanceof Qt && !o2.value.value.isEmpty() || o2.value.value.toString().length > 0) && ("constant" !== s2.value.kind || s2.value.value.length > 0), c2 = "constant" !== l2.value.kind || !!l2.value.value || Object.keys(l2.parameters).length > 0, h2 = a2.get("symbol-sort-key");
if (this.features = [], !u2 && !c2) return;
const p2 = r2.iconDependencies, f2 = r2.glyphDependencies, d2 = r2.availableImages, y2 = new li(this.zoom);
for (const { feature: r3, id: o3, index: l3, sourceLayerIndex: m2 } of e2) {
const e3 = i3._featureFilter.needGeometry, g2 = ss(r3, e3);
if (!i3._featureFilter.filter(y2, g2, n2)) continue;
let x2, v2;
if (e3 || (g2.geometry = as(r3)), u2) {
const t2 = i3.getValueAndResolveTokens("text-field", g2, n2, d2), e4 = Qt.factory(t2);
Lu(e4) && (this.hasRTLText = true), (!this.hasRTLText || "unavailable" === ai() || this.hasRTLText && oi.isParsed()) && (x2 = Bl(e4, i3, g2));
}
if (c2) {
const t2 = i3.getValueAndResolveTokens("icon-image", g2, n2, d2);
v2 = t2 instanceof ne ? t2 : ne.fromString(t2);
}
if (!x2 && !v2) continue;
const b2 = this.sortFeaturesByKey ? h2.evaluate(g2, {}, n2) : void 0;
if (this.features.push({ id: o3, text: x2, icon: v2, index: l3, sourceLayerIndex: m2, geometry: g2.geometry, properties: r3.properties, type: Eu[r3.type], sortKey: b2 }), v2 && (p2[v2.name] = true), x2) {
const e4 = s2.evaluate(g2, {}, n2).join(","), r4 = "viewport" !== a2.get("text-rotation-alignment") && "point" !== a2.get("symbol-placement");
this.allowVerticalPlacement = this.writingModes && this.writingModes.indexOf(t.ai.vertical) >= 0;
for (const t2 of x2.sections) if (t2.image) p2[t2.image.name] = true;
else {
const n3 = qn(x2.toString()), i4 = t2.fontStack || e4, a3 = f2[i4] = f2[i4] || {};
this.calculateGlyphDependencies(t2.text, a3, r4, this.allowVerticalPlacement, n3);
}
}
}
"line" === a2.get("symbol-placement") && (this.features = (function(t2) {
const e3 = {}, r3 = {}, n3 = [];
let i4 = 0;
function a3(e4) {
n3.push(t2[e4]), i4++;
}
function s3(t3, e4, i5) {
const a4 = r3[t3];
return delete r3[t3], r3[e4] = a4, n3[a4].geometry[0].pop(), n3[a4].geometry[0] = n3[a4].geometry[0].concat(i5[0]), a4;
}
function o3(t3, r4, i5) {
const a4 = e3[r4];
return delete e3[r4], e3[t3] = a4, n3[a4].geometry[0].shift(), n3[a4].geometry[0] = i5[0].concat(n3[a4].geometry[0]), a4;
}
function l3(t3, e4, r4) {
const n4 = r4 ? e4[0][e4[0].length - 1] : e4[0][0];
return `${t3}:${n4.x}:${n4.y}`;
}
for (let u3 = 0; u3 < t2.length; u3++) {
const c3 = t2[u3], h3 = c3.geometry, p3 = c3.text ? c3.text.toString() : null;
if (!p3) {
a3(u3);
continue;
}
const f3 = l3(p3, h3), d3 = l3(p3, h3, true);
if (f3 in r3 && d3 in e3 && r3[f3] !== e3[d3]) {
const t3 = o3(f3, d3, h3), i5 = s3(f3, d3, n3[t3].geometry);
delete e3[f3], delete r3[d3], r3[l3(p3, n3[i5].geometry, true)] = i5, n3[t3].geometry = null;
} else f3 in r3 ? s3(f3, d3, h3) : d3 in e3 ? o3(f3, d3, h3) : (a3(u3), e3[f3] = i4 - 1, r3[d3] = i4 - 1);
}
return n3.filter(((t3) => t3.geometry));
})(this.features)), this.sortFeaturesByKey && this.features.sort(((t2, e3) => t2.sortKey - e3.sortKey));
}
update(t2, e2, r2) {
this.stateDependentLayers.length && (this.text.programConfigurations.updatePaintArrays(t2, e2, this.layers, r2), this.icon.programConfigurations.updatePaintArrays(t2, e2, this.layers, r2));
}
isEmpty() {
return 0 === this.symbolInstances.length && !this.hasRTLText;
}
uploadPending() {
return !this.uploaded || this.text.programConfigurations.needsUpload || this.icon.programConfigurations.needsUpload;
}
upload(t2) {
!this.uploaded && this.hasDebugData() && (this.textCollisionBox.upload(t2), this.iconCollisionBox.upload(t2)), this.text.upload(t2, this.sortFeaturesByY, !this.uploaded, this.text.programConfigurations.needsUpload), this.icon.upload(t2, this.sortFeaturesByY, !this.uploaded, this.icon.programConfigurations.needsUpload), this.uploaded = true;
}
destroyDebugData() {
this.textCollisionBox.destroy(), this.iconCollisionBox.destroy();
}
destroy() {
this.text.destroy(), this.icon.destroy(), this.hasDebugData() && this.destroyDebugData();
}
addToLineVertexArray(t2, e2) {
const r2 = this.lineVertexArray.length;
if (void 0 !== t2.segment) {
let r3 = t2.dist(e2[t2.segment + 1]), n2 = t2.dist(e2[t2.segment]);
const i3 = {};
for (let n3 = t2.segment + 1; n3 < e2.length; n3++) i3[n3] = { x: e2[n3].x, y: e2[n3].y, tileUnitDistanceFromAnchor: r3 }, n3 < e2.length - 1 && (r3 += e2[n3 + 1].dist(e2[n3]));
for (let r4 = t2.segment || 0; r4 >= 0; r4--) i3[r4] = { x: e2[r4].x, y: e2[r4].y, tileUnitDistanceFromAnchor: n2 }, r4 > 0 && (n2 += e2[r4 - 1].dist(e2[r4]));
for (let t3 = 0; t3 < e2.length; t3++) {
const e3 = i3[t3];
this.lineVertexArray.emplaceBack(e3.x, e3.y, e3.tileUnitDistanceFromAnchor);
}
}
return { lineStartIndex: r2, lineLength: this.lineVertexArray.length - r2 };
}
addSymbols(e2, r2, n2, i3, a2, s2, o2, l2, u2, c2, h2, p2) {
const f2 = e2.indexArray, d2 = e2.layoutVertexArray, y2 = e2.segments.prepareSegment(4 * r2.length, d2, f2, this.canOverlap ? s2.sortKey : void 0), m2 = this.glyphOffsetArray.length, g2 = y2.vertexLength, x2 = this.allowVerticalPlacement && o2 === t.ai.vertical ? Math.PI / 2 : 0, v2 = s2.text && s2.text.sections;
for (let t2 = 0; t2 < r2.length; t2++) {
const { tl: i4, tr: a3, bl: o3, br: u3, tex: c3, pixelOffsetTL: h3, pixelOffsetBR: m3, minFontScaleX: g3, minFontScaleY: b2, glyphOffset: w2, isSDF: _2, sectionIndex: A2 } = r2[t2], S2 = y2.vertexLength, k2 = w2[1];
Tu(d2, l2.x, l2.y, i4.x, k2 + i4.y, c3.x, c3.y, n2, _2, h3.x, h3.y, g3, b2), Tu(d2, l2.x, l2.y, a3.x, k2 + a3.y, c3.x + c3.w, c3.y, n2, _2, m3.x, h3.y, g3, b2), Tu(d2, l2.x, l2.y, o3.x, k2 + o3.y, c3.x, c3.y + c3.h, n2, _2, h3.x, m3.y, g3, b2), Tu(d2, l2.x, l2.y, u3.x, k2 + u3.y, c3.x + c3.w, c3.y + c3.h, n2, _2, m3.x, m3.y, g3, b2), $u(e2.dynamicLayoutVertexArray, l2, x2), f2.emplaceBack(S2, S2 + 1, S2 + 2), f2.emplaceBack(S2 + 1, S2 + 2, S2 + 3), y2.vertexLength += 4, y2.primitiveLength += 2, this.glyphOffsetArray.emplaceBack(w2[0]), t2 !== r2.length - 1 && A2 === r2[t2 + 1].sectionIndex || e2.programConfigurations.populatePaintArrays(d2.length, s2, s2.index, {}, p2, v2 && v2[A2]);
}
e2.placedSymbolArray.emplaceBack(l2.x, l2.y, m2, this.glyphOffsetArray.length - m2, g2, u2, c2, l2.segment, n2 ? n2[0] : 0, n2 ? n2[1] : 0, i3[0], i3[1], o2, 0, false, 0, h2);
}
_addCollisionDebugVertex(t2, e2, r2, n2, i3, a2) {
return e2.emplaceBack(0, 0), t2.emplaceBack(r2.x, r2.y, n2, i3, Math.round(a2.x), Math.round(a2.y));
}
addCollisionDebugVertices(t2, e2, r2, n2, i3, s2, o2) {
const l2 = i3.segments.prepareSegment(4, i3.layoutVertexArray, i3.indexArray), u2 = l2.vertexLength, c2 = i3.layoutVertexArray, h2 = i3.collisionVertexArray, p2 = o2.anchorX, f2 = o2.anchorY;
this._addCollisionDebugVertex(c2, h2, s2, p2, f2, new a(t2, e2)), this._addCollisionDebugVertex(c2, h2, s2, p2, f2, new a(r2, e2)), this._addCollisionDebugVertex(c2, h2, s2, p2, f2, new a(r2, n2)), this._addCollisionDebugVertex(c2, h2, s2, p2, f2, new a(t2, n2)), l2.vertexLength += 4;
const d2 = i3.indexArray;
d2.emplaceBack(u2, u2 + 1), d2.emplaceBack(u2 + 1, u2 + 2), d2.emplaceBack(u2 + 2, u2 + 3), d2.emplaceBack(u2 + 3, u2), l2.primitiveLength += 4;
}
addDebugCollisionBoxes(t2, e2, r2, n2) {
for (let i3 = t2; i3 < e2; i3++) {
const t3 = this.collisionBoxArray.get(i3);
this.addCollisionDebugVertices(t3.x1, t3.y1, t3.x2, t3.y2, n2 ? this.textCollisionBox : this.iconCollisionBox, t3.anchorPoint, r2);
}
}
generateCollisionDebugBuffers() {
this.hasDebugData() && this.destroyDebugData(), this.textCollisionBox = new Ou(wa, Ml.members, Sa), this.iconCollisionBox = new Ou(wa, Ml.members, Sa);
for (let t2 = 0; t2 < this.symbolInstances.length; t2++) {
const e2 = this.symbolInstances.get(t2);
this.addDebugCollisionBoxes(e2.textBoxStartIndex, e2.textBoxEndIndex, e2, true), this.addDebugCollisionBoxes(e2.verticalTextBoxStartIndex, e2.verticalTextBoxEndIndex, e2, true), this.addDebugCollisionBoxes(e2.iconBoxStartIndex, e2.iconBoxEndIndex, e2, false), this.addDebugCollisionBoxes(e2.verticalIconBoxStartIndex, e2.verticalIconBoxEndIndex, e2, false);
}
}
_deserializeCollisionBoxesForSymbol(t2, e2, r2, n2, i3, a2, s2, o2, l2) {
const u2 = {};
for (let n3 = e2; n3 < r2; n3++) {
const e3 = t2.get(n3);
u2.textBox = { x1: e3.x1, y1: e3.y1, x2: e3.x2, y2: e3.y2, anchorPointX: e3.anchorPointX, anchorPointY: e3.anchorPointY }, u2.textFeatureIndex = e3.featureIndex;
break;
}
for (let e3 = n2; e3 < i3; e3++) {
const r3 = t2.get(e3);
u2.verticalTextBox = { x1: r3.x1, y1: r3.y1, x2: r3.x2, y2: r3.y2, anchorPointX: r3.anchorPointX, anchorPointY: r3.anchorPointY }, u2.verticalTextFeatureIndex = r3.featureIndex;
break;
}
for (let e3 = a2; e3 < s2; e3++) {
const r3 = t2.get(e3);
u2.iconBox = { x1: r3.x1, y1: r3.y1, x2: r3.x2, y2: r3.y2, anchorPointX: r3.anchorPointX, anchorPointY: r3.anchorPointY }, u2.iconFeatureIndex = r3.featureIndex;
break;
}
for (let e3 = o2; e3 < l2; e3++) {
const r3 = t2.get(e3);
u2.verticalIconBox = { x1: r3.x1, y1: r3.y1, x2: r3.x2, y2: r3.y2, anchorPointX: r3.anchorPointX, anchorPointY: r3.anchorPointY }, u2.verticalIconFeatureIndex = r3.featureIndex;
break;
}
return u2;
}
deserializeCollisionBoxes(t2) {
this.collisionArrays = [];
for (let e2 = 0; e2 < this.symbolInstances.length; e2++) {
const r2 = this.symbolInstances.get(e2);
this.collisionArrays.push(this._deserializeCollisionBoxesForSymbol(t2, r2.textBoxStartIndex, r2.textBoxEndIndex, r2.verticalTextBoxStartIndex, r2.verticalTextBoxEndIndex, r2.iconBoxStartIndex, r2.iconBoxEndIndex, r2.verticalIconBoxStartIndex, r2.verticalIconBoxEndIndex));
}
}
hasTextData() {
return this.text.segments.get().length > 0;
}
hasIconData() {
return this.icon.segments.get().length > 0;
}
hasDebugData() {
return this.textCollisionBox && this.iconCollisionBox;
}
hasTextCollisionBoxData() {
return this.hasDebugData() && this.textCollisionBox.segments.get().length > 0;
}
hasIconCollisionBoxData() {
return this.hasDebugData() && this.iconCollisionBox.segments.get().length > 0;
}
addIndicesForPlacedSymbol(t2, e2) {
const r2 = t2.placedSymbolArray.get(e2), n2 = r2.vertexStartIndex + 4 * r2.numGlyphs;
for (let e3 = r2.vertexStartIndex; e3 < n2; e3 += 4) t2.indexArray.emplaceBack(e3, e3 + 1, e3 + 2), t2.indexArray.emplaceBack(e3 + 1, e3 + 2, e3 + 3);
}
getSortedSymbolIndexes(t2) {
if (this.sortedAngle === t2 && void 0 !== this.symbolInstanceIndexes) return this.symbolInstanceIndexes;
const e2 = Math.sin(t2), r2 = Math.cos(t2), n2 = [], i3 = [], a2 = [];
for (let t3 = 0; t3 < this.symbolInstances.length; ++t3) {
a2.push(t3);
const s2 = this.symbolInstances.get(t3);
n2.push(0 | Math.round(e2 * s2.anchorX + r2 * s2.anchorY)), i3.push(s2.featureIndex);
}
return a2.sort(((t3, e3) => n2[t3] - n2[e3] || i3[e3] - i3[t3])), a2;
}
addToSortKeyRanges(t2, e2) {
const r2 = this.sortKeyRanges[this.sortKeyRanges.length - 1];
r2 && r2.sortKey === e2 ? r2.symbolInstanceEnd = t2 + 1 : this.sortKeyRanges.push({ sortKey: e2, symbolInstanceStart: t2, symbolInstanceEnd: t2 + 1 });
}
sortFeatures(t2) {
if (this.sortFeaturesByY && this.sortedAngle !== t2 && !(this.text.segments.get().length > 1 || this.icon.segments.get().length > 1)) {
this.symbolInstanceIndexes = this.getSortedSymbolIndexes(t2), this.sortedAngle = t2, this.text.indexArray.clear(), this.icon.indexArray.clear(), this.featureSortOrder = [];
for (const t3 of this.symbolInstanceIndexes) {
const e2 = this.symbolInstances.get(t3);
this.featureSortOrder.push(e2.featureIndex), [e2.rightJustifiedTextSymbolIndex, e2.centerJustifiedTextSymbolIndex, e2.leftJustifiedTextSymbolIndex].forEach(((t4, e3, r2) => {
t4 >= 0 && r2.indexOf(t4) === e3 && this.addIndicesForPlacedSymbol(this.text, t4);
})), e2.verticalPlacedTextSymbolIndex >= 0 && this.addIndicesForPlacedSymbol(this.text, e2.verticalPlacedTextSymbolIndex), e2.placedIconSymbolIndex >= 0 && this.addIndicesForPlacedSymbol(this.icon, e2.placedIconSymbolIndex), e2.verticalPlacedIconSymbolIndex >= 0 && this.addIndicesForPlacedSymbol(this.icon, e2.verticalPlacedIconSymbolIndex);
}
this.text.indexBuffer && this.text.indexBuffer.updateData(this.text.indexArray), this.icon.indexBuffer && this.icon.indexBuffer.updateData(this.icon.indexArray);
}
}
}
let Ru, qu;
$n("SymbolBucket", Uu, { omit: ["layers", "collisionBoxArray", "features", "compareText"] }), Uu.MAX_GLYPHS = 65535, Uu.addDynamicAttributes = $u;
var ju = { get paint() {
return qu = qu || new _i({ "icon-opacity": new xi(X.paint_symbol["icon-opacity"]), "icon-color": new xi(X.paint_symbol["icon-color"]), "icon-halo-color": new xi(X.paint_symbol["icon-halo-color"]), "icon-halo-width": new xi(X.paint_symbol["icon-halo-width"]), "icon-halo-blur": new xi(X.paint_symbol["icon-halo-blur"]), "icon-translate": new gi(X.paint_symbol["icon-translate"]), "icon-translate-anchor": new gi(X.paint_symbol["icon-translate-anchor"]), "text-opacity": new xi(X.paint_symbol["text-opacity"]), "text-color": new xi(X.paint_symbol["text-color"], { runtimeType: yt, getOverride: (t2) => t2.textColor, hasOverride: (t2) => !!t2.textColor }), "text-halo-color": new xi(X.paint_symbol["text-halo-color"]), "text-halo-width": new xi(X.paint_symbol["text-halo-width"]), "text-halo-blur": new xi(X.paint_symbol["text-halo-blur"]), "text-translate": new gi(X.paint_symbol["text-translate"]), "text-translate-anchor": new gi(X.paint_symbol["text-translate-anchor"]) });
}, get layout() {
return Ru = Ru || new _i({ "symbol-placement": new gi(X.layout_symbol["symbol-placement"]), "symbol-spacing": new gi(X.layout_symbol["symbol-spacing"]), "symbol-avoid-edges": new gi(X.layout_symbol["symbol-avoid-edges"]), "symbol-sort-key": new xi(X.layout_symbol["symbol-sort-key"]), "symbol-z-order": new gi(X.layout_symbol["symbol-z-order"]), "icon-allow-overlap": new gi(X.layout_symbol["icon-allow-overlap"]), "icon-overlap": new gi(X.layout_symbol["icon-overlap"]), "icon-ignore-placement": new gi(X.layout_symbol["icon-ignore-placement"]), "icon-optional": new gi(X.layout_symbol["icon-optional"]), "icon-rotation-alignment": new gi(X.layout_symbol["icon-rotation-alignment"]), "icon-size": new xi(X.layout_symbol["icon-size"]), "icon-text-fit": new gi(X.layout_symbol["icon-text-fit"]), "icon-text-fit-padding": new gi(X.layout_symbol["icon-text-fit-padding"]), "icon-image": new xi(X.layout_symbol["icon-image"]), "icon-rotate": new xi(X.layout_symbol["icon-rotate"]), "icon-padding": new xi(X.layout_symbol["icon-padding"]), "icon-keep-upright": new gi(X.layout_symbol["icon-keep-upright"]), "icon-offset": new xi(X.layout_symbol["icon-offset"]), "icon-anchor": new xi(X.layout_symbol["icon-anchor"]), "icon-pitch-alignment": new gi(X.layout_symbol["icon-pitch-alignment"]), "text-pitch-alignment": new gi(X.layout_symbol["text-pitch-alignment"]), "text-rotation-alignment": new gi(X.layout_symbol["text-rotation-alignment"]), "text-field": new xi(X.layout_symbol["text-field"]), "text-font": new xi(X.layout_symbol["text-font"]), "text-size": new xi(X.layout_symbol["text-size"]), "text-max-width": new xi(X.layout_symbol["text-max-width"]), "text-line-height": new gi(X.layout_symbol["text-line-height"]), "text-letter-spacing": new xi(X.layout_symbol["text-letter-spacing"]), "text-justify": new xi(X.layout_symbol["text-justify"]), "text-radial-offset": new xi(X.layout_symbol["text-radial-offset"]), "text-variable-anchor": new gi(X.layout_symbol["text-variable-anchor"]), "text-variable-anchor-offset": new xi(X.layout_symbol["text-variable-anchor-offset"]), "text-anchor": new xi(X.layout_symbol["text-anchor"]), "text-max-angle": new gi(X.layout_symbol["text-max-angle"]), "text-writing-mode": new gi(X.layout_symbol["text-writing-mode"]), "text-rotate": new xi(X.layout_symbol["text-rotate"]), "text-padding": new gi(X.layout_symbol["text-padding"]), "text-keep-upright": new gi(X.layout_symbol["text-keep-upright"]), "text-transform": new xi(X.layout_symbol["text-transform"]), "text-offset": new xi(X.layout_symbol["text-offset"]), "text-allow-overlap": new gi(X.layout_symbol["text-allow-overlap"]), "text-overlap": new gi(X.layout_symbol["text-overlap"]), "text-ignore-placement": new gi(X.layout_symbol["text-ignore-placement"]), "text-optional": new gi(X.layout_symbol["text-optional"]) });
} };
class Nu {
constructor(t2) {
if (void 0 === t2.property.overrides) throw new Error("overrides must be provided to instantiate FormatSectionOverride class");
this.type = t2.property.overrides ? t2.property.overrides.runtimeType : ht, this.defaultValue = t2;
}
evaluate(t2) {
if (t2.formattedSection) {
const e2 = this.defaultValue.property.overrides;
if (e2 && e2.hasOverride(t2.formattedSection)) return e2.getOverride(t2.formattedSection);
}
return t2.feature && t2.featureState ? this.defaultValue.evaluate(t2.feature, t2.featureState) : this.defaultValue.property.specification.default;
}
eachChild(t2) {
this.defaultValue.isConstant() || t2(this.defaultValue.value._styleExpression.expression);
}
outputDefined() {
return false;
}
serialize() {
return null;
}
}
$n("FormatSectionOverride", Nu, { omit: ["defaultValue"] });
class Zu extends Si {
constructor(t2) {
super(t2, ju);
}
recalculate(t2, e2) {
if (super.recalculate(t2, e2), "auto" === this.layout.get("icon-rotation-alignment") && (this.layout._values["icon-rotation-alignment"] = "point" !== this.layout.get("symbol-placement") ? "map" : "viewport"), "auto" === this.layout.get("text-rotation-alignment") && (this.layout._values["text-rotation-alignment"] = "point" !== this.layout.get("symbol-placement") ? "map" : "viewport"), "auto" === this.layout.get("text-pitch-alignment") && (this.layout._values["text-pitch-alignment"] = "map" === this.layout.get("text-rotation-alignment") ? "map" : "viewport"), "auto" === this.layout.get("icon-pitch-alignment") && (this.layout._values["icon-pitch-alignment"] = this.layout.get("icon-rotation-alignment")), "point" === this.layout.get("symbol-placement")) {
const t3 = this.layout.get("text-writing-mode");
if (t3) {
const e3 = [];
for (const r2 of t3) e3.indexOf(r2) < 0 && e3.push(r2);
this.layout._values["text-writing-mode"] = e3;
} else this.layout._values["text-writing-mode"] = ["horizontal"];
}
this._setPaintOverrides();
}
getValueAndResolveTokens(t2, e2, r2, n2) {
const i3 = this.layout.get(t2).evaluate(e2, {}, r2, n2), a2 = this._unevaluatedLayout._values[t2];
return a2.isDataDriven() || Tr(a2.value) || !i3 ? i3 : (function(t3, e3) {
return e3.replace(/{([^{}]+)}/g, ((e4, r3) => t3 && r3 in t3 ? String(t3[r3]) : ""));
})(e2.properties, i3);
}
createBucket(t2) {
return new Uu(t2);
}
queryRadius() {
return 0;
}
queryIntersectsFeature() {
throw new Error("Should take a different path in FeatureIndex");
}
_setPaintOverrides() {
for (const t2 of ju.paint.overridableProperties) {
if (!Zu.hasPaintOverride(this.layout, t2)) continue;
const e2 = this.paint.get(t2), r2 = new Nu(e2), n2 = new Fr(r2, e2.property.specification);
let i3 = null;
i3 = "constant" === e2.value.kind || "source" === e2.value.kind ? new Lr("source", n2) : new Dr("composite", n2, e2.value.zoomStops), this.paint._values[t2] = new yi(e2.property, i3, e2.parameters);
}
}
_handleOverridablePaintPropertyUpdate(t2, e2, r2) {
return !(!this.layout || e2.isDataDriven() || r2.isDataDriven()) && Zu.hasPaintOverride(this.layout, t2);
}
static hasPaintOverride(t2, e2) {
const r2 = t2.get("text-field"), n2 = ju.paint.properties[e2];
let i3 = false;
const a2 = (t3) => {
for (const e3 of t3) if (n2.overrides && n2.overrides.hasOverride(e3)) return void (i3 = true);
};
if ("constant" === r2.value.kind && r2.value.value instanceof Qt) a2(r2.value.value.sections);
else if ("source" === r2.value.kind) {
const t3 = (e4) => {
i3 || (e4 instanceof le && se(e4.value) === vt ? a2(e4.value.sections) : e4 instanceof pr ? a2(e4.sections) : e4.eachChild(t3));
}, e3 = r2.value;
e3._styleExpression && t3(e3._styleExpression.expression);
}
return i3;
}
}
let Ku;
var Gu = { get paint() {
return Ku = Ku || new _i({ "background-color": new gi(X.paint_background["background-color"]), "background-pattern": new bi(X.paint_background["background-pattern"]), "background-opacity": new gi(X.paint_background["background-opacity"]) });
} };
class Ju extends Si {
constructor(t2) {
super(t2, Gu);
}
}
let Xu;
var Yu = { get paint() {
return Xu = Xu || new _i({ "raster-opacity": new gi(X.paint_raster["raster-opacity"]), "raster-hue-rotate": new gi(X.paint_raster["raster-hue-rotate"]), "raster-brightness-min": new gi(X.paint_raster["raster-brightness-min"]), "raster-brightness-max": new gi(X.paint_raster["raster-brightness-max"]), "raster-saturation": new gi(X.paint_raster["raster-saturation"]), "raster-contrast": new gi(X.paint_raster["raster-contrast"]), "raster-resampling": new gi(X.paint_raster["raster-resampling"]), "raster-fade-duration": new gi(X.paint_raster["raster-fade-duration"]) });
} };
class Hu extends Si {
constructor(t2) {
super(t2, Yu);
}
}
class Wu extends Si {
constructor(t2) {
super(t2, {}), this.onAdd = (t3) => {
this.implementation.onAdd && this.implementation.onAdd(t3, t3.painter.context.gl);
}, this.onRemove = (t3) => {
this.implementation.onRemove && this.implementation.onRemove(t3, t3.painter.context.gl);
}, this.implementation = t2;
}
is3D() {
return "3d" === this.implementation.renderingMode;
}
hasOffscreenPass() {
return void 0 !== this.implementation.prerender;
}
recalculate() {
}
updateTransitions() {
}
hasTransition() {
return false;
}
serialize() {
throw new Error("Custom layers cannot be serialized");
}
}
class Qu {
constructor(t2) {
this._callback = t2, this._triggered = false, "undefined" != typeof MessageChannel && (this._channel = new MessageChannel(), this._channel.port2.onmessage = () => {
this._triggered = false, this._callback();
});
}
trigger() {
this._triggered || (this._triggered = true, this._channel ? this._channel.port1.postMessage(true) : setTimeout((() => {
this._triggered = false, this._callback();
}), 0));
}
remove() {
delete this._channel, this._callback = () => {
};
}
}
const tc = 63710088e-1;
class ec {
constructor(t2, e2) {
if (isNaN(t2) || isNaN(e2)) throw new Error(`Invalid LngLat object: (${t2}, ${e2})`);
if (this.lng = +t2, this.lat = +e2, this.lat > 90 || this.lat < -90) throw new Error("Invalid LngLat latitude value: must be between -90 and 90");
}
wrap() {
return new ec(m(this.lng, -180, 180), this.lat);
}
toArray() {
return [this.lng, this.lat];
}
toString() {
return `LngLat(${this.lng}, ${this.lat})`;
}
distanceTo(t2) {
const e2 = Math.PI / 180, r2 = this.lat * e2, n2 = t2.lat * e2, i3 = Math.sin(r2) * Math.sin(n2) + Math.cos(r2) * Math.cos(n2) * Math.cos((t2.lng - this.lng) * e2);
return tc * Math.acos(Math.min(i3, 1));
}
static convert(t2) {
if (t2 instanceof ec) return t2;
if (Array.isArray(t2) && (2 === t2.length || 3 === t2.length)) return new ec(Number(t2[0]), Number(t2[1]));
if (!Array.isArray(t2) && "object" == typeof t2 && null !== t2) return new ec(Number("lng" in t2 ? t2.lng : t2.lon), Number(t2.lat));
throw new Error("`LngLatLike` argument must be specified as a LngLat instance, an object {lng: <lng>, lat: <lat>}, an object {lon: <lng>, lat: <lat>}, or an array of [<lng>, <lat>]");
}
}
const rc = 2 * Math.PI * tc;
function nc(t2) {
return rc * Math.cos(t2 * Math.PI / 180);
}
function ic(t2) {
return (180 + t2) / 360;
}
function ac(t2) {
return (180 - 180 / Math.PI * Math.log(Math.tan(Math.PI / 4 + t2 * Math.PI / 360))) / 360;
}
function sc(t2, e2) {
return t2 / nc(e2);
}
function oc(t2) {
return 360 * t2 - 180;
}
function lc(t2) {
return 360 / Math.PI * Math.atan(Math.exp((180 - 360 * t2) * Math.PI / 180)) - 90;
}
class uc {
constructor(t2, e2, r2 = 0) {
this.x = +t2, this.y = +e2, this.z = +r2;
}
static fromLngLat(t2, e2 = 0) {
const r2 = ec.convert(t2);
return new uc(ic(r2.lng), ac(r2.lat), sc(e2, r2.lat));
}
toLngLat() {
return new ec(oc(this.x), lc(this.y));
}
toAltitude() {
return this.z * nc(lc(this.y));
}
meterInMercatorCoordinateUnits() {
return 1 / rc * (t2 = lc(this.y), 1 / Math.cos(t2 * Math.PI / 180));
var t2;
}
}
function cc(t2, e2, r2) {
var n2 = 2 * Math.PI * 6378137 / 256 / Math.pow(2, r2);
return [t2 * n2 - 2 * Math.PI * 6378137 / 2, e2 * n2 - 2 * Math.PI * 6378137 / 2];
}
class hc {
constructor(t2, e2, r2) {
if (t2 < 0 || t2 > 25 || r2 < 0 || r2 >= Math.pow(2, t2) || e2 < 0 || e2 >= Math.pow(2, t2)) throw new Error(`x=${e2}, y=${r2}, z=${t2} outside of bounds. 0<=x<${Math.pow(2, t2)}, 0<=y<${Math.pow(2, t2)} 0<=z<=25 `);
this.z = t2, this.x = e2, this.y = r2, this.key = dc(0, t2, t2, e2, r2);
}
equals(t2) {
return this.z === t2.z && this.x === t2.x && this.y === t2.y;
}
url(t2, e2, r2) {
const n2 = (a2 = this.y, s2 = this.z, o2 = cc(256 * (i3 = this.x), 256 * (a2 = Math.pow(2, s2) - a2 - 1), s2), l2 = cc(256 * (i3 + 1), 256 * (a2 + 1), s2), o2[0] + "," + o2[1] + "," + l2[0] + "," + l2[1]);
var i3, a2, s2, o2, l2;
const u2 = (function(t3, e3, r3) {
let n3, i4 = "";
for (let a3 = t3; a3 > 0; a3--) n3 = 1 << a3 - 1, i4 += (e3 & n3 ? 1 : 0) + (r3 & n3 ? 2 : 0);
return i4;
})(this.z, this.x, this.y);
return t2[(this.x + this.y) % t2.length].replace(/{prefix}/g, (this.x % 16).toString(16) + (this.y % 16).toString(16)).replace(/{z}/g, String(this.z)).replace(/{x}/g, String(this.x)).replace(/{y}/g, String("tms" === r2 ? Math.pow(2, this.z) - this.y - 1 : this.y)).replace(/{ratio}/g, e2 > 1 ? "@2x" : "").replace(/{quadkey}/g, u2).replace(/{bbox-epsg-3857}/g, n2);
}
isChildOf(t2) {
const e2 = this.z - t2.z;
return e2 > 0 && t2.x === this.x >> e2 && t2.y === this.y >> e2;
}
getTilePoint(t2) {
const e2 = Math.pow(2, this.z);
return new a((t2.x * e2 - this.x) * rs, (t2.y * e2 - this.y) * rs);
}
toString() {
return `${this.z}/${this.x}/${this.y}`;
}
}
class pc {
constructor(t2, e2) {
this.wrap = t2, this.canonical = e2, this.key = dc(t2, e2.z, e2.z, e2.x, e2.y);
}
}
class fc {
constructor(t2, e2, r2, n2, i3) {
if (t2 < r2) throw new Error(`overscaledZ should be >= z; overscaledZ = ${t2}; z = ${r2}`);
this.overscaledZ = t2, this.wrap = e2, this.canonical = new hc(r2, +n2, +i3), this.key = dc(e2, t2, r2, n2, i3);
}
clone() {
return new fc(this.overscaledZ, this.wrap, this.canonical.z, this.canonical.x, this.canonical.y);
}
equals(t2) {
return this.overscaledZ === t2.overscaledZ && this.wrap === t2.wrap && this.canonical.equals(t2.canonical);
}
scaledTo(t2) {
if (t2 > this.overscaledZ) throw new Error(`targetZ > this.overscaledZ; targetZ = ${t2}; overscaledZ = ${this.overscaledZ}`);
const e2 = this.canonical.z - t2;
return t2 > this.canonical.z ? new fc(t2, this.wrap, this.canonical.z, this.canonical.x, this.canonical.y) : new fc(t2, this.wrap, t2, this.canonical.x >> e2, this.canonical.y >> e2);
}
calculateScaledKey(t2, e2) {
if (t2 > this.overscaledZ) throw new Error(`targetZ > this.overscaledZ; targetZ = ${t2}; overscaledZ = ${this.overscaledZ}`);
const r2 = this.canonical.z - t2;
return t2 > this.canonical.z ? dc(this.wrap * +e2, t2, this.canonical.z, this.canonical.x, this.canonical.y) : dc(this.wrap * +e2, t2, t2, this.canonical.x >> r2, this.canonical.y >> r2);
}
isChildOf(t2) {
if (t2.wrap !== this.wrap) return false;
const e2 = this.canonical.z - t2.canonical.z;
return 0 === t2.overscaledZ || t2.overscaledZ < this.overscaledZ && t2.canonical.x === this.canonical.x >> e2 && t2.canonical.y === this.canonical.y >> e2;
}
children(t2) {
if (this.overscaledZ >= t2) return [new fc(this.overscaledZ + 1, this.wrap, this.canonical.z, this.canonical.x, this.canonical.y)];
const e2 = this.canonical.z + 1, r2 = 2 * this.canonical.x, n2 = 2 * this.canonical.y;
return [new fc(e2, this.wrap, e2, r2, n2), new fc(e2, this.wrap, e2, r2 + 1, n2), new fc(e2, this.wrap, e2, r2, n2 + 1), new fc(e2, this.wrap, e2, r2 + 1, n2 + 1)];
}
isLessThan(t2) {
return this.wrap < t2.wrap || !(this.wrap > t2.wrap) && (this.overscaledZ < t2.overscaledZ || !(this.overscaledZ > t2.overscaledZ) && (this.canonical.x < t2.canonical.x || !(this.canonical.x > t2.canonical.x) && this.canonical.y < t2.canonical.y));
}
wrapped() {
return new fc(this.overscaledZ, 0, this.canonical.z, this.canonical.x, this.canonical.y);
}
unwrapTo(t2) {
return new fc(this.overscaledZ, t2, this.canonical.z, this.canonical.x, this.canonical.y);
}
overscaleFactor() {
return Math.pow(2, this.overscaledZ - this.canonical.z);
}
toUnwrapped() {
return new pc(this.wrap, this.canonical);
}
toString() {
return `${this.overscaledZ}/${this.canonical.x}/${this.canonical.y}`;
}
getTilePoint(t2) {
return this.canonical.getTilePoint(new uc(t2.x - this.wrap, t2.y));
}
}
function dc(t2, e2, r2, n2, i3) {
(t2 *= 2) < 0 && (t2 = -1 * t2 - 1);
const a2 = 1 << r2;
return (a2 * a2 * t2 + a2 * i3 + n2).toString(36) + r2.toString(36) + e2.toString(36);
}
$n("CanonicalTileID", hc), $n("OverscaledTileID", fc, { omit: ["posMatrix"] });
class yc {
constructor(t2, e2, r2, n2 = 1, i3 = 1, a2 = 1, s2 = 0) {
if (this.uid = t2, e2.height !== e2.width) throw new RangeError("DEM tiles must be square");
if (r2 && !["mapbox", "terrarium", "custom"].includes(r2)) return void A(`"${r2}" is not a valid encoding type. Valid types include "mapbox", "terrarium" and "custom".`);
this.stride = e2.height;
const o2 = this.dim = e2.height - 2;
switch (this.data = new Uint32Array(e2.data.buffer), r2) {
case "terrarium":
this.redFactor = 256, this.greenFactor = 1, this.blueFactor = 1 / 256, this.baseShift = 32768;
break;
case "custom":
this.redFactor = n2, this.greenFactor = i3, this.blueFactor = a2, this.baseShift = s2;
break;
default:
this.redFactor = 6553.6, this.greenFactor = 25.6, this.blueFactor = 0.1, this.baseShift = 1e4;
}
for (let t3 = 0; t3 < o2; t3++) this.data[this._idx(-1, t3)] = this.data[this._idx(0, t3)], this.data[this._idx(o2, t3)] = this.data[this._idx(o2 - 1, t3)], this.data[this._idx(t3, -1)] = this.data[this._idx(t3, 0)], this.data[this._idx(t3, o2)] = this.data[this._idx(t3, o2 - 1)];
this.data[this._idx(-1, -1)] = this.data[this._idx(0, 0)], this.data[this._idx(o2, -1)] = this.data[this._idx(o2 - 1, 0)], this.data[this._idx(-1, o2)] = this.data[this._idx(0, o2 - 1)], this.data[this._idx(o2, o2)] = this.data[this._idx(o2 - 1, o2 - 1)], this.min = Number.MAX_SAFE_INTEGER, this.max = Number.MIN_SAFE_INTEGER;
for (let t3 = 0; t3 < o2; t3++) for (let e3 = 0; e3 < o2; e3++) {
const r3 = this.get(t3, e3);
r3 > this.max && (this.max = r3), r3 < this.min && (this.min = r3);
}
}
get(t2, e2) {
const r2 = new Uint8Array(this.data.buffer), n2 = 4 * this._idx(t2, e2);
return this.unpack(r2[n2], r2[n2 + 1], r2[n2 + 2]);
}
getUnpackVector() {
return [this.redFactor, this.greenFactor, this.blueFactor, this.baseShift];
}
_idx(t2, e2) {
if (t2 < -1 || t2 >= this.dim + 1 || e2 < -1 || e2 >= this.dim + 1) throw new RangeError("out of range source coordinates for DEM data");
return (e2 + 1) * this.stride + (t2 + 1);
}
unpack(t2, e2, r2) {
return t2 * this.redFactor + e2 * this.greenFactor + r2 * this.blueFactor - this.baseShift;
}
getPixels() {
return new qs({ width: this.stride, height: this.stride }, new Uint8Array(this.data.buffer));
}
backfillBorder(t2, e2, r2) {
if (this.dim !== t2.dim) throw new Error("dem dimension mismatch");
let n2 = e2 * this.dim, i3 = e2 * this.dim + this.dim, a2 = r2 * this.dim, s2 = r2 * this.dim + this.dim;
switch (e2) {
case -1:
n2 = i3 - 1;
break;
case 1:
i3 = n2 + 1;
}
switch (r2) {
case -1:
a2 = s2 - 1;
break;
case 1:
s2 = a2 + 1;
}
const o2 = -e2 * this.dim, l2 = -r2 * this.dim;
for (let e3 = a2; e3 < s2; e3++) for (let r3 = n2; r3 < i3; r3++) this.data[this._idx(r3, e3)] = t2.data[this._idx(r3 + o2, e3 + l2)];
}
}
$n("DEMData", yc);
class mc {
constructor(t2) {
this._stringToNumber = {}, this._numberToString = [];
for (let e2 = 0; e2 < t2.length; e2++) {
const r2 = t2[e2];
this._stringToNumber[r2] = e2, this._numberToString[e2] = r2;
}
}
encode(t2) {
return this._stringToNumber[t2];
}
decode(t2) {
if (t2 >= this._numberToString.length) throw new Error(`Out of bounds. Index requested n=${t2} can't be >= this._numberToString.length ${this._numberToString.length}`);
return this._numberToString[t2];
}
}
class gc {
constructor(t2, e2, r2, n2, i3) {
this.type = "Feature", this._vectorTileFeature = t2, t2._z = e2, t2._x = r2, t2._y = n2, this.properties = t2.properties, this.id = i3;
}
get geometry() {
return void 0 === this._geometry && (this._geometry = this._vectorTileFeature.toGeoJSON(this._vectorTileFeature._x, this._vectorTileFeature._y, this._vectorTileFeature._z).geometry), this._geometry;
}
set geometry(t2) {
this._geometry = t2;
}
toJSON() {
const t2 = { geometry: this.geometry };
for (const e2 in this) "_geometry" !== e2 && "_vectorTileFeature" !== e2 && (t2[e2] = this[e2]);
return t2;
}
}
class xc {
constructor(t2, e2) {
this.tileID = t2, this.x = t2.canonical.x, this.y = t2.canonical.y, this.z = t2.canonical.z, this.grid = new Fn(rs, 16, 0), this.grid3D = new Fn(rs, 16, 0), this.featureIndexArray = new ca(), this.promoteId = e2;
}
insert(t2, e2, r2, n2, i3, a2) {
const s2 = this.featureIndexArray.length;
this.featureIndexArray.emplaceBack(r2, n2, i3);
const o2 = a2 ? this.grid3D : this.grid;
for (let t3 = 0; t3 < e2.length; t3++) {
const r3 = e2[t3], n3 = [1 / 0, 1 / 0, -1 / 0, -1 / 0];
for (let t4 = 0; t4 < r3.length; t4++) {
const e3 = r3[t4];
n3[0] = Math.min(n3[0], e3.x), n3[1] = Math.min(n3[1], e3.y), n3[2] = Math.max(n3[2], e3.x), n3[3] = Math.max(n3[3], e3.y);
}
n3[0] < rs && n3[1] < rs && n3[2] >= 0 && n3[3] >= 0 && o2.insert(s2, n3[0], n3[1], n3[2], n3[3]);
}
}
loadVTLayers() {
return this.vtLayers || (this.vtLayers = new Ro.VectorTile(new eu(this.rawTileData)).layers, this.sourceLayerCoder = new mc(this.vtLayers ? Object.keys(this.vtLayers).sort() : ["_geojsonTileLayer"])), this.vtLayers;
}
query(t2, e2, r2, n2) {
this.loadVTLayers();
const i3 = t2.params || {}, s2 = rs / t2.tileSize / t2.scale, o2 = Nr(i3.filter), l2 = t2.queryGeometry, u2 = t2.queryPadding * s2, c2 = bc(l2), h2 = this.grid.query(c2.minX - u2, c2.minY - u2, c2.maxX + u2, c2.maxY + u2), p2 = bc(t2.cameraQueryGeometry), f2 = this.grid3D.query(p2.minX - u2, p2.minY - u2, p2.maxX + u2, p2.maxY + u2, ((e3, r3, n3, i4) => (function(t3, e4, r4, n4, i5) {
for (const a2 of t3) if (e4 <= a2.x && r4 <= a2.y && n4 >= a2.x && i5 >= a2.y) return true;
const s3 = [new a(e4, r4), new a(e4, i5), new a(n4, i5), new a(n4, r4)];
if (t3.length > 2) {
for (const e5 of s3) if (xs(t3, e5)) return true;
}
for (let e5 = 0; e5 < t3.length - 1; e5++) if (vs(t3[e5], t3[e5 + 1], s3)) return true;
return false;
})(t2.cameraQueryGeometry, e3 - u2, r3 - u2, n3 + u2, i4 + u2)));
for (const t3 of f2) h2.push(t3);
h2.sort(wc);
const d2 = {};
let y2;
for (let a2 = 0; a2 < h2.length; a2++) {
const u3 = h2[a2];
if (u3 === y2) continue;
y2 = u3;
const c3 = this.featureIndexArray.get(u3);
let p3 = null;
this.loadMatchingFeature(d2, c3.bucketIndex, c3.sourceLayerIndex, c3.featureIndex, o2, i3.layers, i3.availableImages, e2, r2, n2, ((e3, r3, n3) => (p3 || (p3 = as(e3)), r3.queryIntersectsFeature(l2, e3, n3, p3, this.z, t2.transform, s2, t2.pixelPosMatrix))));
}
return d2;
}
loadMatchingFeature(t2, e2, r2, n2, i3, a2, s2, o2, l2, u2, c2) {
const h2 = this.bucketLayerIDs[e2];
if (a2 && !(function(t3, e3) {
for (let r3 = 0; r3 < t3.length; r3++) if (e3.indexOf(t3[r3]) >= 0) return true;
return false;
})(a2, h2)) return;
const p2 = this.sourceLayerCoder.decode(r2), f2 = this.vtLayers[p2].feature(n2);
if (i3.needGeometry) {
const t3 = ss(f2, true);
if (!i3.filter(new li(this.tileID.overscaledZ), t3, this.tileID.canonical)) return;
} else if (!i3.filter(new li(this.tileID.overscaledZ), f2)) return;
const d2 = this.getId(f2, p2);
for (let e3 = 0; e3 < h2.length; e3++) {
const r3 = h2[e3];
if (a2 && a2.indexOf(r3) < 0) continue;
const i4 = o2[r3];
if (!i4) continue;
let p3 = {};
d2 && u2 && (p3 = u2.getState(i4.sourceLayer || "_geojsonTileLayer", d2));
const y2 = g({}, l2[r3]);
y2.paint = vc(y2.paint, i4.paint, f2, p3, s2), y2.layout = vc(y2.layout, i4.layout, f2, p3, s2);
const m2 = !c2 || c2(f2, i4, p3);
if (!m2) continue;
const x2 = new gc(f2, this.z, this.x, this.y, d2);
x2.layer = y2;
let v2 = t2[r3];
void 0 === v2 && (v2 = t2[r3] = []), v2.push({ featureIndex: n2, feature: x2, intersectionZ: m2 });
}
}
lookupSymbolFeatures(t2, e2, r2, n2, i3, a2, s2, o2) {
const l2 = {};
this.loadVTLayers();
const u2 = Nr(i3);
for (const i4 of t2) this.loadMatchingFeature(l2, r2, n2, i4, u2, a2, s2, o2, e2);
return l2;
}
hasLayer(t2) {
for (const e2 of this.bucketLayerIDs) for (const r2 of e2) if (t2 === r2) return true;
return false;
}
getId(t2, e2) {
let r2 = t2.id;
return this.promoteId && (r2 = t2.properties["string" == typeof this.promoteId ? this.promoteId : this.promoteId[e2]], "boolean" == typeof r2 && (r2 = Number(r2))), r2;
}
}
function vc(t2, e2, r2, n2, i3) {
return v(t2, ((t3, a2) => {
const s2 = e2 instanceof mi ? e2.get(a2) : null;
return s2 && s2.evaluate ? s2.evaluate(r2, n2, i3) : s2;
}));
}
function bc(t2) {
let e2 = 1 / 0, r2 = 1 / 0, n2 = -1 / 0, i3 = -1 / 0;
for (const a2 of t2) e2 = Math.min(e2, a2.x), r2 = Math.min(r2, a2.y), n2 = Math.max(n2, a2.x), i3 = Math.max(i3, a2.y);
return { minX: e2, minY: r2, maxX: n2, maxY: i3 };
}
function wc(t2, e2) {
return e2 - t2;
}
function _c(t2, e2, r2, n2, i3) {
const s2 = [];
for (let o2 = 0; o2 < t2.length; o2++) {
const l2 = t2[o2];
let u2;
for (let t3 = 0; t3 < l2.length - 1; t3++) {
let o3 = l2[t3], c2 = l2[t3 + 1];
o3.x < e2 && c2.x < e2 || (o3.x < e2 ? o3 = new a(e2, o3.y + (e2 - o3.x) / (c2.x - o3.x) * (c2.y - o3.y))._round() : c2.x < e2 && (c2 = new a(e2, o3.y + (e2 - o3.x) / (c2.x - o3.x) * (c2.y - o3.y))._round()), o3.y < r2 && c2.y < r2 || (o3.y < r2 ? o3 = new a(o3.x + (r2 - o3.y) / (c2.y - o3.y) * (c2.x - o3.x), r2)._round() : c2.y < r2 && (c2 = new a(o3.x + (r2 - o3.y) / (c2.y - o3.y) * (c2.x - o3.x), r2)._round()), o3.x >= n2 && c2.x >= n2 || (o3.x >= n2 ? o3 = new a(n2, o3.y + (n2 - o3.x) / (c2.x - o3.x) * (c2.y - o3.y))._round() : c2.x >= n2 && (c2 = new a(n2, o3.y + (n2 - o3.x) / (c2.x - o3.x) * (c2.y - o3.y))._round()), o3.y >= i3 && c2.y >= i3 || (o3.y >= i3 ? o3 = new a(o3.x + (i3 - o3.y) / (c2.y - o3.y) * (c2.x - o3.x), i3)._round() : c2.y >= i3 && (c2 = new a(o3.x + (i3 - o3.y) / (c2.y - o3.y) * (c2.x - o3.x), i3)._round()), u2 && o3.equals(u2[u2.length - 1]) || (u2 = [o3], s2.push(u2)), u2.push(c2)))));
}
}
return s2;
}
$n("FeatureIndex", xc, { omit: ["rawTileData", "sourceLayerCoder"] });
class Ac extends a {
constructor(t2, e2, r2, n2) {
super(t2, e2), this.angle = r2, void 0 !== n2 && (this.segment = n2);
}
clone() {
return new Ac(this.x, this.y, this.angle, this.segment);
}
}
function Sc(t2, e2, r2, n2, i3) {
if (void 0 === e2.segment || 0 === r2) return true;
let a2 = e2, s2 = e2.segment + 1, o2 = 0;
for (; o2 > -r2 / 2; ) {
if (s2--, s2 < 0) return false;
o2 -= t2[s2].dist(a2), a2 = t2[s2];
}
o2 += t2[s2].dist(t2[s2 + 1]), s2++;
const l2 = [];
let u2 = 0;
for (; o2 < r2 / 2; ) {
const e3 = t2[s2], r3 = t2[s2 + 1];
if (!r3) return false;
let a3 = t2[s2 - 1].angleTo(e3) - e3.angleTo(r3);
for (a3 = Math.abs((a3 + 3 * Math.PI) % (2 * Math.PI) - Math.PI), l2.push({ distance: o2, angleDelta: a3 }), u2 += a3; o2 - l2[0].distance > n2; ) u2 -= l2.shift().angleDelta;
if (u2 > i3) return false;
s2++, o2 += e3.dist(r3);
}
return true;
}
function kc(t2) {
let e2 = 0;
for (let r2 = 0; r2 < t2.length - 1; r2++) e2 += t2[r2].dist(t2[r2 + 1]);
return e2;
}
function Ic(t2, e2, r2) {
return t2 ? 0.6 * e2 * r2 : 0;
}
function zc(t2, e2) {
return Math.max(t2 ? t2.right - t2.left : 0, e2 ? e2.right - e2.left : 0);
}
function Mc(t2, e2, r2, n2, i3, a2) {
const s2 = Ic(r2, i3, a2), o2 = zc(r2, n2) * a2;
let l2 = 0;
const u2 = kc(t2) / 2;
for (let r3 = 0; r3 < t2.length - 1; r3++) {
const n3 = t2[r3], i4 = t2[r3 + 1], a3 = n3.dist(i4);
if (l2 + a3 > u2) {
const c2 = (u2 - l2) / a3, h2 = Ze.number(n3.x, i4.x, c2), p2 = Ze.number(n3.y, i4.y, c2), f2 = new Ac(h2, p2, i4.angleTo(n3), r3);
return f2._round(), !s2 || Sc(t2, f2, o2, s2, e2) ? f2 : void 0;
}
l2 += a3;
}
}
function Cc(t2, e2, r2, n2, i3, a2, s2, o2, l2) {
const u2 = Ic(n2, a2, s2), c2 = zc(n2, i3), h2 = c2 * s2, p2 = 0 === t2[0].x || t2[0].x === l2 || 0 === t2[0].y || t2[0].y === l2;
return e2 - h2 < e2 / 4 && (e2 = h2 + e2 / 4), Bc(t2, p2 ? e2 / 2 * o2 % e2 : (c2 / 2 + 2 * a2) * s2 * o2 % e2, e2, u2, r2, h2, p2, false, l2);
}
function Bc(t2, e2, r2, n2, i3, a2, s2, o2, l2) {
const u2 = a2 / 2, c2 = kc(t2);
let h2 = 0, p2 = e2 - r2, f2 = [];
for (let e3 = 0; e3 < t2.length - 1; e3++) {
const s3 = t2[e3], o3 = t2[e3 + 1], d2 = s3.dist(o3), y2 = o3.angleTo(s3);
for (; p2 + r2 < h2 + d2; ) {
p2 += r2;
const m2 = (p2 - h2) / d2, g2 = Ze.number(s3.x, o3.x, m2), x2 = Ze.number(s3.y, o3.y, m2);
if (g2 >= 0 && g2 < l2 && x2 >= 0 && x2 < l2 && p2 - u2 >= 0 && p2 + u2 <= c2) {
const r3 = new Ac(g2, x2, y2, e3);
r3._round(), n2 && !Sc(t2, r3, a2, n2, i3) || f2.push(r3);
}
}
h2 += d2;
}
return o2 || f2.length || s2 || (f2 = Bc(t2, h2 / 2, r2, n2, i3, a2, s2, true, l2)), f2;
}
$n("Anchor", Ac);
const Pc = lu;
function Vc(t2, e2, r2, n2) {
const i3 = [], s2 = t2.image, o2 = s2.pixelRatio, l2 = s2.paddedRect.w - 2 * Pc, u2 = s2.paddedRect.h - 2 * Pc, c2 = t2.right - t2.left, h2 = t2.bottom - t2.top, p2 = s2.stretchX || [[0, l2]], f2 = s2.stretchY || [[0, u2]], d2 = (t3, e3) => t3 + e3[1] - e3[0], y2 = p2.reduce(d2, 0), m2 = f2.reduce(d2, 0), g2 = l2 - y2, x2 = u2 - m2;
let v2 = 0, b2 = y2, w2 = 0, _2 = m2, A2 = 0, S2 = g2, k2 = 0, I2 = x2;
if (s2.content && n2) {
const t3 = s2.content;
v2 = Ec(p2, 0, t3[0]), w2 = Ec(f2, 0, t3[1]), b2 = Ec(p2, t3[0], t3[2]), _2 = Ec(f2, t3[1], t3[3]), A2 = t3[0] - v2, k2 = t3[1] - w2, S2 = t3[2] - t3[0] - b2, I2 = t3[3] - t3[1] - _2;
}
const z2 = (n3, i4, l3, u3) => {
const p3 = Tc(n3.stretch - v2, b2, c2, t2.left), f3 = $c(n3.fixed - A2, S2, n3.stretch, y2), d3 = Tc(i4.stretch - w2, _2, h2, t2.top), g3 = $c(i4.fixed - k2, I2, i4.stretch, m2), x3 = Tc(l3.stretch - v2, b2, c2, t2.left), z3 = $c(l3.fixed - A2, S2, l3.stretch, y2), M2 = Tc(u3.stretch - w2, _2, h2, t2.top), C2 = $c(u3.fixed - k2, I2, u3.stretch, m2), B2 = new a(p3, d3), P2 = new a(x3, d3), V2 = new a(x3, M2), E2 = new a(p3, M2), F2 = new a(f3 / o2, g3 / o2), T2 = new a(z3 / o2, C2 / o2), $2 = e2 * Math.PI / 180;
if ($2) {
const t3 = Math.sin($2), e3 = Math.cos($2), r3 = [e3, -t3, t3, e3];
B2._matMult(r3), P2._matMult(r3), E2._matMult(r3), V2._matMult(r3);
}
const L2 = n3.stretch + n3.fixed, D2 = i4.stretch + i4.fixed;
return { tl: B2, tr: P2, bl: E2, br: V2, tex: { x: s2.paddedRect.x + Pc + L2, y: s2.paddedRect.y + Pc + D2, w: l3.stretch + l3.fixed - L2, h: u3.stretch + u3.fixed - D2 }, writingMode: void 0, glyphOffset: [0, 0], sectionIndex: 0, pixelOffsetTL: F2, pixelOffsetBR: T2, minFontScaleX: S2 / o2 / c2, minFontScaleY: I2 / o2 / h2, isSDF: r2 };
};
if (n2 && (s2.stretchX || s2.stretchY)) {
const t3 = Fc(p2, g2, y2), e3 = Fc(f2, x2, m2);
for (let r3 = 0; r3 < t3.length - 1; r3++) {
const n3 = t3[r3], a2 = t3[r3 + 1];
for (let t4 = 0; t4 < e3.length - 1; t4++) i3.push(z2(n3, e3[t4], a2, e3[t4 + 1]));
}
} else i3.push(z2({ fixed: 0, stretch: -1 }, { fixed: 0, stretch: -1 }, { fixed: 0, stretch: l2 + 1 }, { fixed: 0, stretch: u2 + 1 }));
return i3;
}
function Ec(t2, e2, r2) {
let n2 = 0;
for (const i3 of t2) n2 += Math.max(e2, Math.min(r2, i3[1])) - Math.max(e2, Math.min(r2, i3[0]));
return n2;
}
function Fc(t2, e2, r2) {
const n2 = [{ fixed: -Pc, stretch: 0 }];
for (const [e3, r3] of t2) {
const t3 = n2[n2.length - 1];
n2.push({ fixed: e3 - t3.stretch, stretch: t3.stretch }), n2.push({ fixed: e3 - t3.stretch, stretch: t3.stretch + (r3 - e3) });
}
return n2.push({ fixed: e2 + Pc, stretch: r2 }), n2;
}
function Tc(t2, e2, r2, n2) {
return t2 / e2 * r2 + n2;
}
function $c(t2, e2, r2, n2) {
return t2 - e2 * r2 / n2;
}
class Lc {
constructor(t2, e2, r2, n2, i3, s2, o2, l2, u2, c2) {
if (this.boxStartIndex = t2.length, u2) {
let t3 = s2.top, e3 = s2.bottom;
const r3 = s2.collisionPadding;
r3 && (t3 -= r3[1], e3 += r3[3]);
let n3 = e3 - t3;
n3 > 0 && (n3 = Math.max(10, n3), this.circleDiameter = n3);
} else {
let u3 = s2.top * o2 - l2[0], h2 = s2.bottom * o2 + l2[2], p2 = s2.left * o2 - l2[3], f2 = s2.right * o2 + l2[1];
const d2 = s2.collisionPadding;
if (d2 && (p2 -= d2[0] * o2, u3 -= d2[1] * o2, f2 += d2[2] * o2, h2 += d2[3] * o2), c2) {
const t3 = new a(p2, u3), e3 = new a(f2, u3), r3 = new a(p2, h2), n3 = new a(f2, h2), i4 = c2 * Math.PI / 180;
t3._rotate(i4), e3._rotate(i4), r3._rotate(i4), n3._rotate(i4), p2 = Math.min(t3.x, e3.x, r3.x, n3.x), f2 = Math.max(t3.x, e3.x, r3.x, n3.x), u3 = Math.min(t3.y, e3.y, r3.y, n3.y), h2 = Math.max(t3.y, e3.y, r3.y, n3.y);
}
t2.emplaceBack(e2.x, e2.y, p2, u3, f2, h2, r2, n2, i3);
}
this.boxEndIndex = t2.length;
}
}
class Dc {
constructor(t2 = [], e2 = Oc) {
if (this.data = t2, this.length = this.data.length, this.compare = e2, this.length > 0) for (let t3 = (this.length >> 1) - 1; t3 >= 0; t3--) this._down(t3);
}
push(t2) {
this.data.push(t2), this.length++, this._up(this.length - 1);
}
pop() {
if (0 === this.length) return;
const t2 = this.data[0], e2 = this.data.pop();
return this.length--, this.length > 0 && (this.data[0] = e2, this._down(0)), t2;
}
peek() {
return this.data[0];
}
_up(t2) {
const { data: e2, compare: r2 } = this, n2 = e2[t2];
for (; t2 > 0; ) {
const i3 = t2 - 1 >> 1, a2 = e2[i3];
if (r2(n2, a2) >= 0) break;
e2[t2] = a2, t2 = i3;
}
e2[t2] = n2;
}
_down(t2) {
const { data: e2, compare: r2 } = this, n2 = this.length >> 1, i3 = e2[t2];
for (; t2 < n2; ) {
let n3 = 1 + (t2 << 1), a2 = e2[n3];
const s2 = n3 + 1;
if (s2 < this.length && r2(e2[s2], a2) < 0 && (n3 = s2, a2 = e2[s2]), r2(a2, i3) >= 0) break;
e2[t2] = a2, t2 = n3;
}
e2[t2] = i3;
}
}
function Oc(t2, e2) {
return t2 < e2 ? -1 : t2 > e2 ? 1 : 0;
}
function Uc(t2, e2 = 1, r2 = false) {
let n2 = 1 / 0, i3 = 1 / 0, s2 = -1 / 0, o2 = -1 / 0;
const l2 = t2[0];
for (let t3 = 0; t3 < l2.length; t3++) {
const e3 = l2[t3];
(!t3 || e3.x < n2) && (n2 = e3.x), (!t3 || e3.y < i3) && (i3 = e3.y), (!t3 || e3.x > s2) && (s2 = e3.x), (!t3 || e3.y > o2) && (o2 = e3.y);
}
const u2 = Math.min(s2 - n2, o2 - i3);
let c2 = u2 / 2;
const h2 = new Dc([], Rc);
if (0 === u2) return new a(n2, i3);
for (let e3 = n2; e3 < s2; e3 += u2) for (let r3 = i3; r3 < o2; r3 += u2) h2.push(new qc(e3 + c2, r3 + c2, c2, t2));
let p2 = (function(t3) {
let e3 = 0, r3 = 0, n3 = 0;
const i4 = t3[0];
for (let t4 = 0, a2 = i4.length, s3 = a2 - 1; t4 < a2; s3 = t4++) {
const a3 = i4[t4], o3 = i4[s3], l3 = a3.x * o3.y - o3.x * a3.y;
r3 += (a3.x + o3.x) * l3, n3 += (a3.y + o3.y) * l3, e3 += 3 * l3;
}
return new qc(r3 / e3, n3 / e3, 0, t3);
})(t2), f2 = h2.length;
for (; h2.length; ) {
const n3 = h2.pop();
(n3.d > p2.d || !p2.d) && (p2 = n3, r2 && console.log("found best %d after %d probes", Math.round(1e4 * n3.d) / 1e4, f2)), n3.max - p2.d <= e2 || (c2 = n3.h / 2, h2.push(new qc(n3.p.x - c2, n3.p.y - c2, c2, t2)), h2.push(new qc(n3.p.x + c2, n3.p.y - c2, c2, t2)), h2.push(new qc(n3.p.x - c2, n3.p.y + c2, c2, t2)), h2.push(new qc(n3.p.x + c2, n3.p.y + c2, c2, t2)), f2 += 4);
}
return r2 && (console.log(`num probes: ${f2}`), console.log(`best distance: ${p2.d}`)), p2.p;
}
function Rc(t2, e2) {
return e2.max - t2.max;
}
function qc(t2, e2, r2, n2) {
this.p = new a(t2, e2), this.h = r2, this.d = (function(t3, e3) {
let r3 = false, n3 = 1 / 0;
for (let i3 = 0; i3 < e3.length; i3++) {
const a2 = e3[i3];
for (let e4 = 0, i4 = a2.length, s2 = i4 - 1; e4 < i4; s2 = e4++) {
const i5 = a2[e4], o2 = a2[s2];
i5.y > t3.y != o2.y > t3.y && t3.x < (o2.x - i5.x) * (t3.y - i5.y) / (o2.y - i5.y) + i5.x && (r3 = !r3), n3 = Math.min(n3, ms(t3, i5, o2));
}
}
return (r3 ? 1 : -1) * Math.sqrt(n3);
})(this.p, n2), this.max = this.d + this.h * Math.SQRT2;
}
var jc;
t.aq = void 0, (jc = t.aq || (t.aq = {}))[jc.center = 1] = "center", jc[jc.left = 2] = "left", jc[jc.right = 3] = "right", jc[jc.top = 4] = "top", jc[jc.bottom = 5] = "bottom", jc[jc["top-left"] = 6] = "top-left", jc[jc["top-right"] = 7] = "top-right", jc[jc["bottom-left"] = 8] = "bottom-left", jc[jc["bottom-right"] = 9] = "bottom-right";
const Nc = 7, Zc = Number.POSITIVE_INFINITY;
function Kc(t2, e2) {
return e2[1] !== Zc ? (function(t3, e3, r2) {
let n2 = 0, i3 = 0;
switch (e3 = Math.abs(e3), r2 = Math.abs(r2), t3) {
case "top-right":
case "top-left":
case "top":
i3 = r2 - Nc;
break;
case "bottom-right":
case "bottom-left":
case "bottom":
i3 = -r2 + Nc;
}
switch (t3) {
case "top-right":
case "bottom-right":
case "right":
n2 = -e3;
break;
case "top-left":
case "bottom-left":
case "left":
n2 = e3;
}
return [n2, i3];
})(t2, e2[0], e2[1]) : (function(t3, e3) {
let r2 = 0, n2 = 0;
e3 < 0 && (e3 = 0);
const i3 = e3 / Math.SQRT2;
switch (t3) {
case "top-right":
case "top-left":
n2 = i3 - Nc;
break;
case "bottom-right":
case "bottom-left":
n2 = -i3 + Nc;
break;
case "bottom":
n2 = -e3 + Nc;
break;
case "top":
n2 = e3 - Nc;
}
switch (t3) {
case "top-right":
case "bottom-right":
r2 = -i3;
break;
case "top-left":
case "bottom-left":
r2 = i3;
break;
case "left":
r2 = e3;
break;
case "right":
r2 = -e3;
}
return [r2, n2];
})(t2, e2[0]);
}
function Gc(t2, e2, r2) {
var n2;
const i3 = t2.layout, a2 = null === (n2 = i3.get("text-variable-anchor-offset")) || void 0 === n2 ? void 0 : n2.evaluate(e2, {}, r2);
if (a2) {
const t3 = a2.values, e3 = [];
for (let r3 = 0; r3 < t3.length; r3 += 2) {
const n3 = e3[r3] = t3[r3], i4 = t3[r3 + 1].map(((t4) => t4 * Vl));
n3.startsWith("top") ? i4[1] -= Nc : n3.startsWith("bottom") && (i4[1] += Nc), e3[r3 + 1] = i4;
}
return new re(e3);
}
const s2 = i3.get("text-variable-anchor");
if (s2) {
let n3;
n3 = void 0 !== t2._unevaluatedLayout.getValue("text-radial-offset") ? [i3.get("text-radial-offset").evaluate(e2, {}, r2) * Vl, Zc] : i3.get("text-offset").evaluate(e2, {}, r2).map(((t3) => t3 * Vl));
const a3 = [];
for (const t3 of s2) a3.push(t3, Kc(t3, n3));
return new re(a3);
}
return null;
}
function Jc(t2) {
switch (t2) {
case "right":
case "top-right":
case "bottom-right":
return "right";
case "left":
case "top-left":
case "bottom-left":
return "left";
}
return "center";
}
function Xc(e2, r2, n2, i3, a2, s2, o2, l2, u2, c2, h2) {
let p2 = s2.textMaxSize.evaluate(r2, {});
void 0 === p2 && (p2 = o2);
const f2 = e2.layers[0].layout, d2 = f2.get("icon-offset").evaluate(r2, {}, h2), y2 = Hc(n2.horizontal), m2 = o2 / 24, g2 = e2.tilePixelRatio * m2, x2 = e2.tilePixelRatio * p2 / 24, v2 = e2.tilePixelRatio * l2, b2 = e2.tilePixelRatio * f2.get("symbol-spacing"), w2 = f2.get("text-padding") * e2.tilePixelRatio, _2 = (function(t2, e3, r3, n3 = 1) {
const i4 = t2.get("icon-padding").evaluate(e3, {}, r3), a3 = i4 && i4.values;
return [a3[0] * n3, a3[1] * n3, a3[2] * n3, a3[3] * n3];
})(f2, r2, h2, e2.tilePixelRatio), S2 = f2.get("text-max-angle") / 180 * Math.PI, k2 = "viewport" !== f2.get("text-rotation-alignment") && "point" !== f2.get("symbol-placement"), I2 = "map" === f2.get("icon-rotation-alignment") && "point" !== f2.get("symbol-placement"), z2 = f2.get("symbol-placement"), M2 = b2 / 2, C2 = f2.get("icon-text-fit");
let B2;
i3 && "none" !== C2 && (e2.allowVerticalPlacement && n2.vertical && (B2 = zu(i3, n2.vertical, C2, f2.get("icon-text-fit-padding"), d2, m2)), y2 && (i3 = zu(i3, y2, C2, f2.get("icon-text-fit-padding"), d2, m2)));
const P2 = (l3, p3) => {
p3.x < 0 || p3.x >= rs || p3.y < 0 || p3.y >= rs || (function(e3, r3, n3, i4, a3, s3, o3, l4, u3, c3, h3, p4, f3, d3, y3, m3, g3, x3, v3, b3, w3, _3, S3, k3, I3) {
const z3 = e3.addToLineVertexArray(r3, n3);
let M3, C3, B3, P3, V2 = 0, E2 = 0, F2 = 0, T2 = 0, $2 = -1, L2 = -1;
const D2 = {};
let O2 = $a("");
if (e3.allowVerticalPlacement && i4.vertical) {
const t2 = l4.layout.get("text-rotate").evaluate(w3, {}, k3) + 90;
B3 = new Lc(u3, r3, c3, h3, p4, i4.vertical, f3, d3, y3, t2), o3 && (P3 = new Lc(u3, r3, c3, h3, p4, o3, g3, x3, y3, t2));
}
if (a3) {
const n4 = l4.layout.get("icon-rotate").evaluate(w3, {}), i5 = "none" !== l4.layout.get("icon-text-fit"), s4 = Vc(a3, n4, S3, i5), f4 = o3 ? Vc(o3, n4, S3, i5) : void 0;
C3 = new Lc(u3, r3, c3, h3, p4, a3, g3, x3, false, n4), V2 = 4 * s4.length;
const d4 = e3.iconSizeData;
let y4 = null;
"source" === d4.kind ? (y4 = [Cu * l4.layout.get("icon-size").evaluate(w3, {})], y4[0] > Bu && A(`${e3.layerIds[0]}: Value for "icon-size" is >= ${Mu}. Reduce your "icon-size".`)) : "composite" === d4.kind && (y4 = [Cu * _3.compositeIconSizes[0].evaluate(w3, {}, k3), Cu * _3.compositeIconSizes[1].evaluate(w3, {}, k3)], (y4[0] > Bu || y4[1] > Bu) && A(`${e3.layerIds[0]}: Value for "icon-size" is >= ${Mu}. Reduce your "icon-size".`)), e3.addSymbols(e3.icon, s4, y4, b3, v3, w3, t.ai.none, r3, z3.lineStartIndex, z3.lineLength, -1, k3), $2 = e3.icon.placedSymbolArray.length - 1, f4 && (E2 = 4 * f4.length, e3.addSymbols(e3.icon, f4, y4, b3, v3, w3, t.ai.vertical, r3, z3.lineStartIndex, z3.lineLength, -1, k3), L2 = e3.icon.placedSymbolArray.length - 1);
}
const U2 = Object.keys(i4.horizontal);
for (const n4 of U2) {
const a4 = i4.horizontal[n4];
if (!M3) {
O2 = $a(a4.text);
const t2 = l4.layout.get("text-rotate").evaluate(w3, {}, k3);
M3 = new Lc(u3, r3, c3, h3, p4, a4, f3, d3, y3, t2);
}
const o4 = 1 === a4.positionedLines.length;
if (F2 += Yc(e3, r3, a4, s3, l4, y3, w3, m3, z3, i4.vertical ? t.ai.horizontal : t.ai.horizontalOnly, o4 ? U2 : [n4], D2, $2, _3, k3), o4) break;
}
i4.vertical && (T2 += Yc(e3, r3, i4.vertical, s3, l4, y3, w3, m3, z3, t.ai.vertical, ["vertical"], D2, L2, _3, k3));
const R2 = M3 ? M3.boxStartIndex : e3.collisionBoxArray.length, q2 = M3 ? M3.boxEndIndex : e3.collisionBoxArray.length, j2 = B3 ? B3.boxStartIndex : e3.collisionBoxArray.length, N2 = B3 ? B3.boxEndIndex : e3.collisionBoxArray.length, Z2 = C3 ? C3.boxStartIndex : e3.collisionBoxArray.length, K2 = C3 ? C3.boxEndIndex : e3.collisionBoxArray.length, G2 = P3 ? P3.boxStartIndex : e3.collisionBoxArray.length, J2 = P3 ? P3.boxEndIndex : e3.collisionBoxArray.length;
let X2 = -1;
const Y2 = (t2, e4) => t2 && t2.circleDiameter ? Math.max(t2.circleDiameter, e4) : e4;
X2 = Y2(M3, X2), X2 = Y2(B3, X2), X2 = Y2(C3, X2), X2 = Y2(P3, X2);
const H2 = X2 > -1 ? 1 : 0;
H2 && (X2 *= I3 / Vl), e3.glyphOffsetArray.length >= Uu.MAX_GLYPHS && A("Too many glyphs being rendered in a tile. See https://github.com/mapbox/mapbox-gl-js/issues/2907"), void 0 !== w3.sortKey && e3.addToSortKeyRanges(e3.symbolInstances.length, w3.sortKey);
const W2 = Gc(l4, w3, k3), [Q2, tt2] = (function(e4, r4) {
const n4 = e4.length, i5 = null == r4 ? void 0 : r4.values;
if ((null == i5 ? void 0 : i5.length) > 0) for (let r5 = 0; r5 < i5.length; r5 += 2) {
const n5 = i5[r5 + 1];
e4.emplaceBack(t.aq[i5[r5]], n5[0], n5[1]);
}
return [n4, e4.length];
})(e3.textAnchorOffsets, W2);
e3.symbolInstances.emplaceBack(r3.x, r3.y, D2.right >= 0 ? D2.right : -1, D2.center >= 0 ? D2.center : -1, D2.left >= 0 ? D2.left : -1, D2.vertical || -1, $2, L2, O2, R2, q2, j2, N2, Z2, K2, G2, J2, c3, F2, T2, V2, E2, H2, 0, f3, X2, Q2, tt2);
})(e2, p3, l3, n2, i3, a2, B2, e2.layers[0], e2.collisionBoxArray, r2.index, r2.sourceLayerIndex, e2.index, g2, [w2, w2, w2, w2], k2, u2, v2, _2, I2, d2, r2, s2, c2, h2, o2);
};
if ("line" === z2) for (const t2 of _c(r2.geometry, 0, 0, rs, rs)) {
const r3 = Cc(t2, b2, S2, n2.vertical || y2, i3, 24, x2, e2.overscaling, rs);
for (const n3 of r3) y2 && Wc(e2, y2.text, M2, n3) || P2(t2, n3);
}
else if ("line-center" === z2) {
for (const t2 of r2.geometry) if (t2.length > 1) {
const e3 = Mc(t2, S2, n2.vertical || y2, i3, 24, x2);
e3 && P2(t2, e3);
}
} else if ("Polygon" === r2.type) for (const t2 of Co(r2.geometry, 0)) {
const e3 = Uc(t2, 16);
P2(t2[0], new Ac(e3.x, e3.y, 0));
}
else if ("LineString" === r2.type) for (const t2 of r2.geometry) P2(t2, new Ac(t2[0].x, t2[0].y, 0));
else if ("Point" === r2.type) for (const t2 of r2.geometry) for (const e3 of t2) P2([e3], new Ac(e3.x, e3.y, 0));
}
function Yc(t2, e2, r2, n2, i3, s2, o2, l2, u2, c2, h2, p2, f2, d2, y2) {
const m2 = (function(t3, e3, r3, n3, i4, s3, o3, l3) {
const u3 = n3.layout.get("text-rotate").evaluate(s3, {}) * Math.PI / 180, c3 = [];
for (const t4 of e3.positionedLines) for (const n4 of t4.positionedGlyphs) {
if (!n4.rect) continue;
const s4 = n4.rect || {};
let h3 = su + 1, p3 = true, f3 = 1, d3 = 0;
const y3 = (i4 || l3) && n4.vertical, m3 = n4.metrics.advance * n4.scale / 2;
if (l3 && e3.verticalizable && (d3 = t4.lineOffset / 2 - (n4.imageName ? -(Vl - n4.metrics.width * n4.scale) / 2 : (n4.scale - 1) * Vl)), n4.imageName) {
const t5 = o3[n4.imageName];
p3 = t5.sdf, f3 = t5.pixelRatio, h3 = lu / f3;
}
const g3 = i4 ? [n4.x + m3, n4.y] : [0, 0];
let x3 = i4 ? [0, 0] : [n4.x + m3 + r3[0], n4.y + r3[1] - d3], v2 = [0, 0];
y3 && (v2 = x3, x3 = [0, 0]);
const b2 = n4.metrics.isDoubleResolution ? 2 : 1, w2 = (n4.metrics.left - h3) * n4.scale - m3 + x3[0], _2 = (-n4.metrics.top - h3) * n4.scale + x3[1], A2 = w2 + s4.w / b2 * n4.scale / f3, S2 = _2 + s4.h / b2 * n4.scale / f3, k2 = new a(w2, _2), I2 = new a(A2, _2), z2 = new a(w2, S2), M2 = new a(A2, S2);
if (y3) {
const t5 = new a(-m3, m3 - pu), e4 = -Math.PI / 2, r4 = Vl / 2 - m3, i5 = new a(5 - pu - r4, -(n4.imageName ? r4 : 0)), s5 = new a(...v2);
k2._rotateAround(e4, t5)._add(i5)._add(s5), I2._rotateAround(e4, t5)._add(i5)._add(s5), z2._rotateAround(e4, t5)._add(i5)._add(s5), M2._rotateAround(e4, t5)._add(i5)._add(s5);
}
if (u3) {
const t5 = Math.sin(u3), e4 = Math.cos(u3), r4 = [e4, -t5, t5, e4];
k2._matMult(r4), I2._matMult(r4), z2._matMult(r4), M2._matMult(r4);
}
const C2 = new a(0, 0), B2 = new a(0, 0);
c3.push({ tl: k2, tr: I2, bl: z2, br: M2, tex: s4, writingMode: e3.writingMode, glyphOffset: g3, sectionIndex: n4.sectionIndex, isSDF: p3, pixelOffsetTL: C2, pixelOffsetBR: B2, minFontScaleX: 0, minFontScaleY: 0 });
}
return c3;
})(0, r2, l2, i3, s2, o2, n2, t2.allowVerticalPlacement), g2 = t2.textSizeData;
let x2 = null;
"source" === g2.kind ? (x2 = [Cu * i3.layout.get("text-size").evaluate(o2, {})], x2[0] > Bu && A(`${t2.layerIds[0]}: Value for "text-size" is >= ${Mu}. Reduce your "text-size".`)) : "composite" === g2.kind && (x2 = [Cu * d2.compositeTextSizes[0].evaluate(o2, {}, y2), Cu * d2.compositeTextSizes[1].evaluate(o2, {}, y2)], (x2[0] > Bu || x2[1] > Bu) && A(`${t2.layerIds[0]}: Value for "text-size" is >= ${Mu}. Reduce your "text-size".`)), t2.addSymbols(t2.text, m2, x2, l2, s2, o2, c2, e2, u2.lineStartIndex, u2.lineLength, f2, y2);
for (const e3 of h2) p2[e3] = t2.text.placedSymbolArray.length - 1;
return 4 * m2.length;
}
function Hc(t2) {
for (const e2 in t2) return t2[e2];
return null;
}
function Wc(t2, e2, r2, n2) {
const i3 = t2.compareText;
if (e2 in i3) {
const t3 = i3[e2];
for (let e3 = t3.length - 1; e3 >= 0; e3--) if (n2.dist(t3[e3]) < r2) return true;
} else i3[e2] = [];
return i3[e2].push(n2), false;
}
const Qc = [Int8Array, Uint8Array, Uint8ClampedArray, Int16Array, Uint16Array, Int32Array, Uint32Array, Float32Array, Float64Array];
class th {
static from(t2) {
if (!(t2 instanceof ArrayBuffer)) throw new Error("Data must be an instance of ArrayBuffer.");
const [e2, r2] = new Uint8Array(t2, 0, 2);
if (219 !== e2) throw new Error("Data does not appear to be in a KDBush format.");
const n2 = r2 >> 4;
if (1 !== n2) throw new Error(`Got v${n2} data when expected v1.`);
const i3 = Qc[15 & r2];
if (!i3) throw new Error("Unrecognized array type.");
const [a2] = new Uint16Array(t2, 2, 1), [s2] = new Uint32Array(t2, 4, 1);
return new th(s2, a2, i3, t2);
}
constructor(t2, e2 = 64, r2 = Float64Array, n2) {
if (isNaN(t2) || t2 < 0) throw new Error(`Unpexpected numItems value: ${t2}.`);
this.numItems = +t2, this.nodeSize = Math.min(Math.max(+e2, 2), 65535), this.ArrayType = r2, this.IndexArrayType = t2 < 65536 ? Uint16Array : Uint32Array;
const i3 = Qc.indexOf(this.ArrayType), a2 = 2 * t2 * this.ArrayType.BYTES_PER_ELEMENT, s2 = t2 * this.IndexArrayType.BYTES_PER_ELEMENT, o2 = (8 - s2 % 8) % 8;
if (i3 < 0) throw new Error(`Unexpected typed array class: ${r2}.`);
n2 && n2 instanceof ArrayBuffer ? (this.data = n2, this.ids = new this.IndexArrayType(this.data, 8, t2), this.coords = new this.ArrayType(this.data, 8 + s2 + o2, 2 * t2), this._pos = 2 * t2, this._finished = true) : (this.data = new ArrayBuffer(8 + a2 + s2 + o2), this.ids = new this.IndexArrayType(this.data, 8, t2), this.coords = new this.ArrayType(this.data, 8 + s2 + o2, 2 * t2), this._pos = 0, this._finished = false, new Uint8Array(this.data, 0, 2).set([219, 16 + i3]), new Uint16Array(this.data, 2, 1)[0] = e2, new Uint32Array(this.data, 4, 1)[0] = t2);
}
add(t2, e2) {
const r2 = this._pos >> 1;
return this.ids[r2] = r2, this.coords[this._pos++] = t2, this.coords[this._pos++] = e2, r2;
}
finish() {
const t2 = this._pos >> 1;
if (t2 !== this.numItems) throw new Error(`Added ${t2} items when expected ${this.numItems}.`);
return eh(this.ids, this.coords, this.nodeSize, 0, this.numItems - 1, 0), this._finished = true, this;
}
range(t2, e2, r2, n2) {
if (!this._finished) throw new Error("Data not yet indexed - call index.finish().");
const { ids: i3, coords: a2, nodeSize: s2 } = this, o2 = [0, i3.length - 1, 0], l2 = [];
for (; o2.length; ) {
const u2 = o2.pop() || 0, c2 = o2.pop() || 0, h2 = o2.pop() || 0;
if (c2 - h2 <= s2) {
for (let s3 = h2; s3 <= c2; s3++) {
const o3 = a2[2 * s3], u3 = a2[2 * s3 + 1];
o3 >= t2 && o3 <= r2 && u3 >= e2 && u3 <= n2 && l2.push(i3[s3]);
}
continue;
}
const p2 = h2 + c2 >> 1, f2 = a2[2 * p2], d2 = a2[2 * p2 + 1];
f2 >= t2 && f2 <= r2 && d2 >= e2 && d2 <= n2 && l2.push(i3[p2]), (0 === u2 ? t2 <= f2 : e2 <= d2) && (o2.push(h2), o2.push(p2 - 1), o2.push(1 - u2)), (0 === u2 ? r2 >= f2 : n2 >= d2) && (o2.push(p2 + 1), o2.push(c2), o2.push(1 - u2));
}
return l2;
}
within(t2, e2, r2) {
if (!this._finished) throw new Error("Data not yet indexed - call index.finish().");
const { ids: n2, coords: i3, nodeSize: a2 } = this, s2 = [0, n2.length - 1, 0], o2 = [], l2 = r2 * r2;
for (; s2.length; ) {
const u2 = s2.pop() || 0, c2 = s2.pop() || 0, h2 = s2.pop() || 0;
if (c2 - h2 <= a2) {
for (let r3 = h2; r3 <= c2; r3++) ah(i3[2 * r3], i3[2 * r3 + 1], t2, e2) <= l2 && o2.push(n2[r3]);
continue;
}
const p2 = h2 + c2 >> 1, f2 = i3[2 * p2], d2 = i3[2 * p2 + 1];
ah(f2, d2, t2, e2) <= l2 && o2.push(n2[p2]), (0 === u2 ? t2 - r2 <= f2 : e2 - r2 <= d2) && (s2.push(h2), s2.push(p2 - 1), s2.push(1 - u2)), (0 === u2 ? t2 + r2 >= f2 : e2 + r2 >= d2) && (s2.push(p2 + 1), s2.push(c2), s2.push(1 - u2));
}
return o2;
}
}
function eh(t2, e2, r2, n2, i3, a2) {
if (i3 - n2 <= r2) return;
const s2 = n2 + i3 >> 1;
rh(t2, e2, s2, n2, i3, a2), eh(t2, e2, r2, n2, s2 - 1, 1 - a2), eh(t2, e2, r2, s2 + 1, i3, 1 - a2);
}
function rh(t2, e2, r2, n2, i3, a2) {
for (; i3 > n2; ) {
if (i3 - n2 > 600) {
const s3 = i3 - n2 + 1, o3 = r2 - n2 + 1, l3 = Math.log(s3), u2 = 0.5 * Math.exp(2 * l3 / 3), c2 = 0.5 * Math.sqrt(l3 * u2 * (s3 - u2) / s3) * (o3 - s3 / 2 < 0 ? -1 : 1);
rh(t2, e2, r2, Math.max(n2, Math.floor(r2 - o3 * u2 / s3 + c2)), Math.min(i3, Math.floor(r2 + (s3 - o3) * u2 / s3 + c2)), a2);
}
const s2 = e2[2 * r2 + a2];
let o2 = n2, l2 = i3;
for (nh(t2, e2, n2, r2), e2[2 * i3 + a2] > s2 && nh(t2, e2, n2, i3); o2 < l2; ) {
for (nh(t2, e2, o2, l2), o2++, l2--; e2[2 * o2 + a2] < s2; ) o2++;
for (; e2[2 * l2 + a2] > s2; ) l2--;
}
e2[2 * n2 + a2] === s2 ? nh(t2, e2, n2, l2) : (l2++, nh(t2, e2, l2, i3)), l2 <= r2 && (n2 = l2 + 1), r2 <= l2 && (i3 = l2 - 1);
}
}
function nh(t2, e2, r2, n2) {
ih(t2, r2, n2), ih(e2, 2 * r2, 2 * n2), ih(e2, 2 * r2 + 1, 2 * n2 + 1);
}
function ih(t2, e2, r2) {
const n2 = t2[e2];
t2[e2] = t2[r2], t2[r2] = n2;
}
function ah(t2, e2, r2, n2) {
const i3 = t2 - r2, a2 = e2 - n2;
return i3 * i3 + a2 * a2;
}
var sh;
t.bh = void 0, (sh = t.bh || (t.bh = {})).create = "create", sh.load = "load", sh.fullLoad = "fullLoad";
let oh = null, lh = [];
const uh = 1e3 / 60, ch = "loadTime", hh = "fullLoadTime", ph = { mark(t2) {
performance.mark(t2);
}, frame(t2) {
const e2 = t2;
null != oh && lh.push(e2 - oh), oh = e2;
}, clearMetrics() {
oh = null, lh = [], performance.clearMeasures(ch), performance.clearMeasures(hh);
for (const e2 in t.bh) performance.clearMarks(t.bh[e2]);
}, getPerformanceMetrics() {
performance.measure(ch, t.bh.create, t.bh.load), performance.measure(hh, t.bh.create, t.bh.fullLoad);
const e2 = performance.getEntriesByName(ch)[0].duration, r2 = performance.getEntriesByName(hh)[0].duration, n2 = lh.length, i3 = 1 / (lh.reduce(((t2, e3) => t2 + e3), 0) / n2 / 1e3), a2 = lh.filter(((t2) => t2 > uh)).reduce(((t2, e3) => t2 + (e3 - uh) / uh), 0);
return { loadTime: e2, fullLoadTime: r2, fps: i3, percentDroppedFrames: a2 / (n2 + a2) * 100, totalFrames: n2 };
} };
t.$ = function(t2, e2, r2) {
var n2, i3, a2, s2, o2, l2, u2, c2, h2, p2, f2, d2, y2 = r2[0], m2 = r2[1], g2 = r2[2];
return e2 === t2 ? (t2[12] = e2[0] * y2 + e2[4] * m2 + e2[8] * g2 + e2[12], t2[13] = e2[1] * y2 + e2[5] * m2 + e2[9] * g2 + e2[13], t2[14] = e2[2] * y2 + e2[6] * m2 + e2[10] * g2 + e2[14], t2[15] = e2[3] * y2 + e2[7] * m2 + e2[11] * g2 + e2[15]) : (i3 = e2[1], a2 = e2[2], s2 = e2[3], o2 = e2[4], l2 = e2[5], u2 = e2[6], c2 = e2[7], h2 = e2[8], p2 = e2[9], f2 = e2[10], d2 = e2[11], t2[0] = n2 = e2[0], t2[1] = i3, t2[2] = a2, t2[3] = s2, t2[4] = o2, t2[5] = l2, t2[6] = u2, t2[7] = c2, t2[8] = h2, t2[9] = p2, t2[10] = f2, t2[11] = d2, t2[12] = n2 * y2 + o2 * m2 + h2 * g2 + e2[12], t2[13] = i3 * y2 + l2 * m2 + p2 * g2 + e2[13], t2[14] = a2 * y2 + u2 * m2 + f2 * g2 + e2[14], t2[15] = s2 * y2 + c2 * m2 + d2 * g2 + e2[15]), t2;
}, t.A = zs, t.B = Ze, t.C = class {
constructor(t2, e2, r2) {
this.receive = (t3) => {
const e3 = t3.data, r3 = e3.id;
if (r3 && (!e3.targetMapId || this.mapId === e3.targetMapId)) if ("<cancel>" === e3.type) {
delete this.tasks[r3];
const t4 = this.cancelCallbacks[r3];
delete this.cancelCallbacks[r3], t4 && t4();
} else I() || e3.mustQueue ? (this.tasks[r3] = e3, this.taskQueue.push(r3), this.invoker.trigger()) : this.processTask(r3, e3);
}, this.process = () => {
if (!this.taskQueue.length) return;
const t3 = this.taskQueue.shift(), e3 = this.tasks[t3];
delete this.tasks[t3], this.taskQueue.length && this.invoker.trigger(), e3 && this.processTask(t3, e3);
}, this.target = t2, this.parent = e2, this.mapId = r2, this.callbacks = {}, this.tasks = {}, this.taskQueue = [], this.cancelCallbacks = {}, this.invoker = new Qu(this.process), this.target.addEventListener("message", this.receive, false), this.globalScope = I() ? t2 : window;
}
send(t2, e2, r2, n2, i3 = false) {
const a2 = Math.round(1e18 * Math.random()).toString(36).substring(0, 10);
r2 && (this.callbacks[a2] = r2);
const s2 = [], o2 = { id: a2, type: t2, hasCallback: !!r2, targetMapId: n2, mustQueue: i3, sourceMapId: this.mapId, data: Dn(e2, s2) };
return this.target.postMessage(o2, { transfer: s2 }), { cancel: () => {
r2 && delete this.callbacks[a2], this.target.postMessage({ id: a2, type: "<cancel>", targetMapId: n2, sourceMapId: this.mapId });
} };
}
processTask(t2, e2) {
if ("<response>" === e2.type) {
const r2 = this.callbacks[t2];
delete this.callbacks[t2], r2 && (e2.error ? r2(On(e2.error)) : r2(null, On(e2.data)));
} else {
let r2 = false;
const n2 = [], i3 = e2.hasCallback ? (e3, i4) => {
r2 = true, delete this.cancelCallbacks[t2];
const a3 = { id: t2, type: "<response>", sourceMapId: this.mapId, error: e3 ? Dn(e3) : null, data: Dn(i4, n2) };
this.target.postMessage(a3, { transfer: n2 });
} : (t3) => {
r2 = true;
};
let a2 = null;
const s2 = On(e2.data);
if (this.parent[e2.type]) a2 = this.parent[e2.type](e2.sourceMapId, s2, i3);
else if ("getWorkerSource" in this.parent) {
const t3 = e2.type.split(".");
a2 = this.parent.getWorkerSource(e2.sourceMapId, t3[0], s2.source)[t3[1]](s2, i3);
} else i3(new Error(`Could not find function ${e2.type}`));
!r2 && a2 && a2.cancel && (this.cancelCallbacks[t2] = a2.cancel);
}
}
remove() {
this.invoker.remove(), this.target.removeEventListener("message", this.receive, false);
}
}, t.D = gi, t.E = J, t.F = function(t2, e2) {
const r2 = {};
for (let n2 = 0; n2 < e2.length; n2++) {
const i3 = e2[n2];
i3 in t2 && (r2[i3] = t2[i3]);
}
return r2;
}, t.G = ic, t.H = ac, t.I = uu, t.J = h, t.K = p, t.L = ec, t.M = B, t.N = rs, t.O = fc, t.P = a, t.Q = Mi, t.R = qs, t.S = za, t.T = hi, t.U = uc, t.V = class extends Vi {
}, t.W = hc, t.X = function(t2, e2) {
const r2 = window.document.createElement("video");
r2.muted = true, r2.onloadstart = function() {
e2(null, r2);
};
for (let e3 = 0; e3 < t2.length; e3++) {
const n2 = window.document.createElement("source");
j(t2[e3]) || (r2.crossOrigin = "Anonymous"), n2.src = t2[e3], r2.appendChild(n2);
}
return { cancel: () => {
} };
}, t.Y = ot, t.Z = function() {
var t2 = new zs(16);
return zs != Float32Array && (t2[1] = 0, t2[2] = 0, t2[3] = 0, t2[4] = 0, t2[6] = 0, t2[7] = 0, t2[8] = 0, t2[9] = 0, t2[11] = 0, t2[12] = 0, t2[13] = 0, t2[14] = 0), t2[0] = 1, t2[5] = 1, t2[10] = 1, t2[15] = 1, t2;
}, t._ = e, t.a = M, t.a$ = class extends Hi {
}, t.a0 = function(t2, e2, r2) {
var n2 = r2[0], i3 = r2[1], a2 = r2[2];
return t2[0] = e2[0] * n2, t2[1] = e2[1] * n2, t2[2] = e2[2] * n2, t2[3] = e2[3] * n2, t2[4] = e2[4] * i3, t2[5] = e2[5] * i3, t2[6] = e2[6] * i3, t2[7] = e2[7] * i3, t2[8] = e2[8] * a2, t2[9] = e2[9] * a2, t2[10] = e2[10] * a2, t2[11] = e2[11] * a2, t2[12] = e2[12], t2[13] = e2[13], t2[14] = e2[14], t2[15] = e2[15], t2;
}, t.a1 = Cs, t.a2 = function() {
return x++;
}, t.a3 = ta, t.a4 = Uu, t.a5 = function() {
oi.isLoading() || oi.isLoaded() || "deferred" !== ai() || si();
}, t.a6 = Nr, t.a7 = ss, t.a8 = li, t.a9 = gc, t.aA = ri, t.aB = function(t2) {
t2 = t2.slice();
const e2 = /* @__PURE__ */ Object.create(null);
for (let r2 = 0; r2 < t2.length; r2++) e2[t2[r2].id] = t2[r2];
for (let r2 = 0; r2 < t2.length; r2++) "ref" in t2[r2] && (t2[r2] = H(t2[r2], e2[t2[r2].ref]));
return t2;
}, t.aC = function(t2) {
if ("custom" === t2.type) return new Wu(t2);
switch (t2.type) {
case "background":
return new Ju(t2);
case "circle":
return new Es(t2);
case "fill":
return new Lo(t2);
case "fill-extrusion":
return new ol(t2);
case "heatmap":
return new Ns(t2);
case "hillshade":
return new Gs(t2);
case "line":
return new Al(t2);
case "raster":
return new Hu(t2);
case "symbol":
return new Zu(t2);
}
}, t.aD = w, t.aE = function(t2, e2) {
if (!t2) return [{ command: Q.setStyle, args: [e2] }];
let r2 = [];
try {
if (!W(t2.version, e2.version)) return [{ command: Q.setStyle, args: [e2] }];
W(t2.center, e2.center) || r2.push({ command: Q.setCenter, args: [e2.center] }), W(t2.zoom, e2.zoom) || r2.push({ command: Q.setZoom, args: [e2.zoom] }), W(t2.bearing, e2.bearing) || r2.push({ command: Q.setBearing, args: [e2.bearing] }), W(t2.pitch, e2.pitch) || r2.push({ command: Q.setPitch, args: [e2.pitch] }), W(t2.sprite, e2.sprite) || r2.push({ command: Q.setSprite, args: [e2.sprite] }), W(t2.glyphs, e2.glyphs) || r2.push({ command: Q.setGlyphs, args: [e2.glyphs] }), W(t2.transition, e2.transition) || r2.push({ command: Q.setTransition, args: [e2.transition] }), W(t2.light, e2.light) || r2.push({ command: Q.setLight, args: [e2.light] });
const n2 = {}, i3 = [];
!(function(t3, e3, r3, n3) {
let i4;
for (i4 in e3 = e3 || {}, t3 = t3 || {}) Object.prototype.hasOwnProperty.call(t3, i4) && (Object.prototype.hasOwnProperty.call(e3, i4) || et(i4, r3, n3));
for (i4 in e3) Object.prototype.hasOwnProperty.call(e3, i4) && (Object.prototype.hasOwnProperty.call(t3, i4) ? W(t3[i4], e3[i4]) || ("geojson" === t3[i4].type && "geojson" === e3[i4].type && nt(t3, e3, i4) ? r3.push({ command: Q.setGeoJSONSourceData, args: [i4, e3[i4].data] }) : rt(i4, e3, r3, n3)) : tt(i4, e3, r3));
})(t2.sources, e2.sources, i3, n2);
const a2 = [];
t2.layers && t2.layers.forEach(((t3) => {
n2[t3.source] ? r2.push({ command: Q.removeLayer, args: [t3.id] }) : a2.push(t3);
})), r2 = r2.concat(i3), (function(t3, e3, r3) {
e3 = e3 || [];
const n3 = (t3 = t3 || []).map(at), i4 = e3.map(at), a3 = t3.reduce(st, {}), s2 = e3.reduce(st, {}), o2 = n3.slice(), l2 = /* @__PURE__ */ Object.create(null);
let u2, c2, h2, p2, f2, d2, y2;
for (u2 = 0, c2 = 0; u2 < n3.length; u2++) h2 = n3[u2], Object.prototype.hasOwnProperty.call(s2, h2) ? c2++ : (r3.push({ command: Q.removeLayer, args: [h2] }), o2.splice(o2.indexOf(h2, c2), 1));
for (u2 = 0, c2 = 0; u2 < i4.length; u2++) h2 = i4[i4.length - 1 - u2], o2[o2.length - 1 - u2] !== h2 && (Object.prototype.hasOwnProperty.call(a3, h2) ? (r3.push({ command: Q.removeLayer, args: [h2] }), o2.splice(o2.lastIndexOf(h2, o2.length - c2), 1)) : c2++, d2 = o2[o2.length - u2], r3.push({ command: Q.addLayer, args: [s2[h2], d2] }), o2.splice(o2.length - u2, 0, h2), l2[h2] = true);
for (u2 = 0; u2 < i4.length; u2++) if (h2 = i4[u2], p2 = a3[h2], f2 = s2[h2], !l2[h2] && !W(p2, f2)) if (W(p2.source, f2.source) && W(p2["source-layer"], f2["source-layer"]) && W(p2.type, f2.type)) {
for (y2 in it(p2.layout, f2.layout, r3, h2, null, Q.setLayoutProperty), it(p2.paint, f2.paint, r3, h2, null, Q.setPaintProperty), W(p2.filter, f2.filter) || r3.push({ command: Q.setFilter, args: [h2, f2.filter] }), W(p2.minzoom, f2.minzoom) && W(p2.maxzoom, f2.maxzoom) || r3.push({ command: Q.setLayerZoomRange, args: [h2, f2.minzoom, f2.maxzoom] }), p2) Object.prototype.hasOwnProperty.call(p2, y2) && "layout" !== y2 && "paint" !== y2 && "filter" !== y2 && "metadata" !== y2 && "minzoom" !== y2 && "maxzoom" !== y2 && (0 === y2.indexOf("paint.") ? it(p2[y2], f2[y2], r3, h2, y2.slice(6), Q.setPaintProperty) : W(p2[y2], f2[y2]) || r3.push({ command: Q.setLayerProperty, args: [h2, y2, f2[y2]] }));
for (y2 in f2) Object.prototype.hasOwnProperty.call(f2, y2) && !Object.prototype.hasOwnProperty.call(p2, y2) && "layout" !== y2 && "paint" !== y2 && "filter" !== y2 && "metadata" !== y2 && "minzoom" !== y2 && "maxzoom" !== y2 && (0 === y2.indexOf("paint.") ? it(p2[y2], f2[y2], r3, h2, y2.slice(6), Q.setPaintProperty) : W(p2[y2], f2[y2]) || r3.push({ command: Q.setLayerProperty, args: [h2, y2, f2[y2]] }));
} else r3.push({ command: Q.removeLayer, args: [h2] }), d2 = o2[o2.lastIndexOf(h2) + 1], r3.push({ command: Q.addLayer, args: [f2, d2] });
})(a2, e2.layers, r2);
} catch (t3) {
console.warn("Unable to compute style diff:", t3), r2 = [{ command: Q.setStyle, args: [e2] }];
}
return r2;
}, t.aF = function(t2) {
const e2 = [], r2 = t2.id;
return void 0 === r2 && e2.push({ message: `layers.${r2}: missing required property "id"` }), void 0 === t2.render && e2.push({ message: `layers.${r2}: missing required method "render"` }), t2.renderingMode && "2d" !== t2.renderingMode && "3d" !== t2.renderingMode && e2.push({ message: `layers.${r2}: property "renderingMode" must be either "2d" or "3d"` }), e2;
}, t.aG = function t2(e2, r2) {
if (Array.isArray(e2)) {
if (!Array.isArray(r2) || e2.length !== r2.length) return false;
for (let n2 = 0; n2 < e2.length; n2++) if (!t2(e2[n2], r2[n2])) return false;
return true;
}
if ("object" == typeof e2 && null !== e2 && null !== r2) {
if ("object" != typeof r2) return false;
if (Object.keys(e2).length !== Object.keys(r2).length) return false;
for (const n2 in e2) if (!t2(e2[n2], r2[n2])) return false;
return true;
}
return e2 === r2;
}, t.aH = v, t.aI = b, t.aJ = ii, t.aK = function(t2) {
return t2({ pluginStatus: ti, pluginURL: ei }), ii.on("pluginStateChange", t2), t2;
}, t.aL = class extends Ra {
constructor(t2, e2) {
super(t2, e2), this.current = 0;
}
set(t2) {
this.current !== t2 && (this.current = t2, this.gl.uniform1i(this.location, t2));
}
}, t.aM = qa, t.aN = class extends Ra {
constructor(t2, e2) {
super(t2, e2), this.current = Za;
}
set(t2) {
if (t2[12] !== this.current[12] || t2[0] !== this.current[0]) return this.current = t2, void this.gl.uniformMatrix4fv(this.location, false, t2);
for (let e2 = 1; e2 < 16; e2++) if (t2[e2] !== this.current[e2]) {
this.current = t2, this.gl.uniformMatrix4fv(this.location, false, t2);
break;
}
}
}, t.aO = ja, t.aP = class extends Ra {
constructor(t2, e2) {
super(t2, e2), this.current = [0, 0, 0];
}
set(t2) {
t2[0] === this.current[0] && t2[1] === this.current[1] && t2[2] === this.current[2] || (this.current = t2, this.gl.uniform3f(this.location, t2[0], t2[1], t2[2]));
}
}, t.aQ = class extends Ra {
constructor(t2, e2) {
super(t2, e2), this.current = [0, 0];
}
set(t2) {
t2[0] === this.current[0] && t2[1] === this.current[1] || (this.current = t2, this.gl.uniform2f(this.location, t2[0], t2[1]));
}
}, t.aR = Na, t.aS = function(t2, e2, r2, n2, i3, a2, s2) {
var o2 = 1 / (e2 - r2), l2 = 1 / (n2 - i3), u2 = 1 / (a2 - s2);
return t2[0] = -2 * o2, t2[1] = 0, t2[2] = 0, t2[3] = 0, t2[4] = 0, t2[5] = -2 * l2, t2[6] = 0, t2[7] = 0, t2[8] = 0, t2[9] = 0, t2[10] = 2 * u2, t2[11] = 0, t2[12] = (e2 + r2) * o2, t2[13] = (i3 + n2) * l2, t2[14] = (s2 + a2) * u2, t2[15] = 1, t2;
}, t.aT = Yt, t.aU = Ps, t.aV = class extends qi {
}, t.aW = Cl, t.aX = class extends Ni {
}, t.aY = function(t2) {
return t2 <= 1 ? 1 : Math.pow(2, Math.ceil(Math.log(t2) / Math.LN2));
}, t.aZ = js, t.a_ = ha, t.aa = function(t2) {
const e2 = {};
if (t2.replace(/(?:^|(?:\s*\,\s*))([^\x00-\x20\(\)<>@\,;\:\\"\/\[\]\?\=\{\}\x7F]+)(?:\=(?:([^\x00-\x20\(\)<>@\,;\:\\"\/\[\]\?\=\{\}\x7F]+)|(?:\"((?:[^"\\]|\\.)*)\")))?/g, ((t3, r2, n2, i3) => {
const a2 = n2 || i3;
return e2[r2] = !a2 || a2.toLowerCase(), "";
})), e2["max-age"]) {
const t3 = parseInt(e2["max-age"], 10);
isNaN(t3) ? delete e2["max-age"] : e2["max-age"] = t3;
}
return e2;
}, t.ab = function(t2, e2) {
const r2 = [];
for (const n2 in t2) n2 in e2 || r2.push(n2);
return r2;
}, t.ac = function(t2) {
if (null == z) {
const e2 = t2.navigator ? t2.navigator.userAgent : null;
z = !!t2.safari || !(!e2 || !(/\b(iPad|iPhone|iPod)\b/.test(e2) || e2.match("Safari") && !e2.match("Chrome")));
}
return z;
}, t.ad = y, t.ae = function(t2, e2, r2) {
var n2 = Math.sin(r2), i3 = Math.cos(r2), a2 = e2[0], s2 = e2[1], o2 = e2[2], l2 = e2[3], u2 = e2[4], c2 = e2[5], h2 = e2[6], p2 = e2[7];
return e2 !== t2 && (t2[8] = e2[8], t2[9] = e2[9], t2[10] = e2[10], t2[11] = e2[11], t2[12] = e2[12], t2[13] = e2[13], t2[14] = e2[14], t2[15] = e2[15]), t2[0] = a2 * i3 + u2 * n2, t2[1] = s2 * i3 + c2 * n2, t2[2] = o2 * i3 + h2 * n2, t2[3] = l2 * i3 + p2 * n2, t2[4] = u2 * i3 - a2 * n2, t2[5] = c2 * i3 - s2 * n2, t2[6] = h2 * i3 - o2 * n2, t2[7] = p2 * i3 - l2 * n2, t2;
}, t.af = function(t2) {
var e2 = new zs(16);
return e2[0] = t2[0], e2[1] = t2[1], e2[2] = t2[2], e2[3] = t2[3], e2[4] = t2[4], e2[5] = t2[5], e2[6] = t2[6], e2[7] = t2[7], e2[8] = t2[8], e2[9] = t2[9], e2[10] = t2[10], e2[11] = t2[11], e2[12] = t2[12], e2[13] = t2[13], e2[14] = t2[14], e2[15] = t2[15], e2;
}, t.ag = Vs, t.ah = function(t2, e2) {
let r2 = 0, n2 = 0;
if ("constant" === t2.kind) n2 = t2.layoutSize;
else if ("source" !== t2.kind) {
const { interpolationType: i3, minZoom: a2, maxZoom: s2 } = t2, o2 = i3 ? y(Ke.interpolationFactor(i3, e2, a2, s2), 0, 1) : 0;
"camera" === t2.kind ? n2 = Ze.number(t2.minSize, t2.maxSize, o2) : r2 = o2;
}
return { uSizeT: r2, uSize: n2 };
}, t.aj = function(t2, { uSize: e2, uSizeT: r2 }, { lowerSize: n2, upperSize: i3 }) {
return "source" === t2.kind ? n2 / Cu : "composite" === t2.kind ? Ze.number(n2 / Cu, i3 / Cu, r2) : e2;
}, t.ak = $u, t.al = function(t2, e2, r2, n2) {
const i3 = e2.y - t2.y, s2 = e2.x - t2.x, o2 = n2.y - r2.y, l2 = n2.x - r2.x, u2 = o2 * s2 - l2 * i3;
if (0 === u2) return null;
const c2 = (l2 * (t2.y - r2.y) - o2 * (t2.x - r2.x)) / u2;
return new a(t2.x + c2 * s2, t2.y + c2 * i3);
}, t.am = _c, t.an = us, t.ao = Ms, t.ap = Vl, t.ar = Vu, t.as = function(t2, e2) {
var r2 = e2[0], n2 = e2[1], i3 = e2[2], a2 = e2[3], s2 = e2[4], o2 = e2[5], l2 = e2[6], u2 = e2[7], c2 = e2[8], h2 = e2[9], p2 = e2[10], f2 = e2[11], d2 = e2[12], y2 = e2[13], m2 = e2[14], g2 = e2[15], x2 = r2 * o2 - n2 * s2, v2 = r2 * l2 - i3 * s2, b2 = r2 * u2 - a2 * s2, w2 = n2 * l2 - i3 * o2, _2 = n2 * u2 - a2 * o2, A2 = i3 * u2 - a2 * l2, S2 = c2 * y2 - h2 * d2, k2 = c2 * m2 - p2 * d2, I2 = c2 * g2 - f2 * d2, z2 = h2 * m2 - p2 * y2, M2 = h2 * g2 - f2 * y2, C2 = p2 * g2 - f2 * m2, B2 = x2 * C2 - v2 * M2 + b2 * z2 + w2 * I2 - _2 * k2 + A2 * S2;
return B2 ? (t2[0] = (o2 * C2 - l2 * M2 + u2 * z2) * (B2 = 1 / B2), t2[1] = (i3 * M2 - n2 * C2 - a2 * z2) * B2, t2[2] = (y2 * A2 - m2 * _2 + g2 * w2) * B2, t2[3] = (p2 * _2 - h2 * A2 - f2 * w2) * B2, t2[4] = (l2 * I2 - s2 * C2 - u2 * k2) * B2, t2[5] = (r2 * C2 - i3 * I2 + a2 * k2) * B2, t2[6] = (m2 * b2 - d2 * A2 - g2 * v2) * B2, t2[7] = (c2 * A2 - p2 * b2 + f2 * v2) * B2, t2[8] = (s2 * M2 - o2 * I2 + u2 * S2) * B2, t2[9] = (n2 * I2 - r2 * M2 - a2 * S2) * B2, t2[10] = (d2 * _2 - y2 * b2 + g2 * x2) * B2, t2[11] = (h2 * b2 - c2 * _2 - f2 * x2) * B2, t2[12] = (o2 * k2 - s2 * z2 - l2 * S2) * B2, t2[13] = (r2 * z2 - n2 * k2 + i3 * S2) * B2, t2[14] = (y2 * v2 - d2 * w2 - m2 * x2) * B2, t2[15] = (c2 * w2 - h2 * v2 + p2 * x2) * B2, t2) : null;
}, t.at = Jc, t.au = Su, t.av = th, t.aw = function() {
const t2 = {}, e2 = X.$version;
for (const r2 in X.$root) {
const n2 = X.$root[r2];
if (n2.required) {
let i3 = null;
i3 = "version" === r2 ? e2 : "array" === n2.type ? [] : {}, null != i3 && (t2[r2] = i3);
}
}
return t2;
}, t.ax = Q, t.ay = Un, t.az = D, t.b = function(t2, e2) {
const r2 = new Blob([new Uint8Array(t2)], { type: "image/png" });
createImageBitmap(r2).then(((t3) => {
e2(null, t3);
})).catch(((t3) => {
e2(new Error(`Could not load image because of ${t3.message}. Please make sure to use a supported image type such as PNG or JPEG. Note that SVGs are not supported.`));
}));
}, t.b0 = Aa, t.b1 = function(t2, e2) {
var r2 = t2[0], n2 = t2[1], i3 = t2[2], a2 = t2[3], s2 = t2[4], o2 = t2[5], l2 = t2[6], u2 = t2[7], c2 = t2[8], h2 = t2[9], p2 = t2[10], f2 = t2[11], d2 = t2[12], y2 = t2[13], m2 = t2[14], g2 = t2[15], x2 = e2[0], v2 = e2[1], b2 = e2[2], w2 = e2[3], _2 = e2[4], A2 = e2[5], S2 = e2[6], k2 = e2[7], I2 = e2[8], z2 = e2[9], M2 = e2[10], C2 = e2[11], B2 = e2[12], P2 = e2[13], V2 = e2[14], E2 = e2[15];
return Math.abs(r2 - x2) <= Is * Math.max(1, Math.abs(r2), Math.abs(x2)) && Math.abs(n2 - v2) <= Is * Math.max(1, Math.abs(n2), Math.abs(v2)) && Math.abs(i3 - b2) <= Is * Math.max(1, Math.abs(i3), Math.abs(b2)) && Math.abs(a2 - w2) <= Is * Math.max(1, Math.abs(a2), Math.abs(w2)) && Math.abs(s2 - _2) <= Is * Math.max(1, Math.abs(s2), Math.abs(_2)) && Math.abs(o2 - A2) <= Is * Math.max(1, Math.abs(o2), Math.abs(A2)) && Math.abs(l2 - S2) <= Is * Math.max(1, Math.abs(l2), Math.abs(S2)) && Math.abs(u2 - k2) <= Is * Math.max(1, Math.abs(u2), Math.abs(k2)) && Math.abs(c2 - I2) <= Is * Math.max(1, Math.abs(c2), Math.abs(I2)) && Math.abs(h2 - z2) <= Is * Math.max(1, Math.abs(h2), Math.abs(z2)) && Math.abs(p2 - M2) <= Is * Math.max(1, Math.abs(p2), Math.abs(M2)) && Math.abs(f2 - C2) <= Is * Math.max(1, Math.abs(f2), Math.abs(C2)) && Math.abs(d2 - B2) <= Is * Math.max(1, Math.abs(d2), Math.abs(B2)) && Math.abs(y2 - P2) <= Is * Math.max(1, Math.abs(y2), Math.abs(P2)) && Math.abs(m2 - V2) <= Is * Math.max(1, Math.abs(m2), Math.abs(V2)) && Math.abs(g2 - E2) <= Is * Math.max(1, Math.abs(g2), Math.abs(E2));
}, t.b2 = function(t2, e2) {
return t2[0] = e2[0], t2[1] = e2[1], t2[2] = e2[2], t2[3] = e2[3], t2[4] = e2[4], t2[5] = e2[5], t2[6] = e2[6], t2[7] = e2[7], t2[8] = e2[8], t2[9] = e2[9], t2[10] = e2[10], t2[11] = e2[11], t2[12] = e2[12], t2[13] = e2[13], t2[14] = e2[14], t2[15] = e2[15], t2;
}, t.b3 = function(t2, e2, r2) {
return t2[0] = e2[0] * r2[0], t2[1] = e2[1] * r2[1], t2[2] = e2[2] * r2[2], t2[3] = e2[3] * r2[3], t2;
}, t.b4 = function(t2, e2) {
return t2[0] * e2[0] + t2[1] * e2[1] + t2[2] * e2[2] + t2[3] * e2[3];
}, t.b5 = m, t.b6 = pc, t.b7 = sc, t.b8 = function(t2, e2, r2, n2, i3) {
var a2, s2 = 1 / Math.tan(e2 / 2);
return t2[0] = s2 / r2, t2[1] = 0, t2[2] = 0, t2[3] = 0, t2[4] = 0, t2[5] = s2, t2[6] = 0, t2[7] = 0, t2[8] = 0, t2[9] = 0, t2[11] = -1, t2[12] = 0, t2[13] = 0, t2[15] = 0, null != i3 && i3 !== 1 / 0 ? (t2[10] = (i3 + n2) * (a2 = 1 / (n2 - i3)), t2[14] = 2 * i3 * n2 * a2) : (t2[10] = -1, t2[14] = -2 * n2), t2;
}, t.b9 = function(t2, e2, r2) {
var n2 = Math.sin(r2), i3 = Math.cos(r2), a2 = e2[4], s2 = e2[5], o2 = e2[6], l2 = e2[7], u2 = e2[8], c2 = e2[9], h2 = e2[10], p2 = e2[11];
return e2 !== t2 && (t2[0] = e2[0], t2[1] = e2[1], t2[2] = e2[2], t2[3] = e2[3], t2[12] = e2[12], t2[13] = e2[13], t2[14] = e2[14], t2[15] = e2[15]), t2[4] = a2 * i3 + u2 * n2, t2[5] = s2 * i3 + c2 * n2, t2[6] = o2 * i3 + h2 * n2, t2[7] = l2 * i3 + p2 * n2, t2[8] = u2 * i3 - a2 * n2, t2[9] = c2 * i3 - s2 * n2, t2[10] = h2 * i3 - o2 * n2, t2[11] = p2 * i3 - l2 * n2, t2;
}, t.bA = n, t.bB = El, t.bC = $r, t.bD = oi, t.ba = f, t.bb = d, t.bc = function(t2, e2) {
return t2[0] = e2[0], t2[1] = 0, t2[2] = 0, t2[3] = 0, t2[4] = 0, t2[5] = e2[1], t2[6] = 0, t2[7] = 0, t2[8] = 0, t2[9] = 0, t2[10] = e2[2], t2[11] = 0, t2[12] = 0, t2[13] = 0, t2[14] = 0, t2[15] = 1, t2;
}, t.bd = class extends Pi {
}, t.be = tc, t.bf = oc, t.bg = ph, t.bi = L, t.bj = function(t2, e2, r2 = false) {
if (ti === Yn || ti === Hn || ti === Wn) throw new Error("setRTLTextPlugin cannot be called multiple times.");
ei = T.resolveURL(t2), ti = Yn, Qn = e2, ni(), r2 || si();
}, t.bk = ai, t.bl = function(t2, e2) {
const r2 = {};
for (let n3 = 0; n3 < t2.length; n3++) {
const i3 = e2 && e2[t2[n3].id] || Qr(t2[n3]);
e2 && (e2[t2[n3].id] = i3);
let a2 = r2[i3];
a2 || (a2 = r2[i3] = []), a2.push(t2[n3]);
}
const n2 = [];
for (const t3 in r2) n2.push(r2[t3]);
return n2;
}, t.bm = $n, t.bn = mc, t.bo = xc, t.bp = cu, t.bq = function(e2) {
e2.bucket.createArrays(), e2.bucket.tilePixelRatio = rs / (512 * e2.bucket.overscaling), e2.bucket.compareText = {}, e2.bucket.iconsNeedLinear = false;
const r2 = e2.bucket.layers[0], n2 = r2.layout, i3 = r2._unevaluatedLayout._values, a2 = { layoutIconSize: i3["icon-size"].possiblyEvaluate(new li(e2.bucket.zoom + 1), e2.canonical), layoutTextSize: i3["text-size"].possiblyEvaluate(new li(e2.bucket.zoom + 1), e2.canonical), textMaxSize: i3["text-size"].possiblyEvaluate(new li(18)) };
if ("composite" === e2.bucket.textSizeData.kind) {
const { minZoom: t2, maxZoom: r3 } = e2.bucket.textSizeData;
a2.compositeTextSizes = [i3["text-size"].possiblyEvaluate(new li(t2), e2.canonical), i3["text-size"].possiblyEvaluate(new li(r3), e2.canonical)];
}
if ("composite" === e2.bucket.iconSizeData.kind) {
const { minZoom: t2, maxZoom: r3 } = e2.bucket.iconSizeData;
a2.compositeIconSizes = [i3["icon-size"].possiblyEvaluate(new li(t2), e2.canonical), i3["icon-size"].possiblyEvaluate(new li(r3), e2.canonical)];
}
const s2 = n2.get("text-line-height") * Vl, o2 = "viewport" !== n2.get("text-rotation-alignment") && "point" !== n2.get("symbol-placement"), l2 = n2.get("text-keep-upright"), u2 = n2.get("text-size");
for (const i4 of e2.bucket.features) {
const c2 = n2.get("text-font").evaluate(i4, {}, e2.canonical).join(","), h2 = u2.evaluate(i4, {}, e2.canonical), p2 = a2.layoutTextSize.evaluate(i4, {}, e2.canonical), f2 = a2.layoutIconSize.evaluate(i4, {}, e2.canonical), d2 = { horizontal: {}, vertical: void 0 }, y2 = i4.text;
let m2, g2 = [0, 0];
if (y2) {
const a3 = y2.toString(), u3 = n2.get("text-letter-spacing").evaluate(i4, {}, e2.canonical) * Vl, f3 = jn(a3) ? u3 : 0, m3 = n2.get("text-anchor").evaluate(i4, {}, e2.canonical), x3 = Gc(r2, i4, e2.canonical);
if (!x3) {
const t2 = n2.get("text-radial-offset").evaluate(i4, {}, e2.canonical);
g2 = t2 ? Kc(m3, [t2 * Vl, Zc]) : n2.get("text-offset").evaluate(i4, {}, e2.canonical).map(((t3) => t3 * Vl));
}
let v3 = o2 ? "center" : n2.get("text-justify").evaluate(i4, {}, e2.canonical);
const b2 = n2.get("symbol-placement"), w2 = "point" === b2 ? n2.get("text-max-width").evaluate(i4, {}, e2.canonical) * Vl : 0, _2 = () => {
e2.bucket.allowVerticalPlacement && qn(a3) && (d2.vertical = yu(y2, e2.glyphMap, e2.glyphPositions, e2.imagePositions, c2, w2, s2, m3, "left", f3, g2, t.ai.vertical, true, b2, p2, h2));
};
if (!o2 && x3) {
const r3 = /* @__PURE__ */ new Set();
if ("auto" === v3) for (let t2 = 0; t2 < x3.values.length; t2 += 2) r3.add(Jc(x3.values[t2]));
else r3.add(v3);
let n3 = false;
for (const i5 of r3) if (!d2.horizontal[i5]) if (n3) d2.horizontal[i5] = d2.horizontal[0];
else {
const r4 = yu(y2, e2.glyphMap, e2.glyphPositions, e2.imagePositions, c2, w2, s2, "center", i5, f3, g2, t.ai.horizontal, false, b2, p2, h2);
r4 && (d2.horizontal[i5] = r4, n3 = 1 === r4.positionedLines.length);
}
_2();
} else {
"auto" === v3 && (v3 = Jc(m3));
const r3 = yu(y2, e2.glyphMap, e2.glyphPositions, e2.imagePositions, c2, w2, s2, m3, v3, f3, g2, t.ai.horizontal, false, b2, p2, h2);
r3 && (d2.horizontal[v3] = r3), _2(), qn(a3) && o2 && l2 && (d2.vertical = yu(y2, e2.glyphMap, e2.glyphPositions, e2.imagePositions, c2, w2, s2, m3, v3, f3, g2, t.ai.vertical, false, b2, p2, h2));
}
}
let x2 = false;
if (i4.icon && i4.icon.name) {
const t2 = e2.imageMap[i4.icon.name];
t2 && (m2 = Iu(e2.imagePositions[i4.icon.name], n2.get("icon-offset").evaluate(i4, {}, e2.canonical), n2.get("icon-anchor").evaluate(i4, {}, e2.canonical)), x2 = !!t2.sdf, void 0 === e2.bucket.sdfIcons ? e2.bucket.sdfIcons = x2 : e2.bucket.sdfIcons !== x2 && A("Style sheet warning: Cannot mix SDF and non-SDF icons in one buffer"), (t2.pixelRatio !== e2.bucket.pixelRatio || 0 !== n2.get("icon-rotate").constantOr(1)) && (e2.bucket.iconsNeedLinear = true));
}
const v2 = Hc(d2.horizontal) || d2.vertical;
e2.bucket.iconsInText = !!v2 && v2.iconsInText, (v2 || m2) && Xc(e2.bucket, i4, d2, m2, e2.imageMap, a2, p2, f2, g2, x2, e2.canonical);
}
e2.showCollisionBoxes && e2.bucket.generateCollisionDebugBuffers();
}, t.br = gl, t.bs = Eo, t.bt = rl, t.bu = class {
constructor(t2) {
this._marks = { start: [t2.url, "start"].join("#"), end: [t2.url, "end"].join("#"), measure: t2.url.toString() }, performance.mark(this._marks.start);
}
finish() {
performance.mark(this._marks.end);
let t2 = performance.getEntriesByName(this._marks.measure);
return 0 === t2.length && (performance.measure(this._marks.measure, this._marks.start, this._marks.end), t2 = performance.getEntriesByName(this._marks.measure), performance.clearMarks(this._marks.start), performance.clearMarks(this._marks.end), performance.clearMeasures(this._marks.measure)), t2;
}
}, t.bv = eu, t.bw = Ro, t.bx = function(t2, r2, n2, i3, a2) {
return e(this, void 0, void 0, (function* () {
if (p()) try {
return yield B(t2, r2, n2, i3, a2);
} catch (t3) {
}
return (function(t3, e2, r3, n3, i4) {
const a3 = t3.width, s2 = t3.height;
P && V || (P = new OffscreenCanvas(a3, s2), V = P.getContext("2d", { willReadFrequently: true })), P.width = a3, P.height = s2, V.drawImage(t3, 0, 0, a3, s2);
const o2 = V.getImageData(e2, r3, n3, i4);
return V.clearRect(0, 0, a3, s2), o2.data;
})(t2, r2, n2, i3, a2);
}));
}, t.by = yc, t.bz = r, t.c = $, t.d = function(t2, e2) {
const r2 = new Image();
r2.onload = () => {
e2(null, r2), URL.revokeObjectURL(r2.src), r2.onload = null, window.requestAnimationFrame((() => {
r2.src = C;
}));
}, r2.onerror = () => e2(new Error("Could not load image. Please make sure to use a supported image type such as PNG or JPEG. Note that SVGs are not supported."));
const n2 = new Blob([new Uint8Array(t2)], { type: "image/png" });
r2.src = t2.byteLength ? URL.createObjectURL(n2) : C;
}, t.e = g, t.f = function(t2, e2) {
return R(g(t2, { type: "json" }), e2);
}, t.g = O, t.h = T, t.i = I, t.j = G, t.k = K, t.l = q, t.m = R, t.n = function(t2) {
return new eu(t2).readFields(nu, []);
}, t.o = function(t2, e2, r2) {
if (!t2.length) return r2(null, []);
let n2 = t2.length;
const i3 = new Array(t2.length);
let a2 = null;
t2.forEach(((t3, s2) => {
e2(t3, ((t4, e3) => {
t4 && (a2 = t4), i3[s2] = e3, 0 == --n2 && r2(a2, i3);
}));
}));
}, t.p = ou, t.q = Rs, t.r = _i, t.s = j, t.t = Bn, t.u = Rn, t.v = X, t.w = A, t.x = En, t.y = Cn, t.z = function([t2, e2, r2]) {
return e2 += 90, e2 *= Math.PI / 180, r2 *= Math.PI / 180, { x: t2 * Math.cos(e2) * Math.sin(r2), y: t2 * Math.sin(e2) * Math.sin(r2), z: t2 * Math.cos(r2) };
};
}));
define(["./shared"], (function(e) {
class t {
constructor(e2) {
this.keyCache = {}, e2 && this.replace(e2);
}
replace(e2) {
this._layerConfigs = {}, this._layers = {}, this.update(e2, []);
}
update(t2, i3) {
for (const i4 of t2) {
this._layerConfigs[i4.id] = i4;
const t3 = this._layers[i4.id] = e.aC(i4);
t3._featureFilter = e.a6(t3.filter), this.keyCache[i4.id] && delete this.keyCache[i4.id];
}
for (const e2 of i3) delete this.keyCache[e2], delete this._layerConfigs[e2], delete this._layers[e2];
this.familiesBySource = {};
const o2 = e.bl(Object.values(this._layerConfigs), this.keyCache);
for (const e2 of o2) {
const t3 = e2.map(((e3) => this._layers[e3.id])), i4 = t3[0];
if ("none" === i4.visibility) continue;
const o3 = i4.source || "";
let r2 = this.familiesBySource[o3];
r2 || (r2 = this.familiesBySource[o3] = {});
const s2 = i4.sourceLayer || "_geojsonTileLayer";
let n2 = r2[s2];
n2 || (n2 = r2[s2] = []), n2.push(t3);
}
}
}
class i2 {
constructor(t2) {
const i3 = {}, o2 = [];
for (const e2 in t2) {
const r3 = t2[e2], s3 = i3[e2] = {};
for (const e3 in r3) {
const t3 = r3[+e3];
if (!t3 || 0 === t3.bitmap.width || 0 === t3.bitmap.height) continue;
const i4 = { x: 0, y: 0, w: t3.bitmap.width + 2, h: t3.bitmap.height + 2 };
o2.push(i4), s3[e3] = { rect: i4, metrics: t3.metrics };
}
}
const { w: r2, h: s2 } = e.p(o2), n2 = new e.q({ width: r2 || 1, height: s2 || 1 });
for (const o3 in t2) {
const r3 = t2[o3];
for (const t3 in r3) {
const s3 = r3[+t3];
if (!s3 || 0 === s3.bitmap.width || 0 === s3.bitmap.height) continue;
const a2 = i3[o3][t3].rect;
e.q.copy(s3.bitmap, n2, { x: 0, y: 0 }, { x: a2.x + 1, y: a2.y + 1 }, s3.bitmap);
}
}
this.image = n2, this.positions = i3;
}
}
e.bm("GlyphAtlas", i2);
class o {
constructor(t2) {
this.tileID = new e.O(t2.tileID.overscaledZ, t2.tileID.wrap, t2.tileID.canonical.z, t2.tileID.canonical.x, t2.tileID.canonical.y), this.uid = t2.uid, this.zoom = t2.zoom, this.pixelRatio = t2.pixelRatio, this.tileSize = t2.tileSize, this.source = t2.source, this.overscaling = this.tileID.overscaleFactor(), this.showCollisionBoxes = t2.showCollisionBoxes, this.collectResourceTiming = !!t2.collectResourceTiming, this.returnDependencies = !!t2.returnDependencies, this.promoteId = t2.promoteId, this.inFlightDependencies = [], this.dependencySentinel = -1;
}
parse(t2, o2, s2, n2, a2) {
this.status = "parsing", this.data = t2, this.collisionBoxArray = new e.a3();
const l2 = new e.bn(Object.keys(t2.layers).sort()), c2 = new e.bo(this.tileID, this.promoteId);
c2.bucketLayerIDs = [];
const h2 = {}, u2 = { featureIndex: c2, iconDependencies: {}, patternDependencies: {}, glyphDependencies: {}, availableImages: s2 }, d2 = o2.familiesBySource[this.source];
for (const i3 in d2) {
const o3 = t2.layers[i3];
if (!o3) continue;
1 === o3.version && e.w(`Vector tile source "${this.source}" layer "${i3}" does not use vector tile spec v2 and therefore may have some rendering errors.`);
const n3 = l2.encode(i3), a3 = [];
for (let e2 = 0; e2 < o3.length; e2++) {
const t3 = o3.feature(e2), r2 = c2.getId(t3, i3);
a3.push({ feature: t3, id: r2, index: e2, sourceLayerIndex: n3 });
}
for (const t3 of d2[i3]) {
const i4 = t3[0];
i4.source !== this.source && e.w(`layer.source = ${i4.source} does not equal this.source = ${this.source}`), i4.minzoom && this.zoom < Math.floor(i4.minzoom) || i4.maxzoom && this.zoom >= i4.maxzoom || "none" !== i4.visibility && (r(t3, this.zoom, s2), (h2[i4.id] = i4.createBucket({ index: c2.bucketLayerIDs.length, layers: t3, zoom: this.zoom, pixelRatio: this.pixelRatio, overscaling: this.overscaling, collisionBoxArray: this.collisionBoxArray, sourceLayerIndex: n3, sourceID: this.source })).populate(a3, u2, this.tileID.canonical), c2.bucketLayerIDs.push(t3.map(((e2) => e2.id))));
}
}
let p2, f2, g2, m2;
const y2 = e.aH(u2.glyphDependencies, ((e2) => Object.keys(e2).map(Number)));
this.inFlightDependencies.forEach(((e2) => null == e2 ? void 0 : e2.cancel())), this.inFlightDependencies = [];
const v2 = ++this.dependencySentinel;
Object.keys(y2).length ? this.inFlightDependencies.push(n2.send("getGlyphs", { uid: this.uid, stacks: y2, source: this.source, tileID: this.tileID, type: "glyphs" }, ((e2, t3) => {
v2 === this.dependencySentinel && (p2 || (p2 = e2, f2 = t3, b2.call(this)));
}))) : f2 = {};
const w2 = Object.keys(u2.iconDependencies);
w2.length ? this.inFlightDependencies.push(n2.send("getImages", { icons: w2, source: this.source, tileID: this.tileID, type: "icons" }, ((e2, t3) => {
v2 === this.dependencySentinel && (p2 || (p2 = e2, g2 = t3, b2.call(this)));
}))) : g2 = {};
const x2 = Object.keys(u2.patternDependencies);
function b2() {
if (p2) return a2(p2);
if (f2 && g2 && m2) {
const t3 = new i2(f2), o3 = new e.bp(g2, m2);
for (const i3 in h2) {
const n3 = h2[i3];
n3 instanceof e.a4 ? (r(n3.layers, this.zoom, s2), e.bq({ bucket: n3, glyphMap: f2, glyphPositions: t3.positions, imageMap: g2, imagePositions: o3.iconPositions, showCollisionBoxes: this.showCollisionBoxes, canonical: this.tileID.canonical })) : n3.hasPattern && (n3 instanceof e.br || n3 instanceof e.bs || n3 instanceof e.bt) && (r(n3.layers, this.zoom, s2), n3.addFeatures(u2, this.tileID.canonical, o3.patternPositions));
}
this.status = "done", a2(null, { buckets: Object.values(h2).filter(((e2) => !e2.isEmpty())), featureIndex: c2, collisionBoxArray: this.collisionBoxArray, glyphAtlasImage: t3.image, imageAtlas: o3, glyphMap: this.returnDependencies ? f2 : null, iconMap: this.returnDependencies ? g2 : null, glyphPositions: this.returnDependencies ? t3.positions : null });
}
}
x2.length ? this.inFlightDependencies.push(n2.send("getImages", { icons: x2, source: this.source, tileID: this.tileID, type: "patterns" }, ((e2, t3) => {
v2 === this.dependencySentinel && (p2 || (p2 = e2, m2 = t3, b2.call(this)));
}))) : m2 = {}, b2.call(this);
}
}
function r(t2, i3, o2) {
const r2 = new e.a8(i3);
for (const e2 of t2) e2.recalculate(r2, o2);
}
function s(t2, i3) {
const o2 = e.l(t2.request, ((o3, r2, s2, n2) => {
if (o3) i3(o3);
else if (r2) try {
const t3 = new e.bw.VectorTile(new e.bv(r2));
i3(null, { vectorTile: t3, rawData: r2, cacheControl: s2, expires: n2 });
} catch (e2) {
const o4 = new Uint8Array(r2);
let s3 = `Unable to parse the tile at ${t2.request.url}, `;
s3 += 31 === o4[0] && 139 === o4[1] ? "please make sure the data is not gzipped and that you have configured the relevant header in the server" : `got error: ${e2.messge}`, i3(new Error(s3));
}
}));
return () => {
o2.cancel(), i3();
};
}
class n {
constructor(e2, t2, i3, o2) {
this.actor = e2, this.layerIndex = t2, this.availableImages = i3, this.loadVectorData = o2 || s, this.fetching = {}, this.loading = {}, this.loaded = {};
}
loadTile(t2, i3) {
const r2 = t2.uid;
this.loading || (this.loading = {});
const s2 = !!(t2 && t2.request && t2.request.collectResourceTiming) && new e.bu(t2.request), n2 = this.loading[r2] = new o(t2);
n2.abort = this.loadVectorData(t2, ((t3, o2) => {
if (delete this.loading[r2], t3 || !o2) return n2.status = "done", this.loaded[r2] = n2, i3(t3);
const a2 = o2.rawData, l2 = {};
o2.expires && (l2.expires = o2.expires), o2.cacheControl && (l2.cacheControl = o2.cacheControl);
const c2 = {};
if (s2) {
const e2 = s2.finish();
e2 && (c2.resourceTiming = JSON.parse(JSON.stringify(e2)));
}
n2.vectorTile = o2.vectorTile, n2.parse(o2.vectorTile, this.layerIndex, this.availableImages, this.actor, ((t4, o3) => {
if (delete this.fetching[r2], t4 || !o3) return i3(t4);
i3(null, e.e({ rawTileData: a2.slice(0) }, o3, l2, c2));
})), this.loaded = this.loaded || {}, this.loaded[r2] = n2, this.fetching[r2] = { rawTileData: a2, cacheControl: l2, resourceTiming: c2 };
}));
}
reloadTile(t2, i3) {
const o2 = this.loaded, r2 = t2.uid;
if (o2 && o2[r2]) {
const s2 = o2[r2];
s2.showCollisionBoxes = t2.showCollisionBoxes, "parsing" === s2.status ? s2.parse(s2.vectorTile, this.layerIndex, this.availableImages, this.actor, ((t3, o3) => {
if (t3 || !o3) return i3(t3, o3);
let s3;
if (this.fetching[r2]) {
const { rawTileData: t4, cacheControl: i4, resourceTiming: n2 } = this.fetching[r2];
delete this.fetching[r2], s3 = e.e({ rawTileData: t4.slice(0) }, o3, i4, n2);
} else s3 = o3;
i3(null, s3);
})) : "done" === s2.status && (s2.vectorTile ? s2.parse(s2.vectorTile, this.layerIndex, this.availableImages, this.actor, i3) : i3());
}
}
abortTile(e2, t2) {
const i3 = this.loading, o2 = e2.uid;
i3 && i3[o2] && i3[o2].abort && (i3[o2].abort(), delete i3[o2]), t2();
}
removeTile(e2, t2) {
const i3 = this.loaded, o2 = e2.uid;
i3 && i3[o2] && delete i3[o2], t2();
}
}
class a {
constructor() {
this.loaded = {};
}
loadTile(t2, i3) {
return e._(this, void 0, void 0, (function* () {
const { uid: o2, encoding: r2, rawImageData: s2, redFactor: n2, greenFactor: a2, blueFactor: l2, baseShift: c2 } = t2, h2 = s2.width + 2, u2 = s2.height + 2, d2 = e.a(s2) ? new e.R({ width: h2, height: u2 }, yield e.bx(s2, -1, -1, h2, u2)) : s2, p2 = new e.by(o2, d2, r2, n2, a2, l2, c2);
this.loaded = this.loaded || {}, this.loaded[o2] = p2, i3(null, p2);
}));
}
removeTile(e2) {
const t2 = this.loaded, i3 = e2.uid;
t2 && t2[i3] && delete t2[i3];
}
}
function l(e2, t2) {
if (0 !== e2.length) {
c(e2[0], t2);
for (var i3 = 1; i3 < e2.length; i3++) c(e2[i3], !t2);
}
}
function c(e2, t2) {
for (var i3 = 0, o2 = 0, r2 = 0, s2 = e2.length, n2 = s2 - 1; r2 < s2; n2 = r2++) {
var a2 = (e2[r2][0] - e2[n2][0]) * (e2[n2][1] + e2[r2][1]), l2 = i3 + a2;
o2 += Math.abs(i3) >= Math.abs(a2) ? i3 - l2 + a2 : a2 - l2 + i3, i3 = l2;
}
i3 + o2 >= 0 != !!t2 && e2.reverse();
}
var h = e.bz((function e2(t2, i3) {
var o2, r2 = t2 && t2.type;
if ("FeatureCollection" === r2) for (o2 = 0; o2 < t2.features.length; o2++) e2(t2.features[o2], i3);
else if ("GeometryCollection" === r2) for (o2 = 0; o2 < t2.geometries.length; o2++) e2(t2.geometries[o2], i3);
else if ("Feature" === r2) e2(t2.geometry, i3);
else if ("Polygon" === r2) l(t2.coordinates, i3);
else if ("MultiPolygon" === r2) for (o2 = 0; o2 < t2.coordinates.length; o2++) l(t2.coordinates[o2], i3);
return t2;
}));
const u = e.bw.VectorTileFeature.prototype.toGeoJSON;
var d = { exports: {} }, p = e.bA, f = e.bw.VectorTileFeature, g = m;
function m(e2, t2) {
this.options = t2 || {}, this.features = e2, this.length = e2.length;
}
function y(e2, t2) {
this.id = "number" == typeof e2.id ? e2.id : void 0, this.type = e2.type, this.rawGeometry = 1 === e2.type ? [e2.geometry] : e2.geometry, this.properties = e2.tags, this.extent = t2 || 4096;
}
m.prototype.feature = function(e2) {
return new y(this.features[e2], this.options.extent);
}, y.prototype.loadGeometry = function() {
var e2 = this.rawGeometry;
this.geometry = [];
for (var t2 = 0; t2 < e2.length; t2++) {
for (var i3 = e2[t2], o2 = [], r2 = 0; r2 < i3.length; r2++) o2.push(new p(i3[r2][0], i3[r2][1]));
this.geometry.push(o2);
}
return this.geometry;
}, y.prototype.bbox = function() {
this.geometry || this.loadGeometry();
for (var e2 = this.geometry, t2 = 1 / 0, i3 = -1 / 0, o2 = 1 / 0, r2 = -1 / 0, s2 = 0; s2 < e2.length; s2++) for (var n2 = e2[s2], a2 = 0; a2 < n2.length; a2++) {
var l2 = n2[a2];
t2 = Math.min(t2, l2.x), i3 = Math.max(i3, l2.x), o2 = Math.min(o2, l2.y), r2 = Math.max(r2, l2.y);
}
return [t2, o2, i3, r2];
}, y.prototype.toGeoJSON = f.prototype.toGeoJSON;
var v = e.bB, w = g;
function x(e2) {
var t2 = new v();
return (function(e3, t3) {
for (var i3 in e3.layers) t3.writeMessage(3, b, e3.layers[i3]);
})(e2, t2), t2.finish();
}
function b(e2, t2) {
var i3;
t2.writeVarintField(15, e2.version || 1), t2.writeStringField(1, e2.name || ""), t2.writeVarintField(5, e2.extent || 4096);
var o2 = { keys: [], values: [], keycache: {}, valuecache: {} };
for (i3 = 0; i3 < e2.length; i3++) o2.feature = e2.feature(i3), t2.writeMessage(2, S, o2);
var r2 = o2.keys;
for (i3 = 0; i3 < r2.length; i3++) t2.writeStringField(3, r2[i3]);
var s2 = o2.values;
for (i3 = 0; i3 < s2.length; i3++) t2.writeMessage(4, _, s2[i3]);
}
function S(e2, t2) {
var i3 = e2.feature;
void 0 !== i3.id && t2.writeVarintField(1, i3.id), t2.writeMessage(2, M, e2), t2.writeVarintField(3, i3.type), t2.writeMessage(4, T, i3);
}
function M(e2, t2) {
var i3 = e2.feature, o2 = e2.keys, r2 = e2.values, s2 = e2.keycache, n2 = e2.valuecache;
for (var a2 in i3.properties) {
var l2 = i3.properties[a2], c2 = s2[a2];
if (null !== l2) {
void 0 === c2 && (o2.push(a2), s2[a2] = c2 = o2.length - 1), t2.writeVarint(c2);
var h2 = typeof l2;
"string" !== h2 && "boolean" !== h2 && "number" !== h2 && (l2 = JSON.stringify(l2));
var u2 = h2 + ":" + l2, d2 = n2[u2];
void 0 === d2 && (r2.push(l2), n2[u2] = d2 = r2.length - 1), t2.writeVarint(d2);
}
}
}
function I(e2, t2) {
return (t2 << 3) + (7 & e2);
}
function P(e2) {
return e2 << 1 ^ e2 >> 31;
}
function T(e2, t2) {
for (var i3 = e2.loadGeometry(), o2 = e2.type, r2 = 0, s2 = 0, n2 = i3.length, a2 = 0; a2 < n2; a2++) {
var l2 = i3[a2], c2 = 1;
1 === o2 && (c2 = l2.length), t2.writeVarint(I(1, c2));
for (var h2 = 3 === o2 ? l2.length - 1 : l2.length, u2 = 0; u2 < h2; u2++) {
1 === u2 && 1 !== o2 && t2.writeVarint(I(2, h2 - 1));
var d2 = l2[u2].x - r2, p2 = l2[u2].y - s2;
t2.writeVarint(P(d2)), t2.writeVarint(P(p2)), r2 += d2, s2 += p2;
}
3 === o2 && t2.writeVarint(I(7, 1));
}
}
function _(e2, t2) {
var i3 = typeof e2;
"string" === i3 ? t2.writeStringField(1, e2) : "boolean" === i3 ? t2.writeBooleanField(7, e2) : "number" === i3 && (e2 % 1 != 0 ? t2.writeDoubleField(3, e2) : e2 < 0 ? t2.writeSVarintField(6, e2) : t2.writeVarintField(5, e2));
}
d.exports = x, d.exports.fromVectorTileJs = x, d.exports.fromGeojsonVt = function(e2, t2) {
t2 = t2 || {};
var i3 = {};
for (var o2 in e2) i3[o2] = new w(e2[o2].features, t2), i3[o2].name = o2, i3[o2].version = t2.version, i3[o2].extent = t2.extent;
return x({ layers: i3 });
}, d.exports.GeoJSONWrapper = w;
var k = e.bz(d.exports);
const D = { minZoom: 0, maxZoom: 16, minPoints: 2, radius: 40, extent: 512, nodeSize: 64, log: false, generateId: false, reduce: null, map: (e2) => e2 }, O = Math.fround || (C = new Float32Array(1), (e2) => (C[0] = +e2, C[0]));
var C;
const L = 3, F = 5, z = 6;
class N {
constructor(e2) {
this.options = Object.assign(Object.create(D), e2), this.trees = new Array(this.options.maxZoom + 1), this.stride = this.options.reduce ? 7 : 6, this.clusterProps = [];
}
load(e2) {
const { log: t2, minZoom: i3, maxZoom: o2 } = this.options;
t2 && console.time("total time");
const r2 = `prepare ${e2.length} points`;
t2 && console.time(r2), this.points = e2;
const s2 = [];
for (let t3 = 0; t3 < e2.length; t3++) {
const i4 = e2[t3];
if (!i4.geometry) continue;
const [o3, r3] = i4.geometry.coordinates, n3 = O(Z(o3)), a2 = O(G(r3));
s2.push(n3, a2, 1 / 0, t3, -1, 1), this.options.reduce && s2.push(0);
}
let n2 = this.trees[o2 + 1] = this._createTree(s2);
t2 && console.timeEnd(r2);
for (let e3 = o2; e3 >= i3; e3--) {
const i4 = +Date.now();
n2 = this.trees[e3] = this._createTree(this._cluster(n2, e3)), t2 && console.log("z%d: %d clusters in %dms", e3, n2.numItems, +Date.now() - i4);
}
return t2 && console.timeEnd("total time"), this;
}
getClusters(e2, t2) {
let i3 = ((e2[0] + 180) % 360 + 360) % 360 - 180;
const o2 = Math.max(-90, Math.min(90, e2[1]));
let r2 = 180 === e2[2] ? 180 : ((e2[2] + 180) % 360 + 360) % 360 - 180;
const s2 = Math.max(-90, Math.min(90, e2[3]));
if (e2[2] - e2[0] >= 360) i3 = -180, r2 = 180;
else if (i3 > r2) {
const e3 = this.getClusters([i3, o2, 180, s2], t2), n3 = this.getClusters([-180, o2, r2, s2], t2);
return e3.concat(n3);
}
const n2 = this.trees[this._limitZoom(t2)], a2 = n2.range(Z(i3), G(s2), Z(r2), G(o2)), l2 = n2.data, c2 = [];
for (const e3 of a2) {
const t3 = this.stride * e3;
c2.push(l2[t3 + F] > 1 ? E(l2, t3, this.clusterProps) : this.points[l2[t3 + L]]);
}
return c2;
}
getChildren(e2) {
const t2 = this._getOriginId(e2), i3 = this._getOriginZoom(e2), o2 = "No cluster with the specified id.", r2 = this.trees[i3];
if (!r2) throw new Error(o2);
const s2 = r2.data;
if (t2 * this.stride >= s2.length) throw new Error(o2);
const n2 = this.options.radius / (this.options.extent * Math.pow(2, i3 - 1)), a2 = r2.within(s2[t2 * this.stride], s2[t2 * this.stride + 1], n2), l2 = [];
for (const t3 of a2) {
const i4 = t3 * this.stride;
s2[i4 + 4] === e2 && l2.push(s2[i4 + F] > 1 ? E(s2, i4, this.clusterProps) : this.points[s2[i4 + L]]);
}
if (0 === l2.length) throw new Error(o2);
return l2;
}
getLeaves(e2, t2, i3) {
const o2 = [];
return this._appendLeaves(o2, e2, t2 = t2 || 10, i3 = i3 || 0, 0), o2;
}
getTile(e2, t2, i3) {
const o2 = this.trees[this._limitZoom(e2)], r2 = Math.pow(2, e2), { extent: s2, radius: n2 } = this.options, a2 = n2 / s2, l2 = (i3 - a2) / r2, c2 = (i3 + 1 + a2) / r2, h2 = { features: [] };
return this._addTileFeatures(o2.range((t2 - a2) / r2, l2, (t2 + 1 + a2) / r2, c2), o2.data, t2, i3, r2, h2), 0 === t2 && this._addTileFeatures(o2.range(1 - a2 / r2, l2, 1, c2), o2.data, r2, i3, r2, h2), t2 === r2 - 1 && this._addTileFeatures(o2.range(0, l2, a2 / r2, c2), o2.data, -1, i3, r2, h2), h2.features.length ? h2 : null;
}
getClusterExpansionZoom(e2) {
let t2 = this._getOriginZoom(e2) - 1;
for (; t2 <= this.options.maxZoom; ) {
const i3 = this.getChildren(e2);
if (t2++, 1 !== i3.length) break;
e2 = i3[0].properties.cluster_id;
}
return t2;
}
_appendLeaves(e2, t2, i3, o2, r2) {
const s2 = this.getChildren(t2);
for (const t3 of s2) {
const s3 = t3.properties;
if (s3 && s3.cluster ? r2 + s3.point_count <= o2 ? r2 += s3.point_count : r2 = this._appendLeaves(e2, s3.cluster_id, i3, o2, r2) : r2 < o2 ? r2++ : e2.push(t3), e2.length === i3) break;
}
return r2;
}
_createTree(t2) {
const i3 = new e.av(t2.length / this.stride | 0, this.options.nodeSize, Float32Array);
for (let e2 = 0; e2 < t2.length; e2 += this.stride) i3.add(t2[e2], t2[e2 + 1]);
return i3.finish(), i3.data = t2, i3;
}
_addTileFeatures(e2, t2, i3, o2, r2, s2) {
for (const n2 of e2) {
const e3 = n2 * this.stride, a2 = t2[e3 + F] > 1;
let l2, c2, h2;
if (a2) l2 = j(t2, e3, this.clusterProps), c2 = t2[e3], h2 = t2[e3 + 1];
else {
const i4 = this.points[t2[e3 + L]];
l2 = i4.properties;
const [o3, r3] = i4.geometry.coordinates;
c2 = Z(o3), h2 = G(r3);
}
const u2 = { type: 1, geometry: [[Math.round(this.options.extent * (c2 * r2 - i3)), Math.round(this.options.extent * (h2 * r2 - o2))]], tags: l2 };
let d2;
d2 = a2 || this.options.generateId ? t2[e3 + L] : this.points[t2[e3 + L]].id, void 0 !== d2 && (u2.id = d2), s2.features.push(u2);
}
}
_limitZoom(e2) {
return Math.max(this.options.minZoom, Math.min(Math.floor(+e2), this.options.maxZoom + 1));
}
_cluster(e2, t2) {
const { radius: i3, extent: o2, reduce: r2, minPoints: s2 } = this.options, n2 = i3 / (o2 * Math.pow(2, t2)), a2 = e2.data, l2 = [], c2 = this.stride;
for (let i4 = 0; i4 < a2.length; i4 += c2) {
if (a2[i4 + 2] <= t2) continue;
a2[i4 + 2] = t2;
const o3 = a2[i4], h2 = a2[i4 + 1], u2 = e2.within(a2[i4], a2[i4 + 1], n2), d2 = a2[i4 + F];
let p2 = d2;
for (const e3 of u2) {
const i5 = e3 * c2;
a2[i5 + 2] > t2 && (p2 += a2[i5 + F]);
}
if (p2 > d2 && p2 >= s2) {
let e3, s3 = o3 * d2, n3 = h2 * d2, f2 = -1;
const g2 = ((i4 / c2 | 0) << 5) + (t2 + 1) + this.points.length;
for (const o4 of u2) {
const l3 = o4 * c2;
if (a2[l3 + 2] <= t2) continue;
a2[l3 + 2] = t2;
const h3 = a2[l3 + F];
s3 += a2[l3] * h3, n3 += a2[l3 + 1] * h3, a2[l3 + 4] = g2, r2 && (e3 || (e3 = this._map(a2, i4, true), f2 = this.clusterProps.length, this.clusterProps.push(e3)), r2(e3, this._map(a2, l3)));
}
a2[i4 + 4] = g2, l2.push(s3 / p2, n3 / p2, 1 / 0, g2, -1, p2), r2 && l2.push(f2);
} else {
for (let e3 = 0; e3 < c2; e3++) l2.push(a2[i4 + e3]);
if (p2 > 1) for (const e3 of u2) {
const i5 = e3 * c2;
if (!(a2[i5 + 2] <= t2)) {
a2[i5 + 2] = t2;
for (let e4 = 0; e4 < c2; e4++) l2.push(a2[i5 + e4]);
}
}
}
}
return l2;
}
_getOriginId(e2) {
return e2 - this.points.length >> 5;
}
_getOriginZoom(e2) {
return (e2 - this.points.length) % 32;
}
_map(e2, t2, i3) {
if (e2[t2 + F] > 1) {
const o3 = this.clusterProps[e2[t2 + z]];
return i3 ? Object.assign({}, o3) : o3;
}
const o2 = this.points[e2[t2 + L]].properties, r2 = this.options.map(o2);
return i3 && r2 === o2 ? Object.assign({}, r2) : r2;
}
}
function E(e2, t2, i3) {
return { type: "Feature", id: e2[t2 + L], properties: j(e2, t2, i3), geometry: { type: "Point", coordinates: [(o2 = e2[t2], 360 * (o2 - 0.5)), J(e2[t2 + 1])] } };
var o2;
}
function j(e2, t2, i3) {
const o2 = e2[t2 + F], r2 = o2 >= 1e4 ? `${Math.round(o2 / 1e3)}k` : o2 >= 1e3 ? Math.round(o2 / 100) / 10 + "k" : o2, s2 = e2[t2 + z], n2 = -1 === s2 ? {} : Object.assign({}, i3[s2]);
return Object.assign(n2, { cluster: true, cluster_id: e2[t2 + L], point_count: o2, point_count_abbreviated: r2 });
}
function Z(e2) {
return e2 / 360 + 0.5;
}
function G(e2) {
const t2 = Math.sin(e2 * Math.PI / 180), i3 = 0.5 - 0.25 * Math.log((1 + t2) / (1 - t2)) / Math.PI;
return i3 < 0 ? 0 : i3 > 1 ? 1 : i3;
}
function J(e2) {
const t2 = (180 - 360 * e2) * Math.PI / 180;
return 360 * Math.atan(Math.exp(t2)) / Math.PI - 90;
}
function Y(e2, t2, i3, o2) {
for (var r2, s2 = o2, n2 = i3 - t2 >> 1, a2 = i3 - t2, l2 = e2[t2], c2 = e2[t2 + 1], h2 = e2[i3], u2 = e2[i3 + 1], d2 = t2 + 3; d2 < i3; d2 += 3) {
var p2 = A(e2[d2], e2[d2 + 1], l2, c2, h2, u2);
if (p2 > s2) r2 = d2, s2 = p2;
else if (p2 === s2) {
var f2 = Math.abs(d2 - n2);
f2 < a2 && (r2 = d2, a2 = f2);
}
}
s2 > o2 && (r2 - t2 > 3 && Y(e2, t2, r2, o2), e2[r2 + 2] = s2, i3 - r2 > 3 && Y(e2, r2, i3, o2));
}
function A(e2, t2, i3, o2, r2, s2) {
var n2 = r2 - i3, a2 = s2 - o2;
if (0 !== n2 || 0 !== a2) {
var l2 = ((e2 - i3) * n2 + (t2 - o2) * a2) / (n2 * n2 + a2 * a2);
l2 > 1 ? (i3 = r2, o2 = s2) : l2 > 0 && (i3 += n2 * l2, o2 += a2 * l2);
}
return (n2 = e2 - i3) * n2 + (a2 = t2 - o2) * a2;
}
function V(e2, t2, i3, o2) {
var r2 = { id: void 0 === e2 ? null : e2, type: t2, geometry: i3, tags: o2, minX: 1 / 0, minY: 1 / 0, maxX: -1 / 0, maxY: -1 / 0 };
return (function(e3) {
var t3 = e3.geometry, i4 = e3.type;
if ("Point" === i4 || "MultiPoint" === i4 || "LineString" === i4) B(e3, t3);
else if ("Polygon" === i4 || "MultiLineString" === i4) for (var o3 = 0; o3 < t3.length; o3++) B(e3, t3[o3]);
else if ("MultiPolygon" === i4) for (o3 = 0; o3 < t3.length; o3++) for (var r3 = 0; r3 < t3[o3].length; r3++) B(e3, t3[o3][r3]);
})(r2), r2;
}
function B(e2, t2) {
for (var i3 = 0; i3 < t2.length; i3 += 3) e2.minX = Math.min(e2.minX, t2[i3]), e2.minY = Math.min(e2.minY, t2[i3 + 1]), e2.maxX = Math.max(e2.maxX, t2[i3]), e2.maxY = Math.max(e2.maxY, t2[i3 + 1]);
}
function X(e2, t2, i3, o2) {
if (t2.geometry) {
var r2 = t2.geometry.coordinates, s2 = t2.geometry.type, n2 = Math.pow(i3.tolerance / ((1 << i3.maxZoom) * i3.extent), 2), a2 = [], l2 = t2.id;
if (i3.promoteId ? l2 = t2.properties[i3.promoteId] : i3.generateId && (l2 = o2 || 0), "Point" === s2) q(r2, a2);
else if ("MultiPoint" === s2) for (var c2 = 0; c2 < r2.length; c2++) q(r2[c2], a2);
else if ("LineString" === s2) R(r2, a2, n2, false);
else if ("MultiLineString" === s2) {
if (i3.lineMetrics) {
for (c2 = 0; c2 < r2.length; c2++) R(r2[c2], a2 = [], n2, false), e2.push(V(l2, "LineString", a2, t2.properties));
return;
}
W(r2, a2, n2, false);
} else if ("Polygon" === s2) W(r2, a2, n2, true);
else {
if ("MultiPolygon" !== s2) {
if ("GeometryCollection" === s2) {
for (c2 = 0; c2 < t2.geometry.geometries.length; c2++) X(e2, { id: l2, geometry: t2.geometry.geometries[c2], properties: t2.properties }, i3, o2);
return;
}
throw new Error("Input data is not a valid GeoJSON object.");
}
for (c2 = 0; c2 < r2.length; c2++) {
var h2 = [];
W(r2[c2], h2, n2, true), a2.push(h2);
}
}
e2.push(V(l2, s2, a2, t2.properties));
}
}
function q(e2, t2) {
t2.push($(e2[0])), t2.push(U(e2[1])), t2.push(0);
}
function R(e2, t2, i3, o2) {
for (var r2, s2, n2 = 0, a2 = 0; a2 < e2.length; a2++) {
var l2 = $(e2[a2][0]), c2 = U(e2[a2][1]);
t2.push(l2), t2.push(c2), t2.push(0), a2 > 0 && (n2 += o2 ? (r2 * c2 - l2 * s2) / 2 : Math.sqrt(Math.pow(l2 - r2, 2) + Math.pow(c2 - s2, 2))), r2 = l2, s2 = c2;
}
var h2 = t2.length - 3;
t2[2] = 1, Y(t2, 0, h2, i3), t2[h2 + 2] = 1, t2.size = Math.abs(n2), t2.start = 0, t2.end = t2.size;
}
function W(e2, t2, i3, o2) {
for (var r2 = 0; r2 < e2.length; r2++) {
var s2 = [];
R(e2[r2], s2, i3, o2), t2.push(s2);
}
}
function $(e2) {
return e2 / 360 + 0.5;
}
function U(e2) {
var t2 = Math.sin(e2 * Math.PI / 180), i3 = 0.5 - 0.25 * Math.log((1 + t2) / (1 - t2)) / Math.PI;
return i3 < 0 ? 0 : i3 > 1 ? 1 : i3;
}
function H(e2, t2, i3, o2, r2, s2, n2, a2) {
if (o2 /= t2, s2 >= (i3 /= t2) && n2 < o2) return e2;
if (n2 < i3 || s2 >= o2) return null;
for (var l2 = [], c2 = 0; c2 < e2.length; c2++) {
var h2 = e2[c2], u2 = h2.geometry, d2 = h2.type, p2 = 0 === r2 ? h2.minX : h2.minY, f2 = 0 === r2 ? h2.maxX : h2.maxY;
if (p2 >= i3 && f2 < o2) l2.push(h2);
else if (!(f2 < i3 || p2 >= o2)) {
var g2 = [];
if ("Point" === d2 || "MultiPoint" === d2) K(u2, g2, i3, o2, r2);
else if ("LineString" === d2) Q(u2, g2, i3, o2, r2, false, a2.lineMetrics);
else if ("MultiLineString" === d2) te(u2, g2, i3, o2, r2, false);
else if ("Polygon" === d2) te(u2, g2, i3, o2, r2, true);
else if ("MultiPolygon" === d2) for (var m2 = 0; m2 < u2.length; m2++) {
var y2 = [];
te(u2[m2], y2, i3, o2, r2, true), y2.length && g2.push(y2);
}
if (g2.length) {
if (a2.lineMetrics && "LineString" === d2) {
for (m2 = 0; m2 < g2.length; m2++) l2.push(V(h2.id, d2, g2[m2], h2.tags));
continue;
}
"LineString" !== d2 && "MultiLineString" !== d2 || (1 === g2.length ? (d2 = "LineString", g2 = g2[0]) : d2 = "MultiLineString"), "Point" !== d2 && "MultiPoint" !== d2 || (d2 = 3 === g2.length ? "Point" : "MultiPoint"), l2.push(V(h2.id, d2, g2, h2.tags));
}
}
}
return l2.length ? l2 : null;
}
function K(e2, t2, i3, o2, r2) {
for (var s2 = 0; s2 < e2.length; s2 += 3) {
var n2 = e2[s2 + r2];
n2 >= i3 && n2 <= o2 && (t2.push(e2[s2]), t2.push(e2[s2 + 1]), t2.push(e2[s2 + 2]));
}
}
function Q(e2, t2, i3, o2, r2, s2, n2) {
for (var a2, l2, c2 = ee(e2), h2 = 0 === r2 ? oe : re, u2 = e2.start, d2 = 0; d2 < e2.length - 3; d2 += 3) {
var p2 = e2[d2], f2 = e2[d2 + 1], g2 = e2[d2 + 2], m2 = e2[d2 + 3], y2 = e2[d2 + 4], v2 = 0 === r2 ? p2 : f2, w2 = 0 === r2 ? m2 : y2, x2 = false;
n2 && (a2 = Math.sqrt(Math.pow(p2 - m2, 2) + Math.pow(f2 - y2, 2))), v2 < i3 ? w2 > i3 && (l2 = h2(c2, p2, f2, m2, y2, i3), n2 && (c2.start = u2 + a2 * l2)) : v2 > o2 ? w2 < o2 && (l2 = h2(c2, p2, f2, m2, y2, o2), n2 && (c2.start = u2 + a2 * l2)) : ie(c2, p2, f2, g2), w2 < i3 && v2 >= i3 && (l2 = h2(c2, p2, f2, m2, y2, i3), x2 = true), w2 > o2 && v2 <= o2 && (l2 = h2(c2, p2, f2, m2, y2, o2), x2 = true), !s2 && x2 && (n2 && (c2.end = u2 + a2 * l2), t2.push(c2), c2 = ee(e2)), n2 && (u2 += a2);
}
var b2 = e2.length - 3;
p2 = e2[b2], f2 = e2[b2 + 1], g2 = e2[b2 + 2], (v2 = 0 === r2 ? p2 : f2) >= i3 && v2 <= o2 && ie(c2, p2, f2, g2), b2 = c2.length - 3, s2 && b2 >= 3 && (c2[b2] !== c2[0] || c2[b2 + 1] !== c2[1]) && ie(c2, c2[0], c2[1], c2[2]), c2.length && t2.push(c2);
}
function ee(e2) {
var t2 = [];
return t2.size = e2.size, t2.start = e2.start, t2.end = e2.end, t2;
}
function te(e2, t2, i3, o2, r2, s2) {
for (var n2 = 0; n2 < e2.length; n2++) Q(e2[n2], t2, i3, o2, r2, s2, false);
}
function ie(e2, t2, i3, o2) {
e2.push(t2), e2.push(i3), e2.push(o2);
}
function oe(e2, t2, i3, o2, r2, s2) {
var n2 = (s2 - t2) / (o2 - t2);
return e2.push(s2), e2.push(i3 + (r2 - i3) * n2), e2.push(1), n2;
}
function re(e2, t2, i3, o2, r2, s2) {
var n2 = (s2 - i3) / (r2 - i3);
return e2.push(t2 + (o2 - t2) * n2), e2.push(s2), e2.push(1), n2;
}
function se(e2, t2) {
for (var i3 = [], o2 = 0; o2 < e2.length; o2++) {
var r2, s2 = e2[o2], n2 = s2.type;
if ("Point" === n2 || "MultiPoint" === n2 || "LineString" === n2) r2 = ne(s2.geometry, t2);
else if ("MultiLineString" === n2 || "Polygon" === n2) {
r2 = [];
for (var a2 = 0; a2 < s2.geometry.length; a2++) r2.push(ne(s2.geometry[a2], t2));
} else if ("MultiPolygon" === n2) for (r2 = [], a2 = 0; a2 < s2.geometry.length; a2++) {
for (var l2 = [], c2 = 0; c2 < s2.geometry[a2].length; c2++) l2.push(ne(s2.geometry[a2][c2], t2));
r2.push(l2);
}
i3.push(V(s2.id, n2, r2, s2.tags));
}
return i3;
}
function ne(e2, t2) {
var i3 = [];
i3.size = e2.size, void 0 !== e2.start && (i3.start = e2.start, i3.end = e2.end);
for (var o2 = 0; o2 < e2.length; o2 += 3) i3.push(e2[o2] + t2, e2[o2 + 1], e2[o2 + 2]);
return i3;
}
function ae(e2, t2) {
if (e2.transformed) return e2;
var i3, o2, r2, s2 = 1 << e2.z, n2 = e2.x, a2 = e2.y;
for (i3 = 0; i3 < e2.features.length; i3++) {
var l2 = e2.features[i3], c2 = l2.geometry, h2 = l2.type;
if (l2.geometry = [], 1 === h2) for (o2 = 0; o2 < c2.length; o2 += 2) l2.geometry.push(le(c2[o2], c2[o2 + 1], t2, s2, n2, a2));
else for (o2 = 0; o2 < c2.length; o2++) {
var u2 = [];
for (r2 = 0; r2 < c2[o2].length; r2 += 2) u2.push(le(c2[o2][r2], c2[o2][r2 + 1], t2, s2, n2, a2));
l2.geometry.push(u2);
}
}
return e2.transformed = true, e2;
}
function le(e2, t2, i3, o2, r2, s2) {
return [Math.round(i3 * (e2 * o2 - r2)), Math.round(i3 * (t2 * o2 - s2))];
}
function ce(e2, t2, i3, o2, r2) {
for (var s2 = t2 === r2.maxZoom ? 0 : r2.tolerance / ((1 << t2) * r2.extent), n2 = { features: [], numPoints: 0, numSimplified: 0, numFeatures: 0, source: null, x: i3, y: o2, z: t2, transformed: false, minX: 2, minY: 1, maxX: -1, maxY: 0 }, a2 = 0; a2 < e2.length; a2++) {
n2.numFeatures++, he(n2, e2[a2], s2, r2);
var l2 = e2[a2].minX, c2 = e2[a2].minY, h2 = e2[a2].maxX, u2 = e2[a2].maxY;
l2 < n2.minX && (n2.minX = l2), c2 < n2.minY && (n2.minY = c2), h2 > n2.maxX && (n2.maxX = h2), u2 > n2.maxY && (n2.maxY = u2);
}
return n2;
}
function he(e2, t2, i3, o2) {
var r2 = t2.geometry, s2 = t2.type, n2 = [];
if ("Point" === s2 || "MultiPoint" === s2) for (var a2 = 0; a2 < r2.length; a2 += 3) n2.push(r2[a2]), n2.push(r2[a2 + 1]), e2.numPoints++, e2.numSimplified++;
else if ("LineString" === s2) ue(n2, r2, e2, i3, false, false);
else if ("MultiLineString" === s2 || "Polygon" === s2) for (a2 = 0; a2 < r2.length; a2++) ue(n2, r2[a2], e2, i3, "Polygon" === s2, 0 === a2);
else if ("MultiPolygon" === s2) for (var l2 = 0; l2 < r2.length; l2++) {
var c2 = r2[l2];
for (a2 = 0; a2 < c2.length; a2++) ue(n2, c2[a2], e2, i3, true, 0 === a2);
}
if (n2.length) {
var h2 = t2.tags || null;
if ("LineString" === s2 && o2.lineMetrics) {
for (var u2 in h2 = {}, t2.tags) h2[u2] = t2.tags[u2];
h2.mapbox_clip_start = r2.start / r2.size, h2.mapbox_clip_end = r2.end / r2.size;
}
var d2 = { geometry: n2, type: "Polygon" === s2 || "MultiPolygon" === s2 ? 3 : "LineString" === s2 || "MultiLineString" === s2 ? 2 : 1, tags: h2 };
null !== t2.id && (d2.id = t2.id), e2.features.push(d2);
}
}
function ue(e2, t2, i3, o2, r2, s2) {
var n2 = o2 * o2;
if (o2 > 0 && t2.size < (r2 ? n2 : o2)) i3.numPoints += t2.length / 3;
else {
for (var a2 = [], l2 = 0; l2 < t2.length; l2 += 3) (0 === o2 || t2[l2 + 2] > n2) && (i3.numSimplified++, a2.push(t2[l2]), a2.push(t2[l2 + 1])), i3.numPoints++;
r2 && (function(e3, t3) {
for (var i4 = 0, o3 = 0, r3 = e3.length, s3 = r3 - 2; o3 < r3; s3 = o3, o3 += 2) i4 += (e3[o3] - e3[s3]) * (e3[o3 + 1] + e3[s3 + 1]);
if (i4 > 0 === t3) for (o3 = 0, r3 = e3.length; o3 < r3 / 2; o3 += 2) {
var n3 = e3[o3], a3 = e3[o3 + 1];
e3[o3] = e3[r3 - 2 - o3], e3[o3 + 1] = e3[r3 - 1 - o3], e3[r3 - 2 - o3] = n3, e3[r3 - 1 - o3] = a3;
}
})(a2, s2), e2.push(a2);
}
}
function de(e2, t2) {
var i3 = (t2 = this.options = (function(e3, t3) {
for (var i4 in t3) e3[i4] = t3[i4];
return e3;
})(Object.create(this.options), t2)).debug;
if (i3 && console.time("preprocess data"), t2.maxZoom < 0 || t2.maxZoom > 24) throw new Error("maxZoom should be in the 0-24 range");
if (t2.promoteId && t2.generateId) throw new Error("promoteId and generateId cannot be used together.");
var o2 = (function(e3, t3) {
var i4 = [];
if ("FeatureCollection" === e3.type) for (var o3 = 0; o3 < e3.features.length; o3++) X(i4, e3.features[o3], t3, o3);
else X(i4, "Feature" === e3.type ? e3 : { geometry: e3 }, t3);
return i4;
})(e2, t2);
this.tiles = {}, this.tileCoords = [], i3 && (console.timeEnd("preprocess data"), console.log("index: maxZoom: %d, maxPoints: %d", t2.indexMaxZoom, t2.indexMaxPoints), console.time("generate tiles"), this.stats = {}, this.total = 0), o2 = (function(e3, t3) {
var i4 = t3.buffer / t3.extent, o3 = e3, r2 = H(e3, 1, -1 - i4, i4, 0, -1, 2, t3), s2 = H(e3, 1, 1 - i4, 2 + i4, 0, -1, 2, t3);
return (r2 || s2) && (o3 = H(e3, 1, -i4, 1 + i4, 0, -1, 2, t3) || [], r2 && (o3 = se(r2, 1).concat(o3)), s2 && (o3 = o3.concat(se(s2, -1)))), o3;
})(o2, t2), o2.length && this.splitTile(o2, 0, 0, 0), i3 && (o2.length && console.log("features: %d, points: %d", this.tiles[0].numFeatures, this.tiles[0].numPoints), console.timeEnd("generate tiles"), console.log("tiles generated:", this.total, JSON.stringify(this.stats)));
}
function pe(e2, t2, i3) {
return 32 * ((1 << e2) * i3 + t2) + e2;
}
function fe(e2, t2) {
return t2 ? e2.properties[t2] : e2.id;
}
function ge(e2, t2) {
if (null == e2) return true;
if ("Feature" === e2.type) return null != fe(e2, t2);
if ("FeatureCollection" === e2.type) {
const i3 = /* @__PURE__ */ new Set();
for (const o2 of e2.features) {
const e3 = fe(o2, t2);
if (null == e3) return false;
if (i3.has(e3)) return false;
i3.add(e3);
}
return true;
}
return false;
}
function me(e2, t2) {
const i3 = /* @__PURE__ */ new Map();
if (null == e2) ;
else if ("Feature" === e2.type) i3.set(fe(e2, t2), e2);
else for (const o2 of e2.features) i3.set(fe(o2, t2), o2);
return i3;
}
de.prototype.options = { maxZoom: 14, indexMaxZoom: 5, indexMaxPoints: 1e5, tolerance: 3, extent: 4096, buffer: 64, lineMetrics: false, promoteId: null, generateId: false, debug: 0 }, de.prototype.splitTile = function(e2, t2, i3, o2, r2, s2, n2) {
for (var a2 = [e2, t2, i3, o2], l2 = this.options, c2 = l2.debug; a2.length; ) {
o2 = a2.pop(), i3 = a2.pop(), t2 = a2.pop(), e2 = a2.pop();
var h2 = 1 << t2, u2 = pe(t2, i3, o2), d2 = this.tiles[u2];
if (!d2 && (c2 > 1 && console.time("creation"), d2 = this.tiles[u2] = ce(e2, t2, i3, o2, l2), this.tileCoords.push({ z: t2, x: i3, y: o2 }), c2)) {
c2 > 1 && (console.log("tile z%d-%d-%d (features: %d, points: %d, simplified: %d)", t2, i3, o2, d2.numFeatures, d2.numPoints, d2.numSimplified), console.timeEnd("creation"));
var p2 = "z" + t2;
this.stats[p2] = (this.stats[p2] || 0) + 1, this.total++;
}
if (d2.source = e2, r2) {
if (t2 === l2.maxZoom || t2 === r2) continue;
var f2 = 1 << r2 - t2;
if (i3 !== Math.floor(s2 / f2) || o2 !== Math.floor(n2 / f2)) continue;
} else if (t2 === l2.indexMaxZoom || d2.numPoints <= l2.indexMaxPoints) continue;
if (d2.source = null, 0 !== e2.length) {
c2 > 1 && console.time("clipping");
var g2, m2, y2, v2, w2, x2, b2 = 0.5 * l2.buffer / l2.extent, S2 = 0.5 - b2, M2 = 0.5 + b2, I2 = 1 + b2;
g2 = m2 = y2 = v2 = null, w2 = H(e2, h2, i3 - b2, i3 + M2, 0, d2.minX, d2.maxX, l2), x2 = H(e2, h2, i3 + S2, i3 + I2, 0, d2.minX, d2.maxX, l2), e2 = null, w2 && (g2 = H(w2, h2, o2 - b2, o2 + M2, 1, d2.minY, d2.maxY, l2), m2 = H(w2, h2, o2 + S2, o2 + I2, 1, d2.minY, d2.maxY, l2), w2 = null), x2 && (y2 = H(x2, h2, o2 - b2, o2 + M2, 1, d2.minY, d2.maxY, l2), v2 = H(x2, h2, o2 + S2, o2 + I2, 1, d2.minY, d2.maxY, l2), x2 = null), c2 > 1 && console.timeEnd("clipping"), a2.push(g2 || [], t2 + 1, 2 * i3, 2 * o2), a2.push(m2 || [], t2 + 1, 2 * i3, 2 * o2 + 1), a2.push(y2 || [], t2 + 1, 2 * i3 + 1, 2 * o2), a2.push(v2 || [], t2 + 1, 2 * i3 + 1, 2 * o2 + 1);
}
}
}, de.prototype.getTile = function(e2, t2, i3) {
var o2 = this.options, r2 = o2.extent, s2 = o2.debug;
if (e2 < 0 || e2 > 24) return null;
var n2 = 1 << e2, a2 = pe(e2, t2 = (t2 % n2 + n2) % n2, i3);
if (this.tiles[a2]) return ae(this.tiles[a2], r2);
s2 > 1 && console.log("drilling down to z%d-%d-%d", e2, t2, i3);
for (var l2, c2 = e2, h2 = t2, u2 = i3; !l2 && c2 > 0; ) c2--, h2 = Math.floor(h2 / 2), u2 = Math.floor(u2 / 2), l2 = this.tiles[pe(c2, h2, u2)];
return l2 && l2.source ? (s2 > 1 && console.log("found parent tile z%d-%d-%d", c2, h2, u2), s2 > 1 && console.time("drilling down"), this.splitTile(l2.source, c2, h2, u2, e2, t2, i3), s2 > 1 && console.timeEnd("drilling down"), this.tiles[a2] ? ae(this.tiles[a2], r2) : null) : null;
};
class ye extends n {
constructor(t2, i3, o2, r2) {
super(t2, i3, o2), this._dataUpdateable = /* @__PURE__ */ new Map(), this.loadGeoJSON = (t3, i4) => {
const { promoteId: o3 } = t3;
if (t3.request) return e.f(t3.request, ((e2, t4, r3, s2) => {
this._dataUpdateable = ge(t4, o3) ? me(t4, o3) : void 0, i4(e2, t4, r3, s2);
}));
if ("string" == typeof t3.data) try {
const e2 = JSON.parse(t3.data);
this._dataUpdateable = ge(e2, o3) ? me(e2, o3) : void 0, i4(null, e2);
} catch (e2) {
i4(new Error(`Input data given to '${t3.source}' is not a valid GeoJSON object.`));
}
else t3.dataDiff ? this._dataUpdateable ? ((function(e2, t4, i5) {
var o4, r3, s2, n2;
if (t4.removeAll && e2.clear(), t4.remove) for (const i6 of t4.remove) e2.delete(i6);
if (t4.add) for (const o5 of t4.add) {
const t5 = fe(o5, i5);
null != t5 && e2.set(t5, o5);
}
if (t4.update) for (const i6 of t4.update) {
let t5 = e2.get(i6.id);
if (null == t5) continue;
const a2 = !i6.removeAllProperties && ((null === (o4 = i6.removeProperties) || void 0 === o4 ? void 0 : o4.length) > 0 || (null === (r3 = i6.addOrUpdateProperties) || void 0 === r3 ? void 0 : r3.length) > 0);
if ((i6.newGeometry || i6.removeAllProperties || a2) && (t5 = Object.assign({}, t5), e2.set(i6.id, t5), a2 && (t5.properties = Object.assign({}, t5.properties))), i6.newGeometry && (t5.geometry = i6.newGeometry), i6.removeAllProperties) t5.properties = {};
else if ((null === (s2 = i6.removeProperties) || void 0 === s2 ? void 0 : s2.length) > 0) for (const e3 of i6.removeProperties) Object.prototype.hasOwnProperty.call(t5.properties, e3) && delete t5.properties[e3];
if ((null === (n2 = i6.addOrUpdateProperties) || void 0 === n2 ? void 0 : n2.length) > 0) for (const { key: e3, value: o5 } of i6.addOrUpdateProperties) t5.properties[e3] = o5;
}
})(this._dataUpdateable, t3.dataDiff, o3), i4(null, { type: "FeatureCollection", features: Array.from(this._dataUpdateable.values()) })) : i4(new Error(`Cannot update existing geojson data in ${t3.source}`)) : i4(new Error(`Input data given to '${t3.source}' is not a valid GeoJSON object.`));
return { cancel: () => {
} };
}, this.loadVectorData = this.loadGeoJSONTile, r2 && (this.loadGeoJSON = r2);
}
loadGeoJSONTile(t2, i3) {
const o2 = t2.tileID.canonical;
if (!this._geoJSONIndex) return i3(null, null);
const r2 = this._geoJSONIndex.getTile(o2.z, o2.x, o2.y);
if (!r2) return i3(null, null);
const s2 = new class {
constructor(t3) {
this.layers = { _geojsonTileLayer: this }, this.name = "_geojsonTileLayer", this.extent = e.N, this.length = t3.length, this._features = t3;
}
feature(t3) {
return new class {
constructor(t4) {
this._feature = t4, this.extent = e.N, this.type = t4.type, this.properties = t4.tags, "id" in t4 && !isNaN(t4.id) && (this.id = parseInt(t4.id, 10));
}
loadGeometry() {
if (1 === this._feature.type) {
const t4 = [];
for (const i4 of this._feature.geometry) t4.push([new e.P(i4[0], i4[1])]);
return t4;
}
{
const t4 = [];
for (const i4 of this._feature.geometry) {
const o3 = [];
for (const t5 of i4) o3.push(new e.P(t5[0], t5[1]));
t4.push(o3);
}
return t4;
}
}
toGeoJSON(e2, t4, i4) {
return u.call(this, e2, t4, i4);
}
}(this._features[t3]);
}
}(r2.features);
let n2 = k(s2);
0 === n2.byteOffset && n2.byteLength === n2.buffer.byteLength || (n2 = new Uint8Array(n2)), i3(null, { vectorTile: s2, rawData: n2.buffer });
}
loadData(t2, i3) {
var o2;
null === (o2 = this._pendingRequest) || void 0 === o2 || o2.cancel(), this._pendingCallback && this._pendingCallback(null, { abandoned: true });
const r2 = !!(t2 && t2.request && t2.request.collectResourceTiming) && new e.bu(t2.request);
this._pendingCallback = i3, this._pendingRequest = this.loadGeoJSON(t2, ((o3, s2) => {
if (delete this._pendingCallback, delete this._pendingRequest, o3 || !s2) return i3(o3);
if ("object" != typeof s2) return i3(new Error(`Input data given to '${t2.source}' is not a valid GeoJSON object.`));
{
h(s2, true);
try {
if (t2.filter) {
const i4 = e.bC(t2.filter, { type: "boolean", "property-type": "data-driven", overridable: false, transition: false });
if ("error" === i4.result) throw new Error(i4.value.map(((e2) => `${e2.key}: ${e2.message}`)).join(", "));
const o4 = s2.features.filter(((e2) => i4.value.evaluate({ zoom: 0 }, e2)));
s2 = { type: "FeatureCollection", features: o4 };
}
this._geoJSONIndex = t2.cluster ? new N((function({ superclusterOptions: t3, clusterProperties: i4 }) {
if (!i4 || !t3) return t3;
const o4 = {}, r3 = {}, s3 = { accumulated: null, zoom: 0 }, n3 = { properties: null }, a2 = Object.keys(i4);
for (const t4 of a2) {
const [s4, n4] = i4[t4], a3 = e.bC(n4), l2 = e.bC("string" == typeof s4 ? [s4, ["accumulated"], ["get", t4]] : s4);
o4[t4] = a3.value, r3[t4] = l2.value;
}
return t3.map = (e2) => {
n3.properties = e2;
const t4 = {};
for (const e3 of a2) t4[e3] = o4[e3].evaluate(s3, n3);
return t4;
}, t3.reduce = (e2, t4) => {
n3.properties = t4;
for (const t5 of a2) s3.accumulated = e2[t5], e2[t5] = r3[t5].evaluate(s3, n3);
}, t3;
})(t2)).load(s2.features) : (function(e2, t3) {
return new de(e2, t3);
})(s2, t2.geojsonVtOptions);
} catch (o4) {
return i3(o4);
}
this.loaded = {};
const n2 = {};
if (r2) {
const e2 = r2.finish();
e2 && (n2.resourceTiming = {}, n2.resourceTiming[t2.source] = JSON.parse(JSON.stringify(e2)));
}
i3(null, n2);
}
}));
}
reloadTile(e2, t2) {
const i3 = this.loaded;
return i3 && i3[e2.uid] ? super.reloadTile(e2, t2) : this.loadTile(e2, t2);
}
removeSource(e2, t2) {
this._pendingCallback && this._pendingCallback(null, { abandoned: true }), t2();
}
getClusterExpansionZoom(e2, t2) {
try {
t2(null, this._geoJSONIndex.getClusterExpansionZoom(e2.clusterId));
} catch (e3) {
t2(e3);
}
}
getClusterChildren(e2, t2) {
try {
t2(null, this._geoJSONIndex.getChildren(e2.clusterId));
} catch (e3) {
t2(e3);
}
}
getClusterLeaves(e2, t2) {
try {
t2(null, this._geoJSONIndex.getLeaves(e2.clusterId, e2.limit, e2.offset));
} catch (e3) {
t2(e3);
}
}
}
class ve {
constructor(t2) {
this.self = t2, this.actor = new e.C(t2, this), this.layerIndexes = {}, this.availableImages = {}, this.workerSourceTypes = { vector: n, geojson: ye }, this.workerSources = {}, this.demWorkerSources = {}, this.self.registerWorkerSource = (e2, t3) => {
if (this.workerSourceTypes[e2]) throw new Error(`Worker source with name "${e2}" already registered.`);
this.workerSourceTypes[e2] = t3;
}, this.self.registerRTLTextPlugin = (t3) => {
if (e.bD.isParsed()) throw new Error("RTL text plugin already registered.");
e.bD.applyArabicShaping = t3.applyArabicShaping, e.bD.processBidirectionalText = t3.processBidirectionalText, e.bD.processStyledBidirectionalText = t3.processStyledBidirectionalText;
};
}
setReferrer(e2, t2) {
this.referrer = t2;
}
setImages(e2, t2, i3) {
this.availableImages[e2] = t2;
for (const i4 in this.workerSources[e2]) {
const o2 = this.workerSources[e2][i4];
for (const e3 in o2) o2[e3].availableImages = t2;
}
i3();
}
setLayers(e2, t2, i3) {
this.getLayerIndex(e2).replace(t2), i3();
}
updateLayers(e2, t2, i3) {
this.getLayerIndex(e2).update(t2.layers, t2.removedIds), i3();
}
loadTile(e2, t2, i3) {
this.getWorkerSource(e2, t2.type, t2.source).loadTile(t2, i3);
}
loadDEMTile(e2, t2, i3) {
this.getDEMWorkerSource(e2, t2.source).loadTile(t2, i3);
}
reloadTile(e2, t2, i3) {
this.getWorkerSource(e2, t2.type, t2.source).reloadTile(t2, i3);
}
abortTile(e2, t2, i3) {
this.getWorkerSource(e2, t2.type, t2.source).abortTile(t2, i3);
}
removeTile(e2, t2, i3) {
this.getWorkerSource(e2, t2.type, t2.source).removeTile(t2, i3);
}
removeDEMTile(e2, t2) {
this.getDEMWorkerSource(e2, t2.source).removeTile(t2);
}
removeSource(e2, t2, i3) {
if (!this.workerSources[e2] || !this.workerSources[e2][t2.type] || !this.workerSources[e2][t2.type][t2.source]) return;
const o2 = this.workerSources[e2][t2.type][t2.source];
delete this.workerSources[e2][t2.type][t2.source], void 0 !== o2.removeSource ? o2.removeSource(t2, i3) : i3();
}
loadWorkerSource(e2, t2, i3) {
try {
this.self.importScripts(t2.url), i3();
} catch (e3) {
i3(e3.toString());
}
}
syncRTLPluginState(t2, i3, o2) {
try {
e.bD.setState(i3);
const t3 = e.bD.getPluginURL();
if (e.bD.isLoaded() && !e.bD.isParsed() && null != t3) {
this.self.importScripts(t3);
const i4 = e.bD.isParsed();
o2(i4 ? void 0 : new Error(`RTL Text Plugin failed to import scripts from ${t3}`), i4);
}
} catch (e2) {
o2(e2.toString());
}
}
getAvailableImages(e2) {
let t2 = this.availableImages[e2];
return t2 || (t2 = []), t2;
}
getLayerIndex(e2) {
let i3 = this.layerIndexes[e2];
return i3 || (i3 = this.layerIndexes[e2] = new t()), i3;
}
getWorkerSource(e2, t2, i3) {
return this.workerSources[e2] || (this.workerSources[e2] = {}), this.workerSources[e2][t2] || (this.workerSources[e2][t2] = {}), this.workerSources[e2][t2][i3] || (this.workerSources[e2][t2][i3] = new this.workerSourceTypes[t2]({ send: (t3, i4, o2) => {
this.actor.send(t3, i4, o2, e2);
} }, this.getLayerIndex(e2), this.getAvailableImages(e2))), this.workerSources[e2][t2][i3];
}
getDEMWorkerSource(e2, t2) {
return this.demWorkerSources[e2] || (this.demWorkerSources[e2] = {}), this.demWorkerSources[e2][t2] || (this.demWorkerSources[e2][t2] = new a()), this.demWorkerSources[e2][t2];
}
}
return e.i() && (self.worker = new ve(self)), ve;
}));
define(["./shared"], (function(t) {
var e = "3.6.2";
class i2 {
static testProp(t2) {
if (!i2.docStyle) return t2[0];
for (let e2 = 0; e2 < t2.length; e2++) if (t2[e2] in i2.docStyle) return t2[e2];
return t2[0];
}
static create(t2, e2, i3) {
const s2 = window.document.createElement(t2);
return void 0 !== e2 && (s2.className = e2), i3 && i3.appendChild(s2), s2;
}
static createNS(t2, e2) {
return window.document.createElementNS(t2, e2);
}
static disableDrag() {
i2.docStyle && i2.selectProp && (i2.userSelect = i2.docStyle[i2.selectProp], i2.docStyle[i2.selectProp] = "none");
}
static enableDrag() {
i2.docStyle && i2.selectProp && (i2.docStyle[i2.selectProp] = i2.userSelect);
}
static setTransform(t2, e2) {
t2.style[i2.transformProp] = e2;
}
static addEventListener(t2, e2, i3, s2 = {}) {
t2.addEventListener(e2, i3, "passive" in s2 ? s2 : s2.capture);
}
static removeEventListener(t2, e2, i3, s2 = {}) {
t2.removeEventListener(e2, i3, "passive" in s2 ? s2 : s2.capture);
}
static suppressClickInternal(t2) {
t2.preventDefault(), t2.stopPropagation(), window.removeEventListener("click", i2.suppressClickInternal, true);
}
static suppressClick() {
window.addEventListener("click", i2.suppressClickInternal, true), window.setTimeout((() => {
window.removeEventListener("click", i2.suppressClickInternal, true);
}), 0);
}
static mousePos(e2, i3) {
const s2 = e2.getBoundingClientRect();
return new t.P(i3.clientX - s2.left - e2.clientLeft, i3.clientY - s2.top - e2.clientTop);
}
static touchPos(e2, i3) {
const s2 = e2.getBoundingClientRect(), a2 = [];
for (let o2 = 0; o2 < i3.length; o2++) a2.push(new t.P(i3[o2].clientX - s2.left - e2.clientLeft, i3[o2].clientY - s2.top - e2.clientTop));
return a2;
}
static mouseButton(t2) {
return t2.button;
}
static remove(t2) {
t2.parentNode && t2.parentNode.removeChild(t2);
}
}
i2.docStyle = "undefined" != typeof window && window.document && window.document.documentElement.style, i2.selectProp = i2.testProp(["userSelect", "MozUserSelect", "WebkitUserSelect", "msUserSelect"]), i2.transformProp = i2.testProp(["transform", "WebkitTransform"]);
const s = { supported: false, testSupport: function(t2) {
!r && o && (n ? l(t2) : a = t2);
} };
let a, o, r = false, n = false;
function l(t2) {
const e2 = t2.createTexture();
t2.bindTexture(t2.TEXTURE_2D, e2);
try {
if (t2.texImage2D(t2.TEXTURE_2D, 0, t2.RGBA, t2.RGBA, t2.UNSIGNED_BYTE, o), t2.isContextLost()) return;
s.supported = true;
} catch (t3) {
}
t2.deleteTexture(e2), r = true;
}
var h, c;
"undefined" != typeof document && (o = document.createElement("img"), o.onload = function() {
a && l(a), a = null, n = true;
}, o.onerror = function() {
r = true, a = null;
}, o.src = ""), (function(e2) {
let i3, a2, o2, r2;
e2.resetRequestQueue = () => {
i3 = [], a2 = 0, o2 = 0, r2 = {};
}, e2.addThrottleControl = (t2) => {
const e3 = o2++;
return r2[e3] = t2, e3;
}, e2.removeThrottleControl = (t2) => {
delete r2[t2], h2();
}, e2.getImage = (t2, e3, o3 = true) => {
s.supported && (t2.headers || (t2.headers = {}), t2.headers.accept = "image/webp,*/*");
const r3 = { requestParameters: t2, supportImageRefresh: o3, callback: e3, cancelled: false, completed: false, cancel: () => {
r3.completed || r3.cancelled || (r3.cancelled = true, r3.innerRequest && (r3.innerRequest.cancel(), a2--), h2());
} };
return i3.push(r3), h2(), r3;
};
const n2 = (e3) => {
const { requestParameters: i4, supportImageRefresh: s2, callback: a3 } = e3;
return t.e(i4, { type: "image" }), (false !== s2 || t.i() || t.g(i4.url) || i4.headers && !Object.keys(i4.headers).reduce(((t2, e4) => t2 && "accept" === e4), true) ? t.m : c2)(i4, ((t2, i5, s3, o3) => {
l2(e3, a3, t2, i5, s3, o3);
}));
}, l2 = (e3, i4, s2, o3, r3, n3) => {
s2 ? i4(s2) : o3 instanceof HTMLImageElement || t.a(o3) ? i4(null, o3) : o3 && ((e4, i5) => {
"function" == typeof createImageBitmap ? t.b(e4, i5) : t.d(e4, i5);
})(o3, ((t2, e4) => {
null != t2 ? i4(t2) : null != e4 && i4(null, e4, { cacheControl: r3, expires: n3 });
})), e3.cancelled || (e3.completed = true, a2--, h2());
}, h2 = () => {
const e3 = (() => {
const t2 = Object.keys(r2);
let e4 = false;
if (t2.length > 0) {
for (const i4 of t2) if (e4 = r2[i4](), e4) break;
}
return e4;
})() ? t.c.MAX_PARALLEL_IMAGE_REQUESTS_PER_FRAME : t.c.MAX_PARALLEL_IMAGE_REQUESTS;
for (let t2 = a2; t2 < e3 && i3.length > 0; t2++) {
const e4 = i3.shift();
if (e4.cancelled) {
t2--;
continue;
}
const s2 = n2(e4);
a2++, e4.innerRequest = s2;
}
}, c2 = (e3, i4) => {
const s2 = new Image(), a3 = e3.url;
let o3 = false;
const r3 = e3.credentials;
return r3 && "include" === r3 ? s2.crossOrigin = "use-credentials" : (r3 && "same-origin" === r3 || !t.s(a3)) && (s2.crossOrigin = "anonymous"), s2.fetchPriority = "high", s2.onload = () => {
i4(null, s2), s2.onerror = s2.onload = null;
}, s2.onerror = () => {
o3 || i4(new Error("Could not load image. Please make sure to use a supported image type such as PNG or JPEG. Note that SVGs are not supported.")), s2.onerror = s2.onload = null;
}, s2.src = a3, { cancel: () => {
o3 = true, s2.src = "";
} };
};
})(h || (h = {})), h.resetRequestQueue(), (function(t2) {
t2.Glyphs = "Glyphs", t2.Image = "Image", t2.Source = "Source", t2.SpriteImage = "SpriteImage", t2.SpriteJSON = "SpriteJSON", t2.Style = "Style", t2.Tile = "Tile", t2.Unknown = "Unknown";
})(c || (c = {}));
class u {
constructor(t2) {
this._transformRequestFn = t2;
}
transformRequest(t2, e2) {
return this._transformRequestFn && this._transformRequestFn(t2, e2) || { url: t2 };
}
normalizeSpriteURL(t2, e2, i3) {
const s2 = (function(t3) {
const e3 = t3.match(d);
if (!e3) throw new Error(`Unable to parse URL "${t3}"`);
return { protocol: e3[1], authority: e3[2], path: e3[3] || "/", params: e3[4] ? e3[4].split("&") : [] };
})(t2);
return s2.path += `${e2}${i3}`, (function(t3) {
const e3 = t3.params.length ? `?${t3.params.join("&")}` : "";
return `${t3.protocol}://${t3.authority}${t3.path}${e3}`;
})(s2);
}
setTransformRequest(t2) {
this._transformRequestFn = t2;
}
}
const d = /^(\w+):\/\/([^/?]*)(\/[^?]+)?\??(.+)?/;
function _(e2) {
var i3 = new t.A(3);
return i3[0] = e2[0], i3[1] = e2[1], i3[2] = e2[2], i3;
}
var p, m = function(t2, e2, i3) {
return t2[0] = e2[0] - i3[0], t2[1] = e2[1] - i3[1], t2[2] = e2[2] - i3[2], t2;
};
p = new t.A(3), t.A != Float32Array && (p[0] = 0, p[1] = 0, p[2] = 0);
var f = function(t2) {
var e2 = t2[0], i3 = t2[1];
return e2 * e2 + i3 * i3;
};
function g(t2) {
const e2 = [];
if ("string" == typeof t2) e2.push({ id: "default", url: t2 });
else if (t2 && t2.length > 0) {
const i3 = [];
for (const { id: s2, url: a2 } of t2) {
const t3 = `${s2}${a2}`;
-1 === i3.indexOf(t3) && (i3.push(t3), e2.push({ id: s2, url: a2 }));
}
}
return e2;
}
function v(e2, i3, s2, a2, o2) {
if (a2) return void e2(a2);
if (o2 !== Object.values(i3).length || o2 !== Object.values(s2).length) return;
const r2 = {};
for (const e3 in i3) {
r2[e3] = {};
const a3 = t.h.getImageCanvasContext(s2[e3]), o3 = i3[e3];
for (const t2 in o3) {
const { width: i4, height: s3, x: n2, y: l2, sdf: h2, pixelRatio: c2, stretchX: u2, stretchY: d2, content: _2 } = o3[t2];
r2[e3][t2] = { data: null, pixelRatio: c2, sdf: h2, stretchX: u2, stretchY: d2, content: _2, spriteData: { width: i4, height: s3, x: n2, y: l2, context: a3 } };
}
}
e2(null, r2);
}
!(function() {
var e2 = new t.A(2);
t.A != Float32Array && (e2[0] = 0, e2[1] = 0);
})();
class x {
constructor(t2, e2, i3, s2) {
this.context = t2, this.format = i3, this.texture = t2.gl.createTexture(), this.update(e2, s2);
}
update(e2, i3, s2) {
const { width: a2, height: o2 } = e2, r2 = !(this.size && this.size[0] === a2 && this.size[1] === o2 || s2), { context: n2 } = this, { gl: l2 } = n2;
if (this.useMipmap = Boolean(i3 && i3.useMipmap), l2.bindTexture(l2.TEXTURE_2D, this.texture), n2.pixelStoreUnpackFlipY.set(false), n2.pixelStoreUnpack.set(1), n2.pixelStoreUnpackPremultiplyAlpha.set(this.format === l2.RGBA && (!i3 || false !== i3.premultiply)), r2) this.size = [a2, o2], e2 instanceof HTMLImageElement || e2 instanceof HTMLCanvasElement || e2 instanceof HTMLVideoElement || e2 instanceof ImageData || t.a(e2) ? l2.texImage2D(l2.TEXTURE_2D, 0, this.format, this.format, l2.UNSIGNED_BYTE, e2) : l2.texImage2D(l2.TEXTURE_2D, 0, this.format, a2, o2, 0, this.format, l2.UNSIGNED_BYTE, e2.data);
else {
const { x: i4, y: r3 } = s2 || { x: 0, y: 0 };
e2 instanceof HTMLImageElement || e2 instanceof HTMLCanvasElement || e2 instanceof HTMLVideoElement || e2 instanceof ImageData || t.a(e2) ? l2.texSubImage2D(l2.TEXTURE_2D, 0, i4, r3, l2.RGBA, l2.UNSIGNED_BYTE, e2) : l2.texSubImage2D(l2.TEXTURE_2D, 0, i4, r3, a2, o2, l2.RGBA, l2.UNSIGNED_BYTE, e2.data);
}
this.useMipmap && this.isSizePowerOfTwo() && l2.generateMipmap(l2.TEXTURE_2D);
}
bind(t2, e2, i3) {
const { context: s2 } = this, { gl: a2 } = s2;
a2.bindTexture(a2.TEXTURE_2D, this.texture), i3 !== a2.LINEAR_MIPMAP_NEAREST || this.isSizePowerOfTwo() || (i3 = a2.LINEAR), t2 !== this.filter && (a2.texParameteri(a2.TEXTURE_2D, a2.TEXTURE_MAG_FILTER, t2), a2.texParameteri(a2.TEXTURE_2D, a2.TEXTURE_MIN_FILTER, i3 || t2), this.filter = t2), e2 !== this.wrap && (a2.texParameteri(a2.TEXTURE_2D, a2.TEXTURE_WRAP_S, e2), a2.texParameteri(a2.TEXTURE_2D, a2.TEXTURE_WRAP_T, e2), this.wrap = e2);
}
isSizePowerOfTwo() {
return this.size[0] === this.size[1] && Math.log(this.size[0]) / Math.LN2 % 1 == 0;
}
destroy() {
const { gl: t2 } = this.context;
t2.deleteTexture(this.texture), this.texture = null;
}
}
function y(t2) {
const { userImage: e2 } = t2;
return !!(e2 && e2.render && e2.render()) && (t2.data.replace(new Uint8Array(e2.data.buffer)), true);
}
class b extends t.E {
constructor() {
super(), this.images = {}, this.updatedImages = {}, this.callbackDispatchedThisFrame = {}, this.loaded = false, this.requestors = [], this.patterns = {}, this.atlasImage = new t.R({ width: 1, height: 1 }), this.dirty = true;
}
isLoaded() {
return this.loaded;
}
setLoaded(t2) {
if (this.loaded !== t2 && (this.loaded = t2, t2)) {
for (const { ids: t3, callback: e2 } of this.requestors) this._notify(t3, e2);
this.requestors = [];
}
}
getImage(e2) {
const i3 = this.images[e2];
if (i3 && !i3.data && i3.spriteData) {
const e3 = i3.spriteData;
i3.data = new t.R({ width: e3.width, height: e3.height }, e3.context.getImageData(e3.x, e3.y, e3.width, e3.height).data), i3.spriteData = null;
}
return i3;
}
addImage(t2, e2) {
if (this.images[t2]) throw new Error(`Image id ${t2} already exist, use updateImage instead`);
this._validate(t2, e2) && (this.images[t2] = e2);
}
_validate(e2, i3) {
let s2 = true;
const a2 = i3.data || i3.spriteData;
return this._validateStretch(i3.stretchX, a2 && a2.width) || (this.fire(new t.j(new Error(`Image "${e2}" has invalid "stretchX" value`))), s2 = false), this._validateStretch(i3.stretchY, a2 && a2.height) || (this.fire(new t.j(new Error(`Image "${e2}" has invalid "stretchY" value`))), s2 = false), this._validateContent(i3.content, i3) || (this.fire(new t.j(new Error(`Image "${e2}" has invalid "content" value`))), s2 = false), s2;
}
_validateStretch(t2, e2) {
if (!t2) return true;
let i3 = 0;
for (const s2 of t2) {
if (s2[0] < i3 || s2[1] < s2[0] || e2 < s2[1]) return false;
i3 = s2[1];
}
return true;
}
_validateContent(t2, e2) {
if (!t2) return true;
if (4 !== t2.length) return false;
const i3 = e2.spriteData, s2 = i3 && i3.width || e2.data.width, a2 = i3 && i3.height || e2.data.height;
return !(t2[0] < 0 || s2 < t2[0] || t2[1] < 0 || a2 < t2[1] || t2[2] < 0 || s2 < t2[2] || t2[3] < 0 || a2 < t2[3] || t2[2] < t2[0] || t2[3] < t2[1]);
}
updateImage(t2, e2, i3 = true) {
const s2 = this.getImage(t2);
if (i3 && (s2.data.width !== e2.data.width || s2.data.height !== e2.data.height)) throw new Error(`size mismatch between old image (${s2.data.width}x${s2.data.height}) and new image (${e2.data.width}x${e2.data.height}).`);
e2.version = s2.version + 1, this.images[t2] = e2, this.updatedImages[t2] = true;
}
removeImage(t2) {
const e2 = this.images[t2];
delete this.images[t2], delete this.patterns[t2], e2.userImage && e2.userImage.onRemove && e2.userImage.onRemove();
}
listImages() {
return Object.keys(this.images);
}
getImages(t2, e2) {
let i3 = true;
if (!this.isLoaded()) for (const e3 of t2) this.images[e3] || (i3 = false);
this.isLoaded() || i3 ? this._notify(t2, e2) : this.requestors.push({ ids: t2, callback: e2 });
}
_notify(e2, i3) {
const s2 = {};
for (const i4 of e2) {
let e3 = this.getImage(i4);
e3 || (this.fire(new t.k("styleimagemissing", { id: i4 })), e3 = this.getImage(i4)), e3 ? s2[i4] = { data: e3.data.clone(), pixelRatio: e3.pixelRatio, sdf: e3.sdf, version: e3.version, stretchX: e3.stretchX, stretchY: e3.stretchY, content: e3.content, hasRenderCallback: Boolean(e3.userImage && e3.userImage.render) } : t.w(`Image "${i4}" could not be loaded. Please make sure you have added the image with map.addImage() or a "sprite" property in your style. You can provide missing images by listening for the "styleimagemissing" map event.`);
}
i3(null, s2);
}
getPixelSize() {
const { width: t2, height: e2 } = this.atlasImage;
return { width: t2, height: e2 };
}
getPattern(e2) {
const i3 = this.patterns[e2], s2 = this.getImage(e2);
if (!s2) return null;
if (i3 && i3.position.version === s2.version) return i3.position;
if (i3) i3.position.version = s2.version;
else {
const i4 = { w: s2.data.width + 2, h: s2.data.height + 2, x: 0, y: 0 }, a2 = new t.I(i4, s2);
this.patterns[e2] = { bin: i4, position: a2 };
}
return this._updatePatternAtlas(), this.patterns[e2].position;
}
bind(t2) {
const e2 = t2.gl;
this.atlasTexture ? this.dirty && (this.atlasTexture.update(this.atlasImage), this.dirty = false) : this.atlasTexture = new x(t2, this.atlasImage, e2.RGBA), this.atlasTexture.bind(e2.LINEAR, e2.CLAMP_TO_EDGE);
}
_updatePatternAtlas() {
const e2 = [];
for (const t2 in this.patterns) e2.push(this.patterns[t2].bin);
const { w: i3, h: s2 } = t.p(e2), a2 = this.atlasImage;
a2.resize({ width: i3 || 1, height: s2 || 1 });
for (const e3 in this.patterns) {
const { bin: i4 } = this.patterns[e3], s3 = i4.x + 1, o2 = i4.y + 1, r2 = this.getImage(e3).data, n2 = r2.width, l2 = r2.height;
t.R.copy(r2, a2, { x: 0, y: 0 }, { x: s3, y: o2 }, { width: n2, height: l2 }), t.R.copy(r2, a2, { x: 0, y: l2 - 1 }, { x: s3, y: o2 - 1 }, { width: n2, height: 1 }), t.R.copy(r2, a2, { x: 0, y: 0 }, { x: s3, y: o2 + l2 }, { width: n2, height: 1 }), t.R.copy(r2, a2, { x: n2 - 1, y: 0 }, { x: s3 - 1, y: o2 }, { width: 1, height: l2 }), t.R.copy(r2, a2, { x: 0, y: 0 }, { x: s3 + n2, y: o2 }, { width: 1, height: l2 });
}
this.dirty = true;
}
beginFrame() {
this.callbackDispatchedThisFrame = {};
}
dispatchRenderCallbacks(e2) {
for (const i3 of e2) {
if (this.callbackDispatchedThisFrame[i3]) continue;
this.callbackDispatchedThisFrame[i3] = true;
const e3 = this.getImage(i3);
e3 || t.w(`Image with ID: "${i3}" was not found`), y(e3) && this.updateImage(i3, e3);
}
}
}
const w = 1e20;
function T(t2, e2, i3, s2, a2, o2, r2, n2, l2) {
for (let h2 = e2; h2 < e2 + s2; h2++) I(t2, i3 * o2 + h2, o2, a2, r2, n2, l2);
for (let h2 = i3; h2 < i3 + a2; h2++) I(t2, h2 * o2 + e2, 1, s2, r2, n2, l2);
}
function I(t2, e2, i3, s2, a2, o2, r2) {
o2[0] = 0, r2[0] = -w, r2[1] = w, a2[0] = t2[e2];
for (let n2 = 1, l2 = 0, h2 = 0; n2 < s2; n2++) {
a2[n2] = t2[e2 + n2 * i3];
const s3 = n2 * n2;
do {
const t3 = o2[l2];
h2 = (a2[n2] - a2[t3] + s3 - t3 * t3) / (n2 - t3) / 2;
} while (h2 <= r2[l2] && --l2 > -1);
l2++, o2[l2] = n2, r2[l2] = h2, r2[l2 + 1] = w;
}
for (let n2 = 0, l2 = 0; n2 < s2; n2++) {
for (; r2[l2 + 1] < n2; ) l2++;
const s3 = o2[l2], h2 = n2 - s3;
t2[e2 + n2 * i3] = a2[s3] + h2 * h2;
}
}
class E {
constructor(t2, e2) {
this.requestManager = t2, this.localIdeographFontFamily = e2, this.entries = {};
}
setURL(t2) {
this.url = t2;
}
getGlyphs(e2, i3) {
const s2 = [];
for (const t2 in e2) for (const i4 of e2[t2]) s2.push({ stack: t2, id: i4 });
t.o(s2, (({ stack: t2, id: e3 }, i4) => {
let s3 = this.entries[t2];
s3 || (s3 = this.entries[t2] = { glyphs: {}, requests: {}, ranges: {} });
let a2 = s3.glyphs[e3];
if (void 0 !== a2) return void i4(null, { stack: t2, id: e3, glyph: a2 });
if (a2 = this._tinySDF(s3, t2, e3), a2) return s3.glyphs[e3] = a2, void i4(null, { stack: t2, id: e3, glyph: a2 });
const o2 = Math.floor(e3 / 256);
if (256 * o2 > 65535) return void i4(new Error("glyphs > 65535 not supported"));
if (s3.ranges[o2]) return void i4(null, { stack: t2, id: e3, glyph: a2 });
if (!this.url) return void i4(new Error("glyphsUrl is not set"));
let r2 = s3.requests[o2];
r2 || (r2 = s3.requests[o2] = [], E.loadGlyphRange(t2, o2, this.url, this.requestManager, ((t3, e4) => {
if (e4) {
for (const t4 in e4) this._doesCharSupportLocalGlyph(+t4) || (s3.glyphs[+t4] = e4[+t4]);
s3.ranges[o2] = true;
}
for (const i5 of r2) i5(t3, e4);
delete s3.requests[o2];
}))), r2.push(((s4, a3) => {
s4 ? i4(s4) : a3 && i4(null, { stack: t2, id: e3, glyph: a3[e3] || null });
}));
}), ((t2, e3) => {
if (t2) i3(t2);
else if (e3) {
const t3 = {};
for (const { stack: i4, id: s3, glyph: a2 } of e3) (t3[i4] || (t3[i4] = {}))[s3] = a2 && { id: a2.id, bitmap: a2.bitmap.clone(), metrics: a2.metrics };
i3(null, t3);
}
}));
}
_doesCharSupportLocalGlyph(e2) {
return !!this.localIdeographFontFamily && (t.u["CJK Unified Ideographs"](e2) || t.u["Hangul Syllables"](e2) || t.u.Hiragana(e2) || t.u.Katakana(e2));
}
_tinySDF(e2, i3, s2) {
const a2 = this.localIdeographFontFamily;
if (!a2) return;
if (!this._doesCharSupportLocalGlyph(s2)) return;
let o2 = e2.tinySDF;
if (!o2) {
let t2 = "400";
/bold/i.test(i3) ? t2 = "900" : /medium/i.test(i3) ? t2 = "500" : /light/i.test(i3) && (t2 = "200"), o2 = e2.tinySDF = new E.TinySDF({ fontSize: 48, buffer: 6, radius: 16, cutoff: 0.25, fontFamily: a2, fontWeight: t2 });
}
const r2 = o2.draw(String.fromCharCode(s2));
return { id: s2, bitmap: new t.q({ width: r2.width || 60, height: r2.height || 60 }, r2.data), metrics: { width: r2.glyphWidth / 2 || 24, height: r2.glyphHeight / 2 || 24, left: r2.glyphLeft / 2 + 0.5 || 0, top: r2.glyphTop / 2 - 27.5 || -8, advance: r2.glyphAdvance / 2 || 24, isDoubleResolution: true } };
}
}
E.loadGlyphRange = function(e2, i3, s2, a2, o2) {
const r2 = 256 * i3, n2 = r2 + 255, l2 = a2.transformRequest(s2.replace("{fontstack}", e2).replace("{range}", `${r2}-${n2}`), c.Glyphs);
t.l(l2, ((e3, i4) => {
if (e3) o2(e3);
else if (i4) {
const e4 = {};
for (const s3 of t.n(i4)) e4[s3.id] = s3;
o2(null, e4);
}
}));
}, E.TinySDF = class {
constructor({ fontSize: t2 = 24, buffer: e2 = 3, radius: i3 = 8, cutoff: s2 = 0.25, fontFamily: a2 = "sans-serif", fontWeight: o2 = "normal", fontStyle: r2 = "normal" } = {}) {
this.buffer = e2, this.cutoff = s2, this.radius = i3;
const n2 = this.size = t2 + 4 * e2, l2 = this._createCanvas(n2), h2 = this.ctx = l2.getContext("2d", { willReadFrequently: true });
h2.font = `${r2} ${o2} ${t2}px ${a2}`, h2.textBaseline = "alphabetic", h2.textAlign = "left", h2.fillStyle = "black", this.gridOuter = new Float64Array(n2 * n2), this.gridInner = new Float64Array(n2 * n2), this.f = new Float64Array(n2), this.z = new Float64Array(n2 + 1), this.v = new Uint16Array(n2);
}
_createCanvas(t2) {
const e2 = document.createElement("canvas");
return e2.width = e2.height = t2, e2;
}
draw(t2) {
const { width: e2, actualBoundingBoxAscent: i3, actualBoundingBoxDescent: s2, actualBoundingBoxLeft: a2, actualBoundingBoxRight: o2 } = this.ctx.measureText(t2), r2 = Math.ceil(i3), n2 = Math.max(0, Math.min(this.size - this.buffer, Math.ceil(o2 - a2))), l2 = Math.min(this.size - this.buffer, r2 + Math.ceil(s2)), h2 = n2 + 2 * this.buffer, c2 = l2 + 2 * this.buffer, u2 = Math.max(h2 * c2, 0), d2 = new Uint8ClampedArray(u2), _2 = { data: d2, width: h2, height: c2, glyphWidth: n2, glyphHeight: l2, glyphTop: r2, glyphLeft: 0, glyphAdvance: e2 };
if (0 === n2 || 0 === l2) return _2;
const { ctx: p2, buffer: m2, gridInner: f2, gridOuter: g2 } = this;
p2.clearRect(m2, m2, n2, l2), p2.fillText(t2, m2, m2 + r2);
const v2 = p2.getImageData(m2, m2, n2, l2);
g2.fill(w, 0, u2), f2.fill(0, 0, u2);
for (let t3 = 0; t3 < l2; t3++) for (let e3 = 0; e3 < n2; e3++) {
const i4 = v2.data[4 * (t3 * n2 + e3) + 3] / 255;
if (0 === i4) continue;
const s3 = (t3 + m2) * h2 + e3 + m2;
if (1 === i4) g2[s3] = 0, f2[s3] = w;
else {
const t4 = 0.5 - i4;
g2[s3] = t4 > 0 ? t4 * t4 : 0, f2[s3] = t4 < 0 ? t4 * t4 : 0;
}
}
T(g2, 0, 0, h2, c2, h2, this.f, this.v, this.z), T(f2, m2, m2, n2, l2, h2, this.f, this.v, this.z);
for (let t3 = 0; t3 < u2; t3++) {
const e3 = Math.sqrt(g2[t3]) - Math.sqrt(f2[t3]);
d2[t3] = Math.round(255 - 255 * (e3 / this.radius + this.cutoff));
}
return _2;
}
};
class S {
constructor() {
this.specification = t.v.light.position;
}
possiblyEvaluate(e2, i3) {
return t.z(e2.expression.evaluate(i3));
}
interpolate(e2, i3, s2) {
return { x: t.B.number(e2.x, i3.x, s2), y: t.B.number(e2.y, i3.y, s2), z: t.B.number(e2.z, i3.z, s2) };
}
}
let C;
class P extends t.E {
constructor(e2) {
super(), C = C || new t.r({ anchor: new t.D(t.v.light.anchor), position: new S(), color: new t.D(t.v.light.color), intensity: new t.D(t.v.light.intensity) }), this._transitionable = new t.T(C), this.setLight(e2), this._transitioning = this._transitionable.untransitioned();
}
getLight() {
return this._transitionable.serialize();
}
setLight(e2, i3 = {}) {
if (!this._validate(t.t, e2, i3)) for (const t2 in e2) {
const i4 = e2[t2];
t2.endsWith("-transition") ? this._transitionable.setTransition(t2.slice(0, -11), i4) : this._transitionable.setValue(t2, i4);
}
}
updateTransitions(t2) {
this._transitioning = this._transitionable.transitioned(t2, this._transitioning);
}
hasTransition() {
return this._transitioning.hasTransition();
}
recalculate(t2) {
this.properties = this._transitioning.possiblyEvaluate(t2);
}
_validate(e2, i3, s2) {
return (!s2 || false !== s2.validate) && t.x(this, e2.call(t.y, t.e({ value: i3, style: { glyphs: true, sprite: true }, styleSpec: t.v })));
}
}
class D {
constructor(t2, e2) {
this.width = t2, this.height = e2, this.nextRow = 0, this.data = new Uint8Array(this.width * this.height), this.dashEntry = {};
}
getDash(t2, e2) {
const i3 = t2.join(",") + String(e2);
return this.dashEntry[i3] || (this.dashEntry[i3] = this.addDash(t2, e2)), this.dashEntry[i3];
}
getDashRanges(t2, e2, i3) {
const s2 = [];
let a2 = t2.length % 2 == 1 ? -t2[t2.length - 1] * i3 : 0, o2 = t2[0] * i3, r2 = true;
s2.push({ left: a2, right: o2, isDash: r2, zeroLength: 0 === t2[0] });
let n2 = t2[0];
for (let e3 = 1; e3 < t2.length; e3++) {
r2 = !r2;
const l2 = t2[e3];
a2 = n2 * i3, n2 += l2, o2 = n2 * i3, s2.push({ left: a2, right: o2, isDash: r2, zeroLength: 0 === l2 });
}
return s2;
}
addRoundDash(t2, e2, i3) {
const s2 = e2 / 2;
for (let e3 = -i3; e3 <= i3; e3++) {
const a2 = this.width * (this.nextRow + i3 + e3);
let o2 = 0, r2 = t2[o2];
for (let n2 = 0; n2 < this.width; n2++) {
n2 / r2.right > 1 && (r2 = t2[++o2]);
const l2 = Math.abs(n2 - r2.left), h2 = Math.abs(n2 - r2.right), c2 = Math.min(l2, h2);
let u2;
const d2 = e3 / i3 * (s2 + 1);
if (r2.isDash) {
const t3 = s2 - Math.abs(d2);
u2 = Math.sqrt(c2 * c2 + t3 * t3);
} else u2 = s2 - Math.sqrt(c2 * c2 + d2 * d2);
this.data[a2 + n2] = Math.max(0, Math.min(255, u2 + 128));
}
}
}
addRegularDash(t2) {
for (let e3 = t2.length - 1; e3 >= 0; --e3) {
const i4 = t2[e3], s3 = t2[e3 + 1];
i4.zeroLength ? t2.splice(e3, 1) : s3 && s3.isDash === i4.isDash && (s3.left = i4.left, t2.splice(e3, 1));
}
const e2 = t2[0], i3 = t2[t2.length - 1];
e2.isDash === i3.isDash && (e2.left = i3.left - this.width, i3.right = e2.right + this.width);
const s2 = this.width * this.nextRow;
let a2 = 0, o2 = t2[a2];
for (let e3 = 0; e3 < this.width; e3++) {
e3 / o2.right > 1 && (o2 = t2[++a2]);
const i4 = Math.abs(e3 - o2.left), r2 = Math.abs(e3 - o2.right), n2 = Math.min(i4, r2);
this.data[s2 + e3] = Math.max(0, Math.min(255, (o2.isDash ? n2 : -n2) + 128));
}
}
addDash(e2, i3) {
const s2 = i3 ? 7 : 0, a2 = 2 * s2 + 1;
if (this.nextRow + a2 > this.height) return t.w("LineAtlas out of space"), null;
let o2 = 0;
for (let t2 = 0; t2 < e2.length; t2++) o2 += e2[t2];
if (0 !== o2) {
const t2 = this.width / o2, a3 = this.getDashRanges(e2, this.width, t2);
i3 ? this.addRoundDash(a3, t2, s2) : this.addRegularDash(a3);
}
const r2 = { y: (this.nextRow + s2 + 0.5) / this.height, height: 2 * s2 / this.height, width: o2 };
return this.nextRow += a2, this.dirty = true, r2;
}
bind(t2) {
const e2 = t2.gl;
this.texture ? (e2.bindTexture(e2.TEXTURE_2D, this.texture), this.dirty && (this.dirty = false, e2.texSubImage2D(e2.TEXTURE_2D, 0, 0, 0, this.width, this.height, e2.ALPHA, e2.UNSIGNED_BYTE, this.data))) : (this.texture = e2.createTexture(), e2.bindTexture(e2.TEXTURE_2D, this.texture), e2.texParameteri(e2.TEXTURE_2D, e2.TEXTURE_WRAP_S, e2.REPEAT), e2.texParameteri(e2.TEXTURE_2D, e2.TEXTURE_WRAP_T, e2.REPEAT), e2.texParameteri(e2.TEXTURE_2D, e2.TEXTURE_MIN_FILTER, e2.LINEAR), e2.texParameteri(e2.TEXTURE_2D, e2.TEXTURE_MAG_FILTER, e2.LINEAR), e2.texImage2D(e2.TEXTURE_2D, 0, e2.ALPHA, this.width, this.height, 0, e2.ALPHA, e2.UNSIGNED_BYTE, this.data));
}
}
class M {
constructor(e2, i3, s2) {
this.workerPool = e2, this.actors = [], this.currentActor = 0, this.id = s2;
const a2 = this.workerPool.acquire(s2);
for (let e3 = 0; e3 < a2.length; e3++) {
const o2 = new t.C(a2[e3], i3, s2);
o2.name = `Worker ${e3}`, this.actors.push(o2);
}
if (!this.actors.length) throw new Error("No actors found");
}
broadcast(e2, i3, s2) {
t.o(this.actors, ((t2, s3) => {
t2.send(e2, i3, s3);
}), s2 = s2 || function() {
});
}
getActor() {
return this.currentActor = (this.currentActor + 1) % this.actors.length, this.actors[this.currentActor];
}
remove(t2 = true) {
this.actors.forEach(((t3) => {
t3.remove();
})), this.actors = [], t2 && this.workerPool.release(this.id);
}
}
function z(e2, i3, s2) {
const a2 = function(i4, a3) {
if (i4) return s2(i4);
if (a3) {
const i5 = t.F(t.e(a3, e2), ["tiles", "minzoom", "maxzoom", "attribution", "bounds", "scheme", "tileSize", "encoding"]);
a3.vector_layers && (i5.vectorLayers = a3.vector_layers, i5.vectorLayerIds = i5.vectorLayers.map(((t2) => t2.id))), s2(null, i5);
}
};
return e2.url ? t.f(i3.transformRequest(e2.url, c.Source), a2) : t.h.frame((() => a2(null, e2)));
}
class L {
constructor(t2, e2) {
t2 && (e2 ? this.setSouthWest(t2).setNorthEast(e2) : Array.isArray(t2) && (4 === t2.length ? this.setSouthWest([t2[0], t2[1]]).setNorthEast([t2[2], t2[3]]) : this.setSouthWest(t2[0]).setNorthEast(t2[1])));
}
setNorthEast(e2) {
return this._ne = e2 instanceof t.L ? new t.L(e2.lng, e2.lat) : t.L.convert(e2), this;
}
setSouthWest(e2) {
return this._sw = e2 instanceof t.L ? new t.L(e2.lng, e2.lat) : t.L.convert(e2), this;
}
extend(e2) {
const i3 = this._sw, s2 = this._ne;
let a2, o2;
if (e2 instanceof t.L) a2 = e2, o2 = e2;
else {
if (!(e2 instanceof L)) return Array.isArray(e2) ? 4 === e2.length || e2.every(Array.isArray) ? this.extend(L.convert(e2)) : this.extend(t.L.convert(e2)) : e2 && ("lng" in e2 || "lon" in e2) && "lat" in e2 ? this.extend(t.L.convert(e2)) : this;
if (a2 = e2._sw, o2 = e2._ne, !a2 || !o2) return this;
}
return i3 || s2 ? (i3.lng = Math.min(a2.lng, i3.lng), i3.lat = Math.min(a2.lat, i3.lat), s2.lng = Math.max(o2.lng, s2.lng), s2.lat = Math.max(o2.lat, s2.lat)) : (this._sw = new t.L(a2.lng, a2.lat), this._ne = new t.L(o2.lng, o2.lat)), this;
}
getCenter() {
return new t.L((this._sw.lng + this._ne.lng) / 2, (this._sw.lat + this._ne.lat) / 2);
}
getSouthWest() {
return this._sw;
}
getNorthEast() {
return this._ne;
}
getNorthWest() {
return new t.L(this.getWest(), this.getNorth());
}
getSouthEast() {
return new t.L(this.getEast(), this.getSouth());
}
getWest() {
return this._sw.lng;
}
getSouth() {
return this._sw.lat;
}
getEast() {
return this._ne.lng;
}
getNorth() {
return this._ne.lat;
}
toArray() {
return [this._sw.toArray(), this._ne.toArray()];
}
toString() {
return `LngLatBounds(${this._sw.toString()}, ${this._ne.toString()})`;
}
isEmpty() {
return !(this._sw && this._ne);
}
contains(e2) {
const { lng: i3, lat: s2 } = t.L.convert(e2);
let a2 = this._sw.lng <= i3 && i3 <= this._ne.lng;
return this._sw.lng > this._ne.lng && (a2 = this._sw.lng >= i3 && i3 >= this._ne.lng), this._sw.lat <= s2 && s2 <= this._ne.lat && a2;
}
static convert(t2) {
return t2 instanceof L ? t2 : t2 ? new L(t2) : t2;
}
static fromLngLat(e2, i3 = 0) {
const s2 = 360 * i3 / 40075017, a2 = s2 / Math.cos(Math.PI / 180 * e2.lat);
return new L(new t.L(e2.lng - a2, e2.lat - s2), new t.L(e2.lng + a2, e2.lat + s2));
}
}
class A {
constructor(t2, e2, i3) {
this.bounds = L.convert(this.validateBounds(t2)), this.minzoom = e2 || 0, this.maxzoom = i3 || 24;
}
validateBounds(t2) {
return Array.isArray(t2) && 4 === t2.length ? [Math.max(-180, t2[0]), Math.max(-90, t2[1]), Math.min(180, t2[2]), Math.min(90, t2[3])] : [-180, -90, 180, 90];
}
contains(e2) {
const i3 = Math.pow(2, e2.z), s2 = Math.floor(t.G(this.bounds.getWest()) * i3), a2 = Math.floor(t.H(this.bounds.getNorth()) * i3), o2 = Math.ceil(t.G(this.bounds.getEast()) * i3), r2 = Math.ceil(t.H(this.bounds.getSouth()) * i3);
return e2.x >= s2 && e2.x < o2 && e2.y >= a2 && e2.y < r2;
}
}
class R extends t.E {
constructor(e2, i3, s2, a2) {
if (super(), this.load = () => {
this._loaded = false, this.fire(new t.k("dataloading", { dataType: "source" })), this._tileJSONRequest = z(this._options, this.map._requestManager, ((e3, i4) => {
this._tileJSONRequest = null, this._loaded = true, this.map.style.sourceCaches[this.id].clearTiles(), e3 ? this.fire(new t.j(e3)) : i4 && (t.e(this, i4), i4.bounds && (this.tileBounds = new A(i4.bounds, this.minzoom, this.maxzoom)), this.fire(new t.k("data", { dataType: "source", sourceDataType: "metadata" })), this.fire(new t.k("data", { dataType: "source", sourceDataType: "content" })));
}));
}, this.serialize = () => t.e({}, this._options), this.id = e2, this.dispatcher = s2, this.type = "vector", this.minzoom = 0, this.maxzoom = 22, this.scheme = "xyz", this.tileSize = 512, this.reparseOverscaled = true, this.isTileClipped = true, this._loaded = false, t.e(this, t.F(i3, ["url", "scheme", "tileSize", "promoteId"])), this._options = t.e({ type: "vector" }, i3), this._collectResourceTiming = i3.collectResourceTiming, 512 !== this.tileSize) throw new Error("vector tile sources must have a tileSize of 512");
this.setEventedParent(a2);
}
loaded() {
return this._loaded;
}
hasTile(t2) {
return !this.tileBounds || this.tileBounds.contains(t2.canonical);
}
onAdd(t2) {
this.map = t2, this.load();
}
setSourceProperty(t2) {
this._tileJSONRequest && this._tileJSONRequest.cancel(), t2(), this.load();
}
setTiles(t2) {
return this.setSourceProperty((() => {
this._options.tiles = t2;
})), this;
}
setUrl(t2) {
return this.setSourceProperty((() => {
this.url = t2, this._options.url = t2;
})), this;
}
onRemove() {
this._tileJSONRequest && (this._tileJSONRequest.cancel(), this._tileJSONRequest = null);
}
loadTile(t2, e2) {
const i3 = t2.tileID.canonical.url(this.tiles, this.map.getPixelRatio(), this.scheme), s2 = { request: this.map._requestManager.transformRequest(i3, c.Tile), uid: t2.uid, tileID: t2.tileID, zoom: t2.tileID.overscaledZ, tileSize: this.tileSize * t2.tileID.overscaleFactor(), type: this.type, source: this.id, pixelRatio: this.map.getPixelRatio(), showCollisionBoxes: this.map.showCollisionBoxes, promoteId: this.promoteId };
function a2(i4, s3) {
return delete t2.request, t2.aborted ? e2(null) : i4 && 404 !== i4.status ? e2(i4) : (s3 && s3.resourceTiming && (t2.resourceTiming = s3.resourceTiming), this.map._refreshExpiredTiles && s3 && t2.setExpiryData(s3), t2.loadVectorData(s3, this.map.painter), e2(null), void (t2.reloadCallback && (this.loadTile(t2, t2.reloadCallback), t2.reloadCallback = null)));
}
s2.request.collectResourceTiming = this._collectResourceTiming, t2.actor && "expired" !== t2.state ? "loading" === t2.state ? t2.reloadCallback = e2 : t2.request = t2.actor.send("reloadTile", s2, a2.bind(this)) : (t2.actor = this.dispatcher.getActor(), t2.request = t2.actor.send("loadTile", s2, a2.bind(this)));
}
abortTile(t2) {
t2.request && (t2.request.cancel(), delete t2.request), t2.actor && t2.actor.send("abortTile", { uid: t2.uid, type: this.type, source: this.id }, void 0);
}
unloadTile(t2) {
t2.unloadVectorData(), t2.actor && t2.actor.send("removeTile", { uid: t2.uid, type: this.type, source: this.id }, void 0);
}
hasTransition() {
return false;
}
}
class k extends t.E {
constructor(e2, i3, s2, a2) {
super(), this.id = e2, this.dispatcher = s2, this.setEventedParent(a2), this.type = "raster", this.minzoom = 0, this.maxzoom = 22, this.roundZoom = true, this.scheme = "xyz", this.tileSize = 512, this._loaded = false, this._options = t.e({ type: "raster" }, i3), t.e(this, t.F(i3, ["url", "scheme", "tileSize"]));
}
load() {
this._loaded = false, this.fire(new t.k("dataloading", { dataType: "source" })), this._tileJSONRequest = z(this._options, this.map._requestManager, ((e2, i3) => {
this._tileJSONRequest = null, this._loaded = true, e2 ? this.fire(new t.j(e2)) : i3 && (t.e(this, i3), i3.bounds && (this.tileBounds = new A(i3.bounds, this.minzoom, this.maxzoom)), this.fire(new t.k("data", { dataType: "source", sourceDataType: "metadata" })), this.fire(new t.k("data", { dataType: "source", sourceDataType: "content" })));
}));
}
loaded() {
return this._loaded;
}
onAdd(t2) {
this.map = t2, this.load();
}
onRemove() {
this._tileJSONRequest && (this._tileJSONRequest.cancel(), this._tileJSONRequest = null);
}
setSourceProperty(t2) {
this._tileJSONRequest && this._tileJSONRequest.cancel(), t2(), this.load();
}
setTiles(t2) {
return this.setSourceProperty((() => {
this._options.tiles = t2;
})), this;
}
serialize() {
return t.e({}, this._options);
}
hasTile(t2) {
return !this.tileBounds || this.tileBounds.contains(t2.canonical);
}
loadTile(t2, e2) {
const i3 = t2.tileID.canonical.url(this.tiles, this.map.getPixelRatio(), this.scheme);
t2.request = h.getImage(this.map._requestManager.transformRequest(i3, c.Tile), ((i4, s2, a2) => {
if (delete t2.request, t2.aborted) t2.state = "unloaded", e2(null);
else if (i4) t2.state = "errored", e2(i4);
else if (s2) {
this.map._refreshExpiredTiles && a2 && t2.setExpiryData(a2);
const i5 = this.map.painter.context, o2 = i5.gl;
t2.texture = this.map.painter.getTileTexture(s2.width), t2.texture ? t2.texture.update(s2, { useMipmap: true }) : (t2.texture = new x(i5, s2, o2.RGBA, { useMipmap: true }), t2.texture.bind(o2.LINEAR, o2.CLAMP_TO_EDGE, o2.LINEAR_MIPMAP_NEAREST), i5.extTextureFilterAnisotropic && o2.texParameterf(o2.TEXTURE_2D, i5.extTextureFilterAnisotropic.TEXTURE_MAX_ANISOTROPY_EXT, i5.extTextureFilterAnisotropicMax)), t2.state = "loaded", e2(null);
}
}), this.map._refreshExpiredTiles);
}
abortTile(t2, e2) {
t2.request && (t2.request.cancel(), delete t2.request), e2();
}
unloadTile(t2, e2) {
t2.texture && this.map.painter.saveTileTexture(t2.texture), e2();
}
hasTransition() {
return false;
}
}
class F extends k {
constructor(e2, i3, s2, a2) {
super(e2, i3, s2, a2), this.type = "raster-dem", this.maxzoom = 22, this._options = t.e({ type: "raster-dem" }, i3), this.encoding = i3.encoding || "mapbox", this.redFactor = i3.redFactor, this.greenFactor = i3.greenFactor, this.blueFactor = i3.blueFactor, this.baseShift = i3.baseShift;
}
loadTile(e2, i3) {
const s2 = e2.tileID.canonical.url(this.tiles, this.map.getPixelRatio(), this.scheme), a2 = this.map._requestManager.transformRequest(s2, c.Tile);
function o2(t2, s3) {
t2 && (e2.state = "errored", i3(t2)), s3 && (e2.dem = s3, e2.needsHillshadePrepare = true, e2.needsTerrainPrepare = true, e2.state = "loaded", i3(null));
}
e2.neighboringTiles = this._getNeighboringTiles(e2.tileID), e2.request = h.getImage(a2, ((s3, a3, r2) => t._(this, void 0, void 0, (function* () {
if (delete e2.request, e2.aborted) e2.state = "unloaded", i3(null);
else if (s3) e2.state = "errored", i3(s3);
else if (a3) {
this.map._refreshExpiredTiles && e2.setExpiryData(r2);
const i4 = t.a(a3) && t.J() ? a3 : yield (function(e3) {
return t._(this, void 0, void 0, (function* () {
if ("undefined" != typeof VideoFrame && t.K()) {
const i5 = e3.width + 2, s5 = e3.height + 2;
try {
return new t.R({ width: i5, height: s5 }, yield t.M(e3, -1, -1, i5, s5));
} catch (t2) {
}
}
return t.h.getImageData(e3, 1);
}));
})(a3), s4 = { uid: e2.uid, coord: e2.tileID, source: this.id, rawImageData: i4, encoding: this.encoding, redFactor: this.redFactor, greenFactor: this.greenFactor, blueFactor: this.blueFactor, baseShift: this.baseShift };
e2.actor && "expired" !== e2.state || (e2.actor = this.dispatcher.getActor(), e2.actor.send("loadDEMTile", s4, o2));
}
}))), this.map._refreshExpiredTiles);
}
_getNeighboringTiles(e2) {
const i3 = e2.canonical, s2 = Math.pow(2, i3.z), a2 = (i3.x - 1 + s2) % s2, o2 = 0 === i3.x ? e2.wrap - 1 : e2.wrap, r2 = (i3.x + 1 + s2) % s2, n2 = i3.x + 1 === s2 ? e2.wrap + 1 : e2.wrap, l2 = {};
return l2[new t.O(e2.overscaledZ, o2, i3.z, a2, i3.y).key] = { backfilled: false }, l2[new t.O(e2.overscaledZ, n2, i3.z, r2, i3.y).key] = { backfilled: false }, i3.y > 0 && (l2[new t.O(e2.overscaledZ, o2, i3.z, a2, i3.y - 1).key] = { backfilled: false }, l2[new t.O(e2.overscaledZ, e2.wrap, i3.z, i3.x, i3.y - 1).key] = { backfilled: false }, l2[new t.O(e2.overscaledZ, n2, i3.z, r2, i3.y - 1).key] = { backfilled: false }), i3.y + 1 < s2 && (l2[new t.O(e2.overscaledZ, o2, i3.z, a2, i3.y + 1).key] = { backfilled: false }, l2[new t.O(e2.overscaledZ, e2.wrap, i3.z, i3.x, i3.y + 1).key] = { backfilled: false }, l2[new t.O(e2.overscaledZ, n2, i3.z, r2, i3.y + 1).key] = { backfilled: false }), l2;
}
unloadTile(t2) {
t2.demTexture && this.map.painter.saveTileTexture(t2.demTexture), t2.fbo && (t2.fbo.destroy(), delete t2.fbo), t2.dem && delete t2.dem, delete t2.neighboringTiles, t2.state = "unloaded", t2.actor && t2.actor.send("removeDEMTile", { uid: t2.uid, source: this.id });
}
}
class B extends t.E {
constructor(e2, i3, s2, a2) {
super(), this.load = () => {
this._updateWorkerData();
}, this.serialize = () => t.e({}, this._options, { type: this.type, data: this._data }), this.id = e2, this.type = "geojson", this.minzoom = 0, this.maxzoom = 18, this.tileSize = 512, this.isTileClipped = true, this.reparseOverscaled = true, this._removed = false, this._pendingLoads = 0, this.actor = s2.getActor(), this.setEventedParent(a2), this._data = i3.data, this._options = t.e({}, i3), this._collectResourceTiming = i3.collectResourceTiming, void 0 !== i3.maxzoom && (this.maxzoom = i3.maxzoom), i3.type && (this.type = i3.type), i3.attribution && (this.attribution = i3.attribution), this.promoteId = i3.promoteId;
const o2 = t.N / this.tileSize;
this.workerOptions = t.e({ source: this.id, cluster: i3.cluster || false, geojsonVtOptions: { buffer: (void 0 !== i3.buffer ? i3.buffer : 128) * o2, tolerance: (void 0 !== i3.tolerance ? i3.tolerance : 0.375) * o2, extent: t.N, maxZoom: this.maxzoom, lineMetrics: i3.lineMetrics || false, generateId: i3.generateId || false }, superclusterOptions: { maxZoom: void 0 !== i3.clusterMaxZoom ? i3.clusterMaxZoom : this.maxzoom - 1, minPoints: Math.max(2, i3.clusterMinPoints || 2), extent: t.N, radius: (i3.clusterRadius || 50) * o2, log: false, generateId: i3.generateId || false }, clusterProperties: i3.clusterProperties, filter: i3.filter }, i3.workerOptions), "string" == typeof this.promoteId && (this.workerOptions.promoteId = this.promoteId);
}
onAdd(t2) {
this.map = t2, this.load();
}
setData(t2) {
return this._data = t2, this._updateWorkerData(), this;
}
updateData(t2) {
return this._updateWorkerData(t2), this;
}
setClusterOptions(t2) {
return this.workerOptions.cluster = t2.cluster, t2 && (void 0 !== t2.clusterRadius && (this.workerOptions.superclusterOptions.radius = t2.clusterRadius), void 0 !== t2.clusterMaxZoom && (this.workerOptions.superclusterOptions.maxZoom = t2.clusterMaxZoom)), this._updateWorkerData(), this;
}
getClusterExpansionZoom(t2, e2) {
return this.actor.send("geojson.getClusterExpansionZoom", { clusterId: t2, source: this.id }, e2), this;
}
getClusterChildren(t2, e2) {
return this.actor.send("geojson.getClusterChildren", { clusterId: t2, source: this.id }, e2), this;
}
getClusterLeaves(t2, e2, i3, s2) {
return this.actor.send("geojson.getClusterLeaves", { source: this.id, clusterId: t2, limit: e2, offset: i3 }, s2), this;
}
_updateWorkerData(e2) {
const i3 = t.e({}, this.workerOptions);
e2 ? i3.dataDiff = e2 : "string" == typeof this._data ? (i3.request = this.map._requestManager.transformRequest(t.h.resolveURL(this._data), c.Source), i3.request.collectResourceTiming = this._collectResourceTiming) : i3.data = JSON.stringify(this._data), this._pendingLoads++, this.fire(new t.k("dataloading", { dataType: "source" })), this.actor.send(`${this.type}.loadData`, i3, ((e3, i4) => {
if (this._pendingLoads--, this._removed || i4 && i4.abandoned) return void this.fire(new t.k("dataabort", { dataType: "source" }));
let s2 = null;
if (i4 && i4.resourceTiming && i4.resourceTiming[this.id] && (s2 = i4.resourceTiming[this.id].slice(0)), e3) return void this.fire(new t.j(e3));
const a2 = { dataType: "source" };
this._collectResourceTiming && s2 && s2.length > 0 && t.e(a2, { resourceTiming: s2 }), this.fire(new t.k("data", Object.assign(Object.assign({}, a2), { sourceDataType: "metadata" }))), this.fire(new t.k("data", Object.assign(Object.assign({}, a2), { sourceDataType: "content" })));
}));
}
loaded() {
return 0 === this._pendingLoads;
}
loadTile(t2, e2) {
const i3 = t2.actor ? "reloadTile" : "loadTile";
t2.actor = this.actor;
const s2 = { type: this.type, uid: t2.uid, tileID: t2.tileID, zoom: t2.tileID.overscaledZ, maxZoom: this.maxzoom, tileSize: this.tileSize, source: this.id, pixelRatio: this.map.getPixelRatio(), showCollisionBoxes: this.map.showCollisionBoxes, promoteId: this.promoteId };
t2.request = this.actor.send(i3, s2, ((s3, a2) => (delete t2.request, t2.unloadVectorData(), t2.aborted ? e2(null) : s3 ? e2(s3) : (t2.loadVectorData(a2, this.map.painter, "reloadTile" === i3), e2(null)))));
}
abortTile(t2) {
t2.request && (t2.request.cancel(), delete t2.request), t2.aborted = true;
}
unloadTile(t2) {
t2.unloadVectorData(), this.actor.send("removeTile", { uid: t2.uid, type: this.type, source: this.id });
}
onRemove() {
this._removed = true, this.actor.send("removeSource", { type: this.type, source: this.id });
}
hasTransition() {
return false;
}
}
var O = t.Q([{ name: "a_pos", type: "Int16", components: 2 }, { name: "a_texture_pos", type: "Int16", components: 2 }]);
class N extends t.E {
constructor(e2, i3, s2, a2) {
super(), this.load = (e3, i4) => {
this._loaded = false, this.fire(new t.k("dataloading", { dataType: "source" })), this.url = this.options.url, this._request = h.getImage(this.map._requestManager.transformRequest(this.url, c.Image), ((s3, a3) => {
this._request = null, this._loaded = true, s3 ? this.fire(new t.j(s3)) : a3 && (this.image = a3, e3 && (this.coordinates = e3), i4 && i4(), this._finishLoading());
}));
}, this.prepare = () => {
if (0 === Object.keys(this.tiles).length || !this.image) return;
const e3 = this.map.painter.context, i4 = e3.gl;
this.boundsBuffer || (this.boundsBuffer = e3.createVertexBuffer(this._boundsArray, O.members)), this.boundsSegments || (this.boundsSegments = t.S.simpleSegment(0, 0, 4, 2)), this.texture || (this.texture = new x(e3, this.image, i4.RGBA), this.texture.bind(i4.LINEAR, i4.CLAMP_TO_EDGE));
let s3 = false;
for (const t2 in this.tiles) {
const e4 = this.tiles[t2];
"loaded" !== e4.state && (e4.state = "loaded", e4.texture = this.texture, s3 = true);
}
s3 && this.fire(new t.k("data", { dataType: "source", sourceDataType: "idle", sourceId: this.id }));
}, this.serialize = () => ({ type: "image", url: this.options.url, coordinates: this.coordinates }), this.id = e2, this.dispatcher = s2, this.coordinates = i3.coordinates, this.type = "image", this.minzoom = 0, this.maxzoom = 22, this.tileSize = 512, this.tiles = {}, this._loaded = false, this.setEventedParent(a2), this.options = i3;
}
loaded() {
return this._loaded;
}
updateImage(t2) {
return t2.url ? (this._request && (this._request.cancel(), this._request = null), this.options.url = t2.url, this.load(t2.coordinates, (() => {
this.texture = null;
})), this) : this;
}
_finishLoading() {
this.map && (this.setCoordinates(this.coordinates), this.fire(new t.k("data", { dataType: "source", sourceDataType: "metadata" })));
}
onAdd(t2) {
this.map = t2, this.load();
}
onRemove() {
this._request && (this._request.cancel(), this._request = null);
}
setCoordinates(e2) {
this.coordinates = e2;
const i3 = e2.map(t.U.fromLngLat);
this.tileID = (function(e3) {
let i4 = 1 / 0, s3 = 1 / 0, a2 = -1 / 0, o2 = -1 / 0;
for (const t2 of e3) i4 = Math.min(i4, t2.x), s3 = Math.min(s3, t2.y), a2 = Math.max(a2, t2.x), o2 = Math.max(o2, t2.y);
const r2 = Math.max(a2 - i4, o2 - s3), n2 = Math.max(0, Math.floor(-Math.log(r2) / Math.LN2)), l2 = Math.pow(2, n2);
return new t.W(n2, Math.floor((i4 + a2) / 2 * l2), Math.floor((s3 + o2) / 2 * l2));
})(i3), this.minzoom = this.maxzoom = this.tileID.z;
const s2 = i3.map(((t2) => this.tileID.getTilePoint(t2)._round()));
return this._boundsArray = new t.V(), this._boundsArray.emplaceBack(s2[0].x, s2[0].y, 0, 0), this._boundsArray.emplaceBack(s2[1].x, s2[1].y, t.N, 0), this._boundsArray.emplaceBack(s2[3].x, s2[3].y, 0, t.N), this._boundsArray.emplaceBack(s2[2].x, s2[2].y, t.N, t.N), this.boundsBuffer && (this.boundsBuffer.destroy(), delete this.boundsBuffer), this.fire(new t.k("data", { dataType: "source", sourceDataType: "content" })), this;
}
loadTile(t2, e2) {
this.tileID && this.tileID.equals(t2.tileID.canonical) ? (this.tiles[String(t2.tileID.wrap)] = t2, t2.buckets = {}, e2(null)) : (t2.state = "errored", e2(null));
}
hasTransition() {
return false;
}
}
class U extends N {
constructor(e2, i3, s2, a2) {
super(e2, i3, s2, a2), this.load = () => {
this._loaded = false;
const e3 = this.options;
this.urls = [];
for (const t2 of e3.urls) this.urls.push(this.map._requestManager.transformRequest(t2, c.Source).url);
t.X(this.urls, ((e4, i4) => {
this._loaded = true, e4 ? this.fire(new t.j(e4)) : i4 && (this.video = i4, this.video.loop = true, this.video.addEventListener("playing", (() => {
this.map.triggerRepaint();
})), this.map && this.video.play(), this._finishLoading());
}));
}, this.prepare = () => {
if (0 === Object.keys(this.tiles).length || this.video.readyState < 2) return;
const e3 = this.map.painter.context, i4 = e3.gl;
this.boundsBuffer || (this.boundsBuffer = e3.createVertexBuffer(this._boundsArray, O.members)), this.boundsSegments || (this.boundsSegments = t.S.simpleSegment(0, 0, 4, 2)), this.texture ? this.video.paused || (this.texture.bind(i4.LINEAR, i4.CLAMP_TO_EDGE), i4.texSubImage2D(i4.TEXTURE_2D, 0, 0, 0, i4.RGBA, i4.UNSIGNED_BYTE, this.video)) : (this.texture = new x(e3, this.video, i4.RGBA), this.texture.bind(i4.LINEAR, i4.CLAMP_TO_EDGE));
let s3 = false;
for (const t2 in this.tiles) {
const e4 = this.tiles[t2];
"loaded" !== e4.state && (e4.state = "loaded", e4.texture = this.texture, s3 = true);
}
s3 && this.fire(new t.k("data", { dataType: "source", sourceDataType: "idle", sourceId: this.id }));
}, this.serialize = () => ({ type: "video", urls: this.urls, coordinates: this.coordinates }), this.roundZoom = true, this.type = "video", this.options = i3;
}
pause() {
this.video && this.video.pause();
}
play() {
this.video && this.video.play();
}
seek(e2) {
if (this.video) {
const i3 = this.video.seekable;
e2 < i3.start(0) || e2 > i3.end(0) ? this.fire(new t.j(new t.Y(`sources.${this.id}`, null, `Playback for this video can be set only between the ${i3.start(0)} and ${i3.end(0)}-second mark.`))) : this.video.currentTime = e2;
}
}
getVideo() {
return this.video;
}
onAdd(t2) {
this.map || (this.map = t2, this.load(), this.video && (this.video.play(), this.setCoordinates(this.coordinates)));
}
hasTransition() {
return this.video && !this.video.paused;
}
}
class Z extends N {
constructor(e2, i3, s2, a2) {
super(e2, i3, s2, a2), this.load = () => {
this._loaded = true, this.canvas || (this.canvas = this.options.canvas instanceof HTMLCanvasElement ? this.options.canvas : document.getElementById(this.options.canvas)), this.width = this.canvas.width, this.height = this.canvas.height, this._hasInvalidDimensions() ? this.fire(new t.j(new Error("Canvas dimensions cannot be less than or equal to zero."))) : (this.play = function() {
this._playing = true, this.map.triggerRepaint();
}, this.pause = function() {
this._playing && (this.prepare(), this._playing = false);
}, this._finishLoading());
}, this.prepare = () => {
let e3 = false;
if (this.canvas.width !== this.width && (this.width = this.canvas.width, e3 = true), this.canvas.height !== this.height && (this.height = this.canvas.height, e3 = true), this._hasInvalidDimensions()) return;
if (0 === Object.keys(this.tiles).length) return;
const i4 = this.map.painter.context, s3 = i4.gl;
this.boundsBuffer || (this.boundsBuffer = i4.createVertexBuffer(this._boundsArray, O.members)), this.boundsSegments || (this.boundsSegments = t.S.simpleSegment(0, 0, 4, 2)), this.texture ? (e3 || this._playing) && this.texture.update(this.canvas, { premultiply: true }) : this.texture = new x(i4, this.canvas, s3.RGBA, { premultiply: true });
let a3 = false;
for (const t2 in this.tiles) {
const e4 = this.tiles[t2];
"loaded" !== e4.state && (e4.state = "loaded", e4.texture = this.texture, a3 = true);
}
a3 && this.fire(new t.k("data", { dataType: "source", sourceDataType: "idle", sourceId: this.id }));
}, this.serialize = () => ({ type: "canvas", coordinates: this.coordinates }), i3.coordinates ? Array.isArray(i3.coordinates) && 4 === i3.coordinates.length && !i3.coordinates.some(((t2) => !Array.isArray(t2) || 2 !== t2.length || t2.some(((t3) => "number" != typeof t3)))) || this.fire(new t.j(new t.Y(`sources.${e2}`, null, '"coordinates" property must be an array of 4 longitude/latitude array pairs'))) : this.fire(new t.j(new t.Y(`sources.${e2}`, null, 'missing required property "coordinates"'))), i3.animate && "boolean" != typeof i3.animate && this.fire(new t.j(new t.Y(`sources.${e2}`, null, 'optional "animate" property must be a boolean value'))), i3.canvas ? "string" == typeof i3.canvas || i3.canvas instanceof HTMLCanvasElement || this.fire(new t.j(new t.Y(`sources.${e2}`, null, '"canvas" must be either a string representing the ID of the canvas element from which to read, or an HTMLCanvasElement instance'))) : this.fire(new t.j(new t.Y(`sources.${e2}`, null, 'missing required property "canvas"'))), this.options = i3, this.animate = void 0 === i3.animate || i3.animate;
}
getCanvas() {
return this.canvas;
}
onAdd(t2) {
this.map = t2, this.load(), this.canvas && this.animate && this.play();
}
onRemove() {
this.pause();
}
hasTransition() {
return this._playing;
}
_hasInvalidDimensions() {
for (const t2 of [this.canvas.width, this.canvas.height]) if (isNaN(t2) || t2 <= 0) return true;
return false;
}
}
const G = {}, j = (t2) => {
switch (t2) {
case "geojson":
return B;
case "image":
return N;
case "raster":
return k;
case "raster-dem":
return F;
case "vector":
return R;
case "video":
return U;
case "canvas":
return Z;
}
return G[t2];
};
function V(e2, i3) {
const s2 = t.Z();
return t.$(s2, s2, [1, 1, 0]), t.a0(s2, s2, [0.5 * e2.width, 0.5 * e2.height, 1]), t.a1(s2, s2, e2.calculatePosMatrix(i3.toUnwrapped()));
}
function q(t2, e2, i3, s2, a2, o2) {
const r2 = (function(t3, e3, i4) {
if (t3) for (const s3 of t3) {
const t4 = e3[s3];
if (t4 && t4.source === i4 && "fill-extrusion" === t4.type) return true;
}
else for (const t4 in e3) {
const s3 = e3[t4];
if (s3.source === i4 && "fill-extrusion" === s3.type) return true;
}
return false;
})(a2 && a2.layers, e2, t2.id), n2 = o2.maxPitchScaleFactor(), l2 = t2.tilesIn(s2, n2, r2);
l2.sort($);
const h2 = [];
for (const s3 of l2) h2.push({ wrappedTileID: s3.tileID.wrapped().key, queryResults: s3.tile.queryRenderedFeatures(e2, i3, t2._state, s3.queryGeometry, s3.cameraQueryGeometry, s3.scale, a2, o2, n2, V(t2.transform, s3.tileID)) });
const c2 = (function(t3) {
const e3 = {}, i4 = {};
for (const s3 of t3) {
const t4 = s3.queryResults, a3 = s3.wrappedTileID, o3 = i4[a3] = i4[a3] || {};
for (const i5 in t4) {
const s4 = t4[i5], a4 = o3[i5] = o3[i5] || {}, r3 = e3[i5] = e3[i5] || [];
for (const t5 of s4) a4[t5.featureIndex] || (a4[t5.featureIndex] = true, r3.push(t5));
}
}
return e3;
})(h2);
for (const e3 in c2) c2[e3].forEach(((e4) => {
const i4 = e4.feature, s3 = t2.getFeatureState(i4.layer["source-layer"], i4.id);
i4.source = i4.layer.source, i4.layer["source-layer"] && (i4.sourceLayer = i4.layer["source-layer"]), i4.state = s3;
}));
return c2;
}
function $(t2, e2) {
const i3 = t2.tileID, s2 = e2.tileID;
return i3.overscaledZ - s2.overscaledZ || i3.canonical.y - s2.canonical.y || i3.wrap - s2.wrap || i3.canonical.x - s2.canonical.x;
}
class W {
constructor(e2, i3) {
this.timeAdded = 0, this.fadeEndTime = 0, this.tileID = e2, this.uid = t.a2(), this.uses = 0, this.tileSize = i3, this.buckets = {}, this.expirationTime = null, this.queryPadding = 0, this.hasSymbolBuckets = false, this.hasRTLText = false, this.dependencies = {}, this.rtt = [], this.rttCoords = {}, this.expiredRequestCount = 0, this.state = "loading";
}
registerFadeDuration(t2) {
const e2 = t2 + this.timeAdded;
e2 < this.fadeEndTime || (this.fadeEndTime = e2);
}
wasRequested() {
return "errored" === this.state || "loaded" === this.state || "reloading" === this.state;
}
clearTextures(t2) {
this.demTexture && t2.saveTileTexture(this.demTexture), this.demTexture = null;
}
loadVectorData(e2, i3, s2) {
if (this.hasData() && this.unloadVectorData(), this.state = "loaded", e2) {
e2.featureIndex && (this.latestFeatureIndex = e2.featureIndex, e2.rawTileData ? (this.latestRawTileData = e2.rawTileData, this.latestFeatureIndex.rawTileData = e2.rawTileData) : this.latestRawTileData && (this.latestFeatureIndex.rawTileData = this.latestRawTileData)), this.collisionBoxArray = e2.collisionBoxArray, this.buckets = (function(t2, e3) {
const i4 = {};
if (!e3) return i4;
for (const s3 of t2) {
const t3 = s3.layerIds.map(((t4) => e3.getLayer(t4))).filter(Boolean);
if (0 !== t3.length) {
s3.layers = t3, s3.stateDependentLayerIds && (s3.stateDependentLayers = s3.stateDependentLayerIds.map(((e4) => t3.filter(((t4) => t4.id === e4))[0])));
for (const e4 of t3) i4[e4.id] = s3;
}
}
return i4;
})(e2.buckets, i3.style), this.hasSymbolBuckets = false;
for (const e3 in this.buckets) {
const i4 = this.buckets[e3];
if (i4 instanceof t.a4) {
if (this.hasSymbolBuckets = true, !s2) break;
i4.justReloaded = true;
}
}
if (this.hasRTLText = false, this.hasSymbolBuckets) for (const e3 in this.buckets) {
const i4 = this.buckets[e3];
if (i4 instanceof t.a4 && i4.hasRTLText) {
this.hasRTLText = true, t.a5();
break;
}
}
this.queryPadding = 0;
for (const t2 in this.buckets) {
const e3 = this.buckets[t2];
this.queryPadding = Math.max(this.queryPadding, i3.style.getLayer(t2).queryRadius(e3));
}
e2.imageAtlas && (this.imageAtlas = e2.imageAtlas), e2.glyphAtlasImage && (this.glyphAtlasImage = e2.glyphAtlasImage);
} else this.collisionBoxArray = new t.a3();
}
unloadVectorData() {
for (const t2 in this.buckets) this.buckets[t2].destroy();
this.buckets = {}, this.imageAtlasTexture && this.imageAtlasTexture.destroy(), this.imageAtlas && (this.imageAtlas = null), this.glyphAtlasTexture && this.glyphAtlasTexture.destroy(), this.latestFeatureIndex = null, this.state = "unloaded";
}
getBucket(t2) {
return this.buckets[t2.id];
}
upload(t2) {
for (const e3 in this.buckets) {
const i3 = this.buckets[e3];
i3.uploadPending() && i3.upload(t2);
}
const e2 = t2.gl;
this.imageAtlas && !this.imageAtlas.uploaded && (this.imageAtlasTexture = new x(t2, this.imageAtlas.image, e2.RGBA), this.imageAtlas.uploaded = true), this.glyphAtlasImage && (this.glyphAtlasTexture = new x(t2, this.glyphAtlasImage, e2.ALPHA), this.glyphAtlasImage = null);
}
prepare(t2) {
this.imageAtlas && this.imageAtlas.patchUpdatedImages(t2, this.imageAtlasTexture);
}
queryRenderedFeatures(t2, e2, i3, s2, a2, o2, r2, n2, l2, h2) {
return this.latestFeatureIndex && this.latestFeatureIndex.rawTileData ? this.latestFeatureIndex.query({ queryGeometry: s2, cameraQueryGeometry: a2, scale: o2, tileSize: this.tileSize, pixelPosMatrix: h2, transform: n2, params: r2, queryPadding: this.queryPadding * l2 }, t2, e2, i3) : {};
}
querySourceFeatures(e2, i3) {
const s2 = this.latestFeatureIndex;
if (!s2 || !s2.rawTileData) return;
const a2 = s2.loadVTLayers(), o2 = i3 && i3.sourceLayer ? i3.sourceLayer : "", r2 = a2._geojsonTileLayer || a2[o2];
if (!r2) return;
const n2 = t.a6(i3 && i3.filter), { z: l2, x: h2, y: c2 } = this.tileID.canonical, u2 = { z: l2, x: h2, y: c2 };
for (let i4 = 0; i4 < r2.length; i4++) {
const a3 = r2.feature(i4);
if (n2.needGeometry) {
const e3 = t.a7(a3, true);
if (!n2.filter(new t.a8(this.tileID.overscaledZ), e3, this.tileID.canonical)) continue;
} else if (!n2.filter(new t.a8(this.tileID.overscaledZ), a3)) continue;
const d2 = s2.getId(a3, o2), _2 = new t.a9(a3, l2, h2, c2, d2);
_2.tile = u2, e2.push(_2);
}
}
hasData() {
return "loaded" === this.state || "reloading" === this.state || "expired" === this.state;
}
patternsLoaded() {
return this.imageAtlas && !!Object.keys(this.imageAtlas.patternPositions).length;
}
setExpiryData(e2) {
const i3 = this.expirationTime;
if (e2.cacheControl) {
const i4 = t.aa(e2.cacheControl);
i4["max-age"] && (this.expirationTime = Date.now() + 1e3 * i4["max-age"]);
} else e2.expires && (this.expirationTime = new Date(e2.expires).getTime());
if (this.expirationTime) {
const t2 = Date.now();
let e3 = false;
if (this.expirationTime > t2) e3 = false;
else if (i3) if (this.expirationTime < i3) e3 = true;
else {
const s2 = this.expirationTime - i3;
s2 ? this.expirationTime = t2 + Math.max(s2, 3e4) : e3 = true;
}
else e3 = true;
e3 ? (this.expiredRequestCount++, this.state = "expired") : this.expiredRequestCount = 0;
}
}
getExpiryTimeout() {
if (this.expirationTime) return this.expiredRequestCount ? 1e3 * (1 << Math.min(this.expiredRequestCount - 1, 31)) : Math.min(this.expirationTime - (/* @__PURE__ */ new Date()).getTime(), Math.pow(2, 31) - 1);
}
setFeatureState(t2, e2) {
if (!this.latestFeatureIndex || !this.latestFeatureIndex.rawTileData || 0 === Object.keys(t2).length) return;
const i3 = this.latestFeatureIndex.loadVTLayers();
for (const s2 in this.buckets) {
if (!e2.style.hasLayer(s2)) continue;
const a2 = this.buckets[s2], o2 = a2.layers[0].sourceLayer || "_geojsonTileLayer", r2 = i3[o2], n2 = t2[o2];
if (!r2 || !n2 || 0 === Object.keys(n2).length) continue;
a2.update(n2, r2, this.imageAtlas && this.imageAtlas.patternPositions || {});
const l2 = e2 && e2.style && e2.style.getLayer(s2);
l2 && (this.queryPadding = Math.max(this.queryPadding, l2.queryRadius(a2)));
}
}
holdingForFade() {
return void 0 !== this.symbolFadeHoldUntil;
}
symbolFadeFinished() {
return !this.symbolFadeHoldUntil || this.symbolFadeHoldUntil < t.h.now();
}
clearFadeHold() {
this.symbolFadeHoldUntil = void 0;
}
setHoldDuration(e2) {
this.symbolFadeHoldUntil = t.h.now() + e2;
}
setDependencies(t2, e2) {
const i3 = {};
for (const t3 of e2) i3[t3] = true;
this.dependencies[t2] = i3;
}
hasDependency(t2, e2) {
for (const i3 of t2) {
const t3 = this.dependencies[i3];
if (t3) {
for (const i4 of e2) if (t3[i4]) return true;
}
}
return false;
}
}
class H {
constructor(t2, e2) {
this.max = t2, this.onRemove = e2, this.reset();
}
reset() {
for (const t2 in this.data) for (const e2 of this.data[t2]) e2.timeout && clearTimeout(e2.timeout), this.onRemove(e2.value);
return this.data = {}, this.order = [], this;
}
add(t2, e2, i3) {
const s2 = t2.wrapped().key;
void 0 === this.data[s2] && (this.data[s2] = []);
const a2 = { value: e2, timeout: void 0 };
if (void 0 !== i3 && (a2.timeout = setTimeout((() => {
this.remove(t2, a2);
}), i3)), this.data[s2].push(a2), this.order.push(s2), this.order.length > this.max) {
const t3 = this._getAndRemoveByKey(this.order[0]);
t3 && this.onRemove(t3);
}
return this;
}
has(t2) {
return t2.wrapped().key in this.data;
}
getAndRemove(t2) {
return this.has(t2) ? this._getAndRemoveByKey(t2.wrapped().key) : null;
}
_getAndRemoveByKey(t2) {
const e2 = this.data[t2].shift();
return e2.timeout && clearTimeout(e2.timeout), 0 === this.data[t2].length && delete this.data[t2], this.order.splice(this.order.indexOf(t2), 1), e2.value;
}
getByKey(t2) {
const e2 = this.data[t2];
return e2 ? e2[0].value : null;
}
get(t2) {
return this.has(t2) ? this.data[t2.wrapped().key][0].value : null;
}
remove(t2, e2) {
if (!this.has(t2)) return this;
const i3 = t2.wrapped().key, s2 = void 0 === e2 ? 0 : this.data[i3].indexOf(e2), a2 = this.data[i3][s2];
return this.data[i3].splice(s2, 1), a2.timeout && clearTimeout(a2.timeout), 0 === this.data[i3].length && delete this.data[i3], this.onRemove(a2.value), this.order.splice(this.order.indexOf(i3), 1), this;
}
setMaxSize(t2) {
for (this.max = t2; this.order.length > this.max; ) {
const t3 = this._getAndRemoveByKey(this.order[0]);
t3 && this.onRemove(t3);
}
return this;
}
filter(t2) {
const e2 = [];
for (const i3 in this.data) for (const s2 of this.data[i3]) t2(s2.value) || e2.push(s2);
for (const t3 of e2) this.remove(t3.value.tileID, t3);
}
}
class X {
constructor() {
this.state = {}, this.stateChanges = {}, this.deletedStates = {};
}
updateState(e2, i3, s2) {
const a2 = String(i3);
if (this.stateChanges[e2] = this.stateChanges[e2] || {}, this.stateChanges[e2][a2] = this.stateChanges[e2][a2] || {}, t.e(this.stateChanges[e2][a2], s2), null === this.deletedStates[e2]) {
this.deletedStates[e2] = {};
for (const t2 in this.state[e2]) t2 !== a2 && (this.deletedStates[e2][t2] = null);
} else if (this.deletedStates[e2] && null === this.deletedStates[e2][a2]) {
this.deletedStates[e2][a2] = {};
for (const t2 in this.state[e2][a2]) s2[t2] || (this.deletedStates[e2][a2][t2] = null);
} else for (const t2 in s2) this.deletedStates[e2] && this.deletedStates[e2][a2] && null === this.deletedStates[e2][a2][t2] && delete this.deletedStates[e2][a2][t2];
}
removeFeatureState(t2, e2, i3) {
if (null === this.deletedStates[t2]) return;
const s2 = String(e2);
if (this.deletedStates[t2] = this.deletedStates[t2] || {}, i3 && void 0 !== e2) null !== this.deletedStates[t2][s2] && (this.deletedStates[t2][s2] = this.deletedStates[t2][s2] || {}, this.deletedStates[t2][s2][i3] = null);
else if (void 0 !== e2) if (this.stateChanges[t2] && this.stateChanges[t2][s2]) for (i3 in this.deletedStates[t2][s2] = {}, this.stateChanges[t2][s2]) this.deletedStates[t2][s2][i3] = null;
else this.deletedStates[t2][s2] = null;
else this.deletedStates[t2] = null;
}
getState(e2, i3) {
const s2 = String(i3), a2 = t.e({}, (this.state[e2] || {})[s2], (this.stateChanges[e2] || {})[s2]);
if (null === this.deletedStates[e2]) return {};
if (this.deletedStates[e2]) {
const t2 = this.deletedStates[e2][i3];
if (null === t2) return {};
for (const e3 in t2) delete a2[e3];
}
return a2;
}
initializeTileState(t2, e2) {
t2.setFeatureState(this.state, e2);
}
coalesceChanges(e2, i3) {
const s2 = {};
for (const e3 in this.stateChanges) {
this.state[e3] = this.state[e3] || {};
const i4 = {};
for (const s3 in this.stateChanges[e3]) this.state[e3][s3] || (this.state[e3][s3] = {}), t.e(this.state[e3][s3], this.stateChanges[e3][s3]), i4[s3] = this.state[e3][s3];
s2[e3] = i4;
}
for (const e3 in this.deletedStates) {
this.state[e3] = this.state[e3] || {};
const i4 = {};
if (null === this.deletedStates[e3]) for (const t2 in this.state[e3]) i4[t2] = {}, this.state[e3][t2] = {};
else for (const t2 in this.deletedStates[e3]) {
if (null === this.deletedStates[e3][t2]) this.state[e3][t2] = {};
else for (const i5 of Object.keys(this.deletedStates[e3][t2])) delete this.state[e3][t2][i5];
i4[t2] = this.state[e3][t2];
}
s2[e3] = s2[e3] || {}, t.e(s2[e3], i4);
}
if (this.stateChanges = {}, this.deletedStates = {}, 0 !== Object.keys(s2).length) for (const t2 in e2) e2[t2].setFeatureState(s2, i3);
}
}
class K extends t.E {
constructor(t2, e2, i3) {
super(), this.id = t2, this.dispatcher = i3, this.on("data", ((t3) => {
"source" === t3.dataType && "metadata" === t3.sourceDataType && (this._sourceLoaded = true), this._sourceLoaded && !this._paused && "source" === t3.dataType && "content" === t3.sourceDataType && (this.reload(), this.transform && this.update(this.transform, this.terrain), this._didEmitContent = true);
})), this.on("dataloading", (() => {
this._sourceErrored = false;
})), this.on("error", (() => {
this._sourceErrored = this._source.loaded();
})), this._source = ((t3, e3, i4, s2) => {
const a2 = new (j(e3.type))(t3, e3, i4, s2);
if (a2.id !== t3) throw new Error(`Expected Source id to be ${t3} instead of ${a2.id}`);
return a2;
})(t2, e2, i3, this), this._tiles = {}, this._cache = new H(0, this._unloadTile.bind(this)), this._timers = {}, this._cacheTimers = {}, this._maxTileCacheSize = null, this._maxTileCacheZoomLevels = null, this._loadedParentTiles = {}, this._coveredTiles = {}, this._state = new X(), this._didEmitContent = false, this._updated = false;
}
onAdd(t2) {
this.map = t2, this._maxTileCacheSize = t2 ? t2._maxTileCacheSize : null, this._maxTileCacheZoomLevels = t2 ? t2._maxTileCacheZoomLevels : null, this._source && this._source.onAdd && this._source.onAdd(t2);
}
onRemove(t2) {
this.clearTiles(), this._source && this._source.onRemove && this._source.onRemove(t2);
}
loaded() {
if (this._sourceErrored) return true;
if (!this._sourceLoaded) return false;
if (!this._source.loaded()) return false;
if (!(void 0 === this.used && void 0 === this.usedForTerrain || this.used || this.usedForTerrain)) return true;
if (!this._updated) return false;
for (const t2 in this._tiles) {
const e2 = this._tiles[t2];
if ("loaded" !== e2.state && "errored" !== e2.state) return false;
}
return true;
}
getSource() {
return this._source;
}
pause() {
this._paused = true;
}
resume() {
if (!this._paused) return;
const t2 = this._shouldReloadOnResume;
this._paused = false, this._shouldReloadOnResume = false, t2 && this.reload(), this.transform && this.update(this.transform, this.terrain);
}
_loadTile(t2, e2) {
return this._source.loadTile(t2, e2);
}
_unloadTile(t2) {
if (this._source.unloadTile) return this._source.unloadTile(t2, (() => {
}));
}
_abortTile(e2) {
this._source.abortTile && this._source.abortTile(e2, (() => {
})), this._source.fire(new t.k("dataabort", { tile: e2, coord: e2.tileID, dataType: "source" }));
}
serialize() {
return this._source.serialize();
}
prepare(t2) {
this._source.prepare && this._source.prepare(), this._state.coalesceChanges(this._tiles, this.map ? this.map.painter : null);
for (const e2 in this._tiles) {
const i3 = this._tiles[e2];
i3.upload(t2), i3.prepare(this.map.style.imageManager);
}
}
getIds() {
return Object.values(this._tiles).map(((t2) => t2.tileID)).sort(Q).map(((t2) => t2.key));
}
getRenderableIds(e2) {
const i3 = [];
for (const t2 in this._tiles) this._isIdRenderable(t2, e2) && i3.push(this._tiles[t2]);
return e2 ? i3.sort(((e3, i4) => {
const s2 = e3.tileID, a2 = i4.tileID, o2 = new t.P(s2.canonical.x, s2.canonical.y)._rotate(this.transform.angle), r2 = new t.P(a2.canonical.x, a2.canonical.y)._rotate(this.transform.angle);
return s2.overscaledZ - a2.overscaledZ || r2.y - o2.y || r2.x - o2.x;
})).map(((t2) => t2.tileID.key)) : i3.map(((t2) => t2.tileID)).sort(Q).map(((t2) => t2.key));
}
hasRenderableParent(t2) {
const e2 = this.findLoadedParent(t2, 0);
return !!e2 && this._isIdRenderable(e2.tileID.key);
}
_isIdRenderable(t2, e2) {
return this._tiles[t2] && this._tiles[t2].hasData() && !this._coveredTiles[t2] && (e2 || !this._tiles[t2].holdingForFade());
}
reload() {
if (this._paused) this._shouldReloadOnResume = true;
else {
this._cache.reset();
for (const t2 in this._tiles) "errored" !== this._tiles[t2].state && this._reloadTile(t2, "reloading");
}
}
_reloadTile(t2, e2) {
const i3 = this._tiles[t2];
i3 && ("loading" !== i3.state && (i3.state = e2), this._loadTile(i3, this._tileLoaded.bind(this, i3, t2, e2)));
}
_tileLoaded(e2, i3, s2, a2) {
if (a2) return e2.state = "errored", void (404 !== a2.status ? this._source.fire(new t.j(a2, { tile: e2 })) : this.update(this.transform, this.terrain));
e2.timeAdded = t.h.now(), "expired" === s2 && (e2.refreshedUponExpiration = true), this._setTileReloadTimer(i3, e2), "raster-dem" === this.getSource().type && e2.dem && this._backfillDEM(e2), this._state.initializeTileState(e2, this.map ? this.map.painter : null), e2.aborted || this._source.fire(new t.k("data", { dataType: "source", tile: e2, coord: e2.tileID }));
}
_backfillDEM(t2) {
const e2 = this.getRenderableIds();
for (let s2 = 0; s2 < e2.length; s2++) {
const a2 = e2[s2];
if (t2.neighboringTiles && t2.neighboringTiles[a2]) {
const e3 = this.getTileByID(a2);
i3(t2, e3), i3(e3, t2);
}
}
function i3(t3, e3) {
t3.needsHillshadePrepare = true, t3.needsTerrainPrepare = true;
let i4 = e3.tileID.canonical.x - t3.tileID.canonical.x;
const s2 = e3.tileID.canonical.y - t3.tileID.canonical.y, a2 = Math.pow(2, t3.tileID.canonical.z), o2 = e3.tileID.key;
0 === i4 && 0 === s2 || Math.abs(s2) > 1 || (Math.abs(i4) > 1 && (1 === Math.abs(i4 + a2) ? i4 += a2 : 1 === Math.abs(i4 - a2) && (i4 -= a2)), e3.dem && t3.dem && (t3.dem.backfillBorder(e3.dem, i4, s2), t3.neighboringTiles && t3.neighboringTiles[o2] && (t3.neighboringTiles[o2].backfilled = true)));
}
}
getTile(t2) {
return this.getTileByID(t2.key);
}
getTileByID(t2) {
return this._tiles[t2];
}
_retainLoadedChildren(t2, e2, i3, s2) {
for (const a2 in this._tiles) {
let o2 = this._tiles[a2];
if (s2[a2] || !o2.hasData() || o2.tileID.overscaledZ <= e2 || o2.tileID.overscaledZ > i3) continue;
let r2 = o2.tileID;
for (; o2 && o2.tileID.overscaledZ > e2 + 1; ) {
const t3 = o2.tileID.scaledTo(o2.tileID.overscaledZ - 1);
o2 = this._tiles[t3.key], o2 && o2.hasData() && (r2 = t3);
}
let n2 = r2;
for (; n2.overscaledZ > e2; ) if (n2 = n2.scaledTo(n2.overscaledZ - 1), t2[n2.key]) {
s2[r2.key] = r2;
break;
}
}
}
findLoadedParent(t2, e2) {
if (t2.key in this._loadedParentTiles) {
const i3 = this._loadedParentTiles[t2.key];
return i3 && i3.tileID.overscaledZ >= e2 ? i3 : null;
}
for (let i3 = t2.overscaledZ - 1; i3 >= e2; i3--) {
const e3 = t2.scaledTo(i3), s2 = this._getLoadedTile(e3);
if (s2) return s2;
}
}
_getLoadedTile(t2) {
const e2 = this._tiles[t2.key];
return e2 && e2.hasData() ? e2 : this._cache.getByKey(t2.wrapped().key);
}
updateCacheSize(e2) {
const i3 = Math.ceil(e2.width / this._source.tileSize) + 1, s2 = Math.ceil(e2.height / this._source.tileSize) + 1, a2 = Math.floor(i3 * s2 * (null === this._maxTileCacheZoomLevels ? t.c.MAX_TILE_CACHE_ZOOM_LEVELS : this._maxTileCacheZoomLevels)), o2 = "number" == typeof this._maxTileCacheSize ? Math.min(this._maxTileCacheSize, a2) : a2;
this._cache.setMaxSize(o2);
}
handleWrapJump(t2) {
const e2 = Math.round((t2 - (void 0 === this._prevLng ? t2 : this._prevLng)) / 360);
if (this._prevLng = t2, e2) {
const t3 = {};
for (const i3 in this._tiles) {
const s2 = this._tiles[i3];
s2.tileID = s2.tileID.unwrapTo(s2.tileID.wrap + e2), t3[s2.tileID.key] = s2;
}
this._tiles = t3;
for (const t4 in this._timers) clearTimeout(this._timers[t4]), delete this._timers[t4];
for (const t4 in this._tiles) this._setTileReloadTimer(t4, this._tiles[t4]);
}
}
update(e2, i3) {
if (this.transform = e2, this.terrain = i3, !this._sourceLoaded || this._paused) return;
let s2;
this.updateCacheSize(e2), this.handleWrapJump(this.transform.center.lng), this._coveredTiles = {}, this.used || this.usedForTerrain ? this._source.tileID ? s2 = e2.getVisibleUnwrappedCoordinates(this._source.tileID).map(((e3) => new t.O(e3.canonical.z, e3.wrap, e3.canonical.z, e3.canonical.x, e3.canonical.y))) : (s2 = e2.coveringTiles({ tileSize: this.usedForTerrain ? this.tileSize : this._source.tileSize, minzoom: this._source.minzoom, maxzoom: this._source.maxzoom, roundZoom: !this.usedForTerrain && this._source.roundZoom, reparseOverscaled: this._source.reparseOverscaled, terrain: i3 }), this._source.hasTile && (s2 = s2.filter(((t2) => this._source.hasTile(t2))))) : s2 = [];
const a2 = e2.coveringZoomLevel(this._source), o2 = Math.max(a2 - K.maxOverzooming, this._source.minzoom), r2 = Math.max(a2 + K.maxUnderzooming, this._source.minzoom);
if (this.usedForTerrain) {
const t2 = {};
for (const e3 of s2) if (e3.canonical.z > this._source.minzoom) {
const i4 = e3.scaledTo(e3.canonical.z - 1);
t2[i4.key] = i4;
const s3 = e3.scaledTo(Math.max(this._source.minzoom, Math.min(e3.canonical.z, 5)));
t2[s3.key] = s3;
}
s2 = s2.concat(Object.values(t2));
}
const n2 = 0 === s2.length && !this._updated && this._didEmitContent;
this._updated = true, n2 && this.fire(new t.k("data", { sourceDataType: "idle", dataType: "source", sourceId: this.id }));
const l2 = this._updateRetainedTiles(s2, a2);
if (Y(this._source.type)) {
const e3 = {}, n3 = {}, h3 = Object.keys(l2), c2 = t.h.now();
for (const t2 of h3) {
const i4 = l2[t2], s3 = this._tiles[t2];
if (!s3 || 0 !== s3.fadeEndTime && s3.fadeEndTime <= c2) continue;
const a3 = this.findLoadedParent(i4, o2);
a3 && (this._addTile(a3.tileID), e3[a3.tileID.key] = a3.tileID), n3[t2] = i4;
}
this._retainLoadedChildren(n3, a2, r2, l2);
for (const t2 in e3) l2[t2] || (this._coveredTiles[t2] = true, l2[t2] = e3[t2]);
if (i3) {
const t2 = {}, e4 = {};
for (const i4 of s2) this._tiles[i4.key].hasData() ? t2[i4.key] = i4 : e4[i4.key] = i4;
for (const i4 in e4) {
const s3 = e4[i4].children(this._source.maxzoom);
this._tiles[s3[0].key] && this._tiles[s3[1].key] && this._tiles[s3[2].key] && this._tiles[s3[3].key] && (t2[s3[0].key] = l2[s3[0].key] = s3[0], t2[s3[1].key] = l2[s3[1].key] = s3[1], t2[s3[2].key] = l2[s3[2].key] = s3[2], t2[s3[3].key] = l2[s3[3].key] = s3[3], delete e4[i4]);
}
for (const i4 in e4) {
const s3 = this.findLoadedParent(e4[i4], this._source.minzoom);
if (s3) {
t2[s3.tileID.key] = l2[s3.tileID.key] = s3.tileID;
for (const e5 in t2) t2[e5].isChildOf(s3.tileID) && delete t2[e5];
}
}
for (const e5 in this._tiles) t2[e5] || (this._coveredTiles[e5] = true);
}
}
for (const t2 in l2) this._tiles[t2].clearFadeHold();
const h2 = t.ab(this._tiles, l2);
for (const t2 of h2) {
const e3 = this._tiles[t2];
e3.hasSymbolBuckets && !e3.holdingForFade() ? e3.setHoldDuration(this.map._fadeDuration) : e3.hasSymbolBuckets && !e3.symbolFadeFinished() || this._removeTile(t2);
}
this._updateLoadedParentTileCache();
}
releaseSymbolFadeTiles() {
for (const t2 in this._tiles) this._tiles[t2].holdingForFade() && this._removeTile(t2);
}
_updateRetainedTiles(t2, e2) {
const i3 = {}, s2 = {}, a2 = Math.max(e2 - K.maxOverzooming, this._source.minzoom), o2 = Math.max(e2 + K.maxUnderzooming, this._source.minzoom), r2 = {};
for (const s3 of t2) {
const t3 = this._addTile(s3);
i3[s3.key] = s3, t3.hasData() || e2 < this._source.maxzoom && (r2[s3.key] = s3);
}
this._retainLoadedChildren(r2, e2, o2, i3);
for (const o3 of t2) {
let t3 = this._tiles[o3.key];
if (t3.hasData()) continue;
if (e2 + 1 > this._source.maxzoom) {
const t4 = o3.children(this._source.maxzoom)[0], e3 = this.getTile(t4);
if (e3 && e3.hasData()) {
i3[t4.key] = t4;
continue;
}
} else {
const t4 = o3.children(this._source.maxzoom);
if (i3[t4[0].key] && i3[t4[1].key] && i3[t4[2].key] && i3[t4[3].key]) continue;
}
let r3 = t3.wasRequested();
for (let e3 = o3.overscaledZ - 1; e3 >= a2; --e3) {
const a3 = o3.scaledTo(e3);
if (s2[a3.key]) break;
if (s2[a3.key] = true, t3 = this.getTile(a3), !t3 && r3 && (t3 = this._addTile(a3)), t3) {
const e4 = t3.hasData();
if ((r3 || e4) && (i3[a3.key] = a3), r3 = t3.wasRequested(), e4) break;
}
}
}
return i3;
}
_updateLoadedParentTileCache() {
this._loadedParentTiles = {};
for (const t2 in this._tiles) {
const e2 = [];
let i3, s2 = this._tiles[t2].tileID;
for (; s2.overscaledZ > 0; ) {
if (s2.key in this._loadedParentTiles) {
i3 = this._loadedParentTiles[s2.key];
break;
}
e2.push(s2.key);
const t3 = s2.scaledTo(s2.overscaledZ - 1);
if (i3 = this._getLoadedTile(t3), i3) break;
s2 = t3;
}
for (const t3 of e2) this._loadedParentTiles[t3] = i3;
}
}
_addTile(e2) {
let i3 = this._tiles[e2.key];
if (i3) return i3;
i3 = this._cache.getAndRemove(e2), i3 && (this._setTileReloadTimer(e2.key, i3), i3.tileID = e2, this._state.initializeTileState(i3, this.map ? this.map.painter : null), this._cacheTimers[e2.key] && (clearTimeout(this._cacheTimers[e2.key]), delete this._cacheTimers[e2.key], this._setTileReloadTimer(e2.key, i3)));
const s2 = i3;
return i3 || (i3 = new W(e2, this._source.tileSize * e2.overscaleFactor()), this._loadTile(i3, this._tileLoaded.bind(this, i3, e2.key, i3.state))), i3.uses++, this._tiles[e2.key] = i3, s2 || this._source.fire(new t.k("dataloading", { tile: i3, coord: i3.tileID, dataType: "source" })), i3;
}
_setTileReloadTimer(t2, e2) {
t2 in this._timers && (clearTimeout(this._timers[t2]), delete this._timers[t2]);
const i3 = e2.getExpiryTimeout();
i3 && (this._timers[t2] = setTimeout((() => {
this._reloadTile(t2, "expired"), delete this._timers[t2];
}), i3));
}
_removeTile(t2) {
const e2 = this._tiles[t2];
e2 && (e2.uses--, delete this._tiles[t2], this._timers[t2] && (clearTimeout(this._timers[t2]), delete this._timers[t2]), e2.uses > 0 || (e2.hasData() && "reloading" !== e2.state ? this._cache.add(e2.tileID, e2, e2.getExpiryTimeout()) : (e2.aborted = true, this._abortTile(e2), this._unloadTile(e2))));
}
clearTiles() {
this._shouldReloadOnResume = false, this._paused = false;
for (const t2 in this._tiles) this._removeTile(t2);
this._cache.reset();
}
tilesIn(e2, i3, s2) {
const a2 = [], o2 = this.transform;
if (!o2) return a2;
const r2 = s2 ? o2.getCameraQueryGeometry(e2) : e2, n2 = e2.map(((t2) => o2.pointCoordinate(t2, this.terrain))), l2 = r2.map(((t2) => o2.pointCoordinate(t2, this.terrain))), h2 = this.getIds();
let c2 = 1 / 0, u2 = 1 / 0, d2 = -1 / 0, _2 = -1 / 0;
for (const t2 of l2) c2 = Math.min(c2, t2.x), u2 = Math.min(u2, t2.y), d2 = Math.max(d2, t2.x), _2 = Math.max(_2, t2.y);
for (let e3 = 0; e3 < h2.length; e3++) {
const s3 = this._tiles[h2[e3]];
if (s3.holdingForFade()) continue;
const r3 = s3.tileID, p2 = Math.pow(2, o2.zoom - s3.tileID.overscaledZ), m2 = i3 * s3.queryPadding * t.N / s3.tileSize / p2, f2 = [r3.getTilePoint(new t.U(c2, u2)), r3.getTilePoint(new t.U(d2, _2))];
if (f2[0].x - m2 < t.N && f2[0].y - m2 < t.N && f2[1].x + m2 >= 0 && f2[1].y + m2 >= 0) {
const t2 = n2.map(((t3) => r3.getTilePoint(t3))), e4 = l2.map(((t3) => r3.getTilePoint(t3)));
a2.push({ tile: s3, tileID: r3, queryGeometry: t2, cameraQueryGeometry: e4, scale: p2 });
}
}
return a2;
}
getVisibleCoordinates(t2) {
const e2 = this.getRenderableIds(t2).map(((t3) => this._tiles[t3].tileID));
for (const t3 of e2) t3.posMatrix = this.transform.calculatePosMatrix(t3.toUnwrapped());
return e2;
}
hasTransition() {
if (this._source.hasTransition()) return true;
if (Y(this._source.type)) {
const e2 = t.h.now();
for (const t2 in this._tiles) if (this._tiles[t2].fadeEndTime >= e2) return true;
}
return false;
}
setFeatureState(t2, e2, i3) {
this._state.updateState(t2 = t2 || "_geojsonTileLayer", e2, i3);
}
removeFeatureState(t2, e2, i3) {
this._state.removeFeatureState(t2 = t2 || "_geojsonTileLayer", e2, i3);
}
getFeatureState(t2, e2) {
return this._state.getState(t2 = t2 || "_geojsonTileLayer", e2);
}
setDependencies(t2, e2, i3) {
const s2 = this._tiles[t2];
s2 && s2.setDependencies(e2, i3);
}
reloadTilesForDependencies(t2, e2) {
for (const i3 in this._tiles) this._tiles[i3].hasDependency(t2, e2) && this._reloadTile(i3, "reloading");
this._cache.filter(((i3) => !i3.hasDependency(t2, e2)));
}
}
function Q(t2, e2) {
const i3 = Math.abs(2 * t2.wrap) - +(t2.wrap < 0), s2 = Math.abs(2 * e2.wrap) - +(e2.wrap < 0);
return t2.overscaledZ - e2.overscaledZ || s2 - i3 || e2.canonical.y - t2.canonical.y || e2.canonical.x - t2.canonical.x;
}
function Y(t2) {
return "raster" === t2 || "image" === t2 || "video" === t2;
}
K.maxOverzooming = 10, K.maxUnderzooming = 3;
const J = "mapboxgl_preloaded_worker_pool";
class tt {
constructor() {
this.active = {};
}
acquire(e2) {
if (!this.workers) for (this.workers = []; this.workers.length < tt.workerCount; ) this.workers.push(new Worker(t.c.WORKER_URL));
return this.active[e2] = true, this.workers.slice();
}
release(t2) {
delete this.active[t2], 0 === this.numActive() && (this.workers.forEach(((t3) => {
t3.terminate();
})), this.workers = null);
}
isPreloaded() {
return !!this.active[J];
}
numActive() {
return Object.keys(this.active).length;
}
}
const et = Math.floor(t.h.hardwareConcurrency / 2);
let it;
function st() {
return it || (it = new tt()), it;
}
tt.workerCount = t.ac(globalThis) ? Math.max(Math.min(et, 3), 1) : 1;
class at {
constructor(t2, e2) {
this.reset(t2, e2);
}
reset(t2, e2) {
this.points = t2 || [], this._distances = [0];
for (let t3 = 1; t3 < this.points.length; t3++) this._distances[t3] = this._distances[t3 - 1] + this.points[t3].dist(this.points[t3 - 1]);
this.length = this._distances[this._distances.length - 1], this.padding = Math.min(e2 || 0, 0.5 * this.length), this.paddedLength = this.length - 2 * this.padding;
}
lerp(e2) {
if (1 === this.points.length) return this.points[0];
e2 = t.ad(e2, 0, 1);
let i3 = 1, s2 = this._distances[i3];
const a2 = e2 * this.paddedLength + this.padding;
for (; s2 < a2 && i3 < this._distances.length; ) s2 = this._distances[++i3];
const o2 = i3 - 1, r2 = this._distances[o2], n2 = s2 - r2, l2 = n2 > 0 ? (a2 - r2) / n2 : 0;
return this.points[o2].mult(1 - l2).add(this.points[i3].mult(l2));
}
}
function ot(t2, e2) {
let i3 = true;
return "always" === t2 || "never" !== t2 && "never" !== e2 || (i3 = false), i3;
}
class rt {
constructor(t2, e2, i3) {
const s2 = this.boxCells = [], a2 = this.circleCells = [];
this.xCellCount = Math.ceil(t2 / i3), this.yCellCount = Math.ceil(e2 / i3);
for (let t3 = 0; t3 < this.xCellCount * this.yCellCount; t3++) s2.push([]), a2.push([]);
this.circleKeys = [], this.boxKeys = [], this.bboxes = [], this.circles = [], this.width = t2, this.height = e2, this.xScale = this.xCellCount / t2, this.yScale = this.yCellCount / e2, this.boxUid = 0, this.circleUid = 0;
}
keysLength() {
return this.boxKeys.length + this.circleKeys.length;
}
insert(t2, e2, i3, s2, a2) {
this._forEachCell(e2, i3, s2, a2, this._insertBoxCell, this.boxUid++), this.boxKeys.push(t2), this.bboxes.push(e2), this.bboxes.push(i3), this.bboxes.push(s2), this.bboxes.push(a2);
}
insertCircle(t2, e2, i3, s2) {
this._forEachCell(e2 - s2, i3 - s2, e2 + s2, i3 + s2, this._insertCircleCell, this.circleUid++), this.circleKeys.push(t2), this.circles.push(e2), this.circles.push(i3), this.circles.push(s2);
}
_insertBoxCell(t2, e2, i3, s2, a2, o2) {
this.boxCells[a2].push(o2);
}
_insertCircleCell(t2, e2, i3, s2, a2, o2) {
this.circleCells[a2].push(o2);
}
_query(t2, e2, i3, s2, a2, o2, r2) {
if (i3 < 0 || t2 > this.width || s2 < 0 || e2 > this.height) return [];
const n2 = [];
if (t2 <= 0 && e2 <= 0 && this.width <= i3 && this.height <= s2) {
if (a2) return [{ key: null, x1: t2, y1: e2, x2: i3, y2: s2 }];
for (let t3 = 0; t3 < this.boxKeys.length; t3++) n2.push({ key: this.boxKeys[t3], x1: this.bboxes[4 * t3], y1: this.bboxes[4 * t3 + 1], x2: this.bboxes[4 * t3 + 2], y2: this.bboxes[4 * t3 + 3] });
for (let t3 = 0; t3 < this.circleKeys.length; t3++) {
const e3 = this.circles[3 * t3], i4 = this.circles[3 * t3 + 1], s3 = this.circles[3 * t3 + 2];
n2.push({ key: this.circleKeys[t3], x1: e3 - s3, y1: i4 - s3, x2: e3 + s3, y2: i4 + s3 });
}
} else this._forEachCell(t2, e2, i3, s2, this._queryCell, n2, { hitTest: a2, overlapMode: o2, seenUids: { box: {}, circle: {} } }, r2);
return n2;
}
query(t2, e2, i3, s2) {
return this._query(t2, e2, i3, s2, false, null);
}
hitTest(t2, e2, i3, s2, a2, o2) {
return this._query(t2, e2, i3, s2, true, a2, o2).length > 0;
}
hitTestCircle(t2, e2, i3, s2, a2) {
const o2 = t2 - i3, r2 = t2 + i3, n2 = e2 - i3, l2 = e2 + i3;
if (r2 < 0 || o2 > this.width || l2 < 0 || n2 > this.height) return false;
const h2 = [];
return this._forEachCell(o2, n2, r2, l2, this._queryCellCircle, h2, { hitTest: true, overlapMode: s2, circle: { x: t2, y: e2, radius: i3 }, seenUids: { box: {}, circle: {} } }, a2), h2.length > 0;
}
_queryCell(t2, e2, i3, s2, a2, o2, r2, n2) {
const { seenUids: l2, hitTest: h2, overlapMode: c2 } = r2, u2 = this.boxCells[a2];
if (null !== u2) {
const a3 = this.bboxes;
for (const r3 of u2) if (!l2.box[r3]) {
l2.box[r3] = true;
const u3 = 4 * r3, d3 = this.boxKeys[r3];
if (t2 <= a3[u3 + 2] && e2 <= a3[u3 + 3] && i3 >= a3[u3 + 0] && s2 >= a3[u3 + 1] && (!n2 || n2(d3)) && (!h2 || !ot(c2, d3.overlapMode)) && (o2.push({ key: d3, x1: a3[u3], y1: a3[u3 + 1], x2: a3[u3 + 2], y2: a3[u3 + 3] }), h2)) return true;
}
}
const d2 = this.circleCells[a2];
if (null !== d2) {
const a3 = this.circles;
for (const r3 of d2) if (!l2.circle[r3]) {
l2.circle[r3] = true;
const u3 = 3 * r3, d3 = this.circleKeys[r3];
if (this._circleAndRectCollide(a3[u3], a3[u3 + 1], a3[u3 + 2], t2, e2, i3, s2) && (!n2 || n2(d3)) && (!h2 || !ot(c2, d3.overlapMode))) {
const t3 = a3[u3], e3 = a3[u3 + 1], i4 = a3[u3 + 2];
if (o2.push({ key: d3, x1: t3 - i4, y1: e3 - i4, x2: t3 + i4, y2: e3 + i4 }), h2) return true;
}
}
}
return false;
}
_queryCellCircle(t2, e2, i3, s2, a2, o2, r2, n2) {
const { circle: l2, seenUids: h2, overlapMode: c2 } = r2, u2 = this.boxCells[a2];
if (null !== u2) {
const t3 = this.bboxes;
for (const e3 of u2) if (!h2.box[e3]) {
h2.box[e3] = true;
const i4 = 4 * e3, s3 = this.boxKeys[e3];
if (this._circleAndRectCollide(l2.x, l2.y, l2.radius, t3[i4 + 0], t3[i4 + 1], t3[i4 + 2], t3[i4 + 3]) && (!n2 || n2(s3)) && !ot(c2, s3.overlapMode)) return o2.push(true), true;
}
}
const d2 = this.circleCells[a2];
if (null !== d2) {
const t3 = this.circles;
for (const e3 of d2) if (!h2.circle[e3]) {
h2.circle[e3] = true;
const i4 = 3 * e3, s3 = this.circleKeys[e3];
if (this._circlesCollide(t3[i4], t3[i4 + 1], t3[i4 + 2], l2.x, l2.y, l2.radius) && (!n2 || n2(s3)) && !ot(c2, s3.overlapMode)) return o2.push(true), true;
}
}
}
_forEachCell(t2, e2, i3, s2, a2, o2, r2, n2) {
const l2 = this._convertToXCellCoord(t2), h2 = this._convertToYCellCoord(e2), c2 = this._convertToXCellCoord(i3), u2 = this._convertToYCellCoord(s2);
for (let d2 = l2; d2 <= c2; d2++) for (let l3 = h2; l3 <= u2; l3++) if (a2.call(this, t2, e2, i3, s2, this.xCellCount * l3 + d2, o2, r2, n2)) return;
}
_convertToXCellCoord(t2) {
return Math.max(0, Math.min(this.xCellCount - 1, Math.floor(t2 * this.xScale)));
}
_convertToYCellCoord(t2) {
return Math.max(0, Math.min(this.yCellCount - 1, Math.floor(t2 * this.yScale)));
}
_circlesCollide(t2, e2, i3, s2, a2, o2) {
const r2 = s2 - t2, n2 = a2 - e2, l2 = i3 + o2;
return l2 * l2 > r2 * r2 + n2 * n2;
}
_circleAndRectCollide(t2, e2, i3, s2, a2, o2, r2) {
const n2 = (o2 - s2) / 2, l2 = Math.abs(t2 - (s2 + n2));
if (l2 > n2 + i3) return false;
const h2 = (r2 - a2) / 2, c2 = Math.abs(e2 - (a2 + h2));
if (c2 > h2 + i3) return false;
if (l2 <= n2 || c2 <= h2) return true;
const u2 = l2 - n2, d2 = c2 - h2;
return u2 * u2 + d2 * d2 <= i3 * i3;
}
}
function nt(e2, i3, s2, a2, o2) {
const r2 = t.Z();
return i3 ? (t.a0(r2, r2, [1 / o2, 1 / o2, 1]), s2 || t.ae(r2, r2, a2.angle)) : t.a1(r2, a2.labelPlaneMatrix, e2), r2;
}
function lt(e2, i3, s2, a2, o2) {
if (i3) {
const i4 = t.af(e2);
return t.a0(i4, i4, [o2, o2, 1]), s2 || t.ae(i4, i4, -a2.angle), i4;
}
return a2.glCoordMatrix;
}
function ht(e2, i3, s2) {
let a2;
s2 ? (a2 = [e2.x, e2.y, s2(e2.x, e2.y), 1], t.ag(a2, a2, i3)) : (a2 = [e2.x, e2.y, 0, 1], Tt(a2, a2, i3));
const o2 = a2[3];
return { point: new t.P(a2[0] / o2, a2[1] / o2), signedDistanceFromCamera: o2 };
}
function ct(t2, e2) {
return 0.5 + t2 / e2 * 0.5;
}
function ut(t2, e2) {
const i3 = t2[0] / t2[3], s2 = t2[1] / t2[3];
return i3 >= -e2[0] && i3 <= e2[0] && s2 >= -e2[1] && s2 <= e2[1];
}
function dt(e2, i3, s2, a2, o2, r2, n2, l2, h2, c2) {
const u2 = a2 ? e2.textSizeData : e2.iconSizeData, d2 = t.ah(u2, s2.transform.zoom), _2 = [256 / s2.width * 2 + 1, 256 / s2.height * 2 + 1], p2 = a2 ? e2.text.dynamicLayoutVertexArray : e2.icon.dynamicLayoutVertexArray;
p2.clear();
const m2 = e2.lineVertexArray, f2 = a2 ? e2.text.placedSymbolArray : e2.icon.placedSymbolArray, g2 = s2.transform.width / s2.transform.height;
let v2 = false;
for (let a3 = 0; a3 < f2.length; a3++) {
const x2 = f2.get(a3);
if (x2.hidden || x2.writingMode === t.ai.vertical && !v2) {
wt(x2.numGlyphs, p2);
continue;
}
let y2;
if (v2 = false, c2 ? (y2 = [x2.anchorX, x2.anchorY, c2(x2.anchorX, x2.anchorY), 1], t.ag(y2, y2, i3)) : (y2 = [x2.anchorX, x2.anchorY, 0, 1], Tt(y2, y2, i3)), !ut(y2, _2)) {
wt(x2.numGlyphs, p2);
continue;
}
const b2 = ct(s2.transform.cameraToCenterDistance, y2[3]), w2 = t.aj(u2, d2, x2), T2 = n2 ? w2 / b2 : w2 * b2, I2 = new t.P(x2.anchorX, x2.anchorY), E2 = ht(I2, o2, c2).point, S2 = { projections: {}, offsets: {} }, C2 = mt(x2, T2, false, l2, i3, o2, r2, e2.glyphOffsetArray, m2, p2, E2, I2, S2, g2, h2, c2);
v2 = C2.useVertical, (C2.notEnoughRoom || v2 || C2.needsFlipping && mt(x2, T2, true, l2, i3, o2, r2, e2.glyphOffsetArray, m2, p2, E2, I2, S2, g2, h2, c2).notEnoughRoom) && wt(x2.numGlyphs, p2);
}
a2 ? e2.text.dynamicLayoutVertexBuffer.updateData(p2) : e2.icon.dynamicLayoutVertexBuffer.updateData(p2);
}
function _t(t2, e2, i3, s2, a2, o2, r2, n2, l2, h2, c2, u2, d2) {
const _2 = n2.glyphStartIndex + n2.numGlyphs, p2 = n2.lineStartIndex, m2 = n2.lineStartIndex + n2.lineLength, f2 = e2.getoffsetX(n2.glyphStartIndex), g2 = e2.getoffsetX(_2 - 1), v2 = yt(t2 * f2, i3, s2, a2, o2, r2, n2.segment, p2, m2, l2, h2, c2, u2, d2);
if (!v2) return null;
const x2 = yt(t2 * g2, i3, s2, a2, o2, r2, n2.segment, p2, m2, l2, h2, c2, u2, d2);
return x2 ? { first: v2, last: x2 } : null;
}
function pt(e2, i3, s2, a2) {
return e2 === t.ai.horizontal && Math.abs(s2.y - i3.y) > Math.abs(s2.x - i3.x) * a2 ? { useVertical: true } : (e2 === t.ai.vertical ? i3.y < s2.y : i3.x > s2.x) ? { needsFlipping: true } : null;
}
function mt(e2, i3, s2, a2, o2, r2, n2, l2, h2, c2, u2, d2, _2, p2, m2, f2) {
const g2 = i3 / 24, v2 = e2.lineOffsetX * g2, x2 = e2.lineOffsetY * g2;
let y2;
if (e2.numGlyphs > 1) {
const t2 = e2.glyphStartIndex + e2.numGlyphs, i4 = e2.lineStartIndex, o3 = e2.lineStartIndex + e2.lineLength, c3 = _t(g2, l2, v2, x2, s2, u2, d2, e2, h2, r2, _2, m2, f2);
if (!c3) return { notEnoughRoom: true };
const b2 = ht(c3.first.point, n2, f2).point, w2 = ht(c3.last.point, n2, f2).point;
if (a2 && !s2) {
const t3 = pt(e2.writingMode, b2, w2, p2);
if (t3) return t3;
}
y2 = [c3.first];
for (let a3 = e2.glyphStartIndex + 1; a3 < t2 - 1; a3++) y2.push(yt(g2 * l2.getoffsetX(a3), v2, x2, s2, u2, d2, e2.segment, i4, o3, h2, r2, _2, m2, f2));
y2.push(c3.last);
} else {
if (a2 && !s2) {
const i5 = ht(d2, o2, f2).point, s3 = e2.lineStartIndex + e2.segment + 1, a3 = new t.P(h2.getx(s3), h2.gety(s3)), r3 = ht(a3, o2, f2), n3 = r3.signedDistanceFromCamera > 0 ? r3.point : ft(d2, a3, i5, 1, o2, f2), l3 = pt(e2.writingMode, i5, n3, p2);
if (l3) return l3;
}
const i4 = yt(g2 * l2.getoffsetX(e2.glyphStartIndex), v2, x2, s2, u2, d2, e2.segment, e2.lineStartIndex, e2.lineStartIndex + e2.lineLength, h2, r2, _2, m2, f2);
if (!i4) return { notEnoughRoom: true };
y2 = [i4];
}
for (const e3 of y2) t.ak(c2, e3.point, e3.angle);
return {};
}
function ft(t2, e2, i3, s2, a2, o2) {
const r2 = ht(t2.add(t2.sub(e2)._unit()), a2, o2).point, n2 = i3.sub(r2);
return i3.add(n2._mult(s2 / n2.mag()));
}
function gt(e2, i3) {
const { projectionCache: s2, lineVertexArray: a2, labelPlaneMatrix: o2, tileAnchorPoint: r2, distanceFromAnchor: n2, getElevation: l2, previousVertex: h2, direction: c2, absOffsetX: u2 } = i3;
if (s2.projections[e2]) return s2.projections[e2];
const d2 = new t.P(a2.getx(e2), a2.gety(e2)), _2 = ht(d2, o2, l2);
if (_2.signedDistanceFromCamera > 0) return s2.projections[e2] = _2.point, _2.point;
const p2 = e2 - c2;
return ft(0 === n2 ? r2 : new t.P(a2.getx(p2), a2.gety(p2)), d2, h2, u2 - n2 + 1, o2, l2);
}
function vt(t2, e2, i3) {
return t2._unit()._perp()._mult(e2 * i3);
}
function xt(e2, i3, s2, a2, o2, r2, n2, l2) {
const { projectionCache: h2, direction: c2 } = l2;
if (h2.offsets[e2]) return h2.offsets[e2];
const u2 = s2.add(i3);
if (e2 + c2 < a2 || e2 + c2 >= o2) return h2.offsets[e2] = u2, u2;
const d2 = gt(e2 + c2, l2), _2 = vt(d2.sub(s2), n2, c2), p2 = s2.add(_2), m2 = d2.add(_2);
return h2.offsets[e2] = t.al(r2, u2, p2, m2) || u2, h2.offsets[e2];
}
function yt(t2, e2, i3, s2, a2, o2, r2, n2, l2, h2, c2, u2, d2, _2) {
const p2 = s2 ? t2 - e2 : t2 + e2;
let m2 = p2 > 0 ? 1 : -1, f2 = 0;
s2 && (m2 *= -1, f2 = Math.PI), m2 < 0 && (f2 += Math.PI);
let g2, v2, x2 = m2 > 0 ? n2 + r2 : n2 + r2 + 1, y2 = a2, b2 = a2, w2 = 0, T2 = 0;
const I2 = Math.abs(p2), E2 = [];
let S2;
for (; w2 + T2 <= I2; ) {
if (x2 += m2, x2 < n2 || x2 >= l2) return null;
w2 += T2, b2 = y2, v2 = g2;
const t3 = { projectionCache: u2, lineVertexArray: h2, labelPlaneMatrix: c2, tileAnchorPoint: o2, distanceFromAnchor: w2, getElevation: _2, previousVertex: b2, direction: m2, absOffsetX: I2 };
if (y2 = gt(x2, t3), 0 === i3) E2.push(b2), S2 = y2.sub(b2);
else {
let e3;
const s3 = y2.sub(b2);
e3 = 0 === s3.mag() ? vt(gt(x2 + m2, t3).sub(y2), i3, m2) : vt(s3, i3, m2), v2 || (v2 = b2.add(e3)), g2 = xt(x2, e3, y2, n2, l2, v2, i3, t3), E2.push(v2), S2 = g2.sub(v2);
}
T2 = S2.mag();
}
const C2 = S2._mult((I2 - w2) / T2)._add(v2 || b2), P2 = f2 + Math.atan2(y2.y - b2.y, y2.x - b2.x);
return E2.push(C2), { point: C2, angle: d2 ? P2 : 0, path: E2 };
}
const bt = new Float32Array([-1 / 0, -1 / 0, 0, -1 / 0, -1 / 0, 0, -1 / 0, -1 / 0, 0, -1 / 0, -1 / 0, 0]);
function wt(t2, e2) {
for (let i3 = 0; i3 < t2; i3++) {
const t3 = e2.length;
e2.resize(t3 + 4), e2.float32.set(bt, 3 * t3);
}
}
function Tt(t2, e2, i3) {
const s2 = e2[0], a2 = e2[1];
return t2[0] = i3[0] * s2 + i3[4] * a2 + i3[12], t2[1] = i3[1] * s2 + i3[5] * a2 + i3[13], t2[3] = i3[3] * s2 + i3[7] * a2 + i3[15], t2;
}
const It = 100;
class Et {
constructor(t2, e2 = new rt(t2.width + 200, t2.height + 200, 25), i3 = new rt(t2.width + 200, t2.height + 200, 25)) {
this.transform = t2, this.grid = e2, this.ignoredGrid = i3, this.pitchfactor = Math.cos(t2._pitch) * t2.cameraToCenterDistance, this.screenRightBoundary = t2.width + It, this.screenBottomBoundary = t2.height + It, this.gridRightBoundary = t2.width + 200, this.gridBottomBoundary = t2.height + 200, this.perspectiveRatioCutoff = 0.6;
}
placeCollisionBox(t2, e2, i3, s2, a2, o2) {
const r2 = this.projectAndGetPerspectiveRatio(s2, t2.anchorPointX, t2.anchorPointY, o2), n2 = i3 * r2.perspectiveRatio, l2 = t2.x1 * n2 + r2.point.x, h2 = t2.y1 * n2 + r2.point.y, c2 = t2.x2 * n2 + r2.point.x, u2 = t2.y2 * n2 + r2.point.y;
return !this.isInsideGrid(l2, h2, c2, u2) || "always" !== e2 && this.grid.hitTest(l2, h2, c2, u2, e2, a2) || r2.perspectiveRatio < this.perspectiveRatioCutoff ? { box: [], offscreen: false } : { box: [l2, h2, c2, u2], offscreen: this.isOffscreen(l2, h2, c2, u2) };
}
placeCollisionCircles(e2, i3, s2, a2, o2, r2, n2, l2, h2, c2, u2, d2, _2, p2) {
const m2 = [], f2 = new t.P(i3.anchorX, i3.anchorY), g2 = ht(f2, r2, p2), v2 = ct(this.transform.cameraToCenterDistance, g2.signedDistanceFromCamera), x2 = (c2 ? o2 / v2 : o2 * v2) / t.ap, y2 = ht(f2, n2, p2).point, b2 = _t(x2, a2, i3.lineOffsetX * x2, i3.lineOffsetY * x2, false, y2, f2, i3, s2, n2, { projections: {}, offsets: {} }, false, p2);
let w2 = false, T2 = false, I2 = true;
if (b2) {
const i4 = 0.5 * d2 * v2 + _2, s3 = new t.P(-100, -100), a3 = new t.P(this.screenRightBoundary, this.screenBottomBoundary), o3 = new at(), r3 = b2.first, n3 = b2.last;
let c3 = [];
for (let t2 = r3.path.length - 1; t2 >= 1; t2--) c3.push(r3.path[t2]);
for (let t2 = 1; t2 < n3.path.length; t2++) c3.push(n3.path[t2]);
const f3 = 2.5 * i4;
if (l2) {
const t2 = c3.map(((t3) => ht(t3, l2, p2)));
c3 = t2.some(((t3) => t3.signedDistanceFromCamera <= 0)) ? [] : t2.map(((t3) => t3.point));
}
let g3 = [];
if (c3.length > 0) {
const e3 = c3[0].clone(), i5 = c3[0].clone();
for (let t2 = 1; t2 < c3.length; t2++) e3.x = Math.min(e3.x, c3[t2].x), e3.y = Math.min(e3.y, c3[t2].y), i5.x = Math.max(i5.x, c3[t2].x), i5.y = Math.max(i5.y, c3[t2].y);
g3 = e3.x >= s3.x && i5.x <= a3.x && e3.y >= s3.y && i5.y <= a3.y ? [c3] : i5.x < s3.x || e3.x > a3.x || i5.y < s3.y || e3.y > a3.y ? [] : t.am([c3], s3.x, s3.y, a3.x, a3.y);
}
for (const t2 of g3) {
o3.reset(t2, 0.25 * i4);
let s4 = 0;
s4 = o3.length <= 0.5 * i4 ? 1 : Math.ceil(o3.paddedLength / f3) + 1;
for (let t3 = 0; t3 < s4; t3++) {
const a4 = t3 / Math.max(s4 - 1, 1), r4 = o3.lerp(a4), n4 = r4.x + It, l3 = r4.y + It;
m2.push(n4, l3, i4, 0);
const c4 = n4 - i4, d3 = l3 - i4, _3 = n4 + i4, p3 = l3 + i4;
if (I2 = I2 && this.isOffscreen(c4, d3, _3, p3), T2 = T2 || this.isInsideGrid(c4, d3, _3, p3), "always" !== e2 && this.grid.hitTestCircle(n4, l3, i4, e2, u2) && (w2 = true, !h2)) return { circles: [], offscreen: false, collisionDetected: w2 };
}
}
}
return { circles: !h2 && w2 || !T2 || v2 < this.perspectiveRatioCutoff ? [] : m2, offscreen: I2, collisionDetected: w2 };
}
queryRenderedSymbols(e2) {
if (0 === e2.length || 0 === this.grid.keysLength() && 0 === this.ignoredGrid.keysLength()) return {};
const i3 = [];
let s2 = 1 / 0, a2 = 1 / 0, o2 = -1 / 0, r2 = -1 / 0;
for (const n3 of e2) {
const e3 = new t.P(n3.x + It, n3.y + It);
s2 = Math.min(s2, e3.x), a2 = Math.min(a2, e3.y), o2 = Math.max(o2, e3.x), r2 = Math.max(r2, e3.y), i3.push(e3);
}
const n2 = this.grid.query(s2, a2, o2, r2).concat(this.ignoredGrid.query(s2, a2, o2, r2)), l2 = {}, h2 = {};
for (const e3 of n2) {
const s3 = e3.key;
if (void 0 === l2[s3.bucketInstanceId] && (l2[s3.bucketInstanceId] = {}), l2[s3.bucketInstanceId][s3.featureIndex]) continue;
const a3 = [new t.P(e3.x1, e3.y1), new t.P(e3.x2, e3.y1), new t.P(e3.x2, e3.y2), new t.P(e3.x1, e3.y2)];
t.an(i3, a3) && (l2[s3.bucketInstanceId][s3.featureIndex] = true, void 0 === h2[s3.bucketInstanceId] && (h2[s3.bucketInstanceId] = []), h2[s3.bucketInstanceId].push(s3.featureIndex));
}
return h2;
}
insertCollisionBox(t2, e2, i3, s2, a2, o2) {
(i3 ? this.ignoredGrid : this.grid).insert({ bucketInstanceId: s2, featureIndex: a2, collisionGroupID: o2, overlapMode: e2 }, t2[0], t2[1], t2[2], t2[3]);
}
insertCollisionCircles(t2, e2, i3, s2, a2, o2) {
const r2 = i3 ? this.ignoredGrid : this.grid, n2 = { bucketInstanceId: s2, featureIndex: a2, collisionGroupID: o2, overlapMode: e2 };
for (let e3 = 0; e3 < t2.length; e3 += 4) r2.insertCircle(n2, t2[e3], t2[e3 + 1], t2[e3 + 2]);
}
projectAndGetPerspectiveRatio(e2, i3, s2, a2) {
let o2;
return a2 ? (o2 = [i3, s2, a2(i3, s2), 1], t.ag(o2, o2, e2)) : (o2 = [i3, s2, 0, 1], Tt(o2, o2, e2)), { point: new t.P((o2[0] / o2[3] + 1) / 2 * this.transform.width + It, (-o2[1] / o2[3] + 1) / 2 * this.transform.height + It), perspectiveRatio: 0.5 + this.transform.cameraToCenterDistance / o2[3] * 0.5 };
}
isOffscreen(t2, e2, i3, s2) {
return i3 < It || t2 >= this.screenRightBoundary || s2 < It || e2 > this.screenBottomBoundary;
}
isInsideGrid(t2, e2, i3, s2) {
return i3 >= 0 && t2 < this.gridRightBoundary && s2 >= 0 && e2 < this.gridBottomBoundary;
}
getViewportMatrix() {
const e2 = t.ao([]);
return t.$(e2, e2, [-100, -100, 0]), e2;
}
}
function St(e2, i3, s2) {
return i3 * (t.N / (e2.tileSize * Math.pow(2, s2 - e2.tileID.overscaledZ)));
}
class Ct {
constructor(t2, e2, i3, s2) {
this.opacity = t2 ? Math.max(0, Math.min(1, t2.opacity + (t2.placed ? e2 : -e2))) : s2 && i3 ? 1 : 0, this.placed = i3;
}
isHidden() {
return 0 === this.opacity && !this.placed;
}
}
class Pt {
constructor(t2, e2, i3, s2, a2) {
this.text = new Ct(t2 ? t2.text : null, e2, i3, a2), this.icon = new Ct(t2 ? t2.icon : null, e2, s2, a2);
}
isHidden() {
return this.text.isHidden() && this.icon.isHidden();
}
}
class Dt {
constructor(t2, e2, i3) {
this.text = t2, this.icon = e2, this.skipFade = i3;
}
}
class Mt {
constructor() {
this.invProjMatrix = t.Z(), this.viewportMatrix = t.Z(), this.circles = [];
}
}
class zt {
constructor(t2, e2, i3, s2, a2) {
this.bucketInstanceId = t2, this.featureIndex = e2, this.sourceLayerIndex = i3, this.bucketIndex = s2, this.tileID = a2;
}
}
class Lt {
constructor(t2) {
this.crossSourceCollisions = t2, this.maxGroupID = 0, this.collisionGroups = {};
}
get(t2) {
if (this.crossSourceCollisions) return { ID: 0, predicate: null };
if (!this.collisionGroups[t2]) {
const e2 = ++this.maxGroupID;
this.collisionGroups[t2] = { ID: e2, predicate: (t3) => t3.collisionGroupID === e2 };
}
return this.collisionGroups[t2];
}
}
function At(e2, i3, s2, a2, o2) {
const { horizontalAlign: r2, verticalAlign: n2 } = t.au(e2);
return new t.P(-(r2 - 0.5) * i3 + a2[0] * o2, -(n2 - 0.5) * s2 + a2[1] * o2);
}
function Rt(e2, i3, s2, a2, o2, r2) {
const { x1: n2, x2: l2, y1: h2, y2: c2, anchorPointX: u2, anchorPointY: d2 } = e2, _2 = new t.P(i3, s2);
return a2 && _2._rotate(o2 ? r2 : -r2), { x1: n2 + _2.x, y1: h2 + _2.y, x2: l2 + _2.x, y2: c2 + _2.y, anchorPointX: u2, anchorPointY: d2 };
}
class kt {
constructor(t2, e2, i3, s2, a2) {
this.transform = t2.clone(), this.terrain = e2, this.collisionIndex = new Et(this.transform), this.placements = {}, this.opacities = {}, this.variableOffsets = {}, this.stale = false, this.commitTime = 0, this.fadeDuration = i3, this.retainedQueryData = {}, this.collisionGroups = new Lt(s2), this.collisionCircleArrays = {}, this.prevPlacement = a2, a2 && (a2.prevPlacement = void 0), this.placedOrientations = {};
}
getBucketParts(e2, i3, s2, a2) {
const o2 = s2.getBucket(i3), r2 = s2.latestFeatureIndex;
if (!o2 || !r2 || i3.id !== o2.layerIds[0]) return;
const n2 = s2.collisionBoxArray, l2 = o2.layers[0].layout, h2 = Math.pow(2, this.transform.zoom - s2.tileID.overscaledZ), c2 = s2.tileSize / t.N, u2 = this.transform.calculatePosMatrix(s2.tileID.toUnwrapped()), d2 = "map" === l2.get("text-pitch-alignment"), _2 = "map" === l2.get("text-rotation-alignment"), p2 = St(s2, 1, this.transform.zoom), m2 = nt(u2, d2, _2, this.transform, p2);
let f2 = null;
if (d2) {
const e3 = lt(u2, d2, _2, this.transform, p2);
f2 = t.a1([], this.transform.labelPlaneMatrix, e3);
}
this.retainedQueryData[o2.bucketInstanceId] = new zt(o2.bucketInstanceId, r2, o2.sourceLayerIndex, o2.index, s2.tileID);
const g2 = { bucket: o2, layout: l2, posMatrix: u2, textLabelPlaneMatrix: m2, labelToScreenMatrix: f2, scale: h2, textPixelRatio: c2, holdingForFade: s2.holdingForFade(), collisionBoxArray: n2, partiallyEvaluatedTextSize: t.ah(o2.textSizeData, this.transform.zoom), collisionGroup: this.collisionGroups.get(o2.sourceID) };
if (a2) for (const t2 of o2.sortKeyRanges) {
const { sortKey: i4, symbolInstanceStart: s3, symbolInstanceEnd: a3 } = t2;
e2.push({ sortKey: i4, symbolInstanceStart: s3, symbolInstanceEnd: a3, parameters: g2 });
}
else e2.push({ symbolInstanceStart: 0, symbolInstanceEnd: o2.symbolInstances.length, parameters: g2 });
}
attemptAnchorPlacement(e2, i3, s2, a2, o2, r2, n2, l2, h2, c2, u2, d2, _2, p2, m2, f2) {
const g2 = t.aq[e2.textAnchor], v2 = [e2.textOffset0, e2.textOffset1], x2 = At(g2, s2, a2, v2, o2), y2 = this.collisionIndex.placeCollisionBox(Rt(i3, x2.x, x2.y, r2, n2, this.transform.angle), u2, l2, h2, c2.predicate, f2);
if ((!m2 || 0 !== this.collisionIndex.placeCollisionBox(Rt(m2, x2.x, x2.y, r2, n2, this.transform.angle), u2, l2, h2, c2.predicate, f2).box.length) && y2.box.length > 0) {
let t2;
if (this.prevPlacement && this.prevPlacement.variableOffsets[d2.crossTileID] && this.prevPlacement.placements[d2.crossTileID] && this.prevPlacement.placements[d2.crossTileID].text && (t2 = this.prevPlacement.variableOffsets[d2.crossTileID].anchor), 0 === d2.crossTileID) throw new Error("symbolInstance.crossTileID can't be 0");
return this.variableOffsets[d2.crossTileID] = { textOffset: v2, width: s2, height: a2, anchor: g2, textBoxScale: o2, prevAnchor: t2 }, this.markUsedJustification(_2, g2, d2, p2), _2.allowVerticalPlacement && (this.markUsedOrientation(_2, p2, d2), this.placedOrientations[d2.crossTileID] = p2), { shift: x2, placedGlyphBoxes: y2 };
}
}
placeLayerBucketPart(e2, i3, s2) {
const { bucket: a2, layout: o2, posMatrix: r2, textLabelPlaneMatrix: n2, labelToScreenMatrix: l2, textPixelRatio: h2, holdingForFade: c2, collisionBoxArray: u2, partiallyEvaluatedTextSize: d2, collisionGroup: _2 } = e2.parameters, p2 = o2.get("text-optional"), m2 = o2.get("icon-optional"), f2 = t.ar(o2, "text-overlap", "text-allow-overlap"), g2 = "always" === f2, v2 = t.ar(o2, "icon-overlap", "icon-allow-overlap"), x2 = "always" === v2, y2 = "map" === o2.get("text-rotation-alignment"), b2 = "map" === o2.get("text-pitch-alignment"), w2 = "none" !== o2.get("icon-text-fit"), T2 = "viewport-y" === o2.get("symbol-z-order"), I2 = g2 && (x2 || !a2.hasIconData() || m2), E2 = x2 && (g2 || !a2.hasTextData() || p2);
!a2.collisionArrays && u2 && a2.deserializeCollisionBoxes(u2);
const S2 = this.retainedQueryData[a2.bucketInstanceId].tileID, C2 = this.terrain ? (t2, e3) => this.terrain.getElevation(S2, t2, e3) : null, P2 = (e3, u3) => {
var x3, T3;
if (i3[e3.crossTileID]) return;
if (c2) return void (this.placements[e3.crossTileID] = new Dt(false, false, false));
let S3 = false, P3 = false, D2 = true, M2 = null, z2 = { box: null, offscreen: null }, L2 = { box: null }, A2 = null, R2 = null, k2 = null, F2 = 0, B2 = 0, O2 = 0;
u3.textFeatureIndex ? F2 = u3.textFeatureIndex : e3.useRuntimeCollisionCircles && (F2 = e3.featureIndex), u3.verticalTextFeatureIndex && (B2 = u3.verticalTextFeatureIndex);
const N2 = u3.textBox;
if (N2) {
const i4 = (i5) => {
let s4 = t.ai.horizontal;
if (a2.allowVerticalPlacement && !i5 && this.prevPlacement) {
const t2 = this.prevPlacement.placedOrientations[e3.crossTileID];
t2 && (this.placedOrientations[e3.crossTileID] = t2, s4 = t2, this.markUsedOrientation(a2, s4, e3));
}
return s4;
}, s3 = (i5, s4) => {
if (a2.allowVerticalPlacement && e3.numVerticalGlyphVertices > 0 && u3.verticalTextBox) {
for (const e4 of a2.writingModes) if (e4 === t.ai.vertical ? (z2 = s4(), L2 = z2) : z2 = i5(), z2 && z2.box && z2.box.length) break;
} else z2 = i5();
}, o3 = e3.textAnchorOffsetStartIndex, n3 = e3.textAnchorOffsetEndIndex;
if (n3 === o3) {
const o4 = (t2, i5) => {
const s4 = this.collisionIndex.placeCollisionBox(t2, f2, h2, r2, _2.predicate, C2);
return s4 && s4.box && s4.box.length && (this.markUsedOrientation(a2, i5, e3), this.placedOrientations[e3.crossTileID] = i5), s4;
};
s3((() => o4(N2, t.ai.horizontal)), (() => {
const i5 = u3.verticalTextBox;
return a2.allowVerticalPlacement && e3.numVerticalGlyphVertices > 0 && i5 ? o4(i5, t.ai.vertical) : { box: null, offscreen: null };
})), i4(z2 && z2.box && z2.box.length);
} else {
let l3 = t.aq[null === (T3 = null === (x3 = this.prevPlacement) || void 0 === x3 ? void 0 : x3.variableOffsets[e3.crossTileID]) || void 0 === T3 ? void 0 : T3.anchor];
const c3 = (t2, i5, s4) => {
const c4 = t2.x2 - t2.x1, u4 = t2.y2 - t2.y1, d4 = e3.textBoxScale, p3 = w2 && "never" === v2 ? i5 : null;
let m3 = { box: [], offscreen: false }, g3 = "never" === f2 ? 1 : 2, x4 = "never";
l3 && g3++;
for (let i6 = 0; i6 < g3; i6++) {
for (let i7 = o3; i7 < n3; i7++) {
const o4 = a2.textAnchorOffsets.get(i7);
if (l3 && o4.textAnchor !== l3) continue;
const n4 = this.attemptAnchorPlacement(o4, t2, c4, u4, d4, y2, b2, h2, r2, _2, x4, e3, a2, s4, p3, C2);
if (n4 && (m3 = n4.placedGlyphBoxes, m3 && m3.box && m3.box.length)) return S3 = true, M2 = n4.shift, m3;
}
l3 ? l3 = null : x4 = f2;
}
return m3;
};
s3((() => c3(N2, u3.iconBox, t.ai.horizontal)), (() => {
const i5 = u3.verticalTextBox;
return a2.allowVerticalPlacement && !(z2 && z2.box && z2.box.length) && e3.numVerticalGlyphVertices > 0 && i5 ? c3(i5, u3.verticalIconBox, t.ai.vertical) : { box: null, offscreen: null };
})), z2 && (S3 = z2.box, D2 = z2.offscreen);
const d3 = i4(z2 && z2.box);
if (!S3 && this.prevPlacement) {
const t2 = this.prevPlacement.variableOffsets[e3.crossTileID];
t2 && (this.variableOffsets[e3.crossTileID] = t2, this.markUsedJustification(a2, t2.anchor, e3, d3));
}
}
}
if (A2 = z2, S3 = A2 && A2.box && A2.box.length > 0, D2 = A2 && A2.offscreen, e3.useRuntimeCollisionCircles) {
const i4 = a2.text.placedSymbolArray.get(e3.centerJustifiedTextSymbolIndex), h3 = t.aj(a2.textSizeData, d2, i4), c3 = o2.get("text-padding");
R2 = this.collisionIndex.placeCollisionCircles(f2, i4, a2.lineVertexArray, a2.glyphOffsetArray, h3, r2, n2, l2, s2, b2, _2.predicate, e3.collisionCircleDiameter, c3, C2), R2.circles.length && R2.collisionDetected && !s2 && t.w("Collisions detected, but collision boxes are not shown"), S3 = g2 || R2.circles.length > 0 && !R2.collisionDetected, D2 = D2 && R2.offscreen;
}
if (u3.iconFeatureIndex && (O2 = u3.iconFeatureIndex), u3.iconBox) {
const t2 = (t3) => {
const e4 = w2 && M2 ? Rt(t3, M2.x, M2.y, y2, b2, this.transform.angle) : t3;
return this.collisionIndex.placeCollisionBox(e4, v2, h2, r2, _2.predicate, C2);
};
L2 && L2.box && L2.box.length && u3.verticalIconBox ? (k2 = t2(u3.verticalIconBox), P3 = k2.box.length > 0) : (k2 = t2(u3.iconBox), P3 = k2.box.length > 0), D2 = D2 && k2.offscreen;
}
const U2 = p2 || 0 === e3.numHorizontalGlyphVertices && 0 === e3.numVerticalGlyphVertices, Z2 = m2 || 0 === e3.numIconVertices;
if (U2 || Z2 ? Z2 ? U2 || (P3 = P3 && S3) : S3 = P3 && S3 : P3 = S3 = P3 && S3, S3 && A2 && A2.box && this.collisionIndex.insertCollisionBox(A2.box, f2, o2.get("text-ignore-placement"), a2.bucketInstanceId, L2 && L2.box && B2 ? B2 : F2, _2.ID), P3 && k2 && this.collisionIndex.insertCollisionBox(k2.box, v2, o2.get("icon-ignore-placement"), a2.bucketInstanceId, O2, _2.ID), R2 && (S3 && this.collisionIndex.insertCollisionCircles(R2.circles, f2, o2.get("text-ignore-placement"), a2.bucketInstanceId, F2, _2.ID), s2)) {
const t2 = a2.bucketInstanceId;
let e4 = this.collisionCircleArrays[t2];
void 0 === e4 && (e4 = this.collisionCircleArrays[t2] = new Mt());
for (let t3 = 0; t3 < R2.circles.length; t3 += 4) e4.circles.push(R2.circles[t3 + 0]), e4.circles.push(R2.circles[t3 + 1]), e4.circles.push(R2.circles[t3 + 2]), e4.circles.push(R2.collisionDetected ? 1 : 0);
}
if (0 === e3.crossTileID) throw new Error("symbolInstance.crossTileID can't be 0");
if (0 === a2.bucketInstanceId) throw new Error("bucket.bucketInstanceId can't be 0");
this.placements[e3.crossTileID] = new Dt(S3 || I2, P3 || E2, D2 || a2.justReloaded), i3[e3.crossTileID] = true;
};
if (T2) {
if (0 !== e2.symbolInstanceStart) throw new Error("bucket.bucketInstanceId should be 0");
const t2 = a2.getSortedSymbolIndexes(this.transform.angle);
for (let e3 = t2.length - 1; e3 >= 0; --e3) {
const i4 = t2[e3];
P2(a2.symbolInstances.get(i4), a2.collisionArrays[i4]);
}
} else for (let t2 = e2.symbolInstanceStart; t2 < e2.symbolInstanceEnd; t2++) P2(a2.symbolInstances.get(t2), a2.collisionArrays[t2]);
if (s2 && a2.bucketInstanceId in this.collisionCircleArrays) {
const e3 = this.collisionCircleArrays[a2.bucketInstanceId];
t.as(e3.invProjMatrix, r2), e3.viewportMatrix = this.collisionIndex.getViewportMatrix();
}
a2.justReloaded = false;
}
markUsedJustification(e2, i3, s2, a2) {
let o2;
o2 = a2 === t.ai.vertical ? s2.verticalPlacedTextSymbolIndex : { left: s2.leftJustifiedTextSymbolIndex, center: s2.centerJustifiedTextSymbolIndex, right: s2.rightJustifiedTextSymbolIndex }[t.at(i3)];
const r2 = [s2.leftJustifiedTextSymbolIndex, s2.centerJustifiedTextSymbolIndex, s2.rightJustifiedTextSymbolIndex, s2.verticalPlacedTextSymbolIndex];
for (const t2 of r2) t2 >= 0 && (e2.text.placedSymbolArray.get(t2).crossTileID = o2 >= 0 && t2 !== o2 ? 0 : s2.crossTileID);
}
markUsedOrientation(e2, i3, s2) {
const a2 = i3 === t.ai.horizontal || i3 === t.ai.horizontalOnly ? i3 : 0, o2 = i3 === t.ai.vertical ? i3 : 0, r2 = [s2.leftJustifiedTextSymbolIndex, s2.centerJustifiedTextSymbolIndex, s2.rightJustifiedTextSymbolIndex];
for (const t2 of r2) e2.text.placedSymbolArray.get(t2).placedOrientation = a2;
s2.verticalPlacedTextSymbolIndex && (e2.text.placedSymbolArray.get(s2.verticalPlacedTextSymbolIndex).placedOrientation = o2);
}
commit(t2) {
this.commitTime = t2, this.zoomAtLastRecencyCheck = this.transform.zoom;
const e2 = this.prevPlacement;
let i3 = false;
this.prevZoomAdjustment = e2 ? e2.zoomAdjustment(this.transform.zoom) : 0;
const s2 = e2 ? e2.symbolFadeChange(t2) : 1, a2 = e2 ? e2.opacities : {}, o2 = e2 ? e2.variableOffsets : {}, r2 = e2 ? e2.placedOrientations : {};
for (const t3 in this.placements) {
const e3 = this.placements[t3], o3 = a2[t3];
o3 ? (this.opacities[t3] = new Pt(o3, s2, e3.text, e3.icon), i3 = i3 || e3.text !== o3.text.placed || e3.icon !== o3.icon.placed) : (this.opacities[t3] = new Pt(null, s2, e3.text, e3.icon, e3.skipFade), i3 = i3 || e3.text || e3.icon);
}
for (const t3 in a2) {
const e3 = a2[t3];
if (!this.opacities[t3]) {
const a3 = new Pt(e3, s2, false, false);
a3.isHidden() || (this.opacities[t3] = a3, i3 = i3 || e3.text.placed || e3.icon.placed);
}
}
for (const t3 in o2) this.variableOffsets[t3] || !this.opacities[t3] || this.opacities[t3].isHidden() || (this.variableOffsets[t3] = o2[t3]);
for (const t3 in r2) this.placedOrientations[t3] || !this.opacities[t3] || this.opacities[t3].isHidden() || (this.placedOrientations[t3] = r2[t3]);
if (e2 && void 0 === e2.lastPlacementChangeTime) throw new Error("Last placement time for previous placement is not defined");
i3 ? this.lastPlacementChangeTime = t2 : "number" != typeof this.lastPlacementChangeTime && (this.lastPlacementChangeTime = e2 ? e2.lastPlacementChangeTime : t2);
}
updateLayerOpacities(t2, e2) {
const i3 = {};
for (const s2 of e2) {
const e3 = s2.getBucket(t2);
e3 && s2.latestFeatureIndex && t2.id === e3.layerIds[0] && this.updateBucketOpacities(e3, i3, s2.collisionBoxArray);
}
}
updateBucketOpacities(e2, i3, s2) {
e2.hasTextData() && (e2.text.opacityVertexArray.clear(), e2.text.hasVisibleVertices = false), e2.hasIconData() && (e2.icon.opacityVertexArray.clear(), e2.icon.hasVisibleVertices = false), e2.hasIconCollisionBoxData() && e2.iconCollisionBox.collisionVertexArray.clear(), e2.hasTextCollisionBoxData() && e2.textCollisionBox.collisionVertexArray.clear();
const a2 = e2.layers[0], o2 = a2.layout, r2 = new Pt(null, 0, false, false, true), n2 = o2.get("text-allow-overlap"), l2 = o2.get("icon-allow-overlap"), h2 = a2._unevaluatedLayout.hasValue("text-variable-anchor") || a2._unevaluatedLayout.hasValue("text-variable-anchor-offset"), c2 = "map" === o2.get("text-rotation-alignment"), u2 = "map" === o2.get("text-pitch-alignment"), d2 = "none" !== o2.get("icon-text-fit"), _2 = new Pt(null, 0, n2 && (l2 || !e2.hasIconData() || o2.get("icon-optional")), l2 && (n2 || !e2.hasTextData() || o2.get("text-optional")), true);
!e2.collisionArrays && s2 && (e2.hasIconCollisionBoxData() || e2.hasTextCollisionBoxData()) && e2.deserializeCollisionBoxes(s2);
const p2 = (t2, e3, i4) => {
for (let s3 = 0; s3 < e3 / 4; s3++) t2.opacityVertexArray.emplaceBack(i4);
t2.hasVisibleVertices = t2.hasVisibleVertices || i4 !== qt;
};
for (let s3 = 0; s3 < e2.symbolInstances.length; s3++) {
const a3 = e2.symbolInstances.get(s3), { numHorizontalGlyphVertices: o3, numVerticalGlyphVertices: n3, crossTileID: l3 } = a3;
let m2 = this.opacities[l3];
i3[l3] ? m2 = r2 : m2 || (m2 = _2, this.opacities[l3] = m2), i3[l3] = true;
const f2 = a3.numIconVertices > 0, g2 = this.placedOrientations[a3.crossTileID], v2 = g2 === t.ai.vertical, x2 = g2 === t.ai.horizontal || g2 === t.ai.horizontalOnly;
if (o3 > 0 || n3 > 0) {
const t2 = Vt(m2.text);
p2(e2.text, o3, v2 ? qt : t2), p2(e2.text, n3, x2 ? qt : t2);
const i4 = m2.text.isHidden();
[a3.rightJustifiedTextSymbolIndex, a3.centerJustifiedTextSymbolIndex, a3.leftJustifiedTextSymbolIndex].forEach(((t3) => {
t3 >= 0 && (e2.text.placedSymbolArray.get(t3).hidden = i4 || v2 ? 1 : 0);
})), a3.verticalPlacedTextSymbolIndex >= 0 && (e2.text.placedSymbolArray.get(a3.verticalPlacedTextSymbolIndex).hidden = i4 || x2 ? 1 : 0);
const s4 = this.variableOffsets[a3.crossTileID];
s4 && this.markUsedJustification(e2, s4.anchor, a3, g2);
const r3 = this.placedOrientations[a3.crossTileID];
r3 && (this.markUsedJustification(e2, "left", a3, r3), this.markUsedOrientation(e2, r3, a3));
}
if (f2) {
const t2 = Vt(m2.icon), i4 = !(d2 && a3.verticalPlacedIconSymbolIndex && v2);
a3.placedIconSymbolIndex >= 0 && (p2(e2.icon, a3.numIconVertices, i4 ? t2 : qt), e2.icon.placedSymbolArray.get(a3.placedIconSymbolIndex).hidden = m2.icon.isHidden()), a3.verticalPlacedIconSymbolIndex >= 0 && (p2(e2.icon, a3.numVerticalIconVertices, i4 ? qt : t2), e2.icon.placedSymbolArray.get(a3.verticalPlacedIconSymbolIndex).hidden = m2.icon.isHidden());
}
if (e2.hasIconCollisionBoxData() || e2.hasTextCollisionBoxData()) {
const i4 = e2.collisionArrays[s3];
if (i4) {
let s4 = new t.P(0, 0);
if (i4.textBox || i4.verticalTextBox) {
let t2 = true;
if (h2) {
const e3 = this.variableOffsets[l3];
e3 ? (s4 = At(e3.anchor, e3.width, e3.height, e3.textOffset, e3.textBoxScale), c2 && s4._rotate(u2 ? this.transform.angle : -this.transform.angle)) : t2 = false;
}
i4.textBox && Ft(e2.textCollisionBox.collisionVertexArray, m2.text.placed, !t2 || v2, s4.x, s4.y), i4.verticalTextBox && Ft(e2.textCollisionBox.collisionVertexArray, m2.text.placed, !t2 || x2, s4.x, s4.y);
}
const a4 = Boolean(!x2 && i4.verticalIconBox);
i4.iconBox && Ft(e2.iconCollisionBox.collisionVertexArray, m2.icon.placed, a4, d2 ? s4.x : 0, d2 ? s4.y : 0), i4.verticalIconBox && Ft(e2.iconCollisionBox.collisionVertexArray, m2.icon.placed, !a4, d2 ? s4.x : 0, d2 ? s4.y : 0);
}
}
}
if (e2.sortFeatures(this.transform.angle), this.retainedQueryData[e2.bucketInstanceId] && (this.retainedQueryData[e2.bucketInstanceId].featureSortOrder = e2.featureSortOrder), e2.hasTextData() && e2.text.opacityVertexBuffer && e2.text.opacityVertexBuffer.updateData(e2.text.opacityVertexArray), e2.hasIconData() && e2.icon.opacityVertexBuffer && e2.icon.opacityVertexBuffer.updateData(e2.icon.opacityVertexArray), e2.hasIconCollisionBoxData() && e2.iconCollisionBox.collisionVertexBuffer && e2.iconCollisionBox.collisionVertexBuffer.updateData(e2.iconCollisionBox.collisionVertexArray), e2.hasTextCollisionBoxData() && e2.textCollisionBox.collisionVertexBuffer && e2.textCollisionBox.collisionVertexBuffer.updateData(e2.textCollisionBox.collisionVertexArray), e2.text.opacityVertexArray.length !== e2.text.layoutVertexArray.length / 4) throw new Error(`bucket.text.opacityVertexArray.length (= ${e2.text.opacityVertexArray.length}) !== bucket.text.layoutVertexArray.length (= ${e2.text.layoutVertexArray.length}) / 4`);
if (e2.icon.opacityVertexArray.length !== e2.icon.layoutVertexArray.length / 4) throw new Error(`bucket.icon.opacityVertexArray.length (= ${e2.icon.opacityVertexArray.length}) !== bucket.icon.layoutVertexArray.length (= ${e2.icon.layoutVertexArray.length}) / 4`);
if (e2.bucketInstanceId in this.collisionCircleArrays) {
const t2 = this.collisionCircleArrays[e2.bucketInstanceId];
e2.placementInvProjMatrix = t2.invProjMatrix, e2.placementViewportMatrix = t2.viewportMatrix, e2.collisionCircleArray = t2.circles, delete this.collisionCircleArrays[e2.bucketInstanceId];
}
}
symbolFadeChange(t2) {
return 0 === this.fadeDuration ? 1 : (t2 - this.commitTime) / this.fadeDuration + this.prevZoomAdjustment;
}
zoomAdjustment(t2) {
return Math.max(0, (this.transform.zoom - t2) / 1.5);
}
hasTransitions(t2) {
return this.stale || t2 - this.lastPlacementChangeTime < this.fadeDuration;
}
stillRecent(t2, e2) {
const i3 = this.zoomAtLastRecencyCheck === e2 ? 1 - this.zoomAdjustment(e2) : 1;
return this.zoomAtLastRecencyCheck = e2, this.commitTime + this.fadeDuration * i3 > t2;
}
setStale() {
this.stale = true;
}
}
function Ft(t2, e2, i3, s2, a2) {
t2.emplaceBack(e2 ? 1 : 0, i3 ? 1 : 0, s2 || 0, a2 || 0), t2.emplaceBack(e2 ? 1 : 0, i3 ? 1 : 0, s2 || 0, a2 || 0), t2.emplaceBack(e2 ? 1 : 0, i3 ? 1 : 0, s2 || 0, a2 || 0), t2.emplaceBack(e2 ? 1 : 0, i3 ? 1 : 0, s2 || 0, a2 || 0);
}
const Bt = Math.pow(2, 25), Ot = Math.pow(2, 24), Nt = Math.pow(2, 17), Ut = Math.pow(2, 16), Zt = Math.pow(2, 9), Gt = Math.pow(2, 8), jt = Math.pow(2, 1);
function Vt(t2) {
if (0 === t2.opacity && !t2.placed) return 0;
if (1 === t2.opacity && t2.placed) return 4294967295;
const e2 = t2.placed ? 1 : 0, i3 = Math.floor(127 * t2.opacity);
return i3 * Bt + e2 * Ot + i3 * Nt + e2 * Ut + i3 * Zt + e2 * Gt + i3 * jt + e2;
}
const qt = 0;
class $t {
constructor(t2) {
this._sortAcrossTiles = "viewport-y" !== t2.layout.get("symbol-z-order") && !t2.layout.get("symbol-sort-key").isConstant(), this._currentTileIndex = 0, this._currentPartIndex = 0, this._seenCrossTileIDs = {}, this._bucketParts = [];
}
continuePlacement(t2, e2, i3, s2, a2) {
const o2 = this._bucketParts;
for (; this._currentTileIndex < t2.length; ) if (e2.getBucketParts(o2, s2, t2[this._currentTileIndex], this._sortAcrossTiles), this._currentTileIndex++, a2()) return true;
for (this._sortAcrossTiles && (this._sortAcrossTiles = false, o2.sort(((t3, e3) => t3.sortKey - e3.sortKey))); this._currentPartIndex < o2.length; ) if (e2.placeLayerBucketPart(o2[this._currentPartIndex], this._seenCrossTileIDs, i3), this._currentPartIndex++, a2()) return true;
return false;
}
}
class Wt {
constructor(t2, e2, i3, s2, a2, o2, r2, n2) {
this.placement = new kt(t2, e2, o2, r2, n2), this._currentPlacementIndex = i3.length - 1, this._forceFullPlacement = s2, this._showCollisionBoxes = a2, this._done = false;
}
isDone() {
return this._done;
}
continuePlacement(e2, i3, s2) {
const a2 = t.h.now(), o2 = () => !this._forceFullPlacement && t.h.now() - a2 > 2;
for (; this._currentPlacementIndex >= 0; ) {
const t2 = i3[e2[this._currentPlacementIndex]], a3 = this.placement.collisionIndex.transform.zoom;
if ("symbol" === t2.type && (!t2.minzoom || t2.minzoom <= a3) && (!t2.maxzoom || t2.maxzoom > a3)) {
if (this._inProgressLayer || (this._inProgressLayer = new $t(t2)), this._inProgressLayer.continuePlacement(s2[t2.source], this.placement, this._showCollisionBoxes, t2, o2)) return;
delete this._inProgressLayer;
}
this._currentPlacementIndex--;
}
this._done = true;
}
commit(t2) {
return this.placement.commit(t2), this.placement;
}
}
const Ht = 512 / t.N / 2;
class Xt {
constructor(e2, i3, s2) {
this.tileID = e2, this.bucketInstanceId = s2, this._symbolsByKey = {};
const a2 = /* @__PURE__ */ new Map();
for (let t2 = 0; t2 < i3.length; t2++) {
const e3 = i3.get(t2), s3 = e3.key, o2 = a2.get(s3);
o2 ? o2.push(e3) : a2.set(s3, [e3]);
}
for (const [e3, i4] of a2) {
const s3 = { positions: i4.map(((t2) => ({ x: Math.floor(t2.anchorX * Ht), y: Math.floor(t2.anchorY * Ht) }))), crossTileIDs: i4.map(((t2) => t2.crossTileID)) };
if (s3.positions.length > 128) {
const e4 = new t.av(s3.positions.length, 16, Uint16Array);
for (const { x: t2, y: i5 } of s3.positions) e4.add(t2, i5);
e4.finish(), delete s3.positions, s3.index = e4;
}
this._symbolsByKey[e3] = s3;
}
}
getScaledCoordinates(e2, i3) {
const { x: s2, y: a2, z: o2 } = this.tileID.canonical, { x: r2, y: n2, z: l2 } = i3.canonical, h2 = Ht / Math.pow(2, l2 - o2), c2 = (n2 * t.N + e2.anchorY) * h2, u2 = a2 * t.N * Ht;
return { x: Math.floor((r2 * t.N + e2.anchorX) * h2 - s2 * t.N * Ht), y: Math.floor(c2 - u2) };
}
findMatches(t2, e2, i3) {
const s2 = this.tileID.canonical.z < e2.canonical.z ? 1 : Math.pow(2, this.tileID.canonical.z - e2.canonical.z);
for (let a2 = 0; a2 < t2.length; a2++) {
const o2 = t2.get(a2);
if (o2.crossTileID) continue;
const r2 = this._symbolsByKey[o2.key];
if (!r2) continue;
const n2 = this.getScaledCoordinates(o2, e2);
if (r2.index) {
const t3 = r2.index.range(n2.x - s2, n2.y - s2, n2.x + s2, n2.y + s2).sort();
for (const e3 of t3) {
const t4 = r2.crossTileIDs[e3];
if (!i3[t4]) {
i3[t4] = true, o2.crossTileID = t4;
break;
}
}
} else if (r2.positions) for (let t3 = 0; t3 < r2.positions.length; t3++) {
const e3 = r2.positions[t3], a3 = r2.crossTileIDs[t3];
if (Math.abs(e3.x - n2.x) <= s2 && Math.abs(e3.y - n2.y) <= s2 && !i3[a3]) {
i3[a3] = true, o2.crossTileID = a3;
break;
}
}
}
}
getCrossTileIDsLists() {
return Object.values(this._symbolsByKey).map((({ crossTileIDs: t2 }) => t2));
}
}
class Kt {
constructor() {
this.maxCrossTileID = 0;
}
generate() {
return ++this.maxCrossTileID;
}
}
class Qt {
constructor() {
this.indexes = {}, this.usedCrossTileIDs = {}, this.lng = 0;
}
handleWrapJump(t2) {
const e2 = Math.round((t2 - this.lng) / 360);
if (0 !== e2) for (const t3 in this.indexes) {
const i3 = this.indexes[t3], s2 = {};
for (const t4 in i3) {
const a2 = i3[t4];
a2.tileID = a2.tileID.unwrapTo(a2.tileID.wrap + e2), s2[a2.tileID.key] = a2;
}
this.indexes[t3] = s2;
}
this.lng = t2;
}
addBucket(t2, e2, i3) {
if (this.indexes[t2.overscaledZ] && this.indexes[t2.overscaledZ][t2.key]) {
if (this.indexes[t2.overscaledZ][t2.key].bucketInstanceId === e2.bucketInstanceId) return false;
this.removeBucketCrossTileIDs(t2.overscaledZ, this.indexes[t2.overscaledZ][t2.key]);
}
for (let t3 = 0; t3 < e2.symbolInstances.length; t3++) e2.symbolInstances.get(t3).crossTileID = 0;
this.usedCrossTileIDs[t2.overscaledZ] || (this.usedCrossTileIDs[t2.overscaledZ] = {});
const s2 = this.usedCrossTileIDs[t2.overscaledZ];
for (const i4 in this.indexes) {
const a2 = this.indexes[i4];
if (Number(i4) > t2.overscaledZ) for (const i5 in a2) {
const o2 = a2[i5];
o2.tileID.isChildOf(t2) && o2.findMatches(e2.symbolInstances, t2, s2);
}
else {
const o2 = a2[t2.scaledTo(Number(i4)).key];
o2 && o2.findMatches(e2.symbolInstances, t2, s2);
}
}
for (let t3 = 0; t3 < e2.symbolInstances.length; t3++) {
const a2 = e2.symbolInstances.get(t3);
a2.crossTileID || (a2.crossTileID = i3.generate(), s2[a2.crossTileID] = true);
}
return void 0 === this.indexes[t2.overscaledZ] && (this.indexes[t2.overscaledZ] = {}), this.indexes[t2.overscaledZ][t2.key] = new Xt(t2, e2.symbolInstances, e2.bucketInstanceId), true;
}
removeBucketCrossTileIDs(t2, e2) {
for (const i3 of e2.getCrossTileIDsLists()) for (const e3 of i3) delete this.usedCrossTileIDs[t2][e3];
}
removeStaleBuckets(t2) {
let e2 = false;
for (const i3 in this.indexes) {
const s2 = this.indexes[i3];
for (const a2 in s2) t2[s2[a2].bucketInstanceId] || (this.removeBucketCrossTileIDs(i3, s2[a2]), delete s2[a2], e2 = true);
}
return e2;
}
}
class Yt {
constructor() {
this.layerIndexes = {}, this.crossTileIDs = new Kt(), this.maxBucketInstanceId = 0, this.bucketsInCurrentPlacement = {};
}
addLayer(t2, e2, i3) {
let s2 = this.layerIndexes[t2.id];
void 0 === s2 && (s2 = this.layerIndexes[t2.id] = new Qt());
let a2 = false;
const o2 = {};
s2.handleWrapJump(i3);
for (const i4 of e2) {
const e3 = i4.getBucket(t2);
e3 && t2.id === e3.layerIds[0] && (e3.bucketInstanceId || (e3.bucketInstanceId = ++this.maxBucketInstanceId), s2.addBucket(i4.tileID, e3, this.crossTileIDs) && (a2 = true), o2[e3.bucketInstanceId] = true);
}
return s2.removeStaleBuckets(o2) && (a2 = true), a2;
}
pruneUnusedLayers(t2) {
const e2 = {};
t2.forEach(((t3) => {
e2[t3] = true;
}));
for (const t3 in this.layerIndexes) e2[t3] || delete this.layerIndexes[t3];
}
}
const Jt = (e2, i3) => t.x(e2, i3 && i3.filter(((t2) => "source.canvas" !== t2.identifier))), te = t.F(t.ax, ["addLayer", "removeLayer", "setPaintProperty", "setLayoutProperty", "setFilter", "addSource", "removeSource", "setLayerZoomRange", "setLight", "setTransition", "setGeoJSONSourceData", "setGlyphs", "setSprite"]), ee = t.F(t.ax, ["setCenter", "setZoom", "setBearing", "setPitch"]), ie = t.aw();
class se extends t.E {
constructor(e2, i3 = {}) {
super(), this.map = e2, this.dispatcher = new M(st(), this, e2._getMapId()), this.imageManager = new b(), this.imageManager.setEventedParent(this), this.glyphManager = new E(e2._requestManager, i3.localIdeographFontFamily), this.lineAtlas = new D(256, 512), this.crossTileSymbolIndex = new Yt(), this._spritesImagesIds = {}, this._layers = {}, this._order = [], this.sourceCaches = {}, this.zoomHistory = new t.ay(), this._loaded = false, this._availableImages = [], this._resetUpdates(), this.dispatcher.broadcast("setReferrer", t.az());
const s2 = this;
this._rtlTextPluginCallback = se.registerForPluginStateChange(((e3) => {
s2.dispatcher.broadcast("syncRTLPluginState", { pluginStatus: e3.pluginStatus, pluginURL: e3.pluginURL }, ((e4, i4) => {
if (t.aA(e4), i4 && i4.every(((t2) => t2))) for (const t2 in s2.sourceCaches) {
const e5 = s2.sourceCaches[t2].getSource().type;
"vector" !== e5 && "geojson" !== e5 || s2.sourceCaches[t2].reload();
}
}));
})), this.on("data", ((t2) => {
if ("source" !== t2.dataType || "metadata" !== t2.sourceDataType) return;
const e3 = this.sourceCaches[t2.sourceId];
if (!e3) return;
const i4 = e3.getSource();
if (i4 && i4.vectorLayerIds) for (const t3 in this._layers) {
const e4 = this._layers[t3];
e4.source === i4.id && this._validateLayer(e4);
}
}));
}
loadURL(e2, i3 = {}, s2) {
this.fire(new t.k("dataloading", { dataType: "style" })), i3.validate = "boolean" != typeof i3.validate || i3.validate;
const a2 = this.map._requestManager.transformRequest(e2, c.Style);
this._request = t.f(a2, ((e3, a3) => {
this._request = null, e3 ? this.fire(new t.j(e3)) : a3 && this._load(a3, i3, s2);
}));
}
loadJSON(e2, i3 = {}, s2) {
this.fire(new t.k("dataloading", { dataType: "style" })), this._request = t.h.frame((() => {
this._request = null, i3.validate = false !== i3.validate, this._load(e2, i3, s2);
}));
}
loadEmpty() {
this.fire(new t.k("dataloading", { dataType: "style" })), this._load(ie, { validate: false });
}
_load(e2, i3, s2) {
var a2;
const o2 = i3.transformStyle ? i3.transformStyle(s2, e2) : e2;
if (!i3.validate || !Jt(this, t.y(o2))) {
this._loaded = true, this.stylesheet = o2;
for (const t2 in o2.sources) this.addSource(t2, o2.sources[t2], { validate: false });
o2.sprite ? this._loadSprite(o2.sprite) : this.imageManager.setLoaded(true), this.glyphManager.setURL(o2.glyphs), this._createLayers(), this.light = new P(this.stylesheet.light), this.map.setTerrain(null !== (a2 = this.stylesheet.terrain) && void 0 !== a2 ? a2 : null), this.fire(new t.k("data", { dataType: "style" })), this.fire(new t.k("style.load"));
}
}
_createLayers() {
const e2 = t.aB(this.stylesheet.layers);
this.dispatcher.broadcast("setLayers", e2), this._order = e2.map(((t2) => t2.id)), this._layers = {}, this._serializedLayers = null;
for (const i3 of e2) {
const e3 = t.aC(i3);
e3.setEventedParent(this, { layer: { id: i3.id } }), this._layers[i3.id] = e3;
}
}
_loadSprite(e2, i3 = false, s2 = void 0) {
this.imageManager.setLoaded(false), this._spriteRequest = (function(e3, i4, s3, a2) {
const o2 = g(e3), r2 = o2.length, n2 = s3 > 1 ? "@2x" : "", l2 = {}, u2 = {}, d2 = {};
for (const { id: e4, url: s4 } of o2) {
const o3 = i4.transformRequest(i4.normalizeSpriteURL(s4, n2, ".json"), c.SpriteJSON), _2 = `${e4}_${o3.url}`;
l2[_2] = t.f(o3, ((t2, i5) => {
delete l2[_2], u2[e4] = i5, v(a2, u2, d2, t2, r2);
}));
const p2 = i4.transformRequest(i4.normalizeSpriteURL(s4, n2, ".png"), c.SpriteImage), m2 = `${e4}_${p2.url}`;
l2[m2] = h.getImage(p2, ((t2, i5) => {
delete l2[m2], d2[e4] = i5, v(a2, u2, d2, t2, r2);
}));
}
return { cancel() {
for (const t2 of Object.values(l2)) t2.cancel();
} };
})(e2, this.map._requestManager, this.map.getPixelRatio(), ((e3, a2) => {
if (this._spriteRequest = null, e3) this.fire(new t.j(e3));
else if (a2) for (const t2 in a2) {
this._spritesImagesIds[t2] = [];
const e4 = this._spritesImagesIds[t2] ? this._spritesImagesIds[t2].filter(((t3) => !(t3 in a2))) : [];
for (const t3 of e4) this.imageManager.removeImage(t3), this._changedImages[t3] = true;
for (const e5 in a2[t2]) {
const s3 = "default" === t2 ? e5 : `${t2}:${e5}`;
this._spritesImagesIds[t2].push(s3), s3 in this.imageManager.images ? this.imageManager.updateImage(s3, a2[t2][e5], false) : this.imageManager.addImage(s3, a2[t2][e5]), i3 && (this._changedImages[s3] = true);
}
}
this.imageManager.setLoaded(true), this._availableImages = this.imageManager.listImages(), i3 && (this._changed = true), this.dispatcher.broadcast("setImages", this._availableImages), this.fire(new t.k("data", { dataType: "style" })), s2 && s2(e3);
}));
}
_unloadSprite() {
for (const t2 of Object.values(this._spritesImagesIds).flat()) this.imageManager.removeImage(t2), this._changedImages[t2] = true;
this._spritesImagesIds = {}, this._availableImages = this.imageManager.listImages(), this._changed = true, this.dispatcher.broadcast("setImages", this._availableImages), this.fire(new t.k("data", { dataType: "style" }));
}
_validateLayer(e2) {
const i3 = this.sourceCaches[e2.source];
if (!i3) return;
const s2 = e2.sourceLayer;
if (!s2) return;
const a2 = i3.getSource();
("geojson" === a2.type || a2.vectorLayerIds && -1 === a2.vectorLayerIds.indexOf(s2)) && this.fire(new t.j(new Error(`Source layer "${s2}" does not exist on source "${a2.id}" as specified by style layer "${e2.id}".`)));
}
loaded() {
if (!this._loaded) return false;
if (Object.keys(this._updatedSources).length) return false;
for (const t2 in this.sourceCaches) if (!this.sourceCaches[t2].loaded()) return false;
return !!this.imageManager.isLoaded();
}
_serializeByIds(t2) {
const e2 = this._serializedAllLayers();
if (!t2 || 0 === t2.length) return Object.values(e2);
const i3 = [];
for (const s2 of t2) e2[s2] && i3.push(e2[s2]);
return i3;
}
_serializedAllLayers() {
let t2 = this._serializedLayers;
if (t2) return t2;
t2 = this._serializedLayers = {};
const e2 = Object.keys(this._layers);
for (const i3 of e2) {
const e3 = this._layers[i3];
"custom" !== e3.type && (t2[i3] = e3.serialize());
}
return t2;
}
hasTransitions() {
if (this.light && this.light.hasTransition()) return true;
for (const t2 in this.sourceCaches) if (this.sourceCaches[t2].hasTransition()) return true;
for (const t2 in this._layers) if (this._layers[t2].hasTransition()) return true;
return false;
}
_checkLoaded() {
if (!this._loaded) throw new Error("Style is not done loading.");
}
update(e2) {
if (!this._loaded) return;
const i3 = this._changed;
if (this._changed) {
const t2 = Object.keys(this._updatedLayers), i4 = Object.keys(this._removedLayers);
(t2.length || i4.length) && this._updateWorkerLayers(t2, i4);
for (const t3 in this._updatedSources) {
const e3 = this._updatedSources[t3];
if ("reload" === e3) this._reloadSource(t3);
else {
if ("clear" !== e3) throw new Error(`Invalid action ${e3}`);
this._clearSource(t3);
}
}
this._updateTilesForChangedImages(), this._updateTilesForChangedGlyphs();
for (const t3 in this._updatedPaintProps) this._layers[t3].updateTransitions(e2);
this.light.updateTransitions(e2), this._resetUpdates();
}
const s2 = {};
for (const t2 in this.sourceCaches) {
const e3 = this.sourceCaches[t2];
s2[t2] = e3.used, e3.used = false;
}
for (const t2 of this._order) {
const i4 = this._layers[t2];
i4.recalculate(e2, this._availableImages), !i4.isHidden(e2.zoom) && i4.source && (this.sourceCaches[i4.source].used = true);
}
for (const e3 in s2) {
const i4 = this.sourceCaches[e3];
s2[e3] !== i4.used && i4.fire(new t.k("data", { sourceDataType: "visibility", dataType: "source", sourceId: e3 }));
}
this.light.recalculate(e2), this.z = e2.zoom, i3 && this.fire(new t.k("data", { dataType: "style" }));
}
_updateTilesForChangedImages() {
const t2 = Object.keys(this._changedImages);
if (t2.length) {
for (const e2 in this.sourceCaches) this.sourceCaches[e2].reloadTilesForDependencies(["icons", "patterns"], t2);
this._changedImages = {};
}
}
_updateTilesForChangedGlyphs() {
if (this._glyphsDidChange) {
for (const t2 in this.sourceCaches) this.sourceCaches[t2].reloadTilesForDependencies(["glyphs"], [""]);
this._glyphsDidChange = false;
}
}
_updateWorkerLayers(t2, e2) {
this.dispatcher.broadcast("updateLayers", { layers: this._serializeByIds(t2), removedIds: e2 });
}
_resetUpdates() {
this._changed = false, this._updatedLayers = {}, this._removedLayers = {}, this._updatedSources = {}, this._updatedPaintProps = {}, this._changedImages = {}, this._glyphsDidChange = false;
}
setState(e2, i3 = {}) {
this._checkLoaded();
const s2 = this.serialize();
if (e2 = i3.transformStyle ? i3.transformStyle(s2, e2) : e2, Jt(this, t.y(e2))) return false;
(e2 = t.aD(e2)).layers = t.aB(e2.layers);
const a2 = t.aE(s2, e2).filter(((t2) => !(t2.command in ee)));
if (0 === a2.length) return false;
const o2 = a2.filter(((t2) => !(t2.command in te)));
if (o2.length > 0) throw new Error(`Unimplemented: ${o2.map(((t2) => t2.command)).join(", ")}.`);
for (const t2 of a2) "setTransition" !== t2.command && this[t2.command].apply(this, t2.args);
return this.stylesheet = e2, this._serializedLayers = null, true;
}
addImage(e2, i3) {
if (this.getImage(e2)) return this.fire(new t.j(new Error(`An image named "${e2}" already exists.`)));
this.imageManager.addImage(e2, i3), this._afterImageUpdated(e2);
}
updateImage(t2, e2) {
this.imageManager.updateImage(t2, e2);
}
getImage(t2) {
return this.imageManager.getImage(t2);
}
removeImage(e2) {
if (!this.getImage(e2)) return this.fire(new t.j(new Error(`An image named "${e2}" does not exist.`)));
this.imageManager.removeImage(e2), this._afterImageUpdated(e2);
}
_afterImageUpdated(e2) {
this._availableImages = this.imageManager.listImages(), this._changedImages[e2] = true, this._changed = true, this.dispatcher.broadcast("setImages", this._availableImages), this.fire(new t.k("data", { dataType: "style" }));
}
listImages() {
return this._checkLoaded(), this.imageManager.listImages();
}
addSource(e2, i3, s2 = {}) {
if (this._checkLoaded(), void 0 !== this.sourceCaches[e2]) throw new Error(`Source "${e2}" already exists.`);
if (!i3.type) throw new Error(`The type property must be defined, but only the following properties were given: ${Object.keys(i3).join(", ")}.`);
if (["vector", "raster", "geojson", "video", "image"].indexOf(i3.type) >= 0 && this._validate(t.y.source, `sources.${e2}`, i3, null, s2)) return;
this.map && this.map._collectResourceTiming && (i3.collectResourceTiming = true);
const a2 = this.sourceCaches[e2] = new K(e2, i3, this.dispatcher);
a2.style = this, a2.setEventedParent(this, (() => ({ isSourceLoaded: a2.loaded(), source: a2.serialize(), sourceId: e2 }))), a2.onAdd(this.map), this._changed = true;
}
removeSource(e2) {
if (this._checkLoaded(), void 0 === this.sourceCaches[e2]) throw new Error("There is no source with this ID");
for (const i4 in this._layers) if (this._layers[i4].source === e2) return this.fire(new t.j(new Error(`Source "${e2}" cannot be removed while layer "${i4}" is using it.`)));
const i3 = this.sourceCaches[e2];
delete this.sourceCaches[e2], delete this._updatedSources[e2], i3.fire(new t.k("data", { sourceDataType: "metadata", dataType: "source", sourceId: e2 })), i3.setEventedParent(null), i3.onRemove(this.map), this._changed = true;
}
setGeoJSONSourceData(t2, e2) {
if (this._checkLoaded(), void 0 === this.sourceCaches[t2]) throw new Error(`There is no source with this ID=${t2}`);
const i3 = this.sourceCaches[t2].getSource();
if ("geojson" !== i3.type) throw new Error(`geojsonSource.type is ${i3.type}, which is !== 'geojson`);
i3.setData(e2), this._changed = true;
}
getSource(t2) {
return this.sourceCaches[t2] && this.sourceCaches[t2].getSource();
}
addLayer(e2, i3, s2 = {}) {
this._checkLoaded();
const a2 = e2.id;
if (this.getLayer(a2)) return void this.fire(new t.j(new Error(`Layer "${a2}" already exists on this map.`)));
let o2;
if ("custom" === e2.type) {
if (Jt(this, t.aF(e2))) return;
o2 = t.aC(e2);
} else {
if ("source" in e2 && "object" == typeof e2.source && (this.addSource(a2, e2.source), e2 = t.aD(e2), e2 = t.e(e2, { source: a2 })), this._validate(t.y.layer, `layers.${a2}`, e2, { arrayIndex: -1 }, s2)) return;
o2 = t.aC(e2), this._validateLayer(o2), o2.setEventedParent(this, { layer: { id: a2 } });
}
const r2 = i3 ? this._order.indexOf(i3) : this._order.length;
if (i3 && -1 === r2) this.fire(new t.j(new Error(`Cannot add layer "${a2}" before non-existing layer "${i3}".`)));
else {
if (this._order.splice(r2, 0, a2), this._layerOrderChanged = true, this._layers[a2] = o2, this._removedLayers[a2] && o2.source && "custom" !== o2.type) {
const t2 = this._removedLayers[a2];
delete this._removedLayers[a2], t2.type !== o2.type ? this._updatedSources[o2.source] = "clear" : (this._updatedSources[o2.source] = "reload", this.sourceCaches[o2.source].pause());
}
this._updateLayer(o2), o2.onAdd && o2.onAdd(this.map);
}
}
moveLayer(e2, i3) {
if (this._checkLoaded(), this._changed = true, !this._layers[e2]) return void this.fire(new t.j(new Error(`The layer '${e2}' does not exist in the map's style and cannot be moved.`)));
if (e2 === i3) return;
const s2 = this._order.indexOf(e2);
this._order.splice(s2, 1);
const a2 = i3 ? this._order.indexOf(i3) : this._order.length;
i3 && -1 === a2 ? this.fire(new t.j(new Error(`Cannot move layer "${e2}" before non-existing layer "${i3}".`))) : (this._order.splice(a2, 0, e2), this._layerOrderChanged = true);
}
removeLayer(e2) {
this._checkLoaded();
const i3 = this._layers[e2];
if (!i3) return void this.fire(new t.j(new Error(`Cannot remove non-existing layer "${e2}".`)));
i3.setEventedParent(null);
const s2 = this._order.indexOf(e2);
this._order.splice(s2, 1), this._layerOrderChanged = true, this._changed = true, this._removedLayers[e2] = i3, delete this._layers[e2], this._serializedLayers && delete this._serializedLayers[e2], delete this._updatedLayers[e2], delete this._updatedPaintProps[e2], i3.onRemove && i3.onRemove(this.map);
}
getLayer(t2) {
return this._layers[t2];
}
getLayersOrder() {
return [...this._order];
}
hasLayer(t2) {
return t2 in this._layers;
}
setLayerZoomRange(e2, i3, s2) {
this._checkLoaded();
const a2 = this.getLayer(e2);
a2 ? a2.minzoom === i3 && a2.maxzoom === s2 || (null != i3 && (a2.minzoom = i3), null != s2 && (a2.maxzoom = s2), this._updateLayer(a2)) : this.fire(new t.j(new Error(`Cannot set the zoom range of non-existing layer "${e2}".`)));
}
setFilter(e2, i3, s2 = {}) {
this._checkLoaded();
const a2 = this.getLayer(e2);
if (a2) {
if (!t.aG(a2.filter, i3)) return null == i3 ? (a2.filter = void 0, void this._updateLayer(a2)) : void (this._validate(t.y.filter, `layers.${a2.id}.filter`, i3, null, s2) || (a2.filter = t.aD(i3), this._updateLayer(a2)));
} else this.fire(new t.j(new Error(`Cannot filter non-existing layer "${e2}".`)));
}
getFilter(e2) {
return t.aD(this.getLayer(e2).filter);
}
setLayoutProperty(e2, i3, s2, a2 = {}) {
this._checkLoaded();
const o2 = this.getLayer(e2);
o2 ? t.aG(o2.getLayoutProperty(i3), s2) || (o2.setLayoutProperty(i3, s2, a2), this._updateLayer(o2)) : this.fire(new t.j(new Error(`Cannot style non-existing layer "${e2}".`)));
}
getLayoutProperty(e2, i3) {
const s2 = this.getLayer(e2);
if (s2) return s2.getLayoutProperty(i3);
this.fire(new t.j(new Error(`Cannot get style of non-existing layer "${e2}".`)));
}
setPaintProperty(e2, i3, s2, a2 = {}) {
this._checkLoaded();
const o2 = this.getLayer(e2);
o2 ? t.aG(o2.getPaintProperty(i3), s2) || (o2.setPaintProperty(i3, s2, a2) && this._updateLayer(o2), this._changed = true, this._updatedPaintProps[e2] = true) : this.fire(new t.j(new Error(`Cannot style non-existing layer "${e2}".`)));
}
getPaintProperty(t2, e2) {
return this.getLayer(t2).getPaintProperty(e2);
}
setFeatureState(e2, i3) {
this._checkLoaded();
const s2 = e2.source, a2 = e2.sourceLayer, o2 = this.sourceCaches[s2];
if (void 0 === o2) return void this.fire(new t.j(new Error(`The source '${s2}' does not exist in the map's style.`)));
const r2 = o2.getSource().type;
"geojson" === r2 && a2 ? this.fire(new t.j(new Error("GeoJSON sources cannot have a sourceLayer parameter."))) : "vector" !== r2 || a2 ? (void 0 === e2.id && this.fire(new t.j(new Error("The feature id parameter must be provided."))), o2.setFeatureState(a2, e2.id, i3)) : this.fire(new t.j(new Error("The sourceLayer parameter must be provided for vector source types.")));
}
removeFeatureState(e2, i3) {
this._checkLoaded();
const s2 = e2.source, a2 = this.sourceCaches[s2];
if (void 0 === a2) return void this.fire(new t.j(new Error(`The source '${s2}' does not exist in the map's style.`)));
const o2 = a2.getSource().type, r2 = "vector" === o2 ? e2.sourceLayer : void 0;
"vector" !== o2 || r2 ? i3 && "string" != typeof e2.id && "number" != typeof e2.id ? this.fire(new t.j(new Error("A feature id is required to remove its specific state property."))) : a2.removeFeatureState(r2, e2.id, i3) : this.fire(new t.j(new Error("The sourceLayer parameter must be provided for vector source types.")));
}
getFeatureState(e2) {
this._checkLoaded();
const i3 = e2.source, s2 = e2.sourceLayer, a2 = this.sourceCaches[i3];
if (void 0 !== a2) return "vector" !== a2.getSource().type || s2 ? (void 0 === e2.id && this.fire(new t.j(new Error("The feature id parameter must be provided."))), a2.getFeatureState(s2, e2.id)) : void this.fire(new t.j(new Error("The sourceLayer parameter must be provided for vector source types.")));
this.fire(new t.j(new Error(`The source '${i3}' does not exist in the map's style.`)));
}
getTransition() {
return t.e({ duration: 300, delay: 0 }, this.stylesheet && this.stylesheet.transition);
}
serialize() {
if (!this._loaded) return;
const e2 = t.aH(this.sourceCaches, ((t2) => t2.serialize())), i3 = this._serializeByIds(this._order), s2 = this.map.getTerrain() || void 0, a2 = this.stylesheet;
return t.aI({ version: a2.version, name: a2.name, metadata: a2.metadata, light: a2.light, center: a2.center, zoom: a2.zoom, bearing: a2.bearing, pitch: a2.pitch, sprite: a2.sprite, glyphs: a2.glyphs, transition: a2.transition, sources: e2, layers: i3, terrain: s2 }, ((t2) => void 0 !== t2));
}
_updateLayer(t2) {
this._updatedLayers[t2.id] = true, t2.source && !this._updatedSources[t2.source] && "raster" !== this.sourceCaches[t2.source].getSource().type && (this._updatedSources[t2.source] = "reload", this.sourceCaches[t2.source].pause()), this._serializedLayers = null, this._changed = true;
}
_flattenAndSortRenderedFeatures(t2) {
const e2 = (t3) => "fill-extrusion" === this._layers[t3].type, i3 = {}, s2 = [];
for (let a3 = this._order.length - 1; a3 >= 0; a3--) {
const o2 = this._order[a3];
if (e2(o2)) {
i3[o2] = a3;
for (const e3 of t2) {
const t3 = e3[o2];
if (t3) for (const e4 of t3) s2.push(e4);
}
}
}
s2.sort(((t3, e3) => e3.intersectionZ - t3.intersectionZ));
const a2 = [];
for (let o2 = this._order.length - 1; o2 >= 0; o2--) {
const r2 = this._order[o2];
if (e2(r2)) for (let t3 = s2.length - 1; t3 >= 0; t3--) {
const e3 = s2[t3].feature;
if (i3[e3.layer.id] < o2) break;
a2.push(e3), s2.pop();
}
else for (const e3 of t2) {
const t3 = e3[r2];
if (t3) for (const e4 of t3) a2.push(e4.feature);
}
}
return a2;
}
queryRenderedFeatures(e2, i3, s2) {
i3 && i3.filter && this._validate(t.y.filter, "queryRenderedFeatures.filter", i3.filter, null, i3);
const a2 = {};
if (i3 && i3.layers) {
if (!Array.isArray(i3.layers)) return this.fire(new t.j(new Error("parameters.layers must be an Array."))), [];
for (const e3 of i3.layers) {
const i4 = this._layers[e3];
if (!i4) return this.fire(new t.j(new Error(`The layer '${e3}' does not exist in the map's style and cannot be queried for features.`))), [];
a2[i4.source] = true;
}
}
const o2 = [];
i3.availableImages = this._availableImages;
const r2 = this._serializedAllLayers();
for (const t2 in this.sourceCaches) i3.layers && !a2[t2] || o2.push(q(this.sourceCaches[t2], this._layers, r2, e2, i3, s2));
return this.placement && o2.push((function(t2, e3, i4, s3, a3, o3, r3) {
const n2 = {}, l2 = o3.queryRenderedSymbols(s3), h2 = [];
for (const t3 of Object.keys(l2).map(Number)) h2.push(r3[t3]);
h2.sort($);
for (const i5 of h2) {
const s4 = i5.featureIndex.lookupSymbolFeatures(l2[i5.bucketInstanceId], e3, i5.bucketIndex, i5.sourceLayerIndex, a3.filter, a3.layers, a3.availableImages, t2);
for (const t3 in s4) {
const e4 = n2[t3] = n2[t3] || [], a4 = s4[t3];
a4.sort(((t4, e5) => {
const s5 = i5.featureSortOrder;
if (s5) {
const i6 = s5.indexOf(t4.featureIndex);
return s5.indexOf(e5.featureIndex) - i6;
}
return e5.featureIndex - t4.featureIndex;
}));
for (const t4 of a4) e4.push(t4);
}
}
for (const e4 in n2) n2[e4].forEach(((s4) => {
const a4 = s4.feature, o4 = i4[t2[e4].source].getFeatureState(a4.layer["source-layer"], a4.id);
a4.source = a4.layer.source, a4.layer["source-layer"] && (a4.sourceLayer = a4.layer["source-layer"]), a4.state = o4;
}));
return n2;
})(this._layers, r2, this.sourceCaches, e2, i3, this.placement.collisionIndex, this.placement.retainedQueryData)), this._flattenAndSortRenderedFeatures(o2);
}
querySourceFeatures(e2, i3) {
i3 && i3.filter && this._validate(t.y.filter, "querySourceFeatures.filter", i3.filter, null, i3);
const s2 = this.sourceCaches[e2];
return s2 ? (function(t2, e3) {
const i4 = t2.getRenderableIds().map(((e4) => t2.getTileByID(e4))), s3 = [], a2 = {};
for (let t3 = 0; t3 < i4.length; t3++) {
const o2 = i4[t3], r2 = o2.tileID.canonical.key;
a2[r2] || (a2[r2] = true, o2.querySourceFeatures(s3, e3));
}
return s3;
})(s2, i3) : [];
}
addSourceType(t2, e2, i3) {
return j(t2) ? i3(new Error(`A source type called "${t2}" already exists.`)) : (((t3, e3) => {
G[t3] = e3;
})(t2, e2), e2.workerSourceURL ? void this.dispatcher.broadcast("loadWorkerSource", { name: t2, url: e2.workerSourceURL }, i3) : i3(null, null));
}
getLight() {
return this.light.getLight();
}
setLight(e2, i3 = {}) {
this._checkLoaded();
const s2 = this.light.getLight();
let a2 = false;
for (const i4 in e2) if (!t.aG(e2[i4], s2[i4])) {
a2 = true;
break;
}
if (!a2) return;
const o2 = { now: t.h.now(), transition: t.e({ duration: 300, delay: 0 }, this.stylesheet.transition) };
this.light.setLight(e2, i3), this.light.updateTransitions(o2);
}
_validate(e2, i3, s2, a2, o2 = {}) {
return (!o2 || false !== o2.validate) && Jt(this, e2.call(t.y, t.e({ key: i3, style: this.serialize(), value: s2, styleSpec: t.v }, a2)));
}
_remove(e2 = true) {
this._request && (this._request.cancel(), this._request = null), this._spriteRequest && (this._spriteRequest.cancel(), this._spriteRequest = null), t.aJ.off("pluginStateChange", this._rtlTextPluginCallback);
for (const t2 in this._layers) this._layers[t2].setEventedParent(null);
for (const t2 in this.sourceCaches) {
const e3 = this.sourceCaches[t2];
e3.setEventedParent(null), e3.onRemove(this.map);
}
this.imageManager.setEventedParent(null), this.setEventedParent(null), this.dispatcher.remove(e2);
}
_clearSource(t2) {
this.sourceCaches[t2].clearTiles();
}
_reloadSource(t2) {
this.sourceCaches[t2].resume(), this.sourceCaches[t2].reload();
}
_updateSources(t2) {
for (const e2 in this.sourceCaches) this.sourceCaches[e2].update(t2, this.map.terrain);
}
_generateCollisionBoxes() {
for (const t2 in this.sourceCaches) this._reloadSource(t2);
}
_updatePlacement(e2, i3, s2, a2, o2 = false) {
let r2 = false, n2 = false;
const l2 = {};
for (const t2 of this._order) {
const i4 = this._layers[t2];
if ("symbol" !== i4.type) continue;
if (!l2[i4.source]) {
const t3 = this.sourceCaches[i4.source];
l2[i4.source] = t3.getRenderableIds(true).map(((e3) => t3.getTileByID(e3))).sort(((t4, e3) => e3.tileID.overscaledZ - t4.tileID.overscaledZ || (t4.tileID.isLessThan(e3.tileID) ? -1 : 1)));
}
const s3 = this.crossTileSymbolIndex.addLayer(i4, l2[i4.source], e2.center.lng);
r2 = r2 || s3;
}
if (this.crossTileSymbolIndex.pruneUnusedLayers(this._order), ((o2 = o2 || this._layerOrderChanged || 0 === s2) || !this.pauseablePlacement || this.pauseablePlacement.isDone() && !this.placement.stillRecent(t.h.now(), e2.zoom)) && (this.pauseablePlacement = new Wt(e2, this.map.terrain, this._order, o2, i3, s2, a2, this.placement), this._layerOrderChanged = false), this.pauseablePlacement.isDone() ? this.placement.setStale() : (this.pauseablePlacement.continuePlacement(this._order, this._layers, l2), this.pauseablePlacement.isDone() && (this.placement = this.pauseablePlacement.commit(t.h.now()), n2 = true), r2 && this.pauseablePlacement.placement.setStale()), n2 || r2) for (const t2 of this._order) {
const e3 = this._layers[t2];
"symbol" === e3.type && this.placement.updateLayerOpacities(e3, l2[e3.source]);
}
return !this.pauseablePlacement.isDone() || this.placement.hasTransitions(t.h.now());
}
_releaseSymbolFadeTiles() {
for (const t2 in this.sourceCaches) this.sourceCaches[t2].releaseSymbolFadeTiles();
}
getImages(t2, e2, i3) {
this.imageManager.getImages(e2.icons, i3), this._updateTilesForChangedImages();
const s2 = this.sourceCaches[e2.source];
s2 && s2.setDependencies(e2.tileID.key, e2.type, e2.icons);
}
getGlyphs(t2, e2, i3) {
this.glyphManager.getGlyphs(e2.stacks, i3);
const s2 = this.sourceCaches[e2.source];
s2 && s2.setDependencies(e2.tileID.key, e2.type, [""]);
}
getResource(e2, i3, s2) {
return t.m(i3, s2);
}
getGlyphsUrl() {
return this.stylesheet.glyphs || null;
}
setGlyphs(e2, i3 = {}) {
this._checkLoaded(), e2 && this._validate(t.y.glyphs, "glyphs", e2, null, i3) || (this._glyphsDidChange = true, this.stylesheet.glyphs = e2, this.glyphManager.entries = {}, this.glyphManager.setURL(e2));
}
addSprite(e2, i3, s2 = {}, a2) {
this._checkLoaded();
const o2 = [{ id: e2, url: i3 }], r2 = [...g(this.stylesheet.sprite), ...o2];
this._validate(t.y.sprite, "sprite", r2, null, s2) || (this.stylesheet.sprite = r2, this._loadSprite(o2, true, a2));
}
removeSprite(e2) {
this._checkLoaded();
const i3 = g(this.stylesheet.sprite);
if (i3.find(((t2) => t2.id === e2))) {
if (this._spritesImagesIds[e2]) for (const t2 of this._spritesImagesIds[e2]) this.imageManager.removeImage(t2), this._changedImages[t2] = true;
i3.splice(i3.findIndex(((t2) => t2.id === e2)), 1), this.stylesheet.sprite = i3.length > 0 ? i3 : void 0, delete this._spritesImagesIds[e2], this._availableImages = this.imageManager.listImages(), this._changed = true, this.dispatcher.broadcast("setImages", this._availableImages), this.fire(new t.k("data", { dataType: "style" }));
} else this.fire(new t.j(new Error(`Sprite "${e2}" doesn't exists on this map.`)));
}
getSprite() {
return g(this.stylesheet.sprite);
}
setSprite(e2, i3 = {}, s2) {
this._checkLoaded(), e2 && this._validate(t.y.sprite, "sprite", e2, null, i3) || (this.stylesheet.sprite = e2, e2 ? this._loadSprite(e2, true, s2) : (this._unloadSprite(), s2 && s2(null)));
}
}
se.registerForPluginStateChange = t.aK;
var ae = t.Q([{ name: "a_pos", type: "Int16", components: 2 }]), oe = "attribute vec3 a_pos3d;uniform mat4 u_matrix;uniform float u_ele_delta;varying vec2 v_texture_pos;varying float v_depth;void main() {float extent=8192.0;float ele_delta=a_pos3d.z==1.0 ? u_ele_delta : 0.0;v_texture_pos=a_pos3d.xy/extent;gl_Position=u_matrix*vec4(a_pos3d.xy,get_elevation(a_pos3d.xy)-ele_delta,1.0);v_depth=gl_Position.z/gl_Position.w;}";
const re = { prelude: ne("#ifdef GL_ES\nprecision mediump float;\n#else\n#if !defined(lowp)\n#define lowp\n#endif\n#if !defined(mediump)\n#define mediump\n#endif\n#if !defined(highp)\n#define highp\n#endif\n#endif\n", "#ifdef GL_ES\nprecision highp float;\n#else\n#if !defined(lowp)\n#define lowp\n#endif\n#if !defined(mediump)\n#define mediump\n#endif\n#if !defined(highp)\n#define highp\n#endif\n#endif\nvec2 unpack_float(const float packedValue) {int packedIntValue=int(packedValue);int v0=packedIntValue/256;return vec2(v0,packedIntValue-v0*256);}vec2 unpack_opacity(const float packedOpacity) {int intOpacity=int(packedOpacity)/2;return vec2(float(intOpacity)/127.0,mod(packedOpacity,2.0));}vec4 decode_color(const vec2 encodedColor) {return vec4(unpack_float(encodedColor[0])/255.0,unpack_float(encodedColor[1])/255.0\n);}float unpack_mix_vec2(const vec2 packedValue,const float t) {return mix(packedValue[0],packedValue[1],t);}vec4 unpack_mix_color(const vec4 packedColors,const float t) {vec4 minColor=decode_color(vec2(packedColors[0],packedColors[1]));vec4 maxColor=decode_color(vec2(packedColors[2],packedColors[3]));return mix(minColor,maxColor,t);}vec2 get_pattern_pos(const vec2 pixel_coord_upper,const vec2 pixel_coord_lower,const vec2 pattern_size,const float tile_units_to_pixels,const vec2 pos) {vec2 offset=mod(mod(mod(pixel_coord_upper,pattern_size)*256.0,pattern_size)*256.0+pixel_coord_lower,pattern_size);return (tile_units_to_pixels*pos+offset)/pattern_size;}\n#ifdef TERRAIN3D\nuniform sampler2D u_terrain;uniform float u_terrain_dim;uniform mat4 u_terrain_matrix;uniform vec4 u_terrain_unpack;uniform float u_terrain_exaggeration;uniform highp sampler2D u_depth;\n#endif\nconst highp vec4 bitSh=vec4(256.*256.*256.,256.*256.,256.,1.);const highp vec4 bitShifts=vec4(1.)/bitSh;highp float unpack(highp vec4 color) {return dot(color,bitShifts);}highp float depthOpacity(vec3 frag) {\n#ifdef TERRAIN3D\nhighp float d=unpack(texture2D(u_depth,frag.xy*0.5+0.5))+0.0001-frag.z;return 1.0-max(0.0,min(1.0,-d*500.0));\n#else\nreturn 1.0;\n#endif\n}float calculate_visibility(vec4 pos) {\n#ifdef TERRAIN3D\nvec3 frag=pos.xyz/pos.w;highp float d=depthOpacity(frag);if (d > 0.95) return 1.0;return (d+depthOpacity(frag+vec3(0.0,0.01,0.0)))/2.0;\n#else\nreturn 1.0;\n#endif\n}float ele(vec2 pos) {\n#ifdef TERRAIN3D\nvec4 rgb=(texture2D(u_terrain,pos)*255.0)*u_terrain_unpack;return rgb.r+rgb.g+rgb.b-u_terrain_unpack.a;\n#else\nreturn 0.0;\n#endif\n}float get_elevation(vec2 pos) {\n#ifdef TERRAIN3D\nvec2 coord=(u_terrain_matrix*vec4(pos,0.0,1.0)).xy*u_terrain_dim+1.0;vec2 f=fract(coord);vec2 c=(floor(coord)+0.5)/(u_terrain_dim+2.0);float d=1.0/(u_terrain_dim+2.0);float tl=ele(c);float tr=ele(c+vec2(d,0.0));float bl=ele(c+vec2(0.0,d));float br=ele(c+vec2(d,d));float elevation=mix(mix(tl,tr,f.x),mix(bl,br,f.x),f.y);return elevation*u_terrain_exaggeration;\n#else\nreturn 0.0;\n#endif\n}"), background: ne("uniform vec4 u_color;uniform float u_opacity;void main() {gl_FragColor=u_color*u_opacity;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "attribute vec2 a_pos;uniform mat4 u_matrix;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);}"), backgroundPattern: ne("uniform vec2 u_pattern_tl_a;uniform vec2 u_pattern_br_a;uniform vec2 u_pattern_tl_b;uniform vec2 u_pattern_br_b;uniform vec2 u_texsize;uniform float u_mix;uniform float u_opacity;uniform sampler2D u_image;varying vec2 v_pos_a;varying vec2 v_pos_b;void main() {vec2 imagecoord=mod(v_pos_a,1.0);vec2 pos=mix(u_pattern_tl_a/u_texsize,u_pattern_br_a/u_texsize,imagecoord);vec4 color1=texture2D(u_image,pos);vec2 imagecoord_b=mod(v_pos_b,1.0);vec2 pos2=mix(u_pattern_tl_b/u_texsize,u_pattern_br_b/u_texsize,imagecoord_b);vec4 color2=texture2D(u_image,pos2);gl_FragColor=mix(color1,color2,u_mix)*u_opacity;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "uniform mat4 u_matrix;uniform vec2 u_pattern_size_a;uniform vec2 u_pattern_size_b;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform float u_scale_a;uniform float u_scale_b;uniform float u_tile_units_to_pixels;attribute vec2 a_pos;varying vec2 v_pos_a;varying vec2 v_pos_b;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);v_pos_a=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,u_scale_a*u_pattern_size_a,u_tile_units_to_pixels,a_pos);v_pos_b=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,u_scale_b*u_pattern_size_b,u_tile_units_to_pixels,a_pos);}"), circle: ne("varying vec3 v_data;varying float v_visibility;\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define mediump float radius\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define highp vec4 stroke_color\n#pragma mapbox: define mediump float stroke_width\n#pragma mapbox: define lowp float stroke_opacity\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize mediump float radius\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize highp vec4 stroke_color\n#pragma mapbox: initialize mediump float stroke_width\n#pragma mapbox: initialize lowp float stroke_opacity\nvec2 extrude=v_data.xy;float extrude_length=length(extrude);lowp float antialiasblur=v_data.z;float antialiased_blur=-max(blur,antialiasblur);float opacity_t=smoothstep(0.0,antialiased_blur,extrude_length-1.0);float color_t=stroke_width < 0.01 ? 0.0 : smoothstep(antialiased_blur,0.0,extrude_length-radius/(radius+stroke_width));gl_FragColor=v_visibility*opacity_t*mix(color*opacity,stroke_color*stroke_opacity,color_t);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "uniform mat4 u_matrix;uniform bool u_scale_with_map;uniform bool u_pitch_with_map;uniform vec2 u_extrude_scale;uniform lowp float u_device_pixel_ratio;uniform highp float u_camera_to_center_distance;attribute vec2 a_pos;varying vec3 v_data;varying float v_visibility;\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define mediump float radius\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define highp vec4 stroke_color\n#pragma mapbox: define mediump float stroke_width\n#pragma mapbox: define lowp float stroke_opacity\nvoid main(void) {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize mediump float radius\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize highp vec4 stroke_color\n#pragma mapbox: initialize mediump float stroke_width\n#pragma mapbox: initialize lowp float stroke_opacity\nvec2 extrude=vec2(mod(a_pos,2.0)*2.0-1.0);vec2 circle_center=floor(a_pos*0.5);float ele=get_elevation(circle_center);v_visibility=calculate_visibility(u_matrix*vec4(circle_center,ele,1.0));if (u_pitch_with_map) {vec2 corner_position=circle_center;if (u_scale_with_map) {corner_position+=extrude*(radius+stroke_width)*u_extrude_scale;} else {vec4 projected_center=u_matrix*vec4(circle_center,0,1);corner_position+=extrude*(radius+stroke_width)*u_extrude_scale*(projected_center.w/u_camera_to_center_distance);}gl_Position=u_matrix*vec4(corner_position,ele,1);} else {gl_Position=u_matrix*vec4(circle_center,ele,1);if (u_scale_with_map) {gl_Position.xy+=extrude*(radius+stroke_width)*u_extrude_scale*u_camera_to_center_distance;} else {gl_Position.xy+=extrude*(radius+stroke_width)*u_extrude_scale*gl_Position.w;}}lowp float antialiasblur=1.0/u_device_pixel_ratio/(radius+stroke_width);v_data=vec3(extrude.x,extrude.y,antialiasblur);}"), clippingMask: ne("void main() {gl_FragColor=vec4(1.0);}", "attribute vec2 a_pos;uniform mat4 u_matrix;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);}"), heatmap: ne("uniform highp float u_intensity;varying vec2 v_extrude;\n#pragma mapbox: define highp float weight\n#define GAUSS_COEF 0.3989422804014327\nvoid main() {\n#pragma mapbox: initialize highp float weight\nfloat d=-0.5*3.0*3.0*dot(v_extrude,v_extrude);float val=weight*u_intensity*GAUSS_COEF*exp(d);gl_FragColor=vec4(val,1.0,1.0,1.0);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "uniform mat4 u_matrix;uniform float u_extrude_scale;uniform float u_opacity;uniform float u_intensity;attribute vec2 a_pos;varying vec2 v_extrude;\n#pragma mapbox: define highp float weight\n#pragma mapbox: define mediump float radius\nconst highp float ZERO=1.0/255.0/16.0;\n#define GAUSS_COEF 0.3989422804014327\nvoid main(void) {\n#pragma mapbox: initialize highp float weight\n#pragma mapbox: initialize mediump float radius\nvec2 unscaled_extrude=vec2(mod(a_pos,2.0)*2.0-1.0);float S=sqrt(-2.0*log(ZERO/weight/u_intensity/GAUSS_COEF))/3.0;v_extrude=S*unscaled_extrude;vec2 extrude=v_extrude*radius*u_extrude_scale;vec4 pos=vec4(floor(a_pos*0.5)+extrude,0,1);gl_Position=u_matrix*pos;}"), heatmapTexture: ne("uniform sampler2D u_image;uniform sampler2D u_color_ramp;uniform float u_opacity;varying vec2 v_pos;void main() {float t=texture2D(u_image,v_pos).r;vec4 color=texture2D(u_color_ramp,vec2(t,0.5));gl_FragColor=color*u_opacity;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(0.0);\n#endif\n}", "uniform mat4 u_matrix;uniform vec2 u_world;attribute vec2 a_pos;varying vec2 v_pos;void main() {gl_Position=u_matrix*vec4(a_pos*u_world,0,1);v_pos.x=a_pos.x;v_pos.y=1.0-a_pos.y;}"), collisionBox: ne("varying float v_placed;varying float v_notUsed;void main() {float alpha=0.5;gl_FragColor=vec4(1.0,0.0,0.0,1.0)*alpha;if (v_placed > 0.5) {gl_FragColor=vec4(0.0,0.0,1.0,0.5)*alpha;}if (v_notUsed > 0.5) {gl_FragColor*=.1;}}", "attribute vec2 a_pos;attribute vec2 a_anchor_pos;attribute vec2 a_extrude;attribute vec2 a_placed;attribute vec2 a_shift;uniform mat4 u_matrix;uniform vec2 u_extrude_scale;uniform float u_camera_to_center_distance;varying float v_placed;varying float v_notUsed;void main() {vec4 projectedPoint=u_matrix*vec4(a_anchor_pos,0,1);highp float camera_to_anchor_distance=projectedPoint.w;highp float collision_perspective_ratio=clamp(0.5+0.5*(u_camera_to_center_distance/camera_to_anchor_distance),0.0,4.0);gl_Position=u_matrix*vec4(a_pos,get_elevation(a_pos),1.0);gl_Position.xy+=(a_extrude+a_shift)*u_extrude_scale*gl_Position.w*collision_perspective_ratio;v_placed=a_placed.x;v_notUsed=a_placed.y;}"), collisionCircle: ne("varying float v_radius;varying vec2 v_extrude;varying float v_perspective_ratio;varying float v_collision;void main() {float alpha=0.5*min(v_perspective_ratio,1.0);float stroke_radius=0.9*max(v_perspective_ratio,1.0);float distance_to_center=length(v_extrude);float distance_to_edge=abs(distance_to_center-v_radius);float opacity_t=smoothstep(-stroke_radius,0.0,-distance_to_edge);vec4 color=mix(vec4(0.0,0.0,1.0,0.5),vec4(1.0,0.0,0.0,1.0),v_collision);gl_FragColor=color*alpha*opacity_t;}", "attribute vec2 a_pos;attribute float a_radius;attribute vec2 a_flags;uniform mat4 u_matrix;uniform mat4 u_inv_matrix;uniform vec2 u_viewport_size;uniform float u_camera_to_center_distance;varying float v_radius;varying vec2 v_extrude;varying float v_perspective_ratio;varying float v_collision;vec3 toTilePosition(vec2 screenPos) {vec4 rayStart=u_inv_matrix*vec4(screenPos,-1.0,1.0);vec4 rayEnd =u_inv_matrix*vec4(screenPos, 1.0,1.0);rayStart.xyz/=rayStart.w;rayEnd.xyz /=rayEnd.w;highp float t=(0.0-rayStart.z)/(rayEnd.z-rayStart.z);return mix(rayStart.xyz,rayEnd.xyz,t);}void main() {vec2 quadCenterPos=a_pos;float radius=a_radius;float collision=a_flags.x;float vertexIdx=a_flags.y;vec2 quadVertexOffset=vec2(mix(-1.0,1.0,float(vertexIdx >=2.0)),mix(-1.0,1.0,float(vertexIdx >=1.0 && vertexIdx <=2.0)));vec2 quadVertexExtent=quadVertexOffset*radius;vec3 tilePos=toTilePosition(quadCenterPos);vec4 clipPos=u_matrix*vec4(tilePos,1.0);highp float camera_to_anchor_distance=clipPos.w;highp float collision_perspective_ratio=clamp(0.5+0.5*(u_camera_to_center_distance/camera_to_anchor_distance),0.0,4.0);float padding_factor=1.2;v_radius=radius;v_extrude=quadVertexExtent*padding_factor;v_perspective_ratio=collision_perspective_ratio;v_collision=collision;gl_Position=vec4(clipPos.xyz/clipPos.w,1.0)+vec4(quadVertexExtent*padding_factor/u_viewport_size*2.0,0.0,0.0);}"), debug: ne("uniform highp vec4 u_color;uniform sampler2D u_overlay;varying vec2 v_uv;void main() {vec4 overlay_color=texture2D(u_overlay,v_uv);gl_FragColor=mix(u_color,overlay_color,overlay_color.a);}", "attribute vec2 a_pos;varying vec2 v_uv;uniform mat4 u_matrix;uniform float u_overlay_scale;void main() {v_uv=a_pos/8192.0;gl_Position=u_matrix*vec4(a_pos*u_overlay_scale,get_elevation(a_pos),1);}"), fill: ne("#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float opacity\ngl_FragColor=color*opacity;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "attribute vec2 a_pos;uniform mat4 u_matrix;\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float opacity\ngl_Position=u_matrix*vec4(a_pos,0,1);}"), fillOutline: ne("varying vec2 v_pos;\n#pragma mapbox: define highp vec4 outline_color\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize highp vec4 outline_color\n#pragma mapbox: initialize lowp float opacity\nfloat dist=length(v_pos-gl_FragCoord.xy);float alpha=1.0-smoothstep(0.0,1.0,dist);gl_FragColor=outline_color*(alpha*opacity);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "attribute vec2 a_pos;uniform mat4 u_matrix;uniform vec2 u_world;varying vec2 v_pos;\n#pragma mapbox: define highp vec4 outline_color\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize highp vec4 outline_color\n#pragma mapbox: initialize lowp float opacity\ngl_Position=u_matrix*vec4(a_pos,0,1);v_pos=(gl_Position.xy/gl_Position.w+1.0)/2.0*u_world;}"), fillOutlinePattern: ne("uniform vec2 u_texsize;uniform sampler2D u_image;uniform float u_fade;varying vec2 v_pos_a;varying vec2 v_pos_b;varying vec2 v_pos;\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;vec2 imagecoord=mod(v_pos_a,1.0);vec2 pos=mix(pattern_tl_a/u_texsize,pattern_br_a/u_texsize,imagecoord);vec4 color1=texture2D(u_image,pos);vec2 imagecoord_b=mod(v_pos_b,1.0);vec2 pos2=mix(pattern_tl_b/u_texsize,pattern_br_b/u_texsize,imagecoord_b);vec4 color2=texture2D(u_image,pos2);float dist=length(v_pos-gl_FragCoord.xy);float alpha=1.0-smoothstep(0.0,1.0,dist);gl_FragColor=mix(color1,color2,u_fade)*alpha*opacity;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "uniform mat4 u_matrix;uniform vec2 u_world;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform vec3 u_scale;attribute vec2 a_pos;varying vec2 v_pos_a;varying vec2 v_pos_b;varying vec2 v_pos;\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\n#pragma mapbox: define lowp float pixel_ratio_from\n#pragma mapbox: define lowp float pixel_ratio_to\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\n#pragma mapbox: initialize lowp float pixel_ratio_from\n#pragma mapbox: initialize lowp float pixel_ratio_to\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;gl_Position=u_matrix*vec4(a_pos,0,1);vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;v_pos_a=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,fromScale*display_size_a,tileRatio,a_pos);v_pos_b=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,toScale*display_size_b,tileRatio,a_pos);v_pos=(gl_Position.xy/gl_Position.w+1.0)/2.0*u_world;}"), fillPattern: ne("#ifdef GL_ES\nprecision highp float;\n#endif\nuniform vec2 u_texsize;uniform float u_fade;uniform sampler2D u_image;varying vec2 v_pos_a;varying vec2 v_pos_b;\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;vec2 imagecoord=mod(v_pos_a,1.0);vec2 pos=mix(pattern_tl_a/u_texsize,pattern_br_a/u_texsize,imagecoord);vec4 color1=texture2D(u_image,pos);vec2 imagecoord_b=mod(v_pos_b,1.0);vec2 pos2=mix(pattern_tl_b/u_texsize,pattern_br_b/u_texsize,imagecoord_b);vec4 color2=texture2D(u_image,pos2);gl_FragColor=mix(color1,color2,u_fade)*opacity;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "uniform mat4 u_matrix;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform vec3 u_scale;attribute vec2 a_pos;varying vec2 v_pos_a;varying vec2 v_pos_b;\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\n#pragma mapbox: define lowp float pixel_ratio_from\n#pragma mapbox: define lowp float pixel_ratio_to\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\n#pragma mapbox: initialize lowp float pixel_ratio_from\n#pragma mapbox: initialize lowp float pixel_ratio_to\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileZoomRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;gl_Position=u_matrix*vec4(a_pos,0,1);v_pos_a=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,fromScale*display_size_a,tileZoomRatio,a_pos);v_pos_b=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,toScale*display_size_b,tileZoomRatio,a_pos);}"), fillExtrusion: ne("varying vec4 v_color;void main() {gl_FragColor=v_color;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "uniform mat4 u_matrix;uniform vec3 u_lightcolor;uniform lowp vec3 u_lightpos;uniform lowp float u_lightintensity;uniform float u_vertical_gradient;uniform lowp float u_opacity;attribute vec2 a_pos;attribute vec4 a_normal_ed;\n#ifdef TERRAIN3D\nattribute vec2 a_centroid;\n#endif\nvarying vec4 v_color;\n#pragma mapbox: define highp float base\n#pragma mapbox: define highp float height\n#pragma mapbox: define highp vec4 color\nvoid main() {\n#pragma mapbox: initialize highp float base\n#pragma mapbox: initialize highp float height\n#pragma mapbox: initialize highp vec4 color\nvec3 normal=a_normal_ed.xyz;\n#ifdef TERRAIN3D\nfloat height_terrain3d_offset=get_elevation(a_centroid);float base_terrain3d_offset=height_terrain3d_offset-(base > 0.0 ? 0.0 : 10.0);\n#else\nfloat height_terrain3d_offset=0.0;float base_terrain3d_offset=0.0;\n#endif\nbase=max(0.0,base)+base_terrain3d_offset;height=max(0.0,height)+height_terrain3d_offset;float t=mod(normal.x,2.0);gl_Position=u_matrix*vec4(a_pos,t > 0.0 ? height : base,1);float colorvalue=color.r*0.2126+color.g*0.7152+color.b*0.0722;v_color=vec4(0.0,0.0,0.0,1.0);vec4 ambientlight=vec4(0.03,0.03,0.03,1.0);color+=ambientlight;float directional=clamp(dot(normal/16384.0,u_lightpos),0.0,1.0);directional=mix((1.0-u_lightintensity),max((1.0-colorvalue+u_lightintensity),1.0),directional);if (normal.y !=0.0) {directional*=((1.0-u_vertical_gradient)+(u_vertical_gradient*clamp((t+base)*pow(height/150.0,0.5),mix(0.7,0.98,1.0-u_lightintensity),1.0)));}v_color.r+=clamp(color.r*directional*u_lightcolor.r,mix(0.0,0.3,1.0-u_lightcolor.r),1.0);v_color.g+=clamp(color.g*directional*u_lightcolor.g,mix(0.0,0.3,1.0-u_lightcolor.g),1.0);v_color.b+=clamp(color.b*directional*u_lightcolor.b,mix(0.0,0.3,1.0-u_lightcolor.b),1.0);v_color*=u_opacity;}"), fillExtrusionPattern: ne("uniform vec2 u_texsize;uniform float u_fade;uniform sampler2D u_image;varying vec2 v_pos_a;varying vec2 v_pos_b;varying vec4 v_lighting;\n#pragma mapbox: define lowp float base\n#pragma mapbox: define lowp float height\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\n#pragma mapbox: define lowp float pixel_ratio_from\n#pragma mapbox: define lowp float pixel_ratio_to\nvoid main() {\n#pragma mapbox: initialize lowp float base\n#pragma mapbox: initialize lowp float height\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\n#pragma mapbox: initialize lowp float pixel_ratio_from\n#pragma mapbox: initialize lowp float pixel_ratio_to\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;vec2 imagecoord=mod(v_pos_a,1.0);vec2 pos=mix(pattern_tl_a/u_texsize,pattern_br_a/u_texsize,imagecoord);vec4 color1=texture2D(u_image,pos);vec2 imagecoord_b=mod(v_pos_b,1.0);vec2 pos2=mix(pattern_tl_b/u_texsize,pattern_br_b/u_texsize,imagecoord_b);vec4 color2=texture2D(u_image,pos2);vec4 mixedColor=mix(color1,color2,u_fade);gl_FragColor=mixedColor*v_lighting;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "uniform mat4 u_matrix;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform float u_height_factor;uniform vec3 u_scale;uniform float u_vertical_gradient;uniform lowp float u_opacity;uniform vec3 u_lightcolor;uniform lowp vec3 u_lightpos;uniform lowp float u_lightintensity;attribute vec2 a_pos;attribute vec4 a_normal_ed;\n#ifdef TERRAIN3D\nattribute vec2 a_centroid;\n#endif\nvarying vec2 v_pos_a;varying vec2 v_pos_b;varying vec4 v_lighting;\n#pragma mapbox: define lowp float base\n#pragma mapbox: define lowp float height\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\n#pragma mapbox: define lowp float pixel_ratio_from\n#pragma mapbox: define lowp float pixel_ratio_to\nvoid main() {\n#pragma mapbox: initialize lowp float base\n#pragma mapbox: initialize lowp float height\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\n#pragma mapbox: initialize lowp float pixel_ratio_from\n#pragma mapbox: initialize lowp float pixel_ratio_to\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;vec3 normal=a_normal_ed.xyz;float edgedistance=a_normal_ed.w;vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;\n#ifdef TERRAIN3D\nfloat height_terrain3d_offset=get_elevation(a_centroid);float base_terrain3d_offset=height_terrain3d_offset-(base > 0.0 ? 0.0 : 10.0);\n#else\nfloat height_terrain3d_offset=0.0;float base_terrain3d_offset=0.0;\n#endif\nbase=max(0.0,base)+base_terrain3d_offset;height=max(0.0,height)+height_terrain3d_offset;float t=mod(normal.x,2.0);float z=t > 0.0 ? height : base;gl_Position=u_matrix*vec4(a_pos,z,1);vec2 pos=normal.x==1.0 && normal.y==0.0 && normal.z==16384.0\n? a_pos\n: vec2(edgedistance,z*u_height_factor);v_pos_a=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,fromScale*display_size_a,tileRatio,pos);v_pos_b=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,toScale*display_size_b,tileRatio,pos);v_lighting=vec4(0.0,0.0,0.0,1.0);float directional=clamp(dot(normal/16383.0,u_lightpos),0.0,1.0);directional=mix((1.0-u_lightintensity),max((0.5+u_lightintensity),1.0),directional);if (normal.y !=0.0) {directional*=((1.0-u_vertical_gradient)+(u_vertical_gradient*clamp((t+base)*pow(height/150.0,0.5),mix(0.7,0.98,1.0-u_lightintensity),1.0)));}v_lighting.rgb+=clamp(directional*u_lightcolor,mix(vec3(0.0),vec3(0.3),1.0-u_lightcolor),vec3(1.0));v_lighting*=u_opacity;}"), hillshadePrepare: ne("#ifdef GL_ES\nprecision highp float;\n#endif\nuniform sampler2D u_image;varying vec2 v_pos;uniform vec2 u_dimension;uniform float u_zoom;uniform vec4 u_unpack;float getElevation(vec2 coord,float bias) {vec4 data=texture2D(u_image,coord)*255.0;data.a=-1.0;return dot(data,u_unpack)/4.0;}void main() {vec2 epsilon=1.0/u_dimension;float a=getElevation(v_pos+vec2(-epsilon.x,-epsilon.y),0.0);float b=getElevation(v_pos+vec2(0,-epsilon.y),0.0);float c=getElevation(v_pos+vec2(epsilon.x,-epsilon.y),0.0);float d=getElevation(v_pos+vec2(-epsilon.x,0),0.0);float e=getElevation(v_pos,0.0);float f=getElevation(v_pos+vec2(epsilon.x,0),0.0);float g=getElevation(v_pos+vec2(-epsilon.x,epsilon.y),0.0);float h=getElevation(v_pos+vec2(0,epsilon.y),0.0);float i=getElevation(v_pos+vec2(epsilon.x,epsilon.y),0.0);float exaggerationFactor=u_zoom < 2.0 ? 0.4 : u_zoom < 4.5 ? 0.35 : 0.3;float exaggeration=u_zoom < 15.0 ? (u_zoom-15.0)*exaggerationFactor : 0.0;vec2 deriv=vec2((c+f+f+i)-(a+d+d+g),(g+h+h+i)-(a+b+b+c))/pow(2.0,exaggeration+(19.2562-u_zoom));gl_FragColor=clamp(vec4(deriv.x/2.0+0.5,deriv.y/2.0+0.5,1.0,1.0),0.0,1.0);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "uniform mat4 u_matrix;uniform vec2 u_dimension;attribute vec2 a_pos;attribute vec2 a_texture_pos;varying vec2 v_pos;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);highp vec2 epsilon=1.0/u_dimension;float scale=(u_dimension.x-2.0)/u_dimension.x;v_pos=(a_texture_pos/8192.0)*scale+epsilon;}"), hillshade: ne("uniform sampler2D u_image;varying vec2 v_pos;uniform vec2 u_latrange;uniform vec2 u_light;uniform vec4 u_shadow;uniform vec4 u_highlight;uniform vec4 u_accent;\n#define PI 3.141592653589793\nvoid main() {vec4 pixel=texture2D(u_image,v_pos);vec2 deriv=((pixel.rg*2.0)-1.0);float scaleFactor=cos(radians((u_latrange[0]-u_latrange[1])*(1.0-v_pos.y)+u_latrange[1]));float slope=atan(1.25*length(deriv)/scaleFactor);float aspect=deriv.x !=0.0 ? atan(deriv.y,-deriv.x) : PI/2.0*(deriv.y > 0.0 ? 1.0 :-1.0);float intensity=u_light.x;float azimuth=u_light.y+PI;float base=1.875-intensity*1.75;float maxValue=0.5*PI;float scaledSlope=intensity !=0.5 ? ((pow(base,slope)-1.0)/(pow(base,maxValue)-1.0))*maxValue : slope;float accent=cos(scaledSlope);vec4 accent_color=(1.0-accent)*u_accent*clamp(intensity*2.0,0.0,1.0);float shade=abs(mod((aspect+azimuth)/PI+0.5,2.0)-1.0);vec4 shade_color=mix(u_shadow,u_highlight,shade)*sin(scaledSlope)*clamp(intensity*2.0,0.0,1.0);gl_FragColor=accent_color*(1.0-shade_color.a)+shade_color;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "uniform mat4 u_matrix;attribute vec2 a_pos;attribute vec2 a_texture_pos;varying vec2 v_pos;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);v_pos=a_texture_pos/8192.0;}"), line: ne("uniform lowp float u_device_pixel_ratio;varying vec2 v_width2;varying vec2 v_normal;varying float v_gamma_scale;\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\nfloat dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);gl_FragColor=color*(alpha*opacity);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "\n#define scale 0.015873016\nattribute vec2 a_pos_normal;attribute vec4 a_data;uniform mat4 u_matrix;uniform mediump float u_ratio;uniform vec2 u_units_to_pixels;uniform lowp float u_device_pixel_ratio;varying vec2 v_normal;varying vec2 v_width2;varying float v_gamma_scale;varying highp float v_linesofar;\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define mediump float gapwidth\n#pragma mapbox: define lowp float offset\n#pragma mapbox: define mediump float width\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump float gapwidth\n#pragma mapbox: initialize lowp float offset\n#pragma mapbox: initialize mediump float width\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;v_linesofar=(floor(a_data.z/4.0)+a_data.w*64.0)*2.0;vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;\n#ifdef TERRAIN3D\nv_gamma_scale=1.0;\n#else\nfloat extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;\n#endif\nv_width2=vec2(outset,inset);}"), lineGradient: ne("uniform lowp float u_device_pixel_ratio;uniform sampler2D u_image;varying vec2 v_width2;varying vec2 v_normal;varying float v_gamma_scale;varying highp vec2 v_uv;\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\nfloat dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);vec4 color=texture2D(u_image,v_uv);gl_FragColor=color*(alpha*opacity);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "\n#define scale 0.015873016\nattribute vec2 a_pos_normal;attribute vec4 a_data;attribute float a_uv_x;attribute float a_split_index;uniform mat4 u_matrix;uniform mediump float u_ratio;uniform lowp float u_device_pixel_ratio;uniform vec2 u_units_to_pixels;uniform float u_image_height;varying vec2 v_normal;varying vec2 v_width2;varying float v_gamma_scale;varying highp vec2 v_uv;\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define mediump float gapwidth\n#pragma mapbox: define lowp float offset\n#pragma mapbox: define mediump float width\nvoid main() {\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump float gapwidth\n#pragma mapbox: initialize lowp float offset\n#pragma mapbox: initialize mediump float width\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;highp float texel_height=1.0/u_image_height;highp float half_texel_height=0.5*texel_height;v_uv=vec2(a_uv_x,a_split_index*texel_height-half_texel_height);vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;\n#ifdef TERRAIN3D\nv_gamma_scale=1.0;\n#else\nfloat extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;\n#endif\nv_width2=vec2(outset,inset);}"), linePattern: ne("#ifdef GL_ES\nprecision highp float;\n#endif\nuniform lowp float u_device_pixel_ratio;uniform vec2 u_texsize;uniform float u_fade;uniform mediump vec3 u_scale;uniform sampler2D u_image;varying vec2 v_normal;varying vec2 v_width2;varying float v_linesofar;varying float v_gamma_scale;varying float v_width;\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\n#pragma mapbox: define lowp float pixel_ratio_from\n#pragma mapbox: define lowp float pixel_ratio_to\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\n#pragma mapbox: initialize lowp float pixel_ratio_from\n#pragma mapbox: initialize lowp float pixel_ratio_to\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\nvec2 pattern_tl_a=pattern_from.xy;vec2 pattern_br_a=pattern_from.zw;vec2 pattern_tl_b=pattern_to.xy;vec2 pattern_br_b=pattern_to.zw;float tileZoomRatio=u_scale.x;float fromScale=u_scale.y;float toScale=u_scale.z;vec2 display_size_a=(pattern_br_a-pattern_tl_a)/pixel_ratio_from;vec2 display_size_b=(pattern_br_b-pattern_tl_b)/pixel_ratio_to;vec2 pattern_size_a=vec2(display_size_a.x*fromScale/tileZoomRatio,display_size_a.y);vec2 pattern_size_b=vec2(display_size_b.x*toScale/tileZoomRatio,display_size_b.y);float aspect_a=display_size_a.y/v_width;float aspect_b=display_size_b.y/v_width;float dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);float x_a=mod(v_linesofar/pattern_size_a.x*aspect_a,1.0);float x_b=mod(v_linesofar/pattern_size_b.x*aspect_b,1.0);float y=0.5*v_normal.y+0.5;vec2 texel_size=1.0/u_texsize;vec2 pos_a=mix(pattern_tl_a*texel_size-texel_size,pattern_br_a*texel_size+texel_size,vec2(x_a,y));vec2 pos_b=mix(pattern_tl_b*texel_size-texel_size,pattern_br_b*texel_size+texel_size,vec2(x_b,y));vec4 color=mix(texture2D(u_image,pos_a),texture2D(u_image,pos_b),u_fade);gl_FragColor=color*alpha*opacity;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "\n#define scale 0.015873016\n#define LINE_DISTANCE_SCALE 2.0\nattribute vec2 a_pos_normal;attribute vec4 a_data;uniform mat4 u_matrix;uniform vec2 u_units_to_pixels;uniform mediump float u_ratio;uniform lowp float u_device_pixel_ratio;varying vec2 v_normal;varying vec2 v_width2;varying float v_linesofar;varying float v_gamma_scale;varying float v_width;\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp float offset\n#pragma mapbox: define mediump float gapwidth\n#pragma mapbox: define mediump float width\n#pragma mapbox: define lowp float floorwidth\n#pragma mapbox: define lowp vec4 pattern_from\n#pragma mapbox: define lowp vec4 pattern_to\n#pragma mapbox: define lowp float pixel_ratio_from\n#pragma mapbox: define lowp float pixel_ratio_to\nvoid main() {\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize lowp float offset\n#pragma mapbox: initialize mediump float gapwidth\n#pragma mapbox: initialize mediump float width\n#pragma mapbox: initialize lowp float floorwidth\n#pragma mapbox: initialize mediump vec4 pattern_from\n#pragma mapbox: initialize mediump vec4 pattern_to\n#pragma mapbox: initialize lowp float pixel_ratio_from\n#pragma mapbox: initialize lowp float pixel_ratio_to\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;float a_linesofar=(floor(a_data.z/4.0)+a_data.w*64.0)*LINE_DISTANCE_SCALE;vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;\n#ifdef TERRAIN3D\nv_gamma_scale=1.0;\n#else\nfloat extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;\n#endif\nv_linesofar=a_linesofar;v_width2=vec2(outset,inset);v_width=floorwidth;}"), lineSDF: ne("uniform lowp float u_device_pixel_ratio;uniform sampler2D u_image;uniform float u_sdfgamma;uniform float u_mix;varying vec2 v_normal;varying vec2 v_width2;varying vec2 v_tex_a;varying vec2 v_tex_b;varying float v_gamma_scale;\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define mediump float width\n#pragma mapbox: define lowp float floorwidth\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump float width\n#pragma mapbox: initialize lowp float floorwidth\nfloat dist=length(v_normal)*v_width2.s;float blur2=(blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);float sdfdist_a=texture2D(u_image,v_tex_a).a;float sdfdist_b=texture2D(u_image,v_tex_b).a;float sdfdist=mix(sdfdist_a,sdfdist_b,u_mix);alpha*=smoothstep(0.5-u_sdfgamma/floorwidth,0.5+u_sdfgamma/floorwidth,sdfdist);gl_FragColor=color*(alpha*opacity);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "\n#define scale 0.015873016\n#define LINE_DISTANCE_SCALE 2.0\nattribute vec2 a_pos_normal;attribute vec4 a_data;uniform mat4 u_matrix;uniform mediump float u_ratio;uniform lowp float u_device_pixel_ratio;uniform vec2 u_patternscale_a;uniform float u_tex_y_a;uniform vec2 u_patternscale_b;uniform float u_tex_y_b;uniform vec2 u_units_to_pixels;varying vec2 v_normal;varying vec2 v_width2;varying vec2 v_tex_a;varying vec2 v_tex_b;varying float v_gamma_scale;\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define mediump float gapwidth\n#pragma mapbox: define lowp float offset\n#pragma mapbox: define mediump float width\n#pragma mapbox: define lowp float floorwidth\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump float gapwidth\n#pragma mapbox: initialize lowp float offset\n#pragma mapbox: initialize mediump float width\n#pragma mapbox: initialize lowp float floorwidth\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=a_data.xy-128.0;float a_direction=mod(a_data.z,4.0)-1.0;float a_linesofar=(floor(a_data.z/4.0)+a_data.w*64.0)*LINE_DISTANCE_SCALE;vec2 pos=floor(a_pos_normal*0.5);mediump vec2 normal=a_pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=width/2.0;offset=-1.0*offset;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*scale;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist/u_ratio,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2/u_ratio,0.0,1.0)+projected_extrude;\n#ifdef TERRAIN3D\nv_gamma_scale=1.0;\n#else\nfloat extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude.xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=extrude_length_without_perspective/extrude_length_with_perspective;\n#endif\nv_tex_a=vec2(a_linesofar*u_patternscale_a.x/floorwidth,normal.y*u_patternscale_a.y+u_tex_y_a);v_tex_b=vec2(a_linesofar*u_patternscale_b.x/floorwidth,normal.y*u_patternscale_b.y+u_tex_y_b);v_width2=vec2(outset,inset);}"), raster: ne("uniform float u_fade_t;uniform float u_opacity;uniform sampler2D u_image0;uniform sampler2D u_image1;varying vec2 v_pos0;varying vec2 v_pos1;uniform float u_brightness_low;uniform float u_brightness_high;uniform float u_saturation_factor;uniform float u_contrast_factor;uniform vec3 u_spin_weights;void main() {vec4 color0=texture2D(u_image0,v_pos0);vec4 color1=texture2D(u_image1,v_pos1);if (color0.a > 0.0) {color0.rgb=color0.rgb/color0.a;}if (color1.a > 0.0) {color1.rgb=color1.rgb/color1.a;}vec4 color=mix(color0,color1,u_fade_t);color.a*=u_opacity;vec3 rgb=color.rgb;rgb=vec3(dot(rgb,u_spin_weights.xyz),dot(rgb,u_spin_weights.zxy),dot(rgb,u_spin_weights.yzx));float average=(color.r+color.g+color.b)/3.0;rgb+=(average-rgb)*u_saturation_factor;rgb=(rgb-0.5)*u_contrast_factor+0.5;vec3 u_high_vec=vec3(u_brightness_low,u_brightness_low,u_brightness_low);vec3 u_low_vec=vec3(u_brightness_high,u_brightness_high,u_brightness_high);gl_FragColor=vec4(mix(u_high_vec,u_low_vec,rgb)*color.a,color.a);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "uniform mat4 u_matrix;uniform vec2 u_tl_parent;uniform float u_scale_parent;uniform float u_buffer_scale;attribute vec2 a_pos;attribute vec2 a_texture_pos;varying vec2 v_pos0;varying vec2 v_pos1;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);v_pos0=(((a_texture_pos/8192.0)-0.5)/u_buffer_scale )+0.5;v_pos1=(v_pos0*u_scale_parent)+u_tl_parent;}"), symbolIcon: ne("uniform sampler2D u_texture;varying vec2 v_tex;varying float v_fade_opacity;\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\nlowp float alpha=opacity*v_fade_opacity;gl_FragColor=texture2D(u_texture,v_tex)*alpha;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "const float PI=3.141592653589793;attribute vec4 a_pos_offset;attribute vec4 a_data;attribute vec4 a_pixeloffset;attribute vec3 a_projected_pos;attribute float a_fade_opacity;uniform bool u_is_size_zoom_constant;uniform bool u_is_size_feature_constant;uniform highp float u_size_t;uniform highp float u_size;uniform highp float u_camera_to_center_distance;uniform highp float u_pitch;uniform bool u_rotate_symbol;uniform highp float u_aspect_ratio;uniform float u_fade_change;uniform mat4 u_matrix;uniform mat4 u_label_plane_matrix;uniform mat4 u_coord_matrix;uniform bool u_is_text;uniform bool u_pitch_with_map;uniform vec2 u_texsize;varying vec2 v_tex;varying float v_fade_opacity;\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\nvec2 a_pos=a_pos_offset.xy;vec2 a_offset=a_pos_offset.zw;vec2 a_tex=a_data.xy;vec2 a_size=a_data.zw;float a_size_min=floor(a_size[0]*0.5);vec2 a_pxoffset=a_pixeloffset.xy;vec2 a_minFontScale=a_pixeloffset.zw/256.0;float ele=get_elevation(a_pos);highp float segment_angle=-a_projected_pos[2];float size;if (!u_is_size_zoom_constant && !u_is_size_feature_constant) {size=mix(a_size_min,a_size[1],u_size_t)/128.0;} else if (u_is_size_zoom_constant && !u_is_size_feature_constant) {size=a_size_min/128.0;} else {size=u_size;}vec4 projectedPoint=u_matrix*vec4(a_pos,ele,1);highp float camera_to_anchor_distance=projectedPoint.w;highp float distance_ratio=u_pitch_with_map ?\ncamera_to_anchor_distance/u_camera_to_center_distance :\nu_camera_to_center_distance/camera_to_anchor_distance;highp float perspective_ratio=clamp(0.5+0.5*distance_ratio,0.0,4.0);size*=perspective_ratio;float fontScale=u_is_text ? size/24.0 : size;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offsetProjectedPoint=u_matrix*vec4(a_pos+vec2(1,0),ele,1);vec2 a=projectedPoint.xy/projectedPoint.w;vec2 b=offsetProjectedPoint.xy/offsetProjectedPoint.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}highp float angle_sin=sin(segment_angle+symbol_rotation);highp float angle_cos=cos(segment_angle+symbol_rotation);mat2 rotation_matrix=mat2(angle_cos,-1.0*angle_sin,angle_sin,angle_cos);vec4 projected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy,ele,1.0);float z=float(u_pitch_with_map)*projected_pos.z/projected_pos.w;gl_Position=u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+rotation_matrix*(a_offset/32.0*max(a_minFontScale,fontScale)+a_pxoffset/16.0),z,1.0);v_tex=a_tex/u_texsize;vec2 fade_opacity=unpack_opacity(a_fade_opacity);float fade_change=fade_opacity[1] > 0.5 ? u_fade_change :-u_fade_change;float visibility=calculate_visibility(projectedPoint);v_fade_opacity=max(0.0,min(visibility,fade_opacity[0]+fade_change));}"), symbolSDF: ne("#define SDF_PX 8.0\nuniform bool u_is_halo;uniform sampler2D u_texture;uniform highp float u_gamma_scale;uniform lowp float u_device_pixel_ratio;uniform bool u_is_text;varying vec2 v_data0;varying vec3 v_data1;\n#pragma mapbox: define highp vec4 fill_color\n#pragma mapbox: define highp vec4 halo_color\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp float halo_width\n#pragma mapbox: define lowp float halo_blur\nvoid main() {\n#pragma mapbox: initialize highp vec4 fill_color\n#pragma mapbox: initialize highp vec4 halo_color\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize lowp float halo_width\n#pragma mapbox: initialize lowp float halo_blur\nfloat EDGE_GAMMA=0.105/u_device_pixel_ratio;vec2 tex=v_data0.xy;float gamma_scale=v_data1.x;float size=v_data1.y;float fade_opacity=v_data1[2];float fontScale=u_is_text ? size/24.0 : size;lowp vec4 color=fill_color;highp float gamma=EDGE_GAMMA/(fontScale*u_gamma_scale);lowp float inner_edge=(256.0-64.0)/256.0;if (u_is_halo) {color=halo_color;gamma=(halo_blur*1.19/SDF_PX+EDGE_GAMMA)/(fontScale*u_gamma_scale);inner_edge=inner_edge+gamma*gamma_scale;}lowp float dist=texture2D(u_texture,tex).a;highp float gamma_scaled=gamma*gamma_scale;highp float alpha=smoothstep(inner_edge-gamma_scaled,inner_edge+gamma_scaled,dist);if (u_is_halo) {lowp float halo_edge=(6.0-halo_width/fontScale)/SDF_PX;alpha=min(smoothstep(halo_edge-gamma_scaled,halo_edge+gamma_scaled,dist),1.0-alpha);}gl_FragColor=color*(alpha*opacity*fade_opacity);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "const float PI=3.141592653589793;attribute vec4 a_pos_offset;attribute vec4 a_data;attribute vec4 a_pixeloffset;attribute vec3 a_projected_pos;attribute float a_fade_opacity;uniform bool u_is_size_zoom_constant;uniform bool u_is_size_feature_constant;uniform highp float u_size_t;uniform highp float u_size;uniform mat4 u_matrix;uniform mat4 u_label_plane_matrix;uniform mat4 u_coord_matrix;uniform bool u_is_text;uniform bool u_pitch_with_map;uniform highp float u_pitch;uniform bool u_rotate_symbol;uniform highp float u_aspect_ratio;uniform highp float u_camera_to_center_distance;uniform float u_fade_change;uniform vec2 u_texsize;varying vec2 v_data0;varying vec3 v_data1;\n#pragma mapbox: define highp vec4 fill_color\n#pragma mapbox: define highp vec4 halo_color\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp float halo_width\n#pragma mapbox: define lowp float halo_blur\nvoid main() {\n#pragma mapbox: initialize highp vec4 fill_color\n#pragma mapbox: initialize highp vec4 halo_color\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize lowp float halo_width\n#pragma mapbox: initialize lowp float halo_blur\nvec2 a_pos=a_pos_offset.xy;vec2 a_offset=a_pos_offset.zw;vec2 a_tex=a_data.xy;vec2 a_size=a_data.zw;float a_size_min=floor(a_size[0]*0.5);vec2 a_pxoffset=a_pixeloffset.xy;float ele=get_elevation(a_pos);highp float segment_angle=-a_projected_pos[2];float size;if (!u_is_size_zoom_constant && !u_is_size_feature_constant) {size=mix(a_size_min,a_size[1],u_size_t)/128.0;} else if (u_is_size_zoom_constant && !u_is_size_feature_constant) {size=a_size_min/128.0;} else {size=u_size;}vec4 projectedPoint=u_matrix*vec4(a_pos,ele,1);highp float camera_to_anchor_distance=projectedPoint.w;highp float distance_ratio=u_pitch_with_map ?\ncamera_to_anchor_distance/u_camera_to_center_distance :\nu_camera_to_center_distance/camera_to_anchor_distance;highp float perspective_ratio=clamp(0.5+0.5*distance_ratio,0.0,4.0);size*=perspective_ratio;float fontScale=u_is_text ? size/24.0 : size;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offsetProjectedPoint=u_matrix*vec4(a_pos+vec2(1,0),ele,1);vec2 a=projectedPoint.xy/projectedPoint.w;vec2 b=offsetProjectedPoint.xy/offsetProjectedPoint.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}highp float angle_sin=sin(segment_angle+symbol_rotation);highp float angle_cos=cos(segment_angle+symbol_rotation);mat2 rotation_matrix=mat2(angle_cos,-1.0*angle_sin,angle_sin,angle_cos);vec4 projected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy,ele,1.0);float z=float(u_pitch_with_map)*projected_pos.z/projected_pos.w;gl_Position=u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+rotation_matrix*(a_offset/32.0*fontScale+a_pxoffset),z,1.0);float gamma_scale=gl_Position.w;vec2 fade_opacity=unpack_opacity(a_fade_opacity);float visibility=calculate_visibility(projectedPoint);float fade_change=fade_opacity[1] > 0.5 ? u_fade_change :-u_fade_change;float interpolated_fade_opacity=max(0.0,min(visibility,fade_opacity[0]+fade_change));v_data0=a_tex/u_texsize;v_data1=vec3(gamma_scale,size,interpolated_fade_opacity);}"), symbolTextAndIcon: ne("#define SDF_PX 8.0\n#define SDF 1.0\n#define ICON 0.0\nuniform bool u_is_halo;uniform sampler2D u_texture;uniform sampler2D u_texture_icon;uniform highp float u_gamma_scale;uniform lowp float u_device_pixel_ratio;varying vec4 v_data0;varying vec4 v_data1;\n#pragma mapbox: define highp vec4 fill_color\n#pragma mapbox: define highp vec4 halo_color\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp float halo_width\n#pragma mapbox: define lowp float halo_blur\nvoid main() {\n#pragma mapbox: initialize highp vec4 fill_color\n#pragma mapbox: initialize highp vec4 halo_color\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize lowp float halo_width\n#pragma mapbox: initialize lowp float halo_blur\nfloat fade_opacity=v_data1[2];if (v_data1.w==ICON) {vec2 tex_icon=v_data0.zw;lowp float alpha=opacity*fade_opacity;gl_FragColor=texture2D(u_texture_icon,tex_icon)*alpha;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\nreturn;}vec2 tex=v_data0.xy;float EDGE_GAMMA=0.105/u_device_pixel_ratio;float gamma_scale=v_data1.x;float size=v_data1.y;float fontScale=size/24.0;lowp vec4 color=fill_color;highp float gamma=EDGE_GAMMA/(fontScale*u_gamma_scale);lowp float buff=(256.0-64.0)/256.0;if (u_is_halo) {color=halo_color;gamma=(halo_blur*1.19/SDF_PX+EDGE_GAMMA)/(fontScale*u_gamma_scale);buff=(6.0-halo_width/fontScale)/SDF_PX;}lowp float dist=texture2D(u_texture,tex).a;highp float gamma_scaled=gamma*gamma_scale;highp float alpha=smoothstep(buff-gamma_scaled,buff+gamma_scaled,dist);gl_FragColor=color*(alpha*opacity*fade_opacity);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "const float PI=3.141592653589793;attribute vec4 a_pos_offset;attribute vec4 a_data;attribute vec3 a_projected_pos;attribute float a_fade_opacity;uniform bool u_is_size_zoom_constant;uniform bool u_is_size_feature_constant;uniform highp float u_size_t;uniform highp float u_size;uniform mat4 u_matrix;uniform mat4 u_label_plane_matrix;uniform mat4 u_coord_matrix;uniform bool u_is_text;uniform bool u_pitch_with_map;uniform highp float u_pitch;uniform bool u_rotate_symbol;uniform highp float u_aspect_ratio;uniform highp float u_camera_to_center_distance;uniform float u_fade_change;uniform vec2 u_texsize;uniform vec2 u_texsize_icon;varying vec4 v_data0;varying vec4 v_data1;\n#pragma mapbox: define highp vec4 fill_color\n#pragma mapbox: define highp vec4 halo_color\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp float halo_width\n#pragma mapbox: define lowp float halo_blur\nvoid main() {\n#pragma mapbox: initialize highp vec4 fill_color\n#pragma mapbox: initialize highp vec4 halo_color\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize lowp float halo_width\n#pragma mapbox: initialize lowp float halo_blur\nvec2 a_pos=a_pos_offset.xy;vec2 a_offset=a_pos_offset.zw;vec2 a_tex=a_data.xy;vec2 a_size=a_data.zw;float a_size_min=floor(a_size[0]*0.5);float is_sdf=a_size[0]-2.0*a_size_min;float ele=get_elevation(a_pos);highp float segment_angle=-a_projected_pos[2];float size;if (!u_is_size_zoom_constant && !u_is_size_feature_constant) {size=mix(a_size_min,a_size[1],u_size_t)/128.0;} else if (u_is_size_zoom_constant && !u_is_size_feature_constant) {size=a_size_min/128.0;} else {size=u_size;}vec4 projectedPoint=u_matrix*vec4(a_pos,ele,1);highp float camera_to_anchor_distance=projectedPoint.w;highp float distance_ratio=u_pitch_with_map ?\ncamera_to_anchor_distance/u_camera_to_center_distance :\nu_camera_to_center_distance/camera_to_anchor_distance;highp float perspective_ratio=clamp(0.5+0.5*distance_ratio,0.0,4.0);size*=perspective_ratio;float fontScale=size/24.0;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offsetProjectedPoint=u_matrix*vec4(a_pos+vec2(1,0),ele,1);vec2 a=projectedPoint.xy/projectedPoint.w;vec2 b=offsetProjectedPoint.xy/offsetProjectedPoint.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}highp float angle_sin=sin(segment_angle+symbol_rotation);highp float angle_cos=cos(segment_angle+symbol_rotation);mat2 rotation_matrix=mat2(angle_cos,-1.0*angle_sin,angle_sin,angle_cos);vec4 projected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy,ele,1.0);float z=float(u_pitch_with_map)*projected_pos.z/projected_pos.w;gl_Position=u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+rotation_matrix*(a_offset/32.0*fontScale),z,1.0);float gamma_scale=gl_Position.w;vec2 fade_opacity=unpack_opacity(a_fade_opacity);float visibility=calculate_visibility(projectedPoint);float fade_change=fade_opacity[1] > 0.5 ? u_fade_change :-u_fade_change;float interpolated_fade_opacity=max(0.0,min(visibility,fade_opacity[0]+fade_change));v_data0.xy=a_tex/u_texsize;v_data0.zw=a_tex/u_texsize_icon;v_data1=vec4(gamma_scale,size,interpolated_fade_opacity,is_sdf);}"), terrain: ne("uniform sampler2D u_texture;varying vec2 v_texture_pos;void main() {gl_FragColor=texture2D(u_texture,v_texture_pos);}", oe), terrainDepth: ne("varying float v_depth;const highp vec4 bitSh=vec4(256.*256.*256.,256.*256.,256.,1.);const highp vec4 bitMsk=vec4(0.,vec3(1./256.0));highp vec4 pack(highp float value) {highp vec4 comp=fract(value*bitSh);comp-=comp.xxyz*bitMsk;return comp;}void main() {gl_FragColor=pack(v_depth);}", oe), terrainCoords: ne("precision mediump float;uniform sampler2D u_texture;uniform float u_terrain_coords_id;varying vec2 v_texture_pos;void main() {vec4 rgba=texture2D(u_texture,v_texture_pos);gl_FragColor=vec4(rgba.r,rgba.g,rgba.b,u_terrain_coords_id);}", oe) };
function ne(t2, e2) {
const i3 = /#pragma mapbox: ([\w]+) ([\w]+) ([\w]+) ([\w]+)/g, s2 = e2.match(/attribute ([\w]+) ([\w]+)/g), a2 = t2.match(/uniform ([\w]+) ([\w]+)([\s]*)([\w]*)/g), o2 = e2.match(/uniform ([\w]+) ([\w]+)([\s]*)([\w]*)/g), r2 = o2 ? o2.concat(a2) : a2, n2 = {};
return { fragmentSource: t2 = t2.replace(i3, ((t3, e3, i4, s3, a3) => (n2[a3] = true, "define" === e3 ? `
#ifndef HAS_UNIFORM_u_${a3}
varying ${i4} ${s3} ${a3};
#else
uniform ${i4} ${s3} u_${a3};
#endif
` : `
#ifdef HAS_UNIFORM_u_${a3}
${i4} ${s3} ${a3} = u_${a3};
#endif
`))), vertexSource: e2 = e2.replace(i3, ((t3, e3, i4, s3, a3) => {
const o3 = "float" === s3 ? "vec2" : "vec4", r3 = a3.match(/color/) ? "color" : o3;
return n2[a3] ? "define" === e3 ? `
#ifndef HAS_UNIFORM_u_${a3}
uniform lowp float u_${a3}_t;
attribute ${i4} ${o3} a_${a3};
varying ${i4} ${s3} ${a3};
#else
uniform ${i4} ${s3} u_${a3};
#endif
` : "vec4" === r3 ? `
#ifndef HAS_UNIFORM_u_${a3}
${a3} = a_${a3};
#else
${i4} ${s3} ${a3} = u_${a3};
#endif
` : `
#ifndef HAS_UNIFORM_u_${a3}
${a3} = unpack_mix_${r3}(a_${a3}, u_${a3}_t);
#else
${i4} ${s3} ${a3} = u_${a3};
#endif
` : "define" === e3 ? `
#ifndef HAS_UNIFORM_u_${a3}
uniform lowp float u_${a3}_t;
attribute ${i4} ${o3} a_${a3};
#else
uniform ${i4} ${s3} u_${a3};
#endif
` : "vec4" === r3 ? `
#ifndef HAS_UNIFORM_u_${a3}
${i4} ${s3} ${a3} = a_${a3};
#else
${i4} ${s3} ${a3} = u_${a3};
#endif
` : `
#ifndef HAS_UNIFORM_u_${a3}
${i4} ${s3} ${a3} = unpack_mix_${r3}(a_${a3}, u_${a3}_t);
#else
${i4} ${s3} ${a3} = u_${a3};
#endif
`;
})), staticAttributes: s2, staticUniforms: r2 };
}
class le {
constructor() {
this.boundProgram = null, this.boundLayoutVertexBuffer = null, this.boundPaintVertexBuffers = [], this.boundIndexBuffer = null, this.boundVertexOffset = null, this.boundDynamicVertexBuffer = null, this.vao = null;
}
bind(t2, e2, i3, s2, a2, o2, r2, n2, l2) {
this.context = t2;
let h2 = this.boundPaintVertexBuffers.length !== s2.length;
for (let t3 = 0; !h2 && t3 < s2.length; t3++) this.boundPaintVertexBuffers[t3] !== s2[t3] && (h2 = true);
!this.vao || this.boundProgram !== e2 || this.boundLayoutVertexBuffer !== i3 || h2 || this.boundIndexBuffer !== a2 || this.boundVertexOffset !== o2 || this.boundDynamicVertexBuffer !== r2 || this.boundDynamicVertexBuffer2 !== n2 || this.boundDynamicVertexBuffer3 !== l2 ? this.freshBind(e2, i3, s2, a2, o2, r2, n2, l2) : (t2.bindVertexArray.set(this.vao), r2 && r2.bind(), a2 && a2.dynamicDraw && a2.bind(), n2 && n2.bind(), l2 && l2.bind());
}
freshBind(t2, e2, i3, s2, a2, o2, r2, n2) {
const l2 = t2.numAttributes, h2 = this.context, c2 = h2.gl;
this.vao && this.destroy(), this.vao = h2.createVertexArray(), h2.bindVertexArray.set(this.vao), this.boundProgram = t2, this.boundLayoutVertexBuffer = e2, this.boundPaintVertexBuffers = i3, this.boundIndexBuffer = s2, this.boundVertexOffset = a2, this.boundDynamicVertexBuffer = o2, this.boundDynamicVertexBuffer2 = r2, this.boundDynamicVertexBuffer3 = n2, e2.enableAttributes(c2, t2);
for (const e3 of i3) e3.enableAttributes(c2, t2);
o2 && o2.enableAttributes(c2, t2), r2 && r2.enableAttributes(c2, t2), n2 && n2.enableAttributes(c2, t2), e2.bind(), e2.setVertexAttribPointers(c2, t2, a2);
for (const e3 of i3) e3.bind(), e3.setVertexAttribPointers(c2, t2, a2);
o2 && (o2.bind(), o2.setVertexAttribPointers(c2, t2, a2)), s2 && s2.bind(), r2 && (r2.bind(), r2.setVertexAttribPointers(c2, t2, a2)), n2 && (n2.bind(), n2.setVertexAttribPointers(c2, t2, a2)), h2.currentNumAttributes = l2;
}
destroy() {
this.vao && (this.context.deleteVertexArray(this.vao), this.vao = null);
}
}
function he(t2) {
const e2 = [];
for (let i3 = 0; i3 < t2.length; i3++) {
if (null === t2[i3]) continue;
const s2 = t2[i3].split(" ");
e2.push(s2.pop());
}
return e2;
}
class ce {
constructor(e2, i3, s2, a2, o2, r2) {
const n2 = e2.gl;
this.program = n2.createProgram();
const l2 = he(i3.staticAttributes), h2 = s2 ? s2.getBinderAttributes() : [], c2 = l2.concat(h2), u2 = re.prelude.staticUniforms ? he(re.prelude.staticUniforms) : [], d2 = i3.staticUniforms ? he(i3.staticUniforms) : [], _2 = s2 ? s2.getBinderUniforms() : [], p2 = u2.concat(d2).concat(_2), m2 = [];
for (const t2 of p2) m2.indexOf(t2) < 0 && m2.push(t2);
const f2 = s2 ? s2.defines() : [];
o2 && f2.push("#define OVERDRAW_INSPECTOR;"), r2 && f2.push("#define TERRAIN3D;");
const g2 = f2.concat(re.prelude.fragmentSource, i3.fragmentSource).join("\n"), v2 = f2.concat(re.prelude.vertexSource, i3.vertexSource).join("\n"), x2 = n2.createShader(n2.FRAGMENT_SHADER);
if (n2.isContextLost()) return void (this.failedToCreate = true);
if (n2.shaderSource(x2, g2), n2.compileShader(x2), !n2.getShaderParameter(x2, n2.COMPILE_STATUS)) throw new Error(`Could not compile fragment shader: ${n2.getShaderInfoLog(x2)}`);
n2.attachShader(this.program, x2);
const y2 = n2.createShader(n2.VERTEX_SHADER);
if (n2.isContextLost()) return void (this.failedToCreate = true);
if (n2.shaderSource(y2, v2), n2.compileShader(y2), !n2.getShaderParameter(y2, n2.COMPILE_STATUS)) throw new Error(`Could not compile vertex shader: ${n2.getShaderInfoLog(y2)}`);
n2.attachShader(this.program, y2), this.attributes = {};
const b2 = {};
this.numAttributes = c2.length;
for (let t2 = 0; t2 < this.numAttributes; t2++) c2[t2] && (n2.bindAttribLocation(this.program, t2, c2[t2]), this.attributes[c2[t2]] = t2);
if (n2.linkProgram(this.program), !n2.getProgramParameter(this.program, n2.LINK_STATUS)) throw new Error(`Program failed to link: ${n2.getProgramInfoLog(this.program)}`);
n2.deleteShader(y2), n2.deleteShader(x2);
for (let t2 = 0; t2 < m2.length; t2++) {
const e3 = m2[t2];
if (e3 && !b2[e3]) {
const t3 = n2.getUniformLocation(this.program, e3);
t3 && (b2[e3] = t3);
}
}
this.fixedUniforms = a2(e2, b2), this.terrainUniforms = ((e3, i4) => ({ u_depth: new t.aL(e3, i4.u_depth), u_terrain: new t.aL(e3, i4.u_terrain), u_terrain_dim: new t.aM(e3, i4.u_terrain_dim), u_terrain_matrix: new t.aN(e3, i4.u_terrain_matrix), u_terrain_unpack: new t.aO(e3, i4.u_terrain_unpack), u_terrain_exaggeration: new t.aM(e3, i4.u_terrain_exaggeration) }))(e2, b2), this.binderUniforms = s2 ? s2.getUniforms(e2, b2) : [];
}
draw(t2, e2, i3, s2, a2, o2, r2, n2, l2, h2, c2, u2, d2, _2, p2, m2, f2, g2) {
const v2 = t2.gl;
if (this.failedToCreate) return;
if (t2.program.set(this.program), t2.setDepthMode(i3), t2.setStencilMode(s2), t2.setColorMode(a2), t2.setCullFace(o2), n2) {
t2.activeTexture.set(v2.TEXTURE2), v2.bindTexture(v2.TEXTURE_2D, n2.depthTexture), t2.activeTexture.set(v2.TEXTURE3), v2.bindTexture(v2.TEXTURE_2D, n2.texture);
for (const t3 in this.terrainUniforms) this.terrainUniforms[t3].set(n2[t3]);
}
for (const t3 in this.fixedUniforms) this.fixedUniforms[t3].set(r2[t3]);
p2 && p2.setUniforms(t2, this.binderUniforms, d2, { zoom: _2 });
let x2 = 0;
switch (e2) {
case v2.LINES:
x2 = 2;
break;
case v2.TRIANGLES:
x2 = 3;
break;
case v2.LINE_STRIP:
x2 = 1;
}
for (const i4 of u2.get()) {
const s3 = i4.vaos || (i4.vaos = {});
(s3[l2] || (s3[l2] = new le())).bind(t2, this, h2, p2 ? p2.getPaintVertexBuffers() : [], c2, i4.vertexOffset, m2, f2, g2), v2.drawElements(e2, i4.primitiveLength * x2, v2.UNSIGNED_SHORT, i4.primitiveOffset * x2 * 2);
}
}
}
function ue(t2, e2, i3) {
const s2 = 1 / St(i3, 1, e2.transform.tileZoom), a2 = Math.pow(2, i3.tileID.overscaledZ), o2 = i3.tileSize * Math.pow(2, e2.transform.tileZoom) / a2, r2 = o2 * (i3.tileID.canonical.x + i3.tileID.wrap * a2), n2 = o2 * i3.tileID.canonical.y;
return { u_image: 0, u_texsize: i3.imageAtlasTexture.size, u_scale: [s2, t2.fromScale, t2.toScale], u_fade: t2.t, u_pixel_coord_upper: [r2 >> 16, n2 >> 16], u_pixel_coord_lower: [65535 & r2, 65535 & n2] };
}
const de = (e2, i3, s2, a2) => {
const o2 = i3.style.light, r2 = o2.properties.get("position"), n2 = [r2.x, r2.y, r2.z], l2 = (function() {
var e3 = new t.A(9);
return t.A != Float32Array && (e3[1] = 0, e3[2] = 0, e3[3] = 0, e3[5] = 0, e3[6] = 0, e3[7] = 0), e3[0] = 1, e3[4] = 1, e3[8] = 1, e3;
})();
"viewport" === o2.properties.get("anchor") && (function(t2, e3) {
var i4 = Math.sin(e3), s3 = Math.cos(e3);
t2[0] = s3, t2[1] = i4, t2[2] = 0, t2[3] = -i4, t2[4] = s3, t2[5] = 0, t2[6] = 0, t2[7] = 0, t2[8] = 1;
})(l2, -i3.transform.angle), (function(t2, e3, i4) {
var s3 = e3[0], a3 = e3[1], o3 = e3[2];
t2[0] = s3 * i4[0] + a3 * i4[3] + o3 * i4[6], t2[1] = s3 * i4[1] + a3 * i4[4] + o3 * i4[7], t2[2] = s3 * i4[2] + a3 * i4[5] + o3 * i4[8];
})(n2, n2, l2);
const h2 = o2.properties.get("color");
return { u_matrix: e2, u_lightpos: n2, u_lightintensity: o2.properties.get("intensity"), u_lightcolor: [h2.r, h2.g, h2.b], u_vertical_gradient: +s2, u_opacity: a2 };
}, _e = (e2, i3, s2, a2, o2, r2, n2) => t.e(de(e2, i3, s2, a2), ue(r2, i3, n2), { u_height_factor: -Math.pow(2, o2.overscaledZ) / n2.tileSize / 8 }), pe = (t2) => ({ u_matrix: t2 }), me = (e2, i3, s2, a2) => t.e(pe(e2), ue(s2, i3, a2)), fe = (t2, e2) => ({ u_matrix: t2, u_world: e2 }), ge = (e2, i3, s2, a2, o2) => t.e(me(e2, i3, s2, a2), { u_world: o2 }), ve = (t2, e2, i3, s2) => {
const a2 = t2.transform;
let o2, r2;
if ("map" === s2.paint.get("circle-pitch-alignment")) {
const t3 = St(i3, 1, a2.zoom);
o2 = true, r2 = [t3, t3];
} else o2 = false, r2 = a2.pixelsToGLUnits;
return { u_camera_to_center_distance: a2.cameraToCenterDistance, u_scale_with_map: +("map" === s2.paint.get("circle-pitch-scale")), u_matrix: t2.translatePosMatrix(e2.posMatrix, i3, s2.paint.get("circle-translate"), s2.paint.get("circle-translate-anchor")), u_pitch_with_map: +o2, u_device_pixel_ratio: t2.pixelRatio, u_extrude_scale: r2 };
}, xe = (t2, e2, i3) => {
const s2 = St(i3, 1, e2.zoom), a2 = Math.pow(2, e2.zoom - i3.tileID.overscaledZ), o2 = i3.tileID.overscaleFactor();
return { u_matrix: t2, u_camera_to_center_distance: e2.cameraToCenterDistance, u_pixels_to_tile_units: s2, u_extrude_scale: [e2.pixelsToGLUnits[0] / (s2 * a2), e2.pixelsToGLUnits[1] / (s2 * a2)], u_overscale_factor: o2 };
}, ye = (t2, e2, i3 = 1) => ({ u_matrix: t2, u_color: e2, u_overlay: 0, u_overlay_scale: i3 }), be = (t2) => ({ u_matrix: t2 }), we = (t2, e2, i3, s2) => ({ u_matrix: t2, u_extrude_scale: St(e2, 1, i3), u_intensity: s2 });
function Te(e2, i3) {
const s2 = Math.pow(2, i3.canonical.z), a2 = i3.canonical.y;
return [new t.U(0, a2 / s2).toLngLat().lat, new t.U(0, (a2 + 1) / s2).toLngLat().lat];
}
const Ie = (t2, e2, i3, s2) => {
const a2 = t2.transform;
return { u_matrix: De(t2, e2, i3, s2), u_ratio: 1 / St(e2, 1, a2.zoom), u_device_pixel_ratio: t2.pixelRatio, u_units_to_pixels: [1 / a2.pixelsToGLUnits[0], 1 / a2.pixelsToGLUnits[1]] };
}, Ee = (e2, i3, s2, a2, o2) => t.e(Ie(e2, i3, s2, o2), { u_image: 0, u_image_height: a2 }), Se = (t2, e2, i3, s2, a2) => {
const o2 = t2.transform, r2 = Pe(e2, o2);
return { u_matrix: De(t2, e2, i3, a2), u_texsize: e2.imageAtlasTexture.size, u_ratio: 1 / St(e2, 1, o2.zoom), u_device_pixel_ratio: t2.pixelRatio, u_image: 0, u_scale: [r2, s2.fromScale, s2.toScale], u_fade: s2.t, u_units_to_pixels: [1 / o2.pixelsToGLUnits[0], 1 / o2.pixelsToGLUnits[1]] };
}, Ce = (e2, i3, s2, a2, o2, r2) => {
const n2 = e2.lineAtlas, l2 = Pe(i3, e2.transform), h2 = "round" === s2.layout.get("line-cap"), c2 = n2.getDash(a2.from, h2), u2 = n2.getDash(a2.to, h2), d2 = c2.width * o2.fromScale, _2 = u2.width * o2.toScale;
return t.e(Ie(e2, i3, s2, r2), { u_patternscale_a: [l2 / d2, -c2.height / 2], u_patternscale_b: [l2 / _2, -u2.height / 2], u_sdfgamma: n2.width / (256 * Math.min(d2, _2) * e2.pixelRatio) / 2, u_image: 0, u_tex_y_a: c2.y, u_tex_y_b: u2.y, u_mix: o2.t });
};
function Pe(t2, e2) {
return 1 / St(t2, 1, e2.tileZoom);
}
function De(t2, e2, i3, s2) {
return t2.translatePosMatrix(s2 ? s2.posMatrix : e2.tileID.posMatrix, e2, i3.paint.get("line-translate"), i3.paint.get("line-translate-anchor"));
}
const Me = (t2, e2, i3, s2, a2) => {
return { u_matrix: t2, u_tl_parent: e2, u_scale_parent: i3, u_buffer_scale: 1, u_fade_t: s2.mix, u_opacity: s2.opacity * a2.paint.get("raster-opacity"), u_image0: 0, u_image1: 1, u_brightness_low: a2.paint.get("raster-brightness-min"), u_brightness_high: a2.paint.get("raster-brightness-max"), u_saturation_factor: (r2 = a2.paint.get("raster-saturation"), r2 > 0 ? 1 - 1 / (1.001 - r2) : -r2), u_contrast_factor: (o2 = a2.paint.get("raster-contrast"), o2 > 0 ? 1 / (1 - o2) : 1 + o2), u_spin_weights: ze(a2.paint.get("raster-hue-rotate")) };
var o2, r2;
};
function ze(t2) {
t2 *= Math.PI / 180;
const e2 = Math.sin(t2), i3 = Math.cos(t2);
return [(2 * i3 + 1) / 3, (-Math.sqrt(3) * e2 - i3 + 1) / 3, (Math.sqrt(3) * e2 - i3 + 1) / 3];
}
const Le = (t2, e2, i3, s2, a2, o2, r2, n2, l2, h2) => {
const c2 = a2.transform;
return { u_is_size_zoom_constant: +("constant" === t2 || "source" === t2), u_is_size_feature_constant: +("constant" === t2 || "camera" === t2), u_size_t: e2 ? e2.uSizeT : 0, u_size: e2 ? e2.uSize : 0, u_camera_to_center_distance: c2.cameraToCenterDistance, u_pitch: c2.pitch / 360 * 2 * Math.PI, u_rotate_symbol: +i3, u_aspect_ratio: c2.width / c2.height, u_fade_change: a2.options.fadeDuration ? a2.symbolFadeChange : 1, u_matrix: o2, u_label_plane_matrix: r2, u_coord_matrix: n2, u_is_text: +l2, u_pitch_with_map: +s2, u_texsize: h2, u_texture: 0 };
}, Ae = (e2, i3, s2, a2, o2, r2, n2, l2, h2, c2, u2) => {
const d2 = o2.transform;
return t.e(Le(e2, i3, s2, a2, o2, r2, n2, l2, h2, c2), { u_gamma_scale: a2 ? Math.cos(d2._pitch) * d2.cameraToCenterDistance : 1, u_device_pixel_ratio: o2.pixelRatio, u_is_halo: 1 });
}, Re = (e2, i3, s2, a2, o2, r2, n2, l2, h2, c2) => t.e(Ae(e2, i3, s2, a2, o2, r2, n2, l2, true, h2), { u_texsize_icon: c2, u_texture_icon: 1 }), ke = (t2, e2, i3) => ({ u_matrix: t2, u_opacity: e2, u_color: i3 }), Fe = (e2, i3, s2, a2, o2, r2) => t.e((function(t2, e3, i4, s3) {
const a3 = i4.imageManager.getPattern(t2.from.toString()), o3 = i4.imageManager.getPattern(t2.to.toString()), { width: r3, height: n2 } = i4.imageManager.getPixelSize(), l2 = Math.pow(2, s3.tileID.overscaledZ), h2 = s3.tileSize * Math.pow(2, i4.transform.tileZoom) / l2, c2 = h2 * (s3.tileID.canonical.x + s3.tileID.wrap * l2), u2 = h2 * s3.tileID.canonical.y;
return { u_image: 0, u_pattern_tl_a: a3.tl, u_pattern_br_a: a3.br, u_pattern_tl_b: o3.tl, u_pattern_br_b: o3.br, u_texsize: [r3, n2], u_mix: e3.t, u_pattern_size_a: a3.displaySize, u_pattern_size_b: o3.displaySize, u_scale_a: e3.fromScale, u_scale_b: e3.toScale, u_tile_units_to_pixels: 1 / St(s3, 1, i4.transform.tileZoom), u_pixel_coord_upper: [c2 >> 16, u2 >> 16], u_pixel_coord_lower: [65535 & c2, 65535 & u2] };
})(a2, r2, s2, o2), { u_matrix: e2, u_opacity: i3 }), Be = { fillExtrusion: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_lightpos: new t.aP(e2, i3.u_lightpos), u_lightintensity: new t.aM(e2, i3.u_lightintensity), u_lightcolor: new t.aP(e2, i3.u_lightcolor), u_vertical_gradient: new t.aM(e2, i3.u_vertical_gradient), u_opacity: new t.aM(e2, i3.u_opacity) }), fillExtrusionPattern: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_lightpos: new t.aP(e2, i3.u_lightpos), u_lightintensity: new t.aM(e2, i3.u_lightintensity), u_lightcolor: new t.aP(e2, i3.u_lightcolor), u_vertical_gradient: new t.aM(e2, i3.u_vertical_gradient), u_height_factor: new t.aM(e2, i3.u_height_factor), u_image: new t.aL(e2, i3.u_image), u_texsize: new t.aQ(e2, i3.u_texsize), u_pixel_coord_upper: new t.aQ(e2, i3.u_pixel_coord_upper), u_pixel_coord_lower: new t.aQ(e2, i3.u_pixel_coord_lower), u_scale: new t.aP(e2, i3.u_scale), u_fade: new t.aM(e2, i3.u_fade), u_opacity: new t.aM(e2, i3.u_opacity) }), fill: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix) }), fillPattern: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_image: new t.aL(e2, i3.u_image), u_texsize: new t.aQ(e2, i3.u_texsize), u_pixel_coord_upper: new t.aQ(e2, i3.u_pixel_coord_upper), u_pixel_coord_lower: new t.aQ(e2, i3.u_pixel_coord_lower), u_scale: new t.aP(e2, i3.u_scale), u_fade: new t.aM(e2, i3.u_fade) }), fillOutline: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_world: new t.aQ(e2, i3.u_world) }), fillOutlinePattern: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_world: new t.aQ(e2, i3.u_world), u_image: new t.aL(e2, i3.u_image), u_texsize: new t.aQ(e2, i3.u_texsize), u_pixel_coord_upper: new t.aQ(e2, i3.u_pixel_coord_upper), u_pixel_coord_lower: new t.aQ(e2, i3.u_pixel_coord_lower), u_scale: new t.aP(e2, i3.u_scale), u_fade: new t.aM(e2, i3.u_fade) }), circle: (e2, i3) => ({ u_camera_to_center_distance: new t.aM(e2, i3.u_camera_to_center_distance), u_scale_with_map: new t.aL(e2, i3.u_scale_with_map), u_pitch_with_map: new t.aL(e2, i3.u_pitch_with_map), u_extrude_scale: new t.aQ(e2, i3.u_extrude_scale), u_device_pixel_ratio: new t.aM(e2, i3.u_device_pixel_ratio), u_matrix: new t.aN(e2, i3.u_matrix) }), collisionBox: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_camera_to_center_distance: new t.aM(e2, i3.u_camera_to_center_distance), u_pixels_to_tile_units: new t.aM(e2, i3.u_pixels_to_tile_units), u_extrude_scale: new t.aQ(e2, i3.u_extrude_scale), u_overscale_factor: new t.aM(e2, i3.u_overscale_factor) }), collisionCircle: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_inv_matrix: new t.aN(e2, i3.u_inv_matrix), u_camera_to_center_distance: new t.aM(e2, i3.u_camera_to_center_distance), u_viewport_size: new t.aQ(e2, i3.u_viewport_size) }), debug: (e2, i3) => ({ u_color: new t.aR(e2, i3.u_color), u_matrix: new t.aN(e2, i3.u_matrix), u_overlay: new t.aL(e2, i3.u_overlay), u_overlay_scale: new t.aM(e2, i3.u_overlay_scale) }), clippingMask: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix) }), heatmap: (e2, i3) => ({ u_extrude_scale: new t.aM(e2, i3.u_extrude_scale), u_intensity: new t.aM(e2, i3.u_intensity), u_matrix: new t.aN(e2, i3.u_matrix) }), heatmapTexture: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_world: new t.aQ(e2, i3.u_world), u_image: new t.aL(e2, i3.u_image), u_color_ramp: new t.aL(e2, i3.u_color_ramp), u_opacity: new t.aM(e2, i3.u_opacity) }), hillshade: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_image: new t.aL(e2, i3.u_image), u_latrange: new t.aQ(e2, i3.u_latrange), u_light: new t.aQ(e2, i3.u_light), u_shadow: new t.aR(e2, i3.u_shadow), u_highlight: new t.aR(e2, i3.u_highlight), u_accent: new t.aR(e2, i3.u_accent) }), hillshadePrepare: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_image: new t.aL(e2, i3.u_image), u_dimension: new t.aQ(e2, i3.u_dimension), u_zoom: new t.aM(e2, i3.u_zoom), u_unpack: new t.aO(e2, i3.u_unpack) }), line: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_ratio: new t.aM(e2, i3.u_ratio), u_device_pixel_ratio: new t.aM(e2, i3.u_device_pixel_ratio), u_units_to_pixels: new t.aQ(e2, i3.u_units_to_pixels) }), lineGradient: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_ratio: new t.aM(e2, i3.u_ratio), u_device_pixel_ratio: new t.aM(e2, i3.u_device_pixel_ratio), u_units_to_pixels: new t.aQ(e2, i3.u_units_to_pixels), u_image: new t.aL(e2, i3.u_image), u_image_height: new t.aM(e2, i3.u_image_height) }), linePattern: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_texsize: new t.aQ(e2, i3.u_texsize), u_ratio: new t.aM(e2, i3.u_ratio), u_device_pixel_ratio: new t.aM(e2, i3.u_device_pixel_ratio), u_image: new t.aL(e2, i3.u_image), u_units_to_pixels: new t.aQ(e2, i3.u_units_to_pixels), u_scale: new t.aP(e2, i3.u_scale), u_fade: new t.aM(e2, i3.u_fade) }), lineSDF: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_ratio: new t.aM(e2, i3.u_ratio), u_device_pixel_ratio: new t.aM(e2, i3.u_device_pixel_ratio), u_units_to_pixels: new t.aQ(e2, i3.u_units_to_pixels), u_patternscale_a: new t.aQ(e2, i3.u_patternscale_a), u_patternscale_b: new t.aQ(e2, i3.u_patternscale_b), u_sdfgamma: new t.aM(e2, i3.u_sdfgamma), u_image: new t.aL(e2, i3.u_image), u_tex_y_a: new t.aM(e2, i3.u_tex_y_a), u_tex_y_b: new t.aM(e2, i3.u_tex_y_b), u_mix: new t.aM(e2, i3.u_mix) }), raster: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_tl_parent: new t.aQ(e2, i3.u_tl_parent), u_scale_parent: new t.aM(e2, i3.u_scale_parent), u_buffer_scale: new t.aM(e2, i3.u_buffer_scale), u_fade_t: new t.aM(e2, i3.u_fade_t), u_opacity: new t.aM(e2, i3.u_opacity), u_image0: new t.aL(e2, i3.u_image0), u_image1: new t.aL(e2, i3.u_image1), u_brightness_low: new t.aM(e2, i3.u_brightness_low), u_brightness_high: new t.aM(e2, i3.u_brightness_high), u_saturation_factor: new t.aM(e2, i3.u_saturation_factor), u_contrast_factor: new t.aM(e2, i3.u_contrast_factor), u_spin_weights: new t.aP(e2, i3.u_spin_weights) }), symbolIcon: (e2, i3) => ({ u_is_size_zoom_constant: new t.aL(e2, i3.u_is_size_zoom_constant), u_is_size_feature_constant: new t.aL(e2, i3.u_is_size_feature_constant), u_size_t: new t.aM(e2, i3.u_size_t), u_size: new t.aM(e2, i3.u_size), u_camera_to_center_distance: new t.aM(e2, i3.u_camera_to_center_distance), u_pitch: new t.aM(e2, i3.u_pitch), u_rotate_symbol: new t.aL(e2, i3.u_rotate_symbol), u_aspect_ratio: new t.aM(e2, i3.u_aspect_ratio), u_fade_change: new t.aM(e2, i3.u_fade_change), u_matrix: new t.aN(e2, i3.u_matrix), u_label_plane_matrix: new t.aN(e2, i3.u_label_plane_matrix), u_coord_matrix: new t.aN(e2, i3.u_coord_matrix), u_is_text: new t.aL(e2, i3.u_is_text), u_pitch_with_map: new t.aL(e2, i3.u_pitch_with_map), u_texsize: new t.aQ(e2, i3.u_texsize), u_texture: new t.aL(e2, i3.u_texture) }), symbolSDF: (e2, i3) => ({ u_is_size_zoom_constant: new t.aL(e2, i3.u_is_size_zoom_constant), u_is_size_feature_constant: new t.aL(e2, i3.u_is_size_feature_constant), u_size_t: new t.aM(e2, i3.u_size_t), u_size: new t.aM(e2, i3.u_size), u_camera_to_center_distance: new t.aM(e2, i3.u_camera_to_center_distance), u_pitch: new t.aM(e2, i3.u_pitch), u_rotate_symbol: new t.aL(e2, i3.u_rotate_symbol), u_aspect_ratio: new t.aM(e2, i3.u_aspect_ratio), u_fade_change: new t.aM(e2, i3.u_fade_change), u_matrix: new t.aN(e2, i3.u_matrix), u_label_plane_matrix: new t.aN(e2, i3.u_label_plane_matrix), u_coord_matrix: new t.aN(e2, i3.u_coord_matrix), u_is_text: new t.aL(e2, i3.u_is_text), u_pitch_with_map: new t.aL(e2, i3.u_pitch_with_map), u_texsize: new t.aQ(e2, i3.u_texsize), u_texture: new t.aL(e2, i3.u_texture), u_gamma_scale: new t.aM(e2, i3.u_gamma_scale), u_device_pixel_ratio: new t.aM(e2, i3.u_device_pixel_ratio), u_is_halo: new t.aL(e2, i3.u_is_halo) }), symbolTextAndIcon: (e2, i3) => ({ u_is_size_zoom_constant: new t.aL(e2, i3.u_is_size_zoom_constant), u_is_size_feature_constant: new t.aL(e2, i3.u_is_size_feature_constant), u_size_t: new t.aM(e2, i3.u_size_t), u_size: new t.aM(e2, i3.u_size), u_camera_to_center_distance: new t.aM(e2, i3.u_camera_to_center_distance), u_pitch: new t.aM(e2, i3.u_pitch), u_rotate_symbol: new t.aL(e2, i3.u_rotate_symbol), u_aspect_ratio: new t.aM(e2, i3.u_aspect_ratio), u_fade_change: new t.aM(e2, i3.u_fade_change), u_matrix: new t.aN(e2, i3.u_matrix), u_label_plane_matrix: new t.aN(e2, i3.u_label_plane_matrix), u_coord_matrix: new t.aN(e2, i3.u_coord_matrix), u_is_text: new t.aL(e2, i3.u_is_text), u_pitch_with_map: new t.aL(e2, i3.u_pitch_with_map), u_texsize: new t.aQ(e2, i3.u_texsize), u_texsize_icon: new t.aQ(e2, i3.u_texsize_icon), u_texture: new t.aL(e2, i3.u_texture), u_texture_icon: new t.aL(e2, i3.u_texture_icon), u_gamma_scale: new t.aM(e2, i3.u_gamma_scale), u_device_pixel_ratio: new t.aM(e2, i3.u_device_pixel_ratio), u_is_halo: new t.aL(e2, i3.u_is_halo) }), background: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_opacity: new t.aM(e2, i3.u_opacity), u_color: new t.aR(e2, i3.u_color) }), backgroundPattern: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_opacity: new t.aM(e2, i3.u_opacity), u_image: new t.aL(e2, i3.u_image), u_pattern_tl_a: new t.aQ(e2, i3.u_pattern_tl_a), u_pattern_br_a: new t.aQ(e2, i3.u_pattern_br_a), u_pattern_tl_b: new t.aQ(e2, i3.u_pattern_tl_b), u_pattern_br_b: new t.aQ(e2, i3.u_pattern_br_b), u_texsize: new t.aQ(e2, i3.u_texsize), u_mix: new t.aM(e2, i3.u_mix), u_pattern_size_a: new t.aQ(e2, i3.u_pattern_size_a), u_pattern_size_b: new t.aQ(e2, i3.u_pattern_size_b), u_scale_a: new t.aM(e2, i3.u_scale_a), u_scale_b: new t.aM(e2, i3.u_scale_b), u_pixel_coord_upper: new t.aQ(e2, i3.u_pixel_coord_upper), u_pixel_coord_lower: new t.aQ(e2, i3.u_pixel_coord_lower), u_tile_units_to_pixels: new t.aM(e2, i3.u_tile_units_to_pixels) }), terrain: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_texture: new t.aL(e2, i3.u_texture), u_ele_delta: new t.aM(e2, i3.u_ele_delta) }), terrainDepth: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_ele_delta: new t.aM(e2, i3.u_ele_delta) }), terrainCoords: (e2, i3) => ({ u_matrix: new t.aN(e2, i3.u_matrix), u_texture: new t.aL(e2, i3.u_texture), u_terrain_coords_id: new t.aM(e2, i3.u_terrain_coords_id), u_ele_delta: new t.aM(e2, i3.u_ele_delta) }) };
class Oe {
constructor(t2, e2, i3) {
this.context = t2;
const s2 = t2.gl;
this.buffer = s2.createBuffer(), this.dynamicDraw = Boolean(i3), this.context.unbindVAO(), t2.bindElementBuffer.set(this.buffer), s2.bufferData(s2.ELEMENT_ARRAY_BUFFER, e2.arrayBuffer, this.dynamicDraw ? s2.DYNAMIC_DRAW : s2.STATIC_DRAW), this.dynamicDraw || delete e2.arrayBuffer;
}
bind() {
this.context.bindElementBuffer.set(this.buffer);
}
updateData(t2) {
const e2 = this.context.gl;
if (!this.dynamicDraw) throw new Error("Attempted to update data while not in dynamic mode.");
this.context.unbindVAO(), this.bind(), e2.bufferSubData(e2.ELEMENT_ARRAY_BUFFER, 0, t2.arrayBuffer);
}
destroy() {
this.buffer && (this.context.gl.deleteBuffer(this.buffer), delete this.buffer);
}
}
const Ne = { Int8: "BYTE", Uint8: "UNSIGNED_BYTE", Int16: "SHORT", Uint16: "UNSIGNED_SHORT", Int32: "INT", Uint32: "UNSIGNED_INT", Float32: "FLOAT" };
class Ue {
constructor(t2, e2, i3, s2) {
this.length = e2.length, this.attributes = i3, this.itemSize = e2.bytesPerElement, this.dynamicDraw = s2, this.context = t2;
const a2 = t2.gl;
this.buffer = a2.createBuffer(), t2.bindVertexBuffer.set(this.buffer), a2.bufferData(a2.ARRAY_BUFFER, e2.arrayBuffer, this.dynamicDraw ? a2.DYNAMIC_DRAW : a2.STATIC_DRAW), this.dynamicDraw || delete e2.arrayBuffer;
}
bind() {
this.context.bindVertexBuffer.set(this.buffer);
}
updateData(t2) {
if (t2.length !== this.length) throw new Error(`Length of new data is ${t2.length}, which doesn't match current length of ${this.length}`);
const e2 = this.context.gl;
this.bind(), e2.bufferSubData(e2.ARRAY_BUFFER, 0, t2.arrayBuffer);
}
enableAttributes(t2, e2) {
for (let i3 = 0; i3 < this.attributes.length; i3++) {
const s2 = e2.attributes[this.attributes[i3].name];
void 0 !== s2 && t2.enableVertexAttribArray(s2);
}
}
setVertexAttribPointers(t2, e2, i3) {
for (let s2 = 0; s2 < this.attributes.length; s2++) {
const a2 = this.attributes[s2], o2 = e2.attributes[a2.name];
void 0 !== o2 && t2.vertexAttribPointer(o2, a2.components, t2[Ne[a2.type]], false, this.itemSize, a2.offset + this.itemSize * (i3 || 0));
}
}
destroy() {
this.buffer && (this.context.gl.deleteBuffer(this.buffer), delete this.buffer);
}
}
const Ze = /* @__PURE__ */ new WeakMap();
function Ge(t2) {
var e2;
if (Ze.has(t2)) return Ze.get(t2);
{
const i3 = null === (e2 = t2.getParameter(t2.VERSION)) || void 0 === e2 ? void 0 : e2.startsWith("WebGL 2.0");
return Ze.set(t2, i3), i3;
}
}
class je {
constructor(t2) {
this.gl = t2.gl, this.default = this.getDefault(), this.current = this.default, this.dirty = false;
}
get() {
return this.current;
}
set(t2) {
}
getDefault() {
return this.default;
}
setDefault() {
this.set(this.default);
}
}
class Ve extends je {
getDefault() {
return t.aT.transparent;
}
set(t2) {
const e2 = this.current;
(t2.r !== e2.r || t2.g !== e2.g || t2.b !== e2.b || t2.a !== e2.a || this.dirty) && (this.gl.clearColor(t2.r, t2.g, t2.b, t2.a), this.current = t2, this.dirty = false);
}
}
class qe extends je {
getDefault() {
return 1;
}
set(t2) {
(t2 !== this.current || this.dirty) && (this.gl.clearDepth(t2), this.current = t2, this.dirty = false);
}
}
class $e extends je {
getDefault() {
return 0;
}
set(t2) {
(t2 !== this.current || this.dirty) && (this.gl.clearStencil(t2), this.current = t2, this.dirty = false);
}
}
class We extends je {
getDefault() {
return [true, true, true, true];
}
set(t2) {
const e2 = this.current;
(t2[0] !== e2[0] || t2[1] !== e2[1] || t2[2] !== e2[2] || t2[3] !== e2[3] || this.dirty) && (this.gl.colorMask(t2[0], t2[1], t2[2], t2[3]), this.current = t2, this.dirty = false);
}
}
class He extends je {
getDefault() {
return true;
}
set(t2) {
(t2 !== this.current || this.dirty) && (this.gl.depthMask(t2), this.current = t2, this.dirty = false);
}
}
class Xe extends je {
getDefault() {
return 255;
}
set(t2) {
(t2 !== this.current || this.dirty) && (this.gl.stencilMask(t2), this.current = t2, this.dirty = false);
}
}
class Ke extends je {
getDefault() {
return { func: this.gl.ALWAYS, ref: 0, mask: 255 };
}
set(t2) {
const e2 = this.current;
(t2.func !== e2.func || t2.ref !== e2.ref || t2.mask !== e2.mask || this.dirty) && (this.gl.stencilFunc(t2.func, t2.ref, t2.mask), this.current = t2, this.dirty = false);
}
}
class Qe extends je {
getDefault() {
const t2 = this.gl;
return [t2.KEEP, t2.KEEP, t2.KEEP];
}
set(t2) {
const e2 = this.current;
(t2[0] !== e2[0] || t2[1] !== e2[1] || t2[2] !== e2[2] || this.dirty) && (this.gl.stencilOp(t2[0], t2[1], t2[2]), this.current = t2, this.dirty = false);
}
}
class Ye extends je {
getDefault() {
return false;
}
set(t2) {
if (t2 === this.current && !this.dirty) return;
const e2 = this.gl;
t2 ? e2.enable(e2.STENCIL_TEST) : e2.disable(e2.STENCIL_TEST), this.current = t2, this.dirty = false;
}
}
class Je extends je {
getDefault() {
return [0, 1];
}
set(t2) {
const e2 = this.current;
(t2[0] !== e2[0] || t2[1] !== e2[1] || this.dirty) && (this.gl.depthRange(t2[0], t2[1]), this.current = t2, this.dirty = false);
}
}
class ti extends je {
getDefault() {
return false;
}
set(t2) {
if (t2 === this.current && !this.dirty) return;
const e2 = this.gl;
t2 ? e2.enable(e2.DEPTH_TEST) : e2.disable(e2.DEPTH_TEST), this.current = t2, this.dirty = false;
}
}
class ei extends je {
getDefault() {
return this.gl.LESS;
}
set(t2) {
(t2 !== this.current || this.dirty) && (this.gl.depthFunc(t2), this.current = t2, this.dirty = false);
}
}
class ii extends je {
getDefault() {
return false;
}
set(t2) {
if (t2 === this.current && !this.dirty) return;
const e2 = this.gl;
t2 ? e2.enable(e2.BLEND) : e2.disable(e2.BLEND), this.current = t2, this.dirty = false;
}
}
class si extends je {
getDefault() {
const t2 = this.gl;
return [t2.ONE, t2.ZERO];
}
set(t2) {
const e2 = this.current;
(t2[0] !== e2[0] || t2[1] !== e2[1] || this.dirty) && (this.gl.blendFunc(t2[0], t2[1]), this.current = t2, this.dirty = false);
}
}
class ai extends je {
getDefault() {
return t.aT.transparent;
}
set(t2) {
const e2 = this.current;
(t2.r !== e2.r || t2.g !== e2.g || t2.b !== e2.b || t2.a !== e2.a || this.dirty) && (this.gl.blendColor(t2.r, t2.g, t2.b, t2.a), this.current = t2, this.dirty = false);
}
}
class oi extends je {
getDefault() {
return this.gl.FUNC_ADD;
}
set(t2) {
(t2 !== this.current || this.dirty) && (this.gl.blendEquation(t2), this.current = t2, this.dirty = false);
}
}
class ri extends je {
getDefault() {
return false;
}
set(t2) {
if (t2 === this.current && !this.dirty) return;
const e2 = this.gl;
t2 ? e2.enable(e2.CULL_FACE) : e2.disable(e2.CULL_FACE), this.current = t2, this.dirty = false;
}
}
class ni extends je {
getDefault() {
return this.gl.BACK;
}
set(t2) {
(t2 !== this.current || this.dirty) && (this.gl.cullFace(t2), this.current = t2, this.dirty = false);
}
}
class li extends je {
getDefault() {
return this.gl.CCW;
}
set(t2) {
(t2 !== this.current || this.dirty) && (this.gl.frontFace(t2), this.current = t2, this.dirty = false);
}
}
class hi extends je {
getDefault() {
return null;
}
set(t2) {
(t2 !== this.current || this.dirty) && (this.gl.useProgram(t2), this.current = t2, this.dirty = false);
}
}
class ci extends je {
getDefault() {
return this.gl.TEXTURE0;
}
set(t2) {
(t2 !== this.current || this.dirty) && (this.gl.activeTexture(t2), this.current = t2, this.dirty = false);
}
}
class ui extends je {
getDefault() {
const t2 = this.gl;
return [0, 0, t2.drawingBufferWidth, t2.drawingBufferHeight];
}
set(t2) {
const e2 = this.current;
(t2[0] !== e2[0] || t2[1] !== e2[1] || t2[2] !== e2[2] || t2[3] !== e2[3] || this.dirty) && (this.gl.viewport(t2[0], t2[1], t2[2], t2[3]), this.current = t2, this.dirty = false);
}
}
class di extends je {
getDefault() {
return null;
}
set(t2) {
if (t2 === this.current && !this.dirty) return;
const e2 = this.gl;
e2.bindFramebuffer(e2.FRAMEBUFFER, t2), this.current = t2, this.dirty = false;
}
}
class _i extends je {
getDefault() {
return null;
}
set(t2) {
if (t2 === this.current && !this.dirty) return;
const e2 = this.gl;
e2.bindRenderbuffer(e2.RENDERBUFFER, t2), this.current = t2, this.dirty = false;
}
}
class pi extends je {
getDefault() {
return null;
}
set(t2) {
if (t2 === this.current && !this.dirty) return;
const e2 = this.gl;
e2.bindTexture(e2.TEXTURE_2D, t2), this.current = t2, this.dirty = false;
}
}
class mi extends je {
getDefault() {
return null;
}
set(t2) {
if (t2 === this.current && !this.dirty) return;
const e2 = this.gl;
e2.bindBuffer(e2.ARRAY_BUFFER, t2), this.current = t2, this.dirty = false;
}
}
class fi extends je {
getDefault() {
return null;
}
set(t2) {
const e2 = this.gl;
e2.bindBuffer(e2.ELEMENT_ARRAY_BUFFER, t2), this.current = t2, this.dirty = false;
}
}
class gi extends je {
getDefault() {
return null;
}
set(t2) {
var e2;
if (t2 === this.current && !this.dirty) return;
const i3 = this.gl;
Ge(i3) ? i3.bindVertexArray(t2) : null === (e2 = i3.getExtension("OES_vertex_array_object")) || void 0 === e2 || e2.bindVertexArrayOES(t2), this.current = t2, this.dirty = false;
}
}
class vi extends je {
getDefault() {
return 4;
}
set(t2) {
if (t2 === this.current && !this.dirty) return;
const e2 = this.gl;
e2.pixelStorei(e2.UNPACK_ALIGNMENT, t2), this.current = t2, this.dirty = false;
}
}
class xi extends je {
getDefault() {
return false;
}
set(t2) {
if (t2 === this.current && !this.dirty) return;
const e2 = this.gl;
e2.pixelStorei(e2.UNPACK_PREMULTIPLY_ALPHA_WEBGL, t2), this.current = t2, this.dirty = false;
}
}
class yi extends je {
getDefault() {
return false;
}
set(t2) {
if (t2 === this.current && !this.dirty) return;
const e2 = this.gl;
e2.pixelStorei(e2.UNPACK_FLIP_Y_WEBGL, t2), this.current = t2, this.dirty = false;
}
}
class bi extends je {
constructor(t2, e2) {
super(t2), this.context = t2, this.parent = e2;
}
getDefault() {
return null;
}
}
class wi extends bi {
setDirty() {
this.dirty = true;
}
set(t2) {
if (t2 === this.current && !this.dirty) return;
this.context.bindFramebuffer.set(this.parent);
const e2 = this.gl;
e2.framebufferTexture2D(e2.FRAMEBUFFER, e2.COLOR_ATTACHMENT0, e2.TEXTURE_2D, t2, 0), this.current = t2, this.dirty = false;
}
}
class Ti extends bi {
set(t2) {
if (t2 === this.current && !this.dirty) return;
this.context.bindFramebuffer.set(this.parent);
const e2 = this.gl;
e2.framebufferRenderbuffer(e2.FRAMEBUFFER, e2.DEPTH_ATTACHMENT, e2.RENDERBUFFER, t2), this.current = t2, this.dirty = false;
}
}
class Ii extends bi {
set(t2) {
if (t2 === this.current && !this.dirty) return;
this.context.bindFramebuffer.set(this.parent);
const e2 = this.gl;
e2.framebufferRenderbuffer(e2.FRAMEBUFFER, e2.DEPTH_STENCIL_ATTACHMENT, e2.RENDERBUFFER, t2), this.current = t2, this.dirty = false;
}
}
class Ei {
constructor(t2, e2, i3, s2, a2) {
this.context = t2, this.width = e2, this.height = i3;
const o2 = t2.gl, r2 = this.framebuffer = o2.createFramebuffer();
if (this.colorAttachment = new wi(t2, r2), s2) this.depthAttachment = a2 ? new Ii(t2, r2) : new Ti(t2, r2);
else if (a2) throw new Error("Stencil cannot be setted without depth");
if (o2.checkFramebufferStatus(o2.FRAMEBUFFER) !== o2.FRAMEBUFFER_COMPLETE) throw new Error("Framebuffer is not complete");
}
destroy() {
const t2 = this.context.gl, e2 = this.colorAttachment.get();
if (e2 && t2.deleteTexture(e2), this.depthAttachment) {
const e3 = this.depthAttachment.get();
e3 && t2.deleteRenderbuffer(e3);
}
t2.deleteFramebuffer(this.framebuffer);
}
}
class Si {
constructor(t2, e2, i3) {
this.blendFunction = t2, this.blendColor = e2, this.mask = i3;
}
}
Si.Replace = [1, 0], Si.disabled = new Si(Si.Replace, t.aT.transparent, [false, false, false, false]), Si.unblended = new Si(Si.Replace, t.aT.transparent, [true, true, true, true]), Si.alphaBlended = new Si([1, 771], t.aT.transparent, [true, true, true, true]);
class Ci {
constructor(t2) {
var e2, i3;
if (this.gl = t2, this.clearColor = new Ve(this), this.clearDepth = new qe(this), this.clearStencil = new $e(this), this.colorMask = new We(this), this.depthMask = new He(this), this.stencilMask = new Xe(this), this.stencilFunc = new Ke(this), this.stencilOp = new Qe(this), this.stencilTest = new Ye(this), this.depthRange = new Je(this), this.depthTest = new ti(this), this.depthFunc = new ei(this), this.blend = new ii(this), this.blendFunc = new si(this), this.blendColor = new ai(this), this.blendEquation = new oi(this), this.cullFace = new ri(this), this.cullFaceSide = new ni(this), this.frontFace = new li(this), this.program = new hi(this), this.activeTexture = new ci(this), this.viewport = new ui(this), this.bindFramebuffer = new di(this), this.bindRenderbuffer = new _i(this), this.bindTexture = new pi(this), this.bindVertexBuffer = new mi(this), this.bindElementBuffer = new fi(this), this.bindVertexArray = new gi(this), this.pixelStoreUnpack = new vi(this), this.pixelStoreUnpackPremultiplyAlpha = new xi(this), this.pixelStoreUnpackFlipY = new yi(this), this.extTextureFilterAnisotropic = t2.getExtension("EXT_texture_filter_anisotropic") || t2.getExtension("MOZ_EXT_texture_filter_anisotropic") || t2.getExtension("WEBKIT_EXT_texture_filter_anisotropic"), this.extTextureFilterAnisotropic && (this.extTextureFilterAnisotropicMax = t2.getParameter(this.extTextureFilterAnisotropic.MAX_TEXTURE_MAX_ANISOTROPY_EXT)), this.maxTextureSize = t2.getParameter(t2.MAX_TEXTURE_SIZE), Ge(t2)) {
this.HALF_FLOAT = t2.HALF_FLOAT;
const s2 = t2.getExtension("EXT_color_buffer_half_float");
this.RGBA16F = null !== (e2 = t2.RGBA16F) && void 0 !== e2 ? e2 : null == s2 ? void 0 : s2.RGBA16F_EXT, this.RGB16F = null !== (i3 = t2.RGB16F) && void 0 !== i3 ? i3 : null == s2 ? void 0 : s2.RGB16F_EXT, t2.getExtension("EXT_color_buffer_float");
} else {
t2.getExtension("EXT_color_buffer_half_float"), t2.getExtension("OES_texture_half_float_linear");
const e3 = t2.getExtension("OES_texture_half_float");
this.HALF_FLOAT = null == e3 ? void 0 : e3.HALF_FLOAT_OES;
}
}
setDefault() {
this.unbindVAO(), this.clearColor.setDefault(), this.clearDepth.setDefault(), this.clearStencil.setDefault(), this.colorMask.setDefault(), this.depthMask.setDefault(), this.stencilMask.setDefault(), this.stencilFunc.setDefault(), this.stencilOp.setDefault(), this.stencilTest.setDefault(), this.depthRange.setDefault(), this.depthTest.setDefault(), this.depthFunc.setDefault(), this.blend.setDefault(), this.blendFunc.setDefault(), this.blendColor.setDefault(), this.blendEquation.setDefault(), this.cullFace.setDefault(), this.cullFaceSide.setDefault(), this.frontFace.setDefault(), this.program.setDefault(), this.activeTexture.setDefault(), this.bindFramebuffer.setDefault(), this.pixelStoreUnpack.setDefault(), this.pixelStoreUnpackPremultiplyAlpha.setDefault(), this.pixelStoreUnpackFlipY.setDefault();
}
setDirty() {
this.clearColor.dirty = true, this.clearDepth.dirty = true, this.clearStencil.dirty = true, this.colorMask.dirty = true, this.depthMask.dirty = true, this.stencilMask.dirty = true, this.stencilFunc.dirty = true, this.stencilOp.dirty = true, this.stencilTest.dirty = true, this.depthRange.dirty = true, this.depthTest.dirty = true, this.depthFunc.dirty = true, this.blend.dirty = true, this.blendFunc.dirty = true, this.blendColor.dirty = true, this.blendEquation.dirty = true, this.cullFace.dirty = true, this.cullFaceSide.dirty = true, this.frontFace.dirty = true, this.program.dirty = true, this.activeTexture.dirty = true, this.viewport.dirty = true, this.bindFramebuffer.dirty = true, this.bindRenderbuffer.dirty = true, this.bindTexture.dirty = true, this.bindVertexBuffer.dirty = true, this.bindElementBuffer.dirty = true, this.bindVertexArray.dirty = true, this.pixelStoreUnpack.dirty = true, this.pixelStoreUnpackPremultiplyAlpha.dirty = true, this.pixelStoreUnpackFlipY.dirty = true;
}
createIndexBuffer(t2, e2) {
return new Oe(this, t2, e2);
}
createVertexBuffer(t2, e2, i3) {
return new Ue(this, t2, e2, i3);
}
createRenderbuffer(t2, e2, i3) {
const s2 = this.gl, a2 = s2.createRenderbuffer();
return this.bindRenderbuffer.set(a2), s2.renderbufferStorage(s2.RENDERBUFFER, t2, e2, i3), this.bindRenderbuffer.set(null), a2;
}
createFramebuffer(t2, e2, i3, s2) {
return new Ei(this, t2, e2, i3, s2);
}
clear({ color: t2, depth: e2, stencil: i3 }) {
const s2 = this.gl;
let a2 = 0;
t2 && (a2 |= s2.COLOR_BUFFER_BIT, this.clearColor.set(t2), this.colorMask.set([true, true, true, true])), void 0 !== e2 && (a2 |= s2.DEPTH_BUFFER_BIT, this.depthRange.set([0, 1]), this.clearDepth.set(e2), this.depthMask.set(true)), void 0 !== i3 && (a2 |= s2.STENCIL_BUFFER_BIT, this.clearStencil.set(i3), this.stencilMask.set(255)), s2.clear(a2);
}
setCullFace(t2) {
false === t2.enable ? this.cullFace.set(false) : (this.cullFace.set(true), this.cullFaceSide.set(t2.mode), this.frontFace.set(t2.frontFace));
}
setDepthMode(t2) {
t2.func !== this.gl.ALWAYS || t2.mask ? (this.depthTest.set(true), this.depthFunc.set(t2.func), this.depthMask.set(t2.mask), this.depthRange.set(t2.range)) : this.depthTest.set(false);
}
setStencilMode(t2) {
t2.test.func !== this.gl.ALWAYS || t2.mask ? (this.stencilTest.set(true), this.stencilMask.set(t2.mask), this.stencilOp.set([t2.fail, t2.depthFail, t2.pass]), this.stencilFunc.set({ func: t2.test.func, ref: t2.ref, mask: t2.test.mask })) : this.stencilTest.set(false);
}
setColorMode(e2) {
t.aG(e2.blendFunction, Si.Replace) ? this.blend.set(false) : (this.blend.set(true), this.blendFunc.set(e2.blendFunction), this.blendColor.set(e2.blendColor)), this.colorMask.set(e2.mask);
}
createVertexArray() {
var t2;
return Ge(this.gl) ? this.gl.createVertexArray() : null === (t2 = this.gl.getExtension("OES_vertex_array_object")) || void 0 === t2 ? void 0 : t2.createVertexArrayOES();
}
deleteVertexArray(t2) {
var e2;
return Ge(this.gl) ? this.gl.deleteVertexArray(t2) : null === (e2 = this.gl.getExtension("OES_vertex_array_object")) || void 0 === e2 ? void 0 : e2.deleteVertexArrayOES(t2);
}
unbindVAO() {
this.bindVertexArray.set(null);
}
}
class Pi {
constructor(t2, e2, i3) {
this.func = t2, this.mask = e2, this.range = i3;
}
}
Pi.ReadOnly = false, Pi.ReadWrite = true, Pi.disabled = new Pi(519, Pi.ReadOnly, [0, 1]);
const Di = 7680;
class Mi {
constructor(t2, e2, i3, s2, a2, o2) {
this.test = t2, this.ref = e2, this.mask = i3, this.fail = s2, this.depthFail = a2, this.pass = o2;
}
}
Mi.disabled = new Mi({ func: 519, mask: 0 }, 0, 0, Di, Di, Di);
class zi {
constructor(t2, e2, i3) {
this.enable = t2, this.mode = e2, this.frontFace = i3;
}
}
let Li;
function Ai(e2, i3, s2, a2, o2, r2, n2) {
const l2 = e2.context, h2 = l2.gl, c2 = e2.useProgram("collisionBox"), u2 = [];
let d2 = 0, _2 = 0;
for (let p3 = 0; p3 < a2.length; p3++) {
const m3 = a2[p3], f3 = i3.getTile(m3), g3 = f3.getBucket(s2);
if (!g3) continue;
let v3 = m3.posMatrix;
0 === o2[0] && 0 === o2[1] || (v3 = e2.translatePosMatrix(m3.posMatrix, f3, o2, r2));
const x3 = n2 ? g3.textCollisionBox : g3.iconCollisionBox, y2 = g3.collisionCircleArray;
if (y2.length > 0) {
const i4 = t.Z(), s3 = v3;
t.aU(i4, g3.placementInvProjMatrix, e2.transform.glCoordMatrix), t.aU(i4, i4, g3.placementViewportMatrix), u2.push({ circleArray: y2, circleOffset: _2, transform: s3, invTransform: i4, coord: m3 }), d2 += y2.length / 4, _2 = d2;
}
x3 && c2.draw(l2, h2.LINES, Pi.disabled, Mi.disabled, e2.colorModeForRenderPass(), zi.disabled, xe(v3, e2.transform, f3), e2.style.map.terrain && e2.style.map.terrain.getTerrainData(m3), s2.id, x3.layoutVertexBuffer, x3.indexBuffer, x3.segments, null, e2.transform.zoom, null, null, x3.collisionVertexBuffer);
}
if (!n2 || !u2.length) return;
const p2 = e2.useProgram("collisionCircle"), m2 = new t.aV();
m2.resize(4 * d2), m2._trim();
let f2 = 0;
for (const t2 of u2) for (let e3 = 0; e3 < t2.circleArray.length / 4; e3++) {
const i4 = 4 * e3, s3 = t2.circleArray[i4 + 0], a3 = t2.circleArray[i4 + 1], o3 = t2.circleArray[i4 + 2], r3 = t2.circleArray[i4 + 3];
m2.emplace(f2++, s3, a3, o3, r3, 0), m2.emplace(f2++, s3, a3, o3, r3, 1), m2.emplace(f2++, s3, a3, o3, r3, 2), m2.emplace(f2++, s3, a3, o3, r3, 3);
}
(!Li || Li.length < 2 * d2) && (Li = (function(e3) {
const i4 = 2 * e3, s3 = new t.aX();
s3.resize(i4), s3._trim();
for (let t2 = 0; t2 < i4; t2++) {
const e4 = 6 * t2;
s3.uint16[e4 + 0] = 4 * t2 + 0, s3.uint16[e4 + 1] = 4 * t2 + 1, s3.uint16[e4 + 2] = 4 * t2 + 2, s3.uint16[e4 + 3] = 4 * t2 + 2, s3.uint16[e4 + 4] = 4 * t2 + 3, s3.uint16[e4 + 5] = 4 * t2 + 0;
}
return s3;
})(d2));
const g2 = l2.createIndexBuffer(Li, true), v2 = l2.createVertexBuffer(m2, t.aW.members, true);
for (const i4 of u2) {
const a3 = { u_matrix: i4.transform, u_inv_matrix: i4.invTransform, u_camera_to_center_distance: (x2 = e2.transform).cameraToCenterDistance, u_viewport_size: [x2.width, x2.height] };
p2.draw(l2, h2.TRIANGLES, Pi.disabled, Mi.disabled, e2.colorModeForRenderPass(), zi.disabled, a3, e2.style.map.terrain && e2.style.map.terrain.getTerrainData(i4.coord), s2.id, v2, g2, t.S.simpleSegment(0, 2 * i4.circleOffset, i4.circleArray.length, i4.circleArray.length / 2), null, e2.transform.zoom, null, null, null);
}
var x2;
v2.destroy(), g2.destroy();
}
zi.disabled = new zi(false, 1029, 2305), zi.backCCW = new zi(true, 1029, 2305);
const Ri = t.ao(new Float32Array(16));
function ki(e2, i3, s2, a2, o2, r2) {
const { horizontalAlign: n2, verticalAlign: l2 } = t.au(e2);
return new t.P((-(n2 - 0.5) * i3 / o2 + a2[0]) * r2, (-(l2 - 0.5) * s2 / o2 + a2[1]) * r2);
}
function Fi(e2, i3, s2, a2, o2, r2, n2, l2, h2, c2, u2) {
const d2 = e2.text.placedSymbolArray, _2 = e2.text.dynamicLayoutVertexArray, p2 = e2.icon.dynamicLayoutVertexArray, m2 = {};
_2.clear();
for (let p3 = 0; p3 < d2.length; p3++) {
const f2 = d2.get(p3), g2 = f2.hidden || !f2.crossTileID || e2.allowVerticalPlacement && !f2.placedOrientation ? null : a2[f2.crossTileID];
if (g2) {
const a3 = new t.P(f2.anchorX, f2.anchorY), d3 = ht(a3, s2 ? n2 : r2, u2), p4 = ct(o2.cameraToCenterDistance, d3.signedDistanceFromCamera);
let v2 = t.aj(e2.textSizeData, h2, f2) * p4 / t.ap;
s2 && (v2 *= e2.tilePixelRatio / l2);
const { width: x2, height: y2, anchor: b2, textOffset: w2, textBoxScale: T2 } = g2, I2 = ki(b2, x2, y2, w2, T2, v2), E2 = s2 ? ht(a3.add(I2), r2, u2).point : d3.point.add(i3 ? I2.rotate(-o2.angle) : I2), S2 = e2.allowVerticalPlacement && f2.placedOrientation === t.ai.vertical ? Math.PI / 2 : 0;
for (let e3 = 0; e3 < f2.numGlyphs; e3++) t.ak(_2, E2, S2);
c2 && f2.associatedIconIndex >= 0 && (m2[f2.associatedIconIndex] = { shiftedAnchor: E2, angle: S2 });
} else wt(f2.numGlyphs, _2);
}
if (c2) {
p2.clear();
const i4 = e2.icon.placedSymbolArray;
for (let e3 = 0; e3 < i4.length; e3++) {
const s3 = i4.get(e3);
if (s3.hidden) wt(s3.numGlyphs, p2);
else {
const i5 = m2[e3];
if (i5) for (let e4 = 0; e4 < s3.numGlyphs; e4++) t.ak(p2, i5.shiftedAnchor, i5.angle);
else wt(s3.numGlyphs, p2);
}
}
e2.icon.dynamicLayoutVertexBuffer.updateData(p2);
}
e2.text.dynamicLayoutVertexBuffer.updateData(_2);
}
function Bi(t2, e2, i3) {
return i3.iconsInText && e2 ? "symbolTextAndIcon" : t2 ? "symbolSDF" : "symbolIcon";
}
function Oi(e2, i3, s2, a2, o2, r2, n2, l2, h2, c2, u2, d2) {
const _2 = e2.context, p2 = _2.gl, m2 = e2.transform, f2 = "map" === l2, g2 = "map" === h2, v2 = "viewport" !== l2 && "point" !== s2.layout.get("symbol-placement"), x2 = f2 && !g2 && !v2, y2 = !s2.layout.get("symbol-sort-key").isConstant();
let b2 = false;
const w2 = e2.depthModeForSublayer(0, Pi.ReadOnly), T2 = s2._unevaluatedLayout.hasValue("text-variable-anchor") || s2._unevaluatedLayout.hasValue("text-variable-anchor-offset"), I2 = [];
for (const l3 of a2) {
const a3 = i3.getTile(l3), h3 = a3.getBucket(s2);
if (!h3) continue;
const u3 = o2 ? h3.text : h3.icon;
if (!u3 || !u3.segments.get().length || !u3.hasVisibleVertices) continue;
const d3 = u3.programConfigurations.get(s2.id), _3 = o2 || h3.sdfIcons, w3 = o2 ? h3.textSizeData : h3.iconSizeData, E2 = g2 || 0 !== m2.pitch, S2 = e2.useProgram(Bi(_3, o2, h3), d3), C2 = t.ah(w3, m2.zoom), P2 = e2.style.map.terrain && e2.style.map.terrain.getTerrainData(l3);
let D2, M2, z2, L2, A2 = [0, 0], R2 = null;
if (o2) M2 = a3.glyphAtlasTexture, z2 = p2.LINEAR, D2 = a3.glyphAtlasTexture.size, h3.iconsInText && (A2 = a3.imageAtlasTexture.size, R2 = a3.imageAtlasTexture, L2 = E2 || e2.options.rotating || e2.options.zooming || "composite" === w3.kind || "camera" === w3.kind ? p2.LINEAR : p2.NEAREST);
else {
const t2 = 1 !== s2.layout.get("icon-size").constantOr(0) || h3.iconsNeedLinear;
M2 = a3.imageAtlasTexture, z2 = _3 || e2.options.rotating || e2.options.zooming || t2 || E2 ? p2.LINEAR : p2.NEAREST, D2 = a3.imageAtlasTexture.size;
}
const k2 = St(a3, 1, e2.transform.zoom), F2 = nt(l3.posMatrix, g2, f2, e2.transform, k2), B2 = lt(l3.posMatrix, g2, f2, e2.transform, k2), O2 = T2 && h3.hasTextData(), N2 = "none" !== s2.layout.get("icon-text-fit") && O2 && h3.hasIconData();
if (v2) {
const t2 = e2.style.map.terrain ? (t3, i5) => e2.style.map.terrain.getElevation(l3, t3, i5) : null, i4 = "map" === s2.layout.get("text-rotation-alignment");
dt(h3, l3.posMatrix, e2, o2, F2, B2, g2, c2, i4, t2);
}
const U2 = e2.translatePosMatrix(l3.posMatrix, a3, r2, n2), Z2 = v2 || o2 && T2 || N2 ? Ri : F2, G2 = e2.translatePosMatrix(B2, a3, r2, n2, true), j2 = _3 && 0 !== s2.paint.get(o2 ? "text-halo-width" : "icon-halo-width").constantOr(1);
let V2;
V2 = _3 ? h3.iconsInText ? Re(w3.kind, C2, x2, g2, e2, U2, Z2, G2, D2, A2) : Ae(w3.kind, C2, x2, g2, e2, U2, Z2, G2, o2, D2) : Le(w3.kind, C2, x2, g2, e2, U2, Z2, G2, o2, D2);
const q2 = { program: S2, buffers: u3, uniformValues: V2, atlasTexture: M2, atlasTextureIcon: R2, atlasInterpolation: z2, atlasInterpolationIcon: L2, isSDF: _3, hasHalo: j2 };
if (y2 && h3.canOverlap) {
b2 = true;
const e3 = u3.segments.get();
for (const i4 of e3) I2.push({ segments: new t.S([i4]), sortKey: i4.sortKey, state: q2, terrainData: P2 });
} else I2.push({ segments: u3.segments, sortKey: 0, state: q2, terrainData: P2 });
}
b2 && I2.sort(((t2, e3) => t2.sortKey - e3.sortKey));
for (const t2 of I2) {
const i4 = t2.state;
if (_2.activeTexture.set(p2.TEXTURE0), i4.atlasTexture.bind(i4.atlasInterpolation, p2.CLAMP_TO_EDGE), i4.atlasTextureIcon && (_2.activeTexture.set(p2.TEXTURE1), i4.atlasTextureIcon && i4.atlasTextureIcon.bind(i4.atlasInterpolationIcon, p2.CLAMP_TO_EDGE)), i4.isSDF) {
const a3 = i4.uniformValues;
i4.hasHalo && (a3.u_is_halo = 1, Ni(i4.buffers, t2.segments, s2, e2, i4.program, w2, u2, d2, a3, t2.terrainData)), a3.u_is_halo = 0;
}
Ni(i4.buffers, t2.segments, s2, e2, i4.program, w2, u2, d2, i4.uniformValues, t2.terrainData);
}
}
function Ni(t2, e2, i3, s2, a2, o2, r2, n2, l2, h2) {
const c2 = s2.context;
a2.draw(c2, c2.gl.TRIANGLES, o2, r2, n2, zi.disabled, l2, h2, i3.id, t2.layoutVertexBuffer, t2.indexBuffer, e2, i3.paint, s2.transform.zoom, t2.programConfigurations.get(i3.id), t2.dynamicLayoutVertexBuffer, t2.opacityVertexBuffer);
}
function Ui(t2, e2, i3, s2, a2) {
if (!i3 || !s2 || !s2.imageAtlas) return;
const o2 = s2.imageAtlas.patternPositions;
let r2 = o2[i3.to.toString()], n2 = o2[i3.from.toString()];
if (!r2 && n2 && (r2 = n2), !n2 && r2 && (n2 = r2), !r2 || !n2) {
const t3 = a2.getPaintProperty(e2);
r2 = o2[t3], n2 = o2[t3];
}
r2 && n2 && t2.setConstantPatternPositions(r2, n2);
}
function Zi(t2, e2, i3, s2, a2, o2, r2) {
const n2 = t2.context.gl, l2 = "fill-pattern", h2 = i3.paint.get(l2), c2 = h2 && h2.constantOr(1), u2 = i3.getCrossfadeParameters();
let d2, _2, p2, m2, f2;
r2 ? (_2 = c2 && !i3.getPaintProperty("fill-outline-color") ? "fillOutlinePattern" : "fillOutline", d2 = n2.LINES) : (_2 = c2 ? "fillPattern" : "fill", d2 = n2.TRIANGLES);
const g2 = h2.constantOr(null);
for (const h3 of s2) {
const s3 = e2.getTile(h3);
if (c2 && !s3.patternsLoaded()) continue;
const v2 = s3.getBucket(i3);
if (!v2) continue;
const x2 = v2.programConfigurations.get(i3.id), y2 = t2.useProgram(_2, x2), b2 = t2.style.map.terrain && t2.style.map.terrain.getTerrainData(h3);
c2 && (t2.context.activeTexture.set(n2.TEXTURE0), s3.imageAtlasTexture.bind(n2.LINEAR, n2.CLAMP_TO_EDGE), x2.updatePaintBuffers(u2)), Ui(x2, l2, g2, s3, i3);
const w2 = b2 ? h3 : null, T2 = t2.translatePosMatrix(w2 ? w2.posMatrix : h3.posMatrix, s3, i3.paint.get("fill-translate"), i3.paint.get("fill-translate-anchor"));
if (r2) {
m2 = v2.indexBuffer2, f2 = v2.segments2;
const e3 = [n2.drawingBufferWidth, n2.drawingBufferHeight];
p2 = "fillOutlinePattern" === _2 && c2 ? ge(T2, t2, u2, s3, e3) : fe(T2, e3);
} else m2 = v2.indexBuffer, f2 = v2.segments, p2 = c2 ? me(T2, t2, u2, s3) : pe(T2);
y2.draw(t2.context, d2, a2, t2.stencilModeForClipping(h3), o2, zi.disabled, p2, b2, i3.id, v2.layoutVertexBuffer, m2, f2, i3.paint, t2.transform.zoom, x2);
}
}
function Gi(t2, e2, i3, s2, a2, o2, r2) {
const n2 = t2.context, l2 = n2.gl, h2 = "fill-extrusion-pattern", c2 = i3.paint.get(h2), u2 = c2.constantOr(1), d2 = i3.getCrossfadeParameters(), _2 = i3.paint.get("fill-extrusion-opacity"), p2 = c2.constantOr(null);
for (const c3 of s2) {
const s3 = e2.getTile(c3), m2 = s3.getBucket(i3);
if (!m2) continue;
const f2 = t2.style.map.terrain && t2.style.map.terrain.getTerrainData(c3), g2 = m2.programConfigurations.get(i3.id), v2 = t2.useProgram(u2 ? "fillExtrusionPattern" : "fillExtrusion", g2);
u2 && (t2.context.activeTexture.set(l2.TEXTURE0), s3.imageAtlasTexture.bind(l2.LINEAR, l2.CLAMP_TO_EDGE), g2.updatePaintBuffers(d2)), Ui(g2, h2, p2, s3, i3);
const x2 = t2.translatePosMatrix(c3.posMatrix, s3, i3.paint.get("fill-extrusion-translate"), i3.paint.get("fill-extrusion-translate-anchor")), y2 = i3.paint.get("fill-extrusion-vertical-gradient"), b2 = u2 ? _e(x2, t2, y2, _2, c3, d2, s3) : de(x2, t2, y2, _2);
v2.draw(n2, n2.gl.TRIANGLES, a2, o2, r2, zi.backCCW, b2, f2, i3.id, m2.layoutVertexBuffer, m2.indexBuffer, m2.segments, i3.paint, t2.transform.zoom, g2, t2.style.map.terrain && m2.centroidVertexBuffer);
}
}
function ji(t2, e2, i3, s2, a2, o2, r2) {
const n2 = t2.context, l2 = n2.gl, h2 = i3.fbo;
if (!h2) return;
const c2 = t2.useProgram("hillshade"), u2 = t2.style.map.terrain && t2.style.map.terrain.getTerrainData(e2);
n2.activeTexture.set(l2.TEXTURE0), l2.bindTexture(l2.TEXTURE_2D, h2.colorAttachment.get()), c2.draw(n2, l2.TRIANGLES, a2, o2, r2, zi.disabled, ((t3, e3, i4, s3) => {
const a3 = i4.paint.get("hillshade-shadow-color"), o3 = i4.paint.get("hillshade-highlight-color"), r3 = i4.paint.get("hillshade-accent-color");
let n3 = i4.paint.get("hillshade-illumination-direction") * (Math.PI / 180);
"viewport" === i4.paint.get("hillshade-illumination-anchor") && (n3 -= t3.transform.angle);
const l3 = !t3.options.moving;
return { u_matrix: s3 ? s3.posMatrix : t3.transform.calculatePosMatrix(e3.tileID.toUnwrapped(), l3), u_image: 0, u_latrange: Te(0, e3.tileID), u_light: [i4.paint.get("hillshade-exaggeration"), n3], u_shadow: a3, u_highlight: o3, u_accent: r3 };
})(t2, i3, s2, u2 ? e2 : null), u2, s2.id, t2.rasterBoundsBuffer, t2.quadTriangleIndexBuffer, t2.rasterBoundsSegments);
}
function Vi(e2, i3, s2, a2, o2, r2) {
const n2 = e2.context, l2 = n2.gl, h2 = i3.dem;
if (h2 && h2.data) {
const c2 = h2.dim, u2 = h2.stride, d2 = h2.getPixels();
if (n2.activeTexture.set(l2.TEXTURE1), n2.pixelStoreUnpackPremultiplyAlpha.set(false), i3.demTexture = i3.demTexture || e2.getTileTexture(u2), i3.demTexture) {
const t2 = i3.demTexture;
t2.update(d2, { premultiply: false }), t2.bind(l2.NEAREST, l2.CLAMP_TO_EDGE);
} else i3.demTexture = new x(n2, d2, l2.RGBA, { premultiply: false }), i3.demTexture.bind(l2.NEAREST, l2.CLAMP_TO_EDGE);
n2.activeTexture.set(l2.TEXTURE0);
let _2 = i3.fbo;
if (!_2) {
const t2 = new x(n2, { width: c2, height: c2, data: null }, l2.RGBA);
t2.bind(l2.LINEAR, l2.CLAMP_TO_EDGE), _2 = i3.fbo = n2.createFramebuffer(c2, c2, true, false), _2.colorAttachment.set(t2.texture);
}
n2.bindFramebuffer.set(_2.framebuffer), n2.viewport.set([0, 0, c2, c2]), e2.useProgram("hillshadePrepare").draw(n2, l2.TRIANGLES, a2, o2, r2, zi.disabled, ((e3, i4) => {
const s3 = i4.stride, a3 = t.Z();
return t.aS(a3, 0, t.N, -t.N, 0, 0, 1), t.$(a3, a3, [0, -t.N, 0]), { u_matrix: a3, u_image: 1, u_dimension: [s3, s3], u_zoom: e3.overscaledZ, u_unpack: i4.getUnpackVector() };
})(i3.tileID, h2), null, s2.id, e2.rasterBoundsBuffer, e2.quadTriangleIndexBuffer, e2.rasterBoundsSegments), i3.needsHillshadePrepare = false;
}
}
function qi(e2, i3, s2, a2, o2, r2) {
const n2 = a2.paint.get("raster-fade-duration");
if (!r2 && n2 > 0) {
const a3 = t.h.now(), r3 = (a3 - e2.timeAdded) / n2, l2 = i3 ? (a3 - i3.timeAdded) / n2 : -1, h2 = s2.getSource(), c2 = o2.coveringZoomLevel({ tileSize: h2.tileSize, roundZoom: h2.roundZoom }), u2 = !i3 || Math.abs(i3.tileID.overscaledZ - c2) > Math.abs(e2.tileID.overscaledZ - c2), d2 = u2 && e2.refreshedUponExpiration ? 1 : t.ad(u2 ? r3 : 1 - l2, 0, 1);
return e2.refreshedUponExpiration && r3 >= 1 && (e2.refreshedUponExpiration = false), i3 ? { opacity: 1, mix: 1 - d2 } : { opacity: d2, mix: 0 };
}
return { opacity: 1, mix: 0 };
}
const $i = new t.aT(1, 0, 0, 1), Wi = new t.aT(0, 1, 0, 1), Hi = new t.aT(0, 0, 1, 1), Xi = new t.aT(1, 0, 1, 1), Ki = new t.aT(0, 1, 1, 1);
function Qi(t2, e2, i3, s2) {
Ji(t2, 0, e2 + i3 / 2, t2.transform.width, i3, s2);
}
function Yi(t2, e2, i3, s2) {
Ji(t2, e2 - i3 / 2, 0, i3, t2.transform.height, s2);
}
function Ji(t2, e2, i3, s2, a2, o2) {
const r2 = t2.context, n2 = r2.gl;
n2.enable(n2.SCISSOR_TEST), n2.scissor(e2 * t2.pixelRatio, i3 * t2.pixelRatio, s2 * t2.pixelRatio, a2 * t2.pixelRatio), r2.clear({ color: o2 }), n2.disable(n2.SCISSOR_TEST);
}
function ts(e2, i3, s2) {
const a2 = e2.context, o2 = a2.gl, r2 = s2.posMatrix, n2 = e2.useProgram("debug"), l2 = Pi.disabled, h2 = Mi.disabled, c2 = e2.colorModeForRenderPass(), u2 = "$debug", d2 = e2.style.map.terrain && e2.style.map.terrain.getTerrainData(s2);
a2.activeTexture.set(o2.TEXTURE0);
const _2 = i3.getTileByID(s2.key).latestRawTileData, p2 = Math.floor((_2 && _2.byteLength || 0) / 1024), m2 = i3.getTile(s2).tileSize, f2 = 512 / Math.min(m2, 512) * (s2.overscaledZ / e2.transform.zoom) * 0.5;
let g2 = s2.canonical.toString();
s2.overscaledZ !== s2.canonical.z && (g2 += ` => ${s2.overscaledZ}`), (function(t2, e3) {
t2.initDebugOverlayCanvas();
const i4 = t2.debugOverlayCanvas, s3 = t2.context.gl, a3 = t2.debugOverlayCanvas.getContext("2d");
a3.clearRect(0, 0, i4.width, i4.height), a3.shadowColor = "white", a3.shadowBlur = 2, a3.lineWidth = 1.5, a3.strokeStyle = "white", a3.textBaseline = "top", a3.font = "bold 36px Open Sans, sans-serif", a3.fillText(e3, 5, 5), a3.strokeText(e3, 5, 5), t2.debugOverlayTexture.update(i4), t2.debugOverlayTexture.bind(s3.LINEAR, s3.CLAMP_TO_EDGE);
})(e2, `${g2} ${p2}kB`), n2.draw(a2, o2.TRIANGLES, l2, h2, Si.alphaBlended, zi.disabled, ye(r2, t.aT.transparent, f2), null, u2, e2.debugBuffer, e2.quadTriangleIndexBuffer, e2.debugSegments), n2.draw(a2, o2.LINE_STRIP, l2, h2, c2, zi.disabled, ye(r2, t.aT.red), d2, u2, e2.debugBuffer, e2.tileBorderIndexBuffer, e2.debugSegments);
}
function es(t2, e2, i3) {
const s2 = t2.context, a2 = s2.gl, o2 = t2.colorModeForRenderPass(), r2 = new Pi(a2.LEQUAL, Pi.ReadWrite, t2.depthRangeFor3D), n2 = t2.useProgram("terrain"), l2 = e2.getTerrainMesh();
s2.bindFramebuffer.set(null), s2.viewport.set([0, 0, t2.width, t2.height]);
for (const h2 of i3) {
const i4 = t2.renderToTexture.getTexture(h2), c2 = e2.getTerrainData(h2.tileID);
s2.activeTexture.set(a2.TEXTURE0), a2.bindTexture(a2.TEXTURE_2D, i4.texture);
const u2 = { u_matrix: t2.transform.calculatePosMatrix(h2.tileID.toUnwrapped()), u_texture: 0, u_ele_delta: e2.getMeshFrameDelta(t2.transform.zoom) };
n2.draw(s2, a2.TRIANGLES, r2, Mi.disabled, o2, zi.backCCW, u2, c2, "terrain", l2.vertexBuffer, l2.indexBuffer, l2.segments);
}
}
class is {
constructor(e2, i3) {
this.context = new Ci(e2), this.transform = i3, this._tileTextures = {}, this.terrainFacilitator = { dirty: true, matrix: t.Z(), renderTime: 0 }, this.setup(), this.numSublayers = K.maxUnderzooming + K.maxOverzooming + 1, this.depthEpsilon = 1 / Math.pow(2, 16), this.crossTileSymbolIndex = new Yt();
}
resize(t2, e2, i3) {
if (this.width = Math.floor(t2 * i3), this.height = Math.floor(e2 * i3), this.pixelRatio = i3, this.context.viewport.set([0, 0, this.width, this.height]), this.style) for (const t3 of this.style._order) this.style._layers[t3].resize();
}
setup() {
const e2 = this.context, i3 = new t.a_();
i3.emplaceBack(0, 0), i3.emplaceBack(t.N, 0), i3.emplaceBack(0, t.N), i3.emplaceBack(t.N, t.N), this.tileExtentBuffer = e2.createVertexBuffer(i3, ae.members), this.tileExtentSegments = t.S.simpleSegment(0, 0, 4, 2);
const s2 = new t.a_();
s2.emplaceBack(0, 0), s2.emplaceBack(t.N, 0), s2.emplaceBack(0, t.N), s2.emplaceBack(t.N, t.N), this.debugBuffer = e2.createVertexBuffer(s2, ae.members), this.debugSegments = t.S.simpleSegment(0, 0, 4, 5);
const a2 = new t.V();
a2.emplaceBack(0, 0, 0, 0), a2.emplaceBack(t.N, 0, t.N, 0), a2.emplaceBack(0, t.N, 0, t.N), a2.emplaceBack(t.N, t.N, t.N, t.N), this.rasterBoundsBuffer = e2.createVertexBuffer(a2, O.members), this.rasterBoundsSegments = t.S.simpleSegment(0, 0, 4, 2);
const o2 = new t.a_();
o2.emplaceBack(0, 0), o2.emplaceBack(1, 0), o2.emplaceBack(0, 1), o2.emplaceBack(1, 1), this.viewportBuffer = e2.createVertexBuffer(o2, ae.members), this.viewportSegments = t.S.simpleSegment(0, 0, 4, 2);
const r2 = new t.a$();
r2.emplaceBack(0), r2.emplaceBack(1), r2.emplaceBack(3), r2.emplaceBack(2), r2.emplaceBack(0), this.tileBorderIndexBuffer = e2.createIndexBuffer(r2);
const n2 = new t.b0();
n2.emplaceBack(0, 1, 2), n2.emplaceBack(2, 1, 3), this.quadTriangleIndexBuffer = e2.createIndexBuffer(n2);
const l2 = this.context.gl;
this.stencilClearMode = new Mi({ func: l2.ALWAYS, mask: 0 }, 0, 255, l2.ZERO, l2.ZERO, l2.ZERO);
}
clearStencil() {
const e2 = this.context, i3 = e2.gl;
this.nextStencilID = 1, this.currentStencilSource = void 0;
const s2 = t.Z();
t.aS(s2, 0, this.width, this.height, 0, 0, 1), t.a0(s2, s2, [i3.drawingBufferWidth, i3.drawingBufferHeight, 0]), this.useProgram("clippingMask").draw(e2, i3.TRIANGLES, Pi.disabled, this.stencilClearMode, Si.disabled, zi.disabled, be(s2), null, "$clipping", this.viewportBuffer, this.quadTriangleIndexBuffer, this.viewportSegments);
}
_renderTileClippingMasks(t2, e2) {
if (this.currentStencilSource === t2.source || !t2.isTileClipped() || !e2 || !e2.length) return;
this.currentStencilSource = t2.source;
const i3 = this.context, s2 = i3.gl;
this.nextStencilID + e2.length > 256 && this.clearStencil(), i3.setColorMode(Si.disabled), i3.setDepthMode(Pi.disabled);
const a2 = this.useProgram("clippingMask");
this._tileClippingMaskIDs = {};
for (const t3 of e2) {
const e3 = this._tileClippingMaskIDs[t3.key] = this.nextStencilID++, o2 = this.style.map.terrain && this.style.map.terrain.getTerrainData(t3);
a2.draw(i3, s2.TRIANGLES, Pi.disabled, new Mi({ func: s2.ALWAYS, mask: 0 }, e3, 255, s2.KEEP, s2.KEEP, s2.REPLACE), Si.disabled, zi.disabled, be(t3.posMatrix), o2, "$clipping", this.tileExtentBuffer, this.quadTriangleIndexBuffer, this.tileExtentSegments);
}
}
stencilModeFor3D() {
this.currentStencilSource = void 0, this.nextStencilID + 1 > 256 && this.clearStencil();
const t2 = this.nextStencilID++, e2 = this.context.gl;
return new Mi({ func: e2.NOTEQUAL, mask: 255 }, t2, 255, e2.KEEP, e2.KEEP, e2.REPLACE);
}
stencilModeForClipping(t2) {
const e2 = this.context.gl;
return new Mi({ func: e2.EQUAL, mask: 255 }, this._tileClippingMaskIDs[t2.key], 0, e2.KEEP, e2.KEEP, e2.REPLACE);
}
stencilConfigForOverlap(t2) {
const e2 = this.context.gl, i3 = t2.sort(((t3, e3) => e3.overscaledZ - t3.overscaledZ)), s2 = i3[i3.length - 1].overscaledZ, a2 = i3[0].overscaledZ - s2 + 1;
if (a2 > 1) {
this.currentStencilSource = void 0, this.nextStencilID + a2 > 256 && this.clearStencil();
const t3 = {};
for (let i4 = 0; i4 < a2; i4++) t3[i4 + s2] = new Mi({ func: e2.GEQUAL, mask: 255 }, i4 + this.nextStencilID, 255, e2.KEEP, e2.KEEP, e2.REPLACE);
return this.nextStencilID += a2, [t3, i3];
}
return [{ [s2]: Mi.disabled }, i3];
}
colorModeForRenderPass() {
const e2 = this.context.gl;
if (this._showOverdrawInspector) {
const i3 = 1 / 8;
return new Si([e2.CONSTANT_COLOR, e2.ONE], new t.aT(i3, i3, i3, 0), [true, true, true, true]);
}
return "opaque" === this.renderPass ? Si.unblended : Si.alphaBlended;
}
depthModeForSublayer(t2, e2, i3) {
if (!this.opaquePassEnabledForLayer()) return Pi.disabled;
const s2 = 1 - ((1 + this.currentLayer) * this.numSublayers + t2) * this.depthEpsilon;
return new Pi(i3 || this.context.gl.LEQUAL, e2, [s2, s2]);
}
opaquePassEnabledForLayer() {
return this.currentLayer < this.opaquePassCutoff;
}
render(e2, i3) {
this.style = e2, this.options = i3, this.lineAtlas = e2.lineAtlas, this.imageManager = e2.imageManager, this.glyphManager = e2.glyphManager, this.symbolFadeChange = e2.placement.symbolFadeChange(t.h.now()), this.imageManager.beginFrame();
const s2 = this.style._order, a2 = this.style.sourceCaches, o2 = {}, r2 = {}, n2 = {};
for (const t2 in a2) {
const e3 = a2[t2];
e3.used && e3.prepare(this.context), o2[t2] = e3.getVisibleCoordinates(), r2[t2] = o2[t2].slice().reverse(), n2[t2] = e3.getVisibleCoordinates(true).reverse();
}
this.opaquePassCutoff = 1 / 0;
for (let t2 = 0; t2 < s2.length; t2++) if (this.style._layers[s2[t2]].is3D()) {
this.opaquePassCutoff = t2;
break;
}
if (this.renderToTexture) {
this.renderToTexture.prepareForRender(this.style, this.transform.zoom), this.opaquePassCutoff = 0;
const e3 = this.style.map.terrain.sourceCache.tilesAfterTime(this.terrainFacilitator.renderTime);
(this.terrainFacilitator.dirty || !t.b1(this.terrainFacilitator.matrix, this.transform.projMatrix) || e3.length) && (t.b2(this.terrainFacilitator.matrix, this.transform.projMatrix), this.terrainFacilitator.renderTime = Date.now(), this.terrainFacilitator.dirty = false, (function(e4, i4) {
const s3 = e4.context, a3 = s3.gl, o3 = Si.unblended, r3 = new Pi(a3.LEQUAL, Pi.ReadWrite, [0, 1]), n3 = i4.getTerrainMesh(), l2 = i4.sourceCache.getRenderableTiles(), h2 = e4.useProgram("terrainDepth");
s3.bindFramebuffer.set(i4.getFramebuffer("depth").framebuffer), s3.viewport.set([0, 0, e4.width / devicePixelRatio, e4.height / devicePixelRatio]), s3.clear({ color: t.aT.transparent, depth: 1 });
for (const t2 of l2) {
const l3 = i4.getTerrainData(t2.tileID), c2 = { u_matrix: e4.transform.calculatePosMatrix(t2.tileID.toUnwrapped()), u_ele_delta: i4.getMeshFrameDelta(e4.transform.zoom) };
h2.draw(s3, a3.TRIANGLES, r3, Mi.disabled, o3, zi.backCCW, c2, l3, "terrain", n3.vertexBuffer, n3.indexBuffer, n3.segments);
}
s3.bindFramebuffer.set(null), s3.viewport.set([0, 0, e4.width, e4.height]);
})(this, this.style.map.terrain), (function(e4, i4) {
const s3 = e4.context, a3 = s3.gl, o3 = Si.unblended, r3 = new Pi(a3.LEQUAL, Pi.ReadWrite, [0, 1]), n3 = i4.getTerrainMesh(), l2 = i4.getCoordsTexture(), h2 = i4.sourceCache.getRenderableTiles(), c2 = e4.useProgram("terrainCoords");
s3.bindFramebuffer.set(i4.getFramebuffer("coords").framebuffer), s3.viewport.set([0, 0, e4.width / devicePixelRatio, e4.height / devicePixelRatio]), s3.clear({ color: t.aT.transparent, depth: 1 }), i4.coordsIndex = [];
for (const t2 of h2) {
const h3 = i4.getTerrainData(t2.tileID);
s3.activeTexture.set(a3.TEXTURE0), a3.bindTexture(a3.TEXTURE_2D, l2.texture);
const u2 = { u_matrix: e4.transform.calculatePosMatrix(t2.tileID.toUnwrapped()), u_terrain_coords_id: (255 - i4.coordsIndex.length) / 255, u_texture: 0, u_ele_delta: i4.getMeshFrameDelta(e4.transform.zoom) };
c2.draw(s3, a3.TRIANGLES, r3, Mi.disabled, o3, zi.backCCW, u2, h3, "terrain", n3.vertexBuffer, n3.indexBuffer, n3.segments), i4.coordsIndex.push(t2.tileID.key);
}
s3.bindFramebuffer.set(null), s3.viewport.set([0, 0, e4.width, e4.height]);
})(this, this.style.map.terrain));
}
this.renderPass = "offscreen";
for (const t2 of s2) {
const e3 = this.style._layers[t2];
if (!e3.hasOffscreenPass() || e3.isHidden(this.transform.zoom)) continue;
const i4 = r2[e3.source];
("custom" === e3.type || i4.length) && this.renderLayer(this, a2[e3.source], e3, i4);
}
if (this.context.bindFramebuffer.set(null), this.context.clear({ color: i3.showOverdrawInspector ? t.aT.black : t.aT.transparent, depth: 1 }), this.clearStencil(), this._showOverdrawInspector = i3.showOverdrawInspector, this.depthRangeFor3D = [0, 1 - (e2._order.length + 2) * this.numSublayers * this.depthEpsilon], !this.renderToTexture) for (this.renderPass = "opaque", this.currentLayer = s2.length - 1; this.currentLayer >= 0; this.currentLayer--) {
const t2 = this.style._layers[s2[this.currentLayer]], e3 = a2[t2.source], i4 = o2[t2.source];
this._renderTileClippingMasks(t2, i4), this.renderLayer(this, e3, t2, i4);
}
for (this.renderPass = "translucent", this.currentLayer = 0; this.currentLayer < s2.length; this.currentLayer++) {
const t2 = this.style._layers[s2[this.currentLayer]], e3 = a2[t2.source];
if (this.renderToTexture && this.renderToTexture.renderLayer(t2)) continue;
const i4 = ("symbol" === t2.type ? n2 : r2)[t2.source];
this._renderTileClippingMasks(t2, o2[t2.source]), this.renderLayer(this, e3, t2, i4);
}
if (this.options.showTileBoundaries) {
const t2 = (function(t3, e3) {
let i4 = null;
const s3 = Object.values(t3._layers).flatMap(((i5) => i5.source && !i5.isHidden(e3) ? [t3.sourceCaches[i5.source]] : [])), a3 = s3.filter(((t4) => "vector" === t4.getSource().type)), o3 = s3.filter(((t4) => "vector" !== t4.getSource().type)), r3 = (t4) => {
(!i4 || i4.getSource().maxzoom < t4.getSource().maxzoom) && (i4 = t4);
};
return a3.forEach(((t4) => r3(t4))), i4 || o3.forEach(((t4) => r3(t4))), i4;
})(this.style, this.transform.zoom);
t2 && (function(t3, e3, i4) {
for (let s3 = 0; s3 < i4.length; s3++) ts(t3, e3, i4[s3]);
})(this, t2, t2.getVisibleCoordinates());
}
this.options.showPadding && (function(t2) {
const e3 = t2.transform.padding;
Qi(t2, t2.transform.height - (e3.top || 0), 3, $i), Qi(t2, e3.bottom || 0, 3, Wi), Yi(t2, e3.left || 0, 3, Hi), Yi(t2, t2.transform.width - (e3.right || 0), 3, Xi);
const i4 = t2.transform.centerPoint;
!(function(t3, e4, i5, s3) {
Ji(t3, e4 - 1, i5 - 10, 2, 20, s3), Ji(t3, e4 - 10, i5 - 1, 20, 2, s3);
})(t2, i4.x, t2.transform.height - i4.y, Ki);
})(this), this.context.setDefault();
}
renderLayer(e2, i3, s2, a2) {
if (!s2.isHidden(this.transform.zoom) && ("background" === s2.type || "custom" === s2.type || (a2 || []).length)) switch (this.id = s2.id, s2.type) {
case "symbol":
!(function(e3, i4, s3, a3, o2) {
if ("translucent" !== e3.renderPass) return;
const r2 = Mi.disabled, n2 = e3.colorModeForRenderPass();
(s3._unevaluatedLayout.hasValue("text-variable-anchor") || s3._unevaluatedLayout.hasValue("text-variable-anchor-offset")) && (function(e4, i5, s4, a4, o3, r3, n3) {
const l2 = i5.transform, h2 = "map" === o3, c2 = "map" === r3;
for (const o4 of e4) {
const e5 = a4.getTile(o4), r4 = e5.getBucket(s4);
if (!r4 || !r4.text || !r4.text.segments.get().length) continue;
const u2 = t.ah(r4.textSizeData, l2.zoom), d2 = St(e5, 1, i5.transform.zoom), _2 = nt(o4.posMatrix, c2, h2, i5.transform, d2), p2 = "none" !== s4.layout.get("icon-text-fit") && r4.hasIconData();
if (u2) {
const t2 = Math.pow(2, l2.zoom - e5.tileID.overscaledZ);
Fi(r4, h2, c2, n3, l2, _2, o4.posMatrix, t2, u2, p2, i5.style.map.terrain ? (t3, e6) => i5.style.map.terrain.getElevation(o4, t3, e6) : null);
}
}
})(a3, e3, s3, i4, s3.layout.get("text-rotation-alignment"), s3.layout.get("text-pitch-alignment"), o2), 0 !== s3.paint.get("icon-opacity").constantOr(1) && Oi(e3, i4, s3, a3, false, s3.paint.get("icon-translate"), s3.paint.get("icon-translate-anchor"), s3.layout.get("icon-rotation-alignment"), s3.layout.get("icon-pitch-alignment"), s3.layout.get("icon-keep-upright"), r2, n2), 0 !== s3.paint.get("text-opacity").constantOr(1) && Oi(e3, i4, s3, a3, true, s3.paint.get("text-translate"), s3.paint.get("text-translate-anchor"), s3.layout.get("text-rotation-alignment"), s3.layout.get("text-pitch-alignment"), s3.layout.get("text-keep-upright"), r2, n2), i4.map.showCollisionBoxes && (Ai(e3, i4, s3, a3, s3.paint.get("text-translate"), s3.paint.get("text-translate-anchor"), true), Ai(e3, i4, s3, a3, s3.paint.get("icon-translate"), s3.paint.get("icon-translate-anchor"), false));
})(e2, i3, s2, a2, this.style.placement.variableOffsets);
break;
case "circle":
!(function(e3, i4, s3, a3) {
if ("translucent" !== e3.renderPass) return;
const o2 = s3.paint.get("circle-opacity"), r2 = s3.paint.get("circle-stroke-width"), n2 = s3.paint.get("circle-stroke-opacity"), l2 = !s3.layout.get("circle-sort-key").isConstant();
if (0 === o2.constantOr(1) && (0 === r2.constantOr(1) || 0 === n2.constantOr(1))) return;
const h2 = e3.context, c2 = h2.gl, u2 = e3.depthModeForSublayer(0, Pi.ReadOnly), d2 = Mi.disabled, _2 = e3.colorModeForRenderPass(), p2 = [];
for (let o3 = 0; o3 < a3.length; o3++) {
const r3 = a3[o3], n3 = i4.getTile(r3), h3 = n3.getBucket(s3);
if (!h3) continue;
const c3 = h3.programConfigurations.get(s3.id), u3 = e3.useProgram("circle", c3), d3 = h3.layoutVertexBuffer, _3 = h3.indexBuffer, m2 = e3.style.map.terrain && e3.style.map.terrain.getTerrainData(r3), f2 = { programConfiguration: c3, program: u3, layoutVertexBuffer: d3, indexBuffer: _3, uniformValues: ve(e3, r3, n3, s3), terrainData: m2 };
if (l2) {
const e4 = h3.segments.get();
for (const i5 of e4) p2.push({ segments: new t.S([i5]), sortKey: i5.sortKey, state: f2 });
} else p2.push({ segments: h3.segments, sortKey: 0, state: f2 });
}
l2 && p2.sort(((t2, e4) => t2.sortKey - e4.sortKey));
for (const t2 of p2) {
const { programConfiguration: i5, program: a4, layoutVertexBuffer: o3, indexBuffer: r3, uniformValues: n3, terrainData: l3 } = t2.state;
a4.draw(h2, c2.TRIANGLES, u2, d2, _2, zi.disabled, n3, l3, s3.id, o3, r3, t2.segments, s3.paint, e3.transform.zoom, i5);
}
})(e2, i3, s2, a2);
break;
case "heatmap":
!(function(e3, i4, s3, a3) {
if (0 !== s3.paint.get("heatmap-opacity")) if ("offscreen" === e3.renderPass) {
const o2 = e3.context, r2 = o2.gl, n2 = Mi.disabled, l2 = new Si([r2.ONE, r2.ONE], t.aT.transparent, [true, true, true, true]);
!(function(t2, e4, i5) {
const s4 = t2.gl;
t2.activeTexture.set(s4.TEXTURE1), t2.viewport.set([0, 0, e4.width / 4, e4.height / 4]);
let a4 = i5.heatmapFbo;
if (a4) s4.bindTexture(s4.TEXTURE_2D, a4.colorAttachment.get()), t2.bindFramebuffer.set(a4.framebuffer);
else {
const o3 = s4.createTexture();
s4.bindTexture(s4.TEXTURE_2D, o3), s4.texParameteri(s4.TEXTURE_2D, s4.TEXTURE_WRAP_S, s4.CLAMP_TO_EDGE), s4.texParameteri(s4.TEXTURE_2D, s4.TEXTURE_WRAP_T, s4.CLAMP_TO_EDGE), s4.texParameteri(s4.TEXTURE_2D, s4.TEXTURE_MIN_FILTER, s4.LINEAR), s4.texParameteri(s4.TEXTURE_2D, s4.TEXTURE_MAG_FILTER, s4.LINEAR), a4 = i5.heatmapFbo = t2.createFramebuffer(e4.width / 4, e4.height / 4, false, false), (function(t3, e5, i6, s5) {
var a5, o4;
const r3 = t3.gl, n3 = null !== (a5 = t3.HALF_FLOAT) && void 0 !== a5 ? a5 : r3.UNSIGNED_BYTE, l3 = null !== (o4 = t3.RGBA16F) && void 0 !== o4 ? o4 : r3.RGBA;
r3.texImage2D(r3.TEXTURE_2D, 0, l3, e5.width / 4, e5.height / 4, 0, r3.RGBA, n3, null), s5.colorAttachment.set(i6);
})(t2, e4, o3, a4);
}
})(o2, e3, s3), o2.clear({ color: t.aT.transparent });
for (let t2 = 0; t2 < a3.length; t2++) {
const h2 = a3[t2];
if (i4.hasRenderableParent(h2)) continue;
const c2 = i4.getTile(h2), u2 = c2.getBucket(s3);
if (!u2) continue;
const d2 = u2.programConfigurations.get(s3.id), _2 = e3.useProgram("heatmap", d2), { zoom: p2 } = e3.transform;
_2.draw(o2, r2.TRIANGLES, Pi.disabled, n2, l2, zi.disabled, we(h2.posMatrix, c2, p2, s3.paint.get("heatmap-intensity")), null, s3.id, u2.layoutVertexBuffer, u2.indexBuffer, u2.segments, s3.paint, e3.transform.zoom, d2);
}
o2.viewport.set([0, 0, e3.width, e3.height]);
} else "translucent" === e3.renderPass && (e3.context.setColorMode(e3.colorModeForRenderPass()), (function(e4, i5) {
const s4 = e4.context, a4 = s4.gl, o2 = i5.heatmapFbo;
if (!o2) return;
s4.activeTexture.set(a4.TEXTURE0), a4.bindTexture(a4.TEXTURE_2D, o2.colorAttachment.get()), s4.activeTexture.set(a4.TEXTURE1);
let r2 = i5.colorRampTexture;
r2 || (r2 = i5.colorRampTexture = new x(s4, i5.colorRamp, a4.RGBA)), r2.bind(a4.LINEAR, a4.CLAMP_TO_EDGE), e4.useProgram("heatmapTexture").draw(s4, a4.TRIANGLES, Pi.disabled, Mi.disabled, e4.colorModeForRenderPass(), zi.disabled, ((e5, i6, s5, a5) => {
const o3 = t.Z();
t.aS(o3, 0, e5.width, e5.height, 0, 0, 1);
const r3 = e5.context.gl;
return { u_matrix: o3, u_world: [r3.drawingBufferWidth, r3.drawingBufferHeight], u_image: 0, u_color_ramp: 1, u_opacity: i6.paint.get("heatmap-opacity") };
})(e4, i5), null, i5.id, e4.viewportBuffer, e4.quadTriangleIndexBuffer, e4.viewportSegments, i5.paint, e4.transform.zoom);
})(e3, s3));
})(e2, i3, s2, a2);
break;
case "line":
!(function(e3, i4, s3, a3) {
if ("translucent" !== e3.renderPass) return;
const o2 = s3.paint.get("line-opacity"), r2 = s3.paint.get("line-width");
if (0 === o2.constantOr(1) || 0 === r2.constantOr(1)) return;
const n2 = e3.depthModeForSublayer(0, Pi.ReadOnly), l2 = e3.colorModeForRenderPass(), h2 = s3.paint.get("line-dasharray"), c2 = s3.paint.get("line-pattern"), u2 = c2.constantOr(1), d2 = s3.paint.get("line-gradient"), _2 = s3.getCrossfadeParameters(), p2 = u2 ? "linePattern" : h2 ? "lineSDF" : d2 ? "lineGradient" : "line", m2 = e3.context, f2 = m2.gl;
let g2 = true;
for (const o3 of a3) {
const a4 = i4.getTile(o3);
if (u2 && !a4.patternsLoaded()) continue;
const r3 = a4.getBucket(s3);
if (!r3) continue;
const v2 = r3.programConfigurations.get(s3.id), y2 = e3.context.program.get(), b2 = e3.useProgram(p2, v2), w2 = g2 || b2.program !== y2, T2 = e3.style.map.terrain && e3.style.map.terrain.getTerrainData(o3), I2 = c2.constantOr(null);
if (I2 && a4.imageAtlas) {
const t2 = a4.imageAtlas, e4 = t2.patternPositions[I2.to.toString()], i5 = t2.patternPositions[I2.from.toString()];
e4 && i5 && v2.setConstantPatternPositions(e4, i5);
}
const E2 = T2 ? o3 : null, S2 = u2 ? Se(e3, a4, s3, _2, E2) : h2 ? Ce(e3, a4, s3, h2, _2, E2) : d2 ? Ee(e3, a4, s3, r3.lineClipsArray.length, E2) : Ie(e3, a4, s3, E2);
if (u2) m2.activeTexture.set(f2.TEXTURE0), a4.imageAtlasTexture.bind(f2.LINEAR, f2.CLAMP_TO_EDGE), v2.updatePaintBuffers(_2);
else if (h2 && (w2 || e3.lineAtlas.dirty)) m2.activeTexture.set(f2.TEXTURE0), e3.lineAtlas.bind(m2);
else if (d2) {
const a5 = r3.gradients[s3.id];
let n3 = a5.texture;
if (s3.gradientVersion !== a5.version) {
let l3 = 256;
if (s3.stepInterpolant) {
const s4 = i4.getSource().maxzoom, a6 = o3.canonical.z === s4 ? Math.ceil(1 << e3.transform.maxZoom - o3.canonical.z) : 1;
l3 = t.ad(t.aY(r3.maxLineLength / t.N * 1024 * a6), 256, m2.maxTextureSize);
}
a5.gradient = t.aZ({ expression: s3.gradientExpression(), evaluationKey: "lineProgress", resolution: l3, image: a5.gradient || void 0, clips: r3.lineClipsArray }), a5.texture ? a5.texture.update(a5.gradient) : a5.texture = new x(m2, a5.gradient, f2.RGBA), a5.version = s3.gradientVersion, n3 = a5.texture;
}
m2.activeTexture.set(f2.TEXTURE0), n3.bind(s3.stepInterpolant ? f2.NEAREST : f2.LINEAR, f2.CLAMP_TO_EDGE);
}
b2.draw(m2, f2.TRIANGLES, n2, e3.stencilModeForClipping(o3), l2, zi.disabled, S2, T2, s3.id, r3.layoutVertexBuffer, r3.indexBuffer, r3.segments, s3.paint, e3.transform.zoom, v2, r3.layoutVertexBuffer2), g2 = false;
}
})(e2, i3, s2, a2);
break;
case "fill":
!(function(e3, i4, s3, a3) {
const o2 = s3.paint.get("fill-color"), r2 = s3.paint.get("fill-opacity");
if (0 === r2.constantOr(1)) return;
const n2 = e3.colorModeForRenderPass(), l2 = s3.paint.get("fill-pattern"), h2 = e3.opaquePassEnabledForLayer() && !l2.constantOr(1) && 1 === o2.constantOr(t.aT.transparent).a && 1 === r2.constantOr(0) ? "opaque" : "translucent";
if (e3.renderPass === h2) {
const t2 = e3.depthModeForSublayer(1, "opaque" === e3.renderPass ? Pi.ReadWrite : Pi.ReadOnly);
Zi(e3, i4, s3, a3, t2, n2, false);
}
if ("translucent" === e3.renderPass && s3.paint.get("fill-antialias")) {
const t2 = e3.depthModeForSublayer(s3.getPaintProperty("fill-outline-color") ? 2 : 0, Pi.ReadOnly);
Zi(e3, i4, s3, a3, t2, n2, true);
}
})(e2, i3, s2, a2);
break;
case "fill-extrusion":
!(function(t2, e3, i4, s3) {
const a3 = i4.paint.get("fill-extrusion-opacity");
if (0 !== a3 && "translucent" === t2.renderPass) {
const o2 = new Pi(t2.context.gl.LEQUAL, Pi.ReadWrite, t2.depthRangeFor3D);
if (1 !== a3 || i4.paint.get("fill-extrusion-pattern").constantOr(1)) Gi(t2, e3, i4, s3, o2, Mi.disabled, Si.disabled), Gi(t2, e3, i4, s3, o2, t2.stencilModeFor3D(), t2.colorModeForRenderPass());
else {
const a4 = t2.colorModeForRenderPass();
Gi(t2, e3, i4, s3, o2, Mi.disabled, a4);
}
}
})(e2, i3, s2, a2);
break;
case "hillshade":
!(function(t2, e3, i4, s3) {
if ("offscreen" !== t2.renderPass && "translucent" !== t2.renderPass) return;
const a3 = t2.context, o2 = t2.depthModeForSublayer(0, Pi.ReadOnly), r2 = t2.colorModeForRenderPass(), [n2, l2] = "translucent" === t2.renderPass ? t2.stencilConfigForOverlap(s3) : [{}, s3];
for (const s4 of l2) {
const a4 = e3.getTile(s4);
void 0 !== a4.needsHillshadePrepare && a4.needsHillshadePrepare && "offscreen" === t2.renderPass ? Vi(t2, a4, i4, o2, Mi.disabled, r2) : "translucent" === t2.renderPass && ji(t2, s4, a4, i4, o2, n2[s4.overscaledZ], r2);
}
a3.viewport.set([0, 0, t2.width, t2.height]);
})(e2, i3, s2, a2);
break;
case "raster":
!(function(t2, e3, i4, s3) {
if ("translucent" !== t2.renderPass) return;
if (0 === i4.paint.get("raster-opacity")) return;
if (!s3.length) return;
const a3 = t2.context, o2 = a3.gl, r2 = e3.getSource(), n2 = t2.useProgram("raster"), l2 = t2.colorModeForRenderPass(), [h2, c2] = r2 instanceof N ? [{}, s3] : t2.stencilConfigForOverlap(s3), u2 = c2[c2.length - 1].overscaledZ, d2 = !t2.options.moving;
for (const s4 of c2) {
const c3 = t2.depthModeForSublayer(s4.overscaledZ - u2, 1 === i4.paint.get("raster-opacity") ? Pi.ReadWrite : Pi.ReadOnly, o2.LESS), _2 = e3.getTile(s4);
_2.registerFadeDuration(i4.paint.get("raster-fade-duration"));
const p2 = e3.findLoadedParent(s4, 0), m2 = qi(_2, p2, e3, i4, t2.transform, t2.style.map.terrain);
let f2, g2;
const v2 = "nearest" === i4.paint.get("raster-resampling") ? o2.NEAREST : o2.LINEAR;
a3.activeTexture.set(o2.TEXTURE0), _2.texture.bind(v2, o2.CLAMP_TO_EDGE, o2.LINEAR_MIPMAP_NEAREST), a3.activeTexture.set(o2.TEXTURE1), p2 ? (p2.texture.bind(v2, o2.CLAMP_TO_EDGE, o2.LINEAR_MIPMAP_NEAREST), f2 = Math.pow(2, p2.tileID.overscaledZ - _2.tileID.overscaledZ), g2 = [_2.tileID.canonical.x * f2 % 1, _2.tileID.canonical.y * f2 % 1]) : _2.texture.bind(v2, o2.CLAMP_TO_EDGE, o2.LINEAR_MIPMAP_NEAREST);
const x2 = t2.style.map.terrain && t2.style.map.terrain.getTerrainData(s4), y2 = x2 ? s4 : null, b2 = y2 ? y2.posMatrix : t2.transform.calculatePosMatrix(s4.toUnwrapped(), d2), w2 = Me(b2, g2 || [0, 0], f2 || 1, m2, i4);
r2 instanceof N ? n2.draw(a3, o2.TRIANGLES, c3, Mi.disabled, l2, zi.disabled, w2, x2, i4.id, r2.boundsBuffer, t2.quadTriangleIndexBuffer, r2.boundsSegments) : n2.draw(a3, o2.TRIANGLES, c3, h2[s4.overscaledZ], l2, zi.disabled, w2, x2, i4.id, t2.rasterBoundsBuffer, t2.quadTriangleIndexBuffer, t2.rasterBoundsSegments);
}
})(e2, i3, s2, a2);
break;
case "background":
!(function(t2, e3, i4, s3) {
const a3 = i4.paint.get("background-color"), o2 = i4.paint.get("background-opacity");
if (0 === o2) return;
const r2 = t2.context, n2 = r2.gl, l2 = t2.transform, h2 = l2.tileSize, c2 = i4.paint.get("background-pattern");
if (t2.isPatternMissing(c2)) return;
const u2 = !c2 && 1 === a3.a && 1 === o2 && t2.opaquePassEnabledForLayer() ? "opaque" : "translucent";
if (t2.renderPass !== u2) return;
const d2 = Mi.disabled, _2 = t2.depthModeForSublayer(0, "opaque" === u2 ? Pi.ReadWrite : Pi.ReadOnly), p2 = t2.colorModeForRenderPass(), m2 = t2.useProgram(c2 ? "backgroundPattern" : "background"), f2 = s3 || l2.coveringTiles({ tileSize: h2, terrain: t2.style.map.terrain });
c2 && (r2.activeTexture.set(n2.TEXTURE0), t2.imageManager.bind(t2.context));
const g2 = i4.getCrossfadeParameters();
for (const e4 of f2) {
const l3 = s3 ? e4.posMatrix : t2.transform.calculatePosMatrix(e4.toUnwrapped()), u3 = c2 ? Fe(l3, o2, t2, c2, { tileID: e4, tileSize: h2 }, g2) : ke(l3, o2, a3), f3 = t2.style.map.terrain && t2.style.map.terrain.getTerrainData(e4);
m2.draw(r2, n2.TRIANGLES, _2, d2, p2, zi.disabled, u3, f3, i4.id, t2.tileExtentBuffer, t2.quadTriangleIndexBuffer, t2.tileExtentSegments);
}
})(e2, 0, s2, a2);
break;
case "custom":
!(function(t2, e3, i4) {
const s3 = t2.context, a3 = i4.implementation;
if ("offscreen" === t2.renderPass) {
const e4 = a3.prerender;
e4 && (t2.setCustomLayerDefaults(), s3.setColorMode(t2.colorModeForRenderPass()), e4.call(a3, s3.gl, t2.transform.customLayerMatrix()), s3.setDirty(), t2.setBaseState());
} else if ("translucent" === t2.renderPass) {
t2.setCustomLayerDefaults(), s3.setColorMode(t2.colorModeForRenderPass()), s3.setStencilMode(Mi.disabled);
const e4 = "3d" === a3.renderingMode ? new Pi(t2.context.gl.LEQUAL, Pi.ReadWrite, t2.depthRangeFor3D) : t2.depthModeForSublayer(0, Pi.ReadOnly);
s3.setDepthMode(e4), a3.render(s3.gl, t2.transform.customLayerMatrix()), s3.setDirty(), t2.setBaseState(), s3.bindFramebuffer.set(null);
}
})(e2, 0, s2);
}
}
translatePosMatrix(e2, i3, s2, a2, o2) {
if (!s2[0] && !s2[1]) return e2;
const r2 = o2 ? "map" === a2 ? this.transform.angle : 0 : "viewport" === a2 ? -this.transform.angle : 0;
if (r2) {
const t2 = Math.sin(r2), e3 = Math.cos(r2);
s2 = [s2[0] * e3 - s2[1] * t2, s2[0] * t2 + s2[1] * e3];
}
const n2 = [o2 ? s2[0] : St(i3, s2[0], this.transform.zoom), o2 ? s2[1] : St(i3, s2[1], this.transform.zoom), 0], l2 = new Float32Array(16);
return t.$(l2, e2, n2), l2;
}
saveTileTexture(t2) {
const e2 = this._tileTextures[t2.size[0]];
e2 ? e2.push(t2) : this._tileTextures[t2.size[0]] = [t2];
}
getTileTexture(t2) {
const e2 = this._tileTextures[t2];
return e2 && e2.length > 0 ? e2.pop() : null;
}
isPatternMissing(t2) {
if (!t2) return false;
if (!t2.from || !t2.to) return true;
const e2 = this.imageManager.getPattern(t2.from.toString()), i3 = this.imageManager.getPattern(t2.to.toString());
return !e2 || !i3;
}
useProgram(t2, e2) {
this.cache = this.cache || {};
const i3 = t2 + (e2 ? e2.cacheKey : "") + (this._showOverdrawInspector ? "/overdraw" : "") + (this.style.map.terrain ? "/terrain" : "");
return this.cache[i3] || (this.cache[i3] = new ce(this.context, re[t2], e2, Be[t2], this._showOverdrawInspector, this.style.map.terrain)), this.cache[i3];
}
setCustomLayerDefaults() {
this.context.unbindVAO(), this.context.cullFace.setDefault(), this.context.activeTexture.setDefault(), this.context.pixelStoreUnpack.setDefault(), this.context.pixelStoreUnpackPremultiplyAlpha.setDefault(), this.context.pixelStoreUnpackFlipY.setDefault();
}
setBaseState() {
const t2 = this.context.gl;
this.context.cullFace.set(false), this.context.viewport.set([0, 0, this.width, this.height]), this.context.blendEquation.set(t2.FUNC_ADD);
}
initDebugOverlayCanvas() {
null == this.debugOverlayCanvas && (this.debugOverlayCanvas = document.createElement("canvas"), this.debugOverlayCanvas.width = 512, this.debugOverlayCanvas.height = 512, this.debugOverlayTexture = new x(this.context, this.debugOverlayCanvas, this.context.gl.RGBA));
}
destroy() {
this.debugOverlayTexture && this.debugOverlayTexture.destroy();
}
overLimit() {
const { drawingBufferWidth: t2, drawingBufferHeight: e2 } = this.context.gl;
return this.width !== t2 || this.height !== e2;
}
}
class ss {
constructor(t2, e2) {
this.points = t2, this.planes = e2;
}
static fromInvProjectionMatrix(e2, i3, s2) {
const a2 = Math.pow(2, s2), o2 = [[-1, 1, -1, 1], [1, 1, -1, 1], [1, -1, -1, 1], [-1, -1, -1, 1], [-1, 1, 1, 1], [1, 1, 1, 1], [1, -1, 1, 1], [-1, -1, 1, 1]].map(((s3) => {
const o3 = 1 / (s3 = t.ag([], s3, e2))[3] / i3 * a2;
return t.b3(s3, s3, [o3, o3, 1 / s3[3], o3]);
})), r2 = [[0, 1, 2], [6, 5, 4], [0, 3, 7], [2, 1, 5], [3, 2, 6], [0, 4, 5]].map(((t2) => {
const e3 = (function(t3, e4) {
var i5 = e4[0], s4 = e4[1], a4 = e4[2], o3 = i5 * i5 + s4 * s4 + a4 * a4;
return o3 > 0 && (o3 = 1 / Math.sqrt(o3)), t3[0] = e4[0] * o3, t3[1] = e4[1] * o3, t3[2] = e4[2] * o3, t3;
})([], (function(t3, e4, i5) {
var s4 = e4[0], a4 = e4[1], o3 = e4[2], r3 = i5[0], n2 = i5[1], l2 = i5[2];
return t3[0] = a4 * l2 - o3 * n2, t3[1] = o3 * r3 - s4 * l2, t3[2] = s4 * n2 - a4 * r3, t3;
})([], m([], o2[t2[0]], o2[t2[1]]), m([], o2[t2[2]], o2[t2[1]]))), i4 = -((s3 = e3)[0] * (a3 = o2[t2[1]])[0] + s3[1] * a3[1] + s3[2] * a3[2]);
var s3, a3;
return e3.concat(i4);
}));
return new ss(o2, r2);
}
}
class as {
constructor(t2, e2) {
this.min = t2, this.max = e2, this.center = (function(t3, e3, i3) {
return t3[0] = 0.5 * e3[0], t3[1] = 0.5 * e3[1], t3[2] = 0.5 * e3[2], t3;
})([], (function(t3, e3, i3) {
return t3[0] = e3[0] + i3[0], t3[1] = e3[1] + i3[1], t3[2] = e3[2] + i3[2], t3;
})([], this.min, this.max));
}
quadrant(t2) {
const e2 = [t2 % 2 == 0, t2 < 2], i3 = _(this.min), s2 = _(this.max);
for (let t3 = 0; t3 < e2.length; t3++) i3[t3] = e2[t3] ? this.min[t3] : this.center[t3], s2[t3] = e2[t3] ? this.center[t3] : this.max[t3];
return s2[2] = this.max[2], new as(i3, s2);
}
distanceX(t2) {
return Math.max(Math.min(this.max[0], t2[0]), this.min[0]) - t2[0];
}
distanceY(t2) {
return Math.max(Math.min(this.max[1], t2[1]), this.min[1]) - t2[1];
}
intersects(e2) {
const i3 = [[this.min[0], this.min[1], this.min[2], 1], [this.max[0], this.min[1], this.min[2], 1], [this.max[0], this.max[1], this.min[2], 1], [this.min[0], this.max[1], this.min[2], 1], [this.min[0], this.min[1], this.max[2], 1], [this.max[0], this.min[1], this.max[2], 1], [this.max[0], this.max[1], this.max[2], 1], [this.min[0], this.max[1], this.max[2], 1]];
let s2 = true;
for (let a2 = 0; a2 < e2.planes.length; a2++) {
const o2 = e2.planes[a2];
let r2 = 0;
for (let e3 = 0; e3 < i3.length; e3++) t.b4(o2, i3[e3]) >= 0 && r2++;
if (0 === r2) return 0;
r2 !== i3.length && (s2 = false);
}
if (s2) return 2;
for (let t2 = 0; t2 < 3; t2++) {
let i4 = Number.MAX_VALUE, s3 = -Number.MAX_VALUE;
for (let a2 = 0; a2 < e2.points.length; a2++) {
const o2 = e2.points[a2][t2] - this.min[t2];
i4 = Math.min(i4, o2), s3 = Math.max(s3, o2);
}
if (s3 < 0 || i4 > this.max[t2] - this.min[t2]) return 0;
}
return 1;
}
}
class os {
constructor(t2 = 0, e2 = 0, i3 = 0, s2 = 0) {
if (isNaN(t2) || t2 < 0 || isNaN(e2) || e2 < 0 || isNaN(i3) || i3 < 0 || isNaN(s2) || s2 < 0) throw new Error("Invalid value for edge-insets, top, bottom, left and right must all be numbers");
this.top = t2, this.bottom = e2, this.left = i3, this.right = s2;
}
interpolate(e2, i3, s2) {
return null != i3.top && null != e2.top && (this.top = t.B.number(e2.top, i3.top, s2)), null != i3.bottom && null != e2.bottom && (this.bottom = t.B.number(e2.bottom, i3.bottom, s2)), null != i3.left && null != e2.left && (this.left = t.B.number(e2.left, i3.left, s2)), null != i3.right && null != e2.right && (this.right = t.B.number(e2.right, i3.right, s2)), this;
}
getCenter(e2, i3) {
const s2 = t.ad((this.left + e2 - this.right) / 2, 0, e2), a2 = t.ad((this.top + i3 - this.bottom) / 2, 0, i3);
return new t.P(s2, a2);
}
equals(t2) {
return this.top === t2.top && this.bottom === t2.bottom && this.left === t2.left && this.right === t2.right;
}
clone() {
return new os(this.top, this.bottom, this.left, this.right);
}
toJSON() {
return { top: this.top, bottom: this.bottom, left: this.left, right: this.right };
}
}
class rs {
constructor(e2, i3, s2, a2, o2) {
this.tileSize = 512, this.maxValidLatitude = 85.051129, this._renderWorldCopies = void 0 === o2 || !!o2, this._minZoom = e2 || 0, this._maxZoom = i3 || 22, this._minPitch = null == s2 ? 0 : s2, this._maxPitch = null == a2 ? 60 : a2, this.setMaxBounds(), this.width = 0, this.height = 0, this._center = new t.L(0, 0), this._elevation = 0, this.zoom = 0, this.angle = 0, this._fov = 0.6435011087932844, this._pitch = 0, this._unmodified = true, this._edgeInsets = new os(), this._posMatrixCache = {}, this._alignedPosMatrixCache = {}, this._minEleveationForCurrentTile = 0;
}
clone() {
const t2 = new rs(this._minZoom, this._maxZoom, this._minPitch, this.maxPitch, this._renderWorldCopies);
return t2.apply(this), t2;
}
apply(t2) {
this.tileSize = t2.tileSize, this.latRange = t2.latRange, this.width = t2.width, this.height = t2.height, this._center = t2._center, this._elevation = t2._elevation, this._minEleveationForCurrentTile = t2._minEleveationForCurrentTile, this.zoom = t2.zoom, this.angle = t2.angle, this._fov = t2._fov, this._pitch = t2._pitch, this._unmodified = t2._unmodified, this._edgeInsets = t2._edgeInsets.clone(), this._calcMatrices();
}
get minZoom() {
return this._minZoom;
}
set minZoom(t2) {
this._minZoom !== t2 && (this._minZoom = t2, this.zoom = Math.max(this.zoom, t2));
}
get maxZoom() {
return this._maxZoom;
}
set maxZoom(t2) {
this._maxZoom !== t2 && (this._maxZoom = t2, this.zoom = Math.min(this.zoom, t2));
}
get minPitch() {
return this._minPitch;
}
set minPitch(t2) {
this._minPitch !== t2 && (this._minPitch = t2, this.pitch = Math.max(this.pitch, t2));
}
get maxPitch() {
return this._maxPitch;
}
set maxPitch(t2) {
this._maxPitch !== t2 && (this._maxPitch = t2, this.pitch = Math.min(this.pitch, t2));
}
get renderWorldCopies() {
return this._renderWorldCopies;
}
set renderWorldCopies(t2) {
void 0 === t2 ? t2 = true : null === t2 && (t2 = false), this._renderWorldCopies = t2;
}
get worldSize() {
return this.tileSize * this.scale;
}
get centerOffset() {
return this.centerPoint._sub(this.size._div(2));
}
get size() {
return new t.P(this.width, this.height);
}
get bearing() {
return -this.angle / Math.PI * 180;
}
set bearing(e2) {
const i3 = -t.b5(e2, -180, 180) * Math.PI / 180;
this.angle !== i3 && (this._unmodified = false, this.angle = i3, this._calcMatrices(), this.rotationMatrix = (function() {
var e3 = new t.A(4);
return t.A != Float32Array && (e3[1] = 0, e3[2] = 0), e3[0] = 1, e3[3] = 1, e3;
})(), (function(t2, e3, i4) {
var s2 = e3[0], a2 = e3[1], o2 = e3[2], r2 = e3[3], n2 = Math.sin(i4), l2 = Math.cos(i4);
t2[0] = s2 * l2 + o2 * n2, t2[1] = a2 * l2 + r2 * n2, t2[2] = s2 * -n2 + o2 * l2, t2[3] = a2 * -n2 + r2 * l2;
})(this.rotationMatrix, this.rotationMatrix, this.angle));
}
get pitch() {
return this._pitch / Math.PI * 180;
}
set pitch(e2) {
const i3 = t.ad(e2, this.minPitch, this.maxPitch) / 180 * Math.PI;
this._pitch !== i3 && (this._unmodified = false, this._pitch = i3, this._calcMatrices());
}
get fov() {
return this._fov / Math.PI * 180;
}
set fov(t2) {
t2 = Math.max(0.01, Math.min(60, t2)), this._fov !== t2 && (this._unmodified = false, this._fov = t2 / 180 * Math.PI, this._calcMatrices());
}
get zoom() {
return this._zoom;
}
set zoom(t2) {
const e2 = Math.min(Math.max(t2, this.minZoom), this.maxZoom);
this._zoom !== e2 && (this._unmodified = false, this._zoom = e2, this.tileZoom = Math.max(0, Math.floor(e2)), this.scale = this.zoomScale(e2), this._constrain(), this._calcMatrices());
}
get center() {
return this._center;
}
set center(t2) {
t2.lat === this._center.lat && t2.lng === this._center.lng || (this._unmodified = false, this._center = t2, this._constrain(), this._calcMatrices());
}
get elevation() {
return this._elevation;
}
set elevation(t2) {
t2 !== this._elevation && (this._elevation = t2, this._constrain(), this._calcMatrices());
}
get padding() {
return this._edgeInsets.toJSON();
}
set padding(t2) {
this._edgeInsets.equals(t2) || (this._unmodified = false, this._edgeInsets.interpolate(this._edgeInsets, t2, 1), this._calcMatrices());
}
get centerPoint() {
return this._edgeInsets.getCenter(this.width, this.height);
}
isPaddingEqual(t2) {
return this._edgeInsets.equals(t2);
}
interpolatePadding(t2, e2, i3) {
this._unmodified = false, this._edgeInsets.interpolate(t2, e2, i3), this._constrain(), this._calcMatrices();
}
coveringZoomLevel(t2) {
const e2 = (t2.roundZoom ? Math.round : Math.floor)(this.zoom + this.scaleZoom(this.tileSize / t2.tileSize));
return Math.max(0, e2);
}
getVisibleUnwrappedCoordinates(e2) {
const i3 = [new t.b6(0, e2)];
if (this._renderWorldCopies) {
const s2 = this.pointCoordinate(new t.P(0, 0)), a2 = this.pointCoordinate(new t.P(this.width, 0)), o2 = this.pointCoordinate(new t.P(this.width, this.height)), r2 = this.pointCoordinate(new t.P(0, this.height)), n2 = Math.floor(Math.min(s2.x, a2.x, o2.x, r2.x)), l2 = Math.floor(Math.max(s2.x, a2.x, o2.x, r2.x)), h2 = 1;
for (let s3 = n2 - h2; s3 <= l2 + h2; s3++) 0 !== s3 && i3.push(new t.b6(s3, e2));
}
return i3;
}
coveringTiles(e2) {
var i3, s2;
let a2 = this.coveringZoomLevel(e2);
const o2 = a2;
if (void 0 !== e2.minzoom && a2 < e2.minzoom) return [];
void 0 !== e2.maxzoom && a2 > e2.maxzoom && (a2 = e2.maxzoom);
const r2 = this.pointCoordinate(this.getCameraPoint()), n2 = t.U.fromLngLat(this.center), l2 = Math.pow(2, a2), h2 = [l2 * r2.x, l2 * r2.y, 0], c2 = [l2 * n2.x, l2 * n2.y, 0], u2 = ss.fromInvProjectionMatrix(this.invProjMatrix, this.worldSize, a2);
let d2 = e2.minzoom || 0;
!e2.terrain && this.pitch <= 60 && this._edgeInsets.top < 0.1 && (d2 = a2);
const _2 = e2.terrain ? 2 / Math.min(this.tileSize, e2.tileSize) * this.tileSize : 3, p2 = (t2) => ({ aabb: new as([t2 * l2, 0, 0], [(t2 + 1) * l2, l2, 0]), zoom: 0, x: 0, y: 0, wrap: t2, fullyVisible: false }), m2 = [], g2 = [], v2 = a2, x2 = e2.reparseOverscaled ? o2 : a2;
if (this._renderWorldCopies) for (let t2 = 1; t2 <= 3; t2++) m2.push(p2(-t2)), m2.push(p2(t2));
for (m2.push(p2(0)); m2.length > 0; ) {
const a3 = m2.pop(), o3 = a3.x, r3 = a3.y;
let n3 = a3.fullyVisible;
if (!n3) {
const t2 = a3.aabb.intersects(u2);
if (0 === t2) continue;
n3 = 2 === t2;
}
const l3 = e2.terrain ? h2 : c2, p3 = a3.aabb.distanceX(l3), y2 = a3.aabb.distanceY(l3), b2 = Math.max(Math.abs(p3), Math.abs(y2));
if (a3.zoom === v2 || b2 > _2 + (1 << v2 - a3.zoom) - 2 && a3.zoom >= d2) {
const e3 = v2 - a3.zoom, i4 = h2[0] - 0.5 - (o3 << e3), s3 = h2[1] - 0.5 - (r3 << e3);
g2.push({ tileID: new t.O(a3.zoom === v2 ? x2 : a3.zoom, a3.wrap, a3.zoom, o3, r3), distanceSq: f([c2[0] - 0.5 - o3, c2[1] - 0.5 - r3]), tileDistanceToCamera: Math.sqrt(i4 * i4 + s3 * s3) });
} else for (let l4 = 0; l4 < 4; l4++) {
const h3 = (o3 << 1) + l4 % 2, c3 = (r3 << 1) + (l4 >> 1), u3 = a3.zoom + 1;
let d3 = a3.aabb.quadrant(l4);
if (e2.terrain) {
const o4 = new t.O(u3, a3.wrap, u3, h3, c3), r4 = e2.terrain.getMinMaxElevation(o4), n4 = null !== (i3 = r4.minElevation) && void 0 !== i3 ? i3 : this.elevation, l5 = null !== (s2 = r4.maxElevation) && void 0 !== s2 ? s2 : this.elevation;
d3 = new as([d3.min[0], d3.min[1], n4], [d3.max[0], d3.max[1], l5]);
}
m2.push({ aabb: d3, zoom: u3, x: h3, y: c3, wrap: a3.wrap, fullyVisible: n3 });
}
}
return g2.sort(((t2, e3) => t2.distanceSq - e3.distanceSq)).map(((t2) => t2.tileID));
}
resize(t2, e2) {
this.width = t2, this.height = e2, this.pixelsToGLUnits = [2 / t2, -2 / e2], this._constrain(), this._calcMatrices();
}
get unmodified() {
return this._unmodified;
}
zoomScale(t2) {
return Math.pow(2, t2);
}
scaleZoom(t2) {
return Math.log(t2) / Math.LN2;
}
project(e2) {
const i3 = t.ad(e2.lat, -this.maxValidLatitude, this.maxValidLatitude);
return new t.P(t.G(e2.lng) * this.worldSize, t.H(i3) * this.worldSize);
}
unproject(e2) {
return new t.U(e2.x / this.worldSize, e2.y / this.worldSize).toLngLat();
}
get point() {
return this.project(this.center);
}
getCameraPosition() {
return { lngLat: this.pointLocation(this.getCameraPoint()), altitude: Math.cos(this._pitch) * this.cameraToCenterDistance / this._pixelPerMeter + this.elevation };
}
recalculateZoom(e2) {
const i3 = this.pointLocation(this.centerPoint, e2), s2 = e2.getElevationForLngLatZoom(i3, this.tileZoom);
if (!(this.elevation - s2)) return;
const a2 = this.getCameraPosition(), o2 = t.U.fromLngLat(a2.lngLat, a2.altitude), r2 = t.U.fromLngLat(i3, s2), n2 = o2.x - r2.x, l2 = o2.y - r2.y, h2 = o2.z - r2.z, c2 = Math.sqrt(n2 * n2 + l2 * l2 + h2 * h2), u2 = this.scaleZoom(this.cameraToCenterDistance / c2 / this.tileSize);
this._elevation = s2, this._center = i3, this.zoom = u2;
}
setLocationAtPoint(e2, i3) {
const s2 = this.pointCoordinate(i3), a2 = this.pointCoordinate(this.centerPoint), o2 = this.locationCoordinate(e2), r2 = new t.U(o2.x - (s2.x - a2.x), o2.y - (s2.y - a2.y));
this.center = this.coordinateLocation(r2), this._renderWorldCopies && (this.center = this.center.wrap());
}
locationPoint(t2, e2) {
return e2 ? this.coordinatePoint(this.locationCoordinate(t2), e2.getElevationForLngLatZoom(t2, this.tileZoom), this.pixelMatrix3D) : this.coordinatePoint(this.locationCoordinate(t2));
}
pointLocation(t2, e2) {
return this.coordinateLocation(this.pointCoordinate(t2, e2));
}
locationCoordinate(e2) {
return t.U.fromLngLat(e2);
}
coordinateLocation(t2) {
return t2 && t2.toLngLat();
}
pointCoordinate(e2, i3) {
if (i3) {
const t2 = i3.pointCoordinate(e2);
if (null != t2) return t2;
}
const s2 = [e2.x, e2.y, 0, 1], a2 = [e2.x, e2.y, 1, 1];
t.ag(s2, s2, this.pixelMatrixInverse), t.ag(a2, a2, this.pixelMatrixInverse);
const o2 = s2[3], r2 = a2[3], n2 = s2[1] / o2, l2 = a2[1] / r2, h2 = s2[2] / o2, c2 = a2[2] / r2, u2 = h2 === c2 ? 0 : (0 - h2) / (c2 - h2);
return new t.U(t.B.number(s2[0] / o2, a2[0] / r2, u2) / this.worldSize, t.B.number(n2, l2, u2) / this.worldSize);
}
coordinatePoint(e2, i3 = 0, s2 = this.pixelMatrix) {
const a2 = [e2.x * this.worldSize, e2.y * this.worldSize, i3, 1];
return t.ag(a2, a2, s2), new t.P(a2[0] / a2[3], a2[1] / a2[3]);
}
getBounds() {
const e2 = Math.max(0, this.height / 2 - this.getHorizon());
return new L().extend(this.pointLocation(new t.P(0, e2))).extend(this.pointLocation(new t.P(this.width, e2))).extend(this.pointLocation(new t.P(this.width, this.height))).extend(this.pointLocation(new t.P(0, this.height)));
}
getMaxBounds() {
return this.latRange && 2 === this.latRange.length && this.lngRange && 2 === this.lngRange.length ? new L([this.lngRange[0], this.latRange[0]], [this.lngRange[1], this.latRange[1]]) : null;
}
getHorizon() {
return Math.tan(Math.PI / 2 - this._pitch) * this.cameraToCenterDistance * 0.85;
}
setMaxBounds(t2) {
t2 ? (this.lngRange = [t2.getWest(), t2.getEast()], this.latRange = [t2.getSouth(), t2.getNorth()], this._constrain()) : (this.lngRange = null, this.latRange = [-this.maxValidLatitude, this.maxValidLatitude]);
}
calculatePosMatrix(e2, i3 = false) {
const s2 = e2.key, a2 = i3 ? this._alignedPosMatrixCache : this._posMatrixCache;
if (a2[s2]) return a2[s2];
const o2 = e2.canonical, r2 = this.worldSize / this.zoomScale(o2.z), n2 = o2.x + Math.pow(2, o2.z) * e2.wrap, l2 = t.ao(new Float64Array(16));
return t.$(l2, l2, [n2 * r2, o2.y * r2, 0]), t.a0(l2, l2, [r2 / t.N, r2 / t.N, 1]), t.a1(l2, i3 ? this.alignedProjMatrix : this.projMatrix, l2), a2[s2] = new Float32Array(l2), a2[s2];
}
customLayerMatrix() {
return this.mercatorMatrix.slice();
}
_constrain() {
if (!this.center || !this.width || !this.height || this._constraining) return;
this._constraining = true;
let e2, i3, s2, a2, o2 = -90, r2 = 90, n2 = -180, l2 = 180;
const h2 = this.size, c2 = this._unmodified;
if (this.latRange) {
const i4 = this.latRange;
o2 = t.H(i4[1]) * this.worldSize, r2 = t.H(i4[0]) * this.worldSize, e2 = r2 - o2 < h2.y ? h2.y / (r2 - o2) : 0;
}
if (this.lngRange) {
const e3 = this.lngRange;
n2 = t.b5(t.G(e3[0]) * this.worldSize, 0, this.worldSize), l2 = t.b5(t.G(e3[1]) * this.worldSize, 0, this.worldSize), l2 < n2 && (l2 += this.worldSize), i3 = l2 - n2 < h2.x ? h2.x / (l2 - n2) : 0;
}
const u2 = this.point, d2 = Math.max(i3 || 0, e2 || 0);
if (d2) return this.center = this.unproject(new t.P(i3 ? (l2 + n2) / 2 : u2.x, e2 ? (r2 + o2) / 2 : u2.y)), this.zoom += this.scaleZoom(d2), this._unmodified = c2, void (this._constraining = false);
if (this.latRange) {
const t2 = u2.y, e3 = h2.y / 2;
t2 - e3 < o2 && (a2 = o2 + e3), t2 + e3 > r2 && (a2 = r2 - e3);
}
if (this.lngRange) {
const e3 = (n2 + l2) / 2, i4 = t.b5(u2.x, e3 - this.worldSize / 2, e3 + this.worldSize / 2), a3 = h2.x / 2;
i4 - a3 < n2 && (s2 = n2 + a3), i4 + a3 > l2 && (s2 = l2 - a3);
}
void 0 === s2 && void 0 === a2 || (this.center = this.unproject(new t.P(void 0 !== s2 ? s2 : u2.x, void 0 !== a2 ? a2 : u2.y)).wrap()), this._unmodified = c2, this._constraining = false;
}
_calcMatrices() {
if (!this.height) return;
const e2 = this.centerOffset, i3 = this.point.x, s2 = this.point.y;
this.cameraToCenterDistance = 0.5 / Math.tan(this._fov / 2) * this.height, this._pixelPerMeter = t.b7(1, this.center.lat) * this.worldSize;
let a2 = t.ao(new Float64Array(16));
t.a0(a2, a2, [this.width / 2, -this.height / 2, 1]), t.$(a2, a2, [1, -1, 0]), this.labelPlaneMatrix = a2, a2 = t.ao(new Float64Array(16)), t.a0(a2, a2, [1, -1, 1]), t.$(a2, a2, [-1, -1, 0]), t.a0(a2, a2, [2 / this.width, 2 / this.height, 1]), this.glCoordMatrix = a2;
const o2 = this.cameraToCenterDistance + this._elevation * this._pixelPerMeter / Math.cos(this._pitch), r2 = Math.min(this.elevation, this._minEleveationForCurrentTile), n2 = o2 - r2 * this._pixelPerMeter / Math.cos(this._pitch), l2 = r2 < 0 ? n2 : o2, h2 = Math.PI / 2 + this._pitch, c2 = this._fov * (0.5 + e2.y / this.height), u2 = Math.sin(c2) * l2 / Math.sin(t.ad(Math.PI - h2 - c2, 0.01, Math.PI - 0.01)), d2 = this.getHorizon(), _2 = 2 * Math.atan(d2 / this.cameraToCenterDistance) * (0.5 + e2.y / (2 * d2)), p2 = Math.sin(_2) * l2 / Math.sin(t.ad(Math.PI - h2 - _2, 0.01, Math.PI - 0.01)), m2 = Math.min(u2, p2), f2 = 1.01 * (Math.cos(Math.PI / 2 - this._pitch) * m2 + l2), g2 = this.height / 50;
a2 = new Float64Array(16), t.b8(a2, this._fov, this.width / this.height, g2, f2), a2[8] = 2 * -e2.x / this.width, a2[9] = 2 * e2.y / this.height, t.a0(a2, a2, [1, -1, 1]), t.$(a2, a2, [0, 0, -this.cameraToCenterDistance]), t.b9(a2, a2, this._pitch), t.ae(a2, a2, this.angle), t.$(a2, a2, [-i3, -s2, 0]), this.mercatorMatrix = t.a0([], a2, [this.worldSize, this.worldSize, this.worldSize]), t.a0(a2, a2, [1, 1, this._pixelPerMeter]), this.pixelMatrix = t.a1(new Float64Array(16), this.labelPlaneMatrix, a2), t.$(a2, a2, [0, 0, -this.elevation]), this.projMatrix = a2, this.invProjMatrix = t.as([], a2), this.pixelMatrix3D = t.a1(new Float64Array(16), this.labelPlaneMatrix, a2);
const v2 = this.width % 2 / 2, x2 = this.height % 2 / 2, y2 = Math.cos(this.angle), b2 = Math.sin(this.angle), w2 = i3 - Math.round(i3) + y2 * v2 + b2 * x2, T2 = s2 - Math.round(s2) + y2 * x2 + b2 * v2, I2 = new Float64Array(a2);
if (t.$(I2, I2, [w2 > 0.5 ? w2 - 1 : w2, T2 > 0.5 ? T2 - 1 : T2, 0]), this.alignedProjMatrix = I2, a2 = t.as(new Float64Array(16), this.pixelMatrix), !a2) throw new Error("failed to invert matrix");
this.pixelMatrixInverse = a2, this._posMatrixCache = {}, this._alignedPosMatrixCache = {};
}
maxPitchScaleFactor() {
if (!this.pixelMatrixInverse) return 1;
const e2 = this.pointCoordinate(new t.P(0, 0)), i3 = [e2.x * this.worldSize, e2.y * this.worldSize, 0, 1];
return t.ag(i3, i3, this.pixelMatrix)[3] / this.cameraToCenterDistance;
}
getCameraPoint() {
const e2 = Math.tan(this._pitch) * (this.cameraToCenterDistance || 1);
return this.centerPoint.add(new t.P(0, e2));
}
getCameraQueryGeometry(e2) {
const i3 = this.getCameraPoint();
if (1 === e2.length) return [e2[0], i3];
{
let s2 = i3.x, a2 = i3.y, o2 = i3.x, r2 = i3.y;
for (const t2 of e2) s2 = Math.min(s2, t2.x), a2 = Math.min(a2, t2.y), o2 = Math.max(o2, t2.x), r2 = Math.max(r2, t2.y);
return [new t.P(s2, a2), new t.P(o2, a2), new t.P(o2, r2), new t.P(s2, r2), new t.P(s2, a2)];
}
}
}
function ns(t2, e2) {
let i3, s2 = false, a2 = null, o2 = null;
const r2 = () => {
a2 = null, s2 && (t2.apply(o2, i3), a2 = setTimeout(r2, e2), s2 = false);
};
return (...t3) => (s2 = true, o2 = this, i3 = t3, a2 || r2(), a2);
}
class ls {
constructor(t2) {
this._getCurrentHash = () => {
const t3 = window.location.hash.replace("#", "");
if (this._hashName) {
let e2;
return t3.split("&").map(((t4) => t4.split("="))).forEach(((t4) => {
t4[0] === this._hashName && (e2 = t4);
})), (e2 && e2[1] || "").split("/");
}
return t3.split("/");
}, this._onHashChange = () => {
const t3 = this._getCurrentHash();
if (t3.length >= 3 && !t3.some(((t4) => isNaN(t4)))) {
const e2 = this._map.dragRotate.isEnabled() && this._map.touchZoomRotate.isEnabled() ? +(t3[3] || 0) : this._map.getBearing();
return this._map.jumpTo({ center: [+t3[2], +t3[1]], zoom: +t3[0], bearing: e2, pitch: +(t3[4] || 0) }), true;
}
return false;
}, this._updateHashUnthrottled = () => {
const t3 = window.location.href.replace(/(#.+)?$/, this.getHashString());
try {
window.history.replaceState(window.history.state, null, t3);
} catch (t4) {
}
}, this._updateHash = ns(this._updateHashUnthrottled, 300), this._hashName = t2 && encodeURIComponent(t2);
}
addTo(t2) {
return this._map = t2, addEventListener("hashchange", this._onHashChange, false), this._map.on("moveend", this._updateHash), this;
}
remove() {
return removeEventListener("hashchange", this._onHashChange, false), this._map.off("moveend", this._updateHash), clearTimeout(this._updateHash()), delete this._map, this;
}
getHashString(t2) {
const e2 = this._map.getCenter(), i3 = Math.round(100 * this._map.getZoom()) / 100, s2 = Math.ceil((i3 * Math.LN2 + Math.log(512 / 360 / 0.5)) / Math.LN10), a2 = Math.pow(10, s2), o2 = Math.round(e2.lng * a2) / a2, r2 = Math.round(e2.lat * a2) / a2, n2 = this._map.getBearing(), l2 = this._map.getPitch();
let h2 = "";
if (h2 += t2 ? `/${o2}/${r2}/${i3}` : `${i3}/${r2}/${o2}`, (n2 || l2) && (h2 += "/" + Math.round(10 * n2) / 10), l2 && (h2 += `/${Math.round(l2)}`), this._hashName) {
const t3 = this._hashName;
let e3 = false;
const i4 = window.location.hash.slice(1).split("&").map(((i5) => {
const s3 = i5.split("=")[0];
return s3 === t3 ? (e3 = true, `${s3}=${h2}`) : i5;
})).filter(((t4) => t4));
return e3 || i4.push(`${t3}=${h2}`), `#${i4.join("&")}`;
}
return `#${h2}`;
}
}
const hs = { linearity: 0.3, easing: t.ba(0, 0, 0.3, 1) }, cs = t.e({ deceleration: 2500, maxSpeed: 1400 }, hs), us = t.e({ deceleration: 20, maxSpeed: 1400 }, hs), ds = t.e({ deceleration: 1e3, maxSpeed: 360 }, hs), _s = t.e({ deceleration: 1e3, maxSpeed: 90 }, hs);
class ps {
constructor(t2) {
this._map = t2, this.clear();
}
clear() {
this._inertiaBuffer = [];
}
record(e2) {
this._drainInertiaBuffer(), this._inertiaBuffer.push({ time: t.h.now(), settings: e2 });
}
_drainInertiaBuffer() {
const e2 = this._inertiaBuffer, i3 = t.h.now();
for (; e2.length > 0 && i3 - e2[0].time > 160; ) e2.shift();
}
_onMoveEnd(e2) {
if (this._drainInertiaBuffer(), this._inertiaBuffer.length < 2) return;
const i3 = { zoom: 0, bearing: 0, pitch: 0, pan: new t.P(0, 0), pinchAround: void 0, around: void 0 };
for (const { settings: t2 } of this._inertiaBuffer) i3.zoom += t2.zoomDelta || 0, i3.bearing += t2.bearingDelta || 0, i3.pitch += t2.pitchDelta || 0, t2.panDelta && i3.pan._add(t2.panDelta), t2.around && (i3.around = t2.around), t2.pinchAround && (i3.pinchAround = t2.pinchAround);
const s2 = this._inertiaBuffer[this._inertiaBuffer.length - 1].time - this._inertiaBuffer[0].time, a2 = {};
if (i3.pan.mag()) {
const o2 = fs(i3.pan.mag(), s2, t.e({}, cs, e2 || {}));
a2.offset = i3.pan.mult(o2.amount / i3.pan.mag()), a2.center = this._map.transform.center, ms(a2, o2);
}
if (i3.zoom) {
const t2 = fs(i3.zoom, s2, us);
a2.zoom = this._map.transform.zoom + t2.amount, ms(a2, t2);
}
if (i3.bearing) {
const e3 = fs(i3.bearing, s2, ds);
a2.bearing = this._map.transform.bearing + t.ad(e3.amount, -179, 179), ms(a2, e3);
}
if (i3.pitch) {
const t2 = fs(i3.pitch, s2, _s);
a2.pitch = this._map.transform.pitch + t2.amount, ms(a2, t2);
}
if (a2.zoom || a2.bearing) {
const t2 = void 0 === i3.pinchAround ? i3.around : i3.pinchAround;
a2.around = t2 ? this._map.unproject(t2) : this._map.getCenter();
}
return this.clear(), t.e(a2, { noMoveStart: true });
}
}
function ms(t2, e2) {
(!t2.duration || t2.duration < e2.duration) && (t2.duration = e2.duration, t2.easing = e2.easing);
}
function fs(e2, i3, s2) {
const { maxSpeed: a2, linearity: o2, deceleration: r2 } = s2, n2 = t.ad(e2 * o2 / (i3 / 1e3), -a2, a2), l2 = Math.abs(n2) / (r2 * o2);
return { easing: s2.easing, duration: 1e3 * l2, amount: n2 * (l2 / 2) };
}
class gs extends t.k {
preventDefault() {
this._defaultPrevented = true;
}
get defaultPrevented() {
return this._defaultPrevented;
}
constructor(e2, s2, a2, o2 = {}) {
const r2 = i2.mousePos(s2.getCanvasContainer(), a2), n2 = s2.unproject(r2);
super(e2, t.e({ point: r2, lngLat: n2, originalEvent: a2 }, o2)), this._defaultPrevented = false, this.target = s2;
}
}
class vs extends t.k {
preventDefault() {
this._defaultPrevented = true;
}
get defaultPrevented() {
return this._defaultPrevented;
}
constructor(e2, s2, a2) {
const o2 = "touchend" === e2 ? a2.changedTouches : a2.touches, r2 = i2.touchPos(s2.getCanvasContainer(), o2), n2 = r2.map(((t2) => s2.unproject(t2))), l2 = r2.reduce(((t2, e3, i3, s3) => t2.add(e3.div(s3.length))), new t.P(0, 0));
super(e2, { points: r2, point: l2, lngLats: n2, lngLat: s2.unproject(l2), originalEvent: a2 }), this._defaultPrevented = false;
}
}
class xs extends t.k {
preventDefault() {
this._defaultPrevented = true;
}
get defaultPrevented() {
return this._defaultPrevented;
}
constructor(t2, e2, i3) {
super(t2, { originalEvent: i3 }), this._defaultPrevented = false;
}
}
class ys {
constructor(t2, e2) {
this._map = t2, this._clickTolerance = e2.clickTolerance;
}
reset() {
delete this._mousedownPos;
}
wheel(t2) {
return this._firePreventable(new xs(t2.type, this._map, t2));
}
mousedown(t2, e2) {
return this._mousedownPos = e2, this._firePreventable(new gs(t2.type, this._map, t2));
}
mouseup(t2) {
this._map.fire(new gs(t2.type, this._map, t2));
}
click(t2, e2) {
this._mousedownPos && this._mousedownPos.dist(e2) >= this._clickTolerance || this._map.fire(new gs(t2.type, this._map, t2));
}
dblclick(t2) {
return this._firePreventable(new gs(t2.type, this._map, t2));
}
mouseover(t2) {
this._map.fire(new gs(t2.type, this._map, t2));
}
mouseout(t2) {
this._map.fire(new gs(t2.type, this._map, t2));
}
touchstart(t2) {
return this._firePreventable(new vs(t2.type, this._map, t2));
}
touchmove(t2) {
this._map.fire(new vs(t2.type, this._map, t2));
}
touchend(t2) {
this._map.fire(new vs(t2.type, this._map, t2));
}
touchcancel(t2) {
this._map.fire(new vs(t2.type, this._map, t2));
}
_firePreventable(t2) {
if (this._map.fire(t2), t2.defaultPrevented) return {};
}
isEnabled() {
return true;
}
isActive() {
return false;
}
enable() {
}
disable() {
}
}
class bs {
constructor(t2) {
this._map = t2;
}
reset() {
this._delayContextMenu = false, this._ignoreContextMenu = true, delete this._contextMenuEvent;
}
mousemove(t2) {
this._map.fire(new gs(t2.type, this._map, t2));
}
mousedown() {
this._delayContextMenu = true, this._ignoreContextMenu = false;
}
mouseup() {
this._delayContextMenu = false, this._contextMenuEvent && (this._map.fire(new gs("contextmenu", this._map, this._contextMenuEvent)), delete this._contextMenuEvent);
}
contextmenu(t2) {
this._delayContextMenu ? this._contextMenuEvent = t2 : this._ignoreContextMenu || this._map.fire(new gs(t2.type, this._map, t2)), this._map.listens("contextmenu") && t2.preventDefault();
}
isEnabled() {
return true;
}
isActive() {
return false;
}
enable() {
}
disable() {
}
}
class ws {
constructor(t2) {
this._map = t2;
}
get transform() {
return this._map._requestedCameraState || this._map.transform;
}
get center() {
return { lng: this.transform.center.lng, lat: this.transform.center.lat };
}
get zoom() {
return this.transform.zoom;
}
get pitch() {
return this.transform.pitch;
}
get bearing() {
return this.transform.bearing;
}
unproject(e2) {
return this.transform.pointLocation(t.P.convert(e2), this._map.terrain);
}
}
class Ts {
constructor(t2, e2) {
this._map = t2, this._tr = new ws(t2), this._el = t2.getCanvasContainer(), this._container = t2.getContainer(), this._clickTolerance = e2.clickTolerance || 1;
}
isEnabled() {
return !!this._enabled;
}
isActive() {
return !!this._active;
}
enable() {
this.isEnabled() || (this._enabled = true);
}
disable() {
this.isEnabled() && (this._enabled = false);
}
mousedown(t2, e2) {
this.isEnabled() && t2.shiftKey && 0 === t2.button && (i2.disableDrag(), this._startPos = this._lastPos = e2, this._active = true);
}
mousemoveWindow(t2, e2) {
if (!this._active) return;
const s2 = e2;
if (this._lastPos.equals(s2) || !this._box && s2.dist(this._startPos) < this._clickTolerance) return;
const a2 = this._startPos;
this._lastPos = s2, this._box || (this._box = i2.create("div", "maplibregl-boxzoom", this._container), this._container.classList.add("maplibregl-crosshair"), this._fireEvent("boxzoomstart", t2));
const o2 = Math.min(a2.x, s2.x), r2 = Math.max(a2.x, s2.x), n2 = Math.min(a2.y, s2.y), l2 = Math.max(a2.y, s2.y);
i2.setTransform(this._box, `translate(${o2}px,${n2}px)`), this._box.style.width = r2 - o2 + "px", this._box.style.height = l2 - n2 + "px";
}
mouseupWindow(e2, s2) {
if (!this._active) return;
if (0 !== e2.button) return;
const a2 = this._startPos, o2 = s2;
if (this.reset(), i2.suppressClick(), a2.x !== o2.x || a2.y !== o2.y) return this._map.fire(new t.k("boxzoomend", { originalEvent: e2 })), { cameraAnimation: (t2) => t2.fitScreenCoordinates(a2, o2, this._tr.bearing, { linear: true }) };
this._fireEvent("boxzoomcancel", e2);
}
keydown(t2) {
this._active && 27 === t2.keyCode && (this.reset(), this._fireEvent("boxzoomcancel", t2));
}
reset() {
this._active = false, this._container.classList.remove("maplibregl-crosshair"), this._box && (i2.remove(this._box), this._box = null), i2.enableDrag(), delete this._startPos, delete this._lastPos;
}
_fireEvent(e2, i3) {
return this._map.fire(new t.k(e2, { originalEvent: i3 }));
}
}
function Is(t2, e2) {
if (t2.length !== e2.length) throw new Error(`The number of touches and points are not equal - touches ${t2.length}, points ${e2.length}`);
const i3 = {};
for (let s2 = 0; s2 < t2.length; s2++) i3[t2[s2].identifier] = e2[s2];
return i3;
}
class Es {
constructor(t2) {
this.reset(), this.numTouches = t2.numTouches;
}
reset() {
delete this.centroid, delete this.startTime, delete this.touches, this.aborted = false;
}
touchstart(e2, i3, s2) {
(this.centroid || s2.length > this.numTouches) && (this.aborted = true), this.aborted || (void 0 === this.startTime && (this.startTime = e2.timeStamp), s2.length === this.numTouches && (this.centroid = (function(e3) {
const i4 = new t.P(0, 0);
for (const t2 of e3) i4._add(t2);
return i4.div(e3.length);
})(i3), this.touches = Is(s2, i3)));
}
touchmove(t2, e2, i3) {
if (this.aborted || !this.centroid) return;
const s2 = Is(i3, e2);
for (const t3 in this.touches) {
const e3 = s2[t3];
(!e3 || e3.dist(this.touches[t3]) > 30) && (this.aborted = true);
}
}
touchend(t2, e2, i3) {
if ((!this.centroid || t2.timeStamp - this.startTime > 500) && (this.aborted = true), 0 === i3.length) {
const t3 = !this.aborted && this.centroid;
if (this.reset(), t3) return t3;
}
}
}
class Ss {
constructor(t2) {
this.singleTap = new Es(t2), this.numTaps = t2.numTaps, this.reset();
}
reset() {
this.lastTime = 1 / 0, delete this.lastTap, this.count = 0, this.singleTap.reset();
}
touchstart(t2, e2, i3) {
this.singleTap.touchstart(t2, e2, i3);
}
touchmove(t2, e2, i3) {
this.singleTap.touchmove(t2, e2, i3);
}
touchend(t2, e2, i3) {
const s2 = this.singleTap.touchend(t2, e2, i3);
if (s2) {
const e3 = t2.timeStamp - this.lastTime < 500, i4 = !this.lastTap || this.lastTap.dist(s2) < 30;
if (e3 && i4 || this.reset(), this.count++, this.lastTime = t2.timeStamp, this.lastTap = s2, this.count === this.numTaps) return this.reset(), s2;
}
}
}
class Cs {
constructor(t2) {
this._tr = new ws(t2), this._zoomIn = new Ss({ numTouches: 1, numTaps: 2 }), this._zoomOut = new Ss({ numTouches: 2, numTaps: 1 }), this.reset();
}
reset() {
this._active = false, this._zoomIn.reset(), this._zoomOut.reset();
}
touchstart(t2, e2, i3) {
this._zoomIn.touchstart(t2, e2, i3), this._zoomOut.touchstart(t2, e2, i3);
}
touchmove(t2, e2, i3) {
this._zoomIn.touchmove(t2, e2, i3), this._zoomOut.touchmove(t2, e2, i3);
}
touchend(t2, e2, i3) {
const s2 = this._zoomIn.touchend(t2, e2, i3), a2 = this._zoomOut.touchend(t2, e2, i3), o2 = this._tr;
return s2 ? (this._active = true, t2.preventDefault(), setTimeout((() => this.reset()), 0), { cameraAnimation: (e3) => e3.easeTo({ duration: 300, zoom: o2.zoom + 1, around: o2.unproject(s2) }, { originalEvent: t2 }) }) : a2 ? (this._active = true, t2.preventDefault(), setTimeout((() => this.reset()), 0), { cameraAnimation: (e3) => e3.easeTo({ duration: 300, zoom: o2.zoom - 1, around: o2.unproject(a2) }, { originalEvent: t2 }) }) : void 0;
}
touchcancel() {
this.reset();
}
enable() {
this._enabled = true;
}
disable() {
this._enabled = false, this.reset();
}
isEnabled() {
return this._enabled;
}
isActive() {
return this._active;
}
}
class Ps {
constructor(t2) {
this._enabled = !!t2.enable, this._moveStateManager = t2.moveStateManager, this._clickTolerance = t2.clickTolerance || 1, this._moveFunction = t2.move, this._activateOnStart = !!t2.activateOnStart, t2.assignEvents(this), this.reset();
}
reset(t2) {
this._active = false, this._moved = false, delete this._lastPoint, this._moveStateManager.endMove(t2);
}
_move(...t2) {
const e2 = this._moveFunction(...t2);
if (e2.bearingDelta || e2.pitchDelta || e2.around || e2.panDelta) return this._active = true, e2;
}
dragStart(t2, e2) {
this.isEnabled() && !this._lastPoint && this._moveStateManager.isValidStartEvent(t2) && (this._moveStateManager.startMove(t2), this._lastPoint = e2.length ? e2[0] : e2, this._activateOnStart && this._lastPoint && (this._active = true));
}
dragMove(t2, e2) {
if (!this.isEnabled()) return;
const i3 = this._lastPoint;
if (!i3) return;
if (t2.preventDefault(), !this._moveStateManager.isValidMoveEvent(t2)) return void this.reset(t2);
const s2 = e2.length ? e2[0] : e2;
return !this._moved && s2.dist(i3) < this._clickTolerance ? void 0 : (this._moved = true, this._lastPoint = s2, this._move(i3, s2));
}
dragEnd(t2) {
this.isEnabled() && this._lastPoint && this._moveStateManager.isValidEndEvent(t2) && (this._moved && i2.suppressClick(), this.reset(t2));
}
enable() {
this._enabled = true;
}
disable() {
this._enabled = false, this.reset();
}
isEnabled() {
return this._enabled;
}
isActive() {
return this._active;
}
getClickTolerance() {
return this._clickTolerance;
}
}
const Ds = { 0: 1, 2: 2 };
class Ms {
constructor(t2) {
this._correctEvent = t2.checkCorrectEvent;
}
startMove(t2) {
const e2 = i2.mouseButton(t2);
this._eventButton = e2;
}
endMove(t2) {
delete this._eventButton;
}
isValidStartEvent(t2) {
return this._correctEvent(t2);
}
isValidMoveEvent(t2) {
return !(function(t3, e2) {
const i3 = Ds[e2];
return void 0 === t3.buttons || (t3.buttons & i3) !== i3;
})(t2, this._eventButton);
}
isValidEndEvent(t2) {
return i2.mouseButton(t2) === this._eventButton;
}
}
class zs {
constructor() {
this._firstTouch = void 0;
}
_isOneFingerTouch(t2) {
return 1 === t2.targetTouches.length;
}
_isSameTouchEvent(t2) {
return t2.targetTouches[0].identifier === this._firstTouch;
}
startMove(t2) {
this._firstTouch = t2.targetTouches[0].identifier;
}
endMove(t2) {
delete this._firstTouch;
}
isValidStartEvent(t2) {
return this._isOneFingerTouch(t2);
}
isValidMoveEvent(t2) {
return this._isOneFingerTouch(t2) && this._isSameTouchEvent(t2);
}
isValidEndEvent(t2) {
return this._isOneFingerTouch(t2) && this._isSameTouchEvent(t2);
}
}
const Ls = (t2) => {
t2.mousedown = t2.dragStart, t2.mousemoveWindow = t2.dragMove, t2.mouseup = t2.dragEnd, t2.contextmenu = function(t3) {
t3.preventDefault();
};
}, As = ({ enable: t2, clickTolerance: e2, bearingDegreesPerPixelMoved: s2 = 0.8 }) => {
const a2 = new Ms({ checkCorrectEvent: (t3) => 0 === i2.mouseButton(t3) && t3.ctrlKey || 2 === i2.mouseButton(t3) });
return new Ps({ clickTolerance: e2, move: (t3, e3) => ({ bearingDelta: (e3.x - t3.x) * s2 }), moveStateManager: a2, enable: t2, assignEvents: Ls });
}, Rs = ({ enable: t2, clickTolerance: e2, pitchDegreesPerPixelMoved: s2 = -0.5 }) => {
const a2 = new Ms({ checkCorrectEvent: (t3) => 0 === i2.mouseButton(t3) && t3.ctrlKey || 2 === i2.mouseButton(t3) });
return new Ps({ clickTolerance: e2, move: (t3, e3) => ({ pitchDelta: (e3.y - t3.y) * s2 }), moveStateManager: a2, enable: t2, assignEvents: Ls });
};
class ks {
constructor(t2, e2) {
this._minTouches = t2.cooperativeGestures ? 2 : 1, this._clickTolerance = t2.clickTolerance || 1, this._map = e2, this.reset();
}
reset() {
this._active = false, this._touches = {}, this._sum = new t.P(0, 0), setTimeout((() => {
this._cancelCooperativeMessage = false;
}), 200);
}
touchstart(t2, e2, i3) {
return this._calculateTransform(t2, e2, i3);
}
touchmove(t2, e2, i3) {
if (this._map._cooperativeGestures && (2 === this._minTouches && i3.length < 2 && !this._cancelCooperativeMessage ? this._map._onCooperativeGesture(t2, false, i3.length) : this._cancelCooperativeMessage || (this._cancelCooperativeMessage = true)), this._active && !(i3.length < this._minTouches)) return t2.preventDefault(), this._calculateTransform(t2, e2, i3);
}
touchend(t2, e2, i3) {
this._calculateTransform(t2, e2, i3), this._active && i3.length < this._minTouches && this.reset();
}
touchcancel() {
this.reset();
}
_calculateTransform(e2, i3, s2) {
s2.length > 0 && (this._active = true);
const a2 = Is(s2, i3), o2 = new t.P(0, 0), r2 = new t.P(0, 0);
let n2 = 0;
for (const t2 in a2) {
const e3 = a2[t2], i4 = this._touches[t2];
i4 && (o2._add(e3), r2._add(e3.sub(i4)), n2++, a2[t2] = e3);
}
if (this._touches = a2, n2 < this._minTouches || !r2.mag()) return;
const l2 = r2.div(n2);
return this._sum._add(l2), this._sum.mag() < this._clickTolerance ? void 0 : { around: o2.div(n2), panDelta: l2 };
}
enable() {
this._enabled = true;
}
disable() {
this._enabled = false, this.reset();
}
isEnabled() {
return this._enabled;
}
isActive() {
return this._active;
}
}
class Fs {
constructor() {
this.reset();
}
reset() {
this._active = false, delete this._firstTwoTouches;
}
touchstart(t2, e2, i3) {
this._firstTwoTouches || i3.length < 2 || (this._firstTwoTouches = [i3[0].identifier, i3[1].identifier], this._start([e2[0], e2[1]]));
}
touchmove(t2, e2, i3) {
if (!this._firstTwoTouches) return;
t2.preventDefault();
const [s2, a2] = this._firstTwoTouches, o2 = Bs(i3, e2, s2), r2 = Bs(i3, e2, a2);
if (!o2 || !r2) return;
const n2 = this._aroundCenter ? null : o2.add(r2).div(2);
return this._move([o2, r2], n2, t2);
}
touchend(t2, e2, s2) {
if (!this._firstTwoTouches) return;
const [a2, o2] = this._firstTwoTouches, r2 = Bs(s2, e2, a2), n2 = Bs(s2, e2, o2);
r2 && n2 || (this._active && i2.suppressClick(), this.reset());
}
touchcancel() {
this.reset();
}
enable(t2) {
this._enabled = true, this._aroundCenter = !!t2 && "center" === t2.around;
}
disable() {
this._enabled = false, this.reset();
}
isEnabled() {
return this._enabled;
}
isActive() {
return this._active;
}
}
function Bs(t2, e2, i3) {
for (let s2 = 0; s2 < t2.length; s2++) if (t2[s2].identifier === i3) return e2[s2];
}
function Os(t2, e2) {
return Math.log(t2 / e2) / Math.LN2;
}
class Ns extends Fs {
reset() {
super.reset(), delete this._distance, delete this._startDistance;
}
_start(t2) {
this._startDistance = this._distance = t2[0].dist(t2[1]);
}
_move(t2, e2) {
const i3 = this._distance;
if (this._distance = t2[0].dist(t2[1]), this._active || !(Math.abs(Os(this._distance, this._startDistance)) < 0.1)) return this._active = true, { zoomDelta: Os(this._distance, i3), pinchAround: e2 };
}
}
function Us(t2, e2) {
return 180 * t2.angleWith(e2) / Math.PI;
}
class Zs extends Fs {
reset() {
super.reset(), delete this._minDiameter, delete this._startVector, delete this._vector;
}
_start(t2) {
this._startVector = this._vector = t2[0].sub(t2[1]), this._minDiameter = t2[0].dist(t2[1]);
}
_move(t2, e2) {
const i3 = this._vector;
if (this._vector = t2[0].sub(t2[1]), this._active || !this._isBelowThreshold(this._vector)) return this._active = true, { bearingDelta: Us(this._vector, i3), pinchAround: e2 };
}
_isBelowThreshold(t2) {
this._minDiameter = Math.min(this._minDiameter, t2.mag());
const e2 = 25 / (Math.PI * this._minDiameter) * 360, i3 = Us(t2, this._startVector);
return Math.abs(i3) < e2;
}
}
function Gs(t2) {
return Math.abs(t2.y) > Math.abs(t2.x);
}
class js extends Fs {
constructor(t2) {
super(), this._map = t2;
}
reset() {
super.reset(), this._valid = void 0, delete this._firstMove, delete this._lastPoints;
}
touchstart(t2, e2, i3) {
super.touchstart(t2, e2, i3), this._currentTouchCount = i3.length;
}
_start(t2) {
this._lastPoints = t2, Gs(t2[0].sub(t2[1])) && (this._valid = false);
}
_move(t2, e2, i3) {
if (this._map._cooperativeGestures && this._currentTouchCount < 3) return;
const s2 = t2[0].sub(this._lastPoints[0]), a2 = t2[1].sub(this._lastPoints[1]);
return this._valid = this.gestureBeginsVertically(s2, a2, i3.timeStamp), this._valid ? (this._lastPoints = t2, this._active = true, { pitchDelta: (s2.y + a2.y) / 2 * -0.5 }) : void 0;
}
gestureBeginsVertically(t2, e2, i3) {
if (void 0 !== this._valid) return this._valid;
const s2 = t2.mag() >= 2, a2 = e2.mag() >= 2;
if (!s2 && !a2) return;
if (!s2 || !a2) return void 0 === this._firstMove && (this._firstMove = i3), i3 - this._firstMove < 100 && void 0;
const o2 = t2.y > 0 == e2.y > 0;
return Gs(t2) && Gs(e2) && o2;
}
}
const Vs = { panStep: 100, bearingStep: 15, pitchStep: 10 };
class qs {
constructor(t2) {
this._tr = new ws(t2);
const e2 = Vs;
this._panStep = e2.panStep, this._bearingStep = e2.bearingStep, this._pitchStep = e2.pitchStep, this._rotationDisabled = false;
}
reset() {
this._active = false;
}
keydown(t2) {
if (t2.altKey || t2.ctrlKey || t2.metaKey) return;
let e2 = 0, i3 = 0, s2 = 0, a2 = 0, o2 = 0;
switch (t2.keyCode) {
case 61:
case 107:
case 171:
case 187:
e2 = 1;
break;
case 189:
case 109:
case 173:
e2 = -1;
break;
case 37:
t2.shiftKey ? i3 = -1 : (t2.preventDefault(), a2 = -1);
break;
case 39:
t2.shiftKey ? i3 = 1 : (t2.preventDefault(), a2 = 1);
break;
case 38:
t2.shiftKey ? s2 = 1 : (t2.preventDefault(), o2 = -1);
break;
case 40:
t2.shiftKey ? s2 = -1 : (t2.preventDefault(), o2 = 1);
break;
default:
return;
}
return this._rotationDisabled && (i3 = 0, s2 = 0), { cameraAnimation: (r2) => {
const n2 = this._tr;
r2.easeTo({ duration: 300, easeId: "keyboardHandler", easing: $s, zoom: e2 ? Math.round(n2.zoom) + e2 * (t2.shiftKey ? 2 : 1) : n2.zoom, bearing: n2.bearing + i3 * this._bearingStep, pitch: n2.pitch + s2 * this._pitchStep, offset: [-a2 * this._panStep, -o2 * this._panStep], center: n2.center }, { originalEvent: t2 });
} };
}
enable() {
this._enabled = true;
}
disable() {
this._enabled = false, this.reset();
}
isEnabled() {
return this._enabled;
}
isActive() {
return this._active;
}
disableRotation() {
this._rotationDisabled = true;
}
enableRotation() {
this._rotationDisabled = false;
}
}
function $s(t2) {
return t2 * (2 - t2);
}
const Ws = 4.000244140625;
class Hs {
constructor(t2, e2) {
this._onTimeout = (t3) => {
this._type = "wheel", this._delta -= this._lastValue, this._active || this._start(t3);
}, this._map = t2, this._tr = new ws(t2), this._el = t2.getCanvasContainer(), this._triggerRenderFrame = e2, this._delta = 0, this._defaultZoomRate = 0.01, this._wheelZoomRate = 0.0022222222222222222;
}
setZoomRate(t2) {
this._defaultZoomRate = t2;
}
setWheelZoomRate(t2) {
this._wheelZoomRate = t2;
}
isEnabled() {
return !!this._enabled;
}
isActive() {
return !!this._active || void 0 !== this._finishTimeout;
}
isZooming() {
return !!this._zooming;
}
enable(t2) {
this.isEnabled() || (this._enabled = true, this._aroundCenter = !!t2 && "center" === t2.around);
}
disable() {
this.isEnabled() && (this._enabled = false);
}
wheel(e2) {
if (!this.isEnabled()) return;
if (this._map._cooperativeGestures) {
if (!e2[this._map._metaKey]) return;
e2.preventDefault();
}
let i3 = e2.deltaMode === WheelEvent.DOM_DELTA_LINE ? 40 * e2.deltaY : e2.deltaY;
const s2 = t.h.now(), a2 = s2 - (this._lastWheelEventTime || 0);
this._lastWheelEventTime = s2, 0 !== i3 && i3 % Ws == 0 ? this._type = "wheel" : 0 !== i3 && Math.abs(i3) < 4 ? this._type = "trackpad" : a2 > 400 ? (this._type = null, this._lastValue = i3, this._timeout = setTimeout(this._onTimeout, 40, e2)) : this._type || (this._type = Math.abs(a2 * i3) < 200 ? "trackpad" : "wheel", this._timeout && (clearTimeout(this._timeout), this._timeout = null, i3 += this._lastValue)), e2.shiftKey && i3 && (i3 /= 4), this._type && (this._lastWheelEvent = e2, this._delta -= i3, this._active || this._start(e2)), e2.preventDefault();
}
_start(e2) {
if (!this._delta) return;
this._frameId && (this._frameId = null), this._active = true, this.isZooming() || (this._zooming = true), this._finishTimeout && (clearTimeout(this._finishTimeout), delete this._finishTimeout);
const s2 = i2.mousePos(this._el, e2), a2 = this._tr;
this._around = t.L.convert(this._aroundCenter ? a2.center : a2.unproject(s2)), this._aroundPoint = a2.transform.locationPoint(this._around), this._frameId || (this._frameId = true, this._triggerRenderFrame());
}
renderFrame() {
if (!this._frameId) return;
if (this._frameId = null, !this.isActive()) return;
const e2 = this._tr.transform;
if (0 !== this._delta) {
const t2 = "wheel" === this._type && Math.abs(this._delta) > Ws ? this._wheelZoomRate : this._defaultZoomRate;
let i4 = 2 / (1 + Math.exp(-Math.abs(this._delta * t2)));
this._delta < 0 && 0 !== i4 && (i4 = 1 / i4);
const s3 = "number" == typeof this._targetZoom ? e2.zoomScale(this._targetZoom) : e2.scale;
this._targetZoom = Math.min(e2.maxZoom, Math.max(e2.minZoom, e2.scaleZoom(s3 * i4))), "wheel" === this._type && (this._startZoom = e2.zoom, this._easing = this._smoothOutEasing(200)), this._delta = 0;
}
const i3 = "number" == typeof this._targetZoom ? this._targetZoom : e2.zoom, s2 = this._startZoom, a2 = this._easing;
let o2, r2 = false;
if ("wheel" === this._type && s2 && a2) {
const e3 = Math.min((t.h.now() - this._lastWheelEventTime) / 200, 1), n2 = a2(e3);
o2 = t.B.number(s2, i3, n2), e3 < 1 ? this._frameId || (this._frameId = true) : r2 = true;
} else o2 = i3, r2 = true;
return this._active = true, r2 && (this._active = false, this._finishTimeout = setTimeout((() => {
this._zooming = false, this._triggerRenderFrame(), delete this._targetZoom, delete this._finishTimeout;
}), 200)), { noInertia: true, needsRenderFrame: !r2, zoomDelta: o2 - e2.zoom, around: this._aroundPoint, originalEvent: this._lastWheelEvent };
}
_smoothOutEasing(e2) {
let i3 = t.bb;
if (this._prevEase) {
const e3 = this._prevEase, s2 = (t.h.now() - e3.start) / e3.duration, a2 = e3.easing(s2 + 0.01) - e3.easing(s2), o2 = 0.27 / Math.sqrt(a2 * a2 + 1e-4) * 0.01, r2 = Math.sqrt(0.0729 - o2 * o2);
i3 = t.ba(o2, r2, 0.25, 1);
}
return this._prevEase = { start: t.h.now(), duration: e2, easing: i3 }, i3;
}
reset() {
this._active = false, this._zooming = false, delete this._targetZoom, this._finishTimeout && (clearTimeout(this._finishTimeout), delete this._finishTimeout);
}
}
class Xs {
constructor(t2, e2) {
this._clickZoom = t2, this._tapZoom = e2;
}
enable() {
this._clickZoom.enable(), this._tapZoom.enable();
}
disable() {
this._clickZoom.disable(), this._tapZoom.disable();
}
isEnabled() {
return this._clickZoom.isEnabled() && this._tapZoom.isEnabled();
}
isActive() {
return this._clickZoom.isActive() || this._tapZoom.isActive();
}
}
class Ks {
constructor(t2) {
this._tr = new ws(t2), this.reset();
}
reset() {
this._active = false;
}
dblclick(t2, e2) {
return t2.preventDefault(), { cameraAnimation: (i3) => {
i3.easeTo({ duration: 300, zoom: this._tr.zoom + (t2.shiftKey ? -1 : 1), around: this._tr.unproject(e2) }, { originalEvent: t2 });
} };
}
enable() {
this._enabled = true;
}
disable() {
this._enabled = false, this.reset();
}
isEnabled() {
return this._enabled;
}
isActive() {
return this._active;
}
}
class Qs {
constructor() {
this._tap = new Ss({ numTouches: 1, numTaps: 1 }), this.reset();
}
reset() {
this._active = false, delete this._swipePoint, delete this._swipeTouch, delete this._tapTime, delete this._tapPoint, this._tap.reset();
}
touchstart(t2, e2, i3) {
if (!this._swipePoint) if (this._tapTime) {
const s2 = e2[0], a2 = t2.timeStamp - this._tapTime < 500, o2 = this._tapPoint.dist(s2) < 30;
a2 && o2 ? i3.length > 0 && (this._swipePoint = s2, this._swipeTouch = i3[0].identifier) : this.reset();
} else this._tap.touchstart(t2, e2, i3);
}
touchmove(t2, e2, i3) {
if (this._tapTime) {
if (this._swipePoint) {
if (i3[0].identifier !== this._swipeTouch) return;
const s2 = e2[0], a2 = s2.y - this._swipePoint.y;
return this._swipePoint = s2, t2.preventDefault(), this._active = true, { zoomDelta: a2 / 128 };
}
} else this._tap.touchmove(t2, e2, i3);
}
touchend(t2, e2, i3) {
if (this._tapTime) this._swipePoint && 0 === i3.length && this.reset();
else {
const s2 = this._tap.touchend(t2, e2, i3);
s2 && (this._tapTime = t2.timeStamp, this._tapPoint = s2);
}
}
touchcancel() {
this.reset();
}
enable() {
this._enabled = true;
}
disable() {
this._enabled = false, this.reset();
}
isEnabled() {
return this._enabled;
}
isActive() {
return this._active;
}
}
class Ys {
constructor(t2, e2, i3) {
this._el = t2, this._mousePan = e2, this._touchPan = i3;
}
enable(t2) {
this._inertiaOptions = t2 || {}, this._mousePan.enable(), this._touchPan.enable(), this._el.classList.add("maplibregl-touch-drag-pan");
}
disable() {
this._mousePan.disable(), this._touchPan.disable(), this._el.classList.remove("maplibregl-touch-drag-pan");
}
isEnabled() {
return this._mousePan.isEnabled() && this._touchPan.isEnabled();
}
isActive() {
return this._mousePan.isActive() || this._touchPan.isActive();
}
}
class Js {
constructor(t2, e2, i3) {
this._pitchWithRotate = t2.pitchWithRotate, this._mouseRotate = e2, this._mousePitch = i3;
}
enable() {
this._mouseRotate.enable(), this._pitchWithRotate && this._mousePitch.enable();
}
disable() {
this._mouseRotate.disable(), this._mousePitch.disable();
}
isEnabled() {
return this._mouseRotate.isEnabled() && (!this._pitchWithRotate || this._mousePitch.isEnabled());
}
isActive() {
return this._mouseRotate.isActive() || this._mousePitch.isActive();
}
}
class ta {
constructor(t2, e2, i3, s2) {
this._el = t2, this._touchZoom = e2, this._touchRotate = i3, this._tapDragZoom = s2, this._rotationDisabled = false, this._enabled = true;
}
enable(t2) {
this._touchZoom.enable(t2), this._rotationDisabled || this._touchRotate.enable(t2), this._tapDragZoom.enable(), this._el.classList.add("maplibregl-touch-zoom-rotate");
}
disable() {
this._touchZoom.disable(), this._touchRotate.disable(), this._tapDragZoom.disable(), this._el.classList.remove("maplibregl-touch-zoom-rotate");
}
isEnabled() {
return this._touchZoom.isEnabled() && (this._rotationDisabled || this._touchRotate.isEnabled()) && this._tapDragZoom.isEnabled();
}
isActive() {
return this._touchZoom.isActive() || this._touchRotate.isActive() || this._tapDragZoom.isActive();
}
disableRotation() {
this._rotationDisabled = true, this._touchRotate.disable();
}
enableRotation() {
this._rotationDisabled = false, this._touchZoom.isEnabled() && this._touchRotate.enable();
}
}
const ea = (t2) => t2.zoom || t2.drag || t2.pitch || t2.rotate;
class ia extends t.k {
}
function sa(t2) {
return t2.panDelta && t2.panDelta.mag() || t2.zoomDelta || t2.bearingDelta || t2.pitchDelta;
}
class aa {
constructor(t2, e2) {
this.handleWindowEvent = (t3) => {
this.handleEvent(t3, `${t3.type}Window`);
}, this.handleEvent = (t3, e3) => {
if ("blur" === t3.type) return void this.stop(true);
this._updatingCamera = true;
const s3 = "renderFrame" === t3.type ? void 0 : t3, a2 = { needsRenderFrame: false }, o2 = {}, r2 = {}, n2 = t3.touches, l2 = n2 ? this._getMapTouches(n2) : void 0, h2 = l2 ? i2.touchPos(this._el, l2) : i2.mousePos(this._el, t3);
for (const { handlerName: i3, handler: n3, allowed: c3 } of this._handlers) {
if (!n3.isEnabled()) continue;
let u3;
this._blockedByActive(r2, c3, i3) ? n3.reset() : n3[e3 || t3.type] && (u3 = n3[e3 || t3.type](t3, h2, l2), this.mergeHandlerResult(a2, o2, u3, i3, s3), u3 && u3.needsRenderFrame && this._triggerRenderFrame()), (u3 || n3.isActive()) && (r2[i3] = n3);
}
const c2 = {};
for (const t4 in this._previousActiveHandlers) r2[t4] || (c2[t4] = s3);
this._previousActiveHandlers = r2, (Object.keys(c2).length || sa(a2)) && (this._changes.push([a2, o2, c2]), this._triggerRenderFrame()), (Object.keys(r2).length || sa(a2)) && this._map._stop(true), this._updatingCamera = false;
const { cameraAnimation: u2 } = a2;
u2 && (this._inertia.clear(), this._fireEvents({}, {}, true), this._changes = [], u2(this._map));
}, this._map = t2, this._el = this._map.getCanvasContainer(), this._handlers = [], this._handlersById = {}, this._changes = [], this._inertia = new ps(t2), this._bearingSnap = e2.bearingSnap, this._previousActiveHandlers = {}, this._eventsInProgress = {}, this._addDefaultHandlers(e2);
const s2 = this._el;
this._listeners = [[s2, "touchstart", { passive: true }], [s2, "touchmove", { passive: false }], [s2, "touchend", void 0], [s2, "touchcancel", void 0], [s2, "mousedown", void 0], [s2, "mousemove", void 0], [s2, "mouseup", void 0], [document, "mousemove", { capture: true }], [document, "mouseup", void 0], [s2, "mouseover", void 0], [s2, "mouseout", void 0], [s2, "dblclick", void 0], [s2, "click", void 0], [s2, "keydown", { capture: false }], [s2, "keyup", void 0], [s2, "wheel", { passive: false }], [s2, "contextmenu", void 0], [window, "blur", void 0]];
for (const [t3, e3, s3] of this._listeners) i2.addEventListener(t3, e3, t3 === document ? this.handleWindowEvent : this.handleEvent, s3);
}
destroy() {
for (const [t2, e2, s2] of this._listeners) i2.removeEventListener(t2, e2, t2 === document ? this.handleWindowEvent : this.handleEvent, s2);
}
_addDefaultHandlers(t2) {
const e2 = this._map, s2 = e2.getCanvasContainer();
this._add("mapEvent", new ys(e2, t2));
const a2 = e2.boxZoom = new Ts(e2, t2);
this._add("boxZoom", a2), t2.interactive && t2.boxZoom && a2.enable();
const o2 = new Cs(e2), r2 = new Ks(e2);
e2.doubleClickZoom = new Xs(r2, o2), this._add("tapZoom", o2), this._add("clickZoom", r2), t2.interactive && t2.doubleClickZoom && e2.doubleClickZoom.enable();
const n2 = new Qs();
this._add("tapDragZoom", n2);
const l2 = e2.touchPitch = new js(e2);
this._add("touchPitch", l2), t2.interactive && t2.touchPitch && e2.touchPitch.enable(t2.touchPitch);
const h2 = As(t2), c2 = Rs(t2);
e2.dragRotate = new Js(t2, h2, c2), this._add("mouseRotate", h2, ["mousePitch"]), this._add("mousePitch", c2, ["mouseRotate"]), t2.interactive && t2.dragRotate && e2.dragRotate.enable();
const u2 = (({ enable: t3, clickTolerance: e3 }) => {
const s3 = new Ms({ checkCorrectEvent: (t4) => 0 === i2.mouseButton(t4) && !t4.ctrlKey });
return new Ps({ clickTolerance: e3, move: (t4, e4) => ({ around: e4, panDelta: e4.sub(t4) }), activateOnStart: true, moveStateManager: s3, enable: t3, assignEvents: Ls });
})(t2), d2 = new ks(t2, e2);
e2.dragPan = new Ys(s2, u2, d2), this._add("mousePan", u2), this._add("touchPan", d2, ["touchZoom", "touchRotate"]), t2.interactive && t2.dragPan && e2.dragPan.enable(t2.dragPan);
const _2 = new Zs(), p2 = new Ns();
e2.touchZoomRotate = new ta(s2, p2, _2, n2), this._add("touchRotate", _2, ["touchPan", "touchZoom"]), this._add("touchZoom", p2, ["touchPan", "touchRotate"]), t2.interactive && t2.touchZoomRotate && e2.touchZoomRotate.enable(t2.touchZoomRotate);
const m2 = e2.scrollZoom = new Hs(e2, (() => this._triggerRenderFrame()));
this._add("scrollZoom", m2, ["mousePan"]), t2.interactive && t2.scrollZoom && e2.scrollZoom.enable(t2.scrollZoom);
const f2 = e2.keyboard = new qs(e2);
this._add("keyboard", f2), t2.interactive && t2.keyboard && e2.keyboard.enable(), this._add("blockableMapEvent", new bs(e2));
}
_add(t2, e2, i3) {
this._handlers.push({ handlerName: t2, handler: e2, allowed: i3 }), this._handlersById[t2] = e2;
}
stop(t2) {
if (!this._updatingCamera) {
for (const { handler: t3 } of this._handlers) t3.reset();
this._inertia.clear(), this._fireEvents({}, {}, t2), this._changes = [];
}
}
isActive() {
for (const { handler: t2 } of this._handlers) if (t2.isActive()) return true;
return false;
}
isZooming() {
return !!this._eventsInProgress.zoom || this._map.scrollZoom.isZooming();
}
isRotating() {
return !!this._eventsInProgress.rotate;
}
isMoving() {
return Boolean(ea(this._eventsInProgress)) || this.isZooming();
}
_blockedByActive(t2, e2, i3) {
for (const s2 in t2) if (s2 !== i3 && (!e2 || e2.indexOf(s2) < 0)) return true;
return false;
}
_getMapTouches(t2) {
const e2 = [];
for (const i3 of t2) this._el.contains(i3.target) && e2.push(i3);
return e2;
}
mergeHandlerResult(e2, i3, s2, a2, o2) {
if (!s2) return;
t.e(e2, s2);
const r2 = { handlerName: a2, originalEvent: s2.originalEvent || o2 };
void 0 !== s2.zoomDelta && (i3.zoom = r2), void 0 !== s2.panDelta && (i3.drag = r2), void 0 !== s2.pitchDelta && (i3.pitch = r2), void 0 !== s2.bearingDelta && (i3.rotate = r2);
}
_applyChanges() {
const e2 = {}, i3 = {}, s2 = {};
for (const [a2, o2, r2] of this._changes) a2.panDelta && (e2.panDelta = (e2.panDelta || new t.P(0, 0))._add(a2.panDelta)), a2.zoomDelta && (e2.zoomDelta = (e2.zoomDelta || 0) + a2.zoomDelta), a2.bearingDelta && (e2.bearingDelta = (e2.bearingDelta || 0) + a2.bearingDelta), a2.pitchDelta && (e2.pitchDelta = (e2.pitchDelta || 0) + a2.pitchDelta), void 0 !== a2.around && (e2.around = a2.around), void 0 !== a2.pinchAround && (e2.pinchAround = a2.pinchAround), a2.noInertia && (e2.noInertia = a2.noInertia), t.e(i3, o2), t.e(s2, r2);
this._updateMapTransform(e2, i3, s2), this._changes = [];
}
_updateMapTransform(t2, e2, i3) {
const s2 = this._map, a2 = s2._getTransformForUpdate(), o2 = s2.terrain;
if (!(sa(t2) || o2 && this._terrainMovement)) return this._fireEvents(e2, i3, true);
let { panDelta: r2, zoomDelta: n2, bearingDelta: l2, pitchDelta: h2, around: c2, pinchAround: u2 } = t2;
void 0 !== u2 && (c2 = u2), s2._stop(true), c2 = c2 || s2.transform.centerPoint;
const d2 = a2.pointLocation(r2 ? c2.sub(r2) : c2);
l2 && (a2.bearing += l2), h2 && (a2.pitch += h2), n2 && (a2.zoom += n2), o2 ? this._terrainMovement || !e2.drag && !e2.zoom ? e2.drag && this._terrainMovement ? a2.center = a2.pointLocation(a2.centerPoint.sub(r2)) : a2.setLocationAtPoint(d2, c2) : (this._terrainMovement = true, this._map._elevationFreeze = true, a2.setLocationAtPoint(d2, c2), this._map.once("moveend", (() => {
this._map._elevationFreeze = false, this._terrainMovement = false, a2.recalculateZoom(s2.terrain);
}))) : a2.setLocationAtPoint(d2, c2), s2._applyUpdatedTransform(a2), this._map._update(), t2.noInertia || this._inertia.record(t2), this._fireEvents(e2, i3, true);
}
_fireEvents(e2, i3, s2) {
const a2 = ea(this._eventsInProgress), o2 = ea(e2), r2 = {};
for (const t2 in e2) {
const { originalEvent: i4 } = e2[t2];
this._eventsInProgress[t2] || (r2[`${t2}start`] = i4), this._eventsInProgress[t2] = e2[t2];
}
!a2 && o2 && this._fireEvent("movestart", o2.originalEvent);
for (const t2 in r2) this._fireEvent(t2, r2[t2]);
o2 && this._fireEvent("move", o2.originalEvent);
for (const t2 in e2) {
const { originalEvent: i4 } = e2[t2];
this._fireEvent(t2, i4);
}
const n2 = {};
let l2;
for (const t2 in this._eventsInProgress) {
const { handlerName: e3, originalEvent: s3 } = this._eventsInProgress[t2];
this._handlersById[e3].isActive() || (delete this._eventsInProgress[t2], l2 = i3[e3] || s3, n2[`${t2}end`] = l2);
}
for (const t2 in n2) this._fireEvent(t2, n2[t2]);
const h2 = ea(this._eventsInProgress);
if (s2 && (a2 || o2) && !h2) {
this._updatingCamera = true;
const e3 = this._inertia._onMoveEnd(this._map.dragPan._inertiaOptions), i4 = (t2) => 0 !== t2 && -this._bearingSnap < t2 && t2 < this._bearingSnap;
!e3 || !e3.essential && t.h.prefersReducedMotion ? (this._map.fire(new t.k("moveend", { originalEvent: l2 })), i4(this._map.getBearing()) && this._map.resetNorth()) : (i4(e3.bearing || this._map.getBearing()) && (e3.bearing = 0), e3.freezeElevation = true, this._map.easeTo(e3, { originalEvent: l2 })), this._updatingCamera = false;
}
}
_fireEvent(e2, i3) {
this._map.fire(new t.k(e2, i3 ? { originalEvent: i3 } : {}));
}
_requestFrame() {
return this._map.triggerRepaint(), this._map._renderTaskQueue.add(((t2) => {
delete this._frameId, this.handleEvent(new ia("renderFrame", { timeStamp: t2 })), this._applyChanges();
}));
}
_triggerRenderFrame() {
void 0 === this._frameId && (this._frameId = this._requestFrame());
}
}
class oa extends t.E {
constructor(e2, i3) {
super(), this._renderFrameCallback = () => {
const e3 = Math.min((t.h.now() - this._easeStart) / this._easeOptions.duration, 1);
this._onEaseFrame(this._easeOptions.easing(e3)), e3 < 1 && this._easeFrameId ? this._easeFrameId = this._requestRenderFrame(this._renderFrameCallback) : this.stop();
}, this._moving = false, this._zooming = false, this.transform = e2, this._bearingSnap = i3.bearingSnap, this.on("moveend", (() => {
delete this._requestedCameraState;
}));
}
getCenter() {
return new t.L(this.transform.center.lng, this.transform.center.lat);
}
setCenter(t2, e2) {
return this.jumpTo({ center: t2 }, e2);
}
panBy(e2, i3, s2) {
return e2 = t.P.convert(e2).mult(-1), this.panTo(this.transform.center, t.e({ offset: e2 }, i3), s2);
}
panTo(e2, i3, s2) {
return this.easeTo(t.e({ center: e2 }, i3), s2);
}
getZoom() {
return this.transform.zoom;
}
setZoom(t2, e2) {
return this.jumpTo({ zoom: t2 }, e2), this;
}
zoomTo(e2, i3, s2) {
return this.easeTo(t.e({ zoom: e2 }, i3), s2);
}
zoomIn(t2, e2) {
return this.zoomTo(this.getZoom() + 1, t2, e2), this;
}
zoomOut(t2, e2) {
return this.zoomTo(this.getZoom() - 1, t2, e2), this;
}
getBearing() {
return this.transform.bearing;
}
setBearing(t2, e2) {
return this.jumpTo({ bearing: t2 }, e2), this;
}
getPadding() {
return this.transform.padding;
}
setPadding(t2, e2) {
return this.jumpTo({ padding: t2 }, e2), this;
}
rotateTo(e2, i3, s2) {
return this.easeTo(t.e({ bearing: e2 }, i3), s2);
}
resetNorth(e2, i3) {
return this.rotateTo(0, t.e({ duration: 1e3 }, e2), i3), this;
}
resetNorthPitch(e2, i3) {
return this.easeTo(t.e({ bearing: 0, pitch: 0, duration: 1e3 }, e2), i3), this;
}
snapToNorth(t2, e2) {
return Math.abs(this.getBearing()) < this._bearingSnap ? this.resetNorth(t2, e2) : this;
}
getPitch() {
return this.transform.pitch;
}
setPitch(t2, e2) {
return this.jumpTo({ pitch: t2 }, e2), this;
}
cameraForBounds(t2, e2) {
t2 = L.convert(t2);
const i3 = e2 && e2.bearing || 0;
return this._cameraForBoxAndBearing(t2.getNorthWest(), t2.getSouthEast(), i3, e2);
}
_cameraForBoxAndBearing(e2, i3, s2, a2) {
const o2 = { top: 0, bottom: 0, right: 0, left: 0 };
if ("number" == typeof (a2 = t.e({ padding: o2, offset: [0, 0], maxZoom: this.transform.maxZoom }, a2)).padding) {
const t2 = a2.padding;
a2.padding = { top: t2, bottom: t2, right: t2, left: t2 };
}
a2.padding = t.e(o2, a2.padding);
const r2 = this.transform, n2 = r2.padding, l2 = r2.project(t.L.convert(e2)), h2 = r2.project(t.L.convert(i3)), c2 = l2.rotate(-s2 * Math.PI / 180), u2 = h2.rotate(-s2 * Math.PI / 180), d2 = new t.P(Math.max(c2.x, u2.x), Math.max(c2.y, u2.y)), _2 = new t.P(Math.min(c2.x, u2.x), Math.min(c2.y, u2.y)), p2 = d2.sub(_2), m2 = (r2.width - (n2.left + n2.right + a2.padding.left + a2.padding.right)) / p2.x, f2 = (r2.height - (n2.top + n2.bottom + a2.padding.top + a2.padding.bottom)) / p2.y;
if (f2 < 0 || m2 < 0) return void t.w("Map cannot fit within canvas with the given bounds, padding, and/or offset.");
const g2 = Math.min(r2.scaleZoom(r2.scale * Math.min(m2, f2)), a2.maxZoom), v2 = t.P.convert(a2.offset), x2 = new t.P((a2.padding.left - a2.padding.right) / 2, (a2.padding.top - a2.padding.bottom) / 2).rotate(s2 * Math.PI / 180), y2 = v2.add(x2).mult(r2.scale / r2.zoomScale(g2));
return { center: r2.unproject(l2.add(h2).div(2).sub(y2)), zoom: g2, bearing: s2 };
}
fitBounds(t2, e2, i3) {
return this._fitInternal(this.cameraForBounds(t2, e2), e2, i3);
}
fitScreenCoordinates(e2, i3, s2, a2, o2) {
return this._fitInternal(this._cameraForBoxAndBearing(this.transform.pointLocation(t.P.convert(e2)), this.transform.pointLocation(t.P.convert(i3)), s2, a2), a2, o2);
}
_fitInternal(e2, i3, s2) {
return e2 ? (delete (i3 = t.e(e2, i3)).padding, i3.linear ? this.easeTo(i3, s2) : this.flyTo(i3, s2)) : this;
}
jumpTo(e2, i3) {
this.stop();
const s2 = this._getTransformForUpdate();
let a2 = false, o2 = false, r2 = false;
return "zoom" in e2 && s2.zoom !== +e2.zoom && (a2 = true, s2.zoom = +e2.zoom), void 0 !== e2.center && (s2.center = t.L.convert(e2.center)), "bearing" in e2 && s2.bearing !== +e2.bearing && (o2 = true, s2.bearing = +e2.bearing), "pitch" in e2 && s2.pitch !== +e2.pitch && (r2 = true, s2.pitch = +e2.pitch), null == e2.padding || s2.isPaddingEqual(e2.padding) || (s2.padding = e2.padding), this._applyUpdatedTransform(s2), this.fire(new t.k("movestart", i3)).fire(new t.k("move", i3)), a2 && this.fire(new t.k("zoomstart", i3)).fire(new t.k("zoom", i3)).fire(new t.k("zoomend", i3)), o2 && this.fire(new t.k("rotatestart", i3)).fire(new t.k("rotate", i3)).fire(new t.k("rotateend", i3)), r2 && this.fire(new t.k("pitchstart", i3)).fire(new t.k("pitch", i3)).fire(new t.k("pitchend", i3)), this.fire(new t.k("moveend", i3));
}
calculateCameraOptionsFromTo(e2, i3, s2, a2 = 0) {
const o2 = t.U.fromLngLat(e2, i3), r2 = t.U.fromLngLat(s2, a2), n2 = r2.x - o2.x, l2 = r2.y - o2.y, h2 = r2.z - o2.z, c2 = Math.hypot(n2, l2, h2);
if (0 === c2) throw new Error("Can't calculate camera options with same From and To");
const u2 = Math.hypot(n2, l2), d2 = this.transform.scaleZoom(this.transform.cameraToCenterDistance / c2 / this.transform.tileSize), _2 = 180 * Math.atan2(n2, -l2) / Math.PI;
let p2 = 180 * Math.acos(u2 / c2) / Math.PI;
return p2 = h2 < 0 ? 90 - p2 : 90 + p2, { center: r2.toLngLat(), zoom: d2, pitch: p2, bearing: _2 };
}
easeTo(e2, i3) {
this._stop(false, e2.easeId), (false === (e2 = t.e({ offset: [0, 0], duration: 500, easing: t.bb }, e2)).animate || !e2.essential && t.h.prefersReducedMotion) && (e2.duration = 0);
const s2 = this._getTransformForUpdate(), a2 = this.getZoom(), o2 = this.getBearing(), r2 = this.getPitch(), n2 = this.getPadding(), l2 = "zoom" in e2 ? +e2.zoom : a2, h2 = "bearing" in e2 ? this._normalizeBearing(e2.bearing, o2) : o2, c2 = "pitch" in e2 ? +e2.pitch : r2, u2 = "padding" in e2 ? e2.padding : s2.padding, d2 = t.P.convert(e2.offset);
let _2 = s2.centerPoint.add(d2);
const p2 = s2.pointLocation(_2), m2 = t.L.convert(e2.center || p2);
this._normalizeCenter(m2);
const f2 = s2.project(p2), g2 = s2.project(m2).sub(f2), v2 = s2.zoomScale(l2 - a2);
let x2, y2;
e2.around && (x2 = t.L.convert(e2.around), y2 = s2.locationPoint(x2));
const b2 = { moving: this._moving, zooming: this._zooming, rotating: this._rotating, pitching: this._pitching };
return this._zooming = this._zooming || l2 !== a2, this._rotating = this._rotating || o2 !== h2, this._pitching = this._pitching || c2 !== r2, this._padding = !s2.isPaddingEqual(u2), this._easeId = e2.easeId, this._prepareEase(i3, e2.noMoveStart, b2), this.terrain && this._prepareElevation(m2), this._ease(((p3) => {
if (this._zooming && (s2.zoom = t.B.number(a2, l2, p3)), this._rotating && (s2.bearing = t.B.number(o2, h2, p3)), this._pitching && (s2.pitch = t.B.number(r2, c2, p3)), this._padding && (s2.interpolatePadding(n2, u2, p3), _2 = s2.centerPoint.add(d2)), this.terrain && !e2.freezeElevation && this._updateElevation(p3), x2) s2.setLocationAtPoint(x2, y2);
else {
const t2 = s2.zoomScale(s2.zoom - a2), e3 = l2 > a2 ? Math.min(2, v2) : Math.max(0.5, v2), i4 = Math.pow(e3, 1 - p3), o3 = s2.unproject(f2.add(g2.mult(p3 * i4)).mult(t2));
s2.setLocationAtPoint(s2.renderWorldCopies ? o3.wrap() : o3, _2);
}
this._applyUpdatedTransform(s2), this._fireMoveEvents(i3);
}), ((t2) => {
this.terrain && this._finalizeElevation(), this._afterEase(i3, t2);
}), e2), this;
}
_prepareEase(e2, i3, s2 = {}) {
this._moving = true, i3 || s2.moving || this.fire(new t.k("movestart", e2)), this._zooming && !s2.zooming && this.fire(new t.k("zoomstart", e2)), this._rotating && !s2.rotating && this.fire(new t.k("rotatestart", e2)), this._pitching && !s2.pitching && this.fire(new t.k("pitchstart", e2));
}
_prepareElevation(t2) {
this._elevationCenter = t2, this._elevationStart = this.transform.elevation, this._elevationTarget = this.terrain.getElevationForLngLatZoom(t2, this.transform.tileZoom), this._elevationFreeze = true;
}
_updateElevation(e2) {
this.transform._minEleveationForCurrentTile = this.terrain.getMinTileElevationForLngLatZoom(this._elevationCenter, this.transform.tileZoom);
const i3 = this.terrain.getElevationForLngLatZoom(this._elevationCenter, this.transform.tileZoom);
if (e2 < 1 && i3 !== this._elevationTarget) {
const t2 = this._elevationTarget - this._elevationStart;
this._elevationStart += e2 * (t2 - (i3 - (t2 * e2 + this._elevationStart)) / (1 - e2)), this._elevationTarget = i3;
}
this.transform.elevation = t.B.number(this._elevationStart, this._elevationTarget, e2);
}
_finalizeElevation() {
this._elevationFreeze = false, this.transform.recalculateZoom(this.terrain);
}
_getTransformForUpdate() {
return this.transformCameraUpdate ? (this._requestedCameraState || (this._requestedCameraState = this.transform.clone()), this._requestedCameraState) : this.transform;
}
_applyUpdatedTransform(t2) {
if (!this.transformCameraUpdate) return;
const e2 = t2.clone(), { center: i3, zoom: s2, pitch: a2, bearing: o2, elevation: r2 } = this.transformCameraUpdate(e2);
i3 && (e2.center = i3), void 0 !== s2 && (e2.zoom = s2), void 0 !== a2 && (e2.pitch = a2), void 0 !== o2 && (e2.bearing = o2), void 0 !== r2 && (e2.elevation = r2), this.transform.apply(e2);
}
_fireMoveEvents(e2) {
this.fire(new t.k("move", e2)), this._zooming && this.fire(new t.k("zoom", e2)), this._rotating && this.fire(new t.k("rotate", e2)), this._pitching && this.fire(new t.k("pitch", e2));
}
_afterEase(e2, i3) {
if (this._easeId && i3 && this._easeId === i3) return;
delete this._easeId;
const s2 = this._zooming, a2 = this._rotating, o2 = this._pitching;
this._moving = false, this._zooming = false, this._rotating = false, this._pitching = false, this._padding = false, s2 && this.fire(new t.k("zoomend", e2)), a2 && this.fire(new t.k("rotateend", e2)), o2 && this.fire(new t.k("pitchend", e2)), this.fire(new t.k("moveend", e2));
}
flyTo(e2, i3) {
if (!e2.essential && t.h.prefersReducedMotion) {
const s3 = t.F(e2, ["center", "zoom", "bearing", "pitch", "around"]);
return this.jumpTo(s3, i3);
}
this.stop(), e2 = t.e({ offset: [0, 0], speed: 1.2, curve: 1.42, easing: t.bb }, e2);
const s2 = this._getTransformForUpdate(), a2 = this.getZoom(), o2 = this.getBearing(), r2 = this.getPitch(), n2 = this.getPadding(), l2 = "zoom" in e2 ? t.ad(+e2.zoom, s2.minZoom, s2.maxZoom) : a2, h2 = "bearing" in e2 ? this._normalizeBearing(e2.bearing, o2) : o2, c2 = "pitch" in e2 ? +e2.pitch : r2, u2 = "padding" in e2 ? e2.padding : s2.padding, d2 = s2.zoomScale(l2 - a2), _2 = t.P.convert(e2.offset);
let p2 = s2.centerPoint.add(_2);
const m2 = s2.pointLocation(p2), f2 = t.L.convert(e2.center || m2);
this._normalizeCenter(f2);
const g2 = s2.project(m2), v2 = s2.project(f2).sub(g2);
let x2 = e2.curve;
const y2 = Math.max(s2.width, s2.height), b2 = y2 / d2, w2 = v2.mag();
if ("minZoom" in e2) {
const i4 = t.ad(Math.min(e2.minZoom, a2, l2), s2.minZoom, s2.maxZoom), o3 = y2 / s2.zoomScale(i4 - a2);
x2 = Math.sqrt(o3 / w2 * 2);
}
const T2 = x2 * x2;
function I2(t2) {
const e3 = (b2 * b2 - y2 * y2 + (t2 ? -1 : 1) * T2 * T2 * w2 * w2) / (2 * (t2 ? b2 : y2) * T2 * w2);
return Math.log(Math.sqrt(e3 * e3 + 1) - e3);
}
function E2(t2) {
return (Math.exp(t2) - Math.exp(-t2)) / 2;
}
function S2(t2) {
return (Math.exp(t2) + Math.exp(-t2)) / 2;
}
const C2 = I2(false);
let P2 = function(t2) {
return S2(C2) / S2(C2 + x2 * t2);
}, D2 = function(t2) {
return y2 * ((S2(C2) * (E2(e3 = C2 + x2 * t2) / S2(e3)) - E2(C2)) / T2) / w2;
var e3;
}, M2 = (I2(true) - C2) / x2;
if (Math.abs(w2) < 1e-6 || !isFinite(M2)) {
if (Math.abs(y2 - b2) < 1e-6) return this.easeTo(e2, i3);
const t2 = b2 < y2 ? -1 : 1;
M2 = Math.abs(Math.log(b2 / y2)) / x2, D2 = function() {
return 0;
}, P2 = function(e3) {
return Math.exp(t2 * x2 * e3);
};
}
return e2.duration = "duration" in e2 ? +e2.duration : 1e3 * M2 / ("screenSpeed" in e2 ? +e2.screenSpeed / x2 : +e2.speed), e2.maxDuration && e2.duration > e2.maxDuration && (e2.duration = 0), this._zooming = true, this._rotating = o2 !== h2, this._pitching = c2 !== r2, this._padding = !s2.isPaddingEqual(u2), this._prepareEase(i3, false), this.terrain && this._prepareElevation(f2), this._ease(((d3) => {
const m3 = d3 * M2, x3 = 1 / P2(m3);
s2.zoom = 1 === d3 ? l2 : a2 + s2.scaleZoom(x3), this._rotating && (s2.bearing = t.B.number(o2, h2, d3)), this._pitching && (s2.pitch = t.B.number(r2, c2, d3)), this._padding && (s2.interpolatePadding(n2, u2, d3), p2 = s2.centerPoint.add(_2)), this.terrain && !e2.freezeElevation && this._updateElevation(d3);
const y3 = 1 === d3 ? f2 : s2.unproject(g2.add(v2.mult(D2(m3))).mult(x3));
s2.setLocationAtPoint(s2.renderWorldCopies ? y3.wrap() : y3, p2), this._applyUpdatedTransform(s2), this._fireMoveEvents(i3);
}), (() => {
this.terrain && this._finalizeElevation(), this._afterEase(i3);
}), e2), this;
}
isEasing() {
return !!this._easeFrameId;
}
stop() {
return this._stop();
}
_stop(t2, e2) {
if (this._easeFrameId && (this._cancelRenderFrame(this._easeFrameId), delete this._easeFrameId, delete this._onEaseFrame), this._onEaseEnd) {
const t3 = this._onEaseEnd;
delete this._onEaseEnd, t3.call(this, e2);
}
if (!t2) {
const t3 = this.handlers;
t3 && t3.stop(false);
}
return this;
}
_ease(e2, i3, s2) {
false === s2.animate || 0 === s2.duration ? (e2(1), i3()) : (this._easeStart = t.h.now(), this._easeOptions = s2, this._onEaseFrame = e2, this._onEaseEnd = i3, this._easeFrameId = this._requestRenderFrame(this._renderFrameCallback));
}
_normalizeBearing(e2, i3) {
e2 = t.b5(e2, -180, 180);
const s2 = Math.abs(e2 - i3);
return Math.abs(e2 - 360 - i3) < s2 && (e2 -= 360), Math.abs(e2 + 360 - i3) < s2 && (e2 += 360), e2;
}
_normalizeCenter(t2) {
const e2 = this.transform;
if (!e2.renderWorldCopies || e2.lngRange) return;
const i3 = t2.lng - e2.center.lng;
t2.lng += i3 > 180 ? -360 : i3 < -180 ? 360 : 0;
}
queryTerrainElevation(e2) {
return this.terrain ? this.terrain.getElevationForLngLatZoom(t.L.convert(e2), this.transform.tileZoom) - this.transform.elevation : null;
}
}
class ra {
constructor(t2 = {}) {
this._toggleAttribution = () => {
this._container.classList.contains("maplibregl-compact") && (this._container.classList.contains("maplibregl-compact-show") ? (this._container.setAttribute("open", ""), this._container.classList.remove("maplibregl-compact-show")) : (this._container.classList.add("maplibregl-compact-show"), this._container.removeAttribute("open")));
}, this._updateData = (t3) => {
!t3 || "metadata" !== t3.sourceDataType && "visibility" !== t3.sourceDataType && "style" !== t3.dataType && "terrain" !== t3.type || this._updateAttributions();
}, this._updateCompact = () => {
this._map.getCanvasContainer().offsetWidth <= 640 || this._compact ? false === this._compact ? this._container.setAttribute("open", "") : this._container.classList.contains("maplibregl-compact") || this._container.classList.contains("maplibregl-attrib-empty") || (this._container.setAttribute("open", ""), this._container.classList.add("maplibregl-compact", "maplibregl-compact-show")) : (this._container.setAttribute("open", ""), this._container.classList.contains("maplibregl-compact") && this._container.classList.remove("maplibregl-compact", "maplibregl-compact-show"));
}, this._updateCompactMinimize = () => {
this._container.classList.contains("maplibregl-compact") && this._container.classList.contains("maplibregl-compact-show") && this._container.classList.remove("maplibregl-compact-show");
}, this.options = t2;
}
getDefaultPosition() {
return "bottom-right";
}
onAdd(t2) {
return this._map = t2, this._compact = this.options && this.options.compact, this._container = i2.create("details", "maplibregl-ctrl maplibregl-ctrl-attrib"), this._compactButton = i2.create("summary", "maplibregl-ctrl-attrib-button", this._container), this._compactButton.addEventListener("click", this._toggleAttribution), this._setElementTitle(this._compactButton, "ToggleAttribution"), this._innerContainer = i2.create("div", "maplibregl-ctrl-attrib-inner", this._container), this._updateAttributions(), this._updateCompact(), this._map.on("styledata", this._updateData), this._map.on("sourcedata", this._updateData), this._map.on("terrain", this._updateData), this._map.on("resize", this._updateCompact), this._map.on("drag", this._updateCompactMinimize), this._container;
}
onRemove() {
i2.remove(this._container), this._map.off("styledata", this._updateData), this._map.off("sourcedata", this._updateData), this._map.off("terrain", this._updateData), this._map.off("resize", this._updateCompact), this._map.off("drag", this._updateCompactMinimize), this._map = void 0, this._compact = void 0, this._attribHTML = void 0;
}
_setElementTitle(t2, e2) {
const i3 = this._map._getUIString(`AttributionControl.${e2}`);
t2.title = i3, t2.setAttribute("aria-label", i3);
}
_updateAttributions() {
if (!this._map.style) return;
let t2 = [];
if (this.options.customAttribution && (Array.isArray(this.options.customAttribution) ? t2 = t2.concat(this.options.customAttribution.map(((t3) => "string" != typeof t3 ? "" : t3))) : "string" == typeof this.options.customAttribution && t2.push(this.options.customAttribution)), this._map.style.stylesheet) {
const t3 = this._map.style.stylesheet;
this.styleOwner = t3.owner, this.styleId = t3.id;
}
const e2 = this._map.style.sourceCaches;
for (const i4 in e2) {
const s2 = e2[i4];
if (s2.used || s2.usedForTerrain) {
const e3 = s2.getSource();
e3.attribution && t2.indexOf(e3.attribution) < 0 && t2.push(e3.attribution);
}
}
t2 = t2.filter(((t3) => String(t3).trim())), t2.sort(((t3, e3) => t3.length - e3.length)), t2 = t2.filter(((e3, i4) => {
for (let s2 = i4 + 1; s2 < t2.length; s2++) if (t2[s2].indexOf(e3) >= 0) return false;
return true;
}));
const i3 = t2.join(" | ");
i3 !== this._attribHTML && (this._attribHTML = i3, t2.length ? (this._innerContainer.innerHTML = i3, this._container.classList.remove("maplibregl-attrib-empty")) : this._container.classList.add("maplibregl-attrib-empty"), this._updateCompact(), this._editLink = null);
}
}
class na {
constructor(t2 = {}) {
this._updateCompact = () => {
const t3 = this._container.children;
if (t3.length) {
const e2 = t3[0];
this._map.getCanvasContainer().offsetWidth <= 640 || this._compact ? false !== this._compact && e2.classList.add("maplibregl-compact") : e2.classList.remove("maplibregl-compact");
}
}, this.options = t2;
}
getDefaultPosition() {
return "bottom-left";
}
onAdd(t2) {
this._map = t2, this._compact = this.options && this.options.compact, this._container = i2.create("div", "maplibregl-ctrl");
const e2 = i2.create("a", "maplibregl-ctrl-logo");
return e2.target = "_blank", e2.rel = "noopener nofollow", e2.href = "https://maplibre.org/", e2.setAttribute("aria-label", this._map._getUIString("LogoControl.Title")), e2.setAttribute("rel", "noopener nofollow"), this._container.appendChild(e2), this._container.style.display = "block", this._map.on("resize", this._updateCompact), this._updateCompact(), this._container;
}
onRemove() {
i2.remove(this._container), this._map.off("resize", this._updateCompact), this._map = void 0, this._compact = void 0;
}
}
class la {
constructor() {
this._queue = [], this._id = 0, this._cleared = false, this._currentlyRunning = false;
}
add(t2) {
const e2 = ++this._id;
return this._queue.push({ callback: t2, id: e2, cancelled: false }), e2;
}
remove(t2) {
const e2 = this._currentlyRunning, i3 = e2 ? this._queue.concat(e2) : this._queue;
for (const e3 of i3) if (e3.id === t2) return void (e3.cancelled = true);
}
run(t2 = 0) {
if (this._currentlyRunning) throw new Error("Attempting to run(), but is already running.");
const e2 = this._currentlyRunning = this._queue;
this._queue = [];
for (const i3 of e2) if (!i3.cancelled && (i3.callback(t2), this._cleared)) break;
this._cleared = false, this._currentlyRunning = false;
}
clear() {
this._currentlyRunning && (this._cleared = true), this._queue = [];
}
}
const ha = { "AttributionControl.ToggleAttribution": "Toggle attribution", "AttributionControl.MapFeedback": "Map feedback", "FullscreenControl.Enter": "Enter fullscreen", "FullscreenControl.Exit": "Exit fullscreen", "GeolocateControl.FindMyLocation": "Find my location", "GeolocateControl.LocationNotAvailable": "Location not available", "LogoControl.Title": "Mapbox logo", "NavigationControl.ResetBearing": "Reset bearing to north", "NavigationControl.ZoomIn": "Zoom in", "NavigationControl.ZoomOut": "Zoom out", "ScaleControl.Feet": "ft", "ScaleControl.Meters": "m", "ScaleControl.Kilometers": "km", "ScaleControl.Miles": "mi", "ScaleControl.NauticalMiles": "nm", "TerrainControl.enableTerrain": "Enable terrain", "TerrainControl.disableTerrain": "Disable terrain" };
var ca = t.Q([{ name: "a_pos3d", type: "Int16", components: 3 }]);
class ua extends t.E {
constructor(t2) {
super(), this.sourceCache = t2, this._tiles = {}, this._renderableTilesKeys = [], this._sourceTileCache = {}, this.minzoom = 0, this.maxzoom = 22, this.tileSize = 512, this.deltaZoom = 1, t2.usedForTerrain = true, t2.tileSize = this.tileSize * 2 ** this.deltaZoom;
}
destruct() {
this.sourceCache.usedForTerrain = false, this.sourceCache.tileSize = null;
}
update(e2, i3) {
this.sourceCache.update(e2, i3), this._renderableTilesKeys = [];
const s2 = {};
for (const a2 of e2.coveringTiles({ tileSize: this.tileSize, minzoom: this.minzoom, maxzoom: this.maxzoom, reparseOverscaled: false, terrain: i3 })) s2[a2.key] = true, this._renderableTilesKeys.push(a2.key), this._tiles[a2.key] || (a2.posMatrix = new Float64Array(16), t.aS(a2.posMatrix, 0, t.N, 0, t.N, 0, 1), this._tiles[a2.key] = new W(a2, this.tileSize));
for (const t2 in this._tiles) s2[t2] || delete this._tiles[t2];
}
freeRtt(t2) {
for (const e2 in this._tiles) {
const i3 = this._tiles[e2];
(!t2 || i3.tileID.equals(t2) || i3.tileID.isChildOf(t2) || t2.isChildOf(i3.tileID)) && (i3.rtt = []);
}
}
getRenderableTiles() {
return this._renderableTilesKeys.map(((t2) => this.getTileByID(t2)));
}
getTileByID(t2) {
return this._tiles[t2];
}
getTerrainCoords(e2) {
const i3 = {};
for (const s2 of this._renderableTilesKeys) {
const a2 = this._tiles[s2].tileID;
if (a2.canonical.equals(e2.canonical)) {
const a3 = e2.clone();
a3.posMatrix = new Float64Array(16), t.aS(a3.posMatrix, 0, t.N, 0, t.N, 0, 1), i3[s2] = a3;
} else if (a2.canonical.isChildOf(e2.canonical)) {
const o2 = e2.clone();
o2.posMatrix = new Float64Array(16);
const r2 = a2.canonical.z - e2.canonical.z, n2 = a2.canonical.x - (a2.canonical.x >> r2 << r2), l2 = a2.canonical.y - (a2.canonical.y >> r2 << r2), h2 = t.N >> r2;
t.aS(o2.posMatrix, 0, h2, 0, h2, 0, 1), t.$(o2.posMatrix, o2.posMatrix, [-n2 * h2, -l2 * h2, 0]), i3[s2] = o2;
} else if (e2.canonical.isChildOf(a2.canonical)) {
const o2 = e2.clone();
o2.posMatrix = new Float64Array(16);
const r2 = e2.canonical.z - a2.canonical.z, n2 = e2.canonical.x - (e2.canonical.x >> r2 << r2), l2 = e2.canonical.y - (e2.canonical.y >> r2 << r2), h2 = t.N >> r2;
t.aS(o2.posMatrix, 0, t.N, 0, t.N, 0, 1), t.$(o2.posMatrix, o2.posMatrix, [n2 * h2, l2 * h2, 0]), t.a0(o2.posMatrix, o2.posMatrix, [1 / 2 ** r2, 1 / 2 ** r2, 0]), i3[s2] = o2;
}
}
return i3;
}
getSourceTile(t2, e2) {
const i3 = this.sourceCache._source;
let s2 = t2.overscaledZ - this.deltaZoom;
if (s2 > i3.maxzoom && (s2 = i3.maxzoom), s2 < i3.minzoom) return null;
this._sourceTileCache[t2.key] || (this._sourceTileCache[t2.key] = t2.scaledTo(s2).key);
let a2 = this.sourceCache.getTileByID(this._sourceTileCache[t2.key]);
if ((!a2 || !a2.dem) && e2) for (; s2 >= i3.minzoom && (!a2 || !a2.dem); ) a2 = this.sourceCache.getTileByID(t2.scaledTo(s2--).key);
return a2;
}
tilesAfterTime(t2 = Date.now()) {
return Object.values(this._tiles).filter(((e2) => e2.timeAdded >= t2));
}
}
class da {
constructor(t2, e2, i3) {
this.painter = t2, this.sourceCache = new ua(e2), this.options = i3, this.exaggeration = "number" == typeof i3.exaggeration ? i3.exaggeration : 1, this.qualityFactor = 2, this.meshSize = 128, this._demMatrixCache = {}, this.coordsIndex = [], this._coordsTextureSize = 1024;
}
getDEMElevation(e2, i3, s2, a2 = t.N) {
var o2;
if (!(i3 >= 0 && i3 < a2 && s2 >= 0 && s2 < a2)) return 0;
const r2 = this.getTerrainData(e2), n2 = null === (o2 = r2.tile) || void 0 === o2 ? void 0 : o2.dem;
if (!n2) return 0;
const l2 = (function(t2, e3, i4) {
var s3 = e3[0], a3 = e3[1];
return t2[0] = i4[0] * s3 + i4[4] * a3 + i4[12], t2[1] = i4[1] * s3 + i4[5] * a3 + i4[13], t2;
})([], [i3 / a2 * t.N, s2 / a2 * t.N], r2.u_terrain_matrix), h2 = [l2[0] * n2.dim, l2[1] * n2.dim], c2 = Math.floor(h2[0]), u2 = Math.floor(h2[1]), d2 = h2[0] - c2, _2 = h2[1] - u2;
return n2.get(c2, u2) * (1 - d2) * (1 - _2) + n2.get(c2 + 1, u2) * d2 * (1 - _2) + n2.get(c2, u2 + 1) * (1 - d2) * _2 + n2.get(c2 + 1, u2 + 1) * d2 * _2;
}
getElevationForLngLatZoom(e2, i3) {
const { tileID: s2, mercatorX: a2, mercatorY: o2 } = this._getOverscaledTileIDFromLngLatZoom(e2, i3);
return this.getElevation(s2, a2 % t.N, o2 % t.N, t.N);
}
getElevation(e2, i3, s2, a2 = t.N) {
return this.getDEMElevation(e2, i3, s2, a2) * this.exaggeration;
}
getTerrainData(e2) {
if (!this._emptyDemTexture) {
const e3 = this.painter.context, i4 = new t.R({ width: 1, height: 1 }, new Uint8Array(4));
this._emptyDepthTexture = new x(e3, i4, e3.gl.RGBA, { premultiply: false }), this._emptyDemUnpack = [0, 0, 0, 0], this._emptyDemTexture = new x(e3, new t.R({ width: 1, height: 1 }), e3.gl.RGBA, { premultiply: false }), this._emptyDemTexture.bind(e3.gl.NEAREST, e3.gl.CLAMP_TO_EDGE), this._emptyDemMatrix = t.ao([]);
}
const i3 = this.sourceCache.getSourceTile(e2, true);
if (i3 && i3.dem && (!i3.demTexture || i3.needsTerrainPrepare)) {
const t2 = this.painter.context;
i3.demTexture = this.painter.getTileTexture(i3.dem.stride), i3.demTexture ? i3.demTexture.update(i3.dem.getPixels(), { premultiply: false }) : i3.demTexture = new x(t2, i3.dem.getPixels(), t2.gl.RGBA, { premultiply: false }), i3.demTexture.bind(t2.gl.NEAREST, t2.gl.CLAMP_TO_EDGE), i3.needsTerrainPrepare = false;
}
const s2 = i3 && i3 + i3.tileID.key + e2.key;
if (s2 && !this._demMatrixCache[s2]) {
const s3 = this.sourceCache.sourceCache._source.maxzoom;
let a2 = e2.canonical.z - i3.tileID.canonical.z;
e2.overscaledZ > e2.canonical.z && (e2.canonical.z >= s3 ? a2 = e2.canonical.z - s3 : t.w("cannot calculate elevation if elevation maxzoom > source.maxzoom"));
const o2 = e2.canonical.x - (e2.canonical.x >> a2 << a2), r2 = e2.canonical.y - (e2.canonical.y >> a2 << a2), n2 = t.bc(new Float64Array(16), [1 / (t.N << a2), 1 / (t.N << a2), 0]);
t.$(n2, n2, [o2 * t.N, r2 * t.N, 0]), this._demMatrixCache[e2.key] = { matrix: n2, coord: e2 };
}
return { u_depth: 2, u_terrain: 3, u_terrain_dim: i3 && i3.dem && i3.dem.dim || 1, u_terrain_matrix: s2 ? this._demMatrixCache[e2.key].matrix : this._emptyDemMatrix, u_terrain_unpack: i3 && i3.dem && i3.dem.getUnpackVector() || this._emptyDemUnpack, u_terrain_exaggeration: this.exaggeration, texture: (i3 && i3.demTexture || this._emptyDemTexture).texture, depthTexture: (this._fboDepthTexture || this._emptyDepthTexture).texture, tile: i3 };
}
getFramebuffer(t2) {
const e2 = this.painter, i3 = e2.width / devicePixelRatio, s2 = e2.height / devicePixelRatio;
return !this._fbo || this._fbo.width === i3 && this._fbo.height === s2 || (this._fbo.destroy(), this._fboCoordsTexture.destroy(), this._fboDepthTexture.destroy(), delete this._fbo, delete this._fboDepthTexture, delete this._fboCoordsTexture), this._fboCoordsTexture || (this._fboCoordsTexture = new x(e2.context, { width: i3, height: s2, data: null }, e2.context.gl.RGBA, { premultiply: false }), this._fboCoordsTexture.bind(e2.context.gl.NEAREST, e2.context.gl.CLAMP_TO_EDGE)), this._fboDepthTexture || (this._fboDepthTexture = new x(e2.context, { width: i3, height: s2, data: null }, e2.context.gl.RGBA, { premultiply: false }), this._fboDepthTexture.bind(e2.context.gl.NEAREST, e2.context.gl.CLAMP_TO_EDGE)), this._fbo || (this._fbo = e2.context.createFramebuffer(i3, s2, true, false), this._fbo.depthAttachment.set(e2.context.createRenderbuffer(e2.context.gl.DEPTH_COMPONENT16, i3, s2))), this._fbo.colorAttachment.set("coords" === t2 ? this._fboCoordsTexture.texture : this._fboDepthTexture.texture), this._fbo;
}
getCoordsTexture() {
const e2 = this.painter.context;
if (this._coordsTexture) return this._coordsTexture;
const i3 = new Uint8Array(this._coordsTextureSize * this._coordsTextureSize * 4);
for (let t2 = 0, e3 = 0; t2 < this._coordsTextureSize; t2++) for (let s3 = 0; s3 < this._coordsTextureSize; s3++, e3 += 4) i3[e3 + 0] = 255 & s3, i3[e3 + 1] = 255 & t2, i3[e3 + 2] = s3 >> 8 << 4 | t2 >> 8, i3[e3 + 3] = 0;
const s2 = new t.R({ width: this._coordsTextureSize, height: this._coordsTextureSize }, new Uint8Array(i3.buffer)), a2 = new x(e2, s2, e2.gl.RGBA, { premultiply: false });
return a2.bind(e2.gl.NEAREST, e2.gl.CLAMP_TO_EDGE), this._coordsTexture = a2, a2;
}
pointCoordinate(e2) {
const i3 = new Uint8Array(4), s2 = this.painter.context, a2 = s2.gl;
s2.bindFramebuffer.set(this.getFramebuffer("coords").framebuffer), a2.readPixels(e2.x, this.painter.height / devicePixelRatio - e2.y - 1, 1, 1, a2.RGBA, a2.UNSIGNED_BYTE, i3), s2.bindFramebuffer.set(null);
const o2 = i3[0] + (i3[2] >> 4 << 8), r2 = i3[1] + ((15 & i3[2]) << 8), n2 = this.coordsIndex[255 - i3[3]], l2 = n2 && this.sourceCache.getTileByID(n2);
if (!l2) return null;
const h2 = this._coordsTextureSize, c2 = (1 << l2.tileID.canonical.z) * h2;
return new t.U(this._allowMercatorOverflow(e2, (l2.tileID.canonical.x * h2 + o2) / c2), (l2.tileID.canonical.y * h2 + r2) / c2, this.getElevation(l2.tileID, o2, r2, h2));
}
getTerrainMesh() {
if (this._mesh) return this._mesh;
const e2 = this.painter.context, i3 = new t.bd(), s2 = new t.b0(), a2 = this.meshSize, o2 = t.N / a2, r2 = a2 * a2;
for (let t2 = 0; t2 <= a2; t2++) for (let e3 = 0; e3 <= a2; e3++) i3.emplaceBack(e3 * o2, t2 * o2, 0);
for (let t2 = 0; t2 < r2; t2 += a2 + 1) for (let e3 = 0; e3 < a2; e3++) s2.emplaceBack(e3 + t2, a2 + e3 + t2 + 1, a2 + e3 + t2 + 2), s2.emplaceBack(e3 + t2, a2 + e3 + t2 + 2, e3 + t2 + 1);
const n2 = i3.length, l2 = n2 + 2 * (a2 + 1);
for (const e3 of [0, 1]) for (let s3 = 0; s3 <= a2; s3++) for (const a3 of [0, 1]) i3.emplaceBack(s3 * o2, e3 * t.N, a3);
for (let t2 = 0; t2 < 2 * a2; t2 += 2) s2.emplaceBack(l2 + t2, l2 + t2 + 1, l2 + t2 + 3), s2.emplaceBack(l2 + t2, l2 + t2 + 3, l2 + t2 + 2), s2.emplaceBack(n2 + t2, n2 + t2 + 3, n2 + t2 + 1), s2.emplaceBack(n2 + t2, n2 + t2 + 2, n2 + t2 + 3);
const h2 = i3.length, c2 = h2 + 2 * (a2 + 1);
for (const e3 of [0, 1]) for (let s3 = 0; s3 <= a2; s3++) for (const a3 of [0, 1]) i3.emplaceBack(e3 * t.N, s3 * o2, a3);
for (let t2 = 0; t2 < 2 * a2; t2 += 2) s2.emplaceBack(h2 + t2, h2 + t2 + 1, h2 + t2 + 3), s2.emplaceBack(h2 + t2, h2 + t2 + 3, h2 + t2 + 2), s2.emplaceBack(c2 + t2, c2 + t2 + 3, c2 + t2 + 1), s2.emplaceBack(c2 + t2, c2 + t2 + 2, c2 + t2 + 3);
return this._mesh = { indexBuffer: e2.createIndexBuffer(s2), vertexBuffer: e2.createVertexBuffer(i3, ca.members), segments: t.S.simpleSegment(0, 0, i3.length, s2.length) }, this._mesh;
}
getMeshFrameDelta(e2) {
return 2 * Math.PI * t.be / Math.pow(2, e2) / 5;
}
getMinTileElevationForLngLatZoom(t2, e2) {
var i3;
const { tileID: s2 } = this._getOverscaledTileIDFromLngLatZoom(t2, e2);
return null !== (i3 = this.getMinMaxElevation(s2).minElevation) && void 0 !== i3 ? i3 : 0;
}
getMinMaxElevation(t2) {
const e2 = this.getTerrainData(t2).tile, i3 = { minElevation: null, maxElevation: null };
return e2 && e2.dem && (i3.minElevation = e2.dem.min * this.exaggeration, i3.maxElevation = e2.dem.max * this.exaggeration), i3;
}
_getOverscaledTileIDFromLngLatZoom(e2, i3) {
const s2 = t.U.fromLngLat(e2.wrap()), a2 = (1 << i3) * t.N, o2 = s2.x * a2, r2 = s2.y * a2, n2 = Math.floor(o2 / t.N), l2 = Math.floor(r2 / t.N);
return { tileID: new t.O(i3, 0, i3, n2, l2), mercatorX: o2, mercatorY: r2 };
}
_allowMercatorOverflow(e2, i3) {
const s2 = e2.x < this.painter.width / 2;
let a2 = t.bf(i3);
const o2 = this.painter.transform.center.lng;
return s2 && Math.sign(a2) > 0 && Math.sign(o2) < 0 || !s2 && Math.sign(a2) < 0 && Math.sign(o2) > 0 ? (a2 = 360 * Math.sign(o2) + a2, t.G(a2)) : i3;
}
}
class _a {
constructor(t2, e2, i3) {
this._context = t2, this._size = e2, this._tileSize = i3, this._objects = [], this._recentlyUsed = [], this._stamp = 0;
}
destruct() {
for (const t2 of this._objects) t2.texture.destroy(), t2.fbo.destroy();
}
_createObject(t2) {
const e2 = this._context.createFramebuffer(this._tileSize, this._tileSize, true, true), i3 = new x(this._context, { width: this._tileSize, height: this._tileSize, data: null }, this._context.gl.RGBA);
return i3.bind(this._context.gl.LINEAR, this._context.gl.CLAMP_TO_EDGE), e2.depthAttachment.set(this._context.createRenderbuffer(this._context.gl.DEPTH_STENCIL, this._tileSize, this._tileSize)), e2.colorAttachment.set(i3.texture), { id: t2, fbo: e2, texture: i3, stamp: -1, inUse: false };
}
getObjectForId(t2) {
return this._objects[t2];
}
useObject(t2) {
t2.inUse = true, this._recentlyUsed = this._recentlyUsed.filter(((e2) => t2.id !== e2)), this._recentlyUsed.push(t2.id);
}
stampObject(t2) {
t2.stamp = ++this._stamp;
}
getOrCreateFreeObject() {
for (const t3 of this._recentlyUsed) if (!this._objects[t3].inUse) return this._objects[t3];
if (this._objects.length >= this._size) throw new Error("No free RenderPool available, call freeAllObjects() required!");
const t2 = this._createObject(this._objects.length);
return this._objects.push(t2), t2;
}
freeObject(t2) {
t2.inUse = false;
}
freeAllObjects() {
for (const t2 of this._objects) this.freeObject(t2);
}
isFull() {
return !(this._objects.length < this._size) && false === this._objects.some(((t2) => !t2.inUse));
}
}
const pa = { background: true, fill: true, line: true, raster: true, hillshade: true };
class ma {
constructor(t2, e2) {
this.painter = t2, this.terrain = e2, this.pool = new _a(t2.context, 30, e2.sourceCache.tileSize * e2.qualityFactor);
}
destruct() {
this.pool.destruct();
}
getTexture(t2) {
return this.pool.getObjectForId(t2.rtt[this._stacks.length - 1].id).texture;
}
prepareForRender(t2, e2) {
this._stacks = [], this._prevType = null, this._rttTiles = [], this._renderableTiles = this.terrain.sourceCache.getRenderableTiles(), this._renderableLayerIds = t2._order.filter(((i3) => !t2._layers[i3].isHidden(e2))), this._coordsDescendingInv = {};
for (const e3 in t2.sourceCaches) {
this._coordsDescendingInv[e3] = {};
const i3 = t2.sourceCaches[e3].getVisibleCoordinates();
for (const t3 of i3) {
const i4 = this.terrain.sourceCache.getTerrainCoords(t3);
for (const t4 in i4) this._coordsDescendingInv[e3][t4] || (this._coordsDescendingInv[e3][t4] = []), this._coordsDescendingInv[e3][t4].push(i4[t4]);
}
}
this._coordsDescendingInvStr = {};
for (const e3 of t2._order) {
const i3 = t2._layers[e3], s2 = i3.source;
if (pa[i3.type] && !this._coordsDescendingInvStr[s2]) {
this._coordsDescendingInvStr[s2] = {};
for (const t3 in this._coordsDescendingInv[s2]) this._coordsDescendingInvStr[s2][t3] = this._coordsDescendingInv[s2][t3].map(((t4) => t4.key)).sort().join();
}
}
for (const t3 of this._renderableTiles) for (const e3 in this._coordsDescendingInvStr) {
const i3 = this._coordsDescendingInvStr[e3][t3.tileID.key];
i3 && i3 !== t3.rttCoords[e3] && (t3.rtt = []);
}
}
renderLayer(e2) {
if (e2.isHidden(this.painter.transform.zoom)) return false;
const i3 = e2.type, s2 = this.painter, a2 = this._renderableLayerIds[this._renderableLayerIds.length - 1] === e2.id;
if (pa[i3] && (this._prevType && pa[this._prevType] || this._stacks.push([]), this._prevType = i3, this._stacks[this._stacks.length - 1].push(e2.id), !a2)) return true;
if (pa[this._prevType] || pa[i3] && a2) {
this._prevType = i3;
const e3 = this._stacks.length - 1, a3 = this._stacks[e3] || [];
for (const i4 of this._renderableTiles) {
if (this.pool.isFull() && (es(this.painter, this.terrain, this._rttTiles), this._rttTiles = [], this.pool.freeAllObjects()), this._rttTiles.push(i4), i4.rtt[e3]) {
const t2 = this.pool.getObjectForId(i4.rtt[e3].id);
if (t2.stamp === i4.rtt[e3].stamp) {
this.pool.useObject(t2);
continue;
}
}
const o2 = this.pool.getOrCreateFreeObject();
this.pool.useObject(o2), this.pool.stampObject(o2), i4.rtt[e3] = { id: o2.id, stamp: o2.stamp }, s2.context.bindFramebuffer.set(o2.fbo.framebuffer), s2.context.clear({ color: t.aT.transparent, stencil: 0 }), s2.currentStencilSource = void 0;
for (let t2 = 0; t2 < a3.length; t2++) {
const e4 = s2.style._layers[a3[t2]], r2 = e4.source ? this._coordsDescendingInv[e4.source][i4.tileID.key] : [i4.tileID];
s2.context.viewport.set([0, 0, o2.fbo.width, o2.fbo.height]), s2._renderTileClippingMasks(e4, r2), s2.renderLayer(s2, s2.style.sourceCaches[e4.source], e4, r2), e4.source && (i4.rttCoords[e4.source] = this._coordsDescendingInvStr[e4.source][i4.tileID.key]);
}
}
return es(this.painter, this.terrain, this._rttTiles), this._rttTiles = [], this.pool.freeAllObjects(), pa[i3];
}
return false;
}
}
const fa = e, ga = { center: [0, 0], zoom: 0, bearing: 0, pitch: 0, minZoom: -2, maxZoom: 22, minPitch: 0, maxPitch: 60, interactive: true, scrollZoom: true, boxZoom: true, dragRotate: true, dragPan: true, keyboard: true, doubleClickZoom: true, touchZoomRotate: true, touchPitch: true, cooperativeGestures: void 0, bearingSnap: 7, clickTolerance: 3, pitchWithRotate: true, hash: false, attributionControl: true, maplibreLogo: false, failIfMajorPerformanceCaveat: false, preserveDrawingBuffer: false, trackResize: true, renderWorldCopies: true, refreshExpiredTiles: true, maxTileCacheSize: null, maxTileCacheZoomLevels: t.c.MAX_TILE_CACHE_ZOOM_LEVELS, localIdeographFontFamily: "sans-serif", transformRequest: null, transformCameraUpdate: null, fadeDuration: 300, crossSourceCollisions: true, validateStyle: true, maxCanvasSize: [4096, 4096] }, va = (t2) => {
t2.touchstart = t2.dragStart, t2.touchmoveWindow = t2.dragMove, t2.touchend = t2.dragEnd;
}, xa = { showCompass: true, showZoom: true, visualizePitch: false };
class ya {
constructor(e2, s2, a2 = false) {
this.mousedown = (e3) => {
this.startMouse(t.e({}, e3, { ctrlKey: true, preventDefault: () => e3.preventDefault() }), i2.mousePos(this.element, e3)), i2.addEventListener(window, "mousemove", this.mousemove), i2.addEventListener(window, "mouseup", this.mouseup);
}, this.mousemove = (t2) => {
this.moveMouse(t2, i2.mousePos(this.element, t2));
}, this.mouseup = (t2) => {
this.mouseRotate.dragEnd(t2), this.mousePitch && this.mousePitch.dragEnd(t2), this.offTemp();
}, this.touchstart = (t2) => {
1 !== t2.targetTouches.length ? this.reset() : (this._startPos = this._lastPos = i2.touchPos(this.element, t2.targetTouches)[0], this.startTouch(t2, this._startPos), i2.addEventListener(window, "touchmove", this.touchmove, { passive: false }), i2.addEventListener(window, "touchend", this.touchend));
}, this.touchmove = (t2) => {
1 !== t2.targetTouches.length ? this.reset() : (this._lastPos = i2.touchPos(this.element, t2.targetTouches)[0], this.moveTouch(t2, this._lastPos));
}, this.touchend = (t2) => {
0 === t2.targetTouches.length && this._startPos && this._lastPos && this._startPos.dist(this._lastPos) < this._clickTolerance && this.element.click(), delete this._startPos, delete this._lastPos, this.offTemp();
}, this.reset = () => {
this.mouseRotate.reset(), this.mousePitch && this.mousePitch.reset(), this.touchRotate.reset(), this.touchPitch && this.touchPitch.reset(), delete this._startPos, delete this._lastPos, this.offTemp();
}, this._clickTolerance = 10;
const o2 = e2.dragRotate._mouseRotate.getClickTolerance(), r2 = e2.dragRotate._mousePitch.getClickTolerance();
this.element = s2, this.mouseRotate = As({ clickTolerance: o2, enable: true }), this.touchRotate = (({ enable: t2, clickTolerance: e3, bearingDegreesPerPixelMoved: i3 = 0.8 }) => {
const s3 = new zs();
return new Ps({ clickTolerance: e3, move: (t3, e4) => ({ bearingDelta: (e4.x - t3.x) * i3 }), moveStateManager: s3, enable: t2, assignEvents: va });
})({ clickTolerance: o2, enable: true }), this.map = e2, a2 && (this.mousePitch = Rs({ clickTolerance: r2, enable: true }), this.touchPitch = (({ enable: t2, clickTolerance: e3, pitchDegreesPerPixelMoved: i3 = -0.5 }) => {
const s3 = new zs();
return new Ps({ clickTolerance: e3, move: (t3, e4) => ({ pitchDelta: (e4.y - t3.y) * i3 }), moveStateManager: s3, enable: t2, assignEvents: va });
})({ clickTolerance: r2, enable: true })), i2.addEventListener(s2, "mousedown", this.mousedown), i2.addEventListener(s2, "touchstart", this.touchstart, { passive: false }), i2.addEventListener(s2, "touchcancel", this.reset);
}
startMouse(t2, e2) {
this.mouseRotate.dragStart(t2, e2), this.mousePitch && this.mousePitch.dragStart(t2, e2), i2.disableDrag();
}
startTouch(t2, e2) {
this.touchRotate.dragStart(t2, e2), this.touchPitch && this.touchPitch.dragStart(t2, e2), i2.disableDrag();
}
moveMouse(t2, e2) {
const i3 = this.map, { bearingDelta: s2 } = this.mouseRotate.dragMove(t2, e2) || {};
if (s2 && i3.setBearing(i3.getBearing() + s2), this.mousePitch) {
const { pitchDelta: s3 } = this.mousePitch.dragMove(t2, e2) || {};
s3 && i3.setPitch(i3.getPitch() + s3);
}
}
moveTouch(t2, e2) {
const i3 = this.map, { bearingDelta: s2 } = this.touchRotate.dragMove(t2, e2) || {};
if (s2 && i3.setBearing(i3.getBearing() + s2), this.touchPitch) {
const { pitchDelta: s3 } = this.touchPitch.dragMove(t2, e2) || {};
s3 && i3.setPitch(i3.getPitch() + s3);
}
}
off() {
const t2 = this.element;
i2.removeEventListener(t2, "mousedown", this.mousedown), i2.removeEventListener(t2, "touchstart", this.touchstart, { passive: false }), i2.removeEventListener(window, "touchmove", this.touchmove, { passive: false }), i2.removeEventListener(window, "touchend", this.touchend), i2.removeEventListener(t2, "touchcancel", this.reset), this.offTemp();
}
offTemp() {
i2.enableDrag(), i2.removeEventListener(window, "mousemove", this.mousemove), i2.removeEventListener(window, "mouseup", this.mouseup), i2.removeEventListener(window, "touchmove", this.touchmove, { passive: false }), i2.removeEventListener(window, "touchend", this.touchend);
}
}
let ba;
function wa(e2, i3, s2) {
if (e2 = new t.L(e2.lng, e2.lat), i3) {
const a2 = new t.L(e2.lng - 360, e2.lat), o2 = new t.L(e2.lng + 360, e2.lat), r2 = s2.locationPoint(e2).distSqr(i3);
s2.locationPoint(a2).distSqr(i3) < r2 ? e2 = a2 : s2.locationPoint(o2).distSqr(i3) < r2 && (e2 = o2);
}
for (; Math.abs(e2.lng - s2.center.lng) > 180; ) {
const t2 = s2.locationPoint(e2);
if (t2.x >= 0 && t2.y >= 0 && t2.x <= s2.width && t2.y <= s2.height) break;
e2.lng > s2.center.lng ? e2.lng -= 360 : e2.lng += 360;
}
return e2;
}
const Ta = { center: "translate(-50%,-50%)", top: "translate(-50%,0)", "top-left": "translate(0,0)", "top-right": "translate(-100%,0)", bottom: "translate(-50%,-100%)", "bottom-left": "translate(0,-100%)", "bottom-right": "translate(-100%,-100%)", left: "translate(0,-50%)", right: "translate(-100%,-50%)" };
function Ia(t2, e2, i3) {
const s2 = t2.classList;
for (const t3 in Ta) s2.remove(`maplibregl-${i3}-anchor-${t3}`);
s2.add(`maplibregl-${i3}-anchor-${e2}`);
}
class Ea extends t.E {
constructor(e2) {
if (super(), this._onKeyPress = (t2) => {
const e3 = t2.code, i3 = t2.charCode || t2.keyCode;
"Space" !== e3 && "Enter" !== e3 && 32 !== i3 && 13 !== i3 || this.togglePopup();
}, this._onMapClick = (t2) => {
const e3 = t2.originalEvent.target, i3 = this._element;
this._popup && (e3 === i3 || i3.contains(e3)) && this.togglePopup();
}, this._update = (t2) => {
if (!this._map) return;
const e3 = this._map.loaded() && !this._map.isMoving();
("terrain" === (null == t2 ? void 0 : t2.type) || "render" === (null == t2 ? void 0 : t2.type) && !e3) && this._map.once("render", this._update), this._map.transform.renderWorldCopies && (this._lngLat = wa(this._lngLat, this._pos, this._map.transform)), this._pos = this._map.project(this._lngLat)._add(this._offset);
let s2 = "";
"viewport" === this._rotationAlignment || "auto" === this._rotationAlignment ? s2 = `rotateZ(${this._rotation}deg)` : "map" === this._rotationAlignment && (s2 = `rotateZ(${this._rotation - this._map.getBearing()}deg)`);
let a2 = "";
"viewport" === this._pitchAlignment || "auto" === this._pitchAlignment ? a2 = "rotateX(0deg)" : "map" === this._pitchAlignment && (a2 = `rotateX(${this._map.getPitch()}deg)`), t2 && "moveend" !== t2.type || (this._pos = this._pos.round()), i2.setTransform(this._element, `${Ta[this._anchor]} translate(${this._pos.x}px, ${this._pos.y}px) ${a2} ${s2}`), this._map.terrain && !this._opacityTimeout && (this._opacityTimeout = setTimeout((() => {
const t3 = this._map.unproject(this._pos), e4 = 40075016686e-3 * Math.abs(Math.cos(this._lngLat.lat * Math.PI / 180)) / Math.pow(2, this._map.transform.tileZoom + 8);
this._element.style.opacity = t3.distanceTo(this._lngLat) > 20 * e4 ? "0.2" : "1.0", this._opacityTimeout = null;
}), 100));
}, this._onMove = (e3) => {
if (!this._isDragging) {
const t2 = this._clickTolerance || this._map._clickTolerance;
this._isDragging = e3.point.dist(this._pointerdownPos) >= t2;
}
this._isDragging && (this._pos = e3.point.sub(this._positionDelta), this._lngLat = this._map.unproject(this._pos), this.setLngLat(this._lngLat), this._element.style.pointerEvents = "none", "pending" === this._state && (this._state = "active", this.fire(new t.k("dragstart"))), this.fire(new t.k("drag")));
}, this._onUp = () => {
this._element.style.pointerEvents = "auto", this._positionDelta = null, this._pointerdownPos = null, this._isDragging = false, this._map.off("mousemove", this._onMove), this._map.off("touchmove", this._onMove), "active" === this._state && this.fire(new t.k("dragend")), this._state = "inactive";
}, this._addDragHandler = (t2) => {
this._element.contains(t2.originalEvent.target) && (t2.preventDefault(), this._positionDelta = t2.point.sub(this._pos).add(this._offset), this._pointerdownPos = t2.point, this._state = "pending", this._map.on("mousemove", this._onMove), this._map.on("touchmove", this._onMove), this._map.once("mouseup", this._onUp), this._map.once("touchend", this._onUp));
}, this._anchor = e2 && e2.anchor || "center", this._color = e2 && e2.color || "#3FB1CE", this._scale = e2 && e2.scale || 1, this._draggable = e2 && e2.draggable || false, this._clickTolerance = e2 && e2.clickTolerance || 0, this._isDragging = false, this._state = "inactive", this._rotation = e2 && e2.rotation || 0, this._rotationAlignment = e2 && e2.rotationAlignment || "auto", this._pitchAlignment = e2 && e2.pitchAlignment && "auto" !== e2.pitchAlignment ? e2.pitchAlignment : this._rotationAlignment, e2 && e2.element) this._element = e2.element, this._offset = t.P.convert(e2 && e2.offset || [0, 0]);
else {
this._defaultMarker = true, this._element = i2.create("div"), this._element.setAttribute("aria-label", "Map marker");
const s2 = i2.createNS("http://www.w3.org/2000/svg", "svg"), a2 = 41, o2 = 27;
s2.setAttributeNS(null, "display", "block"), s2.setAttributeNS(null, "height", `${a2}px`), s2.setAttributeNS(null, "width", `${o2}px`), s2.setAttributeNS(null, "viewBox", `0 0 ${o2} ${a2}`);
const r2 = i2.createNS("http://www.w3.org/2000/svg", "g");
r2.setAttributeNS(null, "stroke", "none"), r2.setAttributeNS(null, "stroke-width", "1"), r2.setAttributeNS(null, "fill", "none"), r2.setAttributeNS(null, "fill-rule", "evenodd");
const n2 = i2.createNS("http://www.w3.org/2000/svg", "g");
n2.setAttributeNS(null, "fill-rule", "nonzero");
const l2 = i2.createNS("http://www.w3.org/2000/svg", "g");
l2.setAttributeNS(null, "transform", "translate(3.0, 29.0)"), l2.setAttributeNS(null, "fill", "#000000");
const h2 = [{ rx: "10.5", ry: "5.25002273" }, { rx: "10.5", ry: "5.25002273" }, { rx: "9.5", ry: "4.77275007" }, { rx: "8.5", ry: "4.29549936" }, { rx: "7.5", ry: "3.81822308" }, { rx: "6.5", ry: "3.34094679" }, { rx: "5.5", ry: "2.86367051" }, { rx: "4.5", ry: "2.38636864" }];
for (const t2 of h2) {
const e3 = i2.createNS("http://www.w3.org/2000/svg", "ellipse");
e3.setAttributeNS(null, "opacity", "0.04"), e3.setAttributeNS(null, "cx", "10.5"), e3.setAttributeNS(null, "cy", "5.80029008"), e3.setAttributeNS(null, "rx", t2.rx), e3.setAttributeNS(null, "ry", t2.ry), l2.appendChild(e3);
}
const c2 = i2.createNS("http://www.w3.org/2000/svg", "g");
c2.setAttributeNS(null, "fill", this._color);
const u2 = i2.createNS("http://www.w3.org/2000/svg", "path");
u2.setAttributeNS(null, "d", "M27,13.5 C27,19.074644 20.250001,27.000002 14.75,34.500002 C14.016665,35.500004 12.983335,35.500004 12.25,34.500002 C6.7499993,27.000002 0,19.222562 0,13.5 C0,6.0441559 6.0441559,0 13.5,0 C20.955844,0 27,6.0441559 27,13.5 Z"), c2.appendChild(u2);
const d2 = i2.createNS("http://www.w3.org/2000/svg", "g");
d2.setAttributeNS(null, "opacity", "0.25"), d2.setAttributeNS(null, "fill", "#000000");
const _2 = i2.createNS("http://www.w3.org/2000/svg", "path");
_2.setAttributeNS(null, "d", "M13.5,0 C6.0441559,0 0,6.0441559 0,13.5 C0,19.222562 6.7499993,27 12.25,34.5 C13,35.522727 14.016664,35.500004 14.75,34.5 C20.250001,27 27,19.074644 27,13.5 C27,6.0441559 20.955844,0 13.5,0 Z M13.5,1 C20.415404,1 26,6.584596 26,13.5 C26,15.898657 24.495584,19.181431 22.220703,22.738281 C19.945823,26.295132 16.705119,30.142167 13.943359,33.908203 C13.743445,34.180814 13.612715,34.322738 13.5,34.441406 C13.387285,34.322738 13.256555,34.180814 13.056641,33.908203 C10.284481,30.127985 7.4148684,26.314159 5.015625,22.773438 C2.6163816,19.232715 1,15.953538 1,13.5 C1,6.584596 6.584596,1 13.5,1 Z"), d2.appendChild(_2);
const p2 = i2.createNS("http://www.w3.org/2000/svg", "g");
p2.setAttributeNS(null, "transform", "translate(6.0, 7.0)"), p2.setAttributeNS(null, "fill", "#FFFFFF");
const m2 = i2.createNS("http://www.w3.org/2000/svg", "g");
m2.setAttributeNS(null, "transform", "translate(8.0, 8.0)");
const f2 = i2.createNS("http://www.w3.org/2000/svg", "circle");
f2.setAttributeNS(null, "fill", "#000000"), f2.setAttributeNS(null, "opacity", "0.25"), f2.setAttributeNS(null, "cx", "5.5"), f2.setAttributeNS(null, "cy", "5.5"), f2.setAttributeNS(null, "r", "5.4999962");
const g2 = i2.createNS("http://www.w3.org/2000/svg", "circle");
g2.setAttributeNS(null, "fill", "#FFFFFF"), g2.setAttributeNS(null, "cx", "5.5"), g2.setAttributeNS(null, "cy", "5.5"), g2.setAttributeNS(null, "r", "5.4999962"), m2.appendChild(f2), m2.appendChild(g2), n2.appendChild(l2), n2.appendChild(c2), n2.appendChild(d2), n2.appendChild(p2), n2.appendChild(m2), s2.appendChild(n2), s2.setAttributeNS(null, "height", a2 * this._scale + "px"), s2.setAttributeNS(null, "width", o2 * this._scale + "px"), this._element.appendChild(s2), this._offset = t.P.convert(e2 && e2.offset || [0, -14]);
}
if (this._element.classList.add("maplibregl-marker"), this._element.addEventListener("dragstart", ((t2) => {
t2.preventDefault();
})), this._element.addEventListener("mousedown", ((t2) => {
t2.preventDefault();
})), Ia(this._element, this._anchor, "marker"), e2 && e2.className) for (const t2 of e2.className.split(" ")) this._element.classList.add(t2);
this._popup = null;
}
addTo(t2) {
return this.remove(), this._map = t2, t2.getCanvasContainer().appendChild(this._element), t2.on("move", this._update), t2.on("moveend", this._update), t2.on("terrain", this._update), this.setDraggable(this._draggable), this._update(), this._map.on("click", this._onMapClick), this;
}
remove() {
return this._opacityTimeout && (clearTimeout(this._opacityTimeout), delete this._opacityTimeout), this._map && (this._map.off("click", this._onMapClick), this._map.off("move", this._update), this._map.off("moveend", this._update), this._map.off("mousedown", this._addDragHandler), this._map.off("touchstart", this._addDragHandler), this._map.off("mouseup", this._onUp), this._map.off("touchend", this._onUp), this._map.off("mousemove", this._onMove), this._map.off("touchmove", this._onMove), delete this._map), i2.remove(this._element), this._popup && this._popup.remove(), this;
}
getLngLat() {
return this._lngLat;
}
setLngLat(e2) {
return this._lngLat = t.L.convert(e2), this._pos = null, this._popup && this._popup.setLngLat(this._lngLat), this._update(), this;
}
getElement() {
return this._element;
}
setPopup(t2) {
if (this._popup && (this._popup.remove(), this._popup = null, this._element.removeEventListener("keypress", this._onKeyPress), this._originalTabIndex || this._element.removeAttribute("tabindex")), t2) {
if (!("offset" in t2.options)) {
const e2 = 38.1, i3 = 13.5, s2 = Math.abs(i3) / Math.SQRT2;
t2.options.offset = this._defaultMarker ? { top: [0, 0], "top-left": [0, 0], "top-right": [0, 0], bottom: [0, -e2], "bottom-left": [s2, -1 * (e2 - i3 + s2)], "bottom-right": [-s2, -1 * (e2 - i3 + s2)], left: [i3, -1 * (e2 - i3)], right: [-i3, -1 * (e2 - i3)] } : this._offset;
}
this._popup = t2, this._lngLat && this._popup.setLngLat(this._lngLat), this._originalTabIndex = this._element.getAttribute("tabindex"), this._originalTabIndex || this._element.setAttribute("tabindex", "0"), this._element.addEventListener("keypress", this._onKeyPress);
}
return this;
}
getPopup() {
return this._popup;
}
togglePopup() {
const t2 = this._popup;
return t2 ? (t2.isOpen() ? t2.remove() : t2.addTo(this._map), this) : this;
}
getOffset() {
return this._offset;
}
setOffset(e2) {
return this._offset = t.P.convert(e2), this._update(), this;
}
addClassName(t2) {
this._element.classList.add(t2);
}
removeClassName(t2) {
this._element.classList.remove(t2);
}
toggleClassName(t2) {
return this._element.classList.toggle(t2);
}
setDraggable(t2) {
return this._draggable = !!t2, this._map && (t2 ? (this._map.on("mousedown", this._addDragHandler), this._map.on("touchstart", this._addDragHandler)) : (this._map.off("mousedown", this._addDragHandler), this._map.off("touchstart", this._addDragHandler))), this;
}
isDraggable() {
return this._draggable;
}
setRotation(t2) {
return this._rotation = t2 || 0, this._update(), this;
}
getRotation() {
return this._rotation;
}
setRotationAlignment(t2) {
return this._rotationAlignment = t2 || "auto", this._update(), this;
}
getRotationAlignment() {
return this._rotationAlignment;
}
setPitchAlignment(t2) {
return this._pitchAlignment = t2 && "auto" !== t2 ? t2 : this._rotationAlignment, this._update(), this;
}
getPitchAlignment() {
return this._pitchAlignment;
}
}
const Sa = { positionOptions: { enableHighAccuracy: false, maximumAge: 0, timeout: 6e3 }, fitBoundsOptions: { maxZoom: 15 }, trackUserLocation: false, showAccuracyCircle: true, showUserLocation: true };
let Ca = 0, Pa = false;
const Da = { maxWidth: 100, unit: "metric" };
function Ma(t2, e2, i3) {
const s2 = i3 && i3.maxWidth || 100, a2 = t2._container.clientHeight / 2, o2 = t2.unproject([0, a2]), r2 = t2.unproject([s2, a2]), n2 = o2.distanceTo(r2);
if (i3 && "imperial" === i3.unit) {
const i4 = 3.2808 * n2;
i4 > 5280 ? za(e2, s2, i4 / 5280, t2._getUIString("ScaleControl.Miles")) : za(e2, s2, i4, t2._getUIString("ScaleControl.Feet"));
} else i3 && "nautical" === i3.unit ? za(e2, s2, n2 / 1852, t2._getUIString("ScaleControl.NauticalMiles")) : n2 >= 1e3 ? za(e2, s2, n2 / 1e3, t2._getUIString("ScaleControl.Kilometers")) : za(e2, s2, n2, t2._getUIString("ScaleControl.Meters"));
}
function za(t2, e2, i3, s2) {
const a2 = (function(t3) {
const e3 = Math.pow(10, `${Math.floor(t3)}`.length - 1);
let i4 = t3 / e3;
return i4 = i4 >= 10 ? 10 : i4 >= 5 ? 5 : i4 >= 3 ? 3 : i4 >= 2 ? 2 : i4 >= 1 ? 1 : (function(t4) {
const e4 = Math.pow(10, Math.ceil(-Math.log(t4) / Math.LN10));
return Math.round(t4 * e4) / e4;
})(i4), e3 * i4;
})(i3);
t2.style.width = e2 * (a2 / i3) + "px", t2.innerHTML = `${a2}&nbsp;${s2}`;
}
const La = { closeButton: true, closeOnClick: true, focusAfterOpen: true, className: "", maxWidth: "240px" }, Aa = ["a[href]", "[tabindex]:not([tabindex='-1'])", "[contenteditable]:not([contenteditable='false'])", "button:not([disabled])", "input:not([disabled])", "select:not([disabled])", "textarea:not([disabled])"].join(", ");
function Ra(e2) {
if (e2) {
if ("number" == typeof e2) {
const i3 = Math.round(Math.abs(e2) / Math.SQRT2);
return { center: new t.P(0, 0), top: new t.P(0, e2), "top-left": new t.P(i3, i3), "top-right": new t.P(-i3, i3), bottom: new t.P(0, -e2), "bottom-left": new t.P(i3, -i3), "bottom-right": new t.P(-i3, -i3), left: new t.P(e2, 0), right: new t.P(-e2, 0) };
}
if (e2 instanceof t.P || Array.isArray(e2)) {
const i3 = t.P.convert(e2);
return { center: i3, top: i3, "top-left": i3, "top-right": i3, bottom: i3, "bottom-left": i3, "bottom-right": i3, left: i3, right: i3 };
}
return { center: t.P.convert(e2.center || [0, 0]), top: t.P.convert(e2.top || [0, 0]), "top-left": t.P.convert(e2["top-left"] || [0, 0]), "top-right": t.P.convert(e2["top-right"] || [0, 0]), bottom: t.P.convert(e2.bottom || [0, 0]), "bottom-left": t.P.convert(e2["bottom-left"] || [0, 0]), "bottom-right": t.P.convert(e2["bottom-right"] || [0, 0]), left: t.P.convert(e2.left || [0, 0]), right: t.P.convert(e2.right || [0, 0]) };
}
return Ra(new t.P(0, 0));
}
const ka = { extend: (e2, ...i3) => t.e(e2, ...i3), run(t2) {
t2();
}, logToElement(t2, e2 = false, i3 = "log") {
const s2 = window.document.getElementById(i3);
s2 && (e2 && (s2.innerHTML = ""), s2.innerHTML += `<br>${t2}`);
} }, Fa = e;
class Ba {
static get version() {
return Fa;
}
static get workerCount() {
return tt.workerCount;
}
static set workerCount(t2) {
tt.workerCount = t2;
}
static get maxParallelImageRequests() {
return t.c.MAX_PARALLEL_IMAGE_REQUESTS;
}
static set maxParallelImageRequests(e2) {
t.c.MAX_PARALLEL_IMAGE_REQUESTS = e2;
}
static get workerUrl() {
return t.c.WORKER_URL;
}
static set workerUrl(e2) {
t.c.WORKER_URL = e2;
}
static addProtocol(e2, i3) {
t.c.REGISTERED_PROTOCOLS[e2] = i3;
}
static removeProtocol(e2) {
delete t.c.REGISTERED_PROTOCOLS[e2];
}
}
return Ba.Map = class extends oa {
constructor(e2) {
if (t.bg.mark(t.bh.create), null != (e2 = t.e({}, ga, e2)).minZoom && null != e2.maxZoom && e2.minZoom > e2.maxZoom) throw new Error("maxZoom must be greater than or equal to minZoom");
if (null != e2.minPitch && null != e2.maxPitch && e2.minPitch > e2.maxPitch) throw new Error("maxPitch must be greater than or equal to minPitch");
if (null != e2.minPitch && e2.minPitch < 0) throw new Error("minPitch must be greater than or equal to 0");
if (null != e2.maxPitch && e2.maxPitch > 85) throw new Error("maxPitch must be less than or equal to 85");
if (super(new rs(e2.minZoom, e2.maxZoom, e2.minPitch, e2.maxPitch, e2.renderWorldCopies), { bearingSnap: e2.bearingSnap }), this._cooperativeGesturesOnWheel = (t2) => {
this._onCooperativeGesture(t2, t2[this._metaKey], 1);
}, this._contextLost = (e3) => {
e3.preventDefault(), this._frame && (this._frame.cancel(), this._frame = null), this.fire(new t.k("webglcontextlost", { originalEvent: e3 }));
}, this._contextRestored = (e3) => {
this._setupPainter(), this.resize(), this._update(), this.fire(new t.k("webglcontextrestored", { originalEvent: e3 }));
}, this._onMapScroll = (t2) => {
if (t2.target === this._container) return this._container.scrollTop = 0, this._container.scrollLeft = 0, false;
}, this._onWindowOnline = () => {
this._update();
}, this._interactive = e2.interactive, this._cooperativeGestures = e2.cooperativeGestures, this._metaKey = 0 === navigator.platform.indexOf("Mac") ? "metaKey" : "ctrlKey", this._maxTileCacheSize = e2.maxTileCacheSize, this._maxTileCacheZoomLevels = e2.maxTileCacheZoomLevels, this._failIfMajorPerformanceCaveat = e2.failIfMajorPerformanceCaveat, this._preserveDrawingBuffer = e2.preserveDrawingBuffer, this._antialias = e2.antialias, this._trackResize = e2.trackResize, this._bearingSnap = e2.bearingSnap, this._refreshExpiredTiles = e2.refreshExpiredTiles, this._fadeDuration = e2.fadeDuration, this._crossSourceCollisions = e2.crossSourceCollisions, this._crossFadingFactor = 1, this._collectResourceTiming = e2.collectResourceTiming, this._renderTaskQueue = new la(), this._controls = [], this._mapId = t.a2(), this._locale = t.e({}, ha, e2.locale), this._clickTolerance = e2.clickTolerance, this._overridePixelRatio = e2.pixelRatio, this._maxCanvasSize = e2.maxCanvasSize, this.transformCameraUpdate = e2.transformCameraUpdate, this._imageQueueHandle = h.addThrottleControl((() => this.isMoving())), this._requestManager = new u(e2.transformRequest), "string" == typeof e2.container) {
if (this._container = document.getElementById(e2.container), !this._container) throw new Error(`Container '${e2.container}' not found.`);
} else {
if (!(e2.container instanceof HTMLElement)) throw new Error("Invalid type: 'container' must be a String or HTMLElement.");
this._container = e2.container;
}
if (e2.maxBounds && this.setMaxBounds(e2.maxBounds), this._setupContainer(), this._setupPainter(), this.on("move", (() => this._update(false))), this.on("moveend", (() => this._update(false))), this.on("zoom", (() => this._update(true))), this.on("terrain", (() => {
this.painter.terrainFacilitator.dirty = true, this._update(true);
})), this.once("idle", (() => {
this._idleTriggered = true;
})), "undefined" != typeof window) {
addEventListener("online", this._onWindowOnline, false);
let t2 = false;
const e3 = ns(((t3) => {
this._trackResize && !this._removed && this.resize(t3)._update();
}), 50);
this._resizeObserver = new ResizeObserver(((i3) => {
t2 ? e3(i3) : t2 = true;
})), this._resizeObserver.observe(this._container);
}
this.handlers = new aa(this, e2), this._cooperativeGestures && this._setupCooperativeGestures(), this._hash = e2.hash && new ls("string" == typeof e2.hash && e2.hash || void 0).addTo(this), this._hash && this._hash._onHashChange() || (this.jumpTo({ center: e2.center, zoom: e2.zoom, bearing: e2.bearing, pitch: e2.pitch }), e2.bounds && (this.resize(), this.fitBounds(e2.bounds, t.e({}, e2.fitBoundsOptions, { duration: 0 })))), this.resize(), this._localIdeographFontFamily = e2.localIdeographFontFamily, this._validateStyle = e2.validateStyle, e2.style && this.setStyle(e2.style, { localIdeographFontFamily: e2.localIdeographFontFamily }), e2.attributionControl && this.addControl(new ra({ customAttribution: e2.customAttribution })), e2.maplibreLogo && this.addControl(new na(), e2.logoPosition), this.on("style.load", (() => {
this.transform.unmodified && this.jumpTo(this.style.stylesheet);
})), this.on("data", ((e3) => {
this._update("style" === e3.dataType), this.fire(new t.k(`${e3.dataType}data`, e3));
})), this.on("dataloading", ((e3) => {
this.fire(new t.k(`${e3.dataType}dataloading`, e3));
})), this.on("dataabort", ((e3) => {
this.fire(new t.k("sourcedataabort", e3));
}));
}
_getMapId() {
return this._mapId;
}
addControl(e2, i3) {
if (void 0 === i3 && (i3 = e2.getDefaultPosition ? e2.getDefaultPosition() : "top-right"), !e2 || !e2.onAdd) return this.fire(new t.j(new Error("Invalid argument to map.addControl(). Argument must be a control with onAdd and onRemove methods.")));
const s2 = e2.onAdd(this);
this._controls.push(e2);
const a2 = this._controlPositions[i3];
return -1 !== i3.indexOf("bottom") ? a2.insertBefore(s2, a2.firstChild) : a2.appendChild(s2), this;
}
removeControl(e2) {
if (!e2 || !e2.onRemove) return this.fire(new t.j(new Error("Invalid argument to map.removeControl(). Argument must be a control with onAdd and onRemove methods.")));
const i3 = this._controls.indexOf(e2);
return i3 > -1 && this._controls.splice(i3, 1), e2.onRemove(this), this;
}
hasControl(t2) {
return this._controls.indexOf(t2) > -1;
}
calculateCameraOptionsFromTo(t2, e2, i3, s2) {
return null == s2 && this.terrain && (s2 = this.terrain.getElevationForLngLatZoom(i3, this.transform.tileZoom)), super.calculateCameraOptionsFromTo(t2, e2, i3, s2);
}
resize(e2) {
var i3;
const s2 = this._containerDimensions(), a2 = s2[0], o2 = s2[1], r2 = this._getClampedPixelRatio(a2, o2);
if (this._resizeCanvas(a2, o2, r2), this.painter.resize(a2, o2, r2), this.painter.overLimit()) {
const t2 = this.painter.context.gl;
this._maxCanvasSize = [t2.drawingBufferWidth, t2.drawingBufferHeight];
const e3 = this._getClampedPixelRatio(a2, o2);
this._resizeCanvas(a2, o2, e3), this.painter.resize(a2, o2, e3);
}
this.transform.resize(a2, o2), null === (i3 = this._requestedCameraState) || void 0 === i3 || i3.resize(a2, o2);
const n2 = !this._moving;
return n2 && (this.stop(), this.fire(new t.k("movestart", e2)).fire(new t.k("move", e2))), this.fire(new t.k("resize", e2)), n2 && this.fire(new t.k("moveend", e2)), this;
}
_getClampedPixelRatio(t2, e2) {
const { 0: i3, 1: s2 } = this._maxCanvasSize, a2 = this.getPixelRatio(), o2 = t2 * a2, r2 = e2 * a2;
return Math.min(o2 > i3 ? i3 / o2 : 1, r2 > s2 ? s2 / r2 : 1) * a2;
}
getPixelRatio() {
var t2;
return null !== (t2 = this._overridePixelRatio) && void 0 !== t2 ? t2 : devicePixelRatio;
}
setPixelRatio(t2) {
this._overridePixelRatio = t2, this.resize();
}
getBounds() {
return this.transform.getBounds();
}
getMaxBounds() {
return this.transform.getMaxBounds();
}
setMaxBounds(t2) {
return this.transform.setMaxBounds(L.convert(t2)), this._update();
}
setMinZoom(t2) {
if ((t2 = null == t2 ? -2 : t2) >= -2 && t2 <= this.transform.maxZoom) return this.transform.minZoom = t2, this._update(), this.getZoom() < t2 && this.setZoom(t2), this;
throw new Error("minZoom must be between -2 and the current maxZoom, inclusive");
}
getMinZoom() {
return this.transform.minZoom;
}
setMaxZoom(t2) {
if ((t2 = null == t2 ? 22 : t2) >= this.transform.minZoom) return this.transform.maxZoom = t2, this._update(), this.getZoom() > t2 && this.setZoom(t2), this;
throw new Error("maxZoom must be greater than the current minZoom");
}
getMaxZoom() {
return this.transform.maxZoom;
}
setMinPitch(t2) {
if ((t2 = null == t2 ? 0 : t2) < 0) throw new Error("minPitch must be greater than or equal to 0");
if (t2 >= 0 && t2 <= this.transform.maxPitch) return this.transform.minPitch = t2, this._update(), this.getPitch() < t2 && this.setPitch(t2), this;
throw new Error("minPitch must be between 0 and the current maxPitch, inclusive");
}
getMinPitch() {
return this.transform.minPitch;
}
setMaxPitch(t2) {
if ((t2 = null == t2 ? 60 : t2) > 85) throw new Error("maxPitch must be less than or equal to 85");
if (t2 >= this.transform.minPitch) return this.transform.maxPitch = t2, this._update(), this.getPitch() > t2 && this.setPitch(t2), this;
throw new Error("maxPitch must be greater than the current minPitch");
}
getMaxPitch() {
return this.transform.maxPitch;
}
getRenderWorldCopies() {
return this.transform.renderWorldCopies;
}
setRenderWorldCopies(t2) {
return this.transform.renderWorldCopies = t2, this._update();
}
getCooperativeGestures() {
return this._cooperativeGestures;
}
setCooperativeGestures(t2) {
return this._cooperativeGestures = t2, this._cooperativeGestures ? this._setupCooperativeGestures() : this._destroyCooperativeGestures(), this;
}
project(e2) {
return this.transform.locationPoint(t.L.convert(e2), this.style && this.terrain);
}
unproject(e2) {
return this.transform.pointLocation(t.P.convert(e2), this.terrain);
}
isMoving() {
var t2;
return this._moving || (null === (t2 = this.handlers) || void 0 === t2 ? void 0 : t2.isMoving());
}
isZooming() {
var t2;
return this._zooming || (null === (t2 = this.handlers) || void 0 === t2 ? void 0 : t2.isZooming());
}
isRotating() {
var t2;
return this._rotating || (null === (t2 = this.handlers) || void 0 === t2 ? void 0 : t2.isRotating());
}
_createDelegatedListener(t2, e2, i3) {
if ("mouseenter" === t2 || "mouseover" === t2) {
let s2 = false;
const a2 = (a3) => {
const o2 = this.getLayer(e2) ? this.queryRenderedFeatures(a3.point, { layers: [e2] }) : [];
o2.length ? s2 || (s2 = true, i3.call(this, new gs(t2, this, a3.originalEvent, { features: o2 }))) : s2 = false;
};
return { layer: e2, listener: i3, delegates: { mousemove: a2, mouseout: () => {
s2 = false;
} } };
}
if ("mouseleave" === t2 || "mouseout" === t2) {
let s2 = false;
const a2 = (a3) => {
(this.getLayer(e2) ? this.queryRenderedFeatures(a3.point, { layers: [e2] }) : []).length ? s2 = true : s2 && (s2 = false, i3.call(this, new gs(t2, this, a3.originalEvent)));
}, o2 = (e3) => {
s2 && (s2 = false, i3.call(this, new gs(t2, this, e3.originalEvent)));
};
return { layer: e2, listener: i3, delegates: { mousemove: a2, mouseout: o2 } };
}
{
const s2 = (t3) => {
const s3 = this.getLayer(e2) ? this.queryRenderedFeatures(t3.point, { layers: [e2] }) : [];
s3.length && (t3.features = s3, i3.call(this, t3), delete t3.features);
};
return { layer: e2, listener: i3, delegates: { [t2]: s2 } };
}
}
on(t2, e2, i3) {
if (void 0 === i3) return super.on(t2, e2);
const s2 = this._createDelegatedListener(t2, e2, i3);
this._delegatedListeners = this._delegatedListeners || {}, this._delegatedListeners[t2] = this._delegatedListeners[t2] || [], this._delegatedListeners[t2].push(s2);
for (const t3 in s2.delegates) this.on(t3, s2.delegates[t3]);
return this;
}
once(t2, e2, i3) {
if (void 0 === i3) return super.once(t2, e2);
const s2 = this._createDelegatedListener(t2, e2, i3);
for (const t3 in s2.delegates) this.once(t3, s2.delegates[t3]);
return this;
}
off(t2, e2, i3) {
return void 0 === i3 ? super.off(t2, e2) : (this._delegatedListeners && this._delegatedListeners[t2] && ((s2) => {
const a2 = this._delegatedListeners[t2];
for (let t3 = 0; t3 < a2.length; t3++) {
const s3 = a2[t3];
if (s3.layer === e2 && s3.listener === i3) {
for (const t4 in s3.delegates) this.off(t4, s3.delegates[t4]);
return a2.splice(t3, 1), this;
}
}
})(), this);
}
queryRenderedFeatures(e2, i3) {
if (!this.style) return [];
let s2;
const a2 = e2 instanceof t.P || Array.isArray(e2), o2 = a2 ? e2 : [[0, 0], [this.transform.width, this.transform.height]];
if (i3 = i3 || (a2 ? {} : e2) || {}, o2 instanceof t.P || "number" == typeof o2[0]) s2 = [t.P.convert(o2)];
else {
const e3 = t.P.convert(o2[0]), i4 = t.P.convert(o2[1]);
s2 = [e3, new t.P(i4.x, e3.y), i4, new t.P(e3.x, i4.y), e3];
}
return this.style.queryRenderedFeatures(s2, i3, this.transform);
}
querySourceFeatures(t2, e2) {
return this.style.querySourceFeatures(t2, e2);
}
setStyle(e2, i3) {
return false !== (i3 = t.e({}, { localIdeographFontFamily: this._localIdeographFontFamily, validate: this._validateStyle }, i3)).diff && i3.localIdeographFontFamily === this._localIdeographFontFamily && this.style && e2 ? (this._diffStyle(e2, i3), this) : (this._localIdeographFontFamily = i3.localIdeographFontFamily, this._updateStyle(e2, i3));
}
setTransformRequest(t2) {
return this._requestManager.setTransformRequest(t2), this;
}
_getUIString(t2) {
const e2 = this._locale[t2];
if (null == e2) throw new Error(`Missing UI string '${t2}'`);
return e2;
}
_updateStyle(t2, e2) {
if (e2.transformStyle && this.style && !this.style._loaded) return void this.style.once("style.load", (() => this._updateStyle(t2, e2)));
const i3 = this.style && e2.transformStyle ? this.style.serialize() : void 0;
return this.style && (this.style.setEventedParent(null), this.style._remove(!t2)), t2 ? (this.style = new se(this, e2 || {}), this.style.setEventedParent(this, { style: this.style }), "string" == typeof t2 ? this.style.loadURL(t2, e2, i3) : this.style.loadJSON(t2, e2, i3), this) : (delete this.style, this);
}
_lazyInitEmptyStyle() {
this.style || (this.style = new se(this, {}), this.style.setEventedParent(this, { style: this.style }), this.style.loadEmpty());
}
_diffStyle(e2, i3) {
if ("string" == typeof e2) {
const s2 = this._requestManager.transformRequest(e2, c.Style);
t.f(s2, ((e3, s3) => {
e3 ? this.fire(new t.j(e3)) : s3 && this._updateDiff(s3, i3);
}));
} else "object" == typeof e2 && this._updateDiff(e2, i3);
}
_updateDiff(e2, i3) {
try {
this.style.setState(e2, i3) && this._update(true);
} catch (s2) {
t.w(`Unable to perform style diff: ${s2.message || s2.error || s2}. Rebuilding the style from scratch.`), this._updateStyle(e2, i3);
}
}
getStyle() {
if (this.style) return this.style.serialize();
}
isStyleLoaded() {
return this.style ? this.style.loaded() : t.w("There is no style added to the map.");
}
addSource(t2, e2) {
return this._lazyInitEmptyStyle(), this.style.addSource(t2, e2), this._update(true);
}
isSourceLoaded(e2) {
const i3 = this.style && this.style.sourceCaches[e2];
if (void 0 !== i3) return i3.loaded();
this.fire(new t.j(new Error(`There is no source with ID '${e2}'`)));
}
setTerrain(e2) {
if (this.style._checkLoaded(), this._terrainDataCallback && this.style.off("data", this._terrainDataCallback), e2) {
const i3 = this.style.sourceCaches[e2.source];
if (!i3) throw new Error(`cannot load terrain, because there exists no source with ID: ${e2.source}`);
for (const i4 in this.style._layers) {
const s2 = this.style._layers[i4];
"hillshade" === s2.type && s2.source === e2.source && t.w("You are using the same source for a hillshade layer and for 3D terrain. Please consider using two separate sources to improve rendering quality.");
}
this.terrain = new da(this.painter, i3, e2), this.painter.renderToTexture = new ma(this.painter, this.terrain), this.transform._minEleveationForCurrentTile = this.terrain.getMinTileElevationForLngLatZoom(this.transform.center, this.transform.tileZoom), this.transform.elevation = this.terrain.getElevationForLngLatZoom(this.transform.center, this.transform.tileZoom), this._terrainDataCallback = (t2) => {
"style" === t2.dataType ? this.terrain.sourceCache.freeRtt() : "source" === t2.dataType && t2.tile && (t2.sourceId !== e2.source || this._elevationFreeze || (this.transform._minEleveationForCurrentTile = this.terrain.getMinTileElevationForLngLatZoom(this.transform.center, this.transform.tileZoom), this.transform.elevation = this.terrain.getElevationForLngLatZoom(this.transform.center, this.transform.tileZoom)), this.terrain.sourceCache.freeRtt(t2.tile.tileID));
}, this.style.on("data", this._terrainDataCallback);
} else this.terrain && this.terrain.sourceCache.destruct(), this.terrain = null, this.painter.renderToTexture && this.painter.renderToTexture.destruct(), this.painter.renderToTexture = null, this.transform._minEleveationForCurrentTile = 0, this.transform.elevation = 0;
return this.fire(new t.k("terrain", { terrain: e2 })), this;
}
getTerrain() {
var t2, e2;
return null !== (e2 = null === (t2 = this.terrain) || void 0 === t2 ? void 0 : t2.options) && void 0 !== e2 ? e2 : null;
}
areTilesLoaded() {
const t2 = this.style && this.style.sourceCaches;
for (const e2 in t2) {
const i3 = t2[e2]._tiles;
for (const t3 in i3) {
const e3 = i3[t3];
if ("loaded" !== e3.state && "errored" !== e3.state) return false;
}
}
return true;
}
addSourceType(t2, e2, i3) {
return this._lazyInitEmptyStyle(), this.style.addSourceType(t2, e2, i3);
}
removeSource(t2) {
return this.style.removeSource(t2), this._update(true);
}
getSource(t2) {
return this.style.getSource(t2);
}
addImage(e2, i3, s2 = {}) {
const { pixelRatio: a2 = 1, sdf: o2 = false, stretchX: r2, stretchY: n2, content: l2 } = s2;
if (this._lazyInitEmptyStyle(), !(i3 instanceof HTMLImageElement || t.a(i3))) {
if (void 0 === i3.width || void 0 === i3.height) return this.fire(new t.j(new Error("Invalid arguments to map.addImage(). The second argument must be an `HTMLImageElement`, `ImageData`, `ImageBitmap`, or object with `width`, `height`, and `data` properties with the same format as `ImageData`")));
{
const { width: s3, height: h2, data: c2 } = i3, u2 = i3;
return this.style.addImage(e2, { data: new t.R({ width: s3, height: h2 }, new Uint8Array(c2)), pixelRatio: a2, stretchX: r2, stretchY: n2, content: l2, sdf: o2, version: 0, userImage: u2 }), u2.onAdd && u2.onAdd(this, e2), this;
}
}
{
const { width: s3, height: h2, data: c2 } = t.h.getImageData(i3);
this.style.addImage(e2, { data: new t.R({ width: s3, height: h2 }, c2), pixelRatio: a2, stretchX: r2, stretchY: n2, content: l2, sdf: o2, version: 0 });
}
}
updateImage(e2, i3) {
const s2 = this.style.getImage(e2);
if (!s2) return this.fire(new t.j(new Error("The map has no image with that id. If you are adding a new image use `map.addImage(...)` instead.")));
const a2 = i3 instanceof HTMLImageElement || t.a(i3) ? t.h.getImageData(i3) : i3, { width: o2, height: r2, data: n2 } = a2;
if (void 0 === o2 || void 0 === r2) return this.fire(new t.j(new Error("Invalid arguments to map.updateImage(). The second argument must be an `HTMLImageElement`, `ImageData`, `ImageBitmap`, or object with `width`, `height`, and `data` properties with the same format as `ImageData`")));
if (o2 !== s2.data.width || r2 !== s2.data.height) return this.fire(new t.j(new Error("The width and height of the updated image must be that same as the previous version of the image")));
const l2 = !(i3 instanceof HTMLImageElement || t.a(i3));
return s2.data.replace(n2, l2), this.style.updateImage(e2, s2), this;
}
getImage(t2) {
return this.style.getImage(t2);
}
hasImage(e2) {
return e2 ? !!this.style.getImage(e2) : (this.fire(new t.j(new Error("Missing required image id"))), false);
}
removeImage(t2) {
this.style.removeImage(t2);
}
loadImage(t2, e2) {
h.getImage(this._requestManager.transformRequest(t2, c.Image), e2);
}
listImages() {
return this.style.listImages();
}
addLayer(t2, e2) {
return this._lazyInitEmptyStyle(), this.style.addLayer(t2, e2), this._update(true);
}
moveLayer(t2, e2) {
return this.style.moveLayer(t2, e2), this._update(true);
}
removeLayer(t2) {
return this.style.removeLayer(t2), this._update(true);
}
getLayer(t2) {
return this.style.getLayer(t2);
}
getLayersOrder() {
return this.style.getLayersOrder();
}
setLayerZoomRange(t2, e2, i3) {
return this.style.setLayerZoomRange(t2, e2, i3), this._update(true);
}
setFilter(t2, e2, i3 = {}) {
return this.style.setFilter(t2, e2, i3), this._update(true);
}
getFilter(t2) {
return this.style.getFilter(t2);
}
setPaintProperty(t2, e2, i3, s2 = {}) {
return this.style.setPaintProperty(t2, e2, i3, s2), this._update(true);
}
getPaintProperty(t2, e2) {
return this.style.getPaintProperty(t2, e2);
}
setLayoutProperty(t2, e2, i3, s2 = {}) {
return this.style.setLayoutProperty(t2, e2, i3, s2), this._update(true);
}
getLayoutProperty(t2, e2) {
return this.style.getLayoutProperty(t2, e2);
}
setGlyphs(t2, e2 = {}) {
return this._lazyInitEmptyStyle(), this.style.setGlyphs(t2, e2), this._update(true);
}
getGlyphs() {
return this.style.getGlyphsUrl();
}
addSprite(t2, e2, i3 = {}) {
return this._lazyInitEmptyStyle(), this.style.addSprite(t2, e2, i3, ((t3) => {
t3 || this._update(true);
})), this;
}
removeSprite(t2) {
return this._lazyInitEmptyStyle(), this.style.removeSprite(t2), this._update(true);
}
getSprite() {
return this.style.getSprite();
}
setSprite(t2, e2 = {}) {
return this._lazyInitEmptyStyle(), this.style.setSprite(t2, e2, ((t3) => {
t3 || this._update(true);
})), this;
}
setLight(t2, e2 = {}) {
return this._lazyInitEmptyStyle(), this.style.setLight(t2, e2), this._update(true);
}
getLight() {
return this.style.getLight();
}
setFeatureState(t2, e2) {
return this.style.setFeatureState(t2, e2), this._update();
}
removeFeatureState(t2, e2) {
return this.style.removeFeatureState(t2, e2), this._update();
}
getFeatureState(t2) {
return this.style.getFeatureState(t2);
}
getContainer() {
return this._container;
}
getCanvasContainer() {
return this._canvasContainer;
}
getCanvas() {
return this._canvas;
}
_containerDimensions() {
let t2 = 0, e2 = 0;
return this._container && (t2 = this._container.clientWidth || 400, e2 = this._container.clientHeight || 300), [t2, e2];
}
_setupContainer() {
const t2 = this._container;
t2.classList.add("maplibregl-map");
const e2 = this._canvasContainer = i2.create("div", "maplibregl-canvas-container", t2);
this._interactive && e2.classList.add("maplibregl-interactive"), this._canvas = i2.create("canvas", "maplibregl-canvas", e2), this._canvas.addEventListener("webglcontextlost", this._contextLost, false), this._canvas.addEventListener("webglcontextrestored", this._contextRestored, false), this._canvas.setAttribute("tabindex", "0"), this._canvas.setAttribute("aria-label", "Map"), this._canvas.setAttribute("role", "region");
const s2 = this._containerDimensions(), a2 = this._getClampedPixelRatio(s2[0], s2[1]);
this._resizeCanvas(s2[0], s2[1], a2);
const o2 = this._controlContainer = i2.create("div", "maplibregl-control-container", t2), r2 = this._controlPositions = {};
["top-left", "top-right", "bottom-left", "bottom-right"].forEach(((t3) => {
r2[t3] = i2.create("div", `maplibregl-ctrl-${t3} `, o2);
})), this._container.addEventListener("scroll", this._onMapScroll, false);
}
_setupCooperativeGestures() {
this._cooperativeGesturesScreen = i2.create("div", "maplibregl-cooperative-gesture-screen", this._container);
let t2 = "boolean" != typeof this._cooperativeGestures && this._cooperativeGestures.windowsHelpText ? this._cooperativeGestures.windowsHelpText : "Use Ctrl + scroll to zoom the map";
0 === navigator.platform.indexOf("Mac") && (t2 = "boolean" != typeof this._cooperativeGestures && this._cooperativeGestures.macHelpText ? this._cooperativeGestures.macHelpText : "Use ⌘ + scroll to zoom the map"), this._cooperativeGesturesScreen.innerHTML = `
<div class="maplibregl-desktop-message">${t2}</div>
<div class="maplibregl-mobile-message">${"boolean" != typeof this._cooperativeGestures && this._cooperativeGestures.mobileHelpText ? this._cooperativeGestures.mobileHelpText : "Use two fingers to move the map"}</div>
`, this._cooperativeGesturesScreen.setAttribute("aria-hidden", "true"), this._canvasContainer.addEventListener("wheel", this._cooperativeGesturesOnWheel, false), this._canvasContainer.classList.add("maplibregl-cooperative-gestures");
}
_destroyCooperativeGestures() {
i2.remove(this._cooperativeGesturesScreen), this._canvasContainer.removeEventListener("wheel", this._cooperativeGesturesOnWheel, false), this._canvasContainer.classList.remove("maplibregl-cooperative-gestures");
}
_resizeCanvas(t2, e2, i3) {
this._canvas.width = Math.floor(i3 * t2), this._canvas.height = Math.floor(i3 * e2), this._canvas.style.width = `${t2}px`, this._canvas.style.height = `${e2}px`;
}
_setupPainter() {
const t2 = { alpha: true, stencil: true, depth: true, failIfMajorPerformanceCaveat: this._failIfMajorPerformanceCaveat, preserveDrawingBuffer: this._preserveDrawingBuffer, antialias: this._antialias || false };
let e2 = null;
this._canvas.addEventListener("webglcontextcreationerror", ((i4) => {
e2 = { requestedAttributes: t2 }, i4 && (e2.statusMessage = i4.statusMessage, e2.type = i4.type);
}), { once: true });
const i3 = this._canvas.getContext("webgl2", t2) || this._canvas.getContext("webgl", t2);
if (!i3) {
const t3 = "Failed to initialize WebGL";
throw e2 ? (e2.message = t3, new Error(JSON.stringify(e2))) : new Error(t3);
}
this.painter = new is(i3, this.transform), s.testSupport(i3);
}
_onCooperativeGesture(t2, e2, i3) {
return !e2 && i3 < 2 && (this._cooperativeGesturesScreen.classList.add("maplibregl-show"), setTimeout((() => {
this._cooperativeGesturesScreen.classList.remove("maplibregl-show");
}), 100)), false;
}
loaded() {
return !this._styleDirty && !this._sourcesDirty && !!this.style && this.style.loaded();
}
_update(t2) {
return this.style && this.style._loaded ? (this._styleDirty = this._styleDirty || t2, this._sourcesDirty = true, this.triggerRepaint(), this) : this;
}
_requestRenderFrame(t2) {
return this._update(), this._renderTaskQueue.add(t2);
}
_cancelRenderFrame(t2) {
this._renderTaskQueue.remove(t2);
}
_render(e2) {
const i3 = this._idleTriggered ? this._fadeDuration : 0;
if (this.painter.context.setDirty(), this.painter.setBaseState(), this._renderTaskQueue.run(e2), this._removed) return;
let s2 = false;
if (this.style && this._styleDirty) {
this._styleDirty = false;
const e3 = this.transform.zoom, a3 = t.h.now();
this.style.zoomHistory.update(e3, a3);
const o2 = new t.a8(e3, { now: a3, fadeDuration: i3, zoomHistory: this.style.zoomHistory, transition: this.style.getTransition() }), r2 = o2.crossFadingFactor();
1 === r2 && r2 === this._crossFadingFactor || (s2 = true, this._crossFadingFactor = r2), this.style.update(o2);
}
this.style && this._sourcesDirty && (this._sourcesDirty = false, this.style._updateSources(this.transform)), this.terrain ? (this.terrain.sourceCache.update(this.transform, this.terrain), this.transform._minEleveationForCurrentTile = this.terrain.getMinTileElevationForLngLatZoom(this.transform.center, this.transform.tileZoom), this._elevationFreeze || (this.transform.elevation = this.terrain.getElevationForLngLatZoom(this.transform.center, this.transform.tileZoom))) : (this.transform._minEleveationForCurrentTile = 0, this.transform.elevation = 0), this._placementDirty = this.style && this.style._updatePlacement(this.painter.transform, this.showCollisionBoxes, i3, this._crossSourceCollisions), this.painter.render(this.style, { showTileBoundaries: this.showTileBoundaries, showOverdrawInspector: this._showOverdrawInspector, rotating: this.isRotating(), zooming: this.isZooming(), moving: this.isMoving(), fadeDuration: i3, showPadding: this.showPadding }), this.fire(new t.k("render")), this.loaded() && !this._loaded && (this._loaded = true, t.bg.mark(t.bh.load), this.fire(new t.k("load"))), this.style && (this.style.hasTransitions() || s2) && (this._styleDirty = true), this.style && !this._placementDirty && this.style._releaseSymbolFadeTiles();
const a2 = this._sourcesDirty || this._styleDirty || this._placementDirty;
return a2 || this._repaint ? this.triggerRepaint() : !this.isMoving() && this.loaded() && this.fire(new t.k("idle")), !this._loaded || this._fullyLoaded || a2 || (this._fullyLoaded = true, t.bg.mark(t.bh.fullLoad)), this;
}
redraw() {
return this.style && (this._frame && (this._frame.cancel(), this._frame = null), this._render(0)), this;
}
remove() {
var e2;
this._hash && this._hash.remove();
for (const t2 of this._controls) t2.onRemove(this);
this._controls = [], this._frame && (this._frame.cancel(), this._frame = null), this._renderTaskQueue.clear(), this.painter.destroy(), this.handlers.destroy(), delete this.handlers, this.setStyle(null), "undefined" != typeof window && removeEventListener("online", this._onWindowOnline, false), h.removeThrottleControl(this._imageQueueHandle), null === (e2 = this._resizeObserver) || void 0 === e2 || e2.disconnect();
const s2 = this.painter.context.gl.getExtension("WEBGL_lose_context");
s2 && s2.loseContext(), this._canvas.removeEventListener("webglcontextrestored", this._contextRestored, false), this._canvas.removeEventListener("webglcontextlost", this._contextLost, false), i2.remove(this._canvasContainer), i2.remove(this._controlContainer), this._cooperativeGestures && this._destroyCooperativeGestures(), this._container.classList.remove("maplibregl-map"), t.bg.clearMetrics(), this._removed = true, this.fire(new t.k("remove"));
}
triggerRepaint() {
this.style && !this._frame && (this._frame = t.h.frame(((e2) => {
t.bg.frame(e2), this._frame = null, this._render(e2);
})));
}
get showTileBoundaries() {
return !!this._showTileBoundaries;
}
set showTileBoundaries(t2) {
this._showTileBoundaries !== t2 && (this._showTileBoundaries = t2, this._update());
}
get showPadding() {
return !!this._showPadding;
}
set showPadding(t2) {
this._showPadding !== t2 && (this._showPadding = t2, this._update());
}
get showCollisionBoxes() {
return !!this._showCollisionBoxes;
}
set showCollisionBoxes(t2) {
this._showCollisionBoxes !== t2 && (this._showCollisionBoxes = t2, t2 ? this.style._generateCollisionBoxes() : this._update());
}
get showOverdrawInspector() {
return !!this._showOverdrawInspector;
}
set showOverdrawInspector(t2) {
this._showOverdrawInspector !== t2 && (this._showOverdrawInspector = t2, this._update());
}
get repaint() {
return !!this._repaint;
}
set repaint(t2) {
this._repaint !== t2 && (this._repaint = t2, this.triggerRepaint());
}
get vertices() {
return !!this._vertices;
}
set vertices(t2) {
this._vertices = t2, this._update();
}
get version() {
return fa;
}
getCameraTargetElevation() {
return this.transform.elevation;
}
}, Ba.NavigationControl = class {
constructor(e2) {
this._updateZoomButtons = () => {
const t2 = this._map.getZoom(), e3 = t2 === this._map.getMaxZoom(), i3 = t2 === this._map.getMinZoom();
this._zoomInButton.disabled = e3, this._zoomOutButton.disabled = i3, this._zoomInButton.setAttribute("aria-disabled", e3.toString()), this._zoomOutButton.setAttribute("aria-disabled", i3.toString());
}, this._rotateCompassArrow = () => {
const t2 = this.options.visualizePitch ? `scale(${1 / Math.pow(Math.cos(this._map.transform.pitch * (Math.PI / 180)), 0.5)}) rotateX(${this._map.transform.pitch}deg) rotateZ(${this._map.transform.angle * (180 / Math.PI)}deg)` : `rotate(${this._map.transform.angle * (180 / Math.PI)}deg)`;
this._compassIcon.style.transform = t2;
}, this._setButtonTitle = (t2, e3) => {
const i3 = this._map._getUIString(`NavigationControl.${e3}`);
t2.title = i3, t2.setAttribute("aria-label", i3);
}, this.options = t.e({}, xa, e2), this._container = i2.create("div", "maplibregl-ctrl maplibregl-ctrl-group"), this._container.addEventListener("contextmenu", ((t2) => t2.preventDefault())), this.options.showZoom && (this._zoomInButton = this._createButton("maplibregl-ctrl-zoom-in", ((t2) => this._map.zoomIn({}, { originalEvent: t2 }))), i2.create("span", "maplibregl-ctrl-icon", this._zoomInButton).setAttribute("aria-hidden", "true"), this._zoomOutButton = this._createButton("maplibregl-ctrl-zoom-out", ((t2) => this._map.zoomOut({}, { originalEvent: t2 }))), i2.create("span", "maplibregl-ctrl-icon", this._zoomOutButton).setAttribute("aria-hidden", "true")), this.options.showCompass && (this._compass = this._createButton("maplibregl-ctrl-compass", ((t2) => {
this.options.visualizePitch ? this._map.resetNorthPitch({}, { originalEvent: t2 }) : this._map.resetNorth({}, { originalEvent: t2 });
})), this._compassIcon = i2.create("span", "maplibregl-ctrl-icon", this._compass), this._compassIcon.setAttribute("aria-hidden", "true"));
}
onAdd(t2) {
return this._map = t2, this.options.showZoom && (this._setButtonTitle(this._zoomInButton, "ZoomIn"), this._setButtonTitle(this._zoomOutButton, "ZoomOut"), this._map.on("zoom", this._updateZoomButtons), this._updateZoomButtons()), this.options.showCompass && (this._setButtonTitle(this._compass, "ResetBearing"), this.options.visualizePitch && this._map.on("pitch", this._rotateCompassArrow), this._map.on("rotate", this._rotateCompassArrow), this._rotateCompassArrow(), this._handler = new ya(this._map, this._compass, this.options.visualizePitch)), this._container;
}
onRemove() {
i2.remove(this._container), this.options.showZoom && this._map.off("zoom", this._updateZoomButtons), this.options.showCompass && (this.options.visualizePitch && this._map.off("pitch", this._rotateCompassArrow), this._map.off("rotate", this._rotateCompassArrow), this._handler.off(), delete this._handler), delete this._map;
}
_createButton(t2, e2) {
const s2 = i2.create("button", t2, this._container);
return s2.type = "button", s2.addEventListener("click", e2), s2;
}
}, Ba.GeolocateControl = class extends t.E {
constructor(e2) {
super(), this._onSuccess = (e3) => {
if (this._map) {
if (this._isOutOfMapMaxBounds(e3)) return this._setErrorState(), this.fire(new t.k("outofmaxbounds", e3)), this._updateMarker(), void this._finish();
if (this.options.trackUserLocation) switch (this._lastKnownPosition = e3, this._watchState) {
case "WAITING_ACTIVE":
case "ACTIVE_LOCK":
case "ACTIVE_ERROR":
this._watchState = "ACTIVE_LOCK", this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-waiting"), this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active-error"), this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-active");
break;
case "BACKGROUND":
case "BACKGROUND_ERROR":
this._watchState = "BACKGROUND", this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-waiting"), this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-background-error"), this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-background");
break;
default:
throw new Error(`Unexpected watchState ${this._watchState}`);
}
this.options.showUserLocation && "OFF" !== this._watchState && this._updateMarker(e3), this.options.trackUserLocation && "ACTIVE_LOCK" !== this._watchState || this._updateCamera(e3), this.options.showUserLocation && this._dotElement.classList.remove("maplibregl-user-location-dot-stale"), this.fire(new t.k("geolocate", e3)), this._finish();
}
}, this._updateCamera = (e3) => {
const i3 = new t.L(e3.coords.longitude, e3.coords.latitude), s2 = e3.coords.accuracy, a2 = this._map.getBearing(), o2 = t.e({ bearing: a2 }, this.options.fitBoundsOptions), r2 = L.fromLngLat(i3, s2);
this._map.fitBounds(r2, o2, { geolocateSource: true });
}, this._updateMarker = (e3) => {
if (e3) {
const i3 = new t.L(e3.coords.longitude, e3.coords.latitude);
this._accuracyCircleMarker.setLngLat(i3).addTo(this._map), this._userLocationDotMarker.setLngLat(i3).addTo(this._map), this._accuracy = e3.coords.accuracy, this.options.showUserLocation && this.options.showAccuracyCircle && this._updateCircleRadius();
} else this._userLocationDotMarker.remove(), this._accuracyCircleMarker.remove();
}, this._onZoom = () => {
this.options.showUserLocation && this.options.showAccuracyCircle && this._updateCircleRadius();
}, this._onError = (e3) => {
if (this._map) {
if (this.options.trackUserLocation) if (1 === e3.code) {
this._watchState = "OFF", this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-waiting"), this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active"), this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active-error"), this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-background"), this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-background-error"), this._geolocateButton.disabled = true;
const t2 = this._map._getUIString("GeolocateControl.LocationNotAvailable");
this._geolocateButton.title = t2, this._geolocateButton.setAttribute("aria-label", t2), void 0 !== this._geolocationWatchID && this._clearWatch();
} else {
if (3 === e3.code && Pa) return;
this._setErrorState();
}
"OFF" !== this._watchState && this.options.showUserLocation && this._dotElement.classList.add("maplibregl-user-location-dot-stale"), this.fire(new t.k("error", e3)), this._finish();
}
}, this._finish = () => {
this._timeoutId && clearTimeout(this._timeoutId), this._timeoutId = void 0;
}, this._setupUI = (e3) => {
if (this._map) {
if (this._container.addEventListener("contextmenu", ((t2) => t2.preventDefault())), this._geolocateButton = i2.create("button", "maplibregl-ctrl-geolocate", this._container), i2.create("span", "maplibregl-ctrl-icon", this._geolocateButton).setAttribute("aria-hidden", "true"), this._geolocateButton.type = "button", false === e3) {
t.w("Geolocation support is not available so the GeolocateControl will be disabled.");
const e4 = this._map._getUIString("GeolocateControl.LocationNotAvailable");
this._geolocateButton.disabled = true, this._geolocateButton.title = e4, this._geolocateButton.setAttribute("aria-label", e4);
} else {
const t2 = this._map._getUIString("GeolocateControl.FindMyLocation");
this._geolocateButton.title = t2, this._geolocateButton.setAttribute("aria-label", t2);
}
this.options.trackUserLocation && (this._geolocateButton.setAttribute("aria-pressed", "false"), this._watchState = "OFF"), this.options.showUserLocation && (this._dotElement = i2.create("div", "maplibregl-user-location-dot"), this._userLocationDotMarker = new Ea({ element: this._dotElement }), this._circleElement = i2.create("div", "maplibregl-user-location-accuracy-circle"), this._accuracyCircleMarker = new Ea({ element: this._circleElement, pitchAlignment: "map" }), this.options.trackUserLocation && (this._watchState = "OFF"), this._map.on("zoom", this._onZoom)), this._geolocateButton.addEventListener("click", this.trigger.bind(this)), this._setup = true, this.options.trackUserLocation && this._map.on("movestart", ((e4) => {
e4.geolocateSource || "ACTIVE_LOCK" !== this._watchState || e4.originalEvent && "resize" === e4.originalEvent.type || (this._watchState = "BACKGROUND", this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-background"), this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active"), this.fire(new t.k("trackuserlocationend")));
}));
}
}, this.options = t.e({}, Sa, e2);
}
onAdd(t2) {
return this._map = t2, this._container = i2.create("div", "maplibregl-ctrl maplibregl-ctrl-group"), (function(t3, e2 = false) {
void 0 === ba || e2 ? void 0 !== window.navigator.permissions ? window.navigator.permissions.query({ name: "geolocation" }).then(((e3) => {
ba = "denied" !== e3.state, t3(ba);
})).catch((() => {
ba = !!window.navigator.geolocation, t3(ba);
})) : (ba = !!window.navigator.geolocation, t3(ba)) : t3(ba);
})(this._setupUI), this._container;
}
onRemove() {
void 0 !== this._geolocationWatchID && (window.navigator.geolocation.clearWatch(this._geolocationWatchID), this._geolocationWatchID = void 0), this.options.showUserLocation && this._userLocationDotMarker && this._userLocationDotMarker.remove(), this.options.showAccuracyCircle && this._accuracyCircleMarker && this._accuracyCircleMarker.remove(), i2.remove(this._container), this._map.off("zoom", this._onZoom), this._map = void 0, Ca = 0, Pa = false;
}
_isOutOfMapMaxBounds(t2) {
const e2 = this._map.getMaxBounds(), i3 = t2.coords;
return e2 && (i3.longitude < e2.getWest() || i3.longitude > e2.getEast() || i3.latitude < e2.getSouth() || i3.latitude > e2.getNorth());
}
_setErrorState() {
switch (this._watchState) {
case "WAITING_ACTIVE":
this._watchState = "ACTIVE_ERROR", this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active"), this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-active-error");
break;
case "ACTIVE_LOCK":
this._watchState = "ACTIVE_ERROR", this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active"), this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-active-error"), this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-waiting");
break;
case "BACKGROUND":
this._watchState = "BACKGROUND_ERROR", this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-background"), this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-background-error"), this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-waiting");
break;
case "ACTIVE_ERROR":
break;
default:
throw new Error(`Unexpected watchState ${this._watchState}`);
}
}
_updateCircleRadius() {
const t2 = this._map.getBounds(), e2 = t2.getSouthEast(), i3 = t2.getNorthEast(), s2 = e2.distanceTo(i3), a2 = Math.ceil(this._accuracy / (s2 / this._map._container.clientHeight) * 2);
this._circleElement.style.width = `${a2}px`, this._circleElement.style.height = `${a2}px`;
}
trigger() {
if (!this._setup) return t.w("Geolocate control triggered before added to a map"), false;
if (this.options.trackUserLocation) {
switch (this._watchState) {
case "OFF":
this._watchState = "WAITING_ACTIVE", this.fire(new t.k("trackuserlocationstart"));
break;
case "WAITING_ACTIVE":
case "ACTIVE_LOCK":
case "ACTIVE_ERROR":
case "BACKGROUND_ERROR":
Ca--, Pa = false, this._watchState = "OFF", this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-waiting"), this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active"), this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-active-error"), this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-background"), this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-background-error"), this.fire(new t.k("trackuserlocationend"));
break;
case "BACKGROUND":
this._watchState = "ACTIVE_LOCK", this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-background"), this._lastKnownPosition && this._updateCamera(this._lastKnownPosition), this.fire(new t.k("trackuserlocationstart"));
break;
default:
throw new Error(`Unexpected watchState ${this._watchState}`);
}
switch (this._watchState) {
case "WAITING_ACTIVE":
this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-waiting"), this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-active");
break;
case "ACTIVE_LOCK":
this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-active");
break;
case "OFF":
break;
default:
throw new Error(`Unexpected watchState ${this._watchState}`);
}
if ("OFF" === this._watchState && void 0 !== this._geolocationWatchID) this._clearWatch();
else if (void 0 === this._geolocationWatchID) {
let t2;
this._geolocateButton.classList.add("maplibregl-ctrl-geolocate-waiting"), this._geolocateButton.setAttribute("aria-pressed", "true"), Ca++, Ca > 1 ? (t2 = { maximumAge: 6e5, timeout: 0 }, Pa = true) : (t2 = this.options.positionOptions, Pa = false), this._geolocationWatchID = window.navigator.geolocation.watchPosition(this._onSuccess, this._onError, t2);
}
} else window.navigator.geolocation.getCurrentPosition(this._onSuccess, this._onError, this.options.positionOptions), this._timeoutId = setTimeout(this._finish, 1e4);
return true;
}
_clearWatch() {
window.navigator.geolocation.clearWatch(this._geolocationWatchID), this._geolocationWatchID = void 0, this._geolocateButton.classList.remove("maplibregl-ctrl-geolocate-waiting"), this._geolocateButton.setAttribute("aria-pressed", "false"), this.options.showUserLocation && this._updateMarker(null);
}
}, Ba.AttributionControl = ra, Ba.LogoControl = na, Ba.ScaleControl = class {
constructor(e2) {
this._onMove = () => {
Ma(this._map, this._container, this.options);
}, this.setUnit = (t2) => {
this.options.unit = t2, Ma(this._map, this._container, this.options);
}, this.options = t.e({}, Da, e2);
}
getDefaultPosition() {
return "bottom-left";
}
onAdd(t2) {
return this._map = t2, this._container = i2.create("div", "maplibregl-ctrl maplibregl-ctrl-scale", t2.getContainer()), this._map.on("move", this._onMove), this._onMove(), this._container;
}
onRemove() {
i2.remove(this._container), this._map.off("move", this._onMove), this._map = void 0;
}
}, Ba.FullscreenControl = class extends t.E {
constructor(e2 = {}) {
super(), this._onFullscreenChange = () => {
(window.document.fullscreenElement || window.document.mozFullScreenElement || window.document.webkitFullscreenElement || window.document.msFullscreenElement) === this._container !== this._fullscreen && this._handleFullscreenChange();
}, this._onClickFullscreen = () => {
this._isFullscreen() ? this._exitFullscreen() : this._requestFullscreen();
}, this._fullscreen = false, e2 && e2.container && (e2.container instanceof HTMLElement ? this._container = e2.container : t.w("Full screen control 'container' must be a DOM element.")), "onfullscreenchange" in document ? this._fullscreenchange = "fullscreenchange" : "onmozfullscreenchange" in document ? this._fullscreenchange = "mozfullscreenchange" : "onwebkitfullscreenchange" in document ? this._fullscreenchange = "webkitfullscreenchange" : "onmsfullscreenchange" in document && (this._fullscreenchange = "MSFullscreenChange");
}
onAdd(t2) {
return this._map = t2, this._container || (this._container = this._map.getContainer()), this._controlContainer = i2.create("div", "maplibregl-ctrl maplibregl-ctrl-group"), this._setupUI(), this._controlContainer;
}
onRemove() {
i2.remove(this._controlContainer), this._map = null, window.document.removeEventListener(this._fullscreenchange, this._onFullscreenChange);
}
_setupUI() {
const t2 = this._fullscreenButton = i2.create("button", "maplibregl-ctrl-fullscreen", this._controlContainer);
i2.create("span", "maplibregl-ctrl-icon", t2).setAttribute("aria-hidden", "true"), t2.type = "button", this._updateTitle(), this._fullscreenButton.addEventListener("click", this._onClickFullscreen), window.document.addEventListener(this._fullscreenchange, this._onFullscreenChange);
}
_updateTitle() {
const t2 = this._getTitle();
this._fullscreenButton.setAttribute("aria-label", t2), this._fullscreenButton.title = t2;
}
_getTitle() {
return this._map._getUIString(this._isFullscreen() ? "FullscreenControl.Exit" : "FullscreenControl.Enter");
}
_isFullscreen() {
return this._fullscreen;
}
_handleFullscreenChange() {
this._fullscreen = !this._fullscreen, this._fullscreenButton.classList.toggle("maplibregl-ctrl-shrink"), this._fullscreenButton.classList.toggle("maplibregl-ctrl-fullscreen"), this._updateTitle(), this._fullscreen ? (this.fire(new t.k("fullscreenstart")), this._map._cooperativeGestures && (this._prevCooperativeGestures = this._map._cooperativeGestures, this._map.setCooperativeGestures())) : (this.fire(new t.k("fullscreenend")), this._prevCooperativeGestures && (this._map.setCooperativeGestures(this._prevCooperativeGestures), delete this._prevCooperativeGestures));
}
_exitFullscreen() {
window.document.exitFullscreen ? window.document.exitFullscreen() : window.document.mozCancelFullScreen ? window.document.mozCancelFullScreen() : window.document.msExitFullscreen ? window.document.msExitFullscreen() : window.document.webkitCancelFullScreen ? window.document.webkitCancelFullScreen() : this._togglePseudoFullScreen();
}
_requestFullscreen() {
this._container.requestFullscreen ? this._container.requestFullscreen() : this._container.mozRequestFullScreen ? this._container.mozRequestFullScreen() : this._container.msRequestFullscreen ? this._container.msRequestFullscreen() : this._container.webkitRequestFullscreen ? this._container.webkitRequestFullscreen() : this._togglePseudoFullScreen();
}
_togglePseudoFullScreen() {
this._container.classList.toggle("maplibregl-pseudo-fullscreen"), this._handleFullscreenChange(), this._map.resize();
}
}, Ba.TerrainControl = class {
constructor(t2) {
this._toggleTerrain = () => {
this._map.getTerrain() ? this._map.setTerrain(null) : this._map.setTerrain(this.options), this._updateTerrainIcon();
}, this._updateTerrainIcon = () => {
this._terrainButton.classList.remove("maplibregl-ctrl-terrain"), this._terrainButton.classList.remove("maplibregl-ctrl-terrain-enabled"), this._map.terrain ? (this._terrainButton.classList.add("maplibregl-ctrl-terrain-enabled"), this._terrainButton.title = this._map._getUIString("TerrainControl.disableTerrain")) : (this._terrainButton.classList.add("maplibregl-ctrl-terrain"), this._terrainButton.title = this._map._getUIString("TerrainControl.enableTerrain"));
}, this.options = t2;
}
onAdd(t2) {
return this._map = t2, this._container = i2.create("div", "maplibregl-ctrl maplibregl-ctrl-group"), this._terrainButton = i2.create("button", "maplibregl-ctrl-terrain", this._container), i2.create("span", "maplibregl-ctrl-icon", this._terrainButton).setAttribute("aria-hidden", "true"), this._terrainButton.type = "button", this._terrainButton.addEventListener("click", this._toggleTerrain), this._updateTerrainIcon(), this._map.on("terrain", this._updateTerrainIcon), this._container;
}
onRemove() {
i2.remove(this._container), this._map.off("terrain", this._updateTerrainIcon), this._map = void 0;
}
}, Ba.Popup = class extends t.E {
constructor(e2) {
super(), this.remove = () => (this._content && i2.remove(this._content), this._container && (i2.remove(this._container), delete this._container), this._map && (this._map.off("move", this._update), this._map.off("move", this._onClose), this._map.off("click", this._onClose), this._map.off("remove", this.remove), this._map.off("mousemove", this._onMouseMove), this._map.off("mouseup", this._onMouseUp), this._map.off("drag", this._onDrag), delete this._map), this.fire(new t.k("close")), this), this._onMouseUp = (t2) => {
this._update(t2.point);
}, this._onMouseMove = (t2) => {
this._update(t2.point);
}, this._onDrag = (t2) => {
this._update(t2.point);
}, this._update = (t2) => {
if (!this._map || !this._lngLat && !this._trackPointer || !this._content) return;
if (!this._container) {
if (this._container = i2.create("div", "maplibregl-popup", this._map.getContainer()), this._tip = i2.create("div", "maplibregl-popup-tip", this._container), this._container.appendChild(this._content), this.options.className) for (const t3 of this.options.className.split(" ")) this._container.classList.add(t3);
this._trackPointer && this._container.classList.add("maplibregl-popup-track-pointer");
}
if (this.options.maxWidth && this._container.style.maxWidth !== this.options.maxWidth && (this._container.style.maxWidth = this.options.maxWidth), this._map.transform.renderWorldCopies && !this._trackPointer && (this._lngLat = wa(this._lngLat, this._pos, this._map.transform)), this._trackPointer && !t2) return;
const e3 = this._pos = this._trackPointer && t2 ? t2 : this._map.project(this._lngLat);
let s2 = this.options.anchor;
const a2 = Ra(this.options.offset);
if (!s2) {
const t3 = this._container.offsetWidth, i3 = this._container.offsetHeight;
let o3;
o3 = e3.y + a2.bottom.y < i3 ? ["top"] : e3.y > this._map.transform.height - i3 ? ["bottom"] : [], e3.x < t3 / 2 ? o3.push("left") : e3.x > this._map.transform.width - t3 / 2 && o3.push("right"), s2 = 0 === o3.length ? "bottom" : o3.join("-");
}
const o2 = e3.add(a2[s2]).round();
i2.setTransform(this._container, `${Ta[s2]} translate(${o2.x}px,${o2.y}px)`), Ia(this._container, s2, "popup");
}, this._onClose = () => {
this.remove();
}, this.options = t.e(Object.create(La), e2);
}
addTo(e2) {
return this._map && this.remove(), this._map = e2, this.options.closeOnClick && this._map.on("click", this._onClose), this.options.closeOnMove && this._map.on("move", this._onClose), this._map.on("remove", this.remove), this._update(), this._focusFirstElement(), this._trackPointer ? (this._map.on("mousemove", this._onMouseMove), this._map.on("mouseup", this._onMouseUp), this._container && this._container.classList.add("maplibregl-popup-track-pointer"), this._map._canvasContainer.classList.add("maplibregl-track-pointer")) : this._map.on("move", this._update), this.fire(new t.k("open")), this;
}
isOpen() {
return !!this._map;
}
getLngLat() {
return this._lngLat;
}
setLngLat(e2) {
return this._lngLat = t.L.convert(e2), this._pos = null, this._trackPointer = false, this._update(), this._map && (this._map.on("move", this._update), this._map.off("mousemove", this._onMouseMove), this._container && this._container.classList.remove("maplibregl-popup-track-pointer"), this._map._canvasContainer.classList.remove("maplibregl-track-pointer")), this;
}
trackPointer() {
return this._trackPointer = true, this._pos = null, this._update(), this._map && (this._map.off("move", this._update), this._map.on("mousemove", this._onMouseMove), this._map.on("drag", this._onDrag), this._container && this._container.classList.add("maplibregl-popup-track-pointer"), this._map._canvasContainer.classList.add("maplibregl-track-pointer")), this;
}
getElement() {
return this._container;
}
setText(t2) {
return this.setDOMContent(document.createTextNode(t2));
}
setHTML(t2) {
const e2 = document.createDocumentFragment(), i3 = document.createElement("body");
let s2;
for (i3.innerHTML = t2; s2 = i3.firstChild, s2; ) e2.appendChild(s2);
return this.setDOMContent(e2);
}
getMaxWidth() {
var t2;
return null === (t2 = this._container) || void 0 === t2 ? void 0 : t2.style.maxWidth;
}
setMaxWidth(t2) {
return this.options.maxWidth = t2, this._update(), this;
}
setDOMContent(t2) {
if (this._content) for (; this._content.hasChildNodes(); ) this._content.firstChild && this._content.removeChild(this._content.firstChild);
else this._content = i2.create("div", "maplibregl-popup-content", this._container);
return this._content.appendChild(t2), this._createCloseButton(), this._update(), this._focusFirstElement(), this;
}
addClassName(t2) {
this._container && this._container.classList.add(t2);
}
removeClassName(t2) {
this._container && this._container.classList.remove(t2);
}
setOffset(t2) {
return this.options.offset = t2, this._update(), this;
}
toggleClassName(t2) {
if (this._container) return this._container.classList.toggle(t2);
}
_createCloseButton() {
this.options.closeButton && (this._closeButton = i2.create("button", "maplibregl-popup-close-button", this._content), this._closeButton.type = "button", this._closeButton.setAttribute("aria-label", "Close popup"), this._closeButton.innerHTML = "&#215;", this._closeButton.addEventListener("click", this._onClose));
}
_focusFirstElement() {
if (!this.options.focusAfterOpen || !this._container) return;
const t2 = this._container.querySelector(Aa);
t2 && t2.focus();
}
}, Ba.Marker = Ea, Ba.Style = se, Ba.LngLat = t.L, Ba.LngLatBounds = L, Ba.Point = t.P, Ba.MercatorCoordinate = t.U, Ba.Evented = t.E, Ba.AJAXError = t.bi, Ba.config = t.c, Ba.CanvasSource = Z, Ba.GeoJSONSource = B, Ba.ImageSource = N, Ba.RasterDEMTileSource = F, Ba.RasterTileSource = k, Ba.VectorTileSource = R, Ba.VideoSource = U, Ba.setRTLTextPlugin = t.bj, Ba.getRTLTextPluginStatus = t.bk, Ba.prewarm = function() {
st().acquire(J);
}, Ba.clearPrewarmedResources = function() {
const t2 = it;
t2 && (t2.isPreloaded() && 1 === t2.numActive() ? (t2.release(J), it = null) : console.warn("Could not clear WebWorkers since there are active Map instances that still reference it. The pre-warmed WebWorker pool can only be cleared when all map instances have been removed with map.remove()"));
}, ka.extend(Ba, { isSafari: t.ac, getPerformanceMetrics: t.bg.getPerformanceMetrics }), Ba;
}));
var maplibregl$1 = maplibregl2;
return maplibregl$1;
}));
})(maplibreGl$1);
return maplibreGl$1.exports;
}
var maplibreGlExports = requireMaplibreGl();
const maplibregl = /* @__PURE__ */ getDefaultExportFromCjs(maplibreGlExports);
function normalizeComponent(scriptExports, render, staticRenderFns, functionalTemplate, injectStyles, scopeId, moduleIdentifier, shadowMode) {
var options = typeof scriptExports === "function" ? scriptExports.options : scriptExports;
if (render) {
options.render = render;
options.staticRenderFns = staticRenderFns;
options._compiled = true;
}
if (scopeId) {
options._scopeId = "data-v-" + scopeId;
}
return {
exports: scriptExports,
options
};
}
const _sfc_main$3 = {
props: {
center: {
type: Object,
required: true
},
zoom: {
type: Number,
required: true
},
markers: {
type: Array,
default: () => []
},
selectedMarkerId: {
type: String,
default: null
}
},
setup(props, { emit }) {
const mapContainer = Vue.ref(null);
const map2 = Vue.ref(null);
const loading = Vue.ref(true);
const markerElements = Vue.ref(/* @__PURE__ */ new Map());
const isDragging = Vue.ref(false);
Vue.onMounted(async () => {
await Vue.nextTick();
initMap();
});
Vue.onBeforeUnmount(() => {
if (map2.value) {
map2.value.remove();
map2.value = null;
}
markerElements.value.clear();
});
Vue.watch(() => props.center, (newCenter) => {
if (map2.value && map2.value.loaded() && !isDragging.value) {
const currentCenter = map2.value.getCenter();
if (Math.abs(currentCenter.lat - newCenter.lat) > 1e-5 || Math.abs(currentCenter.lng - newCenter.lon) > 1e-5) {
map2.value.setCenter([newCenter.lon, newCenter.lat]);
}
}
}, { deep: true });
Vue.watch(() => props.zoom, (newZoom) => {
if (map2.value && map2.value.loaded()) {
const currentZoom = map2.value.getZoom();
if (Math.abs(currentZoom - newZoom) > 0.01) {
map2.value.setZoom(newZoom);
}
}
});
Vue.watch(() => props.markers, () => {
updateMarkers();
}, { deep: true });
Vue.watch(() => props.selectedMarkerId, (newId) => {
updateMarkerSelection(newId);
});
function initMap() {
if (!mapContainer.value) {
console.error("Map container not found");
return;
}
loading.value = true;
try {
map2.value = new maplibregl.Map({
container: mapContainer.value,
style: {
version: 8,
sources: {
osm: {
type: "raster",
tiles: [
"https://a.tile.openstreetmap.org/{z}/{x}/{y}.png",
"https://b.tile.openstreetmap.org/{z}/{x}/{y}.png",
"https://c.tile.openstreetmap.org/{z}/{x}/{y}.png"
],
tileSize: 256,
attribution: '&copy; <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors'
}
},
layers: [
{
id: "osm",
type: "raster",
source: "osm",
minzoom: 0,
maxzoom: 19
}
]
},
center: [props.center.lon, props.center.lat],
zoom: props.zoom
});
map2.value.on("load", () => {
loading.value = false;
updateMarkers();
});
map2.value.on("click", (e) => {
const target = e.originalEvent.target;
const isMarkerClick = target.closest(".custom-marker");
if (!isMarkerClick) {
const clickPos = {
lat: e.lngLat.lat,
lng: e.lngLat.lng
};
emit("map-click", clickPos);
}
});
} catch (error) {
console.error("Error initializing map:", error);
loading.value = false;
}
}
function updateMarkers() {
if (!map2.value || !map2.value.loaded()) {
return;
}
markerElements.value.forEach(({ marker }) => {
if (marker) {
marker.remove();
}
});
markerElements.value.clear();
if (props.markers && Array.isArray(props.markers)) {
props.markers.forEach((markerData, index) => {
addMarkerToMap(markerData, index);
});
}
}
function addMarkerToMap(markerData, index) {
if (!map2.value || !markerData || !markerData.position) {
return;
}
const el = document.createElement("div");
el.className = "custom-marker";
if (markerData.iconUrl) {
el.classList.add("custom-icon");
const img = document.createElement("img");
img.src = markerData.iconUrl;
img.className = "marker-icon-image";
const size = markerData.iconSize || 40;
img.style.width = `${size}px`;
img.style.height = `${size}px`;
if (props.selectedMarkerId === markerData.id) {
img.classList.add("selected");
}
el.appendChild(img);
} else {
const inner = document.createElement("div");
inner.className = "marker-inner";
if (props.selectedMarkerId === markerData.id) {
inner.classList.add("selected");
}
const numberEl = document.createElement("div");
numberEl.className = "marker-number";
numberEl.textContent = index + 1;
inner.appendChild(numberEl);
el.appendChild(inner);
}
try {
const coords = [markerData.position.lon, markerData.position.lat];
const marker = new maplibregl.Marker({
element: el,
draggable: true,
anchor: "bottom"
}).setLngLat(coords).addTo(map2.value);
marker.on("dragstart", () => {
isDragging.value = true;
});
marker.on("dragend", () => {
const lngLat = marker.getLngLat();
emit("marker-moved", {
markerId: markerData.id,
position: {
lat: lngLat.lat,
lng: lngLat.lng
}
});
setTimeout(() => {
isDragging.value = false;
}, 100);
});
el.addEventListener("click", (e) => {
e.stopPropagation();
emit("marker-click", markerData.id);
});
el.addEventListener("dblclick", (e) => {
e.stopPropagation();
emit("marker-dblclick", markerData.id);
});
markerElements.value.set(markerData.id, {
marker,
element: el
});
} catch (error) {
console.error("Error adding marker to map:", error);
}
}
function updateMarkerSelection(selectedId) {
markerElements.value.forEach(({ element }, markerId) => {
if (element) {
const inner = element.querySelector(".marker-inner");
if (inner) {
if (markerId === selectedId) {
inner.classList.add("selected");
} else {
inner.classList.remove("selected");
}
}
const img = element.querySelector(".marker-icon-image");
if (img) {
if (markerId === selectedId) {
img.classList.add("selected");
} else {
img.classList.remove("selected");
}
}
}
});
}
function getCurrentCenter() {
if (map2.value && map2.value.loaded()) {
const center = map2.value.getCenter();
return {
lat: center.lat,
lon: center.lng
};
}
return {
lat: props.center.lat,
lon: props.center.lon
};
}
function getCurrentZoom() {
if (map2.value && map2.value.loaded()) {
return map2.value.getZoom();
}
return props.zoom;
}
function centerOnPosition(lat, lon) {
if (map2.value && map2.value.loaded()) {
map2.value.flyTo({
center: [lon, lat],
zoom: map2.value.getZoom(),
duration: 1e3
});
}
}
return {
mapContainer,
loading,
getCurrentCenter,
getCurrentZoom,
centerOnPosition
};
}
};
var _sfc_render$3 = function render() {
var _vm = this, _c = _vm._self._c;
return _c("div", { staticClass: "map-preview" }, [_c("div", { ref: "mapContainer", staticClass: "map-container" }), _vm.loading ? _c("div", { staticClass: "map-loading" }, [_c("div", { staticClass: "spinner" }), _c("span", [_vm._v("Loading map...")])]) : _vm._e()]);
};
var _sfc_staticRenderFns$3 = [];
_sfc_render$3._withStripped = true;
var __component__$3 = /* @__PURE__ */ normalizeComponent(
_sfc_main$3,
_sfc_render$3,
_sfc_staticRenderFns$3,
false,
null,
null
);
__component__$3.options.__file = "/Users/adrienpayet/Documents/code/en-cours/geoproject/public/site/plugins/map-editor/src/components/map/MapPreview.vue";
const MapPreview = __component__$3.exports;
const NOMINATIM_API = {
BASE_URL: "https://nominatim.openstreetmap.org/search",
USER_AGENT: "GeoProject/1.0 (Kirby CMS Map Editor)",
RATE_LIMIT_MS: 1e3,
// 1 request per second
MIN_QUERY_LENGTH: 3,
MAX_RESULTS: 5,
DEFAULT_LANGUAGE: "fr"
};
const DEBOUNCE_DELAYS = {
GEOCODING: 500
};
async function geocode(query) {
if (!query || query.trim().length < NOMINATIM_API.MIN_QUERY_LENGTH) {
return [];
}
try {
const params = new URLSearchParams({
q: query.trim(),
format: "json",
addressdetails: "1",
limit: String(NOMINATIM_API.MAX_RESULTS),
"accept-language": NOMINATIM_API.DEFAULT_LANGUAGE
});
const response = await fetch(
`${NOMINATIM_API.BASE_URL}?${params.toString()}`,
{
headers: {
"User-Agent": NOMINATIM_API.USER_AGENT
}
}
);
if (!response.ok) {
throw new Error(`Nominatim API error: ${response.status}`);
}
const data = await response.json();
return data.map((result) => ({
id: result.place_id,
displayName: result.display_name,
lat: parseFloat(result.lat),
lon: parseFloat(result.lon),
type: result.type,
importance: result.importance,
boundingBox: result.boundingbox
}));
} catch (error) {
console.error("Geocoding error:", error);
throw error;
}
}
function debounce(func, wait = 500) {
let timeout;
return function executedFunction(...args) {
const later = () => {
clearTimeout(timeout);
func(...args);
};
clearTimeout(timeout);
timeout = setTimeout(later, wait);
};
}
const _sfc_main$2 = {
emits: ["select-location", "center-map"],
setup(props, { emit }) {
const searchInput = Vue.ref(null);
const searchQuery = Vue.ref("");
const results = Vue.ref([]);
const isLoading = Vue.ref(false);
const error = Vue.ref(null);
const showResults = Vue.ref(false);
const selectedIndex = Vue.ref(-1);
const debouncedSearch = debounce(async (query) => {
if (!query || query.trim().length < 3) {
results.value = [];
showResults.value = false;
isLoading.value = false;
return;
}
isLoading.value = true;
error.value = null;
try {
const data = await geocode(query);
results.value = data;
showResults.value = true;
selectedIndex.value = -1;
} catch (err) {
error.value = "Erreur lors de la recherche. Veuillez réessayer.";
results.value = [];
} finally {
isLoading.value = false;
}
}, DEBOUNCE_DELAYS.GEOCODING);
function handleInput() {
debouncedSearch(searchQuery.value);
}
function selectResult(result) {
emit("select-location", {
lat: result.lat,
lon: result.lon,
displayName: result.displayName
});
searchQuery.value = result.displayName;
showResults.value = false;
}
function selectFirstResult() {
if (results.value.length > 0) {
selectResult(results.value[0]);
}
}
function navigateResults(direction) {
if (!showResults.value || results.value.length === 0) {
return;
}
selectedIndex.value += direction;
if (selectedIndex.value < 0) {
selectedIndex.value = results.value.length - 1;
} else if (selectedIndex.value >= results.value.length) {
selectedIndex.value = 0;
}
}
function clearSearch() {
searchQuery.value = "";
results.value = [];
showResults.value = false;
error.value = null;
selectedIndex.value = -1;
}
function focus() {
if (searchInput.value) {
searchInput.value.focus();
}
}
function handleClickOutside(event) {
if (!event.target.closest(".geocode-search")) {
showResults.value = false;
}
}
Vue.watch(showResults, (newValue) => {
if (newValue) {
setTimeout(() => {
document.addEventListener("click", handleClickOutside);
}, 100);
} else {
document.removeEventListener("click", handleClickOutside);
}
});
return {
searchInput,
searchQuery,
results,
isLoading,
error,
showResults,
selectedIndex,
handleInput,
selectResult,
selectFirstResult,
navigateResults,
clearSearch,
focus
};
}
};
var _sfc_render$2 = function render() {
var _vm = this, _c = _vm._self._c;
return _c("div", { staticClass: "geocode-search" }, [_c("div", { staticClass: "search-input-wrapper" }, [_c("input", { directives: [{ name: "model", rawName: "v-model", value: _vm.searchQuery, expression: "searchQuery" }], ref: "searchInput", staticClass: "search-input", attrs: { "type": "text", "placeholder": "Rechercher une adresse..." }, domProps: { "value": _vm.searchQuery }, on: { "input": [function($event) {
if ($event.target.composing) return;
_vm.searchQuery = $event.target.value;
}, _vm.handleInput], "keydown": [function($event) {
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "escape", void 0, $event.key, void 0)) return null;
return _vm.clearSearch.apply(null, arguments);
}, function($event) {
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "enter", 13, $event.key, "Enter")) return null;
$event.preventDefault();
return _vm.selectFirstResult.apply(null, arguments);
}, function($event) {
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "down", 40, $event.key, ["Down", "ArrowDown"])) return null;
$event.preventDefault();
return _vm.navigateResults(1);
}, function($event) {
if (!$event.type.indexOf("key") && _vm._k($event.keyCode, "up", 38, $event.key, ["Up", "ArrowUp"])) return null;
$event.preventDefault();
return _vm.navigateResults(-1);
}] } }), _vm.searchQuery ? _c("button", { staticClass: "clear-button", attrs: { "type": "button", "title": "Effacer" }, on: { "click": _vm.clearSearch } }, [_c("k-icon", { attrs: { "type": "cancel" } })], 1) : _vm._e(), _vm.isLoading ? _c("div", { staticClass: "search-spinner" }, [_c("div", { staticClass: "spinner-icon" })]) : _vm._e()]), _vm.showResults ? _c("div", { staticClass: "results-dropdown" }, [_vm.error ? _c("div", { staticClass: "error-message" }, [_c("k-icon", { attrs: { "type": "alert" } }), _c("span", [_vm._v(_vm._s(_vm.error))])], 1) : _vm.results.length === 0 && !_vm.isLoading ? _c("div", { staticClass: "no-results" }, [_vm._v(" Aucun résultat trouvé ")]) : _c("div", { staticClass: "results-list" }, _vm._l(_vm.results, function(result, index) {
return _c("div", { key: result.id, staticClass: "result-item", class: { active: index === _vm.selectedIndex }, on: { "click": function($event) {
return _vm.selectResult(result);
}, "mouseenter": function($event) {
_vm.selectedIndex = index;
} } }, [_c("div", { staticClass: "result-icon" }, [_c("k-icon", { attrs: { "type": "pin" } })], 1), _c("div", { staticClass: "result-content" }, [_c("div", { staticClass: "result-name" }, [_vm._v(_vm._s(result.displayName))]), _c("div", { staticClass: "result-coords" }, [_vm._v(" " + _vm._s(result.lat.toFixed(6)) + ", " + _vm._s(result.lon.toFixed(6)) + " ")])])]);
}), 0), _vm.results.length > 0 ? _c("div", { staticClass: "results-footer" }, [_c("small", [_vm._v("Powered by OpenStreetMap Nominatim")])]) : _vm._e()]) : _vm._e()]);
};
var _sfc_staticRenderFns$2 = [];
_sfc_render$2._withStripped = true;
var __component__$2 = /* @__PURE__ */ normalizeComponent(
_sfc_main$2,
_sfc_render$2,
_sfc_staticRenderFns$2,
false,
null,
null
);
__component__$2.options.__file = "/Users/adrienpayet/Documents/code/en-cours/geoproject/public/site/plugins/map-editor/src/components/map/GeocodeSearch.vue";
const GeocodeSearch = __component__$2.exports;
const _sfc_main$1 = {
components: {
GeocodeSearch
},
props: {
markers: {
type: Array,
required: true
},
selectedMarkerId: {
type: String,
default: null
},
maxMarkers: {
type: Number,
default: 50
}
},
emits: [
"add-marker",
"select-marker",
"edit-marker",
"delete-marker",
"select-location"
],
setup(props) {
const canAddMarker = Vue.computed(
() => props.markers.length < props.maxMarkers
);
return {
canAddMarker
};
}
};
var _sfc_render$1 = function render() {
var _vm = this, _c = _vm._self._c;
return _c("aside", { staticClass: "k-map-markers-sidebar" }, [_c("header", { staticClass: "k-section-header" }, [_c("k-headline", [_vm._v(" Marqueurs "), _c("k-counter", [_vm._v(_vm._s(_vm.markers.length) + "/" + _vm._s(_vm.maxMarkers))])], 1), _c("k-button", { attrs: { "icon": "add", "size": "xs", "variant": "filled", "title": "Ajouter un marqueur", "disabled": !_vm.canAddMarker }, on: { "click": function($event) {
return _vm.$emit("add-marker");
} } }, [_vm._v(" Ajouter ")])], 1), _c("div", { staticClass: "k-map-markers-search" }, [_c("GeocodeSearch", { on: { "select-location": function($event) {
return _vm.$emit("select-location", $event);
} } })], 1), _c("div", { staticClass: "k-map-markers-list" }, [_vm._l(_vm.markers, function(marker, index) {
return _c("div", { key: marker.id, staticClass: "k-map-marker-item", class: { "is-selected": _vm.selectedMarkerId === marker.id }, on: { "click": function($event) {
return _vm.$emit("select-marker", marker.id);
} } }, [_c("span", { staticClass: "k-map-marker-icon" }, [_vm._v(" " + _vm._s(index + 1) + " ")]), _c("span", { staticClass: "k-map-marker-text" }, [_vm._v(" " + _vm._s(marker.title || `Marqueur ${index + 1}`) + " ")]), _c("span", { staticClass: "k-map-marker-options" }, [_c("k-button", { attrs: { "icon": "open", "size": "xs", "title": "Modifier le marqueur" }, on: { "click": function($event) {
$event.stopPropagation();
return _vm.$emit("edit-marker", marker.id);
} } }), _c("k-button", { attrs: { "icon": "trash", "size": "xs", "title": "Supprimer le marqueur" }, on: { "click": function($event) {
$event.stopPropagation();
return _vm.$emit("delete-marker", marker.id);
} } })], 1)]);
}), _vm.markers.length === 0 ? _c("div", { staticClass: "k-map-markers-empty" }, [_c("k-icon", { attrs: { "type": "map-pin" } }), _c("p", { staticClass: "k-map-markers-empty-text" }, [_vm._v("Aucun marqueur")]), _c("p", { staticClass: "k-map-markers-empty-info" }, [_vm._v(' Cliquez sur la carte ou sur "Ajouter" pour créer un marqueur ')])], 1) : _vm._e()], 2)]);
};
var _sfc_staticRenderFns$1 = [];
_sfc_render$1._withStripped = true;
var __component__$1 = /* @__PURE__ */ normalizeComponent(
_sfc_main$1,
_sfc_render$1,
_sfc_staticRenderFns$1,
false,
null,
"fe272968"
);
__component__$1.options.__file = "/Users/adrienpayet/Documents/code/en-cours/geoproject/public/site/plugins/map-editor/src/components/map/MarkerList.vue";
const MarkerList = __component__$1.exports;
function useMarkersApi(pageId) {
const markers = Vue.ref([]);
const loading = Vue.ref(false);
const error = Vue.ref(null);
const getCsrfToken = () => {
if (window.panel && window.panel.csrf) {
return window.panel.csrf;
}
const meta = document.querySelector('meta[name="csrf"]');
if (meta && meta.content) {
return meta.content;
}
if (window.csrf) {
return window.csrf;
}
console.warn("CSRF token not found");
return "";
};
async function fetchMarkers() {
loading.value = true;
error.value = null;
try {
const response = await fetch(`/api/map-editor/pages/${pageId}/markers`, {
method: "GET",
headers: {
"Content-Type": "application/json"
}
});
const result = await response.json();
if (result.status === "error") {
throw new Error(result.message || "Failed to fetch markers");
}
markers.value = result.data.markers || [];
return markers.value;
} catch (err) {
error.value = err.message;
console.error("Error fetching markers:", err);
throw err;
} finally {
loading.value = false;
}
}
async function createMarker(position) {
loading.value = true;
error.value = null;
try {
const response = await fetch(`/api/map-editor/pages/${pageId}/markers`, {
method: "POST",
headers: {
"Content-Type": "application/json",
"X-CSRF": getCsrfToken()
},
body: JSON.stringify({ position })
});
const result = await response.json();
if (result.status === "error") {
throw new Error(result.message || "Failed to create marker");
}
const newMarker = result.data.marker;
markers.value.push(newMarker);
console.log(newMarker);
return newMarker;
} catch (err) {
error.value = err.message;
console.error("Error creating marker:", err);
throw err;
} finally {
loading.value = false;
}
}
async function updateMarkerPosition(markerId, position) {
loading.value = true;
error.value = null;
try {
const response = await fetch(
`/api/map-editor/pages/${pageId}/markers/${markerId}`,
{
method: "PATCH",
headers: {
"Content-Type": "application/json",
"X-CSRF": getCsrfToken()
},
body: JSON.stringify({ position })
}
);
const result = await response.json();
if (result.status === "error") {
throw new Error(result.message || "Failed to update marker position");
}
const index = markers.value.findIndex((m) => m.id === markerId);
if (index !== -1) {
markers.value[index] = result.data.marker;
}
return result.data.marker;
} catch (err) {
error.value = err.message;
console.error("Error updating marker position:", err);
throw err;
} finally {
loading.value = false;
}
}
async function deleteMarker(markerId) {
loading.value = true;
error.value = null;
try {
const response = await fetch(
`/api/map-editor/pages/${pageId}/markers/${markerId}`,
{
method: "DELETE",
headers: {
"Content-Type": "application/json",
"X-CSRF": getCsrfToken()
}
}
);
const result = await response.json();
if (result.status === "error") {
throw new Error(result.message || "Failed to delete marker");
}
const index = markers.value.findIndex((m) => m.id === markerId);
if (index !== -1) {
markers.value.splice(index, 1);
}
return true;
} catch (err) {
error.value = err.message;
console.error("Error deleting marker:", err);
throw err;
} finally {
loading.value = false;
}
}
return {
markers,
loading,
error,
fetchMarkers,
createMarker,
updateMarkerPosition,
deleteMarker
};
}
/*! js-yaml 4.1.1 https://github.com/nodeca/js-yaml @license MIT */
function isNothing(subject) {
return typeof subject === "undefined" || subject === null;
}
function isObject(subject) {
return typeof subject === "object" && subject !== null;
}
function toArray(sequence) {
if (Array.isArray(sequence)) return sequence;
else if (isNothing(sequence)) return [];
return [sequence];
}
function extend(target, source) {
var index, length, key, sourceKeys;
if (source) {
sourceKeys = Object.keys(source);
for (index = 0, length = sourceKeys.length; index < length; index += 1) {
key = sourceKeys[index];
target[key] = source[key];
}
}
return target;
}
function repeat(string, count) {
var result = "", cycle;
for (cycle = 0; cycle < count; cycle += 1) {
result += string;
}
return result;
}
function isNegativeZero(number) {
return number === 0 && Number.NEGATIVE_INFINITY === 1 / number;
}
var isNothing_1 = isNothing;
var isObject_1 = isObject;
var toArray_1 = toArray;
var repeat_1 = repeat;
var isNegativeZero_1 = isNegativeZero;
var extend_1 = extend;
var common = {
isNothing: isNothing_1,
isObject: isObject_1,
toArray: toArray_1,
repeat: repeat_1,
isNegativeZero: isNegativeZero_1,
extend: extend_1
};
function formatError(exception2, compact) {
var where = "", message = exception2.reason || "(unknown reason)";
if (!exception2.mark) return message;
if (exception2.mark.name) {
where += 'in "' + exception2.mark.name + '" ';
}
where += "(" + (exception2.mark.line + 1) + ":" + (exception2.mark.column + 1) + ")";
if (!compact && exception2.mark.snippet) {
where += "\n\n" + exception2.mark.snippet;
}
return message + " " + where;
}
function YAMLException$1(reason, mark) {
Error.call(this);
this.name = "YAMLException";
this.reason = reason;
this.mark = mark;
this.message = formatError(this, false);
if (Error.captureStackTrace) {
Error.captureStackTrace(this, this.constructor);
} else {
this.stack = new Error().stack || "";
}
}
YAMLException$1.prototype = Object.create(Error.prototype);
YAMLException$1.prototype.constructor = YAMLException$1;
YAMLException$1.prototype.toString = function toString(compact) {
return this.name + ": " + formatError(this, compact);
};
var exception = YAMLException$1;
function getLine(buffer, lineStart, lineEnd, position, maxLineLength) {
var head = "";
var tail = "";
var maxHalfLength = Math.floor(maxLineLength / 2) - 1;
if (position - lineStart > maxHalfLength) {
head = " ... ";
lineStart = position - maxHalfLength + head.length;
}
if (lineEnd - position > maxHalfLength) {
tail = " ...";
lineEnd = position + maxHalfLength - tail.length;
}
return {
str: head + buffer.slice(lineStart, lineEnd).replace(/\t/g, "→") + tail,
pos: position - lineStart + head.length
// relative position
};
}
function padStart(string, max) {
return common.repeat(" ", max - string.length) + string;
}
function makeSnippet(mark, options) {
options = Object.create(options || null);
if (!mark.buffer) return null;
if (!options.maxLength) options.maxLength = 79;
if (typeof options.indent !== "number") options.indent = 1;
if (typeof options.linesBefore !== "number") options.linesBefore = 3;
if (typeof options.linesAfter !== "number") options.linesAfter = 2;
var re = /\r?\n|\r|\0/g;
var lineStarts = [0];
var lineEnds = [];
var match;
var foundLineNo = -1;
while (match = re.exec(mark.buffer)) {
lineEnds.push(match.index);
lineStarts.push(match.index + match[0].length);
if (mark.position <= match.index && foundLineNo < 0) {
foundLineNo = lineStarts.length - 2;
}
}
if (foundLineNo < 0) foundLineNo = lineStarts.length - 1;
var result = "", i2, line;
var lineNoLength = Math.min(mark.line + options.linesAfter, lineEnds.length).toString().length;
var maxLineLength = options.maxLength - (options.indent + lineNoLength + 3);
for (i2 = 1; i2 <= options.linesBefore; i2++) {
if (foundLineNo - i2 < 0) break;
line = getLine(
mark.buffer,
lineStarts[foundLineNo - i2],
lineEnds[foundLineNo - i2],
mark.position - (lineStarts[foundLineNo] - lineStarts[foundLineNo - i2]),
maxLineLength
);
result = common.repeat(" ", options.indent) + padStart((mark.line - i2 + 1).toString(), lineNoLength) + " | " + line.str + "\n" + result;
}
line = getLine(mark.buffer, lineStarts[foundLineNo], lineEnds[foundLineNo], mark.position, maxLineLength);
result += common.repeat(" ", options.indent) + padStart((mark.line + 1).toString(), lineNoLength) + " | " + line.str + "\n";
result += common.repeat("-", options.indent + lineNoLength + 3 + line.pos) + "^\n";
for (i2 = 1; i2 <= options.linesAfter; i2++) {
if (foundLineNo + i2 >= lineEnds.length) break;
line = getLine(
mark.buffer,
lineStarts[foundLineNo + i2],
lineEnds[foundLineNo + i2],
mark.position - (lineStarts[foundLineNo] - lineStarts[foundLineNo + i2]),
maxLineLength
);
result += common.repeat(" ", options.indent) + padStart((mark.line + i2 + 1).toString(), lineNoLength) + " | " + line.str + "\n";
}
return result.replace(/\n$/, "");
}
var snippet = makeSnippet;
var TYPE_CONSTRUCTOR_OPTIONS = [
"kind",
"multi",
"resolve",
"construct",
"instanceOf",
"predicate",
"represent",
"representName",
"defaultStyle",
"styleAliases"
];
var YAML_NODE_KINDS = [
"scalar",
"sequence",
"mapping"
];
function compileStyleAliases(map2) {
var result = {};
if (map2 !== null) {
Object.keys(map2).forEach(function(style) {
map2[style].forEach(function(alias) {
result[String(alias)] = style;
});
});
}
return result;
}
function Type$1(tag, options) {
options = options || {};
Object.keys(options).forEach(function(name) {
if (TYPE_CONSTRUCTOR_OPTIONS.indexOf(name) === -1) {
throw new exception('Unknown option "' + name + '" is met in definition of "' + tag + '" YAML type.');
}
});
this.options = options;
this.tag = tag;
this.kind = options["kind"] || null;
this.resolve = options["resolve"] || function() {
return true;
};
this.construct = options["construct"] || function(data) {
return data;
};
this.instanceOf = options["instanceOf"] || null;
this.predicate = options["predicate"] || null;
this.represent = options["represent"] || null;
this.representName = options["representName"] || null;
this.defaultStyle = options["defaultStyle"] || null;
this.multi = options["multi"] || false;
this.styleAliases = compileStyleAliases(options["styleAliases"] || null);
if (YAML_NODE_KINDS.indexOf(this.kind) === -1) {
throw new exception('Unknown kind "' + this.kind + '" is specified for "' + tag + '" YAML type.');
}
}
var type = Type$1;
function compileList(schema2, name) {
var result = [];
schema2[name].forEach(function(currentType) {
var newIndex = result.length;
result.forEach(function(previousType, previousIndex) {
if (previousType.tag === currentType.tag && previousType.kind === currentType.kind && previousType.multi === currentType.multi) {
newIndex = previousIndex;
}
});
result[newIndex] = currentType;
});
return result;
}
function compileMap() {
var result = {
scalar: {},
sequence: {},
mapping: {},
fallback: {},
multi: {
scalar: [],
sequence: [],
mapping: [],
fallback: []
}
}, index, length;
function collectType(type2) {
if (type2.multi) {
result.multi[type2.kind].push(type2);
result.multi["fallback"].push(type2);
} else {
result[type2.kind][type2.tag] = result["fallback"][type2.tag] = type2;
}
}
for (index = 0, length = arguments.length; index < length; index += 1) {
arguments[index].forEach(collectType);
}
return result;
}
function Schema$1(definition) {
return this.extend(definition);
}
Schema$1.prototype.extend = function extend2(definition) {
var implicit = [];
var explicit = [];
if (definition instanceof type) {
explicit.push(definition);
} else if (Array.isArray(definition)) {
explicit = explicit.concat(definition);
} else if (definition && (Array.isArray(definition.implicit) || Array.isArray(definition.explicit))) {
if (definition.implicit) implicit = implicit.concat(definition.implicit);
if (definition.explicit) explicit = explicit.concat(definition.explicit);
} else {
throw new exception("Schema.extend argument should be a Type, [ Type ], or a schema definition ({ implicit: [...], explicit: [...] })");
}
implicit.forEach(function(type$1) {
if (!(type$1 instanceof type)) {
throw new exception("Specified list of YAML types (or a single Type object) contains a non-Type object.");
}
if (type$1.loadKind && type$1.loadKind !== "scalar") {
throw new exception("There is a non-scalar type in the implicit list of a schema. Implicit resolving of such types is not supported.");
}
if (type$1.multi) {
throw new exception("There is a multi type in the implicit list of a schema. Multi tags can only be listed as explicit.");
}
});
explicit.forEach(function(type$1) {
if (!(type$1 instanceof type)) {
throw new exception("Specified list of YAML types (or a single Type object) contains a non-Type object.");
}
});
var result = Object.create(Schema$1.prototype);
result.implicit = (this.implicit || []).concat(implicit);
result.explicit = (this.explicit || []).concat(explicit);
result.compiledImplicit = compileList(result, "implicit");
result.compiledExplicit = compileList(result, "explicit");
result.compiledTypeMap = compileMap(result.compiledImplicit, result.compiledExplicit);
return result;
};
var schema = Schema$1;
var str = new type("tag:yaml.org,2002:str", {
kind: "scalar",
construct: function(data) {
return data !== null ? data : "";
}
});
var seq = new type("tag:yaml.org,2002:seq", {
kind: "sequence",
construct: function(data) {
return data !== null ? data : [];
}
});
var map = new type("tag:yaml.org,2002:map", {
kind: "mapping",
construct: function(data) {
return data !== null ? data : {};
}
});
var failsafe = new schema({
explicit: [
str,
seq,
map
]
});
function resolveYamlNull(data) {
if (data === null) return true;
var max = data.length;
return max === 1 && data === "~" || max === 4 && (data === "null" || data === "Null" || data === "NULL");
}
function constructYamlNull() {
return null;
}
function isNull(object) {
return object === null;
}
var _null = new type("tag:yaml.org,2002:null", {
kind: "scalar",
resolve: resolveYamlNull,
construct: constructYamlNull,
predicate: isNull,
represent: {
canonical: function() {
return "~";
},
lowercase: function() {
return "null";
},
uppercase: function() {
return "NULL";
},
camelcase: function() {
return "Null";
},
empty: function() {
return "";
}
},
defaultStyle: "lowercase"
});
function resolveYamlBoolean(data) {
if (data === null) return false;
var max = data.length;
return max === 4 && (data === "true" || data === "True" || data === "TRUE") || max === 5 && (data === "false" || data === "False" || data === "FALSE");
}
function constructYamlBoolean(data) {
return data === "true" || data === "True" || data === "TRUE";
}
function isBoolean(object) {
return Object.prototype.toString.call(object) === "[object Boolean]";
}
var bool = new type("tag:yaml.org,2002:bool", {
kind: "scalar",
resolve: resolveYamlBoolean,
construct: constructYamlBoolean,
predicate: isBoolean,
represent: {
lowercase: function(object) {
return object ? "true" : "false";
},
uppercase: function(object) {
return object ? "TRUE" : "FALSE";
},
camelcase: function(object) {
return object ? "True" : "False";
}
},
defaultStyle: "lowercase"
});
function isHexCode(c) {
return 48 <= c && c <= 57 || 65 <= c && c <= 70 || 97 <= c && c <= 102;
}
function isOctCode(c) {
return 48 <= c && c <= 55;
}
function isDecCode(c) {
return 48 <= c && c <= 57;
}
function resolveYamlInteger(data) {
if (data === null) return false;
var max = data.length, index = 0, hasDigits = false, ch;
if (!max) return false;
ch = data[index];
if (ch === "-" || ch === "+") {
ch = data[++index];
}
if (ch === "0") {
if (index + 1 === max) return true;
ch = data[++index];
if (ch === "b") {
index++;
for (; index < max; index++) {
ch = data[index];
if (ch === "_") continue;
if (ch !== "0" && ch !== "1") return false;
hasDigits = true;
}
return hasDigits && ch !== "_";
}
if (ch === "x") {
index++;
for (; index < max; index++) {
ch = data[index];
if (ch === "_") continue;
if (!isHexCode(data.charCodeAt(index))) return false;
hasDigits = true;
}
return hasDigits && ch !== "_";
}
if (ch === "o") {
index++;
for (; index < max; index++) {
ch = data[index];
if (ch === "_") continue;
if (!isOctCode(data.charCodeAt(index))) return false;
hasDigits = true;
}
return hasDigits && ch !== "_";
}
}
if (ch === "_") return false;
for (; index < max; index++) {
ch = data[index];
if (ch === "_") continue;
if (!isDecCode(data.charCodeAt(index))) {
return false;
}
hasDigits = true;
}
if (!hasDigits || ch === "_") return false;
return true;
}
function constructYamlInteger(data) {
var value = data, sign = 1, ch;
if (value.indexOf("_") !== -1) {
value = value.replace(/_/g, "");
}
ch = value[0];
if (ch === "-" || ch === "+") {
if (ch === "-") sign = -1;
value = value.slice(1);
ch = value[0];
}
if (value === "0") return 0;
if (ch === "0") {
if (value[1] === "b") return sign * parseInt(value.slice(2), 2);
if (value[1] === "x") return sign * parseInt(value.slice(2), 16);
if (value[1] === "o") return sign * parseInt(value.slice(2), 8);
}
return sign * parseInt(value, 10);
}
function isInteger(object) {
return Object.prototype.toString.call(object) === "[object Number]" && (object % 1 === 0 && !common.isNegativeZero(object));
}
var int = new type("tag:yaml.org,2002:int", {
kind: "scalar",
resolve: resolveYamlInteger,
construct: constructYamlInteger,
predicate: isInteger,
represent: {
binary: function(obj) {
return obj >= 0 ? "0b" + obj.toString(2) : "-0b" + obj.toString(2).slice(1);
},
octal: function(obj) {
return obj >= 0 ? "0o" + obj.toString(8) : "-0o" + obj.toString(8).slice(1);
},
decimal: function(obj) {
return obj.toString(10);
},
/* eslint-disable max-len */
hexadecimal: function(obj) {
return obj >= 0 ? "0x" + obj.toString(16).toUpperCase() : "-0x" + obj.toString(16).toUpperCase().slice(1);
}
},
defaultStyle: "decimal",
styleAliases: {
binary: [2, "bin"],
octal: [8, "oct"],
decimal: [10, "dec"],
hexadecimal: [16, "hex"]
}
});
var YAML_FLOAT_PATTERN = new RegExp(
// 2.5e4, 2.5 and integers
"^(?:[-+]?(?:[0-9][0-9_]*)(?:\\.[0-9_]*)?(?:[eE][-+]?[0-9]+)?|\\.[0-9_]+(?:[eE][-+]?[0-9]+)?|[-+]?\\.(?:inf|Inf|INF)|\\.(?:nan|NaN|NAN))$"
);
function resolveYamlFloat(data) {
if (data === null) return false;
if (!YAML_FLOAT_PATTERN.test(data) || // Quick hack to not allow integers end with `_`
// Probably should update regexp & check speed
data[data.length - 1] === "_") {
return false;
}
return true;
}
function constructYamlFloat(data) {
var value, sign;
value = data.replace(/_/g, "").toLowerCase();
sign = value[0] === "-" ? -1 : 1;
if ("+-".indexOf(value[0]) >= 0) {
value = value.slice(1);
}
if (value === ".inf") {
return sign === 1 ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY;
} else if (value === ".nan") {
return NaN;
}
return sign * parseFloat(value, 10);
}
var SCIENTIFIC_WITHOUT_DOT = /^[-+]?[0-9]+e/;
function representYamlFloat(object, style) {
var res;
if (isNaN(object)) {
switch (style) {
case "lowercase":
return ".nan";
case "uppercase":
return ".NAN";
case "camelcase":
return ".NaN";
}
} else if (Number.POSITIVE_INFINITY === object) {
switch (style) {
case "lowercase":
return ".inf";
case "uppercase":
return ".INF";
case "camelcase":
return ".Inf";
}
} else if (Number.NEGATIVE_INFINITY === object) {
switch (style) {
case "lowercase":
return "-.inf";
case "uppercase":
return "-.INF";
case "camelcase":
return "-.Inf";
}
} else if (common.isNegativeZero(object)) {
return "-0.0";
}
res = object.toString(10);
return SCIENTIFIC_WITHOUT_DOT.test(res) ? res.replace("e", ".e") : res;
}
function isFloat(object) {
return Object.prototype.toString.call(object) === "[object Number]" && (object % 1 !== 0 || common.isNegativeZero(object));
}
var float = new type("tag:yaml.org,2002:float", {
kind: "scalar",
resolve: resolveYamlFloat,
construct: constructYamlFloat,
predicate: isFloat,
represent: representYamlFloat,
defaultStyle: "lowercase"
});
var json = failsafe.extend({
implicit: [
_null,
bool,
int,
float
]
});
var core = json;
var YAML_DATE_REGEXP = new RegExp(
"^([0-9][0-9][0-9][0-9])-([0-9][0-9])-([0-9][0-9])$"
);
var YAML_TIMESTAMP_REGEXP = new RegExp(
"^([0-9][0-9][0-9][0-9])-([0-9][0-9]?)-([0-9][0-9]?)(?:[Tt]|[ \\t]+)([0-9][0-9]?):([0-9][0-9]):([0-9][0-9])(?:\\.([0-9]*))?(?:[ \\t]*(Z|([-+])([0-9][0-9]?)(?::([0-9][0-9]))?))?$"
);
function resolveYamlTimestamp(data) {
if (data === null) return false;
if (YAML_DATE_REGEXP.exec(data) !== null) return true;
if (YAML_TIMESTAMP_REGEXP.exec(data) !== null) return true;
return false;
}
function constructYamlTimestamp(data) {
var match, year, month, day, hour, minute, second, fraction = 0, delta = null, tz_hour, tz_minute, date;
match = YAML_DATE_REGEXP.exec(data);
if (match === null) match = YAML_TIMESTAMP_REGEXP.exec(data);
if (match === null) throw new Error("Date resolve error");
year = +match[1];
month = +match[2] - 1;
day = +match[3];
if (!match[4]) {
return new Date(Date.UTC(year, month, day));
}
hour = +match[4];
minute = +match[5];
second = +match[6];
if (match[7]) {
fraction = match[7].slice(0, 3);
while (fraction.length < 3) {
fraction += "0";
}
fraction = +fraction;
}
if (match[9]) {
tz_hour = +match[10];
tz_minute = +(match[11] || 0);
delta = (tz_hour * 60 + tz_minute) * 6e4;
if (match[9] === "-") delta = -delta;
}
date = new Date(Date.UTC(year, month, day, hour, minute, second, fraction));
if (delta) date.setTime(date.getTime() - delta);
return date;
}
function representYamlTimestamp(object) {
return object.toISOString();
}
var timestamp = new type("tag:yaml.org,2002:timestamp", {
kind: "scalar",
resolve: resolveYamlTimestamp,
construct: constructYamlTimestamp,
instanceOf: Date,
represent: representYamlTimestamp
});
function resolveYamlMerge(data) {
return data === "<<" || data === null;
}
var merge = new type("tag:yaml.org,2002:merge", {
kind: "scalar",
resolve: resolveYamlMerge
});
var BASE64_MAP = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\n\r";
function resolveYamlBinary(data) {
if (data === null) return false;
var code, idx, bitlen = 0, max = data.length, map2 = BASE64_MAP;
for (idx = 0; idx < max; idx++) {
code = map2.indexOf(data.charAt(idx));
if (code > 64) continue;
if (code < 0) return false;
bitlen += 6;
}
return bitlen % 8 === 0;
}
function constructYamlBinary(data) {
var idx, tailbits, input = data.replace(/[\r\n=]/g, ""), max = input.length, map2 = BASE64_MAP, bits = 0, result = [];
for (idx = 0; idx < max; idx++) {
if (idx % 4 === 0 && idx) {
result.push(bits >> 16 & 255);
result.push(bits >> 8 & 255);
result.push(bits & 255);
}
bits = bits << 6 | map2.indexOf(input.charAt(idx));
}
tailbits = max % 4 * 6;
if (tailbits === 0) {
result.push(bits >> 16 & 255);
result.push(bits >> 8 & 255);
result.push(bits & 255);
} else if (tailbits === 18) {
result.push(bits >> 10 & 255);
result.push(bits >> 2 & 255);
} else if (tailbits === 12) {
result.push(bits >> 4 & 255);
}
return new Uint8Array(result);
}
function representYamlBinary(object) {
var result = "", bits = 0, idx, tail, max = object.length, map2 = BASE64_MAP;
for (idx = 0; idx < max; idx++) {
if (idx % 3 === 0 && idx) {
result += map2[bits >> 18 & 63];
result += map2[bits >> 12 & 63];
result += map2[bits >> 6 & 63];
result += map2[bits & 63];
}
bits = (bits << 8) + object[idx];
}
tail = max % 3;
if (tail === 0) {
result += map2[bits >> 18 & 63];
result += map2[bits >> 12 & 63];
result += map2[bits >> 6 & 63];
result += map2[bits & 63];
} else if (tail === 2) {
result += map2[bits >> 10 & 63];
result += map2[bits >> 4 & 63];
result += map2[bits << 2 & 63];
result += map2[64];
} else if (tail === 1) {
result += map2[bits >> 2 & 63];
result += map2[bits << 4 & 63];
result += map2[64];
result += map2[64];
}
return result;
}
function isBinary(obj) {
return Object.prototype.toString.call(obj) === "[object Uint8Array]";
}
var binary = new type("tag:yaml.org,2002:binary", {
kind: "scalar",
resolve: resolveYamlBinary,
construct: constructYamlBinary,
predicate: isBinary,
represent: representYamlBinary
});
var _hasOwnProperty$3 = Object.prototype.hasOwnProperty;
var _toString$2 = Object.prototype.toString;
function resolveYamlOmap(data) {
if (data === null) return true;
var objectKeys = [], index, length, pair, pairKey, pairHasKey, object = data;
for (index = 0, length = object.length; index < length; index += 1) {
pair = object[index];
pairHasKey = false;
if (_toString$2.call(pair) !== "[object Object]") return false;
for (pairKey in pair) {
if (_hasOwnProperty$3.call(pair, pairKey)) {
if (!pairHasKey) pairHasKey = true;
else return false;
}
}
if (!pairHasKey) return false;
if (objectKeys.indexOf(pairKey) === -1) objectKeys.push(pairKey);
else return false;
}
return true;
}
function constructYamlOmap(data) {
return data !== null ? data : [];
}
var omap = new type("tag:yaml.org,2002:omap", {
kind: "sequence",
resolve: resolveYamlOmap,
construct: constructYamlOmap
});
var _toString$1 = Object.prototype.toString;
function resolveYamlPairs(data) {
if (data === null) return true;
var index, length, pair, keys, result, object = data;
result = new Array(object.length);
for (index = 0, length = object.length; index < length; index += 1) {
pair = object[index];
if (_toString$1.call(pair) !== "[object Object]") return false;
keys = Object.keys(pair);
if (keys.length !== 1) return false;
result[index] = [keys[0], pair[keys[0]]];
}
return true;
}
function constructYamlPairs(data) {
if (data === null) return [];
var index, length, pair, keys, result, object = data;
result = new Array(object.length);
for (index = 0, length = object.length; index < length; index += 1) {
pair = object[index];
keys = Object.keys(pair);
result[index] = [keys[0], pair[keys[0]]];
}
return result;
}
var pairs = new type("tag:yaml.org,2002:pairs", {
kind: "sequence",
resolve: resolveYamlPairs,
construct: constructYamlPairs
});
var _hasOwnProperty$2 = Object.prototype.hasOwnProperty;
function resolveYamlSet(data) {
if (data === null) return true;
var key, object = data;
for (key in object) {
if (_hasOwnProperty$2.call(object, key)) {
if (object[key] !== null) return false;
}
}
return true;
}
function constructYamlSet(data) {
return data !== null ? data : {};
}
var set = new type("tag:yaml.org,2002:set", {
kind: "mapping",
resolve: resolveYamlSet,
construct: constructYamlSet
});
var _default = core.extend({
implicit: [
timestamp,
merge
],
explicit: [
binary,
omap,
pairs,
set
]
});
var _hasOwnProperty$1 = Object.prototype.hasOwnProperty;
var CONTEXT_FLOW_IN = 1;
var CONTEXT_FLOW_OUT = 2;
var CONTEXT_BLOCK_IN = 3;
var CONTEXT_BLOCK_OUT = 4;
var CHOMPING_CLIP = 1;
var CHOMPING_STRIP = 2;
var CHOMPING_KEEP = 3;
var PATTERN_NON_PRINTABLE = /[\x00-\x08\x0B\x0C\x0E-\x1F\x7F-\x84\x86-\x9F\uFFFE\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF]/;
var PATTERN_NON_ASCII_LINE_BREAKS = /[\x85\u2028\u2029]/;
var PATTERN_FLOW_INDICATORS = /[,\[\]\{\}]/;
var PATTERN_TAG_HANDLE = /^(?:!|!!|![a-z\-]+!)$/i;
var PATTERN_TAG_URI = /^(?:!|[^,\[\]\{\}])(?:%[0-9a-f]{2}|[0-9a-z\-#;\/\?:@&=\+\$,_\.!~\*'\(\)\[\]])*$/i;
function _class(obj) {
return Object.prototype.toString.call(obj);
}
function is_EOL(c) {
return c === 10 || c === 13;
}
function is_WHITE_SPACE(c) {
return c === 9 || c === 32;
}
function is_WS_OR_EOL(c) {
return c === 9 || c === 32 || c === 10 || c === 13;
}
function is_FLOW_INDICATOR(c) {
return c === 44 || c === 91 || c === 93 || c === 123 || c === 125;
}
function fromHexCode(c) {
var lc;
if (48 <= c && c <= 57) {
return c - 48;
}
lc = c | 32;
if (97 <= lc && lc <= 102) {
return lc - 97 + 10;
}
return -1;
}
function escapedHexLen(c) {
if (c === 120) {
return 2;
}
if (c === 117) {
return 4;
}
if (c === 85) {
return 8;
}
return 0;
}
function fromDecimalCode(c) {
if (48 <= c && c <= 57) {
return c - 48;
}
return -1;
}
function simpleEscapeSequence(c) {
return c === 48 ? "\0" : c === 97 ? "\x07" : c === 98 ? "\b" : c === 116 ? " " : c === 9 ? " " : c === 110 ? "\n" : c === 118 ? "\v" : c === 102 ? "\f" : c === 114 ? "\r" : c === 101 ? "\x1B" : c === 32 ? " " : c === 34 ? '"' : c === 47 ? "/" : c === 92 ? "\\" : c === 78 ? "…" : c === 95 ? " " : c === 76 ? "\u2028" : c === 80 ? "\u2029" : "";
}
function charFromCodepoint(c) {
if (c <= 65535) {
return String.fromCharCode(c);
}
return String.fromCharCode(
(c - 65536 >> 10) + 55296,
(c - 65536 & 1023) + 56320
);
}
function setProperty(object, key, value) {
if (key === "__proto__") {
Object.defineProperty(object, key, {
configurable: true,
enumerable: true,
writable: true,
value
});
} else {
object[key] = value;
}
}
var simpleEscapeCheck = new Array(256);
var simpleEscapeMap = new Array(256);
for (var i = 0; i < 256; i++) {
simpleEscapeCheck[i] = simpleEscapeSequence(i) ? 1 : 0;
simpleEscapeMap[i] = simpleEscapeSequence(i);
}
function State$1(input, options) {
this.input = input;
this.filename = options["filename"] || null;
this.schema = options["schema"] || _default;
this.onWarning = options["onWarning"] || null;
this.legacy = options["legacy"] || false;
this.json = options["json"] || false;
this.listener = options["listener"] || null;
this.implicitTypes = this.schema.compiledImplicit;
this.typeMap = this.schema.compiledTypeMap;
this.length = input.length;
this.position = 0;
this.line = 0;
this.lineStart = 0;
this.lineIndent = 0;
this.firstTabInLine = -1;
this.documents = [];
}
function generateError(state, message) {
var mark = {
name: state.filename,
buffer: state.input.slice(0, -1),
// omit trailing \0
position: state.position,
line: state.line,
column: state.position - state.lineStart
};
mark.snippet = snippet(mark);
return new exception(message, mark);
}
function throwError(state, message) {
throw generateError(state, message);
}
function throwWarning(state, message) {
if (state.onWarning) {
state.onWarning.call(null, generateError(state, message));
}
}
var directiveHandlers = {
YAML: function handleYamlDirective(state, name, args) {
var match, major, minor;
if (state.version !== null) {
throwError(state, "duplication of %YAML directive");
}
if (args.length !== 1) {
throwError(state, "YAML directive accepts exactly one argument");
}
match = /^([0-9]+)\.([0-9]+)$/.exec(args[0]);
if (match === null) {
throwError(state, "ill-formed argument of the YAML directive");
}
major = parseInt(match[1], 10);
minor = parseInt(match[2], 10);
if (major !== 1) {
throwError(state, "unacceptable YAML version of the document");
}
state.version = args[0];
state.checkLineBreaks = minor < 2;
if (minor !== 1 && minor !== 2) {
throwWarning(state, "unsupported YAML version of the document");
}
},
TAG: function handleTagDirective(state, name, args) {
var handle, prefix;
if (args.length !== 2) {
throwError(state, "TAG directive accepts exactly two arguments");
}
handle = args[0];
prefix = args[1];
if (!PATTERN_TAG_HANDLE.test(handle)) {
throwError(state, "ill-formed tag handle (first argument) of the TAG directive");
}
if (_hasOwnProperty$1.call(state.tagMap, handle)) {
throwError(state, 'there is a previously declared suffix for "' + handle + '" tag handle');
}
if (!PATTERN_TAG_URI.test(prefix)) {
throwError(state, "ill-formed tag prefix (second argument) of the TAG directive");
}
try {
prefix = decodeURIComponent(prefix);
} catch (err) {
throwError(state, "tag prefix is malformed: " + prefix);
}
state.tagMap[handle] = prefix;
}
};
function captureSegment(state, start, end, checkJson) {
var _position, _length, _character, _result;
if (start < end) {
_result = state.input.slice(start, end);
if (checkJson) {
for (_position = 0, _length = _result.length; _position < _length; _position += 1) {
_character = _result.charCodeAt(_position);
if (!(_character === 9 || 32 <= _character && _character <= 1114111)) {
throwError(state, "expected valid JSON character");
}
}
} else if (PATTERN_NON_PRINTABLE.test(_result)) {
throwError(state, "the stream contains non-printable characters");
}
state.result += _result;
}
}
function mergeMappings(state, destination, source, overridableKeys) {
var sourceKeys, key, index, quantity;
if (!common.isObject(source)) {
throwError(state, "cannot merge mappings; the provided source object is unacceptable");
}
sourceKeys = Object.keys(source);
for (index = 0, quantity = sourceKeys.length; index < quantity; index += 1) {
key = sourceKeys[index];
if (!_hasOwnProperty$1.call(destination, key)) {
setProperty(destination, key, source[key]);
overridableKeys[key] = true;
}
}
}
function storeMappingPair(state, _result, overridableKeys, keyTag, keyNode, valueNode, startLine, startLineStart, startPos) {
var index, quantity;
if (Array.isArray(keyNode)) {
keyNode = Array.prototype.slice.call(keyNode);
for (index = 0, quantity = keyNode.length; index < quantity; index += 1) {
if (Array.isArray(keyNode[index])) {
throwError(state, "nested arrays are not supported inside keys");
}
if (typeof keyNode === "object" && _class(keyNode[index]) === "[object Object]") {
keyNode[index] = "[object Object]";
}
}
}
if (typeof keyNode === "object" && _class(keyNode) === "[object Object]") {
keyNode = "[object Object]";
}
keyNode = String(keyNode);
if (_result === null) {
_result = {};
}
if (keyTag === "tag:yaml.org,2002:merge") {
if (Array.isArray(valueNode)) {
for (index = 0, quantity = valueNode.length; index < quantity; index += 1) {
mergeMappings(state, _result, valueNode[index], overridableKeys);
}
} else {
mergeMappings(state, _result, valueNode, overridableKeys);
}
} else {
if (!state.json && !_hasOwnProperty$1.call(overridableKeys, keyNode) && _hasOwnProperty$1.call(_result, keyNode)) {
state.line = startLine || state.line;
state.lineStart = startLineStart || state.lineStart;
state.position = startPos || state.position;
throwError(state, "duplicated mapping key");
}
setProperty(_result, keyNode, valueNode);
delete overridableKeys[keyNode];
}
return _result;
}
function readLineBreak(state) {
var ch;
ch = state.input.charCodeAt(state.position);
if (ch === 10) {
state.position++;
} else if (ch === 13) {
state.position++;
if (state.input.charCodeAt(state.position) === 10) {
state.position++;
}
} else {
throwError(state, "a line break is expected");
}
state.line += 1;
state.lineStart = state.position;
state.firstTabInLine = -1;
}
function skipSeparationSpace(state, allowComments, checkIndent) {
var lineBreaks = 0, ch = state.input.charCodeAt(state.position);
while (ch !== 0) {
while (is_WHITE_SPACE(ch)) {
if (ch === 9 && state.firstTabInLine === -1) {
state.firstTabInLine = state.position;
}
ch = state.input.charCodeAt(++state.position);
}
if (allowComments && ch === 35) {
do {
ch = state.input.charCodeAt(++state.position);
} while (ch !== 10 && ch !== 13 && ch !== 0);
}
if (is_EOL(ch)) {
readLineBreak(state);
ch = state.input.charCodeAt(state.position);
lineBreaks++;
state.lineIndent = 0;
while (ch === 32) {
state.lineIndent++;
ch = state.input.charCodeAt(++state.position);
}
} else {
break;
}
}
if (checkIndent !== -1 && lineBreaks !== 0 && state.lineIndent < checkIndent) {
throwWarning(state, "deficient indentation");
}
return lineBreaks;
}
function testDocumentSeparator(state) {
var _position = state.position, ch;
ch = state.input.charCodeAt(_position);
if ((ch === 45 || ch === 46) && ch === state.input.charCodeAt(_position + 1) && ch === state.input.charCodeAt(_position + 2)) {
_position += 3;
ch = state.input.charCodeAt(_position);
if (ch === 0 || is_WS_OR_EOL(ch)) {
return true;
}
}
return false;
}
function writeFoldedLines(state, count) {
if (count === 1) {
state.result += " ";
} else if (count > 1) {
state.result += common.repeat("\n", count - 1);
}
}
function readPlainScalar(state, nodeIndent, withinFlowCollection) {
var preceding, following, captureStart, captureEnd, hasPendingContent, _line, _lineStart, _lineIndent, _kind = state.kind, _result = state.result, ch;
ch = state.input.charCodeAt(state.position);
if (is_WS_OR_EOL(ch) || is_FLOW_INDICATOR(ch) || ch === 35 || ch === 38 || ch === 42 || ch === 33 || ch === 124 || ch === 62 || ch === 39 || ch === 34 || ch === 37 || ch === 64 || ch === 96) {
return false;
}
if (ch === 63 || ch === 45) {
following = state.input.charCodeAt(state.position + 1);
if (is_WS_OR_EOL(following) || withinFlowCollection && is_FLOW_INDICATOR(following)) {
return false;
}
}
state.kind = "scalar";
state.result = "";
captureStart = captureEnd = state.position;
hasPendingContent = false;
while (ch !== 0) {
if (ch === 58) {
following = state.input.charCodeAt(state.position + 1);
if (is_WS_OR_EOL(following) || withinFlowCollection && is_FLOW_INDICATOR(following)) {
break;
}
} else if (ch === 35) {
preceding = state.input.charCodeAt(state.position - 1);
if (is_WS_OR_EOL(preceding)) {
break;
}
} else if (state.position === state.lineStart && testDocumentSeparator(state) || withinFlowCollection && is_FLOW_INDICATOR(ch)) {
break;
} else if (is_EOL(ch)) {
_line = state.line;
_lineStart = state.lineStart;
_lineIndent = state.lineIndent;
skipSeparationSpace(state, false, -1);
if (state.lineIndent >= nodeIndent) {
hasPendingContent = true;
ch = state.input.charCodeAt(state.position);
continue;
} else {
state.position = captureEnd;
state.line = _line;
state.lineStart = _lineStart;
state.lineIndent = _lineIndent;
break;
}
}
if (hasPendingContent) {
captureSegment(state, captureStart, captureEnd, false);
writeFoldedLines(state, state.line - _line);
captureStart = captureEnd = state.position;
hasPendingContent = false;
}
if (!is_WHITE_SPACE(ch)) {
captureEnd = state.position + 1;
}
ch = state.input.charCodeAt(++state.position);
}
captureSegment(state, captureStart, captureEnd, false);
if (state.result) {
return true;
}
state.kind = _kind;
state.result = _result;
return false;
}
function readSingleQuotedScalar(state, nodeIndent) {
var ch, captureStart, captureEnd;
ch = state.input.charCodeAt(state.position);
if (ch !== 39) {
return false;
}
state.kind = "scalar";
state.result = "";
state.position++;
captureStart = captureEnd = state.position;
while ((ch = state.input.charCodeAt(state.position)) !== 0) {
if (ch === 39) {
captureSegment(state, captureStart, state.position, true);
ch = state.input.charCodeAt(++state.position);
if (ch === 39) {
captureStart = state.position;
state.position++;
captureEnd = state.position;
} else {
return true;
}
} else if (is_EOL(ch)) {
captureSegment(state, captureStart, captureEnd, true);
writeFoldedLines(state, skipSeparationSpace(state, false, nodeIndent));
captureStart = captureEnd = state.position;
} else if (state.position === state.lineStart && testDocumentSeparator(state)) {
throwError(state, "unexpected end of the document within a single quoted scalar");
} else {
state.position++;
captureEnd = state.position;
}
}
throwError(state, "unexpected end of the stream within a single quoted scalar");
}
function readDoubleQuotedScalar(state, nodeIndent) {
var captureStart, captureEnd, hexLength, hexResult, tmp, ch;
ch = state.input.charCodeAt(state.position);
if (ch !== 34) {
return false;
}
state.kind = "scalar";
state.result = "";
state.position++;
captureStart = captureEnd = state.position;
while ((ch = state.input.charCodeAt(state.position)) !== 0) {
if (ch === 34) {
captureSegment(state, captureStart, state.position, true);
state.position++;
return true;
} else if (ch === 92) {
captureSegment(state, captureStart, state.position, true);
ch = state.input.charCodeAt(++state.position);
if (is_EOL(ch)) {
skipSeparationSpace(state, false, nodeIndent);
} else if (ch < 256 && simpleEscapeCheck[ch]) {
state.result += simpleEscapeMap[ch];
state.position++;
} else if ((tmp = escapedHexLen(ch)) > 0) {
hexLength = tmp;
hexResult = 0;
for (; hexLength > 0; hexLength--) {
ch = state.input.charCodeAt(++state.position);
if ((tmp = fromHexCode(ch)) >= 0) {
hexResult = (hexResult << 4) + tmp;
} else {
throwError(state, "expected hexadecimal character");
}
}
state.result += charFromCodepoint(hexResult);
state.position++;
} else {
throwError(state, "unknown escape sequence");
}
captureStart = captureEnd = state.position;
} else if (is_EOL(ch)) {
captureSegment(state, captureStart, captureEnd, true);
writeFoldedLines(state, skipSeparationSpace(state, false, nodeIndent));
captureStart = captureEnd = state.position;
} else if (state.position === state.lineStart && testDocumentSeparator(state)) {
throwError(state, "unexpected end of the document within a double quoted scalar");
} else {
state.position++;
captureEnd = state.position;
}
}
throwError(state, "unexpected end of the stream within a double quoted scalar");
}
function readFlowCollection(state, nodeIndent) {
var readNext = true, _line, _lineStart, _pos, _tag = state.tag, _result, _anchor = state.anchor, following, terminator, isPair, isExplicitPair, isMapping, overridableKeys = /* @__PURE__ */ Object.create(null), keyNode, keyTag, valueNode, ch;
ch = state.input.charCodeAt(state.position);
if (ch === 91) {
terminator = 93;
isMapping = false;
_result = [];
} else if (ch === 123) {
terminator = 125;
isMapping = true;
_result = {};
} else {
return false;
}
if (state.anchor !== null) {
state.anchorMap[state.anchor] = _result;
}
ch = state.input.charCodeAt(++state.position);
while (ch !== 0) {
skipSeparationSpace(state, true, nodeIndent);
ch = state.input.charCodeAt(state.position);
if (ch === terminator) {
state.position++;
state.tag = _tag;
state.anchor = _anchor;
state.kind = isMapping ? "mapping" : "sequence";
state.result = _result;
return true;
} else if (!readNext) {
throwError(state, "missed comma between flow collection entries");
} else if (ch === 44) {
throwError(state, "expected the node content, but found ','");
}
keyTag = keyNode = valueNode = null;
isPair = isExplicitPair = false;
if (ch === 63) {
following = state.input.charCodeAt(state.position + 1);
if (is_WS_OR_EOL(following)) {
isPair = isExplicitPair = true;
state.position++;
skipSeparationSpace(state, true, nodeIndent);
}
}
_line = state.line;
_lineStart = state.lineStart;
_pos = state.position;
composeNode(state, nodeIndent, CONTEXT_FLOW_IN, false, true);
keyTag = state.tag;
keyNode = state.result;
skipSeparationSpace(state, true, nodeIndent);
ch = state.input.charCodeAt(state.position);
if ((isExplicitPair || state.line === _line) && ch === 58) {
isPair = true;
ch = state.input.charCodeAt(++state.position);
skipSeparationSpace(state, true, nodeIndent);
composeNode(state, nodeIndent, CONTEXT_FLOW_IN, false, true);
valueNode = state.result;
}
if (isMapping) {
storeMappingPair(state, _result, overridableKeys, keyTag, keyNode, valueNode, _line, _lineStart, _pos);
} else if (isPair) {
_result.push(storeMappingPair(state, null, overridableKeys, keyTag, keyNode, valueNode, _line, _lineStart, _pos));
} else {
_result.push(keyNode);
}
skipSeparationSpace(state, true, nodeIndent);
ch = state.input.charCodeAt(state.position);
if (ch === 44) {
readNext = true;
ch = state.input.charCodeAt(++state.position);
} else {
readNext = false;
}
}
throwError(state, "unexpected end of the stream within a flow collection");
}
function readBlockScalar(state, nodeIndent) {
var captureStart, folding, chomping = CHOMPING_CLIP, didReadContent = false, detectedIndent = false, textIndent = nodeIndent, emptyLines = 0, atMoreIndented = false, tmp, ch;
ch = state.input.charCodeAt(state.position);
if (ch === 124) {
folding = false;
} else if (ch === 62) {
folding = true;
} else {
return false;
}
state.kind = "scalar";
state.result = "";
while (ch !== 0) {
ch = state.input.charCodeAt(++state.position);
if (ch === 43 || ch === 45) {
if (CHOMPING_CLIP === chomping) {
chomping = ch === 43 ? CHOMPING_KEEP : CHOMPING_STRIP;
} else {
throwError(state, "repeat of a chomping mode identifier");
}
} else if ((tmp = fromDecimalCode(ch)) >= 0) {
if (tmp === 0) {
throwError(state, "bad explicit indentation width of a block scalar; it cannot be less than one");
} else if (!detectedIndent) {
textIndent = nodeIndent + tmp - 1;
detectedIndent = true;
} else {
throwError(state, "repeat of an indentation width identifier");
}
} else {
break;
}
}
if (is_WHITE_SPACE(ch)) {
do {
ch = state.input.charCodeAt(++state.position);
} while (is_WHITE_SPACE(ch));
if (ch === 35) {
do {
ch = state.input.charCodeAt(++state.position);
} while (!is_EOL(ch) && ch !== 0);
}
}
while (ch !== 0) {
readLineBreak(state);
state.lineIndent = 0;
ch = state.input.charCodeAt(state.position);
while ((!detectedIndent || state.lineIndent < textIndent) && ch === 32) {
state.lineIndent++;
ch = state.input.charCodeAt(++state.position);
}
if (!detectedIndent && state.lineIndent > textIndent) {
textIndent = state.lineIndent;
}
if (is_EOL(ch)) {
emptyLines++;
continue;
}
if (state.lineIndent < textIndent) {
if (chomping === CHOMPING_KEEP) {
state.result += common.repeat("\n", didReadContent ? 1 + emptyLines : emptyLines);
} else if (chomping === CHOMPING_CLIP) {
if (didReadContent) {
state.result += "\n";
}
}
break;
}
if (folding) {
if (is_WHITE_SPACE(ch)) {
atMoreIndented = true;
state.result += common.repeat("\n", didReadContent ? 1 + emptyLines : emptyLines);
} else if (atMoreIndented) {
atMoreIndented = false;
state.result += common.repeat("\n", emptyLines + 1);
} else if (emptyLines === 0) {
if (didReadContent) {
state.result += " ";
}
} else {
state.result += common.repeat("\n", emptyLines);
}
} else {
state.result += common.repeat("\n", didReadContent ? 1 + emptyLines : emptyLines);
}
didReadContent = true;
detectedIndent = true;
emptyLines = 0;
captureStart = state.position;
while (!is_EOL(ch) && ch !== 0) {
ch = state.input.charCodeAt(++state.position);
}
captureSegment(state, captureStart, state.position, false);
}
return true;
}
function readBlockSequence(state, nodeIndent) {
var _line, _tag = state.tag, _anchor = state.anchor, _result = [], following, detected = false, ch;
if (state.firstTabInLine !== -1) return false;
if (state.anchor !== null) {
state.anchorMap[state.anchor] = _result;
}
ch = state.input.charCodeAt(state.position);
while (ch !== 0) {
if (state.firstTabInLine !== -1) {
state.position = state.firstTabInLine;
throwError(state, "tab characters must not be used in indentation");
}
if (ch !== 45) {
break;
}
following = state.input.charCodeAt(state.position + 1);
if (!is_WS_OR_EOL(following)) {
break;
}
detected = true;
state.position++;
if (skipSeparationSpace(state, true, -1)) {
if (state.lineIndent <= nodeIndent) {
_result.push(null);
ch = state.input.charCodeAt(state.position);
continue;
}
}
_line = state.line;
composeNode(state, nodeIndent, CONTEXT_BLOCK_IN, false, true);
_result.push(state.result);
skipSeparationSpace(state, true, -1);
ch = state.input.charCodeAt(state.position);
if ((state.line === _line || state.lineIndent > nodeIndent) && ch !== 0) {
throwError(state, "bad indentation of a sequence entry");
} else if (state.lineIndent < nodeIndent) {
break;
}
}
if (detected) {
state.tag = _tag;
state.anchor = _anchor;
state.kind = "sequence";
state.result = _result;
return true;
}
return false;
}
function readBlockMapping(state, nodeIndent, flowIndent) {
var following, allowCompact, _line, _keyLine, _keyLineStart, _keyPos, _tag = state.tag, _anchor = state.anchor, _result = {}, overridableKeys = /* @__PURE__ */ Object.create(null), keyTag = null, keyNode = null, valueNode = null, atExplicitKey = false, detected = false, ch;
if (state.firstTabInLine !== -1) return false;
if (state.anchor !== null) {
state.anchorMap[state.anchor] = _result;
}
ch = state.input.charCodeAt(state.position);
while (ch !== 0) {
if (!atExplicitKey && state.firstTabInLine !== -1) {
state.position = state.firstTabInLine;
throwError(state, "tab characters must not be used in indentation");
}
following = state.input.charCodeAt(state.position + 1);
_line = state.line;
if ((ch === 63 || ch === 58) && is_WS_OR_EOL(following)) {
if (ch === 63) {
if (atExplicitKey) {
storeMappingPair(state, _result, overridableKeys, keyTag, keyNode, null, _keyLine, _keyLineStart, _keyPos);
keyTag = keyNode = valueNode = null;
}
detected = true;
atExplicitKey = true;
allowCompact = true;
} else if (atExplicitKey) {
atExplicitKey = false;
allowCompact = true;
} else {
throwError(state, "incomplete explicit mapping pair; a key node is missed; or followed by a non-tabulated empty line");
}
state.position += 1;
ch = following;
} else {
_keyLine = state.line;
_keyLineStart = state.lineStart;
_keyPos = state.position;
if (!composeNode(state, flowIndent, CONTEXT_FLOW_OUT, false, true)) {
break;
}
if (state.line === _line) {
ch = state.input.charCodeAt(state.position);
while (is_WHITE_SPACE(ch)) {
ch = state.input.charCodeAt(++state.position);
}
if (ch === 58) {
ch = state.input.charCodeAt(++state.position);
if (!is_WS_OR_EOL(ch)) {
throwError(state, "a whitespace character is expected after the key-value separator within a block mapping");
}
if (atExplicitKey) {
storeMappingPair(state, _result, overridableKeys, keyTag, keyNode, null, _keyLine, _keyLineStart, _keyPos);
keyTag = keyNode = valueNode = null;
}
detected = true;
atExplicitKey = false;
allowCompact = false;
keyTag = state.tag;
keyNode = state.result;
} else if (detected) {
throwError(state, "can not read an implicit mapping pair; a colon is missed");
} else {
state.tag = _tag;
state.anchor = _anchor;
return true;
}
} else if (detected) {
throwError(state, "can not read a block mapping entry; a multiline key may not be an implicit key");
} else {
state.tag = _tag;
state.anchor = _anchor;
return true;
}
}
if (state.line === _line || state.lineIndent > nodeIndent) {
if (atExplicitKey) {
_keyLine = state.line;
_keyLineStart = state.lineStart;
_keyPos = state.position;
}
if (composeNode(state, nodeIndent, CONTEXT_BLOCK_OUT, true, allowCompact)) {
if (atExplicitKey) {
keyNode = state.result;
} else {
valueNode = state.result;
}
}
if (!atExplicitKey) {
storeMappingPair(state, _result, overridableKeys, keyTag, keyNode, valueNode, _keyLine, _keyLineStart, _keyPos);
keyTag = keyNode = valueNode = null;
}
skipSeparationSpace(state, true, -1);
ch = state.input.charCodeAt(state.position);
}
if ((state.line === _line || state.lineIndent > nodeIndent) && ch !== 0) {
throwError(state, "bad indentation of a mapping entry");
} else if (state.lineIndent < nodeIndent) {
break;
}
}
if (atExplicitKey) {
storeMappingPair(state, _result, overridableKeys, keyTag, keyNode, null, _keyLine, _keyLineStart, _keyPos);
}
if (detected) {
state.tag = _tag;
state.anchor = _anchor;
state.kind = "mapping";
state.result = _result;
}
return detected;
}
function readTagProperty(state) {
var _position, isVerbatim = false, isNamed = false, tagHandle, tagName, ch;
ch = state.input.charCodeAt(state.position);
if (ch !== 33) return false;
if (state.tag !== null) {
throwError(state, "duplication of a tag property");
}
ch = state.input.charCodeAt(++state.position);
if (ch === 60) {
isVerbatim = true;
ch = state.input.charCodeAt(++state.position);
} else if (ch === 33) {
isNamed = true;
tagHandle = "!!";
ch = state.input.charCodeAt(++state.position);
} else {
tagHandle = "!";
}
_position = state.position;
if (isVerbatim) {
do {
ch = state.input.charCodeAt(++state.position);
} while (ch !== 0 && ch !== 62);
if (state.position < state.length) {
tagName = state.input.slice(_position, state.position);
ch = state.input.charCodeAt(++state.position);
} else {
throwError(state, "unexpected end of the stream within a verbatim tag");
}
} else {
while (ch !== 0 && !is_WS_OR_EOL(ch)) {
if (ch === 33) {
if (!isNamed) {
tagHandle = state.input.slice(_position - 1, state.position + 1);
if (!PATTERN_TAG_HANDLE.test(tagHandle)) {
throwError(state, "named tag handle cannot contain such characters");
}
isNamed = true;
_position = state.position + 1;
} else {
throwError(state, "tag suffix cannot contain exclamation marks");
}
}
ch = state.input.charCodeAt(++state.position);
}
tagName = state.input.slice(_position, state.position);
if (PATTERN_FLOW_INDICATORS.test(tagName)) {
throwError(state, "tag suffix cannot contain flow indicator characters");
}
}
if (tagName && !PATTERN_TAG_URI.test(tagName)) {
throwError(state, "tag name cannot contain such characters: " + tagName);
}
try {
tagName = decodeURIComponent(tagName);
} catch (err) {
throwError(state, "tag name is malformed: " + tagName);
}
if (isVerbatim) {
state.tag = tagName;
} else if (_hasOwnProperty$1.call(state.tagMap, tagHandle)) {
state.tag = state.tagMap[tagHandle] + tagName;
} else if (tagHandle === "!") {
state.tag = "!" + tagName;
} else if (tagHandle === "!!") {
state.tag = "tag:yaml.org,2002:" + tagName;
} else {
throwError(state, 'undeclared tag handle "' + tagHandle + '"');
}
return true;
}
function readAnchorProperty(state) {
var _position, ch;
ch = state.input.charCodeAt(state.position);
if (ch !== 38) return false;
if (state.anchor !== null) {
throwError(state, "duplication of an anchor property");
}
ch = state.input.charCodeAt(++state.position);
_position = state.position;
while (ch !== 0 && !is_WS_OR_EOL(ch) && !is_FLOW_INDICATOR(ch)) {
ch = state.input.charCodeAt(++state.position);
}
if (state.position === _position) {
throwError(state, "name of an anchor node must contain at least one character");
}
state.anchor = state.input.slice(_position, state.position);
return true;
}
function readAlias(state) {
var _position, alias, ch;
ch = state.input.charCodeAt(state.position);
if (ch !== 42) return false;
ch = state.input.charCodeAt(++state.position);
_position = state.position;
while (ch !== 0 && !is_WS_OR_EOL(ch) && !is_FLOW_INDICATOR(ch)) {
ch = state.input.charCodeAt(++state.position);
}
if (state.position === _position) {
throwError(state, "name of an alias node must contain at least one character");
}
alias = state.input.slice(_position, state.position);
if (!_hasOwnProperty$1.call(state.anchorMap, alias)) {
throwError(state, 'unidentified alias "' + alias + '"');
}
state.result = state.anchorMap[alias];
skipSeparationSpace(state, true, -1);
return true;
}
function composeNode(state, parentIndent, nodeContext, allowToSeek, allowCompact) {
var allowBlockStyles, allowBlockScalars, allowBlockCollections, indentStatus = 1, atNewLine = false, hasContent = false, typeIndex, typeQuantity, typeList, type2, flowIndent, blockIndent;
if (state.listener !== null) {
state.listener("open", state);
}
state.tag = null;
state.anchor = null;
state.kind = null;
state.result = null;
allowBlockStyles = allowBlockScalars = allowBlockCollections = CONTEXT_BLOCK_OUT === nodeContext || CONTEXT_BLOCK_IN === nodeContext;
if (allowToSeek) {
if (skipSeparationSpace(state, true, -1)) {
atNewLine = true;
if (state.lineIndent > parentIndent) {
indentStatus = 1;
} else if (state.lineIndent === parentIndent) {
indentStatus = 0;
} else if (state.lineIndent < parentIndent) {
indentStatus = -1;
}
}
}
if (indentStatus === 1) {
while (readTagProperty(state) || readAnchorProperty(state)) {
if (skipSeparationSpace(state, true, -1)) {
atNewLine = true;
allowBlockCollections = allowBlockStyles;
if (state.lineIndent > parentIndent) {
indentStatus = 1;
} else if (state.lineIndent === parentIndent) {
indentStatus = 0;
} else if (state.lineIndent < parentIndent) {
indentStatus = -1;
}
} else {
allowBlockCollections = false;
}
}
}
if (allowBlockCollections) {
allowBlockCollections = atNewLine || allowCompact;
}
if (indentStatus === 1 || CONTEXT_BLOCK_OUT === nodeContext) {
if (CONTEXT_FLOW_IN === nodeContext || CONTEXT_FLOW_OUT === nodeContext) {
flowIndent = parentIndent;
} else {
flowIndent = parentIndent + 1;
}
blockIndent = state.position - state.lineStart;
if (indentStatus === 1) {
if (allowBlockCollections && (readBlockSequence(state, blockIndent) || readBlockMapping(state, blockIndent, flowIndent)) || readFlowCollection(state, flowIndent)) {
hasContent = true;
} else {
if (allowBlockScalars && readBlockScalar(state, flowIndent) || readSingleQuotedScalar(state, flowIndent) || readDoubleQuotedScalar(state, flowIndent)) {
hasContent = true;
} else if (readAlias(state)) {
hasContent = true;
if (state.tag !== null || state.anchor !== null) {
throwError(state, "alias node should not have any properties");
}
} else if (readPlainScalar(state, flowIndent, CONTEXT_FLOW_IN === nodeContext)) {
hasContent = true;
if (state.tag === null) {
state.tag = "?";
}
}
if (state.anchor !== null) {
state.anchorMap[state.anchor] = state.result;
}
}
} else if (indentStatus === 0) {
hasContent = allowBlockCollections && readBlockSequence(state, blockIndent);
}
}
if (state.tag === null) {
if (state.anchor !== null) {
state.anchorMap[state.anchor] = state.result;
}
} else if (state.tag === "?") {
if (state.result !== null && state.kind !== "scalar") {
throwError(state, 'unacceptable node kind for !<?> tag; it should be "scalar", not "' + state.kind + '"');
}
for (typeIndex = 0, typeQuantity = state.implicitTypes.length; typeIndex < typeQuantity; typeIndex += 1) {
type2 = state.implicitTypes[typeIndex];
if (type2.resolve(state.result)) {
state.result = type2.construct(state.result);
state.tag = type2.tag;
if (state.anchor !== null) {
state.anchorMap[state.anchor] = state.result;
}
break;
}
}
} else if (state.tag !== "!") {
if (_hasOwnProperty$1.call(state.typeMap[state.kind || "fallback"], state.tag)) {
type2 = state.typeMap[state.kind || "fallback"][state.tag];
} else {
type2 = null;
typeList = state.typeMap.multi[state.kind || "fallback"];
for (typeIndex = 0, typeQuantity = typeList.length; typeIndex < typeQuantity; typeIndex += 1) {
if (state.tag.slice(0, typeList[typeIndex].tag.length) === typeList[typeIndex].tag) {
type2 = typeList[typeIndex];
break;
}
}
}
if (!type2) {
throwError(state, "unknown tag !<" + state.tag + ">");
}
if (state.result !== null && type2.kind !== state.kind) {
throwError(state, "unacceptable node kind for !<" + state.tag + '> tag; it should be "' + type2.kind + '", not "' + state.kind + '"');
}
if (!type2.resolve(state.result, state.tag)) {
throwError(state, "cannot resolve a node with !<" + state.tag + "> explicit tag");
} else {
state.result = type2.construct(state.result, state.tag);
if (state.anchor !== null) {
state.anchorMap[state.anchor] = state.result;
}
}
}
if (state.listener !== null) {
state.listener("close", state);
}
return state.tag !== null || state.anchor !== null || hasContent;
}
function readDocument(state) {
var documentStart = state.position, _position, directiveName, directiveArgs, hasDirectives = false, ch;
state.version = null;
state.checkLineBreaks = state.legacy;
state.tagMap = /* @__PURE__ */ Object.create(null);
state.anchorMap = /* @__PURE__ */ Object.create(null);
while ((ch = state.input.charCodeAt(state.position)) !== 0) {
skipSeparationSpace(state, true, -1);
ch = state.input.charCodeAt(state.position);
if (state.lineIndent > 0 || ch !== 37) {
break;
}
hasDirectives = true;
ch = state.input.charCodeAt(++state.position);
_position = state.position;
while (ch !== 0 && !is_WS_OR_EOL(ch)) {
ch = state.input.charCodeAt(++state.position);
}
directiveName = state.input.slice(_position, state.position);
directiveArgs = [];
if (directiveName.length < 1) {
throwError(state, "directive name must not be less than one character in length");
}
while (ch !== 0) {
while (is_WHITE_SPACE(ch)) {
ch = state.input.charCodeAt(++state.position);
}
if (ch === 35) {
do {
ch = state.input.charCodeAt(++state.position);
} while (ch !== 0 && !is_EOL(ch));
break;
}
if (is_EOL(ch)) break;
_position = state.position;
while (ch !== 0 && !is_WS_OR_EOL(ch)) {
ch = state.input.charCodeAt(++state.position);
}
directiveArgs.push(state.input.slice(_position, state.position));
}
if (ch !== 0) readLineBreak(state);
if (_hasOwnProperty$1.call(directiveHandlers, directiveName)) {
directiveHandlers[directiveName](state, directiveName, directiveArgs);
} else {
throwWarning(state, 'unknown document directive "' + directiveName + '"');
}
}
skipSeparationSpace(state, true, -1);
if (state.lineIndent === 0 && state.input.charCodeAt(state.position) === 45 && state.input.charCodeAt(state.position + 1) === 45 && state.input.charCodeAt(state.position + 2) === 45) {
state.position += 3;
skipSeparationSpace(state, true, -1);
} else if (hasDirectives) {
throwError(state, "directives end mark is expected");
}
composeNode(state, state.lineIndent - 1, CONTEXT_BLOCK_OUT, false, true);
skipSeparationSpace(state, true, -1);
if (state.checkLineBreaks && PATTERN_NON_ASCII_LINE_BREAKS.test(state.input.slice(documentStart, state.position))) {
throwWarning(state, "non-ASCII line breaks are interpreted as content");
}
state.documents.push(state.result);
if (state.position === state.lineStart && testDocumentSeparator(state)) {
if (state.input.charCodeAt(state.position) === 46) {
state.position += 3;
skipSeparationSpace(state, true, -1);
}
return;
}
if (state.position < state.length - 1) {
throwError(state, "end of the stream or a document separator is expected");
} else {
return;
}
}
function loadDocuments(input, options) {
input = String(input);
options = options || {};
if (input.length !== 0) {
if (input.charCodeAt(input.length - 1) !== 10 && input.charCodeAt(input.length - 1) !== 13) {
input += "\n";
}
if (input.charCodeAt(0) === 65279) {
input = input.slice(1);
}
}
var state = new State$1(input, options);
var nullpos = input.indexOf("\0");
if (nullpos !== -1) {
state.position = nullpos;
throwError(state, "null byte is not allowed in input");
}
state.input += "\0";
while (state.input.charCodeAt(state.position) === 32) {
state.lineIndent += 1;
state.position += 1;
}
while (state.position < state.length - 1) {
readDocument(state);
}
return state.documents;
}
function loadAll$1(input, iterator, options) {
if (iterator !== null && typeof iterator === "object" && typeof options === "undefined") {
options = iterator;
iterator = null;
}
var documents = loadDocuments(input, options);
if (typeof iterator !== "function") {
return documents;
}
for (var index = 0, length = documents.length; index < length; index += 1) {
iterator(documents[index]);
}
}
function load$1(input, options) {
var documents = loadDocuments(input, options);
if (documents.length === 0) {
return void 0;
} else if (documents.length === 1) {
return documents[0];
}
throw new exception("expected a single document in the stream, but found more");
}
var loadAll_1 = loadAll$1;
var load_1 = load$1;
var loader = {
loadAll: loadAll_1,
load: load_1
};
var _toString = Object.prototype.toString;
var _hasOwnProperty = Object.prototype.hasOwnProperty;
var CHAR_BOM = 65279;
var CHAR_TAB = 9;
var CHAR_LINE_FEED = 10;
var CHAR_CARRIAGE_RETURN = 13;
var CHAR_SPACE = 32;
var CHAR_EXCLAMATION = 33;
var CHAR_DOUBLE_QUOTE = 34;
var CHAR_SHARP = 35;
var CHAR_PERCENT = 37;
var CHAR_AMPERSAND = 38;
var CHAR_SINGLE_QUOTE = 39;
var CHAR_ASTERISK = 42;
var CHAR_COMMA = 44;
var CHAR_MINUS = 45;
var CHAR_COLON = 58;
var CHAR_EQUALS = 61;
var CHAR_GREATER_THAN = 62;
var CHAR_QUESTION = 63;
var CHAR_COMMERCIAL_AT = 64;
var CHAR_LEFT_SQUARE_BRACKET = 91;
var CHAR_RIGHT_SQUARE_BRACKET = 93;
var CHAR_GRAVE_ACCENT = 96;
var CHAR_LEFT_CURLY_BRACKET = 123;
var CHAR_VERTICAL_LINE = 124;
var CHAR_RIGHT_CURLY_BRACKET = 125;
var ESCAPE_SEQUENCES = {};
ESCAPE_SEQUENCES[0] = "\\0";
ESCAPE_SEQUENCES[7] = "\\a";
ESCAPE_SEQUENCES[8] = "\\b";
ESCAPE_SEQUENCES[9] = "\\t";
ESCAPE_SEQUENCES[10] = "\\n";
ESCAPE_SEQUENCES[11] = "\\v";
ESCAPE_SEQUENCES[12] = "\\f";
ESCAPE_SEQUENCES[13] = "\\r";
ESCAPE_SEQUENCES[27] = "\\e";
ESCAPE_SEQUENCES[34] = '\\"';
ESCAPE_SEQUENCES[92] = "\\\\";
ESCAPE_SEQUENCES[133] = "\\N";
ESCAPE_SEQUENCES[160] = "\\_";
ESCAPE_SEQUENCES[8232] = "\\L";
ESCAPE_SEQUENCES[8233] = "\\P";
var DEPRECATED_BOOLEANS_SYNTAX = [
"y",
"Y",
"yes",
"Yes",
"YES",
"on",
"On",
"ON",
"n",
"N",
"no",
"No",
"NO",
"off",
"Off",
"OFF"
];
var DEPRECATED_BASE60_SYNTAX = /^[-+]?[0-9_]+(?::[0-9_]+)+(?:\.[0-9_]*)?$/;
function compileStyleMap(schema2, map2) {
var result, keys, index, length, tag, style, type2;
if (map2 === null) return {};
result = {};
keys = Object.keys(map2);
for (index = 0, length = keys.length; index < length; index += 1) {
tag = keys[index];
style = String(map2[tag]);
if (tag.slice(0, 2) === "!!") {
tag = "tag:yaml.org,2002:" + tag.slice(2);
}
type2 = schema2.compiledTypeMap["fallback"][tag];
if (type2 && _hasOwnProperty.call(type2.styleAliases, style)) {
style = type2.styleAliases[style];
}
result[tag] = style;
}
return result;
}
function encodeHex(character) {
var string, handle, length;
string = character.toString(16).toUpperCase();
if (character <= 255) {
handle = "x";
length = 2;
} else if (character <= 65535) {
handle = "u";
length = 4;
} else if (character <= 4294967295) {
handle = "U";
length = 8;
} else {
throw new exception("code point within a string may not be greater than 0xFFFFFFFF");
}
return "\\" + handle + common.repeat("0", length - string.length) + string;
}
var QUOTING_TYPE_SINGLE = 1, QUOTING_TYPE_DOUBLE = 2;
function State(options) {
this.schema = options["schema"] || _default;
this.indent = Math.max(1, options["indent"] || 2);
this.noArrayIndent = options["noArrayIndent"] || false;
this.skipInvalid = options["skipInvalid"] || false;
this.flowLevel = common.isNothing(options["flowLevel"]) ? -1 : options["flowLevel"];
this.styleMap = compileStyleMap(this.schema, options["styles"] || null);
this.sortKeys = options["sortKeys"] || false;
this.lineWidth = options["lineWidth"] || 80;
this.noRefs = options["noRefs"] || false;
this.noCompatMode = options["noCompatMode"] || false;
this.condenseFlow = options["condenseFlow"] || false;
this.quotingType = options["quotingType"] === '"' ? QUOTING_TYPE_DOUBLE : QUOTING_TYPE_SINGLE;
this.forceQuotes = options["forceQuotes"] || false;
this.replacer = typeof options["replacer"] === "function" ? options["replacer"] : null;
this.implicitTypes = this.schema.compiledImplicit;
this.explicitTypes = this.schema.compiledExplicit;
this.tag = null;
this.result = "";
this.duplicates = [];
this.usedDuplicates = null;
}
function indentString(string, spaces) {
var ind = common.repeat(" ", spaces), position = 0, next = -1, result = "", line, length = string.length;
while (position < length) {
next = string.indexOf("\n", position);
if (next === -1) {
line = string.slice(position);
position = length;
} else {
line = string.slice(position, next + 1);
position = next + 1;
}
if (line.length && line !== "\n") result += ind;
result += line;
}
return result;
}
function generateNextLine(state, level) {
return "\n" + common.repeat(" ", state.indent * level);
}
function testImplicitResolving(state, str2) {
var index, length, type2;
for (index = 0, length = state.implicitTypes.length; index < length; index += 1) {
type2 = state.implicitTypes[index];
if (type2.resolve(str2)) {
return true;
}
}
return false;
}
function isWhitespace(c) {
return c === CHAR_SPACE || c === CHAR_TAB;
}
function isPrintable(c) {
return 32 <= c && c <= 126 || 161 <= c && c <= 55295 && c !== 8232 && c !== 8233 || 57344 <= c && c <= 65533 && c !== CHAR_BOM || 65536 <= c && c <= 1114111;
}
function isNsCharOrWhitespace(c) {
return isPrintable(c) && c !== CHAR_BOM && c !== CHAR_CARRIAGE_RETURN && c !== CHAR_LINE_FEED;
}
function isPlainSafe(c, prev, inblock) {
var cIsNsCharOrWhitespace = isNsCharOrWhitespace(c);
var cIsNsChar = cIsNsCharOrWhitespace && !isWhitespace(c);
return (
// ns-plain-safe
(inblock ? (
// c = flow-in
cIsNsCharOrWhitespace
) : cIsNsCharOrWhitespace && c !== CHAR_COMMA && c !== CHAR_LEFT_SQUARE_BRACKET && c !== CHAR_RIGHT_SQUARE_BRACKET && c !== CHAR_LEFT_CURLY_BRACKET && c !== CHAR_RIGHT_CURLY_BRACKET) && c !== CHAR_SHARP && !(prev === CHAR_COLON && !cIsNsChar) || isNsCharOrWhitespace(prev) && !isWhitespace(prev) && c === CHAR_SHARP || prev === CHAR_COLON && cIsNsChar
);
}
function isPlainSafeFirst(c) {
return isPrintable(c) && c !== CHAR_BOM && !isWhitespace(c) && c !== CHAR_MINUS && c !== CHAR_QUESTION && c !== CHAR_COLON && c !== CHAR_COMMA && c !== CHAR_LEFT_SQUARE_BRACKET && c !== CHAR_RIGHT_SQUARE_BRACKET && c !== CHAR_LEFT_CURLY_BRACKET && c !== CHAR_RIGHT_CURLY_BRACKET && c !== CHAR_SHARP && c !== CHAR_AMPERSAND && c !== CHAR_ASTERISK && c !== CHAR_EXCLAMATION && c !== CHAR_VERTICAL_LINE && c !== CHAR_EQUALS && c !== CHAR_GREATER_THAN && c !== CHAR_SINGLE_QUOTE && c !== CHAR_DOUBLE_QUOTE && c !== CHAR_PERCENT && c !== CHAR_COMMERCIAL_AT && c !== CHAR_GRAVE_ACCENT;
}
function isPlainSafeLast(c) {
return !isWhitespace(c) && c !== CHAR_COLON;
}
function codePointAt(string, pos) {
var first = string.charCodeAt(pos), second;
if (first >= 55296 && first <= 56319 && pos + 1 < string.length) {
second = string.charCodeAt(pos + 1);
if (second >= 56320 && second <= 57343) {
return (first - 55296) * 1024 + second - 56320 + 65536;
}
}
return first;
}
function needIndentIndicator(string) {
var leadingSpaceRe = /^\n* /;
return leadingSpaceRe.test(string);
}
var STYLE_PLAIN = 1, STYLE_SINGLE = 2, STYLE_LITERAL = 3, STYLE_FOLDED = 4, STYLE_DOUBLE = 5;
function chooseScalarStyle(string, singleLineOnly, indentPerLevel, lineWidth, testAmbiguousType, quotingType, forceQuotes, inblock) {
var i2;
var char = 0;
var prevChar = null;
var hasLineBreak = false;
var hasFoldableLine = false;
var shouldTrackWidth = lineWidth !== -1;
var previousLineBreak = -1;
var plain = isPlainSafeFirst(codePointAt(string, 0)) && isPlainSafeLast(codePointAt(string, string.length - 1));
if (singleLineOnly || forceQuotes) {
for (i2 = 0; i2 < string.length; char >= 65536 ? i2 += 2 : i2++) {
char = codePointAt(string, i2);
if (!isPrintable(char)) {
return STYLE_DOUBLE;
}
plain = plain && isPlainSafe(char, prevChar, inblock);
prevChar = char;
}
} else {
for (i2 = 0; i2 < string.length; char >= 65536 ? i2 += 2 : i2++) {
char = codePointAt(string, i2);
if (char === CHAR_LINE_FEED) {
hasLineBreak = true;
if (shouldTrackWidth) {
hasFoldableLine = hasFoldableLine || // Foldable line = too long, and not more-indented.
i2 - previousLineBreak - 1 > lineWidth && string[previousLineBreak + 1] !== " ";
previousLineBreak = i2;
}
} else if (!isPrintable(char)) {
return STYLE_DOUBLE;
}
plain = plain && isPlainSafe(char, prevChar, inblock);
prevChar = char;
}
hasFoldableLine = hasFoldableLine || shouldTrackWidth && (i2 - previousLineBreak - 1 > lineWidth && string[previousLineBreak + 1] !== " ");
}
if (!hasLineBreak && !hasFoldableLine) {
if (plain && !forceQuotes && !testAmbiguousType(string)) {
return STYLE_PLAIN;
}
return quotingType === QUOTING_TYPE_DOUBLE ? STYLE_DOUBLE : STYLE_SINGLE;
}
if (indentPerLevel > 9 && needIndentIndicator(string)) {
return STYLE_DOUBLE;
}
if (!forceQuotes) {
return hasFoldableLine ? STYLE_FOLDED : STYLE_LITERAL;
}
return quotingType === QUOTING_TYPE_DOUBLE ? STYLE_DOUBLE : STYLE_SINGLE;
}
function writeScalar(state, string, level, iskey, inblock) {
state.dump = (function() {
if (string.length === 0) {
return state.quotingType === QUOTING_TYPE_DOUBLE ? '""' : "''";
}
if (!state.noCompatMode) {
if (DEPRECATED_BOOLEANS_SYNTAX.indexOf(string) !== -1 || DEPRECATED_BASE60_SYNTAX.test(string)) {
return state.quotingType === QUOTING_TYPE_DOUBLE ? '"' + string + '"' : "'" + string + "'";
}
}
var indent = state.indent * Math.max(1, level);
var lineWidth = state.lineWidth === -1 ? -1 : Math.max(Math.min(state.lineWidth, 40), state.lineWidth - indent);
var singleLineOnly = iskey || state.flowLevel > -1 && level >= state.flowLevel;
function testAmbiguity(string2) {
return testImplicitResolving(state, string2);
}
switch (chooseScalarStyle(
string,
singleLineOnly,
state.indent,
lineWidth,
testAmbiguity,
state.quotingType,
state.forceQuotes && !iskey,
inblock
)) {
case STYLE_PLAIN:
return string;
case STYLE_SINGLE:
return "'" + string.replace(/'/g, "''") + "'";
case STYLE_LITERAL:
return "|" + blockHeader(string, state.indent) + dropEndingNewline(indentString(string, indent));
case STYLE_FOLDED:
return ">" + blockHeader(string, state.indent) + dropEndingNewline(indentString(foldString(string, lineWidth), indent));
case STYLE_DOUBLE:
return '"' + escapeString(string) + '"';
default:
throw new exception("impossible error: invalid scalar style");
}
})();
}
function blockHeader(string, indentPerLevel) {
var indentIndicator = needIndentIndicator(string) ? String(indentPerLevel) : "";
var clip = string[string.length - 1] === "\n";
var keep = clip && (string[string.length - 2] === "\n" || string === "\n");
var chomp = keep ? "+" : clip ? "" : "-";
return indentIndicator + chomp + "\n";
}
function dropEndingNewline(string) {
return string[string.length - 1] === "\n" ? string.slice(0, -1) : string;
}
function foldString(string, width) {
var lineRe = /(\n+)([^\n]*)/g;
var result = (function() {
var nextLF = string.indexOf("\n");
nextLF = nextLF !== -1 ? nextLF : string.length;
lineRe.lastIndex = nextLF;
return foldLine(string.slice(0, nextLF), width);
})();
var prevMoreIndented = string[0] === "\n" || string[0] === " ";
var moreIndented;
var match;
while (match = lineRe.exec(string)) {
var prefix = match[1], line = match[2];
moreIndented = line[0] === " ";
result += prefix + (!prevMoreIndented && !moreIndented && line !== "" ? "\n" : "") + foldLine(line, width);
prevMoreIndented = moreIndented;
}
return result;
}
function foldLine(line, width) {
if (line === "" || line[0] === " ") return line;
var breakRe = / [^ ]/g;
var match;
var start = 0, end, curr = 0, next = 0;
var result = "";
while (match = breakRe.exec(line)) {
next = match.index;
if (next - start > width) {
end = curr > start ? curr : next;
result += "\n" + line.slice(start, end);
start = end + 1;
}
curr = next;
}
result += "\n";
if (line.length - start > width && curr > start) {
result += line.slice(start, curr) + "\n" + line.slice(curr + 1);
} else {
result += line.slice(start);
}
return result.slice(1);
}
function escapeString(string) {
var result = "";
var char = 0;
var escapeSeq;
for (var i2 = 0; i2 < string.length; char >= 65536 ? i2 += 2 : i2++) {
char = codePointAt(string, i2);
escapeSeq = ESCAPE_SEQUENCES[char];
if (!escapeSeq && isPrintable(char)) {
result += string[i2];
if (char >= 65536) result += string[i2 + 1];
} else {
result += escapeSeq || encodeHex(char);
}
}
return result;
}
function writeFlowSequence(state, level, object) {
var _result = "", _tag = state.tag, index, length, value;
for (index = 0, length = object.length; index < length; index += 1) {
value = object[index];
if (state.replacer) {
value = state.replacer.call(object, String(index), value);
}
if (writeNode(state, level, value, false, false) || typeof value === "undefined" && writeNode(state, level, null, false, false)) {
if (_result !== "") _result += "," + (!state.condenseFlow ? " " : "");
_result += state.dump;
}
}
state.tag = _tag;
state.dump = "[" + _result + "]";
}
function writeBlockSequence(state, level, object, compact) {
var _result = "", _tag = state.tag, index, length, value;
for (index = 0, length = object.length; index < length; index += 1) {
value = object[index];
if (state.replacer) {
value = state.replacer.call(object, String(index), value);
}
if (writeNode(state, level + 1, value, true, true, false, true) || typeof value === "undefined" && writeNode(state, level + 1, null, true, true, false, true)) {
if (!compact || _result !== "") {
_result += generateNextLine(state, level);
}
if (state.dump && CHAR_LINE_FEED === state.dump.charCodeAt(0)) {
_result += "-";
} else {
_result += "- ";
}
_result += state.dump;
}
}
state.tag = _tag;
state.dump = _result || "[]";
}
function writeFlowMapping(state, level, object) {
var _result = "", _tag = state.tag, objectKeyList = Object.keys(object), index, length, objectKey, objectValue, pairBuffer;
for (index = 0, length = objectKeyList.length; index < length; index += 1) {
pairBuffer = "";
if (_result !== "") pairBuffer += ", ";
if (state.condenseFlow) pairBuffer += '"';
objectKey = objectKeyList[index];
objectValue = object[objectKey];
if (state.replacer) {
objectValue = state.replacer.call(object, objectKey, objectValue);
}
if (!writeNode(state, level, objectKey, false, false)) {
continue;
}
if (state.dump.length > 1024) pairBuffer += "? ";
pairBuffer += state.dump + (state.condenseFlow ? '"' : "") + ":" + (state.condenseFlow ? "" : " ");
if (!writeNode(state, level, objectValue, false, false)) {
continue;
}
pairBuffer += state.dump;
_result += pairBuffer;
}
state.tag = _tag;
state.dump = "{" + _result + "}";
}
function writeBlockMapping(state, level, object, compact) {
var _result = "", _tag = state.tag, objectKeyList = Object.keys(object), index, length, objectKey, objectValue, explicitPair, pairBuffer;
if (state.sortKeys === true) {
objectKeyList.sort();
} else if (typeof state.sortKeys === "function") {
objectKeyList.sort(state.sortKeys);
} else if (state.sortKeys) {
throw new exception("sortKeys must be a boolean or a function");
}
for (index = 0, length = objectKeyList.length; index < length; index += 1) {
pairBuffer = "";
if (!compact || _result !== "") {
pairBuffer += generateNextLine(state, level);
}
objectKey = objectKeyList[index];
objectValue = object[objectKey];
if (state.replacer) {
objectValue = state.replacer.call(object, objectKey, objectValue);
}
if (!writeNode(state, level + 1, objectKey, true, true, true)) {
continue;
}
explicitPair = state.tag !== null && state.tag !== "?" || state.dump && state.dump.length > 1024;
if (explicitPair) {
if (state.dump && CHAR_LINE_FEED === state.dump.charCodeAt(0)) {
pairBuffer += "?";
} else {
pairBuffer += "? ";
}
}
pairBuffer += state.dump;
if (explicitPair) {
pairBuffer += generateNextLine(state, level);
}
if (!writeNode(state, level + 1, objectValue, true, explicitPair)) {
continue;
}
if (state.dump && CHAR_LINE_FEED === state.dump.charCodeAt(0)) {
pairBuffer += ":";
} else {
pairBuffer += ": ";
}
pairBuffer += state.dump;
_result += pairBuffer;
}
state.tag = _tag;
state.dump = _result || "{}";
}
function detectType(state, object, explicit) {
var _result, typeList, index, length, type2, style;
typeList = explicit ? state.explicitTypes : state.implicitTypes;
for (index = 0, length = typeList.length; index < length; index += 1) {
type2 = typeList[index];
if ((type2.instanceOf || type2.predicate) && (!type2.instanceOf || typeof object === "object" && object instanceof type2.instanceOf) && (!type2.predicate || type2.predicate(object))) {
if (explicit) {
if (type2.multi && type2.representName) {
state.tag = type2.representName(object);
} else {
state.tag = type2.tag;
}
} else {
state.tag = "?";
}
if (type2.represent) {
style = state.styleMap[type2.tag] || type2.defaultStyle;
if (_toString.call(type2.represent) === "[object Function]") {
_result = type2.represent(object, style);
} else if (_hasOwnProperty.call(type2.represent, style)) {
_result = type2.represent[style](object, style);
} else {
throw new exception("!<" + type2.tag + '> tag resolver accepts not "' + style + '" style');
}
state.dump = _result;
}
return true;
}
}
return false;
}
function writeNode(state, level, object, block, compact, iskey, isblockseq) {
state.tag = null;
state.dump = object;
if (!detectType(state, object, false)) {
detectType(state, object, true);
}
var type2 = _toString.call(state.dump);
var inblock = block;
var tagStr;
if (block) {
block = state.flowLevel < 0 || state.flowLevel > level;
}
var objectOrArray = type2 === "[object Object]" || type2 === "[object Array]", duplicateIndex, duplicate;
if (objectOrArray) {
duplicateIndex = state.duplicates.indexOf(object);
duplicate = duplicateIndex !== -1;
}
if (state.tag !== null && state.tag !== "?" || duplicate || state.indent !== 2 && level > 0) {
compact = false;
}
if (duplicate && state.usedDuplicates[duplicateIndex]) {
state.dump = "*ref_" + duplicateIndex;
} else {
if (objectOrArray && duplicate && !state.usedDuplicates[duplicateIndex]) {
state.usedDuplicates[duplicateIndex] = true;
}
if (type2 === "[object Object]") {
if (block && Object.keys(state.dump).length !== 0) {
writeBlockMapping(state, level, state.dump, compact);
if (duplicate) {
state.dump = "&ref_" + duplicateIndex + state.dump;
}
} else {
writeFlowMapping(state, level, state.dump);
if (duplicate) {
state.dump = "&ref_" + duplicateIndex + " " + state.dump;
}
}
} else if (type2 === "[object Array]") {
if (block && state.dump.length !== 0) {
if (state.noArrayIndent && !isblockseq && level > 0) {
writeBlockSequence(state, level - 1, state.dump, compact);
} else {
writeBlockSequence(state, level, state.dump, compact);
}
if (duplicate) {
state.dump = "&ref_" + duplicateIndex + state.dump;
}
} else {
writeFlowSequence(state, level, state.dump);
if (duplicate) {
state.dump = "&ref_" + duplicateIndex + " " + state.dump;
}
}
} else if (type2 === "[object String]") {
if (state.tag !== "?") {
writeScalar(state, state.dump, level, iskey, inblock);
}
} else if (type2 === "[object Undefined]") {
return false;
} else {
if (state.skipInvalid) return false;
throw new exception("unacceptable kind of an object to dump " + type2);
}
if (state.tag !== null && state.tag !== "?") {
tagStr = encodeURI(
state.tag[0] === "!" ? state.tag.slice(1) : state.tag
).replace(/!/g, "%21");
if (state.tag[0] === "!") {
tagStr = "!" + tagStr;
} else if (tagStr.slice(0, 18) === "tag:yaml.org,2002:") {
tagStr = "!!" + tagStr.slice(18);
} else {
tagStr = "!<" + tagStr + ">";
}
state.dump = tagStr + " " + state.dump;
}
}
return true;
}
function getDuplicateReferences(object, state) {
var objects = [], duplicatesIndexes = [], index, length;
inspectNode(object, objects, duplicatesIndexes);
for (index = 0, length = duplicatesIndexes.length; index < length; index += 1) {
state.duplicates.push(objects[duplicatesIndexes[index]]);
}
state.usedDuplicates = new Array(length);
}
function inspectNode(object, objects, duplicatesIndexes) {
var objectKeyList, index, length;
if (object !== null && typeof object === "object") {
index = objects.indexOf(object);
if (index !== -1) {
if (duplicatesIndexes.indexOf(index) === -1) {
duplicatesIndexes.push(index);
}
} else {
objects.push(object);
if (Array.isArray(object)) {
for (index = 0, length = object.length; index < length; index += 1) {
inspectNode(object[index], objects, duplicatesIndexes);
}
} else {
objectKeyList = Object.keys(object);
for (index = 0, length = objectKeyList.length; index < length; index += 1) {
inspectNode(object[objectKeyList[index]], objects, duplicatesIndexes);
}
}
}
}
}
function dump$1(input, options) {
options = options || {};
var state = new State(options);
if (!state.noRefs) getDuplicateReferences(input, state);
var value = input;
if (state.replacer) {
value = state.replacer.call({ "": value }, "", value);
}
if (writeNode(state, 0, value, true, true)) return state.dump + "\n";
return "";
}
var dump_1 = dump$1;
var dumper = {
dump: dump_1
};
function renamed(from, to) {
return function() {
throw new Error("Function yaml." + from + " is removed in js-yaml 4. Use yaml." + to + " instead, which is now safe by default.");
};
}
var Type = type;
var Schema = schema;
var FAILSAFE_SCHEMA = failsafe;
var JSON_SCHEMA = json;
var CORE_SCHEMA = core;
var DEFAULT_SCHEMA = _default;
var load = loader.load;
var loadAll = loader.loadAll;
var dump = dumper.dump;
var YAMLException = exception;
var types = {
binary,
float,
map,
null: _null,
pairs,
set,
timestamp,
bool,
int,
merge,
omap,
seq,
str
};
var safeLoad = renamed("safeLoad", "load");
var safeLoadAll = renamed("safeLoadAll", "loadAll");
var safeDump = renamed("safeDump", "dump");
var jsYaml = {
Type,
Schema,
FAILSAFE_SCHEMA,
JSON_SCHEMA,
CORE_SCHEMA,
DEFAULT_SCHEMA,
load,
loadAll,
dump,
YAMLException,
types,
safeLoad,
safeLoadAll,
safeDump
};
function useMapData(options = {}) {
const {
defaultCenter = { lat: 43.836699, lon: 4.360054 },
defaultZoom = 13,
onSave = () => {
}
} = options;
const center = Vue.ref({ ...defaultCenter });
const zoom = Vue.ref(defaultZoom);
const saveTimeout = Vue.ref(null);
Vue.onBeforeUnmount(() => {
if (saveTimeout.value) {
clearTimeout(saveTimeout.value);
}
});
function loadMapData(yamlString) {
if (!yamlString || yamlString.trim() === "") {
return null;
}
try {
const data = jsYaml.load(yamlString);
if (data) {
if (data.center) {
center.value = {
lat: data.center.lat,
lon: data.center.lon
};
}
if (data.zoom !== void 0) {
zoom.value = data.zoom;
}
return data;
}
} catch (error) {
console.error("Error loading map data:", error);
return null;
}
return null;
}
function saveMapData() {
const data = {
background: {
type: "osm"
},
center: {
lat: center.value.lat,
lon: center.value.lon
},
zoom: zoom.value
};
const yamlString = jsYaml.dump(data, {
indent: 2,
lineWidth: -1,
noRefs: true
});
onSave(yamlString);
return yamlString;
}
function debouncedSave(delay = 300) {
if (saveTimeout.value) {
clearTimeout(saveTimeout.value);
}
saveTimeout.value = setTimeout(() => {
saveMapData();
}, delay);
}
return {
// State
center,
zoom,
// Methods
loadMapData,
saveMapData,
debouncedSave
};
}
const _sfc_main = {
components: {
MapPreview,
MarkerList
},
props: {
value: String,
name: String,
label: String,
help: String,
disabled: Boolean,
defaultCenter: {
type: Array,
default: () => [43.836699, 4.360054]
},
defaultZoom: {
type: Number,
default: 13
},
maxMarkers: {
type: Number,
default: 50
},
mode: {
type: String,
default: "multi",
validator: (value) => ["multi", "single"].includes(value)
},
latitude: {
type: [Number, String],
default: null
},
longitude: {
type: [Number, String],
default: null
},
markerIconUrl: {
type: String,
default: null
},
markerIconSize: {
type: Number,
default: 40
}
},
setup(props, { emit }) {
const mapReady = Vue.ref(false);
const mapPreview = Vue.ref(null);
const selectedMarkerId = Vue.ref(null);
const isInitialLoad = Vue.ref(true);
const pageId = Vue.computed(() => {
var _a;
if (props.mode === "single") return null;
const urlMatch = window.location.pathname.match(/\/panel\/pages\/(.+)/);
if (urlMatch) {
return urlMatch[1].replace(/\+/g, "/");
}
const nameMatch = (_a = props.name) == null ? void 0 : _a.match(/pages\/([^/]+)/);
if (nameMatch) {
return nameMatch[1].replace(/\+/g, "/");
}
console.warn("Could not extract page ID, using default");
return "map/carte";
});
const markersApi = props.mode === "multi" ? useMarkersApi(pageId.value) : { markers: Vue.ref([]), loading: Vue.ref(false), error: Vue.ref(null) };
const { center, zoom, loadMapData, saveMapData, debouncedSave } = useMapData({
defaultCenter: {
lat: props.defaultCenter[0],
lon: props.defaultCenter[1]
},
defaultZoom: props.defaultZoom,
onSave: (yamlString) => emit("input", yamlString)
});
const markers = Vue.computed(() => {
if (props.mode === "single") {
const lat = singleLat.value;
const lon = singleLon.value;
if (!isNaN(lat) && !isNaN(lon) && lat !== null && lon !== null && lat !== 0 && lon !== 0) {
return [
{
id: "single-marker",
position: { lat, lon },
title: "Current position",
iconUrl: props.markerIconUrl,
iconSize: props.markerIconSize
}
];
}
return [];
}
return markersApi.markers.value;
});
const canAddMarker = Vue.computed(() => {
if (props.mode === "single") return false;
return markers.value.length < props.maxMarkers;
});
const singleLat = Vue.ref(null);
const singleLon = Vue.ref(null);
function getCoordinatesFromForm() {
const form = document.querySelector(".k-form");
if (!form) return { lat: null, lon: null };
const latInput = form.querySelector('input[name*="latitude"]');
const lonInput = form.querySelector('input[name*="longitude"]');
return {
lat: latInput ? parseFloat(latInput.value) : null,
lon: lonInput ? parseFloat(lonInput.value) : null
};
}
Vue.onMounted(async () => {
if (props.mode === "multi") {
try {
await markersApi.fetchMarkers();
} catch (error) {
console.error("Failed to load markers:", error);
}
} else if (props.mode === "single") {
const coords = getCoordinatesFromForm();
singleLat.value = coords.lat;
singleLon.value = coords.lon;
if (!isNaN(coords.lat) && !isNaN(coords.lon) && coords.lat !== 0 && coords.lon !== 0) {
center.value = { lat: coords.lat, lon: coords.lon };
}
const form = document.querySelector(".k-form");
if (form) {
form.addEventListener("input", (e) => {
if (e.target.name && (e.target.name.includes("latitude") || e.target.name.includes("longitude"))) {
const newCoords = getCoordinatesFromForm();
singleLat.value = newCoords.lat;
singleLon.value = newCoords.lon;
}
});
const latInput = form.querySelector('input[name*="latitude"]');
const lonInput = form.querySelector('input[name*="longitude"]');
if (latInput && lonInput) {
const observer = new MutationObserver(() => {
const newCoords = getCoordinatesFromForm();
if (newCoords.lat !== singleLat.value || newCoords.lon !== singleLon.value) {
singleLat.value = newCoords.lat;
singleLon.value = newCoords.lon;
}
});
observer.observe(latInput, {
attributes: true,
attributeFilter: ["value"]
});
observer.observe(lonInput, {
attributes: true,
attributeFilter: ["value"]
});
const pollInterval = setInterval(() => {
const newCoords = getCoordinatesFromForm();
if (newCoords.lat !== singleLat.value || newCoords.lon !== singleLon.value) {
singleLat.value = newCoords.lat;
singleLon.value = newCoords.lon;
}
}, 500);
Vue.onBeforeUnmount(() => {
observer.disconnect();
clearInterval(pollInterval);
});
}
}
}
if (props.value && props.mode === "multi") {
loadMapData(props.value);
}
await Vue.nextTick();
mapReady.value = true;
await Vue.nextTick();
isInitialLoad.value = false;
});
Vue.watch(
[center, zoom],
() => {
if (props.mode === "multi" && !isInitialLoad.value) {
debouncedSave();
}
},
{ deep: true }
);
Vue.watch(
() => [singleLat.value, singleLon.value],
([lat, lon]) => {
if (props.mode === "single") {
if (!isNaN(lat) && !isNaN(lon) && lat !== null && lon !== null && lat !== 0 && lon !== 0) {
Vue.nextTick(() => {
if (mapPreview.value && mapPreview.value.centerOnPosition) {
mapPreview.value.centerOnPosition(lat, lon);
}
});
} else {
center.value = {
lat: props.defaultCenter[0],
lon: props.defaultCenter[1]
};
Vue.nextTick(() => {
if (mapPreview.value && mapPreview.value.centerOnPosition) {
mapPreview.value.centerOnPosition(
center.value.lat,
center.value.lon
);
}
});
}
}
}
);
function getCurrentCenter() {
if (mapPreview.value && mapPreview.value.getCurrentCenter) {
return mapPreview.value.getCurrentCenter();
}
return { lat: center.value.lat, lon: center.value.lon };
}
async function handleAddMarker() {
if (!canAddMarker.value || props.mode === "single") {
return;
}
const currentCenter = getCurrentCenter();
const position = {
lat: currentCenter.lat,
lon: currentCenter.lon || currentCenter.lng
};
try {
await markersApi.createMarker(position);
} catch (error) {
console.error("Failed to create marker:", error);
}
}
async function handleMapClick(position) {
if (!canAddMarker.value || props.mode === "single") {
return;
}
try {
await markersApi.createMarker({ lat: position.lat, lon: position.lng });
} catch (error) {
console.error("Failed to create marker:", error);
}
}
function handleSelectMarker(markerId) {
selectedMarkerId.value = markerId;
const marker = markers.value.find((m) => m.id === markerId);
if (marker && mapPreview.value && mapPreview.value.centerOnPosition) {
mapPreview.value.centerOnPosition(
marker.position.lat,
marker.position.lon
);
}
}
async function handleMarkerMoved({ markerId, position }) {
if (props.mode === "single") {
const form = document.querySelector(".k-form");
if (form) {
const latInput = form.querySelector('input[name*="latitude"]');
const lonInput = form.querySelector('input[name*="longitude"]');
if (latInput && lonInput) {
latInput.value = position.lat;
lonInput.value = position.lng;
latInput.dispatchEvent(new Event("input", { bubbles: true }));
lonInput.dispatchEvent(new Event("input", { bubbles: true }));
singleLat.value = position.lat;
singleLon.value = position.lng;
}
}
} else {
try {
await markersApi.updateMarkerPosition(markerId, {
lat: position.lat,
lon: position.lng
});
} catch (error) {
console.error("Failed to update marker position:", error);
}
}
}
function editMarker(markerId) {
if (props.mode === "single") return;
const marker = markers.value.find((m) => m.id === markerId);
if (marker && marker.panelUrl) {
window.top.location.href = marker.panelUrl;
}
}
async function deleteMarker(markerId) {
if (props.mode === "single") return;
if (!confirm("Supprimer ce marqueur ?")) {
return;
}
try {
await markersApi.deleteMarker(markerId);
if (selectedMarkerId.value === markerId) {
selectedMarkerId.value = null;
}
} catch (error) {
console.error("Failed to delete marker:", error);
}
}
function handleLocationSelect(location) {
if (mapPreview.value && mapPreview.value.centerOnPosition) {
mapPreview.value.centerOnPosition(location.lat, location.lon);
}
}
function saveCurrentFraming() {
if (!mapPreview.value) return;
const currentCenter = mapPreview.value.getCurrentCenter ? mapPreview.value.getCurrentCenter() : { lat: center.value.lat, lon: center.value.lon };
const currentZoom = mapPreview.value.getCurrentZoom ? mapPreview.value.getCurrentZoom() : zoom.value;
center.value = {
lat: currentCenter.lat,
lon: currentCenter.lon
};
zoom.value = currentZoom;
saveMapData();
}
return {
// State
center,
zoom,
markers,
selectedMarkerId,
mapReady,
mapPreview,
canAddMarker,
loading: markersApi.loading,
error: markersApi.error,
// Methods
handleAddMarker,
handleMapClick,
handleSelectMarker,
handleMarkerMoved,
handleLocationSelect,
deleteMarker,
editMarker,
saveCurrentFraming
};
}
};
var _sfc_render = function render() {
var _vm = this, _c = _vm._self._c;
return _c("k-field", _vm._b({ staticClass: "k-map-editor-field" }, "k-field", _vm.$props, false), [_c("div", { staticClass: "map-editor-container" }, [_c("div", { staticClass: "map-content", class: { "single-mode": _vm.mode === "single" } }, [_vm.mode === "multi" ? _c("MarkerList", { attrs: { "markers": _vm.markers, "selected-marker-id": _vm.selectedMarkerId, "max-markers": _vm.maxMarkers }, on: { "add-marker": _vm.handleAddMarker, "select-marker": _vm.handleSelectMarker, "edit-marker": _vm.editMarker, "delete-marker": _vm.deleteMarker, "select-location": _vm.handleLocationSelect } }) : _vm._e(), _c("div", { staticClass: "map-preview-container" }, [_vm.mode === "multi" ? _c("button", { staticClass: "save-framing-button", attrs: { "type": "button", "title": "Utiliser le niveau de zoom et centrage actuel comme cadrage par défaut" }, on: { "click": _vm.saveCurrentFraming } }, [_vm._v(" Définir le cadrage ")]) : _vm._e(), _vm.mapReady ? _c("MapPreview", { ref: "mapPreview", attrs: { "center": _vm.center, "zoom": _vm.zoom, "markers": _vm.markers, "selected-marker-id": _vm.selectedMarkerId }, on: { "marker-moved": _vm.handleMarkerMoved, "map-click": _vm.handleMapClick, "marker-click": _vm.handleSelectMarker, "marker-dblclick": _vm.editMarker } }) : _vm._e()], 1)], 1)])]);
};
var _sfc_staticRenderFns = [];
_sfc_render._withStripped = true;
var __component__ = /* @__PURE__ */ normalizeComponent(
_sfc_main,
_sfc_render,
_sfc_staticRenderFns,
false,
null,
null
);
__component__.options.__file = "/Users/adrienpayet/Documents/code/en-cours/geoproject/public/site/plugins/map-editor/src/components/field/MapEditor.vue";
const MapEditor = __component__.exports;
window.panel.plugin("geoproject/map-editor", {
fields: {
"map-editor": MapEditor
}
});
})();