Server IP : 103.191.208.50 / Your IP : 216.73.216.53 Web Server : LiteSpeed System : Linux orion.herosite.pro 4.18.0-553.53.1.lve.el8.x86_64 #1 SMP Wed May 28 17:01:02 UTC 2025 x86_64 User : celkcksm ( 1031) PHP Version : 7.4.33 Disable Function : show_source, system, shell_exec, passthru, popen, exec MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON Directory (0755) : /home/celkcksm/gtsgmbh.ncriptech.com/../royalrasoi.ncriptech.com/js/ |
[ Home ] | [ C0mmand ] | [ Upload File ] |
---|
/* Mapbox GL JS is Copyright © 2020 Mapbox and subject to the Mapbox Terms of Service ((https://www.mapbox.com/legal/tos/). */ (function(global, factory) { typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : typeof define === 'function' && define.amd ? define(factory) : (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.mapboxgl = factory()); })(this, (function() { 'use strict'; /* eslint-disable */ var shared, worker, mapboxgl; // define gets called three times: one for each chunk. we rely on the order // they're imported to know which is which function define(_, chunk) { if (!shared) { shared = chunk; } else if (!worker) { worker = chunk; } else { var workerBundleString = "self.onerror = function() { console.error('An error occurred while parsing the WebWorker bundle. This is most likely due to improper transpilation by Babel; please see https://docs.mapbox.com/mapbox-gl-js/guides/install/#transpiling'); }; var sharedChunk = {}; (" + shared + ")(sharedChunk); (" + worker + ")(sharedChunk); self.onerror = null;" var sharedChunk = {}; shared(sharedChunk); mapboxgl = chunk(sharedChunk); if (typeof window !== 'undefined' && window && window.URL && window.URL.createObjectURL) { mapboxgl.workerUrl = window.URL.createObjectURL(new Blob([workerBundleString], { type: 'text/javascript' })); } } } define(["exports"], (function(t) { "use strict"; var e = "undefined" != typeof self ? self : {}, r = "2.14.1"; let n; const i = { API_URL: "https://api.mapbox.com", get API_URL_REGEX() { if (null == n) { const t = /^((https?:)?\/\/)?([^\/]+\.)?mapbox\.c(n|om)(\/|\?|$)/i; try { n = null != process.env.API_URL_REGEX ? new RegExp(process.env.API_URL_REGEX) : t; } catch (e) { n = t; } } return n }, get API_TILEJSON_REGEX() { return /^((https?:)?\/\/)?([^\/]+\.)?mapbox\.c(n|om)(\/v[0-9]*\/.*\.json.*$)/i }, get API_SPRITE_REGEX() { return /^((https?:)?\/\/)?([^\/]+\.)?mapbox\.c(n|om)(\/styles\/v[0-9]*\/)(.*\/sprite.*\..*$)/i }, get API_FONTS_REGEX() { return /^((https?:)?\/\/)?([^\/]+\.)?mapbox\.c(n|om)(\/fonts\/v[0-9]*\/)(.*\.pbf.*$)/i }, get API_STYLE_REGEX() { return /^((https?:)?\/\/)?([^\/]+\.)?mapbox\.c(n|om)(\/styles\/v[0-9]*\/)(.*$)/i }, get API_CDN_URL_REGEX() { return /^((https?:)?\/\/)?api\.mapbox\.c(n|om)(\/mapbox-gl-js\/)(.*$)/i }, get EVENTS_URL() { if (!i.API_URL) return null; try { const t = new URL(i.API_URL); return "api.mapbox.cn" === t.hostname ? "https://events.mapbox.cn/events/v2" : "api.mapbox.com" === t.hostname ? "https://events.mapbox.com/events/v2" : null } catch (t) { return null } }, SESSION_PATH: "/map-sessions/v1", FEEDBACK_URL: "https://apps.mapbox.com/feedback", TILE_URL_VERSION: "v4", RASTER_URL_PREFIX: "raster/v1", REQUIRE_ACCESS_TOKEN: !0, ACCESS_TOKEN: null, MAX_PARALLEL_IMAGE_REQUESTS: 16 }, s = { supported: !1, testSupport: function(t) { !l && o && (u ? c(t) : a = t); } }; let a, o, l = !1, u = !1; function c(t) { const e = t.createTexture(); t.bindTexture(t.TEXTURE_2D, e); try { if (t.texImage2D(t.TEXTURE_2D, 0, t.RGBA, t.RGBA, t.UNSIGNED_BYTE, o), t.isContextLost()) return; s.supported = !0; } catch (t) {} t.deleteTexture(e), l = !0; } e.document && (o = e.document.createElement("img"), o.onload = function() { a && c(a), a = null, u = !0; }, o.onerror = function() { l = !0, a = null; }, o.src = ""); const h = "01"; var p = f; function f(t, e, r, n) { this.cx = 3 * t, this.bx = 3 * (r - t) - this.cx, this.ax = 1 - this.cx - this.bx, this.cy = 3 * e, this.by = 3 * (n - e) - this.cy, this.ay = 1 - this.cy - this.by, this.p1x = t, this.p1y = e, this.p2x = r, this.p2y = n; } f.prototype = { sampleCurveX: function(t) { return ((this.ax * t + this.bx) * t + this.cx) * t }, sampleCurveY: function(t) { return ((this.ay * t + this.by) * t + this.cy) * t }, sampleCurveDerivativeX: function(t) { return (3 * this.ax * t + 2 * this.bx) * t + this.cx }, solveCurveX: function(t, e) { if (void 0 === e && (e = 1e-6), t < 0) return 0; if (t > 1) return 1; for (var r = t, n = 0; n < 8; n++) { var i = this.sampleCurveX(r) - t; if (Math.abs(i) < e) return r; var s = this.sampleCurveDerivativeX(r); if (Math.abs(s) < 1e-6) break; r -= i / s; } var a = 0, o = 1; for (r = t, n = 0; n < 20 && (i = this.sampleCurveX(r), !(Math.abs(i - t) < e)); n++) t > i ? a = r : o = r, r = .5 * (o - a) + a; return r }, solve: function(t, e) { return this.sampleCurveY(this.solveCurveX(t, e)) } }; var d = y; function y(t, e) { this.x = t, this.y = e; } y.prototype = { clone: function() { return new y(this.x, this.y) }, add: function(t) { return this.clone()._add(t) }, sub: function(t) { return this.clone()._sub(t) }, multByPoint: function(t) { return this.clone()._multByPoint(t) }, divByPoint: function(t) { return this.clone()._divByPoint(t) }, mult: function(t) { return this.clone()._mult(t) }, div: function(t) { return this.clone()._div(t) }, rotate: function(t) { return this.clone()._rotate(t) }, rotateAround: function(t, e) { return this.clone()._rotateAround(t, e) }, matMult: function(t) { return this.clone()._matMult(t) }, 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(t) { return this.x === t.x && this.y === t.y }, dist: function(t) { return Math.sqrt(this.distSqr(t)) }, distSqr: function(t) { var e = t.x - this.x, r = t.y - this.y; return e * e + r * r }, angle: function() { return Math.atan2(this.y, this.x) }, angleTo: function(t) { return Math.atan2(this.y - t.y, this.x - t.x) }, angleWith: function(t) { return this.angleWithSep(t.x, t.y) }, angleWithSep: function(t, e) { return Math.atan2(this.x * e - this.y * t, this.x * t + this.y * e) }, _matMult: function(t) { var e = t[2] * this.x + t[3] * this.y; return this.x = t[0] * this.x + t[1] * this.y, this.y = e, this }, _add: function(t) { return this.x += t.x, this.y += t.y, this }, _sub: function(t) { return this.x -= t.x, this.y -= t.y, this }, _mult: function(t) { return this.x *= t, this.y *= t, this }, _div: function(t) { return this.x /= t, this.y /= t, this }, _multByPoint: function(t) { return this.x *= t.x, this.y *= t.y, this }, _divByPoint: function(t) { return this.x /= t.x, this.y /= t.y, this }, _unit: function() { return this._div(this.mag()), this }, _perp: function() { var t = this.y; return this.y = this.x, this.x = -t, this }, _rotate: function(t) { var e = Math.cos(t), r = Math.sin(t), n = r * this.x + e * this.y; return this.x = e * this.x - r * this.y, this.y = n, this }, _rotateAround: function(t, e) { var r = Math.cos(t), n = Math.sin(t), i = e.y + n * (this.x - e.x) + r * (this.y - e.y); return this.x = e.x + r * (this.x - e.x) - n * (this.y - e.y), this.y = i, this }, _round: function() { return this.x = Math.round(this.x), this.y = Math.round(this.y), this } }, y.convert = function(t) { return t instanceof y ? t : Array.isArray(t) ? new y(t[0], t[1]) : t }; const m = Math.PI / 180, g = 180 / Math.PI; function x(t) { return t * m } function v(t) { return t * g } const b = [ [0, 0], [1, 0], [1, 1], [0, 1] ]; function w(t) { if (t <= 0) return 0; if (t >= 1) return 1; const e = t * t, r = e * t; return 4 * (t < .5 ? r : 3 * (t - e) + r - .75) } function _(t, e, r, n) { const i = new p(t, e, r, n); return function(t) { return i.solve(t) } } const A = _(.25, .1, .25, 1); function S(t, e, r) { return Math.min(r, Math.max(e, t)) } function k(t, e, r) { return (r = S((r - t) / (e - t), 0, 1)) * r * (3 - 2 * r) } function I(t, e, r) { const n = r - e, i = ((t - e) % n + n) % n + e; return i === e ? r : i } function M(t, e, r) { if (!t.length) return r(null, []); let n = t.length; const i = new Array(t.length); let s = null; t.forEach(((t, a) => { e(t, ((t, e) => { t && (s = t), i[a] = e, 0 == --n && r(s, i); })); })); } function T(t) { const e = []; for (const r in t) e.push(t[r]); return e } function z(t, ...e) { for (const r of e) for (const e in r) t[e] = r[e]; return t } let B = 1; function E() { return B++ } function C() { return function t(e) { return e ? (e ^ Math.random() * (16 >> e / 4)).toString(16) : ([1e7] + -[1e3] + -4e3 + -8e3 + -1e11).replace(/[018]/g, t) }() } function P(t) { return t <= 1 ? 1 : Math.pow(2, Math.ceil(Math.log(t) / Math.LN2)) } function D(t) { return !!t && /^[0-9a-f]{8}-[0-9a-f]{4}-[4][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i.test(t) } function V(t, e) { t.forEach((t => { e[t] && (e[t] = e[t].bind(e)); })); } function L(t, e) { return -1 !== t.indexOf(e, t.length - e.length) } function F(t, e, r) { const n = {}; for (const i in t) n[i] = e.call(r || this, t[i], i, t); return n } function R(t, e, r) { const n = {}; for (const i in t) e.call(r || this, t[i], i, t) && (n[i] = t[i]); return n } function j(t) { return Array.isArray(t) ? t.map(j) : "object" == typeof t && t ? F(t, j) : t } const $ = {}; function U(t) { $[t] || ("undefined" != typeof console && console.warn(t), $[t] = !0); } function O(t, e, r) { return (r.y - t.y) * (e.x - t.x) > (e.y - t.y) * (r.x - t.x) } function q(t) { let e = 0; for (let r, n, i = 0, s = t.length, a = s - 1; i < s; a = i++) r = t[i], n = t[a], e += (n.x - r.x) * (r.y + n.y); return e } function N() { return "undefined" != typeof WorkerGlobalScope && "undefined" != typeof self && self instanceof WorkerGlobalScope } function G(t) { const e = {}; if (t.replace(/(?:^|(?:\s*\,\s*))([^\x00-\x20\(\)<>@\,;\:\\"\/\[\]\?\=\{\}\x7F]+)(?:\=(?:([^\x00-\x20\(\)<>@\,;\:\\"\/\[\]\?\=\{\}\x7F]+)|(?:\"((?:[^"\\]|\\.)*)\")))?/g, ((t, r, n, i) => { const s = n || i; return e[r] = !s || s.toLowerCase(), "" })), e["max-age"]) { const t = parseInt(e["max-age"], 10); isNaN(t) ? delete e["max-age"] : e["max-age"] = t; } return e } let Z = null; function X(t) { if (null == Z) { const e = t.navigator ? t.navigator.userAgent : null; Z = !!t.safari || !(!e || !(/\b(iPad|iPhone|iPod)\b/.test(e) || e.match("Safari") && !e.match("Chrome"))); } return Z } function K(t) { try { const r = e[t]; return r.setItem("_mapbox_test_", 1), r.removeItem("_mapbox_test_"), !0 } catch (t) { return !1 } } function Y(t, e) { return [t[4 * e], t[4 * e + 1], t[4 * e + 2], t[4 * e + 3]] } const H = "mapbox-tiles"; let W, J, Q = 500, tt = 50; function et() { try { return e.caches } catch (t) {} } function rt() { et() && !W && (W = e.caches.open(H)); } function nt(t) { const e = t.indexOf("?"); if (e < 0) return t; const r = function(t) { const e = t.indexOf("?"); return e > 0 ? t.slice(e + 1).split("&") : [] }(t), n = r.filter((t => { const e = t.split("="); return "language" === e[0] || "worldview" === e[0] })); return n.length ? `${t.slice(0,e)}?${n.join("&")}` : t.slice(0, e) } let it = 1 / 0; const st = { Unknown: "Unknown", Style: "Style", Source: "Source", Tile: "Tile", Glyphs: "Glyphs", SpriteImage: "SpriteImage", SpriteJSON: "SpriteJSON", Image: "Image" }; "function" == typeof Object.freeze && Object.freeze(st); class at extends Error { constructor(t, e, r) { 401 === e && gt(r) && (t += ": you may have provided an invalid Mapbox access token. See https://docs.mapbox.com/api/overview/#access-tokens-and-token-scopes"), super(t), this.status = e, this.url = r; } toString() { return `${this.name}: ${this.message} (${this.status}): ${this.url}` } } const ot = N() ? () => self.worker && self.worker.referrer : () => ("blob:" === e.location.protocol ? e.parent : e).location.href; const lt = function(t, r) { if (!(/^file:/.test(n = t.url) || /^file:/.test(ot()) && !/^\w+:/.test(n))) { if (e.fetch && e.Request && e.AbortController && e.Request.prototype.hasOwnProperty("signal")) return function(t, r) { const n = new e.AbortController, i = new e.Request(t.url, { method: t.method || "GET", body: t.body, credentials: t.credentials, headers: t.headers, referrer: ot(), referrerPolicy: t.referrerPolicy, signal: n.signal }); let s = !1, a = !1; const o = (l = i.url).indexOf("sku=") > 0 && gt(l); var l; "json" === t.type && i.headers.set("Accept", "application/json"); const u = (n, s, l) => { if (a) return; if (n && "SecurityError" !== n.message && U(n), s && l) return c(s); const u = Date.now(); e.fetch(i).then((e => { if (e.ok) { const t = o ? e.clone() : null; return c(e, t, u) } return r(new at(e.statusText, e.status, t.url)) })).catch((e => { "AbortError" !== e.name && r(new Error(`${e.message} ${t.url}`)); })); }, c = (n, o, l) => { ("arrayBuffer" === t.type ? n.arrayBuffer() : "json" === t.type ? n.json() : n.text()).then((t => { a || (o && l && function(t, r, n) { if (rt(), !W) return; const i = { status: r.status, statusText: r.statusText, headers: new e.Headers }; r.headers.forEach(((t, e) => i.headers.set(e, t))); const s = G(r.headers.get("Cache-Control") || ""); if (s["no-store"]) return; s["max-age"] && i.headers.set("Expires", new Date(n + 1e3 * s["max-age"]).toUTCString()); const a = i.headers.get("Expires"); a && (new Date(a).getTime() - n < 42e4 || function(t, e) { if (void 0 === J) try { new Response(new ReadableStream), J = !0; } catch (t) { J = !1; } J ? e(t.body) : t.blob().then(e); }(r, (r => { const n = new e.Response(r, i); rt(), W && W.then((e => e.put(nt(t.url), n))).catch((t => U(t.message))); }))); }(i, o, l), s = !0, r(null, t, n.headers.get("Cache-Control"), n.headers.get("Expires"))); })).catch((t => { a || r(new Error(t.message)); })); }; return o ? function(t, e) { if (rt(), !W) return e(null); const r = nt(t.url); W.then((t => { t.match(r).then((n => { const i = function(t) { if (!t) return !1; const e = new Date(t.headers.get("Expires") || 0), r = G(t.headers.get("Cache-Control") || ""); return e > Date.now() && !r["no-cache"] }(n); t.delete(r), i && t.put(r, n.clone()), e(null, n, i); })).catch(e); })).catch(e); }(i, u) : u(null, null), { cancel: () => { a = !0, s || n.abort(); } } }(t, r); if (N() && self.worker && self.worker.actor) return self.worker.actor.send("getResource", t, r, void 0, !0) } var n; return function(t, r) { const n = new e.XMLHttpRequest; n.open(t.method || "GET", t.url, !0), "arrayBuffer" === t.type && (n.responseType = "arraybuffer"); for (const e in t.headers) n.setRequestHeader(e, t.headers[e]); return "json" === t.type && (n.responseType = "text", n.setRequestHeader("Accept", "application/json")), n.withCredentials = "include" === t.credentials, n.onerror = () => { r(new Error(n.statusText)); }, n.onload = () => { if ((n.status >= 200 && n.status < 300 || 0 === n.status) && null !== n.response) { let e = n.response; if ("json" === t.type) try { e = JSON.parse(n.response); } catch (t) { return r(t) } r(null, e, n.getResponseHeader("Cache-Control"), n.getResponseHeader("Expires")); } else r(new at(n.statusText, n.status, t.url)); }, n.send(t.body), { cancel: () => n.abort() } }(t, r) }, ut = function(t, e) { return lt(z(t, { type: "arrayBuffer" }), e) }; function ct(t) { const r = e.document.createElement("a"); return r.href = t, r.protocol === e.document.location.protocol && r.host === e.document.location.host } const ht = ""; let pt, ft; pt = [], ft = 0; const dt = function(t, r) { if (s.supported && (t.headers || (t.headers = {}), t.headers.accept = "image/webp,*/*"), ft >= i.MAX_PARALLEL_IMAGE_REQUESTS) { const e = { requestParameters: t, callback: r, cancelled: !1, cancel() { this.cancelled = !0; } }; return pt.push(e), e } ft++; let n = !1; const a = () => { if (!n) for (n = !0, ft--; pt.length && ft < i.MAX_PARALLEL_IMAGE_REQUESTS;) { const t = pt.shift(), { requestParameters: e, callback: r, cancelled: n } = t; n || (t.cancel = dt(e, r).cancel); } }, o = ut(t, ((t, n, i, s) => { a(), t ? r(t) : n && (e.createImageBitmap ? function(t, r) { const n = new e.Blob([new Uint8Array(t)], { type: "image/png" }); e.createImageBitmap(n).then((t => { r(null, t); })).catch((t => { r(new Error(`Could not load image because of ${t.message}. Please make sure to use a supported image type such as PNG or JPEG. Note that SVGs are not supported.`)); })); }(n, ((t, e) => r(t, e, i, s))) : function(t, r) { const n = new e.Image, i = e.URL; n.onload = () => { r(null, n), i.revokeObjectURL(n.src), n.onload = null, e.requestAnimationFrame((() => { n.src = ht; })); }, n.onerror = () => r(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 s = new e.Blob([new Uint8Array(t)], { type: "image/png" }); n.src = t.byteLength ? i.createObjectURL(s) : ht; }(n, ((t, e) => r(t, e, i, s)))); })); return { cancel: () => { o.cancel(), a(); } } }, yt = "NO_ACCESS_TOKEN"; function mt(t) { return 0 === t.indexOf("mapbox:") } function gt(t) { return i.API_URL_REGEX.test(t) } function xt(t) { return i.API_CDN_URL_REGEX.test(t) } function vt(t) { return i.API_STYLE_REGEX.test(t) && !bt(t) } function bt(t) { return i.API_SPRITE_REGEX.test(t) } const wt = /^(\w+):\/\/([^/?]*)(\/[^?]+)?\??(.+)?/; function _t(t) { const e = t.match(wt); if (!e) throw new Error("Unable to parse URL object"); return { protocol: e[1], authority: e[2], path: e[3] || "/", params: e[4] ? e[4].split("&") : [] } } function At(t) { const e = t.params.length ? `?${t.params.join("&")}` : ""; return `${t.protocol}://${t.authority}${t.path}${e}` } function St(t) { if (!t) return null; const r = t.split("."); if (!r || 3 !== r.length) return null; try { return JSON.parse(decodeURIComponent(e.atob(r[1]).split("").map((t => "%" + ("00" + t.charCodeAt(0).toString(16)).slice(-2))).join(""))) } catch (t) { return null } } class kt { constructor(t) { this.type = t, this.anonId = null, this.eventData = {}, this.queue = [], this.pendingRequest = null; } getStorageKey(t) { const r = St(i.ACCESS_TOKEN); let n = ""; return n = r && r.u ? e.btoa(encodeURIComponent(r.u).replace(/%([0-9A-F]{2})/g, ((t, e) => String.fromCharCode(Number("0x" + e))))) : i.ACCESS_TOKEN || "", t ? `mapbox.eventData.${t}:${n}` : `mapbox.eventData:${n}` } fetchEventData() { const t = K("localStorage"), r = this.getStorageKey(), n = this.getStorageKey("uuid"); if (t) try { const t = e.localStorage.getItem(r); t && (this.eventData = JSON.parse(t)); const i = e.localStorage.getItem(n); i && (this.anonId = i); } catch (t) { U("Unable to read from LocalStorage"); } } saveEventData() { const t = K("localStorage"), r = this.getStorageKey(), n = this.getStorageKey("uuid"); if (t) try { e.localStorage.setItem(n, this.anonId), Object.keys(this.eventData).length >= 1 && e.localStorage.setItem(r, JSON.stringify(this.eventData)); } catch (t) { U("Unable to write to LocalStorage"); } } processRequests(t) {} postEvent(t, e, r, n) { if (!i.EVENTS_URL) return; const s = _t(i.EVENTS_URL); s.params.push(`access_token=${n||i.ACCESS_TOKEN||""}`); const a = { event: this.type, created: new Date(t).toISOString() }, o = e ? z(a, e) : a, l = { url: At(s), headers: { "Content-Type": "text/plain" }, body: JSON.stringify([o]) }; this.pendingRequest = function(t, e) { return lt(z(t, { method: "POST" }), e) }(l, (t => { this.pendingRequest = null, r(t), this.saveEventData(), this.processRequests(n); })); } queueRequest(t, e) { this.queue.push(t), this.processRequests(e); } } const It = new class extends kt { constructor(t) { super("appUserTurnstile"), this._customAccessToken = t; } postTurnstileEvent(t, e) { i.EVENTS_URL && i.ACCESS_TOKEN && Array.isArray(t) && t.some((t => mt(t) || gt(t))) && this.queueRequest(Date.now(), e); } processRequests(t) { if (this.pendingRequest || 0 === this.queue.length) return; this.anonId && this.eventData.lastSuccess && this.eventData.tokenU || this.fetchEventData(); const e = St(i.ACCESS_TOKEN), n = e ? e.u : i.ACCESS_TOKEN; let s = n !== this.eventData.tokenU; D(this.anonId) || (this.anonId = C(), s = !0); const a = this.queue.shift(); if (this.eventData.lastSuccess) { const t = new Date(this.eventData.lastSuccess), e = new Date(a), r = (a - this.eventData.lastSuccess) / 864e5; s = s || r >= 1 || r < -1 || t.getDate() !== e.getDate(); } else s = !0; s ? this.postEvent(a, { sdkIdentifier: "mapbox-gl-js", sdkVersion: r, skuId: h, "enabled.telemetry": !1, userId: this.anonId }, (t => { t || (this.eventData.lastSuccess = a, this.eventData.tokenU = n); }), t) : this.processRequests(); } }, Mt = It.postTurnstileEvent.bind(It), Tt = new class extends kt { constructor() { super("map.load"), this.success = {}, this.skuToken = ""; } postMapLoadEvent(t, e, r, n) { this.skuToken = e, this.errorCb = n, i.EVENTS_URL && (r || i.ACCESS_TOKEN ? this.queueRequest({ id: t, timestamp: Date.now() }, r) : this.errorCb(new Error(yt))); } processRequests(t) { if (this.pendingRequest || 0 === this.queue.length) return; const { id: e, timestamp: n } = this.queue.shift(); e && this.success[e] || (this.anonId || this.fetchEventData(), D(this.anonId) || (this.anonId = C()), this.postEvent(n, { sdkIdentifier: "mapbox-gl-js", sdkVersion: r, skuId: h, skuToken: this.skuToken, userId: this.anonId }, (t => { t ? this.errorCb(t) : e && (this.success[e] = !0); }), t)); } }, zt = Tt.postMapLoadEvent.bind(Tt), Bt = new class extends kt { constructor() { super("gljs.performance"); } postPerformanceEvent(t, e) { i.EVENTS_URL && (t || i.ACCESS_TOKEN) && this.queueRequest({ timestamp: Date.now(), performanceData: e }, t); } processRequests(t) { if (this.pendingRequest || 0 === this.queue.length) return; const { timestamp: n, performanceData: i } = this.queue.shift(), s = function(t) { const n = e.performance.getEntriesByType("resource"), i = e.performance.getEntriesByType("mark"), s = function(t) { const e = {}; if (t) for (const r in t) if ("other" !== r) for (const n of t[r]) { const t = `${r}ResolveRangeMin`, i = `${r}ResolveRangeMax`, s = `${r}RequestCount`, a = `${r}RequestCachedCount`; e[t] = Math.min(e[t] || 1 / 0, n.startTime), e[i] = Math.max(e[i] || -1 / 0, n.responseEnd); const o = t => { void 0 === e[t] && (e[t] = 0), ++e[t]; }; void 0 !== n.transferSize && 0 === n.transferSize && o(a), o(s); } return e }(function(t, e) { const r = {}; if (t) for (const n of t) { const t = e(n); void 0 === r[t] && (r[t] = []), r[t].push(n); } return r }(n, Ft)), a = e.devicePixelRatio, o = e.navigator.connection || e.navigator.mozConnection || e.navigator.webkitConnection, l = { counters: [], metadata: [], attributes: [] }, u = (t, e, r) => { null != r && t.push({ name: e, value: r.toString() }); }; for (const t in s) u(l.counters, t, s[t]); if (t.interactionRange[0] !== 1 / 0 && t.interactionRange[1] !== -1 / 0 && (u(l.counters, "interactionRangeMin", t.interactionRange[0]), u(l.counters, "interactionRangeMax", t.interactionRange[1])), i) for (const t of Object.keys(Vt)) { const e = Vt[t], r = i.find((t => t.name === e)); r && u(l.counters, e, r.startTime); } return u(l.counters, "visibilityHidden", t.visibilityHidden), u(l.attributes, "style", function(t) { if (t) for (const e of t) { const t = e.name.split("?")[0]; if (vt(t)) { const e = t.split("/").slice(-2); if (2 === e.length) return `mapbox://styles/${e[0]}/${e[1]}` } } }(n)), u(l.attributes, "terrainEnabled", t.terrainEnabled ? "true" : "false"), u(l.attributes, "fogEnabled", t.fogEnabled ? "true" : "false"), u(l.attributes, "projection", t.projection), u(l.attributes, "zoom", t.zoom), u(l.metadata, "devicePixelRatio", a), u(l.metadata, "connectionEffectiveType", o ? o.effectiveType : void 0), u(l.metadata, "navigatorUserAgent", e.navigator.userAgent), u(l.metadata, "screenWidth", e.screen.width), u(l.metadata, "screenHeight", e.screen.height), u(l.metadata, "windowWidth", e.innerWidth), u(l.metadata, "windowHeight", e.innerHeight), u(l.metadata, "mapWidth", t.width / a), u(l.metadata, "mapHeight", t.height / a), u(l.metadata, "webglRenderer", t.renderer), u(l.metadata, "webglVendor", t.vendor), u(l.metadata, "sdkVersion", r), u(l.metadata, "sdkIdentifier", "mapbox-gl-js"), l }(i); for (const t of s.metadata); for (const t of s.counters); for (const t of s.attributes); this.postEvent(n, s, (() => {}), t); } }, Et = Bt.postPerformanceEvent.bind(Bt), Ct = new class extends kt { constructor() { super("map.auth"), this.success = {}, this.skuToken = ""; } getSession(t, e, r, n) { if (!i.API_URL || !i.SESSION_PATH) return; const s = _t(i.API_URL + i.SESSION_PATH); s.params.push(`sku=${e||""}`), s.params.push(`access_token=${n||i.ACCESS_TOKEN||""}`); const a = { url: At(s), headers: { "Content-Type": "text/plain" } }; this.pendingRequest = function(t, e) { return lt(z(t, { method: "GET" }), e) }(a, (t => { this.pendingRequest = null, r(t), this.saveEventData(), this.processRequests(n); })); } getSessionAPI(t, e, r, n) { this.skuToken = e, this.errorCb = n, i.SESSION_PATH && i.API_URL && (r || i.ACCESS_TOKEN ? this.queueRequest({ id: t, timestamp: Date.now() }, r) : this.errorCb(new Error(yt))); } processRequests(t) { if (this.pendingRequest || 0 === this.queue.length) return; const { id: e, timestamp: r } = this.queue.shift(); e && this.success[e] || this.getSession(r, this.skuToken, (t => { t ? this.errorCb(t) : e && (this.success[e] = !0); }), t); } }, Pt = Ct.getSessionAPI.bind(Ct), Dt = new Set, Vt = { create: "create", load: "load", fullLoad: "fullLoad" }, Lt = { mark(t) { e.performance.mark(t); }, measure(t, r, n) { e.performance.measure(t, r, n); } }; function Ft(t) { const e = t.name.split("?")[0]; return xt(e) && e.includes("mapbox-gl.js") ? "javascript" : xt(e) && e.includes("mapbox-gl.css") ? "css" : function(t) { return i.API_FONTS_REGEX.test(t) }(e) ? "fontRange" : bt(e) ? "sprite" : vt(e) ? "style" : function(t) { return i.API_TILEJSON_REGEX.test(t) }(e) ? "tilejson" : "other" } const Rt = e.performance; function jt(t) { const e = t ? t.url.toString() : void 0; return Rt.getEntriesByName(e) } let $t, Ut, Ot, qt; const Nt = { now: () => void 0 !== Ot ? Ot : e.performance.now(), setNow(t) { Ot = t; }, restoreNow() { Ot = void 0; }, frame(t) { const r = e.requestAnimationFrame(t); return { cancel: () => e.cancelAnimationFrame(r) } }, getImageData(t, r = 0) { const { width: n, height: i } = t; qt || (qt = e.document.createElement("canvas")); const s = qt.getContext("2d", { willReadFrequently: !0 }); if (!s) throw new Error("failed to create canvas 2d context"); return (n > qt.width || i > qt.height) && (qt.width = n, qt.height = i), s.clearRect(-r, -r, n + 2 * r, i + 2 * r), s.drawImage(t, 0, 0, n, i), s.getImageData(-r, -r, n + 2 * r, i + 2 * r) }, resolveURL: t => ($t || ($t = e.document.createElement("a")), $t.href = t, $t.href), get devicePixelRatio() { return e.devicePixelRatio }, get prefersReducedMotion() { return !!e.matchMedia && (null == Ut && (Ut = e.matchMedia("(prefers-reduced-motion: reduce)")), Ut.matches) } }; function Gt(t, e, r) { r[t] && -1 !== r[t].indexOf(e) || (r[t] = r[t] || [], r[t].push(e)); } function Zt(t, e, r) { if (r && r[t]) { const n = r[t].indexOf(e); - 1 !== n && r[t].splice(n, 1); } } class Xt { constructor(t, e = {}) { z(this, e), this.type = t; } } class Kt extends Xt { constructor(t, e = {}) { super("error", z({ error: t }, e)); } } class Yt { on(t, e) { return this._listeners = this._listeners || {}, Gt(t, e, this._listeners), this } off(t, e) { return Zt(t, e, this._listeners), Zt(t, e, this._oneTimeListeners), this } once(t, e) { return e ? (this._oneTimeListeners = this._oneTimeListeners || {}, Gt(t, e, this._oneTimeListeners), this) : new Promise((e => this.once(t, e))) } fire(t, e) { "string" == typeof t && (t = new Xt(t, e || {})); const r = t.type; if (this.listens(r)) { t.target = this; const e = this._listeners && this._listeners[r] ? this._listeners[r].slice() : []; for (const r of e) r.call(this, t); const n = this._oneTimeListeners && this._oneTimeListeners[r] ? this._oneTimeListeners[r].slice() : []; for (const e of n) Zt(r, e, this._oneTimeListeners), e.call(this, t); const i = this._eventedParent; i && (z(t, "function" == typeof this._eventedParentData ? this._eventedParentData() : this._eventedParentData), i.fire(t)); } else t instanceof Kt && console.error(t.error); return this } listens(t) { return !!(this._listeners && this._listeners[t] && this._listeners[t].length > 0 || this._oneTimeListeners && this._oneTimeListeners[t] && this._oneTimeListeners[t].length > 0 || this._eventedParent && this._eventedParent.listens(t)) } setEventedParent(t, e) { return this._eventedParent = t, this._eventedParentData = e, this } } var Ht = JSON.parse('{"$version":8,"$root":{"version":{"required":true,"type":"enum","values":[8]},"name":{"type":"string"},"metadata":{"type":"*"},"center":{"type":"array","value":"number"},"zoom":{"type":"number"},"bearing":{"type":"number","default":0,"period":360,"units":"degrees"},"pitch":{"type":"number","default":0,"units":"degrees"},"light":{"type":"light"},"terrain":{"type":"terrain"},"fog":{"type":"fog"},"sources":{"required":true,"type":"sources"},"sprite":{"type":"string"},"glyphs":{"type":"string"},"transition":{"type":"transition"},"projection":{"type":"projection"},"layers":{"required":true,"type":"array","value":"layer"}},"sources":{"*":{"type":"source"}},"source":["source_vector","source_raster","source_raster_dem","source_geojson","source_video","source_image"],"source_vector":{"type":{"required":true,"type":"enum","values":{"vector":{}}},"url":{"type":"string"},"tiles":{"type":"array","value":"string"},"bounds":{"type":"array","value":"number","length":4,"default":[-180,-85.051129,180,85.051129]},"scheme":{"type":"enum","values":{"xyz":{},"tms":{}},"default":"xyz"},"minzoom":{"type":"number","default":0},"maxzoom":{"type":"number","default":22},"attribution":{"type":"string"},"promoteId":{"type":"promoteId"},"volatile":{"type":"boolean","default":false},"*":{"type":"*"}},"source_raster":{"type":{"required":true,"type":"enum","values":{"raster":{}}},"url":{"type":"string"},"tiles":{"type":"array","value":"string"},"bounds":{"type":"array","value":"number","length":4,"default":[-180,-85.051129,180,85.051129]},"minzoom":{"type":"number","default":0},"maxzoom":{"type":"number","default":22},"tileSize":{"type":"number","default":512,"units":"pixels"},"scheme":{"type":"enum","values":{"xyz":{},"tms":{}},"default":"xyz"},"attribution":{"type":"string"},"volatile":{"type":"boolean","default":false},"*":{"type":"*"}},"source_raster_dem":{"type":{"required":true,"type":"enum","values":{"raster-dem":{}}},"url":{"type":"string"},"tiles":{"type":"array","value":"string"},"bounds":{"type":"array","value":"number","length":4,"default":[-180,-85.051129,180,85.051129]},"minzoom":{"type":"number","default":0},"maxzoom":{"type":"number","default":22},"tileSize":{"type":"number","default":512,"units":"pixels"},"attribution":{"type":"string"},"encoding":{"type":"enum","values":{"terrarium":{},"mapbox":{}},"default":"mapbox"},"volatile":{"type":"boolean","default":false},"*":{"type":"*"}},"source_geojson":{"type":{"required":true,"type":"enum","values":{"geojson":{}}},"data":{"type":"*"},"maxzoom":{"type":"number","default":18},"attribution":{"type":"string"},"buffer":{"type":"number","default":128,"maximum":512,"minimum":0},"filter":{"type":"*"},"tolerance":{"type":"number","default":0.375},"cluster":{"type":"boolean","default":false},"clusterRadius":{"type":"number","default":50,"minimum":0},"clusterMaxZoom":{"type":"number"},"clusterMinPoints":{"type":"number"},"clusterProperties":{"type":"*"},"lineMetrics":{"type":"boolean","default":false},"generateId":{"type":"boolean","default":false},"promoteId":{"type":"promoteId"}},"source_video":{"type":{"required":true,"type":"enum","values":{"video":{}}},"urls":{"required":true,"type":"array","value":"string"},"coordinates":{"required":true,"type":"array","length":4,"value":{"type":"array","length":2,"value":"number"}}},"source_image":{"type":{"required":true,"type":"enum","values":{"image":{}}},"url":{"required":true,"type":"string"},"coordinates":{"required":true,"type":"array","length":4,"value":{"type":"array","length":2,"value":"number"}}},"layer":{"id":{"type":"string","required":true},"type":{"type":"enum","values":{"fill":{},"line":{},"symbol":{},"circle":{},"heatmap":{},"fill-extrusion":{},"raster":{},"hillshade":{},"background":{},"sky":{}},"required":true},"metadata":{"type":"*"},"source":{"type":"string"},"source-layer":{"type":"string"},"minzoom":{"type":"number","minimum":0,"maximum":24},"maxzoom":{"type":"number","minimum":0,"maximum":24},"filter":{"type":"filter"},"layout":{"type":"layout"},"paint":{"type":"paint"}},"layout":["layout_fill","layout_line","layout_circle","layout_heatmap","layout_fill-extrusion","layout_symbol","layout_raster","layout_hillshade","layout_background","layout_sky"],"layout_background":{"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_sky":{"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_fill":{"fill-sort-key":{"type":"number","expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_circle":{"circle-sort-key":{"type":"number","expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_heatmap":{"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_fill-extrusion":{"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"},"fill-extrusion-edge-radius":{"type":"number","private":true,"default":0,"minimum":0,"maximum":1,"property-type":"constant"}},"layout_line":{"line-cap":{"type":"enum","values":{"butt":{},"round":{},"square":{}},"default":"butt","expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-join":{"type":"enum","values":{"bevel":{},"round":{},"miter":{}},"default":"miter","expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-miter-limit":{"type":"number","default":2,"requires":[{"line-join":"miter"}],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"line-round-limit":{"type":"number","default":1.05,"requires":[{"line-join":"round"}],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"line-sort-key":{"type":"number","expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_symbol":{"symbol-placement":{"type":"enum","values":{"point":{},"line":{},"line-center":{}},"default":"point","expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"symbol-spacing":{"type":"number","default":250,"minimum":1,"units":"pixels","requires":[{"symbol-placement":"line"}],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"symbol-avoid-edges":{"type":"boolean","default":false,"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"symbol-sort-key":{"type":"number","expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"symbol-z-order":{"type":"enum","values":{"auto":{},"viewport-y":{},"source":{}},"default":"auto","expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-allow-overlap":{"type":"boolean","default":false,"requires":["icon-image"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-ignore-placement":{"type":"boolean","default":false,"requires":["icon-image"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-optional":{"type":"boolean","default":false,"requires":["icon-image","text-field"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-rotation-alignment":{"type":"enum","values":{"map":{},"viewport":{},"auto":{}},"default":"auto","requires":["icon-image"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-size":{"type":"number","default":1,"minimum":0,"units":"factor of the original icon size","requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-text-fit":{"type":"enum","values":{"none":{},"width":{},"height":{},"both":{}},"default":"none","requires":["icon-image","text-field"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-text-fit-padding":{"type":"array","value":"number","length":4,"default":[0,0,0,0],"units":"pixels","requires":["icon-image","text-field",{"icon-text-fit":["both","width","height"]}],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"icon-image":{"type":"resolvedImage","tokens":true,"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-rotate":{"type":"number","default":0,"period":360,"units":"degrees","requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-padding":{"type":"number","default":2,"minimum":0,"units":"pixels","requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"icon-keep-upright":{"type":"boolean","default":false,"requires":["icon-image",{"icon-rotation-alignment":"map"},{"symbol-placement":["line","line-center"]}],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-offset":{"type":"array","value":"number","length":2,"default":[0,0],"requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-anchor":{"type":"enum","values":{"center":{},"left":{},"right":{},"top":{},"bottom":{},"top-left":{},"top-right":{},"bottom-left":{},"bottom-right":{}},"default":"center","requires":["icon-image"],"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-pitch-alignment":{"type":"enum","values":{"map":{},"viewport":{},"auto":{}},"default":"auto","requires":["icon-image"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-pitch-alignment":{"type":"enum","values":{"map":{},"viewport":{},"auto":{}},"default":"auto","requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-rotation-alignment":{"type":"enum","values":{"map":{},"viewport":{},"auto":{}},"default":"auto","requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-field":{"type":"formatted","default":"","tokens":true,"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-font":{"type":"array","value":"string","default":["Open Sans Regular","Arial Unicode MS Regular"],"requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-size":{"type":"number","default":16,"minimum":0,"units":"pixels","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-max-width":{"type":"number","default":10,"minimum":0,"units":"ems","requires":["text-field",{"symbol-placement":["point"]}],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-line-height":{"type":"number","default":1.2,"units":"ems","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-letter-spacing":{"type":"number","default":0,"units":"ems","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-justify":{"type":"enum","values":{"auto":{},"left":{},"center":{},"right":{}},"default":"center","requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-radial-offset":{"type":"number","units":"ems","default":0,"requires":["text-field"],"property-type":"data-driven","expression":{"interpolated":true,"parameters":["zoom","feature"]}},"text-variable-anchor":{"type":"array","value":"enum","values":{"center":{},"left":{},"right":{},"top":{},"bottom":{},"top-left":{},"top-right":{},"bottom-left":{},"bottom-right":{}},"requires":["text-field",{"symbol-placement":["point"]}],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-anchor":{"type":"enum","values":{"center":{},"left":{},"right":{},"top":{},"bottom":{},"top-left":{},"top-right":{},"bottom-left":{},"bottom-right":{}},"default":"center","requires":["text-field",{"!":"text-variable-anchor"}],"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-max-angle":{"type":"number","default":45,"units":"degrees","requires":["text-field",{"symbol-placement":["line","line-center"]}],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"text-writing-mode":{"type":"array","value":"enum","values":{"horizontal":{},"vertical":{}},"requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-rotate":{"type":"number","default":0,"period":360,"units":"degrees","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-padding":{"type":"number","default":2,"minimum":0,"units":"pixels","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"text-keep-upright":{"type":"boolean","default":true,"requires":["text-field",{"text-rotation-alignment":"map"},{"symbol-placement":["line","line-center"]}],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-transform":{"type":"enum","values":{"none":{},"uppercase":{},"lowercase":{}},"default":"none","requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-offset":{"type":"array","value":"number","units":"ems","length":2,"default":[0,0],"requires":["text-field",{"!":"text-radial-offset"}],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-allow-overlap":{"type":"boolean","default":false,"requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-ignore-placement":{"type":"boolean","default":false,"requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-optional":{"type":"boolean","default":false,"requires":["text-field","icon-image"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_raster":{"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_hillshade":{"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"filter":{"type":"array","value":"*"},"filter_symbol":{"type":"boolean","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature","pitch","distance-from-center"]}},"filter_fill":{"type":"boolean","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature"]}},"filter_line":{"type":"boolean","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature"]}},"filter_circle":{"type":"boolean","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature"]}},"filter_fill-extrusion":{"type":"boolean","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature"]}},"filter_heatmap":{"type":"boolean","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature"]}},"filter_operator":{"type":"enum","values":{"==":{},"!=":{},">":{},">=":{},"<":{},"<=":{},"in":{},"!in":{},"all":{},"any":{},"none":{},"has":{},"!has":{},"within":{}}},"geometry_type":{"type":"enum","values":{"Point":{},"LineString":{},"Polygon":{}}},"function":{"expression":{"type":"expression"},"stops":{"type":"array","value":"function_stop"},"base":{"type":"number","default":1,"minimum":0},"property":{"type":"string","default":"$zoom"},"type":{"type":"enum","values":{"identity":{},"exponential":{},"interval":{},"categorical":{}},"default":"exponential"},"colorSpace":{"type":"enum","values":{"rgb":{},"lab":{},"hcl":{}},"default":"rgb"},"default":{"type":"*","required":false}},"function_stop":{"type":"array","minimum":0,"maximum":24,"value":["number","color"],"length":2},"expression":{"type":"array","value":"*","minimum":1},"fog":{"range":{"type":"array","default":[0.5,10],"minimum":-20,"maximum":20,"length":2,"value":"number","property-type":"data-constant","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"color":{"type":"color","property-type":"data-constant","default":"#ffffff","expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"high-color":{"type":"color","property-type":"data-constant","default":"#245cdf","expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"space-color":{"type":"color","property-type":"data-constant","default":["interpolate",["linear"],["zoom"],4,"#010b19",7,"#367ab9"],"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"horizon-blend":{"type":"number","property-type":"data-constant","default":["interpolate",["linear"],["zoom"],4,0.2,7,0.1],"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"star-intensity":{"type":"number","property-type":"data-constant","default":["interpolate",["linear"],["zoom"],5,0.35,6,0],"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true}},"light":{"anchor":{"type":"enum","default":"viewport","values":{"map":{},"viewport":{}},"property-type":"data-constant","transition":false,"expression":{"interpolated":false,"parameters":["zoom"]}},"position":{"type":"array","default":[1.15,210,30],"length":3,"value":"number","property-type":"data-constant","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"color":{"type":"color","property-type":"data-constant","default":"#ffffff","expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"intensity":{"type":"number","property-type":"data-constant","default":0.5,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true}},"projection":{"name":{"type":"enum","values":{"albers":{},"equalEarth":{},"equirectangular":{},"lambertConformalConic":{},"mercator":{},"naturalEarth":{},"winkelTripel":{},"globe":{}},"default":"mercator","required":true},"center":{"type":"array","length":2,"value":"number","property-type":"data-constant","minimum":[-180,-90],"maximum":[180,90],"transition":false,"requires":[{"name":["albers","lambertConformalConic"]}]},"parallels":{"type":"array","length":2,"value":"number","property-type":"data-constant","minimum":[-90,-90],"maximum":[90,90],"transition":false,"requires":[{"name":["albers","lambertConformalConic"]}]}},"terrain":{"source":{"type":"string","required":true},"exaggeration":{"type":"number","property-type":"data-constant","default":1,"minimum":0,"maximum":1000,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true,"requires":["source"]}},"paint":["paint_fill","paint_line","paint_circle","paint_heatmap","paint_fill-extrusion","paint_symbol","paint_raster","paint_hillshade","paint_background","paint_sky"],"paint_fill":{"fill-antialias":{"type":"boolean","default":true,"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"fill-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-color":{"type":"color","default":"#000000","transition":true,"requires":[{"!":"fill-pattern"}],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-outline-color":{"type":"color","transition":true,"requires":[{"!":"fill-pattern"},{"fill-antialias":true}],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"fill-translate-anchor":{"type":"enum","values":{"map":{},"viewport":{}},"default":"map","requires":["fill-translate"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"fill-pattern":{"type":"resolvedImage","transition":false,"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"}},"paint_fill-extrusion":{"fill-extrusion-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"fill-extrusion-color":{"type":"color","default":"#000000","transition":true,"requires":[{"!":"fill-extrusion-pattern"}],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"fill-extrusion-translate-anchor":{"type":"enum","values":{"map":{},"viewport":{}},"default":"map","requires":["fill-extrusion-translate"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"fill-extrusion-pattern":{"type":"resolvedImage","transition":false,"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"fill-extrusion-height":{"type":"number","default":0,"minimum":0,"units":"meters","transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-base":{"type":"number","default":0,"minimum":0,"units":"meters","transition":true,"requires":["fill-extrusion-height"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-vertical-gradient":{"type":"boolean","default":true,"transition":false,"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"fill-extrusion-ambient-occlusion-intensity":{"property-type":"data-constant","type":"number","private":true,"default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"fill-extrusion-ambient-occlusion-radius":{"property-type":"data-constant","type":"number","private":true,"default":3,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true,"requires":["fill-extrusion-edge-radius"]}},"paint_line":{"line-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-color":{"type":"color","default":"#000000","transition":true,"requires":[{"!":"line-pattern"}],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"line-translate-anchor":{"type":"enum","values":{"map":{},"viewport":{}},"default":"map","requires":["line-translate"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"line-width":{"type":"number","default":1,"minimum":0,"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-gap-width":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-offset":{"type":"number","default":0,"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-blur":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-dasharray":{"type":"array","value":"number","minimum":0,"transition":false,"units":"line widths","requires":[{"!":"line-pattern"}],"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-pattern":{"type":"resolvedImage","transition":false,"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-gradient":{"type":"color","transition":false,"requires":[{"!":"line-pattern"},{"source":"geojson","has":{"lineMetrics":true}}],"expression":{"interpolated":true,"parameters":["line-progress"]},"property-type":"color-ramp"},"line-trim-offset":{"type":"array","value":"number","length":2,"default":[0,0],"minimum":[0,0],"maximum":[1,1],"transition":false,"requires":[{"source":"geojson","has":{"lineMetrics":true}}],"property-type":"constant"}},"paint_circle":{"circle-radius":{"type":"number","default":5,"minimum":0,"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-color":{"type":"color","default":"#000000","transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-blur":{"type":"number","default":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"circle-translate-anchor":{"type":"enum","values":{"map":{},"viewport":{}},"default":"map","requires":["circle-translate"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"circle-pitch-scale":{"type":"enum","values":{"map":{},"viewport":{}},"default":"map","expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"circle-pitch-alignment":{"type":"enum","values":{"map":{},"viewport":{}},"default":"viewport","expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"circle-stroke-width":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-stroke-color":{"type":"color","default":"#000000","transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-stroke-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"}},"paint_heatmap":{"heatmap-radius":{"type":"number","default":30,"minimum":1,"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"heatmap-weight":{"type":"number","default":1,"minimum":0,"transition":false,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"heatmap-intensity":{"type":"number","default":1,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"heatmap-color":{"type":"color","default":["interpolate",["linear"],["heatmap-density"],0,"rgba(0, 0, 255, 0)",0.1,"royalblue",0.3,"cyan",0.5,"lime",0.7,"yellow",1,"red"],"transition":false,"expression":{"interpolated":true,"parameters":["heatmap-density"]},"property-type":"color-ramp"},"heatmap-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_symbol":{"icon-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-color":{"type":"color","default":"#000000","transition":true,"requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-color":{"type":"color","default":"rgba(0, 0, 0, 0)","transition":true,"requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-width":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-blur":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"icon-translate-anchor":{"type":"enum","values":{"map":{},"viewport":{}},"default":"map","requires":["icon-image","icon-translate"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-color":{"type":"color","default":"#000000","transition":true,"overridable":true,"requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-color":{"type":"color","default":"rgba(0, 0, 0, 0)","transition":true,"requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-width":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-blur":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"text-translate-anchor":{"type":"enum","values":{"map":{},"viewport":{}},"default":"map","requires":["text-field","text-translate"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_raster":{"raster-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-hue-rotate":{"type":"number","default":0,"period":360,"transition":true,"units":"degrees","expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-brightness-min":{"type":"number","default":0,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-brightness-max":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-saturation":{"type":"number","default":0,"minimum":-1,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-contrast":{"type":"number","default":0,"minimum":-1,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-resampling":{"type":"enum","values":{"linear":{},"nearest":{}},"default":"linear","expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"raster-fade-duration":{"type":"number","default":300,"minimum":0,"transition":false,"units":"milliseconds","expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_hillshade":{"hillshade-illumination-direction":{"type":"number","default":335,"minimum":0,"maximum":359,"transition":false,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-illumination-anchor":{"type":"enum","values":{"map":{},"viewport":{}},"default":"viewport","expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-exaggeration":{"type":"number","default":0.5,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-shadow-color":{"type":"color","default":"#000000","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-highlight-color":{"type":"color","default":"#FFFFFF","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-accent-color":{"type":"color","default":"#000000","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_background":{"background-color":{"type":"color","default":"#000000","transition":true,"requires":[{"!":"background-pattern"}],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"background-pattern":{"type":"resolvedImage","transition":false,"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"background-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_sky":{"sky-type":{"type":"enum","values":{"gradient":{},"atmosphere":{}},"default":"atmosphere","expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"sky-atmosphere-sun":{"type":"array","value":"number","length":2,"units":"degrees","minimum":[0,0],"maximum":[360,180],"transition":false,"requires":[{"sky-type":"atmosphere"}],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"sky-atmosphere-sun-intensity":{"type":"number","requires":[{"sky-type":"atmosphere"}],"default":10,"minimum":0,"maximum":100,"transition":false,"property-type":"data-constant"},"sky-gradient-center":{"type":"array","requires":[{"sky-type":"gradient"}],"value":"number","default":[0,0],"length":2,"units":"degrees","minimum":[0,0],"maximum":[360,180],"transition":false,"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"sky-gradient-radius":{"type":"number","requires":[{"sky-type":"gradient"}],"default":90,"minimum":0,"maximum":180,"transition":false,"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"sky-gradient":{"type":"color","default":["interpolate",["linear"],["sky-radial-progress"],0.8,"#87ceeb",1,"white"],"transition":false,"requires":[{"sky-type":"gradient"}],"expression":{"interpolated":true,"parameters":["sky-radial-progress"]},"property-type":"color-ramp"},"sky-atmosphere-halo-color":{"type":"color","default":"white","transition":false,"requires":[{"sky-type":"atmosphere"}],"property-type":"data-constant"},"sky-atmosphere-color":{"type":"color","default":"white","transition":false,"requires":[{"sky-type":"atmosphere"}],"property-type":"data-constant"},"sky-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"transition":{"duration":{"type":"number","default":300,"minimum":0,"units":"milliseconds"},"delay":{"type":"number","default":0,"minimum":0,"units":"milliseconds"}},"property-type":{"data-driven":{"type":"property-type"},"color-ramp":{"type":"property-type"},"data-constant":{"type":"property-type"},"constant":{"type":"property-type"}},"promoteId":{"*":{"type":"string"}}}'); function Wt(t, ...e) { for (const r of e) for (const e in r) t[e] = r[e]; return t } function Jt(t) { return t instanceof Number || t instanceof String || t instanceof Boolean ? t.valueOf() : t } function Qt(t) { if (Array.isArray(t)) return t.map(Qt); if (t instanceof Object && !(t instanceof Number || t instanceof String || t instanceof Boolean)) { const e = {}; for (const r in t) e[r] = Qt(t[r]); return e } return Jt(t) } class te extends Error { constructor(t, e) { super(e), this.message = e, this.key = t; } } var ee = te; class re { constructor(t, e = []) { this.parent = t, this.bindings = {}; for (const [t, r] of e) this.bindings[t] = r; } concat(t) { return new re(this, t) } get(t) { if (this.bindings[t]) return this.bindings[t]; if (this.parent) return this.parent.get(t); throw new Error(`${t} not found in scope.`) } has(t) { return !!this.bindings[t] || !!this.parent && this.parent.has(t) } } var ne = re; const ie = { kind: "null" }, se = { kind: "number" }, ae = { kind: "string" }, oe = { kind: "boolean" }, le = { kind: "color" }, ue = { kind: "object" }, ce = { kind: "value" }, he = { kind: "collator" }, pe = { kind: "formatted" }, fe = { kind: "resolvedImage" }; function de(t, e) { return { kind: "array", itemType: t, N: e } } function ye(t) { if ("array" === t.kind) { const e = ye(t.itemType); return "number" == typeof t.N ? `array<${e}, ${t.N}>` : "value" === t.itemType.kind ? "array" : `array<${e}>` } return t.kind } const me = [ie, se, ae, oe, le, pe, ue, de(ce), fe]; function ge(t, e) { if ("error" === e.kind) return null; if ("array" === t.kind) { if ("array" === e.kind && (0 === e.N && "value" === e.itemType.kind || !ge(t.itemType, e.itemType)) && ("number" != typeof t.N || t.N === e.N)) return null } else { if (t.kind === e.kind) return null; if ("value" === t.kind) for (const t of me) if (!ge(t, e)) return null } return `Expected ${ye(t)} but found ${ye(e)} instead.` } function xe(t, e) { return e.some((e => e.kind === t.kind)) } function ve(t, e) { return e.some((e => "null" === e ? null === t : "array" === e ? Array.isArray(t) : "object" === e ? t && !Array.isArray(t) && "object" == typeof t : e === typeof t)) } var be, we = { transparent: [0, 0, 0, 0], aliceblue: [240, 248, 255, 1], antiquewhite: [250, 235, 215, 1], aqua: [0, 255, 255, 1], aquamarine: [127, 255, 212, 1], azure: [240, 255, 255, 1], beige: [245, 245, 220, 1], bisque: [255, 228, 196, 1], black: [0, 0, 0, 1], blanchedalmond: [255, 235, 205, 1], blue: [0, 0, 255, 1], blueviolet: [138, 43, 226, 1], brown: [165, 42, 42, 1], burlywood: [222, 184, 135, 1], cadetblue: [95, 158, 160, 1], chartreuse: [127, 255, 0, 1], chocolate: [210, 105, 30, 1], coral: [255, 127, 80, 1], cornflowerblue: [100, 149, 237, 1], cornsilk: [255, 248, 220, 1], crimson: [220, 20, 60, 1], cyan: [0, 255, 255, 1], darkblue: [0, 0, 139, 1], darkcyan: [0, 139, 139, 1], darkgoldenrod: [184, 134, 11, 1], darkgray: [169, 169, 169, 1], darkgreen: [0, 100, 0, 1], darkgrey: [169, 169, 169, 1], darkkhaki: [189, 183, 107, 1], darkmagenta: [139, 0, 139, 1], darkolivegreen: [85, 107, 47, 1], darkorange: [255, 140, 0, 1], darkorchid: [153, 50, 204, 1], darkred: [139, 0, 0, 1], darksalmon: [233, 150, 122, 1], darkseagreen: [143, 188, 143, 1], darkslateblue: [72, 61, 139, 1], darkslategray: [47, 79, 79, 1], darkslategrey: [47, 79, 79, 1], darkturquoise: [0, 206, 209, 1], darkviolet: [148, 0, 211, 1], deeppink: [255, 20, 147, 1], deepskyblue: [0, 191, 255, 1], dimgray: [105, 105, 105, 1], dimgrey: [105, 105, 105, 1], dodgerblue: [30, 144, 255, 1], firebrick: [178, 34, 34, 1], floralwhite: [255, 250, 240, 1], forestgreen: [34, 139, 34, 1], fuchsia: [255, 0, 255, 1], gainsboro: [220, 220, 220, 1], ghostwhite: [248, 248, 255, 1], gold: [255, 215, 0, 1], goldenrod: [218, 165, 32, 1], gray: [128, 128, 128, 1], green: [0, 128, 0, 1], greenyellow: [173, 255, 47, 1], grey: [128, 128, 128, 1], honeydew: [240, 255, 240, 1], hotpink: [255, 105, 180, 1], indianred: [205, 92, 92, 1], indigo: [75, 0, 130, 1], ivory: [255, 255, 240, 1], khaki: [240, 230, 140, 1], lavender: [230, 230, 250, 1], lavenderblush: [255, 240, 245, 1], lawngreen: [124, 252, 0, 1], lemonchiffon: [255, 250, 205, 1], lightblue: [173, 216, 230, 1], lightcoral: [240, 128, 128, 1], lightcyan: [224, 255, 255, 1], lightgoldenrodyellow: [250, 250, 210, 1], lightgray: [211, 211, 211, 1], lightgreen: [144, 238, 144, 1], lightgrey: [211, 211, 211, 1], lightpink: [255, 182, 193, 1], lightsalmon: [255, 160, 122, 1], lightseagreen: [32, 178, 170, 1], lightskyblue: [135, 206, 250, 1], lightslategray: [119, 136, 153, 1], lightslategrey: [119, 136, 153, 1], lightsteelblue: [176, 196, 222, 1], lightyellow: [255, 255, 224, 1], lime: [0, 255, 0, 1], limegreen: [50, 205, 50, 1], linen: [250, 240, 230, 1], magenta: [255, 0, 255, 1], maroon: [128, 0, 0, 1], mediumaquamarine: [102, 205, 170, 1], mediumblue: [0, 0, 205, 1], mediumorchid: [186, 85, 211, 1], mediumpurple: [147, 112, 219, 1], mediumseagreen: [60, 179, 113, 1], mediumslateblue: [123, 104, 238, 1], mediumspringgreen: [0, 250, 154, 1], mediumturquoise: [72, 209, 204, 1], mediumvioletred: [199, 21, 133, 1], midnightblue: [25, 25, 112, 1], mintcream: [245, 255, 250, 1], mistyrose: [255, 228, 225, 1], moccasin: [255, 228, 181, 1], navajowhite: [255, 222, 173, 1], navy: [0, 0, 128, 1], oldlace: [253, 245, 230, 1], olive: [128, 128, 0, 1], olivedrab: [107, 142, 35, 1], orange: [255, 165, 0, 1], orangered: [255, 69, 0, 1], orchid: [218, 112, 214, 1], palegoldenrod: [238, 232, 170, 1], palegreen: [152, 251, 152, 1], paleturquoise: [175, 238, 238, 1], palevioletred: [219, 112, 147, 1], papayawhip: [255, 239, 213, 1], peachpuff: [255, 218, 185, 1], peru: [205, 133, 63, 1], pink: [255, 192, 203, 1], plum: [221, 160, 221, 1], powderblue: [176, 224, 230, 1], purple: [128, 0, 128, 1], rebeccapurple: [102, 51, 153, 1], red: [255, 0, 0, 1], rosybrown: [188, 143, 143, 1], royalblue: [65, 105, 225, 1], saddlebrown: [139, 69, 19, 1], salmon: [250, 128, 114, 1], sandybrown: [244, 164, 96, 1], seagreen: [46, 139, 87, 1], seashell: [255, 245, 238, 1], sienna: [160, 82, 45, 1], silver: [192, 192, 192, 1], skyblue: [135, 206, 235, 1], slateblue: [106, 90, 205, 1], slategray: [112, 128, 144, 1], slategrey: [112, 128, 144, 1], snow: [255, 250, 250, 1], springgreen: [0, 255, 127, 1], steelblue: [70, 130, 180, 1], tan: [210, 180, 140, 1], teal: [0, 128, 128, 1], thistle: [216, 191, 216, 1], tomato: [255, 99, 71, 1], turquoise: [64, 224, 208, 1], violet: [238, 130, 238, 1], wheat: [245, 222, 179, 1], white: [255, 255, 255, 1], whitesmoke: [245, 245, 245, 1], yellow: [255, 255, 0, 1], yellowgreen: [154, 205, 50, 1] }; function _e(t) { return (t = Math.round(t)) < 0 ? 0 : t > 255 ? 255 : t } function Ae(t) { return _e("%" === t[t.length - 1] ? parseFloat(t) / 100 * 255 : parseInt(t)) } function Se(t) { return (e = "%" === t[t.length - 1] ? parseFloat(t) / 100 : parseFloat(t)) < 0 ? 0 : e > 1 ? 1 : e; var e; } function ke(t, e, r) { return r < 0 ? r += 1 : r > 1 && (r -= 1), 6 * r < 1 ? t + (e - t) * r * 6 : 2 * r < 1 ? e : 3 * r < 2 ? t + (e - t) * (2 / 3 - r) * 6 : t } try { be = {}.parseCSSColor = function(t) { var e, r = t.replace(/ /g, "").toLowerCase(); if (r in we) return we[r].slice(); if ("#" === r[0]) return 4 === r.length ? (e = parseInt(r.substr(1), 16)) >= 0 && e <= 4095 ? [(3840 & e) >> 4 | (3840 & e) >> 8, 240 & e | (240 & e) >> 4, 15 & e | (15 & e) << 4, 1] : null : 7 === r.length && (e = parseInt(r.substr(1), 16)) >= 0 && e <= 16777215 ? [(16711680 & e) >> 16, (65280 & e) >> 8, 255 & e, 1] : null; var n = r.indexOf("("), i = r.indexOf(")"); if (-1 !== n && i + 1 === r.length) { var s = r.substr(0, n), a = r.substr(n + 1, i - (n + 1)).split(","), o = 1; switch (s) { case "rgba": if (4 !== a.length) return null; o = Se(a.pop()); case "rgb": return 3 !== a.length ? null : [Ae(a[0]), Ae(a[1]), Ae(a[2]), o]; case "hsla": if (4 !== a.length) return null; o = Se(a.pop()); case "hsl": if (3 !== a.length) return null; var l = (parseFloat(a[0]) % 360 + 360) % 360 / 360, u = Se(a[1]), c = Se(a[2]), h = c <= .5 ? c * (u + 1) : c + u - c * u, p = 2 * c - h; return [_e(255 * ke(p, h, l + 1 / 3)), _e(255 * ke(p, h, l)), _e(255 * ke(p, h, l - 1 / 3)), o]; default: return null } } return null }; } catch (t) {} class Ie { constructor(t, e, r, n = 1) { this.r = t, this.g = e, this.b = r, this.a = n; } static parse(t) { if (!t) return; if (t instanceof Ie) return t; if ("string" != typeof t) return; const e = be(t); return e ? new Ie(e[0] / 255 * e[3], e[1] / 255 * e[3], e[2] / 255 * e[3], e[3]) : void 0 } toString() { const [t, e, r, n] = this.toArray(); return `rgba(${Math.round(t)},${Math.round(e)},${Math.round(r)},${n})` } toArray() { const { r: t, g: e, b: r, a: n } = this; return 0 === n ? [0, 0, 0, 0] : [255 * t / n, 255 * e / n, 255 * r / n, n] } toArray01() { const { r: t, g: e, b: r, a: n } = this; return 0 === n ? [0, 0, 0, 0] : [t / n, e / n, r / n, n] } toArray01PremultipliedAlpha() { const { r: t, g: e, b: r, a: n } = this; return [t, e, r, n] } } Ie.black = new Ie(0, 0, 0, 1), Ie.white = new Ie(1, 1, 1, 1), Ie.transparent = new Ie(0, 0, 0, 0), Ie.red = new Ie(1, 0, 0, 1), Ie.blue = new Ie(0, 0, 1, 1); var Me = Ie; class Te { constructor(t, e, r) { this.sensitivity = t ? e ? "variant" : "case" : e ? "accent" : "base", this.locale = r, this.collator = new Intl.Collator(this.locale ? this.locale : [], { sensitivity: this.sensitivity, usage: "search" }); } compare(t, e) { return this.collator.compare(t, e) } resolvedLocale() { return new Intl.Collator(this.locale ? this.locale : []).resolvedOptions().locale } } class ze { constructor(t, e, r, n, i) { this.text = t.normalize ? t.normalize() : t, this.image = e, this.scale = r, this.fontStack = n, this.textColor = i; } } class Be { constructor(t) { this.sections = t; } static fromString(t) { return new Be([new ze(t, null, null, null, null)]) } isEmpty() { return 0 === this.sections.length || !this.sections.some((t => 0 !== t.text.length || t.image && 0 !== t.image.name.length)) } static factory(t) { return t instanceof Be ? t : Be.fromString(t) } toString() { return 0 === this.sections.length ? "" : this.sections.map((t => t.text)).join("") } serialize() { const t = ["format"]; for (const e of this.sections) { if (e.image) { t.push(["image", e.image.name]); continue } t.push(e.text); const r = {}; e.fontStack && (r["text-font"] = ["literal", e.fontStack.split(",")]), e.scale && (r["font-scale"] = e.scale), e.textColor && (r["text-color"] = ["rgba"].concat(e.textColor.toArray())), t.push(r); } return t } } class Ee { constructor(t) { this.name = t.name, this.available = t.available; } toString() { return this.name } static fromString(t) { return t ? new Ee({ name: t, available: !1 }) : null } serialize() { return ["image", this.name] } } function Ce(t, e, r, n) { return "number" == typeof t && t >= 0 && t <= 255 && "number" == typeof e && e >= 0 && e <= 255 && "number" == typeof r && r >= 0 && r <= 255 ? void 0 === n || "number" == typeof n && n >= 0 && n <= 1 ? null : `Invalid rgba value [${[t,e,r,n].join(", ")}]: 'a' must be between 0 and 1.` : `Invalid rgba value [${("number"==typeof n?[t,e,r,n]:[t,e,r]).join(", ")}]: 'r', 'g', and 'b' must be between 0 and 255.` } function Pe(t) { if (null === t) return !0; if ("string" == typeof t) return !0; if ("boolean" == typeof t) return !0; if ("number" == typeof t) return !0; if (t instanceof Me) return !0; if (t instanceof Te) return !0; if (t instanceof Be) return !0; if (t instanceof Ee) return !0; if (Array.isArray(t)) { for (const e of t) if (!Pe(e)) return !1; return !0 } if ("object" == typeof t) { for (const e in t) if (!Pe(t[e])) return !1; return !0 } return !1 } function De(t) { if (null === t) return ie; if ("string" == typeof t) return ae; if ("boolean" == typeof t) return oe; if ("number" == typeof t) return se; if (t instanceof Me) return le; if (t instanceof Te) return he; if (t instanceof Be) return pe; if (t instanceof Ee) return fe; if (Array.isArray(t)) { const e = t.length; let r; for (const e of t) { const t = De(e); if (r) { if (r === t) continue; r = ce; break } r = t; } return de(r || ce, e) } return ue } function Ve(t) { const e = typeof t; return null === t ? "" : "string" === e || "number" === e || "boolean" === e ? String(t) : t instanceof Me || t instanceof Be || t instanceof Ee ? t.toString() : JSON.stringify(t) } class Le { constructor(t, e) { this.type = t, this.value = e; } static parse(t, e) { if (2 !== t.length) return e.error(`'literal' expression requires exactly one argument, but found ${t.length-1} instead.`); if (!Pe(t[1])) return e.error("invalid value"); const r = t[1]; let n = De(r); const i = e.expectedType; return "array" !== n.kind || 0 !== n.N || !i || "array" !== i.kind || "number" == typeof i.N && 0 !== i.N || (n = i), new Le(n, r) } evaluate() { return this.value } eachChild() {} outputDefined() { return !0 } serialize() { return "array" === this.type.kind || "object" === this.type.kind ? ["literal", this.value] : this.value instanceof Me ? ["rgba"].concat(this.value.toArray()) : this.value instanceof Be ? this.value.serialize() : this.value } } var Fe = Le, Re = class { constructor(t) { this.name = "ExpressionEvaluationError", this.message = t; } toJSON() { return this.message } }; const je = { string: ae, number: se, boolean: oe, object: ue }; class $e { constructor(t, e) { this.type = t, this.args = e; } static parse(t, e) { if (t.length < 2) return e.error("Expected at least one argument."); let r, n = 1; const i = t[0]; if ("array" === i) { let i, s; if (t.length > 2) { const r = t[1]; if ("string" != typeof r || !(r in je) || "object" === r) return e.error('The item type argument of "array" must be one of string, number, boolean', 1); i = je[r], n++; } else i = ce; if (t.length > 3) { if (null !== t[2] && ("number" != typeof t[2] || t[2] < 0 || t[2] !== Math.floor(t[2]))) return e.error('The length argument to "array" must be a positive integer literal', 2); s = t[2], n++; } r = de(i, s); } else r = je[i]; const s = []; for (; n < t.length; n++) { const r = e.parse(t[n], n, ce); if (!r) return null; s.push(r); } return new $e(r, s) } evaluate(t) { for (let e = 0; e < this.args.length; e++) { const r = this.args[e].evaluate(t); if (!ge(this.type, De(r))) return r; if (e === this.args.length - 1) throw new Re(`Expected value to be of type ${ye(this.type)}, but found ${ye(De(r))} instead.`) } return null } eachChild(t) { this.args.forEach(t); } outputDefined() { return this.args.every((t => t.outputDefined())) } serialize() { const t = this.type, e = [t.kind]; if ("array" === t.kind) { const r = t.itemType; if ("string" === r.kind || "number" === r.kind || "boolean" === r.kind) { e.push(r.kind); const n = t.N; ("number" == typeof n || this.args.length > 1) && e.push(n); } } return e.concat(this.args.map((t => t.serialize()))) } } var Ue = $e; class Oe { constructor(t) { this.type = pe, this.sections = t; } static parse(t, e) { if (t.length < 2) return e.error("Expected at least one argument."); const r = t[1]; if (!Array.isArray(r) && "object" == typeof r) return e.error("First argument must be an image or text section."); const n = []; let i = !1; for (let r = 1; r <= t.length - 1; ++r) { const s = t[r]; if (i && "object" == typeof s && !Array.isArray(s)) { i = !1; let t = null; if (s["font-scale"] && (t = e.parse(s["font-scale"], 1, se), !t)) return null; let r = null; if (s["text-font"] && (r = e.parse(s["text-font"], 1, de(ae)), !r)) return null; let a = null; if (s["text-color"] && (a = e.parse(s["text-color"], 1, le), !a)) return null; const o = n[n.length - 1]; o.scale = t, o.font = r, o.textColor = a; } else { const s = e.parse(t[r], 1, ce); if (!s) return null; const a = s.type.kind; if ("string" !== a && "value" !== a && "null" !== a && "resolvedImage" !== a) return e.error("Formatted text type must be 'string', 'value', 'image' or 'null'."); i = !0, n.push({ content: s, scale: null, font: null, textColor: null }); } } return new Oe(n) } evaluate(t) { return new Be(this.sections.map((e => { const r = e.content.evaluate(t); return De(r) === fe ? new ze("", r, null, null, null) : new ze(Ve(r), null, e.scale ? e.scale.evaluate(t) : null, e.font ? e.font.evaluate(t).join(",") : null, e.textColor ? e.textColor.evaluate(t) : null) }))) } eachChild(t) { for (const e of this.sections) t(e.content), e.scale && t(e.scale), e.font && t(e.font), e.textColor && t(e.textColor); } outputDefined() { return !1 } serialize() { const t = ["format"]; for (const e of this.sections) { t.push(e.content.serialize()); const r = {}; e.scale && (r["font-scale"] = e.scale.serialize()), e.font && (r["text-font"] = e.font.serialize()), e.textColor && (r["text-color"] = e.textColor.serialize()), t.push(r); } return t } } class qe { constructor(t) { this.type = fe, this.input = t; } static parse(t, e) { if (2 !== t.length) return e.error("Expected two arguments."); const r = e.parse(t[1], 1, ae); return r ? new qe(r) : e.error("No image name provided.") } evaluate(t) { const e = this.input.evaluate(t), r = Ee.fromString(e); return r && t.availableImages && (r.available = t.availableImages.indexOf(e) > -1), r } eachChild(t) { t(this.input); } outputDefined() { return !1 } serialize() { return ["image", this.input.serialize()] } } const Ne = { "to-boolean": oe, "to-color": le, "to-number": se, "to-string": ae }; class Ge { constructor(t, e) { this.type = t, this.args = e; } static parse(t, e) { if (t.length < 2) return e.error("Expected at least one argument."); const r = t[0]; if (("to-boolean" === r || "to-string" === r) && 2 !== t.length) return e.error("Expected one argument."); const n = Ne[r], i = []; for (let r = 1; r < t.length; r++) { const n = e.parse(t[r], r, ce); if (!n) return null; i.push(n); } return new Ge(n, i) } evaluate(t) { if ("boolean" === this.type.kind) return Boolean(this.args[0].evaluate(t)); if ("color" === this.type.kind) { let e, r; for (const n of this.args) { if (e = n.evaluate(t), r = null, e instanceof Me) return e; if ("string" == typeof e) { const r = t.parseColor(e); if (r) return r } else if (Array.isArray(e) && (r = e.length < 3 || e.length > 4 ? `Invalid rbga value ${JSON.stringify(e)}: expected an array containing either three or four numeric values.` : Ce(e[0], e[1], e[2], e[3]), !r)) return new Me(e[0] / 255, e[1] / 255, e[2] / 255, e[3]) } throw new Re(r || `Could not parse color from value '${"string"==typeof e?e:String(JSON.stringify(e))}'`) } if ("number" === this.type.kind) { let e = null; for (const r of this.args) { if (e = r.evaluate(t), null === e) return 0; const n = Number(e); if (!isNaN(n)) return n } throw new Re(`Could not convert ${JSON.stringify(e)} to number.`) } return "formatted" === this.type.kind ? Be.fromString(Ve(this.args[0].evaluate(t))) : "resolvedImage" === this.type.kind ? Ee.fromString(Ve(this.args[0].evaluate(t))) : Ve(this.args[0].evaluate(t)) } eachChild(t) { this.args.forEach(t); } outputDefined() { return this.args.every((t => t.outputDefined())) } serialize() { if ("formatted" === this.type.kind) return new Oe([{ content: this.args[0], scale: null, font: null, textColor: null }]).serialize(); if ("resolvedImage" === this.type.kind) return new qe(this.args[0]).serialize(); const t = [`to-${this.type.kind}`]; return this.eachChild((e => { t.push(e.serialize()); })), t } } var Ze = Ge; const Xe = ["Unknown", "Point", "LineString", "Polygon"]; var Ke = class { constructor() { this.globals = null, this.feature = null, this.featureState = null, this.formattedSection = null, this._parseColorCache = {}, this.availableImages = null, this.canonical = null, this.featureTileCoord = null, this.featureDistanceData = null; } id() { return this.feature && void 0 !== this.feature.id ? this.feature.id : null } geometryType() { return this.feature ? "number" == typeof this.feature.type ? Xe[this.feature.type] : this.feature.type : null } geometry() { return this.feature && "geometry" in this.feature ? this.feature.geometry : null } canonicalID() { return this.canonical } properties() { return this.feature && this.feature.properties || {} } distanceFromCenter() { if (this.featureTileCoord && this.featureDistanceData) { const t = this.featureDistanceData.center, e = this.featureDistanceData.scale, { x: r, y: n } = this.featureTileCoord; return this.featureDistanceData.bearing[0] * (r * e - t[0]) + this.featureDistanceData.bearing[1] * (n * e - t[1]) } return 0 } parseColor(t) { let e = this._parseColorCache[t]; return e || (e = this._parseColorCache[t] = Me.parse(t)), e } }; class Ye { constructor(t, e, r, n) { this.name = t, this.type = e, this._evaluate = r, this.args = n; } evaluate(t) { return this._evaluate(t, this.args) } eachChild(t) { this.args.forEach(t); } outputDefined() { return !1 } serialize() { return [this.name].concat(this.args.map((t => t.serialize()))) } static parse(t, e) { const r = t[0], n = Ye.definitions[r]; if (!n) return e.error(`Unknown expression "${r}". If you wanted a literal array, use ["literal", [...]].`, 0); const i = Array.isArray(n) ? n[0] : n.type, s = Array.isArray(n) ? [ [n[1], n[2]] ] : n.overloads, a = s.filter((([e]) => !Array.isArray(e) || e.length === t.length - 1)); let o = null; for (const [n, s] of a) { o = new _r(e.registry, e.path, null, e.scope); const a = []; let l = !1; for (let e = 1; e < t.length; e++) { const r = t[e], i = Array.isArray(n) ? n[e - 1] : n.type, s = o.parse(r, 1 + a.length, i); if (!s) { l = !0; break } a.push(s); } if (!l) if (Array.isArray(n) && n.length !== a.length) o.error(`Expected ${n.length} arguments, but found ${a.length} instead.`); else { for (let t = 0; t < a.length; t++) { const e = Array.isArray(n) ? n[t] : n.type, r = a[t]; o.concat(t + 1).checkSubtype(e, r.type); } if (0 === o.errors.length) return new Ye(r, i, s, a) } } if (1 === a.length) e.errors.push(...o.errors); else { const r = (a.length ? a : s).map((([t]) => { return e = t, Array.isArray(e) ? `(${e.map(ye).join(", ")})` : `(${ye(e.type)}...)`; var e; })).join(" | "), n = []; for (let r = 1; r < t.length; r++) { const i = e.parse(t[r], 1 + n.length); if (!i) return null; n.push(ye(i.type)); } e.error(`Expected arguments of type ${r}, but found (${n.join(", ")}) instead.`); } return null } static register(t, e) { Ye.definitions = e; for (const r in e) t[r] = Ye; } } var He = Ye; class We { constructor(t, e, r) { this.type = he, this.locale = r, this.caseSensitive = t, this.diacriticSensitive = e; } static parse(t, e) { if (2 !== t.length) return e.error("Expected one argument."); const r = t[1]; if ("object" != typeof r || Array.isArray(r)) return e.error("Collator options argument must be an object."); const n = e.parse(void 0 !== r["case-sensitive"] && r["case-sensitive"], 1, oe); if (!n) return null; const i = e.parse(void 0 !== r["diacritic-sensitive"] && r["diacritic-sensitive"], 1, oe); if (!i) return null; let s = null; return r.locale && (s = e.parse(r.locale, 1, ae), !s) ? null : new We(n, i, s) } evaluate(t) { return new Te(this.caseSensitive.evaluate(t), this.diacriticSensitive.evaluate(t), this.locale ? this.locale.evaluate(t) : null) } eachChild(t) { t(this.caseSensitive), t(this.diacriticSensitive), this.locale && t(this.locale); } outputDefined() { return !1 } serialize() { const t = {}; return t["case-sensitive"] = this.caseSensitive.serialize(), t["diacritic-sensitive"] = this.diacriticSensitive.serialize(), this.locale && (t.locale = this.locale.serialize()), ["collator", t] } } const Je = 8192; function Qe(t, e) { t[0] = Math.min(t[0], e[0]), t[1] = Math.min(t[1], e[1]), t[2] = Math.max(t[2], e[0]), t[3] = Math.max(t[3], e[1]); } function tr(t, e) { return !(t[0] <= e[0] || t[2] >= e[2] || t[1] <= e[1] || t[3] >= e[3]) } function er(t, e) { const r = (180 + t[0]) / 360, n = (180 - 180 / Math.PI * Math.log(Math.tan(Math.PI / 4 + t[1] * Math.PI / 360))) / 360, i = Math.pow(2, e.z); return [Math.round(r * i * Je), Math.round(n * i * Je)] } function rr(t, e, r) { const n = t[0] - e[0], i = t[1] - e[1], s = t[0] - r[0], a = t[1] - r[1]; return n * a - s * i == 0 && n * s <= 0 && i * a <= 0 } function nr(t, e) { let r = !1; for (let a = 0, o = e.length; a < o; a++) { const o = e[a]; for (let e = 0, a = o.length; e < a - 1; e++) { if (rr(t, o[e], o[e + 1])) return !1; (i = o[e])[1] > (n = t)[1] != (s = o[e + 1])[1] > n[1] && n[0] < (s[0] - i[0]) * (n[1] - i[1]) / (s[1] - i[1]) + i[0] && (r = !r); } } var n, i, s; return r } function ir(t, e) { for (let r = 0; r < e.length; r++) if (nr(t, e[r])) return !0; return !1 } function sr(t, e, r, n) { const i = n[0] - r[0], s = n[1] - r[1], a = (t[0] - r[0]) * s - i * (t[1] - r[1]), o = (e[0] - r[0]) * s - i * (e[1] - r[1]); return a > 0 && o < 0 || a < 0 && o > 0 } function ar(t, e, r) { for (const u of r) for (let r = 0; r < u.length - 1; ++r) if (0 != (o = [(a = u[r + 1])[0] - (s = u[r])[0], a[1] - s[1]])[0] * (l = [(i = e)[0] - (n = t)[0], i[1] - n[1]])[1] - o[1] * l[0] && sr(n, i, s, a) && sr(s, a, n, i)) return !0; var n, i, s, a, o, l; return !1 } function or(t, e) { for (let r = 0; r < t.length; ++r) if (!nr(t[r], e)) return !1; for (let r = 0; r < t.length - 1; ++r) if (ar(t[r], t[r + 1], e)) return !1; return !0 } function lr(t, e) { for (let r = 0; r < e.length; r++) if (or(t, e[r])) return !0; return !1 } function ur(t, e, r) { const n = []; for (let i = 0; i < t.length; i++) { const s = []; for (let n = 0; n < t[i].length; n++) { const a = er(t[i][n], r); Qe(e, a), s.push(a); } n.push(s); } return n } function cr(t, e, r) { const n = []; for (let i = 0; i < t.length; i++) { const s = ur(t[i], e, r); n.push(s); } return n } function hr(t, e, r, n) { if (t[0] < r[0] || t[0] > r[2]) { const e = .5 * n; let i = t[0] - r[0] > e ? -n : r[0] - t[0] > e ? n : 0; 0 === i && (i = t[0] - r[2] > e ? -n : r[2] - t[0] > e ? n : 0), t[0] += i; } Qe(e, t); } function pr(t, e, r, n) { const i = Math.pow(2, n.z) * Je, s = [n.x * Je, n.y * Je], a = []; if (!t) return a; for (const n of t) for (const t of n) { const n = [t.x + s[0], t.y + s[1]]; hr(n, e, r, i), a.push(n); } return a } function fr(t, e, r, n) { const i = Math.pow(2, n.z) * Je, s = [n.x * Je, n.y * Je], a = []; if (!t) return a; for (const r of t) { const t = []; for (const n of r) { const r = [n.x + s[0], n.y + s[1]]; Qe(e, r), t.push(r); } a.push(t); } if (e[2] - e[0] <= i / 2) { (o = e)[0] = o[1] = 1 / 0, o[2] = o[3] = -1 / 0; for (const t of a) for (const n of t) hr(n, e, r, i); } var o; return a } class dr { constructor(t, e) { this.type = oe, this.geojson = t, this.geometries = e; } static parse(t, e) { if (2 !== t.length) return e.error(`'within' expression requires exactly one argument, but found ${t.length-1} instead.`); if (Pe(t[1])) { const e = t[1]; if ("FeatureCollection" === e.type) for (let t = 0; t < e.features.length; ++t) { const r = e.features[t].geometry.type; if ("Polygon" === r || "MultiPolygon" === r) return new dr(e, e.features[t].geometry) } else if ("Feature" === e.type) { const t = e.geometry.type; if ("Polygon" === t || "MultiPolygon" === t) return new dr(e, e.geometry) } else if ("Polygon" === e.type || "MultiPolygon" === e.type) return new dr(e, e) } return e.error("'within' expression requires valid geojson object that contains polygon geometry type.") } evaluate(t) { if (null != t.geometry() && null != t.canonicalID()) { if ("Point" === t.geometryType()) return function(t, e) { const r = [1 / 0, 1 / 0, -1 / 0, -1 / 0], n = [1 / 0, 1 / 0, -1 / 0, -1 / 0], i = t.canonicalID(); if (!i) return !1; if ("Polygon" === e.type) { const s = ur(e.coordinates, n, i), a = pr(t.geometry(), r, n, i); if (!tr(r, n)) return !1; for (const t of a) if (!nr(t, s)) return !1 } if ("MultiPolygon" === e.type) { const s = cr(e.coordinates, n, i), a = pr(t.geometry(), r, n, i); if (!tr(r, n)) return !1; for (const t of a) if (!ir(t, s)) return !1 } return !0 }(t, this.geometries); if ("LineString" === t.geometryType()) return function(t, e) { const r = [1 / 0, 1 / 0, -1 / 0, -1 / 0], n = [1 / 0, 1 / 0, -1 / 0, -1 / 0], i = t.canonicalID(); if (!i) return !1; if ("Polygon" === e.type) { const s = ur(e.coordinates, n, i), a = fr(t.geometry(), r, n, i); if (!tr(r, n)) return !1; for (const t of a) if (!or(t, s)) return !1 } if ("MultiPolygon" === e.type) { const s = cr(e.coordinates, n, i), a = fr(t.geometry(), r, n, i); if (!tr(r, n)) return !1; for (const t of a) if (!lr(t, s)) return !1 } return !0 }(t, this.geometries) } return !1 } eachChild() {} outputDefined() { return !0 } serialize() { return ["within", this.geojson] } } var yr = dr; function mr(t) { if (t instanceof He) { if ("get" === t.name && 1 === t.args.length) return !1; if ("feature-state" === t.name) return !1; if ("has" === t.name && 1 === t.args.length) return !1; if ("properties" === t.name || "geometry-type" === t.name || "id" === t.name) return !1; if (/^filter-/.test(t.name)) return !1 } if (t instanceof yr) return !1; let e = !0; return t.eachChild((t => { e && !mr(t) && (e = !1); })), e } function gr(t) { if (t instanceof He && "feature-state" === t.name) return !1; let e = !0; return t.eachChild((t => { e && !gr(t) && (e = !1); })), e } function xr(t, e) { if (t instanceof He && e.indexOf(t.name) >= 0) return !1; let r = !0; return t.eachChild((t => { r && !xr(t, e) && (r = !1); })), r } class vr { constructor(t, e) { this.type = e.type, this.name = t, this.boundExpression = e; } static parse(t, e) { if (2 !== t.length || "string" != typeof t[1]) return e.error("'var' expression requires exactly one string literal argument."); const r = t[1]; return e.scope.has(r) ? new vr(r, e.scope.get(r)) : e.error(`Unknown variable "${r}". Make sure "${r}" has been bound in an enclosing "let" expression before using it.`, 1) } evaluate(t) { return this.boundExpression.evaluate(t) } eachChild() {} outputDefined() { return !1 } serialize() { return ["var", this.name] } } var br = vr; class wr { constructor(t, e = [], r, n = new ne, i = []) { this.registry = t, this.path = e, this.key = e.map((t => `[${t}]`)).join(""), this.scope = n, this.errors = i, this.expectedType = r; } parse(t, e, r, n, i = {}) { return e ? this.concat(e, r, n)._parse(t, i) : this._parse(t, i) } _parse(t, e) { function r(t, e, r) { return "assert" === r ? new Ue(e, [t]) : "coerce" === r ? new Ze(e, [t]) : t } if (null !== t && "string" != typeof t && "boolean" != typeof t && "number" != typeof t || (t = ["literal", t]), Array.isArray(t)) { if (0 === t.length) return this.error('Expected an array with at least one element. If you wanted a literal array, use ["literal", []].'); const n = t[0]; if ("string" != typeof n) return this.error(`Expression name must be a string, but found ${typeof n} instead. If you wanted a literal array, use ["literal", [...]].`, 0), null; const i = this.registry[n]; if (i) { let n = i.parse(t, this); if (!n) return null; if (this.expectedType) { const t = this.expectedType, i = n.type; if ("string" !== t.kind && "number" !== t.kind && "boolean" !== t.kind && "object" !== t.kind && "array" !== t.kind || "value" !== i.kind) if ("color" !== t.kind && "formatted" !== t.kind && "resolvedImage" !== t.kind || "value" !== i.kind && "string" !== i.kind) { if (this.checkSubtype(t, i)) return null } else n = r(n, t, e.typeAnnotation || "coerce"); else n = r(n, t, e.typeAnnotation || "assert"); } if (!(n instanceof Fe) && "resolvedImage" !== n.type.kind && Ar(n)) { const t = new Ke; try { n = new Fe(n.type, n.evaluate(t)); } catch (t) { return this.error(t.message), null } } return n } return this.error(`Unknown expression "${n}". If you wanted a literal array, use ["literal", [...]].`, 0) } return this.error(void 0 === t ? "'undefined' value invalid. Use null instead." : "object" == typeof t ? 'Bare objects invalid. Use ["literal", {...}] instead.' : `Expected an array, but found ${typeof t} instead.`) } concat(t, e, r) { const n = "number" == typeof t ? this.path.concat(t) : this.path, i = r ? this.scope.concat(r) : this.scope; return new wr(this.registry, n, e || null, i, this.errors) } error(t, ...e) { const r = `${this.key}${e.map((t=>`[${t}]`)).join("")}`; this.errors.push(new ee(r, t)); } checkSubtype(t, e) { const r = ge(t, e); return r && this.error(r), r } } var _r = wr; function Ar(t) { if (t instanceof br) return Ar(t.boundExpression); if (t instanceof He && "error" === t.name) return !1; if (t instanceof We) return !1; if (t instanceof yr) return !1; const e = t instanceof Ze || t instanceof Ue; let r = !0; return t.eachChild((t => { r = e ? r && Ar(t) : r && t instanceof Fe; })), !!r && mr(t) && xr(t, ["zoom", "heatmap-density", "line-progress", "sky-radial-progress", "accumulated", "is-supported-script", "pitch", "distance-from-center"]) } function Sr(t, e) { const r = t.length - 1; let n, i, s = 0, a = r, o = 0; for (; s <= a;) if (o = Math.floor((s + a) / 2), n = t[o], i = t[o + 1], n <= e) { if (o === r || e < i) return o; s = o + 1; } else { if (!(n > e)) throw new Re("Input is not a number."); a = o - 1; } return 0 } class kr { constructor(t, e, r) { this.type = t, this.input = e, this.labels = [], this.outputs = []; for (const [t, e] of r) this.labels.push(t), this.outputs.push(e); } static parse(t, e) { if (t.length - 1 < 4) return e.error(`Expected at least 4 arguments, but found only ${t.length-1}.`); if ((t.length - 1) % 2 != 0) return e.error("Expected an even number of arguments."); const r = e.parse(t[1], 1, se); if (!r) return null; const n = []; let i = null; e.expectedType && "value" !== e.expectedType.kind && (i = e.expectedType); for (let r = 1; r < t.length; r += 2) { const s = 1 === r ? -1 / 0 : t[r], a = t[r + 1], o = r, l = r + 1; if ("number" != typeof s) return e.error('Input/output pairs for "step" expressions must be defined using literal numeric values (not computed expressions) for the input values.', o); if (n.length && n[n.length - 1][0] >= s) return e.error('Input/output pairs for "step" expressions must be arranged with input values in strictly ascending order.', o); const u = e.parse(a, l, i); if (!u) return null; i = i || u.type, n.push([s, u]); } return new kr(i, r, n) } evaluate(t) { const e = this.labels, r = this.outputs; if (1 === e.length) return r[0].evaluate(t); const n = this.input.evaluate(t); if (n <= e[0]) return r[0].evaluate(t); const i = e.length; return n >= e[i - 1] ? r[i - 1].evaluate(t) : r[Sr(e, n)].evaluate(t) } eachChild(t) { t(this.input); for (const e of this.outputs) t(e); } outputDefined() { return this.outputs.every((t => t.outputDefined())) } serialize() { const t = ["step", this.input.serialize()]; for (let e = 0; e < this.labels.length; e++) e > 0 && t.push(this.labels[e]), t.push(this.outputs[e].serialize()); return t } } var Ir = kr; function Mr(t, e, r) { return t * (1 - r) + e * r } var Tr = Object.freeze({ __proto__: null, number: Mr, color: function(t, e, r) { return new Me(Mr(t.r, e.r, r), Mr(t.g, e.g, r), Mr(t.b, e.b, r), Mr(t.a, e.a, r)) }, array: function(t, e, r) { return t.map(((t, n) => Mr(t, e[n], r))) } }); const zr = .95047, Br = 1.08883, Er = 4 / 29, Cr = 6 / 29, Pr = 3 * Cr * Cr, Dr = Math.PI / 180, Vr = 180 / Math.PI; function Lr(t) { return t > .008856451679035631 ? Math.pow(t, 1 / 3) : t / Pr + Er } function Fr(t) { return t > Cr ? t * t * t : Pr * (t - Er) } function Rr(t) { return 255 * (t <= .0031308 ? 12.92 * t : 1.055 * Math.pow(t, 1 / 2.4) - .055) } function jr(t) { return (t /= 255) <= .04045 ? t / 12.92 : Math.pow((t + .055) / 1.055, 2.4) } function $r(t) { const e = jr(t.r), r = jr(t.g), n = jr(t.b), i = Lr((.4124564 * e + .3575761 * r + .1804375 * n) / zr), s = Lr((.2126729 * e + .7151522 * r + .072175 * n) / 1); return { l: 116 * s - 16, a: 500 * (i - s), b: 200 * (s - Lr((.0193339 * e + .119192 * r + .9503041 * n) / Br)), alpha: t.a } } function Ur(t) { let e = (t.l + 16) / 116, r = isNaN(t.a) ? e : e + t.a / 500, n = isNaN(t.b) ? e : e - t.b / 200; return e = 1 * Fr(e), r = zr * Fr(r), n = Br * Fr(n), new Me(Rr(3.2404542 * r - 1.5371385 * e - .4985314 * n), Rr(-.969266 * r + 1.8760108 * e + .041556 * n), Rr(.0556434 * r - .2040259 * e + 1.0572252 * n), t.alpha) } function Or(t, e, r) { const n = e - t; return t + r * (n > 180 || n < -180 ? n - 360 * Math.round(n / 360) : n) } const qr = { forward: $r, reverse: Ur, interpolate: function(t, e, r) { return { l: Mr(t.l, e.l, r), a: Mr(t.a, e.a, r), b: Mr(t.b, e.b, r), alpha: Mr(t.alpha, e.alpha, r) } } }, Nr = { forward: function(t) { const { l: e, a: r, b: n } = $r(t), i = Math.atan2(n, r) * Vr; return { h: i < 0 ? i + 360 : i, c: Math.sqrt(r * r + n * n), l: e, alpha: t.a } }, reverse: function(t) { const e = t.h * Dr, r = t.c; return Ur({ l: t.l, a: Math.cos(e) * r, b: Math.sin(e) * r, alpha: t.alpha }) }, interpolate: function(t, e, r) { return { h: Or(t.h, e.h, r), c: Mr(t.c, e.c, r), l: Mr(t.l, e.l, r), alpha: Mr(t.alpha, e.alpha, r) } } }; var Gr = Object.freeze({ __proto__: null, lab: qr, hcl: Nr }); class Zr { constructor(t, e, r, n, i) { this.type = t, this.operator = e, this.interpolation = r, this.input = n, this.labels = [], this.outputs = []; for (const [t, e] of i) this.labels.push(t), this.outputs.push(e); } static interpolationFactor(t, e, r, n) { let i = 0; if ("exponential" === t.name) i = Xr(e, t.base, r, n); else if ("linear" === t.name) i = Xr(e, 1, r, n); else if ("cubic-bezier" === t.name) { const s = t.controlPoints; i = new p(s[0], s[1], s[2], s[3]).solve(Xr(e, 1, r, n)); } return i } static parse(t, e) { let [r, n, i, ...s] = t; if (!Array.isArray(n) || 0 === n.length) return e.error("Expected an interpolation type expression.", 1); if ("linear" === n[0]) n = { name: "linear" }; else if ("exponential" === n[0]) { const t = n[1]; if ("number" != typeof t) return e.error("Exponential interpolation requires a numeric base.", 1, 1); n = { name: "exponential", base: t }; } else { if ("cubic-bezier" !== n[0]) return e.error(`Unknown interpolation type ${String(n[0])}`, 1, 0); { const t = n.slice(1); if (4 !== t.length || t.some((t => "number" != typeof t || t < 0 || t > 1))) return e.error("Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.", 1); n = { name: "cubic-bezier", controlPoints: t }; } } if (t.length - 1 < 4) return e.error(`Expected at least 4 arguments, but found only ${t.length-1}.`); if ((t.length - 1) % 2 != 0) return e.error("Expected an even number of arguments."); if (i = e.parse(i, 2, se), !i) return null; const a = []; let o = null; "interpolate-hcl" === r || "interpolate-lab" === r ? o = le : e.expectedType && "value" !== e.expectedType.kind && (o = e.expectedType); for (let t = 0; t < s.length; t += 2) { const r = s[t], n = s[t + 1], i = t + 3, l = t + 4; if ("number" != typeof r) return e.error('Input/output pairs for "interpolate" expressions must be defined using literal numeric values (not computed expressions) for the input values.', i); if (a.length && a[a.length - 1][0] >= r) return e.error('Input/output pairs for "interpolate" expressions must be arranged with input values in strictly ascending order.', i); const u = e.parse(n, l, o); if (!u) return null; o = o || u.type, a.push([r, u]); } return "number" === o.kind || "color" === o.kind || "array" === o.kind && "number" === o.itemType.kind && "number" == typeof o.N ? new Zr(o, r, n, i, a) : e.error(`Type ${ye(o)} is not interpolatable.`) } evaluate(t) { const e = this.labels, r = this.outputs; if (1 === e.length) return r[0].evaluate(t); const n = this.input.evaluate(t); if (n <= e[0]) return r[0].evaluate(t); const i = e.length; if (n >= e[i - 1]) return r[i - 1].evaluate(t); const s = Sr(e, n), a = Zr.interpolationFactor(this.interpolation, n, e[s], e[s + 1]), o = r[s].evaluate(t), l = r[s + 1].evaluate(t); return "interpolate" === this.operator ? Tr[this.type.kind.toLowerCase()](o, l, a) : "interpolate-hcl" === this.operator ? Nr.reverse(Nr.interpolate(Nr.forward(o), Nr.forward(l), a)) : qr.reverse(qr.interpolate(qr.forward(o), qr.forward(l), a)) } eachChild(t) { t(this.input); for (const e of this.outputs) t(e); } outputDefined() { return this.outputs.every((t => t.outputDefined())) } serialize() { let t; t = "linear" === this.interpolation.name ? ["linear"] : "exponential" === this.interpolation.name ? 1 === this.interpolation.base ? ["linear"] : ["exponential", this.interpolation.base] : ["cubic-bezier"].concat(this.interpolation.controlPoints); const e = [this.operator, t, this.input.serialize()]; for (let t = 0; t < this.labels.length; t++) e.push(this.labels[t], this.outputs[t].serialize()); return e } } function Xr(t, e, r, n) { const i = n - r, s = t - r; return 0 === i ? 0 : 1 === e ? s / i : (Math.pow(e, s) - 1) / (Math.pow(e, i) - 1) } var Kr = Zr; class Yr { constructor(t, e) { this.type = t, this.args = e; } static parse(t, e) { if (t.length < 2) return e.error("Expectected at least one argument."); let r = null; const n = e.expectedType; n && "value" !== n.kind && (r = n); const i = []; for (const n of t.slice(1)) { const t = e.parse(n, 1 + i.length, r, void 0, { typeAnnotation: "omit" }); if (!t) return null; r = r || t.type, i.push(t); } const s = n && i.some((t => ge(n, t.type))); return new Yr(s ? ce : r, i) } evaluate(t) { let e, r = null, n = 0; for (const i of this.args) { if (n++, r = i.evaluate(t), r && r instanceof Ee && !r.available && (e || (e = r), r = null, n === this.args.length)) return e; if (null !== r) break } return r } eachChild(t) { this.args.forEach(t); } outputDefined() { return this.args.every((t => t.outputDefined())) } serialize() { const t = ["coalesce"]; return this.eachChild((e => { t.push(e.serialize()); })), t } } var Hr = Yr; class Wr { constructor(t, e) { this.type = e.type, this.bindings = [].concat(t), this.result = e; } evaluate(t) { return this.result.evaluate(t) } eachChild(t) { for (const e of this.bindings) t(e[1]); t(this.result); } static parse(t, e) { if (t.length < 4) return e.error(`Expected at least 3 arguments, but found ${t.length-1} instead.`); const r = []; for (let n = 1; n < t.length - 1; n += 2) { const i = t[n]; if ("string" != typeof i) return e.error(`Expected string, but found ${typeof i} instead.`, n); if (/[^a-zA-Z0-9_]/.test(i)) return e.error("Variable names must contain only alphanumeric characters or '_'.", n); const s = e.parse(t[n + 1], n + 1); if (!s) return null; r.push([i, s]); } const n = e.parse(t[t.length - 1], t.length - 1, e.expectedType, r); return n ? new Wr(r, n) : null } outputDefined() { return this.result.outputDefined() } serialize() { const t = ["let"]; for (const [e, r] of this.bindings) t.push(e, r.serialize()); return t.push(this.result.serialize()), t } } var Jr = Wr; class Qr { constructor(t, e, r) { this.type = t, this.index = e, this.input = r; } static parse(t, e) { if (3 !== t.length) return e.error(`Expected 2 arguments, but found ${t.length-1} instead.`); const r = e.parse(t[1], 1, se), n = e.parse(t[2], 2, de(e.expectedType || ce)); return r && n ? new Qr(n.type.itemType, r, n) : null } evaluate(t) { const e = this.index.evaluate(t), r = this.input.evaluate(t); if (e < 0) throw new Re(`Array index out of bounds: ${e} < 0.`); if (e >= r.length) throw new Re(`Array index out of bounds: ${e} > ${r.length-1}.`); if (e !== Math.floor(e)) throw new Re(`Array index must be an integer, but found ${e} instead.`); return r[e] } eachChild(t) { t(this.index), t(this.input); } outputDefined() { return !1 } serialize() { return ["at", this.index.serialize(), this.input.serialize()] } } var tn = Qr; class en { constructor(t, e) { this.type = oe, this.needle = t, this.haystack = e; } static parse(t, e) { if (3 !== t.length) return e.error(`Expected 2 arguments, but found ${t.length-1} instead.`); const r = e.parse(t[1], 1, ce), n = e.parse(t[2], 2, ce); return r && n ? xe(r.type, [oe, ae, se, ie, ce]) ? new en(r, n) : e.error(`Expected first argument to be of type boolean, string, number or null, but found ${ye(r.type)} instead`) : null } evaluate(t) { const e = this.needle.evaluate(t), r = this.haystack.evaluate(t); if (null == r) return !1; if (!ve(e, ["boolean", "string", "number", "null"])) throw new Re(`Expected first argument to be of type boolean, string, number or null, but found ${ye(De(e))} instead.`); if (!ve(r, ["string", "array"])) throw new Re(`Expected second argument to be of type array or string, but found ${ye(De(r))} instead.`); return r.indexOf(e) >= 0 } eachChild(t) { t(this.needle), t(this.haystack); } outputDefined() { return !0 } serialize() { return ["in", this.needle.serialize(), this.haystack.serialize()] } } var rn = en; class nn { constructor(t, e, r) { this.type = se, this.needle = t, this.haystack = e, this.fromIndex = r; } static parse(t, e) { if (t.length <= 2 || t.length >= 5) return e.error(`Expected 3 or 4 arguments, but found ${t.length-1} instead.`); const r = e.parse(t[1], 1, ce), n = e.parse(t[2], 2, ce); if (!r || !n) return null; if (!xe(r.type, [oe, ae, se, ie, ce])) return e.error(`Expected first argument to be of type boolean, string, number or null, but found ${ye(r.type)} instead`); if (4 === t.length) { const i = e.parse(t[3], 3, se); return i ? new nn(r, n, i) : null } return new nn(r, n) } evaluate(t) { const e = this.needle.evaluate(t), r = this.haystack.evaluate(t); if (!ve(e, ["boolean", "string", "number", "null"])) throw new Re(`Expected first argument to be of type boolean, string, number or null, but found ${ye(De(e))} instead.`); if (!ve(r, ["string", "array"])) throw new Re(`Expected second argument to be of type array or string, but found ${ye(De(r))} instead.`); if (this.fromIndex) { const n = this.fromIndex.evaluate(t); return r.indexOf(e, n) } return r.indexOf(e) } eachChild(t) { t(this.needle), t(this.haystack), this.fromIndex && t(this.fromIndex); } outputDefined() { return !1 } serialize() { if (null != this.fromIndex && void 0 !== this.fromIndex) { const t = this.fromIndex.serialize(); return ["index-of", this.needle.serialize(), this.haystack.serialize(), t] } return ["index-of", this.needle.serialize(), this.haystack.serialize()] } } var sn = nn; class an { constructor(t, e, r, n, i, s) { this.inputType = t, this.type = e, this.input = r, this.cases = n, this.outputs = i, this.otherwise = s; } static parse(t, e) { if (t.length < 5) return e.error(`Expected at least 4 arguments, but found only ${t.length-1}.`); if (t.length % 2 != 1) return e.error("Expected an even number of arguments."); let r, n; e.expectedType && "value" !== e.expectedType.kind && (n = e.expectedType); const i = {}, s = []; for (let a = 2; a < t.length - 1; a += 2) { let o = t[a]; const l = t[a + 1]; Array.isArray(o) || (o = [o]); const u = e.concat(a); if (0 === o.length) return u.error("Expected at least one branch label."); for (const t of o) { if ("number" != typeof t && "string" != typeof t) return u.error("Branch labels must be numbers or strings."); if ("number" == typeof t && Math.abs(t) > Number.MAX_SAFE_INTEGER) return u.error(`Branch labels must be integers no larger than ${Number.MAX_SAFE_INTEGER}.`); if ("number" == typeof t && Math.floor(t) !== t) return u.error("Numeric branch labels must be integer values."); if (r) { if (u.checkSubtype(r, De(t))) return null } else r = De(t); if (void 0 !== i[String(t)]) return u.error("Branch labels must be unique."); i[String(t)] = s.length; } const c = e.parse(l, a, n); if (!c) return null; n = n || c.type, s.push(c); } const a = e.parse(t[1], 1, ce); if (!a) return null; const o = e.parse(t[t.length - 1], t.length - 1, n); return o ? "value" !== a.type.kind && e.concat(1).checkSubtype(r, a.type) ? null : new an(r, n, a, i, s, o) : null } evaluate(t) { const e = this.input.evaluate(t); return (De(e) === this.inputType && this.outputs[this.cases[e]] || this.otherwise).evaluate(t) } eachChild(t) { t(this.input), this.outputs.forEach(t), t(this.otherwise); } outputDefined() { return this.outputs.every((t => t.outputDefined())) && this.otherwise.outputDefined() } serialize() { const t = ["match", this.input.serialize()], e = Object.keys(this.cases).sort(), r = [], n = {}; for (const t of e) { const e = n[this.cases[t]]; void 0 === e ? (n[this.cases[t]] = r.length, r.push([this.cases[t], [t] ])) : r[e][1].push(t); } const i = t => "number" === this.inputType.kind ? Number(t) : t; for (const [e, n] of r) t.push(1 === n.length ? i(n[0]) : n.map(i)), t.push(this.outputs[e].serialize()); return t.push(this.otherwise.serialize()), t } } var on = an; class ln { constructor(t, e, r) { this.type = t, this.branches = e, this.otherwise = r; } static parse(t, e) { if (t.length < 4) return e.error(`Expected at least 3 arguments, but found only ${t.length-1}.`); if (t.length % 2 != 0) return e.error("Expected an odd number of arguments."); let r; e.expectedType && "value" !== e.expectedType.kind && (r = e.expectedType); const n = []; for (let i = 1; i < t.length - 1; i += 2) { const s = e.parse(t[i], i, oe); if (!s) return null; const a = e.parse(t[i + 1], i + 1, r); if (!a) return null; n.push([s, a]), r = r || a.type; } const i = e.parse(t[t.length - 1], t.length - 1, r); return i ? new ln(r, n, i) : null } evaluate(t) { for (const [e, r] of this.branches) if (e.evaluate(t)) return r.evaluate(t); return this.otherwise.evaluate(t) } eachChild(t) { for (const [e, r] of this.branches) t(e), t(r); t(this.otherwise); } outputDefined() { return this.branches.every((([t, e]) => e.outputDefined())) && this.otherwise.outputDefined() } serialize() { const t = ["case"]; return this.eachChild((e => { t.push(e.serialize()); })), t } } var un = ln; class cn { constructor(t, e, r, n) { this.type = t, this.input = e, this.beginIndex = r, this.endIndex = n; } static parse(t, e) { if (t.length <= 2 || t.length >= 5) return e.error(`Expected 3 or 4 arguments, but found ${t.length-1} instead.`); const r = e.parse(t[1], 1, ce), n = e.parse(t[2], 2, se); if (!r || !n) return null; if (!xe(r.type, [de(ce), ae, ce])) return e.error(`Expected first argument to be of type array or string, but found ${ye(r.type)} instead`); if (4 === t.length) { const i = e.parse(t[3], 3, se); return i ? new cn(r.type, r, n, i) : null } return new cn(r.type, r, n) } evaluate(t) { const e = this.input.evaluate(t), r = this.beginIndex.evaluate(t); if (!ve(e, ["string", "array"])) throw new Re(`Expected first argument to be of type array or string, but found ${ye(De(e))} instead.`); if (this.endIndex) { const n = this.endIndex.evaluate(t); return e.slice(r, n) } return e.slice(r) } eachChild(t) { t(this.input), t(this.beginIndex), this.endIndex && t(this.endIndex); } outputDefined() { return !1 } serialize() { if (null != this.endIndex && void 0 !== this.endIndex) { const t = this.endIndex.serialize(); return ["slice", this.input.serialize(), this.beginIndex.serialize(), t] } return ["slice", this.input.serialize(), this.beginIndex.serialize()] } } var hn = cn; function pn(t, e) { return "==" === t || "!=" === t ? "boolean" === e.kind || "string" === e.kind || "number" === e.kind || "null" === e.kind || "value" === e.kind : "string" === e.kind || "number" === e.kind || "value" === e.kind } function fn(t, e, r, n) { return 0 === n.compare(e, r) } function dn(t, e, r) { const n = "==" !== t && "!=" !== t; return class i { constructor(t, e, r) { this.type = oe, this.lhs = t, this.rhs = e, this.collator = r, this.hasUntypedArgument = "value" === t.type.kind || "value" === e.type.kind; } static parse(t, e) { if (3 !== t.length && 4 !== t.length) return e.error("Expected two or three arguments."); const r = t[0]; let s = e.parse(t[1], 1, ce); if (!s) return null; if (!pn(r, s.type)) return e.concat(1).error(`"${r}" comparisons are not supported for type '${ye(s.type)}'.`); let a = e.parse(t[2], 2, ce); if (!a) return null; if (!pn(r, a.type)) return e.concat(2).error(`"${r}" comparisons are not supported for type '${ye(a.type)}'.`); if (s.type.kind !== a.type.kind && "value" !== s.type.kind && "value" !== a.type.kind) return e.error(`Cannot compare types '${ye(s.type)}' and '${ye(a.type)}'.`); n && ("value" === s.type.kind && "value" !== a.type.kind ? s = new Ue(a.type, [s]) : "value" !== s.type.kind && "value" === a.type.kind && (a = new Ue(s.type, [a]))); let o = null; if (4 === t.length) { if ("string" !== s.type.kind && "string" !== a.type.kind && "value" !== s.type.kind && "value" !== a.type.kind) return e.error("Cannot use collator to compare non-string types."); if (o = e.parse(t[3], 3, he), !o) return null } return new i(s, a, o) } evaluate(i) { const s = this.lhs.evaluate(i), a = this.rhs.evaluate(i); if (n && this.hasUntypedArgument) { const e = De(s), r = De(a); if (e.kind !== r.kind || "string" !== e.kind && "number" !== e.kind) throw new Re(`Expected arguments for "${t}" to be (string, string) or (number, number), but found (${e.kind}, ${r.kind}) instead.`) } if (this.collator && !n && this.hasUntypedArgument) { const t = De(s), r = De(a); if ("string" !== t.kind || "string" !== r.kind) return e(i, s, a) } return this.collator ? r(i, s, a, this.collator.evaluate(i)) : e(i, s, a) } eachChild(t) { t(this.lhs), t(this.rhs), this.collator && t(this.collator); } outputDefined() { return !0 } serialize() { const e = [t]; return this.eachChild((t => { e.push(t.serialize()); })), e } } } const yn = dn("==", (function(t, e, r) { return e === r }), fn), mn = dn("!=", (function(t, e, r) { return e !== r }), (function(t, e, r, n) { return !fn(0, e, r, n) })), gn = dn("<", (function(t, e, r) { return e < r }), (function(t, e, r, n) { return n.compare(e, r) < 0 })), xn = dn(">", (function(t, e, r) { return e > r }), (function(t, e, r, n) { return n.compare(e, r) > 0 })), vn = dn("<=", (function(t, e, r) { return e <= r }), (function(t, e, r, n) { return n.compare(e, r) <= 0 })), bn = dn(">=", (function(t, e, r) { return e >= r }), (function(t, e, r, n) { return n.compare(e, r) >= 0 })); class wn { constructor(t, e, r, n, i, s) { this.type = ae, this.number = t, this.locale = e, this.currency = r, this.unit = n, this.minFractionDigits = i, this.maxFractionDigits = s; } static parse(t, e) { if (3 !== t.length) return e.error("Expected two arguments."); const r = e.parse(t[1], 1, se); if (!r) return null; const n = t[2]; if ("object" != typeof n || Array.isArray(n)) return e.error("NumberFormat options argument must be an object."); let i = null; if (n.locale && (i = e.parse(n.locale, 1, ae), !i)) return null; let s = null; if (n.currency && (s = e.parse(n.currency, 1, ae), !s)) return null; let a = null; if (n.unit && (a = e.parse(n.unit, 1, ae), !a)) return null; let o = null; if (n["min-fraction-digits"] && (o = e.parse(n["min-fraction-digits"], 1, se), !o)) return null; let l = null; return n["max-fraction-digits"] && (l = e.parse(n["max-fraction-digits"], 1, se), !l) ? null : new wn(r, i, s, a, o, l) } evaluate(t) { return new Intl.NumberFormat(this.locale ? this.locale.evaluate(t) : [], { style: (this.currency ? "currency" : this.unit && "unit") || "decimal", currency: this.currency ? this.currency.evaluate(t) : void 0, unit: this.unit ? this.unit.evaluate(t) : void 0, minimumFractionDigits: this.minFractionDigits ? this.minFractionDigits.evaluate(t) : void 0, maximumFractionDigits: this.maxFractionDigits ? this.maxFractionDigits.evaluate(t) : void 0 }).format(this.number.evaluate(t)) } eachChild(t) { t(this.number), this.locale && t(this.locale), this.currency && t(this.currency), this.unit && t(this.unit), this.minFractionDigits && t(this.minFractionDigits), this.maxFractionDigits && t(this.maxFractionDigits); } outputDefined() { return !1 } serialize() { const t = {}; return this.locale && (t.locale = this.locale.serialize()), this.currency && (t.currency = this.currency.serialize()), this.unit && (t.unit = this.unit.serialize()), this.minFractionDigits && (t["min-fraction-digits"] = this.minFractionDigits.serialize()), this.maxFractionDigits && (t["max-fraction-digits"] = this.maxFractionDigits.serialize()), ["number-format", this.number.serialize(), t] } } class _n { constructor(t) { this.type = se, this.input = t; } static parse(t, e) { if (2 !== t.length) return e.error(`Expected 1 argument, but found ${t.length-1} instead.`); const r = e.parse(t[1], 1); return r ? "array" !== r.type.kind && "string" !== r.type.kind && "value" !== r.type.kind ? e.error(`Expected argument of type string or array, but found ${ye(r.type)} instead.`) : new _n(r) : null } evaluate(t) { const e = this.input.evaluate(t); if ("string" == typeof e) return e.length; if (Array.isArray(e)) return e.length; throw new Re(`Expected value to be of type string or array, but found ${ye(De(e))} instead.`) } eachChild(t) { t(this.input); } outputDefined() { return !1 } serialize() { const t = ["length"]; return this.eachChild((e => { t.push(e.serialize()); })), t } } const An = { "==": yn, "!=": mn, ">": xn, "<": gn, ">=": bn, "<=": vn, array: Ue, at: tn, boolean: Ue, case: un, coalesce: Hr, collator: We, format: Oe, image: qe, in: rn, "index-of": sn, interpolate: Kr, "interpolate-hcl": Kr, "interpolate-lab": Kr, length: _n, let: Jr, literal: Fe, match: on, number: Ue, "number-format": wn, object: Ue, slice: hn, step: Ir, string: Ue, "to-boolean": Ze, "to-color": Ze, "to-number": Ze, "to-string": Ze, var: br, within: yr }; function Sn(t, [e, r, n, i]) { e = e.evaluate(t), r = r.evaluate(t), n = n.evaluate(t); const s = i ? i.evaluate(t) : 1, a = Ce(e, r, n, s); if (a) throw new Re(a); return new Me(e / 255 * s, r / 255 * s, n / 255 * s, s) } function kn(t, e) { return t in e } function In(t, e) { const r = e[t]; return void 0 === r ? null : r } function Mn(t) { return { type: t } } He.register(An, { error: [{ kind: "error" }, [ae], (t, [e]) => { throw new Re(e.evaluate(t)) } ], typeof: [ae, [ce], (t, [e]) => ye(De(e.evaluate(t)))], "to-rgba": [de(se, 4), [le], (t, [e]) => e.evaluate(t).toArray()], rgb: [le, [se, se, se], Sn], rgba: [le, [se, se, se, se], Sn], has: { type: oe, overloads: [ [ [ae], (t, [e]) => kn(e.evaluate(t), t.properties()) ], [ [ae, ue], (t, [e, r]) => kn(e.evaluate(t), r.evaluate(t)) ] ] }, get: { type: ce, overloads: [ [ [ae], (t, [e]) => In(e.evaluate(t), t.properties()) ], [ [ae, ue], (t, [e, r]) => In(e.evaluate(t), r.evaluate(t)) ] ] }, "feature-state": [ce, [ae], (t, [e]) => In(e.evaluate(t), t.featureState || {})], properties: [ue, [], t => t.properties()], "geometry-type": [ae, [], t => t.geometryType()], id: [ce, [], t => t.id()], zoom: [se, [], t => t.globals.zoom], pitch: [se, [], t => t.globals.pitch || 0], "distance-from-center": [se, [], t => t.distanceFromCenter()], "heatmap-density": [se, [], t => t.globals.heatmapDensity || 0], "line-progress": [se, [], t => t.globals.lineProgress || 0], "sky-radial-progress": [se, [], t => t.globals.skyRadialProgress || 0], accumulated: [ce, [], t => void 0 === t.globals.accumulated ? null : t.globals.accumulated], "+": [se, Mn(se), (t, e) => { let r = 0; for (const n of e) r += n.evaluate(t); return r }], "*": [se, Mn(se), (t, e) => { let r = 1; for (const n of e) r *= n.evaluate(t); return r }], "-": { type: se, overloads: [ [ [se, se], (t, [e, r]) => e.evaluate(t) - r.evaluate(t) ], [ [se], (t, [e]) => -e.evaluate(t) ] ] }, "/": [se, [se, se], (t, [e, r]) => e.evaluate(t) / r.evaluate(t)], "%": [se, [se, se], (t, [e, r]) => e.evaluate(t) % r.evaluate(t)], ln2: [se, [], () => Math.LN2], pi: [se, [], () => Math.PI], e: [se, [], () => Math.E], "^": [se, [se, se], (t, [e, r]) => Math.pow(e.evaluate(t), r.evaluate(t))], sqrt: [se, [se], (t, [e]) => Math.sqrt(e.evaluate(t))], log10: [se, [se], (t, [e]) => Math.log(e.evaluate(t)) / Math.LN10], ln: [se, [se], (t, [e]) => Math.log(e.evaluate(t))], log2: [se, [se], (t, [e]) => Math.log(e.evaluate(t)) / Math.LN2], sin: [se, [se], (t, [e]) => Math.sin(e.evaluate(t))], cos: [se, [se], (t, [e]) => Math.cos(e.evaluate(t))], tan: [se, [se], (t, [e]) => Math.tan(e.evaluate(t))], asin: [se, [se], (t, [e]) => Math.asin(e.evaluate(t))], acos: [se, [se], (t, [e]) => Math.acos(e.evaluate(t))], atan: [se, [se], (t, [e]) => Math.atan(e.evaluate(t))], min: [se, Mn(se), (t, e) => Math.min(...e.map((e => e.evaluate(t))))], max: [se, Mn(se), (t, e) => Math.max(...e.map((e => e.evaluate(t))))], abs: [se, [se], (t, [e]) => Math.abs(e.evaluate(t))], round: [se, [se], (t, [e]) => { const r = e.evaluate(t); return r < 0 ? -Math.round(-r) : Math.round(r) }], floor: [se, [se], (t, [e]) => Math.floor(e.evaluate(t))], ceil: [se, [se], (t, [e]) => Math.ceil(e.evaluate(t))], "filter-==": [oe, [ae, ce], (t, [e, r]) => t.properties()[e.value] === r.value], "filter-id-==": [oe, [ce], (t, [e]) => t.id() === e.value], "filter-type-==": [oe, [ae], (t, [e]) => t.geometryType() === e.value], "filter-<": [oe, [ae, ce], (t, [e, r]) => { const n = t.properties()[e.value], i = r.value; return typeof n == typeof i && n < i }], "filter-id-<": [oe, [ce], (t, [e]) => { const r = t.id(), n = e.value; return typeof r == typeof n && r < n }], "filter->": [oe, [ae, ce], (t, [e, r]) => { const n = t.properties()[e.value], i = r.value; return typeof n == typeof i && n > i }], "filter-id->": [oe, [ce], (t, [e]) => { const r = t.id(), n = e.value; return typeof r == typeof n && r > n }], "filter-<=": [oe, [ae, ce], (t, [e, r]) => { const n = t.properties()[e.value], i = r.value; return typeof n == typeof i && n <= i }], "filter-id-<=": [oe, [ce], (t, [e]) => { const r = t.id(), n = e.value; return typeof r == typeof n && r <= n }], "filter->=": [oe, [ae, ce], (t, [e, r]) => { const n = t.properties()[e.value], i = r.value; return typeof n == typeof i && n >= i }], "filter-id->=": [oe, [ce], (t, [e]) => { const r = t.id(), n = e.value; return typeof r == typeof n && r >= n }], "filter-has": [oe, [ce], (t, [e]) => e.value in t.properties()], "filter-has-id": [oe, [], t => null !== t.id() && void 0 !== t.id()], "filter-type-in": [oe, [de(ae)], (t, [e]) => e.value.indexOf(t.geometryType()) >= 0], "filter-id-in": [oe, [de(ce)], (t, [e]) => e.value.indexOf(t.id()) >= 0], "filter-in-small": [oe, [ae, de(ce)], (t, [e, r]) => r.value.indexOf(t.properties()[e.value]) >= 0], "filter-in-large": [oe, [ae, de(ce)], (t, [e, r]) => function(t, e, r, n) { for (; r <= n;) { const i = r + n >> 1; if (e[i] === t) return !0; e[i] > t ? n = i - 1 : r = i + 1; } return !1 }(t.properties()[e.value], r.value, 0, r.value.length - 1)], all: { type: oe, overloads: [ [ [oe, oe], (t, [e, r]) => e.evaluate(t) && r.evaluate(t) ], [Mn(oe), (t, e) => { for (const r of e) if (!r.evaluate(t)) return !1; return !0 }] ] }, any: { type: oe, overloads: [ [ [oe, oe], (t, [e, r]) => e.evaluate(t) || r.evaluate(t) ], [Mn(oe), (t, e) => { for (const r of e) if (r.evaluate(t)) return !0; return !1 }] ] }, "!": [oe, [oe], (t, [e]) => !e.evaluate(t)], "is-supported-script": [oe, [ae], (t, [e]) => { const r = t.globals && t.globals.isSupportedScript; return !r || r(e.evaluate(t)) }], upcase: [ae, [ae], (t, [e]) => e.evaluate(t).toUpperCase()], downcase: [ae, [ae], (t, [e]) => e.evaluate(t).toLowerCase()], concat: [ae, Mn(ce), (t, e) => e.map((e => Ve(e.evaluate(t)))).join("")], "resolved-locale": [ae, [he], (t, [e]) => e.evaluate(t).resolvedLocale()] }); var Tn = An; function zn(t) { return { result: "success", value: t } } function Bn(t) { return { result: "error", value: t } } function En(t) { return "data-driven" === t["property-type"] } function Cn(t) { return !!t.expression && t.expression.parameters.indexOf("zoom") > -1 } function Pn(t) { return !!t.expression && t.expression.interpolated } function Dn(t) { return t instanceof Number ? "number" : t instanceof String ? "string" : t instanceof Boolean ? "boolean" : Array.isArray(t) ? "array" : null === t ? "null" : typeof t } function Vn(t) { return "object" == typeof t && null !== t && !Array.isArray(t) } function Ln(t) { return t } function Fn(t, e) { const r = "color" === e.type, n = t.stops && "object" == typeof t.stops[0][0], i = n || !(n || void 0 !== t.property), s = t.type || (Pn(e) ? "exponential" : "interval"); if (r && ((t = Wt({}, t)).stops && (t.stops = t.stops.map((t => [t[0], Me.parse(t[1])]))), t.default = Me.parse(t.default ? t.default : e.default)), t.colorSpace && "rgb" !== t.colorSpace && !Gr[t.colorSpace]) throw new Error(`Unknown color space: ${t.colorSpace}`); let a, o, l; if ("exponential" === s) a = Un; else if ("interval" === s) a = $n; else if ("categorical" === s) { a = jn, o = Object.create(null); for (const e of t.stops) o[e[0]] = e[1]; l = typeof t.stops[0][0]; } else { if ("identity" !== s) throw new Error(`Unknown function type "${s}"`); a = On; } if (n) { const r = {}, n = []; for (let e = 0; e < t.stops.length; e++) { const i = t.stops[e], s = i[0].zoom; void 0 === r[s] && (r[s] = { zoom: s, type: t.type, property: t.property, default: t.default, stops: [] }, n.push(s)), r[s].stops.push([i[0].value, i[1]]); } const i = []; for (const t of n) i.push([r[t].zoom, Fn(r[t], e)]); const s = { name: "linear" }; return { kind: "composite", interpolationType: s, interpolationFactor: Kr.interpolationFactor.bind(void 0, s), zoomStops: i.map((t => t[0])), evaluate: ({ zoom: r }, n) => Un({ stops: i, base: t.base }, e, r).evaluate(r, n) } } if (i) { const r = "exponential" === s ? { name: "exponential", base: void 0 !== t.base ? t.base : 1 } : null; return { kind: "camera", interpolationType: r, interpolationFactor: Kr.interpolationFactor.bind(void 0, r), zoomStops: t.stops.map((t => t[0])), evaluate: ({ zoom: r }) => a(t, e, r, o, l) } } return { kind: "source", evaluate(r, n) { const i = n && n.properties ? n.properties[t.property] : void 0; return void 0 === i ? Rn(t.default, e.default) : a(t, e, i, o, l) } } } function Rn(t, e, r) { return void 0 !== t ? t : void 0 !== e ? e : void 0 !== r ? r : void 0 } function jn(t, e, r, n, i) { return Rn(typeof r === i ? n[r] : void 0, t.default, e.default) } function $n(t, e, r) { if ("number" !== Dn(r)) return Rn(t.default, e.default); const n = t.stops.length; if (1 === n) return t.stops[0][1]; if (r <= t.stops[0][0]) return t.stops[0][1]; if (r >= t.stops[n - 1][0]) return t.stops[n - 1][1]; const i = Sr(t.stops.map((t => t[0])), r); return t.stops[i][1] } function Un(t, e, r) { const n = void 0 !== t.base ? t.base : 1; if ("number" !== Dn(r)) return Rn(t.default, e.default); const i = t.stops.length; if (1 === i) return t.stops[0][1]; if (r <= t.stops[0][0]) return t.stops[0][1]; if (r >= t.stops[i - 1][0]) return t.stops[i - 1][1]; const s = Sr(t.stops.map((t => t[0])), r), a = function(t, e, r, n) { const i = n - r, s = t - r; return 0 === i ? 0 : 1 === e ? s / i : (Math.pow(e, s) - 1) / (Math.pow(e, i) - 1) }(r, n, t.stops[s][0], t.stops[s + 1][0]), o = t.stops[s][1], l = t.stops[s + 1][1]; let u = Tr[e.type] || Ln; if (t.colorSpace && "rgb" !== t.colorSpace) { const e = Gr[t.colorSpace]; u = (t, r) => e.reverse(e.interpolate(e.forward(t), e.forward(r), a)); } return "function" == typeof o.evaluate ? { evaluate(...t) { const e = o.evaluate.apply(void 0, t), r = l.evaluate.apply(void 0, t); if (void 0 !== e && void 0 !== r) return u(e, r, a) } } : u(o, l, a) } function On(t, e, r) { return "color" === e.type ? r = Me.parse(r) : "formatted" === e.type ? r = Be.fromString(r.toString()) : "resolvedImage" === e.type ? r = Ee.fromString(r.toString()) : Dn(r) === e.type || "enum" === e.type && e.values[r] || (r = void 0), Rn(r, t.default, e.default) } class qn { constructor(t, e) { this.expression = t, this._warningHistory = {}, this._evaluator = new Ke, this._defaultValue = e ? function(t) { return "color" === t.type && (Vn(t.default) || Array.isArray(t.default)) ? new Me(0, 0, 0, 0) : "color" === t.type ? Me.parse(t.default) || null : void 0 === t.default ? null : t.default }(e) : null, this._enumValues = e && "enum" === e.type ? e.values : null; } evaluateWithoutErrorHandling(t, e, r, n, i, s, a, o) { return this._evaluator.globals = t, this._evaluator.feature = e, this._evaluator.featureState = r, this._evaluator.canonical = n || null, this._evaluator.availableImages = i || null, this._evaluator.formattedSection = s, this._evaluator.featureTileCoord = a || null, this._evaluator.featureDistanceData = o || null, this.expression.evaluate(this._evaluator) } evaluate(t, e, r, n, i, s, a, o) { this._evaluator.globals = t, this._evaluator.feature = e || null, this._evaluator.featureState = r || null, this._evaluator.canonical = n || null, this._evaluator.availableImages = i || null, this._evaluator.formattedSection = s || null, this._evaluator.featureTileCoord = a || null, this._evaluator.featureDistanceData = o || null; try { const t = this.expression.evaluate(this._evaluator); if (null == t || "number" == typeof t && t != t) return this._defaultValue; if (this._enumValues && !(t in this._enumValues)) throw new Re(`Expected value to be one of ${Object.keys(this._enumValues).map((t=>JSON.stringify(t))).join(", ")}, but found ${JSON.stringify(t)} instead.`); return t } catch (t) { return this._warningHistory[t.message] || (this._warningHistory[t.message] = !0, "undefined" != typeof console && console.warn(t.message)), this._defaultValue } } } function Nn(t) { return Array.isArray(t) && t.length > 0 && "string" == typeof t[0] && t[0] in Tn } function Gn(t, e) { const r = new _r(Tn, [], e ? function(t) { const e = { color: le, string: ae, number: se, enum: ae, boolean: oe, formatted: pe, resolvedImage: fe }; return "array" === t.type ? de(e[t.value] || ce, t.length) : e[t.type] }(e) : void 0), n = r.parse(t, void 0, void 0, void 0, e && "string" === e.type ? { typeAnnotation: "coerce" } : void 0); return n ? zn(new qn(n, e)) : Bn(r.errors) } class Zn { constructor(t, e) { this.kind = t, this._styleExpression = e, this.isStateDependent = "constant" !== t && !gr(e.expression); } evaluateWithoutErrorHandling(t, e, r, n, i, s) { return this._styleExpression.evaluateWithoutErrorHandling(t, e, r, n, i, s) } evaluate(t, e, r, n, i, s) { return this._styleExpression.evaluate(t, e, r, n, i, s) } } class Xn { constructor(t, e, r, n) { this.kind = t, this.zoomStops = r, this._styleExpression = e, this.isStateDependent = "camera" !== t && !gr(e.expression), this.interpolationType = n; } evaluateWithoutErrorHandling(t, e, r, n, i, s) { return this._styleExpression.evaluateWithoutErrorHandling(t, e, r, n, i, s) } evaluate(t, e, r, n, i, s) { return this._styleExpression.evaluate(t, e, r, n, i, s) } interpolationFactor(t, e, r) { return this.interpolationType ? Kr.interpolationFactor(this.interpolationType, t, e, r) : 0 } } function Kn(t, e) { if ("error" === (t = Gn(t, e)).result) return t; const r = t.value.expression, n = mr(r); if (!n && !En(e)) return Bn([new ee("", "data expressions not supported")]); const i = xr(r, ["zoom", "pitch", "distance-from-center"]); if (!i && !Cn(e)) return Bn([new ee("", "zoom expressions not supported")]); const s = Hn(r); return s || i ? s instanceof ee ? Bn([s]) : s instanceof Kr && !Pn(e) ? Bn([new ee("", '"interpolate" expressions cannot be used with this property')]) : zn(s ? new Xn(n ? "camera" : "composite", t.value, s.labels, s instanceof Kr ? s.interpolation : void 0) : new Zn(n ? "constant" : "source", t.value)) : Bn([new ee("", '"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.')]) } class Yn { constructor(t, e) { this._parameters = t, this._specification = e, Wt(this, Fn(this._parameters, this._specification)); } static deserialize(t) { return new Yn(t._parameters, t._specification) } static serialize(t) { return { _parameters: t._parameters, _specification: t._specification } } } function Hn(t) { let e = null; if (t instanceof Jr) e = Hn(t.result); else if (t instanceof Hr) { for (const r of t.args) if (e = Hn(r), e) break } else(t instanceof Ir || t instanceof Kr) && t.input instanceof He && "zoom" === t.input.name && (e = t); return e instanceof ee || t.eachChild((t => { const r = Hn(t); r instanceof ee ? e = r : !e && r ? e = new ee("", '"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.') : e && r && e !== r && (e = new ee("", 'Only one zoom-based "step" or "interpolate" subexpression may be used in an expression.')); })), e } class Wn { constructor(t, e, r, n) { this.message = (t ? `${t}: ` : "") + r, n && (this.identifier = n), null != e && e.__line__ && (this.line = e.__line__); } } function Jn(t) { const e = t.key, r = t.value, n = t.valueSpec || {}, i = t.objectElementValidators || {}, s = t.style, a = t.styleSpec; let o = []; const l = Dn(r); if ("object" !== l) return [new Wn(e, r, `object expected, ${l} found`)]; for (const t in r) { const l = t.split(".")[0], u = n[l] || n["*"]; let c; i[l] ? c = i[l] : n[l] ? c = Ci : i["*"] ? c = i["*"] : n["*"] && (c = Ci), c ? o = o.concat(c({ key: (e ? `${e}.` : e) + t, value: r[t], valueSpec: u, style: s, styleSpec: a, object: r, objectKey: t }, r)) : o.push(new Wn(e, r[t], `unknown property "${t}"`)); } for (const t in n) i[t] || n[t].required && void 0 === n[t].default && void 0 === r[t] && o.push(new Wn(e, r, `missing required property "${t}"`)); return o } function Qn(t) { const e = t.value, r = t.valueSpec, n = t.style, i = t.styleSpec, s = t.key, a = t.arrayElementValidator || Ci; if ("array" !== Dn(e)) return [new Wn(s, e, `array expected, ${Dn(e)} found`)]; if (r.length && e.length !== r.length) return [new Wn(s, e, `array length ${r.length} expected, length ${e.length} found`)]; if (r["min-length"] && e.length < r["min-length"]) return [new Wn(s, e, `array length at least ${r["min-length"]} expected, length ${e.length} found`)]; let o = { type: r.value, values: r.values, minimum: r.minimum, maximum: r.maximum, function: void 0 }; i.$version < 7 && (o.function = r.function), "object" === Dn(r.value) && (o = r.value); let l = []; for (let t = 0; t < e.length; t++) l = l.concat(a({ array: e, arrayIndex: t, value: e[t], valueSpec: o, style: n, styleSpec: i, key: `${s}[${t}]` })); return l } function ti(t) { const e = t.key, r = t.value, n = t.valueSpec; let i = Dn(r); if ("number" === i && r != r && (i = "NaN"), "number" !== i) return [new Wn(e, r, `number expected, ${i} found`)]; if ("minimum" in n) { let i = n.minimum; if ("array" === Dn(n.minimum) && (i = n.minimum[t.arrayIndex]), r < i) return [new Wn(e, r, `${r} is less than the minimum value ${i}`)] } if ("maximum" in n) { let i = n.maximum; if ("array" === Dn(n.maximum) && (i = n.maximum[t.arrayIndex]), r > i) return [new Wn(e, r, `${r} is greater than the maximum value ${i}`)] } return [] } function ei(t) { const e = t.valueSpec, r = Jt(t.value.type); let n, i, s, a = {}; const o = "categorical" !== r && void 0 === t.value.property, l = !o, u = "array" === Dn(t.value.stops) && "array" === Dn(t.value.stops[0]) && "object" === Dn(t.value.stops[0][0]), c = Jn({ key: t.key, value: t.value, valueSpec: t.styleSpec.function, style: t.style, styleSpec: t.styleSpec, objectElementValidators: { stops: function(t) { if ("identity" === r) return [new Wn(t.key, t.value, 'identity function may not have a "stops" property')]; let e = []; const n = t.value; return e = e.concat(Qn({ key: t.key, value: n, valueSpec: t.valueSpec, style: t.style, styleSpec: t.styleSpec, arrayElementValidator: h })), "array" === Dn(n) && 0 === n.length && e.push(new Wn(t.key, n, "array must have at least one stop")), e }, default: function(t) { return Ci({ key: t.key, value: t.value, valueSpec: e, style: t.style, styleSpec: t.styleSpec }) } } }); return "identity" === r && o && c.push(new Wn(t.key, t.value, 'missing required property "property"')), "identity" === r || t.value.stops || c.push(new Wn(t.key, t.value, 'missing required property "stops"')), "exponential" === r && t.valueSpec.expression && !Pn(t.valueSpec) && c.push(new Wn(t.key, t.value, "exponential functions not supported")), t.styleSpec.$version >= 8 && (l && !En(t.valueSpec) ? c.push(new Wn(t.key, t.value, "property functions not supported")) : o && !Cn(t.valueSpec) && c.push(new Wn(t.key, t.value, "zoom functions not supported"))), "categorical" !== r && !u || void 0 !== t.value.property || c.push(new Wn(t.key, t.value, '"property" property is required')), c; function h(t) { let r = []; const n = t.value, o = t.key; if ("array" !== Dn(n)) return [new Wn(o, n, `array expected, ${Dn(n)} found`)]; if (2 !== n.length) return [new Wn(o, n, `array length 2 expected, length ${n.length} found`)]; if (u) { if ("object" !== Dn(n[0])) return [new Wn(o, n, `object expected, ${Dn(n[0])} found`)]; if (void 0 === n[0].zoom) return [new Wn(o, n, "object stop key must have zoom")]; if (void 0 === n[0].value) return [new Wn(o, n, "object stop key must have value")]; const e = Jt(n[0].zoom); if ("number" != typeof e) return [new Wn(o, n[0].zoom, "stop zoom values must be numbers")]; if (s && s > e) return [new Wn(o, n[0].zoom, "stop zoom values must appear in ascending order")]; e !== s && (s = e, i = void 0, a = {}), r = r.concat(Jn({ key: `${o}[0]`, value: n[0], valueSpec: { zoom: {} }, style: t.style, styleSpec: t.styleSpec, objectElementValidators: { zoom: ti, value: p } })); } else r = r.concat(p({ key: `${o}[0]`, value: n[0], valueSpec: {}, style: t.style, styleSpec: t.styleSpec }, n)); return Nn(Qt(n[1])) ? r.concat([new Wn(`${o}[1]`, n[1], "expressions are not allowed in function stops.")]) : r.concat(Ci({ key: `${o}[1]`, value: n[1], valueSpec: e, style: t.style, styleSpec: t.styleSpec })) } function p(t, s) { const o = Dn(t.value), l = Jt(t.value), u = null !== t.value ? t.value : s; if (n) { if (o !== n) return [new Wn(t.key, u, `${o} stop domain type must match previous stop domain type ${n}`)] } else n = o; if ("number" !== o && "string" !== o && "boolean" !== o && "number" != typeof l && "string" != typeof l && "boolean" != typeof l) return [new Wn(t.key, u, "stop domain value must be a number, string, or boolean")]; if ("number" !== o && "categorical" !== r) { let n = `number expected, ${o} found`; return En(e) && void 0 === r && (n += '\nIf you intended to use a categorical function, specify `"type": "categorical"`.'), [new Wn(t.key, u, n)] } return "categorical" !== r || "number" !== o || "number" == typeof l && isFinite(l) && Math.floor(l) === l ? "categorical" !== r && "number" === o && "number" == typeof l && "number" == typeof i && void 0 !== i && l < i ? [new Wn(t.key, u, "stop domain values must appear in ascending order")] : (i = l, "categorical" === r && l in a ? [new Wn(t.key, u, "stop domain values must be unique")] : (a[l] = !0, [])) : [new Wn(t.key, u, `integer expected, found ${String(l)}`)] } } function ri(t) { const e = ("property" === t.expressionContext ? Kn : Gn)(Qt(t.value), t.valueSpec); if ("error" === e.result) return e.value.map((e => new Wn(`${t.key}${e.key}`, t.value, e.message))); const r = e.value.expression || e.value._styleExpression.expression; if ("property" === t.expressionContext && "text-font" === t.propertyKey && !r.outputDefined()) return [new Wn(t.key, t.value, `Invalid data expression for "${t.propertyKey}". Output values must be contained as literals within the expression.`)]; if ("property" === t.expressionContext && "layout" === t.propertyType && !gr(r)) return [new Wn(t.key, t.value, '"feature-state" data expressions are not supported with layout properties.')]; if ("filter" === t.expressionContext) return ni(r, t); if (t.expressionContext && 0 === t.expressionContext.indexOf("cluster")) { if (!xr(r, ["zoom", "feature-state"])) return [new Wn(t.key, t.value, '"zoom" and "feature-state" expressions are not supported with cluster properties.')]; if ("cluster-initial" === t.expressionContext && !mr(r)) return [new Wn(t.key, t.value, "Feature data expressions are not supported with initial expression part of cluster properties.")] } return [] } function ni(t, e) { const r = new Set(["zoom", "feature-state", "pitch", "distance-from-center"]); if (e.valueSpec && e.valueSpec.expression) for (const t of e.valueSpec.expression.parameters) r.delete(t); if (0 === r.size) return []; const n = []; return t instanceof He && r.has(t.name) ? [new Wn(e.key, e.value, `["${t.name}"] expression is not supported in a filter for a ${e.object.type} layer with id: ${e.object.id}`)] : (t.eachChild((t => { n.push(...ni(t, e)); })), n) } function ii(t) { const e = t.key, r = t.value, n = t.valueSpec, i = []; return Array.isArray(n.values) ? -1 === n.values.indexOf(Jt(r)) && i.push(new Wn(e, r, `expected one of [${n.values.join(", ")}], ${JSON.stringify(r)} found`)) : -1 === Object.keys(n.values).indexOf(Jt(r)) && i.push(new Wn(e, r, `expected one of [${Object.keys(n.values).join(", ")}], ${JSON.stringify(r)} found`)), i } function si(t) { if (!0 === t || !1 === t) return !0; if (!Array.isArray(t) || 0 === t.length) return !1; switch (t[0]) { case "has": return t.length >= 2 && "$id" !== t[1] && "$type" !== t[1]; case "in": return t.length >= 3 && ("string" != typeof t[1] || Array.isArray(t[2])); case "!in": case "!has": case "none": return !1; case "==": case "!=": case ">": case ">=": case "<": case "<=": return 3 !== t.length || Array.isArray(t[1]) || Array.isArray(t[2]); case "any": case "all": for (const e of t.slice(1)) if (!si(e) && "boolean" != typeof e) return !1; return !0; default: return !0 } } function ai(t, e = "fill") { if (null == t) return { filter: () => !0, needGeometry: !1, needFeature: !1 }; si(t) || (t = fi(t)); const r = t; let n = !0; try { n = function(t) { if (!ui(t)) return t; let e = Qt(t); return li(e), e = oi(e), e }(r); } catch (t) { console.warn(`Failed to extract static filter. Filter will continue working, but at higher memory usage and slower framerate.\nThis is most likely a bug, please report this via https://github.com/mapbox/mapbox-gl-js/issues/new?assignees=&labels=&template=Bug_report.md\nand paste the contents of this message in the report.\nThank you!\nFilter Expression:\n${JSON.stringify(r,null,2)}\n `); } const i = Ht[`filter_${e}`], s = Gn(n, i); let a = null; if ("error" === s.result) throw new Error(s.value.map((t => `${t.key}: ${t.message}`)).join(", ")); a = (t, e, r) => s.value.evaluate(t, e, {}, r); let o = null, l = null; if (n !== r) { const t = Gn(r, i); if ("error" === t.result) throw new Error(t.value.map((t => `${t.key}: ${t.message}`)).join(", ")); o = (e, r, n, i, s) => t.value.evaluate(e, r, {}, n, void 0, void 0, i, s), l = !mr(t.value.expression); } return { filter: a, dynamicFilter: o || void 0, needGeometry: pi(n), needFeature: !!l } } function oi(t) { if (!Array.isArray(t)) return t; const e = function(t) { if (ci.has(t[0])) for (let e = 1; e < t.length; e++) if (ui(t[e])) return !0; return t }(t); return !0 === e ? e : e.map((t => oi(t))) } function li(t) { let e = !1; const r = []; if ("case" === t[0]) { for (let n = 1; n < t.length - 1; n += 2) e = e || ui(t[n]), r.push(t[n + 1]); r.push(t[t.length - 1]); } else if ("match" === t[0]) { e = e || ui(t[1]); for (let e = 2; e < t.length - 1; e += 2) r.push(t[e + 1]); r.push(t[t.length - 1]); } else if ("step" === t[0]) { e = e || ui(t[1]); for (let e = 1; e < t.length - 1; e += 2) r.push(t[e + 1]); } e && (t.length = 0, t.push("any", ...r)); for (let e = 1; e < t.length; e++) li(t[e]); } function ui(t) { if (!Array.isArray(t)) return !1; if ("pitch" === (e = t[0]) || "distance-from-center" === e) return !0; var e; for (let e = 1; e < t.length; e++) if (ui(t[e])) return !0; return !1 } const ci = new Set(["in", "==", "!=", ">", ">=", "<", "<=", "to-boolean"]); function hi(t, e) { return t < e ? -1 : t > e ? 1 : 0 } function pi(t) { if (!Array.isArray(t)) return !1; if ("within" === t[0]) return !0; for (let e = 1; e < t.length; e++) if (pi(t[e])) return !0; return !1 } function fi(t) { if (!t) return !0; const e = t[0]; return t.length <= 1 ? "any" !== e : "==" === e ? di(t[1], t[2], "==") : "!=" === e ? gi(di(t[1], t[2], "==")) : "<" === e || ">" === e || "<=" === e || ">=" === e ? di(t[1], t[2], e) : "any" === e ? (r = t.slice(1), ["any"].concat(r.map(fi))) : "all" === e ? ["all"].concat(t.slice(1).map(fi)) : "none" === e ? ["all"].concat(t.slice(1).map(fi).map(gi)) : "in" === e ? yi(t[1], t.slice(2)) : "!in" === e ? gi(yi(t[1], t.slice(2))) : "has" === e ? mi(t[1]) : "!has" === e ? gi(mi(t[1])) : "within" !== e || t; var r; } function di(t, e, r) { switch (t) { case "$type": return [`filter-type-${r}`, e]; case "$id": return [`filter-id-${r}`, e]; default: return [`filter-${r}`, t, e] } } function yi(t, e) { if (0 === e.length) return !1; switch (t) { case "$type": return ["filter-type-in", ["literal", e]]; case "$id": return ["filter-id-in", ["literal", e]]; default: return e.length > 200 && !e.some((t => typeof t != typeof e[0])) ? ["filter-in-large", t, ["literal", e.sort(hi)]] : ["filter-in-small", t, ["literal", e]] } } function mi(t) { switch (t) { case "$type": return !0; case "$id": return ["filter-has-id"]; default: return ["filter-has", t] } } function gi(t) { return ["!", t] } function xi(t) { return si(Qt(t.value)) ? ri(Wt({}, t, { expressionContext: "filter", valueSpec: t.styleSpec[`filter_${t.layerType||"fill"}`] })) : vi(t) } function vi(t) { const e = t.value, r = t.key; if ("array" !== Dn(e)) return [new Wn(r, e, `array expected, ${Dn(e)} found`)]; const n = t.styleSpec; let i, s = []; if (e.length < 1) return [new Wn(r, e, "filter array must have at least 1 element")]; switch (s = s.concat(ii({ key: `${r}[0]`, value: e[0], valueSpec: n.filter_operator, style: t.style, styleSpec: t.styleSpec })), Jt(e[0])) { case "<": case "<=": case ">": case ">=": e.length >= 2 && "$type" === Jt(e[1]) && s.push(new Wn(r, e, `"$type" cannot be use with operator "${e[0]}"`)); case "==": case "!=": 3 !== e.length && s.push(new Wn(r, e, `filter array for operator "${e[0]}" must have 3 elements`)); case "in": case "!in": e.length >= 2 && (i = Dn(e[1]), "string" !== i && s.push(new Wn(`${r}[1]`, e[1], `string expected, ${i} found`))); for (let a = 2; a < e.length; a++) i = Dn(e[a]), "$type" === Jt(e[1]) ? s = s.concat(ii({ key: `${r}[${a}]`, value: e[a], valueSpec: n.geometry_type, style: t.style, styleSpec: t.styleSpec })) : "string" !== i && "number" !== i && "boolean" !== i && s.push(new Wn(`${r}[${a}]`, e[a], `string, number, or boolean expected, ${i} found`)); break; case "any": case "all": case "none": for (let n = 1; n < e.length; n++) s = s.concat(vi({ key: `${r}[${n}]`, value: e[n], style: t.style, styleSpec: t.styleSpec })); break; case "has": case "!has": i = Dn(e[1]), 2 !== e.length ? s.push(new Wn(r, e, `filter array for "${e[0]}" operator must have 2 elements`)) : "string" !== i && s.push(new Wn(`${r}[1]`, e[1], `string expected, ${i} found`)); break; case "within": i = Dn(e[1]), 2 !== e.length ? s.push(new Wn(r, e, `filter array for "${e[0]}" operator must have 2 elements`)) : "object" !== i && s.push(new Wn(`${r}[1]`, e[1], `object expected, ${i} found`)); } return s } function bi(t, e) { const r = t.key, n = t.style, i = t.styleSpec, s = t.value, a = t.objectKey, o = i[`${e}_${t.layerType}`]; if (!o) return []; const l = a.match(/^(.*)-transition$/); if ("paint" === e && l && o[l[1]] && o[l[1]].transition) return Ci({ key: r, value: s, valueSpec: i.transition, style: n, styleSpec: i }); const u = t.valueSpec || o[a]; if (!u) return [new Wn(r, s, `unknown property "${a}"`)]; let c; if ("string" === Dn(s) && En(u) && !u.tokens && (c = /^{([^}]+)}$/.exec(s))) { const t = `\`{ "type": "identity", "property": ${c?JSON.stringify(c[1]):'"_"'} }\``; return [new Wn(r, s, `"${a}" does not support interpolation syntax\nUse an identity property function instead: ${t}.`)] } const h = []; return "symbol" === t.layerType && ("text-field" === a && n && !n.glyphs && h.push(new Wn(r, s, 'use of "text-field" requires a style "glyphs" property')), "text-font" === a && Vn(Qt(s)) && "identity" === Jt(s.type) && h.push(new Wn(r, s, '"text-font" does not support identity functions'))), h.concat(Ci({ key: t.key, value: s, valueSpec: u, style: n, styleSpec: i, expressionContext: "property", propertyType: e, propertyKey: a })) } function wi(t) { return bi(t, "paint") } function _i(t) { return bi(t, "layout") } function Ai(t) { let e = []; const r = t.value, n = t.key, i = t.style, s = t.styleSpec; r.type || r.ref || e.push(new Wn(n, r, 'either "type" or "ref" is required')); let a = Jt(r.type); const o = Jt(r.ref); if (r.id) { const s = Jt(r.id); for (let a = 0; a < t.arrayIndex; a++) { const t = i.layers[a]; Jt(t.id) === s && e.push(new Wn(n, r.id, `duplicate layer id "${r.id}", previously used at line ${t.id.__line__}`)); } } if ("ref" in r) { let t; ["type", "source", "source-layer", "filter", "layout"].forEach((t => { t in r && e.push(new Wn(n, r[t], `"${t}" is prohibited for ref layers`)); })), i.layers.forEach((e => { Jt(e.id) === o && (t = e); })), t ? t.ref ? e.push(new Wn(n, r.ref, "ref cannot reference another ref layer")) : a = Jt(t.type) : "string" == typeof o && e.push(new Wn(n, r.ref, `ref layer "${o}" not found`)); } else if ("background" !== a && "sky" !== a) if (r.source) { const t = i.sources && i.sources[r.source], s = t && Jt(t.type); t ? "vector" === s && "raster" === a ? e.push(new Wn(n, r.source, `layer "${r.id}" requires a raster source`)) : "raster" === s && "raster" !== a ? e.push(new Wn(n, r.source, `layer "${r.id}" requires a vector source`)) : "vector" !== s || r["source-layer"] ? "raster-dem" === s && "hillshade" !== a ? e.push(new Wn(n, r.source, "raster-dem source can only be used with layer type 'hillshade'.")) : "line" !== a || !r.paint || !r.paint["line-gradient"] && !r.paint["line-trim-offset"] || "geojson" === s && t.lineMetrics || e.push(new Wn(n, r, `layer "${r.id}" specifies a line-gradient, which requires a GeoJSON source with \`lineMetrics\` enabled.`)) : e.push(new Wn(n, r, `layer "${r.id}" must specify a "source-layer"`)) : e.push(new Wn(n, r.source, `source "${r.source}" not found`)); } else e.push(new Wn(n, r, 'missing required property "source"')); return e = e.concat(Jn({ key: n, value: r, valueSpec: s.layer, style: t.style, styleSpec: t.styleSpec, objectElementValidators: { "*": () => [], type: () => Ci({ key: `${n}.type`, value: r.type, valueSpec: s.layer.type, style: t.style, styleSpec: t.styleSpec, object: r, objectKey: "type" }), filter: t => xi(Wt({ layerType: a }, t)), layout: t => Jn({ layer: r, key: t.key, value: t.value, valueSpec: {}, style: t.style, styleSpec: t.styleSpec, objectElementValidators: { "*": t => _i(Wt({ layerType: a }, t)) } }), paint: t => Jn({ layer: r, key: t.key, value: t.value, valueSpec: {}, style: t.style, styleSpec: t.styleSpec, objectElementValidators: { "*": t => wi(Wt({ layerType: a }, t)) } }) } })), e } function Si(t) { const e = t.value, r = t.key, n = Dn(e); return "string" !== n ? [new Wn(r, e, `string expected, ${n} found`)] : [] } const ki = { promoteId: function({ key: t, value: e }) { if ("string" === Dn(e)) return Si({ key: t, value: e }); { const r = []; for (const n in e) r.push(...Si({ key: `${t}.${n}`, value: e[n] })); return r } } }; function Ii(t) { const e = t.value, r = t.key, n = t.styleSpec, i = t.style; if (!e.type) return [new Wn(r, e, '"type" is required')]; const s = Jt(e.type); let a; switch (s) { case "vector": case "raster": case "raster-dem": return a = Jn({ key: r, value: e, valueSpec: n[`source_${s.replace("-","_")}`], style: t.style, styleSpec: n, objectElementValidators: ki }), a; case "geojson": if (a = Jn({ key: r, value: e, valueSpec: n.source_geojson, style: i, styleSpec: n, objectElementValidators: ki }), e.cluster) for (const t in e.clusterProperties) { const [n, i] = e.clusterProperties[t], s = "string" == typeof n ? [n, ["accumulated"], ["get", t] ] : n; a.push(...ri({ key: `${r}.${t}.map`, value: i, expressionContext: "cluster-map" })), a.push(...ri({ key: `${r}.${t}.reduce`, value: s, expressionContext: "cluster-reduce" })); } return a; case "video": return Jn({ key: r, value: e, valueSpec: n.source_video, style: i, styleSpec: n }); case "image": return Jn({ key: r, value: e, valueSpec: n.source_image, style: i, styleSpec: n }); case "canvas": return [new Wn(r, null, "Please use runtime APIs to add canvas sources, rather than including them in stylesheets.", "source.canvas")]; default: return ii({ key: `${r}.type`, value: e.type, valueSpec: { values: Mi(n) }, style: i, styleSpec: n }) } } function Mi(t) { return t.source.reduce(((e, r) => { const n = t[r]; return "enum" === n.type.type && (e = e.concat(Object.keys(n.type.values))), e }), []) } function Ti(t) { const e = t.value, r = t.styleSpec, n = r.light, i = t.style; let s = []; const a = Dn(e); if (void 0 === e) return s; if ("object" !== a) return s = s.concat([new Wn("light", e, `object expected, ${a} found`)]), s; for (const t in e) { const a = t.match(/^(.*)-transition$/); s = s.concat(a && n[a[1]] && n[a[1]].transition ? Ci({ key: t, value: e[t], valueSpec: r.transition, style: i, styleSpec: r }) : n[t] ? Ci({ key: t, value: e[t], valueSpec: n[t], style: i, styleSpec: r }) : [new Wn(t, e[t], `unknown property "${t}"`)]); } return s } function zi(t) { const e = t.value, r = t.key, n = t.style, i = t.styleSpec, s = i.terrain; let a = []; const o = Dn(e); if (void 0 === e) return a; if ("object" !== o) return a = a.concat([new Wn("terrain", e, `object expected, ${o} found`)]), a; for (const t in e) { const r = t.match(/^(.*)-transition$/); a = a.concat(r && s[r[1]] && s[r[1]].transition ? Ci({ key: t, value: e[t], valueSpec: i.transition, style: n, styleSpec: i }) : s[t] ? Ci({ key: t, value: e[t], valueSpec: s[t], style: n, styleSpec: i }) : [new Wn(t, e[t], `unknown property "${t}"`)]); } if (e.source) { const t = n.sources && n.sources[e.source], i = t && Jt(t.type); t ? "raster-dem" !== i && a.push(new Wn(r, e.source, `terrain cannot be used with a source of type ${String(i)}, it only be used with a "raster-dem" source type`)) : a.push(new Wn(r, e.source, `source "${e.source}" not found`)); } else a.push(new Wn(r, e, 'terrain is missing required property "source"')); return a } function Bi(t) { const e = t.value, r = t.style, n = t.styleSpec, i = n.fog; let s = []; const a = Dn(e); if (void 0 === e) return s; if ("object" !== a) return s = s.concat([new Wn("fog", e, `object expected, ${a} found`)]), s; for (const t in e) { const a = t.match(/^(.*)-transition$/); s = s.concat(a && i[a[1]] && i[a[1]].transition ? Ci({ key: t, value: e[t], valueSpec: n.transition, style: r, styleSpec: n }) : i[t] ? Ci({ key: t, value: e[t], valueSpec: i[t], style: r, styleSpec: n }) : [new Wn(t, e[t], `unknown property "${t}"`)]); } return s } const Ei = { "*": () => [], array: Qn, boolean: function(t) { const e = t.value, r = t.key, n = Dn(e); return "boolean" !== n ? [new Wn(r, e, `boolean expected, ${n} found`)] : [] }, number: ti, color: function(t) { const e = t.key, r = t.value, n = Dn(r); return "string" !== n ? [new Wn(e, r, `color expected, ${n} found`)] : null === be(r) ? [new Wn(e, r, `color expected, "${r}" found`)] : [] }, enum: ii, filter: xi, function: ei, layer: Ai, object: Jn, source: Ii, light: Ti, terrain: zi, fog: Bi, string: Si, formatted: function(t) { return 0 === Si(t).length ? [] : ri(t) }, resolvedImage: function(t) { return 0 === Si(t).length ? [] : ri(t) }, projection: function(t) { const e = t.value, r = t.styleSpec, n = r.projection, i = t.style; let s = []; const a = Dn(e); if ("object" === a) for (const t in e) s = s.concat(Ci({ key: t, value: e[t], valueSpec: n[t], style: i, styleSpec: r })); else "string" !== a && (s = s.concat([new Wn("projection", e, `object or string expected, ${a} found`)])); return s } }; function Ci(t) { const e = t.value, r = t.valueSpec, n = t.styleSpec; return r.expression && Vn(Jt(e)) ? ei(t) : r.expression && Nn(Qt(e)) ? ri(t) : r.type && Ei[r.type] ? Ei[r.type](t) : Jn(Wt({}, t, { valueSpec: r.type ? n[r.type] : r })) } function Pi(t) { const e = t.value, r = t.key, n = Si(t); return n.length || (-1 === e.indexOf("{fontstack}") && n.push(new Wn(r, e, '"glyphs" url must include a "{fontstack}" token')), -1 === e.indexOf("{range}") && n.push(new Wn(r, e, '"glyphs" url must include a "{range}" token'))), n } function Di(t, e = Ht) { return Fi(Ci({ key: "", value: t, valueSpec: e.$root, styleSpec: e, style: t, objectElementValidators: { glyphs: Pi, "*": () => [] } })) } const Vi = t => Fi(wi(t)), Li = t => Fi(_i(t)); function Fi(t) { return t.slice().sort(((t, e) => t.line && e.line ? t.line - e.line : 0)) } function Ri(t, e) { let r = !1; if (e && e.length) for (const n of e) t.fire(new Kt(new Error(n.message))), r = !0; return r } var ji = $i; function $i(t, e, r) { var n = this.cells = []; if (t instanceof ArrayBuffer) { this.arrayBuffer = t; var i = new Int32Array(this.arrayBuffer); t = i[0], this.d = (e = i[1]) + 2 * (r = i[2]); for (var s = 0; s < this.d * this.d; s++) { var a = i[3 + s], o = i[3 + s + 1]; n.push(a === o ? null : i.subarray(a, o)); } var l = i[3 + n.length + 1]; this.keys = i.subarray(i[3 + n.length], l), this.bboxes = i.subarray(l), this.insert = this._insertReadonly; } else { this.d = e + 2 * r; for (var u = 0; u < this.d * this.d; u++) n.push([]); this.keys = [], this.bboxes = []; } this.n = e, this.extent = t, this.padding = r, this.scale = e / t, this.uid = 0; var c = r / e * t; this.min = -c, this.max = t + c; } $i.prototype.insert = function(t, e, r, n, i) { this._forEachCell(e, r, n, i, this._insertCell, this.uid++), this.keys.push(t), this.bboxes.push(e), this.bboxes.push(r), this.bboxes.push(n), this.bboxes.push(i); }, $i.prototype._insertReadonly = function() { throw "Cannot insert into a GridIndex created from an ArrayBuffer." }, $i.prototype._insertCell = function(t, e, r, n, i, s) { this.cells[i].push(s); }, $i.prototype.query = function(t, e, r, n, i) { var s = this.min, a = this.max; if (t <= s && e <= s && a <= r && a <= n && !i) return Array.prototype.slice.call(this.keys); var o = []; return this._forEachCell(t, e, r, n, this._queryCell, o, {}, i), o }, $i.prototype._queryCell = function(t, e, r, n, i, s, a, o) { var l = this.cells[i]; if (null !== l) for (var u = this.keys, c = this.bboxes, h = 0; h < l.length; h++) { var p = l[h]; if (void 0 === a[p]) { var f = 4 * p; (o ? o(c[f + 0], c[f + 1], c[f + 2], c[f + 3]) : t <= c[f + 2] && e <= c[f + 3] && r >= c[f + 0] && n >= c[f + 1]) ? (a[p] = !0, s.push(u[p])) : a[p] = !1; } } }, $i.prototype._forEachCell = function(t, e, r, n, i, s, a, o) { for (var l = this._convertToCellCoord(t), u = this._convertToCellCoord(e), c = this._convertToCellCoord(r), h = this._convertToCellCoord(n), p = l; p <= c; p++) for (var f = u; f <= h; f++) { var d = this.d * f + p; if ((!o || o(this._convertFromCellCoord(p), this._convertFromCellCoord(f), this._convertFromCellCoord(p + 1), this._convertFromCellCoord(f + 1))) && i.call(this, t, e, r, n, d, s, a, o)) return } }, $i.prototype._convertFromCellCoord = function(t) { return (t - this.padding) / this.scale }, $i.prototype._convertToCellCoord = function(t) { return Math.max(0, Math.min(this.d - 1, Math.floor(t * this.scale) + this.padding)) }, $i.prototype.toArrayBuffer = function() { if (this.arrayBuffer) return this.arrayBuffer; for (var t = this.cells, e = 3 + this.cells.length + 1 + 1, r = 0, n = 0; n < this.cells.length; n++) r += this.cells[n].length; var i = new Int32Array(e + r + this.keys.length + this.bboxes.length); i[0] = this.extent, i[1] = this.n, i[2] = this.padding; for (var s = e, a = 0; a < t.length; a++) { var o = t[a]; i[3 + a] = s, i.set(o, s), s += o.length; } return i[3 + t.length] = s, i.set(this.keys, s), i[3 + t.length + 1] = s += this.keys.length, i.set(this.bboxes, s), s += this.bboxes.length, i.buffer }; const Ui = {}; function Oi(t, e, r = {}) { Object.defineProperty(t, "_classRegistryKey", { value: e, writeable: !1 }), Ui[e] = { klass: t, omit: r.omit || [] }; } Oi(Object, "Object"), ji.serialize = function(t, e) { const r = t.toArrayBuffer(); return e && e.push(r), { buffer: r } }, ji.deserialize = function(t) { return new ji(t.buffer) }, Object.defineProperty(ji, "name", { value: "Grid" }), Oi(ji, "Grid"), Oi(Me, "Color"), Oi(Error, "Error"), Oi(at, "AJAXError"), Oi(Ee, "ResolvedImage"), Oi(Yn, "StylePropertyFunction"), Oi(qn, "StyleExpression", { omit: ["_evaluator"] }), Oi(Xn, "ZoomDependentExpression"), Oi(Zn, "ZoomConstantExpression"), Oi(He, "CompoundExpression", { omit: ["_evaluate"] }); for (const t in Tn) Ui[Tn[t]._classRegistryKey] || Oi(Tn[t], `Expression${t}`); function qi(t) { return t && "undefined" != typeof ArrayBuffer && (t instanceof ArrayBuffer || t.constructor && "ArrayBuffer" === t.constructor.name) } function Ni(t) { return e.ImageBitmap && t instanceof e.ImageBitmap } function Gi(t, r) { if (null == t || "boolean" == typeof t || "number" == typeof t || "string" == typeof t || t instanceof Boolean || t instanceof Number || t instanceof String || t instanceof Date || t instanceof RegExp) return t; if (qi(t) || Ni(t)) return r && r.push(t), t; if (ArrayBuffer.isView(t)) { const e = t; return r && r.push(e.buffer), e } if (t instanceof e.ImageData) return r && r.push(t.data.buffer), t; if (Array.isArray(t)) { const e = []; for (const n of t) e.push(Gi(n, r)); return e } if ("object" == typeof t) { const e = t.constructor, n = e._classRegistryKey; if (!n) throw new Error(`can't serialize object of unregistered class ${n}`); const i = e.serialize ? e.serialize(t, r) : {}; if (!e.serialize) { for (const e in t) t.hasOwnProperty(e) && (Ui[n].omit.indexOf(e) >= 0 || (i[e] = Gi(t[e], r))); t instanceof Error && (i.message = t.message); } if (i.$name) throw new Error("$name property is reserved for worker serialization logic."); return "Object" !== n && (i.$name = n), i } throw new Error("can't serialize object of type " + typeof t) } function Zi(t) { if (null == t || "boolean" == typeof t || "number" == typeof t || "string" == typeof t || t instanceof Boolean || t instanceof Number || t instanceof String || t instanceof Date || t instanceof RegExp || qi(t) || Ni(t) || ArrayBuffer.isView(t) || t instanceof e.ImageData) return t; if (Array.isArray(t)) return t.map(Zi); if ("object" == typeof t) { const e = t.$name || "Object", { klass: r } = Ui[e]; if (!r) throw new Error(`can't deserialize unregistered class ${e}`); if (r.deserialize) return r.deserialize(t); const n = Object.create(r.prototype); for (const e of Object.keys(t)) "$name" !== e && (n[e] = Zi(t[e])); return n } throw new Error("can't deserialize object of type " + typeof t) } const Xi = t => t >= 1536 && t <= 1791, Ki = t => t >= 1872 && t <= 1919, Yi = t => t >= 2208 && t <= 2303, Hi = t => t >= 11904 && t <= 12031, Wi = t => t >= 12032 && t <= 12255, Ji = t => t >= 12272 && t <= 12287, Qi = t => t >= 12288 && t <= 12351, ts = t => t >= 12352 && t <= 12447, es = t => t >= 12448 && t <= 12543, rs = t => t >= 12544 && t <= 12591, ns = t => t >= 12704 && t <= 12735, is = t => t >= 12736 && t <= 12783, ss = t => t >= 12784 && t <= 12799, as = t => t >= 12800 && t <= 13055, os = t => t >= 13056 && t <= 13311, ls = t => t >= 13312 && t <= 19903, us = t => t >= 19968 && t <= 40959, cs = t => t >= 40960 && t <= 42127, hs = t => t >= 42128 && t <= 42191, ps = t => t >= 44032 && t <= 55215, fs = t => t >= 63744 && t <= 64255, ds = t => t >= 64336 && t <= 65023, ys = t => t >= 65040 && t <= 65055, ms = t => t >= 65072 && t <= 65103, gs = t => t >= 65104 && t <= 65135, xs = t => t >= 65136 && t <= 65279, vs = t => t >= 65280 && t <= 65519; function bs(t) { for (const e of t) if (As(e.charCodeAt(0))) return !0; return !1 } function ws(t) { for (const e of t) if (!_s(e.charCodeAt(0))) return !1; return !0 } function _s(t) { return !(Xi(t) || Ki(t) || Yi(t) || ds(t) || xs(t)) } function As(t) { return !(746 !== t && 747 !== t && (t < 4352 || !(ns(t) || rs(t) || ms(t) && !(t >= 65097 && t <= 65103) || fs(t) || os(t) || Hi(t) || is(t) || !(!Qi(t) || t >= 12296 && t <= 12305 || t >= 12308 && t <= 12319 || 12336 === t) || ls(t) || us(t) || as(t) || (t => t >= 12592 && t <= 12687)(t) || (t => t >= 43360 && t <= 43391)(t) || (t => t >= 55216 && t <= 55295)(t) || (t => t >= 4352 && t <= 4607)(t) || ps(t) || ts(t) || Ji(t) || (t => t >= 12688 && t <= 12703)(t) || Wi(t) || ss(t) || es(t) && 12540 !== t || !(!vs(t) || 65288 === t || 65289 === t || 65293 === t || t >= 65306 && t <= 65310 || 65339 === t || 65341 === t || 65343 === t || t >= 65371 && t <= 65503 || 65507 === t || t >= 65512 && t <= 65519) || !(!gs(t) || t >= 65112 && t <= 65118 || t >= 65123 && t <= 65126) || (t => t >= 5120 && t <= 5759)(t) || (t => t >= 6320 && t <= 6399)(t) || ys(t) || (t => t >= 19904 && t <= 19967)(t) || cs(t) || hs(t)))) } function Ss(t) { return !(As(t) || function(t) { return !!((t => t >= 128 && t <= 255)(t) && (167 === t || 169 === t || 174 === t || 177 === t || 188 === t || 189 === t || 190 === t || 215 === t || 247 === t) || (t => t >= 8192 && t <= 8303)(t) && (8214 === t || 8224 === t || 8225 === t || 8240 === t || 8241 === t || 8251 === t || 8252 === t || 8258 === t || 8263 === t || 8264 === t || 8265 === t || 8273 === t) || (t => t >= 8448 && t <= 8527)(t) || (t => t >= 8528 && t <= 8591)(t) || (t => t >= 8960 && t <= 9215)(t) && (t >= 8960 && t <= 8967 || t >= 8972 && t <= 8991 || t >= 8996 && t <= 9e3 || 9003 === t || t >= 9085 && t <= 9114 || t >= 9150 && t <= 9165 || 9167 === t || t >= 9169 && t <= 9179 || t >= 9186 && t <= 9215) || (t => t >= 9216 && t <= 9279)(t) && 9251 !== t || (t => t >= 9280 && t <= 9311)(t) || (t => t >= 9312 && t <= 9471)(t) || (t => t >= 9632 && t <= 9727)(t) || (t => t >= 9728 && t <= 9983)(t) && !(t >= 9754 && t <= 9759) || (t => t >= 11008 && t <= 11263)(t) && (t >= 11026 && t <= 11055 || t >= 11088 && t <= 11097 || t >= 11192 && t <= 11243) || Qi(t) || es(t) || (t => t >= 57344 && t <= 63743)(t) || ms(t) || gs(t) || vs(t) || 8734 === t || 8756 === t || 8757 === t || t >= 9984 && t <= 10087 || t >= 10102 && t <= 10131 || 65532 === t || 65533 === t) }(t)) } function ks(t) { return t >= 1424 && t <= 2303 || ds(t) || xs(t) } function Is(t, e) { return !(!e && ks(t) || t >= 2304 && t <= 3583 || t >= 3840 && t <= 4255 || (t => t >= 6016 && t <= 6143)(t)) } function Ms(t) { for (const e of t) if (ks(e.charCodeAt(0))) return !0; return !1 } const Ts = "deferred", zs = "loading", Bs = "loaded"; let Es = null, Cs = "unavailable", Ps = null; const Ds = function(t) { t && "string" == typeof t && t.indexOf("NetworkError") > -1 && (Cs = "error"), Es && Es(t); }; function Vs() { Ls.fire(new Xt("pluginStateChange", { pluginStatus: Cs, pluginURL: Ps })); } const Ls = new Yt, Fs = function() { return Cs }, Rs = function() { if (Cs !== Ts || !Ps) throw new Error("rtl-text-plugin cannot be downloaded unless a pluginURL is specified"); Cs = zs, Vs(), Ps && ut({ url: Ps }, (t => { t ? Ds(t) : (Cs = Bs, Vs()); })); }, js = { applyArabicShaping: null, processBidirectionalText: null, processStyledBidirectionalText: null, isLoaded: () => Cs === Bs || null != js.applyArabicShaping, isLoading: () => Cs === zs, setState(t) { Cs = t.pluginStatus, Ps = t.pluginURL; }, isParsed: () => null != js.applyArabicShaping && null != js.processBidirectionalText && null != js.processStyledBidirectionalText, getPluginURL: () => Ps }; class $s { constructor(t, e) { this.zoom = t, e ? (this.now = e.now, this.fadeDuration = e.fadeDuration, this.transition = e.transition, this.pitch = e.pitch) : (this.now = 0, this.fadeDuration = 0, this.transition = {}, this.pitch = 0); } isSupportedScript(t) { return function(t, e) { for (const r of t) if (!Is(r.charCodeAt(0), e)) return !1; return !0 }(t, js.isLoaded()) } } class Us { constructor(t, e) { this.property = t, this.value = e, this.expression = function(t, e) { if (Vn(t)) return new Yn(t, e); if (Nn(t)) { const r = Kn(t, e); if ("error" === r.result) throw new Error(r.value.map((t => `${t.key}: ${t.message}`)).join(", ")); return r.value } { let r = t; return "string" == typeof t && "color" === e.type && (r = Me.parse(t)), { kind: "constant", evaluate: () => r } } }(void 0 === e ? t.specification.default : e, t.specification); } isDataDriven() { return "source" === this.expression.kind || "composite" === this.expression.kind } possiblyEvaluate(t, e, r) { return this.property.possiblyEvaluate(this, t, e, r) } } class Os { constructor(t) { this.property = t, this.value = new Us(t, void 0); } transitioned(t, e) { return new Ns(this.property, this.value, e, z({}, t.transition, this.transition), t.now) } untransitioned() { return new Ns(this.property, this.value, null, {}, 0) } } class qs { constructor(t) { this._properties = t, this._values = Object.create(t.defaultTransitionablePropertyValues); } getValue(t) { return j(this._values[t].value.value) } setValue(t, e) { this._values.hasOwnProperty(t) || (this._values[t] = new Os(this._values[t].property)), this._values[t].value = new Us(this._values[t].property, null === e ? void 0 : j(e)); } getTransition(t) { return j(this._values[t].transition) } setTransition(t, e) { this._values.hasOwnProperty(t) || (this._values[t] = new Os(this._values[t].property)), this._values[t].transition = j(e) || void 0; } serialize() { const t = {}; for (const e of Object.keys(this._values)) { const r = this.getValue(e); void 0 !== r && (t[e] = r); const n = this.getTransition(e); void 0 !== n && (t[`${e}-transition`] = n); } return t } transitioned(t, e) { const r = new Gs(this._properties); for (const n of Object.keys(this._values)) r._values[n] = this._values[n].transitioned(t, e._values[n]); return r } untransitioned() { const t = new Gs(this._properties); for (const e of Object.keys(this._values)) t._values[e] = this._values[e].untransitioned(); return t } } class Ns { constructor(t, e, r, n, i) { const s = n.delay || 0, a = n.duration || 0; i = i || 0, this.property = t, this.value = e, this.begin = i + s, this.end = this.begin + a, t.specification.transition && (n.delay || n.duration) && (this.prior = r); } possiblyEvaluate(t, e, r) { const n = t.now || 0, i = this.value.possiblyEvaluate(t, e, r), s = this.prior; if (s) { if (n > this.end) return this.prior = null, i; if (this.value.isDataDriven()) return this.prior = null, i; if (n < this.begin) return s.possiblyEvaluate(t, e, r); { const a = (n - this.begin) / (this.end - this.begin); return this.property.interpolate(s.possiblyEvaluate(t, e, r), i, w(a)) } } return i } } class Gs { constructor(t) { this._properties = t, this._values = Object.create(t.defaultTransitioningPropertyValues); } possiblyEvaluate(t, e, r) { const n = new Ks(this._properties); for (const i of Object.keys(this._values)) n._values[i] = this._values[i].possiblyEvaluate(t, e, r); return n } hasTransition() { for (const t of Object.keys(this._values)) if (this._values[t].prior) return !0; return !1 } } class Zs { constructor(t) { this._properties = t, this._values = Object.create(t.defaultPropertyValues); } getValue(t) { return j(this._values[t].value) } setValue(t, e) { this._values[t] = new Us(this._values[t].property, null === e ? void 0 : j(e)); } serialize() { const t = {}; for (const e of Object.keys(this._values)) { const r = this.getValue(e); void 0 !== r && (t[e] = r); } return t } possiblyEvaluate(t, e, r) { const n = new Ks(this._properties); for (const i of Object.keys(this._values)) n._values[i] = this._values[i].possiblyEvaluate(t, e, r); return n } } class Xs { constructor(t, e, r) { this.property = t, this.value = e, this.parameters = r; } isConstant() { return "constant" === this.value.kind } constantOr(t) { return "constant" === this.value.kind ? this.value.value : t } evaluate(t, e, r, n) { return this.property.evaluate(this.value, this.parameters, t, e, r, n) } } class Ks { constructor(t) { this._properties = t, this._values = Object.create(t.defaultPossiblyEvaluatedValues); } get(t) { return this._values[t] } } class Ys { constructor(t) { this.specification = t; } possiblyEvaluate(t, e) { return t.expression.evaluate(e) } interpolate(t, e, r) { const n = Tr[this.specification.type]; return n ? n(t, e, r) : t } } class Hs { constructor(t, e) { this.specification = t, this.overrides = e; } possiblyEvaluate(t, e, r, n) { return new Xs(this, "constant" === t.expression.kind || "camera" === t.expression.kind ? { kind: "constant", value: t.expression.evaluate(e, null, {}, r, n) } : t.expression, e) } interpolate(t, e, r) { if ("constant" !== t.value.kind || "constant" !== e.value.kind) return t; if (void 0 === t.value.value || void 0 === e.value.value) return new Xs(this, { kind: "constant", value: void 0 }, t.parameters); const n = Tr[this.specification.type]; return n ? new Xs(this, { kind: "constant", value: n(t.value.value, e.value.value, r) }, t.parameters) : t } evaluate(t, e, r, n, i, s) { return "constant" === t.kind ? t.value : t.evaluate(e, r, n, i, s) } } class Ws { constructor(t) { this.specification = t; } possiblyEvaluate(t, e, r, n) { return !!t.expression.evaluate(e, null, {}, r, n) } interpolate() { return !1 } } class Js { constructor(t) { this.properties = t, this.defaultPropertyValues = {}, this.defaultTransitionablePropertyValues = {}, this.defaultTransitioningPropertyValues = {}, this.defaultPossiblyEvaluatedValues = {}, this.overridableProperties = []; const e = new $s(0, {}); for (const r in t) { const n = t[r]; n.specification.overridable && this.overridableProperties.push(r); const i = this.defaultPropertyValues[r] = new Us(n, void 0), s = this.defaultTransitionablePropertyValues[r] = new Os(n); this.defaultTransitioningPropertyValues[r] = s.untransitioned(), this.defaultPossiblyEvaluatedValues[r] = i.possiblyEvaluate(e); } } } function Qs(t, e) { return 256 * (t = S(Math.floor(t), 0, 255)) + S(Math.floor(e), 0, 255) } Oi(Hs, "DataDrivenProperty"), Oi(Ys, "DataConstantProperty"), Oi(Ws, "ColorRampProperty"); const ta = { Int8: Int8Array, Uint8: Uint8Array, Int16: Int16Array, Uint16: Uint16Array, Int32: Int32Array, Uint32: Uint32Array, Float32: Float32Array }; class ea { constructor(t, e) { this._structArray = t, this._pos1 = e * this.size, this._pos2 = this._pos1 / 2, this._pos4 = this._pos1 / 4, this._pos8 = this._pos1 / 8; } } class ra { constructor() { this.isTransferred = !1, this.capacity = -1, this.resize(0); } static serialize(t, e) { return t._trim(), e && (t.isTransferred = !0, e.push(t.arrayBuffer)), { length: t.length, arrayBuffer: t.arrayBuffer } } static deserialize(t) { const e = Object.create(this.prototype); return e.arrayBuffer = t.arrayBuffer, e.length = t.length, e.capacity = t.arrayBuffer.byteLength / e.bytesPerElement, e._refreshViews(), e } _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(t) { this.reserve(t), this.length = t; } reserve(t) { if (t > this.capacity) { this.capacity = Math.max(t, Math.floor(5 * this.capacity), 128), this.arrayBuffer = new ArrayBuffer(this.capacity * this.bytesPerElement); const e = this.uint8; this._refreshViews(), e && this.uint8.set(e); } } _refreshViews() { throw new Error("_refreshViews() must be implemented by each concrete StructArray layout") } destroy() { this.int8 = this.uint8 = this.int16 = this.uint16 = this.int32 = this.uint32 = this.float32 = null, this.arrayBuffer = null; } } function na(t, e = 1) { let r = 0, n = 0; return { members: t.map((t => { const i = ta[t.type].BYTES_PER_ELEMENT, s = r = ia(r, Math.max(e, i)), a = t.components || 1; return n = Math.max(n, i), r += i * a, { name: t.name, type: t.type, components: a, offset: s } })), size: ia(r, Math.max(n, e)), alignment: e } } function ia(t, e) { return Math.ceil(t / e) * e } class sa extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer); } emplaceBack(t, e) { const r = this.length; return this.resize(r + 1), this.emplace(r, t, e) } emplace(t, e, r) { const n = 2 * t; return this.int16[n + 0] = e, this.int16[n + 1] = r, t } } sa.prototype.bytesPerElement = 4, Oi(sa, "StructArrayLayout2i4"); class aa extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer); } emplaceBack(t, e, r) { const n = this.length; return this.resize(n + 1), this.emplace(n, t, e, r) } emplace(t, e, r, n) { const i = 3 * t; return this.int16[i + 0] = e, this.int16[i + 1] = r, this.int16[i + 2] = n, t } } aa.prototype.bytesPerElement = 6, Oi(aa, "StructArrayLayout3i6"); class oa extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer); } emplaceBack(t, e, r, n) { const i = this.length; return this.resize(i + 1), this.emplace(i, t, e, r, n) } emplace(t, e, r, n, i) { const s = 4 * t; return this.int16[s + 0] = e, this.int16[s + 1] = r, this.int16[s + 2] = n, this.int16[s + 3] = i, t } } oa.prototype.bytesPerElement = 8, Oi(oa, "StructArrayLayout4i8"); class la extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(t, e, r, n, i, s, a) { const o = this.length; return this.resize(o + 1), this.emplace(o, t, e, r, n, i, s, a) } emplace(t, e, r, n, i, s, a, o) { const l = 6 * t, u = 12 * t, c = 3 * t; return this.int16[l + 0] = e, this.int16[l + 1] = r, this.uint8[u + 4] = n, this.uint8[u + 5] = i, this.uint8[u + 6] = s, this.uint8[u + 7] = a, this.float32[c + 2] = o, t } } la.prototype.bytesPerElement = 12, Oi(la, "StructArrayLayout2i4ub1f12"); class ua extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(t, e, r, n) { const i = this.length; return this.resize(i + 1), this.emplace(i, t, e, r, n) } emplace(t, e, r, n, i) { const s = 4 * t; return this.float32[s + 0] = e, this.float32[s + 1] = r, this.float32[s + 2] = n, this.float32[s + 3] = i, t } } ua.prototype.bytesPerElement = 16, Oi(ua, "StructArrayLayout4f16"); class ca extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(t, e, r, n, i) { const s = this.length; return this.resize(s + 1), this.emplace(s, t, e, r, n, i) } emplace(t, e, r, n, i, s) { const a = 6 * t, o = 3 * t; return this.uint16[a + 0] = e, this.uint16[a + 1] = r, this.uint16[a + 2] = n, this.uint16[a + 3] = i, this.float32[o + 2] = s, t } } ca.prototype.bytesPerElement = 12, Oi(ca, "StructArrayLayout4ui1f12"); class ha extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer); } emplaceBack(t, e, r, n) { const i = this.length; return this.resize(i + 1), this.emplace(i, t, e, r, n) } emplace(t, e, r, n, i) { const s = 4 * t; return this.uint16[s + 0] = e, this.uint16[s + 1] = r, this.uint16[s + 2] = n, this.uint16[s + 3] = i, t } } ha.prototype.bytesPerElement = 8, Oi(ha, "StructArrayLayout4ui8"); class pa extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer); } emplaceBack(t, e, r, n, i, s) { const a = this.length; return this.resize(a + 1), this.emplace(a, t, e, r, n, i, s) } emplace(t, e, r, n, i, s, a) { const o = 6 * t; return this.int16[o + 0] = e, this.int16[o + 1] = r, this.int16[o + 2] = n, this.int16[o + 3] = i, this.int16[o + 4] = s, this.int16[o + 5] = a, t } } pa.prototype.bytesPerElement = 12, Oi(pa, "StructArrayLayout6i12"); class fa extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer); } emplaceBack(t, e, r, n, i, s, a, o, l, u, c, h) { const p = this.length; return this.resize(p + 1), this.emplace(p, t, e, r, n, i, s, a, o, l, u, c, h) } emplace(t, e, r, n, i, s, a, o, l, u, c, h, p) { const f = 12 * t; return this.int16[f + 0] = e, this.int16[f + 1] = r, this.int16[f + 2] = n, this.int16[f + 3] = i, this.uint16[f + 4] = s, this.uint16[f + 5] = a, this.uint16[f + 6] = o, this.uint16[f + 7] = l, this.int16[f + 8] = u, this.int16[f + 9] = c, this.int16[f + 10] = h, this.int16[f + 11] = p, t } } fa.prototype.bytesPerElement = 24, Oi(fa, "StructArrayLayout4i4ui4i24"); class da extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(t, e, r, n, i, s) { const a = this.length; return this.resize(a + 1), this.emplace(a, t, e, r, n, i, s) } emplace(t, e, r, n, i, s, a) { const o = 10 * t, l = 5 * t; return this.int16[o + 0] = e, this.int16[o + 1] = r, this.int16[o + 2] = n, this.float32[l + 2] = i, this.float32[l + 3] = s, this.float32[l + 4] = a, t } } da.prototype.bytesPerElement = 20, Oi(da, "StructArrayLayout3i3f20"); class ya extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.uint32 = new Uint32Array(this.arrayBuffer); } emplaceBack(t) { const e = this.length; return this.resize(e + 1), this.emplace(e, t) } emplace(t, e) { return this.uint32[1 * t + 0] = e, t } } ya.prototype.bytesPerElement = 4, Oi(ya, "StructArrayLayout1ul4"); class ma extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer), this.uint32 = new Uint32Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer); } emplaceBack(t, e, r, n, i, s, a, o, l, u, c, h, p) { const f = this.length; return this.resize(f + 1), this.emplace(f, t, e, r, n, i, s, a, o, l, u, c, h, p) } emplace(t, e, r, n, i, s, a, o, l, u, c, h, p, f) { const d = 20 * t, y = 10 * t; return this.int16[d + 0] = e, this.int16[d + 1] = r, this.int16[d + 2] = n, this.int16[d + 3] = i, this.int16[d + 4] = s, this.float32[y + 3] = a, this.float32[y + 4] = o, this.float32[y + 5] = l, this.float32[y + 6] = u, this.int16[d + 14] = c, this.uint32[y + 8] = h, this.uint16[d + 18] = p, this.uint16[d + 19] = f, t } } ma.prototype.bytesPerElement = 40, Oi(ma, "StructArrayLayout5i4f1i1ul2ui40"); class ga extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer); } emplaceBack(t, e, r, n, i, s, a) { const o = this.length; return this.resize(o + 1), this.emplace(o, t, e, r, n, i, s, a) } emplace(t, e, r, n, i, s, a, o) { const l = 8 * t; return this.int16[l + 0] = e, this.int16[l + 1] = r, this.int16[l + 2] = n, this.int16[l + 4] = i, this.int16[l + 5] = s, this.int16[l + 6] = a, this.int16[l + 7] = o, t } } ga.prototype.bytesPerElement = 16, Oi(ga, "StructArrayLayout3i2i2i16"); class xa extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer); } emplaceBack(t, e, r, n, i) { const s = this.length; return this.resize(s + 1), this.emplace(s, t, e, r, n, i) } emplace(t, e, r, n, i, s) { const a = 4 * t, o = 8 * t; return this.float32[a + 0] = e, this.float32[a + 1] = r, this.float32[a + 2] = n, this.int16[o + 6] = i, this.int16[o + 7] = s, t } } xa.prototype.bytesPerElement = 16, Oi(xa, "StructArrayLayout2f1f2i16"); class va extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(t, e, r, n) { const i = this.length; return this.resize(i + 1), this.emplace(i, t, e, r, n) } emplace(t, e, r, n, i) { const s = 12 * t, a = 3 * t; return this.uint8[s + 0] = e, this.uint8[s + 1] = r, this.float32[a + 1] = n, this.float32[a + 2] = i, t } } va.prototype.bytesPerElement = 12, Oi(va, "StructArrayLayout2ub2f12"); class ba extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(t, e, r) { const n = this.length; return this.resize(n + 1), this.emplace(n, t, e, r) } emplace(t, e, r, n) { const i = 3 * t; return this.float32[i + 0] = e, this.float32[i + 1] = r, this.float32[i + 2] = n, t } } ba.prototype.bytesPerElement = 12, Oi(ba, "StructArrayLayout3f12"); class wa extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer); } emplaceBack(t, e, r) { const n = this.length; return this.resize(n + 1), this.emplace(n, t, e, r) } emplace(t, e, r, n) { const i = 3 * t; return this.uint16[i + 0] = e, this.uint16[i + 1] = r, this.uint16[i + 2] = n, t } } wa.prototype.bytesPerElement = 6, Oi(wa, "StructArrayLayout3ui6"); class _a extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer), this.uint32 = new Uint32Array(this.arrayBuffer); } emplaceBack(t, e, r, n, i, s, a, o, l, u, c, h, p, f, d, y, m, g, x, v, b) { const w = this.length; return this.resize(w + 1), this.emplace(w, t, e, r, n, i, s, a, o, l, u, c, h, p, f, d, y, m, g, x, v, b) } emplace(t, e, r, n, i, s, a, o, l, u, c, h, p, f, d, y, m, g, x, v, b, w) { const _ = 30 * t, A = 15 * t, S = 60 * t; return this.int16[_ + 0] = e, this.int16[_ + 1] = r, this.int16[_ + 2] = n, this.float32[A + 2] = i, this.float32[A + 3] = s, this.uint16[_ + 8] = a, this.uint16[_ + 9] = o, this.uint32[A + 5] = l, this.uint32[A + 6] = u, this.uint32[A + 7] = c, this.uint16[_ + 16] = h, this.uint16[_ + 17] = p, this.uint16[_ + 18] = f, this.float32[A + 10] = d, this.float32[A + 11] = y, this.uint8[S + 48] = m, this.uint8[S + 49] = g, this.uint8[S + 50] = x, this.uint32[A + 13] = v, this.int16[_ + 28] = b, this.uint8[S + 58] = w, t } } _a.prototype.bytesPerElement = 60, Oi(_a, "StructArrayLayout3i2f2ui3ul3ui2f3ub1ul1i1ub60"); class Aa extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer), this.uint32 = new Uint32Array(this.arrayBuffer); } emplaceBack(t, e, r, n, i, s, a, o, l, u, c, h, p, f, d, y, m, g, x, v, b, w, _, A, S, k, I, M, T, z) { const B = this.length; return this.resize(B + 1), this.emplace(B, t, e, r, n, i, s, a, o, l, u, c, h, p, f, d, y, m, g, x, v, b, w, _, A, S, k, I, M, T, z) } emplace(t, e, r, n, i, s, a, o, l, u, c, h, p, f, d, y, m, g, x, v, b, w, _, A, S, k, I, M, T, z, B) { const E = 38 * t, C = 19 * t; return this.int16[E + 0] = e, this.int16[E + 1] = r, this.int16[E + 2] = n, this.float32[C + 2] = i, this.float32[C + 3] = s, this.int16[E + 8] = a, this.int16[E + 9] = o, this.int16[E + 10] = l, this.int16[E + 11] = u, this.int16[E + 12] = c, this.int16[E + 13] = h, this.uint16[E + 14] = p, this.uint16[E + 15] = f, this.uint16[E + 16] = d, this.uint16[E + 17] = y, this.uint16[E + 18] = m, this.uint16[E + 19] = g, this.uint16[E + 20] = x, this.uint16[E + 21] = v, this.uint16[E + 22] = b, this.uint16[E + 23] = w, this.uint16[E + 24] = _, this.uint16[E + 25] = A, this.uint16[E + 26] = S, this.uint16[E + 27] = k, this.uint16[E + 28] = I, this.uint32[C + 15] = M, this.float32[C + 16] = T, this.float32[C + 17] = z, this.float32[C + 18] = B, t } } Aa.prototype.bytesPerElement = 76, Oi(Aa, "StructArrayLayout3i2f6i15ui1ul3f76"); class Sa extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(t) { const e = this.length; return this.resize(e + 1), this.emplace(e, t) } emplace(t, e) { return this.float32[1 * t + 0] = e, t } } Sa.prototype.bytesPerElement = 4, Oi(Sa, "StructArrayLayout1f4"); class ka extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(t, e, r, n, i) { const s = this.length; return this.resize(s + 1), this.emplace(s, t, e, r, n, i) } emplace(t, e, r, n, i, s) { const a = 5 * t; return this.float32[a + 0] = e, this.float32[a + 1] = r, this.float32[a + 2] = n, this.float32[a + 3] = i, this.float32[a + 4] = s, t } } ka.prototype.bytesPerElement = 20, Oi(ka, "StructArrayLayout5f20"); class Ia extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.uint32 = new Uint32Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer); } emplaceBack(t, e, r, n) { const i = this.length; return this.resize(i + 1), this.emplace(i, t, e, r, n) } emplace(t, e, r, n, i) { const s = 6 * t; return this.uint32[3 * t + 0] = e, this.uint16[s + 2] = r, this.uint16[s + 3] = n, this.uint16[s + 4] = i, t } } Ia.prototype.bytesPerElement = 12, Oi(Ia, "StructArrayLayout1ul3ui12"); class Ma extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer); } emplaceBack(t, e) { const r = this.length; return this.resize(r + 1), this.emplace(r, t, e) } emplace(t, e, r) { const n = 2 * t; return this.uint16[n + 0] = e, this.uint16[n + 1] = r, t } } Ma.prototype.bytesPerElement = 4, Oi(Ma, "StructArrayLayout2ui4"); class Ta extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer); } emplaceBack(t) { const e = this.length; return this.resize(e + 1), this.emplace(e, t) } emplace(t, e) { return this.uint16[1 * t + 0] = e, t } } Ta.prototype.bytesPerElement = 2, Oi(Ta, "StructArrayLayout1ui2"); class za extends ra { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(t, e) { const r = this.length; return this.resize(r + 1), this.emplace(r, t, e) } emplace(t, e, r) { const n = 2 * t; return this.float32[n + 0] = e, this.float32[n + 1] = r, t } } za.prototype.bytesPerElement = 8, Oi(za, "StructArrayLayout2f8"); class Ba extends ea { get projectedAnchorX() { return this._structArray.int16[this._pos2 + 0] } get projectedAnchorY() { return this._structArray.int16[this._pos2 + 1] } get projectedAnchorZ() { return this._structArray.int16[this._pos2 + 2] } get tileAnchorX() { return this._structArray.int16[this._pos2 + 3] } get tileAnchorY() { return this._structArray.int16[this._pos2 + 4] } get x1() { return this._structArray.float32[this._pos4 + 3] } get y1() { return this._structArray.float32[this._pos4 + 4] } get x2() { return this._structArray.float32[this._pos4 + 5] } get y2() { return this._structArray.float32[this._pos4 + 6] } get padding() { return this._structArray.int16[this._pos2 + 14] } get featureIndex() { return this._structArray.uint32[this._pos4 + 8] } get sourceLayerIndex() { return this._structArray.uint16[this._pos2 + 18] } get bucketIndex() { return this._structArray.uint16[this._pos2 + 19] } } Ba.prototype.size = 40; class Ea extends ma { get(t) { return new Ba(this, t) } } Oi(Ea, "CollisionBoxArray"); class Ca extends ea { get projectedAnchorX() { return this._structArray.int16[this._pos2 + 0] } get projectedAnchorY() { return this._structArray.int16[this._pos2 + 1] } get projectedAnchorZ() { return this._structArray.int16[this._pos2 + 2] } get tileAnchorX() { return this._structArray.float32[this._pos4 + 2] } get tileAnchorY() { return this._structArray.float32[this._pos4 + 3] } get glyphStartIndex() { return this._structArray.uint16[this._pos2 + 8] } get numGlyphs() { return this._structArray.uint16[this._pos2 + 9] } get vertexStartIndex() { return this._structArray.uint32[this._pos4 + 5] } get lineStartIndex() { return this._structArray.uint32[this._pos4 + 6] } get lineLength() { return this._structArray.uint32[this._pos4 + 7] } get segment() { return this._structArray.uint16[this._pos2 + 16] } get lowerSize() { return this._structArray.uint16[this._pos2 + 17] } get upperSize() { return this._structArray.uint16[this._pos2 + 18] } get lineOffsetX() { return this._structArray.float32[this._pos4 + 10] } get lineOffsetY() { return this._structArray.float32[this._pos4 + 11] } get writingMode() { return this._structArray.uint8[this._pos1 + 48] } get placedOrientation() { return this._structArray.uint8[this._pos1 + 49] } set placedOrientation(t) { this._structArray.uint8[this._pos1 + 49] = t; } get hidden() { return this._structArray.uint8[this._pos1 + 50] } set hidden(t) { this._structArray.uint8[this._pos1 + 50] = t; } get crossTileID() { return this._structArray.uint32[this._pos4 + 13] } set crossTileID(t) { this._structArray.uint32[this._pos4 + 13] = t; } get associatedIconIndex() { return this._structArray.int16[this._pos2 + 28] } get flipState() { return this._structArray.uint8[this._pos1 + 58] } set flipState(t) { this._structArray.uint8[this._pos1 + 58] = t; } } Ca.prototype.size = 60; class Pa extends _a { get(t) { return new Ca(this, t) } } Oi(Pa, "PlacedSymbolArray"); class Da extends ea { get projectedAnchorX() { return this._structArray.int16[this._pos2 + 0] } get projectedAnchorY() { return this._structArray.int16[this._pos2 + 1] } get projectedAnchorZ() { return this._structArray.int16[this._pos2 + 2] } get tileAnchorX() { return this._structArray.float32[this._pos4 + 2] } get tileAnchorY() { return this._structArray.float32[this._pos4 + 3] } get rightJustifiedTextSymbolIndex() { return this._structArray.int16[this._pos2 + 8] } get centerJustifiedTextSymbolIndex() { return this._structArray.int16[this._pos2 + 9] } get leftJustifiedTextSymbolIndex() { return this._structArray.int16[this._pos2 + 10] } get verticalPlacedTextSymbolIndex() { return this._structArray.int16[this._pos2 + 11] } get placedIconSymbolIndex() { return this._structArray.int16[this._pos2 + 12] } get verticalPlacedIconSymbolIndex() { return this._structArray.int16[this._pos2 + 13] } get key() { return this._structArray.uint16[this._pos2 + 14] } get textBoxStartIndex() { return this._structArray.uint16[this._pos2 + 15] } get textBoxEndIndex() { return this._structArray.uint16[this._pos2 + 16] } get verticalTextBoxStartIndex() { return this._structArray.uint16[this._pos2 + 17] } get verticalTextBoxEndIndex() { return this._structArray.uint16[this._pos2 + 18] } get iconBoxStartIndex() { return this._structArray.uint16[this._pos2 + 19] } get iconBoxEndIndex() { return this._structArray.uint16[this._pos2 + 20] } get verticalIconBoxStartIndex() { return this._structArray.uint16[this._pos2 + 21] } get verticalIconBoxEndIndex() { return this._structArray.uint16[this._pos2 + 22] } get featureIndex() { return this._structArray.uint16[this._pos2 + 23] } get numHorizontalGlyphVertices() { return this._structArray.uint16[this._pos2 + 24] } get numVerticalGlyphVertices() { return this._structArray.uint16[this._pos2 + 25] } get numIconVertices() { return this._structArray.uint16[this._pos2 + 26] } get numVerticalIconVertices() { return this._structArray.uint16[this._pos2 + 27] } get useRuntimeCollisionCircles() { return this._structArray.uint16[this._pos2 + 28] } get crossTileID() { return this._structArray.uint32[this._pos4 + 15] } set crossTileID(t) { this._structArray.uint32[this._pos4 + 15] = t; } get textOffset0() { return this._structArray.float32[this._pos4 + 16] } get textOffset1() { return this._structArray.float32[this._pos4 + 17] } get collisionCircleDiameter() { return this._structArray.float32[this._pos4 + 18] } } Da.prototype.size = 76; class Va extends Aa { get(t) { return new Da(this, t) } } Oi(Va, "SymbolInstanceArray"); class La extends Sa { getoffsetX(t) { return this.float32[1 * t + 0] } } Oi(La, "GlyphOffsetArray"); class Fa extends sa { getx(t) { return this.int16[2 * t + 0] } gety(t) { return this.int16[2 * t + 1] } } Oi(Fa, "SymbolLineVertexArray"); class Ra extends ea { 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] } get layoutVertexArrayOffset() { return this._structArray.uint16[this._pos2 + 4] } } Ra.prototype.size = 12; class ja extends Ia { get(t) { return new Ra(this, t) } } Oi(ja, "FeatureIndexArray"); class $a extends Ma { geta_centroid_pos0(t) { return this.uint16[2 * t + 0] } geta_centroid_pos1(t) { return this.uint16[2 * t + 1] } } Oi($a, "FillExtrusionCentroidArray"); const Ua = na([{ name: "a_pattern", components: 4, type: "Uint16" }, { name: "a_pixel_ratio", components: 1, type: "Float32" }]), Oa = na([{ name: "a_dash", components: 4, type: "Uint16" }]); var qa = {}, Na = { get exports() { return qa }, set exports(t) { qa = t; } }, Ga = {}; ({ get exports() { return Ga }, set exports(t) { Ga = t; } }).exports = function(t, e) { var r, n, i, s, a, o, l, u; for (n = t.length - (r = 3 & t.length), i = e, a = 3432918353, o = 461845907, u = 0; u < n;) l = 255 & t.charCodeAt(u) | (255 & t.charCodeAt(++u)) << 8 | (255 & t.charCodeAt(++u)) << 16 | (255 & t.charCodeAt(++u)) << 24, ++u, i = 27492 + (65535 & (s = 5 * (65535 & (i = (i ^= l = (65535 & (l = (l = (65535 & l) * a + (((l >>> 16) * a & 65535) << 16) & 4294967295) << 15 | l >>> 17)) * o + (((l >>> 16) * o & 65535) << 16) & 4294967295) << 13 | i >>> 19)) + ((5 * (i >>> 16) & 65535) << 16) & 4294967295)) + ((58964 + (s >>> 16) & 65535) << 16); switch (l = 0, r) { case 3: l ^= (255 & t.charCodeAt(u + 2)) << 16; case 2: l ^= (255 & t.charCodeAt(u + 1)) << 8; case 1: i ^= l = (65535 & (l = (l = (65535 & (l ^= 255 & t.charCodeAt(u))) * a + (((l >>> 16) * a & 65535) << 16) & 4294967295) << 15 | l >>> 17)) * o + (((l >>> 16) * o & 65535) << 16) & 4294967295; } return i ^= t.length, i = 2246822507 * (65535 & (i ^= i >>> 16)) + ((2246822507 * (i >>> 16) & 65535) << 16) & 4294967295, i = 3266489909 * (65535 & (i ^= i >>> 13)) + ((3266489909 * (i >>> 16) & 65535) << 16) & 4294967295, (i ^= i >>> 16) >>> 0 }; var Za = {}; ({ get exports() { return Za }, set exports(t) { Za = t; } }).exports = function(t, e) { for (var r, n = t.length, i = e ^ n, s = 0; n >= 4;) r = 1540483477 * (65535 & (r = 255 & t.charCodeAt(s) | (255 & t.charCodeAt(++s)) << 8 | (255 & t.charCodeAt(++s)) << 16 | (255 & t.charCodeAt(++s)) << 24)) + ((1540483477 * (r >>> 16) & 65535) << 16), i = 1540483477 * (65535 & i) + ((1540483477 * (i >>> 16) & 65535) << 16) ^ (r = 1540483477 * (65535 & (r ^= r >>> 24)) + ((1540483477 * (r >>> 16) & 65535) << 16)), n -= 4, ++s; switch (n) { case 3: i ^= (255 & t.charCodeAt(s + 2)) << 16; case 2: i ^= (255 & t.charCodeAt(s + 1)) << 8; case 1: i = 1540483477 * (65535 & (i ^= 255 & t.charCodeAt(s))) + ((1540483477 * (i >>> 16) & 65535) << 16); } return i = 1540483477 * (65535 & (i ^= i >>> 13)) + ((1540483477 * (i >>> 16) & 65535) << 16), (i ^= i >>> 15) >>> 0 }; var Xa = Ga, Ka = Za; Na.exports = Xa, qa.murmur3 = Xa, qa.murmur2 = Ka; class Ya { constructor() { this.ids = [], this.positions = [], this.indexed = !1; } add(t, e, r, n) { this.ids.push(Ha(t)), this.positions.push(e, r, n); } getPositions(t) { const e = Ha(t); let r = 0, n = this.ids.length - 1; for (; r < n;) { const t = r + n >> 1; this.ids[t] >= e ? n = t : r = t + 1; } const i = []; for (; this.ids[r] === e;) i.push({ index: this.positions[3 * r], start: this.positions[3 * r + 1], end: this.positions[3 * r + 2] }), r++; return i } static serialize(t, e) { const r = new Float64Array(t.ids), n = new Uint32Array(t.positions); return Wa(r, n, 0, r.length - 1), e && e.push(r.buffer, n.buffer), { ids: r, positions: n } } static deserialize(t) { const e = new Ya; return e.ids = t.ids, e.positions = t.positions, e.indexed = !0, e } } function Ha(t) { const e = +t; return !isNaN(e) && Number.MIN_SAFE_INTEGER <= e && e <= Number.MAX_SAFE_INTEGER ? e : qa(String(t)) } function Wa(t, e, r, n) { for (; r < n;) { const i = t[r + n >> 1]; let s = r - 1, a = n + 1; for (;;) { do { s++; } while (t[s] < i); do { a--; } while (t[a] > i); if (s >= a) break; Ja(t, s, a), Ja(e, 3 * s, 3 * a), Ja(e, 3 * s + 1, 3 * a + 1), Ja(e, 3 * s + 2, 3 * a + 2); } a - r < n - a ? (Wa(t, e, r, a), r = a + 1) : (Wa(t, e, a + 1, n), n = a); } } function Ja(t, e, r) { const n = t[e]; t[e] = t[r], t[r] = n; } Oi(Ya, "FeaturePositionMap"); class Qa { constructor(t) { this.gl = t.gl, this.initialized = !1; } fetchUniformLocation(t, e) { return this.location || this.initialized || (this.location = this.gl.getUniformLocation(t, e), this.initialized = !0), !!this.location } } class to extends Qa { constructor(t) { super(t), this.current = 0; } set(t, e, r) { this.fetchUniformLocation(t, e) && this.current !== r && (this.current = r, this.gl.uniform1f(this.location, r)); } } class eo extends Qa { constructor(t) { super(t), this.current = [0, 0, 0, 0]; } set(t, e, r) { this.fetchUniformLocation(t, e) && (r[0] === this.current[0] && r[1] === this.current[1] && r[2] === this.current[2] && r[3] === this.current[3] || (this.current = r, this.gl.uniform4f(this.location, r[0], r[1], r[2], r[3]))); } } class ro extends Qa { constructor(t) { super(t), this.current = Me.transparent; } set(t, e, r) { this.fetchUniformLocation(t, e) && (r.r === this.current.r && r.g === this.current.g && r.b === this.current.b && r.a === this.current.a || (this.current = r, this.gl.uniform4f(this.location, r.r, r.g, r.b, r.a))); } } const no = new Float32Array(16), io = new Float32Array(9), so = new Float32Array(4); function ao(t) { return [Qs(255 * t.r, 255 * t.g), Qs(255 * t.b, 255 * t.a)] } class oo { constructor(t, e, r) { this.value = t, this.uniformNames = e.map((t => `u_${t}`)), this.type = r; } setUniform(t, e, r, n, i) { e.set(t, i, n.constantOr(this.value)); } getBinding(t, e) { return "color" === this.type ? new ro(t) : new to(t) } } class lo { constructor(t, e) { this.uniformNames = e.map((t => `u_${t}`)), this.pattern = null, this.pixelRatio = 1; } setConstantPatternPositions(t) { this.pixelRatio = t.pixelRatio || 1, this.pattern = t.tl.concat(t.br); } setUniform(t, e, r, n, i) { const s = "u_pattern" === i || "u_dash" === i ? this.pattern : "u_pixel_ratio" === i ? this.pixelRatio : null; s && e.set(t, i, s); } getBinding(t, e) { return "u_pattern" === e || "u_dash" === e ? new eo(t) : new to(t) } } class uo { constructor(t, e, r, n) { this.expression = t, this.type = r, this.maxValue = 0, this.paintVertexAttributes = e.map((t => ({ name: `a_${t}`, type: "Float32", components: "color" === r ? 2 : 1, offset: 0 }))), this.paintVertexArray = new n; } populatePaintArray(t, e, r, n, i, s) { const a = this.paintVertexArray.length, o = this.expression.evaluate(new $s(0), e, {}, i, n, s); this.paintVertexArray.resize(t), this._setPaintValue(a, t, o); } updatePaintArray(t, e, r, n, i) { const s = this.expression.evaluate({ zoom: 0 }, r, n, void 0, i); this._setPaintValue(t, e, s); } _setPaintValue(t, e, r) { if ("color" === this.type) { const n = ao(r); for (let r = t; r < e; r++) this.paintVertexArray.emplace(r, n[0], n[1]); } else { for (let n = t; n < e; n++) this.paintVertexArray.emplace(n, r); this.maxValue = Math.max(this.maxValue, Math.abs(r)); } } upload(t) { this.paintVertexArray && this.paintVertexArray.arrayBuffer && (this.paintVertexBuffer && this.paintVertexBuffer.buffer ? this.paintVertexBuffer.updateData(this.paintVertexArray) : this.paintVertexBuffer = t.createVertexBuffer(this.paintVertexArray, this.paintVertexAttributes, this.expression.isStateDependent)); } destroy() { this.paintVertexBuffer && this.paintVertexBuffer.destroy(); } } class co { constructor(t, e, r, n, i, s) { this.expression = t, this.uniformNames = e.map((t => `u_${t}_t`)), this.type = r, this.useIntegerZoom = n, this.zoom = i, this.maxValue = 0, this.paintVertexAttributes = e.map((t => ({ name: `a_${t}`, type: "Float32", components: "color" === r ? 4 : 2, offset: 0 }))), this.paintVertexArray = new s; } populatePaintArray(t, e, r, n, i, s) { const a = this.expression.evaluate(new $s(this.zoom), e, {}, i, n, s), o = this.expression.evaluate(new $s(this.zoom + 1), e, {}, i, n, s), l = this.paintVertexArray.length; this.paintVertexArray.resize(t), this._setPaintValue(l, t, a, o); } updatePaintArray(t, e, r, n, i) { const s = this.expression.evaluate({ zoom: this.zoom }, r, n, void 0, i), a = this.expression.evaluate({ zoom: this.zoom + 1 }, r, n, void 0, i); this._setPaintValue(t, e, s, a); } _setPaintValue(t, e, r, n) { if ("color" === this.type) { const i = ao(r), s = ao(n); for (let r = t; r < e; r++) this.paintVertexArray.emplace(r, i[0], i[1], s[0], s[1]); } else { for (let i = t; i < e; i++) this.paintVertexArray.emplace(i, r, n); this.maxValue = Math.max(this.maxValue, Math.abs(r), Math.abs(n)); } } upload(t) { this.paintVertexArray && this.paintVertexArray.arrayBuffer && (this.paintVertexBuffer && this.paintVertexBuffer.buffer ? this.paintVertexBuffer.updateData(this.paintVertexArray) : this.paintVertexBuffer = t.createVertexBuffer(this.paintVertexArray, this.paintVertexAttributes, this.expression.isStateDependent)); } destroy() { this.paintVertexBuffer && this.paintVertexBuffer.destroy(); } setUniform(t, e, r, n, i) { const s = this.useIntegerZoom ? Math.floor(r.zoom) : r.zoom, a = S(this.expression.interpolationFactor(s, this.zoom, this.zoom + 1), 0, 1); e.set(t, i, a); } getBinding(t, e) { return new to(t) } } class ho { constructor(t, e, r, n, i) { this.expression = t, this.layerId = i, this.paintVertexAttributes = ("array" === r ? Oa : Ua).members; for (let t = 0; t < e.length; ++t); this.paintVertexArray = new n; } populatePaintArray(t, e, r) { const n = this.paintVertexArray.length; this.paintVertexArray.resize(t), this._setPaintValues(n, t, e.patterns && e.patterns[this.layerId], r); } updatePaintArray(t, e, r, n, i, s) { this._setPaintValues(t, e, r.patterns && r.patterns[this.layerId], s); } _setPaintValues(t, e, r, n) { if (!n || !r) return; const i = n[r]; if (!i) return; const { tl: s, br: a, pixelRatio: o } = i; for (let r = t; r < e; r++) this.paintVertexArray.emplace(r, s[0], s[1], a[0], a[1], o); } upload(t) { this.paintVertexArray && this.paintVertexArray.arrayBuffer && (this.paintVertexBuffer = t.createVertexBuffer(this.paintVertexArray, this.paintVertexAttributes, this.expression.isStateDependent)); } destroy() { this.paintVertexBuffer && this.paintVertexBuffer.destroy(); } } class po { constructor(t, e, r = (() => !0)) { this.binders = {}, this._buffers = []; const n = []; for (const i in t.paint._values) { if (!r(i)) continue; const s = t.paint.get(i); if (!(s instanceof Xs && En(s.property.specification))) continue; const a = mo(i, t.type), o = s.value, l = s.property.specification.type, u = !!s.property.useIntegerZoom, c = "line-dasharray" === i || i.endsWith("pattern"), h = "line-dasharray" === i && "constant" !== t.layout.get("line-cap").value.kind; if ("constant" !== o.kind || h) if ("source" === o.kind || h || c) { const e = vo(i, l, "source"); this.binders[i] = c ? new ho(o, a, l, e, t.id) : new uo(o, a, l, e), n.push(`/a_${i}`); } else { const t = vo(i, l, "composite"); this.binders[i] = new co(o, a, l, u, e, t), n.push(`/z_${i}`); } else this.binders[i] = c ? new lo(o.value, a) : new oo(o.value, a, l), n.push(`/u_${i}`); } this.cacheKey = n.sort().join(""); } getMaxValue(t) { const e = this.binders[t]; return e instanceof uo || e instanceof co ? e.maxValue : 0 } populatePaintArrays(t, e, r, n, i, s) { for (const a in this.binders) { const o = this.binders[a]; (o instanceof uo || o instanceof co || o instanceof ho) && o.populatePaintArray(t, e, r, n, i, s); } } setConstantPatternPositions(t) { for (const e in this.binders) { const r = this.binders[e]; r instanceof lo && r.setConstantPatternPositions(t); } } updatePaintArrays(t, e, r, n, i, s) { let a = !1; for (const o in t) { const l = e.getPositions(o); for (const e of l) { const l = r.feature(e.index); for (const r in this.binders) { const u = this.binders[r]; if ((u instanceof uo || u instanceof co || u instanceof ho) && !0 === u.expression.isStateDependent) { const c = n.paint.get(r); u.expression = c.value, u.updatePaintArray(e.start, e.end, l, t[o], i, s), a = !0; } } } } return a } defines() { const t = []; for (const e in this.binders) { const r = this.binders[e]; (r instanceof oo || r instanceof lo) && t.push(...r.uniformNames.map((t => `#define HAS_UNIFORM_${t}`))); } return t } getBinderAttributes() { const t = []; for (const e in this.binders) { const r = this.binders[e]; if (r instanceof uo || r instanceof co || r instanceof ho) for (let e = 0; e < r.paintVertexAttributes.length; e++) t.push(r.paintVertexAttributes[e].name); } return t } getBinderUniforms() { const t = []; for (const e in this.binders) { const r = this.binders[e]; if (r instanceof oo || r instanceof lo || r instanceof co) for (const e of r.uniformNames) t.push(e); } return t } getPaintVertexBuffers() { return this._buffers } getUniforms(t) { const e = []; for (const r in this.binders) { const n = this.binders[r]; if (n instanceof oo || n instanceof lo || n instanceof co) for (const i of n.uniformNames) e.push({ name: i, property: r, binding: n.getBinding(t, i) }); } return e } setUniforms(t, e, r, n, i) { for (const { name: e, property: s, binding: a } of r) this.binders[s].setUniform(t, a, i, n.get(s), e); } updatePaintBuffers() { this._buffers = []; for (const t in this.binders) { const e = this.binders[t]; (e instanceof uo || e instanceof co || e instanceof ho) && e.paintVertexBuffer && this._buffers.push(e.paintVertexBuffer); } } upload(t) { for (const e in this.binders) { const r = this.binders[e]; (r instanceof uo || r instanceof co || r instanceof ho) && r.upload(t); } this.updatePaintBuffers(); } destroy() { for (const t in this.binders) { const e = this.binders[t]; (e instanceof uo || e instanceof co || e instanceof ho) && e.destroy(); } } } class fo { constructor(t, e, r = (() => !0)) { this.programConfigurations = {}; for (const n of t) this.programConfigurations[n.id] = new po(n, e, r); this.needsUpload = !1, this._featureMap = new Ya, this._bufferOffset = 0; } populatePaintArrays(t, e, r, n, i, s, a) { for (const r in this.programConfigurations) this.programConfigurations[r].populatePaintArrays(t, e, n, i, s, a); void 0 !== e.id && this._featureMap.add(e.id, r, this._bufferOffset, t), this._bufferOffset = t, this.needsUpload = !0; } updatePaintArrays(t, e, r, n, i) { for (const s of r) this.needsUpload = this.programConfigurations[s.id].updatePaintArrays(t, this._featureMap, e, s, n, i) || this.needsUpload; } get(t) { return this.programConfigurations[t] } upload(t) { if (this.needsUpload) { for (const e in this.programConfigurations) this.programConfigurations[e].upload(t); this.needsUpload = !1; } } destroy() { for (const t in this.programConfigurations) this.programConfigurations[t].destroy(); } } const yo = { "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", "pixel_ratio"], "fill-pattern": ["pattern", "pixel_ratio"], "fill-extrusion-pattern": ["pattern", "pixel_ratio"], "line-dasharray": ["dash"] }; function mo(t, e) { return yo[t] || [t.replace(`${e}-`, "").replace(/-/g, "_")] } const go = { "line-pattern": { source: ca, composite: ca }, "fill-pattern": { source: ca, composite: ca }, "fill-extrusion-pattern": { source: ca, composite: ca }, "line-dasharray": { source: ha, composite: ha } }, xo = { color: { source: za, composite: ua }, number: { source: Sa, composite: za } }; function vo(t, e, r) { const n = go[t]; return n && n[r] || xo[e][r] } Oi(oo, "ConstantBinder"), Oi(lo, "PatternConstantBinder"), Oi(uo, "SourceExpressionBinder"), Oi(ho, "PatternCompositeBinder"), Oi(co, "CompositeExpressionBinder"), Oi(po, "ProgramConfiguration", { omit: ["_buffers"] }), Oi(fo, "ProgramConfigurationSet"); const bo = "-transition"; class wo extends Yt { constructor(t, e) { if (super(), this.id = t.id, this.type = t.type, this._featureFilter = { filter: () => !0, needGeometry: !1, needFeature: !1 }, this._filterCompiled = !1, "custom" !== t.type && (this.metadata = t.metadata, this.minzoom = t.minzoom, this.maxzoom = t.maxzoom, "background" !== t.type && "sky" !== t.type && (this.source = t.source, this.sourceLayer = t["source-layer"], this.filter = t.filter), e.layout && (this._unevaluatedLayout = new Zs(e.layout)), e.paint)) { this._transitionablePaint = new qs(e.paint); for (const e in t.paint) this.setPaintProperty(e, t.paint[e], { validate: !1 }); for (const e in t.layout) this.setLayoutProperty(e, t.layout[e], { validate: !1 }); this._transitioningPaint = this._transitionablePaint.untransitioned(), this.paint = new Ks(e.paint); } } getLayoutProperty(t) { return "visibility" === t ? this.visibility : this._unevaluatedLayout.getValue(t) } setLayoutProperty(t, e, r = {}) { null != e && this._validate(Li, `layers.${this.id}.layout.${t}`, t, e, r) || ("visibility" !== t ? this._unevaluatedLayout.setValue(t, e) : this.visibility = e); } getPaintProperty(t) { return L(t, bo) ? this._transitionablePaint.getTransition(t.slice(0, -bo.length)) : this._transitionablePaint.getValue(t) } setPaintProperty(t, e, r = {}) { if (null != e && this._validate(Vi, `layers.${this.id}.paint.${t}`, t, e, r)) return !1; if (L(t, bo)) return this._transitionablePaint.setTransition(t.slice(0, -bo.length), e || void 0), !1; { const r = this._transitionablePaint._values[t], n = r.value.isDataDriven(), i = r.value; this._transitionablePaint.setValue(t, e), this._handleSpecialPaintPropertyUpdate(t); const s = this._transitionablePaint._values[t].value, a = s.isDataDriven(), o = L(t, "pattern") || "line-dasharray" === t; return a || n || o || this._handleOverridablePaintPropertyUpdate(t, i, s) } } _handleSpecialPaintPropertyUpdate(t) {} getProgramIds() { return null } getProgramConfiguration(t) { return null } _handleOverridablePaintPropertyUpdate(t, e, r) { return !1 } isHidden(t) { return !!(this.minzoom && t < this.minzoom) || !!(this.maxzoom && t >= this.maxzoom) || "none" === this.visibility } updateTransitions(t) { this._transitioningPaint = this._transitionablePaint.transitioned(t, this._transitioningPaint); } hasTransition() { return this._transitioningPaint.hasTransition() } recalculate(t, e) { this._unevaluatedLayout && (this.layout = this._unevaluatedLayout.possiblyEvaluate(t, void 0, e)), this.paint = this._transitioningPaint.possiblyEvaluate(t, void 0, e); } serialize() { const t = { 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 && (t.layout = t.layout || {}, t.layout.visibility = this.visibility), R(t, ((t, e) => !(void 0 === t || "layout" === e && !Object.keys(t).length || "paint" === e && !Object.keys(t).length))) } _validate(t, e, r, n, i = {}) { return (!i || !1 !== i.validate) && Ri(this, t.call(Di, { key: e, layerType: this.type, objectKey: r, value: n, styleSpec: Ht, style: { glyphs: !0, sprite: !0 } })) } is3D() { return !1 } isSky() { return !1 } isTileClipped() { return !1 } hasOffscreenPass() { return !1 } resize() {} isStateDependent() { for (const t in this.paint._values) { const e = this.paint.get(t); if (e instanceof Xs && En(e.property.specification) && ("source" === e.value.kind || "composite" === e.value.kind) && e.value.isStateDependent) return !0 } return !1 } compileFilter() { this._filterCompiled || (this._featureFilter = ai(this.filter), this._filterCompiled = !0); } invalidateCompiledFilter() { this._filterCompiled = !1; } dynamicFilter() { return this._featureFilter.dynamicFilter } dynamicFilterNeedsFeature() { return this._featureFilter.needFeature } } const _o = na([{ name: "a_pos", components: 2, type: "Int16" }], 4), Ao = na([{ name: "a_pos_3", components: 3, type: "Int16" }, { name: "a_pos_normal_3", components: 3, type: "Int16" }]); class So { constructor(t = []) { this.segments = t; } prepareSegment(t, e, r, n) { let i = this.segments[this.segments.length - 1]; return t > So.MAX_VERTEX_ARRAY_LENGTH && U(`Max vertices per segment is ${So.MAX_VERTEX_ARRAY_LENGTH}: bucket requested ${t}`), (!i || i.vertexLength + t > So.MAX_VERTEX_ARRAY_LENGTH || i.sortKey !== n) && (i = { vertexOffset: e.length, primitiveOffset: r.length, vertexLength: 0, primitiveLength: 0 }, void 0 !== n && (i.sortKey = n), this.segments.push(i)), i } get() { return this.segments } destroy() { for (const t of this.segments) for (const e in t.vaos) t.vaos[e].destroy(); } static simpleSegment(t, e, r, n) { return new So([{ vertexOffset: t, primitiveOffset: e, vertexLength: r, primitiveLength: n, vaos: {}, sortKey: 0 }]) } } So.MAX_VERTEX_ARRAY_LENGTH = Math.pow(2, 16) - 1, Oi(So, "SegmentVector"); var ko = 8192; class Io { constructor(t, e) { t && (e ? this.setSouthWest(t).setNorthEast(e) : 4 === t.length ? this.setSouthWest([t[0], t[1]]).setNorthEast([t[2], t[3]]) : this.setSouthWest(t[0]).setNorthEast(t[1])); } setNorthEast(t) { return this._ne = t instanceof ru ? new ru(t.lng, t.lat) : ru.convert(t), this } setSouthWest(t) { return this._sw = t instanceof ru ? new ru(t.lng, t.lat) : ru.convert(t), this } extend(t) { const e = this._sw, r = this._ne; let n, i; if (t instanceof ru) n = t, i = t; else { if (!(t instanceof Io)) return Array.isArray(t) ? 4 === t.length || t.every(Array.isArray) ? this.extend(Io.convert(t)) : this.extend(ru.convert(t)) : "object" == typeof t && null !== t && t.hasOwnProperty("lat") && (t.hasOwnProperty("lon") || t.hasOwnProperty("lng")) ? this.extend(ru.convert(t)) : this; if (n = t._sw, i = t._ne, !n || !i) return this } return e || r ? (e.lng = Math.min(n.lng, e.lng), e.lat = Math.min(n.lat, e.lat), r.lng = Math.max(i.lng, r.lng), r.lat = Math.max(i.lat, r.lat)) : (this._sw = new ru(n.lng, n.lat), this._ne = new ru(i.lng, i.lat)), this } getCenter() { return new ru((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 ru(this.getWest(), this.getNorth()) } getSouthEast() { return new ru(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(t) { const { lng: e, lat: r } = ru.convert(t); let n = this._sw.lng <= e && e <= this._ne.lng; return this._sw.lng > this._ne.lng && (n = this._sw.lng >= e && e >= this._ne.lng), this._sw.lat <= r && r <= this._ne.lat && n } static convert(t) { return !t || t instanceof Io ? t : new Io(t) } } var Mo = 1e-6, To = "undefined" != typeof Float32Array ? Float32Array : Array; function zo() { var t = new To(9); return To != Float32Array && (t[1] = 0, t[2] = 0, t[3] = 0, t[5] = 0, t[6] = 0, t[7] = 0), t[0] = 1, t[4] = 1, t[8] = 1, t } function Bo(t, e, r) { var n = e[0], i = e[1], s = e[2], a = e[3], o = e[4], l = e[5], u = e[6], c = e[7], h = e[8], p = r[0], f = r[1], d = r[2], y = r[3], m = r[4], g = r[5], x = r[6], v = r[7], b = r[8]; return t[0] = p * n + f * a + d * u, t[1] = p * i + f * o + d * c, t[2] = p * s + f * l + d * h, t[3] = y * n + m * a + g * u, t[4] = y * i + m * o + g * c, t[5] = y * s + m * l + g * h, t[6] = x * n + v * a + b * u, t[7] = x * i + v * o + b * c, t[8] = x * s + v * l + b * h, t } function Eo(t) { return t[0] = 1, t[1] = 0, t[2] = 0, t[3] = 0, t[4] = 0, t[5] = 1, t[6] = 0, t[7] = 0, t[8] = 0, t[9] = 0, t[10] = 1, t[11] = 0, t[12] = 0, t[13] = 0, t[14] = 0, t[15] = 1, t } function Co(t, e) { var r = e[0], n = e[1], i = e[2], s = e[3], a = e[4], o = e[5], l = e[6], u = e[7], c = e[8], h = e[9], p = e[10], f = e[11], d = e[12], y = e[13], m = e[14], g = e[15], x = r * o - n * a, v = r * l - i * a, b = r * u - s * a, w = n * l - i * o, _ = n * u - s * o, A = i * u - s * l, S = c * y - h * d, k = c * m - p * d, I = c * g - f * d, M = h * m - p * y, T = h * g - f * y, z = p * g - f * m, B = x * z - v * T + b * M + w * I - _ * k + A * S; return B ? (t[0] = (o * z - l * T + u * M) * (B = 1 / B), t[1] = (i * T - n * z - s * M) * B, t[2] = (y * A - m * _ + g * w) * B, t[3] = (p * _ - h * A - f * w) * B, t[4] = (l * I - a * z - u * k) * B, t[5] = (r * z - i * I + s * k) * B, t[6] = (m * b - d * A - g * v) * B, t[7] = (c * A - p * b + f * v) * B, t[8] = (a * T - o * I + u * S) * B, t[9] = (n * I - r * T - s * S) * B, t[10] = (d * _ - y * b + g * x) * B, t[11] = (h * b - c * _ - f * x) * B, t[12] = (o * k - a * M - l * S) * B, t[13] = (r * M - n * k + i * S) * B, t[14] = (y * v - d * w - m * x) * B, t[15] = (c * w - h * v + p * x) * B, t) : null } function Po(t, e, r) { var n = e[0], i = e[1], s = e[2], a = e[3], o = e[4], l = e[5], u = e[6], c = e[7], h = e[8], p = e[9], f = e[10], d = e[11], y = e[12], m = e[13], g = e[14], x = e[15], v = r[0], b = r[1], w = r[2], _ = r[3]; return t[0] = v * n + b * o + w * h + _ * y, t[1] = v * i + b * l + w * p + _ * m, t[2] = v * s + b * u + w * f + _ * g, t[3] = v * a + b * c + w * d + _ * x, t[4] = (v = r[4]) * n + (b = r[5]) * o + (w = r[6]) * h + (_ = r[7]) * y, t[5] = v * i + b * l + w * p + _ * m, t[6] = v * s + b * u + w * f + _ * g, t[7] = v * a + b * c + w * d + _ * x, t[8] = (v = r[8]) * n + (b = r[9]) * o + (w = r[10]) * h + (_ = r[11]) * y, t[9] = v * i + b * l + w * p + _ * m, t[10] = v * s + b * u + w * f + _ * g, t[11] = v * a + b * c + w * d + _ * x, t[12] = (v = r[12]) * n + (b = r[13]) * o + (w = r[14]) * h + (_ = r[15]) * y, t[13] = v * i + b * l + w * p + _ * m, t[14] = v * s + b * u + w * f + _ * g, t[15] = v * a + b * c + w * d + _ * x, t } function Do(t, e, r) { var n, i, s, a, o, l, u, c, h, p, f, d, y = r[0], m = r[1], g = r[2]; return e === t ? (t[12] = e[0] * y + e[4] * m + e[8] * g + e[12], t[13] = e[1] * y + e[5] * m + e[9] * g + e[13], t[14] = e[2] * y + e[6] * m + e[10] * g + e[14], t[15] = e[3] * y + e[7] * m + e[11] * g + e[15]) : (i = e[1], s = e[2], a = e[3], o = e[4], l = e[5], u = e[6], c = e[7], h = e[8], p = e[9], f = e[10], d = e[11], t[0] = n = e[0], t[1] = i, t[2] = s, t[3] = a, t[4] = o, t[5] = l, t[6] = u, t[7] = c, t[8] = h, t[9] = p, t[10] = f, t[11] = d, t[12] = n * y + o * m + h * g + e[12], t[13] = i * y + l * m + p * g + e[13], t[14] = s * y + u * m + f * g + e[14], t[15] = a * y + c * m + d * g + e[15]), t } function Vo(t, e, r) { var n = r[0], i = r[1], s = r[2]; return t[0] = e[0] * n, t[1] = e[1] * n, t[2] = e[2] * n, t[3] = e[3] * n, t[4] = e[4] * i, t[5] = e[5] * i, t[6] = e[6] * i, t[7] = e[7] * i, t[8] = e[8] * s, t[9] = e[9] * s, t[10] = e[10] * s, t[11] = e[11] * s, t[12] = e[12], t[13] = e[13], t[14] = e[14], t[15] = e[15], t } function Lo(t, e, r) { var n = Math.sin(r), i = Math.cos(r), s = e[4], a = e[5], o = e[6], l = e[7], u = e[8], c = e[9], h = e[10], p = e[11]; return e !== t && (t[0] = e[0], t[1] = e[1], t[2] = e[2], t[3] = e[3], t[12] = e[12], t[13] = e[13], t[14] = e[14], t[15] = e[15]), t[4] = s * i + u * n, t[5] = a * i + c * n, t[6] = o * i + h * n, t[7] = l * i + p * n, t[8] = u * i - s * n, t[9] = c * i - a * n, t[10] = h * i - o * n, t[11] = p * i - l * n, t } function Fo(t, e, r) { var n = Math.sin(r), i = Math.cos(r), s = e[0], a = e[1], o = e[2], l = e[3], u = e[8], c = e[9], h = e[10], p = e[11]; return e !== t && (t[4] = e[4], t[5] = e[5], t[6] = e[6], t[7] = e[7], t[12] = e[12], t[13] = e[13], t[14] = e[14], t[15] = e[15]), t[0] = s * i - u * n, t[1] = a * i - c * n, t[2] = o * i - h * n, t[3] = l * i - p * n, t[8] = s * n + u * i, t[9] = a * n + c * i, t[10] = o * n + h * i, t[11] = l * n + p * i, t } function Ro(t, e) { return t[0] = e[0], t[1] = 0, t[2] = 0, t[3] = 0, t[4] = 0, t[5] = e[1], t[6] = 0, t[7] = 0, t[8] = 0, t[9] = 0, t[10] = e[2], t[11] = 0, t[12] = 0, t[13] = 0, t[14] = 0, t[15] = 1, t } function jo(t, e, r) { var n, i, s, a = r[0], o = r[1], l = r[2], u = Math.hypot(a, o, l); return u < Mo ? null : (a *= u = 1 / u, o *= u, l *= u, n = Math.sin(e), i = Math.cos(e), t[0] = a * a * (s = 1 - i) + i, t[1] = o * a * s + l * n, t[2] = l * a * s - o * n, t[3] = 0, t[4] = a * o * s - l * n, t[5] = o * o * s + i, t[6] = l * o * s + a * n, t[7] = 0, t[8] = a * l * s + o * n, t[9] = o * l * s - a * n, t[10] = l * l * s + i, t[11] = 0, t[12] = 0, t[13] = 0, t[14] = 0, t[15] = 1, t) } Math.hypot || (Math.hypot = function() { for (var t = 0, e = arguments.length; e--;) t += arguments[e] * arguments[e]; return Math.sqrt(t) }); var $o = Po; function Uo() { var t = new To(3); return To != Float32Array && (t[0] = 0, t[1] = 0, t[2] = 0), t } function Oo(t) { var e = new To(3); return e[0] = t[0], e[1] = t[1], e[2] = t[2], e } function qo(t) { return Math.hypot(t[0], t[1], t[2]) } function No(t, e, r) { var n = new To(3); return n[0] = t, n[1] = e, n[2] = r, n } function Go(t, e, r) { return t[0] = e[0] + r[0], t[1] = e[1] + r[1], t[2] = e[2] + r[2], t } function Zo(t, e, r) { return t[0] = e[0] - r[0], t[1] = e[1] - r[1], t[2] = e[2] - r[2], t } function Xo(t, e, r) { return t[0] = e[0] * r[0], t[1] = e[1] * r[1], t[2] = e[2] * r[2], t } function Ko(t, e, r) { return t[0] = Math.min(e[0], r[0]), t[1] = Math.min(e[1], r[1]), t[2] = Math.min(e[2], r[2]), t } function Yo(t, e, r) { return t[0] = Math.max(e[0], r[0]), t[1] = Math.max(e[1], r[1]), t[2] = Math.max(e[2], r[2]), t } function Ho(t, e, r) { return t[0] = e[0] * r, t[1] = e[1] * r, t[2] = e[2] * r, t } function Wo(t, e, r, n) { return t[0] = e[0] + r[0] * n, t[1] = e[1] + r[1] * n, t[2] = e[2] + r[2] * n, t } function Jo(t, e) { var r = e[0], n = e[1], i = e[2], s = r * r + n * n + i * i; return s > 0 && (s = 1 / Math.sqrt(s)), t[0] = e[0] * s, t[1] = e[1] * s, t[2] = e[2] * s, t } function Qo(t, e) { return t[0] * e[0] + t[1] * e[1] + t[2] * e[2] } function tl(t, e, r) { var n = e[0], i = e[1], s = e[2], a = r[0], o = r[1], l = r[2]; return t[0] = i * l - s * o, t[1] = s * a - n * l, t[2] = n * o - i * a, t } function el(t, e, r) { var n = e[0], i = e[1], s = e[2], a = r[3] * n + r[7] * i + r[11] * s + r[15]; return t[0] = (r[0] * n + r[4] * i + r[8] * s + r[12]) / (a = a || 1), t[1] = (r[1] * n + r[5] * i + r[9] * s + r[13]) / a, t[2] = (r[2] * n + r[6] * i + r[10] * s + r[14]) / a, t } function rl(t, e, r) { var n = r[0], i = r[1], s = r[2], a = e[0], o = e[1], l = e[2], u = i * l - s * o, c = s * a - n * l, h = n * o - i * a, p = i * h - s * c, f = s * u - n * h, d = n * c - i * u, y = 2 * r[3]; return c *= y, h *= y, f *= 2, d *= 2, t[0] = a + (u *= y) + (p *= 2), t[1] = o + c + f, t[2] = l + h + d, t } var nl, il = Zo, sl = Xo, al = qo; function ol(t, e, r) { return t[0] = e[0] * r, t[1] = e[1] * r, t[2] = e[2] * r, t[3] = e[3] * r, t } function ll(t, e) { var r = e[0], n = e[1], i = e[2], s = e[3], a = r * r + n * n + i * i + s * s; return a > 0 && (a = 1 / Math.sqrt(a)), t[0] = r * a, t[1] = n * a, t[2] = i * a, t[3] = s * a, t } function ul(t, e, r) { var n = e[0], i = e[1], s = e[2], a = e[3]; return t[0] = r[0] * n + r[4] * i + r[8] * s + r[12] * a, t[1] = r[1] * n + r[5] * i + r[9] * s + r[13] * a, t[2] = r[2] * n + r[6] * i + r[10] * s + r[14] * a, t[3] = r[3] * n + r[7] * i + r[11] * s + r[15] * a, t } function cl() { var t = new To(4); return To != Float32Array && (t[0] = 0, t[1] = 0, t[2] = 0), t[3] = 1, t } function hl(t) { return t[0] = 0, t[1] = 0, t[2] = 0, t[3] = 1, t } function pl(t, e, r) { r *= .5; var n = e[0], i = e[1], s = e[2], a = e[3], o = Math.sin(r), l = Math.cos(r); return t[0] = n * l + a * o, t[1] = i * l + s * o, t[2] = s * l - i * o, t[3] = a * l - n * o, t } function fl(t, e, r) { r *= .5; var n = e[0], i = e[1], s = e[2], a = e[3], o = Math.sin(r), l = Math.cos(r); return t[0] = n * l - s * o, t[1] = i * l + a * o, t[2] = s * l + n * o, t[3] = a * l - i * o, t } Uo(), nl = new To(4), To != Float32Array && (nl[0] = 0, nl[1] = 0, nl[2] = 0, nl[3] = 0); var dl = ll; Uo(), No(1, 0, 0), No(0, 1, 0), cl(), cl(), zo(); const yl = na([{ type: "Float32", name: "a_globe_pos", components: 3 }, { type: "Float32", name: "a_uv", components: 2 }]), { members: ml } = yl, gl = na([{ name: "a_pos_3", components: 3, type: "Int16" }]); var xl = na([{ name: "a_pos", type: "Int16", components: 2 }]); class vl { constructor(t, e) { this.pos = t, this.dir = e; } intersectsPlane(t, e, r) { const n = Qo(e, this.dir); if (Math.abs(n) < 1e-6) return !1; const i = ((t[0] - this.pos[0]) * e[0] + (t[1] - this.pos[1]) * e[1] + (t[2] - this.pos[2]) * e[2]) / n; return r[0] = this.pos[0] + this.dir[0] * i, r[1] = this.pos[1] + this.dir[1] * i, r[2] = this.pos[2] + this.dir[2] * i, !0 } closestPointOnSphere(t, e, r) { if (function(t, e) { var r = t[0], n = t[1], i = t[2], s = e[0], a = e[1], o = e[2]; return Math.abs(r - s) <= Mo * Math.max(1, Math.abs(r), Math.abs(s)) && Math.abs(n - a) <= Mo * Math.max(1, Math.abs(n), Math.abs(a)) && Math.abs(i - o) <= Mo * Math.max(1, Math.abs(i), Math.abs(o)) }(this.pos, t) || 0 === e) return r[0] = r[1] = r[2] = 0, !1; const [n, i, s] = this.dir, a = this.pos[0] - t[0], o = this.pos[1] - t[1], l = this.pos[2] - t[2], u = n * n + i * i + s * s, c = 2 * (a * n + o * i + l * s), h = c * c - 4 * u * (a * a + o * o + l * l - e * e); if (h < 0) { const t = Math.max(-c / 2, 0), u = a + n * t, h = o + i * t, p = l + s * t, f = Math.hypot(u, h, p); return r[0] = u * e / f, r[1] = h * e / f, r[2] = p * e / f, !1 } { const t = (-c - Math.sqrt(h)) / (2 * u); if (t < 0) { const t = Math.hypot(a, o, l); return r[0] = a * e / t, r[1] = o * e / t, r[2] = l * e / t, !1 } return r[0] = a + n * t, r[1] = o + i * t, r[2] = l + s * t, !0 } } } class bl { constructor(t, e, r, n, i) { this.TL = t, this.TR = e, this.BR = r, this.BL = n, this.horizon = i; } static fromInvProjectionMatrix(t, e, r) { const n = [-1, 1, 1], i = [1, 1, 1], s = [1, -1, 1], a = [-1, -1, 1], o = el(n, n, t), l = el(i, i, t), u = el(s, s, t), c = el(a, a, t); return new bl(o, l, u, c, e / r) } } class wl { constructor(t, e) { this.points = t, this.planes = e; } static fromInvProjectionMatrix(t, e, r, n) { const i = Math.pow(2, r), s = [ [-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((r => { const s = ul([], r, t), a = 1 / s[3] / e * i; return function(t, e, r) { return t[0] = e[0] * r[0], t[1] = e[1] * r[1], t[2] = e[2] * r[2], t[3] = e[3] * r[3], t }(s, s, [a, a, n ? 1 / s[3] : a, a]) })), a = [ [0, 1, 2], [6, 5, 4], [0, 3, 7], [2, 1, 5], [3, 2, 6], [0, 4, 5] ].map((t => { const e = Jo([], tl([], il([], s[t[0]], s[t[1]]), il([], s[t[2]], s[t[1]]))), r = -Qo(e, s[t[1]]); return e.concat(r) })); return new wl(s, a) } } class _l { static fromPoints(t) { const e = [1 / 0, 1 / 0, 1 / 0], r = [-1 / 0, -1 / 0, -1 / 0]; for (const n of t) Ko(e, e, n), Yo(r, r, n); return new _l(e, r) } static applyTransform(t, e) { const r = t.getCorners(); for (let t = 0; t < r.length; ++t) el(r[t], r[t], e); return _l.fromPoints(r) } constructor(t, e) { this.min = t, this.max = e, this.center = Ho([], Go([], this.min, this.max), .5); } quadrant(t) { const e = [t % 2 == 0, t < 2], r = Oo(this.min), n = Oo(this.max); for (let t = 0; t < e.length; t++) r[t] = e[t] ? this.min[t] : this.center[t], n[t] = e[t] ? this.center[t] : this.max[t]; return n[2] = this.max[2], new _l(r, n) } distanceX(t) { return Math.max(Math.min(this.max[0], t[0]), this.min[0]) - t[0] } distanceY(t) { return Math.max(Math.min(this.max[1], t[1]), this.min[1]) - t[1] } distanceZ(t) { return Math.max(Math.min(this.max[2], t[2]), this.min[2]) - t[2] } getCorners() { const t = this.min, e = this.max; return [ [t[0], t[1], t[2]], [e[0], t[1], t[2]], [e[0], e[1], t[2]], [t[0], e[1], t[2]], [t[0], t[1], e[2]], [e[0], t[1], e[2]], [e[0], e[1], e[2]], [t[0], e[1], e[2]] ] } intersects(t) { const e = this.getCorners(); let r = !0; for (let n = 0; n < t.planes.length; n++) { const i = t.planes[n]; let s = 0; for (let t = 0; t < e.length; t++) s += Qo(i, e[t]) + i[3] >= 0; if (0 === s) return 0; s !== e.length && (r = !1); } if (r) return 2; for (let e = 0; e < 3; e++) { let r = Number.MAX_VALUE, n = -Number.MAX_VALUE; for (let i = 0; i < t.points.length; i++) { const s = t.points[i][e] - this.min[e]; r = Math.min(r, s), n = Math.max(n, s); } if (n < 0 || r > this.max[e] - this.min[e]) return 0 } return 1 } } const Al = ko / Math.PI / 2, Sl = 64, kl = [Sl, 32, 16], Il = -Al, Ml = Al, Tl = [new _l([Il, Il, Il], [Ml, Ml, Ml]), new _l([Il, Il, Il], [0, 0, Ml]), new _l([0, Il, Il], [Ml, 0, Ml]), new _l([Il, 0, Il], [0, Ml, Ml]), new _l([0, 0, Il], [Ml, Ml, Ml])]; function zl(t) { return t * Al / tu } function Bl(t, e, r, n = !0) { const i = Ho([], t._camera.position, t.worldSize), s = [e, r, 1, 1]; ul(s, s, t.pixelMatrixInverse), ol(s, s, 1 / s[3]); const a = Jo([], il([], s, i)), o = t.globeMatrix, l = [o[12], o[13], o[14]], u = il([], l, i), c = qo(u), h = Jo([], u), p = t.worldSize / (2 * Math.PI), f = Qo(h, a), d = Math.asin(p / c); if (d < Math.acos(f)) { if (!n) return null; const t = [], e = []; Ho(t, a, c / f), Jo(e, il(e, t, u)), Jo(a, Go(a, u, Ho(a, e, Math.tan(d) * c))); } const y = []; new vl(i, a).closestPointOnSphere(l, p, y); const m = Jo([], Y(o, 0)), g = Jo([], Y(o, 1)), x = Jo([], Y(o, 2)), b = Qo(m, y), w = Qo(g, y), _ = Qo(x, y), A = v(Math.asin(-w / p)); let k = v(Math.atan2(b, _)); k = t.center.lng + function(t, e) { const r = (e - t + 180) % 360 - 180; return r < -180 ? r + 360 : r }(t.center.lng, k); const I = iu(k), M = S(su(A), 0, 1); return new pu(I, M) } class El { constructor(t, e, r) { this.a = il([], t, r), this.b = il([], e, r), this.center = r; const n = Jo([], this.a), i = Jo([], this.b); this.angle = Math.acos(Qo(n, i)); } } function Cl(t, e) { if (0 === t.angle) return null; let r; return r = 0 === t.a[e] ? 1 / t.angle * .5 * Math.PI : 1 / t.angle * Math.atan(t.b[e] / t.a[e] / Math.sin(t.angle) - 1 / Math.tan(t.angle)), r < 0 || r > 1 ? null : function(t, e, r, n) { const i = Math.sin(r); return t * (Math.sin((1 - n) * r) / i) + e * (Math.sin(n * r) / i) }(t.a[e], t.b[e], t.angle, S(r, 0, 1)) + t.center[e] } function Pl(t) { if (t.z <= 1) return Tl[t.z + 2 * t.y + t.x]; const e = jl(Rl(t)); return _l.fromPoints(e) } function Dl(t, e, r) { return Ho(t, t, 1 - r), Wo(t, t, e, r) } function Vl(t, e) { const r = Kl(e.zoom); if (0 === r) return Pl(t); const n = Rl(t), i = jl(n), s = iu(n.getWest()) * e.worldSize, a = iu(n.getEast()) * e.worldSize, o = su(n.getNorth()) * e.worldSize, l = su(n.getSouth()) * e.worldSize, u = [s, o, 0], c = [a, o, 0], h = [s, l, 0], p = [a, l, 0], f = Co([], e.globeMatrix); return el(u, u, f), el(c, c, f), el(h, h, f), el(p, p, f), i[0] = Dl(i[0], h, r), i[1] = Dl(i[1], p, r), i[2] = Dl(i[2], c, r), i[3] = Dl(i[3], u, r), _l.fromPoints(i) } function Ll(t, e, r) { for (const n of t) el(n, n, e), Ho(n, n, r); } function Fl(t, e, r) { const n = e / t.worldSize, i = t.globeMatrix; if (r.z <= 1) { const t = Pl(r).getCorners(); return Ll(t, i, n), _l.fromPoints(t) } const s = Rl(r), a = jl(s); Ll(a, i, n); const o = Number.MAX_VALUE, l = [-o, -o, -o], u = [o, o, o]; if (s.contains(t.center)) { for (const t of a) Ko(u, u, t), Yo(l, l, t); l[2] = 0; const e = t.point, r = [e.x * n, e.y * n, 0]; return Ko(u, u, r), Yo(l, l, r), new _l(u, l) } const c = [i[12] * n, i[13] * n, i[14] * n], h = s.getCenter(), p = S(t.center.lat, -cu, cu), f = S(h.lat, -cu, cu), d = iu(t.center.lng), y = su(p); let m = d - iu(h.lng); const g = y - su(f); m > .5 ? m -= 1 : m < -.5 && (m += 1); let v = 0; Math.abs(m) > Math.abs(g) ? v = m >= 0 ? 1 : 3 : (v = g >= 0 ? 0 : 2, Wo(c, c, [i[4] * n, i[5] * n, i[6] * n], -Math.sin(x(g >= 0 ? s.getSouth() : s.getNorth())) * Al)); const b = a[v], w = a[(v + 1) % 4], _ = new El(b, w, c), A = [Cl(_, 0) || b[0], Cl(_, 1) || b[1], Cl(_, 2) || b[2]], k = Kl(t.zoom); if (k > 0) { const n = function({ x: t, y: e, z: r }, n, i, s, a) { const o = 1 / (1 << r); let l = t * o, u = l + o, c = e * o, h = c + o, p = 0; const f = (l + u) / 2 - s; return f > .5 ? p = -1 : f < -.5 && (p = 1), l = ((l + p) * n - (s *= n)) * i + s, u = ((u + p) * n - s) * i + s, c = (c * n - (a *= n)) * i + a, h = (h * n - a) * i + a, [ [l, h, 0], [u, h, 0], [u, c, 0], [l, c, 0] ] }(r, e, t._pixelsPerMercatorPixel, d, y); for (let t = 0; t < a.length; t++) Dl(a[t], n[t], k); const i = Go([], n[v], n[(v + 1) % 4]); Ho(i, i, .5), Dl(A, i, k); } for (const t of a) Ko(u, u, t), Yo(l, l, t); return u[2] = Math.min(b[2], w[2]), Ko(u, u, A), Yo(l, l, A), new _l(u, l) } function Rl({ x: t, y: e, z: r }) { const n = 1 / (1 << r), i = new ru(ou(t * n), lu((e + 1) * n)), s = new ru(ou((t + 1) * n), lu(e * n)); return new Io(i, s) } function jl(t) { const e = x(t.getNorth()), r = x(t.getSouth()), n = Math.cos(e), i = Math.cos(r), s = Math.sin(e), a = Math.sin(r), o = t.getWest(), l = t.getEast(); return [$l(i, a, o), $l(i, a, l), $l(n, s, l), $l(n, s, o)] } function $l(t, e, r, n = Al) { return r = x(r), [t * Math.sin(r) * n, -e * n, t * Math.cos(r) * n] } function Ul(t, e, r) { return $l(Math.cos(x(t)), Math.sin(x(t)), e, r) } function Ol(t, e, r, n) { const i = 1 << r.z, s = (t / ko + r.x) / i; return Ul(lu((e / ko + r.y) / i), ou(s), n) } function ql({ min: t, max: e }) { return 16383 / Math.max(e[0] - t[0], e[1] - t[1], e[2] - t[2]) } const Nl = new Float64Array(16); function Gl(t) { const e = ql(t), r = Ro(Nl, [e, e, e]); return Do(r, r, ((n = [])[0] = -(i = t.min)[0], n[1] = -i[1], n[2] = -i[2], n)); var n, i; } function Zl(t) { const e = (n = t.min, (r = Nl)[0] = 1, r[1] = 0, r[2] = 0, r[3] = 0, r[4] = 0, r[5] = 1, r[6] = 0, r[7] = 0, r[8] = 0, r[9] = 0, r[10] = 1, r[11] = 0, r[12] = n[0], r[13] = n[1], r[14] = n[2], r[15] = 1, r); var r, n; const i = 1 / ql(t); return Vo(e, e, [i, i, i]) } function Xl(t, e, r, n, i) { const s = function(t) { const e = ko / (2 * Math.PI); return t / (2 * Math.PI) / e }(r), a = [t, e, -r / (2 * Math.PI)], o = Eo(new Float64Array(16)); return Do(o, o, a), Vo(o, o, [s, s, s]), Lo(o, o, x(-i)), Fo(o, o, x(-n)), o } function Kl(t) { return k(5, 6, t) } function Yl(t, e) { const r = Ul(e.lat, e.lng), n = function(t) { const e = Ul(t._center.lat, t._center.lng); let r = tl([], No(0, 1, 0), e); const n = jo([], -t.angle, e); r = el(r, r, n), jo(n, -t._pitch, r); const i = Jo([], e); return Ho(i, i, zl(t.cameraToCenterDistance / t.pixelsPerMeter)), el(i, i, n), Go([], e, i) }(t); return a = (i = Zo([], n, r))[0], o = i[1], l = i[2], u = (s = r)[0], c = s[1], h = s[2], f = (p = Math.sqrt(a * a + o * o + l * l) * Math.sqrt(u * u + c * c + h * h)) && Qo(i, s) / p, Math.acos(Math.min(Math.max(f, -1), 1)); var i, s, a, o, l, u, c, h, p, f; } function Hl(t, e) { return Yl(t, e) > Math.PI / 2 * 1.01 } const Wl = x(85), Jl = Math.cos(Wl), Ql = Math.sin(Wl), tu = 6371008.8, eu = 2 * Math.PI * tu; class ru { constructor(t, e) { if (isNaN(t) || isNaN(e)) throw new Error(`Invalid LngLat object: (${t}, ${e})`); if (this.lng = +t, this.lat = +e, this.lat > 90 || this.lat < -90) throw new Error("Invalid LngLat latitude value: must be between -90 and 90") } wrap() { return new ru(I(this.lng, -180, 180), this.lat) } toArray() { return [this.lng, this.lat] } toString() { return `LngLat(${this.lng}, ${this.lat})` } distanceTo(t) { const e = Math.PI / 180, r = this.lat * e, n = t.lat * e, i = Math.sin(r) * Math.sin(n) + Math.cos(r) * Math.cos(n) * Math.cos((t.lng - this.lng) * e); return tu * Math.acos(Math.min(i, 1)) } toBounds(t = 0) { const e = 360 * t / 40075017, r = e / Math.cos(Math.PI / 180 * this.lat); return new Io(new ru(this.lng - r, this.lat - e), new ru(this.lng + r, this.lat + e)) } toEcef(t) { const e = zl(t); return Ul(this.lat, this.lng, Al + e) } static convert(t) { if (t instanceof ru) return t; if (Array.isArray(t) && (2 === t.length || 3 === t.length)) return new ru(Number(t[0]), Number(t[1])); if (!Array.isArray(t) && "object" == typeof t && null !== t) return new ru(Number("lng" in t ? t.lng : t.lon), Number(t.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>]") } } function nu(t) { return eu * Math.cos(t * Math.PI / 180) } function iu(t) { return (180 + t) / 360 } function su(t) { return (180 - 180 / Math.PI * Math.log(Math.tan(Math.PI / 4 + t * Math.PI / 360))) / 360 } function au(t, e) { return t / nu(e) } function ou(t) { return 360 * t - 180 } function lu(t) { return 360 / Math.PI * Math.atan(Math.exp((180 - 360 * t) * Math.PI / 180)) - 90 } function uu(t, e) { return t * nu(lu(e)) } const cu = 85.051129; function hu(t) { return 1 / Math.cos(t * Math.PI / 180) } class pu { constructor(t, e, r = 0) { this.x = +t, this.y = +e, this.z = +r; } static fromLngLat(t, e = 0) { const r = ru.convert(t); return new pu(iu(r.lng), su(r.lat), au(e, r.lat)) } toLngLat() { return new ru(ou(this.x), lu(this.y)) } toAltitude() { return uu(this.z, this.y) } meterInMercatorCoordinateUnits() { return 1 / eu * hu(lu(this.y)) } } function fu(t, e, r, n, i, s, a, o, l) { const u = (e + n) / 2, c = (r + i) / 2, h = new d(u, c); o(h), function(t, e, r, n, i, s) { const a = r - i, o = n - s; return Math.abs((n - e) * a - (r - t) * o) / Math.hypot(a, o) }(h.x, h.y, s.x, s.y, a.x, a.y) >= l ? (fu(t, e, r, u, c, s, h, o, l), fu(t, u, c, n, i, h, a, o, l)) : t.push(a); } function du(t, e, r) { let n = t[0], i = n.x, s = n.y; e(n); const a = [n]; for (let o = 1; o < t.length; o++) { const l = t[o], { x: u, y: c } = l; e(l), fu(a, i, s, u, c, n, l, e, r), i = u, s = c, n = l; } return a } function yu(t, e, r, n) { if (n(e, r)) { const i = e.add(r)._mult(.5); yu(t, e, i, n), yu(t, i, r, n); } else t.push(r); } function mu(t, e) { let r = t[0]; const n = [r]; for (let i = 1; i < t.length; i++) { const s = t[i]; yu(n, r, s, e), r = s; } return n } const gu = Math.pow(2, 14) - 1, xu = -gu - 1; function vu(t, e) { const r = Math.round(t.x * e), n = Math.round(t.y * e); return t.x = S(r, xu, gu), t.y = S(n, xu, gu), (r < t.x || r > t.x + 1 || n < t.y || n > t.y + 1) && U("Geometry exceeds allowed extent, reduce your vector tile buffer size"), t } function bu(t, e, r) { const n = t.loadGeometry(), i = t.extent, s = ko / i; if (e && r && r.projection.isReprojectedInTileSpace) { const s = 1 << e.z, { scale: a, x: o, y: l, projection: u } = r, c = t => { const r = ou((e.x + t.x / i) / s), n = lu((e.y + t.y / i) / s), c = u.project(r, n); t.x = (c.x * a - o) * i, t.y = (c.y * a - l) * i; }; for (let e = 0; e < n.length; e++) if (1 !== t.type) n[e] = du(n[e], c, 1); else { const t = []; for (const r of n[e]) r.x < 0 || r.x >= i || r.y < 0 || r.y >= i || (c(r), t.push(r)); n[e] = t; } } for (const t of n) for (const e of t) vu(e, s); return n } function wu(t, e) { return { type: t.type, id: t.id, properties: t.properties, geometry: e ? bu(t) : [] } } function _u(t, e, r, n, i) { t.emplaceBack(2 * e + (n + 1) / 2, 2 * r + (i + 1) / 2); } function Au(t, e, r) { const n = 16384; t.emplaceBack(e.x, e.y, e.z, r[0] * n, r[1] * n, r[2] * n); } class Su { constructor(t) { this.zoom = t.zoom, this.overscaling = t.overscaling, this.layers = t.layers, this.layerIds = this.layers.map((t => t.id)), this.index = t.index, this.hasPattern = !1, this.projection = t.projection, this.layoutVertexArray = new sa, this.indexArray = new wa, this.segments = new So, this.programConfigurations = new fo(t.layers, t.zoom), this.stateDependentLayerIds = this.layers.filter((t => t.isStateDependent())).map((t => t.id)); } populate(t, e, r, n) { const i = this.layers[0], s = []; let a = null; "circle" === i.type && (a = i.layout.get("circle-sort-key")); for (const { feature: e, id: i, index: o, sourceLayerIndex: l } of t) { const t = this.layers[0]._featureFilter.needGeometry, u = wu(e, t); if (!this.layers[0]._featureFilter.filter(new $s(this.zoom), u, r)) continue; const c = a ? a.evaluate(u, {}, r) : void 0, h = { id: i, properties: e.properties, type: e.type, sourceLayerIndex: l, index: o, geometry: t ? u.geometry : bu(e, r, n), patterns: {}, sortKey: c }; s.push(h); } a && s.sort(((t, e) => t.sortKey - e.sortKey)); let o = null; "globe" === n.projection.name && (this.globeExtVertexArray = new pa, o = n.projection); for (const n of s) { const { geometry: i, index: s, sourceLayerIndex: a } = n, l = t[s].feature; this.addFeature(n, i, s, e.availableImages, r, o), e.featureIndex.insert(l, i, s, a, this.index); } } update(t, e, r, n) { this.stateDependentLayers.length && this.programConfigurations.updatePaintArrays(t, e, this.stateDependentLayers, r, n); } isEmpty() { return 0 === this.layoutVertexArray.length } uploadPending() { return !this.uploaded || this.programConfigurations.needsUpload } upload(t) { this.uploaded || (this.layoutVertexBuffer = t.createVertexBuffer(this.layoutVertexArray, _o.members), this.indexBuffer = t.createIndexBuffer(this.indexArray), this.globeExtVertexArray && (this.globeExtVertexBuffer = t.createVertexBuffer(this.globeExtVertexArray, Ao.members))), this.programConfigurations.upload(t), this.uploaded = !0; } destroy() { this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.indexBuffer.destroy(), this.programConfigurations.destroy(), this.segments.destroy(), this.globeExtVertexBuffer && this.globeExtVertexBuffer.destroy()); } addFeature(t, e, r, n, i, s) { for (const r of e) for (const e of r) { const r = e.x, n = e.y; if (r < 0 || r >= ko || n < 0 || n >= ko) continue; if (s) { const t = s.projectTilePoint(r, n, i), e = s.upVector(i, r, n), a = this.globeExtVertexArray; Au(a, t, e), Au(a, t, e), Au(a, t, e), Au(a, t, e); } const a = this.segments.prepareSegment(4, this.layoutVertexArray, this.indexArray, t.sortKey), o = a.vertexLength; _u(this.layoutVertexArray, r, n, -1, -1), _u(this.layoutVertexArray, r, n, 1, -1), _u(this.layoutVertexArray, r, n, 1, 1), _u(this.layoutVertexArray, r, n, -1, 1), this.indexArray.emplaceBack(o, o + 1, o + 2), this.indexArray.emplaceBack(o, o + 2, o + 3), a.vertexLength += 4, a.primitiveLength += 2; } this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, t, r, {}, n, i); } } function ku(t, e) { for (let r = 0; r < t.length; r++) if (Du(e, t[r])) return !0; for (let r = 0; r < e.length; r++) if (Du(t, e[r])) return !0; return !!zu(t, e) } function Iu(t, e, r) { return !!Du(t, e) || !!Eu(e, t, r) } function Mu(t, e) { if (1 === t.length) return Pu(e, t[0]); for (let r = 0; r < e.length; r++) { const n = e[r]; for (let e = 0; e < n.length; e++) if (Du(t, n[e])) return !0 } for (let r = 0; r < t.length; r++) if (Pu(e, t[r])) return !0; for (let r = 0; r < e.length; r++) if (zu(t, e[r])) return !0; return !1 } function Tu(t, e, r) { if (t.length > 1) { if (zu(t, e)) return !0; for (let n = 0; n < e.length; n++) if (Eu(e[n], t, r)) return !0 } for (let n = 0; n < t.length; n++) if (Eu(t[n], e, r)) return !0; return !1 } function zu(t, e) { if (0 === t.length || 0 === e.length) return !1; for (let r = 0; r < t.length - 1; r++) { const n = t[r], i = t[r + 1]; for (let t = 0; t < e.length - 1; t++) if (Bu(n, i, e[t], e[t + 1])) return !0 } return !1 } function Bu(t, e, r, n) { return O(t, r, n) !== O(e, r, n) && O(t, e, r) !== O(t, e, n) } function Eu(t, e, r) { const n = r * r; if (1 === e.length) return t.distSqr(e[0]) < n; for (let r = 1; r < e.length; r++) if (Cu(t, e[r - 1], e[r]) < n) return !0; return !1 } function Cu(t, e, r) { const n = e.distSqr(r); if (0 === n) return t.distSqr(e); const i = ((t.x - e.x) * (r.x - e.x) + (t.y - e.y) * (r.y - e.y)) / n; return t.distSqr(i < 0 ? e : i > 1 ? r : r.sub(e)._mult(i)._add(e)) } function Pu(t, e) { let r, n, i, s = !1; for (let a = 0; a < t.length; a++) { r = t[a]; for (let t = 0, a = r.length - 1; t < r.length; a = t++) n = r[t], i = r[a], n.y > e.y != i.y > e.y && e.x < (i.x - n.x) * (e.y - n.y) / (i.y - n.y) + n.x && (s = !s); } return s } function Du(t, e) { let r = !1; for (let n = 0, i = t.length - 1; n < t.length; i = n++) { const s = t[n], a = t[i]; s.y > e.y != a.y > e.y && e.x < (a.x - s.x) * (e.y - s.y) / (a.y - s.y) + s.x && (r = !r); } return r } function Vu(t, e, r, n, i) { for (const s of t) if (e <= s.x && r <= s.y && n >= s.x && i >= s.y) return !0; const s = [new d(e, r), new d(e, i), new d(n, i), new d(n, r)]; if (t.length > 2) for (const e of s) if (Du(t, e)) return !0; for (let e = 0; e < t.length - 1; e++) if (Lu(t[e], t[e + 1], s)) return !0; return !1 } function Lu(t, e, r) { const n = r[0], i = r[2]; if (t.x < n.x && e.x < n.x || t.x > i.x && e.x > i.x || t.y < n.y && e.y < n.y || t.y > i.y && e.y > i.y) return !1; const s = O(t, e, r[0]); return s !== O(t, e, r[1]) || s !== O(t, e, r[2]) || s !== O(t, e, r[3]) } function Fu(t, e, r) { const n = e.paint.get(t).value; return "constant" === n.kind ? n.value : r.programConfigurations.get(e.id).getMaxValue(t) } function Ru(t) { return Math.sqrt(t[0] * t[0] + t[1] * t[1]) } function ju(t, e, r, n, i) { if (!e[0] && !e[1]) return t; const s = d.convert(e)._mult(i); "viewport" === r && s._rotate(-n); const a = []; for (let e = 0; e < t.length; e++) a.push(t[e].sub(s)); return a } function $u(t, e, r, n) { const i = d.convert(t)._mult(n); return "viewport" === e && i._rotate(-r), i } Oi(Su, "CircleBucket", { omit: ["layers"] }); const Uu = new Js({ "circle-sort-key": new Hs(Ht.layout_circle["circle-sort-key"]) }); var Ou = { paint: new Js({ "circle-radius": new Hs(Ht.paint_circle["circle-radius"]), "circle-color": new Hs(Ht.paint_circle["circle-color"]), "circle-blur": new Hs(Ht.paint_circle["circle-blur"]), "circle-opacity": new Hs(Ht.paint_circle["circle-opacity"]), "circle-translate": new Ys(Ht.paint_circle["circle-translate"]), "circle-translate-anchor": new Ys(Ht.paint_circle["circle-translate-anchor"]), "circle-pitch-scale": new Ys(Ht.paint_circle["circle-pitch-scale"]), "circle-pitch-alignment": new Ys(Ht.paint_circle["circle-pitch-alignment"]), "circle-stroke-width": new Hs(Ht.paint_circle["circle-stroke-width"]), "circle-stroke-color": new Hs(Ht.paint_circle["circle-stroke-color"]), "circle-stroke-opacity": new Hs(Ht.paint_circle["circle-stroke-opacity"]) }), layout: Uu }; function qu(t, e, r, n, i, s, a, o, l) { if (s && t.queryGeometry.isAboveHorizon) return !1; s && (l *= t.pixelToTileUnitsFactor); const u = t.tileID.canonical, c = r.projection.upVectorScale(u, r.center.lat, r.worldSize).metersToTile; for (const h of e) for (const e of h) { const h = e.add(o), p = i && r.elevation ? r.elevation.exaggeration() * i.getElevationAt(h.x, h.y, !0) : 0, f = r.projection.projectTilePoint(h.x, h.y, u); if (p > 0) { const t = r.projection.upVector(u, h.x, h.y); f.x += t[0] * c * p, f.y += t[1] * c * p, f.z += t[2] * c * p; } const d = s ? h : Nu(f.x, f.y, f.z, n), y = s ? t.tilespaceRays.map((t => Xu(t, p))) : t.queryGeometry.screenGeometry, m = ul([], [f.x, f.y, f.z, 1], n); if (!a && s ? l *= m[3] / r.cameraToCenterDistance : a && !s && (l *= r.cameraToCenterDistance / m[3]), s) { const t = lu((e.y / ko + u.y) / (1 << u.z)); l /= r.projection.pixelsPerMeter(t, 1) / au(1, t); } if (Iu(y, d, l)) return !0 } return !1 } function Nu(t, e, r, n) { const i = ul([], [t, e, r, 1], n); return new d(i[0] / i[3], i[1] / i[3]) } const Gu = No(0, 0, 0), Zu = No(0, 0, 1); function Xu(t, e) { const r = Uo(); return Gu[2] = e, t.intersectsPlane(Gu, Zu, r), new d(r[0], r[1]) } class Ku extends Su {} function Yu(t, { width: e, height: r }, n, i) { if (i) { if (i instanceof Uint8ClampedArray) i = new Uint8Array(i.buffer); else if (i.length !== e * r * n) throw new RangeError("mismatched image size") } else i = new Uint8Array(e * r * n); return t.width = e, t.height = r, t.data = i, t } function Hu(t, e, r) { const { width: n, height: i } = e; n === t.width && i === t.height || (Wu(t, e, { x: 0, y: 0 }, { x: 0, y: 0 }, { width: Math.min(t.width, n), height: Math.min(t.height, i) }, r), t.width = n, t.height = i, t.data = e.data); } function Wu(t, e, r, n, i, s) { if (0 === i.width || 0 === i.height) return e; if (i.width > t.width || i.height > t.height || r.x > t.width - i.width || r.y > t.height - i.height) throw new RangeError("out of range source coordinates for image copy"); if (i.width > e.width || i.height > e.height || n.x > e.width - i.width || n.y > e.height - i.height) throw new RangeError("out of range destination coordinates for image copy"); const a = t.data, o = e.data; for (let l = 0; l < i.height; l++) { const u = ((r.y + l) * t.width + r.x) * s, c = ((n.y + l) * e.width + n.x) * s; for (let t = 0; t < i.width * s; t++) o[c + t] = a[u + t]; } return e } Oi(Ku, "HeatmapBucket", { omit: ["layers"] }); class Ju { constructor(t, e) { Yu(this, t, 1, e); } resize(t) { Hu(this, new Ju(t), 1); } clone() { return new Ju({ width: this.width, height: this.height }, new Uint8Array(this.data)) } static copy(t, e, r, n, i) { Wu(t, e, r, n, i, 1); } } class Qu { constructor(t, e) { Yu(this, t, 4, e); } resize(t) { Hu(this, new Qu(t), 4); } replace(t, e) { e ? this.data.set(t) : this.data = t instanceof Uint8ClampedArray ? new Uint8Array(t.buffer) : t; } clone() { return new Qu({ width: this.width, height: this.height }, new Uint8Array(this.data)) } static copy(t, e, r, n, i) { Wu(t, e, r, n, i, 4); } } Oi(Ju, "AlphaImage"), Oi(Qu, "RGBAImage"); var tc = { paint: new Js({ "heatmap-radius": new Hs(Ht.paint_heatmap["heatmap-radius"]), "heatmap-weight": new Hs(Ht.paint_heatmap["heatmap-weight"]), "heatmap-intensity": new Ys(Ht.paint_heatmap["heatmap-intensity"]), "heatmap-color": new Ws(Ht.paint_heatmap["heatmap-color"]), "heatmap-opacity": new Ys(Ht.paint_heatmap["heatmap-opacity"]) }) }; function ec(t) { const e = {}, r = t.resolution || 256, n = t.clips ? t.clips.length : 1, i = t.image || new Qu({ width: r, height: n }), s = (r, n, s) => { e[t.evaluationKey] = s; const a = t.expression.evaluate(e); i.data[r + n + 0] = Math.floor(255 * a.r / a.a), i.data[r + n + 1] = Math.floor(255 * a.g / a.a), i.data[r + n + 2] = Math.floor(255 * a.b / a.a), i.data[r + n + 3] = Math.floor(255 * a.a); }; if (t.clips) for (let e = 0, i = 0; e < n; ++e, i += 4 * r) for (let n = 0, a = 0; n < r; n++, a += 4) { const o = n / (r - 1), { start: l, end: u } = t.clips[e]; s(i, a, l * (1 - o) + u * o); } else for (let t = 0, e = 0; t < r; t++, e += 4) s(0, e, t / (r - 1)); return i } var rc = { paint: new Js({ "hillshade-illumination-direction": new Ys(Ht.paint_hillshade["hillshade-illumination-direction"]), "hillshade-illumination-anchor": new Ys(Ht.paint_hillshade["hillshade-illumination-anchor"]), "hillshade-exaggeration": new Ys(Ht.paint_hillshade["hillshade-exaggeration"]), "hillshade-shadow-color": new Ys(Ht.paint_hillshade["hillshade-shadow-color"]), "hillshade-highlight-color": new Ys(Ht.paint_hillshade["hillshade-highlight-color"]), "hillshade-accent-color": new Ys(Ht.paint_hillshade["hillshade-accent-color"]) }) }; const nc = na([{ name: "a_pos", components: 2, type: "Int16" }], 4), { members: ic } = nc; var sc = {}; function ac(t, e, r) { r = r || 2; var n, i, s, a, o, l, u, c = e && e.length, h = c ? e[0] * r : t.length, p = oc(t, 0, h, r, !0), f = []; if (!p || p.next === p.prev) return f; if (c && (p = function(t, e, r, n) { var i, s, a, o = []; for (i = 0, s = e.length; i < s; i++)(a = oc(t, e[i] * n, i < s - 1 ? e[i + 1] * n : t.length, n, !1)) === a.next && (a.steiner = !0), o.push(xc(a)); for (o.sort(dc), i = 0; i < o.length; i++) r = yc(o[i], r); return r }(t, e, p, r)), t.length > 80 * r) { n = s = t[0], i = a = t[1]; for (var d = r; d < h; d += r)(o = t[d]) < n && (n = o), (l = t[d + 1]) < i && (i = l), o > s && (s = o), l > a && (a = l); u = 0 !== (u = Math.max(s - n, a - i)) ? 32767 / u : 0; } return uc(p, f, r, n, i, u, 0), f } function oc(t, e, r, n, i) { var s, a; if (i === Ec(t, e, r, n) > 0) for (s = e; s < r; s += n) a = Tc(s, t[s], t[s + 1], a); else for (s = r - n; s >= e; s -= n) a = Tc(s, t[s], t[s + 1], a); return a && _c(a, a.next) && (zc(a), a = a.next), a } function lc(t, e) { if (!t) return t; e || (e = t); var r, n = t; do { if (r = !1, n.steiner || !_c(n, n.next) && 0 !== wc(n.prev, n, n.next)) n = n.next; else { if (zc(n), (n = e = n.prev) === n.next) break; r = !0; } } while (r || n !== e); return e } function uc(t, e, r, n, i, s, a) { if (t) { !a && s && function(t, e, r, n) { var i = t; do { 0 === i.z && (i.z = gc(i.x, i.y, e, r, n)), i.prevZ = i.prev, i.nextZ = i.next, i = i.next; } while (i !== t); i.prevZ.nextZ = null, i.prevZ = null, function(t) { var e, r, n, i, s, a, o, l, u = 1; do { for (r = t, t = null, s = null, a = 0; r;) { for (a++, n = r, o = 0, e = 0; e < u && (o++, n = n.nextZ); e++); for (l = u; o > 0 || l > 0 && n;) 0 !== o && (0 === l || !n || r.z <= n.z) ? (i = r, r = r.nextZ, o--) : (i = n, n = n.nextZ, l--), s ? s.nextZ = i : t = i, i.prevZ = s, s = i; r = n; } s.nextZ = null, u *= 2; } while (a > 1) }(i); }(t, n, i, s); for (var o, l, u = t; t.prev !== t.next;) if (o = t.prev, l = t.next, s ? hc(t, n, i, s) : cc(t)) e.push(o.i / r | 0), e.push(t.i / r | 0), e.push(l.i / r | 0), zc(t), t = l.next, u = l.next; else if ((t = l) === u) { a ? 1 === a ? uc(t = pc(lc(t), e, r), e, r, n, i, s, 2) : 2 === a && fc(t, e, r, n, i, s) : uc(lc(t), e, r, n, i, s, 1); break } } } function cc(t) { var e = t.prev, r = t, n = t.next; if (wc(e, r, n) >= 0) return !1; for (var i = e.x, s = r.x, a = n.x, o = e.y, l = r.y, u = n.y, c = i < s ? i < a ? i : a : s < a ? s : a, h = o < l ? o < u ? o : u : l < u ? l : u, p = i > s ? i > a ? i : a : s > a ? s : a, f = o > l ? o > u ? o : u : l > u ? l : u, d = n.next; d !== e;) { if (d.x >= c && d.x <= p && d.y >= h && d.y <= f && vc(i, o, s, l, a, u, d.x, d.y) && wc(d.prev, d, d.next) >= 0) return !1; d = d.next; } return !0 } function hc(t, e, r, n) { var i = t.prev, s = t, a = t.next; if (wc(i, s, a) >= 0) return !1; for (var o = i.x, l = s.x, u = a.x, c = i.y, h = s.y, p = a.y, f = o < l ? o < u ? o : u : l < u ? l : u, d = c < h ? c < p ? c : p : h < p ? h : p, y = o > l ? o > u ? o : u : l > u ? l : u, m = c > h ? c > p ? c : p : h > p ? h : p, g = gc(f, d, e, r, n), x = gc(y, m, e, r, n), v = t.prevZ, b = t.nextZ; v && v.z >= g && b && b.z <= x;) { if (v.x >= f && v.x <= y && v.y >= d && v.y <= m && v !== i && v !== a && vc(o, c, l, h, u, p, v.x, v.y) && wc(v.prev, v, v.next) >= 0) return !1; if (v = v.prevZ, b.x >= f && b.x <= y && b.y >= d && b.y <= m && b !== i && b !== a && vc(o, c, l, h, u, p, b.x, b.y) && wc(b.prev, b, b.next) >= 0) return !1; b = b.nextZ; } for (; v && v.z >= g;) { if (v.x >= f && v.x <= y && v.y >= d && v.y <= m && v !== i && v !== a && vc(o, c, l, h, u, p, v.x, v.y) && wc(v.prev, v, v.next) >= 0) return !1; v = v.prevZ; } for (; b && b.z <= x;) { if (b.x >= f && b.x <= y && b.y >= d && b.y <= m && b !== i && b !== a && vc(o, c, l, h, u, p, b.x, b.y) && wc(b.prev, b, b.next) >= 0) return !1; b = b.nextZ; } return !0 } function pc(t, e, r) { var n = t; do { var i = n.prev, s = n.next.next; !_c(i, s) && Ac(i, n, n.next, s) && Ic(i, s) && Ic(s, i) && (e.push(i.i / r | 0), e.push(n.i / r | 0), e.push(s.i / r | 0), zc(n), zc(n.next), n = t = s), n = n.next; } while (n !== t); return lc(n) } function fc(t, e, r, n, i, s) { var a = t; do { for (var o = a.next.next; o !== a.prev;) { if (a.i !== o.i && bc(a, o)) { var l = Mc(a, o); return a = lc(a, a.next), l = lc(l, l.next), uc(a, e, r, n, i, s, 0), void uc(l, e, r, n, i, s, 0) } o = o.next; } a = a.next; } while (a !== t) } function dc(t, e) { return t.x - e.x } function yc(t, e) { var r = function(t, e) { var r, n = e, i = t.x, s = t.y, a = -1 / 0; do { if (s <= n.y && s >= n.next.y && n.next.y !== n.y) { var o = n.x + (s - n.y) * (n.next.x - n.x) / (n.next.y - n.y); if (o <= i && o > a && (a = o, r = n.x < n.next.x ? n : n.next, o === i)) return r } n = n.next; } while (n !== e); if (!r) return null; var l, u = r, c = r.x, h = r.y, p = 1 / 0; n = r; do { i >= n.x && n.x >= c && i !== n.x && vc(s < h ? i : a, s, c, h, s < h ? a : i, s, n.x, n.y) && (l = Math.abs(s - n.y) / (i - n.x), Ic(n, t) && (l < p || l === p && (n.x > r.x || n.x === r.x && mc(r, n))) && (r = n, p = l)), n = n.next; } while (n !== u); return r }(t, e); if (!r) return e; var n = Mc(r, t); return lc(n, n.next), lc(r, r.next) } function mc(t, e) { return wc(t.prev, t, e.prev) < 0 && wc(e.next, t, t.next) < 0 } function gc(t, e, r, n, i) { return (t = 1431655765 & ((t = 858993459 & ((t = 252645135 & ((t = 16711935 & ((t = (t - r) * i | 0) | t << 8)) | t << 4)) | t << 2)) | t << 1)) | (e = 1431655765 & ((e = 858993459 & ((e = 252645135 & ((e = 16711935 & ((e = (e - n) * i | 0) | e << 8)) | e << 4)) | e << 2)) | e << 1)) << 1 } function xc(t) { var e = t, r = t; do { (e.x < r.x || e.x === r.x && e.y < r.y) && (r = e), e = e.next; } while (e !== t); return r } function vc(t, e, r, n, i, s, a, o) { return (i - a) * (e - o) >= (t - a) * (s - o) && (t - a) * (n - o) >= (r - a) * (e - o) && (r - a) * (s - o) >= (i - a) * (n - o) } function bc(t, e) { return t.next.i !== e.i && t.prev.i !== e.i && ! function(t, e) { var r = t; do { if (r.i !== t.i && r.next.i !== t.i && r.i !== e.i && r.next.i !== e.i && Ac(r, r.next, t, e)) return !0; r = r.next; } while (r !== t); return !1 }(t, e) && (Ic(t, e) && Ic(e, t) && function(t, e) { var r = t, n = !1, i = (t.x + e.x) / 2, s = (t.y + e.y) / 2; do { r.y > s != r.next.y > s && r.next.y !== r.y && i < (r.next.x - r.x) * (s - r.y) / (r.next.y - r.y) + r.x && (n = !n), r = r.next; } while (r !== t); return n }(t, e) && (wc(t.prev, t, e.prev) || wc(t, e.prev, e)) || _c(t, e) && wc(t.prev, t, t.next) > 0 && wc(e.prev, e, e.next) > 0) } function wc(t, e, r) { return (e.y - t.y) * (r.x - e.x) - (e.x - t.x) * (r.y - e.y) } function _c(t, e) { return t.x === e.x && t.y === e.y } function Ac(t, e, r, n) { var i = kc(wc(t, e, r)), s = kc(wc(t, e, n)), a = kc(wc(r, n, t)), o = kc(wc(r, n, e)); return i !== s && a !== o || !(0 !== i || !Sc(t, r, e)) || !(0 !== s || !Sc(t, n, e)) || !(0 !== a || !Sc(r, t, n)) || !(0 !== o || !Sc(r, e, n)) } function Sc(t, e, r) { return e.x <= Math.max(t.x, r.x) && e.x >= Math.min(t.x, r.x) && e.y <= Math.max(t.y, r.y) && e.y >= Math.min(t.y, r.y) } function kc(t) { return t > 0 ? 1 : t < 0 ? -1 : 0 } function Ic(t, e) { return wc(t.prev, t, t.next) < 0 ? wc(t, e, t.next) >= 0 && wc(t, t.prev, e) >= 0 : wc(t, e, t.prev) < 0 || wc(t, t.next, e) < 0 } function Mc(t, e) { var r = new Bc(t.i, t.x, t.y), n = new Bc(e.i, e.x, e.y), i = t.next, s = e.prev; return t.next = e, e.prev = t, r.next = i, i.prev = r, n.next = r, r.prev = n, s.next = n, n.prev = s, n } function Tc(t, e, r, n) { var i = new Bc(t, e, r); return n ? (i.next = n.next, i.prev = n, n.next.prev = i, n.next = i) : (i.prev = i, i.next = i), i } function zc(t) { t.next.prev = t.prev, t.prev.next = t.next, t.prevZ && (t.prevZ.nextZ = t.nextZ), t.nextZ && (t.nextZ.prevZ = t.prevZ); } function Bc(t, e, r) { this.i = t, this.x = e, this.y = r, this.prev = null, this.next = null, this.z = 0, this.prevZ = null, this.nextZ = null, this.steiner = !1; } function Ec(t, e, r, n) { for (var i = 0, s = e, a = r - n; s < r; s += n) i += (t[a] - t[s]) * (t[s + 1] + t[a + 1]), a = s; return i } function Cc(t, e, r, n, i) { Pc(t, e, r || 0, n || t.length - 1, i || Vc); } function Pc(t, e, r, n, i) { for (; n > r;) { if (n - r > 600) { var s = n - r + 1, a = e - r + 1, o = Math.log(s), l = .5 * Math.exp(2 * o / 3), u = .5 * Math.sqrt(o * l * (s - l) / s) * (a - s / 2 < 0 ? -1 : 1); Pc(t, e, Math.max(r, Math.floor(e - a * l / s + u)), Math.min(n, Math.floor(e + (s - a) * l / s + u)), i); } var c = t[e], h = r, p = n; for (Dc(t, r, e), i(t[n], c) > 0 && Dc(t, r, n); h < p;) { for (Dc(t, h, p), h++, p--; i(t[h], c) < 0;) h++; for (; i(t[p], c) > 0;) p--; } 0 === i(t[r], c) ? Dc(t, r, p) : Dc(t, ++p, n), p <= e && (r = p + 1), e <= p && (n = p - 1); } } function Dc(t, e, r) { var n = t[e]; t[e] = t[r], t[r] = n; } function Vc(t, e) { return t < e ? -1 : t > e ? 1 : 0 } function Lc(t, e) { const r = t.length; if (r <= 1) return [t]; const n = []; let i, s; for (let e = 0; e < r; e++) { const r = q(t[e]); 0 !== r && (t[e].area = Math.abs(r), void 0 === s && (s = r < 0), s === r < 0 ? (i && n.push(i), i = [t[e]]) : i.push(t[e])); } if (i && n.push(i), e > 1) for (let t = 0; t < n.length; t++) n[t].length <= e || (Cc(n[t], e, 1, n[t].length - 1, Fc), n[t] = n[t].slice(0, e)); return n } function Fc(t, e) { return e.area - t.area } function Rc(t, e, r) { const n = r.patternDependencies; let i = !1; for (const r of e) { const e = r.paint.get(`${t}-pattern`); e.isConstant() || (i = !0); const s = e.constantOr(null); s && (i = !0, n[s] = !0); } return i } function jc(t, e, r, n, i) { const s = i.patternDependencies; for (const a of e) { const e = a.paint.get(`${t}-pattern`).value; if ("constant" !== e.kind) { let t = e.evaluate({ zoom: n }, r, {}, i.availableImages); t = t && t.name ? t.name : t, s[t] = !0, r.patterns[a.id] = t; } } return r }({ get exports() { return sc }, set exports(t) { sc = t; } }).exports = ac, sc.default = ac, ac.deviation = function(t, e, r, n) { var i = e && e.length, s = Math.abs(Ec(t, 0, i ? e[0] * r : t.length, r)); if (i) for (var a = 0, o = e.length; a < o; a++) s -= Math.abs(Ec(t, e[a] * r, a < o - 1 ? e[a + 1] * r : t.length, r)); var l = 0; for (a = 0; a < n.length; a += 3) { var u = n[a] * r, c = n[a + 1] * r, h = n[a + 2] * r; l += Math.abs((t[u] - t[h]) * (t[c + 1] - t[u + 1]) - (t[u] - t[c]) * (t[h + 1] - t[u + 1])); } return 0 === s && 0 === l ? 0 : Math.abs((l - s) / s) }, ac.flatten = function(t) { for (var e = t[0][0].length, r = { vertices: [], holes: [], dimensions: e }, n = 0, i = 0; i < t.length; i++) { for (var s = 0; s < t[i].length; s++) for (var a = 0; a < e; a++) r.vertices.push(t[i][s][a]); i > 0 && r.holes.push(n += t[i - 1].length); } return r }; class $c { constructor(t) { this.zoom = t.zoom, this.overscaling = t.overscaling, this.layers = t.layers, this.layerIds = this.layers.map((t => t.id)), this.index = t.index, this.hasPattern = !1, this.patternFeatures = [], this.layoutVertexArray = new sa, this.indexArray = new wa, this.indexArray2 = new Ma, this.programConfigurations = new fo(t.layers, t.zoom), this.segments = new So, this.segments2 = new So, this.stateDependentLayerIds = this.layers.filter((t => t.isStateDependent())).map((t => t.id)), this.projection = t.projection; } populate(t, e, r, n) { this.hasPattern = Rc("fill", this.layers, e); const i = this.layers[0].layout.get("fill-sort-key"), s = []; for (const { feature: a, id: o, index: l, sourceLayerIndex: u } of t) { const t = this.layers[0]._featureFilter.needGeometry, c = wu(a, t); if (!this.layers[0]._featureFilter.filter(new $s(this.zoom), c, r)) continue; const h = i ? i.evaluate(c, {}, r, e.availableImages) : void 0, p = { id: o, properties: a.properties, type: a.type, sourceLayerIndex: u, index: l, geometry: t ? c.geometry : bu(a, r, n), patterns: {}, sortKey: h }; s.push(p); } i && s.sort(((t, e) => t.sortKey - e.sortKey)); for (const n of s) { const { geometry: i, index: s, sourceLayerIndex: a } = n; if (this.hasPattern) { const t = jc("fill", this.layers, n, this.zoom, e); this.patternFeatures.push(t); } else this.addFeature(n, i, s, r, {}, e.availableImages); e.featureIndex.insert(t[s].feature, i, s, a, this.index); } } update(t, e, r, n) { this.stateDependentLayers.length && this.programConfigurations.updatePaintArrays(t, e, this.stateDependentLayers, r, n); } addFeatures(t, e, r, n, i) { for (const t of this.patternFeatures) this.addFeature(t, t.geometry, t.index, e, r, n); } isEmpty() { return 0 === this.layoutVertexArray.length } uploadPending() { return !this.uploaded || this.programConfigurations.needsUpload } upload(t) { this.uploaded || (this.layoutVertexBuffer = t.createVertexBuffer(this.layoutVertexArray, ic), this.indexBuffer = t.createIndexBuffer(this.indexArray), this.indexBuffer2 = t.createIndexBuffer(this.indexArray2)), this.programConfigurations.upload(t), this.uploaded = !0; } destroy() { this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.indexBuffer.destroy(), this.indexBuffer2.destroy(), this.programConfigurations.destroy(), this.segments.destroy(), this.segments2.destroy()); } addFeature(t, e, r, n, i, s = []) { for (const t of Lc(e, 500)) { let e = 0; for (const r of t) e += r.length; const r = this.segments.prepareSegment(e, this.layoutVertexArray, this.indexArray), n = r.vertexLength, i = [], s = []; for (const e of t) { if (0 === e.length) continue; e !== t[0] && s.push(i.length / 2); const r = this.segments2.prepareSegment(e.length, this.layoutVertexArray, this.indexArray2), n = r.vertexLength; this.layoutVertexArray.emplaceBack(e[0].x, e[0].y), this.indexArray2.emplaceBack(n + e.length - 1, n), i.push(e[0].x), i.push(e[0].y); for (let t = 1; t < e.length; t++) this.layoutVertexArray.emplaceBack(e[t].x, e[t].y), this.indexArray2.emplaceBack(n + t - 1, n + t), i.push(e[t].x), i.push(e[t].y); r.vertexLength += e.length, r.primitiveLength += e.length; } const a = sc(i, s); for (let t = 0; t < a.length; t += 3) this.indexArray.emplaceBack(n + a[t], n + a[t + 1], n + a[t + 2]); r.vertexLength += e, r.primitiveLength += a.length / 3; } this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, t, r, i, s, n); } } Oi($c, "FillBucket", { omit: ["layers", "patternFeatures"] }); const Uc = new Js({ "fill-sort-key": new Hs(Ht.layout_fill["fill-sort-key"]) }); var Oc = { paint: new Js({ "fill-antialias": new Ys(Ht.paint_fill["fill-antialias"]), "fill-opacity": new Hs(Ht.paint_fill["fill-opacity"]), "fill-color": new Hs(Ht.paint_fill["fill-color"]), "fill-outline-color": new Hs(Ht.paint_fill["fill-outline-color"]), "fill-translate": new Ys(Ht.paint_fill["fill-translate"]), "fill-translate-anchor": new Ys(Ht.paint_fill["fill-translate-anchor"]), "fill-pattern": new Hs(Ht.paint_fill["fill-pattern"]) }), layout: Uc }; const qc = na([{ name: "a_pos_normal_ed", components: 4, type: "Int16" }]), Nc = na([{ name: "a_centroid_pos", components: 2, type: "Uint16" }]), Gc = na([{ name: "a_pos_3", components: 3, type: "Int16" }, { name: "a_pos_normal_3", components: 3, type: "Int16" }]), { members: Zc } = qc; var Xc = {}, Kc = d, Yc = Hc; function Hc(t, e, r, n, i) { this.properties = {}, this.extent = r, this.type = 0, this._pbf = t, this._geometry = -1, this._keys = n, this._values = i, t.readFields(Wc, this, e); } function Wc(t, e, r) { 1 == t ? e.id = r.readVarint() : 2 == t ? function(t, e) { for (var r = t.readVarint() + t.pos; t.pos < r;) { var n = e._keys[t.readVarint()], i = e._values[t.readVarint()]; e.properties[n] = i; } }(r, e) : 3 == t ? e.type = r.readVarint() : 4 == t && (e._geometry = r.pos); } function Jc(t) { for (var e, r, n = 0, i = 0, s = t.length, a = s - 1; i < s; a = i++) n += ((r = t[a]).x - (e = t[i]).x) * (e.y + r.y); return n } Hc.types = ["Unknown", "Point", "LineString", "Polygon"], Hc.prototype.loadGeometry = function() { var t = this._pbf; t.pos = this._geometry; for (var e, r = t.readVarint() + t.pos, n = 1, i = 0, s = 0, a = 0, o = []; t.pos < r;) { if (i <= 0) { var l = t.readVarint(); n = 7 & l, i = l >> 3; } if (i--, 1 === n || 2 === n) s += t.readSVarint(), a += t.readSVarint(), 1 === n && (e && o.push(e), e = []), e.push(new Kc(s, a)); else { if (7 !== n) throw new Error("unknown command " + n); e && e.push(e[0].clone()); } } return e && o.push(e), o }, Hc.prototype.bbox = function() { var t = this._pbf; t.pos = this._geometry; for (var e = t.readVarint() + t.pos, r = 1, n = 0, i = 0, s = 0, a = 1 / 0, o = -1 / 0, l = 1 / 0, u = -1 / 0; t.pos < e;) { if (n <= 0) { var c = t.readVarint(); r = 7 & c, n = c >> 3; } if (n--, 1 === r || 2 === r)(i += t.readSVarint()) < a && (a = i), i > o && (o = i), (s += t.readSVarint()) < l && (l = s), s > u && (u = s); else if (7 !== r) throw new Error("unknown command " + r) } return [a, l, o, u] }, Hc.prototype.toGeoJSON = function(t, e, r) { var n, i, s = this.extent * Math.pow(2, r), a = this.extent * t, o = this.extent * e, l = this.loadGeometry(), u = Hc.types[this.type]; function c(t) { for (var e = 0; e < t.length; e++) { var r = t[e]; t[e] = [360 * (r.x + a) / s - 180, 360 / Math.PI * Math.atan(Math.exp((180 - 360 * (r.y + o) / s) * Math.PI / 180)) - 90]; } } switch (this.type) { case 1: var h = []; for (n = 0; n < l.length; n++) h[n] = l[n][0]; c(l = h); break; case 2: for (n = 0; n < l.length; n++) c(l[n]); break; case 3: for (l = function(t) { var e = t.length; if (e <= 1) return [t]; for (var r, n, i = [], s = 0; s < e; s++) { var a = Jc(t[s]); 0 !== a && (void 0 === n && (n = a < 0), n === a < 0 ? (r && i.push(r), r = [t[s]]) : r.push(t[s])); } return r && i.push(r), i }(l), n = 0; n < l.length; n++) for (i = 0; i < l[n].length; i++) c(l[n][i]); } 1 === l.length ? l = l[0] : u = "Multi" + u; var p = { type: "Feature", geometry: { type: u, coordinates: l }, properties: this.properties }; return "id" in this && (p.id = this.id), p }; var Qc = Yc, th = eh; function eh(t, e) { this.version = 1, this.name = null, this.extent = 4096, this.length = 0, this._pbf = t, this._keys = [], this._values = [], this._features = [], t.readFields(rh, this, e), this.length = this._features.length; } function rh(t, e, r) { 15 === t ? e.version = r.readVarint() : 1 === t ? e.name = r.readString() : 5 === t ? e.extent = r.readVarint() : 2 === t ? e._features.push(r.pos) : 3 === t ? e._keys.push(r.readString()) : 4 === t && e._values.push(function(t) { for (var e = null, r = t.readVarint() + t.pos; t.pos < r;) { var n = t.readVarint() >> 3; e = 1 === n ? t.readString() : 2 === n ? t.readFloat() : 3 === n ? t.readDouble() : 4 === n ? t.readVarint64() : 5 === n ? t.readVarint() : 6 === n ? t.readSVarint() : 7 === n ? t.readBoolean() : null; } return e }(r)); } eh.prototype.feature = function(t) { if (t < 0 || t >= this._features.length) throw new Error("feature index out of bounds"); this._pbf.pos = this._features[t]; var e = this._pbf.readVarint() + this._pbf.pos; return new Qc(this._pbf, e, this.extent, this._keys, this._values) }; var nh = th; function ih(t, e, r) { if (3 === t) { var n = new nh(r, r.readVarint() + r.pos); n.length && (e[n.name] = n); } } var sh = Xc.VectorTile = function(t, e) { this.layers = t.readFields(ih, {}, e); }, ah = Xc.VectorTileFeature = Yc; function oh(t, e, r, n) { const i = [], s = 0 === n ? (t, e, r, n, i, s) => { t.push(new d(s, r + (s - e) / (n - e) * (i - r))); } : (t, e, r, n, i, s) => { t.push(new d(e + (s - r) / (i - r) * (n - e), s)); }; for (const a of t) { const t = []; for (const i of a) { if (i.length <= 2) continue; const a = []; for (let t = 0; t < i.length - 1; t++) { const o = i[t].x, l = i[t].y, u = i[t + 1].x, c = i[t + 1].y, h = 0 === n ? o : l, p = 0 === n ? u : c; h < e ? p > e && s(a, o, l, u, c, e) : h > r ? p < r && s(a, o, l, u, c, r) : a.push(i[t]), p < e && h >= e && s(a, o, l, u, c, e), p > r && h <= r && s(a, o, l, u, c, r); } let o = i[i.length - 1]; const l = 0 === n ? o.x : o.y; l >= e && l <= r && a.push(o), a.length && (o = a[a.length - 1], a[0].x === o.x && a[0].y === o.y || a.push(a[0]), t.push(a)); } t.length && i.push(t); } return i } Xc.VectorTileLayer = th; const lh = ah.types, uh = Math.pow(2, 13); function ch(t, e, r, n, i, s, a, o) { t.emplaceBack((e << 1) + a, (r << 1) + s, (Math.floor(n * uh) << 1) + i, Math.round(o)); } function hh(t, e, r) { const n = 16384; t.emplaceBack(e.x, e.y, e.z, r[0] * n, r[1] * n, r[2] * n); } class ph { constructor() { this.acc = new d(0, 0), this.polyCount = []; } startRing(t) { this.currentPolyCount = { edges: 0, top: 0 }, this.polyCount.push(this.currentPolyCount), this.min || (this.min = new d(t.x, t.y), this.max = new d(t.x, t.y)); } append(t, e) { this.currentPolyCount.edges++, this.acc._add(t); const r = this.min, n = this.max; t.x < r.x ? r.x = t.x : t.x > n.x && (n.x = t.x), t.y < r.y ? r.y = t.y : t.y > n.y && (n.y = t.y), ((0 === t.x || t.x === ko) && t.x === e.x) != ((0 === t.y || t.y === ko) && t.y === e.y) && this.processBorderOverlap(t, e), e.x < 0 != t.x < 0 && this.addBorderIntersection(0, Mr(e.y, t.y, (0 - e.x) / (t.x - e.x))), e.x > ko != t.x > ko && this.addBorderIntersection(1, Mr(e.y, t.y, (ko - e.x) / (t.x - e.x))), e.y < 0 != t.y < 0 && this.addBorderIntersection(2, Mr(e.x, t.x, (0 - e.y) / (t.y - e.y))), e.y > ko != t.y > ko && this.addBorderIntersection(3, Mr(e.x, t.x, (ko - e.y) / (t.y - e.y))); } addBorderIntersection(t, e) { this.borders || (this.borders = [ [Number.MAX_VALUE, -Number.MAX_VALUE], [Number.MAX_VALUE, -Number.MAX_VALUE], [Number.MAX_VALUE, -Number.MAX_VALUE], [Number.MAX_VALUE, -Number.MAX_VALUE] ]); const r = this.borders[t]; e < r[0] && (r[0] = e), e > r[1] && (r[1] = e); } processBorderOverlap(t, e) { if (t.x === e.x) { if (t.y === e.y) return; const r = 0 === t.x ? 0 : 1; this.addBorderIntersection(r, e.y), this.addBorderIntersection(r, t.y); } else { const r = 0 === t.y ? 2 : 3; this.addBorderIntersection(r, e.x), this.addBorderIntersection(r, t.x); } } centroid() { const t = this.polyCount.reduce(((t, e) => t + e.edges), 0); return 0 !== t ? this.acc.div(t)._round() : new d(0, 0) } span() { return new d(this.max.x - this.min.x, this.max.y - this.min.y) } intersectsCount() { return this.borders.reduce(((t, e) => t + +(e[0] !== Number.MAX_VALUE)), 0) } } class fh { constructor(t) { this.zoom = t.zoom, this.canonical = t.canonical, this.overscaling = t.overscaling, this.layers = t.layers, this.layerIds = this.layers.map((t => t.id)), this.index = t.index, this.hasPattern = !1, this.edgeRadius = 0, this.projection = t.projection, this.layoutVertexArray = new oa, this.centroidVertexArray = new $a, this.indexArray = new wa, this.programConfigurations = new fo(t.layers, t.zoom), this.segments = new So, this.stateDependentLayerIds = this.layers.filter((t => t.isStateDependent())).map((t => t.id)), this.enableTerrain = t.enableTerrain; } populate(t, e, r, n) { this.features = [], this.hasPattern = Rc("fill-extrusion", this.layers, e), this.featuresOnBorder = [], this.borders = [ [], [], [], [] ], this.borderDoneWithNeighborZ = [-1, -1, -1, -1], this.tileToMeter = function(t) { const e = Math.exp(Math.PI * (1 - t.y / (1 << t.z) * 2)); return 80150034 * e / (e * e + 1) / ko / (1 << t.z) }(r), this.edgeRadius = this.layers[0].layout.get("fill-extrusion-edge-radius") / this.tileToMeter; for (const { feature: i, id: s, index: a, sourceLayerIndex: o } of t) { const t = this.layers[0]._featureFilter.needGeometry, l = wu(i, t); if (!this.layers[0]._featureFilter.filter(new $s(this.zoom), l, r)) continue; const u = { id: s, sourceLayerIndex: o, index: a, geometry: t ? l.geometry : bu(i, r, n), properties: i.properties, type: i.type, patterns: {} }, c = this.layoutVertexArray.length; this.hasPattern ? this.features.push(jc("fill-extrusion", this.layers, u, this.zoom, e)) : this.addFeature(u, u.geometry, a, r, {}, e.availableImages, n), e.featureIndex.insert(i, u.geometry, a, o, this.index, c); } this.sortBorders(); } addFeatures(t, e, r, n, i) { for (const t of this.features) { const { geometry: s } = t; this.addFeature(t, s, t.index, e, r, n, i); } this.sortBorders(); } update(t, e, r, n) { this.stateDependentLayers.length && this.programConfigurations.updatePaintArrays(t, e, this.stateDependentLayers, r, n); } isEmpty() { return 0 === this.layoutVertexArray.length } uploadPending() { return !this.uploaded || this.programConfigurations.needsUpload } upload(t) { this.uploaded || (this.layoutVertexBuffer = t.createVertexBuffer(this.layoutVertexArray, Zc), this.indexBuffer = t.createIndexBuffer(this.indexArray), this.layoutVertexExtArray && (this.layoutVertexExtBuffer = t.createVertexBuffer(this.layoutVertexExtArray, Gc.members, !0))), this.programConfigurations.upload(t), this.uploaded = !0; } uploadCentroid(t) { 0 !== this.centroidVertexArray.length && (this.centroidVertexBuffer ? this.needsCentroidUpdate && this.centroidVertexBuffer.updateData(this.centroidVertexArray) : this.centroidVertexBuffer = t.createVertexBuffer(this.centroidVertexArray, Nc.members, !0), this.needsCentroidUpdate = !1); } destroy() { this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.centroidVertexBuffer && this.centroidVertexBuffer.destroy(), this.layoutVertexExtBuffer && this.layoutVertexExtBuffer.destroy(), this.indexBuffer.destroy(), this.programConfigurations.destroy(), this.segments.destroy()); } addFeature(t, e, r, n, i, s, a) { const o = [new d(0, 0), new d(ko, ko)], l = a.projection, u = "globe" === l.name, c = this.enableTerrain && !u ? new ph : null, h = "Polygon" === lh[t.type]; u && !this.layoutVertexExtArray && (this.layoutVertexExtArray = new pa); const p = Lc(e, 500); for (let t = p.length - 1; t >= 0; t--) { const e = p[t]; (0 === e.length || (f = e[0]).every((t => t.x <= 0)) || f.every((t => t.x >= ko)) || f.every((t => t.y <= 0)) || f.every((t => t.y >= ko))) && p.splice(t, 1); } var f; let y; if (u) y = wh(p, o, n); else { y = []; for (const t of p) y.push({ polygon: t, bounds: o }); } const m = h ? this.edgeRadius : 0; for (const { polygon: t, bounds: e } of y) { let r = 0, i = 0; for (const e of t) h && !e[0].equals(e[e.length - 1]) && e.push(e[0]), i += h ? e.length - 1 : e.length; const s = this.segments.prepareSegment((h ? 5 : 4) * i, this.layoutVertexArray, this.indexArray); if (h) { const e = [], i = []; r = s.vertexLength; for (const r of t) { let a, o; r.length && r !== t[0] && i.push(e.length / 2), a = r[1].sub(r[0])._perp()._unit(); for (let t = 1; t < r.length; t++) { const i = r[t], c = r[t === r.length - 1 ? 1 : t + 1]; let { x: h, y: p } = i; if (m) { o = c.sub(i)._perp()._unit(); const t = a.add(o)._unit(), e = m * Math.min(4, 1 / (a.x * t.x + a.y * t.y)); h += e * t.x, p += e * t.y, a = o; } ch(this.layoutVertexArray, h, p, 0, 0, 1, 1, 0), s.vertexLength++, e.push(i.x, i.y), u && hh(this.layoutVertexExtArray, l.projectTilePoint(h, p, n), l.upVector(n, h, p)); } } const a = sc(e, i); for (let t = 0; t < a.length; t += 3) this.indexArray.emplaceBack(r + a[t], r + a[t + 2], r + a[t + 1]), s.primitiveLength++; } for (const i of t) { c && i.length && c.startRing(i[0]); let t, a, o, p = i.length > 4 && xh(i[i.length - 2], i[0], i[1]), f = m ? yh(i[i.length - 2], i[0], i[1], m) : 0; a = i[1].sub(i[0])._perp()._unit(); let d = !0; for (let y = 1, g = 0; y < i.length; y++) { let x = i[y - 1], v = i[y]; const b = i[y === i.length - 1 ? 1 : y + 1]; if (c && h && c.currentPolyCount.top++, gh(v, x, e)) { m && (a = b.sub(v)._perp()._unit(), d = !d); continue } c && c.append(v, x); const w = v.sub(x)._perp(), _ = w.x / (Math.abs(w.x) + Math.abs(w.y)), A = w.y > 0 ? 1 : 0, S = x.dist(v); if (g + S > 32768 && (g = 0), m) { o = b.sub(v)._perp()._unit(); let t = mh(x, v, b, dh(a, o), m); isNaN(t) && (t = 0); const e = v.sub(x)._unit(); x = x.add(e.mult(f))._round(), v = v.add(e.mult(-t))._round(), f = t, a = o; } const k = s.vertexLength, I = i.length > 4 && xh(x, v, b); let M = vh(g, p, d); if (ch(this.layoutVertexArray, x.x, x.y, _, A, 0, 0, M), ch(this.layoutVertexArray, x.x, x.y, _, A, 0, 1, M), g += S, M = vh(g, I, !d), p = I, ch(this.layoutVertexArray, v.x, v.y, _, A, 0, 0, M), ch(this.layoutVertexArray, v.x, v.y, _, A, 0, 1, M), s.vertexLength += 4, this.indexArray.emplaceBack(k + 0, k + 1, k + 2), this.indexArray.emplaceBack(k + 1, k + 3, k + 2), s.primitiveLength += 2, m) { const n = r + (1 === y ? i.length - 2 : y - 2), a = 1 === y ? r : n + 1; if (this.indexArray.emplaceBack(k + 1, n, k + 3), this.indexArray.emplaceBack(n, a, k + 3), s.primitiveLength += 2, void 0 === t && (t = k), !gh(b, i[y], e)) { const e = y === i.length - 1 ? t : s.vertexLength; this.indexArray.emplaceBack(k + 2, k + 3, e), this.indexArray.emplaceBack(k + 3, e + 1, e), this.indexArray.emplaceBack(k + 3, a, e + 1), s.primitiveLength += 3; } d = !d; } if (u) { const t = this.layoutVertexExtArray, e = l.projectTilePoint(x.x, x.y, n), r = l.projectTilePoint(v.x, v.y, n), i = l.upVector(n, x.x, x.y), s = l.upVector(n, v.x, v.y); hh(t, e, i), hh(t, e, i), hh(t, r, s), hh(t, r, s); } } h && (r += i.length - 1); } } if (c && c.polyCount.length > 0) { if (c.borders) { c.vertexArrayOffset = this.centroidVertexArray.length; const t = c.borders, e = this.featuresOnBorder.push(c) - 1; for (let r = 0; r < 4; r++) t[r][0] !== Number.MAX_VALUE && this.borders[r].push(e); } this.encodeCentroid(c.borders ? void 0 : c.centroid(), c); } this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, t, r, i, s, n); } sortBorders() { for (let t = 0; t < 4; t++) this.borders[t].sort(((e, r) => this.featuresOnBorder[e].borders[t][0] - this.featuresOnBorder[r].borders[t][0])); } encodeCentroid(t, e, r = !0) { let n, i; if (t) if (0 !== t.y) { const r = e.span()._mult(this.tileToMeter); n = (Math.max(t.x, 1) << 3) + Math.min(7, Math.round(r.x / 10)), i = (Math.max(t.y, 1) << 3) + Math.min(7, Math.round(r.y / 10)); } else n = Math.ceil(7 * (t.x + 450)), i = 0; else n = 0, i = +r; let s = r ? this.centroidVertexArray.length : e.vertexArrayOffset; for (const t of e.polyCount) { r && this.centroidVertexArray.resize(this.centroidVertexArray.length + 4 * t.edges + t.top); for (let e = 0; e < t.top; e++) this.centroidVertexArray.emplace(s++, n, i); for (let e = 0; e < 2 * t.edges; e++) this.centroidVertexArray.emplace(s++, 0, i), this.centroidVertexArray.emplace(s++, n, i); } } } function dh(t, e) { const r = t.add(e)._unit(); return t.x * r.x + t.y * r.y } function yh(t, e, r, n) { const i = e.sub(t)._perp()._unit(), s = r.sub(e)._perp()._unit(); return mh(t, e, r, dh(i, s), n) } function mh(t, e, r, n, i) { const s = Math.sqrt(1 - n * n); return Math.min(t.dist(e) / 3, e.dist(r) / 3, i * s / n) } function gh(t, e, r) { return t.x < r[0].x && e.x < r[0].x || t.x > r[1].x && e.x > r[1].x || t.y < r[0].y && e.y < r[0].y || t.y > r[1].y && e.y > r[1].y } function xh(t, e, r) { if (t.x < 0 || t.x >= ko || e.x < 0 || e.x >= ko || r.x < 0 || r.x >= ko) return !1; const n = r.sub(e), i = n.perp(), s = t.sub(e); return (n.x * s.x + n.y * s.y) / Math.sqrt((n.x * n.x + n.y * n.y) * (s.x * s.x + s.y * s.y)) > -.866 && i.x * s.x + i.y * s.y < 0 } function vh(t, e, r) { const n = e ? 2 | t : -3 & t; return r ? 1 | n : -2 & n } function bh() { const t = Math.PI / 32, e = Math.tan(t), r = tu; return r * Math.sqrt(1 + 2 * e * e) - r } function wh(t, e, r) { const n = 1 << r.z, i = ou(r.x / n), s = ou((r.x + 1) / n), a = lu(r.y / n), o = lu((r.y + 1) / n); return function(t, e, r, n, i = 0, s) { const a = []; if (!t.length || !r || !n) return a; const o = (t, e) => { for (const r of t) a.push({ polygon: r, bounds: e }); }, l = Math.ceil(Math.log2(r)), u = Math.ceil(Math.log2(n)), c = l - u, h = []; for (let t = 0; t < Math.abs(c); t++) h.push(c > 0 ? 0 : 1); for (let t = 0; t < Math.min(l, u); t++) h.push(0), h.push(1); let p = t; if (p = oh(p, e[0].y - i, e[1].y + i, 1), p = oh(p, e[0].x - i, e[1].x + i, 0), !p.length) return a; const f = []; for (h.length ? f.push({ polygons: p, bounds: e, depth: 0 }) : o(p, e); f.length;) { const t = f.pop(), e = t.depth, r = h[e], n = t.bounds[0], a = t.bounds[1], l = 0 === r ? n.x : n.y, u = 0 === r ? a.x : a.y, c = s ? s(r, l, u) : .5 * (l + u), p = oh(t.polygons, l - i, c + i, r), y = oh(t.polygons, c - i, u + i, r); if (p.length) { const t = [n, new d(0 === r ? c : a.x, 1 === r ? c : a.y)]; h.length > e + 1 ? f.push({ polygons: p, bounds: t, depth: e + 1 }) : o(p, t); } if (y.length) { const t = [new d(0 === r ? c : n.x, 1 === r ? c : n.y), a]; h.length > e + 1 ? f.push({ polygons: y, bounds: t, depth: e + 1 }) : o(y, t); } } return a }(t, e, Math.ceil((s - i) / 11.25), Math.ceil((a - o) / 11.25), 1, ((t, e, i) => { if (0 === t) return .5 * (e + i); { const t = lu((r.y + e / ko) / n); return (su(.5 * (lu((r.y + i / ko) / n) + t)) * n - r.y) * ko } })) } Oi(fh, "FillExtrusionBucket", { omit: ["layers", "features"] }), Oi(ph, "PartMetadata"); const _h = new Js({ "fill-extrusion-edge-radius": new Ys(Ht["layout_fill-extrusion"]["fill-extrusion-edge-radius"]) }); var Ah = { paint: new Js({ "fill-extrusion-opacity": new Ys(Ht["paint_fill-extrusion"]["fill-extrusion-opacity"]), "fill-extrusion-color": new Hs(Ht["paint_fill-extrusion"]["fill-extrusion-color"]), "fill-extrusion-translate": new Ys(Ht["paint_fill-extrusion"]["fill-extrusion-translate"]), "fill-extrusion-translate-anchor": new Ys(Ht["paint_fill-extrusion"]["fill-extrusion-translate-anchor"]), "fill-extrusion-pattern": new Hs(Ht["paint_fill-extrusion"]["fill-extrusion-pattern"]), "fill-extrusion-height": new Hs(Ht["paint_fill-extrusion"]["fill-extrusion-height"]), "fill-extrusion-base": new Hs(Ht["paint_fill-extrusion"]["fill-extrusion-base"]), "fill-extrusion-vertical-gradient": new Ys(Ht["paint_fill-extrusion"]["fill-extrusion-vertical-gradient"]), "fill-extrusion-ambient-occlusion-intensity": new Ys(Ht["paint_fill-extrusion"]["fill-extrusion-ambient-occlusion-intensity"]), "fill-extrusion-ambient-occlusion-radius": new Ys(Ht["paint_fill-extrusion"]["fill-extrusion-ambient-occlusion-radius"]) }), layout: _h }; function Sh(t, e, r) { var n = 2 * Math.PI * 6378137 / 256 / Math.pow(2, r); return [t * n - 2 * Math.PI * 6378137 / 2, e * n - 2 * Math.PI * 6378137 / 2] } class kh { constructor(t, e, r) { this.z = t, this.x = e, this.y = r, this.key = Th(0, t, t, e, r); } equals(t) { return this.z === t.z && this.x === t.x && this.y === t.y } url(t, e) { const r = function(t, e, r) { var n = Sh(256 * t, 256 * (e = Math.pow(2, r) - e - 1), r), i = Sh(256 * (t + 1), 256 * (e + 1), r); return n[0] + "," + n[1] + "," + i[0] + "," + i[1] }(this.x, this.y, this.z), n = function(t, e, r) { let n, i = ""; for (let s = t; s > 0; s--) n = 1 << s - 1, i += (e & n ? 1 : 0) + (r & n ? 2 : 0); return i }(this.z, this.x, this.y); return t[(this.x + this.y) % t.length].replace("{prefix}", (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" === e ? Math.pow(2, this.z) - this.y - 1 : this.y)).replace("{quadkey}", n).replace("{bbox-epsg-3857}", r) } toString() { return `${this.z}/${this.x}/${this.y}` } } class Ih { constructor(t, e) { this.wrap = t, this.canonical = e, this.key = Th(t, e.z, e.z, e.x, e.y); } } class Mh { constructor(t, e, r, n, i) { this.overscaledZ = t, this.wrap = e, this.canonical = new kh(r, +n, +i), this.key = 0 === e && t === r ? this.canonical.key : Th(e, t, r, n, i); } equals(t) { return this.overscaledZ === t.overscaledZ && this.wrap === t.wrap && this.canonical.equals(t.canonical) } scaledTo(t) { const e = this.canonical.z - t; return t > this.canonical.z ? new Mh(t, this.wrap, this.canonical.z, this.canonical.x, this.canonical.y) : new Mh(t, this.wrap, t, this.canonical.x >> e, this.canonical.y >> e) } calculateScaledKey(t, e = !0) { if (this.overscaledZ === t && e) return this.key; if (t > this.canonical.z) return Th(this.wrap * +e, t, this.canonical.z, this.canonical.x, this.canonical.y); { const r = this.canonical.z - t; return Th(this.wrap * +e, t, t, this.canonical.x >> r, this.canonical.y >> r) } } isChildOf(t) { if (t.wrap !== this.wrap) return !1; const e = this.canonical.z - t.canonical.z; return 0 === t.overscaledZ || t.overscaledZ < this.overscaledZ && t.canonical.x === this.canonical.x >> e && t.canonical.y === this.canonical.y >> e } children(t) { if (this.overscaledZ >= t) return [new Mh(this.overscaledZ + 1, this.wrap, this.canonical.z, this.canonical.x, this.canonical.y)]; const e = this.canonical.z + 1, r = 2 * this.canonical.x, n = 2 * this.canonical.y; return [new Mh(e, this.wrap, e, r, n), new Mh(e, this.wrap, e, r + 1, n), new Mh(e, this.wrap, e, r, n + 1), new Mh(e, this.wrap, e, r + 1, n + 1)] } isLessThan(t) { return this.wrap < t.wrap || !(this.wrap > t.wrap) && (this.overscaledZ < t.overscaledZ || !(this.overscaledZ > t.overscaledZ) && (this.canonical.x < t.canonical.x || !(this.canonical.x > t.canonical.x) && this.canonical.y < t.canonical.y)) } wrapped() { return new Mh(this.overscaledZ, 0, this.canonical.z, this.canonical.x, this.canonical.y) } unwrapTo(t) { return new Mh(this.overscaledZ, t, this.canonical.z, this.canonical.x, this.canonical.y) } overscaleFactor() { return Math.pow(2, this.overscaledZ - this.canonical.z) } toUnwrapped() { return new Ih(this.wrap, this.canonical) } toString() { return `${this.overscaledZ}/${this.canonical.x}/${this.canonical.y}` } } function Th(t, e, r, n, i) { const s = 1 << Math.min(r, 22); let a = s * (i % s) + n % s; return t && r < 22 && (a += s * s * ((t < 0 ? -2 * t - 1 : 2 * t) % (1 << 2 * (22 - r)))), 16 * (32 * a + r) + (e - r) } Oi(kh, "CanonicalTileID"), Oi(Mh, "OverscaledTileID", { omit: ["projMatrix"] }); class zh extends d { constructor(t, e, r) { super(t, e), this.z = r; } } function Bh(t, e) { return t.x * e.x + t.y * e.y } function Eh(t, e) { if (1 === t.length) { let r = 0; const n = e[r++]; let i; for (; !i || n.equals(i);) if (i = e[r++], !i) return 1 / 0; for (; r < e.length; r++) { const s = e[r], a = t[0], o = i.sub(n), l = s.sub(n), u = a.sub(n), c = Bh(o, o), h = Bh(o, l), p = Bh(l, l), f = Bh(u, o), d = Bh(u, l), y = c * p - h * h, m = (p * f - h * d) / y, g = (c * d - h * f) / y, x = n.z * (1 - m - g) + i.z * m + s.z * g; if (isFinite(x)) return x } return 1 / 0 } { let t = 1 / 0; for (const r of e) t = Math.min(t, r.z); return t } } function Ch(t, e, r, n, i, s, a, o) { const l = a * i.getElevationAt(t, e, !0, !0), u = 0 !== s[0], c = u ? 0 === s[1] ? a * (s[0] / 7 - 450) : a * function(t, e, r) { const n = Math.floor(e[0] / 8), i = Math.floor(e[1] / 8), s = 10 * (e[0] - 8 * n), a = 10 * (e[1] - 8 * i), o = t.getElevationAt(n, i, !0, !0), l = t.getMeterToDEM(r), u = Math.floor(.5 * (s * l - 1)), c = Math.floor(.5 * (a * l - 1)), h = t.tileCoordToPixel(n, i), p = 2 * u + 1, f = 2 * c + 1, d = function(t, e, r, n, i) { return [t.getElevationAtPixel(e, r, !0), t.getElevationAtPixel(e + i, r, !0), t.getElevationAtPixel(e, r + i, !0), t.getElevationAtPixel(e + n, r + i, !0)] }(t, h.x - u, h.y - c, p, f), y = Math.abs(d[0] - d[1]), m = Math.abs(d[2] - d[3]), g = Math.abs(d[0] - d[2]) + Math.abs(d[1] - d[3]), x = Math.min(.25, .5 * l * (y + m) / p), v = Math.min(.25, .5 * l * g / f); return o + Math.max(x * s, v * a) }(i, s, o) : l; return { base: l + (0 === r) ? -1 : r, top: u ? Math.max(c + n, l + r + 2) : l + n } } const Ph = na([{ name: "a_pos_normal", components: 2, type: "Int16" }, { name: "a_data", components: 4, type: "Uint8" }, { name: "a_linesofar", components: 1, type: "Float32" }], 4), { members: Dh } = Ph, Vh = na([{ name: "a_packed", components: 4, type: "Float32" }]), { members: Lh } = Vh, Fh = ah.types, Rh = Math.cos(Math.PI / 180 * 37.5); class jh { constructor(t) { this.zoom = t.zoom, this.overscaling = t.overscaling, this.layers = t.layers, this.layerIds = this.layers.map((t => t.id)), this.index = t.index, this.projection = t.projection, this.hasPattern = !1, this.patternFeatures = [], this.lineClipsArray = [], this.gradients = {}, this.layers.forEach((t => { this.gradients[t.id] = {}; })), this.layoutVertexArray = new la, this.layoutVertexArray2 = new ua, this.indexArray = new wa, this.programConfigurations = new fo(t.layers, t.zoom), this.segments = new So, this.maxLineLength = 0, this.stateDependentLayerIds = this.layers.filter((t => t.isStateDependent())).map((t => t.id)); } populate(t, e, r, n) { this.hasPattern = Rc("line", this.layers, e); const i = this.layers[0].layout.get("line-sort-key"), s = []; for (const { feature: e, id: a, index: o, sourceLayerIndex: l } of t) { const t = this.layers[0]._featureFilter.needGeometry, u = wu(e, t); if (!this.layers[0]._featureFilter.filter(new $s(this.zoom), u, r)) continue; const c = i ? i.evaluate(u, {}, r) : void 0, h = { id: a, properties: e.properties, type: e.type, sourceLayerIndex: l, index: o, geometry: t ? u.geometry : bu(e, r, n), patterns: {}, sortKey: c }; s.push(h); } i && s.sort(((t, e) => t.sortKey - e.sortKey)); const { lineAtlas: a, featureIndex: o } = e, l = this.addConstantDashes(a); for (const n of s) { const { geometry: i, index: s, sourceLayerIndex: u } = n; if (l && this.addFeatureDashes(n, a), this.hasPattern) { const t = jc("line", this.layers, n, this.zoom, e); this.patternFeatures.push(t); } else this.addFeature(n, i, s, r, a.positions, e.availableImages); o.insert(t[s].feature, i, s, u, this.index); } } addConstantDashes(t) { let e = !1; for (const r of this.layers) { const n = r.paint.get("line-dasharray").value, i = r.layout.get("line-cap").value; if ("constant" !== n.kind || "constant" !== i.kind) e = !0; else { const e = i.value, r = n.value; if (!r) continue; t.addDash(r, e); } } return e } addFeatureDashes(t, e) { const r = this.zoom; for (const n of this.layers) { const i = n.paint.get("line-dasharray").value, s = n.layout.get("line-cap").value; if ("constant" === i.kind && "constant" === s.kind) continue; let a, o; if ("constant" === i.kind) { if (a = i.value, !a) continue } else a = i.evaluate({ zoom: r }, t); o = "constant" === s.kind ? s.value : s.evaluate({ zoom: r }, t), e.addDash(a, o), t.patterns[n.id] = e.getKey(a, o); } } update(t, e, r, n) { this.stateDependentLayers.length && this.programConfigurations.updatePaintArrays(t, e, this.stateDependentLayers, r, n); } addFeatures(t, e, r, n, i) { for (const t of this.patternFeatures) this.addFeature(t, t.geometry, t.index, e, r, n); } isEmpty() { return 0 === this.layoutVertexArray.length } uploadPending() { return !this.uploaded || this.programConfigurations.needsUpload } upload(t) { this.uploaded || (0 !== this.layoutVertexArray2.length && (this.layoutVertexBuffer2 = t.createVertexBuffer(this.layoutVertexArray2, Lh)), this.layoutVertexBuffer = t.createVertexBuffer(this.layoutVertexArray, Dh), this.indexBuffer = t.createIndexBuffer(this.indexArray)), this.programConfigurations.upload(t), this.uploaded = !0; } destroy() { this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.indexBuffer.destroy(), this.programConfigurations.destroy(), this.segments.destroy()); } lineFeatureClips(t) { if (t.properties && t.properties.hasOwnProperty("mapbox_clip_start") && t.properties.hasOwnProperty("mapbox_clip_end")) return { start: +t.properties.mapbox_clip_start, end: +t.properties.mapbox_clip_end } } addFeature(t, e, r, n, i, s) { const a = this.layers[0].layout, o = a.get("line-join").evaluate(t, {}), l = a.get("line-cap").evaluate(t, {}), u = a.get("line-miter-limit"), c = a.get("line-round-limit"); this.lineClips = this.lineFeatureClips(t); for (const r of e) this.addLine(r, t, o, l, u, c); this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, t, r, i, s, n); } addLine(t, e, r, n, i, s) { if (this.distance = 0, this.scaledDistance = 0, this.totalDistance = 0, this.lineSoFar = 0, this.lineClips) { this.lineClipsArray.push(this.lineClips); for (let e = 0; e < t.length - 1; e++) this.totalDistance += t[e].dist(t[e + 1]); this.updateScaledDistance(), this.maxLineLength = Math.max(this.maxLineLength, this.totalDistance); } const a = "Polygon" === Fh[e.type]; let o = t.length; for (; o >= 2 && t[o - 1].equals(t[o - 2]);) o--; let l = 0; for (; l < o - 1 && t[l].equals(t[l + 1]);) l++; if (o < (a ? 3 : 2)) return; "bevel" === r && (i = 1.05); const u = this.overscaling <= 16 ? 122880 / (512 * this.overscaling) : 0, c = this.segments.prepareSegment(10 * o, this.layoutVertexArray, this.indexArray); let h, p, f, d, y; this.e1 = this.e2 = -1, a && (h = t[o - 2], y = t[l].sub(h)._unit()._perp()); for (let e = l; e < o; e++) { if (f = e === o - 1 ? a ? t[l + 1] : void 0 : t[e + 1], f && t[e].equals(f)) continue; y && (d = y), h && (p = h), h = t[e], y = f ? f.sub(h)._unit()._perp() : d, d = d || y; let m = d.add(y); 0 === m.x && 0 === m.y || m._unit(); const g = d.x * y.x + d.y * y.y, x = m.x * y.x + m.y * y.y, v = 0 !== x ? 1 / x : 1 / 0, b = 2 * Math.sqrt(2 - 2 * x), w = x < Rh && p && f, _ = d.x * y.y - d.y * y.x > 0; if (w && e > l) { const t = h.dist(p); if (t > 2 * u) { const e = h.sub(h.sub(p)._mult(u / t)._round()); this.updateDistance(p, e), this.addCurrentVertex(e, d, 0, 0, c), p = e; } } const A = p && f; let S = A ? r : a ? "butt" : n; if (A && "round" === S && (v < s ? S = "miter" : v <= 2 && (S = "fakeround")), "miter" === S && v > i && (S = "bevel"), "bevel" === S && (v > 2 && (S = "flipbevel"), v < i && (S = "miter")), p && this.updateDistance(p, h), "miter" === S) m._mult(v), this.addCurrentVertex(h, m, 0, 0, c); else if ("flipbevel" === S) { if (v > 100) m = y.mult(-1); else { const t = v * d.add(y).mag() / d.sub(y).mag(); m._perp()._mult(t * (_ ? -1 : 1)); } this.addCurrentVertex(h, m, 0, 0, c), this.addCurrentVertex(h, m.mult(-1), 0, 0, c); } else if ("bevel" === S || "fakeround" === S) { const t = -Math.sqrt(v * v - 1), e = _ ? t : 0, r = _ ? 0 : t; if (p && this.addCurrentVertex(h, d, e, r, c), "fakeround" === S) { const t = Math.round(180 * b / Math.PI / 20); for (let e = 1; e < t; e++) { let r = e / t; if (.5 !== r) { const t = r - .5; r += r * t * (r - 1) * ((1.0904 + g * (g * (3.55645 - 1.43519 * g) - 3.2452)) * t * t + (.848013 + g * (.215638 * g - 1.06021))); } const n = y.sub(d)._mult(r)._add(d)._unit()._mult(_ ? -1 : 1); this.addHalfVertex(h, n.x, n.y, !1, _, 0, c); } } f && this.addCurrentVertex(h, y, -e, -r, c); } else if ("butt" === S) this.addCurrentVertex(h, m, 0, 0, c); else if ("square" === S) { const t = p ? 1 : -1; p || this.addCurrentVertex(h, m, t, t, c), this.addCurrentVertex(h, m, 0, 0, c), p && this.addCurrentVertex(h, m, t, t, c); } else "round" === S && (p && (this.addCurrentVertex(h, d, 0, 0, c), this.addCurrentVertex(h, d, 1, 1, c, !0)), f && (this.addCurrentVertex(h, y, -1, -1, c, !0), this.addCurrentVertex(h, y, 0, 0, c))); if (w && e < o - 1) { const t = h.dist(f); if (t > 2 * u) { const e = h.add(f.sub(h)._mult(u / t)._round()); this.updateDistance(h, e), this.addCurrentVertex(e, y, 0, 0, c), h = e; } } } } addCurrentVertex(t, e, r, n, i, s = !1) { const a = e.y * n - e.x, o = -e.y - e.x * n; this.addHalfVertex(t, e.x + e.y * r, e.y - e.x * r, s, !1, r, i), this.addHalfVertex(t, a, o, s, !0, -n, i); } addHalfVertex({ x: t, y: e }, r, n, i, s, a, o) { this.layoutVertexArray.emplaceBack((t << 1) + (i ? 1 : 0), (e << 1) + (s ? 1 : 0), Math.round(63 * r) + 128, Math.round(63 * n) + 128, 1 + (0 === a ? 0 : a < 0 ? -1 : 1), 0, this.lineSoFar), this.lineClips && this.layoutVertexArray2.emplaceBack(this.scaledDistance, this.lineClipsArray.length, this.lineClips.start, this.lineClips.end); const l = o.vertexLength++; this.e1 >= 0 && this.e2 >= 0 && (this.indexArray.emplaceBack(this.e1, this.e2, l), o.primitiveLength++), s ? this.e2 = l : this.e1 = l; } updateScaledDistance() { if (this.lineClips) { const t = this.totalDistance / (this.lineClips.end - this.lineClips.start); this.scaledDistance = this.distance / this.totalDistance, this.lineSoFar = t * this.lineClips.start + this.distance; } else this.lineSoFar = this.distance; } updateDistance(t, e) { this.distance += t.dist(e), this.updateScaledDistance(); } } Oi(jh, "LineBucket", { omit: ["layers", "patternFeatures"] }); const $h = new Js({ "line-cap": new Hs(Ht.layout_line["line-cap"]), "line-join": new Hs(Ht.layout_line["line-join"]), "line-miter-limit": new Ys(Ht.layout_line["line-miter-limit"]), "line-round-limit": new Ys(Ht.layout_line["line-round-limit"]), "line-sort-key": new Hs(Ht.layout_line["line-sort-key"]) }); var Uh = { paint: new Js({ "line-opacity": new Hs(Ht.paint_line["line-opacity"]), "line-color": new Hs(Ht.paint_line["line-color"]), "line-translate": new Ys(Ht.paint_line["line-translate"]), "line-translate-anchor": new Ys(Ht.paint_line["line-translate-anchor"]), "line-width": new Hs(Ht.paint_line["line-width"]), "line-gap-width": new Hs(Ht.paint_line["line-gap-width"]), "line-offset": new Hs(Ht.paint_line["line-offset"]), "line-blur": new Hs(Ht.paint_line["line-blur"]), "line-dasharray": new Hs(Ht.paint_line["line-dasharray"]), "line-pattern": new Hs(Ht.paint_line["line-pattern"]), "line-gradient": new Ws(Ht.paint_line["line-gradient"]), "line-trim-offset": new Ys(Ht.paint_line["line-trim-offset"]) }), layout: $h }; const Oh = new class extends Hs { possiblyEvaluate(t, e) { return e = new $s(Math.floor(e.zoom), { now: e.now, fadeDuration: e.fadeDuration, transition: e.transition }), super.possiblyEvaluate(t, e) } evaluate(t, e, r, n) { return e = z({}, e, { zoom: Math.floor(e.zoom) }), super.evaluate(t, e, r, n) } }(Uh.paint.properties["line-width"].specification); function qh(t, e) { return e > 0 ? e + 2 * t : t } Oh.useIntegerZoom = !0; const Nh = na([{ name: "a_pos_offset", components: 4, type: "Int16" }, { name: "a_tex_size", components: 4, type: "Uint16" }, { name: "a_pixeloffset", components: 4, type: "Int16" }], 4), Gh = na([{ name: "a_globe_anchor", components: 3, type: "Int16" }, { name: "a_globe_normal", components: 3, type: "Float32" }], 4), Zh = na([{ name: "a_projected_pos", components: 4, type: "Float32" }], 4); na([{ name: "a_fade_opacity", components: 1, type: "Uint32" }], 4); const Xh = na([{ name: "a_placed", components: 2, type: "Uint8" }, { name: "a_shift", components: 2, type: "Float32" }]), Kh = na([{ name: "a_size_scale", components: 1, type: "Float32" }, { name: "a_padding", components: 2, type: "Float32" }]); na([{ type: "Int16", name: "projectedAnchorX" }, { type: "Int16", name: "projectedAnchorY" }, { type: "Int16", name: "projectedAnchorZ" }, { type: "Int16", name: "tileAnchorX" }, { type: "Int16", name: "tileAnchorY" }, { type: "Float32", name: "x1" }, { type: "Float32", name: "y1" }, { type: "Float32", name: "x2" }, { type: "Float32", name: "y2" }, { type: "Int16", name: "padding" }, { type: "Uint32", name: "featureIndex" }, { type: "Uint16", name: "sourceLayerIndex" }, { type: "Uint16", name: "bucketIndex" }]); const Yh = na([{ name: "a_pos", components: 3, type: "Int16" }, { name: "a_anchor_pos", components: 2, type: "Int16" }, { name: "a_extrude", components: 2, type: "Int16" }], 4), Hh = na([{ name: "a_pos_2f", components: 2, type: "Float32" }, { name: "a_radius", components: 1, type: "Float32" }, { name: "a_flags", components: 2, type: "Int16" }], 4); na([{ name: "triangle", components: 3, type: "Uint16" }]), na([{ type: "Int16", name: "projectedAnchorX" }, { type: "Int16", name: "projectedAnchorY" }, { type: "Int16", name: "projectedAnchorZ" }, { type: "Float32", name: "tileAnchorX" }, { type: "Float32", name: "tileAnchorY" }, { 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" }, { type: "Uint8", name: "flipState" }]), na([{ type: "Int16", name: "projectedAnchorX" }, { type: "Int16", name: "projectedAnchorY" }, { type: "Int16", name: "projectedAnchorZ" }, { type: "Float32", name: "tileAnchorX" }, { type: "Float32", name: "tileAnchorY" }, { 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", components: 2, name: "textOffset" }, { type: "Float32", name: "collisionCircleDiameter" }]), na([{ type: "Float32", name: "offsetX" }]), na([{ type: "Int16", name: "x" }, { type: "Int16", name: "y" }]); var Wh = 24; const Jh = 128; function Qh(t, e) { const { expression: r } = e; if ("constant" === r.kind) return { kind: "constant", layoutSize: r.evaluate(new $s(t + 1)) }; if ("source" === r.kind) return { kind: "source" }; { const { zoomStops: e, interpolationType: n } = r; let i = 0; for (; i < e.length && e[i] <= t;) i++; i = Math.max(0, i - 1); let s = i; for (; s < e.length && e[s] < t + 1;) s++; s = Math.min(e.length - 1, s); const a = e[i], o = e[s]; return "composite" === r.kind ? { kind: "composite", minZoom: a, maxZoom: o, interpolationType: n } : { kind: "camera", minZoom: a, maxZoom: o, minSize: r.evaluate(new $s(a)), maxSize: r.evaluate(new $s(o)), interpolationType: n } } } function tp(t, { uSize: e, uSizeT: r }, { lowerSize: n, upperSize: i }) { return "source" === t.kind ? n / Jh : "composite" === t.kind ? Mr(n / Jh, i / Jh, r) : e } function ep(t, e) { let r = 0, n = 0; if ("constant" === t.kind) n = t.layoutSize; else if ("source" !== t.kind) { const { interpolationType: i, minZoom: s, maxZoom: a } = t, o = i ? S(Kr.interpolationFactor(i, e, s, a), 0, 1) : 0; "camera" === t.kind ? n = Mr(t.minSize, t.maxSize, o) : r = o; } return { uSizeT: r, uSize: n } } var rp = Object.freeze({ __proto__: null, getSizeData: Qh, evaluateSizeForFeature: tp, evaluateSizeForZoom: ep, SIZE_PACK_FACTOR: Jh }); function np(t, e, r) { return t.sections.forEach((t => { t.text = function(t, e, r) { const n = e.layout.get("text-transform").evaluate(r, {}); return "uppercase" === n ? t = t.toLocaleUpperCase() : "lowercase" === n && (t = t.toLocaleLowerCase()), js.applyArabicShaping && (t = js.applyArabicShaping(t)), t }(t.text, e, r); })), t } const ip = { "!": "︕", "#": "#", $: "$", "%": "%", "&": "&", "(": "︵", ")": "︶", "*": "*", "+": "+", ",": "︐", "-": "︲", ".": "・", "/": "/", ":": "︓", ";": "︔", "<": "︿", "=": "=", ">": "﹀", "?": "︖", "@": "@", "[": "﹇", "\\": "\", "]": "﹈", "^": "^", _: "︳", "`": "`", "{": "︷", "|": "―", "}": "︸", "~": "~", "¢": "¢", "£": "£", "¥": "¥", "¦": "¦", "¬": "¬", "¯": " ̄", "–": "︲", "—": "︱", "‘": "﹃", "’": "﹄", "“": "﹁", "”": "﹂", "…": "︙", "‧": "・", "₩": "₩", "、": "︑", "。": "︒", "〈": "︿", "〉": "﹀", "《": "︽", "》": "︾", "「": "﹁", "」": "﹂", "『": "﹃", "』": "﹄", "【": "︻", "】": "︼", "〔": "︹", "〕": "︺", "〖": "︗", "〗": "︘", "!": "︕", "(": "︵", ")": "︶", ",": "︐", "-": "︲", ".": "・", ":": "︓", ";": "︔", "<": "︿", ">": "﹀", "?": "︖", "[": "﹇", "]": "﹈", "_": "︳", "{": "︷", "|": "―", "}": "︸", "⦅": "︵", "⦆": "︶", "。": "︒", "「": "﹁", "」": "﹂", "←": "↑", "→": "↓" }; function sp(t) { return "︶" === t || "﹈" === t || "︸" === t || "﹄" === t || "﹂" === t || "︾" === t || "︼" === t || "︺" === t || "︘" === t || "﹀" === t || "︐" === t || "︓" === t || "︔" === t || "`" === t || " ̄" === t || "︑" === t || "︒" === t } function ap(t) { return "︵" === t || "﹇" === t || "︷" === t || "﹃" === t || "﹁" === t || "︽" === t || "︻" === t || "︹" === t || "︗" === t || "︿" === t } var op = cp, lp = function(t, e, r, n, i) { var s, a, o = 8 * i - n - 1, l = (1 << o) - 1, u = l >> 1, c = -7, h = r ? i - 1 : 0, p = r ? -1 : 1, f = t[e + h]; for (h += p, s = f & (1 << -c) - 1, f >>= -c, c += o; c > 0; s = 256 * s + t[e + h], h += p, c -= 8); for (a = s & (1 << -c) - 1, s >>= -c, c += n; c > 0; a = 256 * a + t[e + h], h += p, c -= 8); if (0 === s) s = 1 - u; else { if (s === l) return a ? NaN : 1 / 0 * (f ? -1 : 1); a += Math.pow(2, n), s -= u; } return (f ? -1 : 1) * a * Math.pow(2, s - n) }, up = function(t, e, r, n, i, s) { var a, o, l, u = 8 * s - i - 1, c = (1 << u) - 1, h = c >> 1, p = 23 === i ? Math.pow(2, -24) - Math.pow(2, -77) : 0, f = n ? 0 : s - 1, d = n ? 1 : -1, y = e < 0 || 0 === e && 1 / e < 0 ? 1 : 0; for (e = Math.abs(e), isNaN(e) || e === 1 / 0 ? (o = isNaN(e) ? 1 : 0, a = c) : (a = Math.floor(Math.log(e) / Math.LN2), e * (l = Math.pow(2, -a)) < 1 && (a--, l *= 2), (e += a + h >= 1 ? p / l : p * Math.pow(2, 1 - h)) * l >= 2 && (a++, l /= 2), a + h >= c ? (o = 0, a = c) : a + h >= 1 ? (o = (e * l - 1) * Math.pow(2, i), a += h) : (o = e * Math.pow(2, h - 1) * Math.pow(2, i), a = 0)); i >= 8; t[r + f] = 255 & o, f += d, o /= 256, i -= 8); for (a = a << i | o, u += i; u > 0; t[r + f] = 255 & a, f += d, a /= 256, u -= 8); t[r + f - d] |= 128 * y; }; /*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh <https://feross.org/opensource> */ function cp(t) { this.buf = ArrayBuffer.isView && ArrayBuffer.isView(t) ? t : new Uint8Array(t || 0), this.pos = 0, this.type = 0, this.length = this.buf.length; } cp.Varint = 0, cp.Fixed64 = 1, cp.Bytes = 2, cp.Fixed32 = 5; var hp = 4294967296, pp = 1 / hp, fp = "undefined" == typeof TextDecoder ? null : new TextDecoder("utf8"); function dp(t) { return t.type === cp.Bytes ? t.readVarint() + t.pos : t.pos + 1 } function yp(t, e, r) { return r ? 4294967296 * e + (t >>> 0) : 4294967296 * (e >>> 0) + (t >>> 0) } function mp(t, e, r) { var n = e <= 16383 ? 1 : e <= 2097151 ? 2 : e <= 268435455 ? 3 : Math.floor(Math.log(e) / (7 * Math.LN2)); r.realloc(n); for (var i = r.pos - 1; i >= t; i--) r.buf[i + n] = r.buf[i]; } function gp(t, e) { for (var r = 0; r < t.length; r++) e.writeVarint(t[r]); } function xp(t, e) { for (var r = 0; r < t.length; r++) e.writeSVarint(t[r]); } function vp(t, e) { for (var r = 0; r < t.length; r++) e.writeFloat(t[r]); } function bp(t, e) { for (var r = 0; r < t.length; r++) e.writeDouble(t[r]); } function wp(t, e) { for (var r = 0; r < t.length; r++) e.writeBoolean(t[r]); } function _p(t, e) { for (var r = 0; r < t.length; r++) e.writeFixed32(t[r]); } function Ap(t, e) { for (var r = 0; r < t.length; r++) e.writeSFixed32(t[r]); } function Sp(t, e) { for (var r = 0; r < t.length; r++) e.writeFixed64(t[r]); } function kp(t, e) { for (var r = 0; r < t.length; r++) e.writeSFixed64(t[r]); } function Ip(t, e) { return (t[e] | t[e + 1] << 8 | t[e + 2] << 16) + 16777216 * t[e + 3] } function Mp(t, e, r) { t[r] = e, t[r + 1] = e >>> 8, t[r + 2] = e >>> 16, t[r + 3] = e >>> 24; } function Tp(t, e) { return (t[e] | t[e + 1] << 8 | t[e + 2] << 16) + (t[e + 3] << 24) } function zp(t, e, r) { e.glyphs = [], 1 === t && r.readMessage(Bp, e); } function Bp(t, e, r) { if (3 === t) { const { id: t, bitmap: n, width: i, height: s, left: a, top: o, advance: l } = r.readMessage(Ep, {}); e.glyphs.push({ id: t, bitmap: new Ju({ width: i + 6, height: s + 6 }, n), metrics: { width: i, height: s, left: a, top: o, advance: l } }); } else 4 === t ? e.ascender = r.readSVarint() : 5 === t && (e.descender = r.readSVarint()); } function Ep(t, e, r) { 1 === t ? e.id = r.readVarint() : 2 === t ? e.bitmap = r.readBytes() : 3 === t ? e.width = r.readVarint() : 4 === t ? e.height = r.readVarint() : 5 === t ? e.left = r.readSVarint() : 6 === t ? e.top = r.readSVarint() : 7 === t && (e.advance = r.readVarint()); } function Cp(t) { let e = 0, r = 0; for (const n of t) e += n.w * n.h, r = Math.max(r, n.w); t.sort(((t, e) => e.h - t.h)); const n = [{ x: 0, y: 0, w: Math.max(Math.ceil(Math.sqrt(e / .95)), r), h: 1 / 0 }]; let i = 0, s = 0; for (const e of t) for (let t = n.length - 1; t >= 0; t--) { const r = n[t]; if (!(e.w > r.w || e.h > r.h)) { if (e.x = r.x, e.y = r.y, s = Math.max(s, e.y + e.h), i = Math.max(i, e.x + e.w), e.w === r.w && e.h === r.h) { const e = n.pop(); t < n.length && (n[t] = e); } else e.h === r.h ? (r.x += e.w, r.w -= e.w) : e.w === r.w ? (r.y += e.h, r.h -= e.h) : (n.push({ x: r.x + e.w, y: r.y, w: r.w - e.w, h: e.h }), r.y += e.h, r.h -= e.h); break } } return { w: i, h: s, fill: e / (i * s) || 0 } } cp.prototype = { destroy: function() { this.buf = null; }, readFields: function(t, e, r) { for (r = r || this.length; this.pos < r;) { var n = this.readVarint(), i = n >> 3, s = this.pos; this.type = 7 & n, t(i, e, this), this.pos === s && this.skip(n); } return e }, readMessage: function(t, e) { return this.readFields(t, e, this.readVarint() + this.pos) }, readFixed32: function() { var t = Ip(this.buf, this.pos); return this.pos += 4, t }, readSFixed32: function() { var t = Tp(this.buf, this.pos); return this.pos += 4, t }, readFixed64: function() { var t = Ip(this.buf, this.pos) + Ip(this.buf, this.pos + 4) * hp; return this.pos += 8, t }, readSFixed64: function() { var t = Ip(this.buf, this.pos) + Tp(this.buf, this.pos + 4) * hp; return this.pos += 8, t }, readFloat: function() { var t = lp(this.buf, this.pos, !0, 23, 4); return this.pos += 4, t }, readDouble: function() { var t = lp(this.buf, this.pos, !0, 52, 8); return this.pos += 8, t }, readVarint: function(t) { var e, r, n = this.buf; return e = 127 & (r = n[this.pos++]), r < 128 ? e : (e |= (127 & (r = n[this.pos++])) << 7, r < 128 ? e : (e |= (127 & (r = n[this.pos++])) << 14, r < 128 ? e : (e |= (127 & (r = n[this.pos++])) << 21, r < 128 ? e : function(t, e, r) { var n, i, s = r.buf; if (n = (112 & (i = s[r.pos++])) >> 4, i < 128) return yp(t, n, e); if (n |= (127 & (i = s[r.pos++])) << 3, i < 128) return yp(t, n, e); if (n |= (127 & (i = s[r.pos++])) << 10, i < 128) return yp(t, n, e); if (n |= (127 & (i = s[r.pos++])) << 17, i < 128) return yp(t, n, e); if (n |= (127 & (i = s[r.pos++])) << 24, i < 128) return yp(t, n, e); if (n |= (1 & (i = s[r.pos++])) << 31, i < 128) return yp(t, n, e); throw new Error("Expected varint not more than 10 bytes") }(e |= (15 & (r = n[this.pos])) << 28, t, this)))) }, readVarint64: function() { return this.readVarint(!0) }, readSVarint: function() { var t = this.readVarint(); return t % 2 == 1 ? (t + 1) / -2 : t / 2 }, readBoolean: function() { return Boolean(this.readVarint()) }, readString: function() { var t = this.readVarint() + this.pos, e = this.pos; return this.pos = t, t - e >= 12 && fp ? function(t, e, r) { return fp.decode(t.subarray(e, r)) }(this.buf, e, t) : function(t, e, r) { for (var n = "", i = e; i < r;) { var s, a, o, l = t[i], u = null, c = l > 239 ? 4 : l > 223 ? 3 : l > 191 ? 2 : 1; if (i + c > r) break; 1 === c ? l < 128 && (u = l) : 2 === c ? 128 == (192 & (s = t[i + 1])) && (u = (31 & l) << 6 | 63 & s) <= 127 && (u = null) : 3 === c ? (a = t[i + 2], 128 == (192 & (s = t[i + 1])) && 128 == (192 & a) && ((u = (15 & l) << 12 | (63 & s) << 6 | 63 & a) <= 2047 || u >= 55296 && u <= 57343) && (u = null)) : 4 === c && (a = t[i + 2], o = t[i + 3], 128 == (192 & (s = t[i + 1])) && 128 == (192 & a) && 128 == (192 & o) && ((u = (15 & l) << 18 | (63 & s) << 12 | (63 & a) << 6 | 63 & o) <= 65535 || u >= 1114112) && (u = null)), null === u ? (u = 65533, c = 1) : u > 65535 && (u -= 65536, n += String.fromCharCode(u >>> 10 & 1023 | 55296), u = 56320 | 1023 & u), n += String.fromCharCode(u), i += c; } return n }(this.buf, e, t) }, readBytes: function() { var t = this.readVarint() + this.pos, e = this.buf.subarray(this.pos, t); return this.pos = t, e }, readPackedVarint: function(t, e) { if (this.type !== cp.Bytes) return t.push(this.readVarint(e)); var r = dp(this); for (t = t || []; this.pos < r;) t.push(this.readVarint(e)); return t }, readPackedSVarint: function(t) { if (this.type !== cp.Bytes) return t.push(this.readSVarint()); var e = dp(this); for (t = t || []; this.pos < e;) t.push(this.readSVarint()); return t }, readPackedBoolean: function(t) { if (this.type !== cp.Bytes) return t.push(this.readBoolean()); var e = dp(this); for (t = t || []; this.pos < e;) t.push(this.readBoolean()); return t }, readPackedFloat: function(t) { if (this.type !== cp.Bytes) return t.push(this.readFloat()); var e = dp(this); for (t = t || []; this.pos < e;) t.push(this.readFloat()); return t }, readPackedDouble: function(t) { if (this.type !== cp.Bytes) return t.push(this.readDouble()); var e = dp(this); for (t = t || []; this.pos < e;) t.push(this.readDouble()); return t }, readPackedFixed32: function(t) { if (this.type !== cp.Bytes) return t.push(this.readFixed32()); var e = dp(this); for (t = t || []; this.pos < e;) t.push(this.readFixed32()); return t }, readPackedSFixed32: function(t) { if (this.type !== cp.Bytes) return t.push(this.readSFixed32()); var e = dp(this); for (t = t || []; this.pos < e;) t.push(this.readSFixed32()); return t }, readPackedFixed64: function(t) { if (this.type !== cp.Bytes) return t.push(this.readFixed64()); var e = dp(this); for (t = t || []; this.pos < e;) t.push(this.readFixed64()); return t }, readPackedSFixed64: function(t) { if (this.type !== cp.Bytes) return t.push(this.readSFixed64()); var e = dp(this); for (t = t || []; this.pos < e;) t.push(this.readSFixed64()); return t }, skip: function(t) { var e = 7 & t; if (e === cp.Varint) for (; this.buf[this.pos++] > 127;); else if (e === cp.Bytes) this.pos = this.readVarint() + this.pos; else if (e === cp.Fixed32) this.pos += 4; else { if (e !== cp.Fixed64) throw new Error("Unimplemented type: " + e); this.pos += 8; } }, writeTag: function(t, e) { this.writeVarint(t << 3 | e); }, realloc: function(t) { for (var e = this.length || 16; e < this.pos + t;) e *= 2; if (e !== this.length) { var r = new Uint8Array(e); r.set(this.buf), this.buf = r, this.length = e; } }, finish: function() { return this.length = this.pos, this.pos = 0, this.buf.subarray(0, this.length) }, writeFixed32: function(t) { this.realloc(4), Mp(this.buf, t, this.pos), this.pos += 4; }, writeSFixed32: function(t) { this.realloc(4), Mp(this.buf, t, this.pos), this.pos += 4; }, writeFixed64: function(t) { this.realloc(8), Mp(this.buf, -1 & t, this.pos), Mp(this.buf, Math.floor(t * pp), this.pos + 4), this.pos += 8; }, writeSFixed64: function(t) { this.realloc(8), Mp(this.buf, -1 & t, this.pos), Mp(this.buf, Math.floor(t * pp), this.pos + 4), this.pos += 8; }, writeVarint: function(t) { (t = +t || 0) > 268435455 || t < 0 ? function(t, e) { var r, n; if (t >= 0 ? (r = t % 4294967296 | 0, n = t / 4294967296 | 0) : (n = ~(-t / 4294967296), 4294967295 ^ (r = ~(-t % 4294967296)) ? r = r + 1 | 0 : (r = 0, n = n + 1 | 0)), t >= 0x10000000000000000 || t < -0x10000000000000000) throw new Error("Given varint doesn't fit into 10 bytes"); e.realloc(10), function(t, e, r) { r.buf[r.pos++] = 127 & t | 128, t >>>= 7, r.buf[r.pos++] = 127 & t | 128, t >>>= 7, r.buf[r.pos++] = 127 & t | 128, t >>>= 7, r.buf[r.pos++] = 127 & t | 128, r.buf[r.pos] = 127 & (t >>>= 7); }(r, 0, e), function(t, e) { var r = (7 & t) << 4; e.buf[e.pos++] |= r | ((t >>>= 3) ? 128 : 0), t && (e.buf[e.pos++] = 127 & t | ((t >>>= 7) ? 128 : 0), t && (e.buf[e.pos++] = 127 & t | ((t >>>= 7) ? 128 : 0), t && (e.buf[e.pos++] = 127 & t | ((t >>>= 7) ? 128 : 0), t && (e.buf[e.pos++] = 127 & t | ((t >>>= 7) ? 128 : 0), t && (e.buf[e.pos++] = 127 & t))))); }(n, e); }(t, this) : (this.realloc(4), this.buf[this.pos++] = 127 & t | (t > 127 ? 128 : 0), t <= 127 || (this.buf[this.pos++] = 127 & (t >>>= 7) | (t > 127 ? 128 : 0), t <= 127 || (this.buf[this.pos++] = 127 & (t >>>= 7) | (t > 127 ? 128 : 0), t <= 127 || (this.buf[this.pos++] = t >>> 7 & 127)))); }, writeSVarint: function(t) { this.writeVarint(t < 0 ? 2 * -t - 1 : 2 * t); }, writeBoolean: function(t) { this.writeVarint(Boolean(t)); }, writeString: function(t) { t = String(t), this.realloc(4 * t.length), this.pos++; var e = this.pos; this.pos = function(t, e, r) { for (var n, i, s = 0; s < e.length; s++) { if ((n = e.charCodeAt(s)) > 55295 && n < 57344) { if (!i) { n > 56319 || s + 1 === e.length ? (t[r++] = 239, t[r++] = 191, t[r++] = 189) : i = n; continue } if (n < 56320) { t[r++] = 239, t[r++] = 191, t[r++] = 189, i = n; continue } n = i - 55296 << 10 | n - 56320 | 65536, i = null; } else i && (t[r++] = 239, t[r++] = 191, t[r++] = 189, i = null); n < 128 ? t[r++] = n : (n < 2048 ? t[r++] = n >> 6 | 192 : (n < 65536 ? t[r++] = n >> 12 | 224 : (t[r++] = n >> 18 | 240, t[r++] = n >> 12 & 63 | 128), t[r++] = n >> 6 & 63 | 128), t[r++] = 63 & n | 128); } return r }(this.buf, t, this.pos); var r = this.pos - e; r >= 128 && mp(e, r, this), this.pos = e - 1, this.writeVarint(r), this.pos += r; }, writeFloat: function(t) { this.realloc(4), up(this.buf, t, this.pos, !0, 23, 4), this.pos += 4; }, writeDouble: function(t) { this.realloc(8), up(this.buf, t, this.pos, !0, 52, 8), this.pos += 8; }, writeBytes: function(t) { var e = t.length; this.writeVarint(e), this.realloc(e); for (var r = 0; r < e; r++) this.buf[this.pos++] = t[r]; }, writeRawMessage: function(t, e) { this.pos++; var r = this.pos; t(e, this); var n = this.pos - r; n >= 128 && mp(r, n, this), this.pos = r - 1, this.writeVarint(n), this.pos += n; }, writeMessage: function(t, e, r) { this.writeTag(t, cp.Bytes), this.writeRawMessage(e, r); }, writePackedVarint: function(t, e) { e.length && this.writeMessage(t, gp, e); }, writePackedSVarint: function(t, e) { e.length && this.writeMessage(t, xp, e); }, writePackedBoolean: function(t, e) { e.length && this.writeMessage(t, wp, e); }, writePackedFloat: function(t, e) { e.length && this.writeMessage(t, vp, e); }, writePackedDouble: function(t, e) { e.length && this.writeMessage(t, bp, e); }, writePackedFixed32: function(t, e) { e.length && this.writeMessage(t, _p, e); }, writePackedSFixed32: function(t, e) { e.length && this.writeMessage(t, Ap, e); }, writePackedFixed64: function(t, e) { e.length && this.writeMessage(t, Sp, e); }, writePackedSFixed64: function(t, e) { e.length && this.writeMessage(t, kp, e); }, writeBytesField: function(t, e) { this.writeTag(t, cp.Bytes), this.writeBytes(e); }, writeFixed32Field: function(t, e) { this.writeTag(t, cp.Fixed32), this.writeFixed32(e); }, writeSFixed32Field: function(t, e) { this.writeTag(t, cp.Fixed32), this.writeSFixed32(e); }, writeFixed64Field: function(t, e) { this.writeTag(t, cp.Fixed64), this.writeFixed64(e); }, writeSFixed64Field: function(t, e) { this.writeTag(t, cp.Fixed64), this.writeSFixed64(e); }, writeVarintField: function(t, e) { this.writeTag(t, cp.Varint), this.writeVarint(e); }, writeSVarintField: function(t, e) { this.writeTag(t, cp.Varint), this.writeSVarint(e); }, writeStringField: function(t, e) { this.writeTag(t, cp.Bytes), this.writeString(e); }, writeFloatField: function(t, e) { this.writeTag(t, cp.Fixed32), this.writeFloat(e); }, writeDoubleField: function(t, e) { this.writeTag(t, cp.Fixed64), this.writeDouble(e); }, writeBooleanField: function(t, e) { this.writeVarintField(t, Boolean(e)); } }; class Pp { constructor(t, { pixelRatio: e, version: r, stretchX: n, stretchY: i, content: s }) { this.paddedRect = t, this.pixelRatio = e, this.stretchX = n, this.stretchY = i, this.content = s, this.version = r; } get tl() { return [this.paddedRect.x + 1, this.paddedRect.y + 1] } get br() { return [this.paddedRect.x + this.paddedRect.w - 1, this.paddedRect.y + this.paddedRect.h - 1] } get displaySize() { return [(this.paddedRect.w - 2) / this.pixelRatio, (this.paddedRect.h - 2) / this.pixelRatio] } } class Dp { constructor(t, e) { const r = {}, n = {}; this.haveRenderCallbacks = []; const i = []; this.addImages(t, r, i), this.addImages(e, n, i); const { w: s, h: a } = Cp(i), o = new Qu({ width: s || 1, height: a || 1 }); for (const e in t) { const n = t[e], i = r[e].paddedRect; Qu.copy(n.data, o, { x: 0, y: 0 }, { x: i.x + 1, y: i.y + 1 }, n.data); } for (const t in e) { const r = e[t], i = n[t].paddedRect, s = i.x + 1, a = i.y + 1, l = r.data.width, u = r.data.height; Qu.copy(r.data, o, { x: 0, y: 0 }, { x: s, y: a }, r.data), Qu.copy(r.data, o, { x: 0, y: u - 1 }, { x: s, y: a - 1 }, { width: l, height: 1 }), Qu.copy(r.data, o, { x: 0, y: 0 }, { x: s, y: a + u }, { width: l, height: 1 }), Qu.copy(r.data, o, { x: l - 1, y: 0 }, { x: s - 1, y: a }, { width: 1, height: u }), Qu.copy(r.data, o, { x: 0, y: 0 }, { x: s + l, y: a }, { width: 1, height: u }); } this.image = o, this.iconPositions = r, this.patternPositions = n; } addImages(t, e, r) { for (const n in t) { const i = t[n], s = { x: 0, y: 0, w: i.data.width + 2, h: i.data.height + 2 }; r.push(s), e[n] = new Pp(s, i), i.hasRenderCallback && this.haveRenderCallbacks.push(n); } } patchUpdatedImages(t, e) { this.haveRenderCallbacks = this.haveRenderCallbacks.filter((e => t.hasImage(e))), t.dispatchRenderCallbacks(this.haveRenderCallbacks); for (const r in t.updatedImages) this.patchUpdatedImage(this.iconPositions[r], t.getImage(r), e), this.patchUpdatedImage(this.patternPositions[r], t.getImage(r), e); } patchUpdatedImage(t, e, r) { if (!t || !e) return; if (t.version === e.version) return; t.version = e.version; const [n, i] = t.tl; r.update(e.data, void 0, { x: n, y: i }); } } Oi(Pp, "ImagePosition"), Oi(Dp, "ImageAtlas"); const Vp = { horizontal: 1, vertical: 2, horizontalOnly: 3 }; class Lp { constructor() { this.scale = 1, this.fontStack = "", this.imageName = null; } static forText(t, e) { const r = new Lp; return r.scale = t || 1, r.fontStack = e, r } static forImage(t) { const e = new Lp; return e.imageName = t, e } } class Fp { constructor() { this.text = "", this.sectionIndex = [], this.sections = [], this.imageSectionID = null; } static fromFeature(t, e) { const r = new Fp; for (let n = 0; n < t.sections.length; n++) { const i = t.sections[n]; i.image ? r.addImageSection(i) : r.addTextSection(i, e); } return r } length() { return this.text.length } getSection(t) { return this.sections[this.sectionIndex[t]] } getSections() { return this.sections } getSectionIndex(t) { return this.sectionIndex[t] } getCharCode(t) { return this.text.charCodeAt(t) } verticalizePunctuation(t) { this.text = function(t, e) { let r = ""; for (let n = 0; n < t.length; n++) { const i = t.charCodeAt(n + 1) || null, s = t.charCodeAt(n - 1) || null; r += !e && (i && Ss(i) && !ip[t[n + 1]] || s && Ss(s) && !ip[t[n - 1]]) || !ip[t[n]] ? t[n] : ip[t[n]]; } return r }(this.text, t); } trim() { let t = 0; for (let e = 0; e < this.text.length && jp[this.text.charCodeAt(e)]; e++) t++; let e = this.text.length; for (let r = this.text.length - 1; r >= 0 && r >= t && jp[this.text.charCodeAt(r)]; r--) e--; this.text = this.text.substring(t, e), this.sectionIndex = this.sectionIndex.slice(t, e); } substring(t, e) { const r = new Fp; return r.text = this.text.substring(t, e), r.sectionIndex = this.sectionIndex.slice(t, e), r.sections = this.sections, r } toString() { return this.text } getMaxScale() { return this.sectionIndex.reduce(((t, e) => Math.max(t, this.sections[e].scale)), 0) } addTextSection(t, e) { this.text += t.text, this.sections.push(Lp.forText(t.scale, t.fontStack || e)); const r = this.sections.length - 1; for (let e = 0; e < t.text.length; ++e) this.sectionIndex.push(r); } addImageSection(t) { const e = t.image ? t.image.name : ""; if (0 === e.length) return void U("Can't add FormattedSection with an empty image."); const r = this.getNextImageSectionCharCode(); r ? (this.text += String.fromCharCode(r), this.sections.push(Lp.forImage(e)), this.sectionIndex.push(this.sections.length - 1)) : U("Reached maximum number of images 6401"); } getNextImageSectionCharCode() { return this.imageSectionID ? this.imageSectionID >= 63743 ? null : ++this.imageSectionID : (this.imageSectionID = 57344, this.imageSectionID) } } function Rp(t, e, r, n, i, s, a, o, l, u, c, h, p, f, d) { const y = Fp.fromFeature(t, i); h === Vp.vertical && y.verticalizePunctuation(p); let m = []; const g = function(t, e, r, n, i, s) { if (!t) return []; const a = [], o = function(t, e, r, n, i, s) { let a = 0; for (let r = 0; r < t.length(); r++) { const o = t.getSection(r); a += Up(t.getCharCode(r), o, n, i, e, s); } return a / Math.max(1, Math.ceil(a / r)) }(t, e, r, n, i, s), l = t.text.indexOf("") >= 0; let u = 0; for (let r = 0; r < t.length(); r++) { const h = t.getSection(r), p = t.getCharCode(r); if (jp[p] || (u += Up(p, h, n, i, e, s)), r < t.length() - 1) { const e = !((c = p) < 11904 || !(ns(c) || rs(c) || ms(c) || fs(c) || os(c) || Hi(c) || is(c) || Qi(c) || ls(c) || us(c) || as(c) || vs(c) || ts(c) || Ji(c) || Wi(c) || ss(c) || es(c) || ys(c) || hs(c) || cs(c))); ($p[p] || e || h.imageName) && a.push(Np(r + 1, u, o, a, qp(p, t.getCharCode(r + 1), e && l), !1)); } } var c; return Gp(Np(t.length(), u, o, a, 0, !0)) }(y, u, s, e, n, f), { processBidirectionalText: x, processStyledBidirectionalText: v } = js; if (x && 1 === y.sections.length) { const t = x(y.toString(), g); for (const e of t) { const t = new Fp; t.text = e, t.sections = y.sections; for (let r = 0; r < e.length; r++) t.sectionIndex.push(0); m.push(t); } } else if (v) { const t = v(y.text, y.sectionIndex, g); for (const e of t) { const t = new Fp; t.text = e[0], t.sectionIndex = e[1], t.sections = y.sections, m.push(t); } } else m = function(t, e) { const r = [], n = t.text; let i = 0; for (const n of e) r.push(t.substring(i, n)), i = n; return i < n.length && r.push(t.substring(i, n.length)), r }(y, g); const b = [], w = { positionedLines: b, text: y.toString(), top: c[1], bottom: c[1], left: c[0], right: c[0], writingMode: h, iconsInText: !1, verticalizable: !1, hasBaseline: !1 }; return function(t, e, r, n, i, s, a, o, l, u, c, h) { let p = 0, f = 0, d = 0; const y = "right" === o ? 1 : "left" === o ? 0 : .5; let m = !1; for (const t of i) { const r = t.getSections(); for (const t of r) { if (t.imageName) continue; const r = e[t.fontStack]; if (r && (m = void 0 !== r.ascender && void 0 !== r.descender, !m)) break } if (!m) break } let g = 0; for (const a of i) { a.trim(); const i = a.getMaxScale(), o = (i - 1) * Wh, v = { positionedGlyphs: [], lineOffset: 0 }; t.positionedLines[g] = v; const b = v.positionedGlyphs; let w = 0; if (!a.length()) { f += s, ++g; continue } let _ = 0, A = 0; for (let s = 0; s < a.length(); s++) { const o = a.getSection(s), d = a.getSectionIndex(s), y = a.getCharCode(s); let g = o.scale, v = null, S = null, k = null, I = Wh, M = 0; const T = !(l === Vp.horizontal || !c && !As(y) || c && (jp[y] || (x = y, Xi(x) || Ki(x) || Yi(x) || ds(x) || xs(x)))); if (o.imageName) { const e = n[o.imageName]; if (!e) continue; k = o.imageName, t.iconsInText = t.iconsInText || !0, S = e.paddedRect; const r = e.displaySize; g = g * Wh / h, v = { width: r[0], height: r[1], left: 1, top: -3, advance: T ? r[1] : r[0], localGlyph: !1 }, M = m ? -v.height * g : i * Wh - 17 - r[1] * g, I = v.advance; const s = (T ? r[0] : r[1]) * g - Wh * i; s > 0 && s > w && (w = s); } else { const t = r[o.fontStack]; if (!t) continue; t[y] && (S = t[y]); const n = e[o.fontStack]; if (!n) continue; const s = n.glyphs[y]; if (!s) continue; if (v = s.metrics, I = 8203 !== y ? Wh : 0, m) { const t = void 0 !== n.ascender ? Math.abs(n.ascender) : 0, e = void 0 !== n.descender ? Math.abs(n.descender) : 0, r = (t + e) * g; _ < r && (_ = r, A = (t - e) / 2 * g), M = -t * g; } else M = (i - g) * Wh - 17; } T ? (t.verticalizable = !0, b.push({ glyph: y, imageName: k, x: p, y: f + M, vertical: T, scale: g, localGlyph: v.localGlyph, fontStack: o.fontStack, sectionIndex: d, metrics: v, rect: S }), p += I * g + u) : (b.push({ glyph: y, imageName: k, x: p, y: f + M, vertical: T, scale: g, localGlyph: v.localGlyph, fontStack: o.fontStack, sectionIndex: d, metrics: v, rect: S }), p += v.advance * g + u); } 0 !== b.length && (d = Math.max(p - u, d), m ? Xp(b, y, w, A, s * i / 2) : Xp(b, y, w, 0, s / 2)), p = 0; const S = s * i + w; v.lineOffset = Math.max(w, o), f += S, ++g; } var x; const v = f, { horizontalAlign: b, verticalAlign: w } = Zp(a); ((function(t, e, r, n, i, s) { const a = (e - r) * i, o = -s * n; for (const e of t) for (const t of e.positionedGlyphs) t.x += a, t.y += o; }))(t.positionedLines, y, b, w, d, v), t.top += -w * v, t.bottom = t.top + v, t.left += -b * d, t.right = t.left + d, t.hasBaseline = m; }(w, e, r, n, m, a, o, l, h, u, p, d), ! function(t) { for (const e of t) if (0 !== e.positionedGlyphs.length) return !1; return !0 }(b) && w } const jp = { 9: !0, 10: !0, 11: !0, 12: !0, 13: !0, 32: !0 }, $p = { 10: !0, 32: !0, 38: !0, 40: !0, 41: !0, 43: !0, 45: !0, 47: !0, 173: !0, 183: !0, 8203: !0, 8208: !0, 8211: !0, 8231: !0 }; function Up(t, e, r, n, i, s) { if (e.imageName) { const t = n[e.imageName]; return t ? t.displaySize[0] * e.scale * Wh / s + i : 0 } { const n = r[e.fontStack], s = n && n.glyphs[t]; return s ? s.metrics.advance * e.scale + i : 0 } } function Op(t, e, r, n) { const i = Math.pow(t - e, 2); return n ? t < e ? i / 2 : 2 * i : i + Math.abs(r) * r } function qp(t, e, r) { let n = 0; return 10 === t && (n -= 1e4), r && (n += 150), 40 !== t && 65288 !== t || (n += 50), 41 !== e && 65289 !== e || (n += 50), n } function Np(t, e, r, n, i, s) { let a = null, o = Op(e, r, i, s); for (const t of n) { const n = Op(e - t.x, r, i, s) + t.badness; n <= o && (a = t, o = n); } return { index: t, x: e, priorBreak: a, badness: o } } function Gp(t) { return t ? Gp(t.priorBreak).concat(t.index) : [] } function Zp(t) { let e = .5, r = .5; switch (t) { case "right": case "top-right": case "bottom-right": e = 1; break; case "left": case "top-left": case "bottom-left": e = 0; } switch (t) { case "bottom": case "bottom-right": case "bottom-left": r = 1; break; case "top": case "top-right": case "top-left": r = 0; } return { horizontalAlign: e, verticalAlign: r } } function Xp(t, e, r, n, i) { if (!(e || r || n || i)) return; const s = t.length - 1, a = t[s], o = (a.x + a.metrics.advance * a.scale) * e; for (let e = 0; e <= s; e++) t[e].x -= o, t[e].y += r + n + i; } function Kp(t, e, r) { const { horizontalAlign: n, verticalAlign: i } = Zp(r), s = e[0] - t.displaySize[0] * n, a = e[1] - t.displaySize[1] * i; return { image: t, top: a, bottom: a + t.displaySize[1], left: s, right: s + t.displaySize[0] } } function Yp(t, e, r, n, i, s) { const a = t.image; let o; if (a.content) { const t = a.content, e = a.pixelRatio || 1; o = [t[0] / e, t[1] / e, a.displaySize[0] - t[2] / e, a.displaySize[1] - t[3] / e]; } const l = e.left * s, u = e.right * s; let c, h, p, f; "width" === r || "both" === r ? (f = i[0] + l - n[3], h = i[0] + u + n[1]) : (f = i[0] + (l + u - a.displaySize[0]) / 2, h = f + a.displaySize[0]); const d = e.top * s, y = e.bottom * s; return "height" === r || "both" === r ? (c = i[1] + d - n[0], p = i[1] + y + n[2]) : (c = i[1] + (d + y - a.displaySize[1]) / 2, p = c + a.displaySize[1]), { image: a, top: c, right: h, bottom: p, left: f, collisionPadding: o } } class Hp extends d { constructor(t, e, r, n, i) { super(t, e), this.angle = n, this.z = r, void 0 !== i && (this.segment = i); } clone() { return new Hp(this.x, this.y, this.z, this.angle, this.segment) } } function Wp(t, e, r, n, i) { if (void 0 === e.segment) return !0; let s = e, a = e.segment + 1, o = 0; for (; o > -r / 2;) { if (a--, a < 0) return !1; o -= t[a].dist(s), s = t[a]; } o += t[a].dist(t[a + 1]), a++; const l = []; let u = 0; for (; o < r / 2;) { const e = t[a], r = t[a + 1]; if (!r) return !1; let s = t[a - 1].angleTo(e) - e.angleTo(r); for (s = Math.abs((s + 3 * Math.PI) % (2 * Math.PI) - Math.PI), l.push({ distance: o, angleDelta: s }), u += s; o - l[0].distance > n;) u -= l.shift().angleDelta; if (u > i) return !1; a++, o += e.dist(r); } return !0 } function Jp(t) { let e = 0; for (let r = 0; r < t.length - 1; r++) e += t[r].dist(t[r + 1]); return e } function Qp(t, e, r) { return t ? .6 * e * r : 0 } function tf(t, e) { return Math.max(t ? t.right - t.left : 0, e ? e.right - e.left : 0) } function ef(t, e, r, n, i, s) { const a = Qp(r, i, s), o = tf(r, n) * s; let l = 0; const u = Jp(t) / 2; for (let r = 0; r < t.length - 1; r++) { const n = t[r], i = t[r + 1], s = n.dist(i); if (l + s > u) { const c = (u - l) / s, h = Mr(n.x, i.x, c), p = Mr(n.y, i.y, c), f = new Hp(h, p, 0, i.angleTo(n), r); return !a || Wp(t, f, o, a, e) ? f : void 0 } l += s; } } function rf(t, e, r, n, i, s, a, o, l) { const u = Qp(n, s, a), c = tf(n, i), h = c * a, p = 0 === t[0].x || t[0].x === l || 0 === t[0].y || t[0].y === l; return e - h < e / 4 && (e = h + e / 4), nf(t, p ? e / 2 * o % e : (c / 2 + 2 * s) * a * o % e, e, u, r, h, p, !1, l) } function nf(t, e, r, n, i, s, a, o, l) { const u = s / 2, c = Jp(t); let h = 0, p = e - r, f = []; for (let e = 0; e < t.length - 1; e++) { const a = t[e], o = t[e + 1], d = a.dist(o), y = o.angleTo(a); for (; p + r < h + d;) { p += r; const m = (p - h) / d, g = Mr(a.x, o.x, m), x = Mr(a.y, o.y, m); if (g >= 0 && g < l && x >= 0 && x < l && p - u >= 0 && p + u <= c) { const r = new Hp(g, x, 0, y, e); r._round(), n && !Wp(t, r, s, n, i) || f.push(r); } } h += d; } return o || f.length || a || (f = nf(t, h / 2, r, n, i, s, a, !0, l)), f } function sf(t, e, r, n, i) { const s = []; for (let a = 0; a < t.length; a++) { const o = t[a]; let l; for (let t = 0; t < o.length - 1; t++) { let a = o[t], u = o[t + 1]; a.x < e && u.x < e || (a.x < e ? a = new d(e, a.y + (e - a.x) / (u.x - a.x) * (u.y - a.y))._round() : u.x < e && (u = new d(e, a.y + (e - a.x) / (u.x - a.x) * (u.y - a.y))._round()), a.y < r && u.y < r || (a.y < r ? a = new d(a.x + (r - a.y) / (u.y - a.y) * (u.x - a.x), r)._round() : u.y < r && (u = new d(a.x + (r - a.y) / (u.y - a.y) * (u.x - a.x), r)._round()), a.x >= n && u.x >= n || (a.x >= n ? a = new d(n, a.y + (n - a.x) / (u.x - a.x) * (u.y - a.y))._round() : u.x >= n && (u = new d(n, a.y + (n - a.x) / (u.x - a.x) * (u.y - a.y))._round()), a.y >= i && u.y >= i || (a.y >= i ? a = new d(a.x + (i - a.y) / (u.y - a.y) * (u.x - a.x), i)._round() : u.y >= i && (u = new d(a.x + (i - a.y) / (u.y - a.y) * (u.x - a.x), i)._round()), l && a.equals(l[l.length - 1]) || (l = [a], s.push(l)), l.push(u))))); } } return s } Oi(Hp, "Anchor"); const af = 1e20; function of (t, e, r, n, i, s, a, o, l) { for (let u = e; u < e + n; u++) lf(t, r * s + u, s, i, a, o, l); for (let u = r; u < r + i; u++) lf(t, u * s + e, 1, n, a, o, l); } function lf(t, e, r, n, i, s, a) { s[0] = 0, a[0] = -af, a[1] = af, i[0] = t[e]; for (let o = 1, l = 0, u = 0; o < n; o++) { i[o] = t[e + o * r]; const n = o * o; do { const t = s[l]; u = (i[o] - i[t] + n - t * t) / (o - t) / 2; } while (u <= a[l] && --l > -1); l++, s[l] = o, a[l] = u, a[l + 1] = af; } for (let o = 0, l = 0; o < n; o++) { for (; a[l + 1] < o;) l++; const n = s[l], u = o - n; t[e + o * r] = i[n] + u * u; } } const uf = { none: 0, ideographs: 1, all: 2 }; class cf { constructor(t, e, r) { this.requestManager = t, this.localGlyphMode = e, this.localFontFamily = r, this.entries = {}, this.localGlyphs = { 200: {}, 400: {}, 500: {}, 900: {} }; } setURL(t) { this.url = t; } getGlyphs(t, e) { const r = []; for (const e in t) for (const n of t[e]) r.push({ stack: e, id: n }); M(r, (({ stack: t, id: e }, r) => { let n = this.entries[t]; n || (n = this.entries[t] = { glyphs: {}, requests: {}, ranges: {}, ascender: void 0, descender: void 0 }); let i = n.glyphs[e]; if (void 0 !== i) return void r(null, { stack: t, id: e, glyph: i }); if (i = this._tinySDF(n, t, e), i) return n.glyphs[e] = i, void r(null, { stack: t, id: e, glyph: i }); const s = Math.floor(e / 256); if (256 * s > 65535) return void r(new Error("glyphs > 65535 not supported")); if (n.ranges[s]) return void r(null, { stack: t, id: e, glyph: i }); let a = n.requests[s]; a || (a = n.requests[s] = [], cf.loadGlyphRange(t, s, this.url, this.requestManager, ((t, e) => { if (e) { n.ascender = e.ascender, n.descender = e.descender; for (const t in e.glyphs) this._doesCharSupportLocalGlyph(+t) || (n.glyphs[+t] = e.glyphs[+t]); n.ranges[s] = !0; } for (const r of a) r(t, e); delete n.requests[s]; }))), a.push(((n, i) => { n ? r(n) : i && r(null, { stack: t, id: e, glyph: i.glyphs[e] || null }); })); }), ((t, r) => { if (t) e(t); else if (r) { const t = {}; for (const { stack: e, id: n, glyph: i } of r) void 0 === t[e] && (t[e] = {}), void 0 === t[e].glyphs && (t[e].glyphs = {}), t[e].glyphs[n] = i && { id: i.id, bitmap: i.bitmap.clone(), metrics: i.metrics }, t[e].ascender = this.entries[e].ascender, t[e].descender = this.entries[e].descender; e(null, t); } })); } _doesCharSupportLocalGlyph(t) { return this.localGlyphMode !== uf.none && (this.localGlyphMode === uf.all ? !!this.localFontFamily : !!this.localFontFamily && (us(t) || ps(t) || ts(t) || es(t) || Qi(t))) } _tinySDF(t, e, r) { const n = this.localFontFamily; if (!n || !this._doesCharSupportLocalGlyph(r)) return; let i = t.tinySDF; if (!i) { let r = "400"; /bold/i.test(e) ? r = "900" : /medium/i.test(e) ? r = "500" : /light/i.test(e) && (r = "200"), i = t.tinySDF = new cf.TinySDF({ fontFamily: n, fontWeight: r, fontSize: 48, buffer: 6, radius: 16 }), i.fontWeight = r; } if (this.localGlyphs[i.fontWeight][r]) return this.localGlyphs[i.fontWeight][r]; const s = String.fromCharCode(r), { data: a, width: o, height: l, glyphWidth: u, glyphHeight: c, glyphLeft: h, glyphTop: p, glyphAdvance: f } = i.draw(s); return this.localGlyphs[i.fontWeight][r] = { id: r, bitmap: new Ju({ width: o, height: l }, a), metrics: { width: u / 2, height: c / 2, left: h / 2, top: p / 2 - 27, advance: f / 2, localGlyph: !0 } } } } function hf(t, e, r, n) { const i = [], s = t.image, a = s.pixelRatio, o = s.paddedRect.w - 2, l = s.paddedRect.h - 2, u = t.right - t.left, c = t.bottom - t.top, h = s.stretchX || [ [0, o] ], p = s.stretchY || [ [0, l] ], f = (t, e) => t + e[1] - e[0], y = h.reduce(f, 0), m = p.reduce(f, 0), g = o - y, x = l - m; let v = 0, b = y, w = 0, _ = m, A = 0, S = g, k = 0, I = x; if (s.content && n) { const t = s.content; v = pf(h, 0, t[0]), w = pf(p, 0, t[1]), b = pf(h, t[0], t[2]), _ = pf(p, t[1], t[3]), A = t[0] - v, k = t[1] - w, S = t[2] - t[0] - b, I = t[3] - t[1] - _; } const M = (n, i, o, l) => { const h = df(n.stretch - v, b, u, t.left), p = yf(n.fixed - A, S, n.stretch, y), f = df(i.stretch - w, _, c, t.top), g = yf(i.fixed - k, I, i.stretch, m), x = df(o.stretch - v, b, u, t.left), M = yf(o.fixed - A, S, o.stretch, y), T = df(l.stretch - w, _, c, t.top), z = yf(l.fixed - k, I, l.stretch, m), B = new d(h, f), E = new d(x, f), C = new d(x, T), P = new d(h, T), D = new d(p / a, g / a), V = new d(M / a, z / a), L = e * Math.PI / 180; if (L) { const t = Math.sin(L), e = Math.cos(L), r = [e, -t, t, e]; B._matMult(r), E._matMult(r), P._matMult(r), C._matMult(r); } const F = n.stretch + n.fixed, R = i.stretch + i.fixed; return { tl: B, tr: E, bl: P, br: C, tex: { x: s.paddedRect.x + 1 + F, y: s.paddedRect.y + 1 + R, w: o.stretch + o.fixed - F, h: l.stretch + l.fixed - R }, writingMode: void 0, glyphOffset: [0, 0], sectionIndex: 0, pixelOffsetTL: D, pixelOffsetBR: V, minFontScaleX: S / a / u, minFontScaleY: I / a / c, isSDF: r } }; if (n && (s.stretchX || s.stretchY)) { const t = ff(h, g, y), e = ff(p, x, m); for (let r = 0; r < t.length - 1; r++) { const n = t[r], s = t[r + 1]; for (let t = 0; t < e.length - 1; t++) i.push(M(n, e[t], s, e[t + 1])); } } else i.push(M({ fixed: 0, stretch: -1 }, { fixed: 0, stretch: -1 }, { fixed: 0, stretch: o + 1 }, { fixed: 0, stretch: l + 1 })); return i } function pf(t, e, r) { let n = 0; for (const i of t) n += Math.max(e, Math.min(r, i[1])) - Math.max(e, Math.min(r, i[0])); return n } function ff(t, e, r) { const n = [{ fixed: -1, stretch: 0 }]; for (const [e, r] of t) { const t = n[n.length - 1]; n.push({ fixed: e - t.stretch, stretch: t.stretch }), n.push({ fixed: e - t.stretch, stretch: t.stretch + (r - e) }); } return n.push({ fixed: e + 1, stretch: r }), n } function df(t, e, r, n) { return t / e * r + n } function yf(t, e, r, n) { return t - e * r / n } function mf(t, e, r, n) { const i = e + t.positionedLines[n].lineOffset; return 0 === n ? r + i / 2 : r + (i + (e + t.positionedLines[n - 1].lineOffset)) / 2 } cf.loadGlyphRange = function(t, e, r, n, i) { const s = 256 * e, a = s + 255, o = n.transformRequest(n.normalizeGlyphsURL(r).replace("{fontstack}", t).replace("{range}", `${s}-${a}`), st.Glyphs); ut(o, ((t, e) => { if (t) i(t); else if (e) { const t = {}, r = function(t) { return new op(t).readFields(zp, {}) }(e); for (const e of r.glyphs) t[e.id] = e; i(null, { glyphs: t, ascender: r.ascender, descender: r.descender }); } })); }, cf.TinySDF = class { constructor({ fontSize: t = 24, buffer: e = 3, radius: r = 8, cutoff: n = .25, fontFamily: i = "sans-serif", fontWeight: s = "normal", fontStyle: a = "normal" } = {}) { this.buffer = e, this.cutoff = n, this.radius = r; const o = this.size = t + 4 * e, l = this._createCanvas(o), u = this.ctx = l.getContext("2d", { willReadFrequently: !0 }); u.font = `${a} ${s} ${t}px ${i}`, u.textBaseline = "alphabetic", u.textAlign = "left", u.fillStyle = "black", this.gridOuter = new Float64Array(o * o), this.gridInner = new Float64Array(o * o), this.f = new Float64Array(o), this.z = new Float64Array(o + 1), this.v = new Uint16Array(o); } _createCanvas(t) { const e = document.createElement("canvas"); return e.width = e.height = t, e } draw(t) { const { width: e, actualBoundingBoxAscent: r, actualBoundingBoxDescent: n, actualBoundingBoxLeft: i, actualBoundingBoxRight: s } = this.ctx.measureText(t), a = Math.ceil(r), o = Math.max(0, Math.min(this.size - this.buffer, Math.ceil(s - i))), l = Math.min(this.size - this.buffer, a + Math.ceil(n)), u = o + 2 * this.buffer, c = l + 2 * this.buffer, h = Math.max(u * c, 0), p = new Uint8ClampedArray(h), f = { data: p, width: u, height: c, glyphWidth: o, glyphHeight: l, glyphTop: a, glyphLeft: 0, glyphAdvance: e }; if (0 === o || 0 === l) return f; const { ctx: d, buffer: y, gridInner: m, gridOuter: g } = this; d.clearRect(y, y, o, l), d.fillText(t, y, y + a); const x = d.getImageData(y, y, o, l); g.fill(af, 0, h), m.fill(0, 0, h); for (let t = 0; t < l; t++) for (let e = 0; e < o; e++) { const r = x.data[4 * (t * o + e) + 3] / 255; if (0 === r) continue; const n = (t + y) * u + e + y; if (1 === r) g[n] = 0, m[n] = af; else { const t = .5 - r; g[n] = t > 0 ? t * t : 0, m[n] = t < 0 ? t * t : 0; } } of (g, 0, 0, u, c, u, this.f, this.v, this.z), of (m, y, y, o, l, u, this.f, this.v, this.z); for (let t = 0; t < h; t++) { const e = Math.sqrt(g[t]) - Math.sqrt(m[t]); p[t] = Math.round(255 - 255 * (e / this.radius + this.cutoff)); } return f } }; class gf { constructor(t = [], e = xf) { if (this.data = t, this.length = this.data.length, this.compare = e, this.length > 0) for (let t = (this.length >> 1) - 1; t >= 0; t--) this._down(t); } push(t) { this.data.push(t), this.length++, this._up(this.length - 1); } pop() { if (0 === this.length) return; const t = this.data[0], e = this.data.pop(); return this.length--, this.length > 0 && (this.data[0] = e, this._down(0)), t } peek() { return this.data[0] } _up(t) { const { data: e, compare: r } = this, n = e[t]; for (; t > 0;) { const i = t - 1 >> 1, s = e[i]; if (r(n, s) >= 0) break; e[t] = s, t = i; } e[t] = n; } _down(t) { const { data: e, compare: r } = this, n = this.length >> 1, i = e[t]; for (; t < n;) { let n = 1 + (t << 1), s = e[n]; const a = n + 1; if (a < this.length && r(e[a], s) < 0 && (n = a, s = e[a]), r(s, i) >= 0) break; e[t] = s, t = n; } e[t] = i; } } function xf(t, e) { return t < e ? -1 : t > e ? 1 : 0 } function vf(t, e = 1, r = !1) { let n = 1 / 0, i = 1 / 0, s = -1 / 0, a = -1 / 0; const o = t[0]; for (let t = 0; t < o.length; t++) { const e = o[t]; (!t || e.x < n) && (n = e.x), (!t || e.y < i) && (i = e.y), (!t || e.x > s) && (s = e.x), (!t || e.y > a) && (a = e.y); } const l = Math.min(s - n, a - i); let u = l / 2; const c = new gf([], bf); if (0 === l) return new d(n, i); for (let e = n; e < s; e += l) for (let r = i; r < a; r += l) c.push(new wf(e + u, r + u, u, t)); let h = function(t) { let e = 0, r = 0, n = 0; const i = t[0]; for (let t = 0, s = i.length, a = s - 1; t < s; a = t++) { const s = i[t], o = i[a], l = s.x * o.y - o.x * s.y; r += (s.x + o.x) * l, n += (s.y + o.y) * l, e += 3 * l; } return new wf(r / e, n / e, 0, t) }(t), p = c.length; for (; c.length;) { const n = c.pop(); (n.d > h.d || !h.d) && (h = n, r && console.log("found best %d after %d probes", Math.round(1e4 * n.d) / 1e4, p)), n.max - h.d <= e || (u = n.h / 2, c.push(new wf(n.p.x - u, n.p.y - u, u, t)), c.push(new wf(n.p.x + u, n.p.y - u, u, t)), c.push(new wf(n.p.x - u, n.p.y + u, u, t)), c.push(new wf(n.p.x + u, n.p.y + u, u, t)), p += 4); } return r && (console.log(`num probes: ${p}`), console.log(`best distance: ${h.d}`)), h.p } function bf(t, e) { return e.max - t.max } class wf { constructor(t, e, r, n) { this.p = new d(t, e), this.h = r, this.d = function(t, e) { let r = !1, n = 1 / 0; for (let i = 0; i < e.length; i++) { const s = e[i]; for (let e = 0, i = s.length, a = i - 1; e < i; a = e++) { const i = s[e], o = s[a]; i.y > t.y != o.y > t.y && t.x < (o.x - i.x) * (t.y - i.y) / (o.y - i.y) + i.x && (r = !r), n = Math.min(n, Cu(t, i, o)); } } return (r ? 1 : -1) * Math.sqrt(n) }(this.p, n), this.max = this.d + this.h * Math.SQRT2; } } const _f = Number.POSITIVE_INFINITY, Af = Math.sqrt(2); function Sf(t, [e, r]) { let n = 0, i = 0; if (r === _f) { e < 0 && (e = 0); const r = e / Af; switch (t) { case "top-right": case "top-left": i = r - 7; break; case "bottom-right": case "bottom-left": i = 7 - r; break; case "bottom": i = 7 - e; break; case "top": i = e - 7; } switch (t) { case "top-right": case "bottom-right": n = -r; break; case "top-left": case "bottom-left": n = r; break; case "left": n = e; break; case "right": n = -e; } } else { switch (e = Math.abs(e), r = Math.abs(r), t) { case "top-right": case "top-left": case "top": i = r - 7; break; case "bottom-right": case "bottom-left": case "bottom": i = 7 - r; } switch (t) { case "top-right": case "bottom-right": case "right": n = -e; break; case "top-left": case "bottom-left": case "left": n = e; } } return [n, i] } function kf(t, e, r, n, i, s, a, o, l, u) { t.createArrays(), t.tilePixelRatio = ko / (512 * t.overscaling), t.compareText = {}, t.iconsNeedLinear = !1; const c = t.layers[0].layout, h = t.layers[0]._unevaluatedLayout._values, p = {}; if ("composite" === t.textSizeData.kind) { const { minZoom: e, maxZoom: r } = t.textSizeData; p.compositeTextSizes = [h["text-size"].possiblyEvaluate(new $s(e), o), h["text-size"].possiblyEvaluate(new $s(r), o)]; } if ("composite" === t.iconSizeData.kind) { const { minZoom: e, maxZoom: r } = t.iconSizeData; p.compositeIconSizes = [h["icon-size"].possiblyEvaluate(new $s(e), o), h["icon-size"].possiblyEvaluate(new $s(r), o)]; } p.layoutTextSize = h["text-size"].possiblyEvaluate(new $s(l + 1), o), p.layoutIconSize = h["icon-size"].possiblyEvaluate(new $s(l + 1), o), p.textMaxSize = h["text-size"].possiblyEvaluate(new $s(18), o); const f = "map" === c.get("text-rotation-alignment") && "point" !== c.get("symbol-placement"), d = c.get("text-size"); for (const s of t.features) { const l = c.get("text-font").evaluate(s, {}, o).join(","), h = d.evaluate(s, {}, o), y = p.layoutTextSize.evaluate(s, {}, o), m = (p.layoutIconSize.evaluate(s, {}, o), { horizontal: {}, vertical: void 0 }), g = s.text; let x, v = [0, 0]; if (g) { const n = g.toString(), a = c.get("text-letter-spacing").evaluate(s, {}, o) * Wh, u = c.get("text-line-height").evaluate(s, {}, o) * Wh, p = ws(n) ? a : 0, d = c.get("text-anchor").evaluate(s, {}, o), x = c.get("text-variable-anchor"); if (!x) { const t = c.get("text-radial-offset").evaluate(s, {}, o); v = t ? Sf(d, [t * Wh, _f]) : c.get("text-offset").evaluate(s, {}, o).map((t => t * Wh)); } let b = f ? "center" : c.get("text-justify").evaluate(s, {}, o); const w = "point" === c.get("symbol-placement"), _ = w ? c.get("text-max-width").evaluate(s, {}, o) * Wh : 1 / 0, A = s => { t.allowVerticalPlacement && bs(n) && (m.vertical = Rp(g, e, r, i, l, _, u, d, s, p, v, Vp.vertical, !0, y, h)); }; if (!f && x) { const t = "auto" === b ? x.map((t => If(t))) : [b]; let n = !1; for (let s = 0; s < t.length; s++) { const a = t[s]; if (!m.horizontal[a]) if (n) m.horizontal[a] = m.horizontal[0]; else { const t = Rp(g, e, r, i, l, _, u, "center", a, p, v, Vp.horizontal, !1, y, h); t && (m.horizontal[a] = t, n = 1 === t.positionedLines.length); } } A("left"); } else { if ("auto" === b && (b = If(d)), w || c.get("text-writing-mode").indexOf("horizontal") >= 0 || !bs(n)) { const t = Rp(g, e, r, i, l, _, u, d, b, p, v, Vp.horizontal, !1, y, h); t && (m.horizontal[b] = t); } A(w ? "left" : b); } } let b = !1; if (s.icon && s.icon.name) { const e = n[s.icon.name]; e && (x = Kp(i[s.icon.name], c.get("icon-offset").evaluate(s, {}, o), c.get("icon-anchor").evaluate(s, {}, o)), b = e.sdf, void 0 === t.sdfIcons ? t.sdfIcons = e.sdf : t.sdfIcons !== e.sdf && U("Style sheet warning: Cannot mix SDF and non-SDF icons in one buffer"), (e.pixelRatio !== t.pixelRatio || 0 !== c.get("icon-rotate").constantOr(1)) && (t.iconsNeedLinear = !0)); } const w = Bf(m.horizontal) || m.vertical; t.iconsInText || (t.iconsInText = !!w && w.iconsInText), (w || x) && Mf(t, s, m, x, n, p, y, 0, v, b, a, o, u); } s && t.generateCollisionDebugBuffers(l, t.collisionBoxArray); } function If(t) { switch (t) { case "right": case "top-right": case "bottom-right": return "right"; case "left": case "top-left": case "bottom-left": return "left" } return "center" } function Mf(t, e, r, n, i, s, a, o, l, u, c, h, p) { let f = s.textMaxSize.evaluate(e, {}, h); void 0 === f && (f = a); const d = t.layers[0].layout, y = d.get("icon-offset").evaluate(e, {}, h), m = Bf(r.horizontal) || r.vertical, g = "globe" === p.name, v = a / 24, b = t.tilePixelRatio * f / 24, w = (z = t.overscaling, t.zoom > 18 && z > 2 && (z >>= 1), Math.max(ko / (512 * z), 1) * d.get("symbol-spacing")), _ = d.get("text-padding") * t.tilePixelRatio, A = d.get("icon-padding") * t.tilePixelRatio, S = x(d.get("text-max-angle")), k = "map" === d.get("text-rotation-alignment") && "point" !== d.get("symbol-placement"), I = "map" === d.get("icon-rotation-alignment") && "point" !== d.get("symbol-placement"), M = d.get("symbol-placement"), T = w / 2; var z; const B = d.get("icon-text-fit"); let E; n && "none" !== B && (t.allowVerticalPlacement && r.vertical && (E = Yp(n, r.vertical, B, d.get("icon-text-fit-padding"), y, v)), m && (n = Yp(n, m, B, d.get("icon-text-fit-padding"), y, v))); const C = (a, o, f) => { if (o.x < 0 || o.x >= ko || o.y < 0 || o.y >= ko) return; let d = null; if (g) { const { x: t, y: e, z: r } = p.projectTilePoint(o.x, o.y, f); d = { anchor: new Hp(t, e, r, 0, void 0), up: p.upVector(f, o.x, o.y) }; }! function(t, e, r, n, i, s, a, o, l, u, c, h, p, f, d, y, m, g, x, v, b, w, _, A, S) { const k = t.addToLineVertexArray(e, n); let I, M, T, z, B, E, C, P = 0, D = 0, V = 0, L = 0, F = -1, R = -1; const j = {}; let $ = qa(""); const O = r ? r.anchor : e; let q = 0, N = 0; if (void 0 === l._unevaluatedLayout.getValue("text-radial-offset") ? [q, N] = l.layout.get("text-offset").evaluate(b, {}, S).map((t => t * Wh)) : (q = l.layout.get("text-radial-offset").evaluate(b, {}, S) * Wh, N = _f), t.allowVerticalPlacement && i.vertical) { const t = i.vertical; if (d) E = Cf(t), o && (C = Cf(o)); else { const r = l.layout.get("text-rotate").evaluate(b, {}, S) + 90; T = Ef(u, O, e, c, h, p, t, f, r, y), o && (z = Ef(u, O, e, c, h, p, o, g, r)); } } if (s) { const n = l.layout.get("icon-rotate").evaluate(b, {}, S), i = "none" !== l.layout.get("icon-text-fit"), a = hf(s, n, _, i), f = o ? hf(o, n, _, i) : void 0; M = Ef(u, O, e, c, h, p, s, g, n), P = 4 * a.length; const d = t.iconSizeData; let y = null; "source" === d.kind ? (y = [Jh * l.layout.get("icon-size").evaluate(b, {}, S)], y[0] > Tf && U(`${t.layerIds[0]}: Value for "icon-size" is >= 255. Reduce your "icon-size".`)) : "composite" === d.kind && (y = [Jh * w.compositeIconSizes[0].evaluate(b, {}, S), Jh * w.compositeIconSizes[1].evaluate(b, {}, S)], (y[0] > Tf || y[1] > Tf) && U(`${t.layerIds[0]}: Value for "icon-size" is >= 255. Reduce your "icon-size".`)), t.addSymbols(t.icon, a, y, v, x, b, !1, r, e, k.lineStartIndex, k.lineLength, -1, A, S), F = t.icon.placedSymbolArray.length - 1, f && (D = 4 * f.length, t.addSymbols(t.icon, f, y, v, x, b, Vp.vertical, r, e, k.lineStartIndex, k.lineLength, -1, A, S), R = t.icon.placedSymbolArray.length - 1); } for (const n in i.horizontal) { const s = i.horizontal[n]; I || ($ = qa(s.text), d ? B = Cf(s) : I = Ef(u, O, e, c, h, p, s, f, l.layout.get("text-rotate").evaluate(b, {}, S), y)); const o = 1 === s.positionedLines.length; if (V += zf(t, r, e, s, a, l, d, b, y, k, i.vertical ? Vp.horizontal : Vp.horizontalOnly, o ? Object.keys(i.horizontal) : [n], j, F, w, A, S), o) break } i.vertical && (L += zf(t, r, e, i.vertical, a, l, d, b, y, k, Vp.vertical, ["vertical"], j, R, w, A, S)); let G = -1; const Z = (t, e) => t ? Math.max(t, e) : e; G = Z(B, G), G = Z(E, G), G = Z(C, G); const X = G > -1 ? 1 : 0; t.glyphOffsetArray.length >= hd.MAX_GLYPHS && U("Too many glyphs being rendered in a tile. See https://github.com/mapbox/mapbox-gl-js/issues/2907"), void 0 !== b.sortKey && t.addToSortKeyRanges(t.symbolInstances.length, b.sortKey), t.symbolInstances.emplaceBack(O.x, O.y, O.z, e.x, e.y, j.right >= 0 ? j.right : -1, j.center >= 0 ? j.center : -1, j.left >= 0 ? j.left : -1, j.vertical >= 0 ? j.vertical : -1, F, R, $, void 0 !== I ? I : t.collisionBoxArray.length, void 0 !== I ? I + 1 : t.collisionBoxArray.length, void 0 !== T ? T : t.collisionBoxArray.length, void 0 !== T ? T + 1 : t.collisionBoxArray.length, void 0 !== M ? M : t.collisionBoxArray.length, void 0 !== M ? M + 1 : t.collisionBoxArray.length, z || t.collisionBoxArray.length, z ? z + 1 : t.collisionBoxArray.length, c, V, L, P, D, X, 0, q, N, G); }(t, o, d, a, r, n, i, E, t.layers[0], t.collisionBoxArray, e.index, e.sourceLayerIndex, t.index, _, k, l, 0, A, I, y, e, s, u, c, h); }; if ("line" === M) for (const i of sf(e.geometry, 0, 0, ko, ko)) { const e = rf(i, w, S, r.vertical || m, n, 24, b, t.overscaling, ko); for (const r of e) { const e = m; e && Pf(t, e.text, T, r) || C(i, r, h); } } else if ("line-center" === M) { for (const t of e.geometry) if (t.length > 1) { const e = ef(t, S, r.vertical || m, n, 24, b); e && C(t, e, h); } } else if ("Polygon" === e.type) for (const t of Lc(e.geometry, 0)) { const e = vf(t, 16); C(t[0], new Hp(e.x, e.y, 0, 0, void 0), h); } else if ("LineString" === e.type) for (const t of e.geometry) C(t, new Hp(t[0].x, t[0].y, 0, 0, void 0), h); else if ("Point" === e.type) for (const t of e.geometry) for (const e of t) C([e], new Hp(e.x, e.y, 0, 0, void 0), h); } const Tf = 32640; function zf(t, e, r, n, i, s, a, o, l, u, c, h, p, f, y, m, g) { const x = function(t, e, r, n, i, s, a, o) { const l = []; if (0 === e.positionedLines.length) return l; const u = n.layout.get("text-rotate").evaluate(s, {}) * Math.PI / 180, c = function(t) { const e = t[0], r = t[1], n = e * r; return n > 0 ? [e, -r] : n < 0 ? [-e, r] : 0 === e ? [r, e] : [r, -e] }(r); let h = Math.abs(e.top - e.bottom); for (const t of e.positionedLines) h -= t.lineOffset; const p = e.positionedLines.length, f = h / p; let y = e.top - r[1]; for (let t = 0; t < p; ++t) { const n = e.positionedLines[t]; y = mf(e, f, y, t); for (const t of n.positionedGlyphs) { if (!t.rect) continue; const n = t.rect || {}; let s = 4, h = !0, p = 1, f = 0; if (t.imageName) { const e = a[t.imageName]; if (!e) continue; if (e.sdf) { U("SDF images are not supported in formatted text and will be ignored."); continue } h = !1, p = e.pixelRatio, s = 1 / p; } const m = (i || o) && t.vertical, g = t.metrics.advance * t.scale / 2, x = t.metrics, v = t.rect; if (null === v) continue; o && e.verticalizable && (f = t.imageName ? g - t.metrics.width * t.scale / 2 : 0); const b = i ? [t.x + g, t.y] : [0, 0]; let w = [0, 0], _ = [0, 0], A = !1; i || (m ? (_ = [t.x + g + c[0], t.y + c[1] - f], A = !0) : w = [t.x + g + r[0], t.y + r[1] - f]); const S = v.w * t.scale / (p * (t.localGlyph ? 2 : 1)), k = v.h * t.scale / (p * (t.localGlyph ? 2 : 1)); let I, M, T, z; if (m) { const e = t.y - y, r = new d(-g, g - e), n = -Math.PI / 2, i = new d(..._); I = new d(-g + w[0], w[1]), I._rotateAround(n, r)._add(i), I.x += -e + g, I.y -= (x.left - s) * t.scale; const a = t.imageName ? x.advance * t.scale : Wh * t.scale, o = String.fromCharCode(t.glyph); sp(o) ? I.x += (1 - s) * t.scale : ap(o) ? I.x += a - x.height * t.scale + (-s - 1) * t.scale : I.x += t.imageName || x.width + 2 * s === v.w && x.height + 2 * s === v.h ? (a - k) / 2 : (a - (x.height + 2 * s) * t.scale) / 2, M = new d(I.x, I.y - S), T = new d(I.x + k, I.y), z = new d(I.x + k, I.y - S); } else { const e = (x.left - s) * t.scale - g + w[0], r = (-x.top - s) * t.scale + w[1], n = e + S, i = r + k; I = new d(e, r), M = new d(n, r), T = new d(e, i), z = new d(n, i); } if (u) { let t; t = i ? new d(0, 0) : A ? new d(c[0], c[1]) : new d(r[0], r[1]), I._rotateAround(u, t), M._rotateAround(u, t), T._rotateAround(u, t), z._rotateAround(u, t); } const B = new d(0, 0), E = new d(0, 0); l.push({ tl: I, tr: M, bl: T, br: z, tex: n, writingMode: e.writingMode, glyphOffset: b, sectionIndex: t.sectionIndex, isSDF: h, pixelOffsetTL: B, pixelOffsetBR: E, minFontScaleX: 0, minFontScaleY: 0 }); } } return l }(0, n, l, s, a, o, i, t.allowVerticalPlacement), v = t.textSizeData; let b = null; "source" === v.kind ? (b = [Jh * s.layout.get("text-size").evaluate(o, {}, g)], b[0] > Tf && U(`${t.layerIds[0]}: Value for "text-size" is >= 255. Reduce your "text-size".`)) : "composite" === v.kind && (b = [Jh * y.compositeTextSizes[0].evaluate(o, {}, g), Jh * y.compositeTextSizes[1].evaluate(o, {}, g)], (b[0] > Tf || b[1] > Tf) && U(`${t.layerIds[0]}: Value for "text-size" is >= 255. Reduce your "text-size".`)), t.addSymbols(t.text, x, b, l, a, o, c, e, r, u.lineStartIndex, u.lineLength, f, m, g); for (const e of h) p[e] = t.text.placedSymbolArray.length - 1; return 4 * x.length } function Bf(t) { for (const e in t) return t[e]; return null } function Ef(t, e, r, n, i, s, a, o, l, u) { let c = a.top, h = a.bottom, p = a.left, f = a.right; const y = a.collisionPadding; if (y && (p -= y[0], c -= y[1], f += y[2], h += y[3]), l) { const t = new d(p, c), e = new d(f, c), r = new d(p, h), n = new d(f, h), i = x(l); let s = new d(0, 0); u && (s = new d(u[0], u[1])), t._rotateAround(i, s), e._rotateAround(i, s), r._rotateAround(i, s), n._rotateAround(i, s), p = Math.min(t.x, e.x, r.x, n.x), f = Math.max(t.x, e.x, r.x, n.x), c = Math.min(t.y, e.y, r.y, n.y), h = Math.max(t.y, e.y, r.y, n.y); } return t.emplaceBack(e.x, e.y, e.z, r.x, r.y, p, c, f, h, o, n, i, s), t.length - 1 } function Cf(t) { t.collisionPadding && (t.top -= t.collisionPadding[1], t.bottom += t.collisionPadding[3]); const e = t.bottom - t.top; return e > 0 ? Math.max(10, e) : null } function Pf(t, e, r, n) { const i = t.compareText; if (e in i) { const t = i[e]; for (let e = t.length - 1; e >= 0; e--) if (n.dist(t[e]) < r) return !0 } else i[e] = []; return i[e].push(n), !1 } function Df(t, e) { const r = t.fovAboveCenter, n = t.elevation ? t.elevation.getMinElevationBelowMSL() * e : 0, i = (t._camera.position[2] * t.worldSize - n) / Math.cos(t._pitch), s = Math.sin(r) * i / Math.sin(Math.max(Math.PI / 2 - t._pitch - r, .01)), a = Math.sin(t._pitch) * s + i; return Math.min(1.01 * a, i * (1 / t._horizonShift)) } function Vf(t, e) { if (!e.isReprojectedInTileSpace) return { scale: 1 << t.z, x: t.x, y: t.y, x2: t.x + 1, y2: t.y + 1, projection: e }; const r = Math.pow(2, -t.z), n = t.x * r, i = (t.x + 1) * r, s = t.y * r, a = (t.y + 1) * r, o = ou(n), l = ou(i), u = lu(s), c = lu(a), h = e.project(o, u), p = e.project(l, u), f = e.project(l, c), d = e.project(o, c); let y = Math.min(h.x, p.x, f.x, d.x), m = Math.min(h.y, p.y, f.y, d.y), g = Math.max(h.x, p.x, f.x, d.x), x = Math.max(h.y, p.y, f.y, d.y); const v = r / 16; function b(t, r, n, i, s, a) { const o = (n + s) / 2, l = (i + a) / 2, u = e.project(ou(o), lu(l)), c = Math.max(0, y - u.x, m - u.y, u.x - g, u.y - x); y = Math.min(y, u.x), g = Math.max(g, u.x), m = Math.min(m, u.y), x = Math.max(x, u.y), c > v && (b(t, u, n, i, o, l), b(u, r, o, l, s, a)); } b(h, p, n, s, i, s), b(p, f, i, s, i, a), b(f, d, i, a, n, a), b(d, h, n, a, n, s), y -= v, m -= v, g += v, x += v; const w = 1 / Math.max(g - y, x - m); return { scale: w, x: y * w, y: m * w, x2: g * w, y2: x * w, projection: e } } const Lf = Eo(new Float32Array(16)); class Ff { constructor(t) { this.spec = t, this.name = t.name, this.wrap = !1, this.requiresDraping = !1, this.supportsWorldCopies = !1, this.supportsTerrain = !1, this.supportsFog = !1, this.supportsFreeCamera = !1, this.zAxisUnit = "meters", this.isReprojectedInTileSpace = !0, this.unsupportedLayers = ["custom"], this.center = [0, 0], this.range = [3.5, 7]; } project(t, e) { return { x: 0, y: 0, z: 0 } } unproject(t, e) { return new ru(0, 0) } projectTilePoint(t, e, r) { return { x: t, y: e, z: 0 } } locationPoint(t, e, r = !0) { return t._coordinatePoint(t.locationCoordinate(e), r) } pixelsPerMeter(t, e) { return au(1, t) * e } pixelSpaceConversion(t, e, r) { return 1 } farthestPixelDistance(t) { return Df(t, t.pixelsPerMeter) } pointCoordinate(t, e, r, n) { const i = t.horizonLineFromTop(!1), s = new d(e, Math.max(i, r)); return t.rayIntersectionCoordinate(t.pointRayIntersection(s, n)) } pointCoordinate3D(t, e, r) { const n = new d(e, r); if (t.elevation) return t.elevation.pointCoordinate(n); { const e = this.pointCoordinate(t, n.x, n.y, 0); return [e.x, e.y, e.z] } } isPointAboveHorizon(t, e) { if (t.elevation) return !this.pointCoordinate3D(t, e.x, e.y); const r = t.horizonLineFromTop(); return e.y < r } createInversionMatrix(t, e) { return Lf } createTileMatrix(t, e, r) { let n, i, s; const a = r.canonical, o = Eo(new Float64Array(16)); if (this.isReprojectedInTileSpace) { const l = Vf(a, this); n = 1, i = l.x + r.wrap * l.scale, s = l.y, Vo(o, o, [n / l.scale, n / l.scale, t.pixelsPerMeter / e]); } else n = e / t.zoomScale(a.z), i = (a.x + Math.pow(2, a.z) * r.wrap) * n, s = a.y * n; return Do(o, o, [i, s, 0]), Vo(o, o, [n / ko, n / ko, 1]), o } upVector(t, e, r) { return [0, 0, 1] } upVectorScale(t, e, r) { return { metersToTile: 1 } } } class Rf extends Ff { constructor(t) { super(t), this.range = [4, 7], this.center = t.center || [-96, 37.5]; const [e, r] = this.parallels = t.parallels || [29.5, 45.5], n = Math.sin(x(e)); this.n = (n + Math.sin(x(r))) / 2, this.c = 1 + n * (2 * this.n - n), this.r0 = Math.sqrt(this.c) / this.n; } project(t, e) { const { n: r, c: n, r0: i } = this, s = x(t - this.center[0]), a = x(e), o = Math.sqrt(n - 2 * r * Math.sin(a)) / r; return { x: o * Math.sin(s * r), y: o * Math.cos(s * r) - i, z: 0 } } unproject(t, e) { const { n: r, c: n, r0: i } = this, s = i + e; let a = Math.atan2(t, Math.abs(s)) * Math.sign(s); s * r < 0 && (a -= Math.PI * Math.sign(t) * Math.sign(s)); const o = x(this.center[0]) * r; a = I(a, -Math.PI - o, Math.PI - o); const l = S(v(a / r) + this.center[0], -180, 180), u = Math.asin(S((n - (t * t + s * s) * r * r) / (2 * r), -1, 1)), c = S(v(u), -cu, cu); return new ru(l, c) } } const jf = 1.340264, $f = -.081106, Uf = 893e-6, Of = .003796, qf = Math.sqrt(3) / 2; class Nf extends Ff { project(t, e) { e = e / 180 * Math.PI, t = t / 180 * Math.PI; const r = Math.asin(qf * Math.sin(e)), n = r * r, i = n * n * n; return { x: .5 * (t * Math.cos(r) / (qf * (jf + 3 * $f * n + i * (7 * Uf + 9 * Of * n))) / Math.PI + .5), y: 1 - .5 * (r * (jf + $f * n + i * (Uf + Of * n)) / Math.PI + 1), z: 0 } } unproject(t, e) { t = (2 * t - .5) * Math.PI; let r = e = (2 * (1 - e) - 1) * Math.PI, n = r * r, i = n * n * n; for (let t, s, a, o = 0; o < 12 && (s = r * (jf + $f * n + i * (Uf + Of * n)) - e, a = jf + 3 * $f * n + i * (7 * Uf + 9 * Of * n), t = s / a, r = S(r - t, -Math.PI / 3, Math.PI / 3), n = r * r, i = n * n * n, !(Math.abs(t) < 1e-12)); ++o); const s = qf * t * (jf + 3 * $f * n + i * (7 * Uf + 9 * Of * n)) / Math.cos(r), a = Math.asin(Math.sin(r) / qf), o = S(180 * s / Math.PI, -180, 180), l = S(180 * a / Math.PI, -cu, cu); return new ru(o, l) } } class Gf extends Ff { constructor(t) { super(t), this.wrap = !0, this.supportsWorldCopies = !0; } project(t, e) { return { x: .5 + t / 360, y: .5 - e / 360, z: 0 } } unproject(t, e) { const r = 360 * (t - .5), n = S(360 * (.5 - e), -cu, cu); return new ru(r, n) } } const Zf = Math.PI / 2; function Xf(t) { return Math.tan((Zf + t) / 2) } class Kf extends Ff { constructor(t) { super(t), this.center = t.center || [0, 30]; const [e, r] = this.parallels = t.parallels || [30, 30]; let n = x(e), i = x(r); this.southernCenter = n + i < 0, this.southernCenter && (n = -n, i = -i); const s = Math.cos(n), a = Xf(n); this.n = n === i ? Math.sin(n) : Math.log(s / Math.cos(i)) / Math.log(Xf(i) / a), this.f = s * Math.pow(Xf(n), this.n) / this.n; } project(t, e) { e = x(e), this.southernCenter && (e = -e), t = x(t - this.center[0]); const r = 1e-6, { n: n, f: i } = this; i > 0 ? e < -Zf + r && (e = -Zf + r) : e > Zf - r && (e = Zf - r); const s = i / Math.pow(Xf(e), n); let a = s * Math.sin(n * t), o = i - s * Math.cos(n * t); return a = .5 * (a / Math.PI + .5), o = .5 * (o / Math.PI + .5), { x: a, y: this.southernCenter ? o : 1 - o, z: 0 } } unproject(t, e) { t = (2 * t - .5) * Math.PI, this.southernCenter && (e = 1 - e), e = (2 * (1 - e) - .5) * Math.PI; const { n: r, f: n } = this, i = n - e, s = Math.sign(i), a = Math.sign(r) * Math.sqrt(t * t + i * i); let o = Math.atan2(t, Math.abs(i)) * s; i * r < 0 && (o -= Math.PI * Math.sign(t) * s); const l = S(v(o / r) + this.center[0], -180, 180), u = S(v(2 * Math.atan(Math.pow(n / a, 1 / r)) - Zf), -cu, cu); return new ru(l, this.southernCenter ? -u : u) } } class Yf extends Ff { constructor(t) { super(t), this.wrap = !0, this.supportsWorldCopies = !0, this.supportsTerrain = !0, this.supportsFog = !0, this.supportsFreeCamera = !0, this.isReprojectedInTileSpace = !1, this.unsupportedLayers = [], this.range = null; } project(t, e) { return { x: iu(t), y: su(e), z: 0 } } unproject(t, e) { const r = ou(t), n = lu(e); return new ru(r, n) } } const Hf = x(cu); class Wf extends Ff { project(t, e) { const r = (e = x(e)) * e, n = r * r; return { x: .5 * ((t = x(t)) * (.8707 - .131979 * r + n * (n * (.003971 * r - .001529 * n) - .013791)) / Math.PI + .5), y: 1 - .5 * (e * (1.007226 + r * (.015085 + n * (.028874 * r - .044475 - .005916 * n))) / Math.PI + 1), z: 0 } } unproject(t, e) { t = (2 * t - .5) * Math.PI; let r = e = (2 * (1 - e) - 1) * Math.PI, n = 25, i = 0, s = r * r; do { s = r * r; const t = s * s; i = (r * (1.007226 + s * (.015085 + t * (.028874 * s - .044475 - .005916 * t))) - e) / (1.007226 + s * (.045255 + t * (.259866 * s - .311325 - .005916 * 11 * t))), r = S(r - i, -Hf, Hf); } while (Math.abs(i) > 1e-6 && --n > 0); s = r * r; const a = S(v(t / (.8707 + s * (s * (s * s * s * (.003971 - .001529 * s) - .013791) - .131979))), -180, 180), o = v(r); return new ru(a, o) } } const Jf = x(cu); class Qf extends Ff { project(t, e) { e = x(e), t = x(t); const r = Math.cos(e), n = 2 / Math.PI, i = Math.acos(r * Math.cos(t / 2)), s = Math.sin(i) / i, a = .5 * (t * n + 2 * r * Math.sin(t / 2) / s) || 0, o = .5 * (e + Math.sin(e) / s) || 0; return { x: .5 * (a / Math.PI + .5), y: 1 - .5 * (o / Math.PI + 1), z: 0 } } unproject(t, e) { let r = t = (2 * t - .5) * Math.PI, n = e = (2 * (1 - e) - 1) * Math.PI, i = 25; const s = 1e-6; let a = 0, o = 0; do { const i = Math.cos(n), s = Math.sin(n), l = 2 * s * i, u = s * s, c = i * i, h = Math.cos(r / 2), p = Math.sin(r / 2), f = 2 * h * p, d = p * p, y = 1 - c * h * h, m = y ? 1 / y : 0, g = y ? Math.acos(i * h) * Math.sqrt(1 / y) : 0, x = .5 * (2 * g * i * p + 2 * r / Math.PI) - t, v = .5 * (g * s + n) - e, b = .5 * m * (c * d + g * i * h * u) + 1 / Math.PI, w = m * (f * l / 4 - g * s * p), _ = .125 * m * (l * p - g * s * c * f), A = .5 * m * (u * h + g * d * i) + .5, k = w * _ - A * b; a = (v * w - x * A) / k, o = (x * _ - v * b) / k, r = S(r - a, -Math.PI, Math.PI), n = S(n - o, -Jf, Jf); } while ((Math.abs(a) > s || Math.abs(o) > s) && --i > 0); return new ru(v(r), v(n)) } } class td extends Ff { constructor(t) { super(t), this.center = t.center || [0, 0], this.parallels = t.parallels || [0, 0], this.cosPhi = Math.max(.01, Math.cos(x(this.parallels[0]))), this.scale = 1 / (2 * Math.max(Math.PI * this.cosPhi, 1 / this.cosPhi)), this.wrap = !0, this.supportsWorldCopies = !0; } project(t, e) { const { scale: r, cosPhi: n } = this; return { x: x(t) * n * r + .5, y: -Math.sin(x(e)) / n * r + .5, z: 0 } } unproject(t, e) { const { scale: r, cosPhi: n } = this, i = -(e - .5) / r, s = S(v((t - .5) / r) / n, -180, 180), a = Math.asin(S(i * n, -1, 1)), o = S(v(a), -cu, cu); return new ru(s, o) } } class ed extends Yf { constructor(t) { super(t), this.requiresDraping = !0, this.supportsWorldCopies = !1, this.supportsFog = !0, this.zAxisUnit = "pixels", this.unsupportedLayers = ["debug"], this.range = [3, 5]; } projectTilePoint(t, e, r) { const n = Ol(t, e, r); return el(n, n, Gl(Pl(r))), { x: n[0], y: n[1], z: n[2] } } locationPoint(t, e) { const r = Ul(e.lat, e.lng), n = Jo([], r), i = t.elevation ? t.elevation.getAtPointOrZero(t.locationCoordinate(e), t._centerAltitude) : t._centerAltitude; Wo(r, r, n, au(1, 0) * ko * i); const s = Eo(new Float64Array(16)); return Po(s, t.pixelMatrix, t.globeMatrix), el(r, r, s), new d(r[0], r[1]) } pixelsPerMeter(t, e) { return au(1, 0) * e } pixelSpaceConversion(t, e, r) { const n = au(1, t) * e, i = Mr(au(1, 45) * e, n, r); return this.pixelsPerMeter(t, e) / i } createTileMatrix(t, e, r) { const n = Zl(Pl(r.canonical)); return Po(new Float64Array(16), t.globeMatrix, n) } createInversionMatrix(t, e) { const { center: r } = t, n = Gl(Pl(e)); return Fo(n, n, x(r.lng)), Lo(n, n, x(r.lat)), Vo(n, n, [t._pixelsPerMercatorPixel, t._pixelsPerMercatorPixel, 1]), Float32Array.from(n) } pointCoordinate(t, e, r, n) { return Bl(t, e, r, !0) || new pu(0, 0) } pointCoordinate3D(t, e, r) { const n = this.pointCoordinate(t, e, r, 0); return [n.x, n.y, n.z] } isPointAboveHorizon(t, e) { return !Bl(t, e.x, e.y, !1) } farthestPixelDistance(t) { const e = function(t, e) { const r = t.cameraToCenterDistance, n = t._centerAltitude * e, i = t._camera, s = t._camera.forward(), a = Go([], Ho([], s, -r), [0, 0, n]), o = t.worldSize / (2 * Math.PI), l = [0, 0, -o], u = t.width / t.height, c = Math.tan(t.fovAboveCenter), h = Ho([], i.up(), c), p = Ho([], i.right(), c * u), f = Jo([], Go([], Go([], s, h), p)), d = []; let y; if (new vl(a, f).closestPointOnSphere(l, o, d)) { const e = Go([], d, l), r = il([], e, a); y = Math.cos(t.fovAboveCenter) * qo(r); } else { const t = il([], a, l), e = il([], l, a); Jo(e, e); const r = qo(t) - o; y = Math.sqrt(r * (r + 2 * o)); const n = Math.acos(y / (o + r)) - Math.acos(Qo(s, e)); y *= Math.cos(n); } return 1.01 * y }(t, this.pixelsPerMeter(t.center.lat, t.worldSize)), r = Kl(t.zoom); if (r > 0) { const n = Df(t, au(1, t.center.lat) * t.worldSize), i = t.worldSize / (2 * Math.PI), s = Math.max(t.width, t.height) / t.worldSize * Math.PI; return Mr(e, n + i * (1 - Math.cos(s)), Math.pow(r, 10)) } return e } upVector(t, e, r) { return Ol(e, r, t, 1) } upVectorScale(t) { return { metersToTile: zl(ql(Pl(t))) } } } function rd(t) { const e = t.parallels, r = !!e && Math.abs(e[0] + e[1]) < .01; switch (t.name) { case "mercator": return new Yf(t); case "equirectangular": return new Gf(t); case "naturalEarth": return new Wf(t); case "equalEarth": return new Nf(t); case "winkelTripel": return new Qf(t); case "albers": return r ? new td(t) : new Rf(t); case "lambertConformalConic": return r ? new td(t) : new Kf(t); case "globe": return new ed(t) } throw new Error(`Invalid projection name: ${t.name}`) } const nd = ah.types, id = [{ name: "a_fade_opacity", components: 1, type: "Uint8", offset: 0 }]; function sd(t, e, r, n, i, s, a, o, l, u, c, h, p) { const f = o ? Math.min(Tf, Math.round(o[0])) : 0, d = o ? Math.min(Tf, Math.round(o[1])) : 0; t.emplaceBack(e, r, Math.round(32 * n), Math.round(32 * i), s, a, (f << 1) + (l ? 1 : 0), d, 16 * u, 16 * c, 256 * h, 256 * p); } function ad(t, e, r, n, i, s, a) { t.emplaceBack(e, r, n, i, s, a); } function od(t, e, r, n, i) { t.emplaceBack(e, r, n, i), t.emplaceBack(e, r, n, i), t.emplaceBack(e, r, n, i), t.emplaceBack(e, r, n, i); } function ld(t) { for (const e of t.sections) if (Ms(e.text)) return !0; return !1 } class ud { constructor(t) { this.layoutVertexArray = new fa, this.indexArray = new wa, this.programConfigurations = t, this.segments = new So, this.dynamicLayoutVertexArray = new ua, this.opacityVertexArray = new ya, this.placedSymbolArray = new Pa, this.globeExtVertexArray = new da; } isEmpty() { return 0 === this.layoutVertexArray.length && 0 === this.indexArray.length && 0 === this.dynamicLayoutVertexArray.length && 0 === this.opacityVertexArray.length } upload(t, e, r, n) { this.isEmpty() || (r && (this.layoutVertexBuffer = t.createVertexBuffer(this.layoutVertexArray, Nh.members), this.indexBuffer = t.createIndexBuffer(this.indexArray, e), this.dynamicLayoutVertexBuffer = t.createVertexBuffer(this.dynamicLayoutVertexArray, Zh.members, !0), this.opacityVertexBuffer = t.createVertexBuffer(this.opacityVertexArray, id, !0), this.globeExtVertexArray.length > 0 && (this.globeExtVertexBuffer = t.createVertexBuffer(this.globeExtVertexArray, Gh.members, !0)), this.opacityVertexBuffer.itemSize = 1), (r || n) && this.programConfigurations.upload(t)); } destroy() { this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.indexBuffer.destroy(), this.programConfigurations.destroy(), this.segments.destroy(), this.dynamicLayoutVertexBuffer.destroy(), this.opacityVertexBuffer.destroy(), this.globeExtVertexBuffer && this.globeExtVertexBuffer.destroy()); } } Oi(ud, "SymbolBuffers"); class cd { constructor(t, e, r) { this.layoutVertexArray = new t, this.layoutAttributes = e, this.indexArray = new r, this.segments = new So, this.collisionVertexArray = new va, this.collisionVertexArrayExt = new ba; } upload(t) { this.layoutVertexBuffer = t.createVertexBuffer(this.layoutVertexArray, this.layoutAttributes), this.indexBuffer = t.createIndexBuffer(this.indexArray), this.collisionVertexBuffer = t.createVertexBuffer(this.collisionVertexArray, Xh.members, !0), this.collisionVertexBufferExt = t.createVertexBuffer(this.collisionVertexArrayExt, Kh.members, !0); } destroy() { this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.indexBuffer.destroy(), this.segments.destroy(), this.collisionVertexBuffer.destroy(), this.collisionVertexBufferExt.destroy()); } } Oi(cd, "CollisionBuffers"); class hd { constructor(t) { this.collisionBoxArray = t.collisionBoxArray, this.zoom = t.zoom, this.overscaling = t.overscaling, this.layers = t.layers, this.layerIds = this.layers.map((t => t.id)), this.index = t.index, this.pixelRatio = t.pixelRatio, this.sourceLayerIndex = t.sourceLayerIndex, this.hasPattern = !1, this.hasRTLText = !1, this.fullyClipped = !1, this.sortKeyRanges = [], this.collisionCircleArray = [], this.placementInvProjMatrix = Eo([]), this.placementViewportMatrix = Eo([]); const e = this.layers[0]._unevaluatedLayout._values; this.textSizeData = Qh(this.zoom, e["text-size"]), this.iconSizeData = Qh(this.zoom, e["icon-size"]); const r = this.layers[0].layout, n = r.get("symbol-sort-key"), i = r.get("symbol-z-order"); this.canOverlap = r.get("text-allow-overlap") || r.get("icon-allow-overlap") || r.get("text-ignore-placement") || r.get("icon-ignore-placement"), this.sortFeaturesByKey = "viewport-y" !== i && void 0 !== n.constantOr(1), this.sortFeaturesByY = ("viewport-y" === i || "auto" === i && !this.sortFeaturesByKey) && this.canOverlap, this.writingModes = r.get("text-writing-mode").map((t => Vp[t])), this.stateDependentLayerIds = this.layers.filter((t => t.isStateDependent())).map((t => t.id)), this.sourceID = t.sourceID, this.projection = t.projection; } createArrays() { this.text = new ud(new fo(this.layers, this.zoom, (t => /^text/.test(t)))), this.icon = new ud(new fo(this.layers, this.zoom, (t => /^icon/.test(t)))), this.glyphOffsetArray = new La, this.lineVertexArray = new Fa, this.symbolInstances = new Va; } calculateGlyphDependencies(t, e, r, n, i) { for (let r = 0; r < t.length; r++) if (e[t.charCodeAt(r)] = !0, n && i) { const n = ip[t.charAt(r)]; n && (e[n.charCodeAt(0)] = !0); } } populate(t, e, r, n) { const i = this.layers[0], s = i.layout, a = "globe" === this.projection.name, o = s.get("text-font"), l = s.get("text-field"), u = s.get("icon-image"), c = ("constant" !== l.value.kind || l.value.value instanceof Be && !l.value.value.isEmpty() || l.value.value.toString().length > 0) && ("constant" !== o.value.kind || o.value.value.length > 0), h = "constant" !== u.value.kind || !!u.value.value || Object.keys(u.parameters).length > 0, p = s.get("symbol-sort-key"); if (this.features = [], !c && !h) return; const f = e.iconDependencies, d = e.glyphDependencies, y = e.availableImages, m = new $s(this.zoom); for (const { feature: e, id: l, index: u, sourceLayerIndex: g } of t) { const t = i._featureFilter.needGeometry, x = wu(e, t); if (!i._featureFilter.filter(m, x, r)) continue; if (t || (x.geometry = bu(e, r, n)), a && 1 !== e.type && r.z <= 5) { const t = x.geometry, e = .98078528056, n = (t, n) => Qo(Ol(t.x, t.y, r, 1), Ol(n.x, n.y, r, 1)) < e; for (let e = 0; e < t.length; e++) t[e] = mu(t[e], n); } let v, b; if (c) { const t = i.getValueAndResolveTokens("text-field", x, r, y), e = Be.factory(t); ld(e) && (this.hasRTLText = !0), (!this.hasRTLText || "unavailable" === Fs() || this.hasRTLText && js.isParsed()) && (v = np(e, i, x)); } if (h) { const t = i.getValueAndResolveTokens("icon-image", x, r, y); b = t instanceof Ee ? t : Ee.fromString(t); } if (!v && !b) continue; const w = this.sortFeaturesByKey ? p.evaluate(x, {}, r) : void 0; if (this.features.push({ id: l, text: v, icon: b, index: u, sourceLayerIndex: g, geometry: x.geometry, properties: e.properties, type: nd[e.type], sortKey: w }), b && (f[b.name] = !0), v) { const t = o.evaluate(x, {}, r).join(","), e = "map" === s.get("text-rotation-alignment") && "point" !== s.get("symbol-placement"); this.allowVerticalPlacement = this.writingModes && this.writingModes.indexOf(Vp.vertical) >= 0; for (const r of v.sections) if (r.image) f[r.image.name] = !0; else { const n = bs(v.toString()), i = r.fontStack || t, s = d[i] = d[i] || {}; this.calculateGlyphDependencies(r.text, s, e, this.allowVerticalPlacement, n); } } } "line" === s.get("symbol-placement") && (this.features = function(t) { const e = {}, r = {}, n = []; let i = 0; function s(e) { n.push(t[e]), i++; } function a(t, e, i) { const s = r[t]; return delete r[t], r[e] = s, n[s].geometry[0].pop(), n[s].geometry[0] = n[s].geometry[0].concat(i[0]), s } function o(t, r, i) { const s = e[r]; return delete e[r], e[t] = s, n[s].geometry[0].shift(), n[s].geometry[0] = i[0].concat(n[s].geometry[0]), s } function l(t, e, r) { const n = r ? e[0][e[0].length - 1] : e[0][0]; return `${t}:${n.x}:${n.y}` } for (let u = 0; u < t.length; u++) { const c = t[u], h = c.geometry, p = c.text ? c.text.toString() : null; if (!p) { s(u); continue } const f = l(p, h), d = l(p, h, !0); if (f in r && d in e && r[f] !== e[d]) { const t = o(f, d, h), i = a(f, d, n[t].geometry); delete e[f], delete r[d], r[l(p, n[i].geometry, !0)] = i, n[t].geometry = null; } else f in r ? a(f, d, h) : d in e ? o(f, d, h) : (s(u), e[f] = i - 1, r[d] = i - 1); } return n.filter((t => t.geometry)) }(this.features)), this.sortFeaturesByKey && this.features.sort(((t, e) => t.sortKey - e.sortKey)); } update(t, e, r, n) { this.stateDependentLayers.length && (this.text.programConfigurations.updatePaintArrays(t, e, this.layers, r, n), this.icon.programConfigurations.updatePaintArrays(t, e, this.layers, r, n)); } isEmpty() { return 0 === this.symbolInstances.length && !this.hasRTLText } uploadPending() { return !this.uploaded || this.text.programConfigurations.needsUpload || this.icon.programConfigurations.needsUpload } upload(t) { !this.uploaded && this.hasDebugData() && (this.textCollisionBox.upload(t), this.iconCollisionBox.upload(t)), this.text.upload(t, this.sortFeaturesByY, !this.uploaded, this.text.programConfigurations.needsUpload), this.icon.upload(t, this.sortFeaturesByY, !this.uploaded, this.icon.programConfigurations.needsUpload), this.uploaded = !0; } destroyDebugData() { this.textCollisionBox.destroy(), this.iconCollisionBox.destroy(); } getProjection() { return this.projectionInstance || (this.projectionInstance = rd(this.projection)), this.projectionInstance } destroy() { this.text.destroy(), this.icon.destroy(), this.hasDebugData() && this.destroyDebugData(); } addToLineVertexArray(t, e) { const r = this.lineVertexArray.length; if (void 0 !== t.segment) for (const { x: t, y: r } of e) this.lineVertexArray.emplaceBack(t, r); return { lineStartIndex: r, lineLength: this.lineVertexArray.length - r } } addSymbols(t, e, r, n, i, s, a, o, l, u, c, h, p, f) { const d = t.indexArray, y = t.layoutVertexArray, m = t.globeExtVertexArray, g = t.segments.prepareSegment(4 * e.length, y, d, this.canOverlap ? s.sortKey : void 0), x = this.glyphOffsetArray.length, v = g.vertexLength, b = this.allowVerticalPlacement && a === Vp.vertical ? Math.PI / 2 : 0, w = s.text && s.text.sections; for (let n = 0; n < e.length; n++) { const { tl: i, tr: a, bl: u, br: c, tex: h, pixelOffsetTL: x, pixelOffsetBR: v, minFontScaleX: _, minFontScaleY: A, glyphOffset: S, isSDF: k, sectionIndex: I } = e[n], M = g.vertexLength, T = S[1]; if (sd(y, l.x, l.y, i.x, T + i.y, h.x, h.y, r, k, x.x, x.y, _, A), sd(y, l.x, l.y, a.x, T + a.y, h.x + h.w, h.y, r, k, v.x, x.y, _, A), sd(y, l.x, l.y, u.x, T + u.y, h.x, h.y + h.h, r, k, x.x, v.y, _, A), sd(y, l.x, l.y, c.x, T + c.y, h.x + h.w, h.y + h.h, r, k, v.x, v.y, _, A), o) { const { x: e, y: r, z: n } = o.anchor, [i, s, a] = o.up; ad(m, e, r, n, i, s, a), ad(m, e, r, n, i, s, a), ad(m, e, r, n, i, s, a), ad(m, e, r, n, i, s, a), od(t.dynamicLayoutVertexArray, e, r, n, b); } else od(t.dynamicLayoutVertexArray, l.x, l.y, l.z, b); d.emplaceBack(M, M + 1, M + 2), d.emplaceBack(M + 1, M + 2, M + 3), g.vertexLength += 4, g.primitiveLength += 2, this.glyphOffsetArray.emplaceBack(S[0]), n !== e.length - 1 && I === e[n + 1].sectionIndex || t.programConfigurations.populatePaintArrays(y.length, s, s.index, {}, p, f, w && w[I]); } const _ = o ? o.anchor : l; t.placedSymbolArray.emplaceBack(_.x, _.y, _.z, l.x, l.y, x, this.glyphOffsetArray.length - x, v, u, c, l.segment, r ? r[0] : 0, r ? r[1] : 0, n[0], n[1], a, 0, !1, 0, h, 0); } _commitLayoutVertex(t, e, r, n, i, s, a) { t.emplaceBack(e, r, n, i, s, Math.round(a.x), Math.round(a.y)); } _addCollisionDebugVertices(t, e, r, n, i, s, a) { const o = r.segments.prepareSegment(4, r.layoutVertexArray, r.indexArray), l = o.vertexLength, u = a.tileAnchorX, c = a.tileAnchorY; for (let t = 0; t < 4; t++) r.collisionVertexArray.emplaceBack(0, 0, 0, 0); r.collisionVertexArrayExt.emplaceBack(e, -t.padding, -t.padding), r.collisionVertexArrayExt.emplaceBack(e, t.padding, -t.padding), r.collisionVertexArrayExt.emplaceBack(e, t.padding, t.padding), r.collisionVertexArrayExt.emplaceBack(e, -t.padding, t.padding), this._commitLayoutVertex(r.layoutVertexArray, n, i, s, u, c, new d(t.x1, t.y1)), this._commitLayoutVertex(r.layoutVertexArray, n, i, s, u, c, new d(t.x2, t.y1)), this._commitLayoutVertex(r.layoutVertexArray, n, i, s, u, c, new d(t.x2, t.y2)), this._commitLayoutVertex(r.layoutVertexArray, n, i, s, u, c, new d(t.x1, t.y2)), o.vertexLength += 4; const h = r.indexArray; h.emplaceBack(l, l + 1), h.emplaceBack(l + 1, l + 2), h.emplaceBack(l + 2, l + 3), h.emplaceBack(l + 3, l), o.primitiveLength += 4; } _addTextDebugCollisionBoxes(t, e, r, n, i, s) { for (let a = n; a < i; a++) { const n = r.get(a), i = this.getSymbolInstanceTextSize(t, s, e, a); this._addCollisionDebugVertices(n, i, this.textCollisionBox, n.projectedAnchorX, n.projectedAnchorY, n.projectedAnchorZ, s); } } _addIconDebugCollisionBoxes(t, e, r, n, i, s) { for (let a = n; a < i; a++) { const n = r.get(a), i = this.getSymbolInstanceIconSize(t, e, s.placedIconSymbolIndex); this._addCollisionDebugVertices(n, i, this.iconCollisionBox, n.projectedAnchorX, n.projectedAnchorY, n.projectedAnchorZ, s); } } generateCollisionDebugBuffers(t, e) { this.hasDebugData() && this.destroyDebugData(), this.textCollisionBox = new cd(ga, Yh.members, Ma), this.iconCollisionBox = new cd(ga, Yh.members, Ma); const r = ep(this.iconSizeData, t), n = ep(this.textSizeData, t); for (let i = 0; i < this.symbolInstances.length; i++) { const s = this.symbolInstances.get(i); this._addTextDebugCollisionBoxes(n, t, e, s.textBoxStartIndex, s.textBoxEndIndex, s), this._addTextDebugCollisionBoxes(n, t, e, s.verticalTextBoxStartIndex, s.verticalTextBoxEndIndex, s), this._addIconDebugCollisionBoxes(r, t, e, s.iconBoxStartIndex, s.iconBoxEndIndex, s), this._addIconDebugCollisionBoxes(r, t, e, s.verticalIconBoxStartIndex, s.verticalIconBoxEndIndex, s); } } getSymbolInstanceTextSize(t, e, r, n) { const i = this.text.placedSymbolArray.get(e.rightJustifiedTextSymbolIndex >= 0 ? e.rightJustifiedTextSymbolIndex : e.centerJustifiedTextSymbolIndex >= 0 ? e.centerJustifiedTextSymbolIndex : e.leftJustifiedTextSymbolIndex >= 0 ? e.leftJustifiedTextSymbolIndex : e.verticalPlacedTextSymbolIndex >= 0 ? e.verticalPlacedTextSymbolIndex : n), s = tp(this.textSizeData, t, i) / Wh; return this.tilePixelRatio * s } getSymbolInstanceIconSize(t, e, r) { const n = this.icon.placedSymbolArray.get(r), i = tp(this.iconSizeData, t, n); return this.tilePixelRatio * i } _commitDebugCollisionVertexUpdate(t, e, r) { t.emplaceBack(e, -r, -r), t.emplaceBack(e, r, -r), t.emplaceBack(e, r, r), t.emplaceBack(e, -r, r); } _updateTextDebugCollisionBoxes(t, e, r, n, i, s) { for (let a = n; a < i; a++) { const n = r.get(a), i = this.getSymbolInstanceTextSize(t, s, e, a); this._commitDebugCollisionVertexUpdate(this.textCollisionBox.collisionVertexArrayExt, i, n.padding); } } _updateIconDebugCollisionBoxes(t, e, r, n, i, s) { for (let a = n; a < i; a++) { const n = r.get(a), i = this.getSymbolInstanceIconSize(t, e, s); this._commitDebugCollisionVertexUpdate(this.iconCollisionBox.collisionVertexArrayExt, i, n.padding); } } updateCollisionDebugBuffers(t, e) { if (!this.hasDebugData()) return; this.hasTextCollisionBoxData() && this.textCollisionBox.collisionVertexArrayExt.clear(), this.hasIconCollisionBoxData() && this.iconCollisionBox.collisionVertexArrayExt.clear(); const r = ep(this.iconSizeData, t), n = ep(this.textSizeData, t); for (let i = 0; i < this.symbolInstances.length; i++) { const s = this.symbolInstances.get(i); this._updateTextDebugCollisionBoxes(n, t, e, s.textBoxStartIndex, s.textBoxEndIndex, s), this._updateTextDebugCollisionBoxes(n, t, e, s.verticalTextBoxStartIndex, s.verticalTextBoxEndIndex, s), this._updateIconDebugCollisionBoxes(r, t, e, s.iconBoxStartIndex, s.iconBoxEndIndex, s.placedIconSymbolIndex), this._updateIconDebugCollisionBoxes(r, t, e, s.verticalIconBoxStartIndex, s.verticalIconBoxEndIndex, s.placedIconSymbolIndex); } this.hasTextCollisionBoxData() && this.textCollisionBox.collisionVertexBufferExt && this.textCollisionBox.collisionVertexBufferExt.updateData(this.textCollisionBox.collisionVertexArrayExt), this.hasIconCollisionBoxData() && this.iconCollisionBox.collisionVertexBufferExt && this.iconCollisionBox.collisionVertexBufferExt.updateData(this.iconCollisionBox.collisionVertexArrayExt); } _deserializeCollisionBoxesForSymbol(t, e, r, n, i, s, a, o, l) { const u = {}; if (e < r) { const { x1: r, y1: n, x2: i, y2: s, padding: a, projectedAnchorX: o, projectedAnchorY: l, projectedAnchorZ: c, tileAnchorX: h, tileAnchorY: p, featureIndex: f } = t.get(e); u.textBox = { x1: r, y1: n, x2: i, y2: s, padding: a, projectedAnchorX: o, projectedAnchorY: l, projectedAnchorZ: c, tileAnchorX: h, tileAnchorY: p }, u.textFeatureIndex = f; } if (n < i) { const { x1: e, y1: r, x2: i, y2: s, padding: a, projectedAnchorX: o, projectedAnchorY: l, projectedAnchorZ: c, tileAnchorX: h, tileAnchorY: p, featureIndex: f } = t.get(n); u.verticalTextBox = { x1: e, y1: r, x2: i, y2: s, padding: a, projectedAnchorX: o, projectedAnchorY: l, projectedAnchorZ: c, tileAnchorX: h, tileAnchorY: p }, u.verticalTextFeatureIndex = f; } if (s < a) { const { x1: e, y1: r, x2: n, y2: i, padding: a, projectedAnchorX: o, projectedAnchorY: l, projectedAnchorZ: c, tileAnchorX: h, tileAnchorY: p, featureIndex: f } = t.get(s); u.iconBox = { x1: e, y1: r, x2: n, y2: i, padding: a, projectedAnchorX: o, projectedAnchorY: l, projectedAnchorZ: c, tileAnchorX: h, tileAnchorY: p }, u.iconFeatureIndex = f; } if (o < l) { const { x1: e, y1: r, x2: n, y2: i, padding: s, projectedAnchorX: a, projectedAnchorY: l, projectedAnchorZ: c, tileAnchorX: h, tileAnchorY: p, featureIndex: f } = t.get(o); u.verticalIconBox = { x1: e, y1: r, x2: n, y2: i, padding: s, projectedAnchorX: a, projectedAnchorY: l, projectedAnchorZ: c, tileAnchorX: h, tileAnchorY: p }, u.verticalIconFeatureIndex = f; } return u } deserializeCollisionBoxes(t) { this.collisionArrays = []; for (let e = 0; e < this.symbolInstances.length; e++) { const r = this.symbolInstances.get(e); this.collisionArrays.push(this._deserializeCollisionBoxesForSymbol(t, r.textBoxStartIndex, r.textBoxEndIndex, r.verticalTextBoxStartIndex, r.verticalTextBoxEndIndex, r.iconBoxStartIndex, r.iconBoxEndIndex, r.verticalIconBoxStartIndex, r.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(t, e) { const r = t.placedSymbolArray.get(e), n = r.vertexStartIndex + 4 * r.numGlyphs; for (let e = r.vertexStartIndex; e < n; e += 4) t.indexArray.emplaceBack(e, e + 1, e + 2), t.indexArray.emplaceBack(e + 1, e + 2, e + 3); } getSortedSymbolIndexes(t) { if (this.sortedAngle === t && void 0 !== this.symbolInstanceIndexes) return this.symbolInstanceIndexes; const e = Math.sin(t), r = Math.cos(t), n = [], i = [], s = []; for (let t = 0; t < this.symbolInstances.length; ++t) { s.push(t); const a = this.symbolInstances.get(t); n.push(0 | Math.round(e * a.tileAnchorX + r * a.tileAnchorY)), i.push(a.featureIndex); } return s.sort(((t, e) => n[t] - n[e] || i[e] - i[t])), s } addToSortKeyRanges(t, e) { const r = this.sortKeyRanges[this.sortKeyRanges.length - 1]; r && r.sortKey === e ? r.symbolInstanceEnd = t + 1 : this.sortKeyRanges.push({ sortKey: e, symbolInstanceStart: t, symbolInstanceEnd: t + 1 }); } sortFeatures(t) { if (this.sortFeaturesByY && this.sortedAngle !== t && !(this.text.segments.get().length > 1 || this.icon.segments.get().length > 1)) { this.symbolInstanceIndexes = this.getSortedSymbolIndexes(t), this.sortedAngle = t, this.text.indexArray.clear(), this.icon.indexArray.clear(), this.featureSortOrder = []; for (const t of this.symbolInstanceIndexes) { const e = this.symbolInstances.get(t); this.featureSortOrder.push(e.featureIndex); const { rightJustifiedTextSymbolIndex: r, centerJustifiedTextSymbolIndex: n, leftJustifiedTextSymbolIndex: i, verticalPlacedTextSymbolIndex: s, placedIconSymbolIndex: a, verticalPlacedIconSymbolIndex: o } = e; r >= 0 && this.addIndicesForPlacedSymbol(this.text, r), n >= 0 && n !== r && this.addIndicesForPlacedSymbol(this.text, n), i >= 0 && i !== n && i !== r && this.addIndicesForPlacedSymbol(this.text, i), s >= 0 && this.addIndicesForPlacedSymbol(this.text, s), a >= 0 && this.addIndicesForPlacedSymbol(this.icon, a), o >= 0 && this.addIndicesForPlacedSymbol(this.icon, o); } this.text.indexBuffer && this.text.indexBuffer.updateData(this.text.indexArray), this.icon.indexBuffer && this.icon.indexBuffer.updateData(this.icon.indexArray); } } } Oi(hd, "SymbolBucket", { omit: ["layers", "collisionBoxArray", "features", "compareText"] }), hd.MAX_GLYPHS = 65535, hd.addDynamicAttributes = od; const pd = new Js({ "symbol-placement": new Ys(Ht.layout_symbol["symbol-placement"]), "symbol-spacing": new Ys(Ht.layout_symbol["symbol-spacing"]), "symbol-avoid-edges": new Ys(Ht.layout_symbol["symbol-avoid-edges"]), "symbol-sort-key": new Hs(Ht.layout_symbol["symbol-sort-key"]), "symbol-z-order": new Ys(Ht.layout_symbol["symbol-z-order"]), "icon-allow-overlap": new Ys(Ht.layout_symbol["icon-allow-overlap"]), "icon-ignore-placement": new Ys(Ht.layout_symbol["icon-ignore-placement"]), "icon-optional": new Ys(Ht.layout_symbol["icon-optional"]), "icon-rotation-alignment": new Ys(Ht.layout_symbol["icon-rotation-alignment"]), "icon-size": new Hs(Ht.layout_symbol["icon-size"]), "icon-text-fit": new Ys(Ht.layout_symbol["icon-text-fit"]), "icon-text-fit-padding": new Ys(Ht.layout_symbol["icon-text-fit-padding"]), "icon-image": new Hs(Ht.layout_symbol["icon-image"]), "icon-rotate": new Hs(Ht.layout_symbol["icon-rotate"]), "icon-padding": new Ys(Ht.layout_symbol["icon-padding"]), "icon-keep-upright": new Ys(Ht.layout_symbol["icon-keep-upright"]), "icon-offset": new Hs(Ht.layout_symbol["icon-offset"]), "icon-anchor": new Hs(Ht.layout_symbol["icon-anchor"]), "icon-pitch-alignment": new Ys(Ht.layout_symbol["icon-pitch-alignment"]), "text-pitch-alignment": new Ys(Ht.layout_symbol["text-pitch-alignment"]), "text-rotation-alignment": new Ys(Ht.layout_symbol["text-rotation-alignment"]), "text-field": new Hs(Ht.layout_symbol["text-field"]), "text-font": new Hs(Ht.layout_symbol["text-font"]), "text-size": new Hs(Ht.layout_symbol["text-size"]), "text-max-width": new Hs(Ht.layout_symbol["text-max-width"]), "text-line-height": new Hs(Ht.layout_symbol["text-line-height"]), "text-letter-spacing": new Hs(Ht.layout_symbol["text-letter-spacing"]), "text-justify": new Hs(Ht.layout_symbol["text-justify"]), "text-radial-offset": new Hs(Ht.layout_symbol["text-radial-offset"]), "text-variable-anchor": new Ys(Ht.layout_symbol["text-variable-anchor"]), "text-anchor": new Hs(Ht.layout_symbol["text-anchor"]), "text-max-angle": new Ys(Ht.layout_symbol["text-max-angle"]), "text-writing-mode": new Ys(Ht.layout_symbol["text-writing-mode"]), "text-rotate": new Hs(Ht.layout_symbol["text-rotate"]), "text-padding": new Ys(Ht.layout_symbol["text-padding"]), "text-keep-upright": new Ys(Ht.layout_symbol["text-keep-upright"]), "text-transform": new Hs(Ht.layout_symbol["text-transform"]), "text-offset": new Hs(Ht.layout_symbol["text-offset"]), "text-allow-overlap": new Ys(Ht.layout_symbol["text-allow-overlap"]), "text-ignore-placement": new Ys(Ht.layout_symbol["text-ignore-placement"]), "text-optional": new Ys(Ht.layout_symbol["text-optional"]) }); var fd = { paint: new Js({ "icon-opacity": new Hs(Ht.paint_symbol["icon-opacity"]), "icon-color": new Hs(Ht.paint_symbol["icon-color"]), "icon-halo-color": new Hs(Ht.paint_symbol["icon-halo-color"]), "icon-halo-width": new Hs(Ht.paint_symbol["icon-halo-width"]), "icon-halo-blur": new Hs(Ht.paint_symbol["icon-halo-blur"]), "icon-translate": new Ys(Ht.paint_symbol["icon-translate"]), "icon-translate-anchor": new Ys(Ht.paint_symbol["icon-translate-anchor"]), "text-opacity": new Hs(Ht.paint_symbol["text-opacity"]), "text-color": new Hs(Ht.paint_symbol["text-color"], { runtimeType: le, getOverride: t => t.textColor, hasOverride: t => !!t.textColor }), "text-halo-color": new Hs(Ht.paint_symbol["text-halo-color"]), "text-halo-width": new Hs(Ht.paint_symbol["text-halo-width"]), "text-halo-blur": new Hs(Ht.paint_symbol["text-halo-blur"]), "text-translate": new Ys(Ht.paint_symbol["text-translate"]), "text-translate-anchor": new Ys(Ht.paint_symbol["text-translate-anchor"]) }), layout: pd }; class dd { constructor(t) { this.type = t.property.overrides ? t.property.overrides.runtimeType : ie, this.defaultValue = t; } evaluate(t) { if (t.formattedSection) { const e = this.defaultValue.property.overrides; if (e && e.hasOverride(t.formattedSection)) return e.getOverride(t.formattedSection) } return t.feature && t.featureState ? this.defaultValue.evaluate(t.feature, t.featureState) : this.defaultValue.property.specification.default } eachChild(t) { this.defaultValue.isConstant() || t(this.defaultValue.value._styleExpression.expression); } outputDefined() { return !1 } serialize() { return null } } Oi(dd, "FormatSectionOverride", { omit: ["defaultValue"] }); class yd extends wo { constructor(t) { super(t, fd); } recalculate(t, e) { super.recalculate(t, e), "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"] = this.layout.get("text-rotation-alignment")), "auto" === this.layout.get("icon-pitch-alignment") && (this.layout._values["icon-pitch-alignment"] = this.layout.get("icon-rotation-alignment")); const r = this.layout.get("text-writing-mode"); if (r) { const t = []; for (const e of r) t.indexOf(e) < 0 && t.push(e); this.layout._values["text-writing-mode"] = t; } else this.layout._values["text-writing-mode"] = "point" === this.layout.get("symbol-placement") ? ["horizontal"] : ["horizontal", "vertical"]; this._setPaintOverrides(); } getValueAndResolveTokens(t, e, r, n) { const i = this.layout.get(t).evaluate(e, {}, r, n), s = this._unevaluatedLayout._values[t]; return s.isDataDriven() || Nn(s.value) || !i ? i : function(t, e) { return e.replace(/{([^{}]+)}/g, ((e, r) => r in t ? String(t[r]) : "")) }(e.properties, i) } createBucket(t) { return new hd(t) } queryRadius() { return 0 } queryIntersectsFeature() { return !1 } _setPaintOverrides() { for (const t of fd.paint.overridableProperties) { if (!yd.hasPaintOverride(this.layout, t)) continue; const e = this.paint.get(t), r = new dd(e), n = new qn(r, e.property.specification); let i = null; i = "constant" === e.value.kind || "source" === e.value.kind ? new Zn("source", n) : new Xn("composite", n, e.value.zoomStops, e.value._interpolationType), this.paint._values[t] = new Xs(e.property, i, e.parameters); } } _handleOverridablePaintPropertyUpdate(t, e, r) { return !(!this.layout || e.isDataDriven() || r.isDataDriven()) && yd.hasPaintOverride(this.layout, t) } static hasPaintOverride(t, e) { const r = t.get("text-field"), n = fd.paint.properties[e]; let i = !1; const s = t => { for (const e of t) if (n.overrides && n.overrides.hasOverride(e)) return void(i = !0) }; if ("constant" === r.value.kind && r.value.value instanceof Be) s(r.value.value.sections); else if ("source" === r.value.kind) { const t = e => { i || (e instanceof Fe && De(e.value) === pe ? s(e.value.sections) : e instanceof Oe ? s(e.sections) : e.eachChild(t)); }, e = r.value; e._styleExpression && t(e._styleExpression.expression); } return i } getProgramConfiguration(t) { return new po(this, t) } } var md = { paint: new Js({ "background-color": new Ys(Ht.paint_background["background-color"]), "background-pattern": new Ys(Ht.paint_background["background-pattern"]), "background-opacity": new Ys(Ht.paint_background["background-opacity"]) }) }, gd = { paint: new Js({ "raster-opacity": new Ys(Ht.paint_raster["raster-opacity"]), "raster-hue-rotate": new Ys(Ht.paint_raster["raster-hue-rotate"]), "raster-brightness-min": new Ys(Ht.paint_raster["raster-brightness-min"]), "raster-brightness-max": new Ys(Ht.paint_raster["raster-brightness-max"]), "raster-saturation": new Ys(Ht.paint_raster["raster-saturation"]), "raster-contrast": new Ys(Ht.paint_raster["raster-contrast"]), "raster-resampling": new Ys(Ht.paint_raster["raster-resampling"]), "raster-fade-duration": new Ys(Ht.paint_raster["raster-fade-duration"]) }) }; class xd extends wo { constructor(t) { super(t, {}), this.implementation = t; } is3D() { return "3d" === this.implementation.renderingMode } hasOffscreenPass() { return void 0 !== this.implementation.prerender } isLayerDraped() { return void 0 !== this.implementation.renderToTile } shouldRedrape() { return !!this.implementation.shouldRerenderTiles && this.implementation.shouldRerenderTiles() } recalculate() {} updateTransitions() {} hasTransition() { return !1 } serialize() {} onAdd(t) { this.implementation.onAdd && this.implementation.onAdd(t, t.painter.context.gl); } onRemove(t) { this.implementation.onRemove && this.implementation.onRemove(t, t.painter.context.gl); } } var vd = { paint: new Js({ "sky-type": new Ys(Ht.paint_sky["sky-type"]), "sky-atmosphere-sun": new Ys(Ht.paint_sky["sky-atmosphere-sun"]), "sky-atmosphere-sun-intensity": new Ys(Ht.paint_sky["sky-atmosphere-sun-intensity"]), "sky-gradient-center": new Ys(Ht.paint_sky["sky-gradient-center"]), "sky-gradient-radius": new Ys(Ht.paint_sky["sky-gradient-radius"]), "sky-gradient": new Ws(Ht.paint_sky["sky-gradient"]), "sky-atmosphere-halo-color": new Ys(Ht.paint_sky["sky-atmosphere-halo-color"]), "sky-atmosphere-color": new Ys(Ht.paint_sky["sky-atmosphere-color"]), "sky-opacity": new Ys(Ht.paint_sky["sky-opacity"]) }) }; function bd(t, e, r) { const n = [0, 0, 1], i = hl([]); return fl(i, i, r ? -x(t) + Math.PI : x(t)), pl(i, i, -x(e)), rl(n, n, i), Jo(n, n) } const wd = { circle: class extends wo { constructor(t) { super(t, Ou); } createBucket(t) { return new Su(t) } queryRadius(t) { const e = t; return Fu("circle-radius", this, e) + Fu("circle-stroke-width", this, e) + Ru(this.paint.get("circle-translate")) } queryIntersectsFeature(t, e, r, n, i, s, a, o) { const l = $u(this.paint.get("circle-translate"), this.paint.get("circle-translate-anchor"), s.angle, t.pixelToTileUnitsFactor), u = this.paint.get("circle-radius").evaluate(e, r) + this.paint.get("circle-stroke-width").evaluate(e, r); return qu(t, n, s, a, o, "map" === this.paint.get("circle-pitch-alignment"), "map" === this.paint.get("circle-pitch-scale"), l, u) } getProgramIds() { return ["circle"] } getProgramConfiguration(t) { return new po(this, t) } }, heatmap: class extends wo { createBucket(t) { return new Ku(t) } constructor(t) { super(t, tc), this._updateColorRamp(); } _handleSpecialPaintPropertyUpdate(t) { "heatmap-color" === t && this._updateColorRamp(); } _updateColorRamp() { this.colorRamp = ec({ 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(t) { return Fu("heatmap-radius", this, t) } queryIntersectsFeature(t, e, r, n, i, s, a, o) { const l = this.paint.get("heatmap-radius").evaluate(e, r); return qu(t, n, s, a, o, !0, !0, new d(0, 0), l) } hasOffscreenPass() { return 0 !== this.paint.get("heatmap-opacity") && "none" !== this.visibility } getProgramIds() { return ["heatmap", "heatmapTexture"] } getProgramConfiguration(t) { return new po(this, t) } }, hillshade: class extends wo { constructor(t) { super(t, rc); } hasOffscreenPass() { return 0 !== this.paint.get("hillshade-exaggeration") && "none" !== this.visibility } getProgramIds() { return ["hillshade", "hillshadePrepare"] } }, fill: class extends wo { constructor(t) { super(t, Oc); } getProgramIds() { const t = this.paint.get("fill-pattern"), e = t && t.constantOr(1), r = [e ? "fillPattern" : "fill"]; return this.paint.get("fill-antialias") && r.push(e && !this.getPaintProperty("fill-outline-color") ? "fillOutlinePattern" : "fillOutline"), r } getProgramConfiguration(t) { return new po(this, t) } recalculate(t, e) { super.recalculate(t, e); const r = this.paint._values["fill-outline-color"]; "constant" === r.value.kind && void 0 === r.value.value && (this.paint._values["fill-outline-color"] = this.paint._values["fill-color"]); } createBucket(t) { return new $c(t) } queryRadius() { return Ru(this.paint.get("fill-translate")) } queryIntersectsFeature(t, e, r, n, i, s) { return !t.queryGeometry.isAboveHorizon && Mu(ju(t.tilespaceGeometry, this.paint.get("fill-translate"), this.paint.get("fill-translate-anchor"), s.angle, t.pixelToTileUnitsFactor), n) } isTileClipped() { return !0 } }, "fill-extrusion": class extends wo { constructor(t) { super(t, Ah); } createBucket(t) { return new fh(t) } queryRadius() { return Ru(this.paint.get("fill-extrusion-translate")) } is3D() { return !0 } getProgramIds() { return [this.paint.get("fill-extrusion-pattern").constantOr(1) ? "fillExtrusionPattern" : "fillExtrusion"] } getProgramConfiguration(t) { return new po(this, t) } queryIntersectsFeature(t, e, r, n, i, s, a, o, l) { const u = $u(this.paint.get("fill-extrusion-translate"), this.paint.get("fill-extrusion-translate-anchor"), s.angle, t.pixelToTileUnitsFactor), c = this.paint.get("fill-extrusion-height").evaluate(e, r), h = this.paint.get("fill-extrusion-base").evaluate(e, r), p = [0, 0], f = o && s.elevation, y = s.elevation ? s.elevation.exaggeration() : 1, m = t.tile.getBucket(this); if (f && m instanceof fh) { const t = m.centroidVertexArray, e = l + 1; e < t.length && (p[0] = t.geta_centroid_pos0(e), p[1] = t.geta_centroid_pos1(e)); } if (0 === p[0] && 1 === p[1]) return !1; "globe" === s.projection.name && (n = wh([n], [new d(0, 0), new d(ko, ko)], t.tileID.canonical).map((t => t.polygon)).flat()); const g = f ? o : null, [x, v] = function(t, e, r, n, i, s, a, o, l, u, c) { return "globe" === t.projection.name ? function(t, e, r, n, i, s, a, o, l, u, c) { const h = [], p = [], f = t.projection.upVectorScale(c, t.center.lat, t.worldSize).metersToTile, d = [0, 0, 0, 1], y = [0, 0, 0, 1], m = (t, e, r, n) => { t[0] = e, t[1] = r, t[2] = n, t[3] = 1; }, g = bh(); r > 0 && (r += g), n += g; for (const g of e) { const e = [], x = []; for (const h of g) { const p = h.x + i.x, g = h.y + i.y, v = t.projection.projectTilePoint(p, g, c), b = t.projection.upVector(c, h.x, h.y); let w = r, _ = n; if (a) { const t = Ch(p, g, r, n, a, o, l, u); w += t.base, _ += t.top; } 0 !== r ? m(d, v.x + b[0] * f * w, v.y + b[1] * f * w, v.z + b[2] * f * w) : m(d, v.x, v.y, v.z), m(y, v.x + b[0] * f * _, v.y + b[1] * f * _, v.z + b[2] * f * _), el(d, d, s), el(y, y, s), e.push(new zh(d[0], d[1], d[2])), x.push(new zh(y[0], y[1], y[2])); } h.push(e), p.push(x); } return [h, p] }(t, e, r, n, i, s, a, o, l, u, c) : a ? function(t, e, r, n, i, s, a, o, l) { const u = [], c = [], h = [0, 0, 0, 1]; for (const p of t) { const t = [], f = []; for (const u of p) { const c = u.x + n.x, p = u.y + n.y, d = Ch(c, p, e, r, s, a, o, l); h[0] = c, h[1] = p, h[2] = d.base, h[3] = 1, ul(h, h, i), h[3] = Math.max(h[3], 1e-5); const y = new zh(h[0] / h[3], h[1] / h[3], h[2] / h[3]); h[0] = c, h[1] = p, h[2] = d.top, h[3] = 1, ul(h, h, i), h[3] = Math.max(h[3], 1e-5); const m = new zh(h[0] / h[3], h[1] / h[3], h[2] / h[3]); t.push(y), f.push(m); } u.push(t), c.push(f); } return [u, c] }(e, r, n, i, s, a, o, l, u) : function(t, e, r, n, i) { const s = [], a = [], o = i[8] * e, l = i[9] * e, u = i[10] * e, c = i[11] * e, h = i[8] * r, p = i[9] * r, f = i[10] * r, d = i[11] * r; for (const e of t) { const t = [], r = []; for (const s of e) { const e = s.x + n.x, a = s.y + n.y, y = i[0] * e + i[4] * a + i[12], m = i[1] * e + i[5] * a + i[13], g = i[2] * e + i[6] * a + i[14], x = i[3] * e + i[7] * a + i[15], v = y + o, b = m + l, w = g + u, _ = Math.max(x + c, 1e-5), A = y + h, S = m + p, k = g + f, I = Math.max(x + d, 1e-5); t.push(new zh(v / _, b / _, w / _)), r.push(new zh(A / I, S / I, k / I)); } s.push(t), a.push(r); } return [s, a] }(e, r, n, i, s) }(s, n, h, c, u, a, g, p, y, s.center.lat, t.tileID.canonical), b = t.queryGeometry; return function(t, e, r) { let n = 1 / 0; Mu(r, e) && (n = Eh(r, e[0])); for (let i = 0; i < e.length; i++) { const s = e[i], a = t[i]; for (let t = 0; t < s.length - 1; t++) { const e = s[t], i = [e, s[t + 1], a[t + 1], a[t], e]; ku(r, i) && (n = Math.min(n, Eh(r, i))); } } return n !== 1 / 0 && n }(x, v, b.isPointQuery() ? b.screenBounds : b.screenGeometry) } }, line: class extends wo { constructor(t) { super(t, Uh), this.gradientVersion = 0; } _handleSpecialPaintPropertyUpdate(t) { if ("line-gradient" === t) { const t = this._transitionablePaint._values["line-gradient"].value.expression; this.stepInterpolant = t._styleExpression && t._styleExpression.expression instanceof Ir, this.gradientVersion = (this.gradientVersion + 1) % Number.MAX_SAFE_INTEGER; } } gradientExpression() { return this._transitionablePaint._values["line-gradient"].value.expression } widthExpression() { return this._transitionablePaint._values["line-width"].value.expression } recalculate(t, e) { super.recalculate(t, e), this.paint._values["line-floorwidth"] = Oh.possiblyEvaluate(this._transitioningPaint._values["line-width"].value, t); } createBucket(t) { return new jh(t) } getProgramIds() { return [this.paint.get("line-pattern").constantOr(1) ? "linePattern" : "line"] } getProgramConfiguration(t) { return new po(this, t) } queryRadius(t) { const e = t, r = qh(Fu("line-width", this, e), Fu("line-gap-width", this, e)), n = Fu("line-offset", this, e); return r / 2 + Math.abs(n) + Ru(this.paint.get("line-translate")) } queryIntersectsFeature(t, e, r, n, i, s) { if (t.queryGeometry.isAboveHorizon) return !1; const a = ju(t.tilespaceGeometry, this.paint.get("line-translate"), this.paint.get("line-translate-anchor"), s.angle, t.pixelToTileUnitsFactor), o = t.pixelToTileUnitsFactor / 2 * qh(this.paint.get("line-width").evaluate(e, r), this.paint.get("line-gap-width").evaluate(e, r)), l = this.paint.get("line-offset").evaluate(e, r); return l && (n = function(t, e) { const r = [], n = new d(0, 0); for (let i = 0; i < t.length; i++) { const s = t[i], a = []; for (let t = 0; t < s.length; t++) { const r = s[t - 1], i = s[t], o = s[t + 1], l = 0 === t ? n : i.sub(r)._unit()._perp(), u = t === s.length - 1 ? n : o.sub(i)._unit()._perp(), c = l._add(u)._unit(); c._mult(1 / (c.x * u.x + c.y * u.y)), a.push(c._mult(e)._add(i)); } r.push(a); } return r }(n, l * t.pixelToTileUnitsFactor)), function(t, e, r) { for (let n = 0; n < e.length; n++) { const i = e[n]; if (t.length >= 3) for (let e = 0; e < i.length; e++) if (Du(t, i[e])) return !0; if (Tu(t, i, r)) return !0 } return !1 }(a, n, o) } isTileClipped() { return !0 } }, symbol: yd, background: class extends wo { constructor(t) { super(t, md); } getProgramIds() { return [this.paint.get("background-pattern") ? "backgroundPattern" : "background"] } }, raster: class extends wo { constructor(t) { super(t, gd); } getProgramIds() { return ["raster"] } }, sky: class extends wo { constructor(t) { super(t, vd), this._updateColorRamp(); } _handleSpecialPaintPropertyUpdate(t) { "sky-gradient" === t ? this._updateColorRamp() : "sky-atmosphere-sun" !== t && "sky-atmosphere-halo-color" !== t && "sky-atmosphere-color" !== t && "sky-atmosphere-sun-intensity" !== t || (this._skyboxInvalidated = !0); } _updateColorRamp() { this.colorRamp = ec({ expression: this._transitionablePaint._values["sky-gradient"].value.expression, evaluationKey: "skyRadialProgress" }), this.colorRampTexture && (this.colorRampTexture.destroy(), this.colorRampTexture = null); } needsSkyboxCapture(t) { if (this._skyboxInvalidated || !this.skyboxTexture || !this.skyboxGeometry) return !0; if (!this.paint.get("sky-atmosphere-sun")) { const e = t.style.light.properties.get("position"); return this._lightPosition.azimuthal !== e.azimuthal || this._lightPosition.polar !== e.polar } return !1 } getCenter(t, e) { if ("atmosphere" === this.paint.get("sky-type")) { const r = this.paint.get("sky-atmosphere-sun"), n = !r, i = t.style.light, s = i.properties.get("position"); return n && "viewport" === i.properties.get("anchor") && U("The sun direction is attached to a light with viewport anchor, lighting may behave unexpectedly."), n ? bd(s.azimuthal, 90 - s.polar, e) : bd(r[0], 90 - r[1], e) } const r = this.paint.get("sky-gradient-center"); return bd(r[0], 90 - r[1], e) } is3D() { return !1 } isSky() { return !0 } markSkyboxValid(t) { this._skyboxInvalidated = !1, this._lightPosition = t.style.light.properties.get("position"); } hasOffscreenPass() { return !0 } getProgramIds() { const t = this.paint.get("sky-type"); return "atmosphere" === t ? ["skyboxCapture", "skybox"] : "gradient" === t ? ["skyboxGradient"] : null } } }; class _d { constructor(t, e, r, n) { this.context = t, this.format = r, this.texture = t.gl.createTexture(), this.update(e, n); } update(t, r, n) { const { width: i, height: s } = t, { context: a } = this, { gl: o } = a, { HTMLImageElement: l, HTMLCanvasElement: u, HTMLVideoElement: c, ImageData: h, ImageBitmap: p } = e; if (o.bindTexture(o.TEXTURE_2D, this.texture), a.pixelStoreUnpackFlipY.set(!1), a.pixelStoreUnpack.set(1), a.pixelStoreUnpackPremultiplyAlpha.set(this.format === o.RGBA && (!r || !1 !== r.premultiply)), n || this.size && this.size[0] === i && this.size[1] === s) { const { x: e, y: r } = n || { x: 0, y: 0 }; t instanceof l || t instanceof u || t instanceof c || t instanceof h || p && t instanceof p ? o.texSubImage2D(o.TEXTURE_2D, 0, e, r, o.RGBA, o.UNSIGNED_BYTE, t) : o.texSubImage2D(o.TEXTURE_2D, 0, e, r, i, s, o.RGBA, o.UNSIGNED_BYTE, t.data); } else this.size = [i, s], t instanceof l || t instanceof u || t instanceof c || t instanceof h || p && t instanceof p ? o.texImage2D(o.TEXTURE_2D, 0, this.format, this.format, o.UNSIGNED_BYTE, t) : o.texImage2D(o.TEXTURE_2D, 0, this.format, i, s, 0, this.format, o.UNSIGNED_BYTE, t.data); this.useMipmap = Boolean(r && r.useMipmap && this.isSizePowerOfTwo()), this.useMipmap && o.generateMipmap(o.TEXTURE_2D); } bind(t, e) { const { context: r } = this, { gl: n } = r; n.bindTexture(n.TEXTURE_2D, this.texture), t !== this.filter && (n.texParameteri(n.TEXTURE_2D, n.TEXTURE_MAG_FILTER, t), n.texParameteri(n.TEXTURE_2D, n.TEXTURE_MIN_FILTER, this.useMipmap ? t === n.NEAREST ? n.NEAREST_MIPMAP_NEAREST : n.LINEAR_MIPMAP_NEAREST : t), this.filter = t), e !== this.wrap && (n.texParameteri(n.TEXTURE_2D, n.TEXTURE_WRAP_S, e), n.texParameteri(n.TEXTURE_2D, n.TEXTURE_WRAP_T, e), this.wrap = e); } isSizePowerOfTwo() { return this.size[0] === this.size[1] && Math.log(this.size[0]) / Math.LN2 % 1 == 0 } destroy() { const { gl: t } = this.context; t.deleteTexture(this.texture), this.texture = null; } } class Ad { constructor(t) { this._callback = t, this._triggered = !1, "undefined" != typeof MessageChannel && (this._channel = new MessageChannel, this._channel.port2.onmessage = () => { this._triggered = !1, this._callback(); }); } trigger() { this._triggered || (this._triggered = !0, this._channel ? this._channel.port1.postMessage(!0) : setTimeout((() => { this._triggered = !1, this._callback(); }), 0)); } remove() { this._channel = void 0, this._callback = () => {}; } } class Sd { constructor() { this.tasks = {}, this.taskQueue = [], V(["process"], this), this.invoker = new Ad(this.process), this.nextId = 0; } add(t, e) { const r = this.nextId++, n = function({ type: t, isSymbolTile: e, zoom: r }) { return r = r || 0, "message" === t ? 0 : "maybePrepare" !== t || e ? "parseTile" !== t || e ? "parseTile" === t && e ? 300 - r : "maybePrepare" === t && e ? 400 - r : 500 : 200 - r : 100 - r }(e); if (0 === n) { N(); try { t(); } finally {} return { cancel: () => {} } } return this.tasks[r] = { fn: t, metadata: e, priority: n, id: r }, this.taskQueue.push(r), this.invoker.trigger(), { cancel: () => { delete this.tasks[r]; } } } process() { N(); try { if (this.taskQueue = this.taskQueue.filter((t => !!this.tasks[t])), !this.taskQueue.length) return; const t = this.pick(); if (null === t) return; const e = this.tasks[t]; if (delete this.tasks[t], this.taskQueue.length && this.invoker.trigger(), !e) return; e.fn(); } finally {} } pick() { let t = null, e = 1 / 0; for (let r = 0; r < this.taskQueue.length; r++) { const n = this.tasks[this.taskQueue[r]]; n.priority < e && (e = n.priority, t = r); } if (null === t) return null; const r = this.taskQueue[t]; return this.taskQueue.splice(t, 1), r } remove() { this.invoker.remove(); } } class kd { constructor(t) { this._stringToNumber = {}, this._numberToString = []; for (let e = 0; e < t.length; e++) { const r = t[e]; this._stringToNumber[r] = e, this._numberToString[e] = r; } } encode(t) { return this._stringToNumber[t] } decode(t) { return this._numberToString[t] } } const Id = ["tile", "layer", "source", "sourceLayer", "state"]; class Md { constructor(t, e, r, n, i) { this.type = "Feature", this._vectorTileFeature = t, this._z = e, this._x = r, this._y = n, this.properties = t.properties, this.id = i; } get geometry() { return void 0 === this._geometry && (this._geometry = this._vectorTileFeature.toGeoJSON(this._x, this._y, this._z).geometry), this._geometry } set geometry(t) { this._geometry = t; } toJSON() { const t = { type: "Feature", state: void 0, geometry: this.geometry, properties: this.properties }; void 0 !== this.id && (t.id = this.id); for (const e of Id) void 0 !== this[e] && (t[e] = this[e]); return t } } const Td = 32, zd = 33, Bd = new Uint16Array(8184); for (let t = 0; t < 2046; t++) { let e = t + 2, r = 0, n = 0, i = 0, s = 0, a = 0, o = 0; for (1 & e ? i = s = a = Td : r = n = o = Td; (e >>= 1) > 1;) { const t = r + i >> 1, l = n + s >> 1; 1 & e ? (i = r, s = n, r = a, n = o) : (r = i, n = s, i = a, s = o), a = t, o = l; } const l = 4 * t; Bd[l + 0] = r, Bd[l + 1] = n, Bd[l + 2] = i, Bd[l + 3] = s; } const Ed = new Uint16Array(2178), Cd = new Uint8Array(1089), Pd = new Uint16Array(1089); function Dd(t) { return 0 === t ? -.03125 : 32 === t ? .03125 : 0 } var Vd = na([{ name: "a_pos", type: "Int16", components: 2 }, { name: "a_texture_pos", type: "Int16", components: 2 }]); const Ld = { type: 2, extent: ko, loadGeometry: () => [ [new d(0, 0), new d(8193, 0), new d(8193, 8193), new d(0, 8193), new d(0, 0)] ] }; class Fd { constructor(t, e, r, n, i) { this.tileID = t, this.uid = E(), this.uses = 0, this.tileSize = e, this.tileZoom = r, this.buckets = {}, this.expirationTime = null, this.queryPadding = 0, this.hasSymbolBuckets = !1, this.hasRTLText = !1, this.dependencies = {}, this.isRaster = i, this.expiredRequestCount = 0, this.state = "loading", n && n.transform && (this.projection = n.transform.projection); } registerFadeDuration(t) { const e = t + this.timeAdded; e < Nt.now() || this.fadeEndTime && e < this.fadeEndTime || (this.fadeEndTime = e); } wasRequested() { return "errored" === this.state || "loaded" === this.state || "reloading" === this.state } get tileTransform() { return this._tileTransform || (this._tileTransform = Vf(this.tileID.canonical, this.projection)), this._tileTransform } loadVectorData(t, e, r) { if (this.unloadVectorData(), this.state = "loaded", t) { t.featureIndex && (this.latestFeatureIndex = t.featureIndex, t.rawTileData ? (this.latestRawTileData = t.rawTileData, this.latestFeatureIndex.rawTileData = t.rawTileData) : this.latestRawTileData && (this.latestFeatureIndex.rawTileData = this.latestRawTileData)), this.collisionBoxArray = t.collisionBoxArray, this.buckets = function(t, e) { const r = {}; if (!e) return r; for (const n of t) { const t = n.layerIds.map((t => e.getLayer(t))).filter(Boolean); if (0 !== t.length) { n.layers = t, n.stateDependentLayerIds && (n.stateDependentLayers = n.stateDependentLayerIds.map((e => t.filter((t => t.id === e))[0]))); for (const e of t) r[e.id] = n; } } return r }(t.buckets, e.style), this.hasSymbolBuckets = !1; for (const t in this.buckets) { const e = this.buckets[t]; if (e instanceof hd) { if (this.hasSymbolBuckets = !0, !r) break; e.justReloaded = !0; } } if (this.hasRTLText = !1, this.hasSymbolBuckets) for (const t in this.buckets) { const e = this.buckets[t]; if (e instanceof hd && e.hasRTLText) { this.hasRTLText = !0, js.isLoading() || js.isLoaded() || "deferred" !== Fs() || Rs(); break } } this.queryPadding = 0; for (const t in this.buckets) { const r = this.buckets[t]; this.queryPadding = Math.max(this.queryPadding, e.style.getLayer(t).queryRadius(r)); } t.imageAtlas && (this.imageAtlas = t.imageAtlas), t.glyphAtlasImage && (this.glyphAtlasImage = t.glyphAtlasImage), t.lineAtlas && (this.lineAtlas = t.lineAtlas); } else this.collisionBoxArray = new Ea; } unloadVectorData() { if (this.hasData()) { for (const t in this.buckets) this.buckets[t].destroy(); this.buckets = {}, this.imageAtlas && (this.imageAtlas = null), this.lineAtlas && (this.lineAtlas = null), this.imageAtlasTexture && this.imageAtlasTexture.destroy(), this.glyphAtlasTexture && this.glyphAtlasTexture.destroy(), this.lineAtlasTexture && this.lineAtlasTexture.destroy(), this._tileBoundsBuffer && (this._tileBoundsBuffer.destroy(), this._tileBoundsIndexBuffer.destroy(), this._tileBoundsSegments.destroy(), this._tileBoundsBuffer = null), this._tileDebugBuffer && (this._tileDebugBuffer.destroy(), this._tileDebugSegments.destroy(), this._tileDebugBuffer = null), this._tileDebugIndexBuffer && (this._tileDebugIndexBuffer.destroy(), this._tileDebugIndexBuffer = null), this._globeTileDebugBorderBuffer && (this._globeTileDebugBorderBuffer.destroy(), this._globeTileDebugBorderBuffer = null), this._tileDebugTextBuffer && (this._tileDebugTextBuffer.destroy(), this._tileDebugTextSegments.destroy(), this._tileDebugTextIndexBuffer.destroy(), this._tileDebugTextBuffer = null), this._globeTileDebugTextBuffer && (this._globeTileDebugTextBuffer.destroy(), this._globeTileDebugTextBuffer = null), this.latestFeatureIndex = null, this.state = "unloaded"; } } getBucket(t) { return this.buckets[t.id] } upload(t) { for (const e in this.buckets) { const r = this.buckets[e]; r.uploadPending() && r.upload(t); } const e = t.gl; this.imageAtlas && !this.imageAtlas.uploaded && (this.imageAtlasTexture = new _d(t, this.imageAtlas.image, e.RGBA), this.imageAtlas.uploaded = !0), this.glyphAtlasImage && (this.glyphAtlasTexture = new _d(t, this.glyphAtlasImage, e.ALPHA), this.glyphAtlasImage = null), this.lineAtlas && !this.lineAtlas.uploaded && (this.lineAtlasTexture = new _d(t, this.lineAtlas.image, e.ALPHA), this.lineAtlas.uploaded = !0); } prepare(t) { this.imageAtlas && this.imageAtlas.patchUpdatedImages(t, this.imageAtlasTexture); } queryRenderedFeatures(t, e, r, n, i, s, a, o) { return this.latestFeatureIndex && this.latestFeatureIndex.rawTileData ? this.latestFeatureIndex.query({ tileResult: n, pixelPosMatrix: a, transform: s, params: i, tileTransform: this.tileTransform }, t, e, r) : {} } querySourceFeatures(t, e) { const r = this.latestFeatureIndex; if (!r || !r.rawTileData) return; const n = r.loadVTLayers(), i = e ? e.sourceLayer : "", s = n._geojsonTileLayer || n[i]; if (!s) return; const a = ai(e && e.filter), { z: o, x: l, y: u } = this.tileID.canonical, c = { z: o, x: l, y: u }; for (let e = 0; e < s.length; e++) { const n = s.feature(e); if (a.needGeometry) { const t = wu(n, !0); if (!a.filter(new $s(this.tileID.overscaledZ), t, this.tileID.canonical)) continue } else if (!a.filter(new $s(this.tileID.overscaledZ), n)) continue; const h = r.getId(n, i), p = new Md(n, o, l, u, h); p.tile = c, t.push(p); } } hasData() { return "loaded" === this.state || "reloading" === this.state || "expired" === this.state } patternsLoaded() { return !!this.imageAtlas && !!Object.keys(this.imageAtlas.patternPositions).length } setExpiryData(t) { const e = this.expirationTime; if (t.cacheControl) { const e = G(t.cacheControl); e["max-age"] && (this.expirationTime = Date.now() + 1e3 * e["max-age"]); } else t.expires && (this.expirationTime = new Date(t.expires).getTime()); if (this.expirationTime) { const t = Date.now(); let r = !1; if (this.expirationTime > t) r = !1; else if (e) if (this.expirationTime < e) r = !0; else { const n = this.expirationTime - e; n ? this.expirationTime = t + Math.max(n, 3e4) : r = !0; } else r = !0; r ? (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 - (new Date).getTime(), Math.pow(2, 31) - 1) } setFeatureState(t, e) { if (!this.latestFeatureIndex || !this.latestFeatureIndex.rawTileData || 0 === Object.keys(t).length || !e) return; const r = this.latestFeatureIndex.loadVTLayers(), n = e.style.listImages(); for (const i in this.buckets) { if (!e.style.hasLayer(i)) continue; const s = this.buckets[i], a = s.layers[0].sourceLayer || "_geojsonTileLayer", o = r[a], l = t[a]; if (!o || !l || 0 === Object.keys(l).length) continue; if (s.update(l, o, n, this.imageAtlas && this.imageAtlas.patternPositions || {}), s instanceof jh || s instanceof $c) { const t = e.style._getSourceCache(s.layers[0].source); e._terrain && e._terrain.enabled && t && s.programConfigurations.needsUpload && e._terrain._clearRenderCacheForTile(t.id, this.tileID); } const u = e && e.style && e.style.getLayer(i); u && (this.queryPadding = Math.max(this.queryPadding, u.queryRadius(s))); } } holdingForFade() { return void 0 !== this.symbolFadeHoldUntil } symbolFadeFinished() { return !this.symbolFadeHoldUntil || this.symbolFadeHoldUntil < Nt.now() } clearFadeHold() { this.symbolFadeHoldUntil = void 0; } setHoldDuration(t) { this.symbolFadeHoldUntil = Nt.now() + t; } setTexture(t, e) { const r = e.context, n = r.gl; this.texture = this.texture || e.getTileTexture(t.width), this.texture ? this.texture.update(t, { useMipmap: !0 }) : (this.texture = new _d(r, t, n.RGBA, { useMipmap: !0 }), this.texture.bind(n.LINEAR, n.CLAMP_TO_EDGE)); } setDependencies(t, e) { const r = {}; for (const t of e) r[t] = !0; this.dependencies[t] = r; } hasDependency(t, e) { for (const r of t) { const t = this.dependencies[r]; if (t) for (const r of e) if (t[r]) return !0 } return !1 } clearQueryDebugViz() {} _makeDebugTileBoundsBuffers(t, e) { if (!e || "mercator" === e.name || this._tileDebugBuffer) return; const r = bu(Ld, this.tileID.canonical, this.tileTransform)[0], n = new sa, i = new Ta; for (let t = 0; t < r.length; t++) { const { x: e, y: s } = r[t]; n.emplaceBack(e, s), i.emplaceBack(t); } i.emplaceBack(0), this._tileDebugIndexBuffer = t.createIndexBuffer(i), this._tileDebugBuffer = t.createVertexBuffer(n, xl.members), this._tileDebugSegments = So.simpleSegment(0, 0, n.length, i.length); } _makeTileBoundsBuffers(t, e) { if (this._tileBoundsBuffer || !e || "mercator" === e.name) return; const r = bu(Ld, this.tileID.canonical, this.tileTransform)[0]; let n, i; if (this.isRaster) { const t = function(t, e) { const r = Vf(t, e), n = Math.pow(2, t.z); for (let i = 0; i < zd; i++) for (let s = 0; s < zd; s++) { const a = ou((t.x + (s + Dd(s)) / Td) / n), o = lu((t.y + (i + Dd(i)) / Td) / n), l = e.project(a, o), u = i * zd + s; Ed[2 * u + 0] = Math.round((l.x * r.scale - r.x) * ko), Ed[2 * u + 1] = Math.round((l.y * r.scale - r.y) * ko); } Cd.fill(0), Pd.fill(0); for (let t = 2045; t >= 0; t--) { const e = 4 * t, r = Bd[e + 0], n = Bd[e + 1], i = Bd[e + 2], s = Bd[e + 3], a = r + i >> 1, o = n + s >> 1, l = a + o - n, u = o + r - a, c = n * zd + r, h = s * zd + i, p = o * zd + a, f = Math.hypot((Ed[2 * c + 0] + Ed[2 * h + 0]) / 2 - Ed[2 * p + 0], (Ed[2 * c + 1] + Ed[2 * h + 1]) / 2 - Ed[2 * p + 1]) >= 16; if (Cd[p] = Cd[p] || (f ? 1 : 0), t < 1022) { const t = (n + u >> 1) * zd + (r + l >> 1), e = (s + u >> 1) * zd + (i + l >> 1); Cd[p] = Cd[p] || Cd[t] || Cd[e]; } } const i = new oa, s = new wa; let a = 0; function o(t, e) { const r = e * zd + t; return 0 === Pd[r] && (i.emplaceBack(Ed[2 * r + 0], Ed[2 * r + 1], t * ko / Td, e * ko / Td), Pd[r] = ++a), Pd[r] - 1 } function l(t, e, r, n, i, a) { const u = t + r >> 1, c = e + n >> 1; if (Math.abs(t - i) + Math.abs(e - a) > 1 && Cd[c * zd + u]) l(i, a, t, e, u, c), l(r, n, i, a, u, c); else { const l = o(t, e), u = o(r, n), c = o(i, a); s.emplaceBack(l, u, c); } } return l(0, 0, Td, Td, Td, 0), l(Td, Td, 0, 0, 0, Td), { vertices: i, indices: s } }(this.tileID.canonical, e); n = t.vertices, i = t.indices; } else { n = new oa, i = new wa; for (const { x: t, y: e } of r) n.emplaceBack(t, e, 0, 0); const t = sc(n.int16, void 0, 4); for (let e = 0; e < t.length; e += 3) i.emplaceBack(t[e], t[e + 1], t[e + 2]); } this._tileBoundsBuffer = t.createVertexBuffer(n, Vd.members), this._tileBoundsIndexBuffer = t.createIndexBuffer(i), this._tileBoundsSegments = So.simpleSegment(0, 0, n.length, i.length); } _makeGlobeTileDebugBuffers(t, e) { const r = e.projection; if (!r || "globe" !== r.name || e.freezeTileCoverage) return; const n = this.tileID.canonical, i = Gl(Vl(n, e)), s = Kl(e.zoom); let a; s > 0 && (a = Co(new Float64Array(16), e.globeMatrix)), this._makeGlobeTileDebugBorderBuffer(t, n, e, i, a, s), this._makeGlobeTileDebugTextBuffer(t, n, e, i, a, s); } _globePoint(t, e, r, n, i, s, a) { let o = Ol(t, e, r); if (s) { const i = 1 << r.z, l = iu(n.center.lng), u = su(n.center.lat), c = (r.x + .5) / i - l; let h = 0; c > .5 ? h = -1 : c < -.5 && (h = 1); let p = (t / ko + r.x) / i + h, f = (e / ko + r.y) / i; p = (p - l) * n._pixelsPerMercatorPixel + l, f = (f - u) * n._pixelsPerMercatorPixel + u; const d = [p * n.worldSize, f * n.worldSize, 0]; el(d, d, s), o = Dl(o, d, a); } return el(o, o, i) } _makeGlobeTileDebugBorderBuffer(t, e, r, n, i, s) { const a = new sa, o = new Ta, l = new aa, u = (t, u, c, h, p) => { const f = (c - t) / (p - 1), d = (h - u) / (p - 1), y = a.length; for (let c = 0; c < p; c++) { const h = t + c * f, p = u + c * d; a.emplaceBack(h, p); const m = this._globePoint(h, p, e, r, n, i, s); l.emplaceBack(m[0], m[1], m[2]), o.emplaceBack(y + c); } }, c = ko; u(0, 0, c, 0, 16), u(c, 0, c, c, 16), u(c, c, 0, c, 16), u(0, c, 0, 0, 16), this._tileDebugIndexBuffer = t.createIndexBuffer(o), this._tileDebugBuffer = t.createVertexBuffer(a, xl.members), this._globeTileDebugBorderBuffer = t.createVertexBuffer(l, gl.members), this._tileDebugSegments = So.simpleSegment(0, 0, a.length, o.length); } _makeGlobeTileDebugTextBuffer(t, e, r, n, i, s) { const a = new sa, o = new wa, l = new aa, u = 25; o.reserve(32), a.reserve(u), l.reserve(u); const c = (t, e) => u * t + e; for (let t = 0; t < u; t++) { const o = 2048 * t; for (let t = 0; t < u; t++) { const u = 2048 * t; a.emplaceBack(u, o); const c = this._globePoint(u, o, e, r, n, i, s); l.emplaceBack(c[0], c[1], c[2]); } } for (let t = 0; t < 4; t++) for (let e = 0; e < 4; e++) { const r = c(t, e), n = c(t, e + 1), i = c(t + 1, e), s = c(t + 1, e + 1); o.emplaceBack(r, n, i), o.emplaceBack(i, n, s); } this._tileDebugTextIndexBuffer = t.createIndexBuffer(o), this._tileDebugTextBuffer = t.createVertexBuffer(a, xl.members), this._globeTileDebugTextBuffer = t.createVertexBuffer(l, gl.members), this._tileDebugTextSegments = So.simpleSegment(0, 0, u, 32); } } class Rd { constructor() { this.state = {}, this.stateChanges = {}, this.deletedStates = {}; } updateState(t, e, r) { const n = String(e); if (this.stateChanges[t] = this.stateChanges[t] || {}, this.stateChanges[t][n] = this.stateChanges[t][n] || {}, z(this.stateChanges[t][n], r), null === this.deletedStates[t]) { this.deletedStates[t] = {}; for (const e in this.state[t]) e !== n && (this.deletedStates[t][e] = null); } else if (this.deletedStates[t] && null === this.deletedStates[t][n]) { this.deletedStates[t][n] = {}; for (const e in this.state[t][n]) r[e] || (this.deletedStates[t][n][e] = null); } else for (const e in r) this.deletedStates[t] && this.deletedStates[t][n] && null === this.deletedStates[t][n][e] && delete this.deletedStates[t][n][e]; } removeFeatureState(t, e, r) { if (null === this.deletedStates[t]) return; const n = String(e); if (this.deletedStates[t] = this.deletedStates[t] || {}, r && void 0 !== e) null !== this.deletedStates[t][n] && (this.deletedStates[t][n] = this.deletedStates[t][n] || {}, this.deletedStates[t][n][r] = null); else if (void 0 !== e) if (this.stateChanges[t] && this.stateChanges[t][n]) for (r in this.deletedStates[t][n] = {}, this.stateChanges[t][n]) this.deletedStates[t][n][r] = null; else this.deletedStates[t][n] = null; else this.deletedStates[t] = null; } getState(t, e) { const r = String(e), n = z({}, (this.state[t] || {})[r], (this.stateChanges[t] || {})[r]); if (null === this.deletedStates[t]) return {}; if (this.deletedStates[t]) { const r = this.deletedStates[t][e]; if (null === r) return {}; for (const t in r) delete n[t]; } return n } initializeTileState(t, e) { t.setFeatureState(this.state, e); } coalesceChanges(t, e) { const r = {}; for (const t in this.stateChanges) { this.state[t] = this.state[t] || {}; const e = {}; for (const r in this.stateChanges[t]) this.state[t][r] || (this.state[t][r] = {}), z(this.state[t][r], this.stateChanges[t][r]), e[r] = this.state[t][r]; r[t] = e; } for (const t in this.deletedStates) { this.state[t] = this.state[t] || {}; const e = {}; if (null === this.deletedStates[t]) for (const r in this.state[t]) e[r] = {}, this.state[t][r] = {}; else for (const r in this.deletedStates[t]) { if (null === this.deletedStates[t][r]) this.state[t][r] = {}; else if (this.state[t][r]) for (const e of Object.keys(this.deletedStates[t][r])) delete this.state[t][r][e]; e[r] = this.state[t][r]; } r[t] = r[t] || {}, z(r[t], e); } if (this.stateChanges = {}, this.deletedStates = {}, 0 !== Object.keys(r).length) for (const n in t) t[n].setFeatureState(r, e); } } class jd { constructor(t) { this.size = t, this.minimums = [], this.maximums = [], this.leaves = []; } getElevation(t, e) { const r = this.toIdx(t, e); return { min: this.minimums[r], max: this.maximums[r] } } isLeaf(t, e) { return this.leaves[this.toIdx(t, e)] } toIdx(t, e) { return e * this.size + t } } function $d(t, e, r, n) { let i = 0, s = Number.MAX_VALUE; for (let a = 0; a < 3; a++) if (Math.abs(n[a]) < 1e-15) { if (r[a] < t[a] || r[a] > e[a]) return null } else { const o = 1 / n[a]; let l = (t[a] - r[a]) * o, u = (e[a] - r[a]) * o; if (l > u) { const t = l; l = u, u = t; } if (l > i && (i = l), u < s && (s = u), i > s) return null } return i } function Ud(t, e, r, n, i, s, a, o, l, u, c) { const h = n - t, p = i - e, f = s - r, d = a - t, y = o - e, m = l - r, g = c[1] * m - c[2] * y, x = c[2] * d - c[0] * m, v = c[0] * y - c[1] * d, b = h * g + p * x + f * v; if (Math.abs(b) < 1e-15) return null; const w = 1 / b, _ = u[0] - t, A = u[1] - e, S = u[2] - r, k = (_ * g + A * x + S * v) * w; if (k < 0 || k > 1) return null; const I = A * f - S * p, M = S * h - _ * f, T = _ * p - A * h, z = (c[0] * I + c[1] * M + c[2] * T) * w; return z < 0 || k + z > 1 ? null : (d * I + y * M + m * T) * w } function Od(t, e, r) { return (t - e) / (r - e) } function qd(t, e, r, n, i, s, a, o, l) { const u = 1 << r, c = s - n, h = a - i, p = (t + 1) / u * c + n, f = (e + 0) / u * h + i, d = (e + 1) / u * h + i; o[0] = (t + 0) / u * c + n, o[1] = f, l[0] = p, l[1] = d; } class Nd { constructor(t) { if (this.maximums = [], this.minimums = [], this.leaves = [], this.childOffsets = [], this.nodeCount = 0, this.dem = t, this._siblingOffset = [ [0, 0], [1, 0], [0, 1], [1, 1] ], !this.dem) return; const e = function(t) { const e = Math.ceil(Math.log2(t.dim / 8)), r = []; let n = Math.ceil(Math.pow(2, e)); const i = 1 / n, s = (t, e, r, n, i) => { const s = n ? 1 : 0, a = (t + 1) * r - s, o = e * r, l = (e + 1) * r - s; i[0] = t * r, i[1] = o, i[2] = a, i[3] = l; }; let a = new jd(n); const o = []; for (let e = 0; e < n * n; e++) { s(e % n, Math.floor(e / n), i, !1, o); const r = Zd(o[0], o[1], t), l = Zd(o[2], o[1], t), u = Zd(o[2], o[3], t), c = Zd(o[0], o[3], t); a.minimums.push(Math.min(r, l, u, c)), a.maximums.push(Math.max(r, l, u, c)), a.leaves.push(1); } for (r.push(a), n /= 2; n >= 1; n /= 2) { const t = r[r.length - 1]; a = new jd(n); for (let e = 0; e < n * n; e++) { s(e % n, Math.floor(e / n), 2, !0, o); const r = t.getElevation(o[0], o[1]), i = t.getElevation(o[2], o[1]), l = t.getElevation(o[2], o[3]), u = t.getElevation(o[0], o[3]), c = t.isLeaf(o[0], o[1]), h = t.isLeaf(o[2], o[1]), p = t.isLeaf(o[2], o[3]), f = t.isLeaf(o[0], o[3]), d = Math.min(r.min, i.min, l.min, u.min), y = Math.max(r.max, i.max, l.max, u.max), m = c && h && p && f; a.maximums.push(y), a.minimums.push(d), a.leaves.push(y - d <= 5 && m ? 1 : 0); } r.push(a); } return r }(this.dem), r = e.length - 1, n = e[r]; this._addNode(n.minimums[0], n.maximums[0], n.leaves[0]), this._construct(e, 0, 0, r, 0); } raycastRoot(t, e, r, n, i, s, a = 1) { return $d([t, e, -100], [r, n, this.maximums[0] * a], i, s) } raycast(t, e, r, n, i, s, a = 1) { if (!this.nodeCount) return null; const o = this.raycastRoot(t, e, r, n, i, s, a); if (null == o) return null; const l = [], u = [], c = [], h = [], p = [{ idx: 0, t: o, nodex: 0, nodey: 0, depth: 0 }]; for (; p.length > 0;) { const { idx: o, t: f, nodex: d, nodey: y, depth: m } = p.pop(); if (this.leaves[o]) { qd(d, y, m, t, e, r, n, c, h); const o = 1 << m, l = (d + 0) / o, u = (d + 1) / o, p = (y + 0) / o, g = (y + 1) / o, x = Zd(l, p, this.dem) * a, v = Zd(u, p, this.dem) * a, b = Zd(u, g, this.dem) * a, w = Zd(l, g, this.dem) * a, _ = Ud(c[0], c[1], x, h[0], c[1], v, h[0], h[1], b, i, s), A = Ud(h[0], h[1], b, c[0], h[1], w, c[0], c[1], x, i, s), S = Math.min(null !== _ ? _ : Number.MAX_VALUE, null !== A ? A : Number.MAX_VALUE); if (S !== Number.MAX_VALUE) return S; { const t = Wo([], i, s, f); if (Gd(x, v, w, b, Od(t[0], c[0], h[0]), Od(t[1], c[1], h[1])) >= t[2]) return f } continue } let g = 0; for (let p = 0; p < this._siblingOffset.length; p++) { qd((d << 1) + this._siblingOffset[p][0], (y << 1) + this._siblingOffset[p][1], m + 1, t, e, r, n, c, h), c[2] = -100, h[2] = this.maximums[this.childOffsets[o] + p] * a; const f = $d(c, h, i, s); if (null != f) { const t = f; l[p] = t; let e = !1; for (let r = 0; r < g && !e; r++) t >= l[u[r]] && (u.splice(r, 0, p), e = !0); e || (u[g] = p), g++; } } for (let t = 0; t < g; t++) { const e = u[t]; p.push({ idx: this.childOffsets[o] + e, t: l[e], nodex: (d << 1) + this._siblingOffset[e][0], nodey: (y << 1) + this._siblingOffset[e][1], depth: m + 1 }); } } return null } _addNode(t, e, r) { return this.minimums.push(t), this.maximums.push(e), this.leaves.push(r), this.childOffsets.push(0), this.nodeCount++ } _construct(t, e, r, n, i) { if (1 === t[n].isLeaf(e, r)) return; this.childOffsets[i] || (this.childOffsets[i] = this.nodeCount); const s = n - 1, a = t[s]; let o = 0, l = 0; for (let t = 0; t < this._siblingOffset.length; t++) { const n = 2 * e + this._siblingOffset[t][0], i = 2 * r + this._siblingOffset[t][1], s = a.getElevation(n, i), u = a.isLeaf(n, i), c = this._addNode(s.min, s.max, u); u && (o |= 1 << t), l || (l = c); } for (let n = 0; n < this._siblingOffset.length; n++) o & 1 << n || this._construct(t, 2 * e + this._siblingOffset[n][0], 2 * r + this._siblingOffset[n][1], s, l + n); } } function Gd(t, e, r, n, i, s) { return Mr(Mr(t, r, s), Mr(e, n, s), i) } function Zd(t, e, r) { const n = r.dim, i = S(t * n - .5, 0, n - 1), s = S(e * n - .5, 0, n - 1), a = Math.floor(i), o = Math.floor(s), l = Math.min(a + 1, n - 1), u = Math.min(o + 1, n - 1); return Gd(r.get(a, o), r.get(l, o), r.get(a, u), r.get(l, u), i - a, s - o) } const Xd = { mapbox: [6553.6, 25.6, .1, 1e4], terrarium: [256, 1, 1 / 256, 32768] }; function Kd(t, e, r) { return (256 * t * 256 + 256 * e + r) / 10 - 1e4 } function Yd(t, e, r) { return 256 * t + e + r / 256 - 32768 } class Hd { get tree() { return this._tree || this._buildQuadTree(), this._tree } constructor(t, e, r, n = !1, i = !1) { if (this.uid = t, e.height !== e.width) throw new RangeError("DEM tiles must be square"); if (r && "mapbox" !== r && "terrarium" !== r) return U(`"${r}" is not a valid encoding type. Valid types include "mapbox" and "terrarium".`); this.stride = e.height; const s = this.dim = e.height - 2, a = new Uint32Array(e.data.buffer); if (this.pixels = new Uint8Array(e.data.buffer), this.encoding = r || "mapbox", this.borderReady = n, !n) { for (let t = 0; t < s; t++) a[this._idx(-1, t)] = a[this._idx(0, t)], a[this._idx(s, t)] = a[this._idx(s - 1, t)], a[this._idx(t, -1)] = a[this._idx(t, 0)], a[this._idx(t, s)] = a[this._idx(t, s - 1)]; a[this._idx(-1, -1)] = a[this._idx(0, 0)], a[this._idx(s, -1)] = a[this._idx(s - 1, 0)], a[this._idx(-1, s)] = a[this._idx(0, s - 1)], a[this._idx(s, s)] = a[this._idx(s - 1, s - 1)], i && this._buildQuadTree(); } } _buildQuadTree() { this._tree = new Nd(this); } get(t, e, r = !1) { r && (t = S(t, -1, this.dim), e = S(e, -1, this.dim)); const n = 4 * this._idx(t, e); return ("terrarium" === this.encoding ? Yd : Kd)(this.pixels[n], this.pixels[n + 1], this.pixels[n + 2]) } static getUnpackVector(t) { return Xd[t] } get unpackVector() { return Xd[this.encoding] } _idx(t, e) { if (t < -1 || t >= this.dim + 1 || e < -1 || e >= this.dim + 1) throw new RangeError("out of range source coordinates for DEM data"); return (e + 1) * this.stride + (t + 1) } static pack(t, e) { const r = [0, 0, 0, 0], n = Hd.getUnpackVector(e); let i = Math.floor((t + n[3]) / n[2]); return r[2] = i % 256, i = Math.floor(i / 256), r[1] = i % 256, i = Math.floor(i / 256), r[0] = i, r } getPixels() { return new Qu({ width: this.stride, height: this.stride }, this.pixels) } backfillBorder(t, e, r) { if (this.dim !== t.dim) throw new Error("dem dimension mismatch"); let n = e * this.dim, i = e * this.dim + this.dim, s = r * this.dim, a = r * this.dim + this.dim; switch (e) { case -1: n = i - 1; break; case 1: i = n + 1; } switch (r) { case -1: s = a - 1; break; case 1: a = s + 1; } const o = -e * this.dim, l = -r * this.dim; for (let e = s; e < a; e++) for (let r = n; r < i; r++) { const n = 4 * this._idx(r, e), i = 4 * this._idx(r + o, e + l); this.pixels[n + 0] = t.pixels[i + 0], this.pixels[n + 1] = t.pixels[i + 1], this.pixels[n + 2] = t.pixels[i + 2], this.pixels[n + 3] = t.pixels[i + 3]; } } onDeserialize() { this._tree && (this._tree.dem = this); } } Oi(Hd, "DEMData"), Oi(Nd, "DemMinMaxQuadTree", { omit: ["dem"] }); class Wd { constructor(t, e) { this.max = t, this.onRemove = e, this.reset(); } reset() { for (const t in this.data) for (const e of this.data[t]) e.timeout && clearTimeout(e.timeout), this.onRemove(e.value); return this.data = {}, this.order = [], this } add(t, e, r) { const n = t.wrapped().key; void 0 === this.data[n] && (this.data[n] = []); const i = { value: e, timeout: void 0 }; if (void 0 !== r && (i.timeout = setTimeout((() => { this.remove(t, i); }), r)), this.data[n].push(i), this.order.push(n), this.order.length > this.max) { const t = this._getAndRemoveByKey(this.order[0]); t && this.onRemove(t); } return this } has(t) { return t.wrapped().key in this.data } getAndRemove(t) { return this.has(t) ? this._getAndRemoveByKey(t.wrapped().key) : null } _getAndRemoveByKey(t) { const e = this.data[t].shift(); return e.timeout && clearTimeout(e.timeout), 0 === this.data[t].length && delete this.data[t], this.order.splice(this.order.indexOf(t), 1), e.value } getByKey(t) { const e = this.data[t]; return e ? e[0].value : null } get(t) { return this.has(t) ? this.data[t.wrapped().key][0].value : null } remove(t, e) { if (!this.has(t)) return this; const r = t.wrapped().key, n = void 0 === e ? 0 : this.data[r].indexOf(e), i = this.data[r][n]; return this.data[r].splice(n, 1), i.timeout && clearTimeout(i.timeout), 0 === this.data[r].length && delete this.data[r], this.onRemove(i.value), this.order.splice(this.order.indexOf(r), 1), this } setMaxSize(t) { for (this.max = t; this.order.length > this.max;) { const t = this._getAndRemoveByKey(this.order[0]); t && this.onRemove(t); } return this } filter(t) { const e = []; for (const r in this.data) for (const n of this.data[r]) t(n.value) || e.push(n); for (const t of e) this.remove(t.value.tileID, t); } } class Jd { constructor(t, e, r) { this.func = t, this.mask = e, this.range = r; } } Jd.ReadOnly = !1, Jd.ReadWrite = !0, Jd.disabled = new Jd(519, Jd.ReadOnly, [0, 1]); const Qd = 7680; class ty { constructor(t, e, r, n, i, s) { this.test = t, this.ref = e, this.mask = r, this.fail = n, this.depthFail = i, this.pass = s; } } ty.disabled = new ty({ func: 519, mask: 0 }, 0, 0, Qd, Qd, Qd); class ey { constructor(t, e, r) { this.blendFunction = t, this.blendColor = e, this.mask = r; } } ey.Replace = [1, 0], ey.disabled = new ey(ey.Replace, Me.transparent, [!1, !1, !1, !1]), ey.unblended = new ey(ey.Replace, Me.transparent, [!0, !0, !0, !0]), ey.alphaBlended = new ey([1, 771], Me.transparent, [!0, !0, !0, !0]); const ry = 1029, ny = 2305; class iy { constructor(t, e, r) { this.enable = t, this.mode = e, this.frontFace = r; } } iy.disabled = new iy(!1, ry, ny), iy.backCCW = new iy(!0, ry, ny), iy.backCW = new iy(!0, ry, 2304), iy.frontCW = new iy(!0, 1028, 2304), iy.frontCCW = new iy(!0, 1028, ny); class sy extends Yt { constructor(t, e, r) { super(), this.id = t, this._onlySymbols = r, e.on("data", (t => { "source" === t.dataType && "metadata" === t.sourceDataType && (this._sourceLoaded = !0), this._sourceLoaded && !this._paused && "source" === t.dataType && "content" === t.sourceDataType && (this.reload(), this.transform && this.update(this.transform)); })), e.on("error", (() => { this._sourceErrored = !0; })), this._source = e, this._tiles = {}, this._cache = new Wd(0, this._unloadTile.bind(this)), this._timers = {}, this._cacheTimers = {}, this._minTileCacheSize = e.minTileCacheSize, this._maxTileCacheSize = e.maxTileCacheSize, this._loadedParentTiles = {}, this._coveredTiles = {}, this._state = new Rd, this._isRaster = "raster" === this._source.type || "raster-dem" === this._source.type || "custom" === this._source.type && "raster" === this._source._dataType; } onAdd(t) { this.map = t, this._minTileCacheSize = void 0 === this._minTileCacheSize && t ? t._minTileCacheSize : this._minTileCacheSize, this._maxTileCacheSize = void 0 === this._maxTileCacheSize && t ? t._maxTileCacheSize : this._maxTileCacheSize; } loaded() { if (this._sourceErrored) return !0; if (!this._sourceLoaded) return !1; if (!this._source.loaded()) return !1; for (const t in this._tiles) { const e = this._tiles[t]; if ("loaded" !== e.state && "errored" !== e.state) return !1 } return !0 } getSource() { return this._source } pause() { this._paused = !0; } resume() { if (!this._paused) return; const t = this._shouldReloadOnResume; this._paused = !1, this._shouldReloadOnResume = !1, t && this.reload(), this.transform && this.update(this.transform); } _loadTile(t, e) { return t.isSymbolTile = this._onlySymbols, this._source.loadTile(t, e) } _unloadTile(t) { if (this._source.unloadTile) return this._source.unloadTile(t, (() => {})) } _abortTile(t) { if (this._source.abortTile) return this._source.abortTile(t, (() => {})) } serialize() { return this._source.serialize() } prepare(t) { this._source.prepare && this._source.prepare(), this._state.coalesceChanges(this._tiles, this.map ? this.map.painter : null); for (const e in this._tiles) { const r = this._tiles[e]; r.upload(t), r.prepare(this.map.style.imageManager); } } getIds() { return T(this._tiles).map((t => t.tileID)).sort(ay).map((t => t.key)) } getRenderableIds(t) { const e = []; for (const r in this._tiles) this._isIdRenderable(+r, t) && e.push(this._tiles[r]); return t ? e.sort(((t, e) => { const r = t.tileID, n = e.tileID, i = new d(r.canonical.x, r.canonical.y)._rotate(this.transform.angle), s = new d(n.canonical.x, n.canonical.y)._rotate(this.transform.angle); return r.overscaledZ - n.overscaledZ || s.y - i.y || s.x - i.x })).map((t => t.tileID.key)) : e.map((t => t.tileID)).sort(ay).map((t => t.key)) } hasRenderableParent(t) { const e = this.findLoadedParent(t, 0); return !!e && this._isIdRenderable(e.tileID.key) } _isIdRenderable(t, e) { return this._tiles[t] && this._tiles[t].hasData() && !this._coveredTiles[t] && (e || !this._tiles[t].holdingForFade()) } reload() { if (this._paused) this._shouldReloadOnResume = !0; else { this._cache.reset(); for (const t in this._tiles) "errored" !== this._tiles[t].state && this._reloadTile(+t, "reloading"); } } _reloadTile(t, e) { const r = this._tiles[t]; r && ("loading" !== r.state && (r.state = e), this._loadTile(r, this._tileLoaded.bind(this, r, t, e))); } _tileLoaded(t, e, r, n) { if (n) if (t.state = "errored", 404 !== n.status) this._source.fire(new Kt(n, { tile: t })); else if ("raster-dem" === this._source.type && this.usedForTerrain && this.map.painter.terrain) { const t = this.map.painter.terrain; this.update(this.transform, t.getScaledDemTileSize(), !0), t.resetTileLookupCache(this.id); } else this.update(this.transform); else t.timeAdded = Nt.now(), "expired" === r && (t.refreshedUponExpiration = !0), this._setTileReloadTimer(e, t), "raster-dem" === this._source.type && t.dem && this._backfillDEM(t), this._state.initializeTileState(t, this.map ? this.map.painter : null), this._source.fire(new Xt("data", { dataType: "source", tile: t, coord: t.tileID, sourceCacheId: this.id })); } _backfillDEM(t) { const e = this.getRenderableIds(); for (let n = 0; n < e.length; n++) { const i = e[n]; if (t.neighboringTiles && t.neighboringTiles[i]) { const e = this.getTileByID(i); r(t, e), r(e, t); } } function r(t, e) { if (!t.dem || t.dem.borderReady) return; t.needsHillshadePrepare = !0, t.needsDEMTextureUpload = !0; let r = e.tileID.canonical.x - t.tileID.canonical.x; const n = e.tileID.canonical.y - t.tileID.canonical.y, i = Math.pow(2, t.tileID.canonical.z), s = e.tileID.key; 0 === r && 0 === n || Math.abs(n) > 1 || (Math.abs(r) > 1 && (1 === Math.abs(r + i) ? r += i : 1 === Math.abs(r - i) && (r -= i)), e.dem && t.dem && (t.dem.backfillBorder(e.dem, r, n), t.neighboringTiles && t.neighboringTiles[s] && (t.neighboringTiles[s].backfilled = !0))); } } getTile(t) { return this.getTileByID(t.key) } getTileByID(t) { return this._tiles[t] } _retainLoadedChildren(t, e, r, n) { for (const i in this._tiles) { let s = this._tiles[i]; if (n[i] || !s.hasData() || s.tileID.overscaledZ <= e || s.tileID.overscaledZ > r) continue; let a = s.tileID; for (; s && s.tileID.overscaledZ > e + 1;) { const t = s.tileID.scaledTo(s.tileID.overscaledZ - 1); s = this._tiles[t.key], s && s.hasData() && (a = t); } let o = a; for (; o.overscaledZ > e;) if (o = o.scaledTo(o.overscaledZ - 1), t[o.key]) { n[a.key] = a; break } } } findLoadedParent(t, e) { if (t.key in this._loadedParentTiles) { const r = this._loadedParentTiles[t.key]; return r && r.tileID.overscaledZ >= e ? r : null } for (let r = t.overscaledZ - 1; r >= e; r--) { const e = t.scaledTo(r), n = this._getLoadedTile(e); if (n) return n } } _getLoadedTile(t) { const e = this._tiles[t.key]; return e && e.hasData() ? e : this._cache.getByKey(this._source.reparseOverscaled ? t.wrapped().key : t.canonical.key) } updateCacheSize(t, e) { e = e || this._source.tileSize; const r = Math.ceil(t.width / e) + 1, n = Math.ceil(t.height / e) + 1, i = Math.floor(r * n * 5), s = "number" == typeof this._minTileCacheSize ? Math.max(this._minTileCacheSize, i) : i, a = "number" == typeof this._maxTileCacheSize ? Math.min(this._maxTileCacheSize, s) : s; this._cache.setMaxSize(a); } handleWrapJump(t) { const e = Math.round((t - (void 0 === this._prevLng ? t : this._prevLng)) / 360); if (this._prevLng = t, e) { const t = {}; for (const r in this._tiles) { const n = this._tiles[r]; n.tileID = n.tileID.unwrapTo(n.tileID.wrap + e), t[n.tileID.key] = n; } this._tiles = t; for (const t in this._timers) clearTimeout(this._timers[t]), delete this._timers[t]; for (const t in this._tiles) this._setTileReloadTimer(+t, this._tiles[t]); } } update(t, e, r) { if (this.transform = t, !this._sourceLoaded || this._paused || this.transform.freezeTileCoverage) return; if (this.usedForTerrain && !r) return; let n; this.updateCacheSize(t, e), "globe" !== this.transform.projection.name && this.handleWrapJump(this.transform.center.lng), this._coveredTiles = {}, this.used || this.usedForTerrain ? this._source.tileID ? n = t.getVisibleUnwrappedCoordinates(this._source.tileID).map((t => new Mh(t.canonical.z, t.wrap, t.canonical.z, t.canonical.x, t.canonical.y))) : (n = t.coveringTiles({ tileSize: e || this._source.tileSize, minzoom: this._source.minzoom, maxzoom: this._source.maxzoom, roundZoom: this._source.roundZoom && !r, reparseOverscaled: this._source.reparseOverscaled, isTerrainDEM: this.usedForTerrain }), this._source.hasTile && (n = n.filter((t => this._source.hasTile(t))))) : n = []; const i = this._updateRetainedTiles(n); if (oy(this._source.type) && 0 !== n.length) { const t = {}, e = {}, r = Object.keys(i); for (const n of r) { const r = i[n], s = this._tiles[n]; if (!s || s.fadeEndTime && s.fadeEndTime <= Nt.now()) continue; const a = this.findLoadedParent(r, Math.max(r.overscaledZ - sy.maxOverzooming, this._source.minzoom)); a && (this._addTile(a.tileID), t[a.tileID.key] = a.tileID), e[n] = r; } const s = n[n.length - 1].overscaledZ; for (const t in this._tiles) { const r = this._tiles[t]; if (i[t] || !r.hasData()) continue; let n = r.tileID; for (; n.overscaledZ > s;) { n = n.scaledTo(n.overscaledZ - 1); const s = this._tiles[n.key]; if (s && s.hasData() && e[n.key]) { i[t] = r.tileID; break } } } for (const e in t) i[e] || (this._coveredTiles[e] = !0, i[e] = t[e]); } for (const t in i) this._tiles[t].clearFadeHold(); const s = function(t, e) { const r = []; for (const n in t) n in e || r.push(n); return r }(this._tiles, i); for (const t of s) { const e = this._tiles[t]; e.hasSymbolBuckets && !e.holdingForFade() ? e.setHoldDuration(this.map._fadeDuration) : e.hasSymbolBuckets && !e.symbolFadeFinished() || this._removeTile(+t); } this._updateLoadedParentTileCache(), this._onlySymbols && this._source.afterUpdate && this._source.afterUpdate(); } releaseSymbolFadeTiles() { for (const t in this._tiles) this._tiles[t].holdingForFade() && this._removeTile(+t); } _updateRetainedTiles(t) { const e = {}; if (0 === t.length) return e; const r = {}, n = t.reduce(((t, e) => Math.min(t, e.overscaledZ)), 1 / 0), i = t[0].overscaledZ, s = Math.max(i - sy.maxOverzooming, this._source.minzoom), a = Math.max(i + sy.maxUnderzooming, this._source.minzoom), o = {}; for (const r of t) { const t = this._addTile(r); e[r.key] = r, t.hasData() || n < this._source.maxzoom && (o[r.key] = r); } this._retainLoadedChildren(o, n, a, e); for (const n of t) { let t = this._tiles[n.key]; if (t.hasData()) continue; if (n.canonical.z >= this._source.maxzoom) { const t = n.children(this._source.maxzoom)[0], r = this.getTile(t); if (r && r.hasData()) { e[t.key] = t; continue } } else { const t = n.children(this._source.maxzoom); if (e[t[0].key] && e[t[1].key] && e[t[2].key] && e[t[3].key]) continue } let i = t.wasRequested(); for (let a = n.overscaledZ - 1; a >= s; --a) { const s = n.scaledTo(a); if (r[s.key]) break; if (r[s.key] = !0, t = this.getTile(s), !t && i && (t = this._addTile(s)), t && (e[s.key] = s, i = t.wasRequested(), t.hasData())) break } } return e } _updateLoadedParentTileCache() { this._loadedParentTiles = {}; for (const t in this._tiles) { const e = []; let r, n = this._tiles[t].tileID; for (; n.overscaledZ > 0;) { if (n.key in this._loadedParentTiles) { r = this._loadedParentTiles[n.key]; break } e.push(n.key); const t = n.scaledTo(n.overscaledZ - 1); if (r = this._getLoadedTile(t), r) break; n = t; } for (const t of e) this._loadedParentTiles[t] = r; } } _addTile(t) { let e = this._tiles[t.key]; if (e) return e; e = this._cache.getAndRemove(t), e && (this._setTileReloadTimer(t.key, e), e.tileID = t, this._state.initializeTileState(e, this.map ? this.map.painter : null), this._cacheTimers[t.key] && (clearTimeout(this._cacheTimers[t.key]), delete this._cacheTimers[t.key], this._setTileReloadTimer(t.key, e))); const r = Boolean(e); if (!r) { const r = this.map ? this.map.painter : null; e = new Fd(t, this._source.tileSize * t.overscaleFactor(), this.transform.tileZoom, r, this._isRaster), this._loadTile(e, this._tileLoaded.bind(this, e, t.key, e.state)); } return e ? (e.uses++, this._tiles[t.key] = e, r || this._source.fire(new Xt("dataloading", { tile: e, coord: e.tileID, dataType: "source" })), e) : null } _setTileReloadTimer(t, e) { t in this._timers && (clearTimeout(this._timers[t]), delete this._timers[t]); const r = e.getExpiryTimeout(); r && (this._timers[t] = setTimeout((() => { this._reloadTile(t, "expired"), delete this._timers[t]; }), r)); } _removeTile(t) { const e = this._tiles[t]; e && (e.uses--, delete this._tiles[t], this._timers[t] && (clearTimeout(this._timers[t]), delete this._timers[t]), e.uses > 0 || (e.hasData() && "reloading" !== e.state ? this._cache.add(e.tileID, e, e.getExpiryTimeout()) : (e.aborted = !0, this._abortTile(e), this._unloadTile(e)))); } clearTiles() { this._shouldReloadOnResume = !1, this._paused = !1; for (const t in this._tiles) this._removeTile(+t); this._source._clear && this._source._clear(), this._cache.reset(), this.map && this.usedForTerrain && this.map.painter.terrain && this.map.painter.terrain.resetTileLookupCache(this.id); } tilesIn(t, e, r) { const n = [], i = this.transform; if (!i) return n; const s = "globe" === i.projection.name, a = iu(i.center.lng); for (const o in this._tiles) { const l = this._tiles[o]; if (r && l.clearQueryDebugViz(), l.holdingForFade()) continue; let u; if (s) { const t = l.tileID.canonical; if (0 === t.z) { const e = [Math.abs(S(a, ...ly(t, -1)) - a), Math.abs(S(a, ...ly(t, 1)) - a)]; u = [0, 2 * e.indexOf(Math.min(...e)) - 1]; } else { const e = [Math.abs(S(a, ...ly(t, -1)) - a), Math.abs(S(a, ...ly(t, 0)) - a), Math.abs(S(a, ...ly(t, 1)) - a)]; u = [e.indexOf(Math.min(...e)) - 1]; } } else u = [0]; for (const r of u) { const s = t.containsTile(l, i, e, r); s && n.push(s); } } return n } getVisibleCoordinates(t) { const e = this.getRenderableIds(t).map((t => this._tiles[t].tileID)); for (const t of e) t.projMatrix = this.transform.calculateProjMatrix(t.toUnwrapped()); return e } hasTransition() { if (this._source.hasTransition()) return !0; if (oy(this._source.type)) for (const t in this._tiles) { const e = this._tiles[t]; if (void 0 !== e.fadeEndTime && e.fadeEndTime >= Nt.now()) return !0 } return !1 } setFeatureState(t, e, r) { this._state.updateState(t = t || "_geojsonTileLayer", e, r); } removeFeatureState(t, e, r) { this._state.removeFeatureState(t = t || "_geojsonTileLayer", e, r); } getFeatureState(t, e) { return this._state.getState(t = t || "_geojsonTileLayer", e) } setDependencies(t, e, r) { const n = this._tiles[t]; n && n.setDependencies(e, r); } reloadTilesForDependencies(t, e) { for (const r in this._tiles) this._tiles[r].hasDependency(t, e) && this._reloadTile(+r, "reloading"); this._cache.filter((r => !r.hasDependency(t, e))); } _preloadTiles(t, e) { const r = new Map, n = Array.isArray(t) ? t : [t], i = this.map.painter.terrain, s = this.usedForTerrain && i ? i.getScaledDemTileSize() : this._source.tileSize; for (const t of n) { const e = t.coveringTiles({ tileSize: s, minzoom: this._source.minzoom, maxzoom: this._source.maxzoom, roundZoom: this._source.roundZoom && !this.usedForTerrain, reparseOverscaled: this._source.reparseOverscaled, isTerrainDEM: this.usedForTerrain }); for (const t of e) r.set(t.key, t); this.usedForTerrain && t.updateElevation(!1); } M(Array.from(r.values()), ((t, e) => { const r = new Fd(t, this._source.tileSize * t.overscaleFactor(), this.transform.tileZoom, this.map.painter, this._isRaster); this._loadTile(r, (t => { "raster-dem" === this._source.type && r.dem && this._backfillDEM(r), e(t, r); })); }), e); } } function ay(t, e) { const r = Math.abs(2 * t.wrap) - +(t.wrap < 0), n = Math.abs(2 * e.wrap) - +(e.wrap < 0); return t.overscaledZ - e.overscaledZ || n - r || e.canonical.y - t.canonical.y || e.canonical.x - t.canonical.x } function oy(t) { return "raster" === t || "image" === t || "video" === t || "custom" === t } function ly(t, e) { const r = 1 << t.z; return [t.x / r + e, (t.x + 1) / r + e] } sy.maxOverzooming = 10, sy.maxUnderzooming = 3; class uy { constructor(t, e, r) { this._demTile = t, this._dem = this._demTile.dem, this._scale = e, this._offset = r; } static create(t, e, r) { const n = r || t.findDEMTileFor(e); if (!n || !n.dem) return; const i = n.dem, s = n.tileID, a = 1 << e.canonical.z - s.canonical.z; return new uy(n, n.tileSize / ko / a, [(e.canonical.x / a - s.canonical.x) * i.dim, (e.canonical.y / a - s.canonical.y) * i.dim]) } tileCoordToPixel(t, e) { const r = e * this._scale + this._offset[1], n = Math.floor(t * this._scale + this._offset[0]), i = Math.floor(r); return new d(n, i) } getElevationAt(t, e, r, n) { const i = t * this._scale + this._offset[0], s = e * this._scale + this._offset[1], a = Math.floor(i), o = Math.floor(s), l = this._dem; return n = !!n, r ? Mr(Mr(l.get(a, o, n), l.get(a, o + 1, n), s - o), Mr(l.get(a + 1, o, n), l.get(a + 1, o + 1, n), s - o), i - a) : l.get(a, o, n) } getElevationAtPixel(t, e, r) { return this._dem.get(t, e, !!r) } getMeterToDEM(t) { return (1 << this._demTile.tileID.canonical.z) * au(1, t) * this._dem.stride } } class cy { constructor(t, e) { this.tileID = t, this.x = t.canonical.x, this.y = t.canonical.y, this.z = t.canonical.z, this.grid = new ji(ko, 16, 0), this.featureIndexArray = new ja, this.promoteId = e; } insert(t, e, r, n, i, s = 0) { const a = this.featureIndexArray.length; this.featureIndexArray.emplaceBack(r, n, i, s); const o = this.grid; for (let t = 0; t < e.length; t++) { const r = e[t], n = [1 / 0, 1 / 0, -1 / 0, -1 / 0]; for (let t = 0; t < r.length; t++) { const e = r[t]; n[0] = Math.min(n[0], e.x), n[1] = Math.min(n[1], e.y), n[2] = Math.max(n[2], e.x), n[3] = Math.max(n[3], e.y); } n[0] < ko && n[1] < ko && n[2] >= 0 && n[3] >= 0 && o.insert(a, n[0], n[1], n[2], n[3]); } } loadVTLayers() { if (!this.vtLayers) { this.vtLayers = new sh(new op(this.rawTileData)).layers, this.sourceLayerCoder = new kd(this.vtLayers ? Object.keys(this.vtLayers).sort() : ["_geojsonTileLayer"]), this.vtFeatures = {}; for (const t in this.vtLayers) this.vtFeatures[t] = []; } return this.vtLayers } query(t, e, r, n) { this.loadVTLayers(); const i = t.params || {}, s = ai(i.filter), a = t.tileResult, o = t.transform, l = a.bufferedTilespaceBounds, u = this.grid.query(l.min.x, l.min.y, l.max.x, l.max.y, ((t, e, r, n) => Vu(a.bufferedTilespaceGeometry, t, e, r, n))); u.sort(py); let c = null; o.elevation && u.length > 0 && (c = uy.create(o.elevation, this.tileID)); const h = {}; let p; for (let o = 0; o < u.length; o++) { const l = u[o]; if (l === p) continue; p = l; const f = this.featureIndexArray.get(l); let d = null; this.loadMatchingFeature(h, f, s, i.layers, i.availableImages, e, r, n, ((e, r, n, i = 0) => (d || (d = bu(e, this.tileID.canonical, t.tileTransform)), r.queryIntersectsFeature(a, e, n, d, this.z, t.transform, t.pixelPosMatrix, c, i)))); } return h } loadMatchingFeature(t, e, r, n, i, s, a, o, l) { const { featureIndex: u, bucketIndex: c, sourceLayerIndex: h, layoutVertexArrayOffset: p } = e, f = this.bucketLayerIDs[c]; if (n && ! function(t, e) { for (let r = 0; r < t.length; r++) if (e.indexOf(t[r]) >= 0) return !0; return !1 }(n, f)) return; const d = this.sourceLayerCoder.decode(h), y = this.vtLayers[d].feature(u); if (r.needGeometry) { const t = wu(y, !0); if (!r.filter(new $s(this.tileID.overscaledZ), t, this.tileID.canonical)) return } else if (!r.filter(new $s(this.tileID.overscaledZ), y)) return; const m = this.getId(y, d); for (let e = 0; e < f.length; e++) { const r = f[e]; if (n && n.indexOf(r) < 0) continue; const c = s[r]; if (!c) continue; let h = {}; void 0 !== m && o && (h = o.getState(c.sourceLayer || "_geojsonTileLayer", m)); const d = z({}, a[r]); d.paint = hy(d.paint, c.paint, y, h, i), d.layout = hy(d.layout, c.layout, y, h, i); const g = !l || l(y, c, h, p); if (!g) continue; const x = new Md(y, this.z, this.x, this.y, m); x.layer = d; let v = t[r]; void 0 === v && (v = t[r] = []), v.push({ featureIndex: u, feature: x, intersectionZ: g }); } } lookupSymbolFeatures(t, e, r, n, i, s, a, o) { const l = {}; this.loadVTLayers(); const u = ai(i); for (const i of t) this.loadMatchingFeature(l, { bucketIndex: r, sourceLayerIndex: n, featureIndex: i, layoutVertexArrayOffset: 0 }, u, s, a, o, e); return l } loadFeature(t) { const { featureIndex: e, sourceLayerIndex: r } = t; this.loadVTLayers(); const n = this.sourceLayerCoder.decode(r), i = this.vtFeatures[n]; if (i[e]) return i[e]; const s = this.vtLayers[n].feature(e); return i[e] = s, s } hasLayer(t) { for (const e of this.bucketLayerIDs) for (const r of e) if (t === r) return !0; return !1 } getId(t, e) { let r = t.id; if (this.promoteId) { const n = "string" == typeof this.promoteId ? this.promoteId : this.promoteId[e]; null != n && (r = t.properties[n]), "boolean" == typeof r && (r = Number(r)); } return r } } function hy(t, e, r, n, i) { return F(t, ((t, s) => { const a = e instanceof Ks ? e.get(s) : null; return a && a.evaluate ? a.evaluate(r, n, i) : a })) } function py(t, e) { return e - t } Oi(cy, "FeatureIndex", { omit: ["rawTileData", "sourceLayerCoder"] }); class fy { constructor(t, e) { this.width = t, this.height = e, this.nextRow = 0, this.image = new Ju({ width: t, height: e }), this.positions = {}, this.uploaded = !1; } getDash(t, e) { const r = this.getKey(t, e); return this.positions[r] } trim() { const t = this.width, e = this.height = P(this.nextRow); this.image.resize({ width: t, height: e }); } getKey(t, e) { return t.join(",") + e } getDashRanges(t, e, r) { const n = []; let i = t.length % 2 == 1 ? -t[t.length - 1] * r : 0, s = t[0] * r, a = !0; n.push({ left: i, right: s, isDash: a, zeroLength: 0 === t[0] }); let o = t[0]; for (let e = 1; e < t.length; e++) { a = !a; const l = t[e]; i = o * r, o += l, s = o * r, n.push({ left: i, right: s, isDash: a, zeroLength: 0 === l }); } return n } addRoundDash(t, e, r) { const n = e / 2; for (let e = -r; e <= r; e++) { const i = this.width * (this.nextRow + r + e); let s = 0, a = t[s]; for (let o = 0; o < this.width; o++) { o / a.right > 1 && (a = t[++s]); const l = Math.abs(o - a.left), u = Math.abs(o - a.right), c = Math.min(l, u); let h; const p = e / r * (n + 1); if (a.isDash) { const t = n - Math.abs(p); h = Math.sqrt(c * c + t * t); } else h = n - Math.sqrt(c * c + p * p); this.image.data[i + o] = Math.max(0, Math.min(255, h + 128)); } } } addRegularDash(t, e) { for (let e = t.length - 1; e >= 0; --e) { const r = t[e], n = t[e + 1]; r.zeroLength ? t.splice(e, 1) : n && n.isDash === r.isDash && (n.left = r.left, t.splice(e, 1)); } const r = t[0], n = t[t.length - 1]; r.isDash === n.isDash && (r.left = n.left - this.width, n.right = r.right + this.width); const i = this.width * this.nextRow; let s = 0, a = t[s]; for (let r = 0; r < this.width; r++) { r / a.right > 1 && (a = t[++s]); const n = Math.abs(r - a.left), o = Math.abs(r - a.right), l = Math.min(n, o); this.image.data[i + r] = Math.max(0, Math.min(255, (a.isDash ? l : -l) + e + 128)); } } addDash(t, e) { const r = this.getKey(t, e); if (this.positions[r]) return this.positions[r]; const n = "round" === e, i = n ? 7 : 0, s = 2 * i + 1; if (this.nextRow + s > this.height) return U("LineAtlas out of space"), null; 0 === t.length && t.push(1); let a = 0; for (let e = 0; e < t.length; e++) t[e] < 0 && (U("Negative value is found in line dasharray, replacing values with 0"), t[e] = 0), a += t[e]; if (0 !== a) { const r = this.width / a, s = this.getDashRanges(t, this.width, r); n ? this.addRoundDash(s, r, i) : this.addRegularDash(s, "square" === e ? .5 * r : 0); } const o = this.nextRow + i; this.nextRow += s; const l = { tl: [o, i], br: [a, 0] }; return this.positions[r] = l, l } } Oi(fy, "LineAtlas"); class dy { constructor(t) { const e = {}, r = []; for (const n in t) { const i = t[n], s = e[n] = {}; for (const t in i.glyphs) { const e = i.glyphs[+t]; if (!e || 0 === e.bitmap.width || 0 === e.bitmap.height) continue; const n = e.metrics.localGlyph ? 2 : 1, a = { x: 0, y: 0, w: e.bitmap.width + 2 * n, h: e.bitmap.height + 2 * n }; r.push(a), s[t] = a; } } const { w: n, h: i } = Cp(r), s = new Ju({ width: n || 1, height: i || 1 }); for (const r in t) { const n = t[r]; for (const t in n.glyphs) { const i = n.glyphs[+t]; if (!i || 0 === i.bitmap.width || 0 === i.bitmap.height) continue; const a = e[r][t], o = i.metrics.localGlyph ? 2 : 1; Ju.copy(i.bitmap, s, { x: 0, y: 0 }, { x: a.x + o, y: a.y + o }, i.bitmap); } } this.image = s, this.positions = e; } } Oi(dy, "GlyphAtlas"); class yy { constructor(t) { this.tileID = new Mh(t.tileID.overscaledZ, t.tileID.wrap, t.tileID.canonical.z, t.tileID.canonical.x, t.tileID.canonical.y), this.tileZoom = t.tileZoom, this.uid = t.uid, this.zoom = t.zoom, this.canonical = t.tileID.canonical, this.pixelRatio = t.pixelRatio, this.tileSize = t.tileSize, this.source = t.source, this.overscaling = this.tileID.overscaleFactor(), this.showCollisionBoxes = t.showCollisionBoxes, this.collectResourceTiming = !!t.collectResourceTiming, this.returnDependencies = !!t.returnDependencies, this.promoteId = t.promoteId, this.enableTerrain = !!t.enableTerrain, this.isSymbolTile = t.isSymbolTile, this.tileTransform = Vf(t.tileID.canonical, t.projection), this.projection = t.projection; } parse(t, e, r, n, i) { this.status = "parsing", this.data = t, this.collisionBoxArray = new Ea; const s = new kd(Object.keys(t.layers).sort()), a = new cy(this.tileID, this.promoteId); a.bucketLayerIDs = []; const o = {}, l = new fy(256, 256), u = { featureIndex: a, iconDependencies: {}, patternDependencies: {}, glyphDependencies: {}, lineAtlas: l, availableImages: r }, c = e.familiesBySource[this.source]; for (const e in c) { const n = t.layers[e]; if (!n) continue; let i = !1, l = !1; for (const t of c[e]) "symbol" === t[0].type ? i = !0 : l = !0; if (!0 === this.isSymbolTile && !i) continue; if (!1 === this.isSymbolTile && !l) continue; 1 === n.version && U(`Vector tile source "${this.source}" layer "${e}" does not use vector tile spec v2 and therefore may have some rendering errors.`); const h = s.encode(e), p = []; for (let t = 0; t < n.length; t++) { const r = n.feature(t), i = a.getId(r, e); p.push({ feature: r, id: i, index: t, sourceLayerIndex: h }); } for (const t of c[e]) { const e = t[0]; void 0 !== this.isSymbolTile && "symbol" === e.type !== this.isSymbolTile || e.minzoom && this.zoom < Math.floor(e.minzoom) || e.maxzoom && this.zoom >= e.maxzoom || "none" !== e.visibility && (my(t, this.zoom, r), (o[e.id] = e.createBucket({ index: a.bucketLayerIDs.length, layers: t, zoom: this.zoom, canonical: this.canonical, pixelRatio: this.pixelRatio, overscaling: this.overscaling, collisionBoxArray: this.collisionBoxArray, sourceLayerIndex: h, sourceID: this.source, enableTerrain: this.enableTerrain, projection: this.projection.spec, availableImages: r })).populate(p, u, this.tileID.canonical, this.tileTransform), a.bucketLayerIDs.push(t.map((t => t.id)))); } } let h, p, f, d; l.trim(); const y = { type: "maybePrepare", isSymbolTile: this.isSymbolTile, zoom: this.zoom }, m = F(u.glyphDependencies, (t => Object.keys(t).map(Number))); Object.keys(m).length ? n.send("getGlyphs", { uid: this.uid, stacks: m }, ((t, e) => { h || (h = t, p = e, v.call(this)); }), void 0, !1, y) : p = {}; const g = Object.keys(u.iconDependencies); g.length ? n.send("getImages", { icons: g, source: this.source, tileID: this.tileID, type: "icons" }, ((t, e) => { h || (h = t, f = e, v.call(this)); }), void 0, !1, y) : f = {}; const x = Object.keys(u.patternDependencies); function v() { if (h) return i(h); if (p && f && d) { const t = new dy(p), e = new Dp(f, d); for (const n in o) { const i = o[n]; i instanceof hd ? (my(i.layers, this.zoom, r), kf(i, p, t.positions, f, e.iconPositions, this.showCollisionBoxes, r, this.tileID.canonical, this.tileZoom, this.projection)) : i.hasPattern && (i instanceof jh || i instanceof $c || i instanceof fh) && (my(i.layers, this.zoom, r), i.addFeatures(u, this.tileID.canonical, e.patternPositions, r, this.tileTransform)); } this.status = "done", i(null, { buckets: T(o).filter((t => !t.isEmpty())), featureIndex: a, collisionBoxArray: this.collisionBoxArray, glyphAtlasImage: t.image, lineAtlas: l, imageAtlas: e, glyphMap: this.returnDependencies ? p : null, iconMap: this.returnDependencies ? f : null, glyphPositions: this.returnDependencies ? t.positions : null }); } } x.length ? n.send("getImages", { icons: x, source: this.source, tileID: this.tileID, type: "patterns" }, ((t, e) => { h || (h = t, d = e, v.call(this)); }), void 0, !1, y) : d = {}, v.call(this); } } function my(t, e, r) { const n = new $s(e); for (const e of t) e.recalculate(n, r); } class gy { constructor(t) { this.entries = {}, this.scheduler = t; } request(t, e, r, n) { const i = this.entries[t] = this.entries[t] || { callbacks: [] }; if (i.result) { const [t, r] = i.result; return this.scheduler ? this.scheduler.add((() => { n(t, r); }), e) : n(t, r), () => {} } return i.callbacks.push(n), i.cancel || (i.cancel = r(((r, n) => { i.result = [r, n]; for (const t of i.callbacks) this.scheduler ? this.scheduler.add((() => { t(r, n); }), e) : t(r, n); setTimeout((() => delete this.entries[t]), 3e3); }))), () => { i.result || (i.callbacks = i.callbacks.filter((t => t !== n)), i.callbacks.length || (i.cancel(), delete this.entries[t])); } } } function xy(t, e, r) { const n = JSON.stringify(t.request); return t.data && (this.deduped.entries[n] = { result: [null, t.data] }), this.deduped.request(n, { type: "parseTile", isSymbolTile: t.isSymbolTile, zoom: t.tileZoom }, (e => { const n = ut(t.request, ((t, n, i, s) => { t ? e(t) : n && e(null, { vectorTile: r ? void 0 : new sh(new op(n)), rawData: n, cacheControl: i, expires: s }); })); return () => { n.cancel(), e(); } }), e) } t.ARRAY_TYPE = To, t.AUTH_ERR_MSG = yt, t.Aabb = _l, t.Actor = class { constructor(t, r, n) { this.target = t, this.parent = r, this.mapId = n, this.callbacks = {}, this.cancelCallbacks = {}, V(["receive"], this), this.target.addEventListener("message", this.receive, !1), this.globalScope = N() ? t : e, this.scheduler = new Sd; } send(t, e, r, n, i = !1, s) { const a = Math.round(1e18 * Math.random()).toString(36).substring(0, 10); r && (r.metadata = s, this.callbacks[a] = r); const o = X(this.globalScope) ? void 0 : []; return this.target.postMessage({ id: a, type: t, hasCallback: !!r, targetMapId: n, mustQueue: i, sourceMapId: this.mapId, data: Gi(e, o) }, o), { cancel: () => { r && delete this.callbacks[a], this.target.postMessage({ id: a, type: "<cancel>", targetMapId: n, sourceMapId: this.mapId }); } } } receive(t) { const e = t.data, r = e.id; if (r && (!e.targetMapId || this.mapId === e.targetMapId)) if ("<cancel>" === e.type) { const t = this.cancelCallbacks[r]; delete this.cancelCallbacks[r], t && t.cancel(); } else if (e.mustQueue || N()) { const t = this.callbacks[r]; this.cancelCallbacks[r] = this.scheduler.add((() => this.processTask(r, e)), t && t.metadata || { type: "message" }); } else this.processTask(r, e); } processTask(t, e) { if ("<response>" === e.type) { const r = this.callbacks[t]; delete this.callbacks[t], r && (e.error ? r(Zi(e.error)) : r(null, Zi(e.data))); } else { const r = X(this.globalScope) ? void 0 : [], n = e.hasCallback ? (e, n) => { delete this.cancelCallbacks[t], this.target.postMessage({ id: t, type: "<response>", sourceMapId: this.mapId, error: e ? Gi(e) : null, data: Gi(n, r) }, r); } : t => {}, i = Zi(e.data); if (this.parent[e.type]) this.parent[e.type](e.sourceMapId, i, n); else if (this.parent.getWorkerSource) { const t = e.type.split("."); this.parent.getWorkerSource(e.sourceMapId, t[0], i.source)[t[1]](i, n); } else n(new Error(`Could not find function ${e.type}`)); } } remove() { this.scheduler.remove(), this.target.removeEventListener("message", this.receive, !1); } }, t.CanonicalTileID = kh, t.Color = Me, t.ColorMode = ey, t.CullFaceMode = iy, t.DEMData = Hd, t.DataConstantProperty = Ys, t.DedupedRequest = gy, t.DepthMode = Jd, t.EXTENT = ko, t.Elevation = class { isDataAvailableAtPoint(t) { const e = this._source(); if (this.isUsingMockSource() || !e || t.y < 0 || t.y > 1) return !1; const r = e.getSource().maxzoom, n = 1 << r, i = Math.floor(t.x), s = Math.floor((t.x - i) * n), a = Math.floor(t.y * n), o = this.findDEMTileFor(new Mh(r, i, r, s, a)); return !(!o || !o.dem) } getAtPointOrZero(t, e = 0) { return this.getAtPoint(t, e) || 0 } getAtPoint(t, e, r = !0) { if (this.isUsingMockSource()) return null; null == e && (e = null); const n = this._source(); if (!n) return e; if (t.y < 0 || t.y > 1) return e; const i = n.getSource().maxzoom, s = 1 << i, a = Math.floor(t.x), o = t.x - a, l = new Mh(i, a, i, Math.floor(o * s), Math.floor(t.y * s)), u = this.findDEMTileFor(l); if (!u || !u.dem) return e; const c = u.dem, h = 1 << u.tileID.canonical.z, p = (o * h - u.tileID.canonical.x) * c.dim, f = (t.y * h - u.tileID.canonical.y) * c.dim, d = Math.floor(p), y = Math.floor(f); return (r ? this.exaggeration() : 1) * Mr(Mr(c.get(d, y), c.get(d, y + 1), f - y), Mr(c.get(d + 1, y), c.get(d + 1, y + 1), f - y), p - d) } getAtTileOffset(t, e, r) { const n = 1 << t.canonical.z; return this.getAtPointOrZero(new pu(t.wrap + (t.canonical.x + e / ko) / n, (t.canonical.y + r / ko) / n)) } getAtTileOffsetFunc(t, e, r, n) { return i => { const s = this.getAtTileOffset(t, i.x, i.y), a = n.upVector(t.canonical, i.x, i.y); return Ho(a, a, s * n.upVectorScale(t.canonical, e, r).metersToTile), a } } getForTilePoints(t, e, r, n) { if (this.isUsingMockSource()) return !1; const i = uy.create(this, t, n); return !!i && (e.forEach((t => { t[2] = this.exaggeration() * i.getElevationAt(t[0], t[1], r); })), !0) } getMinMaxForTile(t) { if (this.isUsingMockSource()) return null; const e = this.findDEMTileFor(t); if (!e || !e.dem) return null; const r = e.dem.tree, n = e.tileID, i = 1 << t.canonical.z - n.canonical.z; let s = t.canonical.x / i - n.canonical.x, a = t.canonical.y / i - n.canonical.y, o = 0; for (let e = 0; e < t.canonical.z - n.canonical.z && !r.leaves[o]; e++) { s *= 2, a *= 2; const t = 2 * Math.floor(a) + Math.floor(s); o = r.childOffsets[o] + t, s %= 1, a %= 1; } return { min: this.exaggeration() * r.minimums[o], max: this.exaggeration() * r.maximums[o] } } getMinElevationBelowMSL() { throw new Error("Pure virtual method called.") } raycast(t, e, r) { throw new Error("Pure virtual method called.") } pointCoordinate(t) { throw new Error("Pure virtual method called.") } _source() { throw new Error("Pure virtual method called.") } isUsingMockSource() { throw new Error("Pure virtual method called.") } exaggeration() { throw new Error("Pure virtual method called.") } findDEMTileFor(t) { throw new Error("Pure virtual method called.") } get visibleDemTiles() { throw new Error("Getter must be implemented in subclass.") } }, t.ErrorEvent = Kt, t.EvaluationParameters = $s, t.Event = Xt, t.Evented = Yt, t.FillExtrusionBucket = fh, t.Frustum = wl, t.FrustumCorners = bl, t.GLOBE_RADIUS = Al, t.GLOBE_SCALE_MATCH_LATITUDE = 45, t.GLOBE_ZOOM_THRESHOLD_MAX = 6, t.GLOBE_ZOOM_THRESHOLD_MIN = 5, t.GlobeSharedBuffers = class { constructor(t) { this._createGrid(t), this._createPoles(t); } destroy() { this._poleIndexBuffer.destroy(), this._gridBuffer.destroy(), this._gridIndexBuffer.destroy(), this._poleNorthVertexBuffer.destroy(), this._poleSouthVertexBuffer.destroy(); for (const t of this._poleSegments) t.destroy(); for (const t of this._gridSegments) t.withSkirts.destroy(), t.withoutSkirts.destroy(); if (this._wireframeIndexBuffer) { this._wireframeIndexBuffer.destroy(); for (const t of this._wireframeSegments) t.destroy(); } } _fillGridMeshWithLods(t, e) { const r = new sa, n = new wa, i = [], s = t + 1 + 2, a = e[0] + 1, o = e[0] + 1 + (1 + e.length), l = (t, e, r) => { let n = t === s - 1 ? t - 2 : 0 === t ? t : t - 1; return n += r ? 24575 : 0, [n, e] }; for (let t = 0; t < s; ++t) r.emplaceBack(...l(t, 0, !0)); for (let t = 0; t < a; ++t) for (let e = 0; e < s; ++e) r.emplaceBack(...l(e, t, (0 === e || e === s - 1) && !0)); for (let t = 0; t < e.length; ++t) { const n = e[t]; for (let t = 0; t < s; ++t) r.emplaceBack(...l(t, n, !0)); } for (let t = 0; t < e.length; ++t) { const a = n.length, l = e[t] + 1 + 2, u = new wa; for (let r = 0; r < l - 1; r++) { const i = r === l - 2, a = i ? s * (o - e.length + t - r) : s; for (let t = 0; t < s - 1; t++) { const e = r * s + t; 0 === r || i || 0 === t || t === s - 2 ? (u.emplaceBack(e + 1, e, e + a), u.emplaceBack(e + a, e + a + 1, e + 1)) : (n.emplaceBack(e + 1, e, e + a), n.emplaceBack(e + a, e + a + 1, e + 1)); } } const c = So.simpleSegment(0, a, r.length, n.length - a); for (let t = 0; t < u.uint16.length; t += 3) n.emplaceBack(u.uint16[t], u.uint16[t + 1], u.uint16[t + 2]); const h = So.simpleSegment(0, a, r.length, n.length - a); i.push({ withoutSkirts: c, withSkirts: h }); } return { vertices: r, indices: n, segments: i } } _createGrid(t) { const e = this._fillGridMeshWithLods(Sl, kl); this._gridSegments = e.segments, this._gridBuffer = t.createVertexBuffer(e.vertices, xl.members), this._gridIndexBuffer = t.createIndexBuffer(e.indices, !0); } _createPoles(t) { const e = new wa; for (let t = 0; t <= Sl; t++) e.emplaceBack(0, t + 1, t + 2); this._poleIndexBuffer = t.createIndexBuffer(e, !0); const r = new ka, n = new ka; this._poleSegments = []; for (let t = 0, e = 0; t < 5; t++) { const i = 360 / (1 << t); r.emplaceBack(0, -Al, 0, .5, 0), n.emplaceBack(0, -Al, 0, .5, 1); for (let t = 0; t <= Sl; t++) { const e = t / Sl, s = Mr(0, i, e), [a, o, l] = $l(Jl, Ql, s, Al); r.emplaceBack(a, o, l, e, 0), n.emplaceBack(a, o, l, e, 1); } this._poleSegments.push(So.simpleSegment(e, 0, 66, 64)), e += 66; } this._poleNorthVertexBuffer = t.createVertexBuffer(r, ml, !1), this._poleSouthVertexBuffer = t.createVertexBuffer(n, ml, !1); } getGridBuffers(t, e) { return [this._gridBuffer, this._gridIndexBuffer, e ? this._gridSegments[t].withSkirts : this._gridSegments[t].withoutSkirts] } getPoleBuffers(t) { return [this._poleNorthVertexBuffer, this._poleSouthVertexBuffer, this._poleIndexBuffer, this._poleSegments[t]] } getWirefameBuffers(t, e) { if (!this._wireframeSegments) { const e = new Ma, r = Sl, n = r + 1 + 2, i = 1; this._wireframeSegments = []; for (let t = 0, s = 0; t < kl.length; t++) { const a = kl[t]; for (let t = i; t < a + i; t++) for (let s = i; s < r + i; s++) { const r = t * n + s; e.emplaceBack(r, r + 1), e.emplaceBack(r, r + n), e.emplaceBack(r, r + n + 1); } const o = a * r * 3; this._wireframeSegments.push(So.simpleSegment(0, s, (a + 1) * n, o)), s += o; } this._wireframeIndexBuffer = t.createIndexBuffer(e); } return [this._gridBuffer, this._wireframeIndexBuffer, this._wireframeSegments[e]] } }, t.GlyphManager = cf, t.ImagePosition = Pp, t.LivePerformanceUtils = Lt, t.LngLat = ru, t.LngLatBounds = Io, t.LocalGlyphMode = uf, t.MAX_MERCATOR_LATITUDE = cu, t.MercatorCoordinate = pu, t.ONE_EM = Wh, t.OverscaledTileID = Mh, t.PerformanceMarkers = Vt, t.Properties = Js, t.RGBAImage = Qu, t.Ray = vl, t.RequestManager = class { constructor(t, e, r) { this._transformRequestFn = t, this._customAccessToken = e, this._silenceAuthErrors = !!r, this._createSkuToken(); } _createSkuToken() { const t = function() { let t = ""; for (let e = 0; e < 10; e++) t += "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ" [Math.floor(62 * Math.random())]; return { token: ["1", h, t].join(""), tokenExpiresAt: Date.now() + 432e5 } }(); this._skuToken = t.token, this._skuTokenExpiresAt = t.tokenExpiresAt; } _isSkuTokenExpired() { return Date.now() > this._skuTokenExpiresAt } transformRequest(t, e) { return this._transformRequestFn && this._transformRequestFn(t, e) || { url: t } } normalizeStyleURL(t, e) { if (!mt(t)) return t; const r = _t(t); return r.path = `/styles/v1${r.path}`, this._makeAPIURL(r, this._customAccessToken || e) } normalizeGlyphsURL(t, e) { if (!mt(t)) return t; const r = _t(t); return r.path = `/fonts/v1${r.path}`, this._makeAPIURL(r, this._customAccessToken || e) } normalizeSourceURL(t, e, r, n) { if (!mt(t)) return t; const i = _t(t); return i.path = `/v4/${i.authority}.json`, i.params.push("secure"), r && i.params.push(`language=${r}`), n && i.params.push(`worldview=${n}`), this._makeAPIURL(i, this._customAccessToken || e) } normalizeSpriteURL(t, e, r, n) { const i = _t(t); return mt(t) ? (i.path = `/styles/v1${i.path}/sprite${e}${r}`, this._makeAPIURL(i, this._customAccessToken || n)) : (i.path += `${e}${r}`, At(i)) } normalizeTileURL(t, e, r) { if (this._isSkuTokenExpired() && this._createSkuToken(), t && !mt(t)) return t; const n = _t(t); n.path = n.path.replace(/(\.(png|jpg)\d*)(?=$)/, `${e||r&&"raster"!==n.authority&&512===r?"@2x":""}${s.supported?".webp":"$1"}`), "raster" === n.authority ? n.path = `/${i.RASTER_URL_PREFIX}${n.path}` : (n.path = n.path.replace(/^.+\/v4\//, "/"), n.path = `/${i.TILE_URL_VERSION}${n.path}`); const a = this._customAccessToken || function(t) { for (const e of t) { const t = e.match(/^access_token=(.*)$/); if (t) return t[1] } return null }(n.params) || i.ACCESS_TOKEN; return i.REQUIRE_ACCESS_TOKEN && a && this._skuToken && n.params.push(`sku=${this._skuToken}`), this._makeAPIURL(n, a) } canonicalizeTileURL(t, e) { const r = _t(t); if (!r.path.match(/^(\/v4\/|\/raster\/v1\/)/) || !r.path.match(/\.[\w]+$/)) return t; let n = "mapbox://"; r.path.match(/^\/raster\/v1\//) ? n += `raster/${r.path.replace(`/${i.RASTER_URL_PREFIX}/`,"")}` : n += `tiles/${r.path.replace(`/${i.TILE_URL_VERSION}/`,"")}`; let s = r.params; return e && (s = s.filter((t => !t.match(/^access_token=/)))), s.length && (n += `?${s.join("&")}`), n } canonicalizeTileset(t, e) { const r = !!e && mt(e), n = []; for (const e of t.tiles || []) gt(e) ? n.push(this.canonicalizeTileURL(e, r)) : n.push(e); return n } _makeAPIURL(t, e) { const r = "See https://docs.mapbox.com/api/overview/#access-tokens-and-token-scopes", n = _t(i.API_URL); if (t.protocol = n.protocol, t.authority = n.authority, "http" === t.protocol) { const e = t.params.indexOf("secure"); e >= 0 && t.params.splice(e, 1); } if ("/" !== n.path && (t.path = `${n.path}${t.path}`), !i.REQUIRE_ACCESS_TOKEN) return At(t); if (e = e || i.ACCESS_TOKEN, !this._silenceAuthErrors) { if (!e) throw new Error(`An API access token is required to use Mapbox GL. ${r}`); if ("s" === e[0]) throw new Error(`Use a public access token (pk.*) with Mapbox GL, not a secret access token (sk.*). ${r}`) } return t.params = t.params.filter((t => -1 === t.indexOf("access_token"))), t.params.push(`access_token=${e||""}`), At(t) } }, t.ResourceType = st, t.SegmentVector = So, t.SourceCache = sy, t.StencilMode = ty, t.StructArrayLayout1ui2 = Ta, t.StructArrayLayout2f1f2i16 = xa, t.StructArrayLayout2i4 = sa, t.StructArrayLayout2ui4 = Ma, t.StructArrayLayout3f12 = ba, t.StructArrayLayout3ui6 = wa, t.StructArrayLayout4i8 = oa, t.StructArrayLayout5f20 = ka, t.Texture = _d, t.Tile = Fd, t.Transitionable = qs, t.Uniform1f = to, t.Uniform1i = class extends Qa { constructor(t) { super(t), this.current = 0; } set(t, e, r) { this.fetchUniformLocation(t, e) && this.current !== r && (this.current = r, this.gl.uniform1i(this.location, r)); } }, t.Uniform2f = class extends Qa { constructor(t) { super(t), this.current = [0, 0]; } set(t, e, r) { this.fetchUniformLocation(t, e) && (r[0] === this.current[0] && r[1] === this.current[1] || (this.current = r, this.gl.uniform2f(this.location, r[0], r[1]))); } }, t.Uniform3f = class extends Qa { constructor(t) { super(t), this.current = [0, 0, 0]; } set(t, e, r) { this.fetchUniformLocation(t, e) && (r[0] === this.current[0] && r[1] === this.current[1] && r[2] === this.current[2] || (this.current = r, this.gl.uniform3f(this.location, r[0], r[1], r[2]))); } }, t.Uniform4f = eo, t.UniformColor = ro, t.UniformMatrix2f = class extends Qa { constructor(t) { super(t), this.current = so; } set(t, e, r) { if (this.fetchUniformLocation(t, e)) for (let t = 0; t < 4; t++) if (r[t] !== this.current[t]) { this.current = r, this.gl.uniformMatrix2fv(this.location, !1, r); break } } }, t.UniformMatrix3f = class extends Qa { constructor(t) { super(t), this.current = io; } set(t, e, r) { if (this.fetchUniformLocation(t, e)) for (let t = 0; t < 9; t++) if (r[t] !== this.current[t]) { this.current = r, this.gl.uniformMatrix3fv(this.location, !1, r); break } } }, t.UniformMatrix4f = class extends Qa { constructor(t) { super(t), this.current = no; } set(t, e, r) { if (this.fetchUniformLocation(t, e)) { if (r[12] !== this.current[12] || r[0] !== this.current[0]) return this.current = r, void this.gl.uniformMatrix4fv(this.location, !1, r); for (let t = 1; t < 16; t++) if (r[t] !== this.current[t]) { this.current = r, this.gl.uniformMatrix4fv(this.location, !1, r); break } } } }, t.UnwrappedTileID = Ih, t.ValidationError = Wn, t.VectorTileFeature = ah, t.VectorTileWorkerSource = class extends Yt { constructor(t, e, r, n, i) { super(), this.actor = t, this.layerIndex = e, this.availableImages = r, this.loadVectorData = i || xy, this.loading = {}, this.loaded = {}, this.deduped = new gy(t.scheduler), this.isSpriteLoaded = n, this.scheduler = t.scheduler; } loadTile(t, e) { const r = t.uid, n = t && t.request, i = n && n.collectResourceTiming, s = this.loading[r] = new yy(t); s.abort = this.loadVectorData(t, ((a, o) => { const l = !this.loading[r]; if (delete this.loading[r], l || a || !o) return s.status = "done", l || (this.loaded[r] = s), e(a); const u = o.rawData, c = {}; o.expires && (c.expires = o.expires), o.cacheControl && (c.cacheControl = o.cacheControl), s.vectorTile = o.vectorTile || new sh(new op(u)); const h = () => { s.parse(s.vectorTile, this.layerIndex, this.availableImages, this.actor, ((t, r) => { if (t || !r) return e(t); const s = {}; if (i) { const t = jt(n); t.length > 0 && (s.resourceTiming = JSON.parse(JSON.stringify(t))); } e(null, z({ rawTileData: u.slice(0) }, r, c, s)); })); }; this.isSpriteLoaded ? h() : this.once("isSpriteLoaded", (() => { this.scheduler ? this.scheduler.add(h, { type: "parseTile", isSymbolTile: t.isSymbolTile, zoom: t.tileZoom }) : h(); })), this.loaded = this.loaded || {}, this.loaded[r] = s; })); } reloadTile(t, e) { const r = this.loaded, n = t.uid, i = this; if (r && r[n]) { const s = r[n]; s.showCollisionBoxes = t.showCollisionBoxes, s.enableTerrain = !!t.enableTerrain, s.projection = t.projection, s.tileTransform = Vf(t.tileID.canonical, t.projection); const a = (t, r) => { const n = s.reloadCallback; n && (delete s.reloadCallback, s.parse(s.vectorTile, i.layerIndex, this.availableImages, i.actor, n)), e(t, r); }; "parsing" === s.status ? s.reloadCallback = a : "done" === s.status && (s.vectorTile ? s.parse(s.vectorTile, this.layerIndex, this.availableImages, this.actor, a) : a()); } } abortTile(t, e) { const r = t.uid, n = this.loading[r]; n && (n.abort && n.abort(), delete this.loading[r]), e(); } removeTile(t, e) { const r = this.loaded, n = t.uid; r && r[n] && delete r[n], e(); } }, t.WritingMode = Vp, t.ZoomDependentExpression = Xn, t.add = Go, t.addDynamicAttributes = od, t.adjoint = function(t, e) { var r = e[0], n = e[1], i = e[2], s = e[3], a = e[4], o = e[5], l = e[6], u = e[7], c = e[8]; return t[0] = a * c - o * u, t[1] = i * u - n * c, t[2] = n * o - i * a, t[3] = o * l - s * c, t[4] = r * c - i * l, t[5] = i * s - r * o, t[6] = s * u - a * l, t[7] = n * l - r * u, t[8] = r * a - n * s, t }, t.asyncAll = M, t.bezier = _, t.bindAll = V, t.boundsAttributes = Vd, t.bufferConvexPolygon = function(t, e) { const r = []; for (let n = 0; n < t.length; n++) { const i = I(n - 1, -1, t.length - 1), s = I(n + 1, -1, t.length - 1), a = t[n], o = t[s], l = t[i].sub(a).unit(), u = o.sub(a).unit(), c = u.angleWithSep(l.x, l.y), h = l.add(u).unit().mult(-1 * e / Math.sin(c / 2)); r.push(a.add(h)); } return r }, t.cacheEntryPossiblyAdded = function(t) { it++, it > tt && (t.getActor().send("enforceCacheSizeLimit", Q), it = 0); }, t.calculateGlobeLabelMatrix = function(t, e) { const { x: r, y: n } = t.point, i = Xl(r, n, t.worldSize / t._pixelsPerMercatorPixel, 0, 0); return Po(i, i, Zl(Pl(e))) }, t.calculateGlobeMatrix = function(t) { const { x: e, y: r } = t.point, { lng: n, lat: i } = t._center; return Xl(e, r, t.worldSize, n, i) }, t.calculateGlobeMercatorMatrix = function(t) { const e = t.pixelsPerMeter, r = e / au(1, t.center.lat), n = Eo(new Float64Array(16)); return Do(n, n, [t.point.x, t.point.y, 0]), Vo(n, n, [r, r, e]), Float32Array.from(n) }, t.circumferenceAtLatitude = nu, t.clamp = S, t.clearTileCache = function(t) { if (!et()) return; const r = e.caches.delete(H); t && r.catch(t).then((() => t())); }, t.clipLine = sf, t.clone = function(t) { var e = new To(16); return e[0] = t[0], e[1] = t[1], e[2] = t[2], e[3] = t[3], e[4] = t[4], e[5] = t[5], e[6] = t[6], e[7] = t[7], e[8] = t[8], e[9] = t[9], e[10] = t[10], e[11] = t[11], e[12] = t[12], e[13] = t[13], e[14] = t[14], e[15] = t[15], e }, t.clone$1 = j, t.collisionCircleLayout = Hh, t.config = i, t.conjugate = function(t, e) { return t[0] = -e[0], t[1] = -e[1], t[2] = -e[2], t[3] = e[3], t }, t.create = function() { var t = new To(16); return To != Float32Array && (t[1] = 0, t[2] = 0, t[3] = 0, t[4] = 0, t[6] = 0, t[7] = 0, t[8] = 0, t[9] = 0, t[11] = 0, t[12] = 0, t[13] = 0, t[14] = 0), t[0] = 1, t[5] = 1, t[10] = 1, t[15] = 1, t }, t.create$1 = zo, t.createExpression = Gn, t.createLayout = na, t.createStyleLayer = function(t) { return "custom" === t.type ? new xd(t) : new wd[t.type](t) }, t.cross = tl, t.degToRad = x, t.distance = function(t, e) { return Math.hypot(e[0] - t[0], e[1] - t[1], e[2] - t[2]) }, t.div = function(t, e, r) { return t[0] = e[0] / r[0], t[1] = e[1] / r[1], t[2] = e[2] / r[2], t }, t.dot = Qo, t.earthRadius = tu, t.ease = A, t.easeCubicInOut = w, t.ecefToLatLng = function([t, e, r]) { const n = Math.hypot(t, e, r), i = Math.atan2(t, r), s = .5 * Math.PI - Math.acos(-e / n); return new ru(v(i), v(s)) }, t.emitValidationErrors = Ri, t.endsWith = L, t.enforceCacheSizeLimit = function(t) { rt(), W && W.then((e => { e.keys().then((r => { for (let n = 0; n < r.length - t; n++) e.delete(r[n]); })); })); }, t.evaluateSizeForFeature = tp, t.evaluateSizeForZoom = ep, t.evaluateVariableOffset = Sf, t.evented = Ls, t.exactEquals = function(t, e) { return t[0] === e[0] && t[1] === e[1] && t[2] === e[2] && t[3] === e[3] }, t.exactEquals$1 = function(t, e) { return t[0] === e[0] && t[1] === e[1] && t[2] === e[2] }, t.exported = Nt, t.exported$1 = s, t.extend = z, t.extend$1 = Wt, t.fillExtrusionHeightLift = bh, t.filterObject = R, t.fromMat4 = function(t, e) { return t[0] = e[0], t[1] = e[1], t[2] = e[2], t[3] = e[4], t[4] = e[5], t[5] = e[6], t[6] = e[8], t[7] = e[9], t[8] = e[10], t }, t.fromQuat = function(t, e) { var r = e[0], n = e[1], i = e[2], s = e[3], a = r + r, o = n + n, l = i + i, u = r * a, c = n * a, h = n * o, p = i * a, f = i * o, d = i * l, y = s * a, m = s * o, g = s * l; return t[0] = 1 - h - d, t[1] = c + g, t[2] = p - m, t[3] = 0, t[4] = c - g, t[5] = 1 - u - d, t[6] = f + y, t[7] = 0, t[8] = p + m, t[9] = f - y, t[10] = 1 - u - h, t[11] = 0, t[12] = 0, t[13] = 0, t[14] = 0, t[15] = 1, t }, t.fromRotation = function(t, e) { var r = Math.sin(e), n = Math.cos(e); return t[0] = n, t[1] = r, t[2] = 0, t[3] = -r, t[4] = n, t[5] = 0, t[6] = 0, t[7] = 0, t[8] = 1, t }, t.fromScaling = Ro, t.furthestTileCorner = function(t) { const e = Math.round((t + 45 + 360) % 360 / 90) % 4; return b[e] }, t.getAABBPointSquareDist = function(t, e, r) { let n = 0; for (let i = 0; i < 2; ++i) { const s = r ? r[i] : 0; t[i] > s && (n += (t[i] - s) * (t[i] - s)), e[i] < s && (n += (s - e[i]) * (s - e[i])); } return n }, t.getAnchorAlignment = Zp, t.getAnchorJustification = If, t.getBounds = function(t) { let e = 1 / 0, r = 1 / 0, n = -1 / 0, i = -1 / 0; for (const s of t) e = Math.min(e, s.x), r = Math.min(r, s.y), n = Math.max(n, s.x), i = Math.max(i, s.y); return { min: new d(e, r), max: new d(n, i) } }, t.getColumn = Y, t.getGridMatrix = function(t, e, r, n) { const i = e.getNorth(), s = e.getSouth(), a = e.getWest(), o = e.getEast(), l = 1 << t.z, u = o - a, c = i - s, h = u / Sl, p = -c / kl[r], f = [0, h, 0, p, 0, 0, i, a, 0]; if (t.z > 0) { const t = 180 / n; Bo(f, f, [t / u + 1, 0, 0, 0, t / c + 1, 0, -.5 * t / h, .5 * t / p, 1]); } return f[2] = l, f[5] = t.x, f[8] = t.y, f }, t.getImage = dt, t.getJSON = function(t, e) { return lt(z(t, { type: "json" }), e) }, t.getLatitudinalLod = function(t) { const e = cu - 5; t = S(t, -e, e) / e * 90; const r = Math.pow(Math.abs(Math.sin(x(t))), 3); return Math.round(r * (kl.length - 1)) }, t.getMapSessionAPI = Pt, t.getPerformanceMeasurement = jt, t.getProjection = rd, t.getRTLTextPluginStatus = Fs, t.getReferrer = ot, t.getTilePoint = function(t, { x: e, y: r }, n = 0) { return new d(((e - n) * t.scale - t.x) * ko, (r * t.scale - t.y) * ko) }, t.getTileVec3 = function(t, e, r = 0) { return No(((e.x - r) * t.scale - t.x) * ko, (e.y * t.scale - t.y) * ko, uu(e.z, e.y)) }, t.getVideo = function(t, r) { const n = e.document.createElement("video"); n.muted = !0, n.onloadstart = function() { r(null, n); }; for (let r = 0; r < t.length; r++) { const i = e.document.createElement("source"); ct(t[r]) || (n.crossOrigin = "Anonymous"), i.src = t[r], n.appendChild(i); } return { cancel: () => {} } }, t.globeCenterToScreenPoint = function(t) { const e = [0, 0, 0], r = Eo(new Float64Array(16)); return Po(r, t.pixelMatrix, t.globeMatrix), el(e, e, r), new d(e[0], e[1]) }, t.globeDenormalizeECEF = Zl, t.globeECEFOrigin = function(t, e) { const r = [0, 0, 0]; return el(r, r, Gl(Pl(e.canonical))), el(r, r, t), r }, t.globeMetersToEcef = zl, t.globeNormalizeECEF = Gl, t.globePixelsToTileUnits = function(t, e) { return ko / (512 * Math.pow(2, t)) * ql(Pl(e)) }, t.globePoleMatrixForTile = function(t, e, r) { const n = Eo(new Float64Array(16)), i = (e / (1 << t) - .5) * Math.PI * 2; return Fo(n, r.globeMatrix, i), Float32Array.from(n) }, t.globeTileBounds = Pl, t.globeTiltAtLngLat = Yl, t.globeToMercatorTransition = Kl, t.globeUseCustomAntiAliasing = function(t, e, r) { const n = Kl(r.zoom), i = t.style.map._antialias, s = !!e.extStandardDerivatives, a = e.extStandardDerivativesForceOff || t.terrain && t.terrain.exaggeration() > 0; return 0 === n && !i && !a && s }, t.identity = Eo, t.identity$1 = hl, t.invert = Co, t.isFullscreen = function() { return !!e.document.fullscreenElement || !!e.document.webkitFullscreenElement }, t.isLngLatBehindGlobe = Hl, t.isMapAuthenticated = function(t) { return Dt.has(t) }, t.isMapboxURL = mt, t.isSafariWithAntialiasingBug = function(t) { const e = t.navigator ? t.navigator.userAgent : null; return !!X(t) && e && (e.match("Version/15.4") || e.match("Version/15.5") || e.match(/CPU (OS|iPhone OS) (15_4|15_5) like Mac OS X/)) }, t.latFromMercatorY = lu, t.latLngToECEF = Ul, t.len = al, t.length = qo, t.length$1 = function(t) { return Math.hypot(t[0], t[1], t[2], t[3]) }, t.lngFromMercatorX = ou, t.loadVectorTile = xy, t.makeRequest = lt, t.mapValue = function(t, e, r, n, i) { return S((t - e) / (r - e) * (i - n) + n, n, i) }, t.mercatorScale = hu, t.mercatorXfromLng = iu, t.mercatorYfromLat = su, t.mercatorZfromAltitude = au, t.mul = $o, t.mul$1 = sl, t.multiply = Po, t.multiply$1 = Bo, t.multiply$2 = Xo, t.nextPowerOfTwo = P, t.normalize = Jo, t.normalize$1 = dl, t.normalize$2 = ll, t.number = Mr, t.ortho = function(t, e, r, n, i, s, a) { var o = 1 / (e - r), l = 1 / (n - i), u = 1 / (s - a); return t[0] = -2 * o, t[1] = 0, t[2] = 0, t[3] = 0, t[4] = 0, t[5] = -2 * l, t[6] = 0, t[7] = 0, t[8] = 0, t[9] = 0, t[10] = 2 * u, t[11] = 0, t[12] = (e + r) * o, t[13] = (i + n) * l, t[14] = (a + s) * u, t[15] = 1, t }, t.pbf = op, t.perspective = function(t, e, r, n, i) { var s, a = 1 / Math.tan(e / 2); return t[0] = a / r, t[1] = 0, t[2] = 0, t[3] = 0, t[4] = 0, t[5] = a, t[6] = 0, t[7] = 0, t[8] = 0, t[9] = 0, t[11] = -1, t[12] = 0, t[13] = 0, t[15] = 0, null != i && i !== 1 / 0 ? (t[10] = (i + n) * (s = 1 / (n - i)), t[14] = 2 * i * n * s) : (t[10] = -1, t[14] = -2 * n), t }, t.pick = function(t, e) { const r = {}; for (let n = 0; n < e.length; n++) { const i = e[n]; i in t && (r[i] = t[i]); } return r }, t.plugin = js, t.pointGeometry = d, t.polesInViewport = function(t) { const e = Eo(new Float64Array(16)); Po(e, t.pixelMatrix, t.globeMatrix); const r = [0, Il, 0], n = [0, Ml, 0]; return el(r, r, e), el(n, n, e), [r[0] > 0 && r[0] <= t.width && r[1] > 0 && r[1] <= t.height && !Hl(t, new ru(t.center.lat, 90)), n[0] > 0 && n[0] <= t.width && n[1] > 0 && n[1] <= t.height && !Hl(t, new ru(t.center.lat, -90))] }, t.polygonContainsPoint = Du, t.polygonIntersectsBox = Vu, t.polygonIntersectsPolygon = ku, t.polygonizeBounds = function(t, e, r = 0, n = !0) { const i = new d(r, r), s = t.sub(i), a = e.add(i), o = [s, new d(a.x, s.y), a, new d(s.x, a.y)]; return n && o.push(s.clone()), o }, t.posAttributes = xl, t.postMapLoadEvent = zt, t.postPerformanceEvent = Et, t.postTurnstileEvent = Mt, t.potpack = Cp, t.prevPowerOfTwo = function(t) { return t <= 1 ? 1 : Math.pow(2, Math.floor(Math.log(t) / Math.LN2)) }, t.radToDeg = v, t.refProperties = ["type", "source", "source-layer", "minzoom", "maxzoom", "filter", "layout"], t.registerForPluginStateChange = function(t) { return t({ pluginStatus: Cs, pluginURL: Ps }), Ls.on("pluginStateChange", t), t }, t.removeAuthState = function(t) { Dt.delete(t); }, t.renderColorRamp = ec, t.resample = du, t.rotateX = Lo, t.rotateX$1 = pl, t.rotateY = Fo, t.rotateY$1 = fl, t.rotateZ = function(t, e, r) { var n = Math.sin(r), i = Math.cos(r), s = e[0], a = e[1], o = e[2], l = e[3], u = e[4], c = e[5], h = e[6], p = e[7]; return e !== t && (t[8] = e[8], t[9] = e[9], t[10] = e[10], t[11] = e[11], t[12] = e[12], t[13] = e[13], t[14] = e[14], t[15] = e[15]), t[0] = s * i + u * n, t[1] = a * i + c * n, t[2] = o * i + h * n, t[3] = l * i + p * n, t[4] = u * i - s * n, t[5] = c * i - a * n, t[6] = h * i - o * n, t[7] = p * i - l * n, t }, t.rotateZ$1 = function(t, e, r) { r *= .5; var n = e[0], i = e[1], s = e[2], a = e[3], o = Math.sin(r), l = Math.cos(r); return t[0] = n * l + i * o, t[1] = i * l - n * o, t[2] = s * l + a * o, t[3] = a * l - s * o, t }, t.scale = Vo, t.scale$1 = ol, t.scale$2 = Ho, t.scaleAndAdd = Wo, t.set = function(t, e, r, n) { return t[0] = e, t[1] = r, t[2] = n, t }, t.setCacheLimits = function(t, e) { Q = t, tt = e; }, t.setColumn = function(t, e, r) { t[4 * e + 0] = r[0], t[4 * e + 1] = r[1], t[4 * e + 2] = r[2], t[4 * e + 3] = r[3]; }, t.setRTLTextPlugin = function(t, e, r = !1) { if (Cs === Ts || Cs === zs || Cs === Bs) throw new Error("setRTLTextPlugin cannot be called multiple times."); Ps = Nt.resolveURL(t), Cs = Ts, Es = e, Vs(), r || Rs(); }, t.smoothstep = k, t.spec = Ht, t.squaredLength = function(t) { var e = t[0], r = t[1], n = t[2]; return e * e + r * r + n * n }, t.storeAuthState = function(t, e) { e ? Dt.add(t) : Dt.delete(t); }, t.sub = il, t.subtract = Zo, t.symbolSize = rp, t.tileAABB = function(t, e, r, n, i, s, a, o, l) { if ("globe" === l.name) return Fl(t, e, new kh(r, n, i)); const u = Vf({ z: r, x: n, y: i }, l); return new _l([(s + u.x / u.scale) * e, e * (u.y / u.scale), a], [(s + u.x2 / u.scale) * e, e * (u.y2 / u.scale), o]) }, t.tileCornersToBounds = Rl, t.tileTransform = Vf, t.transformMat3 = function(t, e, r) { var n = e[0], i = e[1], s = e[2]; return t[0] = n * r[0] + i * r[3] + s * r[6], t[1] = n * r[1] + i * r[4] + s * r[7], t[2] = n * r[2] + i * r[5] + s * r[8], t }, t.transformMat4 = el, t.transformMat4$1 = ul, t.transformQuat = rl, t.transitionTileAABBinECEF = Vl, t.translate = Do, t.transpose = function(t, e) { if (t === e) { var r = e[1], n = e[2], i = e[5]; t[1] = e[3], t[2] = e[6], t[3] = r, t[5] = e[7], t[6] = n, t[7] = i; } else t[0] = e[0], t[1] = e[3], t[2] = e[6], t[3] = e[1], t[4] = e[4], t[5] = e[7], t[6] = e[2], t[7] = e[5], t[8] = e[8]; return t }, t.triggerPluginCompletionEvent = Ds, t.uniqueId = E, t.updateGlobeVertexNormal = function(t, e, r, n, i) { const s = 5 * e + 2; t.float32[s + 0] = r, t.float32[s + 1] = n, t.float32[s + 2] = i; }, t.validateCustomStyleLayer = function(t) { const e = [], r = t.id; return void 0 === r && e.push({ message: `layers.${r}: missing required property "id"` }), void 0 === t.render && e.push({ message: `layers.${r}: missing required method "render"` }), t.renderingMode && "2d" !== t.renderingMode && "3d" !== t.renderingMode && e.push({ message: `layers.${r}: property "renderingMode" must be either "2d" or "3d"` }), e }, t.validateFilter = t => Fi(xi(t)), t.validateFog = t => Fi(Bi(t)), t.validateLayer = t => Fi(Ai(t)), t.validateLight = t => Fi(Ti(t)), t.validateSource = t => Fi(Ii(t)), t.validateStyle = Di, t.validateTerrain = t => Fi(zi(t)), t.values = T, t.vectorTile = Xc, t.version = r, t.warnOnce = U, t.window = e, t.wrap = I; })); define(["./shared"], (function(e) { "use strict"; function t(e) { if ("number" == typeof e || "boolean" == typeof e || "string" == typeof e || null == e) return JSON.stringify(e); if (Array.isArray(e)) { let r = "["; for (const o of e) r += `${t(o)},`; return `${r}]` } let r = "{"; for (const o of Object.keys(e).sort()) r += `${o}:${t(e[o])},`; return `${r}}` } function r(r) { let o = ""; for (const n of e.refProperties) o += `/${t(r[n])}`; return o } class o { constructor(e) { this.keyCache = {}, e && this.replace(e); } replace(e) { this._layerConfigs = {}, this._layers = {}, this.update(e, []); } update(t, o) { for (const r of t) this._layerConfigs[r.id] = r, (this._layers[r.id] = e.createStyleLayer(r)).compileFilter(), this.keyCache[r.id] && delete this.keyCache[r.id]; for (const e of o) delete this.keyCache[e], delete this._layerConfigs[e], delete this._layers[e]; this.familiesBySource = {}; const n = function(e, t) { const o = {}; for (let n = 0; n < e.length; n++) { const i = t && t[e[n].id] || r(e[n]); t && (t[e[n].id] = i); let s = o[i]; s || (s = o[i] = []), s.push(e[n]); } const n = []; for (const e in o) n.push(o[e]); return n }(e.values(this._layerConfigs), this.keyCache); for (const e of n) { const t = e.map((e => this._layers[e.id])), r = t[0]; if ("none" === r.visibility) continue; const o = r.source || ""; let n = this.familiesBySource[o]; n || (n = this.familiesBySource[o] = {}); const i = r.sourceLayer || "_geojsonTileLayer"; let s = n[i]; s || (s = n[i] = []), s.push(t); } } } class n { loadTile(t, r) { const { uid: o, encoding: n, rawImageData: i, padding: s, buildQuadTree: a } = t, l = e.window.ImageBitmap && i instanceof e.window.ImageBitmap ? this.getImageData(i, s) : i; r(null, new e.DEMData(o, l, n, s < 1, a)); } getImageData(e, t) { this.offscreenCanvas && this.offscreenCanvasContext || (this.offscreenCanvas = new OffscreenCanvas(e.width, e.height), this.offscreenCanvasContext = this.offscreenCanvas.getContext("2d", { willReadFrequently: !0 })), this.offscreenCanvas.width = e.width, this.offscreenCanvas.height = e.height, this.offscreenCanvasContext.drawImage(e, 0, 0, e.width, e.height); const r = this.offscreenCanvasContext.getImageData(-t, -t, e.width + 2 * t, e.height + 2 * t); return this.offscreenCanvasContext.clearRect(0, 0, this.offscreenCanvas.width, this.offscreenCanvas.height), r } } var i = function e(t, r) { var o, n = t && t.type; if ("FeatureCollection" === n) for (o = 0; o < t.features.length; o++) e(t.features[o], r); else if ("GeometryCollection" === n) for (o = 0; o < t.geometries.length; o++) e(t.geometries[o], r); else if ("Feature" === n) e(t.geometry, r); else if ("Polygon" === n) s(t.coordinates, r); else if ("MultiPolygon" === n) for (o = 0; o < t.coordinates.length; o++) s(t.coordinates[o], r); return t }; function s(e, t) { if (0 !== e.length) { a(e[0], t); for (var r = 1; r < e.length; r++) a(e[r], !t); } } function a(e, t) { for (var r = 0, o = 0, n = 0, i = e.length, s = i - 1; n < i; s = n++) { var a = (e[n][0] - e[s][0]) * (e[s][1] + e[n][1]), l = r + a; o += Math.abs(r) >= Math.abs(a) ? r - l + a : a - l + r, r = l; } r + o >= 0 != !!t && e.reverse(); } const l = e.VectorTileFeature.prototype.toGeoJSON; class u { constructor(t) { this._feature = t, this.extent = e.EXTENT, this.type = t.type, this.properties = t.tags, "id" in t && !isNaN(t.id) && (this.id = parseInt(t.id, 10)); } loadGeometry() { if (1 === this._feature.type) { const t = []; for (const r of this._feature.geometry) t.push([new e.pointGeometry(r[0], r[1])]); return t } { const t = []; for (const r of this._feature.geometry) { const o = []; for (const t of r) o.push(new e.pointGeometry(t[0], t[1])); t.push(o); } return t } } toGeoJSON(e, t, r) { return l.call(this, e, t, r) } } class h { constructor(t) { this.layers = { _geojsonTileLayer: this }, this.name = "_geojsonTileLayer", this.extent = e.EXTENT, this.length = t.length, this._features = t; } feature(e) { return new u(this._features[e]) } } var c = {}, f = { get exports() { return c }, set exports(e) { c = e; } }, p = e.pointGeometry, g = e.vectorTile.VectorTileFeature, d = m; function m(e, t) { this.options = t || {}, this.features = e, this.length = e.length; } function y(e, t) { this.id = "number" == typeof e.id ? e.id : void 0, this.type = e.type, this.rawGeometry = 1 === e.type ? [e.geometry] : e.geometry, this.properties = e.tags, this.extent = t || 4096; } m.prototype.feature = function(e) { return new y(this.features[e], this.options.extent) }, y.prototype.loadGeometry = function() { var e = this.rawGeometry; this.geometry = []; for (var t = 0; t < e.length; t++) { for (var r = e[t], o = [], n = 0; n < r.length; n++) o.push(new p(r[n][0], r[n][1])); this.geometry.push(o); } return this.geometry }, y.prototype.bbox = function() { this.geometry || this.loadGeometry(); for (var e = this.geometry, t = 1 / 0, r = -1 / 0, o = 1 / 0, n = -1 / 0, i = 0; i < e.length; i++) for (var s = e[i], a = 0; a < s.length; a++) { var l = s[a]; t = Math.min(t, l.x), r = Math.max(r, l.x), o = Math.min(o, l.y), n = Math.max(n, l.y); } return [t, o, r, n] }, y.prototype.toGeoJSON = g.prototype.toGeoJSON; var v = e.pbf, x = d; function w(e) { var t = new v; return function(e, t) { for (var r in e.layers) t.writeMessage(3, S, e.layers[r]); }(e, t), t.finish() } function S(e, t) { var r; t.writeVarintField(15, e.version || 1), t.writeStringField(1, e.name || ""), t.writeVarintField(5, e.extent || 4096); var o = { keys: [], values: [], keycache: {}, valuecache: {} }; for (r = 0; r < e.length; r++) o.feature = e.feature(r), t.writeMessage(2, M, o); var n = o.keys; for (r = 0; r < n.length; r++) t.writeStringField(3, n[r]); var i = o.values; for (r = 0; r < i.length; r++) t.writeMessage(4, T, i[r]); } function M(e, t) { var r = e.feature; void 0 !== r.id && t.writeVarintField(1, r.id), t.writeMessage(2, P, e), t.writeVarintField(3, r.type), t.writeMessage(4, I, r); } function P(e, t) { var r = e.feature, o = e.keys, n = e.values, i = e.keycache, s = e.valuecache; for (var a in r.properties) { var l = r.properties[a], u = i[a]; if (null !== l) { void 0 === u && (o.push(a), i[a] = u = o.length - 1), t.writeVarint(u); var h = typeof l; "string" !== h && "boolean" !== h && "number" !== h && (l = JSON.stringify(l)); var c = h + ":" + l, f = s[c]; void 0 === f && (n.push(l), s[c] = f = n.length - 1), t.writeVarint(f); } } } function b(e, t) { return (t << 3) + (7 & e) } function k(e) { return e << 1 ^ e >> 31 } function I(e, t) { for (var r = e.loadGeometry(), o = e.type, n = 0, i = 0, s = r.length, a = 0; a < s; a++) { var l = r[a], u = 1; 1 === o && (u = l.length), t.writeVarint(b(1, u)); for (var h = 3 === o ? l.length - 1 : l.length, c = 0; c < h; c++) { 1 === c && 1 !== o && t.writeVarint(b(2, h - 1)); var f = l[c].x - n, p = l[c].y - i; t.writeVarint(k(f)), t.writeVarint(k(p)), n += f, i += p; } 3 === o && t.writeVarint(b(7, 1)); } } function T(e, t) { var r = typeof e; "string" === r ? t.writeStringField(1, e) : "boolean" === r ? t.writeBooleanField(7, e) : "number" === r && (e % 1 != 0 ? t.writeDoubleField(3, e) : e < 0 ? t.writeSVarintField(6, e) : t.writeVarintField(5, e)); } function _(e, t, r, o, n, i) { if (n - o <= r) return; const s = o + n >> 1; L(e, t, s, o, n, i % 2), _(e, t, r, o, s - 1, i + 1), _(e, t, r, s + 1, n, i + 1); } function L(e, t, r, o, n, i) { for (; n > o;) { if (n - o > 600) { const s = n - o + 1, a = r - o + 1, l = Math.log(s), u = .5 * Math.exp(2 * l / 3), h = .5 * Math.sqrt(l * u * (s - u) / s) * (a - s / 2 < 0 ? -1 : 1); L(e, t, r, Math.max(o, Math.floor(r - a * u / s + h)), Math.min(n, Math.floor(r + (s - a) * u / s + h)), i); } const s = t[2 * r + i]; let a = o, l = n; for (C(e, t, o, r), t[2 * n + i] > s && C(e, t, o, n); a < l;) { for (C(e, t, a, l), a++, l--; t[2 * a + i] < s;) a++; for (; t[2 * l + i] > s;) l--; } t[2 * o + i] === s ? C(e, t, o, l) : (l++, C(e, t, l, n)), l <= r && (o = l + 1), r <= l && (n = l - 1); } } function C(e, t, r, o) { O(e, r, o), O(t, 2 * r, 2 * o), O(t, 2 * r + 1, 2 * o + 1); } function O(e, t, r) { const o = e[t]; e[t] = e[r], e[r] = o; } function z(e, t, r, o) { const n = e - r, i = t - o; return n * n + i * i } f.exports = w, c.fromVectorTileJs = w, c.fromGeojsonVt = function(e, t) { t = t || {}; var r = {}; for (var o in e) r[o] = new x(e[o].features, t), r[o].name = o, r[o].version = t.version, r[o].extent = t.extent; return w({ layers: r }) }, c.GeoJSONWrapper = x; const E = e => e[0], F = e => e[1]; class N { constructor(e, t = E, r = F, o = 64, n = Float64Array) { this.nodeSize = o, this.points = e; const i = e.length < 65536 ? Uint16Array : Uint32Array, s = this.ids = new i(e.length), a = this.coords = new n(2 * e.length); for (let o = 0; o < e.length; o++) s[o] = o, a[2 * o] = t(e[o]), a[2 * o + 1] = r(e[o]); _(s, a, o, 0, s.length - 1, 0); } range(e, t, r, o) { return function(e, t, r, o, n, i, s) { const a = [0, e.length - 1, 0], l = []; let u, h; for (; a.length;) { const c = a.pop(), f = a.pop(), p = a.pop(); if (f - p <= s) { for (let s = p; s <= f; s++) u = t[2 * s], h = t[2 * s + 1], u >= r && u <= n && h >= o && h <= i && l.push(e[s]); continue } const g = Math.floor((p + f) / 2); u = t[2 * g], h = t[2 * g + 1], u >= r && u <= n && h >= o && h <= i && l.push(e[g]); const d = (c + 1) % 2; (0 === c ? r <= u : o <= h) && (a.push(p), a.push(g - 1), a.push(d)), (0 === c ? n >= u : i >= h) && (a.push(g + 1), a.push(f), a.push(d)); } return l }(this.ids, this.coords, e, t, r, o, this.nodeSize) } within(e, t, r) { return function(e, t, r, o, n, i) { const s = [0, e.length - 1, 0], a = [], l = n * n; for (; s.length;) { const u = s.pop(), h = s.pop(), c = s.pop(); if (h - c <= i) { for (let n = c; n <= h; n++) z(t[2 * n], t[2 * n + 1], r, o) <= l && a.push(e[n]); continue } const f = Math.floor((c + h) / 2), p = t[2 * f], g = t[2 * f + 1]; z(p, g, r, o) <= l && a.push(e[f]); const d = (u + 1) % 2; (0 === u ? r - n <= p : o - n <= g) && (s.push(c), s.push(f - 1), s.push(d)), (0 === u ? r + n >= p : o + n >= g) && (s.push(f + 1), s.push(h), s.push(d)); } return a }(this.ids, this.coords, e, t, r, this.nodeSize) } } const j = { minZoom: 0, maxZoom: 16, minPoints: 2, radius: 40, extent: 512, nodeSize: 64, log: !1, generateId: !1, reduce: null, map: e => e }, Z = Math.fround || (G = new Float32Array(1), e => (G[0] = +e, G[0])); var G; class J { constructor(e) { this.options = B(Object.create(j), e), this.trees = new Array(this.options.maxZoom + 1); } load(e) { const { log: t, minZoom: r, maxZoom: o, nodeSize: n } = this.options; t && console.time("total time"); const i = `prepare ${e.length} points`; t && console.time(i), this.points = e; let s = []; for (let t = 0; t < e.length; t++) e[t].geometry && s.push(Y(e[t], t)); this.trees[o + 1] = new N(s, R, q, n, Float32Array), t && console.timeEnd(i); for (let e = o; e >= r; e--) { const r = +Date.now(); s = this._cluster(s, e), this.trees[e] = new N(s, R, q, n, Float32Array), t && console.log("z%d: %d clusters in %dms", e, s.length, +Date.now() - r); } return t && console.timeEnd("total time"), this } getClusters(e, t) { let r = ((e[0] + 180) % 360 + 360) % 360 - 180; const o = Math.max(-90, Math.min(90, e[1])); let n = 180 === e[2] ? 180 : ((e[2] + 180) % 360 + 360) % 360 - 180; const i = Math.max(-90, Math.min(90, e[3])); if (e[2] - e[0] >= 360) r = -180, n = 180; else if (r > n) { const e = this.getClusters([r, o, 180, i], t), s = this.getClusters([-180, o, n, i], t); return e.concat(s) } const s = this.trees[this._limitZoom(t)], a = s.range(A(r), D(i), A(n), D(o)), l = []; for (const e of a) { const t = s.points[e]; l.push(t.numPoints ? X(t) : this.points[t.index]); } return l } getChildren(e) { const t = this._getOriginId(e), r = this._getOriginZoom(e), o = "No cluster with the specified id.", n = this.trees[r]; if (!n) throw new Error(o); const i = n.points[t]; if (!i) throw new Error(o); const s = this.options.radius / (this.options.extent * Math.pow(2, r - 1)), a = n.within(i.x, i.y, s), l = []; for (const t of a) { const r = n.points[t]; r.parentId === e && l.push(r.numPoints ? X(r) : this.points[r.index]); } if (0 === l.length) throw new Error(o); return l } getLeaves(e, t, r) { const o = []; return this._appendLeaves(o, e, t = t || 10, r = r || 0, 0), o } getTile(e, t, r) { const o = this.trees[this._limitZoom(e)], n = Math.pow(2, e), { extent: i, radius: s } = this.options, a = s / i, l = (r - a) / n, u = (r + 1 + a) / n, h = { features: [] }; return this._addTileFeatures(o.range((t - a) / n, l, (t + 1 + a) / n, u), o.points, t, r, n, h), 0 === t && this._addTileFeatures(o.range(1 - a / n, l, 1, u), o.points, n, r, n, h), t === n - 1 && this._addTileFeatures(o.range(0, l, a / n, u), o.points, -1, r, n, h), h.features.length ? h : null } getClusterExpansionZoom(e) { let t = this._getOriginZoom(e) - 1; for (; t <= this.options.maxZoom;) { const r = this.getChildren(e); if (t++, 1 !== r.length) break; e = r[0].properties.cluster_id; } return t } _appendLeaves(e, t, r, o, n) { const i = this.getChildren(t); for (const t of i) { const i = t.properties; if (i && i.cluster ? n + i.point_count <= o ? n += i.point_count : n = this._appendLeaves(e, i.cluster_id, r, o, n) : n < o ? n++ : e.push(t), e.length === r) break } return n } _addTileFeatures(e, t, r, o, n, i) { for (const s of e) { const e = t[s], a = e.numPoints; let l, u, h; if (a) l = V(e), u = e.x, h = e.y; else { const t = this.points[e.index]; l = t.properties, u = A(t.geometry.coordinates[0]), h = D(t.geometry.coordinates[1]); } const c = { type: 1, geometry: [ [Math.round(this.options.extent * (u * n - r)), Math.round(this.options.extent * (h * n - o))] ], tags: l }; let f; a ? f = e.id : this.options.generateId ? f = e.index : this.points[e.index].id && (f = this.points[e.index].id), void 0 !== f && (c.id = f), i.features.push(c); } } _limitZoom(e) { return Math.max(this.options.minZoom, Math.min(Math.floor(+e), this.options.maxZoom + 1)) } _cluster(e, t) { const r = [], { radius: o, extent: n, reduce: i, minPoints: s } = this.options, a = o / (n * Math.pow(2, t)); for (let o = 0; o < e.length; o++) { const n = e[o]; if (n.zoom <= t) continue; n.zoom = t; const l = this.trees[t + 1], u = l.within(n.x, n.y, a), h = n.numPoints || 1; let c = h; for (const e of u) { const r = l.points[e]; r.zoom > t && (c += r.numPoints || 1); } if (c > h && c >= s) { let e = n.x * h, s = n.y * h, a = i && h > 1 ? this._map(n, !0) : null; const f = (o << 5) + (t + 1) + this.points.length; for (const r of u) { const o = l.points[r]; if (o.zoom <= t) continue; o.zoom = t; const u = o.numPoints || 1; e += o.x * u, s += o.y * u, o.parentId = f, i && (a || (a = this._map(n, !0)), i(a, this._map(o))); } n.parentId = f, r.push(W(e / c, s / c, f, c, a)); } else if (r.push(n), c > 1) for (const e of u) { const o = l.points[e]; o.zoom <= t || (o.zoom = t, r.push(o)); } } return r } _getOriginId(e) { return e - this.points.length >> 5 } _getOriginZoom(e) { return (e - this.points.length) % 32 } _map(e, t) { if (e.numPoints) return t ? B({}, e.properties) : e.properties; const r = this.points[e.index].properties, o = this.options.map(r); return t && o === r ? B({}, o) : o } } function W(e, t, r, o, n) { return { x: Z(e), y: Z(t), zoom: 1 / 0, id: r, parentId: -1, numPoints: o, properties: n } } function Y(e, t) { const [r, o] = e.geometry.coordinates; return { x: Z(A(r)), y: Z(D(o)), zoom: 1 / 0, index: t, parentId: -1 } } function X(e) { return { type: "Feature", id: e.id, properties: V(e), geometry: { type: "Point", coordinates: [(t = e.x, 360 * (t - .5)), $(e.y)] } }; var t; } function V(e) { const t = e.numPoints, r = t >= 1e4 ? `${Math.round(t/1e3)}k` : t >= 1e3 ? Math.round(t / 100) / 10 + "k" : t; return B(B({}, e.properties), { cluster: !0, cluster_id: e.id, point_count: t, point_count_abbreviated: r }) } function A(e) { return e / 360 + .5 } function D(e) { const t = Math.sin(e * Math.PI / 180), r = .5 - .25 * Math.log((1 + t) / (1 - t)) / Math.PI; return r < 0 ? 0 : r > 1 ? 1 : r } function $(e) { const t = (180 - 360 * e) * Math.PI / 180; return 360 * Math.atan(Math.exp(t)) / Math.PI - 90 } function B(e, t) { for (const r in t) e[r] = t[r]; return e } function R(e) { return e.x } function q(e) { return e.y } function U(e, t, r, o) { for (var n, i = o, s = r - t >> 1, a = r - t, l = e[t], u = e[t + 1], h = e[r], c = e[r + 1], f = t + 3; f < r; f += 3) { var p = Q(e[f], e[f + 1], l, u, h, c); if (p > i) n = f, i = p; else if (p === i) { var g = Math.abs(f - s); g < a && (n = f, a = g); } } i > o && (n - t > 3 && U(e, t, n, o), e[n + 2] = i, r - n > 3 && U(e, n, r, o)); } function Q(e, t, r, o, n, i) { var s = n - r, a = i - o; if (0 !== s || 0 !== a) { var l = ((e - r) * s + (t - o) * a) / (s * s + a * a); l > 1 ? (r = n, o = i) : l > 0 && (r += s * l, o += a * l); } return (s = e - r) * s + (a = t - o) * a } function H(e, t, r, o) { var n = { id: void 0 === e ? null : e, type: t, geometry: r, tags: o, minX: 1 / 0, minY: 1 / 0, maxX: -1 / 0, maxY: -1 / 0 }; return function(e) { var t = e.geometry, r = e.type; if ("Point" === r || "MultiPoint" === r || "LineString" === r) K(e, t); else if ("Polygon" === r || "MultiLineString" === r) for (var o = 0; o < t.length; o++) K(e, t[o]); else if ("MultiPolygon" === r) for (o = 0; o < t.length; o++) for (var n = 0; n < t[o].length; n++) K(e, t[o][n]); }(n), n } function K(e, t) { for (var r = 0; r < t.length; r += 3) e.minX = Math.min(e.minX, t[r]), e.minY = Math.min(e.minY, t[r + 1]), e.maxX = Math.max(e.maxX, t[r]), e.maxY = Math.max(e.maxY, t[r + 1]); } function ee(e, t, r, o) { if (t.geometry) { var n = t.geometry.coordinates, i = t.geometry.type, s = Math.pow(r.tolerance / ((1 << r.maxZoom) * r.extent), 2), a = [], l = t.id; if (r.promoteId ? l = t.properties[r.promoteId] : r.generateId && (l = o || 0), "Point" === i) te(n, a); else if ("MultiPoint" === i) for (var u = 0; u < n.length; u++) te(n[u], a); else if ("LineString" === i) re(n, a, s, !1); else if ("MultiLineString" === i) { if (r.lineMetrics) { for (u = 0; u < n.length; u++) re(n[u], a = [], s, !1), e.push(H(l, "LineString", a, t.properties)); return } oe(n, a, s, !1); } else if ("Polygon" === i) oe(n, a, s, !0); else { if ("MultiPolygon" !== i) { if ("GeometryCollection" === i) { for (u = 0; u < t.geometry.geometries.length; u++) ee(e, { id: l, geometry: t.geometry.geometries[u], properties: t.properties }, r, o); return } throw new Error("Input data is not a valid GeoJSON object.") } for (u = 0; u < n.length; u++) { var h = []; oe(n[u], h, s, !0), a.push(h); } } e.push(H(l, i, a, t.properties)); } } function te(e, t) { t.push(ne(e[0])), t.push(ie(e[1])), t.push(0); } function re(e, t, r, o) { for (var n, i, s = 0, a = 0; a < e.length; a++) { var l = ne(e[a][0]), u = ie(e[a][1]); t.push(l), t.push(u), t.push(0), a > 0 && (s += o ? (n * u - l * i) / 2 : Math.sqrt(Math.pow(l - n, 2) + Math.pow(u - i, 2))), n = l, i = u; } var h = t.length - 3; t[2] = 1, U(t, 0, h, r), t[h + 2] = 1, t.size = Math.abs(s), t.start = 0, t.end = t.size; } function oe(e, t, r, o) { for (var n = 0; n < e.length; n++) { var i = []; re(e[n], i, r, o), t.push(i); } } function ne(e) { return e / 360 + .5 } function ie(e) { var t = Math.sin(e * Math.PI / 180), r = .5 - .25 * Math.log((1 + t) / (1 - t)) / Math.PI; return r < 0 ? 0 : r > 1 ? 1 : r } function se(e, t, r, o, n, i, s, a) { if (o /= t, i >= (r /= t) && s < o) return e; if (s < r || i >= o) return null; for (var l = [], u = 0; u < e.length; u++) { var h = e[u], c = h.geometry, f = h.type, p = 0 === n ? h.minX : h.minY, g = 0 === n ? h.maxX : h.maxY; if (p >= r && g < o) l.push(h); else if (!(g < r || p >= o)) { var d = []; if ("Point" === f || "MultiPoint" === f) ae(c, d, r, o, n); else if ("LineString" === f) le(c, d, r, o, n, !1, a.lineMetrics); else if ("MultiLineString" === f) he(c, d, r, o, n, !1); else if ("Polygon" === f) he(c, d, r, o, n, !0); else if ("MultiPolygon" === f) for (var m = 0; m < c.length; m++) { var y = []; he(c[m], y, r, o, n, !0), y.length && d.push(y); } if (d.length) { if (a.lineMetrics && "LineString" === f) { for (m = 0; m < d.length; m++) l.push(H(h.id, f, d[m], h.tags)); continue } "LineString" !== f && "MultiLineString" !== f || (1 === d.length ? (f = "LineString", d = d[0]) : f = "MultiLineString"), "Point" !== f && "MultiPoint" !== f || (f = 3 === d.length ? "Point" : "MultiPoint"), l.push(H(h.id, f, d, h.tags)); } } } return l.length ? l : null } function ae(e, t, r, o, n) { for (var i = 0; i < e.length; i += 3) { var s = e[i + n]; s >= r && s <= o && (t.push(e[i]), t.push(e[i + 1]), t.push(e[i + 2])); } } function le(e, t, r, o, n, i, s) { for (var a, l, u = ue(e), h = 0 === n ? fe : pe, c = e.start, f = 0; f < e.length - 3; f += 3) { var p = e[f], g = e[f + 1], d = e[f + 2], m = e[f + 3], y = e[f + 4], v = 0 === n ? p : g, x = 0 === n ? m : y, w = !1; s && (a = Math.sqrt(Math.pow(p - m, 2) + Math.pow(g - y, 2))), v < r ? x > r && (l = h(u, p, g, m, y, r), s && (u.start = c + a * l)) : v > o ? x < o && (l = h(u, p, g, m, y, o), s && (u.start = c + a * l)) : ce(u, p, g, d), x < r && v >= r && (l = h(u, p, g, m, y, r), w = !0), x > o && v <= o && (l = h(u, p, g, m, y, o), w = !0), !i && w && (s && (u.end = c + a * l), t.push(u), u = ue(e)), s && (c += a); } var S = e.length - 3; p = e[S], g = e[S + 1], d = e[S + 2], (v = 0 === n ? p : g) >= r && v <= o && ce(u, p, g, d), S = u.length - 3, i && S >= 3 && (u[S] !== u[0] || u[S + 1] !== u[1]) && ce(u, u[0], u[1], u[2]), u.length && t.push(u); } function ue(e) { var t = []; return t.size = e.size, t.start = e.start, t.end = e.end, t } function he(e, t, r, o, n, i) { for (var s = 0; s < e.length; s++) le(e[s], t, r, o, n, i, !1); } function ce(e, t, r, o) { e.push(t), e.push(r), e.push(o); } function fe(e, t, r, o, n, i) { var s = (i - t) / (o - t); return e.push(i), e.push(r + (n - r) * s), e.push(1), s } function pe(e, t, r, o, n, i) { var s = (i - r) / (n - r); return e.push(t + (o - t) * s), e.push(i), e.push(1), s } function ge(e, t) { for (var r = [], o = 0; o < e.length; o++) { var n, i = e[o], s = i.type; if ("Point" === s || "MultiPoint" === s || "LineString" === s) n = de(i.geometry, t); else if ("MultiLineString" === s || "Polygon" === s) { n = []; for (var a = 0; a < i.geometry.length; a++) n.push(de(i.geometry[a], t)); } else if ("MultiPolygon" === s) for (n = [], a = 0; a < i.geometry.length; a++) { for (var l = [], u = 0; u < i.geometry[a].length; u++) l.push(de(i.geometry[a][u], t)); n.push(l); } r.push(H(i.id, s, n, i.tags)); } return r } function de(e, t) { var r = []; r.size = e.size, void 0 !== e.start && (r.start = e.start, r.end = e.end); for (var o = 0; o < e.length; o += 3) r.push(e[o] + t, e[o + 1], e[o + 2]); return r } function me(e, t) { if (e.transformed) return e; var r, o, n, i = 1 << e.z, s = e.x, a = e.y; for (r = 0; r < e.features.length; r++) { var l = e.features[r], u = l.geometry, h = l.type; if (l.geometry = [], 1 === h) for (o = 0; o < u.length; o += 2) l.geometry.push(ye(u[o], u[o + 1], t, i, s, a)); else for (o = 0; o < u.length; o++) { var c = []; for (n = 0; n < u[o].length; n += 2) c.push(ye(u[o][n], u[o][n + 1], t, i, s, a)); l.geometry.push(c); } } return e.transformed = !0, e } function ye(e, t, r, o, n, i) { return [Math.round(r * (e * o - n)), Math.round(r * (t * o - i))] } function ve(e, t, r, o, n) { for (var i = t === n.maxZoom ? 0 : n.tolerance / ((1 << t) * n.extent), s = { features: [], numPoints: 0, numSimplified: 0, numFeatures: 0, source: null, x: r, y: o, z: t, transformed: !1, minX: 2, minY: 1, maxX: -1, maxY: 0 }, a = 0; a < e.length; a++) { s.numFeatures++, xe(s, e[a], i, n); var l = e[a].minX, u = e[a].minY, h = e[a].maxX, c = e[a].maxY; l < s.minX && (s.minX = l), u < s.minY && (s.minY = u), h > s.maxX && (s.maxX = h), c > s.maxY && (s.maxY = c); } return s } function xe(e, t, r, o) { var n = t.geometry, i = t.type, s = []; if ("Point" === i || "MultiPoint" === i) for (var a = 0; a < n.length; a += 3) s.push(n[a]), s.push(n[a + 1]), e.numPoints++, e.numSimplified++; else if ("LineString" === i) we(s, n, e, r, !1, !1); else if ("MultiLineString" === i || "Polygon" === i) for (a = 0; a < n.length; a++) we(s, n[a], e, r, "Polygon" === i, 0 === a); else if ("MultiPolygon" === i) for (var l = 0; l < n.length; l++) { var u = n[l]; for (a = 0; a < u.length; a++) we(s, u[a], e, r, !0, 0 === a); } if (s.length) { var h = t.tags || null; if ("LineString" === i && o.lineMetrics) { for (var c in h = {}, t.tags) h[c] = t.tags[c]; h.mapbox_clip_start = n.start / n.size, h.mapbox_clip_end = n.end / n.size; } var f = { geometry: s, type: "Polygon" === i || "MultiPolygon" === i ? 3 : "LineString" === i || "MultiLineString" === i ? 2 : 1, tags: h }; null !== t.id && (f.id = t.id), e.features.push(f); } } function we(e, t, r, o, n, i) { var s = o * o; if (o > 0 && t.size < (n ? s : o)) r.numPoints += t.length / 3; else { for (var a = [], l = 0; l < t.length; l += 3)(0 === o || t[l + 2] > s) && (r.numSimplified++, a.push(t[l]), a.push(t[l + 1])), r.numPoints++; n && function(e, t) { for (var r = 0, o = 0, n = e.length, i = n - 2; o < n; i = o, o += 2) r += (e[o] - e[i]) * (e[o + 1] + e[i + 1]); if (r > 0 === t) for (o = 0, n = e.length; o < n / 2; o += 2) { var s = e[o], a = e[o + 1]; e[o] = e[n - 2 - o], e[o + 1] = e[n - 1 - o], e[n - 2 - o] = s, e[n - 1 - o] = a; } }(a, i), e.push(a); } } function Se(e, t) { var r = (t = this.options = function(e, t) { for (var r in t) e[r] = t[r]; return e }(Object.create(this.options), t)).debug; if (r && console.time("preprocess data"), t.maxZoom < 0 || t.maxZoom > 24) throw new Error("maxZoom should be in the 0-24 range"); if (t.promoteId && t.generateId) throw new Error("promoteId and generateId cannot be used together."); var o = function(e, t) { var r = []; if ("FeatureCollection" === e.type) for (var o = 0; o < e.features.length; o++) ee(r, e.features[o], t, o); else ee(r, "Feature" === e.type ? e : { geometry: e }, t); return r }(e, t); this.tiles = {}, this.tileCoords = [], r && (console.timeEnd("preprocess data"), console.log("index: maxZoom: %d, maxPoints: %d", t.indexMaxZoom, t.indexMaxPoints), console.time("generate tiles"), this.stats = {}, this.total = 0), o = function(e, t) { var r = t.buffer / t.extent, o = e, n = se(e, 1, -1 - r, r, 0, -1, 2, t), i = se(e, 1, 1 - r, 2 + r, 0, -1, 2, t); return (n || i) && (o = se(e, 1, -r, 1 + r, 0, -1, 2, t) || [], n && (o = ge(n, 1).concat(o)), i && (o = o.concat(ge(i, -1)))), o }(o, t), o.length && this.splitTile(o, 0, 0, 0), r && (o.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 Me(e, t, r) { return 32 * ((1 << e) * r + t) + e } function Pe(e, t) { const r = e.tileID.canonical; if (!this._geoJSONIndex) return t(null, null); const o = this._geoJSONIndex.getTile(r.z, r.x, r.y); if (!o) return t(null, null); const n = new h(o.features); let i = c(n); 0 === i.byteOffset && i.byteLength === i.buffer.byteLength || (i = new Uint8Array(i)), t(null, { vectorTile: n, rawData: i.buffer }); } Se.prototype.options = { maxZoom: 14, indexMaxZoom: 5, indexMaxPoints: 1e5, tolerance: 3, extent: 4096, buffer: 64, lineMetrics: !1, promoteId: null, generateId: !1, debug: 0 }, Se.prototype.splitTile = function(e, t, r, o, n, i, s) { for (var a = [e, t, r, o], l = this.options, u = l.debug; a.length;) { o = a.pop(), r = a.pop(), t = a.pop(), e = a.pop(); var h = 1 << t, c = Me(t, r, o), f = this.tiles[c]; if (!f && (u > 1 && console.time("creation"), f = this.tiles[c] = ve(e, t, r, o, l), this.tileCoords.push({ z: t, x: r, y: o }), u)) { u > 1 && (console.log("tile z%d-%d-%d (features: %d, points: %d, simplified: %d)", t, r, o, f.numFeatures, f.numPoints, f.numSimplified), console.timeEnd("creation")); var p = "z" + t; this.stats[p] = (this.stats[p] || 0) + 1, this.total++; } if (f.source = e, n) { if (t === l.maxZoom || t === n) continue; var g = 1 << n - t; if (r !== Math.floor(i / g) || o !== Math.floor(s / g)) continue } else if (t === l.indexMaxZoom || f.numPoints <= l.indexMaxPoints) continue; if (f.source = null, 0 !== e.length) { u > 1 && console.time("clipping"); var d, m, y, v, x, w, S = .5 * l.buffer / l.extent, M = .5 - S, P = .5 + S, b = 1 + S; d = m = y = v = null, x = se(e, h, r - S, r + P, 0, f.minX, f.maxX, l), w = se(e, h, r + M, r + b, 0, f.minX, f.maxX, l), e = null, x && (d = se(x, h, o - S, o + P, 1, f.minY, f.maxY, l), m = se(x, h, o + M, o + b, 1, f.minY, f.maxY, l), x = null), w && (y = se(w, h, o - S, o + P, 1, f.minY, f.maxY, l), v = se(w, h, o + M, o + b, 1, f.minY, f.maxY, l), w = null), u > 1 && console.timeEnd("clipping"), a.push(d || [], t + 1, 2 * r, 2 * o), a.push(m || [], t + 1, 2 * r, 2 * o + 1), a.push(y || [], t + 1, 2 * r + 1, 2 * o), a.push(v || [], t + 1, 2 * r + 1, 2 * o + 1); } } }, Se.prototype.getTile = function(e, t, r) { var o = this.options, n = o.extent, i = o.debug; if (e < 0 || e > 24) return null; var s = 1 << e, a = Me(e, t = (t % s + s) % s, r); if (this.tiles[a]) return me(this.tiles[a], n); i > 1 && console.log("drilling down to z%d-%d-%d", e, t, r); for (var l, u = e, h = t, c = r; !l && u > 0;) u--, h = Math.floor(h / 2), c = Math.floor(c / 2), l = this.tiles[Me(u, h, c)]; return l && l.source ? (i > 1 && console.log("found parent tile z%d-%d-%d", u, h, c), i > 1 && console.time("drilling down"), this.splitTile(l.source, u, h, c, e, t, r), i > 1 && console.timeEnd("drilling down"), this.tiles[a] ? me(this.tiles[a], n) : null) : null }; class be extends e.VectorTileWorkerSource { constructor(e, t, r, o, n) { super(e, t, r, o, Pe), n && (this.loadGeoJSON = n); } loadData(t, r) { const o = t && t.request, n = o && o.collectResourceTiming; this.loadGeoJSON(t, ((s, a) => { if (s || !a) return r(s); if ("object" != typeof a) return r(new Error(`Input data given to '${t.source}' is not a valid GeoJSON object.`)); { i(a, !0); try { if (t.filter) { const r = e.createExpression(t.filter, { type: "boolean", "property-type": "data-driven", overridable: !1, transition: !1 }); if ("error" === r.result) throw new Error(r.value.map((e => `${e.key}: ${e.message}`)).join(", ")); const o = a.features.filter((e => r.value.evaluate({ zoom: 0 }, e))); a = { type: "FeatureCollection", features: o }; } this._geoJSONIndex = t.cluster ? new J(function({ superclusterOptions: t, clusterProperties: r }) { if (!r || !t) return t; const o = {}, n = {}, i = { accumulated: null, zoom: 0 }, s = { properties: null }, a = Object.keys(r); for (const t of a) { const [i, s] = r[t], a = e.createExpression(s), l = e.createExpression("string" == typeof i ? [i, ["accumulated"], ["get", t] ] : i); o[t] = a.value, n[t] = l.value; } return t.map = e => { s.properties = e; const t = {}; for (const e of a) t[e] = o[e].evaluate(i, s); return t }, t.reduce = (e, t) => { s.properties = t; for (const t of a) i.accumulated = e[t], e[t] = n[t].evaluate(i, s); }, t }(t)).load(a.features) : function(e, t) { return new Se(e, t) }(a, t.geojsonVtOptions); } catch (s) { return r(s) } this.loaded = {}; const l = {}; if (n) { const r = e.getPerformanceMeasurement(o); r && (l.resourceTiming = {}, l.resourceTiming[t.source] = JSON.parse(JSON.stringify(r))); } r(null, l); } })); } reloadTile(e, t) { const r = this.loaded; return r && r[e.uid] ? super.reloadTile(e, t) : this.loadTile(e, t) } loadGeoJSON(t, r) { if (t.request) e.getJSON(t.request, r); else { if ("string" != typeof t.data) return r(new Error(`Input data given to '${t.source}' is not a valid GeoJSON object.`)); try { return r(null, JSON.parse(t.data)) } catch (e) { return r(new Error(`Input data given to '${t.source}' is not a valid GeoJSON object.`)) } } } getClusterExpansionZoom(e, t) { try { t(null, this._geoJSONIndex.getClusterExpansionZoom(e.clusterId)); } catch (e) { t(e); } } getClusterChildren(e, t) { try { t(null, this._geoJSONIndex.getChildren(e.clusterId)); } catch (e) { t(e); } } getClusterLeaves(e, t) { try { t(null, this._geoJSONIndex.getLeaves(e.clusterId, e.limit, e.offset)); } catch (e) { t(e); } } } class ke { constructor(t) { this.self = t, this.actor = new e.Actor(t, this), this.layerIndexes = {}, this.availableImages = {}, this.isSpriteLoaded = {}, this.projections = {}, this.defaultProjection = e.getProjection({ name: "mercator" }), this.workerSourceTypes = { vector: e.VectorTileWorkerSource, geojson: be }, this.workerSources = {}, this.demWorkerSources = {}, this.self.registerWorkerSource = (e, t) => { if (this.workerSourceTypes[e]) throw new Error(`Worker source with name "${e}" already registered.`); this.workerSourceTypes[e] = t; }, this.self.registerRTLTextPlugin = t => { if (e.plugin.isParsed()) throw new Error("RTL text plugin already registered."); e.plugin.applyArabicShaping = t.applyArabicShaping, e.plugin.processBidirectionalText = t.processBidirectionalText, e.plugin.processStyledBidirectionalText = t.processStyledBidirectionalText; }; } clearCaches(e, t, r) { delete this.layerIndexes[e], delete this.availableImages[e], delete this.workerSources[e], delete this.demWorkerSources[e], r(); } checkIfReady(e, t, r) { r(); } setReferrer(e, t) { this.referrer = t; } spriteLoaded(t, r) { this.isSpriteLoaded[t] = r; for (const o in this.workerSources[t]) { const n = this.workerSources[t][o]; for (const t in n) n[t] instanceof e.VectorTileWorkerSource && (n[t].isSpriteLoaded = r, n[t].fire(new e.Event("isSpriteLoaded"))); } } setImages(e, t, r) { this.availableImages[e] = t; for (const r in this.workerSources[e]) { const o = this.workerSources[e][r]; for (const e in o) o[e].availableImages = t; } r(); } enableTerrain(e, t, r) { this.terrain = t, r(); } setProjection(t, r) { this.projections[t] = e.getProjection(r); } setLayers(e, t, r) { this.getLayerIndex(e).replace(t), r(); } updateLayers(e, t, r) { this.getLayerIndex(e).update(t.layers, t.removedIds), r(); } loadTile(t, r, o) { const n = this.enableTerrain ? e.extend({ enableTerrain: this.terrain }, r) : r; n.projection = this.projections[t] || this.defaultProjection, this.getWorkerSource(t, r.type, r.source).loadTile(n, o); } loadDEMTile(t, r, o) { const n = this.enableTerrain ? e.extend({ buildQuadTree: this.terrain }, r) : r; this.getDEMWorkerSource(t, r.source).loadTile(n, o); } reloadTile(t, r, o) { const n = this.enableTerrain ? e.extend({ enableTerrain: this.terrain }, r) : r; n.projection = this.projections[t] || this.defaultProjection, this.getWorkerSource(t, r.type, r.source).reloadTile(n, o); } abortTile(e, t, r) { this.getWorkerSource(e, t.type, t.source).abortTile(t, r); } removeTile(e, t, r) { this.getWorkerSource(e, t.type, t.source).removeTile(t, r); } removeSource(e, t, r) { if (!this.workerSources[e] || !this.workerSources[e][t.type] || !this.workerSources[e][t.type][t.source]) return; const o = this.workerSources[e][t.type][t.source]; delete this.workerSources[e][t.type][t.source], void 0 !== o.removeSource ? o.removeSource(t, r) : r(); } loadWorkerSource(e, t, r) { try { this.self.importScripts(t.url), r(); } catch (e) { r(e.toString()); } } syncRTLPluginState(t, r, o) { try { e.plugin.setState(r); const t = e.plugin.getPluginURL(); if (e.plugin.isLoaded() && !e.plugin.isParsed() && null != t) { this.self.importScripts(t); const r = e.plugin.isParsed(); o(r ? void 0 : new Error(`RTL Text Plugin failed to import scripts from ${t}`), r); } } catch (e) { o(e.toString()); } } getAvailableImages(e) { let t = this.availableImages[e]; return t || (t = []), t } getLayerIndex(e) { let t = this.layerIndexes[e]; return t || (t = this.layerIndexes[e] = new o), t } getWorkerSource(e, t, r) { if (this.workerSources[e] || (this.workerSources[e] = {}), this.workerSources[e][t] || (this.workerSources[e][t] = {}), !this.workerSources[e][t][r]) { const o = { send: (t, r, o, n, i, s) => { this.actor.send(t, r, o, e, i, s); }, scheduler: this.actor.scheduler }; this.workerSources[e][t][r] = new this.workerSourceTypes[t](o, this.getLayerIndex(e), this.getAvailableImages(e), this.isSpriteLoaded[e]); } return this.workerSources[e][t][r] } getDEMWorkerSource(e, t) { return this.demWorkerSources[e] || (this.demWorkerSources[e] = {}), this.demWorkerSources[e][t] || (this.demWorkerSources[e][t] = new n), this.demWorkerSources[e][t] } enforceCacheSizeLimit(t, r) { e.enforceCacheSizeLimit(r); } getWorkerPerformanceMetrics(e, t, r) { r(void 0, void 0); } } return "undefined" != typeof WorkerGlobalScope && "undefined" != typeof self && self instanceof WorkerGlobalScope && (self.worker = new ke(self)), ke })); define(["./shared"], (function(e) { "use strict"; function t(e, i) { if (Array.isArray(e)) { if (!Array.isArray(i) || e.length !== i.length) return !1; for (let o = 0; o < e.length; o++) if (!t(e[o], i[o])) return !1; return !0 } if ("object" == typeof e && null !== e && null !== i) { if ("object" != typeof i) return !1; if (Object.keys(e).length !== Object.keys(i).length) return !1; for (const o in e) if (!t(e[o], i[o])) return !1; return !0 } return e === i } var i = o; function o(e) { return ! function(e) { return "undefined" == typeof window || "undefined" == typeof document ? "not a browser" : Array.prototype && Array.prototype.every && Array.prototype.filter && Array.prototype.forEach && Array.prototype.indexOf && Array.prototype.lastIndexOf && Array.prototype.map && Array.prototype.some && Array.prototype.reduce && Array.prototype.reduceRight && Array.isArray ? Function.prototype && Function.prototype.bind ? Object.keys && Object.create && Object.getPrototypeOf && Object.getOwnPropertyNames && Object.isSealed && Object.isFrozen && Object.isExtensible && Object.getOwnPropertyDescriptor && Object.defineProperty && Object.defineProperties && Object.seal && Object.freeze && Object.preventExtensions ? "JSON" in window && "parse" in JSON && "stringify" in JSON ? function() { if (!("Worker" in window && "Blob" in window && "URL" in window)) return !1; var e, t, i = new Blob([""], { type: "text/javascript" }), o = URL.createObjectURL(i); try { t = new Worker(o), e = !0; } catch (t) { e = !1; } return t && t.terminate(), URL.revokeObjectURL(o), e }() ? "Uint8ClampedArray" in window ? ArrayBuffer.isView ? function() { var e = document.createElement("canvas"); e.width = e.height = 1; var t = e.getContext("2d"); if (!t) return !1; var i = t.getImageData(0, 0, 1, 1); return i && i.width === e.width }() ? (void 0 === r[t = e && e.failIfMajorPerformanceCaveat] && (r[t] = function(e) { var t, i = function(e) { var t = document.createElement("canvas"), i = Object.create(o.webGLContextAttributes); return i.failIfMajorPerformanceCaveat = e, t.getContext("webgl", i) || t.getContext("experimental-webgl", i) }(e); if (!i) return !1; try { t = i.createShader(i.VERTEX_SHADER); } catch (e) { return !1 } return !(!t || i.isContextLost()) && (i.shaderSource(t, "void main() {}"), i.compileShader(t), !0 === i.getShaderParameter(t, i.COMPILE_STATUS)) }(t)), r[t] ? document.documentMode ? "insufficient ECMAScript 6 support" : void 0 : "insufficient WebGL support") : "insufficient Canvas/getImageData support" : "insufficient ArrayBuffer support" : "insufficient Uint8ClampedArray support" : "insufficient worker support" : "insufficient JSON support" : "insufficient Object support" : "insufficient Function support" : "insufficent Array support"; var t; }(e) } var r = {}; function n(t, i, o) { const r = e.window.document.createElement(t); return void 0 !== i && (r.className = i), o && o.appendChild(r), r } function s(t, i, o) { const r = e.window.document.createElementNS("http://www.w3.org/2000/svg", t); for (const e of Object.keys(i)) r.setAttributeNS(null, e, i[e]); return o && o.appendChild(r), r } o.webGLContextAttributes = { antialias: !1, alpha: !0, stencil: !0, depth: !0 }; const a = e.window.document && e.window.document.documentElement.style, l = a && void 0 !== a.userSelect ? "userSelect" : "WebkitUserSelect"; let c; function h() { a && l && (c = a[l], a[l] = "none"); } function u() { a && l && (a[l] = c); } function _(t) { t.preventDefault(), t.stopPropagation(), e.window.removeEventListener("click", _, !0); } function d() { e.window.addEventListener("click", _, !0), e.window.setTimeout((() => { e.window.removeEventListener("click", _, !0); }), 0); } function p(e, t) { const i = e.getBoundingClientRect(); return g(e, i, t) } function m(e, t) { const i = e.getBoundingClientRect(), o = []; for (let r = 0; r < t.length; r++) o.push(g(e, i, t[r])); return o } function f(t) { return void 0 !== e.window.InstallTrigger && 2 === t.button && t.ctrlKey && e.window.navigator.platform.toUpperCase().indexOf("MAC") >= 0 ? 0 : t.button } function g(t, i, o) { const r = t.offsetWidth === i.width ? 1 : t.offsetWidth / i.width; return new e.pointGeometry((o.clientX - i.left) * r, (o.clientY - i.top) * r) } function v(e, t) { var i = t[0], o = t[1], r = t[2], n = t[3], s = i * n - r * o; return s ? (e[0] = n * (s = 1 / s), e[1] = -o * s, e[2] = -r * s, e[3] = i * s, e) : null } function x(e) { const { userImage: t } = e; return !!(t && t.render && t.render()) && (e.data.replace(new Uint8Array(t.data.buffer)), !0) } class y extends e.Evented { constructor() { super(), this.images = {}, this.updatedImages = {}, this.callbackDispatchedThisFrame = {}, this.loaded = !1, this.requestors = [], this.patterns = {}, this.atlasImage = new e.RGBAImage({ width: 1, height: 1 }), this.dirty = !0; } isLoaded() { return this.loaded } setLoaded(e) { if (this.loaded !== e && (this.loaded = e, e)) { for (const { ids: e, callback: t } of this.requestors) this._notify(e, t); this.requestors = []; } } hasImage(e) { return !!this.getImage(e) } getImage(e) { return this.images[e] } addImage(e, t) { this._validate(e, t) && (this.images[e] = t); } _validate(t, i) { let o = !0; return this._validateStretch(i.stretchX, i.data && i.data.width) || (this.fire(new e.ErrorEvent(new Error(`Image "${t}" has invalid "stretchX" value`))), o = !1), this._validateStretch(i.stretchY, i.data && i.data.height) || (this.fire(new e.ErrorEvent(new Error(`Image "${t}" has invalid "stretchY" value`))), o = !1), this._validateContent(i.content, i) || (this.fire(new e.ErrorEvent(new Error(`Image "${t}" has invalid "content" value`))), o = !1), o } _validateStretch(e, t) { if (!e) return !0; let i = 0; for (const o of e) { if (o[0] < i || o[1] < o[0] || t < o[1]) return !1; i = o[1]; } return !0 } _validateContent(e, t) { return !(e && (4 !== e.length || e[0] < 0 || t.data.width < e[0] || e[1] < 0 || t.data.height < e[1] || e[2] < 0 || t.data.width < e[2] || e[3] < 0 || t.data.height < e[3] || e[2] < e[0] || e[3] < e[1])) } updateImage(e, t) { t.version = this.images[e].version + 1, this.images[e] = t, this.updatedImages[e] = !0; } removeImage(e) { const t = this.images[e]; delete this.images[e], delete this.patterns[e], t.userImage && t.userImage.onRemove && t.userImage.onRemove(); } listImages() { return Object.keys(this.images) } getImages(e, t) { let i = !0; if (!this.isLoaded()) for (const t of e) this.images[t] || (i = !1); this.isLoaded() || i ? this._notify(e, t) : this.requestors.push({ ids: e, callback: t }); } _notify(t, i) { const o = {}; for (const i of t) { this.images[i] || this.fire(new e.Event("styleimagemissing", { id: i })); const t = this.images[i]; t ? o[i] = { data: t.data.clone(), pixelRatio: t.pixelRatio, sdf: t.sdf, version: t.version, stretchX: t.stretchX, stretchY: t.stretchY, content: t.content, hasRenderCallback: Boolean(t.userImage && t.userImage.render) } : e.warnOnce(`Image "${i}" 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.`); } i(null, o); } getPixelSize() { const { width: e, height: t } = this.atlasImage; return { width: e, height: t } } getPattern(t) { const i = this.patterns[t], o = this.getImage(t); if (!o) return null; if (i && i.position.version === o.version) return i.position; if (i) i.position.version = o.version; else { const i = { w: o.data.width + 2, h: o.data.height + 2, x: 0, y: 0 }, r = new e.ImagePosition(i, o); this.patterns[t] = { bin: i, position: r }; } return this._updatePatternAtlas(), this.patterns[t].position } bind(t) { const i = t.gl; this.atlasTexture ? this.dirty && (this.atlasTexture.update(this.atlasImage), this.dirty = !1) : this.atlasTexture = new e.Texture(t, this.atlasImage, i.RGBA), this.atlasTexture && this.atlasTexture.bind(i.LINEAR, i.CLAMP_TO_EDGE); } _updatePatternAtlas() { const t = []; for (const e in this.patterns) t.push(this.patterns[e].bin); const { w: i, h: o } = e.potpack(t), r = this.atlasImage; r.resize({ width: i || 1, height: o || 1 }); for (const t in this.patterns) { const { bin: i } = this.patterns[t], o = i.x + 1, n = i.y + 1, s = this.images[t].data, a = s.width, l = s.height; e.RGBAImage.copy(s, r, { x: 0, y: 0 }, { x: o, y: n }, { width: a, height: l }), e.RGBAImage.copy(s, r, { x: 0, y: l - 1 }, { x: o, y: n - 1 }, { width: a, height: 1 }), e.RGBAImage.copy(s, r, { x: 0, y: 0 }, { x: o, y: n + l }, { width: a, height: 1 }), e.RGBAImage.copy(s, r, { x: a - 1, y: 0 }, { x: o - 1, y: n }, { width: 1, height: l }), e.RGBAImage.copy(s, r, { x: 0, y: 0 }, { x: o + a, y: n }, { width: 1, height: l }); } this.dirty = !0; } beginFrame() { this.callbackDispatchedThisFrame = {}; } dispatchRenderCallbacks(e) { for (const t of e) { if (this.callbackDispatchedThisFrame[t]) continue; this.callbackDispatchedThisFrame[t] = !0; const e = this.images[t]; x(e) && this.updateImage(t, e); } } } const b = new e.Properties({ anchor: new e.DataConstantProperty(e.spec.light.anchor), position: new class { constructor() { this.specification = e.spec.light.position; } possiblyEvaluate(t, i) { return function([t, i, o]) { const r = e.degToRad(i + 90), n = e.degToRad(o); return { x: t * Math.cos(r) * Math.sin(n), y: t * Math.sin(r) * Math.sin(n), z: t * Math.cos(n), azimuthal: i, polar: o } }(t.expression.evaluate(i)) } interpolate(t, i, o) { return { x: e.number(t.x, i.x, o), y: e.number(t.y, i.y, o), z: e.number(t.z, i.z, o), azimuthal: e.number(t.azimuthal, i.azimuthal, o), polar: e.number(t.polar, i.polar, o) } } }, color: new e.DataConstantProperty(e.spec.light.color), intensity: new e.DataConstantProperty(e.spec.light.intensity) }), w = "-transition"; class T extends e.Evented { constructor(t) { super(), this._transitionable = new e.Transitionable(b), this.setLight(t), this._transitioning = this._transitionable.untransitioned(); } getLight() { return this._transitionable.serialize() } setLight(t, i = {}) { if (!this._validate(e.validateLight, t, i)) for (const i in t) { const o = t[i]; e.endsWith(i, w) ? this._transitionable.setTransition(i.slice(0, -w.length), o) : this._transitionable.setValue(i, o); } } updateTransitions(e) { this._transitioning = this._transitionable.transitioned(e, this._transitioning); } hasTransition() { return this._transitioning.hasTransition() } recalculate(e) { this.properties = this._transitioning.possiblyEvaluate(e); } _validate(t, i, o) { return (!o || !1 !== o.validate) && e.emitValidationErrors(this, t.call(e.validateStyle, e.extend({ value: i, style: { glyphs: !0, sprite: !0 }, styleSpec: e.spec }))) } } const E = new e.Properties({ source: new e.DataConstantProperty(e.spec.terrain.source), exaggeration: new e.DataConstantProperty(e.spec.terrain.exaggeration) }), C = "-transition"; class M extends e.Evented { constructor(t, i) { super(), this._transitionable = new e.Transitionable(E), this.set(t), this._transitioning = this._transitionable.untransitioned(), this.drapeRenderMode = i; } get() { return this._transitionable.serialize() } set(t) { for (const i in t) { const o = t[i]; e.endsWith(i, C) ? this._transitionable.setTransition(i.slice(0, -C.length), o) : this._transitionable.setValue(i, o); } } updateTransitions(e) { this._transitioning = this._transitionable.transitioned(e, this._transitioning); } hasTransition() { return this._transitioning.hasTransition() } recalculate(e) { this.properties = this._transitioning.possiblyEvaluate(e); } } function I(t, i, o, r) { const n = e.smoothstep(45, 65, o), [s, a] = S(t, r), l = e.length(i); let c = 1 - Math.min(1, Math.exp((l - s) / (a - s) * -6)); return c *= c * c, c = Math.min(1, 1.00747 * c), c * n * t.alpha } function S(e, t) { const i = .5 / Math.tan(.5 * t); return [e.range[0] + i, e.range[1] + i] } const D = new e.Properties({ range: new e.DataConstantProperty(e.spec.fog.range), color: new e.DataConstantProperty(e.spec.fog.color), "high-color": new e.DataConstantProperty(e.spec.fog["high-color"]), "space-color": new e.DataConstantProperty(e.spec.fog["space-color"]), "horizon-blend": new e.DataConstantProperty(e.spec.fog["horizon-blend"]), "star-intensity": new e.DataConstantProperty(e.spec.fog["star-intensity"]) }), L = "-transition"; class A extends e.Evented { constructor(t, i) { super(), this._transitionable = new e.Transitionable(D), this.set(t), this._transitioning = this._transitionable.untransitioned(), this._transform = i; } get state() { const t = this._transform, i = "globe" === t.projection.name, o = e.globeToMercatorTransition(t.zoom), r = this.properties.get("range"), n = [.5, 3]; return { range: i ? [e.number(n[0], r[0], o), e.number(n[1], r[1], o)] : r, horizonBlend: this.properties.get("horizon-blend"), alpha: this.properties.get("color").a } } get() { return this._transitionable.serialize() } set(t, i = {}) { if (!this._validate(e.validateFog, t, i)) { for (const i of Object.keys(e.spec.fog)) t && void 0 === t[i] && (t[i] = e.spec.fog[i].default); for (const i in t) { const o = t[i]; e.endsWith(i, L) ? this._transitionable.setTransition(i.slice(0, -L.length), o) : this._transitionable.setValue(i, o); } } } getOpacity(t) { if (!this._transform.projection.supportsFog) return 0; const i = this.properties && this.properties.get("color") || 1; return ("globe" === this._transform.projection.name ? 1 : e.smoothstep(45, 65, t)) * i.a } getOpacityAtLatLng(t, i) { return this._transform.projection.supportsFog ? function(t, i, o) { const r = e.MercatorCoordinate.fromLngLat(i), n = o.elevation ? o.elevation.getAtPointOrZero(r) : 0, s = [r.x, r.y, n]; return e.transformMat4(s, s, o.mercatorFogMatrix), I(t, s, o.pitch, o._fov) }(this.state, t, i) : 0 } getFovAdjustedRange(e) { return this._transform.projection.supportsFog ? S(this.state, e) : [0, 1] } updateTransitions(e) { this._transitioning = this._transitionable.transitioned(e, this._transitioning); } hasTransition() { return this._transitioning.hasTransition() } recalculate(e) { this.properties = this._transitioning.possiblyEvaluate(e); } _validate(t, i, o) { return (!o || !1 !== o.validate) && e.emitValidationErrors(this, t.call(e.validateStyle, e.extend({ value: i, style: { glyphs: !0, sprite: !0 }, styleSpec: e.spec }))) } } class z { constructor(t, i) { this.workerPool = t, this.actors = [], this.currentActor = 0, this.id = e.uniqueId(); const o = this.workerPool.acquire(this.id); for (let e = 0; e < o.length; e++) { const t = new z.Actor(o[e], i, this.id); t.name = `Worker ${e}`, this.actors.push(t); } this.ready = !1, this.broadcast("checkIfReady", null, (() => { this.ready = !0; })); } broadcast(t, i, o) { e.asyncAll(this.actors, ((e, o) => { e.send(t, i, o); }), o = o || function() {}); } getActor() { return this.currentActor = (this.currentActor + 1) % this.actors.length, this.actors[this.currentActor] } remove() { this.actors.forEach((e => { e.remove(); })), this.actors = [], this.workerPool.release(this.id); } } function P(t, i, o) { return i * (e.EXTENT / (t.tileSize * Math.pow(2, o - t.tileID.overscaledZ))) } z.Actor = e.Actor; class R { constructor(e, t, i, o) { this.screenBounds = e, this.cameraPoint = t, this._screenRaycastCache = {}, this._cameraRaycastCache = {}, this.isAboveHorizon = i, this.screenGeometry = this.bufferedScreenGeometry(0), this.screenGeometryMercator = this._bufferedScreenMercator(0, o); } static createFromScreenPoints(t, i) { let o, r; if (t instanceof e.pointGeometry || "number" == typeof t[0]) { const n = e.pointGeometry.convert(t); o = [n], r = i.isPointAboveHorizon(n); } else { const n = e.pointGeometry.convert(t[0]), s = e.pointGeometry.convert(t[1]); o = [n, s], r = e.polygonizeBounds(n, s).every((e => i.isPointAboveHorizon(e))); } return new R(o, i.getCameraPoint(), r, i) } isPointQuery() { return 1 === this.screenBounds.length } bufferedScreenGeometry(t) { return e.polygonizeBounds(this.screenBounds[0], 1 === this.screenBounds.length ? this.screenBounds[0] : this.screenBounds[1], t) } bufferedCameraGeometry(t) { const i = this.screenBounds[0], o = 1 === this.screenBounds.length ? this.screenBounds[0].add(new e.pointGeometry(1, 1)) : this.screenBounds[1], r = e.polygonizeBounds(i, o, 0, !1); return this.cameraPoint.y > o.y && (this.cameraPoint.x > i.x && this.cameraPoint.x < o.x ? r.splice(3, 0, this.cameraPoint) : this.cameraPoint.x >= o.x ? r[2] = this.cameraPoint : this.cameraPoint.x <= i.x && (r[3] = this.cameraPoint)), e.bufferConvexPolygon(r, t) } bufferedCameraGeometryGlobe(t) { const i = this.screenBounds[0], o = 1 === this.screenBounds.length ? this.screenBounds[0].add(new e.pointGeometry(1, 1)) : this.screenBounds[1], r = e.polygonizeBounds(i, o, t), n = this.cameraPoint.clone(); switch (3 * ((n.y > i.y) + (n.y > o.y)) + ((n.x > i.x) + (n.x > o.x))) { case 0: r[0] = n, r[4] = n.clone(); break; case 1: r.splice(1, 0, n); break; case 2: r[1] = n; break; case 3: r.splice(4, 0, n); break; case 5: r.splice(2, 0, n); break; case 6: r[3] = n; break; case 7: r.splice(3, 0, n); break; case 8: r[2] = n; } return r } containsTile(t, i, o, r = 0) { const n = t.queryPadding / i._pixelsPerMercatorPixel + 1, s = o ? this._bufferedCameraMercator(n, i) : this._bufferedScreenMercator(n, i); let a = t.tileID.wrap + (s.unwrapped ? r : 0); const l = s.polygon.map((i => e.getTilePoint(t.tileTransform, i, a))); if (!e.polygonIntersectsBox(l, 0, 0, e.EXTENT, e.EXTENT)) return; a = t.tileID.wrap + (this.screenGeometryMercator.unwrapped ? r : 0); const c = this.screenGeometryMercator.polygon.map((i => e.getTileVec3(t.tileTransform, i, a))), h = c.map((t => new e.pointGeometry(t[0], t[1]))), u = i.getFreeCameraOptions().position || new e.MercatorCoordinate(0, 0, 0), _ = e.getTileVec3(t.tileTransform, u, a), d = c.map((t => { const i = e.sub(t, t, _); return e.normalize(i, i), new e.Ray(_, i) })), p = P(t, 1, i.zoom) * i._pixelsPerMercatorPixel; return { queryGeometry: this, tilespaceGeometry: h, tilespaceRays: d, bufferedTilespaceGeometry: l, bufferedTilespaceBounds: (m = e.getBounds(l), m.min.x = e.clamp(m.min.x, 0, e.EXTENT), m.min.y = e.clamp(m.min.y, 0, e.EXTENT), m.max.x = e.clamp(m.max.x, 0, e.EXTENT), m.max.y = e.clamp(m.max.y, 0, e.EXTENT), m), tile: t, tileID: t.tileID, pixelToTileUnitsFactor: p }; var m; } _bufferedScreenMercator(e, t) { const i = k(e); if (this._screenRaycastCache[i]) return this._screenRaycastCache[i]; { let o; return o = "globe" === t.projection.name ? this._projectAndResample(this.bufferedScreenGeometry(e), t) : { polygon: this.bufferedScreenGeometry(e).map((e => t.pointCoordinate3D(e))), unwrapped: !0 }, this._screenRaycastCache[i] = o, o } } _bufferedCameraMercator(e, t) { const i = k(e); if (this._cameraRaycastCache[i]) return this._cameraRaycastCache[i]; { let o; return o = "globe" === t.projection.name ? this._projectAndResample(this.bufferedCameraGeometryGlobe(e), t) : { polygon: this.bufferedCameraGeometry(e).map((e => t.pointCoordinate3D(e))), unwrapped: !0 }, this._cameraRaycastCache[i] = o, o } } _projectAndResample(t, i) { const o = function(t, i) { const o = e.multiply([], i.pixelMatrix, i.globeMatrix), r = [0, -e.GLOBE_RADIUS, 0, 1], n = [0, e.GLOBE_RADIUS, 0, 1], s = [0, 0, 0, 1]; e.transformMat4$1(r, r, o), e.transformMat4$1(n, n, o), e.transformMat4$1(s, s, o); const a = new e.pointGeometry(r[0] / r[3], r[1] / r[3]), l = new e.pointGeometry(n[0] / n[3], n[1] / n[3]), c = e.polygonContainsPoint(t, a) && r[3] < s[3], h = e.polygonContainsPoint(t, l) && n[3] < s[3]; if (!c && !h) return null; const u = function(e, t, i) { for (let o = 1; o < e.length; o++) { const r = B(t.pointCoordinate3D(e[o - 1]).x), n = B(t.pointCoordinate3D(e[o]).x); if (i < 0) { if (r < n) return { idx: o, t: -r / (n - 1 - r) } } else if (n < r) return { idx: o, t: (1 - r) / (n + 1 - r) } } return null }(t, i, c ? -1 : 1); if (!u) return null; const { idx: _, t: d } = u; let p = _ > 1 ? O(t.slice(0, _), i) : [], m = _ < t.length ? O(t.slice(_), i) : []; p = p.map((t => new e.pointGeometry(B(t.x), t.y))), m = m.map((t => new e.pointGeometry(B(t.x), t.y))); const f = [...p]; 0 === f.length && f.push(m[m.length - 1]); const g = e.number(f[f.length - 1].y, (0 === m.length ? p[0] : m[0]).y, d); let v; return v = c ? [new e.pointGeometry(0, g), new e.pointGeometry(0, 0), new e.pointGeometry(1, 0), new e.pointGeometry(1, g)] : [new e.pointGeometry(1, g), new e.pointGeometry(1, 1), new e.pointGeometry(0, 1), new e.pointGeometry(0, g)], f.push(...v), 0 === m.length ? f.push(p[0]) : f.push(...m), { polygon: f.map((t => new e.MercatorCoordinate(t.x, t.y))), unwrapped: !1 } }(t, i); if (o) return o; const r = function(t, i) { let o = !1, r = -1 / 0, n = 0; for (let e = 0; e < t.length - 1; e++) t[e].x > r && (r = t[e].x, n = e); for (let e = 0; e < t.length - 1; e++) { const i = (n + e) % (t.length - 1), r = t[i], s = t[i + 1]; Math.abs(r.x - s.x) > .5 && (r.x < s.x ? (r.x += 1, 0 === i && (t[t.length - 1].x += 1)) : (s.x += 1, i + 1 === t.length - 1 && (t[0].x += 1)), o = !0); } const s = e.mercatorXfromLng(i.center.lng); return o && s < Math.abs(s - 1) && t.forEach((e => { e.x -= 1; })), { polygon: t, unwrapped: o } }(O(t, i).map((t => new e.pointGeometry(B(t.x), t.y))), i); return { polygon: r.polygon.map((t => new e.MercatorCoordinate(t.x, t.y))), unwrapped: r.unwrapped } } } function O(t, i) { return e.resample(t, (e => { const t = i.pointCoordinate3D(e); e.x = t.x, e.y = t.y; }), 1 / 256) } function B(e) { return e < 0 ? 1 + e % 1 : e % 1 } function k(e) { return 100 * e | 0 } function F(t, i, o, r, n) { const s = function(o, r) { if (o) return n(o); if (r) { t.url && r.tiles && t.tiles && delete t.tiles; const o = e.pick(e.extend(r, t), ["tiles", "minzoom", "maxzoom", "attribution", "mapbox_logo", "bounds", "scheme", "tileSize", "encoding"]); r.vector_layers && (o.vectorLayers = r.vector_layers, o.vectorLayerIds = o.vectorLayers.map((e => e.id))), o.tiles = i.canonicalizeTileset(o, t.url), n(null, o); } }; return t.url ? e.getJSON(i.transformRequest(i.normalizeSourceURL(t.url, null, o, r), e.ResourceType.Source), s) : e.exported.frame((() => s(null, t))) } class U { constructor(t, i, o) { this.bounds = e.LngLatBounds.convert(this.validateBounds(t)), this.minzoom = i || 0, this.maxzoom = o || 24; } validateBounds(e) { return Array.isArray(e) && 4 === e.length ? [Math.max(-180, e[0]), Math.max(-90, e[1]), Math.min(180, e[2]), Math.min(90, e[3])] : [-180, -90, 180, 90] } contains(t) { const i = Math.pow(2, t.z), o = Math.floor(e.mercatorXfromLng(this.bounds.getWest()) * i), r = Math.floor(e.mercatorYfromLat(this.bounds.getNorth()) * i), n = Math.ceil(e.mercatorXfromLng(this.bounds.getEast()) * i), s = Math.ceil(e.mercatorYfromLat(this.bounds.getSouth()) * i); return t.x >= o && t.x < n && t.y >= r && t.y < s } } class N { constructor(e, t, i) { this.context = e; const o = e.gl; this.buffer = o.createBuffer(), this.dynamicDraw = Boolean(i), this.context.unbindVAO(), e.bindElementBuffer.set(this.buffer), o.bufferData(o.ELEMENT_ARRAY_BUFFER, t.arrayBuffer, this.dynamicDraw ? o.DYNAMIC_DRAW : o.STATIC_DRAW), this.dynamicDraw || t.destroy(); } bind() { this.context.bindElementBuffer.set(this.buffer); } updateData(e) { const t = this.context.gl; this.context.unbindVAO(), this.bind(), t.bufferSubData(t.ELEMENT_ARRAY_BUFFER, 0, e.arrayBuffer); } destroy() { this.buffer && (this.context.gl.deleteBuffer(this.buffer), delete this.buffer); } } const G = { Int8: "BYTE", Uint8: "UNSIGNED_BYTE", Int16: "SHORT", Uint16: "UNSIGNED_SHORT", Int32: "INT", Uint32: "UNSIGNED_INT", Float32: "FLOAT" }; class j { constructor(e, t, i, o) { this.length = t.length, this.attributes = i, this.itemSize = t.bytesPerElement, this.dynamicDraw = o, this.context = e; const r = e.gl; this.buffer = r.createBuffer(), e.bindVertexBuffer.set(this.buffer), r.bufferData(r.ARRAY_BUFFER, t.arrayBuffer, this.dynamicDraw ? r.DYNAMIC_DRAW : r.STATIC_DRAW), this.dynamicDraw || t.destroy(); } bind() { this.context.bindVertexBuffer.set(this.buffer); } updateData(e) { const t = this.context.gl; this.bind(), t.bufferSubData(t.ARRAY_BUFFER, 0, e.arrayBuffer); } enableAttributes(e, t) { for (let i = 0; i < this.attributes.length; i++) { const o = t.attributes[this.attributes[i].name]; void 0 !== o && e.enableVertexAttribArray(o); } } setVertexAttribPointers(e, t, i) { for (let o = 0; o < this.attributes.length; o++) { const r = this.attributes[o], n = t.attributes[r.name]; void 0 !== n && e.vertexAttribPointer(n, r.components, e[G[r.type]], !1, this.itemSize, r.offset + this.itemSize * (i || 0)); } } destroy() { this.buffer && (this.context.gl.deleteBuffer(this.buffer), delete this.buffer); } } class Z { constructor(e) { this.gl = e.gl, this.default = this.getDefault(), this.current = this.default, this.dirty = !1; } get() { return this.current } set(e) {} getDefault() { return this.default } setDefault() { this.set(this.default); } } class V extends Z { getDefault() { return e.Color.transparent } set(e) { const t = this.current; (e.r !== t.r || e.g !== t.g || e.b !== t.b || e.a !== t.a || this.dirty) && (this.gl.clearColor(e.r, e.g, e.b, e.a), this.current = e, this.dirty = !1); } } class W extends Z { getDefault() { return 1 } set(e) { (e !== this.current || this.dirty) && (this.gl.clearDepth(e), this.current = e, this.dirty = !1); } } class X extends Z { getDefault() { return 0 } set(e) { (e !== this.current || this.dirty) && (this.gl.clearStencil(e), this.current = e, this.dirty = !1); } } class q extends Z { getDefault() { return [!0, !0, !0, !0] } set(e) { const t = this.current; (e[0] !== t[0] || e[1] !== t[1] || e[2] !== t[2] || e[3] !== t[3] || this.dirty) && (this.gl.colorMask(e[0], e[1], e[2], e[3]), this.current = e, this.dirty = !1); } } class $ extends Z { getDefault() { return !0 } set(e) { (e !== this.current || this.dirty) && (this.gl.depthMask(e), this.current = e, this.dirty = !1); } } class H extends Z { getDefault() { return 255 } set(e) { (e !== this.current || this.dirty) && (this.gl.stencilMask(e), this.current = e, this.dirty = !1); } } class Y extends Z { getDefault() { return { func: this.gl.ALWAYS, ref: 0, mask: 255 } } set(e) { const t = this.current; (e.func !== t.func || e.ref !== t.ref || e.mask !== t.mask || this.dirty) && (this.gl.stencilFunc(e.func, e.ref, e.mask), this.current = e, this.dirty = !1); } } class K extends Z { getDefault() { const e = this.gl; return [e.KEEP, e.KEEP, e.KEEP] } set(e) { const t = this.current; (e[0] !== t[0] || e[1] !== t[1] || e[2] !== t[2] || this.dirty) && (this.gl.stencilOp(e[0], e[1], e[2]), this.current = e, this.dirty = !1); } } class J extends Z { getDefault() { return !1 } set(e) { if (e === this.current && !this.dirty) return; const t = this.gl; e ? t.enable(t.STENCIL_TEST) : t.disable(t.STENCIL_TEST), this.current = e, this.dirty = !1; } } class Q extends Z { getDefault() { return [0, 1] } set(e) { const t = this.current; (e[0] !== t[0] || e[1] !== t[1] || this.dirty) && (this.gl.depthRange(e[0], e[1]), this.current = e, this.dirty = !1); } } class ee extends Z { getDefault() { return !1 } set(e) { if (e === this.current && !this.dirty) return; const t = this.gl; e ? t.enable(t.DEPTH_TEST) : t.disable(t.DEPTH_TEST), this.current = e, this.dirty = !1; } } class te extends Z { getDefault() { return this.gl.LESS } set(e) { (e !== this.current || this.dirty) && (this.gl.depthFunc(e), this.current = e, this.dirty = !1); } } class ie extends Z { getDefault() { return !1 } set(e) { if (e === this.current && !this.dirty) return; const t = this.gl; e ? t.enable(t.BLEND) : t.disable(t.BLEND), this.current = e, this.dirty = !1; } } class oe extends Z { getDefault() { const e = this.gl; return [e.ONE, e.ZERO] } set(e) { const t = this.current; (e[0] !== t[0] || e[1] !== t[1] || this.dirty) && (this.gl.blendFunc(e[0], e[1]), this.current = e, this.dirty = !1); } } class re extends Z { getDefault() { return e.Color.transparent } set(e) { const t = this.current; (e.r !== t.r || e.g !== t.g || e.b !== t.b || e.a !== t.a || this.dirty) && (this.gl.blendColor(e.r, e.g, e.b, e.a), this.current = e, this.dirty = !1); } } class ne extends Z { getDefault() { return this.gl.FUNC_ADD } set(e) { (e !== this.current || this.dirty) && (this.gl.blendEquation(e), this.current = e, this.dirty = !1); } } class se extends Z { getDefault() { return !1 } set(e) { if (e === this.current && !this.dirty) return; const t = this.gl; e ? t.enable(t.CULL_FACE) : t.disable(t.CULL_FACE), this.current = e, this.dirty = !1; } } class ae extends Z { getDefault() { return this.gl.BACK } set(e) { (e !== this.current || this.dirty) && (this.gl.cullFace(e), this.current = e, this.dirty = !1); } } class le extends Z { getDefault() { return this.gl.CCW } set(e) { (e !== this.current || this.dirty) && (this.gl.frontFace(e), this.current = e, this.dirty = !1); } } class ce extends Z { getDefault() { return null } set(e) { (e !== this.current || this.dirty) && (this.gl.useProgram(e), this.current = e, this.dirty = !1); } } class he extends Z { getDefault() { return this.gl.TEXTURE0 } set(e) { (e !== this.current || this.dirty) && (this.gl.activeTexture(e), this.current = e, this.dirty = !1); } } class ue extends Z { getDefault() { const e = this.gl; return [0, 0, e.drawingBufferWidth, e.drawingBufferHeight] } set(e) { const t = this.current; (e[0] !== t[0] || e[1] !== t[1] || e[2] !== t[2] || e[3] !== t[3] || this.dirty) && (this.gl.viewport(e[0], e[1], e[2], e[3]), this.current = e, this.dirty = !1); } } class _e extends Z { getDefault() { return null } set(e) { if (e === this.current && !this.dirty) return; const t = this.gl; t.bindFramebuffer(t.FRAMEBUFFER, e), this.current = e, this.dirty = !1; } } class de extends Z { getDefault() { return null } set(e) { if (e === this.current && !this.dirty) return; const t = this.gl; t.bindRenderbuffer(t.RENDERBUFFER, e), this.current = e, this.dirty = !1; } } class pe extends Z { getDefault() { return null } set(e) { if (e === this.current && !this.dirty) return; const t = this.gl; t.bindTexture(t.TEXTURE_2D, e), this.current = e, this.dirty = !1; } } class me extends Z { getDefault() { return null } set(e) { if (e === this.current && !this.dirty) return; const t = this.gl; t.bindBuffer(t.ARRAY_BUFFER, e), this.current = e, this.dirty = !1; } } class fe extends Z { getDefault() { return null } set(e) { const t = this.gl; t.bindBuffer(t.ELEMENT_ARRAY_BUFFER, e), this.current = e, this.dirty = !1; } } class ge extends Z { constructor(e) { super(e), this.vao = e.extVertexArrayObject; } getDefault() { return null } set(e) { this.vao && (e !== this.current || this.dirty) && (this.vao.bindVertexArrayOES(e), this.current = e, this.dirty = !1); } } class ve extends Z { getDefault() { return 4 } set(e) { if (e === this.current && !this.dirty) return; const t = this.gl; t.pixelStorei(t.UNPACK_ALIGNMENT, e), this.current = e, this.dirty = !1; } } class xe extends Z { getDefault() { return !1 } set(e) { if (e === this.current && !this.dirty) return; const t = this.gl; t.pixelStorei(t.UNPACK_PREMULTIPLY_ALPHA_WEBGL, e), this.current = e, this.dirty = !1; } } class ye extends Z { getDefault() { return !1 } set(e) { if (e === this.current && !this.dirty) return; const t = this.gl; t.pixelStorei(t.UNPACK_FLIP_Y_WEBGL, e), this.current = e, this.dirty = !1; } } class be extends Z { constructor(e, t) { super(e), this.context = e, this.parent = t; } getDefault() { return null } } class we extends be { setDirty() { this.dirty = !0; } set(e) { if (e === this.current && !this.dirty) return; this.context.bindFramebuffer.set(this.parent); const t = this.gl; t.framebufferTexture2D(t.FRAMEBUFFER, t.COLOR_ATTACHMENT0, t.TEXTURE_2D, e, 0), this.current = e, this.dirty = !1; } } class Te extends be { attachment() { return this.gl.DEPTH_ATTACHMENT } set(e) { if (e === this.current && !this.dirty) return; this.context.bindFramebuffer.set(this.parent); const t = this.gl; t.framebufferRenderbuffer(t.FRAMEBUFFER, this.attachment(), t.RENDERBUFFER, e), this.current = e, this.dirty = !1; } } class Ee extends Te { attachment() { return this.gl.DEPTH_STENCIL_ATTACHMENT } } class Ce { constructor(e, t, i, o) { this.context = e, this.width = t, this.height = i; const r = this.framebuffer = e.gl.createFramebuffer(); this.colorAttachment = new we(e, r), o && (this.depthAttachment = new Te(e, r)); } destroy() { const e = this.context.gl, t = this.colorAttachment.get(); if (t && e.deleteTexture(t), this.depthAttachment) { const t = this.depthAttachment.get(); t && e.deleteRenderbuffer(t); } e.deleteFramebuffer(this.framebuffer); } } class Me { constructor(e, t = !1) { if (this.gl = e, this.isWebGL2 = t, this.extVertexArrayObject = this.gl.getExtension("OES_vertex_array_object"), t) { const t = e; this.extVertexArrayObject = { createVertexArrayOES: t.createVertexArray.bind(e), deleteVertexArrayOES: t.deleteVertexArray.bind(e), bindVertexArrayOES: t.bindVertexArray.bind(e) }; } this.clearColor = new V(this), this.clearDepth = new W(this), this.clearStencil = new X(this), this.colorMask = new q(this), this.depthMask = new $(this), this.stencilMask = new H(this), this.stencilFunc = new Y(this), this.stencilOp = new K(this), this.stencilTest = new J(this), this.depthRange = new Q(this), this.depthTest = new ee(this), this.depthFunc = new te(this), this.blend = new ie(this), this.blendFunc = new oe(this), this.blendColor = new re(this), this.blendEquation = new ne(this), this.cullFace = new se(this), this.cullFaceSide = new ae(this), this.frontFace = new le(this), this.program = new ce(this), this.activeTexture = new he(this), this.viewport = new ue(this), this.bindFramebuffer = new _e(this), this.bindRenderbuffer = new de(this), this.bindTexture = new pe(this), this.bindVertexBuffer = new me(this), this.bindElementBuffer = new fe(this), this.bindVertexArrayOES = this.extVertexArrayObject && new ge(this), this.pixelStoreUnpack = new ve(this), this.pixelStoreUnpackPremultiplyAlpha = new xe(this), this.pixelStoreUnpackFlipY = new ye(this), this.extTextureFilterAnisotropic = e.getExtension("EXT_texture_filter_anisotropic") || e.getExtension("MOZ_EXT_texture_filter_anisotropic") || e.getExtension("WEBKIT_EXT_texture_filter_anisotropic"), this.extTextureFilterAnisotropic && (this.extTextureFilterAnisotropicMax = e.getParameter(this.extTextureFilterAnisotropic.MAX_TEXTURE_MAX_ANISOTROPY_EXT)), this.extTextureFilterAnisotropicForceOff = !1, this.extStandardDerivativesForceOff = !1, this.extDebugRendererInfo = e.getExtension("WEBGL_debug_renderer_info"), this.extDebugRendererInfo && (this.renderer = e.getParameter(this.extDebugRendererInfo.UNMASKED_RENDERER_WEBGL), this.vendor = e.getParameter(this.extDebugRendererInfo.UNMASKED_VENDOR_WEBGL)), t || (this.extTextureHalfFloat = e.getExtension("OES_texture_half_float")), (t || this.extTextureHalfFloat && e.getExtension("OES_texture_half_float_linear")) && (this.extRenderToTextureHalfFloat = e.getExtension("EXT_color_buffer_half_float")), this.extStandardDerivatives = t || e.getExtension("OES_standard_derivatives"), this.extTimerQuery = e.getExtension("EXT_disjoint_timer_query"), this.maxTextureSize = e.getParameter(e.MAX_TEXTURE_SIZE); } 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 = !0, this.clearDepth.dirty = !0, this.clearStencil.dirty = !0, this.colorMask.dirty = !0, this.depthMask.dirty = !0, this.stencilMask.dirty = !0, this.stencilFunc.dirty = !0, this.stencilOp.dirty = !0, this.stencilTest.dirty = !0, this.depthRange.dirty = !0, this.depthTest.dirty = !0, this.depthFunc.dirty = !0, this.blend.dirty = !0, this.blendFunc.dirty = !0, this.blendColor.dirty = !0, this.blendEquation.dirty = !0, this.cullFace.dirty = !0, this.cullFaceSide.dirty = !0, this.frontFace.dirty = !0, this.program.dirty = !0, this.activeTexture.dirty = !0, this.viewport.dirty = !0, this.bindFramebuffer.dirty = !0, this.bindRenderbuffer.dirty = !0, this.bindTexture.dirty = !0, this.bindVertexBuffer.dirty = !0, this.bindElementBuffer.dirty = !0, this.extVertexArrayObject && (this.bindVertexArrayOES.dirty = !0), this.pixelStoreUnpack.dirty = !0, this.pixelStoreUnpackPremultiplyAlpha.dirty = !0, this.pixelStoreUnpackFlipY.dirty = !0; } createIndexBuffer(e, t) { return new N(this, e, t) } createVertexBuffer(e, t, i) { return new j(this, e, t, i) } createRenderbuffer(e, t, i) { const o = this.gl, r = o.createRenderbuffer(); return this.bindRenderbuffer.set(r), o.renderbufferStorage(o.RENDERBUFFER, e, t, i), this.bindRenderbuffer.set(null), r } createFramebuffer(e, t, i) { return new Ce(this, e, t, i) } clear({ color: e, depth: t, stencil: i }) { const o = this.gl; let r = 0; e && (r |= o.COLOR_BUFFER_BIT, this.clearColor.set(e), this.colorMask.set([!0, !0, !0, !0])), void 0 !== t && (r |= o.DEPTH_BUFFER_BIT, this.depthRange.set([0, 1]), this.clearDepth.set(t), this.depthMask.set(!0)), void 0 !== i && (r |= o.STENCIL_BUFFER_BIT, this.clearStencil.set(i), this.stencilMask.set(255)), o.clear(r); } setCullFace(e) { !1 === e.enable ? this.cullFace.set(!1) : (this.cullFace.set(!0), this.cullFaceSide.set(e.mode), this.frontFace.set(e.frontFace)); } setDepthMode(e) { e.func !== this.gl.ALWAYS || e.mask ? (this.depthTest.set(!0), this.depthFunc.set(e.func), this.depthMask.set(e.mask), this.depthRange.set(e.range)) : this.depthTest.set(!1); } setStencilMode(e) { e.test.func !== this.gl.ALWAYS || e.mask ? (this.stencilTest.set(!0), this.stencilMask.set(e.mask), this.stencilOp.set([e.fail, e.depthFail, e.pass]), this.stencilFunc.set({ func: e.test.func, ref: e.ref, mask: e.test.mask })) : this.stencilTest.set(!1); } setColorMode(i) { t(i.blendFunction, e.ColorMode.Replace) ? this.blend.set(!1) : (this.blend.set(!0), this.blendFunc.set(i.blendFunction), this.blendColor.set(i.blendColor)), this.colorMask.set(i.mask); } unbindVAO() { this.extVertexArrayObject && this.bindVertexArrayOES.set(null); } } class Ie extends e.Evented { constructor(t, i, o, r) { if (super(), this.id = t, this.dispatcher = o, this.type = "vector", this.minzoom = 0, this.maxzoom = 22, this.scheme = "xyz", this.tileSize = 512, this.reparseOverscaled = !0, this.isTileClipped = !0, this._loaded = !1, e.extend(this, e.pick(i, ["url", "scheme", "tileSize", "promoteId"])), this._options = e.extend({ type: "vector" }, i), this._collectResourceTiming = i.collectResourceTiming, 512 !== this.tileSize) throw new Error("vector tile sources must have a tileSize of 512"); this.setEventedParent(r), this._tileWorkers = {}, this._deduped = new e.DedupedRequest; } load(t) { this._loaded = !1, this.fire(new e.Event("dataloading", { dataType: "source" })); const i = Array.isArray(this.map._language) ? this.map._language.join() : this.map._language, o = this.map._worldview; this._tileJSONRequest = F(this._options, this.map._requestManager, i, o, ((r, n) => { this._tileJSONRequest = null, this._loaded = !0, r ? (i && console.warn(`Ensure that your requested language string is a valid BCP-47 code or list of codes. Found: ${i}`), o && 2 !== o.length && console.warn(`Requested worldview strings must be a valid ISO alpha-2 code. Found: ${o}`), this.fire(new e.ErrorEvent(r))) : n && (e.extend(this, n), n.bounds && (this.tileBounds = new U(n.bounds, this.minzoom, this.maxzoom)), e.postTurnstileEvent(n.tiles, this.map._requestManager._customAccessToken), this.fire(new e.Event("data", { dataType: "source", sourceDataType: "metadata" })), this.fire(new e.Event("data", { dataType: "source", sourceDataType: "content" }))), t && t(r); })); } loaded() { return this._loaded } hasTile(e) { return !this.tileBounds || this.tileBounds.contains(e.canonical) } onAdd(e) { this.map = e, this.load(); } reload() { this.cancelTileJSONRequest(), this.load((() => this.map.style._clearSource(this.id))); } setTiles(e) { return this._options.tiles = e, this.reload(), this } setUrl(e) { return this.url = e, this._options.url = e, this.reload(), this } onRemove() { this.cancelTileJSONRequest(); } serialize() { return e.extend({}, this._options) } loadTile(t, i) { const o = this.map._requestManager.normalizeTileURL(t.tileID.canonical.url(this.tiles, this.scheme)), r = { request: this.map._requestManager.transformRequest(o, e.ResourceType.Tile), data: void 0, uid: t.uid, tileID: t.tileID, tileZoom: t.tileZoom, zoom: t.tileID.overscaledZ, tileSize: this.tileSize * t.tileID.overscaleFactor(), type: this.type, source: this.id, pixelRatio: e.exported.devicePixelRatio, showCollisionBoxes: this.map.showCollisionBoxes, promoteId: this.promoteId, isSymbolTile: t.isSymbolTile }; if (r.request.collectResourceTiming = this._collectResourceTiming, t.actor && "expired" !== t.state) "loading" === t.state ? t.reloadCallback = i : t.request = t.actor.send("reloadTile", r, n.bind(this)); else if (t.actor = this._tileWorkers[o] = this._tileWorkers[o] || this.dispatcher.getActor(), this.dispatcher.ready) t.request = t.actor.send("loadTile", r, n.bind(this), void 0, !0); else { const i = e.loadVectorTile.call({ deduped: this._deduped }, r, ((e, i) => { e || !i ? n.call(this, e) : (r.data = { cacheControl: i.cacheControl, expires: i.expires, rawData: i.rawData.slice(0) }, t.actor && t.actor.send("loadTile", r, n.bind(this), void 0, !0)); }), !0); t.request = { cancel: i }; } function n(o, r) { return delete t.request, t.aborted ? i(null) : o && 404 !== o.status ? i(o) : (r && r.resourceTiming && (t.resourceTiming = r.resourceTiming), this.map._refreshExpiredTiles && r && t.setExpiryData(r), t.loadVectorData(r, this.map.painter), e.cacheEntryPossiblyAdded(this.dispatcher), i(null), void(t.reloadCallback && (this.loadTile(t, t.reloadCallback), t.reloadCallback = null))) } } abortTile(e) { e.request && (e.request.cancel(), delete e.request), e.actor && e.actor.send("abortTile", { uid: e.uid, type: this.type, source: this.id }); } unloadTile(e) { e.unloadVectorData(), e.actor && e.actor.send("removeTile", { uid: e.uid, type: this.type, source: this.id }); } hasTransition() { return !1 } afterUpdate() { this._tileWorkers = {}; } cancelTileJSONRequest() { this._tileJSONRequest && (this._tileJSONRequest.cancel(), this._tileJSONRequest = null); } } class Se extends e.Evented { constructor(t, i, o, r) { super(), this.id = t, this.dispatcher = o, this.setEventedParent(r), this.type = "raster", this.minzoom = 0, this.maxzoom = 22, this.roundZoom = !0, this.scheme = "xyz", this.tileSize = 512, this._loaded = !1, this._options = e.extend({ type: "raster" }, i), e.extend(this, e.pick(i, ["url", "scheme", "tileSize"])); } load(t) { this._loaded = !1, this.fire(new e.Event("dataloading", { dataType: "source" })), this._tileJSONRequest = F(this._options, this.map._requestManager, null, null, ((i, o) => { this._tileJSONRequest = null, this._loaded = !0, i ? this.fire(new e.ErrorEvent(i)) : o && (e.extend(this, o), o.bounds && (this.tileBounds = new U(o.bounds, this.minzoom, this.maxzoom)), e.postTurnstileEvent(o.tiles), this.fire(new e.Event("data", { dataType: "source", sourceDataType: "metadata" })), this.fire(new e.Event("data", { dataType: "source", sourceDataType: "content" }))), t && t(i); })); } loaded() { return this._loaded } onAdd(e) { this.map = e, this.load(); } reload() { this.cancelTileJSONRequest(), this.load((() => this.map.style._clearSource(this.id))); } setTiles(e) { return this._options.tiles = e, this.reload(), this } setUrl(e) { return this.url = e, this._options.url = e, this.reload(), this } onRemove() { this.cancelTileJSONRequest(); } serialize() { return e.extend({}, this._options) } hasTile(e) { return !this.tileBounds || this.tileBounds.contains(e.canonical) } loadTile(t, i) { const o = e.exported.devicePixelRatio >= 2, r = this.map._requestManager.normalizeTileURL(t.tileID.canonical.url(this.tiles, this.scheme), o, this.tileSize); t.request = e.getImage(this.map._requestManager.transformRequest(r, e.ResourceType.Tile), ((o, r, n, s) => (delete t.request, t.aborted ? (t.state = "unloaded", i(null)) : o ? (t.state = "errored", i(o)) : r ? (this.map._refreshExpiredTiles && t.setExpiryData({ cacheControl: n, expires: s }), t.setTexture(r, this.map.painter), t.state = "loaded", e.cacheEntryPossiblyAdded(this.dispatcher), void i(null)) : i(null)))); } static loadTileData(e, t, i) { e.setTexture(t, i); } static unloadTileData(e, t) { e.texture && t.saveTileTexture(e.texture); } abortTile(e, t) { e.request && (e.request.cancel(), delete e.request), t(); } unloadTile(e, t) { e.texture && this.map.painter.saveTileTexture(e.texture), t(); } hasTransition() { return !1 } cancelTileJSONRequest() { this._tileJSONRequest && (this._tileJSONRequest.cancel(), this._tileJSONRequest = null); } } let De; function Le(t, i, o, r, n, s, a, l) { const c = [t, o, n, i, r, s, 1, 1, 1], h = [a, l, 1], u = e.adjoint([], c), [_, d, p] = e.transformMat3(h, h, e.transpose(u, u)); return e.multiply$1(c, [_, 0, 0, 0, d, 0, 0, 0, p], c) } class Ae extends e.Evented { constructor(e, t, i, o) { super(), this.id = e, this.dispatcher = i, this.coordinates = t.coordinates, this.type = "image", this.minzoom = 0, this.maxzoom = 22, this.tileSize = 512, this.tiles = {}, this._loaded = !1, this.setEventedParent(o), this.options = t, this._dirty = !1; } load(t, i) { this._loaded = i || !1, this.fire(new e.Event("dataloading", { dataType: "source" })), this.url = this.options.url, this._imageRequest = e.getImage(this.map._requestManager.transformRequest(this.url, e.ResourceType.Image), ((i, o) => { if (this._imageRequest = null, this._loaded = !0, i) this.fire(new e.ErrorEvent(i)); else if (o) { const { HTMLImageElement: i } = e.window; this.image = o instanceof i ? e.exported.getImageData(o) : o, this._dirty = !0, this.width = this.image.width, this.height = this.image.height, t && (this.coordinates = t), this._finishLoading(); } })); } loaded() { return this._loaded } updateImage(e) { return this.image && e.url ? (this._imageRequest && e.url !== this.options.url && (this._imageRequest.cancel(), this._imageRequest = null), this.options.url = e.url, this.load(e.coordinates, this._loaded), this) : this } _finishLoading() { this.map && (this.setCoordinates(this.coordinates), this.fire(new e.Event("data", { dataType: "source", sourceDataType: "metadata" }))); } onAdd(e) { this.map = e, this.load(); } onRemove() { this._imageRequest && (this._imageRequest.cancel(), this._imageRequest = null), this.texture && this.texture.destroy(); } setCoordinates(t) { this.coordinates = t, this._boundsArray = void 0; const i = t.map(e.MercatorCoordinate.fromLngLat); return this.tileID = function(t) { let i = 1 / 0, o = 1 / 0, r = -1 / 0, n = -1 / 0; for (const e of t) i = Math.min(i, e.x), o = Math.min(o, e.y), r = Math.max(r, e.x), n = Math.max(n, e.y); const s = Math.max(r - i, n - o), a = Math.max(0, Math.floor(-Math.log(s) / Math.LN2)), l = Math.pow(2, a); return new e.CanonicalTileID(a, Math.floor((i + r) / 2 * l), Math.floor((o + n) / 2 * l)) }(i), this.minzoom = this.maxzoom = this.tileID.z, this.fire(new e.Event("data", { dataType: "source", sourceDataType: "content" })), this } _clear() { this._boundsArray = void 0; } _prepareData(t) { for (const e in this.tiles) { const t = this.tiles[e]; "loaded" !== t.state && (t.state = "loaded", t.texture = this.texture); } if (this._boundsArray) return; const i = e.tileTransform(this.tileID, this.map.transform.projection), [o, r, n, s] = this.coordinates.map((t => { const o = i.projection.project(t[0], t[1]); return e.getTilePoint(i, o)._round() })); this.perspectiveTransform = function(t, i, o, r, n, s, a, l, c, h) { const u = Le(0, 0, t, 0, 0, i, t, i), _ = Le(o, r, n, s, a, l, c, h); return e.multiply$1(_, e.adjoint(u, u), _), [_[6] / _[8] * t / e.EXTENT, _[7] / _[8] * i / e.EXTENT] }(this.width, this.height, o.x, o.y, r.x, r.y, s.x, s.y, n.x, n.y); const a = this._boundsArray = new e.StructArrayLayout4i8; a.emplaceBack(o.x, o.y, 0, 0), a.emplaceBack(r.x, r.y, e.EXTENT, 0), a.emplaceBack(s.x, s.y, 0, e.EXTENT), a.emplaceBack(n.x, n.y, e.EXTENT, e.EXTENT), this.boundsBuffer && this.boundsBuffer.destroy(), this.boundsBuffer = t.createVertexBuffer(a, e.boundsAttributes.members), this.boundsSegments = e.SegmentVector.simpleSegment(0, 0, 4, 2); } prepare() { if (0 === Object.keys(this.tiles).length || !this.image) return; const t = this.map.painter.context, i = t.gl; this._dirty && (this.texture ? this.texture.update(this.image) : (this.texture = new e.Texture(t, this.image, i.RGBA), this.texture.bind(i.LINEAR, i.CLAMP_TO_EDGE)), this._dirty = !1), this._prepareData(t); } loadTile(e, t) { this.tileID && this.tileID.equals(e.tileID.canonical) ? (this.tiles[String(e.tileID.wrap)] = e, e.buckets = {}, t(null)) : (e.state = "errored", t(null)); } serialize() { return { type: "image", url: this.options.url, coordinates: this.coordinates } } hasTransition() { return !1 } } const ze = { vector: Ie, raster: Se, "raster-dem": class extends Se { constructor(t, i, o, r) { super(t, i, o, r), this.type = "raster-dem", this.maxzoom = 22, this._options = e.extend({ type: "raster-dem" }, i), this.encoding = i.encoding || "mapbox"; } loadTile(t, i) { const o = this.map._requestManager.normalizeTileURL(t.tileID.canonical.url(this.tiles, this.scheme), !1, this.tileSize); function r(e, o) { e && (t.state = "errored", i(e)), o && (t.dem = o, t.dem.onDeserialize(), t.needsHillshadePrepare = !0, t.needsDEMTextureUpload = !0, t.state = "loaded", i(null)); } t.request = e.getImage(this.map._requestManager.transformRequest(o, e.ResourceType.Tile), function(o, n, s, a) { if (delete t.request, t.aborted) t.state = "unloaded", i(null); else if (o) t.state = "errored", i(o); else if (n) { this.map._refreshExpiredTiles && t.setExpiryData({ cacheControl: s, expires: a }); const i = e.window.ImageBitmap && n instanceof e.window.ImageBitmap && (null == De && (De = e.window.OffscreenCanvas && new e.window.OffscreenCanvas(1, 1).getContext("2d") && "function" == typeof e.window.createImageBitmap), De), o = 1 - (n.width - e.prevPowerOfTwo(n.width)) / 2; o < 1 || t.neighboringTiles || (t.neighboringTiles = this._getNeighboringTiles(t.tileID)); const l = i ? n : e.exported.getImageData(n, o), c = { uid: t.uid, coord: t.tileID, source: this.id, rawImageData: l, encoding: this.encoding, padding: o }; t.actor && "expired" !== t.state || (t.actor = this.dispatcher.getActor(), t.actor.send("loadDEMTile", c, r.bind(this), void 0, !0)); } }.bind(this)); } _getNeighboringTiles(t) { const i = t.canonical, o = Math.pow(2, i.z), r = (i.x - 1 + o) % o, n = 0 === i.x ? t.wrap - 1 : t.wrap, s = (i.x + 1 + o) % o, a = i.x + 1 === o ? t.wrap + 1 : t.wrap, l = {}; return l[new e.OverscaledTileID(t.overscaledZ, n, i.z, r, i.y).key] = { backfilled: !1 }, l[new e.OverscaledTileID(t.overscaledZ, a, i.z, s, i.y).key] = { backfilled: !1 }, i.y > 0 && (l[new e.OverscaledTileID(t.overscaledZ, n, i.z, r, i.y - 1).key] = { backfilled: !1 }, l[new e.OverscaledTileID(t.overscaledZ, t.wrap, i.z, i.x, i.y - 1).key] = { backfilled: !1 }, l[new e.OverscaledTileID(t.overscaledZ, a, i.z, s, i.y - 1).key] = { backfilled: !1 }), i.y + 1 < o && (l[new e.OverscaledTileID(t.overscaledZ, n, i.z, r, i.y + 1).key] = { backfilled: !1 }, l[new e.OverscaledTileID(t.overscaledZ, t.wrap, i.z, i.x, i.y + 1).key] = { backfilled: !1 }, l[new e.OverscaledTileID(t.overscaledZ, a, i.z, s, i.y + 1).key] = { backfilled: !1 }), l } unloadTile(e) { e.demTexture && this.map.painter.saveTileTexture(e.demTexture), e.fbo && (e.fbo.destroy(), delete e.fbo), e.dem && delete e.dem, delete e.neighboringTiles, e.state = "unloaded"; } }, geojson: class extends e.Evented { constructor(t, i, o, r) { super(), this.id = t, this.type = "geojson", this.minzoom = 0, this.maxzoom = 18, this.tileSize = 512, this.isTileClipped = !0, this.reparseOverscaled = !0, this._loaded = !1, this.actor = o.getActor(), this.setEventedParent(r), this._data = i.data, this._options = e.extend({}, i), this._collectResourceTiming = i.collectResourceTiming, void 0 !== i.maxzoom && (this.maxzoom = i.maxzoom), i.type && (this.type = i.type), i.attribution && (this.attribution = i.attribution), this.promoteId = i.promoteId; const n = e.EXTENT / this.tileSize; this.workerOptions = e.extend({ source: this.id, cluster: i.cluster || !1, geojsonVtOptions: { buffer: (void 0 !== i.buffer ? i.buffer : 128) * n, tolerance: (void 0 !== i.tolerance ? i.tolerance : .375) * n, extent: e.EXTENT, maxZoom: this.maxzoom, lineMetrics: i.lineMetrics || !1, generateId: i.generateId || !1 }, superclusterOptions: { maxZoom: void 0 !== i.clusterMaxZoom ? i.clusterMaxZoom : this.maxzoom - 1, minPoints: Math.max(2, i.clusterMinPoints || 2), extent: e.EXTENT, radius: (void 0 !== i.clusterRadius ? i.clusterRadius : 50) * n, log: !1, generateId: i.generateId || !1 }, clusterProperties: i.clusterProperties, filter: i.filter }, i.workerOptions); } onAdd(e) { this.map = e, this.setData(this._data); } setData(e) { return this._data = e, this._updateWorkerData(), this } getClusterExpansionZoom(e, t) { return this.actor.send("geojson.getClusterExpansionZoom", { clusterId: e, source: this.id }, t), this } getClusterChildren(e, t) { return this.actor.send("geojson.getClusterChildren", { clusterId: e, source: this.id }, t), this } getClusterLeaves(e, t, i, o) { return this.actor.send("geojson.getClusterLeaves", { source: this.id, clusterId: e, limit: t, offset: i }, o), this } _updateWorkerData() { if (this._pendingLoad) return void(this._coalesce = !0); this.fire(new e.Event("dataloading", { dataType: "source" })), this._loaded = !1; const t = e.extend({}, this.workerOptions), i = this._data; "string" == typeof i ? (t.request = this.map._requestManager.transformRequest(e.exported.resolveURL(i), e.ResourceType.Source), t.request.collectResourceTiming = this._collectResourceTiming) : t.data = JSON.stringify(i), this._pendingLoad = this.actor.send(`${this.type}.loadData`, t, ((t, i) => { if (this._loaded = !0, this._pendingLoad = null, t) this.fire(new e.ErrorEvent(t)); else { const t = { dataType: "source", sourceDataType: this._metadataFired ? "content" : "metadata" }; this._collectResourceTiming && i && i.resourceTiming && i.resourceTiming[this.id] && (t.resourceTiming = i.resourceTiming[this.id]), this.fire(new e.Event("data", t)), this._metadataFired = !0; } this._coalesce && (this._updateWorkerData(), this._coalesce = !1); })); } loaded() { return this._loaded } loadTile(t, i) { const o = t.actor ? "reloadTile" : "loadTile"; t.actor = this.actor, t.request = this.actor.send(o, { type: this.type, uid: t.uid, tileID: t.tileID, tileZoom: t.tileZoom, zoom: t.tileID.overscaledZ, maxZoom: this.maxzoom, tileSize: this.tileSize, source: this.id, pixelRatio: e.exported.devicePixelRatio, showCollisionBoxes: this.map.showCollisionBoxes, promoteId: this.promoteId }, ((e, r) => (delete t.request, t.unloadVectorData(), t.aborted ? i(null) : e ? i(e) : (t.loadVectorData(r, this.map.painter, "reloadTile" === o), i(null)))), void 0, "loadTile" === o); } abortTile(e) { e.request && (e.request.cancel(), delete e.request), e.aborted = !0; } unloadTile(e) { e.unloadVectorData(), this.actor.send("removeTile", { uid: e.uid, type: this.type, source: this.id }); } onRemove() { this._pendingLoad && this._pendingLoad.cancel(); } serialize() { return e.extend({}, this._options, { type: this.type, data: this._data }) } hasTransition() { return !1 } }, video: class extends Ae { constructor(e, t, i, o) { super(e, t, i, o), this.roundZoom = !0, this.type = "video", this.options = t; } load() { this._loaded = !1; const t = this.options; this.urls = []; for (const i of t.urls) this.urls.push(this.map._requestManager.transformRequest(i, e.ResourceType.Source).url); e.getVideo(this.urls, ((t, i) => { this._loaded = !0, t ? this.fire(new e.ErrorEvent(t)) : i && (this.video = i, this.video.loop = !0, this.video.setAttribute("playsinline", ""), this.video.addEventListener("playing", (() => { this.map.triggerRepaint(); })), this.map && this.video.play(), this._finishLoading()); })); } pause() { this.video && this.video.pause(); } play() { this.video && this.video.play(); } seek(t) { if (this.video) { const i = this.video.seekable; t < i.start(0) || t > i.end(0) ? this.fire(new e.ErrorEvent(new e.ValidationError(`sources.${this.id}`, null, `Playback for this video can be set only between the ${i.start(0)} and ${i.end(0)}-second mark.`))) : this.video.currentTime = t; } } getVideo() { return this.video } onAdd(e) { this.map || (this.map = e, this.load(), this.video && (this.video.play(), this.setCoordinates(this.coordinates))); } prepare() { if (0 === Object.keys(this.tiles).length || this.video.readyState < 2) return; const t = this.map.painter.context, i = t.gl; this.texture ? this.video.paused || (this.texture.bind(i.LINEAR, i.CLAMP_TO_EDGE), i.texSubImage2D(i.TEXTURE_2D, 0, 0, 0, i.RGBA, i.UNSIGNED_BYTE, this.video)) : (this.texture = new e.Texture(t, this.video, i.RGBA), this.texture.bind(i.LINEAR, i.CLAMP_TO_EDGE), this.width = this.video.videoWidth, this.height = this.video.videoHeight), this._prepareData(t); } serialize() { return { type: "video", urls: this.urls, coordinates: this.coordinates } } hasTransition() { return this.video && !this.video.paused } }, image: Ae, canvas: class extends Ae { constructor(t, i, o, r) { super(t, i, o, r), i.coordinates ? Array.isArray(i.coordinates) && 4 === i.coordinates.length && !i.coordinates.some((e => !Array.isArray(e) || 2 !== e.length || e.some((e => "number" != typeof e)))) || this.fire(new e.ErrorEvent(new e.ValidationError(`sources.${t}`, null, '"coordinates" property must be an array of 4 longitude/latitude array pairs'))) : this.fire(new e.ErrorEvent(new e.ValidationError(`sources.${t}`, null, 'missing required property "coordinates"'))), i.animate && "boolean" != typeof i.animate && this.fire(new e.ErrorEvent(new e.ValidationError(`sources.${t}`, null, 'optional "animate" property must be a boolean value'))), i.canvas ? "string" == typeof i.canvas || i.canvas instanceof e.window.HTMLCanvasElement || this.fire(new e.ErrorEvent(new e.ValidationError(`sources.${t}`, 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 e.ErrorEvent(new e.ValidationError(`sources.${t}`, null, 'missing required property "canvas"'))), this.options = i, this.animate = void 0 === i.animate || i.animate; } load() { this._loaded = !0, this.canvas || (this.canvas = this.options.canvas instanceof e.window.HTMLCanvasElement ? this.options.canvas : e.window.document.getElementById(this.options.canvas)), this.width = this.canvas.width, this.height = this.canvas.height, this._hasInvalidDimensions() ? this.fire(new e.ErrorEvent(new Error("Canvas dimensions cannot be less than or equal to zero."))) : (this.play = function() { this._playing = !0, this.map.triggerRepaint(); }, this.pause = function() { this._playing && (this.prepare(), this._playing = !1); }, this._finishLoading()); } getCanvas() { return this.canvas } onAdd(e) { this.map = e, this.load(), this.canvas && this.animate && this.play(); } onRemove() { this.pause(); } prepare() { let t = !1; if (this.canvas.width !== this.width && (this.width = this.canvas.width, t = !0), this.canvas.height !== this.height && (this.height = this.canvas.height, t = !0), this._hasInvalidDimensions()) return; if (0 === Object.keys(this.tiles).length) return; const i = this.map.painter.context; this.texture ? (t || this._playing) && this.texture.update(this.canvas, { premultiply: !0 }) : this.texture = new e.Texture(i, this.canvas, i.gl.RGBA, { premultiply: !0 }), this._prepareData(i); } serialize() { return { type: "canvas", coordinates: this.coordinates } } hasTransition() { return this._playing } _hasInvalidDimensions() { for (const e of [this.canvas.width, this.canvas.height]) if (isNaN(e) || e <= 0) return !0; return !1 } }, custom: class extends e.Evented { constructor(t, i, o, r) { super(), this.id = t, this.type = "custom", this._dataType = "raster", this._dispatcher = o, this._implementation = i, this.setEventedParent(r), this.scheme = "xyz", this.minzoom = 0, this.maxzoom = 22, this.tileSize = 512, this._loaded = !1, this.roundZoom = !0, this._implementation || this.fire(new e.ErrorEvent(new Error(`Missing implementation for ${this.id} custom source`))), this._implementation.loadTile || this.fire(new e.ErrorEvent(new Error(`Missing loadTile implementation for ${this.id} custom source`))), this._implementation.bounds && (this.tileBounds = new U(this._implementation.bounds, this.minzoom, this.maxzoom)), i.update = this._update.bind(this), i.clearTiles = this._clearTiles.bind(this), i.coveringTiles = this._coveringTiles.bind(this), e.extend(this, e.pick(i, ["dataType", "scheme", "minzoom", "maxzoom", "tileSize", "attribution", "minTileCacheSize", "maxTileCacheSize"])); } serialize() { return e.pick(this, ["type", "scheme", "minzoom", "maxzoom", "tileSize", "attribution"]) } load() { this._loaded = !0, this.fire(new e.Event("data", { dataType: "source", sourceDataType: "metadata" })), this.fire(new e.Event("data", { dataType: "source", sourceDataType: "content" })); } loaded() { return this._loaded } onAdd(t) { this._map = t, this._loaded = !1, this.fire(new e.Event("dataloading", { dataType: "source" })), this._implementation.onAdd && this._implementation.onAdd(t), this.load(); } onRemove(e) { this._implementation.onRemove && this._implementation.onRemove(e); } hasTile(e) { if (this._implementation.hasTile) { const { x: t, y: i, z: o } = e.canonical; return this._implementation.hasTile({ x: t, y: i, z: o }) } return !this.tileBounds || this.tileBounds.contains(e.canonical) } loadTile(t, i) { const { x: o, y: r, z: n } = t.tileID.canonical, s = new e.window.AbortController; t.request = Promise.resolve(this._implementation.loadTile({ x: o, y: r, z: n }, { signal: s.signal })).then(function(o) { return delete t.request, t.aborted ? (t.state = "unloaded", i(null)) : void 0 === o ? (t.state = "errored", i(null)) : null === o ? (this.loadTileData(t, { width: this.tileSize, height: this.tileSize, data: null }), t.state = "loaded", i(null)) : function(t) { return t instanceof e.window.ImageData || t instanceof e.window.HTMLCanvasElement || t instanceof e.window.ImageBitmap || t instanceof e.window.HTMLImageElement }(o) ? (this.loadTileData(t, o), t.state = "loaded", void i(null)) : (t.state = "errored", i(new Error(`Can't infer data type for ${this.id}, only raster data supported at the moment`))) }.bind(this)).catch((e => { 20 !== e.code && (t.state = "errored", i(e)); })), t.request.cancel = () => s.abort(); } loadTileData(e, t) { Se.loadTileData(e, t, this._map.painter); } unloadTileData(e) { Se.unloadTileData(e, this._map.painter); } unloadTile(e, t) { if (this.unloadTileData(e), this._implementation.unloadTile) { const { x: t, y: i, z: o } = e.tileID.canonical; this._implementation.unloadTile({ x: t, y: i, z: o }); } t(); } abortTile(e, t) { e.request && e.request.cancel && (e.request.cancel(), delete e.request), t(); } hasTransition() { return !1 } _coveringTiles() { return this._map.transform.coveringTiles({ tileSize: this.tileSize, minzoom: this.minzoom, maxzoom: this.maxzoom, roundZoom: this.roundZoom }).map((e => ({ x: e.canonical.x, y: e.canonical.y, z: e.canonical.z }))) } _clearTiles() { this._map.style._clearSource(this.id); } _update() { this.fire(new e.Event("data", { dataType: "source", sourceDataType: "content" })); } } }, Pe = function(t, i, o, r) { const n = new ze[i.type](t, i, o, r); if (n.id !== t) throw new Error(`Expected Source id to be ${t} instead of ${n.id}`); return e.bindAll(["load", "abort", "unload", "serialize", "prepare"], n), n }; function Re(t, i) { const o = e.identity([]); return e.scale(o, o, [.5 * t.width, .5 * -t.height, 1]), e.translate(o, o, [1, -1, 0]), e.multiply(o, o, t.calculateProjMatrix(i.toUnwrapped())), Float32Array.from(o) } function Oe(e, t, i, o, r, n, s, a = !1) { const l = e.tilesIn(o, s, a); l.sort(ke); const c = []; for (const o of l) c.push({ wrappedTileID: o.tile.tileID.wrapped().key, queryResults: o.tile.queryRenderedFeatures(t, i, e._state, o, r, n, Re(e.transform, o.tile.tileID), a) }); const h = function(e) { const t = {}, i = {}; for (const o of e) { const e = o.queryResults, r = o.wrappedTileID, n = i[r] = i[r] || {}; for (const i in e) { const o = e[i], r = n[i] = n[i] || {}, s = t[i] = t[i] || []; for (const e of o) r[e.featureIndex] || (r[e.featureIndex] = !0, s.push(e)); } } return t }(c); for (const t in h) h[t].forEach((t => { const i = t.feature, o = i.layer; o && "background" !== o.type && "sky" !== o.type && (i.source = o.source, o["source-layer"] && (i.sourceLayer = o["source-layer"]), i.state = void 0 !== i.id ? e.getFeatureState(o["source-layer"], i.id) : {}); })); return h } function Be(e, t) { const i = e.getRenderableIds().map((t => e.getTileByID(t))), o = [], r = {}; for (let e = 0; e < i.length; e++) { const n = i[e], s = n.tileID.canonical.key; r[s] || (r[s] = !0, n.querySourceFeatures(o, t)); } return o } function ke(e, t) { const i = e.tileID, o = t.tileID; return i.overscaledZ - o.overscaledZ || i.canonical.y - o.canonical.y || i.wrap - o.wrap || i.canonical.x - o.canonical.x } function Fe() { return null != fn.workerClass ? new fn.workerClass : new e.window.Worker(fn.workerUrl) } const Ue = "mapboxgl_preloaded_worker_pool"; class Ne { constructor() { this.active = {}; } acquire(e) { if (!this.workers) for (this.workers = []; this.workers.length < Ne.workerCount;) this.workers.push(new Fe); return this.active[e] = !0, this.workers.slice() } release(e) { delete this.active[e], 0 === this.numActive() && (this.workers.forEach((e => { e.terminate(); })), this.workers = null); } isPreloaded() { return !!this.active[Ue] } numActive() { return Object.keys(this.active).length } } let Ge; function je() { return Ge || (Ge = new Ne), Ge } function Ze(t, i) { const o = {}; for (const e in t) "ref" !== e && (o[e] = t[e]); return e.refProperties.forEach((e => { e in i && (o[e] = i[e]); })), o } function Ve(e) { e = e.slice(); const t = Object.create(null); for (let i = 0; i < e.length; i++) t[e[i].id] = e[i]; for (let i = 0; i < e.length; i++) "ref" in e[i] && (e[i] = Ze(e[i], t[e[i].ref])); return e } Ne.workerCount = 2; const We = { 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", setTerrain: "setTerrain", setFog: "setFog", setProjection: "setProjection" }; function Xe(e, t, i) { i.push({ command: We.addSource, args: [e, t[e]] }); } function qe(e, t, i) { t.push({ command: We.removeSource, args: [e] }), i[e] = !0; } function $e(e, t, i, o) { qe(e, i, o), Xe(e, t, i); } function He(e, i, o) { let r; for (r in e[o]) if (e[o].hasOwnProperty(r) && "data" !== r && !t(e[o][r], i[o][r])) return !1; for (r in i[o]) if (i[o].hasOwnProperty(r) && "data" !== r && !t(e[o][r], i[o][r])) return !1; return !0 } function Ye(e, i, o, r, n, s) { let a; for (a in i = i || {}, e = e || {}) e.hasOwnProperty(a) && (t(e[a], i[a]) || o.push({ command: s, args: [r, a, i[a], n] })); for (a in i) i.hasOwnProperty(a) && !e.hasOwnProperty(a) && (t(e[a], i[a]) || o.push({ command: s, args: [r, a, i[a], n] })); } function Ke(e) { return e.id } function Je(e, t) { return e[t.id] = t, e } class Qe { constructor(e, t) { this.reset(e, t); } reset(e, t) { this.points = e || [], this._distances = [0]; for (let e = 1; e < this.points.length; e++) this._distances[e] = this._distances[e - 1] + this.points[e].dist(this.points[e - 1]); this.length = this._distances[this._distances.length - 1], this.padding = Math.min(t || 0, .5 * this.length), this.paddedLength = this.length - 2 * this.padding; } lerp(t) { if (1 === this.points.length) return this.points[0]; t = e.clamp(t, 0, 1); let i = 1, o = this._distances[i]; const r = t * this.paddedLength + this.padding; for (; o < r && i < this._distances.length;) o = this._distances[++i]; const n = i - 1, s = this._distances[n], a = o - s, l = a > 0 ? (r - s) / a : 0; return this.points[n].mult(1 - l).add(this.points[i].mult(l)) } } class et { constructor(e, t, i) { const o = this.boxCells = [], r = this.circleCells = []; this.xCellCount = Math.ceil(e / i), this.yCellCount = Math.ceil(t / i); for (let e = 0; e < this.xCellCount * this.yCellCount; e++) o.push([]), r.push([]); this.circleKeys = [], this.boxKeys = [], this.bboxes = [], this.circles = [], this.width = e, this.height = t, this.xScale = this.xCellCount / e, this.yScale = this.yCellCount / t, this.boxUid = 0, this.circleUid = 0; } keysLength() { return this.boxKeys.length + this.circleKeys.length } insert(e, t, i, o, r) { this._forEachCell(t, i, o, r, this._insertBoxCell, this.boxUid++), this.boxKeys.push(e), this.bboxes.push(t), this.bboxes.push(i), this.bboxes.push(o), this.bboxes.push(r); } insertCircle(e, t, i, o) { this._forEachCell(t - o, i - o, t + o, i + o, this._insertCircleCell, this.circleUid++), this.circleKeys.push(e), this.circles.push(t), this.circles.push(i), this.circles.push(o); } _insertBoxCell(e, t, i, o, r, n) { this.boxCells[r].push(n); } _insertCircleCell(e, t, i, o, r, n) { this.circleCells[r].push(n); } _query(e, t, i, o, r, n) { if (i < 0 || e > this.width || o < 0 || t > this.height) return !r && []; const s = []; if (e <= 0 && t <= 0 && this.width <= i && this.height <= o) { if (r) return !0; for (let e = 0; e < this.boxKeys.length; e++) s.push({ key: this.boxKeys[e], x1: this.bboxes[4 * e], y1: this.bboxes[4 * e + 1], x2: this.bboxes[4 * e + 2], y2: this.bboxes[4 * e + 3] }); for (let e = 0; e < this.circleKeys.length; e++) { const t = this.circles[3 * e], i = this.circles[3 * e + 1], o = this.circles[3 * e + 2]; s.push({ key: this.circleKeys[e], x1: t - o, y1: i - o, x2: t + o, y2: i + o }); } return n ? s.filter(n) : s } return this._forEachCell(e, t, i, o, this._queryCell, s, { hitTest: r, seenUids: { box: {}, circle: {} } }, n), r ? s.length > 0 : s } _queryCircle(e, t, i, o, r) { const n = e - i, s = e + i, a = t - i, l = t + i; if (s < 0 || n > this.width || l < 0 || a > this.height) return !o && []; const c = []; return this._forEachCell(n, a, s, l, this._queryCellCircle, c, { hitTest: o, circle: { x: e, y: t, radius: i }, seenUids: { box: {}, circle: {} } }, r), o ? c.length > 0 : c } query(e, t, i, o, r) { return this._query(e, t, i, o, !1, r) } hitTest(e, t, i, o, r) { return this._query(e, t, i, o, !0, r) } hitTestCircle(e, t, i, o) { return this._queryCircle(e, t, i, !0, o) } _queryCell(e, t, i, o, r, n, s, a) { const l = s.seenUids, c = this.boxCells[r]; if (null !== c) { const r = this.bboxes; for (const h of c) if (!l.box[h]) { l.box[h] = !0; const c = 4 * h; if (e <= r[c + 2] && t <= r[c + 3] && i >= r[c + 0] && o >= r[c + 1] && (!a || a(this.boxKeys[h]))) { if (s.hitTest) return n.push(!0), !0; n.push({ key: this.boxKeys[h], x1: r[c], y1: r[c + 1], x2: r[c + 2], y2: r[c + 3] }); } } } const h = this.circleCells[r]; if (null !== h) { const r = this.circles; for (const c of h) if (!l.circle[c]) { l.circle[c] = !0; const h = 3 * c; if (this._circleAndRectCollide(r[h], r[h + 1], r[h + 2], e, t, i, o) && (!a || a(this.circleKeys[c]))) { if (s.hitTest) return n.push(!0), !0; { const e = r[h], t = r[h + 1], i = r[h + 2]; n.push({ key: this.circleKeys[c], x1: e - i, y1: t - i, x2: e + i, y2: t + i }); } } } } } _queryCellCircle(e, t, i, o, r, n, s, a) { const l = s.circle, c = s.seenUids, h = this.boxCells[r]; if (null !== h) { const e = this.bboxes; for (const t of h) if (!c.box[t]) { c.box[t] = !0; const i = 4 * t; if (this._circleAndRectCollide(l.x, l.y, l.radius, e[i + 0], e[i + 1], e[i + 2], e[i + 3]) && (!a || a(this.boxKeys[t]))) return n.push(!0), !0 } } const u = this.circleCells[r]; if (null !== u) { const e = this.circles; for (const t of u) if (!c.circle[t]) { c.circle[t] = !0; const i = 3 * t; if (this._circlesCollide(e[i], e[i + 1], e[i + 2], l.x, l.y, l.radius) && (!a || a(this.circleKeys[t]))) return n.push(!0), !0 } } } _forEachCell(e, t, i, o, r, n, s, a) { const l = this._convertToXCellCoord(e), c = this._convertToYCellCoord(t), h = this._convertToXCellCoord(i), u = this._convertToYCellCoord(o); for (let _ = l; _ <= h; _++) for (let l = c; l <= u; l++) if (r.call(this, e, t, i, o, this.xCellCount * l + _, n, s, a)) return } _convertToXCellCoord(e) { return Math.max(0, Math.min(this.xCellCount - 1, Math.floor(e * this.xScale))) } _convertToYCellCoord(e) { return Math.max(0, Math.min(this.yCellCount - 1, Math.floor(e * this.yScale))) } _circlesCollide(e, t, i, o, r, n) { const s = o - e, a = r - t, l = i + n; return l * l > s * s + a * a } _circleAndRectCollide(e, t, i, o, r, n, s) { const a = (n - o) / 2, l = Math.abs(e - (o + a)); if (l > a + i) return !1; const c = (s - r) / 2, h = Math.abs(t - (r + c)); if (h > c + i) return !1; if (l <= a || h <= c) return !0; const u = l - a, _ = h - c; return u * u + _ * _ <= i * i } } const tt = Math.tan(85 * Math.PI / 180); function it(t, i, o, r, n, s, a) { const l = e.create(); if (o) if ("globe" === s.name) { const t = e.calculateGlobeLabelMatrix(n, i); e.multiply(l, l, t); } else { const t = v([], a); l[0] = t[0], l[1] = t[1], l[4] = t[2], l[5] = t[3], r || e.rotateZ(l, l, n.angle); } else e.multiply(l, n.labelPlaneMatrix, t); return l } function ot(e, t, i, o, r, n, s) { const a = it(e, t, i, o, r, n, s); return "globe" === n.name && i || (a[2] = a[6] = a[10] = a[14] = 0), a } function rt(t, i, o, r, n, s, a) { if (o) { if ("globe" === s.name) { const l = it(t, i, o, r, n, s, a); return e.invert(l, l), e.multiply(l, t, l), l } { const i = e.clone(t), o = e.identity([]); return o[0] = a[0], o[1] = a[1], o[4] = a[2], o[5] = a[3], e.multiply(i, i, o), r || e.rotateZ(i, i, -n.angle), i } } return n.glCoordMatrix } function nt(t, i, o, r) { const n = [t, i, o, 1]; o ? e.transformMat4$1(n, n, r) : ft(n, n, r); const s = n[3]; return n[0] /= s, n[1] /= s, n[2] /= s, n } function st(e, t) { return Math.min(.5 + e / t * .5, 1.5) } function at(e, t) { const i = e[0] / e[3], o = e[1] / e[3]; return i >= -t[0] && i <= t[0] && o >= -t[1] && o <= t[1] } function lt(t, i, o, r, n, s, a, l, c, h) { const u = o.transform, _ = r ? t.textSizeData : t.iconSizeData, d = e.evaluateSizeForZoom(_, o.transform.zoom), p = "globe" === u.projection.name, m = [256 / o.width * 2 + 1, 256 / o.height * 2 + 1], f = r ? t.text.dynamicLayoutVertexArray : t.icon.dynamicLayoutVertexArray; f.clear(); let g = null; p && (g = r ? t.text.globeExtVertexArray : t.icon.globeExtVertexArray); const v = t.lineVertexArray, x = r ? t.text.placedSymbolArray : t.icon.placedSymbolArray, y = o.transform.width / o.transform.height; let b, w = !1; for (let r = 0; r < x.length; r++) { const p = x.get(r), { numGlyphs: T, writingMode: E } = p; if (E !== e.WritingMode.vertical || w || b === e.WritingMode.horizontal || (w = !0), b = E, (p.hidden || E === e.WritingMode.vertical) && !w) { mt(T, f); continue } w = !1; const C = new e.pointGeometry(p.tileAnchorX, p.tileAnchorY); let { x: M, y: I, z: S } = u.projection.projectTilePoint(C.x, C.y, h.canonical); if (c) { const [e, t, i] = c(C); M += e, I += t, S += i; } const D = [M, I, S, 1]; if (e.transformMat4$1(D, D, i), !at(D, m)) { mt(T, f); continue } const L = st(o.transform.cameraToCenterDistance, D[3]), A = e.evaluateSizeForFeature(_, d, p), z = a ? A / L : A * L, P = nt(M, I, S, n); if (P[3] <= 0) { mt(T, f); continue } let R = {}; const O = a ? null : c, B = ut(p, z, !1, l, i, n, s, t.glyphOffsetArray, v, f, g, P, C, R, y, O, u.projection, h, a); w = B.useVertical, O && B.needsFlipping && (R = {}), (B.notEnoughRoom || w || B.needsFlipping && ut(p, z, !0, l, i, n, s, t.glyphOffsetArray, v, f, g, P, C, R, y, O, u.projection, h, a).notEnoughRoom) && mt(T, f); } r ? (t.text.dynamicLayoutVertexBuffer.updateData(f), g && t.text.globeExtVertexBuffer.updateData(g)) : (t.icon.dynamicLayoutVertexBuffer.updateData(f), g && t.icon.globeExtVertexBuffer.updateData(g)); } function ct(e, t, i, o, r, n, s, a, l, c, h, u, _, d, p, m) { const { lineStartIndex: f, glyphStartIndex: g, segment: v } = a, x = g + a.numGlyphs, y = f + a.lineLength, b = t.getoffsetX(g), w = t.getoffsetX(x - 1), T = pt(e * b, i, o, r, n, s, v, f, y, l, c, h, u, _, !0, d, p, m); if (!T) return null; const E = pt(e * w, i, o, r, n, s, v, f, y, l, c, h, u, _, !0, d, p, m); return E ? { first: T, last: E } : null } function ht(t, i, o, r) { return t === e.WritingMode.horizontal && Math.abs(r) > Math.abs(o) ? { useVertical: !0 } : t === e.WritingMode.vertical ? r > 0 ? { needsFlipping: !0 } : null : 0 !== i && function(e, t) { return 0 === e || Math.abs(t / e) > tt }(o, r) ? 1 === i ? { needsFlipping: !0 } : null : o < 0 ? { needsFlipping: !0 } : null } function ut(t, i, o, r, n, s, a, l, c, h, u, _, d, p, m, f, g, v, x) { const y = i / 24, b = t.lineOffsetX * y, w = t.lineOffsetY * y, { lineStartIndex: T, glyphStartIndex: E, numGlyphs: C, segment: M, writingMode: I, flipState: S } = t, D = T + t.lineLength, L = t => { if (u) { const [i, o, r] = t.up, n = h.length; e.updateGlobeVertexNormal(u, n + 0, i, o, r), e.updateGlobeVertexNormal(u, n + 1, i, o, r), e.updateGlobeVertexNormal(u, n + 2, i, o, r), e.updateGlobeVertexNormal(u, n + 3, i, o, r); } const [i, o, r] = t.point; e.addDynamicAttributes(h, i, o, r, t.angle); }; if (C > 1) { const e = ct(y, l, b, w, o, _, d, t, c, s, p, f, !1, g, v, x); if (!e) return { notEnoughRoom: !0 }; if (r && !o) { let [i, o, r] = e.first.point, [n, s, l] = e.last.point; [i, o] = nt(i, o, r, a), [n, s] = nt(n, s, l, a); const c = ht(I, S, (n - i) * m, s - o); if (t.flipState = c && c.needsFlipping ? 1 : 2, c) return c } L(e.first); for (let e = E + 1; e < E + C - 1; e++) { const t = pt(y * l.getoffsetX(e), b, w, o, _, d, M, T, D, c, s, p, f, !1, !1, g, v, x); if (!t) return h.length -= 4 * (e - E), { notEnoughRoom: !0 }; L(t); } L(e.last); } else { if (r && !o) { const i = nt(d.x, d.y, 0, n), o = T + M + 1, r = new e.pointGeometry(c.getx(o), c.gety(o)), s = nt(r.x, r.y, 0, n), a = s[3] > 0 ? s : dt(d, r, i, 1, n, void 0, g, v.canonical), l = ht(I, S, (a[0] - i[0]) * m, a[1] - i[1]); if (t.flipState = l && l.needsFlipping ? 1 : 2, l) return l } const i = pt(y * l.getoffsetX(E), b, w, o, _, d, M, T, D, c, s, p, f, !1, !1, g, v, x); if (!i) return { notEnoughRoom: !0 }; L(i); } return {} } function _t(e, t, i, o, r) { const { x: n, y: s, z: a } = o.projectTilePoint(e.x, e.y, t); if (!r) return nt(n, s, a, i); const [l, c, h] = r(e); return nt(n + l, s + c, a + h, i) } function dt(t, i, o, r, n, s, a, l) { const c = _t(t.sub(i)._unit()._add(t), l, n, a, s); return e.sub(c, o, c), e.normalize(c, c), e.scaleAndAdd(c, o, c, r) } function pt(t, i, o, r, n, s, a, l, c, h, u, _, d, p, m, f, g, v) { const x = r ? t - i : t + i; let y = x > 0 ? 1 : -1, b = 0; r && (y *= -1, b = Math.PI), y < 0 && (b += Math.PI); let w = l + a + (y > 0 ? 0 : 1) | 0, T = n, E = n, C = 0, M = 0; const I = Math.abs(x), S = [], D = []; let L = s, A = L; const z = () => dt(A, L, E, I - C + 1, u, d, f, g.canonical); for (; C + M <= I;) { if (w += y, w < l || w >= c) return null; if (E = T, A = L, S.push(E), p && D.push(A), L = new e.pointGeometry(h.getx(w), h.gety(w)), T = _[w], !T) { const e = _t(L, g.canonical, u, f, d); T = e[3] > 0 ? _[w] = e : z(); } C += M, M = e.distance(E, T); } m && d && (_[w] && (T = z(), M = e.distance(E, T)), _[w] = T); const P = (I - C) / M, R = L.sub(A)._mult(P)._add(A), O = e.sub([], T, E), B = e.scaleAndAdd([], E, O, P); let k = [0, 0, 1], F = O[0], U = O[1]; if (v && (k = f.upVector(g.canonical, R.x, R.y), 0 !== k[0] || 0 !== k[1] || 1 !== k[2])) { const t = [k[2], 0, -k[0]], i = e.cross([], k, t); e.normalize(t, t), e.normalize(i, i), F = e.dot(O, t), U = e.dot(O, i); } if (o) { const t = e.cross([], k, O); e.normalize(t, t), e.scaleAndAdd(B, B, t, o * y); } const N = b + Math.atan2(U, F); return S.push(B), p && D.push(R), { point: B, angle: N, path: S, tilePath: D, up: k } } function mt(e, t) { const i = t.length, o = i + 4 * e; t.resize(o), t.float32.fill(-1 / 0, 4 * i, 4 * o); } function ft(e, t, i) { const o = t[0], r = t[1]; return e[0] = i[0] * o + i[4] * r + i[12], e[1] = i[1] * o + i[5] * r + i[13], e[3] = i[3] * o + i[7] * r + i[15], e } const gt = 100; class vt { constructor(e, t, i = new et(e.width + 200, e.height + 200, 25), o = new et(e.width + 200, e.height + 200, 25)) { this.transform = e, this.grid = i, this.ignoredGrid = o, this.pitchfactor = Math.cos(e._pitch) * e.cameraToCenterDistance, this.screenRightBoundary = e.width + gt, this.screenBottomBoundary = e.height + gt, this.gridRightBoundary = e.width + 200, this.gridBottomBoundary = e.height + 200, this.fogState = t; } placeCollisionBox(e, t, i, o, r, n, s, a) { let l = i.projectedAnchorX, c = i.projectedAnchorY, h = i.projectedAnchorZ; const u = i.elevation, _ = i.tileID, d = e.getProjection(); if (u && _) { const [e, t, o] = d.upVector(_.canonical, i.tileAnchorX, i.tileAnchorY), r = d.upVectorScale(_.canonical, this.transform.center.lat, this.transform.worldSize).metersToTile; l += e * u * r, c += t * u * r, h += o * u * r; } const p = this.projectAndGetPerspectiveRatio(s, l, c, h, i.tileID, "globe" === d.name || !!u || this.transform.pitch > 0, d), m = n * p.perspectiveRatio, f = (i.x1 * t + o.x - i.padding) * m + p.point.x, g = (i.y1 * t + o.y - i.padding) * m + p.point.y, v = (i.x2 * t + o.x + i.padding) * m + p.point.x, x = (i.y2 * t + o.y + i.padding) * m + p.point.y, y = p.perspectiveRatio <= .55 || p.occluded; return !this.isInsideGrid(f, g, v, x) || !r && this.grid.hitTest(f, g, v, x, a) || y ? { box: [], offscreen: !1, occluded: p.occluded } : { box: [f, g, v, x], offscreen: this.isOffscreen(f, g, v, x), occluded: !1 } } placeCollisionCircles(t, i, o, r, n, s, a, l, c, h, u, _, d, p, m) { const f = [], g = this.transform.elevation, v = t.getProjection(), x = g ? g.getAtTileOffsetFunc(m, this.transform.center.lat, this.transform.worldSize, v) : null, y = new e.pointGeometry(o.tileAnchorX, o.tileAnchorY); let { x: b, y: w, z: T } = v.projectTilePoint(y.x, y.y, m.canonical); if (x) { const [e, t, i] = x(y); b += e, w += t, T += i; } const E = "globe" === v.name, C = this.projectAndGetPerspectiveRatio(a, b, w, T, m, E || !!g || this.transform.pitch > 0, v), { perspectiveRatio: M } = C, I = (u ? s / M : s * M) / e.ONE_EM, S = nt(b, w, T, l), D = C.signedDistanceFromCamera > 0 ? ct(I, n, o.lineOffsetX * I, o.lineOffsetY * I, !1, S, y, o, r, l, {}, g && !u ? x : null, u && !!g, v, m, u) : null; let L = !1, A = !1, z = !0; if (D && !C.occluded) { const t = .5 * d * M + p, o = new e.pointGeometry(-100, -100), r = new e.pointGeometry(this.screenRightBoundary, this.screenBottomBoundary), n = new Qe, { first: s, last: a } = D, l = s.path.length; let u = []; for (let e = l - 1; e >= 1; e--) u.push(s.path[e]); for (let e = 1; e < a.path.length; e++) u.push(a.path[e]); const m = 2.5 * t; c && (u = u.map((([e, t, i], o) => (x && !E && (i = x(o < l - 1 ? s.tilePath[l - 1 - o] : a.tilePath[o - l + 2])[2]), nt(e, t, i, c)))), u.some((e => e[3] <= 0)) && (u = [])); let g = []; if (u.length > 0) { let t = 1 / 0, i = -1 / 0, n = 1 / 0, s = -1 / 0; for (const e of u) t = Math.min(t, e[0]), n = Math.min(n, e[1]), i = Math.max(i, e[0]), s = Math.max(s, e[1]); i >= o.x && t <= r.x && s >= o.y && n <= r.y && (g = [u.map((t => new e.pointGeometry(t[0], t[1])))], (t < o.x || i > r.x || n < o.y || s > r.y) && (g = e.clipLine(g, o.x, o.y, r.x, r.y))); } for (const e of g) { n.reset(e, .25 * t); let o = 0; o = n.length <= .5 * t ? 1 : Math.ceil(n.paddedLength / m) + 1; for (let e = 0; e < o; e++) { const r = e / Math.max(o - 1, 1), s = n.lerp(r), a = s.x + gt, l = s.y + gt; f.push(a, l, t, 0); const c = a - t, u = l - t, d = a + t, p = l + t; if (z = z && this.isOffscreen(c, u, d, p), A = A || this.isInsideGrid(c, u, d, p), !i && this.grid.hitTestCircle(a, l, t, _) && (L = !0, !h)) return { circles: [], offscreen: !1, collisionDetected: L, occluded: !1 } } } } return { circles: !h && L || !A ? [] : f, offscreen: z, collisionDetected: L, occluded: C.occluded } } queryRenderedSymbols(t) { if (0 === t.length || 0 === this.grid.keysLength() && 0 === this.ignoredGrid.keysLength()) return {}; const i = []; let o = 1 / 0, r = 1 / 0, n = -1 / 0, s = -1 / 0; for (const a of t) { const t = new e.pointGeometry(a.x + gt, a.y + gt); o = Math.min(o, t.x), r = Math.min(r, t.y), n = Math.max(n, t.x), s = Math.max(s, t.y), i.push(t); } const a = this.grid.query(o, r, n, s).concat(this.ignoredGrid.query(o, r, n, s)), l = {}, c = {}; for (const t of a) { const o = t.key; if (void 0 === l[o.bucketInstanceId] && (l[o.bucketInstanceId] = {}), l[o.bucketInstanceId][o.featureIndex]) continue; const r = [new e.pointGeometry(t.x1, t.y1), new e.pointGeometry(t.x2, t.y1), new e.pointGeometry(t.x2, t.y2), new e.pointGeometry(t.x1, t.y2)]; e.polygonIntersectsPolygon(i, r) && (l[o.bucketInstanceId][o.featureIndex] = !0, void 0 === c[o.bucketInstanceId] && (c[o.bucketInstanceId] = []), c[o.bucketInstanceId].push(o.featureIndex)); } return c } insertCollisionBox(e, t, i, o, r) { (t ? this.ignoredGrid : this.grid).insert({ bucketInstanceId: i, featureIndex: o, collisionGroupID: r }, e[0], e[1], e[2], e[3]); } insertCollisionCircles(e, t, i, o, r) { const n = t ? this.ignoredGrid : this.grid, s = { bucketInstanceId: i, featureIndex: o, collisionGroupID: r }; for (let t = 0; t < e.length; t += 4) n.insertCircle(s, e[t], e[t + 1], e[t + 2]); } projectAndGetPerspectiveRatio(t, i, o, r, n, s, a) { const l = [i, o, r, 1]; let c = !1; if (r || this.transform.pitch > 0) { e.transformMat4$1(l, l, t); const s = "globe" === a.name; if (this.fogState && n && !s) { const t = function(t, i, o, r, n, s) { const a = s.calculateFogTileMatrix(n), l = [i, o, r]; return e.transformMat4(l, l, a), I(t, l, s.pitch, s._fov) }(this.fogState, i, o, r, n.toUnwrapped(), this.transform); c = t > .9; } } else ft(l, l, t); const h = l[3]; return { point: new e.pointGeometry((l[0] / h + 1) / 2 * this.transform.width + gt, (-l[1] / h + 1) / 2 * this.transform.height + gt), perspectiveRatio: Math.min(.5 + this.transform.getCameraToCenterDistance(a) / h * .5, 1.5), signedDistanceFromCamera: h, occluded: s && l[2] > h || c } } isOffscreen(e, t, i, o) { return i < gt || e >= this.screenRightBoundary || o < gt || t > this.screenBottomBoundary } isInsideGrid(e, t, i, o) { return i >= 0 && e < this.gridRightBoundary && o >= 0 && t < this.gridBottomBoundary } getViewportMatrix() { const t = e.identity([]); return e.translate(t, t, [-100, -100, 0]), t } } function xt(t, i, o) { const r = i.createTileMatrix(t, t.worldSize, o.toUnwrapped()); return e.multiply(new Float32Array(16), t.projMatrix, r) } function yt(e, t, i) { if (t.projection.name === i.projection.name) return e.projMatrix; const o = i.clone(); return o.setProjection(t.projection), xt(o, t.getProjection(), e) } function bt(e, t, i) { return t.name === i.projection.name ? e.projMatrix : xt(i, t, e) } class wt { constructor(e, t, i, o) { this.opacity = e ? Math.max(0, Math.min(1, e.opacity + (e.placed ? t : -t))) : o && i ? 1 : 0, this.placed = i; } isHidden() { return 0 === this.opacity && !this.placed } } class Tt { constructor(e, t, i, o, r, n = !1) { this.text = new wt(e ? e.text : null, t, i, r), this.icon = new wt(e ? e.icon : null, t, o, r), this.clipped = n; } isHidden() { return this.text.isHidden() && this.icon.isHidden() } } class Et { constructor(e, t, i, o = !1) { this.text = e, this.icon = t, this.skipFade = i, this.clipped = o; } } class Ct { constructor() { this.invProjMatrix = e.create(), this.viewportMatrix = e.create(), this.circles = []; } } class Mt { constructor(e, t, i, o, r) { this.bucketInstanceId = e, this.featureIndex = t, this.sourceLayerIndex = i, this.bucketIndex = o, this.tileID = r; } } class It { constructor(e) { this.crossSourceCollisions = e, this.maxGroupID = 0, this.collisionGroups = {}; } get(e) { if (this.crossSourceCollisions) return { ID: 0, predicate: null }; if (!this.collisionGroups[e]) { const t = ++this.maxGroupID; this.collisionGroups[e] = { ID: t, predicate: e => e.collisionGroupID === t }; } return this.collisionGroups[e] } } function St(t, i, o, r, n) { const { horizontalAlign: s, verticalAlign: a } = e.getAnchorAlignment(t), l = -(s - .5) * i, c = -(a - .5) * o, h = e.evaluateVariableOffset(t, r); return new e.pointGeometry(l + h[0] * n, c + h[1] * n) } function Dt(t, i, o, r, n) { const s = new e.pointGeometry(t, i); return o && s._rotate(r ? n : -n), s } class Lt { constructor(e, t, i, o, r) { this.transform = e.clone(), this.projection = e.projection.name, this.collisionIndex = new vt(this.transform, r), this.placements = {}, this.opacities = {}, this.variableOffsets = {}, this.stale = !1, this.commitTime = 0, this.fadeDuration = t, this.retainedQueryData = {}, this.collisionGroups = new It(i), this.collisionCircleArrays = {}, this.prevPlacement = o, o && (o.prevPlacement = void 0), this.placedOrientations = {}; } getBucketParts(t, i, o, r) { const n = o.getBucket(i), s = o.latestFeatureIndex; if (!n || !s || i.id !== n.layerIds[0]) return; const a = n.layers[0].layout, l = o.collisionBoxArray, c = Math.pow(2, this.transform.zoom - o.tileID.overscaledZ), h = o.tileSize / e.EXTENT, u = o.tileID.toUnwrapped(); this.transform.setProjection(n.projection); const _ = (d = o.tileID, p = n.getProjection(), m = this.transform, p.name === this.projection ? m.calculateProjMatrix(d.toUnwrapped()) : xt(m, p, d)); var d, p, m; const f = "map" === a.get("text-pitch-alignment"), g = "map" === a.get("text-rotation-alignment"); i.compileFilter(); const v = i.dynamicFilter(), x = i.dynamicFilterNeedsFeature(), y = this.transform.calculatePixelsToTileUnitsMatrix(o), b = ot(_, o.tileID.canonical, f, g, this.transform, n.getProjection(), y); let w = null; if (f) { const t = rt(_, o.tileID.canonical, f, g, this.transform, n.getProjection(), y); w = e.multiply([], this.transform.labelPlaneMatrix, t); } let T = null; v && o.latestFeatureIndex && (T = { unwrappedTileID: u, dynamicFilter: v, dynamicFilterNeedsFeature: x, featureIndex: o.latestFeatureIndex }), this.retainedQueryData[n.bucketInstanceId] = new Mt(n.bucketInstanceId, s, n.sourceLayerIndex, n.index, o.tileID); const E = { bucket: n, layout: a, posMatrix: _, textLabelPlaneMatrix: b, labelToScreenMatrix: w, clippingData: T, scale: c, textPixelRatio: h, holdingForFade: o.holdingForFade(), collisionBoxArray: l, partiallyEvaluatedTextSize: e.evaluateSizeForZoom(n.textSizeData, this.transform.zoom), partiallyEvaluatedIconSize: e.evaluateSizeForZoom(n.iconSizeData, this.transform.zoom), collisionGroup: this.collisionGroups.get(n.sourceID) }; if (r) for (const e of n.sortKeyRanges) { const { sortKey: i, symbolInstanceStart: o, symbolInstanceEnd: r } = e; t.push({ sortKey: i, symbolInstanceStart: o, symbolInstanceEnd: r, parameters: E }); } else t.push({ symbolInstanceStart: 0, symbolInstanceEnd: n.symbolInstances.length, parameters: E }); } attemptAnchorPlacement(e, t, i, o, r, n, s, a, l, c, h, u, _, d, p, m, f, g) { const { textOffset0: v, textOffset1: x, crossTileID: y } = u, b = [v, x], w = St(e, i, o, b, r), T = this.collisionIndex.placeCollisionBox(d, r, t, Dt(w.x, w.y, n, s, this.transform.angle), h, a, l, c.predicate); if (m) { const e = d.getSymbolInstanceIconSize(g, this.transform.zoom, u.placedIconSymbolIndex); if (0 === this.collisionIndex.placeCollisionBox(d, e, m, Dt(w.x, w.y, n, s, this.transform.angle), h, a, l, c.predicate).box.length) return } if (T.box.length > 0) { let t; return this.prevPlacement && this.prevPlacement.variableOffsets[y] && this.prevPlacement.placements[y] && this.prevPlacement.placements[y].text && (t = this.prevPlacement.variableOffsets[y].anchor), this.variableOffsets[y] = { textOffset: b, width: i, height: o, anchor: e, textScale: r, prevAnchor: t }, this.markUsedJustification(d, e, u, p), d.allowVerticalPlacement && (this.markUsedOrientation(d, p, u), this.placedOrientations[y] = p), { shift: w, placedGlyphBoxes: T } } } placeLayerBucketPart(t, i, o, r) { const { bucket: n, layout: s, posMatrix: a, textLabelPlaneMatrix: l, labelToScreenMatrix: c, clippingData: h, textPixelRatio: u, holdingForFade: _, collisionBoxArray: d, partiallyEvaluatedTextSize: p, partiallyEvaluatedIconSize: m, collisionGroup: f } = t.parameters, g = s.get("text-optional"), v = s.get("icon-optional"), x = s.get("text-allow-overlap"), y = s.get("icon-allow-overlap"), b = "map" === s.get("text-rotation-alignment"), w = "map" === s.get("text-pitch-alignment"), T = "none" !== s.get("icon-text-fit"), E = "viewport-y" === s.get("symbol-z-order"); this.transform.setProjection(n.projection); let C = x && (y || !n.hasIconData() || v), M = y && (x || !n.hasTextData() || g); !n.collisionArrays && d && n.deserializeCollisionBoxes(d), o && r && n.updateCollisionDebugBuffers(this.transform.zoom, d); const I = (t, r, d) => { const { crossTileID: E, numVerticalGlyphVertices: I } = t; if (h) { const o = { zoom: this.transform.zoom, pitch: this.transform.pitch }; let r = null; if (h.dynamicFilterNeedsFeature) { const e = this.retainedQueryData[n.bucketInstanceId]; r = h.featureIndex.loadFeature({ featureIndex: t.featureIndex, bucketIndex: e.bucketIndex, sourceLayerIndex: e.sourceLayerIndex, layoutVertexArrayOffset: 0 }); } if (!(0, h.dynamicFilter)(o, r, this.retainedQueryData[n.bucketInstanceId].tileID.canonical, new e.pointGeometry(t.tileAnchorX, t.tileAnchorY), this.transform.calculateDistanceTileData(h.unwrappedTileID))) return this.placements[E] = new Et(!1, !1, !1, !0), void(i[E] = !0) } if (i[E]) return; if (_) return void(this.placements[E] = new Et(!1, !1, !1)); let S = !1, D = !1, L = !0, A = !1, z = !1, P = null, R = { box: null, offscreen: null, occluded: null }, O = { box: null, offscreen: null, occluded: null }, B = null, k = null, F = null, U = 0, N = 0, G = 0; d.textFeatureIndex ? U = d.textFeatureIndex : t.useRuntimeCollisionCircles && (U = t.featureIndex), d.verticalTextFeatureIndex && (N = d.verticalTextFeatureIndex); const j = e => { e.tileID = this.retainedQueryData[n.bucketInstanceId].tileID; const t = this.transform.elevation; (t || e.elevation) && (e.elevation = t ? t.getAtTileOffset(e.tileID, e.tileAnchorX, e.tileAnchorY) : 0); }, Z = d.textBox; if (Z) { j(Z); const i = i => { let o = e.WritingMode.horizontal; if (n.allowVerticalPlacement && !i && this.prevPlacement) { const e = this.prevPlacement.placedOrientations[E]; e && (this.placedOrientations[E] = e, o = e, this.markUsedOrientation(n, o, t)); } return o }, o = (t, i) => { if (n.allowVerticalPlacement && I > 0 && d.verticalTextBox) { for (const o of n.writingModes) if (o === e.WritingMode.vertical ? (R = i(), O = R) : R = t(), R && R.box && R.box.length) break } else R = t(); }; if (s.get("text-variable-anchor")) { let l = s.get("text-variable-anchor"); if (this.prevPlacement && this.prevPlacement.variableOffsets[E]) { const e = this.prevPlacement.variableOffsets[E]; l.indexOf(e.anchor) > 0 && (l = l.filter((t => t !== e.anchor)), l.unshift(e.anchor)); } const c = (e, i, o) => { const s = n.getSymbolInstanceTextSize(p, t, this.transform.zoom, r), c = (e.x2 - e.x1) * s + 2 * e.padding, h = (e.y2 - e.y1) * s + 2 * e.padding, _ = T && !y ? i : null; _ && j(_); let d = { box: [], offscreen: !1, occluded: !1 }; const g = x ? 2 * l.length : l.length; for (let i = 0; i < g; ++i) { const g = this.attemptAnchorPlacement(l[i % l.length], e, c, h, s, b, w, u, a, f, i >= l.length, t, r, n, o, _, p, m); if (g && (d = g.placedGlyphBoxes, d && d.box && d.box.length)) { S = !0, P = g.shift; break } } return d }; o((() => c(Z, d.iconBox, e.WritingMode.horizontal)), (() => { const t = d.verticalTextBox; return t && j(t), n.allowVerticalPlacement && !(R && R.box && R.box.length) && I > 0 && t ? c(t, d.verticalIconBox, e.WritingMode.vertical) : { box: null, offscreen: null, occluded: null } })), R && (S = R.box, L = R.offscreen, A = R.occluded); const h = i(R && R.box); if (!S && this.prevPlacement) { const e = this.prevPlacement.variableOffsets[E]; e && (this.variableOffsets[E] = e, this.markUsedJustification(n, e.anchor, t, h)); } } else { const s = (i, o) => { const s = n.getSymbolInstanceTextSize(p, t, this.transform.zoom, r), l = this.collisionIndex.placeCollisionBox(n, s, i, new e.pointGeometry(0, 0), x, u, a, f.predicate); return l && l.box && l.box.length && (this.markUsedOrientation(n, o, t), this.placedOrientations[E] = o), l }; o((() => s(Z, e.WritingMode.horizontal)), (() => { const t = d.verticalTextBox; return n.allowVerticalPlacement && I > 0 && t ? (j(t), s(t, e.WritingMode.vertical)) : { box: null, offscreen: null, occluded: null } })), i(R && R.box && R.box.length); } } if (B = R, S = B && B.box && B.box.length > 0, L = B && B.offscreen, A = B && B.occluded, t.useRuntimeCollisionCircles) { const i = n.text.placedSymbolArray.get(t.centerJustifiedTextSymbolIndex >= 0 ? t.centerJustifiedTextSymbolIndex : t.verticalPlacedTextSymbolIndex), r = e.evaluateSizeForFeature(n.textSizeData, p, i), h = s.get("text-padding"); k = this.collisionIndex.placeCollisionCircles(n, x, i, n.lineVertexArray, n.glyphOffsetArray, r, a, l, c, o, w, f.predicate, t.collisionCircleDiameter * r / e.ONE_EM, h, this.retainedQueryData[n.bucketInstanceId].tileID), S = x || k.circles.length > 0 && !k.collisionDetected, L = L && k.offscreen, A = k.occluded; } if (d.iconFeatureIndex && (G = d.iconFeatureIndex), d.iconBox) { const i = i => { j(i); const o = T && P ? Dt(P.x, P.y, b, w, this.transform.angle) : new e.pointGeometry(0, 0), r = n.getSymbolInstanceIconSize(m, this.transform.zoom, t.placedIconSymbolIndex); return this.collisionIndex.placeCollisionBox(n, r, i, o, y, u, a, f.predicate) }; O && O.box && O.box.length && d.verticalIconBox ? (F = i(d.verticalIconBox), D = F.box.length > 0) : (F = i(d.iconBox), D = F.box.length > 0), L = L && F.offscreen, z = F.occluded; } const V = g || 0 === t.numHorizontalGlyphVertices && 0 === I, W = v || 0 === t.numIconVertices; if (V || W ? W ? V || (D = D && S) : S = D && S : D = S = D && S, S && B && B.box && this.collisionIndex.insertCollisionBox(B.box, s.get("text-ignore-placement"), n.bucketInstanceId, O && O.box && N ? N : U, f.ID), D && F && this.collisionIndex.insertCollisionBox(F.box, s.get("icon-ignore-placement"), n.bucketInstanceId, G, f.ID), k && (S && this.collisionIndex.insertCollisionCircles(k.circles, s.get("text-ignore-placement"), n.bucketInstanceId, U, f.ID), o)) { const e = n.bucketInstanceId; let t = this.collisionCircleArrays[e]; void 0 === t && (t = this.collisionCircleArrays[e] = new Ct); for (let e = 0; e < k.circles.length; e += 4) t.circles.push(k.circles[e + 0]), t.circles.push(k.circles[e + 1]), t.circles.push(k.circles[e + 2]), t.circles.push(k.collisionDetected ? 1 : 0); } const X = "globe" !== n.projection.name; C = C && (X || !A), M = M && (X || !z), this.placements[E] = new Et(S || C, D || M, L || n.justReloaded), i[E] = !0; }; if (E) { const e = n.getSortedSymbolIndexes(this.transform.angle); for (let t = e.length - 1; t >= 0; --t) { const i = e[t]; I(n.symbolInstances.get(i), i, n.collisionArrays[i]); } } else for (let e = t.symbolInstanceStart; e < t.symbolInstanceEnd; e++) I(n.symbolInstances.get(e), e, n.collisionArrays[e]); if (o && n.bucketInstanceId in this.collisionCircleArrays) { const t = this.collisionCircleArrays[n.bucketInstanceId]; e.invert(t.invProjMatrix, a), t.viewportMatrix = this.collisionIndex.getViewportMatrix(); } n.justReloaded = !1; } markUsedJustification(t, i, o, r) { const { leftJustifiedTextSymbolIndex: n, centerJustifiedTextSymbolIndex: s, rightJustifiedTextSymbolIndex: a, verticalPlacedTextSymbolIndex: l, crossTileID: c } = o, h = e.getAnchorJustification(i), u = r === e.WritingMode.vertical ? l : "left" === h ? n : "center" === h ? s : "right" === h ? a : -1; n >= 0 && (t.text.placedSymbolArray.get(n).crossTileID = u >= 0 && n !== u ? 0 : c), s >= 0 && (t.text.placedSymbolArray.get(s).crossTileID = u >= 0 && s !== u ? 0 : c), a >= 0 && (t.text.placedSymbolArray.get(a).crossTileID = u >= 0 && a !== u ? 0 : c), l >= 0 && (t.text.placedSymbolArray.get(l).crossTileID = u >= 0 && l !== u ? 0 : c); } markUsedOrientation(t, i, o) { const r = i === e.WritingMode.horizontal || i === e.WritingMode.horizontalOnly ? i : 0, n = i === e.WritingMode.vertical ? i : 0, { leftJustifiedTextSymbolIndex: s, centerJustifiedTextSymbolIndex: a, rightJustifiedTextSymbolIndex: l, verticalPlacedTextSymbolIndex: c } = o, h = t.text.placedSymbolArray; s >= 0 && (h.get(s).placedOrientation = r), a >= 0 && (h.get(a).placedOrientation = r), l >= 0 && (h.get(l).placedOrientation = r), c >= 0 && (h.get(c).placedOrientation = n); } commit(e) { this.commitTime = e, this.zoomAtLastRecencyCheck = this.transform.zoom; const t = this.prevPlacement; let i = !1; this.prevZoomAdjustment = t ? t.zoomAdjustment(this.transform.zoom) : 0; const o = t ? t.symbolFadeChange(e) : 1, r = t ? t.opacities : {}, n = t ? t.variableOffsets : {}, s = t ? t.placedOrientations : {}; for (const e in this.placements) { const t = this.placements[e], n = r[e]; n ? (this.opacities[e] = new Tt(n, o, t.text, t.icon, null, t.clipped), i = i || t.text !== n.text.placed || t.icon !== n.icon.placed) : (this.opacities[e] = new Tt(null, o, t.text, t.icon, t.skipFade, t.clipped), i = i || t.text || t.icon); } for (const e in r) { const t = r[e]; if (!this.opacities[e]) { const r = new Tt(t, o, !1, !1); r.isHidden() || (this.opacities[e] = r, i = i || t.text.placed || t.icon.placed); } } for (const e in n) this.variableOffsets[e] || !this.opacities[e] || this.opacities[e].isHidden() || (this.variableOffsets[e] = n[e]); for (const e in s) this.placedOrientations[e] || !this.opacities[e] || this.opacities[e].isHidden() || (this.placedOrientations[e] = s[e]); i ? this.lastPlacementChangeTime = e : "number" != typeof this.lastPlacementChangeTime && (this.lastPlacementChangeTime = t ? t.lastPlacementChangeTime : e); } updateLayerOpacities(e, t) { const i = {}; for (const o of t) { const t = o.getBucket(e); t && o.latestFeatureIndex && e.id === t.layerIds[0] && this.updateBucketOpacities(t, i, o.collisionBoxArray); } } updateBucketOpacities(t, i, o) { t.hasTextData() && t.text.opacityVertexArray.clear(), t.hasIconData() && t.icon.opacityVertexArray.clear(), t.hasIconCollisionBoxData() && t.iconCollisionBox.collisionVertexArray.clear(), t.hasTextCollisionBoxData() && t.textCollisionBox.collisionVertexArray.clear(); const r = t.layers[0].layout, n = !!t.layers[0].dynamicFilter(), s = new Tt(null, 0, !1, !1, !0), a = r.get("text-allow-overlap"), l = r.get("icon-allow-overlap"), c = r.get("text-variable-anchor"), h = "map" === r.get("text-rotation-alignment"), u = "map" === r.get("text-pitch-alignment"), _ = "none" !== r.get("icon-text-fit"), d = new Tt(null, 0, a && (l || !t.hasIconData() || r.get("icon-optional")), l && (a || !t.hasTextData() || r.get("text-optional")), !0); !t.collisionArrays && o && (t.hasIconCollisionBoxData() || t.hasTextCollisionBoxData()) && t.deserializeCollisionBoxes(o); const p = (e, t, i) => { for (let o = 0; o < t / 4; o++) e.opacityVertexArray.emplaceBack(i); }; let m = 0; for (let o = 0; o < t.symbolInstances.length; o++) { const r = t.symbolInstances.get(o), { numHorizontalGlyphVertices: a, numVerticalGlyphVertices: l, crossTileID: f, numIconVertices: g } = r; let v = this.opacities[f]; i[f] ? v = s : v || (v = d, this.opacities[f] = v), i[f] = !0; const x = a > 0 || l > 0, y = g > 0, b = this.placedOrientations[f], w = b === e.WritingMode.vertical, T = b === e.WritingMode.horizontal || b === e.WritingMode.horizontalOnly; if (!x && !y || v.isHidden() || m++, x) { const e = Ut(v.text); p(t.text, a, w ? Nt : e), p(t.text, l, T ? Nt : e); const i = v.text.isHidden(), { leftJustifiedTextSymbolIndex: o, centerJustifiedTextSymbolIndex: n, rightJustifiedTextSymbolIndex: s, verticalPlacedTextSymbolIndex: c } = r, h = t.text.placedSymbolArray, u = i || w ? 1 : 0; o >= 0 && (h.get(o).hidden = u), n >= 0 && (h.get(n).hidden = u), s >= 0 && (h.get(s).hidden = u), c >= 0 && (h.get(c).hidden = i || T ? 1 : 0); const _ = this.variableOffsets[f]; _ && this.markUsedJustification(t, _.anchor, r, b); const d = this.placedOrientations[f]; d && (this.markUsedJustification(t, "left", r, d), this.markUsedOrientation(t, d, r)); } if (y) { const e = Ut(v.icon), { placedIconSymbolIndex: i, verticalPlacedIconSymbolIndex: o } = r, n = t.icon.placedSymbolArray, s = v.icon.isHidden() ? 1 : 0; i >= 0 && (p(t.icon, g, w ? Nt : e), n.get(i).hidden = s), o >= 0 && (p(t.icon, r.numVerticalIconVertices, T ? Nt : e), n.get(o).hidden = s); } if (t.hasIconCollisionBoxData() || t.hasTextCollisionBoxData()) { const i = t.collisionArrays[o]; if (i) { let o = new e.pointGeometry(0, 0), r = !0; if (i.textBox || i.verticalTextBox) { if (c) { const e = this.variableOffsets[f]; e ? (o = St(e.anchor, e.width, e.height, e.textOffset, e.textScale), h && o._rotate(u ? this.transform.angle : -this.transform.angle)) : r = !1; } n && (r = !v.clipped), i.textBox && At(t.textCollisionBox.collisionVertexArray, v.text.placed, !r || w, o.x, o.y), i.verticalTextBox && At(t.textCollisionBox.collisionVertexArray, v.text.placed, !r || T, o.x, o.y); } const s = r && Boolean(!T && i.verticalIconBox); i.iconBox && At(t.iconCollisionBox.collisionVertexArray, v.icon.placed, s, _ ? o.x : 0, _ ? o.y : 0), i.verticalIconBox && At(t.iconCollisionBox.collisionVertexArray, v.icon.placed, !s, _ ? o.x : 0, _ ? o.y : 0); } } } if (t.fullyClipped = 0 === m, t.sortFeatures(this.transform.angle), this.retainedQueryData[t.bucketInstanceId] && (this.retainedQueryData[t.bucketInstanceId].featureSortOrder = t.featureSortOrder), t.hasTextData() && t.text.opacityVertexBuffer && t.text.opacityVertexBuffer.updateData(t.text.opacityVertexArray), t.hasIconData() && t.icon.opacityVertexBuffer && t.icon.opacityVertexBuffer.updateData(t.icon.opacityVertexArray), t.hasIconCollisionBoxData() && t.iconCollisionBox.collisionVertexBuffer && t.iconCollisionBox.collisionVertexBuffer.updateData(t.iconCollisionBox.collisionVertexArray), t.hasTextCollisionBoxData() && t.textCollisionBox.collisionVertexBuffer && t.textCollisionBox.collisionVertexBuffer.updateData(t.textCollisionBox.collisionVertexArray), t.bucketInstanceId in this.collisionCircleArrays) { const e = this.collisionCircleArrays[t.bucketInstanceId]; t.placementInvProjMatrix = e.invProjMatrix, t.placementViewportMatrix = e.viewportMatrix, t.collisionCircleArray = e.circles, delete this.collisionCircleArrays[t.bucketInstanceId]; } } symbolFadeChange(e) { return 0 === this.fadeDuration ? 1 : (e - this.commitTime) / this.fadeDuration + this.prevZoomAdjustment } zoomAdjustment(e) { return Math.max(0, (this.transform.zoom - e) / 1.5) } hasTransitions(e) { return this.stale || e - this.lastPlacementChangeTime < this.fadeDuration } stillRecent(e, t) { const i = this.zoomAtLastRecencyCheck === t ? 1 - this.zoomAdjustment(t) : 1; return this.zoomAtLastRecencyCheck = t, this.commitTime + this.fadeDuration * i > e } setStale() { this.stale = !0; } } function At(e, t, i, o, r) { e.emplaceBack(t ? 1 : 0, i ? 1 : 0, o || 0, r || 0), e.emplaceBack(t ? 1 : 0, i ? 1 : 0, o || 0, r || 0), e.emplaceBack(t ? 1 : 0, i ? 1 : 0, o || 0, r || 0), e.emplaceBack(t ? 1 : 0, i ? 1 : 0, o || 0, r || 0); } const zt = Math.pow(2, 25), Pt = Math.pow(2, 24), Rt = Math.pow(2, 17), Ot = Math.pow(2, 16), Bt = Math.pow(2, 9), kt = Math.pow(2, 8), Ft = Math.pow(2, 1); function Ut(e) { if (0 === e.opacity && !e.placed) return 0; if (1 === e.opacity && e.placed) return 4294967295; const t = e.placed ? 1 : 0, i = Math.floor(127 * e.opacity); return i * zt + t * Pt + i * Rt + t * Ot + i * Bt + t * kt + i * Ft + t } const Nt = 0; class Gt { constructor(e) { this._sortAcrossTiles = "viewport-y" !== e.layout.get("symbol-z-order") && void 0 !== e.layout.get("symbol-sort-key").constantOr(1), this._currentTileIndex = 0, this._currentPartIndex = 0, this._seenCrossTileIDs = {}, this._bucketParts = []; } continuePlacement(e, t, i, o, r) { const n = this._bucketParts; for (; this._currentTileIndex < e.length;) if (t.getBucketParts(n, o, e[this._currentTileIndex], this._sortAcrossTiles), this._currentTileIndex++, r()) return !0; for (this._sortAcrossTiles && (this._sortAcrossTiles = !1, n.sort(((e, t) => e.sortKey - t.sortKey))); this._currentPartIndex < n.length;) { const e = n[this._currentPartIndex]; if (t.placeLayerBucketPart(e, this._seenCrossTileIDs, i, 0 === e.symbolInstanceStart), this._currentPartIndex++, r()) return !0 } return !1 } } class jt { constructor(e, t, i, o, r, n, s, a) { this.placement = new Lt(e, r, n, s, a), this._currentPlacementIndex = t.length - 1, this._forceFullPlacement = i, this._showCollisionBoxes = o, this._done = !1; } isDone() { return this._done } continuePlacement(t, i, o) { const r = e.exported.now(), n = () => { const t = e.exported.now() - r; return !this._forceFullPlacement && t > 2 }; for (; this._currentPlacementIndex >= 0;) { const e = i[t[this._currentPlacementIndex]], r = this.placement.collisionIndex.transform.zoom; if ("symbol" === e.type && (!e.minzoom || e.minzoom <= r) && (!e.maxzoom || e.maxzoom > r)) { if (this._inProgressLayer || (this._inProgressLayer = new Gt(e)), this._inProgressLayer.continuePlacement(o[e.source], this.placement, this._showCollisionBoxes, e, n)) return; delete this._inProgressLayer; } this._currentPlacementIndex--; } this._done = !0; } commit(e) { return this.placement.commit(e), this.placement } } const Zt = 512 / e.EXTENT / 2; class Vt { constructor(e, t, i) { this.tileID = e, this.indexedSymbolInstances = {}, this.bucketInstanceId = i; for (let i = 0; i < t.length; i++) { const o = t.get(i), r = o.key; this.indexedSymbolInstances[r] || (this.indexedSymbolInstances[r] = []), this.indexedSymbolInstances[r].push({ crossTileID: o.crossTileID, coord: this.getScaledCoordinates(o, e) }); } } getScaledCoordinates(t, i) { const o = Zt / Math.pow(2, i.canonical.z - this.tileID.canonical.z); return { x: Math.floor((i.canonical.x * e.EXTENT + t.tileAnchorX) * o), y: Math.floor((i.canonical.y * e.EXTENT + t.tileAnchorY) * o) } } findMatches(e, t, i) { const o = this.tileID.canonical.z < t.canonical.z ? 1 : Math.pow(2, this.tileID.canonical.z - t.canonical.z); for (let r = 0; r < e.length; r++) { const n = e.get(r); if (n.crossTileID) continue; const s = this.indexedSymbolInstances[n.key]; if (!s) continue; const a = this.getScaledCoordinates(n, t); for (const e of s) if (Math.abs(e.coord.x - a.x) <= o && Math.abs(e.coord.y - a.y) <= o && !i[e.crossTileID]) { i[e.crossTileID] = !0, n.crossTileID = e.crossTileID; break } } } } class Wt { constructor() { this.maxCrossTileID = 0; } generate() { return ++this.maxCrossTileID } } class Xt { constructor() { this.indexes = {}, this.usedCrossTileIDs = {}, this.lng = 0; } handleWrapJump(e) { const t = Math.round((e - this.lng) / 360); if (0 !== t) for (const e in this.indexes) { const i = this.indexes[e], o = {}; for (const e in i) { const r = i[e]; r.tileID = r.tileID.unwrapTo(r.tileID.wrap + t), o[r.tileID.key] = r; } this.indexes[e] = o; } this.lng = e; } addBucket(e, t, i) { if (this.indexes[e.overscaledZ] && this.indexes[e.overscaledZ][e.key]) { if (this.indexes[e.overscaledZ][e.key].bucketInstanceId === t.bucketInstanceId) return !1; this.removeBucketCrossTileIDs(e.overscaledZ, this.indexes[e.overscaledZ][e.key]); } for (let e = 0; e < t.symbolInstances.length; e++) t.symbolInstances.get(e).crossTileID = 0; this.usedCrossTileIDs[e.overscaledZ] || (this.usedCrossTileIDs[e.overscaledZ] = {}); const o = this.usedCrossTileIDs[e.overscaledZ]; for (const i in this.indexes) { const r = this.indexes[i]; if (Number(i) > e.overscaledZ) for (const i in r) { const n = r[i]; n.tileID.isChildOf(e) && n.findMatches(t.symbolInstances, e, o); } else { const n = r[e.scaledTo(Number(i)).key]; n && n.findMatches(t.symbolInstances, e, o); } } for (let e = 0; e < t.symbolInstances.length; e++) { const r = t.symbolInstances.get(e); r.crossTileID || (r.crossTileID = i.generate(), o[r.crossTileID] = !0); } return void 0 === this.indexes[e.overscaledZ] && (this.indexes[e.overscaledZ] = {}), this.indexes[e.overscaledZ][e.key] = new Vt(e, t.symbolInstances, t.bucketInstanceId), !0 } removeBucketCrossTileIDs(e, t) { for (const i in t.indexedSymbolInstances) for (const o of t.indexedSymbolInstances[i]) delete this.usedCrossTileIDs[e][o.crossTileID]; } removeStaleBuckets(e) { let t = !1; for (const i in this.indexes) { const o = this.indexes[i]; for (const r in o) e[o[r].bucketInstanceId] || (this.removeBucketCrossTileIDs(i, o[r]), delete o[r], t = !0); } return t } } class qt { constructor() { this.layerIndexes = {}, this.crossTileIDs = new Wt, this.maxBucketInstanceId = 0, this.bucketsInCurrentPlacement = {}; } addLayer(e, t, i, o) { let r = this.layerIndexes[e.id]; void 0 === r && (r = this.layerIndexes[e.id] = new Xt); let n = !1; const s = {}; "globe" !== o.name && r.handleWrapJump(i); for (const i of t) { const t = i.getBucket(e); t && e.id === t.layerIds[0] && (t.bucketInstanceId || (t.bucketInstanceId = ++this.maxBucketInstanceId), r.addBucket(i.tileID, t, this.crossTileIDs) && (n = !0), s[t.bucketInstanceId] = !0); } return r.removeStaleBuckets(s) && (n = !0), n } pruneUnusedLayers(e) { const t = {}; e.forEach((e => { t[e] = !0; })); for (const e in this.layerIndexes) t[e] || delete this.layerIndexes[e]; } } const $t = (t, i) => e.emitValidationErrors(t, i && i.filter((e => "source.canvas" !== e.identifier))), Ht = e.pick(We, ["addLayer", "removeLayer", "setPaintProperty", "setLayoutProperty", "setFilter", "addSource", "removeSource", "setLayerZoomRange", "setLight", "setTransition", "setGeoJSONSourceData", "setTerrain", "setFog", "setProjection"]), Yt = e.pick(We, ["setCenter", "setZoom", "setBearing", "setPitch"]), Kt = { version: 8, layers: [], sources: {} }, Jt = { fill: !0, line: !0, background: !0, hillshade: !0, raster: !0 }; class Qt extends e.Evented { constructor(t, i = {}) { super(), this.map = t, this.dispatcher = new z(je(), this), this.imageManager = new y, this.imageManager.setEventedParent(this), this.glyphManager = new e.GlyphManager(t._requestManager, i.localFontFamily ? e.LocalGlyphMode.all : i.localIdeographFontFamily ? e.LocalGlyphMode.ideographs : e.LocalGlyphMode.none, i.localFontFamily || i.localIdeographFontFamily), this.crossTileSymbolIndex = new qt, this._layers = {}, this._num3DLayers = 0, this._numSymbolLayers = 0, this._numCircleLayers = 0, this._serializedLayers = {}, this._sourceCaches = {}, this._otherSourceCaches = {}, this._symbolSourceCaches = {}, this._loaded = !1, this._availableImages = [], this._order = [], this._drapedFirstOrder = [], this._markersNeedUpdate = !1, this._resetUpdates(), this.dispatcher.broadcast("setReferrer", e.getReferrer()); const o = this; this._rtlTextPluginCallback = Qt.registerForPluginStateChange((t => { o.dispatcher.broadcast("syncRTLPluginState", { pluginStatus: t.pluginStatus, pluginURL: t.pluginURL }, ((t, i) => { if (e.triggerPluginCompletionEvent(t), i && i.every((e => e))) for (const e in o._sourceCaches) { const t = o._sourceCaches[e], i = t.getSource().type; "vector" !== i && "geojson" !== i || t.reload(); } })); })), this.on("data", (e => { if ("source" !== e.dataType || "metadata" !== e.sourceDataType) return; const t = this.getSource(e.sourceId); if (t && t.vectorLayerIds) for (const e in this._layers) { const i = this._layers[e]; i.source === t.id && this._validateLayer(i); } })); } loadURL(t, i = {}) { this.fire(new e.Event("dataloading", { dataType: "style" })); const o = "boolean" == typeof i.validate ? i.validate : !e.isMapboxURL(t); t = this.map._requestManager.normalizeStyleURL(t, i.accessToken); const r = this.map._requestManager.transformRequest(t, e.ResourceType.Style); this._request = e.getJSON(r, ((t, i) => { this._request = null, t ? this.fire(new e.ErrorEvent(t)) : i && this._load(i, o); })); } loadJSON(t, i = {}) { this.fire(new e.Event("dataloading", { dataType: "style" })), this._request = e.exported.frame((() => { this._request = null, this._load(t, !1 !== i.validate); })); } loadEmpty() { this.fire(new e.Event("dataloading", { dataType: "style" })), this._load(Kt, !1); } _updateLayerCount(e, t) { const i = t ? 1 : -1; e.is3D() && (this._num3DLayers += i), "circle" === e.type && (this._numCircleLayers += i), "symbol" === e.type && (this._numSymbolLayers += i); } _load(t, i) { if (i && $t(this, e.validateStyle(t))) return; this._loaded = !0, this.stylesheet = e.clone$1(t), this._updateMapProjection(); for (const e in t.sources) this.addSource(e, t.sources[e], { validate: !1 }); this._changed = !1, t.sprite ? this._loadSprite(t.sprite) : (this.imageManager.setLoaded(!0), this.dispatcher.broadcast("spriteLoaded", !0)), this.glyphManager.setURL(t.glyphs); const o = Ve(this.stylesheet.layers); this._order = o.map((e => e.id)), this._layers = {}, this._serializedLayers = {}; for (const t of o) { const i = e.createStyleLayer(t); i.setEventedParent(this, { layer: { id: i.id } }), this._layers[i.id] = i, this._serializedLayers[i.id] = i.serialize(), this._updateLayerCount(i, !0); } this.dispatcher.broadcast("setLayers", this._serializeLayers(this._order)), this.light = new T(this.stylesheet.light), this.stylesheet.terrain && !this.terrainSetForDrapingOnly() && this._createTerrain(this.stylesheet.terrain, 1), this.stylesheet.fog && this._createFog(this.stylesheet.fog), this._updateDrapeFirstLayers(), this.fire(new e.Event("data", { dataType: "style" })), this.fire(new e.Event("style.load")); } terrainSetForDrapingOnly() { return !!this.terrain && 0 === this.terrain.drapeRenderMode } setProjection(e) { e ? this.stylesheet.projection = e : delete this.stylesheet.projection, this._updateMapProjection(); } applyProjectionUpdate() { this._loaded && (this.dispatcher.broadcast("setProjection", this.map.transform.projectionOptions), this.map.transform.projection.requiresDraping ? this.getTerrain() || this.stylesheet.terrain || this.setTerrainForDraping() : this.terrainSetForDrapingOnly() && this.setTerrain(null)); } _updateMapProjection() { this.map._useExplicitProjection ? this.applyProjectionUpdate() : this.map._prioritizeAndUpdateProjection(null, this.stylesheet.projection); } _loadSprite(t) { this._spriteRequest = function(t, i, o) { let r, n, s; const a = e.exported.devicePixelRatio > 1 ? "@2x" : ""; let l = e.getJSON(i.transformRequest(i.normalizeSpriteURL(t, a, ".json"), e.ResourceType.SpriteJSON), ((e, t) => { l = null, s || (s = e, r = t, h()); })), c = e.getImage(i.transformRequest(i.normalizeSpriteURL(t, a, ".png"), e.ResourceType.SpriteImage), ((e, t) => { c = null, s || (s = e, n = t, h()); })); function h() { if (s) o(s); else if (r && n) { const t = e.exported.getImageData(n), i = {}; for (const o in r) { const { width: n, height: s, x: a, y: l, sdf: c, pixelRatio: h, stretchX: u, stretchY: _, content: d } = r[o], p = new e.RGBAImage({ width: n, height: s }); e.RGBAImage.copy(t, p, { x: a, y: l }, { x: 0, y: 0 }, { width: n, height: s }), i[o] = { data: p, pixelRatio: h, sdf: c, stretchX: u, stretchY: _, content: d }; } o(null, i); } } return { cancel() { l && (l.cancel(), l = null), c && (c.cancel(), c = null); } } }(t, this.map._requestManager, ((t, i) => { if (this._spriteRequest = null, t) this.fire(new e.ErrorEvent(t)); else if (i) for (const e in i) this.imageManager.addImage(e, i[e]); this.imageManager.setLoaded(!0), this._availableImages = this.imageManager.listImages(), this.dispatcher.broadcast("setImages", this._availableImages), this.dispatcher.broadcast("spriteLoaded", !0), this.fire(new e.Event("data", { dataType: "style" })); })); } _validateLayer(t) { const i = this.getSource(t.source); if (!i) return; const o = t.sourceLayer; o && ("geojson" === i.type || i.vectorLayerIds && -1 === i.vectorLayerIds.indexOf(o)) && this.fire(new e.ErrorEvent(new Error(`Source layer "${o}" does not exist on source "${i.id}" as specified by style layer "${t.id}"`))); } loaded() { if (!this._loaded) return !1; if (Object.keys(this._updatedSources).length) return !1; for (const e in this._sourceCaches) if (!this._sourceCaches[e].loaded()) return !1; return !!this.imageManager.isLoaded() } _serializeLayers(e) { const t = []; for (const i of e) { const e = this._layers[i]; "custom" !== e.type && t.push(e.serialize()); } return t } hasTransitions() { if (this.light && this.light.hasTransition()) return !0; if (this.fog && this.fog.hasTransition()) return !0; for (const e in this._sourceCaches) if (this._sourceCaches[e].hasTransition()) return !0; for (const e in this._layers) if (this._layers[e].hasTransition()) return !0; return !1 } get order() { return this.map._optimizeForTerrain && this.terrain ? this._drapedFirstOrder : this._order } isLayerDraped(e) { return !!this.terrain && ("function" == typeof e.isLayerDraped ? e.isLayerDraped() : Jt[e.type]) } _checkLoaded() { if (!this._loaded) throw new Error("Style is not done loading") } update(t) { if (!this._loaded) return; const i = this._changed; if (this._changed) { const e = Object.keys(this._updatedLayers), i = Object.keys(this._removedLayers); (e.length || i.length) && this._updateWorkerLayers(e, i); for (const e in this._updatedSources) { const t = this._updatedSources[e]; "reload" === t ? this._reloadSource(e) : "clear" === t && this._clearSource(e); } this._updateTilesForChangedImages(); for (const e in this._updatedPaintProps) this._layers[e].updateTransitions(t); this.light.updateTransitions(t), this.fog && this.fog.updateTransitions(t), this._resetUpdates(); } const o = {}; for (const e in this._sourceCaches) { const t = this._sourceCaches[e]; o[e] = t.used, t.used = !1; } for (const e of this._order) { const i = this._layers[e]; if (i.recalculate(t, this._availableImages), !i.isHidden(t.zoom)) { const e = this._getLayerSourceCache(i); e && (e.used = !0); } const o = this.map.painter; if (o) { const e = i.getProgramIds(); if (!e) continue; const r = i.getProgramConfiguration(t.zoom); for (const t of e) o.useProgram(t, r); } } for (const t in o) { const i = this._sourceCaches[t]; o[t] !== i.used && i.getSource().fire(new e.Event("data", { sourceDataType: "visibility", dataType: "source", sourceId: i.getSource().id })); } this.light.recalculate(t), this.terrain && this.terrain.recalculate(t), this.fog && this.fog.recalculate(t), this.z = t.zoom, this._markersNeedUpdate && (this._updateMarkersOpacity(), this._markersNeedUpdate = !1), i && this.fire(new e.Event("data", { dataType: "style" })); } _updateTilesForChangedImages() { const e = Object.keys(this._changedImages); if (e.length) { for (const t in this._sourceCaches) this._sourceCaches[t].reloadTilesForDependencies(["icons", "patterns"], e); this._changedImages = {}; } } _updateWorkerLayers(e, t) { this.dispatcher.broadcast("updateLayers", { layers: this._serializeLayers(e), removedIds: t }); } _resetUpdates() { this._changed = !1, this._updatedLayers = {}, this._removedLayers = {}, this._updatedSources = {}, this._updatedPaintProps = {}, this._changedImages = {}; } setState(i) { if (this._checkLoaded(), $t(this, e.validateStyle(i))) return !1; (i = e.clone$1(i)).layers = Ve(i.layers); const o = function(e, i) { if (!e) return [{ command: We.setStyle, args: [i] }]; let o = []; try { if (!t(e.version, i.version)) return [{ command: We.setStyle, args: [i] }]; t(e.center, i.center) || o.push({ command: We.setCenter, args: [i.center] }), t(e.zoom, i.zoom) || o.push({ command: We.setZoom, args: [i.zoom] }), t(e.bearing, i.bearing) || o.push({ command: We.setBearing, args: [i.bearing] }), t(e.pitch, i.pitch) || o.push({ command: We.setPitch, args: [i.pitch] }), t(e.sprite, i.sprite) || o.push({ command: We.setSprite, args: [i.sprite] }), t(e.glyphs, i.glyphs) || o.push({ command: We.setGlyphs, args: [i.glyphs] }), t(e.transition, i.transition) || o.push({ command: We.setTransition, args: [i.transition] }), t(e.light, i.light) || o.push({ command: We.setLight, args: [i.light] }), t(e.fog, i.fog) || o.push({ command: We.setFog, args: [i.fog] }), t(e.projection, i.projection) || o.push({ command: We.setProjection, args: [i.projection] }); const r = {}, n = []; ! function(e, i, o, r) { let n; for (n in i = i || {}, e = e || {}) e.hasOwnProperty(n) && (i.hasOwnProperty(n) || qe(n, o, r)); for (n in i) { if (!i.hasOwnProperty(n)) continue; const s = i[n]; e.hasOwnProperty(n) ? t(e[n], s) || ("geojson" === e[n].type && "geojson" === s.type && He(e, i, n) ? o.push({ command: We.setGeoJSONSourceData, args: [n, s.data] }) : $e(n, i, o, r)) : Xe(n, i, o); } }(e.sources, i.sources, n, r); const s = []; e.layers && e.layers.forEach((e => { e.source && r[e.source] ? o.push({ command: We.removeLayer, args: [e.id] }) : s.push(e); })); let a = e.terrain; a && r[a.source] && (o.push({ command: We.setTerrain, args: [void 0] }), a = void 0), o = o.concat(n), t(a, i.terrain) || o.push({ command: We.setTerrain, args: [i.terrain] }), function(e, i, o) { i = i || []; const r = (e = e || []).map(Ke), n = i.map(Ke), s = e.reduce(Je, {}), a = i.reduce(Je, {}), l = r.slice(), c = Object.create(null); let h, u, _, d, p, m, f; for (h = 0, u = 0; h < r.length; h++) _ = r[h], a.hasOwnProperty(_) ? u++ : (o.push({ command: We.removeLayer, args: [_] }), l.splice(l.indexOf(_, u), 1)); for (h = 0, u = 0; h < n.length; h++) _ = n[n.length - 1 - h], l[l.length - 1 - h] !== _ && (s.hasOwnProperty(_) ? (o.push({ command: We.removeLayer, args: [_] }), l.splice(l.lastIndexOf(_, l.length - u), 1)) : u++, m = l[l.length - h], o.push({ command: We.addLayer, args: [a[_], m] }), l.splice(l.length - h, 0, _), c[_] = !0); for (h = 0; h < n.length; h++) if (_ = n[h], d = s[_], p = a[_], !c[_] && !t(d, p)) if (t(d.source, p.source) && t(d["source-layer"], p["source-layer"]) && t(d.type, p.type)) { for (f in Ye(d.layout, p.layout, o, _, null, We.setLayoutProperty), Ye(d.paint, p.paint, o, _, null, We.setPaintProperty), t(d.filter, p.filter) || o.push({ command: We.setFilter, args: [_, p.filter] }), t(d.minzoom, p.minzoom) && t(d.maxzoom, p.maxzoom) || o.push({ command: We.setLayerZoomRange, args: [_, p.minzoom, p.maxzoom] }), d) d.hasOwnProperty(f) && "layout" !== f && "paint" !== f && "filter" !== f && "metadata" !== f && "minzoom" !== f && "maxzoom" !== f && (0 === f.indexOf("paint.") ? Ye(d[f], p[f], o, _, f.slice(6), We.setPaintProperty) : t(d[f], p[f]) || o.push({ command: We.setLayerProperty, args: [_, f, p[f]] })); for (f in p) p.hasOwnProperty(f) && !d.hasOwnProperty(f) && "layout" !== f && "paint" !== f && "filter" !== f && "metadata" !== f && "minzoom" !== f && "maxzoom" !== f && (0 === f.indexOf("paint.") ? Ye(d[f], p[f], o, _, f.slice(6), We.setPaintProperty) : t(d[f], p[f]) || o.push({ command: We.setLayerProperty, args: [_, f, p[f]] })); } else o.push({ command: We.removeLayer, args: [_] }), m = l[l.lastIndexOf(_) + 1], o.push({ command: We.addLayer, args: [p, m] }); }(s, i.layers, o); } catch (e) { console.warn("Unable to compute style diff:", e), o = [{ command: We.setStyle, args: [i] }]; } return o }(this.serialize(), i).filter((e => !(e.command in Yt))); if (0 === o.length) return !1; const r = o.filter((e => !(e.command in Ht))); if (r.length > 0) throw new Error(`Unimplemented: ${r.map((e=>e.command)).join(", ")}.`); return o.forEach((e => { "setTransition" !== e.command && "setProjection" !== e.command && this[e.command].apply(this, e.args); })), this.stylesheet = i, this._updateMapProjection(), !0 } addImage(t, i) { return this.getImage(t) ? this.fire(new e.ErrorEvent(new Error("An image with this name already exists."))) : (this.imageManager.addImage(t, i), this._afterImageUpdated(t), this) } updateImage(e, t) { this.imageManager.updateImage(e, t); } getImage(e) { return this.imageManager.getImage(e) } removeImage(t) { return this.getImage(t) ? (this.imageManager.removeImage(t), this._afterImageUpdated(t), this) : this.fire(new e.ErrorEvent(new Error("No image with this name exists."))) } _afterImageUpdated(t) { this._availableImages = this.imageManager.listImages(), this._changedImages[t] = !0, this._changed = !0, this.dispatcher.broadcast("setImages", this._availableImages), this.fire(new e.Event("data", { dataType: "style" })); } listImages() { return this._checkLoaded(), this._availableImages.slice() } addSource(t, i, o = {}) { if (this._checkLoaded(), void 0 !== this.getSource(t)) throw new Error("There is already a source with this ID"); if (!i.type) throw new Error(`The type property must be defined, but only the following properties were given: ${Object.keys(i).join(", ")}.`); if (["vector", "raster", "geojson", "video", "image"].indexOf(i.type) >= 0 && this._validate(e.validateSource, `sources.${t}`, i, null, o)) return; this.map && this.map._collectResourceTiming && (i.collectResourceTiming = !0); const r = Pe(t, i, this.dispatcher, this); r.setEventedParent(this, (() => ({ isSourceLoaded: this._isSourceCacheLoaded(t), source: r.serialize(), sourceId: t }))); const n = i => { const o = (i ? "symbol:" : "other:") + t, n = this._sourceCaches[o] = new e.SourceCache(o, r, i); (i ? this._symbolSourceCaches : this._otherSourceCaches)[t] = n, n.style = this, n.onAdd(this.map); }; n(!1), "vector" !== i.type && "geojson" !== i.type || n(!0), r.onAdd && r.onAdd(this.map), this._changed = !0; } removeSource(t) { this._checkLoaded(); const i = this.getSource(t); if (!i) throw new Error("There is no source with this ID"); for (const i in this._layers) if (this._layers[i].source === t) return this.fire(new e.ErrorEvent(new Error(`Source "${t}" cannot be removed while layer "${i}" is using it.`))); if (this.terrain && this.terrain.get().source === t) return this.fire(new e.ErrorEvent(new Error(`Source "${t}" cannot be removed while terrain is using it.`))); const o = this._getSourceCaches(t); for (const t of o) delete this._sourceCaches[t.id], delete this._updatedSources[t.id], t.fire(new e.Event("data", { sourceDataType: "metadata", dataType: "source", sourceId: t.getSource().id })), t.setEventedParent(null), t.clearTiles(); return delete this._otherSourceCaches[t], delete this._symbolSourceCaches[t], i.setEventedParent(null), i.onRemove && i.onRemove(this.map), this._changed = !0, this } setGeoJSONSourceData(e, t) { this._checkLoaded(), this.getSource(e).setData(t), this._changed = !0; } getSource(e) { const t = this._getSourceCache(e); return t && t.getSource() } _getSources() { const e = []; for (const t in this._otherSourceCaches) { const i = this._getSourceCache(t); i && e.push(i.getSource()); } return e } addLayer(t, i, o = {}) { this._checkLoaded(); const r = t.id; if (this.getLayer(r)) return void this.fire(new e.ErrorEvent(new Error(`Layer with id "${r}" already exists on this map`))); let n; if ("custom" === t.type) { if ($t(this, e.validateCustomStyleLayer(t))) return; n = e.createStyleLayer(t); } else { if ("object" == typeof t.source && (this.addSource(r, t.source), t = e.clone$1(t), t = e.extend(t, { source: r })), this._validate(e.validateLayer, `layers.${r}`, t, { arrayIndex: -1 }, o)) return; n = e.createStyleLayer(t), this._validateLayer(n), n.setEventedParent(this, { layer: { id: r } }), this._serializedLayers[n.id] = n.serialize(), this._updateLayerCount(n, !0); } const s = i ? this._order.indexOf(i) : this._order.length; if (i && -1 === s) return void this.fire(new e.ErrorEvent(new Error(`Layer with id "${i}" does not exist on this map.`))); this._order.splice(s, 0, r), this._layerOrderChanged = !0, this._layers[r] = n; const a = this._getLayerSourceCache(n); if (this._removedLayers[r] && n.source && a && "custom" !== n.type) { const e = this._removedLayers[r]; delete this._removedLayers[r], e.type !== n.type ? this._updatedSources[n.source] = "clear" : (this._updatedSources[n.source] = "reload", a.pause()); } this._updateLayer(n), n.onAdd && n.onAdd(this.map), this._updateDrapeFirstLayers(); } moveLayer(t, i) { if (this._checkLoaded(), this._changed = !0, !this._layers[t]) return void this.fire(new e.ErrorEvent(new Error(`The layer '${t}' does not exist in the map's style and cannot be moved.`))); if (t === i) return; const o = this._order.indexOf(t); this._order.splice(o, 1); const r = i ? this._order.indexOf(i) : this._order.length; i && -1 === r ? this.fire(new e.ErrorEvent(new Error(`Layer with id "${i}" does not exist on this map.`))) : (this._order.splice(r, 0, t), this._layerOrderChanged = !0, this._updateDrapeFirstLayers()); } removeLayer(t) { this._checkLoaded(); const i = this._layers[t]; if (!i) return void this.fire(new e.ErrorEvent(new Error(`The layer '${t}' does not exist in the map's style and cannot be removed.`))); i.setEventedParent(null), this._updateLayerCount(i, !1); const o = this._order.indexOf(t); this._order.splice(o, 1), this._layerOrderChanged = !0, this._changed = !0, this._removedLayers[t] = i, delete this._layers[t], delete this._serializedLayers[t], delete this._updatedLayers[t], delete this._updatedPaintProps[t], i.onRemove && i.onRemove(this.map), this._updateDrapeFirstLayers(); } getLayer(e) { return this._layers[e] } hasLayer(e) { return e in this._layers } hasLayerType(e) { for (const t in this._layers) if (this._layers[t].type === e) return !0; return !1 } setLayerZoomRange(t, i, o) { this._checkLoaded(); const r = this.getLayer(t); r ? r.minzoom === i && r.maxzoom === o || (null != i && (r.minzoom = i), null != o && (r.maxzoom = o), this._updateLayer(r)) : this.fire(new e.ErrorEvent(new Error(`The layer '${t}' does not exist in the map's style and cannot have zoom extent.`))); } setFilter(i, o, r = {}) { this._checkLoaded(); const n = this.getLayer(i); if (n) { if (!t(n.filter, o)) return null == o ? (n.filter = void 0, void this._updateLayer(n)) : void(this._validate(e.validateFilter, `layers.${n.id}.filter`, o, { layerType: n.type }, r) || (n.filter = e.clone$1(o), this._updateLayer(n))) } else this.fire(new e.ErrorEvent(new Error(`The layer '${i}' does not exist in the map's style and cannot be filtered.`))); } getFilter(t) { const i = this.getLayer(t); return i && e.clone$1(i.filter) } setLayoutProperty(i, o, r, n = {}) { this._checkLoaded(); const s = this.getLayer(i); s ? t(s.getLayoutProperty(o), r) || (s.setLayoutProperty(o, r, n), this._updateLayer(s)) : this.fire(new e.ErrorEvent(new Error(`The layer '${i}' does not exist in the map's style and cannot be styled.`))); } getLayoutProperty(t, i) { const o = this.getLayer(t); if (o) return o.getLayoutProperty(i); this.fire(new e.ErrorEvent(new Error(`The layer '${t}' does not exist in the map's style.`))); } setPaintProperty(i, o, r, n = {}) { this._checkLoaded(); const s = this.getLayer(i); s ? t(s.getPaintProperty(o), r) || (s.setPaintProperty(o, r, n) && this._updateLayer(s), this._changed = !0, this._updatedPaintProps[i] = !0) : this.fire(new e.ErrorEvent(new Error(`The layer '${i}' does not exist in the map's style and cannot be styled.`))); } getPaintProperty(e, t) { const i = this.getLayer(e); return i && i.getPaintProperty(t) } setFeatureState(t, i) { this._checkLoaded(); const o = t.source, r = t.sourceLayer, n = this.getSource(o); if (!n) return void this.fire(new e.ErrorEvent(new Error(`The source '${o}' does not exist in the map's style.`))); const s = n.type; if ("geojson" === s && r) return void this.fire(new e.ErrorEvent(new Error("GeoJSON sources cannot have a sourceLayer parameter."))); if ("vector" === s && !r) return void this.fire(new e.ErrorEvent(new Error("The sourceLayer parameter must be provided for vector source types."))); void 0 === t.id && this.fire(new e.ErrorEvent(new Error("The feature id parameter must be provided."))); const a = this._getSourceCaches(o); for (const e of a) e.setFeatureState(r, t.id, i); } removeFeatureState(t, i) { this._checkLoaded(); const o = t.source, r = this.getSource(o); if (!r) return void this.fire(new e.ErrorEvent(new Error(`The source '${o}' does not exist in the map's style.`))); const n = r.type, s = "vector" === n ? t.sourceLayer : void 0; if ("vector" === n && !s) return void this.fire(new e.ErrorEvent(new Error("The sourceLayer parameter must be provided for vector source types."))); if (i && "string" != typeof t.id && "number" != typeof t.id) return void this.fire(new e.ErrorEvent(new Error("A feature id is required to remove its specific state property."))); const a = this._getSourceCaches(o); for (const e of a) e.removeFeatureState(s, t.id, i); } getFeatureState(t) { this._checkLoaded(); const i = t.source, o = t.sourceLayer, r = this.getSource(i); if (r) { if ("vector" !== r.type || o) return void 0 === t.id && this.fire(new e.ErrorEvent(new Error("The feature id parameter must be provided."))), this._getSourceCaches(i)[0].getFeatureState(o, t.id); this.fire(new e.ErrorEvent(new Error("The sourceLayer parameter must be provided for vector source types."))); } else this.fire(new e.ErrorEvent(new Error(`The source '${i}' does not exist in the map's style.`))); } getTransition() { return e.extend({ duration: 300, delay: 0 }, this.stylesheet && this.stylesheet.transition) } serialize() { const t = {}; for (const e in this._sourceCaches) { const i = this._sourceCaches[e].getSource(); t[i.id] || (t[i.id] = i.serialize()); } return e.filterObject({ version: this.stylesheet.version, name: this.stylesheet.name, metadata: this.stylesheet.metadata, light: this.stylesheet.light, terrain: this.getTerrain() || void 0, fog: this.stylesheet.fog, center: this.stylesheet.center, zoom: this.stylesheet.zoom, bearing: this.stylesheet.bearing, pitch: this.stylesheet.pitch, sprite: this.stylesheet.sprite, glyphs: this.stylesheet.glyphs, transition: this.stylesheet.transition, projection: this.stylesheet.projection, sources: t, layers: this._serializeLayers(this._order) }, (e => void 0 !== e)) } _updateLayer(e) { this._updatedLayers[e.id] = !0; const t = this._getLayerSourceCache(e); e.source && !this._updatedSources[e.source] && t && "raster" !== t.getSource().type && (this._updatedSources[e.source] = "reload", t.pause()), this._changed = !0, e.invalidateCompiledFilter(); } _flattenAndSortRenderedFeatures(e) { const t = e => "fill-extrusion" === this._layers[e].type, i = {}, o = []; for (let r = this._order.length - 1; r >= 0; r--) { const n = this._order[r]; if (t(n)) { i[n] = r; for (const t of e) { const e = t[n]; if (e) for (const t of e) o.push(t); } } } o.sort(((e, t) => t.intersectionZ - e.intersectionZ)); const r = []; for (let n = this._order.length - 1; n >= 0; n--) { const s = this._order[n]; if (t(s)) for (let e = o.length - 1; e >= 0; e--) { const t = o[e].feature; if (i[t.layer.id] < n) break; r.push(t), o.pop(); } else for (const t of e) { const e = t[s]; if (e) for (const t of e) r.push(t.feature); } } return r } queryRenderedFeatures(t, i, o) { i && i.filter && this._validate(e.validateFilter, "queryRenderedFeatures.filter", i.filter, null, i); const r = {}; if (i && i.layers) { if (!Array.isArray(i.layers)) return this.fire(new e.ErrorEvent(new Error("parameters.layers must be an Array."))), []; for (const t of i.layers) { const i = this._layers[t]; if (!i) return this.fire(new e.ErrorEvent(new Error(`The layer '${t}' does not exist in the map's style and cannot be queried for features.`))), []; r[i.source] = !0; } } const n = []; i.availableImages = this._availableImages; const s = i && i.layers ? i.layers.some((e => { const t = this.getLayer(e); return t && t.is3D() })) : this.has3DLayers(), a = R.createFromScreenPoints(t, o); for (const e in this._sourceCaches) { const t = this._sourceCaches[e].getSource().id; i.layers && !r[t] || n.push(Oe(this._sourceCaches[e], this._layers, this._serializedLayers, a, i, o, s, !!this.map._showQueryGeometry)); } return this.placement && n.push(function(e, t, i, o, r, n, s) { const a = {}, l = n.queryRenderedSymbols(o), c = []; for (const e of Object.keys(l).map(Number)) c.push(s[e]); c.sort(ke); for (const i of c) { const o = i.featureIndex.lookupSymbolFeatures(l[i.bucketInstanceId], t, i.bucketIndex, i.sourceLayerIndex, r.filter, r.layers, r.availableImages, e); for (const e in o) { const t = a[e] = a[e] || [], r = o[e]; r.sort(((e, t) => { const o = i.featureSortOrder; if (o) { const i = o.indexOf(e.featureIndex); return o.indexOf(t.featureIndex) - i } return t.featureIndex - e.featureIndex })); for (const e of r) t.push(e); } } for (const t in a) a[t].forEach((o => { const r = o.feature, n = i(e[t]); if (!n) return; const s = n.getFeatureState(r.layer["source-layer"], r.id); r.source = r.layer.source, r.layer["source-layer"] && (r.sourceLayer = r.layer["source-layer"]), r.state = s; })); return a }(this._layers, this._serializedLayers, this._getLayerSourceCache.bind(this), a.screenGeometry, i, this.placement.collisionIndex, this.placement.retainedQueryData)), this._flattenAndSortRenderedFeatures(n) } querySourceFeatures(t, i) { i && i.filter && this._validate(e.validateFilter, "querySourceFeatures.filter", i.filter, null, i); const o = this._getSourceCaches(t); let r = []; for (const e of o) r = r.concat(Be(e, i)); return r } addSourceType(e, t, i) { return Qt.getSourceType(e) ? i(new Error(`A source type called "${e}" already exists.`)) : (Qt.setSourceType(e, t), t.workerSourceURL ? void this.dispatcher.broadcast("loadWorkerSource", { name: e, url: t.workerSourceURL }, i) : i(null, null)) } getLight() { return this.light.getLight() } setLight(e, i = {}) { this._checkLoaded(); const o = this.light.getLight(); let r = !1; for (const i in e) if (!t(e[i], o[i])) { r = !0; break } if (!r) return; const n = this._setTransitionParameters({ duration: 300, delay: 0 }); this.light.setLight(e, i), this.light.updateTransitions(n); } getTerrain() { return this.terrain && 1 === this.terrain.drapeRenderMode ? this.terrain.get() : null } setTerrainForDraping() { this.setTerrain({ source: "", exaggeration: 0 }, 0); } setTerrain(i, o = 1) { if (this._checkLoaded(), !i) return delete this.terrain, delete this.stylesheet.terrain, this.dispatcher.broadcast("enableTerrain", !1), this._force3DLayerUpdate(), void(this._markersNeedUpdate = !0); let r = i; if (1 === o) { if ("object" == typeof r.source) { const t = "terrain-dem-src"; this.addSource(t, r.source), r = e.clone$1(r), r = e.extend(r, { source: t }); } if (this._validate(e.validateTerrain, "terrain", r)) return } if (!this.terrain || this.terrain && o !== this.terrain.drapeRenderMode) { if (!r) return; this._createTerrain(r, o); } else { const i = this.terrain, o = i.get(); for (const t of Object.keys(e.spec.terrain)) !r.hasOwnProperty(t) && e.spec.terrain[t].default && (r[t] = e.spec.terrain[t].default); for (const e in r) if (!t(r[e], o[e])) { i.set(r), this.stylesheet.terrain = r; const e = this._setTransitionParameters({ duration: 0 }); i.updateTransitions(e); break } } this._updateDrapeFirstLayers(), this._markersNeedUpdate = !0; } _createFog(e) { const t = this.fog = new A(e, this.map.transform); this.stylesheet.fog = e; const i = this._setTransitionParameters({ duration: 0 }); t.updateTransitions(i); } _updateMarkersOpacity() { 0 !== this.map._markers.length && this.map._requestDomTask((() => { for (const e of this.map._markers) e._evaluateOpacity(); })); } getFog() { return this.fog ? this.fog.get() : null } setFog(e) { if (this._checkLoaded(), !e) return delete this.fog, delete this.stylesheet.fog, void(this._markersNeedUpdate = !0); if (this.fog) { const i = this.fog, o = i.get(); 0 === Object.keys(e).length && i.set(e); for (const r in e) if (!t(e[r], o[r])) { i.set(e), this.stylesheet.fog = e; const t = this._setTransitionParameters({ duration: 0 }); i.updateTransitions(t); break } } else this._createFog(e); this._markersNeedUpdate = !0; } _setTransitionParameters(t) { return { now: e.exported.now(), transition: e.extend(t, this.stylesheet.transition) } } _updateDrapeFirstLayers() { if (!this.map._optimizeForTerrain || !this.terrain) return; const e = this._order.filter((e => this.isLayerDraped(this._layers[e]))), t = this._order.filter((e => !this.isLayerDraped(this._layers[e]))); this._drapedFirstOrder = [], this._drapedFirstOrder.push(...e), this._drapedFirstOrder.push(...t); } _createTerrain(e, t) { const i = this.terrain = new M(e, t); this.stylesheet.terrain = e, this.dispatcher.broadcast("enableTerrain", !this.terrainSetForDrapingOnly()), this._force3DLayerUpdate(); const o = this._setTransitionParameters({ duration: 0 }); i.updateTransitions(o); } _force3DLayerUpdate() { for (const e in this._layers) { const t = this._layers[e]; "fill-extrusion" === t.type && this._updateLayer(t); } } _forceSymbolLayerUpdate() { for (const e in this._layers) { const t = this._layers[e]; "symbol" === t.type && this._updateLayer(t); } } _validate(t, i, o, r, n = {}) { return (!n || !1 !== n.validate) && $t(this, t.call(e.validateStyle, e.extend({ key: i, style: this.serialize(), value: o, styleSpec: e.spec }, r))) } _remove() { this._request && (this._request.cancel(), this._request = null), this._spriteRequest && (this._spriteRequest.cancel(), this._spriteRequest = null), e.evented.off("pluginStateChange", this._rtlTextPluginCallback); for (const e in this._layers) this._layers[e].setEventedParent(null); for (const e in this._sourceCaches) this._sourceCaches[e].clearTiles(), this._sourceCaches[e].setEventedParent(null); this.imageManager.setEventedParent(null), this.setEventedParent(null), this.dispatcher.remove(); } _clearSource(e) { const t = this._getSourceCaches(e); for (const e of t) e.clearTiles(); } _reloadSource(e) { const t = this._getSourceCaches(e); for (const e of t) e.resume(), e.reload(); } _reloadSources() { for (const e of this._getSources()) e.reload && e.reload(); } _updateSources(e) { for (const t in this._sourceCaches) this._sourceCaches[t].update(e); } _generateCollisionBoxes() { for (const e in this._sourceCaches) { const t = this._sourceCaches[e]; t.resume(), t.reload(); } } _updatePlacement(t, i, o, r, n = !1) { let s = !1, a = !1; const l = {}; for (const e of this._order) { const i = this._layers[e]; if ("symbol" !== i.type) continue; if (!l[i.source]) { const e = this._getLayerSourceCache(i); if (!e) continue; l[i.source] = e.getRenderableIds(!0).map((t => e.getTileByID(t))).sort(((e, t) => t.tileID.overscaledZ - e.tileID.overscaledZ || (e.tileID.isLessThan(t.tileID) ? -1 : 1))); } const o = this.crossTileSymbolIndex.addLayer(i, l[i.source], t.center.lng, t.projection); s = s || o; } if (this.crossTileSymbolIndex.pruneUnusedLayers(this._order), n = n || this._layerOrderChanged || 0 === o, this._layerOrderChanged && this.fire(new e.Event("neworder")), (n || !this.pauseablePlacement || this.pauseablePlacement.isDone() && !this.placement.stillRecent(e.exported.now(), t.zoom)) && (this.pauseablePlacement = new jt(t, this._order, n, i, o, r, this.placement, this.fog && t.projection.supportsFog ? this.fog.state : null), this._layerOrderChanged = !1), this.pauseablePlacement.isDone() ? this.placement.setStale() : (this.pauseablePlacement.continuePlacement(this._order, this._layers, l), this.pauseablePlacement.isDone() && (this.placement = this.pauseablePlacement.commit(e.exported.now()), a = !0), s && this.pauseablePlacement.placement.setStale()), a || s) for (const e of this._order) { const t = this._layers[e]; "symbol" === t.type && this.placement.updateLayerOpacities(t, l[t.source]); } return !this.pauseablePlacement.isDone() || this.placement.hasTransitions(e.exported.now()) } _releaseSymbolFadeTiles() { for (const e in this._sourceCaches) this._sourceCaches[e].releaseSymbolFadeTiles(); } getImages(e, t, i) { this.imageManager.getImages(t.icons, i), this._updateTilesForChangedImages(); const o = e => { e && e.setDependencies(t.tileID.key, t.type, t.icons); }; o(this._otherSourceCaches[t.source]), o(this._symbolSourceCaches[t.source]); } getGlyphs(e, t, i) { this.glyphManager.getGlyphs(t.stacks, i); } getResource(t, i, o) { return e.makeRequest(i, o) } _getSourceCache(e) { return this._otherSourceCaches[e] } _getLayerSourceCache(e) { return "symbol" === e.type ? this._symbolSourceCaches[e.source] : this._otherSourceCaches[e.source] } _getSourceCaches(e) { const t = []; return this._otherSourceCaches[e] && t.push(this._otherSourceCaches[e]), this._symbolSourceCaches[e] && t.push(this._symbolSourceCaches[e]), t } _isSourceCacheLoaded(t) { const i = this._getSourceCaches(t); return 0 === i.length ? (this.fire(new e.ErrorEvent(new Error(`There is no source with ID '${t}'`))), !1) : i.every((e => e.loaded())) } has3DLayers() { return this._num3DLayers > 0 } hasSymbolLayers() { return this._numSymbolLayers > 0 } hasCircleLayers() { return this._numCircleLayers > 0 } _clearWorkerCaches() { this.dispatcher.broadcast("clearCaches"); } destroy() { this._clearWorkerCaches(), this.terrainSetForDrapingOnly() && (delete this.terrain, delete this.stylesheet.terrain); } } Qt.getSourceType = function(e) { return ze[e] }, Qt.setSourceType = function(e, t) { ze[e] = t; }, Qt.registerForPluginStateChange = e.registerForPluginStateChange; var ei = "\n#define EPSILON 0.0000001\n#define PI 3.141592653589793\n#define EXTENT 8192.0\n#define HALF_PI PI/2.0\n#define QUARTER_PI PI/4.0\n#define RAD_TO_DEG 180.0/PI\n#define DEG_TO_RAD PI/180.0\n#define GLOBE_RADIUS EXTENT/PI/2.0", ti = "attribute highp vec3 a_pos_3f;uniform lowp mat4 u_matrix;varying highp vec3 v_uv;void main() {const mat3 half_neg_pi_around_x=mat3(1.0,0.0, 0.0,0.0,0.0,-1.0,0.0,1.0, 0.0);v_uv=half_neg_pi_around_x*a_pos_3f;vec4 pos=u_matrix*vec4(a_pos_3f,1.0);gl_Position=pos.xyww;}", ii = "\n#define ELEVATION_SCALE 7.0\n#define ELEVATION_OFFSET 450.0\n#ifdef PROJECTION_GLOBE_VIEW\nuniform vec3 u_tile_tl_up;uniform vec3 u_tile_tr_up;uniform vec3 u_tile_br_up;uniform vec3 u_tile_bl_up;uniform float u_tile_up_scale;vec3 elevationVector(vec2 pos) {vec2 uv=pos/EXTENT;vec3 up=normalize(mix(\nmix(u_tile_tl_up,u_tile_tr_up,uv.xxx),mix(u_tile_bl_up,u_tile_br_up,uv.xxx),uv.yyy));return up*u_tile_up_scale;}\n#else\nvec3 elevationVector(vec2 pos) { return vec3(0,0,1); }\n#endif\nconst float skirtOffset=24575.0;vec3 decomposeToPosAndSkirt(vec2 posWithComposedSkirt)\n{float skirt=float(posWithComposedSkirt.x >=skirtOffset);vec2 pos=posWithComposedSkirt-vec2(skirt*skirtOffset,0.0);return vec3(pos,skirt);}\n#ifdef TERRAIN\n#ifdef TERRAIN_DEM_FLOAT_FORMAT\nuniform highp sampler2D u_dem;uniform highp sampler2D u_dem_prev;\n#else\nuniform sampler2D u_dem;uniform sampler2D u_dem_prev;\n#endif\nuniform vec4 u_dem_unpack;uniform vec2 u_dem_tl;uniform vec2 u_dem_tl_prev;uniform float u_dem_scale;uniform float u_dem_scale_prev;uniform float u_dem_size;uniform float u_dem_lerp;uniform float u_exaggeration;uniform float u_meter_to_dem;uniform mat4 u_label_plane_matrix_inv;uniform sampler2D u_depth;uniform vec2 u_depth_size_inv;vec4 tileUvToDemSample(vec2 uv,float dem_size,float dem_scale,vec2 dem_tl) {vec2 pos=dem_size*(uv*dem_scale+dem_tl)+1.0;vec2 f=fract(pos);return vec4((pos-f+0.5)/(dem_size+2.0),f);}float decodeElevation(vec4 v) {return dot(vec4(v.xyz*255.0,-1.0),u_dem_unpack);}float currentElevation(vec2 apos) {\n#ifdef TERRAIN_DEM_FLOAT_FORMAT\nvec2 pos=(u_dem_size*(apos/8192.0*u_dem_scale+u_dem_tl)+1.5)/(u_dem_size+2.0);return u_exaggeration*texture2D(u_dem,pos).a;\n#else\nfloat dd=1.0/(u_dem_size+2.0);vec4 r=tileUvToDemSample(apos/8192.0,u_dem_size,u_dem_scale,u_dem_tl);vec2 pos=r.xy;vec2 f=r.zw;float tl=decodeElevation(texture2D(u_dem,pos));\n#ifdef TERRAIN_DEM_NEAREST_FILTER\nreturn u_exaggeration*tl;\n#endif\nfloat tr=decodeElevation(texture2D(u_dem,pos+vec2(dd,0.0)));float bl=decodeElevation(texture2D(u_dem,pos+vec2(0.0,dd)));float br=decodeElevation(texture2D(u_dem,pos+vec2(dd,dd)));return u_exaggeration*mix(mix(tl,tr,f.x),mix(bl,br,f.x),f.y);\n#endif\n}float prevElevation(vec2 apos) {\n#ifdef TERRAIN_DEM_FLOAT_FORMAT\nvec2 pos=(u_dem_size*(apos/8192.0*u_dem_scale_prev+u_dem_tl_prev)+1.5)/(u_dem_size+2.0);return u_exaggeration*texture2D(u_dem_prev,pos).a;\n#else\nfloat dd=1.0/(u_dem_size+2.0);vec4 r=tileUvToDemSample(apos/8192.0,u_dem_size,u_dem_scale_prev,u_dem_tl_prev);vec2 pos=r.xy;vec2 f=r.zw;float tl=decodeElevation(texture2D(u_dem_prev,pos));float tr=decodeElevation(texture2D(u_dem_prev,pos+vec2(dd,0.0)));float bl=decodeElevation(texture2D(u_dem_prev,pos+vec2(0.0,dd)));float br=decodeElevation(texture2D(u_dem_prev,pos+vec2(dd,dd)));return u_exaggeration*mix(mix(tl,tr,f.x),mix(bl,br,f.x),f.y);\n#endif\n}\n#ifdef TERRAIN_VERTEX_MORPHING\nfloat elevation(vec2 apos) {\n#ifdef ZERO_EXAGGERATION\nreturn 0.0;\n#endif\nfloat nextElevation=currentElevation(apos);float prevElevation=prevElevation(apos);return mix(prevElevation,nextElevation,u_dem_lerp);}\n#else\nfloat elevation(vec2 apos) {\n#ifdef ZERO_EXAGGERATION\nreturn 0.0;\n#endif\nreturn currentElevation(apos);}\n#endif\nhighp float unpack_depth(highp vec4 rgba_depth)\n{const highp vec4 bit_shift=vec4(1.0/(255.0*255.0*255.0),1.0/(255.0*255.0),1.0/255.0,1.0);return dot(rgba_depth,bit_shift)*2.0-1.0;}bool isOccluded(vec4 frag) {vec3 coord=frag.xyz/frag.w;float depth=unpack_depth(texture2D(u_depth,(coord.xy+1.0)*0.5));return coord.z > depth+0.0005;}float occlusionFade(vec4 frag) {vec3 coord=frag.xyz/frag.w;vec3 df=vec3(5.0*u_depth_size_inv,0.0);vec2 uv=0.5*coord.xy+0.5;vec4 depth=vec4(\nunpack_depth(texture2D(u_depth,uv-df.xz)),unpack_depth(texture2D(u_depth,uv+df.xz)),unpack_depth(texture2D(u_depth,uv-df.zy)),unpack_depth(texture2D(u_depth,uv+df.zy))\n);return dot(vec4(0.25),vec4(1.0)-clamp(300.0*(vec4(coord.z-0.001)-depth),0.0,1.0));}vec4 fourSample(vec2 pos,vec2 off) {\n#ifdef TERRAIN_DEM_FLOAT_FORMAT\nfloat tl=texture2D(u_dem,pos).a;float tr=texture2D(u_dem,pos+vec2(off.x,0.0)).a;float bl=texture2D(u_dem,pos+vec2(0.0,off.y)).a;float br=texture2D(u_dem,pos+off).a;\n#else\nvec4 demtl=vec4(texture2D(u_dem,pos).xyz*255.0,-1.0);float tl=dot(demtl,u_dem_unpack);vec4 demtr=vec4(texture2D(u_dem,pos+vec2(off.x,0.0)).xyz*255.0,-1.0);float tr=dot(demtr,u_dem_unpack);vec4 dembl=vec4(texture2D(u_dem,pos+vec2(0.0,off.y)).xyz*255.0,-1.0);float bl=dot(dembl,u_dem_unpack);vec4 dembr=vec4(texture2D(u_dem,pos+off).xyz*255.0,-1.0);float br=dot(dembr,u_dem_unpack);\n#endif\nreturn vec4(tl,tr,bl,br);}float flatElevation(vec2 pack) {vec2 apos=floor(pack/8.0);vec2 span=10.0*(pack-apos*8.0);vec2 uvTex=(apos-vec2(1.0,1.0))/8190.0;float size=u_dem_size+2.0;float dd=1.0/size;vec2 pos=u_dem_size*(uvTex*u_dem_scale+u_dem_tl)+1.0;vec2 f=fract(pos);pos=(pos-f+0.5)*dd;vec4 h=fourSample(pos,vec2(dd));float z=mix(mix(h.x,h.y,f.x),mix(h.z,h.w,f.x),f.y);vec2 w=floor(0.5*(span*u_meter_to_dem-1.0));vec2 d=dd*w;h=fourSample(pos-d,2.0*d+vec2(dd));vec4 diff=abs(h.xzxy-h.ywzw);vec2 slope=min(vec2(0.25),u_meter_to_dem*0.5*(diff.xz+diff.yw)/(2.0*w+vec2(1.0)));vec2 fix=slope*span;float base=z+max(fix.x,fix.y);return u_exaggeration*base;}float elevationFromUint16(float word) {return u_exaggeration*(word/ELEVATION_SCALE-ELEVATION_OFFSET);}\n#else\nfloat elevation(vec2 pos) { return 0.0; }bool isOccluded(vec4 frag) { return false; }float occlusionFade(vec4 frag) { return 1.0; }\n#endif", oi = "#ifdef FOG\nuniform mediump vec4 u_fog_color;uniform mediump vec2 u_fog_range;uniform mediump float u_fog_horizon_blend;uniform mediump mat4 u_fog_matrix;varying vec3 v_fog_pos;float fog_range(float depth) {return (depth-u_fog_range[0])/(u_fog_range[1]-u_fog_range[0]);}float fog_horizon_blending(vec3 camera_dir) {float t=max(0.0,camera_dir.z/u_fog_horizon_blend);return u_fog_color.a*exp(-3.0*t*t);}float fog_opacity(float t) {const float decay=6.0;float falloff=1.0-min(1.0,exp(-decay*t));falloff*=falloff*falloff;return u_fog_color.a*min(1.0,1.00747*falloff);}vec3 fog_position(vec3 pos) {return (u_fog_matrix*vec4(pos,1.0)).xyz;}vec3 fog_position(vec2 pos) {return fog_position(vec3(pos,0.0));}float fog(vec3 pos) {float depth=length(pos);float opacity=fog_opacity(fog_range(depth));return opacity*fog_horizon_blending(pos/depth);}\n#endif", ri = "#ifdef FOG\nuniform mediump vec4 u_fog_color;uniform mediump vec2 u_fog_range;uniform mediump float u_fog_horizon_blend;uniform mediump float u_fog_temporal_offset;varying vec3 v_fog_pos;uniform highp vec3 u_frustum_tl;uniform highp vec3 u_frustum_tr;uniform highp vec3 u_frustum_br;uniform highp vec3 u_frustum_bl;uniform highp vec3 u_globe_pos;uniform highp float u_globe_radius;uniform highp vec2 u_viewport;uniform float u_globe_transition;uniform int u_is_globe;float fog_range(float depth) {return (depth-u_fog_range[0])/(u_fog_range[1]-u_fog_range[0]);}float fog_horizon_blending(vec3 camera_dir) {float t=max(0.0,camera_dir.z/u_fog_horizon_blend);return u_fog_color.a*exp(-3.0*t*t);}float fog_opacity(float t) {const float decay=6.0;float falloff=1.0-min(1.0,exp(-decay*t));falloff*=falloff*falloff;return u_fog_color.a*min(1.0,1.00747*falloff);}float globe_glow_progress() {highp vec2 uv=gl_FragCoord.xy/u_viewport;highp vec3 ray_dir=mix(\nmix(u_frustum_tl,u_frustum_tr,uv.x),mix(u_frustum_bl,u_frustum_br,uv.x),1.0-uv.y);highp vec3 dir=normalize(ray_dir);highp vec3 closest_point=dot(u_globe_pos,dir)*dir;highp float sdf=length(closest_point-u_globe_pos)/u_globe_radius;return sdf+PI*0.5;}float fog_opacity(vec3 pos) {float depth=length(pos);return fog_opacity(fog_range(depth));}vec3 fog_apply(vec3 color,vec3 pos) {float depth=length(pos);float opacity;if (u_is_globe==1) {float glow_progress=globe_glow_progress();float t=mix(glow_progress,depth,u_globe_transition);opacity=fog_opacity(fog_range(t));} else {opacity=fog_opacity(fog_range(depth));opacity*=fog_horizon_blending(pos/depth);}return mix(color,u_fog_color.rgb,opacity);}vec4 fog_apply_from_vert(vec4 color,float fog_opac) {float alpha=EPSILON+color.a;color.rgb=mix(color.rgb/alpha,u_fog_color.rgb,fog_opac)*alpha;return color;}vec3 fog_apply_sky_gradient(vec3 camera_ray,vec3 sky_color) {float horizon_blend=fog_horizon_blending(normalize(camera_ray));return mix(sky_color,u_fog_color.rgb,horizon_blend);}vec4 fog_apply_premultiplied(vec4 color,vec3 pos) {float alpha=EPSILON+color.a;color.rgb=fog_apply(color.rgb/alpha,pos)*alpha;return color;}vec3 fog_dither(vec3 color) {vec2 dither_seed=gl_FragCoord.xy+u_fog_temporal_offset;return dither(color,dither_seed);}vec4 fog_dither(vec4 color) {return vec4(fog_dither(color.rgb),color.a);}\n#endif"; let ni = {}, si = {}; const ai = []; _i(ei, ai), _i(ii, ai), _i(oi, ai), _i(ri, ai), ni = di("", ii), si = di(ri, oi); const li = di("\n#if __VERSION__ >=300\n#define varying in\n#define gl_FragColor glFragColor\n#define texture2D texture\n#define textureCube texture\nout vec4 glFragColor;\n#endif\nhighp vec3 hash(highp vec2 p) {highp vec3 p3=fract(p.xyx*vec3(443.8975,397.2973,491.1871));p3+=dot(p3,p3.yxz+19.19);return fract((p3.xxy+p3.yzz)*p3.zyx);}vec3 dither(vec3 color,highp vec2 seed) {vec3 rnd=hash(seed)+hash(seed+0.59374)-0.5;return color+rnd/255.0;}highp float unpack_depth(highp vec4 rgba_depth)\n{const highp vec4 bit_shift=vec4(1.0/(255.0*255.0*255.0),1.0/(255.0*255.0),1.0/255.0,1.0);return dot(rgba_depth,bit_shift)*2.0-1.0;}highp vec4 pack_depth(highp float ndc_z) {highp float depth=ndc_z*0.5+0.5;const highp vec4 bit_shift=vec4(255.0*255.0*255.0,255.0*255.0,255.0,1.0);const highp vec4 bit_mask =vec4(0.0,1.0/255.0,1.0/255.0,1.0/255.0);highp vec4 res=fract(depth*bit_shift);res-=res.xxyz*bit_mask;return res;}", "\n#if __VERSION__ >=300\n#define attribute in\n#define varying out\n#define texture2D texture\n#endif\nfloat wrap(float n,float min,float max) {float d=max-min;float w=mod(mod(n-min,d)+d,d)+min;return (w==min) ? max : w;}\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 mercator_tile_position(mat4 matrix,vec2 tile_anchor,vec3 tile_id,vec2 mercator_center) {\n#ifndef PROJECTED_POS_ON_VIEWPORT\nfloat tiles=tile_id.z;vec2 mercator=(tile_anchor/EXTENT+tile_id.xy)/tiles;mercator-=mercator_center;mercator.x=wrap(mercator.x,-0.5,0.5);vec4 mercator_tile=vec4(mercator.xy*EXTENT,EXTENT/(2.0*PI),1.0);mercator_tile=matrix*mercator_tile;return mercator_tile.xyz;\n#else\nreturn vec3(0.0);\n#endif\n}vec3 mix_globe_mercator(vec3 globe,vec3 mercator,float t) {return mix(globe,mercator,t);}mat3 globe_mercator_surface_vectors(vec3 pos_normal,vec3 up_dir,float zoom_transition) {vec3 normal=zoom_transition==0.0 ? pos_normal : normalize(mix(pos_normal,up_dir,zoom_transition));vec3 xAxis=normalize(vec3(normal.z,0.0,-normal.x));vec3 yAxis=normalize(cross(normal,xAxis));return mat3(xAxis,yAxis,normal);}\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(\nunpack_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;}const vec4 AWAY=vec4(-1000.0,-1000.0,-1000.0,1);//Normalized device coordinate that is not rendered."), ci = ei, hi = "\n#ifdef GL_ES\nprecision mediump float;\n#else\n\n#if !defined(lowp)\n#define lowp\n#endif\n\n#if !defined(mediump)\n#define mediump\n#endif\n\n#if !defined(highp)\n#define highp\n#endif\n\n#endif"; var ui = { background: di("uniform vec4 u_color;uniform float u_opacity;\n#ifdef LIGHTING_3D_MODE\nvarying vec4 v_color;\n#endif\nvoid main() {vec4 out_color;\n#ifdef LIGHTING_3D_MODE\nout_color=v_color;\n#else\nout_color=u_color;\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\ngl_FragColor=out_color*u_opacity;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "attribute vec2 a_pos;uniform mat4 u_matrix;\n#ifdef LIGHTING_3D_MODE\nuniform vec4 u_color;varying vec4 v_color;\n#endif\nvoid main() {gl_Position=u_matrix*vec4(a_pos,0,1);\n#ifdef LIGHTING_3D_MODE\nv_color=apply_lighting(u_color);\n#endif\n#ifdef FOG\nv_fog_pos=fog_position(a_pos);\n#endif\n}"), backgroundPattern: di("uniform vec2 u_pattern_tl;uniform vec2 u_pattern_br;uniform vec2 u_texsize;uniform float u_opacity;uniform sampler2D u_image;varying vec2 v_pos;void main() {vec2 imagecoord=mod(v_pos,1.0);vec2 pos=mix(u_pattern_tl/u_texsize,u_pattern_br/u_texsize,imagecoord);vec4 out_color=texture2D(u_image,pos);\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting(out_color);\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\ngl_FragColor=out_color*u_opacity;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "uniform mat4 u_matrix;uniform vec2 u_pattern_size;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform float u_tile_units_to_pixels;attribute vec2 a_pos;varying vec2 v_pos;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);v_pos=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,u_pattern_size,u_tile_units_to_pixels,a_pos);\n#ifdef FOG\nv_fog_pos=fog_position(a_pos);\n#endif\n}"), circle: di("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(\nantialiased_blur,0.0,extrude_length-radius/(radius+stroke_width)\n);vec4 out_color=mix(color*opacity,stroke_color*stroke_opacity,color_t);\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting(out_color);\n#endif\n#ifdef FOG\nout_color=fog_apply_premultiplied(out_color,v_fog_pos);\n#endif\ngl_FragColor=out_color*(v_visibility*opacity_t);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "#define NUM_VISIBILITY_RINGS 2\n#define INV_SQRT2 0.70710678\n#define ELEVATION_BIAS 0.0001\n#define NUM_SAMPLES_PER_RING 16\nuniform mat4 u_matrix;uniform mat2 u_extrude_scale;uniform lowp float u_device_pixel_ratio;uniform highp float u_camera_to_center_distance;attribute vec2 a_pos;\n#ifdef PROJECTION_GLOBE_VIEW\nattribute vec3 a_pos_3;attribute vec3 a_pos_normal_3;uniform mat4 u_inv_rot_matrix;uniform vec2 u_merc_center;uniform vec3 u_tile_id;uniform float u_zoom_transition;uniform vec3 u_up_dir;\n#endif\nvarying 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\nvec2 calc_offset(vec2 extrusion,float radius,float stroke_width, float view_scale) {return extrusion*(radius+stroke_width)*u_extrude_scale*view_scale;}float cantilevered_elevation(vec2 pos,float radius,float stroke_width,float view_scale) {vec2 c1=pos+calc_offset(vec2(-1,-1),radius,stroke_width,view_scale);vec2 c2=pos+calc_offset(vec2(1,-1),radius,stroke_width,view_scale);vec2 c3=pos+calc_offset(vec2(1,1),radius,stroke_width,view_scale);vec2 c4=pos+calc_offset(vec2(-1,1),radius,stroke_width,view_scale);float h1=elevation(c1)+ELEVATION_BIAS;float h2=elevation(c2)+ELEVATION_BIAS;float h3=elevation(c3)+ELEVATION_BIAS;float h4=elevation(c4)+ELEVATION_BIAS;return max(h4,max(h3,max(h1,h2)));}float circle_elevation(vec2 pos) {\n#if defined(TERRAIN)\nreturn elevation(pos)+ELEVATION_BIAS;\n#else\nreturn 0.0;\n#endif\n}vec4 project_vertex(vec2 extrusion,vec4 world_center,vec4 projected_center,float radius,float stroke_width, float view_scale,mat3 surface_vectors) {vec2 sample_offset=calc_offset(extrusion,radius,stroke_width,view_scale);\n#ifdef PITCH_WITH_MAP\n#ifdef PROJECTION_GLOBE_VIEW\nreturn u_matrix*( world_center+vec4(sample_offset.x*surface_vectors[0]+sample_offset.y*surface_vectors[1],0) );\n#else\nreturn u_matrix*( world_center+vec4(sample_offset,0,0) );\n#endif\n#else\nreturn projected_center+vec4(sample_offset,0,0);\n#endif\n}float get_sample_step() {\n#ifdef PITCH_WITH_MAP\nreturn 2.0*PI/float(NUM_SAMPLES_PER_RING);\n#else\nreturn PI/float(NUM_SAMPLES_PER_RING);\n#endif\n}void 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);vec4 world_center;mat3 surface_vectors;\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 pos_normal_3=a_pos_normal_3/16384.0;surface_vectors=globe_mercator_surface_vectors(pos_normal_3,u_up_dir,u_zoom_transition);vec3 surface_extrusion=extrude.x*surface_vectors[0]+extrude.y*surface_vectors[1];vec3 globe_elevation=elevationVector(circle_center)*circle_elevation(circle_center);vec3 globe_pos=a_pos_3+surface_extrusion+globe_elevation;vec3 mercator_elevation=u_up_dir*u_tile_up_scale*circle_elevation(circle_center);vec3 merc_pos=mercator_tile_position(u_inv_rot_matrix,circle_center,u_tile_id,u_merc_center)+surface_extrusion+mercator_elevation;vec3 pos=mix_globe_mercator(globe_pos,merc_pos,u_zoom_transition);world_center=vec4(pos,1);\n#else \nsurface_vectors=mat3(1.0);float height=circle_elevation(circle_center);world_center=vec4(circle_center,height,1);\n#endif\nvec4 projected_center=u_matrix*world_center;float view_scale=0.0;\n#ifdef PITCH_WITH_MAP\n#ifdef SCALE_WITH_MAP\nview_scale=1.0;\n#else\nview_scale=projected_center.w/u_camera_to_center_distance;\n#endif\n#else\n#ifdef SCALE_WITH_MAP\nview_scale=u_camera_to_center_distance;\n#else\nview_scale=projected_center.w;\n#endif\n#endif\ngl_Position=project_vertex(extrude,world_center,projected_center,radius,stroke_width,view_scale,surface_vectors);float visibility=0.0;\n#ifdef TERRAIN\nfloat step=get_sample_step();vec4 occlusion_world_center;vec4 occlusion_projected_center;\n#ifdef PITCH_WITH_MAP\nfloat cantilevered_height=cantilevered_elevation(circle_center,radius,stroke_width,view_scale);occlusion_world_center=vec4(circle_center,cantilevered_height,1);occlusion_projected_center=u_matrix*occlusion_world_center;\n#else\nocclusion_world_center=world_center;occlusion_projected_center=projected_center;\n#endif\nfor(int ring=0; ring < NUM_VISIBILITY_RINGS; ring++) {float scale=(float(ring)+1.0)/float(NUM_VISIBILITY_RINGS);for(int i=0; i < NUM_SAMPLES_PER_RING; i++) {vec2 extrusion=vec2(cos(step*float(i)),-sin(step*float(i)))*scale;vec4 frag_pos=project_vertex(extrusion,occlusion_world_center,occlusion_projected_center,radius,stroke_width,view_scale,surface_vectors);visibility+=float(!isOccluded(frag_pos));}}visibility/=float(NUM_VISIBILITY_RINGS)*float(NUM_SAMPLES_PER_RING);\n#else\nvisibility=1.0;\n#endif\n#ifdef PROJECTION_GLOBE_VIEW\nvisibility=1.0;\n#endif\nv_visibility=visibility;lowp float antialiasblur=1.0/u_device_pixel_ratio/(radius+stroke_width);v_data=vec3(extrude.x,extrude.y,antialiasblur);\n#ifdef FOG\nv_fog_pos=fog_position(world_center.xyz);\n#endif\n}"), clippingMask: di("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: di("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 FOG\nif (u_is_globe==0) {gl_FragColor.r*=pow(1.0-fog_opacity(v_fog_pos),2.0);}\n#endif\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;\n#ifdef PROJECTION_GLOBE_VIEW\nattribute vec3 a_pos_3;attribute vec3 a_pos_normal_3;uniform mat4 u_inv_rot_matrix;uniform vec2 u_merc_center;uniform vec3 u_tile_id;uniform float u_zoom_transition;uniform vec3 u_up_dir;\n#endif\nvarying 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;vec2 tilePos=floor(a_pos*0.5);vec3 pos;\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 pos_normal_3=a_pos_normal_3/16384.0;mat3 surface_vectors=globe_mercator_surface_vectors(pos_normal_3,u_up_dir,u_zoom_transition);vec3 surface_extrusion=extrude.x*surface_vectors[0]+extrude.y*surface_vectors[1];vec3 globe_elevation=elevationVector(tilePos)*elevation(tilePos);vec3 globe_pos=a_pos_3+surface_extrusion+globe_elevation;vec3 mercator_elevation=u_up_dir*u_tile_up_scale*elevation(tilePos);vec3 merc_pos=mercator_tile_position(u_inv_rot_matrix,tilePos,u_tile_id,u_merc_center)+surface_extrusion+mercator_elevation;pos=mix_globe_mercator(globe_pos,merc_pos,u_zoom_transition);\n#else\npos=vec3(tilePos+extrude,elevation(tilePos));\n#endif\ngl_Position=u_matrix*vec4(pos,1);\n#ifdef FOG\nv_fog_pos=fog_position(pos);\n#endif\n}"), heatmapTexture: di("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}", "attribute vec2 a_pos;varying vec2 v_pos;void main() {gl_Position=vec4(a_pos,0,1);v_pos=a_pos*0.5+0.5;}"), collisionBox: di("varying float v_placed;varying float v_notUsed;void main() {vec4 red =vec4(1.0,0.0,0.0,1.0);vec4 blue=vec4(0.0,0.0,1.0,0.5);gl_FragColor =mix(red,blue,step(0.5,v_placed))*0.5;gl_FragColor*=mix(1.0,0.1,step(0.5,v_notUsed));}", "attribute vec3 a_pos;attribute vec2 a_anchor_pos;attribute vec2 a_extrude;attribute vec2 a_placed;attribute vec2 a_shift;attribute float a_size_scale;attribute vec2 a_padding;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_pos+elevationVector(a_anchor_pos)*elevation(a_anchor_pos),1);highp float camera_to_anchor_distance=projectedPoint.w;highp float collision_perspective_ratio=clamp(\n0.5+0.5*(u_camera_to_center_distance/camera_to_anchor_distance),0.0,1.5);gl_Position=projectedPoint;gl_Position.xy+=(a_extrude*a_size_scale+a_shift+a_padding)*u_extrude_scale*gl_Position.w*collision_perspective_ratio;v_placed=a_placed.x;v_notUsed=a_placed.y;}"), collisionCircle: di("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_2f;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_2f;float radius=a_radius;float collision=a_flags.x;float vertexIdx=a_flags.y;vec2 quadVertexOffset=vec2(\nmix(-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(\n0.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: di("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;\n#ifdef PROJECTION_GLOBE_VIEW\nattribute vec3 a_pos_3;\n#endif\nvarying vec2 v_uv;uniform mat4 u_matrix;uniform float u_overlay_scale;void main() {float h=elevation(a_pos);v_uv=a_pos/8192.0;\n#ifdef PROJECTION_GLOBE_VIEW\ngl_Position=u_matrix*vec4(a_pos_3+elevationVector(a_pos)*h,1);\n#else\ngl_Position=u_matrix*vec4(a_pos*u_overlay_scale,h,1);\n#endif\n}"), fill: di("#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\nvec4 out_color=color;\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting(out_color);\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\ngl_FragColor=out_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);\n#ifdef FOG\nv_fog_pos=fog_position(a_pos);\n#endif\n}"), fillOutline: di("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);vec4 out_color=outline_color;\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting(out_color);\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\ngl_FragColor=out_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;\n#ifdef FOG\nv_fog_pos=fog_position(a_pos);\n#endif\n}"), fillOutlinePattern: di("uniform vec2 u_texsize;uniform sampler2D u_image;varying vec2 v_pos;varying vec2 v_pos_world;\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp vec4 pattern\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump vec4 pattern\nvec2 pattern_tl=pattern.xy;vec2 pattern_br=pattern.zw;vec2 imagecoord=mod(v_pos,1.0);vec2 pos=mix(pattern_tl/u_texsize,pattern_br/u_texsize,imagecoord);float dist=length(v_pos_world-gl_FragCoord.xy);float alpha=1.0-smoothstep(0.0,1.0,dist);vec4 out_color=texture2D(u_image,pos);\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting(out_color);\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\ngl_FragColor=out_color*(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 float u_tile_units_to_pixels;attribute vec2 a_pos;varying vec2 v_pos;varying vec2 v_pos_world;\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp vec4 pattern\n#pragma mapbox: define lowp float pixel_ratio\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump vec4 pattern\n#pragma mapbox: initialize lowp float pixel_ratio\nvec2 pattern_tl=pattern.xy;vec2 pattern_br=pattern.zw;gl_Position=u_matrix*vec4(a_pos,0,1);vec2 display_size=(pattern_br-pattern_tl)/pixel_ratio;v_pos=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,display_size,u_tile_units_to_pixels,a_pos);v_pos_world=(gl_Position.xy/gl_Position.w+1.0)/2.0*u_world;\n#ifdef FOG\nv_fog_pos=fog_position(a_pos);\n#endif\n}"), fillPattern: di("uniform vec2 u_texsize;uniform sampler2D u_image;varying vec2 v_pos;\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp vec4 pattern\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump vec4 pattern\nvec2 pattern_tl=pattern.xy;vec2 pattern_br=pattern.zw;vec2 imagecoord=mod(v_pos,1.0);vec2 pos=mix(pattern_tl/u_texsize,pattern_br/u_texsize,imagecoord);vec4 out_color=texture2D(u_image,pos);\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting(out_color);\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\ngl_FragColor=out_color*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 float u_tile_units_to_pixels;attribute vec2 a_pos;varying vec2 v_pos;\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp vec4 pattern\n#pragma mapbox: define lowp float pixel_ratio\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump vec4 pattern\n#pragma mapbox: initialize lowp float pixel_ratio\nvec2 pattern_tl=pattern.xy;vec2 pattern_br=pattern.zw;vec2 display_size=(pattern_br-pattern_tl)/pixel_ratio;gl_Position=u_matrix*vec4(a_pos,0,1);v_pos=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,display_size,u_tile_units_to_pixels,a_pos);\n#ifdef FOG\nv_fog_pos=fog_position(a_pos);\n#endif\n}"), fillExtrusion: di("varying vec4 v_color;\n#ifdef RENDER_SHADOWS\nvarying highp vec4 v_pos_light_view_0;varying highp vec4 v_pos_light_view_1;varying float v_depth;\n#endif\n#ifdef FAUX_AO\nuniform lowp vec2 u_ao;varying vec3 v_ao;\n#endif\n#ifdef ZERO_ROOF_RADIUS\nvarying vec4 v_roof_color;\n#endif\n#if defined(ZERO_ROOF_RADIUS) || defined(RENDER_SHADOWS)\nvarying highp vec3 v_normal;\n#endif\nvoid main() {\n#if defined(ZERO_ROOF_RADIUS) || defined(RENDER_SHADOWS)\nvec3 normal=v_normal;\n#endif\nfloat z;vec4 color;\n#ifdef ZERO_ROOF_RADIUS\nz=float(normal.z > 0.00001);color=mix(v_color,v_roof_color,z);\n#else\ncolor=v_color;\n#endif\n#ifdef FAUX_AO\nfloat intensity=u_ao[0];float h=max(0.0,v_ao.z);float h_floors=h/u_ao[1];float y_shade=1.0-0.9*intensity*min(v_ao.y,1.0);float shade=(1.0-0.08*intensity)*(y_shade+(1.0-y_shade)*(1.0-pow(1.0-min(h_floors/16.0,1.0),16.0)))+0.08*intensity*min(h_floors/160.0,1.0);float concave=v_ao.x*v_ao.x;\n#ifdef ZERO_ROOF_RADIUS\nconcave*=(1.0-z);\n#endif\nfloat x_shade=mix(1.0,mix(0.6,0.75,min(h_floors/30.0,1.0)),intensity)+0.1*intensity*min(h,1.0);shade*=mix(1.0,x_shade*x_shade*x_shade,concave);color.rgb=color.rgb*shade;\n#endif\n#ifdef RENDER_SHADOWS\n#ifdef ZERO_ROOF_RADIUS\nnormal=mix(normal,vec3(0.0,0.0,1.0),z);\n#endif\ncolor.xyz=shadowed_color_normal(color.xyz,normalize(normal),v_pos_light_view_0,v_pos_light_view_1,v_depth);\n#endif\n#ifdef FOG\ncolor=fog_dither(fog_apply_premultiplied(color,v_fog_pos));\n#endif\ngl_FragColor=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;uniform float u_edge_radius;attribute vec4 a_pos_normal_ed;attribute vec2 a_centroid_pos;\n#ifdef PROJECTION_GLOBE_VIEW\nattribute vec3 a_pos_3;attribute vec3 a_pos_normal_3;uniform mat4 u_inv_rot_matrix;uniform vec2 u_merc_center;uniform vec3 u_tile_id;uniform float u_zoom_transition;uniform vec3 u_up_dir;uniform float u_height_lift;\n#endif\nvarying vec4 v_color;\n#ifdef RENDER_SHADOWS\nuniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;varying highp vec4 v_pos_light_view_0;varying highp vec4 v_pos_light_view_1;varying float v_depth;\n#endif\n#ifdef ZERO_ROOF_RADIUS\nvarying vec4 v_roof_color;\n#endif\n#if defined(ZERO_ROOF_RADIUS) || defined(RENDER_SHADOWS)\nvarying highp vec3 v_normal;\n#endif\n#ifdef FAUX_AO\nuniform lowp vec2 u_ao;varying vec3 v_ao;\n#endif\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\nvec4 pos_nx=floor(a_pos_normal_ed*0.5);vec4 top_up_ny_start=a_pos_normal_ed-2.0*pos_nx;vec3 top_up_ny=top_up_ny_start.xyz;float x_normal=pos_nx.z/8192.0;vec3 normal=top_up_ny.y==1.0 ? vec3(0.0,0.0,1.0) : normalize(vec3(x_normal,(2.0*top_up_ny.z-1.0)*(1.0-abs(x_normal)),0.0));\n#if defined(ZERO_ROOF_RADIUS) || defined(RENDER_SHADOWS)\nv_normal=normal;\n#endif\nbase=max(0.0,base);height=max(0.0,top_up_ny.y==0.0 && top_up_ny.x==1.0 ? height-u_edge_radius : height);float t=top_up_ny.x;vec2 centroid_pos=vec2(0.0);\n#if defined(HAS_CENTROID) || defined(TERRAIN)\ncentroid_pos=a_centroid_pos;\n#endif\nfloat ele=0.0;float h=0.0;float c_ele;vec3 pos;\n#ifdef TERRAIN\nbool flat_roof=centroid_pos.x !=0.0 && t > 0.0;ele=elevation(pos_nx.xy);c_ele=flat_roof ? centroid_pos.y==0.0 ? elevationFromUint16(centroid_pos.x) : flatElevation(centroid_pos) : ele;h=flat_roof ? max(c_ele+height,ele+base+2.0) : ele+(t > 0.0 ? height : base==0.0 ?-5.0 : base);pos=vec3(pos_nx.xy,h);\n#else\nh=t > 0.0 ? height : base;pos=vec3(pos_nx.xy,h);\n#endif\n#ifdef PROJECTION_GLOBE_VIEW\nfloat lift=float((t+base) > 0.0)*u_height_lift;h+=lift;vec3 globe_normal=normalize(mix(a_pos_normal_3/16384.0,u_up_dir,u_zoom_transition));vec3 globe_pos=a_pos_3+globe_normal*(u_tile_up_scale*h);vec3 merc_pos=mercator_tile_position(u_inv_rot_matrix,pos.xy,u_tile_id,u_merc_center)+u_up_dir*u_tile_up_scale*pos.z;pos=mix_globe_mercator(globe_pos,merc_pos,u_zoom_transition);\n#endif\nfloat hidden=float(centroid_pos.x==0.0 && centroid_pos.y==1.0);gl_Position=mix(u_matrix*vec4(pos,1),AWAY,hidden);\n#ifdef RENDER_SHADOWS\nv_pos_light_view_0=u_light_matrix_0*vec4(pos,1);v_pos_light_view_1=u_light_matrix_1*vec4(pos,1);v_depth=gl_Position.w;\n#endif\nfloat NdotL=0.0;float colorvalue=0.0;\n#ifdef LIGHTING_3D_MODE\nNdotL=calculate_NdotL(normal);\n#else\ncolorvalue=color.r*0.2126+color.g*0.7152+color.b*0.0722;vec4 ambientlight=vec4(0.03,0.03,0.03,1.0);color+=ambientlight;NdotL=clamp(dot(normal,u_lightpos),0.0,1.0);NdotL=mix((1.0-u_lightintensity),max((1.0-colorvalue+u_lightintensity),1.0),NdotL);\n#endif\nif (normal.y !=0.0) {float r=0.84;\n#ifndef LIGHTING_3D_MODE\nr=mix(0.7,0.98,1.0-u_lightintensity);\n#endif\nNdotL*=(\n(1.0-u_vertical_gradient)+(u_vertical_gradient*clamp((t+base)*pow(height/150.0,0.5),r,1.0)));}v_color=vec4(0.0,0.0,0.0,1.0);\n#ifdef FAUX_AO\nfloat concave=pos_nx.w-floor(pos_nx.w*0.5)*2.0;float start=top_up_ny_start.w;float y_ground=1.0-clamp(t+base,0.0,1.0);float top_height=height;\n#ifdef TERRAIN\ntop_height=mix(max(c_ele+height,ele+base+2.0),ele+height,float(centroid_pos.x==0.0))-ele;y_ground+=y_ground*5.0/max(3.0,top_height);\n#endif\nv_ao=vec3(mix(concave,-concave,start),y_ground,h-ele);NdotL*=(1.0+0.05*(1.0-top_up_ny.y)*u_ao[0]);\n#ifdef PROJECTION_GLOBE_VIEW\ntop_height+=u_height_lift;\n#endif\ngl_Position.z-=(0.0000006*(min(top_height,500.)+2.0*min(base,500.0)+60.0*concave+3.0*start))*gl_Position.w;\n#endif\n#ifdef LIGHTING_3D_MODE\nv_color=apply_lighting(color,NdotL);\n#else\nv_color.rgb+=clamp(color.rgb*NdotL*u_lightcolor,mix(vec3(0.0),vec3(0.3),1.0-u_lightcolor),vec3(1.0));\n#endif\nv_color*=u_opacity;\n#ifdef ZERO_ROOF_RADIUS\nv_roof_color=vec4(0.0,0.0,0.0,1.0);\n#ifdef LIGHTING_3D_MODE\nv_roof_color=apply_lighting(color,calculate_NdotL(vec3(0.0,0.0,1.0)));\n#else\nfloat roofNdotL=clamp(u_lightpos.z,0.0,1.0);roofNdotL=mix((1.0-u_lightintensity),max((1.0-colorvalue+u_lightintensity),1.0),roofNdotL);v_roof_color.rgb+=clamp(color.rgb*roofNdotL*u_lightcolor,mix(vec3(0.0),vec3(0.3),1.0-u_lightcolor),vec3(1.0));\n#endif\nv_roof_color*=u_opacity;\n#endif\n#ifdef FOG\nv_fog_pos=fog_position(pos);\n#endif\n}"), fillExtrusionPattern: di("uniform vec2 u_texsize;uniform sampler2D u_image;\n#ifdef FAUX_AO\nuniform lowp vec2 u_ao;varying vec3 v_ao;\n#endif\n#ifdef LIGHTING_3D_MODE\nvarying float v_NdotL;\n#endif\nvarying vec2 v_pos;varying vec4 v_lighting;uniform lowp float u_opacity;\n#pragma mapbox: define lowp float base\n#pragma mapbox: define lowp float height\n#pragma mapbox: define lowp vec4 pattern\n#pragma mapbox: define lowp float pixel_ratio\nvoid main() {\n#pragma mapbox: initialize lowp float base\n#pragma mapbox: initialize lowp float height\n#pragma mapbox: initialize mediump vec4 pattern\n#pragma mapbox: initialize lowp float pixel_ratio\nvec2 pattern_tl=pattern.xy;vec2 pattern_br=pattern.zw;vec2 imagecoord=mod(v_pos,1.0);vec2 pos=mix(pattern_tl/u_texsize,pattern_br/u_texsize,imagecoord);vec4 out_color=texture2D(u_image,pos);\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting(out_color,v_NdotL)*u_opacity;\n#else\nout_color=out_color*v_lighting;\n#endif\n#ifdef FAUX_AO\nfloat intensity=u_ao[0];float h=max(0.0,v_ao.z);float h_floors=h/u_ao[1];float y_shade=1.0-0.9*intensity*min(v_ao.y,1.0);float shade=(1.0-0.08*intensity)*(y_shade+(1.0-y_shade)*(1.0-pow(1.0-min(h_floors/16.0,1.0),16.0)))+0.08*intensity*min(h_floors/160.0,1.0);float concave=v_ao.x*v_ao.x;float x_shade=mix(1.0,mix(0.6,0.75,min(h_floors/30.0,1.0)),intensity)+0.1*intensity*min(h,1.0);shade*=mix(1.0,x_shade*x_shade*x_shade,concave);out_color.rgb=out_color.rgb*shade;\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\ngl_FragColor=out_color;\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 float u_tile_units_to_pixels;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 vec4 a_pos_normal_ed;attribute vec2 a_centroid_pos;\n#ifdef PROJECTION_GLOBE_VIEW\nattribute vec3 a_pos_3;attribute vec3 a_pos_normal_3;uniform mat4 u_inv_rot_matrix;uniform vec2 u_merc_center;uniform vec3 u_tile_id;uniform float u_zoom_transition;uniform vec3 u_up_dir;uniform float u_height_lift;\n#endif\nvarying vec2 v_pos;varying vec4 v_lighting;\n#ifdef FAUX_AO\nuniform lowp vec2 u_ao;varying vec3 v_ao;\n#endif\n#ifdef LIGHTING_3D_MODE\nvarying float v_NdotL;\n#endif\n#pragma mapbox: define lowp float base\n#pragma mapbox: define lowp float height\n#pragma mapbox: define lowp vec4 pattern\n#pragma mapbox: define lowp float pixel_ratio\nvoid main() {\n#pragma mapbox: initialize lowp float base\n#pragma mapbox: initialize lowp float height\n#pragma mapbox: initialize mediump vec4 pattern\n#pragma mapbox: initialize lowp float pixel_ratio\nvec2 pattern_tl=pattern.xy;vec2 pattern_br=pattern.zw;vec4 pos_nx=floor(a_pos_normal_ed*0.5);mediump vec4 top_up_ny_start=a_pos_normal_ed-2.0*pos_nx;mediump vec3 top_up_ny=top_up_ny_start.xyz;float x_normal=pos_nx.z/8192.0;vec3 normal=top_up_ny.y==1.0 ? vec3(0.0,0.0,1.0) : normalize(vec3(x_normal,(2.0*top_up_ny.z-1.0)*(1.0-abs(x_normal)),0.0));float edgedistance=a_pos_normal_ed.w;vec2 display_size=(pattern_br-pattern_tl)/pixel_ratio;base=max(0.0,base);height=max(0.0,height);float t=top_up_ny.x;float z=t > 0.0 ? height : base;vec2 centroid_pos=vec2(0.0);\n#if defined(HAS_CENTROID) || defined(TERRAIN)\ncentroid_pos=a_centroid_pos;\n#endif\nfloat ele=0.0;float h=z;vec3 p;float c_ele;\n#ifdef TERRAIN\nbool flat_roof=centroid_pos.x !=0.0 && t > 0.0;ele=elevation(pos_nx.xy);c_ele=flat_roof ? centroid_pos.y==0.0 ? elevationFromUint16(centroid_pos.x) : flatElevation(centroid_pos) : ele;h=flat_roof ? max(c_ele+height,ele+base+2.0) : ele+(t > 0.0 ? height : base==0.0 ?-5.0 : base);p=vec3(pos_nx.xy,h);\n#else\np=vec3(pos_nx.xy,z);\n#endif\n#ifdef PROJECTION_GLOBE_VIEW\nfloat lift=float((t+base) > 0.0)*u_height_lift;h+=lift;vec3 globe_normal=normalize(mix(a_pos_normal_3/16384.0,u_up_dir,u_zoom_transition));vec3 globe_pos=a_pos_3+globe_normal*(u_tile_up_scale*(p.z+lift));vec3 merc_pos=mercator_tile_position(u_inv_rot_matrix,p.xy,u_tile_id,u_merc_center)+u_up_dir*u_tile_up_scale*p.z;p=mix_globe_mercator(globe_pos,merc_pos,u_zoom_transition);\n#endif\nfloat hidden=float(centroid_pos.x==0.0 && centroid_pos.y==1.0);gl_Position=mix(u_matrix*vec4(p,1),AWAY,hidden);vec2 pos=normal.z==1.0\n? pos_nx.xy\n: vec2(edgedistance,z*u_height_factor);v_pos=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,display_size,u_tile_units_to_pixels,pos);v_lighting=vec4(0.0,0.0,0.0,1.0);float NdotL=0.0;\n#ifdef LIGHTING_3D_MODE\nNdotL=calculate_NdotL(normal);\n#else\nNdotL=clamp(dot(normal,u_lightpos),0.0,1.0);NdotL=mix((1.0-u_lightintensity),max((0.5+u_lightintensity),1.0),NdotL);\n#endif\nif (normal.y !=0.0) {float r=0.84;\n#ifndef LIGHTING_3D_MODE\nr=mix(0.7,0.98,1.0-u_lightintensity);\n#endif\nNdotL*=(\n(1.0-u_vertical_gradient)+(u_vertical_gradient*clamp((t+base)*pow(height/150.0,0.5),r,1.0)));}\n#ifdef FAUX_AO\nfloat concave=pos_nx.w-floor(pos_nx.w*0.5)*2.0;float start=top_up_ny_start.w;float y_ground=1.0-clamp(t+base,0.0,1.0);float top_height=height;\n#ifdef TERRAIN\ntop_height=mix(max(c_ele+height,ele+base+2.0),ele+height,float(centroid_pos.x==0.0))-ele;y_ground+=y_ground*5.0/max(3.0,top_height);\n#endif\nv_ao=vec3(mix(concave,-concave,start),y_ground,h-ele);NdotL*=(1.0+0.05*(1.0-top_up_ny.y)*u_ao[0]);\n#ifdef PROJECTION_GLOBE_VIEW\ntop_height+=u_height_lift;\n#endif\ngl_Position.z-=(0.0000006*(min(top_height,500.)+2.0*min(base,500.0)+60.0*concave+3.0*start))*gl_Position.w;\n#endif\n#ifdef LIGHTING_3D_MODE\nv_NdotL=NdotL;\n#else\nv_lighting.rgb+=clamp(NdotL*u_lightcolor,mix(vec3(0.0),vec3(0.3),1.0-u_lightcolor),vec3(1.0));v_lighting*=u_opacity;\n#endif \n#ifdef FOG\nv_fog_pos=fog_position(p);\n#endif\n}"), hillshadePrepare: di("#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) {\n#ifdef TERRAIN_DEM_FLOAT_FORMAT\nreturn texture2D(u_image,coord).a/4.0;\n#else\nvec4 data=texture2D(u_image,coord)*255.0;data.a=-1.0;return dot(data,u_unpack)/4.0;\n#endif\n}void main() {vec2 epsilon=1.0/u_dimension;float a=getElevation(v_pos+vec2(-epsilon.x,-epsilon.y));float b=getElevation(v_pos+vec2(0,-epsilon.y));float c=getElevation(v_pos+vec2(epsilon.x,-epsilon.y));float d=getElevation(v_pos+vec2(-epsilon.x,0));float e=getElevation(v_pos+vec2(epsilon.x,0));float f=getElevation(v_pos+vec2(-epsilon.x,epsilon.y));float g=getElevation(v_pos+vec2(0,epsilon.y));float h=getElevation(v_pos+vec2(epsilon.x,epsilon.y));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(\n(c+e+e+h)-(a+d+d+f),(f+g+g+h)-(a+b+b+c)\n)/pow(2.0,exaggeration+(19.2562-u_zoom));gl_FragColor=clamp(vec4(\nderiv.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: di("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;void 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 LIGHTING_3D_MODE\ngl_FragColor=apply_lighting(gl_FragColor);\n#endif\n#ifdef FOG\ngl_FragColor=fog_dither(fog_apply_premultiplied(gl_FragColor,v_fog_pos));\n#endif\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;\n#ifdef FOG\nv_fog_pos=fog_position(a_pos);\n#endif\n}"), line: di("uniform lowp float u_device_pixel_ratio;uniform float u_alpha_discard_threshold;uniform highp vec2 u_trim_offset;varying vec2 v_width2;varying vec2 v_normal;varying float v_gamma_scale;varying highp vec4 v_uv;\n#ifdef RENDER_LINE_DASH\nuniform sampler2D u_dash_image;varying vec2 v_tex;\n#endif\n#ifdef RENDER_LINE_GRADIENT\nuniform sampler2D u_gradient_image;\n#endif\nuniform float u_border_width;uniform vec4 u_border_color;float luminance(vec3 c) {return (c.r+c.r+c.b+c.g+c.g+c.g)*0.1667;}\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float floorwidth\n#pragma mapbox: define lowp vec4 dash\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\nfloat linearstep(float edge0,float edge1,float x) {return clamp((x-edge0)/(edge1-edge0),0.0,1.0);}void main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float floorwidth\n#pragma mapbox: initialize lowp vec4 dash\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);\n#ifdef RENDER_LINE_DASH\nfloat sdfdist=texture2D(u_dash_image,v_tex).a;float sdfgamma=1.0/(2.0*u_device_pixel_ratio)/dash.z;alpha*=linearstep(0.5-sdfgamma/floorwidth,0.5+sdfgamma/floorwidth,sdfdist);\n#endif\nhighp vec4 out_color;\n#ifdef RENDER_LINE_GRADIENT\nout_color=texture2D(u_gradient_image,v_uv.xy);\n#else\nout_color=color;\n#endif\nfloat trimmed=1.0;\n#ifdef RENDER_LINE_TRIM_OFFSET\nhighp float start=v_uv[2];highp float end=v_uv[3];highp float trim_start=u_trim_offset[0];highp float trim_end=u_trim_offset[1];highp float line_progress=(start+(v_uv.x)*(end-start));if (trim_end > trim_start) {if (line_progress <=trim_end && line_progress >=trim_start) {out_color=vec4(0,0,0,0);trimmed=0.0;}}\n#endif\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting(out_color);\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\n#ifdef RENDER_LINE_ALPHA_DISCARD\nif (alpha < u_alpha_discard_threshold) {discard;}\n#endif\n#ifdef RENDER_LINE_BORDER\nfloat edgeBlur=(u_border_width+1.0/u_device_pixel_ratio);float alpha2=clamp(min(dist-(v_width2.t-edgeBlur),v_width2.s-dist)/edgeBlur,0.0,1.0);if (alpha2 < 1.) {float smoothAlpha=smoothstep(0.6,1.0,alpha2);\n#ifdef RENDER_LINE_BORDER_AUTO\nfloat Y=(out_color.a > 0.01) ? luminance(out_color.rgb/out_color.a) : 1.;float adjustment=(Y > 0.) ? 0.5/Y : 0.45;if (out_color.a > 0.25 && Y < 0.25) {vec3 borderColor=(Y > 0.) ? out_color.rgb : vec3(1,1,1)*out_color.a;out_color.rgb=out_color.rgb+borderColor*(adjustment*(1.0-smoothAlpha));} else {out_color.rgb*=(0.6 +0.4*smoothAlpha);}\n#else\nout_color.rgb=mix(u_border_color.rgb*u_border_color.a*trimmed,out_color.rgb,smoothAlpha);\n#endif\n}\n#endif\ngl_FragColor=out_color*(alpha*opacity);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "\n#define EXTRUDE_SCALE 0.015873016\nattribute vec2 a_pos_normal;attribute vec4 a_data;\n#if defined(RENDER_LINE_GRADIENT) || defined(RENDER_LINE_TRIM_OFFSET)\nattribute highp vec4 a_packed;\n#endif\n#ifdef RENDER_LINE_DASH\nattribute float a_linesofar;\n#endif\nuniform mat4 u_matrix;uniform mat2 u_pixels_to_tile_units;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 vec4 v_uv;\n#ifdef RENDER_LINE_DASH\nuniform vec2 u_texsize;uniform float u_tile_units_to_pixels;varying vec2 v_tex;\n#endif\n#ifdef RENDER_LINE_GRADIENT\nuniform float u_image_height;\n#endif\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float floorwidth\n#pragma mapbox: define lowp vec4 dash\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 floorwidth\n#pragma mapbox: initialize lowp vec4 dash\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;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*EXTRUDE_SCALE;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*EXTRUDE_SCALE*normal.y*mat2(t,-u,u,t);vec4 projected_extrude=u_matrix*vec4(dist*u_pixels_to_tile_units,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2*u_pixels_to_tile_units,0.0,1.0)+projected_extrude;\n#ifndef RENDER_TO_TEXTURE\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#else\nv_gamma_scale=1.0;\n#endif\n#if defined(RENDER_LINE_GRADIENT) || defined(RENDER_LINE_TRIM_OFFSET)\nfloat a_uv_x=a_packed[0];float a_split_index=a_packed[1];highp float a_clip_start=a_packed[2];highp float a_clip_end=a_packed[3];\n#ifdef RENDER_LINE_GRADIENT\nhighp float texel_height=1.0/u_image_height;highp float half_texel_height=0.5*texel_height;v_uv=vec4(a_uv_x,a_split_index*texel_height-half_texel_height,a_clip_start,a_clip_end);\n#else\nv_uv=vec4(a_uv_x,0.0,a_clip_start,a_clip_end);\n#endif\n#endif\n#ifdef RENDER_LINE_DASH\nfloat scale=dash.z==0.0 ? 0.0 : u_tile_units_to_pixels/dash.z;float height=dash.y;v_tex=vec2(a_linesofar*scale/floorwidth,(-normal.y*height+dash.x+0.5)/u_texsize.y);\n#endif\nv_width2=vec2(outset,inset);\n#ifdef FOG\nv_fog_pos=fog_position(pos);\n#endif\n}"), linePattern: di("uniform lowp float u_device_pixel_ratio;uniform vec2 u_texsize;uniform float u_tile_units_to_pixels;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\n#pragma mapbox: define lowp float pixel_ratio\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize mediump vec4 pattern\n#pragma mapbox: initialize lowp float pixel_ratio\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\nvec2 pattern_tl=pattern.xy;vec2 pattern_br=pattern.zw;vec2 display_size=(pattern_br-pattern_tl)/pixel_ratio;vec2 pattern_size=vec2(display_size.x/u_tile_units_to_pixels,display_size.y);float aspect=display_size.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=mod(v_linesofar/pattern_size.x*aspect,1.0);float y=0.5*v_normal.y+0.5;vec2 texel_size=1.0/u_texsize;vec2 pos=mix(pattern_tl*texel_size-texel_size,pattern_br*texel_size+texel_size,vec2(x,y));vec4 color=texture2D(u_image,pos);\n#ifdef LIGHTING_3D_MODE\ncolor=apply_lighting(color);\n#endif\n#ifdef FOG\ncolor=fog_dither(fog_apply_premultiplied(color,v_fog_pos));\n#endif\ngl_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_linesofar;uniform mat4 u_matrix;uniform vec2 u_units_to_pixels;uniform mat2 u_pixels_to_tile_units;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\n#pragma mapbox: define lowp float pixel_ratio\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\n#pragma mapbox: initialize lowp float pixel_ratio\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;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_pixels_to_tile_units,0.0,0.0);gl_Position=u_matrix*vec4(pos+offset2*u_pixels_to_tile_units,0.0,1.0)+projected_extrude;\n#ifndef RENDER_TO_TEXTURE\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#else\nv_gamma_scale=1.0;\n#endif\nv_linesofar=a_linesofar;v_width2=vec2(outset,inset);v_width=floorwidth;\n#ifdef FOG\nv_fog_pos=fog_position(pos);\n#endif\n}"), raster: di("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(\ndot(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);vec3 out_color=mix(u_high_vec,u_low_vec,rgb);\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting(out_color);\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply(out_color,v_fog_pos));\n#endif\ngl_FragColor=vec4(out_color*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 vec2 u_perspective_transform;attribute vec2 a_pos;attribute vec2 a_texture_pos;varying vec2 v_pos0;varying vec2 v_pos1;void main() {float w=1.0+dot(a_texture_pos,u_perspective_transform);gl_Position=u_matrix*vec4(a_pos*w,0,w);v_pos0=a_texture_pos/8192.0;v_pos1=(v_pos0*u_scale_parent)+u_tl_parent;\n#ifdef FOG\nv_fog_pos=fog_position(a_pos);\n#endif\n}"), symbolIcon: di("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}", "attribute vec4 a_pos_offset;attribute vec4 a_tex_size;attribute vec4 a_pixeloffset;attribute vec4 a_projected_pos;attribute float a_fade_opacity;\n#ifdef PROJECTION_GLOBE_VIEW\nattribute vec3 a_globe_anchor;attribute vec3 a_globe_normal;\n#endif\nuniform 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 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;uniform vec3 u_up_vector;\n#ifdef PROJECTION_GLOBE_VIEW\nuniform vec3 u_tile_id;uniform mat4 u_inv_rot_matrix;uniform vec2 u_merc_center;uniform vec3 u_camera_forward;uniform float u_zoom_transition;uniform vec3 u_ecef_origin;uniform mat4 u_tile_matrix;\n#endif\nvarying 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_tex_size.xy;vec2 a_size=a_tex_size.zw;float a_size_min=floor(a_size[0]*0.5);vec2 a_pxoffset=a_pixeloffset.xy;vec2 a_min_font_scale=a_pixeloffset.zw/256.0;highp float segment_angle=-a_projected_pos[3];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;}vec2 tile_anchor=a_pos;vec3 h=elevationVector(tile_anchor)*elevation(tile_anchor);float globe_occlusion_fade;vec3 world_pos;vec3 mercator_pos;\n#ifdef PROJECTION_GLOBE_VIEW\nmercator_pos=mercator_tile_position(u_inv_rot_matrix,tile_anchor,u_tile_id,u_merc_center);world_pos=mix_globe_mercator(a_globe_anchor+h,mercator_pos,u_zoom_transition);vec4 ecef_point=u_tile_matrix*vec4(world_pos,1.0);vec3 origin_to_point=ecef_point.xyz-u_ecef_origin;globe_occlusion_fade=dot(origin_to_point,u_camera_forward) >=0.0 ? 0.0 : 1.0;\n#else\nworld_pos=vec3(tile_anchor,0)+h;globe_occlusion_fade=1.0;\n#endif\nvec4 projected_point=u_matrix*vec4(world_pos,1);highp float camera_to_anchor_distance=projected_point.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(\n0.5+0.5*distance_ratio,0.0,1.5);size*=perspective_ratio;float font_scale=u_is_text ? size/24.0 : size;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offsetProjected_point;\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 displacement=vec3(a_globe_normal.z,0,-a_globe_normal.x);offsetProjected_point=u_matrix*vec4(a_globe_anchor+displacement,1);\n#else\noffsetProjected_point=u_matrix*vec4(tile_anchor+vec2(1,0),0,1);\n#endif\nvec2 a=projected_point.xy/projected_point.w;vec2 b=offsetProjected_point.xy/offsetProjected_point.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}vec4 projected_pos;\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 proj_pos=mix_globe_mercator(a_projected_pos.xyz+h,mercator_pos,u_zoom_transition);projected_pos=u_label_plane_matrix*vec4(proj_pos,1.0);\n#else\nprojected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy,h.z,1.0);\n#endif\nhighp 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);float z=0.0;vec2 offset=rotation_matrix*(a_offset/32.0*max(a_min_font_scale,font_scale)+a_pxoffset/16.0);\n#ifdef TERRAIN\n#ifdef PITCH_WITH_MAP_TERRAIN\nvec4 tile_pos=u_label_plane_matrix_inv*vec4(a_projected_pos.xy+offset,0.0,1.0);z=elevation(tile_pos.xy);\n#endif\n#endif\nfloat occlusion_fade=occlusionFade(projected_point)*globe_occlusion_fade;\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 xAxis=u_pitch_with_map ? normalize(cross(a_globe_normal,u_up_vector)) : vec3(1,0,0);vec3 yAxis=u_pitch_with_map ? normalize(cross(a_globe_normal,xAxis)) : vec3(0,1,0);gl_Position=mix(u_coord_matrix*vec4(projected_pos.xyz/projected_pos.w+xAxis*offset.x+yAxis*offset.y,1.0),AWAY,float(projected_point.w <=0.0 || occlusion_fade==0.0));\n#else\ngl_Position=mix(u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+offset,z,1.0),AWAY,float(projected_point.w <=0.0 || occlusion_fade==0.0));\n#endif\nfloat projection_transition_fade=1.0;\n#if defined(PROJECTED_POS_ON_VIEWPORT) && defined(PROJECTION_GLOBE_VIEW)\nprojection_transition_fade=1.0-step(EPSILON,u_zoom_transition);\n#endif\nv_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;v_fade_opacity=max(0.0,min(occlusion_fade,fade_opacity[0]+fade_change))*projection_transition_fade;}"), symbolSDF: di("#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 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}", "attribute vec4 a_pos_offset;attribute vec4 a_tex_size;attribute vec4 a_pixeloffset;attribute vec4 a_projected_pos;attribute float a_fade_opacity;\n#ifdef PROJECTION_GLOBE_VIEW\nattribute vec3 a_globe_anchor;attribute vec3 a_globe_normal;\n#endif\nuniform 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 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 vec3 u_up_vector;\n#ifdef PROJECTION_GLOBE_VIEW\nuniform vec3 u_tile_id;uniform mat4 u_inv_rot_matrix;uniform vec2 u_merc_center;uniform vec3 u_camera_forward;uniform float u_zoom_transition;uniform vec3 u_ecef_origin;uniform mat4 u_tile_matrix;\n#endif\nvarying 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_tex_size.xy;vec2 a_size=a_tex_size.zw;float a_size_min=floor(a_size[0]*0.5);vec2 a_pxoffset=a_pixeloffset.xy;highp float segment_angle=-a_projected_pos[3];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;}vec2 tile_anchor=a_pos;vec3 h=elevationVector(tile_anchor)*elevation(tile_anchor);float globe_occlusion_fade;vec3 world_pos;vec3 mercator_pos;\n#ifdef PROJECTION_GLOBE_VIEW\nmercator_pos=mercator_tile_position(u_inv_rot_matrix,tile_anchor,u_tile_id,u_merc_center);world_pos=mix_globe_mercator(a_globe_anchor+h,mercator_pos,u_zoom_transition);vec4 ecef_point=u_tile_matrix*vec4(world_pos,1.0);vec3 origin_to_point=ecef_point.xyz-u_ecef_origin;globe_occlusion_fade=dot(origin_to_point,u_camera_forward) >=0.0 ? 0.0 : 1.0;\n#else\nworld_pos=vec3(tile_anchor,0)+h;globe_occlusion_fade=1.0;\n#endif\nvec4 projected_point=u_matrix*vec4(world_pos,1);highp float camera_to_anchor_distance=projected_point.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(\n0.5+0.5*distance_ratio,0.0,1.5);size*=perspective_ratio;float fontScale=u_is_text ? size/24.0 : size;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offsetprojected_point;\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 displacement=vec3(a_globe_normal.z,0,-a_globe_normal.x);offsetprojected_point=u_matrix*vec4(a_globe_anchor+displacement,1);\n#else\noffsetprojected_point=u_matrix*vec4(tile_anchor+vec2(1,0),0,1);\n#endif\nvec2 a=projected_point.xy/projected_point.w;vec2 b=offsetprojected_point.xy/offsetprojected_point.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}vec4 projected_pos;\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 proj_pos=mix_globe_mercator(a_projected_pos.xyz+h,mercator_pos,u_zoom_transition);projected_pos=u_label_plane_matrix*vec4(proj_pos,1.0);\n#else\nprojected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy,h.z,1.0);\n#endif\nhighp 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);float z=0.0;vec2 offset=rotation_matrix*(a_offset/32.0*fontScale+a_pxoffset);\n#ifdef TERRAIN\n#ifdef PITCH_WITH_MAP_TERRAIN\nvec4 tile_pos=u_label_plane_matrix_inv*vec4(a_projected_pos.xy+offset,0.0,1.0);z=elevation(tile_pos.xy);\n#endif\n#endif\nfloat occlusion_fade=occlusionFade(projected_point)*globe_occlusion_fade;\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 xAxis=u_pitch_with_map ? normalize(cross(a_globe_normal,u_up_vector)) : vec3(1,0,0);vec3 yAxis=u_pitch_with_map ? normalize(cross(a_globe_normal,xAxis)) : vec3(0,1,0);gl_Position=mix(u_coord_matrix*vec4(projected_pos.xyz/projected_pos.w+xAxis*offset.x+yAxis*offset.y,1.0),AWAY,float(projected_point.w <=0.0 || occlusion_fade==0.0));\n#else\ngl_Position=mix(u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+offset,z,1.0),AWAY,float(projected_point.w <=0.0 || occlusion_fade==0.0));\n#endif\nfloat gamma_scale=gl_Position.w;float projection_transition_fade=1.0;\n#if defined(PROJECTED_POS_ON_VIEWPORT) && defined(PROJECTION_GLOBE_VIEW)\nprojection_transition_fade=1.0-step(EPSILON,u_zoom_transition);\n#endif\nvec2 fade_opacity=unpack_opacity(a_fade_opacity);float fade_change=fade_opacity[1] > 0.5 ? u_fade_change :-u_fade_change;float interpolated_fade_opacity=max(0.0,min(occlusion_fade,fade_opacity[0]+fade_change));v_data0=a_tex/u_texsize;v_data1=vec3(gamma_scale,size,interpolated_fade_opacity*projection_transition_fade);}"), symbolTextAndIcon: di("#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}", "attribute vec4 a_pos_offset;attribute vec4 a_tex_size;attribute vec4 a_projected_pos;attribute float a_fade_opacity;\n#ifdef PROJECTION_GLOBE_VIEW\nattribute vec3 a_globe_anchor;attribute vec3 a_globe_normal;\n#endif\nuniform 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 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 vec3 u_up_vector;uniform vec2 u_texsize_icon;\n#ifdef PROJECTION_GLOBE_VIEW\nuniform vec3 u_tile_id;uniform mat4 u_inv_rot_matrix;uniform vec2 u_merc_center;uniform vec3 u_camera_forward;uniform float u_zoom_transition;uniform vec3 u_ecef_origin;uniform mat4 u_tile_matrix;\n#endif\nvarying 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_tex_size.xy;vec2 a_size=a_tex_size.zw;float a_size_min=floor(a_size[0]*0.5);float is_sdf=a_size[0]-2.0*a_size_min;highp float segment_angle=-a_projected_pos[3];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;}vec2 tile_anchor=a_pos;vec3 h=elevationVector(tile_anchor)*elevation(tile_anchor);float globe_occlusion_fade;vec3 world_pos;vec3 mercator_pos;\n#ifdef PROJECTION_GLOBE_VIEW\nmercator_pos=mercator_tile_position(u_inv_rot_matrix,tile_anchor,u_tile_id,u_merc_center);world_pos=mix_globe_mercator(a_globe_anchor+h,mercator_pos,u_zoom_transition);vec4 ecef_point=u_tile_matrix*vec4(world_pos,1.0);vec3 origin_to_point=ecef_point.xyz-u_ecef_origin;globe_occlusion_fade=dot(origin_to_point,u_camera_forward) >=0.0 ? 0.0 : 1.0;\n#else\nworld_pos=vec3(tile_anchor,0)+h;globe_occlusion_fade=1.0;\n#endif\nvec4 projected_point=u_matrix*vec4(world_pos,1);highp float camera_to_anchor_distance=projected_point.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(\n0.5+0.5*distance_ratio,0.0,1.5);size*=perspective_ratio;float font_scale=size/24.0;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offset_projected_point=u_matrix*vec4(a_pos+vec2(1,0),0,1);vec2 a=projected_point.xy/projected_point.w;vec2 b=offset_projected_point.xy/offset_projected_point.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}vec4 projected_pos;\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 proj_pos=mix_globe_mercator(a_projected_pos.xyz+h,mercator_pos,u_zoom_transition);projected_pos=u_label_plane_matrix*vec4(proj_pos,1.0);\n#else\nprojected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy,h.z,1.0);\n#endif\nhighp 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);float z=0.0;vec2 offset=rotation_matrix*(a_offset/32.0*font_scale);\n#ifdef TERRAIN\n#ifdef PITCH_WITH_MAP_TERRAIN\nvec4 tile_pos=u_label_plane_matrix_inv*vec4(a_projected_pos.xy+offset,0.0,1.0);z=elevation(tile_pos.xy);\n#endif\n#endif\nfloat occlusion_fade=occlusionFade(projected_point)*globe_occlusion_fade;\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 xAxis=u_pitch_with_map ? normalize(cross(a_globe_normal,u_up_vector)) : vec3(1,0,0);vec3 yAxis=u_pitch_with_map ? normalize(cross(a_globe_normal,xAxis)) : vec3(0,1,0);gl_Position=mix(u_coord_matrix*vec4(projected_pos.xyz/projected_pos.w+xAxis*offset.x+yAxis*offset.y,1.0),AWAY,float(projected_point.w <=0.0 || occlusion_fade==0.0));\n#else\ngl_Position=mix(u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+offset,z,1.0),AWAY,float(projected_point.w <=0.0 || occlusion_fade==0.0));\n#endif\nfloat gamma_scale=gl_Position.w;vec2 fade_opacity=unpack_opacity(a_fade_opacity);float fade_change=fade_opacity[1] > 0.5 ? u_fade_change :-u_fade_change;float interpolated_fade_opacity=max(0.0,min(occlusion_fade,fade_opacity[0]+fade_change));float projection_transition_fade=1.0;\n#if defined(PROJECTED_POS_ON_VIEWPORT) && defined(PROJECTION_GLOBE_VIEW)\nprojection_transition_fade=1.0-step(EPSILON,u_zoom_transition);\n#endif\nv_data0.xy=a_tex/u_texsize;v_data0.zw=a_tex/u_texsize_icon;v_data1=vec4(gamma_scale,size,interpolated_fade_opacity*projection_transition_fade,is_sdf);}"), terrainRaster: di("uniform sampler2D u_image0;varying vec2 v_pos0;\n#ifdef FOG\nvarying float v_fog_opacity;\n#endif\n#ifdef RENDER_SHADOWS\nvarying vec4 v_pos_light_view_0;varying vec4 v_pos_light_view_1;varying float v_depth;\n#endif\nvoid main() {vec4 color=texture2D(u_image0,v_pos0);\n#ifdef RENDER_SHADOWS\ncolor.xyz=shadowed_color(color.xyz,v_pos_light_view_0,v_pos_light_view_1,v_depth);\n#endif\n#ifdef FOG\n#ifdef ZERO_EXAGGERATION\ncolor=fog_dither(fog_apply_premultiplied(color,v_fog_pos));\n#else\ncolor=fog_dither(fog_apply_from_vert(color,v_fog_opacity));\n#endif\n#endif\ngl_FragColor=color;\n#ifdef TERRAIN_WIREFRAME\ngl_FragColor=vec4(1.0,0.0,0.0,0.8);\n#endif\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "uniform mat4 u_matrix;uniform float u_skirt_height;attribute vec2 a_pos;varying vec2 v_pos0;\n#ifdef FOG\nvarying float v_fog_opacity;\n#endif\n#ifdef RENDER_SHADOWS\nuniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;varying vec4 v_pos_light_view_0;varying vec4 v_pos_light_view_1;varying float v_depth;\n#endif\nconst float wireframeOffset=0.00015;void main() {vec3 decomposedPosAndSkirt=decomposeToPosAndSkirt(a_pos);float skirt=decomposedPosAndSkirt.z;vec2 decodedPos=decomposedPosAndSkirt.xy;float elevation=elevation(decodedPos)-skirt*u_skirt_height;\n#ifdef TERRAIN_WIREFRAME\nelevation+=wireframeOffset;\n#endif\nv_pos0=decodedPos/8192.0;gl_Position=u_matrix*vec4(decodedPos,elevation,1.0);\n#ifdef FOG\n#ifdef ZERO_EXAGGERATION\nv_fog_pos=fog_position(decodedPos);\n#else\nv_fog_opacity=fog(fog_position(vec3(decodedPos,elevation)));\n#endif\n#endif\n#ifdef RENDER_SHADOWS\nvec3 pos=vec3(decodedPos,elevation);v_pos_light_view_0=u_light_matrix_0*vec4(pos,1.);v_pos_light_view_1=u_light_matrix_1*vec4(pos,1.);v_depth=gl_Position.w;\n#endif\n}"), terrainDepth: di("#ifdef GL_ES\nprecision highp float;\n#endif\nvarying float v_depth;void main() {gl_FragColor=pack_depth(v_depth);}", "uniform mat4 u_matrix;attribute vec2 a_pos;varying float v_depth;void main() {float elevation=elevation(a_pos);gl_Position=u_matrix*vec4(a_pos,elevation,1.0);v_depth=gl_Position.z/gl_Position.w;}"), skybox: di("\nvarying lowp vec3 v_uv;uniform lowp samplerCube u_cubemap;uniform lowp float u_opacity;uniform highp float u_temporal_offset;uniform highp vec3 u_sun_direction;float sun_disk(highp vec3 ray_direction,highp vec3 sun_direction) {highp float cos_angle=dot(normalize(ray_direction),sun_direction);const highp float cos_sun_angular_diameter=0.99996192306;const highp float smoothstep_delta=1e-5;return smoothstep(\ncos_sun_angular_diameter-smoothstep_delta,cos_sun_angular_diameter+smoothstep_delta,cos_angle);}float map(float value,float start,float end,float new_start,float new_end) {return ((value-start)*(new_end-new_start))/(end-start)+new_start;}void main() {vec3 uv=v_uv;const float y_bias=0.015;uv.y+=y_bias;uv.y=pow(abs(uv.y),1.0/5.0);uv.y=map(uv.y,0.0,1.0,-1.0,1.0);vec3 sky_color=textureCube(u_cubemap,uv).rgb;\n#ifdef FOG\nsky_color=fog_apply_sky_gradient(v_uv.xzy,sky_color);\n#endif\nsky_color.rgb=dither(sky_color.rgb,gl_FragCoord.xy+u_temporal_offset);sky_color+=0.1*sun_disk(v_uv,u_sun_direction);gl_FragColor=vec4(sky_color*u_opacity,u_opacity);\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", ti), skyboxGradient: di("varying highp vec3 v_uv;uniform lowp sampler2D u_color_ramp;uniform highp vec3 u_center_direction;uniform lowp float u_radius;uniform lowp float u_opacity;uniform highp float u_temporal_offset;void main() {float progress=acos(dot(normalize(v_uv),u_center_direction))/u_radius;vec4 color=texture2D(u_color_ramp,vec2(progress,0.5));\n#ifdef FOG\ncolor.rgb=fog_apply_sky_gradient(v_uv.xzy,color.rgb/color.a)*color.a;\n#endif\ncolor*=u_opacity;color.rgb=dither(color.rgb,gl_FragCoord.xy+u_temporal_offset);gl_FragColor=color;\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", ti), skyboxCapture: di("\nvarying highp vec3 v_position;uniform highp float u_sun_intensity;uniform highp float u_luminance;uniform lowp vec3 u_sun_direction;uniform highp vec4 u_color_tint_r;uniform highp vec4 u_color_tint_m;\n#ifdef GL_ES\nprecision highp float;\n#endif\n#define BETA_R vec3(5.5e-6,13.0e-6,22.4e-6)\n#define BETA_M vec3(21e-6,21e-6,21e-6)\n#define MIE_G 0.76\n#define DENSITY_HEIGHT_SCALE_R 8000.0\n#define DENSITY_HEIGHT_SCALE_M 1200.0\n#define PLANET_RADIUS 6360e3\n#define ATMOSPHERE_RADIUS 6420e3\n#define SAMPLE_STEPS 10\n#define DENSITY_STEPS 4\nfloat ray_sphere_exit(vec3 orig,vec3 dir,float radius) {float a=dot(dir,dir);float b=2.0*dot(dir,orig);float c=dot(orig,orig)-radius*radius;float d=sqrt(b*b-4.0*a*c);return (-b+d)/(2.0*a);}vec3 extinction(vec2 density) {return exp(-vec3(BETA_R*u_color_tint_r.a*density.x+BETA_M*u_color_tint_m.a*density.y));}vec2 local_density(vec3 point) {float height=max(length(point)-PLANET_RADIUS,0.0);float exp_r=exp(-height/DENSITY_HEIGHT_SCALE_R);float exp_m=exp(-height/DENSITY_HEIGHT_SCALE_M);return vec2(exp_r,exp_m);}float phase_ray(float cos_angle) {return (3.0/(16.0*PI))*(1.0+cos_angle*cos_angle);}float phase_mie(float cos_angle) {return (3.0/(8.0*PI))*((1.0-MIE_G*MIE_G)*(1.0+cos_angle*cos_angle))/((2.0+MIE_G*MIE_G)*pow(1.0+MIE_G*MIE_G-2.0*MIE_G*cos_angle,1.5));}vec2 density_to_atmosphere(vec3 point,vec3 light_dir) {float ray_len=ray_sphere_exit(point,light_dir,ATMOSPHERE_RADIUS);float step_len=ray_len/float(DENSITY_STEPS);vec2 density_point_to_atmosphere=vec2(0.0);for (int i=0; i < DENSITY_STEPS;++i) {vec3 point_on_ray=point+light_dir*((float(i)+0.5)*step_len);density_point_to_atmosphere+=local_density(point_on_ray)*step_len;;}return density_point_to_atmosphere;}vec3 atmosphere(vec3 ray_dir,vec3 sun_direction,float sun_intensity) {vec2 density_orig_to_point=vec2(0.0);vec3 scatter_r=vec3(0.0);vec3 scatter_m=vec3(0.0);vec3 origin=vec3(0.0,PLANET_RADIUS,0.0);float ray_len=ray_sphere_exit(origin,ray_dir,ATMOSPHERE_RADIUS);float step_len=ray_len/float(SAMPLE_STEPS);for (int i=0; i < SAMPLE_STEPS;++i) {vec3 point_on_ray=origin+ray_dir*((float(i)+0.5)*step_len);vec2 density=local_density(point_on_ray)*step_len;density_orig_to_point+=density;vec2 density_point_to_atmosphere=density_to_atmosphere(point_on_ray,sun_direction);vec2 density_orig_to_atmosphere=density_orig_to_point+density_point_to_atmosphere;vec3 extinction=extinction(density_orig_to_atmosphere);scatter_r+=density.x*extinction;scatter_m+=density.y*extinction;}float cos_angle=dot(ray_dir,sun_direction);float phase_r=phase_ray(cos_angle);float phase_m=phase_mie(cos_angle);vec3 beta_r=BETA_R*u_color_tint_r.rgb*u_color_tint_r.a;vec3 beta_m=BETA_M*u_color_tint_m.rgb*u_color_tint_m.a;return (scatter_r*phase_r*beta_r+scatter_m*phase_m*beta_m)*sun_intensity;}const float A=0.15;const float B=0.50;const float C=0.10;const float D=0.20;const float E=0.02;const float F=0.30;vec3 uncharted2_tonemap(vec3 x) {return ((x*(A*x+C*B)+D*E)/(x*(A*x+B)+D*F))-E/F;}void main() {vec3 ray_direction=v_position;ray_direction.y=pow(ray_direction.y,5.0);const float y_bias=0.015;ray_direction.y+=y_bias;vec3 color=atmosphere(normalize(ray_direction),u_sun_direction,u_sun_intensity);float white_scale=1.0748724675633854;color=uncharted2_tonemap((log2(2.0/pow(u_luminance,4.0)))*color)*white_scale;gl_FragColor=vec4(color,1.0);}", "attribute highp vec3 a_pos_3f;uniform mat3 u_matrix_3f;varying highp vec3 v_position;float map(float value,float start,float end,float new_start,float new_end) {return ((value-start)*(new_end-new_start))/(end-start)+new_start;}void main() {vec4 pos=vec4(u_matrix_3f*a_pos_3f,1.0);v_position=pos.xyz;v_position.y*=-1.0;v_position.y=map(v_position.y,-1.0,1.0,0.0,1.0);gl_Position=vec4(a_pos_3f.xy,0.0,1.0);}"), globeRaster: di("uniform sampler2D u_image0;varying vec2 v_pos0;\n#ifndef FOG\nuniform highp vec3 u_frustum_tl;uniform highp vec3 u_frustum_tr;uniform highp vec3 u_frustum_br;uniform highp vec3 u_frustum_bl;uniform highp vec3 u_globe_pos;uniform highp float u_globe_radius;uniform vec2 u_viewport;\n#endif\nvoid main() {vec4 color;\n#ifdef CUSTOM_ANTIALIASING\nvec2 uv=gl_FragCoord.xy/u_viewport;highp vec3 ray_dir=mix(\nmix(u_frustum_tl,u_frustum_tr,uv.x),mix(u_frustum_bl,u_frustum_br,uv.x),1.0-uv.y);vec3 dir=normalize(ray_dir);vec3 closest_point=dot(u_globe_pos,dir)*dir;float norm_dist_from_center=1.0-length(closest_point-u_globe_pos)/u_globe_radius;const float antialias_pixel=2.0;float antialias_factor=antialias_pixel*fwidth(norm_dist_from_center);float antialias=smoothstep(0.0,antialias_factor,norm_dist_from_center);vec4 raster=texture2D(u_image0,v_pos0);color=vec4(raster.rgb*antialias,raster.a*antialias);\n#else\ncolor=texture2D(u_image0,v_pos0);\n#endif\n#ifdef FOG\ncolor=fog_dither(fog_apply_premultiplied(color,v_fog_pos));\n#endif\ngl_FragColor=color;\n#ifdef TERRAIN_WIREFRAME\ngl_FragColor=vec4(1.0,0.0,0.0,0.8);\n#endif\n#ifdef OVERDRAW_INSPECTOR\ngl_FragColor=vec4(1.0);\n#endif\n}", "uniform mat4 u_proj_matrix;uniform mat4 u_normalize_matrix;uniform mat4 u_globe_matrix;uniform mat4 u_merc_matrix;uniform float u_zoom_transition;uniform vec2 u_merc_center;uniform mat3 u_grid_matrix;uniform float u_skirt_height;\n#ifdef GLOBE_POLES\nattribute vec3 a_globe_pos;attribute vec2 a_uv;\n#else\nattribute vec2 a_pos;\n#endif\nvarying vec2 v_pos0;const float wireframeOffset=1e3;float mercatorXfromLng(float lng) {return (180.0+lng)/360.0;}float mercatorYfromLat(float lat) {return (180.0-(RAD_TO_DEG*log(tan(QUARTER_PI+lat/2.0*DEG_TO_RAD))))/360.0;}vec3 latLngToECEF(vec2 latLng) {latLng=DEG_TO_RAD*latLng;float cosLat=cos(latLng[0]);float sinLat=sin(latLng[0]);float cosLng=cos(latLng[1]);float sinLng=sin(latLng[1]);float sx=cosLat*sinLng*GLOBE_RADIUS;float sy=-sinLat*GLOBE_RADIUS;float sz=cosLat*cosLng*GLOBE_RADIUS;return vec3(sx,sy,sz);}void main() {\n#ifdef GLOBE_POLES\nvec3 globe_pos=a_globe_pos;vec2 uv=a_uv;\n#else\nfloat tiles=u_grid_matrix[0][2];float idx=u_grid_matrix[1][2];float idy=u_grid_matrix[2][2];vec3 decomposed_pos_and_skirt=decomposeToPosAndSkirt(a_pos);vec3 latLng=u_grid_matrix*vec3(decomposed_pos_and_skirt.xy,1.0);float mercatorY=mercatorYfromLat(latLng[0]);float uvY=mercatorY*tiles-idy;float mercatorX=mercatorXfromLng(latLng[1]);float uvX=mercatorX*tiles-idx;vec3 globe_pos=latLngToECEF(latLng.xy);vec2 merc_pos=vec2(mercatorX,mercatorY);vec2 uv=vec2(uvX,uvY);\n#endif\nv_pos0=uv;vec2 tile_pos=uv*EXTENT;vec3 globe_derived_up_vector=normalize(globe_pos)*u_tile_up_scale;\n#ifdef GLOBE_POLES\nvec3 up_vector=globe_derived_up_vector;\n#else\nvec3 up_vector=elevationVector(tile_pos);\n#endif\nfloat height=elevation(tile_pos);\n#ifdef TERRAIN_WIREFRAME\nheight+=wireframeOffset;\n#endif\nglobe_pos+=up_vector*height;\n#ifndef GLOBE_POLES\nglobe_pos-=globe_derived_up_vector*u_skirt_height*decomposed_pos_and_skirt.z;\n#endif\n#ifdef GLOBE_POLES\nvec4 interpolated_pos=u_globe_matrix*vec4(globe_pos,1.0);\n#else\nvec4 globe_world_pos=u_globe_matrix*vec4(globe_pos,1.0);vec4 merc_world_pos=vec4(0.0);if (u_zoom_transition > 0.0) {merc_world_pos=vec4(merc_pos,height-u_skirt_height*decomposed_pos_and_skirt.z,1.0);merc_world_pos.xy-=u_merc_center;merc_world_pos.x=wrap(merc_world_pos.x,-0.5,0.5);merc_world_pos=u_merc_matrix*merc_world_pos;}vec4 interpolated_pos=vec4(mix(globe_world_pos.xyz,merc_world_pos.xyz,u_zoom_transition),1.0);\n#endif\ngl_Position=u_proj_matrix*interpolated_pos;\n#ifdef FOG\nv_fog_pos=fog_position((u_normalize_matrix*vec4(globe_pos,1.0)).xyz);\n#endif\n}"), globeAtmosphere: di("uniform float u_transition;uniform highp float u_fadeout_range;uniform highp float u_temporal_offset;uniform vec3 u_start_color;uniform vec4 u_color;uniform vec4 u_space_color;uniform vec4 u_high_color;uniform float u_star_intensity;uniform float u_star_size;uniform float u_star_density;uniform float u_horizon_angle;uniform mat4 u_rotation_matrix;varying highp vec3 v_ray_dir;varying highp vec3 v_horizon_dir;highp float random(highp vec3 p) {p=fract(p*vec3(23.2342,97.1231,91.2342));p+=dot(p.zxy,p.yxz+123.1234);return fract(p.x*p.y);}float stars(vec3 p,float scale,vec2 offset) {vec2 uv_scale=(u_viewport/u_star_size)*scale;vec3 position=vec3(p.xy*uv_scale+offset*u_viewport,p.z);vec3 q=fract(position)-0.5;vec3 id=floor(position);float random_visibility=step(random(id),u_star_density);float circle=smoothstep(0.5+u_star_intensity,0.5,length(q));return circle*random_visibility;}void main() {highp vec3 dir=normalize(v_ray_dir);float globe_pos_dot_dir;\n#ifdef PROJECTION_GLOBE_VIEW\nglobe_pos_dot_dir=dot(u_globe_pos,dir);highp vec3 closest_point_forward=abs(globe_pos_dot_dir)*dir;float norm_dist_from_center=length(closest_point_forward-u_globe_pos)/u_globe_radius;if (norm_dist_from_center < 0.98) {discard;return;}\n#endif\nhighp vec3 horizon_dir=normalize(v_horizon_dir);float horizon_angle_mercator=dir.y < horizon_dir.y ?\n0.0 : max(acos(dot(dir,horizon_dir)),0.0);float horizon_angle;\n#ifdef PROJECTION_GLOBE_VIEW\nhighp vec3 closest_point=globe_pos_dot_dir*dir;float closest_point_to_center=length(closest_point-u_globe_pos);float theta=asin(clamp(closest_point_to_center/length(u_globe_pos),-1.0,1.0));horizon_angle=globe_pos_dot_dir < 0.0 ?\nPI-theta-u_horizon_angle : theta-u_horizon_angle;float angle_t=pow(u_transition,10.0);horizon_angle=mix(horizon_angle,horizon_angle_mercator,angle_t);\n#else\nhorizon_angle=horizon_angle_mercator;\n#endif\nhorizon_angle/=PI;float t=exp(-horizon_angle/u_fadeout_range);float alpha_0=u_color.a;float alpha_1=u_high_color.a;float alpha_2=u_space_color.a;vec3 color_stop_0=u_color.rgb;vec3 color_stop_1=u_high_color.rgb;vec3 color_stop_2=u_space_color.rgb;vec3 c0=mix(color_stop_2,color_stop_1,alpha_1);vec3 c1=mix(c0,color_stop_0,alpha_0);vec3 c2=mix(c0,c1,t);vec3 c =mix(color_stop_2,c2,t);float a0=mix(alpha_2,1.0,alpha_1);float a1=mix(a0,1.0,alpha_0);float a2=mix(a0,a1,t);float a =mix(alpha_2,a2,t);vec2 uv=gl_FragCoord.xy/u_viewport-0.5;float aspect_ratio=u_viewport.x/u_viewport.y;vec4 uv_dir=vec4(normalize(vec3(uv.x*aspect_ratio,uv.y,1.0)),1.0);uv_dir=u_rotation_matrix*uv_dir;vec3 n=abs(uv_dir.xyz);vec2 uv_remap=(n.x > n.y && n.x > n.z) ? uv_dir.yz/uv_dir.x:\n(n.y > n.x && n.y > n.z) ? uv_dir.zx/uv_dir.y:\nuv_dir.xy/uv_dir.z;uv_remap.x/=aspect_ratio;vec3 D=vec3(uv_remap,1.0);highp float star_field=0.0;if (u_star_intensity > 0.0) {star_field+=stars(D,1.2,vec2(0.0,0.0));star_field+=stars(D,1.0,vec2(1.0,0.0));star_field+=stars(D,0.8,vec2(0.0,1.0));star_field+=stars(D,0.6,vec2(1.0,1.0));star_field*=(1.0-pow(t,0.25+(1.0-u_high_color.a)*0.75));c+=star_field*alpha_2;}c=dither(c,gl_FragCoord.xy+u_temporal_offset);gl_FragColor=vec4(c,a);}", "attribute vec3 a_pos;attribute vec2 a_uv;uniform vec3 u_frustum_tl;uniform vec3 u_frustum_tr;uniform vec3 u_frustum_br;uniform vec3 u_frustum_bl;uniform float u_horizon;varying highp vec3 v_ray_dir;varying highp vec3 v_horizon_dir;void main() {v_ray_dir=mix(\nmix(u_frustum_tl,u_frustum_tr,a_uv.x),mix(u_frustum_bl,u_frustum_br,a_uv.x),a_uv.y);v_horizon_dir=mix(\nmix(u_frustum_tl,u_frustum_bl,u_horizon),mix(u_frustum_tr,u_frustum_br,u_horizon),a_uv.x);gl_Position=vec4(a_pos,1.0);}") }; function _i(e, t) { const i = e.replace(/\s*\/\/[^\n]*\n/g, "\n").split("\n"); for (let e of i) if (e = e.trim(), "#" === e[0] && e.includes("if") && !e.includes("endif")) { e = e.replace("#", "").replace(/ifdef|ifndef|elif|if/g, "").replace(/!|defined|\(|\)|\|\||&&/g, "").replace(/\s+/g, " ").trim(); const i = e.split(" "); for (const e of i) t.includes(e) || t.push(e); } } function di(e, t) { const i = /#pragma mapbox: ([\w]+) ([\w]+) ([\w]+) ([\w]+)/g, o = t.match(/attribute (highp |mediump |lowp )?([\w]+) ([\w]+)/g), r = {}, n = [...ai]; return _i(e, n), _i(t, n), { fragmentSource: e = e.replace(i, ((e, t, i, o, n) => (r[n] = !0, "define" === t ? `\n#ifndef HAS_UNIFORM_u_${n}\nvarying ${i} ${o} ${n};\n#else\nuniform ${i} ${o} u_${n};\n#endif\n` : `\n#ifdef HAS_UNIFORM_u_${n}\n ${i} ${o} ${n} = u_${n};\n#endif\n`))), vertexSource: t = t.replace(i, ((e, t, i, o, n) => { const s = "float" === o ? "vec2" : "vec4", a = n.match(/color/) ? "color" : s; return r[n] ? "define" === t ? `\n#ifndef HAS_UNIFORM_u_${n}\nuniform lowp float u_${n}_t;\nattribute ${i} ${s} a_${n};\nvarying ${i} ${o} ${n};\n#else\nuniform ${i} ${o} u_${n};\n#endif\n` : "vec4" === a ? `\n#ifndef HAS_UNIFORM_u_${n}\n ${n} = a_${n};\n#else\n ${i} ${o} ${n} = u_${n};\n#endif\n` : `\n#ifndef HAS_UNIFORM_u_${n}\n ${n} = unpack_mix_${a}(a_${n}, u_${n}_t);\n#else\n ${i} ${o} ${n} = u_${n};\n#endif\n` : "define" === t ? `\n#ifndef HAS_UNIFORM_u_${n}\nuniform lowp float u_${n}_t;\nattribute ${i} ${s} a_${n};\n#else\nuniform ${i} ${o} u_${n};\n#endif\n` : "vec4" === a ? `\n#ifndef HAS_UNIFORM_u_${n}\n ${i} ${o} ${n} = a_${n};\n#else\n ${i} ${o} ${n} = u_${n};\n#endif\n` : `\n#ifndef HAS_UNIFORM_u_${n}\n ${i} ${o} ${n} = unpack_mix_${a}(a_${n}, u_${n}_t);\n#else\n ${i} ${o} ${n} = u_${n};\n#endif\n` })), staticAttributes: o, usedDefines: n } } class pi { constructor() { this.boundProgram = null, this.boundLayoutVertexBuffer = null, this.boundPaintVertexBuffers = [], this.boundIndexBuffer = null, this.boundVertexOffset = null, this.boundDynamicVertexBuffers = [], this.vao = null; } bind(e, t, i, o, r, n, s) { this.context = e; let a = this.boundPaintVertexBuffers.length !== o.length; for (let e = 0; !a && e < o.length; e++) this.boundPaintVertexBuffers[e] !== o[e] && (a = !0); let l = this.boundDynamicVertexBuffers.length !== s.length; for (let e = 0; !l && e < s.length; e++) this.boundDynamicVertexBuffers[e] !== s[e] && (l = !0); if (!e.extVertexArrayObject || !this.vao || this.boundProgram !== t || this.boundLayoutVertexBuffer !== i || a || l || this.boundIndexBuffer !== r || this.boundVertexOffset !== n) this.freshBind(t, i, o, r, n, s); else { e.bindVertexArrayOES.set(this.vao); for (const e of s) e && e.bind(); r && r.dynamicDraw && r.bind(); } } freshBind(e, t, i, o, r, n) { let s; const a = e.numAttributes, l = this.context, c = l.gl; if (l.extVertexArrayObject) this.vao && this.destroy(), this.vao = l.extVertexArrayObject.createVertexArrayOES(), l.bindVertexArrayOES.set(this.vao), s = 0, this.boundProgram = e, this.boundLayoutVertexBuffer = t, this.boundPaintVertexBuffers = i, this.boundIndexBuffer = o, this.boundVertexOffset = r, this.boundDynamicVertexBuffers = n; else { s = l.currentNumAttributes || 0; for (let e = a; e < s; e++) c.disableVertexAttribArray(e); } t.enableAttributes(c, e), t.bind(), t.setVertexAttribPointers(c, e, r); for (const t of i) t.enableAttributes(c, e), t.bind(), t.setVertexAttribPointers(c, e, r); for (const t of n) t && (t.enableAttributes(c, e), t.bind(), t.setVertexAttribPointers(c, e, r)); o && o.bind(), l.currentNumAttributes = a; } destroy() { this.vao && (this.context.extVertexArrayObject.deleteVertexArrayOES(this.vao), this.vao = null); } } function mi(t, i) { const o = Math.pow(2, i.canonical.z), r = i.canonical.y; return [new e.MercatorCoordinate(0, r / o).toLngLat().lat, new e.MercatorCoordinate(0, (r + 1) / o).toLngLat().lat] } function fi(t, i, o, r, n, s, a) { const l = t.context, c = l.gl, h = o.fbo; if (!h) return; t.prepareDrawTile(); const u = t.useProgram("hillshade"); l.activeTexture.set(c.TEXTURE0), c.bindTexture(c.TEXTURE_2D, h.colorAttachment.get()); const _ = ((e, t, i, o) => { const r = i.paint.get("hillshade-shadow-color"), n = i.paint.get("hillshade-highlight-color"), s = i.paint.get("hillshade-accent-color"); let a = i.paint.get("hillshade-illumination-direction") * (Math.PI / 180); "viewport" === i.paint.get("hillshade-illumination-anchor") && (a -= e.transform.angle); const l = !e.options.moving; return { u_matrix: o || e.transform.calculateProjMatrix(t.tileID.toUnwrapped(), l), u_image: 0, u_latrange: mi(0, t.tileID), u_light: [i.paint.get("hillshade-exaggeration"), a], u_shadow: r, u_highlight: n, u_accent: s } })(t, o, r, t.terrain ? i.projMatrix : null); t.prepareDrawProgram(l, u, i.toUnwrapped()); const { tileBoundsBuffer: d, tileBoundsIndexBuffer: p, tileBoundsSegments: m } = t.getTileBoundsBuffers(o); u.draw(l, c.TRIANGLES, n, s, a, e.CullFaceMode.disabled, _, r.id, d, p, m); } function gi(t, i, o) { if (!i.needsDEMTextureUpload) return; const r = t.context, n = r.gl; r.pixelStoreUnpackPremultiplyAlpha.set(!1), i.demTexture = i.demTexture || t.getTileTexture(o.stride); const s = o.getPixels(); i.demTexture ? i.demTexture.update(s, { premultiply: !1 }) : i.demTexture = new e.Texture(r, s, n.RGBA, { premultiply: !1 }), i.needsDEMTextureUpload = !1; } function vi(t, i, o, r, n, s) { const a = t.context, l = a.gl; if (!i.dem) return; const c = i.dem; if (a.activeTexture.set(l.TEXTURE1), gi(t, i, c), !i.demTexture) return; i.demTexture.bind(l.NEAREST, l.CLAMP_TO_EDGE); const h = c.dim; a.activeTexture.set(l.TEXTURE0); let u = i.fbo; if (!u) { const t = new e.Texture(a, { width: h, height: h, data: null }, l.RGBA); t.bind(l.LINEAR, l.CLAMP_TO_EDGE), u = i.fbo = a.createFramebuffer(h, h, !0), u.colorAttachment.set(t.texture); } a.bindFramebuffer.set(u.framebuffer), a.viewport.set([0, 0, h, h]); const { tileBoundsBuffer: _, tileBoundsIndexBuffer: d, tileBoundsSegments: p } = t.getMercatorTileBoundsBuffers(); t.useProgram("hillshadePrepare").draw(a, l.TRIANGLES, r, n, s, e.CullFaceMode.disabled, ((t, i) => { const o = i.stride, r = e.create(); return e.ortho(r, 0, e.EXTENT, -e.EXTENT, 0, 0, 1), e.translate(r, r, [0, -e.EXTENT, 0]), { u_matrix: r, u_image: 1, u_dimension: [o, o], u_zoom: t.overscaledZ, u_unpack: i.unpackVector } })(i.tileID, c), o.id, _, d, p), i.needsHillshadePrepare = !1; } const xi = t => ({ u_matrix: new e.UniformMatrix4f(t), u_image0: new e.Uniform1i(t), u_skirt_height: new e.Uniform1f(t) }), yi = (e, t) => ({ u_matrix: e, u_image0: 0, u_skirt_height: t }), bi = (e, t, i, o, r, n, s, a, l, c, h, u, _, d, p) => ({ u_proj_matrix: Float32Array.from(e), u_globe_matrix: t, u_normalize_matrix: Float32Array.from(o), u_merc_matrix: i, u_zoom_transition: r, u_merc_center: n, u_image0: 0, u_frustum_tl: s, u_frustum_tr: a, u_frustum_br: l, u_frustum_bl: c, u_globe_pos: h, u_globe_radius: u, u_viewport: _, u_grid_matrix: p ? Float32Array.from(p) : new Float32Array(9), u_skirt_height: d }); function wi(e, t) { return null != e && null != t && !(!e.hasData() || !t.hasData()) && null != e.demTexture && null != t.demTexture && e.tileID.key !== t.tileID.key } const Ti = new class { constructor() { this.operations = {}; } newMorphing(e, t, i, o, r) { if (e in this.operations) { const t = this.operations[e]; t.to.tileID.key !== i.tileID.key && (t.queued = i); } else this.operations[e] = { startTime: o, phase: 0, duration: r, from: t, to: i, queued: null }; } getMorphValuesForProxy(e) { if (!(e in this.operations)) return null; const t = this.operations[e]; return { from: t.from, to: t.to, phase: t.phase } } update(e) { for (const t in this.operations) { const i = this.operations[t]; for (i.phase = (e - i.startTime) / i.duration; i.phase >= 1 || !this._validOp(i);) if (!this._nextOp(i, e)) { delete this.operations[t]; break } } } _nextOp(e, t) { return !!e.queued && (e.from = e.to, e.to = e.queued, e.queued = null, e.phase = 0, e.startTime = t, !0) } _validOp(e) { return e.from.hasData() && e.to.hasData() } }, Ei = { 0: null, 1: "TERRAIN_VERTEX_MORPHING", 2: "TERRAIN_WIREFRAME" }; function Ci(e) { return 6 * Math.pow(1.5, 22 - e) } function Mi(e, t) { const i = 1 << e.z; return !t && (0 === e.x || e.x === i - 1) || 0 === e.y || e.y === i - 1 } const Ii = e => ({ u_matrix: e }); function Si(t, i, o, r, n) { if (n > 0) { const s = e.exported.now(), a = (s - t.timeAdded) / n, l = i ? (s - i.timeAdded) / n : -1, c = o.getSource(), h = r.coveringZoomLevel({ tileSize: c.tileSize, roundZoom: c.roundZoom }), u = !i || Math.abs(i.tileID.overscaledZ - h) > Math.abs(t.tileID.overscaledZ - h), _ = u && t.refreshedUponExpiration ? 1 : e.clamp(u ? a : 1 - l, 0, 1); return t.refreshedUponExpiration && a >= 1 && (t.refreshedUponExpiration = !1), i ? { opacity: 1, mix: 1 - _ } : { opacity: _, mix: 0 } } return { opacity: 1, mix: 0 } } class Di extends e.SourceCache { constructor(e) { const t = { type: "raster-dem", maxzoom: e.transform.maxZoom }, i = new z(je(), null), o = Pe("mock-dem", t, i, e.style); super("mock-dem", o, !1), o.setEventedParent(this), this._sourceLoaded = !0; } _loadTile(e, t) { e.state = "loaded", t(null); } } class Li extends e.SourceCache { constructor(e) { const t = Pe("proxy", { type: "geojson", maxzoom: e.transform.maxZoom }, new z(je(), null), e.style); super("proxy", t, !1), t.setEventedParent(this), this.map = this.getSource().map = e, this.used = this._sourceLoaded = !0, this.renderCache = [], this.renderCachePool = [], this.proxyCachedFBO = {}; } update(t, i, o) { if (t.freezeTileCoverage) return; this.transform = t; const r = t.coveringTiles({ tileSize: this._source.tileSize, minzoom: this._source.minzoom, maxzoom: this._source.maxzoom, roundZoom: this._source.roundZoom, reparseOverscaled: this._source.reparseOverscaled }).reduce(((i, o) => { if (i[o.key] = "", !this._tiles[o.key]) { const i = new e.Tile(o, this._source.tileSize * o.overscaleFactor(), t.tileZoom); i.state = "loaded", this._tiles[o.key] = i; } return i }), {}); for (const e in this._tiles) e in r || (this.freeFBO(e), this._tiles[e].unloadVectorData(), delete this._tiles[e]); } freeFBO(e) { const t = this.proxyCachedFBO[e]; if (void 0 !== t) { const i = Object.values(t); this.renderCachePool.push(...i), delete this.proxyCachedFBO[e]; } } deallocRenderCache() { this.renderCache.forEach((e => e.fb.destroy())), this.renderCache = [], this.renderCachePool = [], this.proxyCachedFBO = {}; } } class Ai extends e.OverscaledTileID { constructor(e, t, i) { super(e.overscaledZ, e.wrap, e.canonical.z, e.canonical.x, e.canonical.y), this.proxyTileKey = t, this.projMatrix = i; } } class zi extends e.Elevation { constructor(t, i) { super(), this.painter = t, this.terrainTileForTile = {}, this.prevTerrainTileForTile = {}; const [o, r, n] = function(t) { const i = new e.StructArrayLayout2i4, o = new e.StructArrayLayout3ui6, r = 131; i.reserve(17161), o.reserve(33800); const n = e.EXTENT / 128, s = e.EXTENT + n / 2, a = s + n; for (let t = -n; t < a; t += n) for (let o = -n; o < a; o += n) { const r = o < 0 || o > s || t < 0 || t > s ? 24575 : 0, n = e.clamp(Math.round(o), 0, e.EXTENT), a = e.clamp(Math.round(t), 0, e.EXTENT); i.emplaceBack(n + r, a); } const l = (e, t) => { const i = t * r + e; o.emplaceBack(i + 1, i, i + r), o.emplaceBack(i + r, i + r + 1, i + 1); }; for (let e = 1; e < 129; e++) for (let t = 1; t < 129; t++) l(t, e); return [0, 129].forEach((e => { for (let t = 0; t < 130; t++) l(t, e), l(e, t); })), [i, o, 32768] }(), s = t.context; this.gridBuffer = s.createVertexBuffer(o, e.posAttributes.members), this.gridIndexBuffer = s.createIndexBuffer(r), this.gridSegments = e.SegmentVector.simpleSegment(0, 0, o.length, r.length), this.gridNoSkirtSegments = e.SegmentVector.simpleSegment(0, 0, o.length, n), this.proxyCoords = [], this.proxiedCoords = {}, this._visibleDemTiles = [], this._drapedRenderBatches = [], this._sourceTilesOverlap = {}, this.proxySourceCache = new Li(i.map), this.orthoMatrix = e.create(), e.ortho(this.orthoMatrix, "globe" === this.painter.transform.projection.name ? .015 : 0, e.EXTENT, 0, e.EXTENT, 0, 1); const a = s.gl; this._overlapStencilMode = new e.StencilMode({ func: a.GEQUAL, mask: 255 }, 0, 255, a.KEEP, a.KEEP, a.REPLACE), this._previousZoom = t.transform.zoom, this.pool = [], this._findCoveringTileCache = {}, this._tilesDirty = {}, this.style = i, this._useVertexMorphing = !0, this._exaggeration = 1, this._mockSourceCache = new Di(i.map); } set style(e) { e.on("data", this._onStyleDataEvent.bind(this)), e.on("neworder", this._checkRenderCacheEfficiency.bind(this)), this._style = e, this._checkRenderCacheEfficiency(), this._style.map.on("moveend", (() => { this._clearLineLayersFromRenderCache(); })); } update(t, i, o) { if (t && t.terrain) { this._style !== t && (this.style = t), this.enabled = !0; const r = t.terrain.properties; this.sourceCache = 0 === t.terrain.drapeRenderMode ? this._mockSourceCache : t._getSourceCache(r.get("source")), this._exaggeration = r.get("exaggeration"); const n = () => { this.sourceCache.used && e.warnOnce(`Raster DEM source '${this.sourceCache.id}' is used both for terrain and as layer source.\nThis leads to lower resolution of hillshade. For full hillshade resolution but higher memory consumption, define another raster DEM source.`); const t = this.getScaledDemTileSize(); this.sourceCache.update(i, t, !0), this.resetTileLookupCache(this.sourceCache.id); }; this.sourceCache.usedForTerrain || (this.resetTileLookupCache(this.sourceCache.id), this.sourceCache.usedForTerrain = !0, n(), this._initializing = !0), n(), i.updateElevation(!0, o), this.resetTileLookupCache(this.proxySourceCache.id), this.proxySourceCache.update(i), this._emptyDEMTextureDirty = !0; } else this._disable(); } resetTileLookupCache(e) { this._findCoveringTileCache[e] = {}; } getScaledDemTileSize() { return this.sourceCache.getSource().tileSize / 128 * this.proxySourceCache.getSource().tileSize } _checkRenderCacheEfficiency() { const t = this.renderCacheEfficiency(this._style); this._style.map._optimizeForTerrain || 100 !== t.efficiency && e.warnOnce(`Terrain render cache efficiency is not optimal (${t.efficiency}%) and performance\n may be affected negatively, consider placing all background, fill and line layers before layer\n with id '${t.firstUndrapedLayer}' or create a map using optimizeForTerrain: true option.`); } _onStyleDataEvent(e) { e.coord && "source" === e.dataType ? this._clearRenderCacheForTile(e.sourceCacheId, e.coord) : "style" === e.dataType && (this._invalidateRenderCache = !0); } _disable() { if (this.enabled && (this.enabled = !1, this._sharedDepthStencil = void 0, this.proxySourceCache.deallocRenderCache(), this._style)) for (const e in this._style._sourceCaches) this._style._sourceCaches[e].usedForTerrain = !1; } destroy() { this._disable(), this._emptyDEMTexture && this._emptyDEMTexture.destroy(), this._emptyDepthBufferTexture && this._emptyDepthBufferTexture.destroy(), this.pool.forEach((e => e.fb.destroy())), this.pool = [], this._depthFBO && (this._depthFBO.destroy(), this._depthFBO = void 0, this._depthTexture = void 0); } _source() { return this.enabled ? this.sourceCache : null } isUsingMockSource() { return this.sourceCache === this._mockSourceCache } exaggeration() { return this._exaggeration } get visibleDemTiles() { return this._visibleDemTiles } get drapeBufferSize() { const e = 2 * this.proxySourceCache.getSource().tileSize; return [e, e] } set useVertexMorphing(e) { this._useVertexMorphing = e; } updateTileBinding(t) { if (!this.enabled) return; this.prevTerrainTileForTile = this.terrainTileForTile; const i = this.proxySourceCache, o = this.painter.transform; this._initializing && (this._initializing = 0 === o._centerAltitude && -1 === this.getAtPointOrZero(e.MercatorCoordinate.fromLngLat(o.center), -1), this._emptyDEMTextureDirty = !this._initializing); const r = this.proxyCoords = i.getIds().map((e => { const t = i.getTileByID(e).tileID; return t.projMatrix = o.calculateProjMatrix(t.toUnwrapped()), t })); ! function(t, i) { const o = i.transform.pointCoordinate(i.transform.getCameraPoint()), r = new e.pointGeometry(o.x, o.y); t.sort(((t, i) => { if (i.overscaledZ - t.overscaledZ) return i.overscaledZ - t.overscaledZ; const o = new e.pointGeometry(t.canonical.x + (1 << t.canonical.z) * t.wrap, t.canonical.y), n = new e.pointGeometry(i.canonical.x + (1 << i.canonical.z) * i.wrap, i.canonical.y), s = r.mult(1 << t.canonical.z); return s.x -= .5, s.y -= .5, s.distSqr(o) - s.distSqr(n) })); }(r, this.painter), this._previousZoom = o.zoom; const n = this.proxyToSource || {}; this.proxyToSource = {}, r.forEach((e => { this.proxyToSource[e.key] = {}; })), this.terrainTileForTile = {}; const s = this._style._sourceCaches; for (const e in s) { const i = s[e]; if (!i.used) continue; if (i !== this.sourceCache && this.resetTileLookupCache(i.id), this._setupProxiedCoordsForOrtho(i, t[e], n), i.usedForTerrain) continue; const o = t[e]; i.getSource().reparseOverscaled && this._assignTerrainTiles(o); } this.proxiedCoords[i.id] = r.map((e => new Ai(e, e.key, this.orthoMatrix))), this._assignTerrainTiles(r), this._prepareDEMTextures(), this._setupDrapedRenderBatches(), this._initFBOPool(), this._setupRenderCache(n), this.renderingToTexture = !1, this._updateTimestamp = e.exported.now(); const a = {}; this._visibleDemTiles = []; for (const e of this.proxyCoords) { const t = this.terrainTileForTile[e.key]; if (!t) continue; const i = t.tileID.key; i in a || (this._visibleDemTiles.push(t), a[i] = i); } } _assignTerrainTiles(e) { this._initializing || e.forEach((e => { if (this.terrainTileForTile[e.key]) return; const t = this._findTileCoveringTileID(e, this.sourceCache); t && (this.terrainTileForTile[e.key] = t); })); } _prepareDEMTextures() { const e = this.painter.context, t = e.gl; for (const i in this.terrainTileForTile) { const o = this.terrainTileForTile[i], r = o.dem; !r || o.demTexture && !o.needsDEMTextureUpload || (e.activeTexture.set(t.TEXTURE1), gi(this.painter, o, r)); } } _prepareDemTileUniforms(e, t, i, o) { if (!t || null == t.demTexture) return !1; const r = e.tileID.canonical, n = Math.pow(2, t.tileID.canonical.z - r.z), s = o || ""; return i[`u_dem_tl${s}`] = [r.x * n % 1, r.y * n % 1], i[`u_dem_scale${s}`] = n, !0 } get emptyDEMTexture() { return !this._emptyDEMTextureDirty && this._emptyDEMTexture ? this._emptyDEMTexture : this._updateEmptyDEMTexture() } get emptyDepthBufferTexture() { const t = this.painter.context, i = t.gl; if (!this._emptyDepthBufferTexture) { const o = new e.RGBAImage({ width: 1, height: 1 }, Uint8Array.of(255, 255, 255, 255)); this._emptyDepthBufferTexture = new e.Texture(t, o, i.RGBA, { premultiply: !1 }); } return this._emptyDepthBufferTexture } _getLoadedAreaMinimum() { let e = 0; const t = this._visibleDemTiles.reduce(((t, i) => { if (!i.dem) return t; const o = i.dem.tree.minimums[0]; return o > 0 && e++, t + o }), 0); return e ? t / e : 0 } _updateEmptyDEMTexture() { const t = this.painter.context, i = t.gl; t.activeTexture.set(i.TEXTURE2); const o = this._getLoadedAreaMinimum(), r = new e.RGBAImage({ width: 1, height: 1 }, new Uint8Array(e.DEMData.pack(o, this.sourceCache.getSource().encoding))); this._emptyDEMTextureDirty = !1; let n = this._emptyDEMTexture; return n ? n.update(r, { premultiply: !1 }) : n = this._emptyDEMTexture = new e.Texture(t, r, i.RGBA, { premultiply: !1 }), n } setupElevationDraw(t, i, o) { const r = this.painter.context, n = r.gl, s = (a = this.sourceCache.getSource().encoding, { u_dem: 2, u_dem_prev: 4, u_dem_unpack: e.DEMData.getUnpackVector(a), u_dem_tl: [0, 0], u_dem_tl_prev: [0, 0], u_dem_scale: 0, u_dem_scale_prev: 0, u_dem_size: 0, u_dem_lerp: 1, u_depth: 3, u_depth_size_inv: [0, 0], u_exaggeration: 0 }); var a; s.u_dem_size = this.sourceCache.getSource().tileSize, s.u_exaggeration = this.exaggeration(); let l = null, c = null, h = 1; if (o && o.morphing && this._useVertexMorphing) { const e = o.morphing.srcDemTile, i = o.morphing.dstDemTile; h = o.morphing.phase, e && i && (this._prepareDemTileUniforms(t, e, s, "_prev") && (c = e), this._prepareDemTileUniforms(t, i, s) && (l = i)); } if (c && l ? (r.activeTexture.set(n.TEXTURE2), l.demTexture.bind(n.NEAREST, n.CLAMP_TO_EDGE, n.NEAREST), r.activeTexture.set(n.TEXTURE4), c.demTexture.bind(n.NEAREST, n.CLAMP_TO_EDGE, n.NEAREST), s.u_dem_lerp = h) : (l = this.terrainTileForTile[t.tileID.key], r.activeTexture.set(n.TEXTURE2), (this._prepareDemTileUniforms(t, l, s) ? l.demTexture : this.emptyDEMTexture).bind(n.NEAREST, n.CLAMP_TO_EDGE)), r.activeTexture.set(n.TEXTURE3), o && o.useDepthForOcclusion ? (this._depthTexture && this._depthTexture.bind(n.NEAREST, n.CLAMP_TO_EDGE), this._depthFBO && (s.u_depth_size_inv = [1 / this._depthFBO.width, 1 / this._depthFBO.height])) : (this.emptyDepthBufferTexture.bind(n.NEAREST, n.CLAMP_TO_EDGE), s.u_depth_size_inv = [1, 1]), o && o.useMeterToDem && l) { const t = (1 << l.tileID.canonical.z) * e.mercatorZfromAltitude(1, this.painter.transform.center.lat) * this.sourceCache.getSource().tileSize; s.u_meter_to_dem = t; } if (o && o.labelPlaneMatrixInv && (s.u_label_plane_matrix_inv = o.labelPlaneMatrixInv), i.setTerrainUniformValues(r, s), "globe" === this.painter.transform.projection.name) { const e = this.globeUniformValues(this.painter.transform, t.tileID.canonical, o && o.useDenormalizedUpVectorScale); i.setGlobeUniformValues(r, e); } } globeUniformValues(t, i, o) { const r = t.projection; return { u_tile_tl_up: r.upVector(i, 0, 0), u_tile_tr_up: r.upVector(i, e.EXTENT, 0), u_tile_br_up: r.upVector(i, e.EXTENT, e.EXTENT), u_tile_bl_up: r.upVector(i, 0, e.EXTENT), u_tile_up_scale: o ? e.globeMetersToEcef(1) : r.upVectorScale(i, t.center.lat, t.worldSize).metersToTile } } renderToBackBuffer(t) { const i = this.painter, o = this.painter.context; 0 !== t.length && (o.bindFramebuffer.set(null), o.viewport.set([0, 0, i.width, i.height]), i.gpuTimingDeferredRenderStart(), this.renderingToTexture = !1, function(t, i, o, r, n) { if ("globe" === t.transform.projection.name) ! function(t, i, o, r, n) { const s = t.context, a = s.gl; let l, c; const h = t.options.showTerrainWireframe ? 2 : 0, u = t.transform, _ = e.globeUseCustomAntiAliasing(t, s, u), d = (e, i) => { if (c === e) return; const o = [Ei[e], "PROJECTION_GLOBE_VIEW"]; _ && o.push("CUSTOM_ANTIALIASING"), i && o.push(Ei[h]), l = t.useProgram("globeRaster", null, o), c = e; }, p = t.colorModeForRenderPass(), m = new e.DepthMode(a.LEQUAL, e.DepthMode.ReadWrite, t.depthRangeFor3D); Ti.update(n); const f = e.calculateGlobeMercatorMatrix(u), g = [e.mercatorXfromLng(u.center.lng), e.mercatorYfromLat(u.center.lat)], v = h ? [!1, !0] : [!1], x = t.globeSharedBuffers, y = [u.width * e.exported.devicePixelRatio, u.height * e.exported.devicePixelRatio], b = Float32Array.from(u.globeMatrix), w = { useDenormalizedUpVectorScale: !0 }; if (v.forEach((h => { const u = t.transform, _ = Ci(u.zoom) * i.exaggeration(); c = -1; const v = h ? a.LINES : a.TRIANGLES; for (const c of r) { const r = o.getTile(c), T = e.StencilMode.disabled, E = i.prevTerrainTileForTile[c.key], C = i.terrainTileForTile[c.key]; wi(E, C) && Ti.newMorphing(c.key, E, C, n, 250), s.activeTexture.set(a.TEXTURE0), r.texture.bind(a.LINEAR, a.CLAMP_TO_EDGE); const M = Ti.getMorphValuesForProxy(c.key), I = M ? 1 : 0; M && e.extend$1(w, { morphing: { srcDemTile: M.from, dstDemTile: M.to, phase: e.easeCubicInOut(M.phase) } }); const S = e.tileCornersToBounds(c.canonical), D = e.getLatitudinalLod(S.getCenter().lat), L = e.getGridMatrix(c.canonical, S, D, u.worldSize / u._pixelsPerMercatorPixel), A = e.globeNormalizeECEF(e.globeTileBounds(c.canonical)), z = bi(u.projMatrix, b, f, A, e.globeToMercatorTransition(u.zoom), g, u.frustumCorners.TL, u.frustumCorners.TR, u.frustumCorners.BR, u.frustumCorners.BL, u.globeCenterInViewSpace, u.globeRadius, y, _, L); if (d(I, h), i.setupElevationDraw(r, l, w), t.prepareDrawProgram(s, l, c.toUnwrapped()), x) { const [i, o, r] = h ? x.getWirefameBuffers(t.context, D) : x.getGridBuffers(D, 0 !== _); l.draw(s, v, m, T, p, e.CullFaceMode.backCCW, z, "globe_raster", i, o, r); } } })), x) { const n = ["GLOBE_POLES", "PROJECTION_GLOBE_VIEW"]; _ && n.push("CUSTOM_ANTIALIASING"), l = t.useProgram("globeRaster", null, n); for (const n of r) { const { x: r, y: c, z: h } = n.canonical, _ = 0 === c, d = c === (1 << h) - 1, [f, v, b, T] = x.getPoleBuffers(h); if (T && (_ || d)) { const c = o.getTile(n); s.activeTexture.set(a.TEXTURE0), c.texture.bind(a.LINEAR, a.CLAMP_TO_EDGE); let x = e.globePoleMatrixForTile(h, r, u); const E = e.globeNormalizeECEF(e.globeTileBounds(n.canonical)), C = (t, i) => t.draw(s, a.TRIANGLES, m, e.StencilMode.disabled, p, e.CullFaceMode.disabled, bi(u.projMatrix, x, x, E, 0, g, u.frustumCorners.TL, u.frustumCorners.TR, u.frustumCorners.BR, u.frustumCorners.BL, u.globeCenterInViewSpace, u.globeRadius, y, 0), "globe_pole_raster", i, b, T); i.setupElevationDraw(c, l, w), t.prepareDrawProgram(s, l, n.toUnwrapped()), _ && C(l, f), d && (x = e.scale(e.create(), x, [1, -1, 1]), C(l, v)); } } } }(t, i, o, r, n); else { const s = t.context, a = s.gl; let l, c; const h = t.options.showTerrainWireframe ? 2 : 0, u = (e, i) => { if (c === e) return; const o = [Ei[e]]; i && o.push(Ei[h]), l = t.useProgram("terrainRaster", null, o), c = e; }, _ = t.colorModeForRenderPass(), d = new e.DepthMode(a.LEQUAL, e.DepthMode.ReadWrite, t.depthRangeFor3D); Ti.update(n); const p = t.transform, m = Ci(p.zoom) * i.exaggeration(); (h ? [!1, !0] : [!1]).forEach((h => { c = -1; const f = h ? a.LINES : a.TRIANGLES, [g, v] = h ? i.getWirefameBuffer() : [i.gridIndexBuffer, i.gridSegments]; for (const c of r) { const r = o.getTile(c), x = e.StencilMode.disabled, y = i.prevTerrainTileForTile[c.key], b = i.terrainTileForTile[c.key]; wi(y, b) && Ti.newMorphing(c.key, y, b, n, 250), s.activeTexture.set(a.TEXTURE0), r.texture.bind(a.LINEAR, a.CLAMP_TO_EDGE, a.LINEAR_MIPMAP_NEAREST); const w = Ti.getMorphValuesForProxy(c.key), T = w ? 1 : 0; let E; w && (E = { morphing: { srcDemTile: w.from, dstDemTile: w.to, phase: e.easeCubicInOut(w.phase) } }); const C = yi(c.projMatrix, Mi(c.canonical, p.renderWorldCopies) ? m / 10 : m); u(T, h), i.setupElevationDraw(r, l, E), t.prepareDrawProgram(s, l, c.toUnwrapped()), l.draw(s, f, d, x, _, e.CullFaceMode.backCCW, C, "terrain_raster", i.gridBuffer, g, v); } })); } }(i, this, this.proxySourceCache, t, this._updateTimestamp), this.renderingToTexture = !0, i.gpuTimingDeferredRenderEnd(), t.splice(0, t.length)); } renderBatch(t) { if (0 === this._drapedRenderBatches.length) return t + 1; this.renderingToTexture = !0; const i = this.painter, o = this.painter.context, r = this.proxySourceCache, n = this.proxiedCoords[r.id], s = this._drapedRenderBatches.shift(), a = [], l = i.style.order; let c = 0; for (const h of n) { const n = r.getTileByID(h.proxyTileKey), u = r.proxyCachedFBO[h.key] ? r.proxyCachedFBO[h.key][t] : void 0, _ = void 0 !== u ? r.renderCache[u] : this.pool[c++], d = void 0 !== u; if (n.texture = _.tex, d && !_.dirty) { a.push(n.tileID); continue } let p; o.bindFramebuffer.set(_.fb.framebuffer), this.renderedToTile = !1, _.dirty && (o.clear({ color: e.Color.transparent, stencil: 0 }), _.dirty = !1); for (let e = s.start; e <= s.end; ++e) { const t = i.style._layers[l[e]]; if (t.isHidden(i.transform.zoom)) continue; const r = i.style._getLayerSourceCache(t), n = r ? this.proxyToSource[h.key][r.id] : [h]; if (!n) continue; const s = n; o.viewport.set([0, 0, _.fb.width, _.fb.height]), p !== (r ? r.id : null) && (this._setupStencil(_, n, t, r), p = r ? r.id : null), i.renderLayer(i, r, t, s); } this.renderedToTile ? (_.dirty = !0, a.push(n.tileID)) : d || --c, 5 === c && (c = 0, this.renderToBackBuffer(a)); } return this.renderToBackBuffer(a), this.renderingToTexture = !1, o.bindFramebuffer.set(null), o.viewport.set([0, 0, i.width, i.height]), s.end + 1 } postRender() {} renderCacheEfficiency(e) { const t = e.order.length; if (0 === t) return { efficiency: 100 }; let i, o = 0, r = 0, n = !1; for (let s = 0; s < t; ++s) { const t = e._layers[e.order[s]]; this._style.isLayerDraped(t) ? (n && ++o, ++r) : n || (n = !0, i = t.id); } return 0 === r ? { efficiency: 100 } : { efficiency: 100 * (1 - o / r), firstUndrapedLayer: i } } getMinElevationBelowMSL() { let e = 0; return this._visibleDemTiles.filter((e => e.dem)).forEach((t => { e = Math.min(e, t.dem.tree.minimums[0]); })), 0 === e ? e : (e - 30) * this._exaggeration } raycast(e, t, i) { if (!this._visibleDemTiles) return null; const o = this._visibleDemTiles.filter((e => e.dem)).map((o => { const r = o.tileID, n = 1 << r.overscaledZ, { x: s, y: a } = r.canonical, l = s / n, c = (s + 1) / n, h = a / n, u = (a + 1) / n; return { minx: l, miny: h, maxx: c, maxy: u, t: o.dem.tree.raycastRoot(l, h, c, u, e, t, i), tile: o } })); o.sort(((e, t) => (null !== e.t ? e.t : Number.MAX_VALUE) - (null !== t.t ? t.t : Number.MAX_VALUE))); for (const r of o) { if (null == r.t) return null; const o = r.tile.dem.tree.raycast(r.minx, r.miny, r.maxx, r.maxy, e, t, i); if (null != o) return o } return null } _createFBO() { const t = this.painter.context, i = t.gl, o = this.drapeBufferSize; t.activeTexture.set(i.TEXTURE0); const r = new e.Texture(t, { width: o[0], height: o[1], data: null }, i.RGBA); r.bind(i.LINEAR, i.CLAMP_TO_EDGE); const n = t.createFramebuffer(o[0], o[1], !1); return n.colorAttachment.set(r.texture), n.depthAttachment = new Ee(t, n.framebuffer), void 0 === this._sharedDepthStencil ? (this._sharedDepthStencil = t.createRenderbuffer(t.gl.DEPTH_STENCIL, o[0], o[1]), this._stencilRef = 0, n.depthAttachment.set(this._sharedDepthStencil), t.clear({ stencil: 0 })) : n.depthAttachment.set(this._sharedDepthStencil), t.extTextureFilterAnisotropic && !t.extTextureFilterAnisotropicForceOff && i.texParameterf(i.TEXTURE_2D, t.extTextureFilterAnisotropic.TEXTURE_MAX_ANISOTROPY_EXT, t.extTextureFilterAnisotropicMax), { fb: n, tex: r, dirty: !1 } } _initFBOPool() { for (; this.pool.length < Math.min(5, this.proxyCoords.length);) this.pool.push(this._createFBO()); } _shouldDisableRenderCache() { if (this._style.light && this._style.light.hasTransition()) return !0; for (const e in this._style._sourceCaches) if (this._style._sourceCaches[e].hasTransition()) return !0; return this._style.order.some((e => { const t = this._style._layers[e], i = t.isHidden(this.painter.transform.zoom); return "custom" === t.type ? !i && t.shouldRedrape() : !i && t.hasTransition() })) } _clearLineLayersFromRenderCache() { let t = !1; for (const e of this._style._getSources()) if (e instanceof Ie) { t = !0; break } if (!t) return; const i = {}; for (let t = 0; t < this._style.order.length; ++t) { const o = this._style._layers[this._style.order[t]], r = this._style._getLayerSourceCache(o); if (r && !i[r.id] && !o.isHidden(this.painter.transform.zoom) && "line" === o.type && o.widthExpression() instanceof e.ZoomDependentExpression) { i[r.id] = !0; for (const e of this.proxyCoords) { const t = this.proxyToSource[e.key][r.id]; if (t) for (const e of t) this._clearRenderCacheForTile(r.id, e); } } } } _clearRasterLayersFromRenderCache() { let e = !1; for (const t in this._style._sourceCaches) if (this._style._sourceCaches[t]._source instanceof Se) { e = !0; break } if (!e) return; const t = {}; for (let e = 0; e < this._style.order.length; ++e) { const i = this._style._layers[this._style.order[e]], o = this._style._getLayerSourceCache(i); if (!o || t[o.id]) continue; if (i.isHidden(this.painter.transform.zoom) || "raster" !== i.type) continue; const r = i.paint.get("raster-fade-duration"); for (const e of this.proxyCoords) { const t = this.proxyToSource[e.key][o.id]; if (t) for (const e of t) { const t = Si(o.getTile(e), o.findLoadedParent(e, 0), o, this.painter.transform, r); (1 !== t.opacity || 0 !== t.mix) && this._clearRenderCacheForTile(o.id, e); } } } } _setupDrapedRenderBatches() { const e = this._style.order, t = e.length; if (0 === t) return; const i = []; let o, r = 0, n = this._style._layers[e[r]]; for (; !this._style.isLayerDraped(n) && n.isHidden(this.painter.transform.zoom) && ++r < t;) n = this._style._layers[e[r]]; for (; r < t; ++r) { const t = this._style._layers[e[r]]; t.isHidden(this.painter.transform.zoom) || (this._style.isLayerDraped(t) ? void 0 === o && (o = r) : void 0 !== o && (i.push({ start: o, end: r - 1 }), o = void 0)); } void 0 !== o && i.push({ start: o, end: r - 1 }), this._drapedRenderBatches = i; } _setupRenderCache(e) { const t = this.proxySourceCache; if (this._shouldDisableRenderCache() || this._invalidateRenderCache) { if (this._invalidateRenderCache = !1, t.renderCache.length > t.renderCachePool.length) { const e = Object.values(t.proxyCachedFBO); t.proxyCachedFBO = {}; for (let i = 0; i < e.length; ++i) { const o = Object.values(e[i]); t.renderCachePool.push(...o); } } return } this._clearRasterLayersFromRenderCache(); const i = this.proxyCoords, o = this._tilesDirty; for (let r = i.length - 1; r >= 0; r--) { const n = i[r]; if (t.getTileByID(n.key), void 0 !== t.proxyCachedFBO[n.key]) { const i = e[n.key], r = this.proxyToSource[n.key]; let s = 0; for (const e in r) { const t = r[e], n = i[e]; if (!n || n.length !== t.length || t.some(((t, i) => t !== n[i] || o[e] && o[e].hasOwnProperty(t.key)))) { s = -1; break }++s; } for (const e in t.proxyCachedFBO[n.key]) t.renderCache[t.proxyCachedFBO[n.key][e]].dirty = s < 0 || s !== Object.values(i).length; } } const r = [...this._drapedRenderBatches]; r.sort(((e, t) => t.end - t.start - (e.end - e.start))); for (const e of r) for (const o of i) { if (t.proxyCachedFBO[o.key]) continue; let i = t.renderCachePool.pop(); void 0 === i && t.renderCache.length < 50 && (i = t.renderCache.length, t.renderCache.push(this._createFBO())), void 0 !== i && (t.proxyCachedFBO[o.key] = {}, t.proxyCachedFBO[o.key][e.start] = i, t.renderCache[i].dirty = !0); } this._tilesDirty = {}; } _setupStencil(e, t, i, o) { if (!o || !this._sourceTilesOverlap[o.id]) return void(this._overlapStencilType && (this._overlapStencilType = !1)); const r = this.painter.context, n = r.gl; if (t.length <= 1) return void(this._overlapStencilType = !1); let s; if (i.isTileClipped()) s = t.length, this._overlapStencilMode.test = { func: n.EQUAL, mask: 255 }, this._overlapStencilType = "Clip"; else { if (!(t[0].overscaledZ > t[t.length - 1].overscaledZ)) return void(this._overlapStencilType = !1); s = 1, this._overlapStencilMode.test = { func: n.GREATER, mask: 255 }, this._overlapStencilType = "Mask"; } this._stencilRef + s > 255 && (r.clear({ stencil: 0 }), this._stencilRef = 0), this._stencilRef += s, this._overlapStencilMode.ref = this._stencilRef, i.isTileClipped() && this._renderTileClippingMasks(t, this._overlapStencilMode.ref); } clipOrMaskOverlapStencilType() { return "Clip" === this._overlapStencilType || "Mask" === this._overlapStencilType } stencilModeForRTTOverlap(t) { return this.renderingToTexture && this._overlapStencilType ? ("Clip" === this._overlapStencilType && (this._overlapStencilMode.ref = this.painter._tileClippingMaskIDs[t.key]), this._overlapStencilMode) : e.StencilMode.disabled } _renderTileClippingMasks(t, i) { const o = this.painter, r = this.painter.context, n = r.gl; o._tileClippingMaskIDs = {}, r.setColorMode(e.ColorMode.disabled), r.setDepthMode(e.DepthMode.disabled); const s = o.useProgram("clippingMask"); for (const a of t) { const t = o._tileClippingMaskIDs[a.key] = --i; s.draw(r, n.TRIANGLES, e.DepthMode.disabled, new e.StencilMode({ func: n.ALWAYS, mask: 0 }, t, 255, n.KEEP, n.KEEP, n.REPLACE), e.ColorMode.disabled, e.CullFaceMode.disabled, Ii(a.projMatrix), "$clipping", o.tileExtentBuffer, o.quadTriangleIndexBuffer, o.tileExtentSegments); } } pointCoordinate(t) { const i = this.painter.transform; if (t.x < 0 || t.x > i.width || t.y < 0 || t.y > i.height) return null; const o = [t.x, t.y, 1, 1]; e.transformMat4$1(o, o, i.pixelMatrixInverse), e.scale$1(o, o, 1 / o[3]), o[0] /= i.worldSize, o[1] /= i.worldSize; const r = i._camera.position, n = e.mercatorZfromAltitude(1, i.center.lat), s = [r[0], r[1], r[2] / n, 0], a = e.subtract([], o.slice(0, 3), s); e.normalize(a, a); const l = this.raycast(s, a, this._exaggeration); return null !== l && l ? (e.scaleAndAdd(s, s, a, l), s[3] = s[2], s[2] *= n, s) : null } drawDepth() { const t = this.painter, i = t.context, o = this.proxySourceCache, r = Math.ceil(t.width), n = Math.ceil(t.height); if (!this._depthFBO || this._depthFBO.width === r && this._depthFBO.height === n || (this._depthFBO.destroy(), this._depthFBO = void 0, this._depthTexture = void 0), !this._depthFBO) { const t = i.gl, o = i.createFramebuffer(r, n, !0); i.activeTexture.set(t.TEXTURE0); const s = new e.Texture(i, { width: r, height: n, data: null }, t.RGBA); s.bind(t.NEAREST, t.CLAMP_TO_EDGE), o.colorAttachment.set(s.texture); const a = i.createRenderbuffer(i.gl.DEPTH_COMPONENT16, r, n); o.depthAttachment.set(a), this._depthFBO = o, this._depthTexture = s; } i.bindFramebuffer.set(this._depthFBO.framebuffer), i.viewport.set([0, 0, r, n]), function(t, i, o, r) { if ("globe" === t.transform.projection.name) return; const n = t.context, s = n.gl; n.clear({ depth: 1 }); const a = t.useProgram("terrainDepth"), l = new e.DepthMode(s.LESS, e.DepthMode.ReadWrite, t.depthRangeFor3D); for (const t of r) { const r = o.getTile(t), c = yi(t.projMatrix, 0); i.setupElevationDraw(r, a), a.draw(n, s.TRIANGLES, l, e.StencilMode.disabled, e.ColorMode.unblended, e.CullFaceMode.backCCW, c, "terrain_depth", i.gridBuffer, i.gridIndexBuffer, i.gridNoSkirtSegments); } }(t, this, o, this.proxyCoords); } _setupProxiedCoordsForOrtho(e, t, i) { if (e.getSource() instanceof Ae) return this._setupProxiedCoordsForImageSource(e, t, i); this._findCoveringTileCache[e.id] = this._findCoveringTileCache[e.id] || {}; const o = this.proxiedCoords[e.id] = [], r = this.proxyCoords; for (let t = 0; t < r.length; t++) { const n = r[t], s = this._findTileCoveringTileID(n, e); if (s) { const t = this._createProxiedId(n, s, i[n.key] && i[n.key][e.id]); o.push(t), this.proxyToSource[n.key][e.id] = [t]; } } let n = !1; for (let r = 0; r < t.length; r++) { const s = e.getTile(t[r]); if (!s || !s.hasData()) continue; const a = this._findTileCoveringTileID(s.tileID, this.proxySourceCache); if (a && a.tileID.canonical.z !== s.tileID.canonical.z) { const t = this.proxyToSource[a.tileID.key][e.id], r = this._createProxiedId(a.tileID, s, i[a.tileID.key] && i[a.tileID.key][e.id]); t ? t.splice(t.length - 1, 0, r) : this.proxyToSource[a.tileID.key][e.id] = [r], o.push(r), n = !0; } } this._sourceTilesOverlap[e.id] = n; } _setupProxiedCoordsForImageSource(t, i, o) { if (!t.getSource().loaded()) return; const r = this.proxiedCoords[t.id] = [], n = this.proxyCoords, s = t.getSource(), a = new e.pointGeometry(s.tileID.x, s.tileID.y)._div(1 << s.tileID.z), l = s.coordinates.map(e.MercatorCoordinate.fromLngLat).reduce(((e, t) => (e.min.x = Math.min(e.min.x, t.x - a.x), e.min.y = Math.min(e.min.y, t.y - a.y), e.max.x = Math.max(e.max.x, t.x - a.x), e.max.y = Math.max(e.max.y, t.y - a.y), e)), { min: new e.pointGeometry(Number.MAX_VALUE, Number.MAX_VALUE), max: new e.pointGeometry(-Number.MAX_VALUE, -Number.MAX_VALUE) }), c = (t, i) => { const o = t.wrap + t.canonical.x / (1 << t.canonical.z), r = t.canonical.y / (1 << t.canonical.z), n = e.EXTENT / (1 << t.canonical.z), s = i.wrap + i.canonical.x / (1 << i.canonical.z), a = i.canonical.y / (1 << i.canonical.z); return o + n < s + l.min.x || o > s + l.max.x || r + n < a + l.min.y || r > a + l.max.y }; for (let e = 0; e < n.length; e++) { const s = n[e]; for (let e = 0; e < i.length; e++) { const n = t.getTile(i[e]); if (!n || !n.hasData()) continue; if (c(s, n.tileID)) continue; const a = this._createProxiedId(s, n, o[s.key] && o[s.key][t.id]), l = this.proxyToSource[s.key][t.id]; l ? l.push(a) : this.proxyToSource[s.key][t.id] = [a], r.push(a); } } } _createProxiedId(t, i, o) { let r = this.orthoMatrix; if (o) { const e = o.find((e => e.key === i.tileID.key)); if (e) return e } if (i.tileID.key !== t.key) { const o = t.canonical.z - i.tileID.canonical.z; let n, s, a; r = e.create(); const l = i.tileID.wrap - t.wrap << t.overscaledZ; o > 0 ? (n = e.EXTENT >> o, s = n * ((i.tileID.canonical.x << o) - t.canonical.x + l), a = n * ((i.tileID.canonical.y << o) - t.canonical.y)) : (n = e.EXTENT << -o, s = e.EXTENT * (i.tileID.canonical.x - (t.canonical.x + l << -o)), a = e.EXTENT * (i.tileID.canonical.y - (t.canonical.y << -o))), e.ortho(r, 0, n, 0, n, 0, 1), e.translate(r, r, [s, a, 0]); } return new Ai(i.tileID, t.key, r) } _findTileCoveringTileID(t, i) { let o = i.getTile(t); if (o && o.hasData()) return o; const r = this._findCoveringTileCache[i.id], n = r[t.key]; if (o = n ? i.getTileByID(n) : null, o && o.hasData() || null === n) return o; let s = o ? o.tileID : t, a = s.overscaledZ; const l = i.getSource().minzoom, c = []; if (!n) { const r = i.getSource().maxzoom; if (t.canonical.z >= r) { const o = t.canonical.z - r; i.getSource().reparseOverscaled ? (a = Math.max(t.canonical.z + 2, i.transform.tileZoom), s = new e.OverscaledTileID(a, t.wrap, r, t.canonical.x >> o, t.canonical.y >> o)) : 0 !== o && (a = r, s = new e.OverscaledTileID(a, t.wrap, r, t.canonical.x >> o, t.canonical.y >> o)); } s.key !== t.key && (c.push(s.key), o = i.getTile(s)); } const h = e => { c.forEach((t => { r[t] = e; })), c.length = 0; }; for (a -= 1; a >= l && (!o || !o.hasData()); a--) { o && h(o.tileID.key); const e = s.calculateScaledKey(a); if (o = i.getTileByID(e), o && o.hasData()) break; const t = r[e]; if (null === t) break; void 0 === t ? c.push(e) : o = i.getTileByID(t); } return h(o ? o.tileID.key : null), o && o.hasData() ? o : null } findDEMTileFor(e) { return this.enabled ? this._findTileCoveringTileID(e, this.sourceCache) : null } prepareDrawTile() { this.renderedToTile = !0; } _clearRenderCacheForTile(e, t) { let i = this._tilesDirty[e]; i || (i = this._tilesDirty[e] = {}), i[t.key] = !0; } getWirefameBuffer() { if (!this.wireframeSegments) { const t = function(t) { let i = 0; const o = new e.StructArrayLayout2ui4, r = 131; for (let e = 1; e < 129; e++) { for (let t = 1; t < 129; t++) i = e * r + t, o.emplaceBack(i, i + 1), o.emplaceBack(i, i + r), o.emplaceBack(i + 1, i + r), 128 === e && o.emplaceBack(i + r, i + r + 1); o.emplaceBack(i + 1, i + 1 + r); } return o }(); this.wireframeIndexBuffer = this.painter.context.createIndexBuffer(t), this.wireframeSegments = e.SegmentVector.simpleSegment(0, 0, this.gridBuffer.length, t.length); } return [this.wireframeIndexBuffer, this.wireframeSegments] } } class Pi { static cacheKey(e, t, i, o) { let r = `${t}${o?o.cacheKey:""}`; for (const t of i) e.usedDefines.includes(t) && (r += `/${t}`); return r } constructor(t, i, o, r, n, s) { const a = t.gl; this.program = a.createProgram(); const l = function(e) { const t = []; for (let i = 0; i < e.length; i++) { if (null === e[i]) continue; const o = e[i].split(" "); t.push(o.pop()); } return t }(o.staticAttributes), c = r ? r.getBinderAttributes() : [], h = l.concat(c); let u = r ? r.defines() : []; u = u.concat(s.map((e => `#define ${e}`))); const _ = t.isWebGL2 ? "#version 300 es\n" : "", d = _ + u.concat(t.extStandardDerivatives && 0 === _.length ? "#extension GL_OES_standard_derivatives : enable\n".concat(hi) : hi, hi, ci, li.fragmentSource, si.fragmentSource, o.fragmentSource).join("\n"), p = _ + u.concat("\n#ifdef GL_ES\nprecision highp float;\n#else\n\n#if !defined(lowp)\n#define lowp\n#endif\n\n#if !defined(mediump)\n#define mediump\n#endif\n\n#if !defined(highp)\n#define highp\n#endif\n\n#endif", ci, li.vertexSource, si.vertexSource, ni.vertexSource, o.vertexSource).join("\n"), m = a.createShader(a.FRAGMENT_SHADER); if (a.isContextLost()) return void(this.failedToCreate = !0); a.shaderSource(m, d), a.compileShader(m), a.attachShader(this.program, m); const f = a.createShader(a.VERTEX_SHADER); if (a.isContextLost()) this.failedToCreate = !0; else { a.shaderSource(f, p), a.compileShader(f), a.attachShader(this.program, f), this.attributes = {}, this.numAttributes = h.length; for (let e = 0; e < this.numAttributes; e++) h[e] && (a.bindAttribLocation(this.program, e, h[e]), this.attributes[h[e]] = e); a.linkProgram(this.program), a.deleteShader(f), a.deleteShader(m), this.fixedUniforms = n(t), this.binderUniforms = r ? r.getUniforms(t) : [], s.includes("TERRAIN") && (this.terrainUniforms = (t => ({ u_dem: new e.Uniform1i(t), u_dem_prev: new e.Uniform1i(t), u_dem_unpack: new e.Uniform4f(t), u_dem_tl: new e.Uniform2f(t), u_dem_scale: new e.Uniform1f(t), u_dem_tl_prev: new e.Uniform2f(t), u_dem_scale_prev: new e.Uniform1f(t), u_dem_size: new e.Uniform1f(t), u_dem_lerp: new e.Uniform1f(t), u_exaggeration: new e.Uniform1f(t), u_depth: new e.Uniform1i(t), u_depth_size_inv: new e.Uniform2f(t), u_meter_to_dem: new e.Uniform1f(t), u_label_plane_matrix_inv: new e.UniformMatrix4f(t) }))(t)), s.includes("GLOBE") && (this.globeUniforms = (t => ({ u_tile_tl_up: new e.Uniform3f(t), u_tile_tr_up: new e.Uniform3f(t), u_tile_br_up: new e.Uniform3f(t), u_tile_bl_up: new e.Uniform3f(t), u_tile_up_scale: new e.Uniform1f(t) }))(t)), s.includes("FOG") && (this.fogUniforms = (t => ({ u_fog_matrix: new e.UniformMatrix4f(t), u_fog_range: new e.Uniform2f(t), u_fog_color: new e.Uniform4f(t), u_fog_horizon_blend: new e.Uniform1f(t), u_fog_temporal_offset: new e.Uniform1f(t), u_frustum_tl: new e.Uniform3f(t), u_frustum_tr: new e.Uniform3f(t), u_frustum_br: new e.Uniform3f(t), u_frustum_bl: new e.Uniform3f(t), u_globe_pos: new e.Uniform3f(t), u_globe_radius: new e.Uniform1f(t), u_globe_transition: new e.Uniform1f(t), u_is_globe: new e.Uniform1i(t), u_viewport: new e.Uniform2f(t) }))(t)); } } setTerrainUniformValues(e, t) { if (!this.terrainUniforms) return; const i = this.terrainUniforms; if (!this.failedToCreate) { e.program.set(this.program); for (const e in t) i[e] && i[e].set(this.program, e, t[e]); } } setGlobeUniformValues(e, t) { if (!this.globeUniforms) return; const i = this.globeUniforms; if (!this.failedToCreate) { e.program.set(this.program); for (const e in t) i[e] && i[e].set(this.program, e, t[e]); } } setFogUniformValues(e, t) { if (!this.fogUniforms) return; const i = this.fogUniforms; if (!this.failedToCreate) { e.program.set(this.program); for (const e in t) i[e].set(this.program, e, t[e]); } } draw(e, t, i, o, r, n, s, a, l, c, h, u, _, d, p) { const m = e.gl; if (this.failedToCreate) return; e.program.set(this.program), e.setDepthMode(i), e.setStencilMode(o), e.setColorMode(r), e.setCullFace(n); for (const e of Object.keys(this.fixedUniforms)) this.fixedUniforms[e].set(this.program, e, s[e]); d && d.setUniforms(this.program, e, this.binderUniforms, u, { zoom: _ }); const f = { [m.LINES]: 2, [m.TRIANGLES]: 3, [m.LINE_STRIP]: 1 }[t]; for (const i of h.get()) { const o = i.vaos || (i.vaos = {}); (o[a] || (o[a] = new pi)).bind(e, this, l, d ? d.getPaintVertexBuffers() : [], c, i.vertexOffset, p || []), m.drawElements(t, i.primitiveLength * f, m.UNSIGNED_SHORT, i.primitiveOffset * f * 2); } } } function Ri(e, t) { const i = Math.pow(2, t.tileID.overscaledZ), o = t.tileSize * Math.pow(2, e.transform.tileZoom) / i, r = o * (t.tileID.canonical.x + t.tileID.wrap * i), n = o * t.tileID.canonical.y; return { u_image: 0, u_texsize: t.imageAtlasTexture.size, u_tile_units_to_pixels: 1 / P(t, 1, e.transform.tileZoom), u_pixel_coord_upper: [r >> 16, n >> 16], u_pixel_coord_lower: [65535 & r, 65535 & n] } } const Oi = e.create(), Bi = (t, i, o, r, n, s, a, l, c, h, u) => { const _ = i.style.light, d = _.properties.get("position"), p = [d.x, d.y, d.z], m = e.create$1(); "viewport" === _.properties.get("anchor") && (e.fromRotation(m, -i.transform.angle), e.transformMat3(p, p, m)); const f = _.properties.get("color"), g = i.transform, v = { u_matrix: t, u_lightpos: p, u_lightintensity: _.properties.get("intensity"), u_lightcolor: [f.r, f.g, f.b], u_vertical_gradient: +o, u_opacity: r, u_tile_id: [0, 0, 0], u_zoom_transition: 0, u_inv_rot_matrix: Oi, u_merc_center: [0, 0], u_up_dir: [0, 0, 0], u_height_lift: 0, u_ao: n, u_edge_radius: s }; return "globe" === g.projection.name && (v.u_tile_id = [a.canonical.x, a.canonical.y, 1 << a.canonical.z], v.u_zoom_transition = c, v.u_inv_rot_matrix = u, v.u_merc_center = h, v.u_up_dir = g.projection.upVector(new e.CanonicalTileID(0, 0, 0), h[0] * e.EXTENT, h[1] * e.EXTENT), v.u_height_lift = l), v }, ki = (t, i, o, r, n, s, a, l, c, h, u, _) => { const d = Bi(t, i, o, r, n, s, a, c, h, u, _), p = { u_height_factor: -Math.pow(2, a.overscaledZ) / l.tileSize / 8 }; return e.extend(d, Ri(i, l), p) }, Fi = e => ({ u_matrix: e }), Ui = (t, i, o) => e.extend(Fi(t), Ri(i, o)), Ni = (e, t) => ({ u_matrix: e, u_world: t }), Gi = (t, i, o, r) => e.extend(Ui(t, i, o), { u_world: r }), ji = e.create(), Zi = (t, i, o, r, n, s) => { const a = t.transform, l = "globe" === a.projection.name; let c; if ("map" === s.paint.get("circle-pitch-alignment")) if (l) { const t = e.globePixelsToTileUnits(a.zoom, i.canonical) * a._pixelsPerMercatorPixel; c = Float32Array.from([t, 0, 0, t]); } else c = a.calculatePixelsToTileUnitsMatrix(o); else c = new Float32Array([a.pixelsToGLUnits[0], 0, 0, a.pixelsToGLUnits[1]]); const h = { u_camera_to_center_distance: a.cameraToCenterDistance, u_matrix: t.translatePosMatrix(i.projMatrix, o, s.paint.get("circle-translate"), s.paint.get("circle-translate-anchor")), u_device_pixel_ratio: e.exported.devicePixelRatio, u_extrude_scale: c, u_inv_rot_matrix: ji, u_merc_center: [0, 0], u_tile_id: [0, 0, 0], u_zoom_transition: 0, u_up_dir: [0, 0, 0] }; if (l) { h.u_inv_rot_matrix = r, h.u_merc_center = n, h.u_tile_id = [i.canonical.x, i.canonical.y, 1 << i.canonical.z], h.u_zoom_transition = e.globeToMercatorTransition(a.zoom); const t = n[0] * e.EXTENT, o = n[1] * e.EXTENT; h.u_up_dir = a.projection.upVector(new e.CanonicalTileID(0, 0, 0), t, o); } return h }, Vi = e => { const t = []; return "map" === e.paint.get("circle-pitch-alignment") && t.push("PITCH_WITH_MAP"), "map" === e.paint.get("circle-pitch-scale") && t.push("SCALE_WITH_MAP"), t }, Wi = (t, i, o, r) => { const n = e.EXTENT / o.tileSize; return { u_matrix: t, u_camera_to_center_distance: i.getCameraToCenterDistance(r), u_extrude_scale: [i.pixelsToGLUnits[0] / n, i.pixelsToGLUnits[1] / n] } }, Xi = (e, t, i = 1) => ({ u_matrix: e, u_color: t, u_overlay: 0, u_overlay_scale: i }), qi = e.create(), $i = (t, i, o, r, n, s, a) => { const l = t.transform, c = "globe" === l.projection.name, h = c ? e.globePixelsToTileUnits(l.zoom, i.canonical) * l._pixelsPerMercatorPixel : P(o, 1, s), u = { u_matrix: i.projMatrix, u_extrude_scale: h, u_intensity: a, u_inv_rot_matrix: qi, u_merc_center: [0, 0], u_tile_id: [0, 0, 0], u_zoom_transition: 0, u_up_dir: [0, 0, 0] }; if (c) { u.u_inv_rot_matrix = r, u.u_merc_center = n, u.u_tile_id = [i.canonical.x, i.canonical.y, 1 << i.canonical.z], u.u_zoom_transition = e.globeToMercatorTransition(l.zoom); const t = n[0] * e.EXTENT, o = n[1] * e.EXTENT; u.u_up_dir = l.projection.upVector(new e.CanonicalTileID(0, 0, 0), t, o); } return u }, Hi = (e, t, i, o, r, n, s) => { const a = e.transform, l = a.calculatePixelsToTileUnitsMatrix(t); return { u_matrix: Ji(e, t, i, o), u_pixels_to_tile_units: l, u_device_pixel_ratio: n, u_units_to_pixels: [1 / a.pixelsToGLUnits[0], 1 / a.pixelsToGLUnits[1]], u_dash_image: 0, u_gradient_image: 1, u_image_height: r, u_texsize: Qi(i) ? t.lineAtlasTexture.size : [0, 0], u_tile_units_to_pixels: Ki(t, e.transform), u_alpha_discard_threshold: 0, u_trim_offset: s } }, Yi = (e, t, i, o, r) => { const n = e.transform; return { u_matrix: Ji(e, t, i, o), u_texsize: t.imageAtlasTexture.size, u_pixels_to_tile_units: n.calculatePixelsToTileUnitsMatrix(t), u_device_pixel_ratio: r, u_image: 0, u_tile_units_to_pixels: Ki(t, n), u_units_to_pixels: [1 / n.pixelsToGLUnits[0], 1 / n.pixelsToGLUnits[1]], u_alpha_discard_threshold: 0 } }; function Ki(e, t) { return 1 / P(e, 1, t.tileZoom) } function Ji(e, t, i, o) { return e.translatePosMatrix(o || t.tileID.projMatrix, t, i.paint.get("line-translate"), i.paint.get("line-translate-anchor")) } function Qi(e) { const t = e.paint.get("line-dasharray").value; return t.value || "constant" !== t.kind } const eo = (e, t, i, o, r, n) => { return { u_matrix: e, u_tl_parent: t, u_scale_parent: i, u_fade_t: o.mix, u_opacity: o.opacity * r.paint.get("raster-opacity"), u_image0: 0, u_image1: 1, u_brightness_low: r.paint.get("raster-brightness-min"), u_brightness_high: r.paint.get("raster-brightness-max"), u_saturation_factor: (a = r.paint.get("raster-saturation"), a > 0 ? 1 - 1 / (1.001 - a) : -a), u_contrast_factor: (s = r.paint.get("raster-contrast"), s > 0 ? 1 / (1 - s) : 1 + s), u_spin_weights: to(r.paint.get("raster-hue-rotate")), u_perspective_transform: n }; var s, a; }; function to(e) { e *= Math.PI / 180; const t = Math.sin(e), i = Math.cos(e); return [(2 * i + 1) / 3, (-Math.sqrt(3) * t - i + 1) / 3, (Math.sqrt(3) * t - i + 1) / 3] } const io = e.create(), oo = (t, i, o, r, n, s, a, l, c, h, u, _, d, p, m, f) => { const g = n.transform, v = { u_is_size_zoom_constant: +("constant" === t || "source" === t), u_is_size_feature_constant: +("constant" === t || "camera" === t), u_size_t: i ? i.uSizeT : 0, u_size: i ? i.uSize : 0, u_camera_to_center_distance: g.cameraToCenterDistance, u_rotate_symbol: +o, u_aspect_ratio: g.width / g.height, u_fade_change: n.options.fadeDuration ? n.symbolFadeChange : 1, u_matrix: s, u_label_plane_matrix: a, u_coord_matrix: l, u_is_text: +c, u_pitch_with_map: +r, u_texsize: h, u_texture: 0, u_tile_id: [0, 0, 0], u_zoom_transition: 0, u_inv_rot_matrix: io, u_merc_center: [0, 0], u_camera_forward: [0, 0, 0], u_ecef_origin: [0, 0, 0], u_tile_matrix: io, u_up_vector: [0, -1, 0] }; return "globe" === f.name && (v.u_tile_id = [u.canonical.x, u.canonical.y, 1 << u.canonical.z], v.u_zoom_transition = _, v.u_inv_rot_matrix = p, v.u_merc_center = d, v.u_camera_forward = g._camera.forward(), v.u_ecef_origin = e.globeECEFOrigin(g.globeMatrix, u.toUnwrapped()), v.u_tile_matrix = Float32Array.from(g.globeMatrix), v.u_up_vector = m), v }, ro = (t, i, o, r, n, s, a, l, c, h, u, _, d, p, m, f, g) => e.extend(oo(t, i, o, r, n, s, a, l, c, h, _, d, p, m, f, g), { u_gamma_scale: r ? n.transform.cameraToCenterDistance * Math.cos(n.terrain ? 0 : n.transform._pitch) : 1, u_device_pixel_ratio: e.exported.devicePixelRatio, u_is_halo: +u }), no = (t, i, o, r, n, s, a, l, c, h, u, _, d, p, m, f) => e.extend(ro(t, i, o, r, n, s, a, l, !0, c, !0, u, _, d, p, m, f), { u_texsize_icon: h, u_texture_icon: 1 }), so = (e, t, i) => ({ u_matrix: e, u_opacity: t, u_color: i }), ao = (t, i, o, r, n) => e.extend(function(e, t, i) { const o = t.imageManager.getPattern(e.toString()), { width: r, height: n } = t.imageManager.getPixelSize(), s = Math.pow(2, i.tileID.overscaledZ), a = i.tileSize * Math.pow(2, t.transform.tileZoom) / s, l = a * (i.tileID.canonical.x + i.tileID.wrap * s), c = a * i.tileID.canonical.y; return { u_image: 0, u_pattern_tl: o.tl, u_pattern_br: o.br, u_texsize: [r, n], u_pattern_size: o.displaySize, u_tile_units_to_pixels: 1 / P(i, 1, t.transform.tileZoom), u_pixel_coord_upper: [l >> 16, c >> 16], u_pixel_coord_lower: [65535 & l, 65535 & c] } }(r, o, n), { u_matrix: t, u_opacity: i }), lo = { fillExtrusion: t => ({ u_matrix: new e.UniformMatrix4f(t), u_lightpos: new e.Uniform3f(t), u_lightintensity: new e.Uniform1f(t), u_lightcolor: new e.Uniform3f(t), u_vertical_gradient: new e.Uniform1f(t), u_opacity: new e.Uniform1f(t), u_edge_radius: new e.Uniform1f(t), u_ao: new e.Uniform2f(t), u_tile_id: new e.Uniform3f(t), u_zoom_transition: new e.Uniform1f(t), u_inv_rot_matrix: new e.UniformMatrix4f(t), u_merc_center: new e.Uniform2f(t), u_up_dir: new e.Uniform3f(t), u_height_lift: new e.Uniform1f(t) }), fillExtrusionPattern: t => ({ u_matrix: new e.UniformMatrix4f(t), u_lightpos: new e.Uniform3f(t), u_lightintensity: new e.Uniform1f(t), u_lightcolor: new e.Uniform3f(t), u_vertical_gradient: new e.Uniform1f(t), u_height_factor: new e.Uniform1f(t), u_edge_radius: new e.Uniform1f(t), u_ao: new e.Uniform2f(t), u_tile_id: new e.Uniform3f(t), u_zoom_transition: new e.Uniform1f(t), u_inv_rot_matrix: new e.UniformMatrix4f(t), u_merc_center: new e.Uniform2f(t), u_up_dir: new e.Uniform3f(t), u_height_lift: new e.Uniform1f(t), u_image: new e.Uniform1i(t), u_texsize: new e.Uniform2f(t), u_pixel_coord_upper: new e.Uniform2f(t), u_pixel_coord_lower: new e.Uniform2f(t), u_tile_units_to_pixels: new e.Uniform1f(t), u_opacity: new e.Uniform1f(t) }), fill: t => ({ u_matrix: new e.UniformMatrix4f(t) }), fillPattern: t => ({ u_matrix: new e.UniformMatrix4f(t), u_image: new e.Uniform1i(t), u_texsize: new e.Uniform2f(t), u_pixel_coord_upper: new e.Uniform2f(t), u_pixel_coord_lower: new e.Uniform2f(t), u_tile_units_to_pixels: new e.Uniform1f(t) }), fillOutline: t => ({ u_matrix: new e.UniformMatrix4f(t), u_world: new e.Uniform2f(t) }), fillOutlinePattern: t => ({ u_matrix: new e.UniformMatrix4f(t), u_world: new e.Uniform2f(t), u_image: new e.Uniform1i(t), u_texsize: new e.Uniform2f(t), u_pixel_coord_upper: new e.Uniform2f(t), u_pixel_coord_lower: new e.Uniform2f(t), u_tile_units_to_pixels: new e.Uniform1f(t) }), circle: t => ({ u_camera_to_center_distance: new e.Uniform1f(t), u_extrude_scale: new e.UniformMatrix2f(t), u_device_pixel_ratio: new e.Uniform1f(t), u_matrix: new e.UniformMatrix4f(t), u_inv_rot_matrix: new e.UniformMatrix4f(t), u_merc_center: new e.Uniform2f(t), u_tile_id: new e.Uniform3f(t), u_zoom_transition: new e.Uniform1f(t), u_up_dir: new e.Uniform3f(t) }), collisionBox: t => ({ u_matrix: new e.UniformMatrix4f(t), u_camera_to_center_distance: new e.Uniform1f(t), u_extrude_scale: new e.Uniform2f(t) }), collisionCircle: t => ({ u_matrix: new e.UniformMatrix4f(t), u_inv_matrix: new e.UniformMatrix4f(t), u_camera_to_center_distance: new e.Uniform1f(t), u_viewport_size: new e.Uniform2f(t) }), debug: t => ({ u_color: new e.UniformColor(t), u_matrix: new e.UniformMatrix4f(t), u_overlay: new e.Uniform1i(t), u_overlay_scale: new e.Uniform1f(t) }), clippingMask: t => ({ u_matrix: new e.UniformMatrix4f(t) }), heatmap: t => ({ u_extrude_scale: new e.Uniform1f(t), u_intensity: new e.Uniform1f(t), u_matrix: new e.UniformMatrix4f(t), u_inv_rot_matrix: new e.UniformMatrix4f(t), u_merc_center: new e.Uniform2f(t), u_tile_id: new e.Uniform3f(t), u_zoom_transition: new e.Uniform1f(t), u_up_dir: new e.Uniform3f(t) }), heatmapTexture: t => ({ u_image: new e.Uniform1i(t), u_color_ramp: new e.Uniform1i(t), u_opacity: new e.Uniform1f(t) }), hillshade: t => ({ u_matrix: new e.UniformMatrix4f(t), u_image: new e.Uniform1i(t), u_latrange: new e.Uniform2f(t), u_light: new e.Uniform2f(t), u_shadow: new e.UniformColor(t), u_highlight: new e.UniformColor(t), u_accent: new e.UniformColor(t) }), hillshadePrepare: t => ({ u_matrix: new e.UniformMatrix4f(t), u_image: new e.Uniform1i(t), u_dimension: new e.Uniform2f(t), u_zoom: new e.Uniform1f(t), u_unpack: new e.Uniform4f(t) }), line: t => ({ u_matrix: new e.UniformMatrix4f(t), u_pixels_to_tile_units: new e.UniformMatrix2f(t), u_device_pixel_ratio: new e.Uniform1f(t), u_units_to_pixels: new e.Uniform2f(t), u_dash_image: new e.Uniform1i(t), u_gradient_image: new e.Uniform1i(t), u_image_height: new e.Uniform1f(t), u_texsize: new e.Uniform2f(t), u_tile_units_to_pixels: new e.Uniform1f(t), u_alpha_discard_threshold: new e.Uniform1f(t), u_trim_offset: new e.Uniform2f(t) }), linePattern: t => ({ u_matrix: new e.UniformMatrix4f(t), u_texsize: new e.Uniform2f(t), u_pixels_to_tile_units: new e.UniformMatrix2f(t), u_device_pixel_ratio: new e.Uniform1f(t), u_image: new e.Uniform1i(t), u_units_to_pixels: new e.Uniform2f(t), u_tile_units_to_pixels: new e.Uniform1f(t), u_alpha_discard_threshold: new e.Uniform1f(t) }), raster: t => ({ u_matrix: new e.UniformMatrix4f(t), u_tl_parent: new e.Uniform2f(t), u_scale_parent: new e.Uniform1f(t), u_fade_t: new e.Uniform1f(t), u_opacity: new e.Uniform1f(t), u_image0: new e.Uniform1i(t), u_image1: new e.Uniform1i(t), u_brightness_low: new e.Uniform1f(t), u_brightness_high: new e.Uniform1f(t), u_saturation_factor: new e.Uniform1f(t), u_contrast_factor: new e.Uniform1f(t), u_spin_weights: new e.Uniform3f(t), u_perspective_transform: new e.Uniform2f(t) }), symbolIcon: t => ({ u_is_size_zoom_constant: new e.Uniform1i(t), u_is_size_feature_constant: new e.Uniform1i(t), u_size_t: new e.Uniform1f(t), u_size: new e.Uniform1f(t), u_camera_to_center_distance: new e.Uniform1f(t), u_rotate_symbol: new e.Uniform1i(t), u_aspect_ratio: new e.Uniform1f(t), u_fade_change: new e.Uniform1f(t), u_matrix: new e.UniformMatrix4f(t), u_label_plane_matrix: new e.UniformMatrix4f(t), u_coord_matrix: new e.UniformMatrix4f(t), u_is_text: new e.Uniform1i(t), u_pitch_with_map: new e.Uniform1i(t), u_texsize: new e.Uniform2f(t), u_tile_id: new e.Uniform3f(t), u_zoom_transition: new e.Uniform1f(t), u_inv_rot_matrix: new e.UniformMatrix4f(t), u_merc_center: new e.Uniform2f(t), u_camera_forward: new e.Uniform3f(t), u_tile_matrix: new e.UniformMatrix4f(t), u_up_vector: new e.Uniform3f(t), u_ecef_origin: new e.Uniform3f(t), u_texture: new e.Uniform1i(t) }), symbolSDF: t => ({ u_is_size_zoom_constant: new e.Uniform1i(t), u_is_size_feature_constant: new e.Uniform1i(t), u_size_t: new e.Uniform1f(t), u_size: new e.Uniform1f(t), u_camera_to_center_distance: new e.Uniform1f(t), u_rotate_symbol: new e.Uniform1i(t), u_aspect_ratio: new e.Uniform1f(t), u_fade_change: new e.Uniform1f(t), u_matrix: new e.UniformMatrix4f(t), u_label_plane_matrix: new e.UniformMatrix4f(t), u_coord_matrix: new e.UniformMatrix4f(t), u_is_text: new e.Uniform1i(t), u_pitch_with_map: new e.Uniform1i(t), u_texsize: new e.Uniform2f(t), u_texture: new e.Uniform1i(t), u_gamma_scale: new e.Uniform1f(t), u_device_pixel_ratio: new e.Uniform1f(t), u_tile_id: new e.Uniform3f(t), u_zoom_transition: new e.Uniform1f(t), u_inv_rot_matrix: new e.UniformMatrix4f(t), u_merc_center: new e.Uniform2f(t), u_camera_forward: new e.Uniform3f(t), u_tile_matrix: new e.UniformMatrix4f(t), u_up_vector: new e.Uniform3f(t), u_ecef_origin: new e.Uniform3f(t), u_is_halo: new e.Uniform1i(t) }), symbolTextAndIcon: t => ({ u_is_size_zoom_constant: new e.Uniform1i(t), u_is_size_feature_constant: new e.Uniform1i(t), u_size_t: new e.Uniform1f(t), u_size: new e.Uniform1f(t), u_camera_to_center_distance: new e.Uniform1f(t), u_rotate_symbol: new e.Uniform1i(t), u_aspect_ratio: new e.Uniform1f(t), u_fade_change: new e.Uniform1f(t), u_matrix: new e.UniformMatrix4f(t), u_label_plane_matrix: new e.UniformMatrix4f(t), u_coord_matrix: new e.UniformMatrix4f(t), u_is_text: new e.Uniform1i(t), u_pitch_with_map: new e.Uniform1i(t), u_texsize: new e.Uniform2f(t), u_texsize_icon: new e.Uniform2f(t), u_texture: new e.Uniform1i(t), u_texture_icon: new e.Uniform1i(t), u_gamma_scale: new e.Uniform1f(t), u_device_pixel_ratio: new e.Uniform1f(t), u_is_halo: new e.Uniform1i(t) }), background: t => ({ u_matrix: new e.UniformMatrix4f(t), u_opacity: new e.Uniform1f(t), u_color: new e.UniformColor(t) }), backgroundPattern: t => ({ u_matrix: new e.UniformMatrix4f(t), u_opacity: new e.Uniform1f(t), u_image: new e.Uniform1i(t), u_pattern_tl: new e.Uniform2f(t), u_pattern_br: new e.Uniform2f(t), u_texsize: new e.Uniform2f(t), u_pattern_size: new e.Uniform2f(t), u_pixel_coord_upper: new e.Uniform2f(t), u_pixel_coord_lower: new e.Uniform2f(t), u_tile_units_to_pixels: new e.Uniform1f(t) }), terrainRaster: xi, terrainDepth: xi, skybox: t => ({ u_matrix: new e.UniformMatrix4f(t), u_sun_direction: new e.Uniform3f(t), u_cubemap: new e.Uniform1i(t), u_opacity: new e.Uniform1f(t), u_temporal_offset: new e.Uniform1f(t) }), skyboxGradient: t => ({ u_matrix: new e.UniformMatrix4f(t), u_color_ramp: new e.Uniform1i(t), u_center_direction: new e.Uniform3f(t), u_radius: new e.Uniform1f(t), u_opacity: new e.Uniform1f(t), u_temporal_offset: new e.Uniform1f(t) }), skyboxCapture: t => ({ u_matrix_3f: new e.UniformMatrix3f(t), u_sun_direction: new e.Uniform3f(t), u_sun_intensity: new e.Uniform1f(t), u_color_tint_r: new e.Uniform4f(t), u_color_tint_m: new e.Uniform4f(t), u_luminance: new e.Uniform1f(t) }), globeRaster: t => ({ u_proj_matrix: new e.UniformMatrix4f(t), u_globe_matrix: new e.UniformMatrix4f(t), u_normalize_matrix: new e.UniformMatrix4f(t), u_merc_matrix: new e.UniformMatrix4f(t), u_zoom_transition: new e.Uniform1f(t), u_merc_center: new e.Uniform2f(t), u_image0: new e.Uniform1i(t), u_grid_matrix: new e.UniformMatrix3f(t), u_skirt_height: new e.Uniform1f(t), u_frustum_tl: new e.Uniform3f(t), u_frustum_tr: new e.Uniform3f(t), u_frustum_br: new e.Uniform3f(t), u_frustum_bl: new e.Uniform3f(t), u_globe_pos: new e.Uniform3f(t), u_globe_radius: new e.Uniform1f(t), u_viewport: new e.Uniform2f(t) }), globeAtmosphere: t => ({ u_frustum_tl: new e.Uniform3f(t), u_frustum_tr: new e.Uniform3f(t), u_frustum_br: new e.Uniform3f(t), u_frustum_bl: new e.Uniform3f(t), u_horizon: new e.Uniform1f(t), u_transition: new e.Uniform1f(t), u_fadeout_range: new e.Uniform1f(t), u_color: new e.Uniform4f(t), u_high_color: new e.Uniform4f(t), u_space_color: new e.Uniform4f(t), u_star_intensity: new e.Uniform1f(t), u_star_density: new e.Uniform1f(t), u_star_size: new e.Uniform1f(t), u_temporal_offset: new e.Uniform1f(t), u_horizon_angle: new e.Uniform1f(t), u_rotation_matrix: new e.UniformMatrix4f(t) }) }; let co; function ho(t, i, o, r, n, s, a) { const l = t.context, c = l.gl, h = t.transform, u = t.useProgram("collisionBox"), _ = []; let d = 0, p = 0; for (let m = 0; m < r.length; m++) { const f = r[m], g = i.getTile(f), v = g.getBucket(o); if (!v) continue; const x = yt(f, v, h); let y = x; 0 === n[0] && 0 === n[1] || (y = t.translatePosMatrix(x, g, n, s)); const b = a ? v.textCollisionBox : v.iconCollisionBox, w = v.collisionCircleArray; if (w.length > 0) { const t = e.create(), i = y; e.mul(t, v.placementInvProjMatrix, h.glCoordMatrix), e.mul(t, t, v.placementViewportMatrix), _.push({ circleArray: w, circleOffset: p, transform: i, invTransform: t, projection: v.getProjection() }), d += w.length / 4, p = d; } b && (t.terrain && t.terrain.setupElevationDraw(g, u), u.draw(l, c.LINES, e.DepthMode.disabled, e.StencilMode.disabled, t.colorModeForRenderPass(), e.CullFaceMode.disabled, Wi(y, h, g, v.getProjection()), o.id, b.layoutVertexBuffer, b.indexBuffer, b.segments, null, h.zoom, null, [b.collisionVertexBuffer, b.collisionVertexBufferExt])); } if (!a || !_.length) return; const m = t.useProgram("collisionCircle"), f = new e.StructArrayLayout2f1f2i16; f.resize(4 * d), f._trim(); let g = 0; for (const e of _) for (let t = 0; t < e.circleArray.length / 4; t++) { const i = 4 * t, o = e.circleArray[i + 0], r = e.circleArray[i + 1], n = e.circleArray[i + 2], s = e.circleArray[i + 3]; f.emplace(g++, o, r, n, s, 0), f.emplace(g++, o, r, n, s, 1), f.emplace(g++, o, r, n, s, 2), f.emplace(g++, o, r, n, s, 3); }(!co || co.length < 2 * d) && (co = function(t) { const i = 2 * t, o = new e.StructArrayLayout3ui6; o.resize(i), o._trim(); for (let e = 0; e < i; e++) { const t = 6 * e; o.uint16[t + 0] = 4 * e + 0, o.uint16[t + 1] = 4 * e + 1, o.uint16[t + 2] = 4 * e + 2, o.uint16[t + 3] = 4 * e + 2, o.uint16[t + 4] = 4 * e + 3, o.uint16[t + 5] = 4 * e + 0; } return o }(d)); const v = l.createIndexBuffer(co, !0), x = l.createVertexBuffer(f, e.collisionCircleLayout.members, !0); for (const i of _) { const r = { u_matrix: i.transform, u_inv_matrix: i.invTransform, u_camera_to_center_distance: (y = h).getCameraToCenterDistance(i.projection), u_viewport_size: [y.width, y.height] }; m.draw(l, c.TRIANGLES, e.DepthMode.disabled, e.StencilMode.disabled, t.colorModeForRenderPass(), e.CullFaceMode.disabled, r, o.id, x, v, e.SegmentVector.simpleSegment(0, 2 * i.circleOffset, i.circleArray.length, i.circleArray.length / 2), null, h.zoom); } var y; x.destroy(), v.destroy(); } const uo = e.create(); function _o({ width: t, height: i, anchor: o, textOffset: r, textScale: n }, s) { const { horizontalAlign: a, verticalAlign: l } = e.getAnchorAlignment(o), c = -(a - .5) * t, h = -(l - .5) * i, u = e.evaluateVariableOffset(o, r); return new e.pointGeometry((c / n + u[0]) * s, (h / n + u[1]) * s) } function po(t, i, o, r, n, s, a, l, c, h, u) { const _ = t.text.placedSymbolArray, d = t.text.dynamicLayoutVertexArray, p = t.icon.dynamicLayoutVertexArray, m = {}, f = t.getProjection(), g = bt(l, f, s), v = s.elevation, x = f.upVectorScale(l.canonical, s.center.lat, s.worldSize).metersToTile; d.clear(); for (let p = 0; p < _.length; p++) { const y = _.get(p), { tileAnchorX: b, tileAnchorY: w, numGlyphs: T } = y, E = t.allowVerticalPlacement && !y.placedOrientation, C = y.hidden || !y.crossTileID || E ? null : r[y.crossTileID]; if (C) { let r = 0, _ = 0, p = 0; if (v) { const e = v ? v.getAtTileOffset(l, b, w) : 0, [t, i, o] = f.upVector(l.canonical, b, w); r = e * t * x, _ = e * i * x, p = e * o * x; } let [E, M, I, S] = nt(y.projectedAnchorX + r, y.projectedAnchorY + _, y.projectedAnchorZ + p, o ? g : a); const D = st(s.getCameraToCenterDistance(f), S); let L = n.evaluateSizeForFeature(t.textSizeData, h, y) * D / e.ONE_EM; o && (L *= t.tilePixelRatio / c); const A = _o(C, L); o ? (({ x: E, y: M, z: I } = f.projectTilePoint(b + A.x, w + A.y, l.canonical)), [E, M, I] = nt(E + r, M + _, I + p, a)) : (i && A._rotate(-s.angle), E += A.x, M += A.y, I = 0); const z = t.allowVerticalPlacement && y.placedOrientation === e.WritingMode.vertical ? Math.PI / 2 : 0; for (let t = 0; t < T; t++) e.addDynamicAttributes(d, E, M, I, z); u && y.associatedIconIndex >= 0 && (m[y.associatedIconIndex] = { x: E, y: M, z: I, angle: z }); } else mt(T, d); } if (u) { p.clear(); const i = t.icon.placedSymbolArray; for (let t = 0; t < i.length; t++) { const o = i.get(t), { numGlyphs: r } = o, n = m[t]; if (o.hidden || !n) mt(r, p); else { const { x: t, y: i, z: o, angle: s } = n; for (let n = 0; n < r; n++) e.addDynamicAttributes(p, t, i, o, s); } } t.icon.dynamicLayoutVertexBuffer.updateData(p); } t.text.dynamicLayoutVertexBuffer.updateData(d); } function mo(e, t, i) { return i.iconsInText && t ? "symbolTextAndIcon" : e ? "symbolSDF" : "symbolIcon" } function fo(t, i, o, r, n, s, a, l, c, h, u, _) { const d = t.context, p = d.gl, m = t.transform, f = "map" === l, g = "map" === c, v = f && "point" !== o.layout.get("symbol-placement"), x = f && !g && !v, y = void 0 !== o.layout.get("symbol-sort-key").constantOr(1); let b = !1; const w = t.depthModeForSublayer(0, e.DepthMode.ReadOnly), T = [e.mercatorXfromLng(m.center.lng), e.mercatorYfromLat(m.center.lat)], E = o.layout.get("text-variable-anchor"), C = "globe" === m.projection.name, M = [], I = [0, -1, 0]; let S = I; !C && !m.mercatorFromTransition || f || (S = function(t) { const i = t._camera.getWorldToCamera(t.worldSize, 1), o = e.multiply([], i, t.globeMatrix); e.invert(o, o); const r = [0, 0, 0], n = [0, 1, 0, 0]; return e.transformMat4$1(n, n, o), r[0] = n[0], r[1] = n[1], r[2] = n[2], e.normalize(r, r), r }(m)); for (const l of r) { const r = i.getTile(l), c = r.getBucket(o); if (!c) continue; if ("mercator" === c.projection.name && C) continue; const u = n ? c.text : c.icon; if (!u || c.fullyClipped || !u.segments.get().length) continue; const _ = u.programConfigurations.get(o.id), d = n || c.sdfIcons, w = n ? c.textSizeData : c.iconSizeData, D = g || 0 !== m.pitch, L = e.evaluateSizeForZoom(w, m.zoom); let A, z, P, R, O = [0, 0], B = null; if (n) { if (z = r.glyphAtlasTexture, P = p.LINEAR, A = r.glyphAtlasTexture.size, c.iconsInText) { O = r.imageAtlasTexture.size, B = r.imageAtlasTexture; const e = "composite" === w.kind || "camera" === w.kind; R = D || t.options.rotating || t.options.zooming || e ? p.LINEAR : p.NEAREST; } } else { const e = 1 !== o.layout.get("icon-size").constantOr(0) || c.iconsNeedLinear; z = r.imageAtlasTexture, P = d || t.options.rotating || t.options.zooming || e || D ? p.LINEAR : p.NEAREST, A = r.imageAtlasTexture.size; } const k = "globe" === c.projection.name, F = k ? S : I, U = k ? e.globeToMercatorTransition(m.zoom) : 0, N = bt(l, c.getProjection(), m), G = m.calculatePixelsToTileUnitsMatrix(r), j = it(N, r.tileID.canonical, g, f, m, c.getProjection(), G), Z = t.terrain && g && v ? e.invert(e.create(), j) : uo, V = rt(N, r.tileID.canonical, g, f, m, c.getProjection(), G), W = E && c.hasTextData(), X = "none" !== o.layout.get("icon-text-fit") && W && c.hasIconData(); if (v) { const e = m.elevation, i = e ? e.getAtTileOffsetFunc(l, m.center.lat, m.worldSize, c.getProjection()) : null, o = ot(N, r.tileID.canonical, g, f, m, c.getProjection(), G); lt(c, N, t, n, o, V, g, h, i, l); } const q = v || n && E || X, $ = t.translatePosMatrix(N, r, s, a), H = q ? uo : j, Y = t.translatePosMatrix(V, r, s, a, !0), K = c.getProjection().createInversionMatrix(m, l.canonical), J = []; t.terrainRenderModeElevated() && g && J.push("PITCH_WITH_MAP_TERRAIN"), k && J.push("PROJECTION_GLOBE_VIEW"), q && J.push("PROJECTED_POS_ON_VIEWPORT"); const Q = d && 0 !== o.paint.get(n ? "text-halo-width" : "icon-halo-width").constantOr(1); let ee; ee = d ? c.iconsInText ? no(w.kind, L, x, g, t, $, H, Y, A, O, l, U, T, K, F, c.getProjection()) : ro(w.kind, L, x, g, t, $, H, Y, n, A, !0, l, U, T, K, F, c.getProjection()) : oo(w.kind, L, x, g, t, $, H, Y, n, A, l, U, T, K, F, c.getProjection()); const te = { program: t.useProgram(mo(d, n, c), _, J), buffers: u, uniformValues: ee, atlasTexture: z, atlasTextureIcon: B, atlasInterpolation: P, atlasInterpolationIcon: R, isSDF: d, hasHalo: Q, tile: r, labelPlaneMatrixInv: Z }; if (y && c.canOverlap) { b = !0; const t = u.segments.get(); for (const i of t) M.push({ segments: new e.SegmentVector([i]), sortKey: i.sortKey, state: te }); } else M.push({ segments: u.segments, sortKey: 0, state: te }); } b && M.sort(((e, t) => e.sortKey - t.sortKey)); for (const e of M) { const i = e.state; if (t.terrain && t.terrain.setupElevationDraw(i.tile, i.program, { useDepthForOcclusion: !C, labelPlaneMatrixInv: i.labelPlaneMatrixInv }), d.activeTexture.set(p.TEXTURE0), i.atlasTexture.bind(i.atlasInterpolation, p.CLAMP_TO_EDGE), i.atlasTextureIcon && (d.activeTexture.set(p.TEXTURE1), i.atlasTextureIcon && i.atlasTextureIcon.bind(i.atlasInterpolationIcon, p.CLAMP_TO_EDGE)), i.isSDF) { const r = i.uniformValues; i.hasHalo && (r.u_is_halo = 1, go(i.buffers, e.segments, o, t, i.program, w, u, _, r)), r.u_is_halo = 0; } go(i.buffers, e.segments, o, t, i.program, w, u, _, i.uniformValues); } } function go(t, i, o, r, n, s, a, l, c) { const h = r.context, u = [t.dynamicLayoutVertexBuffer, t.opacityVertexBuffer, t.globeExtVertexBuffer]; n.draw(h, h.gl.TRIANGLES, s, a, l, e.CullFaceMode.disabled, c, o.id, t.layoutVertexBuffer, t.indexBuffer, i, o.paint, r.transform.zoom, t.programConfigurations.get(o.id), u); } function vo(t, i, o, r, n, s, a) { const l = t.context.gl, c = o.paint.get("fill-pattern"), h = c && c.constantOr(1); let u, _, d, p, m; a ? (_ = h && !o.getPaintProperty("fill-outline-color") ? "fillOutlinePattern" : "fillOutline", u = l.LINES) : (_ = h ? "fillPattern" : "fill", u = l.TRIANGLES); for (const f of r) { const r = i.getTile(f); if (h && !r.patternsLoaded()) continue; const g = r.getBucket(o); if (!g) continue; t.prepareDrawTile(); const v = g.programConfigurations.get(o.id), x = t.useProgram(_, v); h && (t.context.activeTexture.set(l.TEXTURE0), r.imageAtlasTexture.bind(l.LINEAR, l.CLAMP_TO_EDGE), v.updatePaintBuffers()); const y = c.constantOr(null); if (y && r.imageAtlas) { const e = r.imageAtlas.patternPositions[y.toString()]; e && v.setConstantPatternPositions(e); } const b = t.translatePosMatrix(f.projMatrix, r, o.paint.get("fill-translate"), o.paint.get("fill-translate-anchor")); if (a) { p = g.indexBuffer2, m = g.segments2; const e = t.terrain && t.terrain.renderingToTexture ? t.terrain.drapeBufferSize : [l.drawingBufferWidth, l.drawingBufferHeight]; d = "fillOutlinePattern" === _ && h ? Gi(b, t, r, e) : Ni(b, e); } else p = g.indexBuffer, m = g.segments, d = h ? Ui(b, t, r) : Fi(b); t.prepareDrawProgram(t.context, x, f.toUnwrapped()), x.draw(t.context, u, n, t.stencilModeForClipping(f), s, e.CullFaceMode.disabled, d, o.id, g.layoutVertexBuffer, p, m, o.paint, t.transform.zoom, v); } } function xo(t, i, o, r, n, s, a) { const l = t.context, c = l.gl, h = t.transform, u = o.paint.get("fill-extrusion-pattern"), _ = u.constantOr(1), d = o.paint.get("fill-extrusion-opacity"), p = [o.paint.get("fill-extrusion-ambient-occlusion-intensity"), o.paint.get("fill-extrusion-ambient-occlusion-radius")], m = o.layout.get("fill-extrusion-edge-radius"), f = "globe" === h.projection.name ? e.fillExtrusionHeightLift() : 0, g = "globe" === h.projection.name, v = g ? e.globeToMercatorTransition(h.zoom) : 0, x = [e.mercatorXfromLng(h.center.lng), e.mercatorYfromLat(h.center.lat)], y = []; g && y.push("PROJECTION_GLOBE_VIEW"), p[0] > 0 && y.push("FAUX_AO"); for (const b of r) { const r = i.getTile(b), w = r.getBucket(o); if (!w || w.projection.name !== h.projection.name) continue; const T = w.programConfigurations.get(o.id), E = t.useProgram(_ ? "fillExtrusionPattern" : "fillExtrusion", T, y); if (t.terrain) { const e = t.terrain; if (t.style.terrainSetForDrapingOnly()) e.setupElevationDraw(r, E, { useMeterToDem: !0 }); else { if (!w.enableTerrain) continue; if (e.setupElevationDraw(r, E, { useMeterToDem: !0 }), yo(l, i, b, w, o, e), !w.centroidVertexBuffer) { const e = E.attributes.a_centroid_pos; void 0 !== e && c.vertexAttrib2f(e, 0, 0); } } } _ && (t.context.activeTexture.set(c.TEXTURE0), r.imageAtlasTexture.bind(c.LINEAR, c.CLAMP_TO_EDGE), T.updatePaintBuffers()); const C = u.constantOr(null); if (C && r.imageAtlas) { const e = r.imageAtlas.patternPositions[C.toString()]; e && T.setConstantPatternPositions(e); } const M = t.translatePosMatrix(b.projMatrix, r, o.paint.get("fill-extrusion-translate"), o.paint.get("fill-extrusion-translate-anchor")), I = h.projection.createInversionMatrix(h, b.canonical), S = o.paint.get("fill-extrusion-vertical-gradient"), D = _ ? ki(M, t, S, d, p, m, b, r, f, v, x, I) : Bi(M, t, S, d, p, m, b, f, v, x, I); t.prepareDrawProgram(l, E, b.toUnwrapped()); const L = []; t.terrain && L.push(w.centroidVertexBuffer), g && L.push(w.layoutVertexExtBuffer), E.draw(l, l.gl.TRIANGLES, n, s, a, e.CullFaceMode.backCCW, D, o.id, w.layoutVertexBuffer, w.indexBuffer, w.segments, o.paint, t.transform.zoom, T, L); } } function yo(t, i, o, r, n, s) { const a = [t => { let i = t.canonical.x - 1, o = t.wrap; return i < 0 && (i = (1 << t.canonical.z) - 1, o--), new e.OverscaledTileID(t.overscaledZ, o, t.canonical.z, i, t.canonical.y) }, t => { let i = t.canonical.x + 1, o = t.wrap; return i === 1 << t.canonical.z && (i = 0, o++), new e.OverscaledTileID(t.overscaledZ, o, t.canonical.z, i, t.canonical.y) }, t => new e.OverscaledTileID(t.overscaledZ, t.wrap, t.canonical.z, t.canonical.x, (0 === t.canonical.y ? 1 << t.canonical.z : t.canonical.y) - 1), t => new e.OverscaledTileID(t.overscaledZ, t.wrap, t.canonical.z, t.canonical.x, t.canonical.y === (1 << t.canonical.z) - 1 ? 0 : t.canonical.y + 1)], l = e => { const t = i.getSource().minzoom, o = e => { const t = i.getTileByID(e); if (t && t.hasData()) return t.getBucket(n) }, r = [0, -1, 1]; for (const i of r) { if (e.overscaledZ + i < t) continue; const r = o(e.calculateScaledKey(e.overscaledZ + i)); if (r) return r } }, c = [0, 0, 0], h = (t, i) => (c[0] = Math.min(t.min.y, i.min.y), c[1] = Math.max(t.max.y, i.max.y), c[2] = e.EXTENT - i.min.x > t.max.x ? i.min.x - e.EXTENT : t.max.x, c), u = (t, i) => (c[0] = Math.min(t.min.x, i.min.x), c[1] = Math.max(t.max.x, i.max.x), c[2] = e.EXTENT - i.min.y > t.max.y ? i.min.y - e.EXTENT : t.max.y, c), _ = [(e, t) => h(e, t), (e, t) => h(t, e), (e, t) => u(e, t), (e, t) => u(t, e)], d = new e.pointGeometry(0, 0); let p, m, f; const g = (t, i, r, n, a) => { const l = [ [n ? r : t, n ? t : r, 0], [n ? r : i, n ? i : r, 0] ], c = a < 0 ? e.EXTENT + a : a, h = [n ? c : (t + i) / 2, n ? (t + i) / 2 : c, 0]; return 0 === r && a < 0 || 0 !== r && a > 0 ? s.getForTilePoints(f, [h], !0, m) : l.push(h), s.getForTilePoints(o, l, !0, p), Math.max(l[0][2], l[1][2], h[2]) / s.exaggeration() }; for (let t = 0; t < 4; t++) { const i = (t < 2 ? 1 : 5) - t, n = r.borders[t]; if (0 === n.length) continue; const c = f = a[t](o), h = l(c); if (!(h && h instanceof e.FillExtrusionBucket && h.enableTerrain)) continue; if (r.borderDoneWithNeighborZ[t] === h.canonical.z && h.borderDoneWithNeighborZ[i] === r.canonical.z) continue; if (m = s.findDEMTileFor(c), !m || !m.dem) continue; if (!p) { const e = s.findDEMTileFor(o); if (!e || !e.dem) return; p = e; } const u = h.borders[i]; let v = 0; const x = h.borderDoneWithNeighborZ[i] !== r.canonical.z; if (r.canonical.z === h.canonical.z) { for (let o = 0; o < n.length; o++) { const s = r.featuresOnBorder[n[o]], a = s.borders[t]; let l; for (; v < u.length && (l = h.featuresOnBorder[u[v]], !(l.borders[i][1] > a[0] + 3));) x && h.encodeCentroid(void 0, l, !1), v++; if (l && v < u.length) { const o = v; let n = 0; for (; !(l.borders[i][0] > a[1] - 3) && (n++, ++v !== u.length);) l = h.featuresOnBorder[u[v]]; if (l = h.featuresOnBorder[u[o]], s.intersectsCount() > 1 || l.intersectsCount() > 1 || 1 !== n) { 1 !== n && (v = o), r.encodeCentroid(void 0, s, !1), x && h.encodeCentroid(void 0, l, !1); continue } const c = _[t](s, l), p = t % 2 ? e.EXTENT - 1 : 0; d.x = g(c[0], Math.min(e.EXTENT - 1, c[1]), p, t < 2, c[2]), d.y = 0, r.encodeCentroid(d, s, !1), x && h.encodeCentroid(d, l, !1); } else r.encodeCentroid(void 0, s, !1); } r.borderDoneWithNeighborZ[t] = h.canonical.z, r.needsCentroidUpdate = !0, x && (h.borderDoneWithNeighborZ[i] = r.canonical.z, h.needsCentroidUpdate = !0); } else { for (const e of n) r.encodeCentroid(void 0, r.featuresOnBorder[e], !1); if (x) { for (const e of u) h.encodeCentroid(void 0, h.featuresOnBorder[e], !1); h.borderDoneWithNeighborZ[i] = r.canonical.z, h.needsCentroidUpdate = !0; } r.borderDoneWithNeighborZ[t] = h.canonical.z, r.needsCentroidUpdate = !0; } }(r.needsCentroidUpdate || !r.centroidVertexBuffer && 0 !== r.centroidVertexArray.length) && r.uploadCentroid(t); } const bo = new e.Color(1, 0, 0, 1), wo = new e.Color(0, 1, 0, 1), To = new e.Color(0, 0, 1, 1), Eo = new e.Color(1, 0, 1, 1), Co = new e.Color(0, 1, 1, 1); function Mo(t, i, o) { const r = t.context, n = t.transform, s = r.gl, a = "globe" === n.projection.name, l = a ? ["PROJECTION_GLOBE_VIEW"] : null; let c = o.projMatrix; if (a && e.globeToMercatorTransition(n.zoom) > 0) { const t = e.transitionTileAABBinECEF(o.canonical, n), i = e.globeDenormalizeECEF(t); c = e.multiply(new Float32Array(16), n.globeMatrix, i), e.multiply(c, n.projMatrix, c); } const h = t.useProgram("debug", null, l), u = i.getTileByID(o.key); t.terrain && t.terrain.setupElevationDraw(u, h); const _ = e.DepthMode.disabled, d = e.StencilMode.disabled, p = t.colorModeForRenderPass(), m = "$debug"; r.activeTexture.set(s.TEXTURE0), t.emptyTexture.bind(s.LINEAR, s.CLAMP_TO_EDGE), a ? u._makeGlobeTileDebugBuffers(t.context, n) : u._makeDebugTileBoundsBuffers(t.context, n.projection); const f = u._tileDebugBuffer || t.debugBuffer, g = u._tileDebugIndexBuffer || t.debugIndexBuffer, v = u._tileDebugSegments || t.debugSegments; h.draw(r, s.LINE_STRIP, _, d, p, e.CullFaceMode.disabled, Xi(c, e.Color.red), m, f, g, v, null, null, null, [u._globeTileDebugBorderBuffer]); const x = u.latestRawTileData, y = Math.floor((x && x.byteLength || 0) / 1024), b = i.getTile(o).tileSize, w = 512 / Math.min(b, 512) * (o.overscaledZ / n.zoom) * .5; let T = o.canonical.toString(); o.overscaledZ !== o.canonical.z && (T += ` => ${o.overscaledZ}`), T += ` ${y}kb`, function(e, t) { e.initDebugOverlayCanvas(); const i = e.debugOverlayCanvas, o = e.context.gl, r = e.debugOverlayCanvas.getContext("2d"); r.clearRect(0, 0, i.width, i.height), r.shadowColor = "white", r.shadowBlur = 2, r.lineWidth = 1.5, r.strokeStyle = "white", r.textBaseline = "top", r.font = "bold 36px Open Sans, sans-serif", r.fillText(t, 5, 5), r.strokeText(t, 5, 5), e.debugOverlayTexture.update(i), e.debugOverlayTexture.bind(o.LINEAR, o.CLAMP_TO_EDGE); }(t, T); const E = u._tileDebugTextBuffer || t.debugBuffer, C = u._tileDebugTextIndexBuffer || t.quadTriangleIndexBuffer, M = u._tileDebugTextSegments || t.debugSegments; h.draw(r, s.TRIANGLES, _, d, e.ColorMode.alphaBlended, e.CullFaceMode.disabled, Xi(c, e.Color.transparent, w), m, E, C, M, null, null, null, [u._globeTileDebugTextBuffer]); } function Io(e, t, i, o) { Do(e, 0, t + i / 2, e.transform.width, i, o); } function So(e, t, i, o) { Do(e, t - i / 2, 0, i, e.transform.height, o); } function Do(t, i, o, r, n, s) { const a = t.context, l = a.gl; l.enable(l.SCISSOR_TEST), l.scissor(i * e.exported.devicePixelRatio, o * e.exported.devicePixelRatio, r * e.exported.devicePixelRatio, n * e.exported.devicePixelRatio), a.clear({ color: s }), l.disable(l.SCISSOR_TEST); } const Lo = e.createLayout([{ name: "a_pos_3f", components: 3, type: "Float32" }]), { members: Ao } = Lo; function zo(e, t, i, o) { e.emplaceBack(t, i, o); } class Po { constructor(t) { this.vertexArray = new e.StructArrayLayout3f12, this.indices = new e.StructArrayLayout3ui6, zo(this.vertexArray, -1, -1, 1), zo(this.vertexArray, 1, -1, 1), zo(this.vertexArray, -1, 1, 1), zo(this.vertexArray, 1, 1, 1), zo(this.vertexArray, -1, -1, -1), zo(this.vertexArray, 1, -1, -1), zo(this.vertexArray, -1, 1, -1), zo(this.vertexArray, 1, 1, -1), this.indices.emplaceBack(5, 1, 3), this.indices.emplaceBack(3, 7, 5), this.indices.emplaceBack(6, 2, 0), this.indices.emplaceBack(0, 4, 6), this.indices.emplaceBack(2, 6, 7), this.indices.emplaceBack(7, 3, 2), this.indices.emplaceBack(5, 4, 0), this.indices.emplaceBack(0, 1, 5), this.indices.emplaceBack(0, 2, 3), this.indices.emplaceBack(3, 1, 0), this.indices.emplaceBack(7, 6, 4), this.indices.emplaceBack(4, 5, 7), this.vertexBuffer = t.createVertexBuffer(this.vertexArray, Ao), this.indexBuffer = t.createIndexBuffer(this.indices), this.segment = e.SegmentVector.simpleSegment(0, 0, 36, 12); } } function Ro(t, i, o, r, n, s) { const a = t.gl, l = i.paint.get("sky-atmosphere-color"), c = i.paint.get("sky-atmosphere-halo-color"), h = i.paint.get("sky-atmosphere-sun-intensity"), u = ((e, t, i, o, r) => ({ u_matrix_3f: e, u_sun_direction: t, u_sun_intensity: i, u_color_tint_r: [o.r, o.g, o.b, o.a], u_color_tint_m: [r.r, r.g, r.b, r.a], u_luminance: 5e-5 }))(e.fromMat4(e.create$1(), r), n, h, l, c); a.framebufferTexture2D(a.FRAMEBUFFER, a.COLOR_ATTACHMENT0, a.TEXTURE_CUBE_MAP_POSITIVE_X + s, i.skyboxTexture, 0), o.draw(t, a.TRIANGLES, e.DepthMode.disabled, e.StencilMode.disabled, e.ColorMode.unblended, e.CullFaceMode.frontCW, u, "skyboxCapture", i.skyboxGeometry.vertexBuffer, i.skyboxGeometry.indexBuffer, i.skyboxGeometry.segment); } const Oo = e.createLayout([{ type: "Float32", name: "a_pos", components: 3 }, { type: "Float32", name: "a_uv", components: 2 }]); class Bo { constructor(t) { const i = new e.StructArrayLayout5f20; i.emplaceBack(-1, 1, 1, 0, 0), i.emplaceBack(1, 1, 1, 1, 0), i.emplaceBack(1, -1, 1, 1, 1), i.emplaceBack(-1, -1, 1, 0, 1); const o = new e.StructArrayLayout3ui6; o.emplaceBack(0, 1, 2), o.emplaceBack(2, 3, 0), this.vertexBuffer = t.createVertexBuffer(i, Oo.members), this.indexBuffer = t.createIndexBuffer(o), this.segments = e.SegmentVector.simpleSegment(0, 0, 4, 2); } destroy() { this.vertexBuffer.destroy(), this.indexBuffer.destroy(), this.segments.destroy(); } } const ko = { symbol: function(t, i, o, r, n) { if ("translucent" !== t.renderPass) return; const s = e.StencilMode.disabled, a = t.colorModeForRenderPass(); o.layout.get("text-variable-anchor") && function(t, i, o, r, n, s, a) { const l = i.transform, c = "map" === n, h = "map" === s; for (const i of t) { const t = r.getTile(i), n = t.getBucket(o); if (!n || !n.text || !n.text.segments.get().length) continue; const s = e.evaluateSizeForZoom(n.textSizeData, l.zoom), u = bt(i, n.getProjection(), l), _ = l.calculatePixelsToTileUnitsMatrix(t), d = it(u, t.tileID.canonical, h, c, l, n.getProjection(), _), p = "none" !== o.layout.get("icon-text-fit") && n.hasIconData(); if (s) { const o = Math.pow(2, l.zoom - t.tileID.overscaledZ); po(n, c, h, a, e.symbolSize, l, d, i, o, s, p); } } }(r, t, o, i, o.layout.get("text-rotation-alignment"), o.layout.get("text-pitch-alignment"), n), 0 !== o.paint.get("icon-opacity").constantOr(1) && fo(t, i, o, r, !1, o.paint.get("icon-translate"), o.paint.get("icon-translate-anchor"), o.layout.get("icon-rotation-alignment"), o.layout.get("icon-pitch-alignment"), o.layout.get("icon-keep-upright"), s, a), 0 !== o.paint.get("text-opacity").constantOr(1) && fo(t, i, o, r, !0, o.paint.get("text-translate"), o.paint.get("text-translate-anchor"), o.layout.get("text-rotation-alignment"), o.layout.get("text-pitch-alignment"), o.layout.get("text-keep-upright"), s, a), i.map.showCollisionBoxes && (ho(t, i, o, r, o.paint.get("text-translate"), o.paint.get("text-translate-anchor"), !0), ho(t, i, o, r, o.paint.get("icon-translate"), o.paint.get("icon-translate-anchor"), !1)); }, circle: function(t, i, o, r) { if ("translucent" !== t.renderPass) return; const n = o.paint.get("circle-opacity"), s = o.paint.get("circle-stroke-width"), a = o.paint.get("circle-stroke-opacity"), l = void 0 !== o.layout.get("circle-sort-key").constantOr(1); if (0 === n.constantOr(1) && (0 === s.constantOr(1) || 0 === a.constantOr(1))) return; const c = t.context, h = c.gl, u = t.transform, _ = t.depthModeForSublayer(0, e.DepthMode.ReadOnly), d = e.StencilMode.disabled, p = t.colorModeForRenderPass(), m = "globe" === u.projection.name, f = [e.mercatorXfromLng(u.center.lng), e.mercatorYfromLat(u.center.lat)], g = []; for (let n = 0; n < r.length; n++) { const s = r[n], a = i.getTile(s), c = a.getBucket(o); if (!c || c.projection.name !== u.projection.name) continue; const h = c.programConfigurations.get(o.id), _ = Vi(o); m && _.push("PROJECTION_GLOBE_VIEW"); const d = t.useProgram("circle", h, _), p = c.layoutVertexBuffer, v = c.globeExtVertexBuffer, x = c.indexBuffer, y = u.projection.createInversionMatrix(u, s.canonical), b = { programConfiguration: h, program: d, layoutVertexBuffer: p, globeExtVertexBuffer: v, indexBuffer: x, uniformValues: Zi(t, s, a, y, f, o), tile: a }; if (l) { const t = c.segments.get(); for (const i of t) g.push({ segments: new e.SegmentVector([i]), sortKey: i.sortKey, state: b }); } else g.push({ segments: c.segments, sortKey: 0, state: b }); } l && g.sort(((e, t) => e.sortKey - t.sortKey)); const v = { useDepthForOcclusion: !m }; for (const i of g) { const { programConfiguration: r, program: n, layoutVertexBuffer: s, globeExtVertexBuffer: a, indexBuffer: l, uniformValues: m, tile: f } = i.state, g = i.segments; t.terrain && t.terrain.setupElevationDraw(f, n, v), t.prepareDrawProgram(c, n, f.tileID.toUnwrapped()), n.draw(c, h.TRIANGLES, _, d, p, e.CullFaceMode.disabled, m, o.id, s, l, g, o.paint, u.zoom, r, [a]); } }, heatmap: function(t, i, o, r) { if (0 !== o.paint.get("heatmap-opacity")) if ("offscreen" === t.renderPass) { const n = t.context, s = n.gl, a = e.StencilMode.disabled, l = new e.ColorMode([s.ONE, s.ONE], e.Color.transparent, [!0, !0, !0, !0]); ! function(e, t, i, o) { const r = e.gl, n = t.width * o, s = t.height * o; e.activeTexture.set(r.TEXTURE1), e.viewport.set([0, 0, n, s]); let a = i.heatmapFbo; if (!a || a && (a.width !== n || a.height !== s)) { a && a.destroy(); const t = r.createTexture(); r.bindTexture(r.TEXTURE_2D, t), r.texParameteri(r.TEXTURE_2D, r.TEXTURE_WRAP_S, r.CLAMP_TO_EDGE), r.texParameteri(r.TEXTURE_2D, r.TEXTURE_WRAP_T, r.CLAMP_TO_EDGE), r.texParameteri(r.TEXTURE_2D, r.TEXTURE_MIN_FILTER, r.LINEAR), r.texParameteri(r.TEXTURE_2D, r.TEXTURE_MAG_FILTER, r.LINEAR), a = i.heatmapFbo = e.createFramebuffer(n, s, !1), function(e, t, i, o, r, n) { const s = e.gl; s.texImage2D(s.TEXTURE_2D, 0, e.isWebGL2 && e.extRenderToTextureHalfFloat ? s.RGBA16F : s.RGBA, r, n, 0, s.RGBA, e.extRenderToTextureHalfFloat ? e.isWebGL2 ? s.HALF_FLOAT : e.extTextureHalfFloat.HALF_FLOAT_OES : s.UNSIGNED_BYTE, null), o.colorAttachment.set(i); }(e, 0, t, a, n, s); } else r.bindTexture(r.TEXTURE_2D, a.colorAttachment.get()), e.bindFramebuffer.set(a.framebuffer); }(n, t, o, "globe" === t.transform.projection.name ? .5 : .25), n.clear({ color: e.Color.transparent }); const c = t.transform, h = "globe" === c.projection.name, u = h ? ["PROJECTION_GLOBE_VIEW"] : null, _ = h ? e.CullFaceMode.frontCCW : e.CullFaceMode.disabled, d = [e.mercatorXfromLng(c.center.lng), e.mercatorYfromLat(c.center.lat)]; for (let p = 0; p < r.length; p++) { const m = r[p]; if (i.hasRenderableParent(m)) continue; const f = i.getTile(m), g = f.getBucket(o); if (!g || g.projection.name !== c.projection.name) continue; const v = g.programConfigurations.get(o.id), x = t.useProgram("heatmap", v, u), { zoom: y } = t.transform; t.terrain && t.terrain.setupElevationDraw(f, x), t.prepareDrawProgram(n, x, m.toUnwrapped()); const b = c.projection.createInversionMatrix(c, m.canonical); x.draw(n, s.TRIANGLES, e.DepthMode.disabled, a, l, _, $i(t, m, f, b, d, y, o.paint.get("heatmap-intensity")), o.id, g.layoutVertexBuffer, g.indexBuffer, g.segments, o.paint, t.transform.zoom, v, h ? [g.globeExtVertexBuffer] : null); } n.viewport.set([0, 0, t.width, t.height]); } else "translucent" === t.renderPass && (t.context.setColorMode(t.colorModeForRenderPass()), function(t, i) { const o = t.context, r = o.gl, n = i.heatmapFbo; if (!n) return; o.activeTexture.set(r.TEXTURE0), r.bindTexture(r.TEXTURE_2D, n.colorAttachment.get()), o.activeTexture.set(r.TEXTURE1); let s = i.colorRampTexture; s || (s = i.colorRampTexture = new e.Texture(o, i.colorRamp, r.RGBA)), s.bind(r.LINEAR, r.CLAMP_TO_EDGE), t.useProgram("heatmapTexture").draw(o, r.TRIANGLES, e.DepthMode.disabled, e.StencilMode.disabled, t.colorModeForRenderPass(), e.CullFaceMode.disabled, ((e, t, i, o) => ({ u_image: 0, u_color_ramp: 1, u_opacity: t.paint.get("heatmap-opacity") }))(0, i), i.id, t.viewportBuffer, t.quadTriangleIndexBuffer, t.viewportSegments, i.paint, t.transform.zoom); }(t, o)); }, line: function(t, i, o, r) { if ("translucent" !== t.renderPass) return; const n = o.paint.get("line-opacity"), s = o.paint.get("line-width"); if (0 === n.constantOr(1) || 0 === s.constantOr(1)) return; const a = t.depthModeForSublayer(0, e.DepthMode.ReadOnly), l = t.colorModeForRenderPass(), c = t.terrain && t.terrain.renderingToTexture ? 1 : e.exported.devicePixelRatio, h = o.paint.get("line-dasharray"), u = h.constantOr(1), _ = o.layout.get("line-cap"), d = o.paint.get("line-pattern"), p = d.constantOr(1), m = o.paint.get("line-gradient"), f = p ? "linePattern" : "line", g = t.context, v = g.gl, x = (e => { const t = []; Qi(e) && t.push("RENDER_LINE_DASH"), e.paint.get("line-gradient") && t.push("RENDER_LINE_GRADIENT"); const i = e.paint.get("line-trim-offset"); 0 === i[0] && 0 === i[1] || t.push("RENDER_LINE_TRIM_OFFSET"); const o = e.paint.get("line-pattern").constantOr(1), r = 1 !== e.paint.get("line-opacity").constantOr(1); return !o && r && t.push("RENDER_LINE_ALPHA_DISCARD"), t })(o); let y = x.includes("RENDER_LINE_ALPHA_DISCARD"); t.terrain && t.terrain.clipOrMaskOverlapStencilType() && (y = !1); for (const n of r) { const r = i.getTile(n); if (p && !r.patternsLoaded()) continue; const s = r.getBucket(o); if (!s) continue; t.prepareDrawTile(); const b = s.programConfigurations.get(o.id), w = t.useProgram(f, b, x), T = d.constantOr(null); if (T && r.imageAtlas) { const e = r.imageAtlas.patternPositions[T.toString()]; e && b.setConstantPatternPositions(e); } const E = h.constantOr(null), C = _.constantOr(null); if (!p && E && C && r.lineAtlas) { const e = r.lineAtlas.getDash(E, C); e && b.setConstantPatternPositions(e); } let [M, I] = o.paint.get("line-trim-offset"); if ("round" === C || "square" === C) { const e = 1; M !== I && (0 === M && (M -= e), 1 === I && (I += e)); } const S = t.terrain ? n.projMatrix : null, D = p ? Yi(t, r, o, S, c) : Hi(t, r, o, S, s.lineClipsArray.length, c, [M, I]); if (m) { const r = s.gradients[o.id]; let a = r.texture; if (o.gradientVersion !== r.version) { let l = 256; if (o.stepInterpolant) { const o = i.getSource().maxzoom, r = n.canonical.z === o ? Math.ceil(1 << t.transform.maxZoom - n.canonical.z) : 1; l = e.clamp(e.nextPowerOfTwo(s.maxLineLength / e.EXTENT * 1024 * r), 256, g.maxTextureSize); } r.gradient = e.renderColorRamp({ expression: o.gradientExpression(), evaluationKey: "lineProgress", resolution: l, image: r.gradient || void 0, clips: s.lineClipsArray }), r.texture ? r.texture.update(r.gradient) : r.texture = new e.Texture(g, r.gradient, v.RGBA), r.version = o.gradientVersion, a = r.texture; } g.activeTexture.set(v.TEXTURE1), a.bind(o.stepInterpolant ? v.NEAREST : v.LINEAR, v.CLAMP_TO_EDGE); } u && (g.activeTexture.set(v.TEXTURE0), r.lineAtlasTexture.bind(v.LINEAR, v.REPEAT), b.updatePaintBuffers()), p && (g.activeTexture.set(v.TEXTURE0), r.imageAtlasTexture.bind(v.LINEAR, v.CLAMP_TO_EDGE), b.updatePaintBuffers()), t.prepareDrawProgram(g, w, n.toUnwrapped()); const L = i => { w.draw(g, v.TRIANGLES, a, i, l, e.CullFaceMode.disabled, D, o.id, s.layoutVertexBuffer, s.indexBuffer, s.segments, o.paint, t.transform.zoom, b, [s.layoutVertexBuffer2]); }; if (y) { const i = t.stencilModeForClipping(n).ref; 0 === i && t.terrain && g.clear({ stencil: 0 }); const o = { func: v.EQUAL, mask: 255 }; D.u_alpha_discard_threshold = .8, L(new e.StencilMode(o, i, 255, v.KEEP, v.KEEP, v.INVERT)), D.u_alpha_discard_threshold = 0, L(new e.StencilMode(o, i, 255, v.KEEP, v.KEEP, v.KEEP)); } else L(t.stencilModeForClipping(n)); } y && (t.resetStencilClippingMasks(), t.terrain && g.clear({ stencil: 0 })); }, fill: function(t, i, o, r) { const n = o.paint.get("fill-color"), s = o.paint.get("fill-opacity"); if (0 === s.constantOr(1)) return; const a = t.colorModeForRenderPass(), l = o.paint.get("fill-pattern"), c = t.opaquePassEnabledForLayer() && !l.constantOr(1) && 1 === n.constantOr(e.Color.transparent).a && 1 === s.constantOr(0) ? "opaque" : "translucent"; if (t.renderPass === c) { const n = t.depthModeForSublayer(1, "opaque" === t.renderPass ? e.DepthMode.ReadWrite : e.DepthMode.ReadOnly); vo(t, i, o, r, n, a, !1); } if ("translucent" === t.renderPass && o.paint.get("fill-antialias")) { const n = t.depthModeForSublayer(o.getPaintProperty("fill-outline-color") ? 2 : 0, e.DepthMode.ReadOnly); vo(t, i, o, r, n, a, !0); } }, "fill-extrusion": function(t, i, o, r) { const n = o.paint.get("fill-extrusion-opacity"); if (0 !== n && "translucent" === t.renderPass) { const s = new e.DepthMode(t.context.gl.LEQUAL, e.DepthMode.ReadWrite, t.depthRangeFor3D); if (1 !== n || o.paint.get("fill-extrusion-pattern").constantOr(1)) xo(t, i, o, r, s, e.StencilMode.disabled, e.ColorMode.disabled), xo(t, i, o, r, s, t.stencilModeFor3D(), t.colorModeForRenderPass()), t.resetStencilClippingMasks(); else { const n = t.colorModeForRenderPass(); xo(t, i, o, r, s, e.StencilMode.disabled, n); } } }, hillshade: function(t, i, o, r) { if ("offscreen" !== t.renderPass && "translucent" !== t.renderPass) return; const n = t.context, s = t.depthModeForSublayer(0, e.DepthMode.ReadOnly), a = t.colorModeForRenderPass(), l = t.terrain && t.terrain.renderingToTexture, [c, h] = "translucent" !== t.renderPass || l ? [{}, r] : t.stencilConfigForOverlap(r); for (const r of h) { const n = i.getTile(r); if (n.needsHillshadePrepare && "offscreen" === t.renderPass) vi(t, n, o, s, e.StencilMode.disabled, a); else if ("translucent" === t.renderPass) { const e = l && t.terrain ? t.terrain.stencilModeForRTTOverlap(r) : c[r.overscaledZ]; fi(t, r, n, o, s, e, a); } } n.viewport.set([0, 0, t.width, t.height]), t.resetStencilClippingMasks(); }, raster: function(t, i, o, r, n, s) { if ("translucent" !== t.renderPass) return; if (0 === o.paint.get("raster-opacity")) return; if (!r.length) return; const a = t.context, l = a.gl, c = i.getSource(), h = t.useProgram("raster"), u = t.colorModeForRenderPass(), _ = t.terrain && t.terrain.renderingToTexture, [d, p] = c instanceof Ae || _ ? [{}, r] : t.stencilConfigForOverlap(r), m = p[p.length - 1].overscaledZ, f = !t.options.moving; for (const r of p) { const n = _ ? e.DepthMode.disabled : t.depthModeForSublayer(r.overscaledZ - m, 1 === o.paint.get("raster-opacity") ? e.DepthMode.ReadWrite : e.DepthMode.ReadOnly, l.LESS), p = r.toUnwrapped(), g = i.getTile(r); if (_ && (!g || !g.hasData())) continue; const v = _ ? r.projMatrix : t.transform.calculateProjMatrix(p, f), x = t.terrain && _ ? t.terrain.stencilModeForRTTOverlap(r) : d[r.overscaledZ], y = s ? 0 : o.paint.get("raster-fade-duration"); g.registerFadeDuration(y); const b = i.findLoadedParent(r, 0), w = Si(g, b, i, t.transform, y); let T, E; t.terrain && t.terrain.prepareDrawTile(); const C = "nearest" === o.paint.get("raster-resampling") ? l.NEAREST : l.LINEAR; a.activeTexture.set(l.TEXTURE0), g.texture.bind(C, l.CLAMP_TO_EDGE), a.activeTexture.set(l.TEXTURE1), b ? (b.texture.bind(C, l.CLAMP_TO_EDGE), T = Math.pow(2, b.tileID.overscaledZ - g.tileID.overscaledZ), E = [g.tileID.canonical.x * T % 1, g.tileID.canonical.y * T % 1]) : g.texture.bind(C, l.CLAMP_TO_EDGE), g.texture.useMipmap && a.extTextureFilterAnisotropic && t.transform.pitch > 20 && l.texParameterf(l.TEXTURE_2D, a.extTextureFilterAnisotropic.TEXTURE_MAX_ANISOTROPY_EXT, a.extTextureFilterAnisotropicMax); const M = eo(v, E || [0, 0], T || 1, w, o, c instanceof Ae ? c.perspectiveTransform : [0, 0]); if (t.prepareDrawProgram(a, h, p), c instanceof Ae) c.boundsBuffer && c.boundsSegments && h.draw(a, l.TRIANGLES, n, e.StencilMode.disabled, u, e.CullFaceMode.disabled, M, o.id, c.boundsBuffer, t.quadTriangleIndexBuffer, c.boundsSegments); else { const { tileBoundsBuffer: i, tileBoundsIndexBuffer: r, tileBoundsSegments: s } = t.getTileBoundsBuffers(g); h.draw(a, l.TRIANGLES, n, x, u, e.CullFaceMode.disabled, M, o.id, i, r, s); } } t.resetStencilClippingMasks(); }, background: function(t, i, o, r) { const n = o.paint.get("background-color"), s = o.paint.get("background-opacity"); if (0 === s) return; const a = t.context, l = a.gl, c = t.transform, h = c.tileSize, u = o.paint.get("background-pattern"); if (t.isPatternMissing(u)) return; const _ = !u && 1 === n.a && 1 === s && t.opaquePassEnabledForLayer() ? "opaque" : "translucent"; if (t.renderPass !== _) return; const d = e.StencilMode.disabled, p = t.depthModeForSublayer(0, "opaque" === _ ? e.DepthMode.ReadWrite : e.DepthMode.ReadOnly), m = t.colorModeForRenderPass(), f = t.useProgram(u ? "backgroundPattern" : "background"); let g, v = r; v || (g = t.getBackgroundTiles(), v = Object.values(g).map((e => e.tileID))), u && (a.activeTexture.set(l.TEXTURE0), t.imageManager.bind(t.context)); for (const _ of v) { const v = _.toUnwrapped(), x = r ? _.projMatrix : t.transform.calculateProjMatrix(v); t.prepareDrawTile(); const y = i ? i.getTile(_) : g ? g[_.key] : new e.Tile(_, h, c.zoom, t), b = u ? ao(x, s, t, u, { tileID: _, tileSize: h }) : so(x, s, n); t.prepareDrawProgram(a, f, v); const { tileBoundsBuffer: w, tileBoundsIndexBuffer: T, tileBoundsSegments: E } = t.getTileBoundsBuffers(y); f.draw(a, l.TRIANGLES, p, d, m, e.CullFaceMode.disabled, b, o.id, w, T, E); } }, sky: function(t, i, o) { const r = t.transform, n = "mercator" === r.projection.name || "globe" === r.projection.name ? 1 : e.smoothstep(7, 8, r.zoom), s = o.paint.get("sky-opacity") * n; if (0 === s) return; const a = t.context, l = o.paint.get("sky-type"), c = new e.DepthMode(a.gl.LEQUAL, e.DepthMode.ReadOnly, [0, 1]), h = t.frameCounter / 1e3 % 1; "atmosphere" === l ? "offscreen" === t.renderPass ? o.needsSkyboxCapture(t) && (function(t, i, o, r) { const n = t.context, s = n.gl; let a = i.skyboxFbo; if (!a) { a = i.skyboxFbo = n.createFramebuffer(32, 32, !1), i.skyboxGeometry = new Po(n), i.skyboxTexture = n.gl.createTexture(), s.bindTexture(s.TEXTURE_CUBE_MAP, i.skyboxTexture), s.texParameteri(s.TEXTURE_CUBE_MAP, s.TEXTURE_WRAP_S, s.CLAMP_TO_EDGE), s.texParameteri(s.TEXTURE_CUBE_MAP, s.TEXTURE_WRAP_T, s.CLAMP_TO_EDGE), s.texParameteri(s.TEXTURE_CUBE_MAP, s.TEXTURE_MIN_FILTER, s.LINEAR), s.texParameteri(s.TEXTURE_CUBE_MAP, s.TEXTURE_MAG_FILTER, s.LINEAR); for (let e = 0; e < 6; ++e) s.texImage2D(s.TEXTURE_CUBE_MAP_POSITIVE_X + e, 0, s.RGBA, 32, 32, 0, s.RGBA, s.UNSIGNED_BYTE, null); } n.bindFramebuffer.set(a.framebuffer), n.viewport.set([0, 0, 32, 32]); const l = i.getCenter(t, !0), c = t.useProgram("skyboxCapture"), h = new Float64Array(16); e.identity(h), e.rotateY(h, h, .5 * -Math.PI), Ro(n, i, c, h, l, 0), e.identity(h), e.rotateY(h, h, .5 * Math.PI), Ro(n, i, c, h, l, 1), e.identity(h), e.rotateX(h, h, .5 * -Math.PI), Ro(n, i, c, h, l, 2), e.identity(h), e.rotateX(h, h, .5 * Math.PI), Ro(n, i, c, h, l, 3), e.identity(h), Ro(n, i, c, h, l, 4), e.identity(h), e.rotateY(h, h, Math.PI), Ro(n, i, c, h, l, 5), n.viewport.set([0, 0, t.width, t.height]); }(t, o), o.markSkyboxValid(t)) : "sky" === t.renderPass && function(t, i, o, r, n) { const s = t.context, a = s.gl, l = t.transform, c = t.useProgram("skybox"); s.activeTexture.set(a.TEXTURE0), a.bindTexture(a.TEXTURE_CUBE_MAP, i.skyboxTexture); const h = ((e, t, i, o, r) => ({ u_matrix: e, u_sun_direction: t, u_cubemap: 0, u_opacity: o, u_temporal_offset: r }))(l.skyboxMatrix, i.getCenter(t, !1), 0, r, n); t.prepareDrawProgram(s, c), c.draw(s, a.TRIANGLES, o, e.StencilMode.disabled, t.colorModeForRenderPass(), e.CullFaceMode.backCW, h, "skybox", i.skyboxGeometry.vertexBuffer, i.skyboxGeometry.indexBuffer, i.skyboxGeometry.segment); }(t, o, c, s, h) : "gradient" === l && "sky" === t.renderPass && function(t, i, o, r, n) { const s = t.context, a = s.gl, l = t.transform, c = t.useProgram("skyboxGradient"); i.skyboxGeometry || (i.skyboxGeometry = new Po(s)), s.activeTexture.set(a.TEXTURE0); let h = i.colorRampTexture; h || (h = i.colorRampTexture = new e.Texture(s, i.colorRamp, a.RGBA)), h.bind(a.LINEAR, a.CLAMP_TO_EDGE); const u = ((t, i, o, r, n) => ({ u_matrix: t, u_color_ramp: 0, u_center_direction: i, u_radius: e.degToRad(o), u_opacity: r, u_temporal_offset: n }))(l.skyboxMatrix, i.getCenter(t, !1), i.paint.get("sky-gradient-radius"), r, n); t.prepareDrawProgram(s, c), c.draw(s, a.TRIANGLES, o, e.StencilMode.disabled, t.colorModeForRenderPass(), e.CullFaceMode.backCW, u, "skyboxGradient", i.skyboxGeometry.vertexBuffer, i.skyboxGeometry.indexBuffer, i.skyboxGeometry.segment); }(t, o, c, s, h); }, debug: function(e, t, i) { for (let o = 0; o < i.length; o++) Mo(e, t, i[o]); }, custom: function(t, i, o, r) { const n = t.context, s = o.implementation; if (!t.transform.projection.unsupportedLayers || !t.transform.projection.unsupportedLayers.includes("custom") || t.terrain && (t.terrain.renderingToTexture || "offscreen" === t.renderPass) && o.isLayerDraped()) { if ("offscreen" === t.renderPass) { const i = s.prerender; if (i) { if (t.setCustomLayerDefaults(), n.setColorMode(t.colorModeForRenderPass()), "globe" === t.transform.projection.name) { const o = t.transform.pointMerc; i.call(s, n.gl, t.transform.customLayerMatrix(), t.transform.getProjection(), t.transform.globeToMercatorMatrix(), e.globeToMercatorTransition(t.transform.zoom), [o.x, o.y], t.transform.pixelsPerMeterRatio); } else i.call(s, n.gl, t.transform.customLayerMatrix()); n.setDirty(), t.setBaseState(); } } else if ("translucent" === t.renderPass) { if (t.terrain && t.terrain.renderingToTexture) { const i = s.renderToTile; if (i) { const o = r[0].canonical, a = new e.MercatorCoordinate(o.x + r[0].wrap * (1 << o.z), o.y, o.z); n.setDepthMode(e.DepthMode.disabled), n.setStencilMode(e.StencilMode.disabled), n.setColorMode(t.colorModeForRenderPass()), t.setCustomLayerDefaults(), i.call(s, n.gl, a), n.setDirty(), t.setBaseState(); } return } t.setCustomLayerDefaults(), n.setColorMode(t.colorModeForRenderPass()), n.setStencilMode(e.StencilMode.disabled); const i = "3d" === s.renderingMode ? new e.DepthMode(t.context.gl.LEQUAL, e.DepthMode.ReadWrite, t.depthRangeFor3D) : t.depthModeForSublayer(0, e.DepthMode.ReadOnly); if (n.setDepthMode(i), "globe" === t.transform.projection.name) { const i = t.transform.pointMerc; s.render(n.gl, t.transform.customLayerMatrix(), t.transform.getProjection(), t.transform.globeToMercatorMatrix(), e.globeToMercatorTransition(t.transform.zoom), [i.x, i.y], t.transform.pixelsPerMeterRatio); } else s.render(n.gl, t.transform.customLayerMatrix()); n.setDirty(), t.setBaseState(), n.bindFramebuffer.set(null); } } else e.warnOnce("Custom layers are not yet supported with this projection. Use mercator or globe to enable usage of custom layers."); } }; class Fo { constructor(t, i, o = !1) { this.context = new Me(t, o), this.transform = i, this._tileTextures = {}, this.frameCopies = [], this.loadTimeStamps = [], this.setup(), this.numSublayers = e.SourceCache.maxUnderzooming + e.SourceCache.maxOverzooming + 1, this.depthEpsilon = 1 / Math.pow(2, 16), this.crossTileSymbolIndex = new qt, this.deferredRenderGpuTimeQueries = [], this.gpuTimers = {}, this.frameCounter = 0, this._backgroundTiles = {}; } updateTerrain(e, t) { const i = !!e && !!e.terrain && this.transform.projection.supportsTerrain; if (!(i || this._terrain && this._terrain.enabled)) return; this._terrain || (this._terrain = new zi(this, e)); const o = this._terrain; this.transform.elevation = i ? o : null, o.update(e, this.transform, t); } _updateFog(e) { const t = e.fog; if (!t || "globe" === this.transform.projection.name || t.getOpacity(this.transform.pitch) < 1 || t.properties.get("horizon-blend") < .03) return void(this.transform.fogCullDistSq = null); const [i, o] = t.getFovAdjustedRange(this.transform._fov); if (i > o) return void(this.transform.fogCullDistSq = null); const r = i + .78 * (o - i); this.transform.fogCullDistSq = r * r; } get terrain() { return this.transform._terrainEnabled() && this._terrain && this._terrain.enabled ? this._terrain : null } resize(t, i) { if (this.width = t * e.exported.devicePixelRatio, this.height = i * e.exported.devicePixelRatio, this.context.viewport.set([0, 0, this.width, this.height]), this.style) for (const e of this.style.order) this.style._layers[e].resize(); } setup() { const t = this.context, i = new e.StructArrayLayout2i4; i.emplaceBack(0, 0), i.emplaceBack(e.EXTENT, 0), i.emplaceBack(0, e.EXTENT), i.emplaceBack(e.EXTENT, e.EXTENT), this.tileExtentBuffer = t.createVertexBuffer(i, e.posAttributes.members), this.tileExtentSegments = e.SegmentVector.simpleSegment(0, 0, 4, 2); const o = new e.StructArrayLayout2i4; o.emplaceBack(0, 0), o.emplaceBack(e.EXTENT, 0), o.emplaceBack(0, e.EXTENT), o.emplaceBack(e.EXTENT, e.EXTENT), this.debugBuffer = t.createVertexBuffer(o, e.posAttributes.members), this.debugSegments = e.SegmentVector.simpleSegment(0, 0, 4, 5); const r = new e.StructArrayLayout2i4; r.emplaceBack(-1, -1), r.emplaceBack(1, -1), r.emplaceBack(-1, 1), r.emplaceBack(1, 1), this.viewportBuffer = t.createVertexBuffer(r, e.posAttributes.members), this.viewportSegments = e.SegmentVector.simpleSegment(0, 0, 4, 2); const n = new e.StructArrayLayout4i8; n.emplaceBack(0, 0, 0, 0), n.emplaceBack(e.EXTENT, 0, e.EXTENT, 0), n.emplaceBack(0, e.EXTENT, 0, e.EXTENT), n.emplaceBack(e.EXTENT, e.EXTENT, e.EXTENT, e.EXTENT), this.mercatorBoundsBuffer = t.createVertexBuffer(n, e.boundsAttributes.members), this.mercatorBoundsSegments = e.SegmentVector.simpleSegment(0, 0, 4, 2); const s = new e.StructArrayLayout3ui6; s.emplaceBack(0, 1, 2), s.emplaceBack(2, 1, 3), this.quadTriangleIndexBuffer = t.createIndexBuffer(s); const a = new e.StructArrayLayout1ui2; for (const e of [0, 1, 3, 2, 0]) a.emplaceBack(e); this.debugIndexBuffer = t.createIndexBuffer(a), this.emptyTexture = new e.Texture(t, new e.RGBAImage({ width: 1, height: 1 }, Uint8Array.of(0, 0, 0, 0)), t.gl.RGBA), this.identityMat = e.create(); const l = this.context.gl; this.stencilClearMode = new e.StencilMode({ func: l.ALWAYS, mask: 0 }, 0, 255, l.ZERO, l.ZERO, l.ZERO), this.loadTimeStamps.push(e.window.performance.now()), this.atmosphereBuffer = new Bo(this.context); } getMercatorTileBoundsBuffers() { return { tileBoundsBuffer: this.mercatorBoundsBuffer, tileBoundsIndexBuffer: this.quadTriangleIndexBuffer, tileBoundsSegments: this.mercatorBoundsSegments } } getTileBoundsBuffers(e) { return e._makeTileBoundsBuffers(this.context, this.transform.projection), e._tileBoundsBuffer ? { tileBoundsBuffer: e._tileBoundsBuffer, tileBoundsIndexBuffer: e._tileBoundsIndexBuffer, tileBoundsSegments: e._tileBoundsSegments } : this.getMercatorTileBoundsBuffers() } clearStencil() { const t = this.context, i = t.gl; this.nextStencilID = 1, this.currentStencilSource = void 0, this._tileClippingMaskIDs = {}, this.useProgram("clippingMask").draw(t, i.TRIANGLES, e.DepthMode.disabled, this.stencilClearMode, e.ColorMode.disabled, e.CullFaceMode.disabled, Ii(this.identityMat), "$clipping", this.viewportBuffer, this.quadTriangleIndexBuffer, this.viewportSegments); } resetStencilClippingMasks() { this.terrain || (this.currentStencilSource = void 0, this._tileClippingMaskIDs = {}); } _renderTileClippingMasks(t, i, o) { if (!i || this.currentStencilSource === i.id || !t.isTileClipped() || !o || 0 === o.length) return; if (this._tileClippingMaskIDs && !this.terrain) { let e = !1; for (const t of o) if (void 0 === this._tileClippingMaskIDs[t.key]) { e = !0; break } if (!e) return } this.currentStencilSource = i.id; const r = this.context, n = r.gl; this.nextStencilID + o.length > 256 && this.clearStencil(), r.setColorMode(e.ColorMode.disabled), r.setDepthMode(e.DepthMode.disabled); const s = this.useProgram("clippingMask"); this._tileClippingMaskIDs = {}; for (const t of o) { const o = i.getTile(t), a = this._tileClippingMaskIDs[t.key] = this.nextStencilID++, { tileBoundsBuffer: l, tileBoundsIndexBuffer: c, tileBoundsSegments: h } = this.getTileBoundsBuffers(o); s.draw(r, n.TRIANGLES, e.DepthMode.disabled, new e.StencilMode({ func: n.ALWAYS, mask: 0 }, a, 255, n.KEEP, n.KEEP, n.REPLACE), e.ColorMode.disabled, e.CullFaceMode.disabled, Ii(t.projMatrix), "$clipping", l, c, h); } } stencilModeFor3D() { this.currentStencilSource = void 0, this.nextStencilID + 1 > 256 && this.clearStencil(); const t = this.nextStencilID++, i = this.context.gl; return new e.StencilMode({ func: i.NOTEQUAL, mask: 255 }, t, 255, i.KEEP, i.KEEP, i.REPLACE) } stencilModeForClipping(t) { if (this.terrain) return this.terrain.stencilModeForRTTOverlap(t); const i = this.context.gl; return new e.StencilMode({ func: i.EQUAL, mask: 255 }, this._tileClippingMaskIDs[t.key], 0, i.KEEP, i.KEEP, i.REPLACE) } stencilConfigForOverlap(t) { const i = this.context.gl, o = t.sort(((e, t) => t.overscaledZ - e.overscaledZ)), r = o[o.length - 1].overscaledZ, n = o[0].overscaledZ - r + 1; if (n > 1) { this.currentStencilSource = void 0, this.nextStencilID + n > 256 && this.clearStencil(); const t = {}; for (let o = 0; o < n; o++) t[o + r] = new e.StencilMode({ func: i.GEQUAL, mask: 255 }, o + this.nextStencilID, 255, i.KEEP, i.KEEP, i.REPLACE); return this.nextStencilID += n, [t, o] } return [{ [r]: e.StencilMode.disabled }, o] } colorModeForRenderPass() { const t = this.context.gl; if (this._showOverdrawInspector) { const i = 1 / 8; return new e.ColorMode([t.CONSTANT_COLOR, t.ONE], new e.Color(i, i, i, 0), [!0, !0, !0, !0]) } return "opaque" === this.renderPass ? e.ColorMode.unblended : e.ColorMode.alphaBlended } depthModeForSublayer(t, i, o) { if (!this.opaquePassEnabledForLayer()) return e.DepthMode.disabled; const r = 1 - ((1 + this.currentLayer) * this.numSublayers + t) * this.depthEpsilon; return new e.DepthMode(o || this.context.gl.LEQUAL, i, [r, r]) } opaquePassEnabledForLayer() { return this.currentLayer < this.opaquePassCutoff } render(t, i) { this.style = t, this.options = i, this.imageManager = t.imageManager, this.glyphManager = t.glyphManager, this.symbolFadeChange = t.placement.symbolFadeChange(e.exported.now()), this.imageManager.beginFrame(); const o = this.style.order, r = this.style._sourceCaches; for (const e in r) { const t = r[e]; t.used && t.prepare(this.context); } const n = {}, s = {}, a = {}; for (const e in r) { const t = r[e]; n[e] = t.getVisibleCoordinates(), s[e] = n[e].slice().reverse(), a[e] = t.getVisibleCoordinates(!0).reverse(); } this.opaquePassCutoff = 1 / 0; for (let e = 0; e < o.length; e++) if (this.style._layers[o[e]].is3D()) { this.opaquePassCutoff = e; break } if (this.terrain && (this.terrain.updateTileBinding(a), this.opaquePassCutoff = 0), "globe" !== this.transform.projection.name || this.globeSharedBuffers || (this.globeSharedBuffers = new e.GlobeSharedBuffers(this.context)), !e.isMapAuthenticated(this.context.gl)) return; this.renderPass = "offscreen"; for (const e of o) { const i = this.style._layers[e], o = t._getLayerSourceCache(i); if (!i.hasOffscreenPass() || i.isHidden(this.transform.zoom)) continue; const r = o ? s[o.id] : void 0; ("custom" === i.type || i.isSky() || r && r.length) && this.renderLayer(this, o, i, r); } this.depthRangeFor3D = [0, 1 - (t.order.length + 2) * this.numSublayers * this.depthEpsilon]; const l = this.terrain; if (l && (this.style.hasSymbolLayers() || this.style.hasCircleLayers()) && l.drawDepth(), this.context.bindFramebuffer.set(null), this.context.viewport.set([0, 0, this.width, this.height]), this.context.clear({ color: i.showOverdrawInspector ? e.Color.black : e.Color.transparent, depth: 1 }), this.clearStencil(), this._showOverdrawInspector = i.showOverdrawInspector, this.renderPass = "opaque", !this.terrain) for (this.currentLayer = o.length - 1; this.currentLayer >= 0; this.currentLayer--) { const e = this.style._layers[o[this.currentLayer]], i = t._getLayerSourceCache(e); if (e.isSky()) continue; const r = i ? s[i.id] : void 0; this._renderTileClippingMasks(e, i, r), this.renderLayer(this, i, e, r); } if (this.style.fog && this.transform.projection.supportsFog && function(t, i) { const o = t.context, r = o.gl, n = t.transform, s = new e.DepthMode(r.LEQUAL, e.DepthMode.ReadOnly, [0, 1]), a = t.useProgram("globeAtmosphere", null, "globe" === n.projection.name ? ["PROJECTION_GLOBE_VIEW", "FOG"] : ["FOG"]), l = e.globeToMercatorTransition(n.zoom), c = i.properties.get("color").toArray01(), h = i.properties.get("high-color").toArray01(), u = i.properties.get("space-color").toArray01PremultipliedAlpha(), _ = e.identity$1([]); e.rotateY$1(_, _, -e.degToRad(n._center.lng)), e.rotateX$1(_, _, e.degToRad(n._center.lat)), e.rotateZ$1(_, _, n.angle), e.rotateX$1(_, _, -n._pitch); const d = e.fromQuat(new Float32Array(16), _), p = e.mapValue(i.properties.get("star-intensity"), 0, 1, 0, .25), m = 5e-4, f = e.mapValue(i.properties.get("horizon-blend"), 0, 1, m, .25), g = e.globeUseCustomAntiAliasing(t, o, n) && f === m ? n.worldSize / (2 * Math.PI * 1.025) - 1 : n.globeRadius, v = t.frameCounter / 1e3 % 1, x = e.length(n.globeCenterInViewSpace), y = Math.sqrt(Math.pow(x, 2) - Math.pow(g, 2)), b = Math.acos(y / x), w = ((t, i, o, r, n, s, a, l, c, h, u, _, d, p) => ({ u_frustum_tl: t, u_frustum_tr: i, u_frustum_br: o, u_frustum_bl: r, u_horizon: n, u_transition: s, u_fadeout_range: a, u_color: l, u_high_color: c, u_space_color: h, u_star_intensity: u, u_star_size: 5 * e.exported.devicePixelRatio, u_star_density: 0, u_temporal_offset: _, u_horizon_angle: d, u_rotation_matrix: p }))(n.frustumCorners.TL, n.frustumCorners.TR, n.frustumCorners.BR, n.frustumCorners.BL, n.frustumCorners.horizon, l, f, c, h, u, p, v, b, d); t.prepareDrawProgram(o, a); const T = t.atmosphereBuffer; T && a.draw(o, r.TRIANGLES, s, e.StencilMode.disabled, e.ColorMode.alphaBlended, e.CullFaceMode.backCW, w, "skybox", T.vertexBuffer, T.indexBuffer, T.segments); }(this, this.style.fog), this.renderPass = "sky", (e.globeToMercatorTransition(this.transform.zoom) > 0 || "globe" !== this.transform.projection.name) && this.transform.isHorizonVisible()) for (this.currentLayer = 0; this.currentLayer < o.length; this.currentLayer++) { const e = this.style._layers[o[this.currentLayer]], i = t._getLayerSourceCache(e); e.isSky() && this.renderLayer(this, i, e, i ? s[i.id] : void 0); } for (this.renderPass = "translucent", this.currentLayer = 0; this.currentLayer < o.length;) { const e = this.style._layers[o[this.currentLayer]], i = t._getLayerSourceCache(e); if (e.isSky()) { ++this.currentLayer; continue } if (this.terrain && this.style.isLayerDraped(e)) { if (e.isHidden(this.transform.zoom)) { ++this.currentLayer; continue } this.currentLayer = this.terrain.renderBatch(this.currentLayer); continue } const r = i ? ("symbol" === e.type ? a : s)[i.id] : void 0; this._renderTileClippingMasks(e, i, i ? n[i.id] : void 0), this.renderLayer(this, i, e, r), ++this.currentLayer; } if (this.terrain && this.terrain.postRender(), this.options.showTileBoundaries || this.options.showQueryGeometry || this.options.showTileAABBs) { let i = null; e.values(this.style._layers).forEach((e => { const o = t._getLayerSourceCache(e); o && !e.isHidden(this.transform.zoom) && (!i || i.getSource().maxzoom < o.getSource().maxzoom) && (i = o); })), i && this.options.showTileBoundaries && ko.debug(this, i, i.getVisibleCoordinates()); } this.options.showPadding && function(e) { const t = e.transform.padding; Io(e, e.transform.height - (t.top || 0), 3, bo), Io(e, t.bottom || 0, 3, wo), So(e, t.left || 0, 3, To), So(e, e.transform.width - (t.right || 0), 3, Eo); const i = e.transform.centerPoint; ! function(e, t, i, o) { Do(e, t - 1, i - 10, 2, 20, o), Do(e, t - 10, i - 1, 20, 2, o); }(e, i.x, e.transform.height - i.y, Co); }(this), this.context.setDefault(), this.frameCounter = (this.frameCounter + 1) % Number.MAX_SAFE_INTEGER, this.tileLoaded && this.options.speedIndexTiming && (this.loadTimeStamps.push(e.window.performance.now()), this.saveCanvasCopy()); } renderLayer(e, t, i, o) { i.isHidden(this.transform.zoom) || ("background" === i.type || "sky" === i.type || "custom" === i.type || o && o.length) && (this.id = i.id, this.gpuTimingStart(i), (!e.transform.projection.unsupportedLayers || !e.transform.projection.unsupportedLayers.includes(i.type) || e.terrain && "custom" === i.type) && ko[i.type](e, t, i, o, this.style.placement.variableOffsets, this.options.isInitialLoad), this.gpuTimingEnd()); } gpuTimingStart(e) { if (!this.options.gpuTiming) return; const t = this.context.extTimerQuery; let i = this.gpuTimers[e.id]; i || (i = this.gpuTimers[e.id] = { calls: 0, cpuTime: 0, query: t.createQueryEXT() }), i.calls++, t.beginQueryEXT(t.TIME_ELAPSED_EXT, i.query); } gpuTimingDeferredRenderStart() { if (this.options.gpuTimingDeferredRender) { const e = this.context.extTimerQuery, t = e.createQueryEXT(); this.deferredRenderGpuTimeQueries.push(t), e.beginQueryEXT(e.TIME_ELAPSED_EXT, t); } } gpuTimingDeferredRenderEnd() { if (!this.options.gpuTimingDeferredRender) return; const e = this.context.extTimerQuery; e.endQueryEXT(e.TIME_ELAPSED_EXT); } gpuTimingEnd() { if (!this.options.gpuTiming) return; const e = this.context.extTimerQuery; e.endQueryEXT(e.TIME_ELAPSED_EXT); } collectGpuTimers() { const e = this.gpuTimers; return this.gpuTimers = {}, e } collectDeferredRenderGpuQueries() { const e = this.deferredRenderGpuTimeQueries; return this.deferredRenderGpuTimeQueries = [], e } queryGpuTimers(e) { const t = {}; for (const i in e) { const o = e[i], r = this.context.extTimerQuery, n = r.getQueryObjectEXT(o.query, r.QUERY_RESULT_EXT) / 1e6; r.deleteQueryEXT(o.query), t[i] = n; } return t } queryGpuTimeDeferredRender(e) { if (!this.options.gpuTimingDeferredRender) return 0; const t = this.context.extTimerQuery; let i = 0; for (const o of e) i += t.getQueryObjectEXT(o, t.QUERY_RESULT_EXT) / 1e6, t.deleteQueryEXT(o); return i } translatePosMatrix(t, i, o, r, n) { if (!o[0] && !o[1]) return t; const s = n ? "map" === r ? this.transform.angle : 0 : "viewport" === r ? -this.transform.angle : 0; if (s) { const e = Math.sin(s), t = Math.cos(s); o = [o[0] * t - o[1] * e, o[0] * e + o[1] * t]; } const a = [n ? o[0] : P(i, o[0], this.transform.zoom), n ? o[1] : P(i, o[1], this.transform.zoom), 0], l = new Float32Array(16); return e.translate(l, t, a), l } saveTileTexture(e) { const t = this._tileTextures[e.size[0]]; t ? t.push(e) : this._tileTextures[e.size[0]] = [e]; } getTileTexture(e) { const t = this._tileTextures[e]; return t && t.length > 0 ? t.pop() : null } isPatternMissing(e) { return null === e || void 0 !== e && !this.imageManager.getPattern(e.toString()) } terrainRenderModeElevated() { return this.style && !!this.style.getTerrain() && !!this.terrain && !this.terrain.renderingToTexture } currentGlobalDefines() { const e = this.terrain && this.terrain.renderingToTexture, t = this.terrain && 0 === this.terrain.exaggeration(), i = this.style && this.style.fog, o = []; return this.terrainRenderModeElevated() && o.push("TERRAIN"), "globe" === this.transform.projection.name && o.push("GLOBE"), t && o.push("ZERO_EXAGGERATION"), i && !e && 0 !== i.getOpacity(this.transform.pitch) && o.push("FOG"), e && o.push("RENDER_TO_TEXTURE"), this._showOverdrawInspector && o.push("OVERDRAW_INSPECTOR"), o } useProgram(e, t, i) { this.cache = this.cache || {}; const o = i || [], r = this.currentGlobalDefines().concat(o), n = Pi.cacheKey(ui[e], e, r, t); return this.cache[n] || (this.cache[n] = new Pi(this.context, e, ui[e], t, lo[e], r)), this.cache[n] } setCustomLayerDefaults() { this.context.unbindVAO(), this.context.cullFace.setDefault(), this.context.frontFace.setDefault(), this.context.cullFaceSide.setDefault(), this.context.activeTexture.setDefault(), this.context.pixelStoreUnpack.setDefault(), this.context.pixelStoreUnpackPremultiplyAlpha.setDefault(), this.context.pixelStoreUnpackFlipY.setDefault(); } setBaseState() { const e = this.context.gl; this.context.cullFace.set(!1), this.context.viewport.set([0, 0, this.width, this.height]), this.context.blendEquation.set(e.FUNC_ADD); } initDebugOverlayCanvas() { null == this.debugOverlayCanvas && (this.debugOverlayCanvas = e.window.document.createElement("canvas"), this.debugOverlayCanvas.width = 512, this.debugOverlayCanvas.height = 512, this.debugOverlayTexture = new e.Texture(this.context, this.debugOverlayCanvas, this.context.gl.RGBA)); } destroy() { this._terrain && this._terrain.destroy(), this.globeSharedBuffers && this.globeSharedBuffers.destroy(), this.emptyTexture.destroy(), this.debugOverlayTexture && this.debugOverlayTexture.destroy(), this.atmosphereBuffer && this.atmosphereBuffer.destroy(); } prepareDrawTile() { this.terrain && this.terrain.prepareDrawTile(); } prepareDrawProgram(t, i, o) { if (this.terrain && this.terrain.renderingToTexture) return; const r = this.style.fog; if (r) { const n = r.getOpacity(this.transform.pitch), s = ((t, i, o, r, n, s, a, l, c, h, u) => { const _ = t.transform, d = i.properties.get("color").toArray01(); d[3] = r; const p = t.frameCounter / 1e3 % 1; return { u_fog_matrix: o ? _.calculateFogTileMatrix(o) : t.identityMat, u_fog_range: i.getFovAdjustedRange(_._fov), u_fog_color: d, u_fog_horizon_blend: i.properties.get("horizon-blend"), u_fog_temporal_offset: p, u_frustum_tl: n, u_frustum_tr: s, u_frustum_br: a, u_frustum_bl: l, u_globe_pos: c, u_globe_radius: h, u_viewport: u, u_globe_transition: e.globeToMercatorTransition(_.zoom), u_is_globe: +("globe" === _.projection.name) } })(this, r, o, n, this.transform.frustumCorners.TL, this.transform.frustumCorners.TR, this.transform.frustumCorners.BR, this.transform.frustumCorners.BL, this.transform.globeCenterInViewSpace, this.transform.globeRadius, [this.transform.width * e.exported.devicePixelRatio, this.transform.height * e.exported.devicePixelRatio]); i.setFogUniformValues(t, s); } } setTileLoadedFlag(e) { this.tileLoaded = e; } saveCanvasCopy() { const e = this.canvasCopy(); e && (this.frameCopies.push(e), this.tileLoaded = !1); } canvasCopy() { const e = this.context.gl, t = e.createTexture(); return e.bindTexture(e.TEXTURE_2D, t), e.copyTexImage2D(e.TEXTURE_2D, 0, e.RGBA, 0, 0, e.drawingBufferWidth, e.drawingBufferHeight, 0), t } getCanvasCopiesAndTimestamps() { return { canvasCopies: this.frameCopies, timeStamps: this.loadTimeStamps } } averageElevationNeedsEasing() { if (!this.transform._elevation) return !1; const e = this.style && this.style.fog; return !!e && 0 !== e.getOpacity(this.transform.pitch) } getBackgroundTiles() { const t = this._backgroundTiles, i = this._backgroundTiles = {}, o = this.transform.coveringTiles({ tileSize: 512 }); for (const r of o) i[r.key] = t[r.key] || new e.Tile(r, 512, this.transform.tileZoom, this); return i } clearBackgroundTiles() { this._backgroundTiles = {}; } } class Uo { constructor(e = 0, t = 0, i = 0, o = 0) { if (isNaN(e) || e < 0 || isNaN(t) || t < 0 || isNaN(i) || i < 0 || isNaN(o) || o < 0) throw new Error("Invalid value for edge-insets, top, bottom, left and right must all be numbers"); this.top = e, this.bottom = t, this.left = i, this.right = o; } interpolate(t, i, o) { return null != i.top && null != t.top && (this.top = e.number(t.top, i.top, o)), null != i.bottom && null != t.bottom && (this.bottom = e.number(t.bottom, i.bottom, o)), null != i.left && null != t.left && (this.left = e.number(t.left, i.left, o)), null != i.right && null != t.right && (this.right = e.number(t.right, i.right, o)), this } getCenter(t, i) { const o = e.clamp((this.left + t - this.right) / 2, 0, t), r = e.clamp((this.top + i - this.bottom) / 2, 0, i); return new e.pointGeometry(o, r) } equals(e) { return this.top === e.top && this.bottom === e.bottom && this.left === e.left && this.right === e.right } clone() { return new Uo(this.top, this.bottom, this.left, this.right) } toJSON() { return { top: this.top, bottom: this.bottom, left: this.left, right: this.right } } } function No(t, i) { const o = e.getColumn(t, 3); e.fromQuat(t, i), e.setColumn(t, 3, o); } function Go(t, i) { const o = e.identity$1([]); return e.rotateZ$1(o, o, -i), e.rotateX$1(o, o, -t), o } function jo(t, i) { const o = [t[0], t[1], 0], r = [i[0], i[1], 0]; if (e.length(o) >= 1e-15) { const t = e.normalize([], o); e.scale$2(r, t, e.dot(r, t)), i[0] = r[0], i[1] = r[1]; } const n = e.cross([], i, t); if (e.len(n) < 1e-15) return null; const s = Math.atan2(-n[1], n[0]); return Go(Math.atan2(Math.sqrt(t[0] * t[0] + t[1] * t[1]), -t[2]), s) } class Zo { constructor(e, t) { this.position = e, this.orientation = t; } get position() { return this._position } set position(t) { if (t) { const i = t instanceof e.MercatorCoordinate ? t : new e.MercatorCoordinate(t[0], t[1], t[2]); this._renderWorldCopies && (i.x = e.wrap(i.x, 0, 1)), this._position = i; } else this._position = null; } lookAtPoint(t, i) { if (this.orientation = null, !this.position) return; const o = this.position, r = this._elevation ? this._elevation.getAtPointOrZero(e.MercatorCoordinate.fromLngLat(t)) : 0, n = e.MercatorCoordinate.fromLngLat(t, r), s = [n.x - o.x, n.y - o.y, n.z - o.z]; i || (i = [0, 0, 1]), i[2] = Math.abs(i[2]), this.orientation = jo(s, i); } setPitchBearing(t, i) { this.orientation = Go(e.degToRad(t), e.degToRad(-i)); } } class Vo { constructor(t, i) { this._transform = e.identity([]), this.orientation = i, this.position = t; } get mercatorPosition() { const t = this.position; return new e.MercatorCoordinate(t[0], t[1], t[2]) } get position() { const t = e.getColumn(this._transform, 3); return [t[0], t[1], t[2]] } set position(t) { var i; t && e.setColumn(this._transform, 3, [(i = t)[0], i[1], i[2], 1]); } get orientation() { return this._orientation } set orientation(t) { this._orientation = t || e.identity$1([]), t && No(this._transform, this._orientation); } getPitchBearing() { const e = this.forward(), t = this.right(); return { bearing: Math.atan2(-t[1], t[0]), pitch: Math.atan2(Math.sqrt(e[0] * e[0] + e[1] * e[1]), -e[2]) } } setPitchBearing(e, t) { this._orientation = Go(e, t), No(this._transform, this._orientation); } forward() { const t = e.getColumn(this._transform, 2); return [-t[0], -t[1], -t[2]] } up() { const t = e.getColumn(this._transform, 1); return [-t[0], -t[1], -t[2]] } right() { const t = e.getColumn(this._transform, 0); return [t[0], t[1], t[2]] } getCameraToWorld(t, i) { const o = new Float64Array(16); return e.invert(o, this.getWorldToCamera(t, i)), o } getWorldToCameraPosition(t, i, o) { const r = this.position; e.scale$2(r, r, -t); const n = new Float64Array(16); return e.fromScaling(n, [o, o, o]), e.translate(n, n, r), n[10] *= i, n } getWorldToCamera(t, i) { const o = new Float64Array(16), r = new Float64Array(4), n = this.position; return e.conjugate(r, this._orientation), e.scale$2(n, n, -t), e.fromQuat(o, r), e.translate(o, o, n), o[1] *= -1, o[5] *= -1, o[9] *= -1, o[13] *= -1, o[8] *= i, o[9] *= i, o[10] *= i, o[11] *= i, o } getCameraToClipPerspective(t, i, o, r) { const n = new Float64Array(16); return e.perspective(n, t, i, o, r), n } getDistanceToElevation(t, i = !1) { const o = 0 === t ? 0 : e.mercatorZfromAltitude(t, i ? e.latFromMercatorY(this.position[1]) : this.position[1]), r = this.forward(); return (o - this.position[2]) / r[2] } clone() { return new Vo([...this.position], [...this.orientation]) } } function Wo(t, i) { const o = qo(t.projection, t.zoom, t.width, t.height), r = function(t, i, o, r, n) { const s = new e.LngLat(o.lng - 180 * $o, o.lat), a = new e.LngLat(o.lng + 180 * $o, o.lat), l = t.project(s.lng, s.lat), c = t.project(a.lng, a.lat), h = -Math.atan2(c.y - l.y, c.x - l.x), u = e.MercatorCoordinate.fromLngLat(o); u.y = e.clamp(u.y, -.999975, .999975); const _ = u.toLngLat(), d = t.project(_.lng, _.lat), p = e.MercatorCoordinate.fromLngLat(_); p.x += $o; const m = p.toLngLat(), f = t.project(m.lng, m.lat), g = Yo(f.x - d.x, f.y - d.y, h), v = e.MercatorCoordinate.fromLngLat(_); v.y += $o; const x = v.toLngLat(), y = t.project(x.lng, x.lat), b = Yo(y.x - d.x, y.y - d.y, h), w = Math.abs(g.x) / Math.abs(b.y), T = e.identity([]); e.rotateZ(T, T, -h * (1 - (n ? 0 : r))); const E = e.identity([]); return e.scale(E, E, [1, 1 - (1 - w) * r, 1]), E[4] = -b.x / b.y * r, e.rotateZ(E, E, h), e.multiply(E, T, E), E }(t.projection, 0, t.center, o, i), n = Xo(t); return e.scale(r, r, [n, n, 1]), r } function Xo(t) { const i = t.projection, o = qo(t.projection, t.zoom, t.width, t.height), r = Ho(i, t.center), n = Ho(i, e.LngLat.convert(i.center)); return Math.pow(2, r * o + (1 - o) * n) } function qo(t, i, o, r, n = 1 / 0) { const s = t.range; if (!s) return 0; const a = Math.min(n, Math.max(o, r)), l = Math.log(a / 1024) / Math.LN2; return e.smoothstep(s[0] + l, s[1] + l, i) } const $o = 1 / 4e4; function Ho(t, i) { const o = e.clamp(i.lat, -e.MAX_MERCATOR_LATITUDE, e.MAX_MERCATOR_LATITUDE), r = new e.LngLat(i.lng - 180 * $o, o), n = new e.LngLat(i.lng + 180 * $o, o), s = t.project(r.lng, o), a = t.project(n.lng, o), l = e.MercatorCoordinate.fromLngLat(r), c = e.MercatorCoordinate.fromLngLat(n), h = a.x - s.x, u = a.y - s.y, _ = c.x - l.x, d = c.y - l.y, p = Math.sqrt((_ * _ + d * d) / (h * h + u * u)); return Math.log(p) / Math.LN2 } function Yo(e, t, i) { const o = Math.cos(i), r = Math.sin(i); return { x: e * o - t * r, y: e * r + t * o } } class Ko { constructor(t, i, o, r, n, s, a) { this.tileSize = 512, this._renderWorldCopies = void 0 === n || n, this._minZoom = t || 0, this._maxZoom = i || 22, this._minPitch = null == o ? 0 : o, this._maxPitch = null == r ? 60 : r, this.setProjection(s), this.setMaxBounds(a), this.width = 0, this.height = 0, this._center = new e.LngLat(0, 0), this.zoom = 0, this.angle = 0, this._fov = .6435011087932844, this._pitch = 0, this._nearZ = 0, this._farZ = 0, this._unmodified = !0, this._edgeInsets = new Uo, this._projMatrixCache = {}, this._alignedProjMatrixCache = {}, this._fogTileMatrixCache = {}, this._distanceTileDataCache = {}, this._camera = new Vo, this._centerAltitude = 0, this._averageElevation = 0, this.cameraElevationReference = "ground", this._pixelsPerMercatorPixel = 1, this.globeRadius = 0, this.globeCenterInViewSpace = [0, 0, 0], this._horizonShift = .1; } clone() { const e = new Ko(this._minZoom, this._maxZoom, this._minPitch, this.maxPitch, this._renderWorldCopies, this.getProjection()); return e._elevation = this._elevation, e._centerAltitude = this._centerAltitude, e._centerAltitudeValidForExaggeration = this._centerAltitudeValidForExaggeration, e.tileSize = this.tileSize, e.mercatorFromTransition = this.mercatorFromTransition, e.width = this.width, e.height = this.height, e.cameraElevationReference = this.cameraElevationReference, e._center = this._center, e._setZoom(this.zoom), e._seaLevelZoom = this._seaLevelZoom, e.angle = this.angle, e._fov = this._fov, e._pitch = this._pitch, e._nearZ = this._nearZ, e._farZ = this._farZ, e._averageElevation = this._averageElevation, e._unmodified = this._unmodified, e._edgeInsets = this._edgeInsets.clone(), e._camera = this._camera.clone(), e._calcMatrices(), e.freezeTileCoverage = this.freezeTileCoverage, e.frustumCorners = this.frustumCorners, e } get elevation() { return this._elevation } set elevation(e) { this._elevation !== e && (this._elevation = e, this._updateCameraOnTerrain(), this._calcMatrices()); } updateElevation(e, t = !1) { const i = this._elevation && this._elevation.exaggeration() !== this._centerAltitudeValidForExaggeration; (null == this._seaLevelZoom || i) && this._updateCameraOnTerrain(), (e || i) && this._constrainCamera(t), this._calcMatrices(); } getProjection() { return e.pick(this.projection, ["name", "center", "parallels"]) } setProjection(i) { this.projectionOptions = i || { name: "mercator" }; const o = this.projection ? this.getProjection() : void 0; this.projection = e.getProjection(this.projectionOptions); const r = !t(o, this.getProjection()); return r && this._calcMatrices(), this.mercatorFromTransition = !1, r } setMercatorFromTransition() { const t = this.projection.name; this.mercatorFromTransition = !0, this.projectionOptions = { name: "mercator" }, this.projection = e.getProjection({ name: "mercator" }); const i = t !== this.projection.name; return i && this._calcMatrices(), i } get minZoom() { return this._minZoom } set minZoom(e) { this._minZoom !== e && (this._minZoom = e, this.zoom = Math.max(this.zoom, e)); } get maxZoom() { return this._maxZoom } set maxZoom(e) { this._maxZoom !== e && (this._maxZoom = e, this.zoom = Math.min(this.zoom, e)); } get minPitch() { return this._minPitch } set minPitch(e) { this._minPitch !== e && (this._minPitch = e, this.pitch = Math.max(this.pitch, e)); } get maxPitch() { return this._maxPitch } set maxPitch(e) { this._maxPitch !== e && (this._maxPitch = e, this.pitch = Math.min(this.pitch, e)); } get renderWorldCopies() { return this._renderWorldCopies && !0 === this.projection.supportsWorldCopies } set renderWorldCopies(e) { void 0 === e ? e = !0 : null === e && (e = !1), this._renderWorldCopies = e; } get worldSize() { return this.tileSize * this.scale } get cameraWorldSizeForFog() { const e = Math.max(this._camera.getDistanceToElevation(this._averageElevation), Number.EPSILON); return this._worldSizeFromZoom(this._zoomFromMercatorZ(e)) } get cameraWorldSize() { const e = Math.max(this._camera.getDistanceToElevation(this._averageElevation, !0), Number.EPSILON); return this._worldSizeFromZoom(this._zoomFromMercatorZ(e)) } get pixelsPerMeter() { return this.projection.pixelsPerMeter(this.center.lat, this.worldSize) } get cameraPixelsPerMeter() { return e.mercatorZfromAltitude(this.center.lat, this.cameraWorldSizeForFog) } get centerOffset() { return this.centerPoint._sub(this.size._div(2)) } get size() { return new e.pointGeometry(this.width, this.height) } get bearing() { return e.wrap(this.rotation, -180, 180) } set bearing(e) { this.rotation = e; } get rotation() { return -this.angle / Math.PI * 180 } set rotation(t) { const i = -t * Math.PI / 180; var o; this.angle !== i && (this._unmodified = !1, this.angle = i, this._calcMatrices(), this.rotationMatrix = (o = new e.ARRAY_TYPE(4), e.ARRAY_TYPE != Float32Array && (o[1] = 0, o[2] = 0), o[0] = 1, o[3] = 1, o), function(e, t, i) { var o = t[0], r = t[1], n = t[2], s = t[3], a = Math.sin(i), l = Math.cos(i); e[0] = o * l + n * a, e[1] = r * l + s * a, e[2] = o * -a + n * l, e[3] = r * -a + s * l; }(this.rotationMatrix, this.rotationMatrix, this.angle)); } get pitch() { return this._pitch / Math.PI * 180 } set pitch(t) { const i = e.clamp(t, this.minPitch, this.maxPitch) / 180 * Math.PI; this._pitch !== i && (this._unmodified = !1, this._pitch = i, this._calcMatrices()); } get aspect() { return this.width / this.height } get fov() { return this._fov / Math.PI * 180 } get fovX() { return this._fov } get fovY() { const e = 1 / Math.tan(.5 * this.fovX); return 2 * Math.atan(1 / this.aspect / e) } set fov(t) { t = Math.max(.01, Math.min(60, t)), this._fov !== t && (this._unmodified = !1, this._fov = e.degToRad(t), this._calcMatrices()); } get averageElevation() { return this._averageElevation } set averageElevation(e) { this._averageElevation = e, this._calcFogMatrices(), this._distanceTileDataCache = {}; } get zoom() { return this._zoom } set zoom(e) { const t = Math.min(Math.max(e, this.minZoom), this.maxZoom); this._zoom !== t && (this._unmodified = !1, this._setZoom(t), this._updateSeaLevelZoom(), this._constrain(), this._calcMatrices()); } _setZoom(e) { this._zoom = e, this.scale = this.zoomScale(e), this.tileZoom = Math.floor(e), this.zoomFraction = e - this.tileZoom; } _updateCameraOnTerrain() { if (!this._elevation || !this._elevation.isDataAvailableAtPoint(this.locationCoordinate(this.center))) return this._centerAltitude = 0, this._seaLevelZoom = null, void(this._centerAltitudeValidForExaggeration = void 0); const e = this._elevation; this._centerAltitude = e.getAtPointOrZero(this.locationCoordinate(this.center)), this._centerAltitudeValidForExaggeration = e.exaggeration(), this._updateSeaLevelZoom(); } _updateSeaLevelZoom() { void 0 !== this._centerAltitudeValidForExaggeration && (this._seaLevelZoom = this._zoomFromMercatorZ((this.pixelsPerMeter * this._centerAltitude + this.cameraToCenterDistance) / this.worldSize)); } sampleAverageElevation() { if (!this._elevation) return 0; const t = this._elevation, i = [ [.5, .2], [.3, .5], [.5, .5], [.7, .5], [.5, .8] ], o = this.horizonLineFromTop(); let r = 0, n = 0; for (let s = 0; s < i.length; s++) { const a = new e.pointGeometry(i[s][0] * this.width, o + i[s][1] * (this.height - o)), l = t.pointCoordinate(a); if (!l) continue; const c = 1 / Math.hypot(l[0] - this._camera.position[0], l[1] - this._camera.position[1]); r += l[3] * c, n += c; } return 0 === n ? NaN : r / n } get center() { return this._center } set center(e) { e.lat === this._center.lat && e.lng === this._center.lng || (this._unmodified = !1, this._center = e, this._terrainEnabled() && ("ground" === this.cameraElevationReference ? this._updateCameraOnTerrain() : this._updateZoomFromElevation()), this._constrain(), this._calcMatrices()); } _updateZoomFromElevation() { if (null == this._seaLevelZoom || !this._elevation) return; const e = this._seaLevelZoom, t = this._elevation.getAtPointOrZero(this.locationCoordinate(this.center)), i = this.pixelsPerMeter / this.worldSize * t, o = this._mercatorZfromZoom(e), r = this._mercatorZfromZoom(this._maxZoom), n = Math.max(o - i, r); this._setZoom(this._zoomFromMercatorZ(n)); } get padding() { return this._edgeInsets.toJSON() } set padding(e) { this._edgeInsets.equals(e) || (this._unmodified = !1, this._edgeInsets.interpolate(this._edgeInsets, e, 1), this._calcMatrices()); } computeZoomRelativeTo(t) { const i = this.rayIntersectionCoordinate(this.pointRayIntersection(this.centerPoint, t.toAltitude())); let o; o = t.z < this._camera.position[2] ? [i.x, i.y, i.z] : [t.x, t.y, t.z]; const r = e.length(e.sub([], this._camera.position, o)); return e.clamp(this._zoomFromMercatorZ(r), this._minZoom, this._maxZoom) } setFreeCameraOptions(t) { if (!this.height) return; if (!t.position && !t.orientation) return; this._updateCameraState(); let i = !1; if (t.orientation && !e.exactEquals(t.orientation, this._camera.orientation) && (i = this._setCameraOrientation(t.orientation)), t.position) { const o = [t.position.x, t.position.y, t.position.z]; e.exactEquals$1(o, this._camera.position) || (this._setCameraPosition(o), i = !0); } i && (this._updateStateFromCamera(), this.recenterOnTerrain()); } getFreeCameraOptions() { this._updateCameraState(); const t = this._camera.position, i = new Zo; return i.position = new e.MercatorCoordinate(t[0], t[1], t[2]), i.orientation = this._camera.orientation, i._elevation = this.elevation, i._renderWorldCopies = this.renderWorldCopies, i } _setCameraOrientation(t) { if (!e.length$1(t)) return !1; e.normalize$1(t, t); const i = e.transformQuat([], [0, 0, -1], t), o = e.transformQuat([], [0, -1, 0], t); if (o[2] < 0) return !1; const r = jo(i, o); return !!r && (this._camera.orientation = r, !0) } _setCameraPosition(t) { const i = this.zoomScale(this.minZoom) * this.tileSize, o = this.zoomScale(this.maxZoom) * this.tileSize, r = this.cameraToCenterDistance; t[2] = e.clamp(t[2], r / o, r / i), this._camera.position = t; } get centerPoint() { return this._edgeInsets.getCenter(this.width, this.height) } get fovAboveCenter() { return this._fov * (.5 + this.centerOffset.y / this.height) } isPaddingEqual(e) { return this._edgeInsets.equals(e) } interpolatePadding(e, t, i) { this._unmodified = !1, this._edgeInsets.interpolate(e, t, i), this._constrain(), this._calcMatrices(); } coveringZoomLevel(e) { const t = (e.roundZoom ? Math.round : Math.floor)(this.zoom + this.scaleZoom(this.tileSize / e.tileSize)); return Math.max(0, t) } getVisibleUnwrappedCoordinates(t) { const i = [new e.UnwrappedTileID(0, t)]; if (this.renderWorldCopies) { const o = this.pointCoordinate(new e.pointGeometry(0, 0)), r = this.pointCoordinate(new e.pointGeometry(this.width, 0)), n = this.pointCoordinate(new e.pointGeometry(this.width, this.height)), s = this.pointCoordinate(new e.pointGeometry(0, this.height)), a = Math.floor(Math.min(o.x, r.x, n.x, s.x)), l = Math.floor(Math.max(o.x, r.x, n.x, s.x)), c = 1; for (let o = a - c; o <= l + c; o++) 0 !== o && i.push(new e.UnwrappedTileID(o, t)); } return i } coveringTiles(t) { let i = this.coveringZoomLevel(t); const o = i, r = this.elevation && !t.isTerrainDEM, n = "mercator" === this.projection.name; if (void 0 !== t.minzoom && i < t.minzoom) return []; void 0 !== t.maxzoom && i > t.maxzoom && (i = t.maxzoom); const s = this.locationCoordinate(this.center), a = this.center.lat, l = 1 << i, c = [l * s.x, l * s.y, 0], h = "globe" === this.projection.name, u = !h, _ = e.Frustum.fromInvProjectionMatrix(this.invProjMatrix, this.worldSize, i, u), d = h ? this._camera.mercatorPosition : this.pointCoordinate(this.getCameraPoint()), p = l * e.mercatorZfromAltitude(1, this.center.lat), m = this._camera.position[2] / e.mercatorZfromAltitude(1, this.center.lat), f = [l * d.x, l * d.y, m * (u ? 1 : p)], g = this.cameraToCenterDistance / t.tileSize * (t.roundZoom ? 1 : .502), v = this.pitch <= 60 && this._edgeInsets.top <= this._edgeInsets.bottom && !this._elevation && !this.projection.isReprojectedInTileSpace ? i : 0, x = t.isTerrainDEM && this._elevation ? 1e4 * this._elevation.exaggeration() : this._centerAltitude, y = t.isTerrainDEM ? -x : this._elevation ? this._elevation.getMinElevationBelowMSL() : 0, b = this.projection.isReprojectedInTileSpace ? Xo(this) : 1, w = t => { const i = 1 / 4e4, o = new e.MercatorCoordinate(t.x + i, t.y, t.z), r = new e.MercatorCoordinate(t.x, t.y + i, t.z), n = t.toLngLat(), s = o.toLngLat(), a = r.toLngLat(), l = this.locationCoordinate(n), c = this.locationCoordinate(s), h = this.locationCoordinate(a), u = Math.hypot(c.x - l.x, c.y - l.y), _ = Math.hypot(h.x - l.x, h.y - l.y); return Math.sqrt(u * _) * b / i }, T = t => { const i = x, o = y; return { aabb: e.tileAABB(this, l, 0, 0, 0, t, o, i, this.projection), zoom: 0, x: 0, y: 0, minZ: o, maxZ: i, wrap: t, fullyVisible: !1 } }, E = []; let C = []; const M = i, I = t.reparseOverscaled ? o : i, S = e => e * e, D = S((m - this._centerAltitude) * p), L = e => { if (!this._elevation || !e.tileID || !n) return; const t = this._elevation.getMinMaxForTile(e.tileID), i = e.aabb; t ? (i.min[2] = t.min, i.max[2] = t.max, i.center[2] = (i.min[2] + i.max[2]) / 2) : (e.shouldSplit = A(e), e.shouldSplit || (i.min[2] = i.max[2] = i.center[2] = this._centerAltitude)); }, A = t => { if (t.zoom < v) return !0; if (t.zoom === M) return !1; if (null != t.shouldSplit) return t.shouldSplit; const i = t.aabb.distanceX(f), n = t.aabb.distanceY(f); let s = D, l = 1; if (h) { s = S(t.aabb.distanceZ(f)); const i = Math.pow(2, t.zoom), o = e.latFromMercatorY((t.y + 1) / i), r = e.latFromMercatorY(t.y / i), n = Math.min(Math.max(a, o), r), c = e.circumferenceAtLatitude(n) / e.circumferenceAtLatitude(a); if (l = n === a ? 1 / Math.max(1, this._mercatorScaleRatio - .3) : Math.min(1, c / this._mercatorScaleRatio), this.zoom <= e.GLOBE_ZOOM_THRESHOLD_MIN && t.zoom === M - 1 && c >= .9) return !0 } else if (r && (s = S(t.aabb.distanceZ(f) * p)), this.projection.isReprojectedInTileSpace && o <= 5) { const i = Math.pow(2, t.zoom), o = w(new e.MercatorCoordinate((t.x + .5) / i, (t.y + .5) / i)); l = o > .85 ? 1 : o; } const c = i * i + n * n + s, u = S((1 << M - t.zoom) * g * l * ((e, t) => { if (t * S(.707) < e) return 1; const i = Math.sqrt(t / e); return i / (1.4144271570014144 + (Math.pow(1.1, i - 1.4144271570014144 + 1) - 1) / (1.1 - 1) - 1) })(Math.max(s, D), c)); return c < u }; if (this.renderWorldCopies) for (let e = 1; e <= 3; e++) E.push(T(-e)), E.push(T(e)); for (E.push(T(0)); E.length > 0;) { const o = E.pop(), s = o.x, a = o.y; let u = o.fullyVisible; if (!u) { const e = o.aabb.intersects(_); if (0 === e) continue; u = 2 === e; } if (o.zoom !== M && A(o)) for (let t = 0; t < 4; t++) { const i = (s << 1) + t % 2, c = (a << 1) + (t >> 1), _ = { aabb: n ? o.aabb.quadrant(t) : e.tileAABB(this, l, o.zoom + 1, i, c, o.wrap, o.minZ, o.maxZ, this.projection), zoom: o.zoom + 1, x: i, y: c, wrap: o.wrap, fullyVisible: u, tileID: void 0, shouldSplit: void 0, minZ: o.minZ, maxZ: o.maxZ }; r && !h && (_.tileID = new e.OverscaledTileID(o.zoom + 1 === M ? I : o.zoom + 1, o.wrap, o.zoom + 1, i, c), L(_)), E.push(_); } else { const r = o.zoom === M ? I : o.zoom; if (t.minzoom && t.minzoom > r) continue; const n = c[0] - (.5 + s + (o.wrap << o.zoom)) * (1 << i - o.zoom), l = c[1] - .5 - a, h = o.tileID ? o.tileID : new e.OverscaledTileID(r, o.wrap, o.zoom, s, a); C.push({ tileID: h, distanceSq: n * n + l * l }); } } if (this.fogCullDistSq) { const i = this.fogCullDistSq, o = this.horizonLineFromTop(); C = C.filter((r => { const n = [0, 0, 0, 1], s = [e.EXTENT, e.EXTENT, 0, 1], a = this.calculateFogTileMatrix(r.tileID.toUnwrapped()); e.transformMat4$1(n, n, a), e.transformMat4$1(s, s, a); const l = e.getAABBPointSquareDist(n, s); if (0 === l) return !0; let c = !1; const h = this._elevation; if (h && l > i && 0 !== o) { const i = this.calculateProjMatrix(r.tileID.toUnwrapped()); let n; t.isTerrainDEM || (n = h.getMinMaxForTile(r.tileID)), n || (n = { min: y, max: x }); const s = e.furthestTileCorner(this.rotation), a = [s[0] * e.EXTENT, s[1] * e.EXTENT, n.max]; e.transformMat4(a, a, i), c = (1 - a[1]) * this.height * .5 < o; } return l < i || c })); } return C.sort(((e, t) => e.distanceSq - t.distanceSq)).map((e => e.tileID)) } resize(e, t) { this.width = e, this.height = t, this.pixelsToGLUnits = [2 / e, -2 / t], this._constrain(), this._calcMatrices(); } get unmodified() { return this._unmodified } zoomScale(e) { return Math.pow(2, e) } scaleZoom(e) { return Math.log(e) / Math.LN2 } project(t) { const i = e.clamp(t.lat, -e.MAX_MERCATOR_LATITUDE, e.MAX_MERCATOR_LATITUDE), o = this.projection.project(t.lng, i); return new e.pointGeometry(o.x * this.worldSize, o.y * this.worldSize) } unproject(e) { return this.projection.unproject(e.x / this.worldSize, e.y / this.worldSize) } get point() { return this.project(this.center) } get pointMerc() { return this.point._div(this.worldSize) } get pixelsPerMeterRatio() { return this.pixelsPerMeter / e.mercatorZfromAltitude(1, this.center.lat) / this.worldSize } setLocationAtPoint(t, i) { let o, r; const n = this.centerPoint; if ("globe" === this.projection.name) { const e = this.worldSize; o = (i.x - n.x) / e, r = (i.y - n.y) / e; } else { const e = this.pointCoordinate(i), t = this.pointCoordinate(n); o = e.x - t.x, r = e.y - t.y; } const s = this.locationCoordinate(t); this.setLocation(new e.MercatorCoordinate(s.x - o, s.y - r)); } setLocation(e) { this.center = this.coordinateLocation(e), this.projection.wrap && (this.center = this.center.wrap()); } locationPoint(e) { return this.projection.locationPoint(this, e) } locationPoint3D(e) { return this.projection.locationPoint(this, e, !0) } pointLocation(e) { return this.coordinateLocation(this.pointCoordinate(e)) } pointLocation3D(e) { return this.coordinateLocation(this.pointCoordinate3D(e)) } locationCoordinate(t, i) { const o = i ? e.mercatorZfromAltitude(i, t.lat) : void 0, r = this.projection.project(t.lng, t.lat); return new e.MercatorCoordinate(r.x, r.y, o) } coordinateLocation(e) { return this.projection.unproject(e.x, e.y) } pointRayIntersection(t, i) { const o = null != i ? i : this._centerAltitude, r = [t.x, t.y, 0, 1], n = [t.x, t.y, 1, 1]; e.transformMat4$1(r, r, this.pixelMatrixInverse), e.transformMat4$1(n, n, this.pixelMatrixInverse); const s = n[3]; e.scale$1(r, r, 1 / r[3]), e.scale$1(n, n, 1 / s); const a = r[2], l = n[2]; return { p0: r, p1: n, t: a === l ? 0 : (o - a) / (l - a) } } screenPointToMercatorRay(t) { const i = [t.x, t.y, 0, 1], o = [t.x, t.y, 1, 1]; return e.transformMat4$1(i, i, this.pixelMatrixInverse), e.transformMat4$1(o, o, this.pixelMatrixInverse), e.scale$1(i, i, 1 / i[3]), e.scale$1(o, o, 1 / o[3]), i[2] = e.mercatorZfromAltitude(i[2], this._center.lat) * this.worldSize, o[2] = e.mercatorZfromAltitude(o[2], this._center.lat) * this.worldSize, e.scale$1(i, i, 1 / this.worldSize), e.scale$1(o, o, 1 / this.worldSize), new e.Ray([i[0], i[1], i[2]], e.normalize([], e.sub([], o, i))) } rayIntersectionCoordinate(t) { const { p0: i, p1: o, t: r } = t, n = e.mercatorZfromAltitude(i[2], this._center.lat), s = e.mercatorZfromAltitude(o[2], this._center.lat); return new e.MercatorCoordinate(e.number(i[0], o[0], r) / this.worldSize, e.number(i[1], o[1], r) / this.worldSize, e.number(n, s, r)) } pointCoordinate(e, t = this._centerAltitude) { return this.projection.pointCoordinate(this, e.x, e.y, t) } pointCoordinate3D(t) { if (!this.elevation) return this.pointCoordinate(t); let i = this.projection.pointCoordinate3D(this, t.x, t.y); if (i) return new e.MercatorCoordinate(i[0], i[1], i[2]); let o = 0, r = this.horizonLineFromTop(); if (t.y > r) return this.pointCoordinate(t); const n = .02 * r, s = t.clone(); for (let t = 0; t < 10 && r - o > n; t++) { s.y = e.number(o, r, .66); const t = this.projection.pointCoordinate3D(this, s.x, s.y); t ? (r = s.y, i = t) : o = s.y; } return i ? new e.MercatorCoordinate(i[0], i[1], i[2]) : this.pointCoordinate(t) } isPointAboveHorizon(e) { return this.projection.isPointAboveHorizon(this, e) } _coordinatePoint(t, i) { const o = i && this.elevation ? this.elevation.getAtPointOrZero(t, this._centerAltitude) : this._centerAltitude, r = [t.x * this.worldSize, t.y * this.worldSize, o + t.toAltitude(), 1]; return e.transformMat4$1(r, r, this.pixelMatrix), r[3] > 0 ? new e.pointGeometry(r[0] / r[3], r[1] / r[3]) : new e.pointGeometry(Number.MAX_VALUE, Number.MAX_VALUE) } _getBoundsNonRectangular() { const { top: t, left: i } = this._edgeInsets, o = this.height - this._edgeInsets.bottom, r = this.width - this._edgeInsets.right, n = this.pointLocation3D(new e.pointGeometry(i, t)), s = this.pointLocation3D(new e.pointGeometry(r, t)), a = this.pointLocation3D(new e.pointGeometry(r, o)), l = this.pointLocation3D(new e.pointGeometry(i, o)); let c = Math.min(n.lng, s.lng, a.lng, l.lng), h = Math.max(n.lng, s.lng, a.lng, l.lng), u = Math.min(n.lat, s.lat, a.lat, l.lat), _ = Math.max(n.lat, s.lat, a.lat, l.lat); const d = Math.pow(2, -this.zoom) / 16 * 270, p = "globe" === this.projection.name ? 1 : 4, m = (t, i, o, r, n) => { const s = (t + o) / 2, a = (i + r) / 2, l = new e.pointGeometry(s, a), { lng: f, lat: g } = this.pointLocation3D(l), v = Math.max(0, c - f, u - g, f - h, g - _); c = Math.min(c, f), h = Math.max(h, f), u = Math.min(u, g), _ = Math.max(_, g), (n < p || v > d) && (m(t, i, s, a, n + 1), m(s, a, o, r, n + 1)); }; if (m(i, t, r, t, 1), m(r, t, r, o, 1), m(r, o, i, o, 1), m(i, o, i, t, 1), "globe" === this.projection.name) { const [t, i] = e.polesInViewport(this); t ? (_ = 90, h = 180, c = -180) : i && (u = -90, h = 180, c = -180); } return new e.LngLatBounds(new e.LngLat(c, u), new e.LngLat(h, _)) } _getBoundsRectangular(t, i) { const { top: o, left: r } = this._edgeInsets, n = this.height - this._edgeInsets.bottom, s = this.width - this._edgeInsets.right, a = new e.pointGeometry(r, o), l = new e.pointGeometry(s, o), c = new e.pointGeometry(s, n), h = new e.pointGeometry(r, n); let u = this.pointCoordinate(a, t), _ = this.pointCoordinate(l, t); const d = this.pointCoordinate(c, i), p = this.pointCoordinate(h, i), m = (e, t) => (t.y - e.y) / (t.x - e.x); return u.y > 1 && _.y >= 0 ? u = new e.MercatorCoordinate((1 - p.y) / m(p, u) + p.x, 1) : u.y < 0 && _.y <= 1 && (u = new e.MercatorCoordinate(-p.y / m(p, u) + p.x, 0)), _.y > 1 && u.y >= 0 ? _ = new e.MercatorCoordinate((1 - d.y) / m(d, _) + d.x, 1) : _.y < 0 && u.y <= 1 && (_ = new e.MercatorCoordinate(-d.y / m(d, _) + d.x, 0)), (new e.LngLatBounds).extend(this.coordinateLocation(u)).extend(this.coordinateLocation(_)).extend(this.coordinateLocation(p)).extend(this.coordinateLocation(d)) } _getBoundsRectangularTerrain() { const e = this.elevation; if (!e.visibleDemTiles.length || e.isUsingMockSource()) return this._getBoundsRectangular(0, 0); const t = e.visibleDemTiles.reduce(((e, t) => { if (t.dem) { const i = t.dem.tree; e.min = Math.min(e.min, i.minimums[0]), e.max = Math.max(e.max, i.maximums[0]); } return e }), { min: Number.MAX_VALUE, max: 0 }); return this._getBoundsRectangular(t.min * e.exaggeration(), t.max * e.exaggeration()) } getBounds() { return "mercator" === this.projection.name || "equirectangular" === this.projection.name ? this._terrainEnabled() ? this._getBoundsRectangularTerrain() : this._getBoundsRectangular(0, 0) : this._getBoundsNonRectangular() } horizonLineFromTop(e = !0) { const t = this.height / 2 / Math.tan(this._fov / 2) / Math.tan(Math.max(this._pitch, .1)) + this.centerOffset.y, i = this.height / 2 - t * (1 - this._horizonShift); return e ? Math.max(0, i) : i } getMaxBounds() { return this.maxBounds } setMaxBounds(t) { this.maxBounds = t, this.minLat = -e.MAX_MERCATOR_LATITUDE, this.maxLat = e.MAX_MERCATOR_LATITUDE, this.minLng = -180, this.maxLng = 180, t && (this.minLat = t.getSouth(), this.maxLat = t.getNorth(), this.minLng = t.getWest(), this.maxLng = t.getEast(), this.maxLng < this.minLng && (this.maxLng += 360)), this.worldMinX = e.mercatorXfromLng(this.minLng) * this.tileSize, this.worldMaxX = e.mercatorXfromLng(this.maxLng) * this.tileSize, this.worldMinY = e.mercatorYfromLat(this.maxLat) * this.tileSize, this.worldMaxY = e.mercatorYfromLat(this.minLat) * this.tileSize, this._constrain(); } calculatePosMatrix(e, t) { return this.projection.createTileMatrix(this, t, e) } calculateDistanceTileData(t) { const i = t.key, o = this._distanceTileDataCache; if (o[i]) return o[i]; const r = t.canonical, n = 1 / this.height, s = this.cameraWorldSize, a = s / this.zoomScale(r.z), l = (r.x + Math.pow(2, r.z) * t.wrap) * a, c = r.y * a, h = this.point; h.x *= s / this.worldSize, h.y *= s / this.worldSize; const u = this.angle, _ = Math.sin(-u), d = -Math.cos(-u); return o[i] = { bearing: [_, d], center: [(h.x - l) * n, (h.y - c) * n], scale: a / e.EXTENT * n }, o[i] } calculateFogTileMatrix(t) { const i = t.key, o = this._fogTileMatrixCache; if (o[i]) return o[i]; const r = this.projection.createTileMatrix(this, this.cameraWorldSizeForFog, t); return e.multiply(r, this.worldToFogMatrix, r), o[i] = new Float32Array(r), o[i] } calculateProjMatrix(t, i = !1) { const o = t.key, r = i ? this._alignedProjMatrixCache : this._projMatrixCache; if (r[o]) return r[o]; const n = this.calculatePosMatrix(t, this.worldSize); return e.multiply(n, this.projection.isReprojectedInTileSpace ? this.mercatorMatrix : i ? this.alignedProjMatrix : this.projMatrix, n), r[o] = new Float32Array(n), r[o] } calculatePixelsToTileUnitsMatrix(t) { const i = t.tileID.key, o = this._pixelsToTileUnitsCache; if (o[i]) return o[i]; const r = function(t, i) { const { scale: o } = t.tileTransform, r = o * e.EXTENT / (t.tileSize * Math.pow(2, i.zoom - t.tileID.overscaledZ + t.tileID.canonical.z)); return n = new Float32Array(4), l = (s = i.inverseAdjustmentMatrix)[1], c = s[2], h = s[3], _ = (a = [r, r])[1], n[0] = s[0] * (u = a[0]), n[1] = l * u, n[2] = c * _, n[3] = h * _, n; var n, s, a, l, c, h, u, _; }(t, this); return o[i] = r, o[i] } customLayerMatrix() { return this.mercatorMatrix.slice() } globeToMercatorMatrix() { if ("globe" === this.projection.name) { const t = 1 / this.worldSize, i = e.fromScaling([], [t, t, t]); return e.multiply(i, i, this.globeMatrix), i } } recenterOnTerrain() { if (!this._elevation || "globe" === this.projection.name) return; const t = this._elevation; this._updateCameraState(); const i = e.mercatorZfromAltitude(1, this._center.lat) * this.worldSize, o = this._computeCameraPosition(i), r = this._camera.forward(), n = e.mercatorZfromAltitude(1, this._center.lat); o[2] /= n, r[2] /= n, e.normalize(r, r); const s = t.raycast(o, r, t.exaggeration()); if (s) { const t = e.scaleAndAdd([], o, r, s), i = new e.MercatorCoordinate(t[0], t[1], e.mercatorZfromAltitude(t[2], e.latFromMercatorY(t[1]))), a = (i.z + e.length([i.x - o[0], i.y - o[1], i.z - o[2] * n])) * this._pixelsPerMercatorPixel; this._seaLevelZoom = this._zoomFromMercatorZ(a), this._centerAltitude = i.toAltitude(), this._center = this.coordinateLocation(i), this._updateZoomFromElevation(), this._constrain(), this._calcMatrices(); } } _constrainCamera(t = !1) { if (!this._elevation) return; const i = this._elevation, o = e.mercatorZfromAltitude(1, this._center.lat) * this.worldSize, r = this._computeCameraPosition(o), n = i.getAtPointOrZero(new e.MercatorCoordinate(...r)), s = this.pixelsPerMeter / this.worldSize * n, a = this._minimumHeightOverTerrain(), l = r[2] - s; if (l <= a) if (l < 0 || t) { const t = this.locationCoordinate(this._center, this._centerAltitude), i = [r[0], r[1], t.z - r[2]], o = e.length(i); i[2] -= (a - l) / this._pixelsPerMercatorPixel; const n = e.length(i); if (0 === n) return; e.scale$2(i, i, o / n * this._pixelsPerMercatorPixel), this._camera.position = [r[0], r[1], t.z * this._pixelsPerMercatorPixel - i[2]], this._updateStateFromCamera(); } else this._isCameraConstrained = !0; } _constrain() { if (!this.center || !this.width || !this.height || this._constraining) return; this._constraining = !0; const t = "globe" === this.projection.name || this.mercatorFromTransition; if (this.projection.isReprojectedInTileSpace || t) { const i = this.center; return i.lat = e.clamp(i.lat, this.minLat, this.maxLat), (this.maxBounds || !this.renderWorldCopies && !t) && (i.lng = e.clamp(i.lng, this.minLng, this.maxLng)), this.center = i, void(this._constraining = !1) } const i = this._unmodified, { x: o, y: r } = this.point; let n = 0, s = o, a = r; const l = this.width / 2, c = this.height / 2, h = this.worldMinY * this.scale, u = this.worldMaxY * this.scale; if (r - c < h && (a = h + c), r + c > u && (a = u - c), u - h < this.height && (n = Math.max(n, this.height / (u - h)), a = (u + h) / 2), this.maxBounds || !this._renderWorldCopies || !this.projection.wrap) { const e = this.worldMinX * this.scale, t = this.worldMaxX * this.scale, i = this.worldSize / 2 - (e + t) / 2; s = (o + i + this.worldSize) % this.worldSize - i, s - l < e && (s = e + l), s + l > t && (s = t - l), t - e < this.width && (n = Math.max(n, this.width / (t - e)), s = (t + e) / 2); } s === o && a === r || (this.center = this.unproject(new e.pointGeometry(s, a))), n && (this.zoom += this.scaleZoom(n)), this._constrainCamera(), this._unmodified = i, this._constraining = !1; } _minZoomForBounds() { let e = Math.max(0, this.scaleZoom(this.height / (this.worldMaxY - this.worldMinY))); return this.maxBounds && (e = Math.max(e, this.scaleZoom(this.width / (this.worldMaxX - this.worldMinX)))), e } _maxCameraBoundsDistance() { return this._mercatorZfromZoom(this._minZoomForBounds()) } _calcMatrices() { if (!this.height) return; const t = this.centerOffset, i = this.pixelsPerMeter; "globe" === this.projection.name && (this._mercatorScaleRatio = e.mercatorZfromAltitude(1, this.center.lat) / e.mercatorZfromAltitude(1, e.GLOBE_SCALE_MATCH_LATITUDE)); const o = qo(this.projection, this.zoom, this.width, this.height, 1024); this._pixelsPerMercatorPixel = this.projection.pixelSpaceConversion(this.center.lat, this.worldSize, o), this.cameraToCenterDistance = .5 / Math.tan(.5 * this._fov) * this.height * this._pixelsPerMercatorPixel, this._updateCameraState(), this._farZ = this.projection.farthestPixelDistance(this), this._nearZ = this.height / 50; const r = "meters" === this.projection.zAxisUnit ? i : 1, n = this._camera.getWorldToCamera(this.worldSize, r), s = this._camera.getCameraToClipPerspective(this._fov, this.width / this.height, this._nearZ, this._farZ); s[8] = 2 * -t.x / this.width, s[9] = 2 * t.y / this.height; let a = e.mul([], s, n); if (this.projection.isReprojectedInTileSpace) { const t = this.locationCoordinate(this.center), i = e.identity([]); e.translate(i, i, [t.x * this.worldSize, t.y * this.worldSize, 0]), e.multiply(i, i, Wo(this)), e.translate(i, i, [-t.x * this.worldSize, -t.y * this.worldSize, 0]), e.multiply(a, a, i), this.inverseAdjustmentMatrix = function(e) { const t = Wo(e, !0); return v([], [t[0], t[1], t[4], t[5]]) }(this); } else this.inverseAdjustmentMatrix = [1, 0, 0, 1]; this.mercatorMatrix = e.scale([], a, [this.worldSize, this.worldSize, this.worldSize / r, 1]), this.projMatrix = a, this.invProjMatrix = e.invert(new Float64Array(16), this.projMatrix); const l = e.invert([], s); this.frustumCorners = e.FrustumCorners.fromInvProjectionMatrix(l, this.horizonLineFromTop(), this.height); const c = new Float32Array(16); e.identity(c), e.scale(c, c, [1, -1, 1]), e.rotateX(c, c, this._pitch), e.rotateZ(c, c, this.angle); const h = e.perspective(new Float32Array(16), this._fov, this.width / this.height, this._nearZ, this._farZ), u = (Math.PI / 2 - this._pitch) * (this.height / this._fov) * this._horizonShift; h[8] = 2 * -t.x / this.width, h[9] = 2 * (t.y + u) / this.height, this.skyboxMatrix = e.multiply(c, h, c); const _ = this.point, d = _.x, p = _.y, m = this.width % 2 / 2, f = this.height % 2 / 2, g = Math.cos(this.angle), x = Math.sin(this.angle), y = d - Math.round(d) + g * m + x * f, b = p - Math.round(p) + g * f + x * m, w = new Float64Array(a); if (e.translate(w, w, [y > .5 ? y - 1 : y, b > .5 ? b - 1 : b, 0]), this.alignedProjMatrix = w, a = e.create(), e.scale(a, a, [this.width / 2, -this.height / 2, 1]), e.translate(a, a, [1, -1, 0]), this.labelPlaneMatrix = a, a = e.create(), e.scale(a, a, [1, -1, 1]), e.translate(a, a, [-1, -1, 0]), e.scale(a, a, [2 / this.width, 2 / this.height, 1]), this.glCoordMatrix = a, this.pixelMatrix = e.multiply(new Float64Array(16), this.labelPlaneMatrix, this.projMatrix), this._calcFogMatrices(), this._distanceTileDataCache = {}, a = e.invert(new Float64Array(16), this.pixelMatrix), !a) throw new Error("failed to invert matrix"); if (this.pixelMatrixInverse = a, "globe" === this.projection.name || this.mercatorFromTransition) { this.globeMatrix = e.calculateGlobeMatrix(this); const t = [this.globeMatrix[12], this.globeMatrix[13], this.globeMatrix[14]]; this.globeCenterInViewSpace = e.transformMat4(t, t, n), this.globeRadius = this.worldSize / 2 / Math.PI - 1; } else this.globeMatrix = a; this._projMatrixCache = {}, this._alignedProjMatrixCache = {}, this._pixelsToTileUnitsCache = {}; } _calcFogMatrices() { this._fogTileMatrixCache = {}; const t = this.cameraWorldSizeForFog, i = this.cameraPixelsPerMeter, o = this._camera.position, r = 1 / this.height / this._pixelsPerMercatorPixel, n = [t, t, i]; e.scale$2(n, n, r), e.scale$2(o, o, -1), e.multiply$2(o, o, n); const s = e.create(); e.translate(s, s, o), e.scale(s, s, n), this.mercatorFogMatrix = s, this.worldToFogMatrix = this._camera.getWorldToCameraPosition(t, i, r); } _computeCameraPosition(e) { const t = (e = e || this.pixelsPerMeter) / this.pixelsPerMeter, i = this._camera.forward(), o = this.point, r = this._mercatorZfromZoom(this._seaLevelZoom ? this._seaLevelZoom : this._zoom) * t - e / this.worldSize * this._centerAltitude; return [o.x / this.worldSize - i[0] * r, o.y / this.worldSize - i[1] * r, e / this.worldSize * this._centerAltitude - i[2] * r] } _updateCameraState() { this.height && (this._camera.setPitchBearing(this._pitch, this.angle), this._camera.position = this._computeCameraPosition()); } _translateCameraConstrained(t) { const i = this._maxCameraBoundsDistance() * Math.cos(this._pitch), o = this._camera.position[2], r = t[2]; let n = 1; this.projection.wrap && (this.center = this.center.wrap()), r > 0 && (n = Math.min((i - o) / r, 1)), this._camera.position = e.scaleAndAdd([], this._camera.position, t, n), this._updateStateFromCamera(); } _updateStateFromCamera() { const t = this._camera.position, i = this._camera.forward(), { pitch: o, bearing: r } = this._camera.getPitchBearing(), n = e.mercatorZfromAltitude(this._centerAltitude, this.center.lat) * this._pixelsPerMercatorPixel, s = this._mercatorZfromZoom(this._maxZoom) * Math.cos(e.degToRad(this._maxPitch)), a = Math.max((t[2] - n) / Math.cos(o), s), l = this._zoomFromMercatorZ(a); e.scaleAndAdd(t, t, i, a), this._pitch = e.clamp(o, e.degToRad(this.minPitch), e.degToRad(this.maxPitch)), this.angle = e.wrap(r, -Math.PI, Math.PI), this._setZoom(e.clamp(l, this._minZoom, this._maxZoom)), this._updateSeaLevelZoom(), this._center = this.coordinateLocation(new e.MercatorCoordinate(t[0], t[1], t[2])), this._unmodified = !1, this._constrain(), this._calcMatrices(); } _worldSizeFromZoom(e) { return Math.pow(2, e) * this.tileSize } _mercatorZfromZoom(e) { return this.cameraToCenterDistance / this._worldSizeFromZoom(e) } _minimumHeightOverTerrain() { const e = Math.min((null != this._seaLevelZoom ? this._seaLevelZoom : this._zoom) + 4, this._maxZoom); return this._mercatorZfromZoom(e) } _zoomFromMercatorZ(e) { return this.scaleZoom(this.cameraToCenterDistance / (e * this.tileSize)) } zoomFromMercatorZAdjusted(t) { let i = 0, o = e.GLOBE_ZOOM_THRESHOLD_MAX, r = 0, n = 1 / 0; for (; o - i > 1e-6 && o > i;) { const e = i + .5 * (o - i), s = this.tileSize * Math.pow(2, e), a = this.getCameraToCenterDistance(this.projection, e, s), l = this.scaleZoom(a / (t * this.tileSize)), c = Math.abs(e - l); c < n && (n = c, r = e), e < l ? i = e : o = e; } return r } _terrainEnabled() { return !(!this._elevation || !this.projection.supportsTerrain && (e.warnOnce("Terrain is not yet supported with alternate projections. Use mercator or globe to enable terrain."), 1)) } anyCornerOffEdge(t, i) { const o = Math.min(t.x, i.x), r = Math.max(t.x, i.x), n = Math.min(t.y, i.y), s = Math.max(t.y, i.y); if (n < this.horizonLineFromTop(!1)) return !0; if ("mercator" !== this.projection.name) return !1; const a = [new e.pointGeometry(o, n), new e.pointGeometry(r, s), new e.pointGeometry(o, s), new e.pointGeometry(r, n)], l = this.renderWorldCopies ? -3 : 0, c = this.renderWorldCopies ? 4 : 1; for (const e of a) { const t = this.pointRayIntersection(e); if (t.t < 0) return !0; const i = this.rayIntersectionCoordinate(t); if (i.x < l || i.y < 0 || i.x > c || i.y > 1) return !0 } return !1 } isHorizonVisible() { return this.pitch + e.radToDeg(this.fovAboveCenter) > 88 || this.anyCornerOffEdge(new e.pointGeometry(0, 0), new e.pointGeometry(this.width, this.height)) } zoomDeltaToMovement(t, i) { const o = e.length(e.sub([], this._camera.position, t)), r = this._zoomFromMercatorZ(o) + i; return o - this._mercatorZfromZoom(r) } getCameraPoint() { if ("globe" === this.projection.name) { const t = function([t, i, o], r) { const n = [t, i, o, 1]; e.transformMat4$1(n, n, r); const s = n[3] = Math.max(n[3], 1e-6); return n[0] /= s, n[1] /= s, n[2] /= s, n }([this.globeMatrix[12], this.globeMatrix[13], this.globeMatrix[14]], this.pixelMatrix); return new e.pointGeometry(t[0], t[1]) } { const t = Math.tan(this._pitch) * (this.cameraToCenterDistance || 1); return this.centerPoint.add(new e.pointGeometry(0, t)) } } getCameraToCenterDistance(e, t = this.zoom, i = this.worldSize) { const o = qo(e, t, this.width, this.height, 1024), r = e.pixelSpaceConversion(this.center.lat, i, o); return .5 / Math.tan(.5 * this._fov) * this.height * r } getWorldToCameraMatrix() { const t = this._camera.getWorldToCamera(this.worldSize, "meters" === this.projection.zAxisUnit ? this.pixelsPerMeter : 1); return "globe" === this.projection.name && e.multiply(t, t, this.globeMatrix), t } } function Jo(e, t) { let i = !1, o = null; const r = () => { o = null, i && (e(), o = setTimeout(r, t), i = !1); }; return () => (i = !0, o || r(), o) } class Qo { constructor(t) { this._hashName = t && encodeURIComponent(t), e.bindAll(["_getCurrentHash", "_onHashChange", "_updateHash"], this), this._updateHash = Jo(this._updateHashUnthrottled.bind(this), 300); } addTo(t) { return this._map = t, e.window.addEventListener("hashchange", this._onHashChange, !1), t.on("moveend", this._updateHash), this } remove() { return this._map ? (this._map.off("moveend", this._updateHash), e.window.removeEventListener("hashchange", this._onHashChange, !1), clearTimeout(this._updateHash()), this._map = void 0, this) : this } getHashString() { const t = this._map; if (!t) return ""; const i = er(t); if (this._hashName) { const t = this._hashName; let o = !1; const r = e.window.location.hash.slice(1).split("&").map((e => { const r = e.split("=")[0]; return r === t ? (o = !0, `${r}=${i}`) : e })).filter((e => e)); return o || r.push(`${t}=${i}`), `#${r.join("&")}` } return `#${i}` } _getCurrentHash() { const t = e.window.location.hash.replace("#", ""); if (this._hashName) { let e; return t.split("&").map((e => e.split("="))).forEach((t => { t[0] === this._hashName && (e = t); })), (e && e[1] || "").split("/") } return t.split("/") } _onHashChange() { const e = this._map; if (!e) return !1; const t = this._getCurrentHash(); if (t.length >= 3 && !t.some((e => isNaN(e)))) { const i = e.dragRotate.isEnabled() && e.touchZoomRotate.isEnabled() ? +(t[3] || 0) : e.getBearing(); return e.jumpTo({ center: [+t[2], +t[1]], zoom: +t[0], bearing: i, pitch: +(t[4] || 0) }), !0 } return !1 } _updateHashUnthrottled() { const t = e.window.location.href.replace(/(#.+)?$/, this.getHashString()); e.window.history.replaceState(e.window.history.state, null, t); } } function er(e, t) { const i = e.getCenter(), o = Math.round(100 * e.getZoom()) / 100, r = Math.ceil((o * Math.LN2 + Math.log(512 / 360 / .5)) / Math.LN10), n = Math.pow(10, r), s = Math.round(i.lng * n) / n, a = Math.round(i.lat * n) / n, l = e.getBearing(), c = e.getPitch(); let h = t ? `/${s}/${a}/${o}` : `${o}/${a}/${s}`; return (l || c) && (h += "/" + Math.round(10 * l) / 10), c && (h += `/${Math.round(c)}`), h } const tr = { linearity: .3, easing: e.bezier(0, 0, .3, 1) }, ir = e.extend({ deceleration: 2500, maxSpeed: 1400 }, tr), or = e.extend({ deceleration: 20, maxSpeed: 1400 }, tr), rr = e.extend({ deceleration: 1e3, maxSpeed: 360 }, tr), nr = e.extend({ deceleration: 1e3, maxSpeed: 90 }, tr); class sr { constructor(e) { this._map = e, this.clear(); } clear() { this._inertiaBuffer = []; } record(t) { this._drainInertiaBuffer(), this._inertiaBuffer.push({ time: e.exported.now(), settings: t }); } _drainInertiaBuffer() { const t = this._inertiaBuffer, i = e.exported.now(); for (; t.length > 0 && i - t[0].time > 160;) t.shift(); } _onMoveEnd(t) { if (e.exported.prefersReducedMotion) return; if (this._drainInertiaBuffer(), this._inertiaBuffer.length < 2) return; const i = { zoom: 0, bearing: 0, pitch: 0, pan: new e.pointGeometry(0, 0), pinchAround: void 0, around: void 0 }; for (const { settings: e } of this._inertiaBuffer) i.zoom += e.zoomDelta || 0, i.bearing += e.bearingDelta || 0, i.pitch += e.pitchDelta || 0, e.panDelta && i.pan._add(e.panDelta), e.around && (i.around = e.around), e.pinchAround && (i.pinchAround = e.pinchAround); const o = this._inertiaBuffer[this._inertiaBuffer.length - 1].time - this._inertiaBuffer[0].time, r = {}; if (i.pan.mag()) { const n = lr(i.pan.mag(), o, e.extend({}, ir, t || {})); r.offset = i.pan.mult(n.amount / i.pan.mag()), r.center = this._map.transform.center, ar(r, n); } if (i.zoom) { const e = lr(i.zoom, o, or); r.zoom = this._map.transform.zoom + e.amount, ar(r, e); } if (i.bearing) { const t = lr(i.bearing, o, rr); r.bearing = this._map.transform.bearing + e.clamp(t.amount, -179, 179), ar(r, t); } if (i.pitch) { const e = lr(i.pitch, o, nr); r.pitch = this._map.transform.pitch + e.amount, ar(r, e); } if (r.zoom || r.bearing) { const e = void 0 === i.pinchAround ? i.around : i.pinchAround; r.around = e ? this._map.unproject(e) : this._map.getCenter(); } return this.clear(), r.noMoveStart = !0, r } } function ar(e, t) { (!e.duration || e.duration < t.duration) && (e.duration = t.duration, e.easing = t.easing); } function lr(t, i, o) { const { maxSpeed: r, linearity: n, deceleration: s } = o, a = e.clamp(t * n / (i / 1e3), -r, r), l = Math.abs(a) / (s * n); return { easing: o.easing, duration: 1e3 * l, amount: a * (l / 2) } } class cr extends e.Event { preventDefault() { this._defaultPrevented = !0; } get defaultPrevented() { return this._defaultPrevented } constructor(t, i, o, r = {}) { const n = p(i.getCanvasContainer(), o), s = i.unproject(n); super(t, e.extend({ point: n, lngLat: s, originalEvent: o }, r)), this._defaultPrevented = !1, this.target = i; } } class hr extends e.Event { preventDefault() { this._defaultPrevented = !0; } get defaultPrevented() { return this._defaultPrevented } constructor(t, i, o) { const r = "touchend" === t ? o.changedTouches : o.touches, n = m(i.getCanvasContainer(), r), s = n.map((e => i.unproject(e))), a = n.reduce(((e, t, i, o) => e.add(t.div(o.length))), new e.pointGeometry(0, 0)); super(t, { points: n, point: a, lngLats: s, lngLat: i.unproject(a), originalEvent: o }), this._defaultPrevented = !1; } } class ur extends e.Event { preventDefault() { this._defaultPrevented = !0; } get defaultPrevented() { return this._defaultPrevented } constructor(e, t, i) { super(e, { originalEvent: i }), this._defaultPrevented = !1; } } class _r { constructor(e, t) { this._map = e, this._clickTolerance = t.clickTolerance; } reset() { this._mousedownPos = void 0; } wheel(e) { return this._firePreventable(new ur(e.type, this._map, e)) } mousedown(e, t) { return this._mousedownPos = t, this._firePreventable(new cr(e.type, this._map, e)) } mouseup(e) { this._map.fire(new cr(e.type, this._map, e)); } preclick(t) { const i = e.extend({}, t); i.type = "preclick", this._map.fire(new cr(i.type, this._map, i)); } click(e, t) { this._mousedownPos && this._mousedownPos.dist(t) >= this._clickTolerance || (this.preclick(e), this._map.fire(new cr(e.type, this._map, e))); } dblclick(e) { return this._firePreventable(new cr(e.type, this._map, e)) } mouseover(e) { this._map.fire(new cr(e.type, this._map, e)); } mouseout(e) { this._map.fire(new cr(e.type, this._map, e)); } touchstart(e) { return this._firePreventable(new hr(e.type, this._map, e)) } touchmove(e) { this._map.fire(new hr(e.type, this._map, e)); } touchend(e) { this._map.fire(new hr(e.type, this._map, e)); } touchcancel(e) { this._map.fire(new hr(e.type, this._map, e)); } _firePreventable(e) { if (this._map.fire(e), e.defaultPrevented) return {} } isEnabled() { return !0 } isActive() { return !1 } enable() {} disable() {} } class dr { constructor(e) { this._map = e; } reset() { this._delayContextMenu = !1, this._contextMenuEvent = void 0; } mousemove(e) { this._map.fire(new cr(e.type, this._map, e)); } mousedown() { this._delayContextMenu = !0; } mouseup() { this._delayContextMenu = !1, this._contextMenuEvent && (this._map.fire(new cr("contextmenu", this._map, this._contextMenuEvent)), delete this._contextMenuEvent); } contextmenu(e) { this._delayContextMenu ? this._contextMenuEvent = e : this._map.fire(new cr(e.type, this._map, e)), this._map.listens("contextmenu") && e.preventDefault(); } isEnabled() { return !0 } isActive() { return !1 } enable() {} disable() {} } class pr { constructor(e, t) { this._map = e, this._el = e.getCanvasContainer(), this._container = e.getContainer(), this._clickTolerance = t.clickTolerance || 1; } isEnabled() { return !!this._enabled } isActive() { return !!this._active } enable() { this.isEnabled() || (this._enabled = !0); } disable() { this.isEnabled() && (this._enabled = !1); } mousedown(e, t) { this.isEnabled() && e.shiftKey && 0 === e.button && (h(), this._startPos = this._lastPos = t, this._active = !0); } mousemoveWindow(e, t) { if (!this._active) return; const i = t, o = this._startPos, r = this._lastPos; if (!o || !r || r.equals(i) || !this._box && i.dist(o) < this._clickTolerance) return; this._lastPos = i, this._box || (this._box = n("div", "mapboxgl-boxzoom", this._container), this._container.classList.add("mapboxgl-crosshair"), this._fireEvent("boxzoomstart", e)); const s = Math.min(o.x, i.x), a = Math.max(o.x, i.x), l = Math.min(o.y, i.y), c = Math.max(o.y, i.y); this._map._requestDomTask((() => { this._box && (this._box.style.transform = `translate(${s}px,${l}px)`, this._box.style.width = a - s + "px", this._box.style.height = c - l + "px"); })); } mouseupWindow(t, i) { if (!this._active) return; const o = this._startPos, r = i; if (o && 0 === t.button) { if (this.reset(), d(), o.x !== r.x || o.y !== r.y) return this._map.fire(new e.Event("boxzoomend", { originalEvent: t })), { cameraAnimation: e => e.fitScreenCoordinates(o, r, this._map.getBearing(), { linear: !1 }) }; this._fireEvent("boxzoomcancel", t); } } keydown(e) { this._active && 27 === e.keyCode && (this.reset(), this._fireEvent("boxzoomcancel", e)); } blur() { this.reset(); } reset() { this._active = !1, this._container.classList.remove("mapboxgl-crosshair"), this._box && (this._box.remove(), this._box = null), u(), delete this._startPos, delete this._lastPos; } _fireEvent(t, i) { return this._map.fire(new e.Event(t, { originalEvent: i })) } } function mr(e, t) { const i = {}; for (let o = 0; o < e.length; o++) i[e[o].identifier] = t[o]; return i } class fr { constructor(e) { this.reset(), this.numTouches = e.numTouches; } reset() { this.centroid = void 0, this.startTime = 0, this.touches = {}, this.aborted = !1; } touchstart(t, i, o) { (this.centroid || o.length > this.numTouches) && (this.aborted = !0), this.aborted || (0 === this.startTime && (this.startTime = t.timeStamp), o.length === this.numTouches && (this.centroid = function(t) { const i = new e.pointGeometry(0, 0); for (const e of t) i._add(e); return i.div(t.length) }(i), this.touches = mr(o, i))); } touchmove(e, t, i) { if (this.aborted || !this.centroid) return; const o = mr(i, t); for (const e in this.touches) { const t = this.touches[e], i = o[e]; (!i || i.dist(t) > 30) && (this.aborted = !0); } } touchend(e, t, i) { if ((!this.centroid || e.timeStamp - this.startTime > 500) && (this.aborted = !0), 0 === i.length) { const e = !this.aborted && this.centroid; if (this.reset(), e) return e } } } class gr { constructor(e) { this.singleTap = new fr(e), this.numTaps = e.numTaps, this.reset(); } reset() { this.lastTime = 1 / 0, this.lastTap = void 0, this.count = 0, this.singleTap.reset(); } touchstart(e, t, i) { this.singleTap.touchstart(e, t, i); } touchmove(e, t, i) { this.singleTap.touchmove(e, t, i); } touchend(e, t, i) { const o = this.singleTap.touchend(e, t, i); if (o) { const t = e.timeStamp - this.lastTime < 500, i = !this.lastTap || this.lastTap.dist(o) < 30; if (t && i || this.reset(), this.count++, this.lastTime = e.timeStamp, this.lastTap = o, this.count === this.numTaps) return this.reset(), o } } } class vr { constructor() { this._zoomIn = new gr({ numTouches: 1, numTaps: 2 }), this._zoomOut = new gr({ numTouches: 2, numTaps: 1 }), this.reset(); } reset() { this._active = !1, this._zoomIn.reset(), this._zoomOut.reset(); } touchstart(e, t, i) { this._zoomIn.touchstart(e, t, i), this._zoomOut.touchstart(e, t, i); } touchmove(e, t, i) { this._zoomIn.touchmove(e, t, i), this._zoomOut.touchmove(e, t, i); } touchend(e, t, i) { const o = this._zoomIn.touchend(e, t, i), r = this._zoomOut.touchend(e, t, i); return o ? (this._active = !0, e.preventDefault(), setTimeout((() => this.reset()), 0), { cameraAnimation: t => t.easeTo({ duration: 300, zoom: t.getZoom() + 1, around: t.unproject(o) }, { originalEvent: e }) }) : r ? (this._active = !0, e.preventDefault(), setTimeout((() => this.reset()), 0), { cameraAnimation: t => t.easeTo({ duration: 300, zoom: t.getZoom() - 1, around: t.unproject(r) }, { originalEvent: e }) }) : void 0 } touchcancel() { this.reset(); } enable() { this._enabled = !0; } disable() { this._enabled = !1, this.reset(); } isEnabled() { return this._enabled } isActive() { return this._active } } const xr = { 0: 1, 2: 2 }; class yr { constructor(e) { this.reset(), this._clickTolerance = e.clickTolerance || 1; } blur() { this.reset(); } reset() { this._active = !1, this._moved = !1, this._lastPoint = void 0, this._eventButton = void 0; } _correctButton(e, t) { return !1 } _move(e, t) { return {} } mousedown(e, t) { if (this._lastPoint) return; const i = f(e); this._correctButton(e, i) && (this._lastPoint = t, this._eventButton = i); } mousemoveWindow(e, t) { const i = this._lastPoint; if (i) if (e.preventDefault(), null != this._eventButton && function(e, t) { const i = xr[t]; return void 0 === e.buttons || (e.buttons & i) !== i }(e, this._eventButton)) this.reset(); else if (this._moved || !(t.dist(i) < this._clickTolerance)) return this._moved = !0, this._lastPoint = t, this._move(i, t) } mouseupWindow(e) { this._lastPoint && f(e) === this._eventButton && (this._moved && d(), this.reset()); } enable() { this._enabled = !0; } disable() { this._enabled = !1, this.reset(); } isEnabled() { return this._enabled } isActive() { return this._active } } class br extends yr { mousedown(e, t) { super.mousedown(e, t), this._lastPoint && (this._active = !0); } _correctButton(e, t) { return 0 === t && !e.ctrlKey } _move(e, t) { return { around: t, panDelta: t.sub(e) } } } class wr extends yr { _correctButton(e, t) { return 0 === t && e.ctrlKey || 2 === t } _move(e, t) { const i = .8 * (t.x - e.x); if (i) return this._active = !0, { bearingDelta: i } } contextmenu(e) { e.preventDefault(); } } class Tr extends yr { _correctButton(e, t) { return 0 === t && e.ctrlKey || 2 === t } _move(e, t) { const i = -.5 * (t.y - e.y); if (i) return this._active = !0, { pitchDelta: i } } contextmenu(e) { e.preventDefault(); } } class Er { constructor(t, i) { this._map = t, this._el = t.getCanvasContainer(), this._minTouches = 1, this._clickTolerance = i.clickTolerance || 1, this.reset(), e.bindAll(["_addTouchPanBlocker", "_showTouchPanBlockerAlert"], this); } reset() { this._active = !1, this._touches = {}, this._sum = new e.pointGeometry(0, 0); } touchstart(e, t, i) { return this._calculateTransform(e, t, i) } touchmove(t, i, o) { if (this._active && !(o.length < this._minTouches)) { if (this._map._cooperativeGestures && !this._map.isMoving()) { if (1 === o.length && !e.isFullscreen()) return void this._showTouchPanBlockerAlert(); "hidden" !== this._alertContainer.style.visibility && (this._alertContainer.style.visibility = "hidden", clearTimeout(this._alertTimer)); } return t.cancelable && t.preventDefault(), this._calculateTransform(t, i, o) } } touchend(e, t, i) { this._calculateTransform(e, t, i), this._active && i.length < this._minTouches && this.reset(); } touchcancel() { this.reset(); } _calculateTransform(t, i, o) { o.length > 0 && (this._active = !0); const r = mr(o, i), n = new e.pointGeometry(0, 0), s = new e.pointGeometry(0, 0); let a = 0; for (const e in r) { const t = r[e], i = this._touches[e]; i && (n._add(t), s._add(t.sub(i)), a++, r[e] = t); } if (this._touches = r, a < this._minTouches || !s.mag()) return; const l = s.div(a); return this._sum._add(l), this._sum.mag() < this._clickTolerance ? void 0 : { around: n.div(a), panDelta: l } } enable() { this._enabled = !0, this._map._cooperativeGestures && (this._addTouchPanBlocker(), this._el.classList.add("mapboxgl-touch-pan-blocker-override", "mapboxgl-scrollable-page")); } disable() { this._enabled = !1, this._map._cooperativeGestures && (clearTimeout(this._alertTimer), this._alertContainer.remove(), this._el.classList.remove("mapboxgl-touch-pan-blocker-override", "mapboxgl-scrollable-page")), this.reset(); } isEnabled() { return !!this._enabled } isActive() { return !!this._active } _addTouchPanBlocker() { this._map && !this._alertContainer && (this._alertContainer = n("div", "mapboxgl-touch-pan-blocker", this._map._container), this._alertContainer.textContent = this._map._getUIString("TouchPanBlocker.Message"), this._alertContainer.style.fontSize = `${Math.max(10,Math.min(24,Math.floor(.05*this._el.clientWidth)))}px`); } _showTouchPanBlockerAlert() { this._alertContainer.style.visibility = "visible", this._alertContainer.classList.add("mapboxgl-touch-pan-blocker-show"), this._alertContainer.setAttribute("role", "alert"), clearTimeout(this._alertTimer), this._alertTimer = setTimeout((() => { this._alertContainer.classList.remove("mapboxgl-touch-pan-blocker-show"), this._alertContainer.setAttribute("role", "null"); }), 500); } } class Cr { constructor() { this.reset(); } reset() { this._active = !1, this._firstTwoTouches = void 0; } _start(e) {} _move(e, t, i) { return {} } touchstart(e, t, i) { this._firstTwoTouches || i.length < 2 || (this._firstTwoTouches = [i[0].identifier, i[1].identifier], this._start([t[0], t[1]])); } touchmove(e, t, i) { const o = this._firstTwoTouches; if (!o) return; e.preventDefault(); const [r, n] = o, s = Mr(i, t, r), a = Mr(i, t, n); if (!s || !a) return; const l = this._aroundCenter ? null : s.add(a).div(2); return this._move([s, a], l, e) } touchend(e, t, i) { if (!this._firstTwoTouches) return; const [o, r] = this._firstTwoTouches, n = Mr(i, t, o), s = Mr(i, t, r); n && s || (this._active && d(), this.reset()); } touchcancel() { this.reset(); } enable(e) { this._enabled = !0, this._aroundCenter = !!e && "center" === e.around; } disable() { this._enabled = !1, this.reset(); } isEnabled() { return this._enabled } isActive() { return this._active } } function Mr(e, t, i) { for (let o = 0; o < e.length; o++) if (e[o].identifier === i) return t[o] } function Ir(e, t) { return Math.log(e / t) / Math.LN2 } class Sr extends Cr { reset() { super.reset(), this._distance = 0, this._startDistance = 0; } _start(e) { this._startDistance = this._distance = e[0].dist(e[1]); } _move(e, t) { const i = this._distance; if (this._distance = e[0].dist(e[1]), this._active || !(Math.abs(Ir(this._distance, this._startDistance)) < .1)) return this._active = !0, { zoomDelta: Ir(this._distance, i), pinchAround: t } } } function Dr(e, t) { return 180 * e.angleWith(t) / Math.PI } class Lr extends Cr { reset() { super.reset(), this._minDiameter = 0, this._startVector = void 0, this._vector = void 0; } _start(e) { this._startVector = this._vector = e[0].sub(e[1]), this._minDiameter = e[0].dist(e[1]); } _move(e, t) { const i = this._vector; if (this._vector = e[0].sub(e[1]), i && (this._active || !this._isBelowThreshold(this._vector))) return this._active = !0, { bearingDelta: Dr(this._vector, i), pinchAround: t } } _isBelowThreshold(e) { this._minDiameter = Math.min(this._minDiameter, e.mag()); const t = 25 / (Math.PI * this._minDiameter) * 360, i = this._startVector; if (!i) return !1; const o = Dr(e, i); return Math.abs(o) < t } } function Ar(e) { return Math.abs(e.y) > Math.abs(e.x) } class zr extends Cr { constructor(e) { super(), this._map = e; } reset() { super.reset(), this._valid = void 0, this._firstMove = void 0, this._lastPoints = void 0; } _start(e) { this._lastPoints = e, Ar(e[0].sub(e[1])) && (this._valid = !1); } _move(t, i, o) { const r = this._lastPoints; if (!r) return; const n = t[0].sub(r[0]), s = t[1].sub(r[1]); return this._map._cooperativeGestures && !e.isFullscreen() && o.touches.length < 3 || (this._valid = this.gestureBeginsVertically(n, s, o.timeStamp), !this._valid) ? void 0 : (this._lastPoints = t, this._active = !0, { pitchDelta: (n.y + s.y) / 2 * -.5 }) } gestureBeginsVertically(e, t, i) { if (void 0 !== this._valid) return this._valid; const o = e.mag() >= 2, r = t.mag() >= 2; if (!o && !r) return; if (!o || !r) return null == this._firstMove && (this._firstMove = i), i - this._firstMove < 100 && void 0; const n = e.y > 0 == t.y > 0; return Ar(e) && Ar(t) && n } } const Pr = { panStep: 100, bearingStep: 15, pitchStep: 10 }; class Rr { constructor() { const e = Pr; this._panStep = e.panStep, this._bearingStep = e.bearingStep, this._pitchStep = e.pitchStep, this._rotationDisabled = !1; } blur() { this.reset(); } reset() { this._active = !1; } keydown(e) { if (e.altKey || e.ctrlKey || e.metaKey) return; let t = 0, i = 0, o = 0, r = 0, n = 0; switch (e.keyCode) { case 61: case 107: case 171: case 187: t = 1; break; case 189: case 109: case 173: t = -1; break; case 37: e.shiftKey ? i = -1 : (e.preventDefault(), r = -1); break; case 39: e.shiftKey ? i = 1 : (e.preventDefault(), r = 1); break; case 38: e.shiftKey ? o = 1 : (e.preventDefault(), n = -1); break; case 40: e.shiftKey ? o = -1 : (e.preventDefault(), n = 1); break; default: return } return this._rotationDisabled && (i = 0, o = 0), { cameraAnimation: s => { const a = s.getZoom(); s.easeTo({ duration: 300, easeId: "keyboardHandler", easing: Or, zoom: t ? Math.round(a) + t * (e.shiftKey ? 2 : 1) : a, bearing: s.getBearing() + i * this._bearingStep, pitch: s.getPitch() + o * this._pitchStep, offset: [-r * this._panStep, -n * this._panStep], center: s.getCenter() }, { originalEvent: e }); } } } enable() { this._enabled = !0; } disable() { this._enabled = !1, this.reset(); } isEnabled() { return this._enabled } isActive() { return this._active } disableRotation() { this._rotationDisabled = !0; } enableRotation() { this._rotationDisabled = !1; } } function Or(e) { return e * (2 - e) } const Br = 4.000244140625; class kr { constructor(t, i) { this._map = t, this._el = t.getCanvasContainer(), this._handler = i, this._delta = 0, this._defaultZoomRate = .01, this._wheelZoomRate = .0022222222222222222, e.bindAll(["_onTimeout", "_addScrollZoomBlocker", "_showBlockerAlert"], this); } setZoomRate(e) { this._defaultZoomRate = e; } setWheelZoomRate(e) { this._wheelZoomRate = e; } isEnabled() { return !!this._enabled } isActive() { return this._active || void 0 !== this._finishTimeout } isZooming() { return !!this._zooming } enable(e) { this.isEnabled() || (this._enabled = !0, this._aroundCenter = !!e && "center" === e.around, this._map._cooperativeGestures && this._addScrollZoomBlocker()); } disable() { this.isEnabled() && (this._enabled = !1, this._map._cooperativeGestures && (clearTimeout(this._alertTimer), this._alertContainer.remove())); } wheel(t) { if (!this.isEnabled()) return; if (this._map._cooperativeGestures) { if (!(t.ctrlKey || t.metaKey || this.isZooming() || e.isFullscreen())) return void this._showBlockerAlert(); "hidden" !== this._alertContainer.style.visibility && (this._alertContainer.style.visibility = "hidden", clearTimeout(this._alertTimer)); } let i = t.deltaMode === e.window.WheelEvent.DOM_DELTA_LINE ? 40 * t.deltaY : t.deltaY; const o = e.exported.now(), r = o - (this._lastWheelEventTime || 0); this._lastWheelEventTime = o, 0 !== i && i % Br == 0 ? this._type = "wheel" : 0 !== i && Math.abs(i) < 4 ? this._type = "trackpad" : r > 400 ? (this._type = null, this._lastValue = i, this._timeout = setTimeout(this._onTimeout, 40, t)) : this._type || (this._type = Math.abs(r * i) < 200 ? "trackpad" : "wheel", this._timeout && (clearTimeout(this._timeout), this._timeout = null, i += this._lastValue)), t.shiftKey && i && (i /= 4), this._type && (this._lastWheelEvent = t, this._delta -= i, this._active || this._start(t)), t.preventDefault(); } _onTimeout(e) { this._type = "wheel", this._delta -= this._lastValue, this._active || this._start(e); } _start(e) { if (!this._delta) return; this._frameId && (this._frameId = null), this._active = !0, this.isZooming() || (this._zooming = !0), this._finishTimeout && (clearTimeout(this._finishTimeout), delete this._finishTimeout); const t = p(this._el, e); this._aroundPoint = this._aroundCenter ? this._map.transform.centerPoint : t, this._aroundCoord = this._map.transform.pointCoordinate3D(this._aroundPoint), this._targetZoom = void 0, this._frameId || (this._frameId = !0, this._handler._triggerRenderFrame()); } renderFrame() { if (!this._frameId) return; if (this._frameId = null, !this.isActive()) return; const t = this._map.transform; "wheel" === this._type && t.projection.wrap && (t._center.lng >= 180 || t._center.lng <= -180) && (this._prevEase = null, this._easing = null, this._lastWheelEvent = null, this._lastWheelEventTime = 0); const i = () => t._terrainEnabled() && this._aroundCoord ? t.computeZoomRelativeTo(this._aroundCoord) : t.zoom; if (0 !== this._delta) { const e = "wheel" === this._type && Math.abs(this._delta) > Br ? this._wheelZoomRate : this._defaultZoomRate; let o = 2 / (1 + Math.exp(-Math.abs(this._delta * e))); this._delta < 0 && 0 !== o && (o = 1 / o); const r = i(), n = Math.pow(2, r), s = "number" == typeof this._targetZoom ? t.zoomScale(this._targetZoom) : n; this._targetZoom = Math.min(t.maxZoom, Math.max(t.minZoom, t.scaleZoom(s * o))), "wheel" === this._type && (this._startZoom = r, this._easing = this._smoothOutEasing(200)), this._delta = 0; } const o = "number" == typeof this._targetZoom ? this._targetZoom : i(), r = this._startZoom, n = this._easing; let s, a = !1; if ("wheel" === this._type && r && n) { const t = Math.min((e.exported.now() - this._lastWheelEventTime) / 200, 1), i = n(t); s = e.number(r, o, i), t < 1 ? this._frameId || (this._frameId = !0) : a = !0; } else s = o, a = !0; return this._active = !0, a && (this._active = !1, this._finishTimeout = setTimeout((() => { this._zooming = !1, this._handler._triggerRenderFrame(), delete this._targetZoom, delete this._finishTimeout; }), 200)), { noInertia: !0, needsRenderFrame: !a, zoomDelta: s - i(), around: this._aroundPoint, aroundCoord: this._aroundCoord, originalEvent: this._lastWheelEvent } } _smoothOutEasing(t) { let i = e.ease; if (this._prevEase) { const t = this._prevEase, o = (e.exported.now() - t.start) / t.duration, r = t.easing(o + .01) - t.easing(o), n = .27 / Math.sqrt(r * r + 1e-4) * .01, s = Math.sqrt(.0729 - n * n); i = e.bezier(n, s, .25, 1); } return this._prevEase = { start: e.exported.now(), duration: t, easing: i }, i } blur() { this.reset(); } reset() { this._active = !1; } _addScrollZoomBlocker() { this._map && !this._alertContainer && (this._alertContainer = n("div", "mapboxgl-scroll-zoom-blocker", this._map._container), this._alertContainer.textContent = /(Mac|iPad)/i.test(e.window.navigator.userAgent) ? this._map._getUIString("ScrollZoomBlocker.CmdMessage") : this._map._getUIString("ScrollZoomBlocker.CtrlMessage"), this._alertContainer.style.fontSize = `${Math.max(10,Math.min(24,Math.floor(.05*this._el.clientWidth)))}px`); } _showBlockerAlert() { this._alertContainer.style.visibility = "visible", this._alertContainer.classList.add("mapboxgl-scroll-zoom-blocker-show"), this._alertContainer.setAttribute("role", "alert"), clearTimeout(this._alertTimer), this._alertTimer = setTimeout((() => { this._alertContainer.classList.remove("mapboxgl-scroll-zoom-blocker-show"), this._alertContainer.setAttribute("role", "null"); }), 200); } } class Fr { constructor(e, t) { this._clickZoom = e, this._tapZoom = t; } 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 Ur { constructor() { this.reset(); } reset() { this._active = !1; } blur() { this.reset(); } dblclick(e, t) { return e.preventDefault(), { cameraAnimation: i => { i.easeTo({ duration: 300, zoom: i.getZoom() + (e.shiftKey ? -1 : 1), around: i.unproject(t) }, { originalEvent: e }); } } } enable() { this._enabled = !0; } disable() { this._enabled = !1, this.reset(); } isEnabled() { return this._enabled } isActive() { return this._active } } class Nr { constructor() { this._tap = new gr({ numTouches: 1, numTaps: 1 }), this.reset(); } reset() { this._active = !1, this._swipePoint = void 0, this._swipeTouch = 0, this._tapTime = 0, this._tap.reset(); } touchstart(e, t, i) { this._swipePoint || (this._tapTime && e.timeStamp - this._tapTime > 500 && this.reset(), this._tapTime ? i.length > 0 && (this._swipePoint = t[0], this._swipeTouch = i[0].identifier) : this._tap.touchstart(e, t, i)); } touchmove(e, t, i) { if (this._tapTime) { if (this._swipePoint) { if (i[0].identifier !== this._swipeTouch) return; const o = t[0], r = o.y - this._swipePoint.y; return this._swipePoint = o, e.preventDefault(), this._active = !0, { zoomDelta: r / 128 } } } else this._tap.touchmove(e, t, i); } touchend(e, t, i) { this._tapTime ? this._swipePoint && 0 === i.length && this.reset() : this._tap.touchend(e, t, i) && (this._tapTime = e.timeStamp); } touchcancel() { this.reset(); } enable() { this._enabled = !0; } disable() { this._enabled = !1, this.reset(); } isEnabled() { return this._enabled } isActive() { return this._active } } class Gr { constructor(e, t, i) { this._el = e, this._mousePan = t, this._touchPan = i; } enable(e) { this._inertiaOptions = e || {}, this._mousePan.enable(), this._touchPan.enable(), this._el.classList.add("mapboxgl-touch-drag-pan"); } disable() { this._mousePan.disable(), this._touchPan.disable(), this._el.classList.remove("mapboxgl-touch-drag-pan"); } isEnabled() { return this._mousePan.isEnabled() && this._touchPan.isEnabled() } isActive() { return this._mousePan.isActive() || this._touchPan.isActive() } } class jr { constructor(e, t, i) { this._pitchWithRotate = e.pitchWithRotate, this._mouseRotate = t, this._mousePitch = i; } 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 Zr { constructor(e, t, i, o) { this._el = e, this._touchZoom = t, this._touchRotate = i, this._tapDragZoom = o, this._rotationDisabled = !1, this._enabled = !0; } enable(e) { this._touchZoom.enable(e), this._rotationDisabled || this._touchRotate.enable(e), this._tapDragZoom.enable(), this._el.classList.add("mapboxgl-touch-zoom-rotate"); } disable() { this._touchZoom.disable(), this._touchRotate.disable(), this._tapDragZoom.disable(), this._el.classList.remove("mapboxgl-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 = !0, this._touchRotate.disable(); } enableRotation() { this._rotationDisabled = !1, this._touchZoom.isEnabled() && this._touchRotate.enable(); } } const Vr = e => e.zoom || e.drag || e.pitch || e.rotate; class Wr extends e.Event {} class Xr { constructor() { this.constants = [1, 1, .01], this.radius = 0; } setup(t, i) { const o = e.sub([], i, t); this.radius = e.length(o[2] < 0 ? e.div([], o, this.constants) : [o[0], o[1], 0]); } projectRay(t) { e.div(t, t, this.constants), e.normalize(t, t), e.mul$1(t, t, this.constants); const i = e.scale$2([], t, this.radius); if (i[2] > 0) { const t = e.scale$2([], [0, 0, 1], e.dot(i, [0, 0, 1])), o = e.scale$2([], e.normalize([], [i[0], i[1], 0]), this.radius), r = e.add([], i, e.scale$2([], e.sub([], e.add([], o, t), i), 2)); i[0] = r[0], i[1] = r[1]; } return i } } function qr(e) { return e.panDelta && e.panDelta.mag() || e.zoomDelta || e.bearingDelta || e.pitchDelta } class $r { constructor(t, i) { this._map = t, this._el = this._map.getCanvasContainer(), this._handlers = [], this._handlersById = {}, this._changes = [], this._inertia = new sr(t), this._bearingSnap = i.bearingSnap, this._previousActiveHandlers = {}, this._trackingEllipsoid = new Xr, this._dragOrigin = null, this._eventsInProgress = {}, this._addDefaultHandlers(i), e.bindAll(["handleEvent", "handleWindowEvent"], this); const o = this._el; this._listeners = [ [o, "touchstart", { passive: !0 }], [o, "touchmove", { passive: !1 }], [o, "touchend", void 0], [o, "touchcancel", void 0], [o, "mousedown", void 0], [o, "mousemove", void 0], [o, "mouseup", void 0], [e.window.document, "mousemove", { capture: !0 }], [e.window.document, "mouseup", void 0], [o, "mouseover", void 0], [o, "mouseout", void 0], [o, "dblclick", void 0], [o, "click", void 0], [o, "keydown", { capture: !1 }], [o, "keyup", void 0], [o, "wheel", { passive: !1 }], [o, "contextmenu", void 0], [e.window, "blur", void 0] ]; for (const [t, i, o] of this._listeners) t.addEventListener(i, t === e.window.document ? this.handleWindowEvent : this.handleEvent, o); } destroy() { for (const [t, i, o] of this._listeners) t.removeEventListener(i, t === e.window.document ? this.handleWindowEvent : this.handleEvent, o); } _addDefaultHandlers(e) { const t = this._map, i = t.getCanvasContainer(); this._add("mapEvent", new _r(t, e)); const o = t.boxZoom = new pr(t, e); this._add("boxZoom", o); const r = new vr, n = new Ur; t.doubleClickZoom = new Fr(n, r), this._add("tapZoom", r), this._add("clickZoom", n); const s = new Nr; this._add("tapDragZoom", s); const a = t.touchPitch = new zr(t); this._add("touchPitch", a); const l = new wr(e), c = new Tr(e); t.dragRotate = new jr(e, l, c), this._add("mouseRotate", l, ["mousePitch"]), this._add("mousePitch", c, ["mouseRotate"]); const h = new br(e), u = new Er(t, e); t.dragPan = new Gr(i, h, u), this._add("mousePan", h), this._add("touchPan", u, ["touchZoom", "touchRotate"]); const _ = new Lr, d = new Sr; t.touchZoomRotate = new Zr(i, d, _, s), this._add("touchRotate", _, ["touchPan", "touchZoom"]), this._add("touchZoom", d, ["touchPan", "touchRotate"]), this._add("blockableMapEvent", new dr(t)); const p = t.scrollZoom = new kr(t, this); this._add("scrollZoom", p, ["mousePan"]); const m = t.keyboard = new Rr; this._add("keyboard", m); for (const i of ["boxZoom", "doubleClickZoom", "tapDragZoom", "touchPitch", "dragRotate", "dragPan", "touchZoomRotate", "scrollZoom", "keyboard"]) e.interactive && e[i] && t[i].enable(e[i]); } _add(e, t, i) { this._handlers.push({ handlerName: e, handler: t, allowed: i }), this._handlersById[e] = t; } stop(e) { if (!this._updatingCamera) { for (const { handler: e } of this._handlers) e.reset(); this._inertia.clear(), this._fireEvents({}, {}, e), this._changes = []; } } isActive() { for (const { handler: e } of this._handlers) if (e.isActive()) return !0; return !1 } isZooming() { return !!this._eventsInProgress.zoom || this._map.scrollZoom.isZooming() } isRotating() { return !!this._eventsInProgress.rotate } isMoving() { return !!Vr(this._eventsInProgress) || this.isZooming() } _isDragging() { return !!this._eventsInProgress.drag } _blockedByActive(e, t, i) { for (const o in e) if (o !== i && (!t || t.indexOf(o) < 0)) return !0; return !1 } handleWindowEvent(e) { this.handleEvent(e, `${e.type}Window`); } _getMapTouches(e) { const t = []; for (const i of e) this._el.contains(i.target) && t.push(i); return t } handleEvent(e, t) { this._updatingCamera = !0; const i = "renderFrame" === e.type, o = i ? void 0 : e, r = { needsRenderFrame: !1 }, n = {}, s = {}, a = e.touches ? this._getMapTouches(e.touches) : void 0, l = a ? m(this._el, a) : i ? void 0 : p(this._el, e); for (const { handlerName: i, handler: c, allowed: h } of this._handlers) { if (!c.isEnabled()) continue; let u; this._blockedByActive(s, h, i) ? c.reset() : c[t || e.type] && (u = c[t || e.type](e, l, a), this.mergeHandlerResult(r, n, u, i, o), u && u.needsRenderFrame && this._triggerRenderFrame()), (u || c.isActive()) && (s[i] = c); } const c = {}; for (const e in this._previousActiveHandlers) s[e] || (c[e] = o); this._previousActiveHandlers = s, (Object.keys(c).length || qr(r)) && (this._changes.push([r, n, c]), this._triggerRenderFrame()), (Object.keys(s).length || qr(r)) && this._map._stop(!0), this._updatingCamera = !1; const { cameraAnimation: h } = r; h && (this._inertia.clear(), this._fireEvents({}, {}, !0), this._changes = [], h(this._map)); } mergeHandlerResult(t, i, o, r, n) { if (!o) return; e.extend(t, o); const s = { handlerName: r, originalEvent: o.originalEvent || n }; void 0 !== o.zoomDelta && (i.zoom = s), void 0 !== o.panDelta && (i.drag = s), void 0 !== o.pitchDelta && (i.pitch = s), void 0 !== o.bearingDelta && (i.rotate = s); } _applyChanges() { const t = {}, i = {}, o = {}; for (const [r, n, s] of this._changes) r.panDelta && (t.panDelta = (t.panDelta || new e.pointGeometry(0, 0))._add(r.panDelta)), r.zoomDelta && (t.zoomDelta = (t.zoomDelta || 0) + r.zoomDelta), r.bearingDelta && (t.bearingDelta = (t.bearingDelta || 0) + r.bearingDelta), r.pitchDelta && (t.pitchDelta = (t.pitchDelta || 0) + r.pitchDelta), void 0 !== r.around && (t.around = r.around), void 0 !== r.aroundCoord && (t.aroundCoord = r.aroundCoord), void 0 !== r.pinchAround && (t.pinchAround = r.pinchAround), r.noInertia && (t.noInertia = r.noInertia), e.extend(i, n), e.extend(o, s); this._updateMapTransform(t, i, o), this._changes = []; } _updateMapTransform(t, i, o) { const r = this._map, n = r.transform, s = e => [e.x, e.y, e.z]; if ((e => { const t = this._eventsInProgress.drag; return t && !this._handlersById[t.handlerName].isActive() })() && !qr(t)) { const e = n.zoom; n.cameraElevationReference = "sea", n.recenterOnTerrain(), n.cameraElevationReference = "ground", e !== n.zoom && this._map._update(!0); } if (n._isCameraConstrained && r._stop(!0), !qr(t)) return void this._fireEvents(i, o, !0); let { panDelta: a, zoomDelta: l, bearingDelta: c, pitchDelta: h, around: u, aroundCoord: _, pinchAround: d } = t; n._isCameraConstrained && (l > 0 && (l = 0), n._isCameraConstrained = !1), void 0 !== d && (u = d), (l || (e => i.drag && !this._eventsInProgress.drag)()) && u && (this._dragOrigin = s(n.pointCoordinate3D(u)), this._trackingEllipsoid.setup(n._camera.position, this._dragOrigin)), n.cameraElevationReference = "sea", r._stop(!0), u = u || r.transform.centerPoint, c && (n.bearing += c), h && (n.pitch += h), n._updateCameraState(); const p = [0, 0, 0]; if (a) if ("mercator" === n.projection.name) { const e = this._trackingEllipsoid.projectRay(n.screenPointToMercatorRay(u).dir), t = this._trackingEllipsoid.projectRay(n.screenPointToMercatorRay(u.sub(a)).dir); p[0] = t[0] - e[0], p[1] = t[1] - e[1]; } else { const t = n.pointCoordinate(u); if ("globe" === n.projection.name) { a = a.rotate(-n.angle); const i = n._pixelsPerMercatorPixel / n.worldSize; p[0] = -a.x * e.mercatorScale(e.latFromMercatorY(t.y)) * i, p[1] = -a.y * e.mercatorScale(n.center.lat) * i; } else { const e = n.pointCoordinate(u.sub(a)); t && e && (p[0] = e.x - t.x, p[1] = e.y - t.y); } } const m = n.zoom, f = [0, 0, 0]; if (l) { const t = s(_ || n.pointCoordinate3D(u)), i = { dir: e.normalize([], e.sub([], t, n._camera.position)) }; if (i.dir[2] < 0) { const o = n.zoomDeltaToMovement(t, l); e.scale$2(f, i.dir, o); } } const g = e.add(p, p, f); n._translateCameraConstrained(g), l && Math.abs(n.zoom - m) > 1e-4 && n.recenterOnTerrain(), n.cameraElevationReference = "ground", this._map._update(), t.noInertia || this._inertia.record(t), this._fireEvents(i, o, !0); } _fireEvents(t, i, o) { const r = Vr(this._eventsInProgress), n = Vr(t), s = {}; for (const e in t) { const { originalEvent: i } = t[e]; this._eventsInProgress[e] || (s[`${e}start`] = i), this._eventsInProgress[e] = t[e]; }!r && n && this._fireEvent("movestart", n.originalEvent); for (const e in s) this._fireEvent(e, s[e]); n && this._fireEvent("move", n.originalEvent); for (const e in t) { const { originalEvent: i } = t[e]; this._fireEvent(e, i); } const a = {}; let l; for (const e in this._eventsInProgress) { const { handlerName: t, originalEvent: o } = this._eventsInProgress[e]; this._handlersById[t].isActive() || (delete this._eventsInProgress[e], l = i[t] || o, a[`${e}end`] = l); } for (const e in a) this._fireEvent(e, a[e]); const c = Vr(this._eventsInProgress); if (o && (r || n) && !c) { this._updatingCamera = !0; const t = this._inertia._onMoveEnd(this._map.dragPan._inertiaOptions), i = e => 0 !== e && -this._bearingSnap < e && e < this._bearingSnap; t ? (i(t.bearing || this._map.getBearing()) && (t.bearing = 0), this._map.easeTo(t, { originalEvent: l })) : (this._map.fire(new e.Event("moveend", { originalEvent: l })), i(this._map.getBearing()) && this._map.resetNorth()), this._updatingCamera = !1; } } _fireEvent(t, i) { this._map.fire(new e.Event(t, i ? { originalEvent: i } : {})); } _requestFrame() { return this._map.triggerRepaint(), this._map._renderTaskQueue.add((e => { this._frameId = void 0, this.handleEvent(new Wr("renderFrame", { timeStamp: e })), this._applyChanges(); })) } _triggerRenderFrame() { void 0 === this._frameId && (this._frameId = this._requestFrame()); } } const Hr = "map.setFreeCameraOptions(...) and map.getFreeCameraOptions() are not yet supported for non-mercator projections."; class Yr extends e.Evented { constructor(t, i) { super(), this._moving = !1, this._zooming = !1, this.transform = t, this._bearingSnap = i.bearingSnap, e.bindAll(["_renderFrameCallback"], this); } getCenter() { return new e.LngLat(this.transform.center.lng, this.transform.center.lat) } setCenter(e, t) { return this.jumpTo({ center: e }, t) } panBy(t, i, o) { return t = e.pointGeometry.convert(t).mult(-1), this.panTo(this.transform.center, e.extend({ offset: t }, i), o) } panTo(t, i, o) { return this.easeTo(e.extend({ center: t }, i), o) } getZoom() { return this.transform.zoom } setZoom(e, t) { return this.jumpTo({ zoom: e }, t), this } zoomTo(t, i, o) { return this.easeTo(e.extend({ zoom: t }, i), o) } zoomIn(e, t) { return this.zoomTo(this.getZoom() + 1, e, t), this } zoomOut(e, t) { return this.zoomTo(this.getZoom() - 1, e, t), this } getBearing() { return this.transform.bearing } setBearing(e, t) { return this.jumpTo({ bearing: e }, t), this } getPadding() { return this.transform.padding } setPadding(e, t) { return this.jumpTo({ padding: e }, t), this } rotateTo(t, i, o) { return this.easeTo(e.extend({ bearing: t }, i), o) } resetNorth(t, i) { return this.rotateTo(0, e.extend({ duration: 1e3 }, t), i), this } resetNorthPitch(t, i) { return this.easeTo(e.extend({ bearing: 0, pitch: 0, duration: 1e3 }, t), i), this } snapToNorth(e, t) { return Math.abs(this.getBearing()) < this._bearingSnap ? this.resetNorth(e, t) : this } getPitch() { return this.transform.pitch } setPitch(e, t) { return this.jumpTo({ pitch: e }, t), this } cameraForBounds(t, i) { t = e.LngLatBounds.convert(t); const o = i && i.bearing || 0, r = i && i.pitch || 0, n = t.getNorthWest(), s = t.getSouthEast(); return this._cameraForBounds(this.transform, n, s, o, r, i) } _extendCameraOptions(t) { const i = { top: 0, bottom: 0, right: 0, left: 0 }; if ("number" == typeof(t = e.extend({ padding: i, offset: [0, 0], maxZoom: this.transform.maxZoom }, t)).padding) { const e = t.padding; t.padding = { top: e, bottom: e, right: e, left: e }; } return t.padding = e.extend(i, t.padding), t } _minimumAABBFrustumDistance(e, t) { const i = t.max[0] - t.min[0], o = t.max[1] - t.min[1]; return i / o > e.aspect ? i / (2 * Math.tan(.5 * e.fovX) * e.aspect) : o / (2 * Math.tan(.5 * e.fovY) * e.aspect) } _cameraForBoundsOnGlobe(t, i, o, r, n, s) { const a = t.clone(), l = this._extendCameraOptions(s); a.bearing = r, a.pitch = n; const c = e.LngLat.convert(i), h = e.LngLat.convert(o), u = .5 * (c.lat + h.lat), _ = .5 * (c.lng + h.lng), d = e.latLngToECEF(u, _), p = e.normalize([], d), m = e.normalize([], e.cross([], p, [0, 1, 0])), f = e.cross([], m, p), g = [m[0], m[1], m[2], 0, f[0], f[1], f[2], 0, p[0], p[1], p[2], 0, 0, 0, 0, 1], v = [d, e.latLngToECEF(c.lat, c.lng), e.latLngToECEF(h.lat, c.lng), e.latLngToECEF(h.lat, h.lng), e.latLngToECEF(c.lat, h.lng), e.latLngToECEF(u, c.lng), e.latLngToECEF(u, h.lng), e.latLngToECEF(c.lat, _), e.latLngToECEF(h.lat, _)]; let x = e.Aabb.fromPoints(v.map((t => [e.dot(m, t), e.dot(f, t), e.dot(p, t)]))); const y = e.transformMat4([], x.center, g); 0 === e.squaredLength(y) && e.set(y, 0, 0, 1), e.normalize(y, y), e.scale$2(y, y, e.GLOBE_RADIUS), a.center = e.ecefToLatLng(y); const b = a.getWorldToCameraMatrix(), w = e.invert(new Float64Array(16), b); x = e.Aabb.applyTransform(x, e.multiply([], b, g)), e.transformMat4(y, y, b); const T = .5 * (x.max[2] - x.min[2]), E = this._minimumAABBFrustumDistance(a, x), C = e.scale$2([], [0, 0, 1], T), M = e.add(C, y, C), I = E + (0 === a.pitch ? 0 : e.distance(y, M)), S = a.globeCenterInViewSpace, D = e.sub([], y, [S[0], S[1], S[2]]); e.normalize(D, D), e.scale$2(D, D, I); const L = e.add([], y, D); e.transformMat4(L, L, w); const A = e.earthRadius / e.GLOBE_RADIUS, z = e.length(L), P = e.mercatorZfromAltitude(Math.max(z * A - e.earthRadius, Number.EPSILON), 0), R = Math.min(a.zoomFromMercatorZAdjusted(P), l.maxZoom); return R > .5 * (e.GLOBE_ZOOM_THRESHOLD_MIN + e.GLOBE_ZOOM_THRESHOLD_MAX) ? (a.setProjection({ name: "mercator" }), a.zoom = R, this._cameraForBounds(a, i, o, r, n, s)) : { center: a.center, zoom: R, bearing: r, pitch: n } } queryTerrainElevation(t, i) { const o = this.transform.elevation; return o ? (i = e.extend({}, { exaggerated: !0 }, i), o.getAtPoint(e.MercatorCoordinate.fromLngLat(t), null, i.exaggerated)) : null } _cameraForBounds(t, i, o, r, n, s) { if ("globe" === t.projection.name) return this._cameraForBoundsOnGlobe(t, i, o, r, n, s); const a = t.clone(), l = this._extendCameraOptions(s), c = a.padding; a.bearing = r, a.pitch = n; const h = e.LngLat.convert(i), u = e.LngLat.convert(o), _ = new e.LngLat(h.lng, u.lat), d = new e.LngLat(u.lng, h.lat), p = a.project(h), m = a.project(u), f = this.queryTerrainElevation(h), g = this.queryTerrainElevation(u), v = this.queryTerrainElevation(_), x = this.queryTerrainElevation(d), y = [ [p.x, p.y, Math.min(f || 0, g || 0, v || 0, x || 0)], [m.x, m.y, Math.max(f || 0, g || 0, v || 0, x || 0)] ]; let b = e.Aabb.fromPoints(y); const w = a.getWorldToCameraMatrix(), T = e.invert(new Float64Array(16), w); b = e.Aabb.applyTransform(b, w); const E = e.sub([], b.max, b.min), C = c.left || 0, M = c.right || 0, I = c.bottom || 0, S = c.top || 0, { left: D, right: L, top: A, bottom: z } = l.padding, P = .5 * (C + M), R = .5 * (S + I), O = Math.min(a.scaleZoom(a.scale * Math.min((a.width - (C + M + D + L)) / E[0], (a.height - (I + S + z + A)) / E[1])), l.maxZoom), B = a.scale / a.zoomScale(O); b = new e.Aabb([b.min[0] - (D + P) * B, b.min[1] - (z + R) * B, b.min[2]], [b.max[0] + (L + P) * B, b.max[1] + (A + R) * B, b.max[2]]); const k = .5 * E[2], F = this._minimumAABBFrustumDistance(a, b), U = [0, 0, 1, 0]; e.transformMat4$1(U, U, w), e.normalize$2(U, U); const N = e.scale$2([], U, F + k), G = e.add([], b.center, N), j = ("number" == typeof l.offset.x && "number" == typeof l.offset.y ? new e.pointGeometry(l.offset.x, l.offset.y) : e.pointGeometry.convert(l.offset)).rotate(-e.degToRad(r)); b.center[0] -= j.x * B, b.center[1] += j.y * B, e.transformMat4(b.center, b.center, T), e.transformMat4(G, G, T); const Z = [b.center[0], b.center[1], G[2] * a.pixelsPerMeter]; e.scale$2(Z, Z, 1 / a.worldSize); const V = e.lngFromMercatorX(Z[0]), W = e.latFromMercatorY(Z[1]), X = Math.min(a._zoomFromMercatorZ(Z[2]), l.maxZoom), q = new e.LngLat(V, W); return a.mercatorFromTransition && X < .5 * (e.GLOBE_ZOOM_THRESHOLD_MIN + e.GLOBE_ZOOM_THRESHOLD_MAX) ? (a.setProjection({ name: "globe" }), a.zoom = X, this._cameraForBounds(a, i, o, r, n, s)) : { center: q, zoom: X, bearing: r, pitch: n } } fitBounds(e, t, i) { const o = this.cameraForBounds(e, t); return this._fitInternal(o, t, i) } fitScreenCoordinates(t, i, o, r, n) { const s = e.pointGeometry.convert(t), a = e.pointGeometry.convert(i), l = new e.pointGeometry(Math.min(s.x, a.x), Math.min(s.y, a.y)), c = new e.pointGeometry(Math.max(s.x, a.x), Math.max(s.y, a.y)); if ("mercator" === this.transform.projection.name && this.transform.anyCornerOffEdge(s, a)) return this; const h = this.transform.pointLocation3D(l), u = this.transform.pointLocation3D(c), _ = this.transform.pointLocation3D(new e.pointGeometry(l.x, c.y)), d = this.transform.pointLocation3D(new e.pointGeometry(c.x, l.y)), p = [Math.min(h.lng, u.lng, _.lng, d.lng), Math.min(h.lat, u.lat, _.lat, d.lat)], m = [Math.max(h.lng, u.lng, _.lng, d.lng), Math.max(h.lat, u.lat, _.lat, d.lat)], f = r && r.pitch ? r.pitch : this.getPitch(), g = this._cameraForBounds(this.transform, p, m, o, f, r); return this._fitInternal(g, r, n) } _fitInternal(t, i, o) { return t ? (delete(i = e.extend(t, i)).padding, i.linear ? this.easeTo(i, o) : this.flyTo(i, o)) : this } jumpTo(t, i) { this.stop(); const o = t.preloadOnly ? this.transform.clone() : this.transform; let r = !1, n = !1, s = !1; return "zoom" in t && o.zoom !== +t.zoom && (r = !0, o.zoom = +t.zoom), void 0 !== t.center && (o.center = e.LngLat.convert(t.center)), "bearing" in t && o.bearing !== +t.bearing && (n = !0, o.bearing = +t.bearing), "pitch" in t && o.pitch !== +t.pitch && (s = !0, o.pitch = +t.pitch), null == t.padding || o.isPaddingEqual(t.padding) || (o.padding = t.padding), t.preloadOnly ? (this._preloadTiles(o), this) : (this.fire(new e.Event("movestart", i)).fire(new e.Event("move", i)), r && this.fire(new e.Event("zoomstart", i)).fire(new e.Event("zoom", i)).fire(new e.Event("zoomend", i)), n && this.fire(new e.Event("rotatestart", i)).fire(new e.Event("rotate", i)).fire(new e.Event("rotateend", i)), s && this.fire(new e.Event("pitchstart", i)).fire(new e.Event("pitch", i)).fire(new e.Event("pitchend", i)), this.fire(new e.Event("moveend", i))) } getFreeCameraOptions() { return this.transform.projection.supportsFreeCamera || e.warnOnce(Hr), this.transform.getFreeCameraOptions() } setFreeCameraOptions(t, i) { const o = this.transform; if (!o.projection.supportsFreeCamera) return e.warnOnce(Hr), this; this.stop(); const r = o.zoom, n = o.pitch, s = o.bearing; o.setFreeCameraOptions(t); const a = r !== o.zoom, l = n !== o.pitch, c = s !== o.bearing; return this.fire(new e.Event("movestart", i)).fire(new e.Event("move", i)), a && this.fire(new e.Event("zoomstart", i)).fire(new e.Event("zoom", i)).fire(new e.Event("zoomend", i)), c && this.fire(new e.Event("rotatestart", i)).fire(new e.Event("rotate", i)).fire(new e.Event("rotateend", i)), l && this.fire(new e.Event("pitchstart", i)).fire(new e.Event("pitch", i)).fire(new e.Event("pitchend", i)), this.fire(new e.Event("moveend", i)), this } easeTo(t, i) { this._stop(!1, t.easeId), (!1 === (t = e.extend({ offset: [0, 0], duration: 500, easing: e.ease }, t)).animate || !t.essential && e.exported.prefersReducedMotion) && (t.duration = 0); const o = this.transform, r = this.getZoom(), n = this.getBearing(), s = this.getPitch(), a = this.getPadding(), l = "zoom" in t ? +t.zoom : r, c = "bearing" in t ? this._normalizeBearing(t.bearing, n) : n, h = "pitch" in t ? +t.pitch : s, u = "padding" in t ? t.padding : o.padding, _ = e.pointGeometry.convert(t.offset); let d, p, m; if ("globe" === o.projection.name) { const i = e.MercatorCoordinate.fromLngLat(o.center), r = _.rotate(-o.angle); i.x += r.x / o.worldSize, i.y += r.y / o.worldSize; const n = i.toLngLat(), s = e.LngLat.convert(t.center || n); this._normalizeCenter(s), d = o.centerPoint.add(r), p = new e.pointGeometry(i.x, i.y).mult(o.worldSize), m = new e.pointGeometry(e.mercatorXfromLng(s.lng), e.mercatorYfromLat(s.lat)).mult(o.worldSize).sub(p); } else { d = o.centerPoint.add(_); const i = o.pointLocation(d), r = e.LngLat.convert(t.center || i); this._normalizeCenter(r), p = o.project(i), m = o.project(r).sub(p); } const f = o.zoomScale(l - r); let g, v; t.around && (g = e.LngLat.convert(t.around), v = o.locationPoint(g)); const x = this._zooming || l !== r, y = this._rotating || n !== c, b = this._pitching || h !== s, w = !o.isPaddingEqual(u), T = o => T => { if (x && (o.zoom = e.number(r, l, T)), y && (o.bearing = e.number(n, c, T)), b && (o.pitch = e.number(s, h, T)), w && (o.interpolatePadding(a, u, T), d = o.centerPoint.add(_)), g) o.setLocationAtPoint(g, v); else { const e = o.zoomScale(o.zoom - r), t = l > r ? Math.min(2, f) : Math.max(.5, f), i = Math.pow(t, 1 - T), n = o.unproject(p.add(m.mult(T * i)).mult(e)); o.setLocationAtPoint(o.renderWorldCopies ? n.wrap() : n, d); } return t.preloadOnly || this._fireMoveEvents(i), o }; if (t.preloadOnly) { const e = this._emulate(T, t.duration, o); return this._preloadTiles(e), this } const E = { moving: this._moving, zooming: this._zooming, rotating: this._rotating, pitching: this._pitching }; return this._zooming = x, this._rotating = y, this._pitching = b, this._padding = w, this._easeId = t.easeId, this._prepareEase(i, t.noMoveStart, E), this._ease(T(o), (e => { o.recenterOnTerrain(), this._afterEase(i, e); }), t), this } _prepareEase(t, i, o = {}) { this._moving = !0, this.transform.cameraElevationReference = "sea", i || o.moving || this.fire(new e.Event("movestart", t)), this._zooming && !o.zooming && this.fire(new e.Event("zoomstart", t)), this._rotating && !o.rotating && this.fire(new e.Event("rotatestart", t)), this._pitching && !o.pitching && this.fire(new e.Event("pitchstart", t)); } _fireMoveEvents(t) { this.fire(new e.Event("move", t)), this._zooming && this.fire(new e.Event("zoom", t)), this._rotating && this.fire(new e.Event("rotate", t)), this._pitching && this.fire(new e.Event("pitch", t)); } _afterEase(t, i) { if (this._easeId && i && this._easeId === i) return; this._easeId = void 0, this.transform.cameraElevationReference = "ground"; const o = this._zooming, r = this._rotating, n = this._pitching; this._moving = !1, this._zooming = !1, this._rotating = !1, this._pitching = !1, this._padding = !1, o && this.fire(new e.Event("zoomend", t)), r && this.fire(new e.Event("rotateend", t)), n && this.fire(new e.Event("pitchend", t)), this.fire(new e.Event("moveend", t)); } flyTo(t, i) { if (!t.essential && e.exported.prefersReducedMotion) { const o = e.pick(t, ["center", "zoom", "bearing", "pitch", "around"]); return this.jumpTo(o, i) } this.stop(), t = e.extend({ offset: [0, 0], speed: 1.2, curve: 1.42, easing: e.ease }, t); const o = this.transform, r = this.getZoom(), n = this.getBearing(), s = this.getPitch(), a = this.getPadding(), l = "zoom" in t ? e.clamp(+t.zoom, o.minZoom, o.maxZoom) : r, c = "bearing" in t ? this._normalizeBearing(t.bearing, n) : n, h = "pitch" in t ? +t.pitch : s, u = "padding" in t ? t.padding : o.padding, _ = o.zoomScale(l - r), d = e.pointGeometry.convert(t.offset); let p = o.centerPoint.add(d); const m = o.pointLocation(p), f = e.LngLat.convert(t.center || m); this._normalizeCenter(f); const g = o.project(m), v = o.project(f).sub(g); let x = t.curve; const y = Math.max(o.width, o.height), b = y / _, w = v.mag(); if ("minZoom" in t) { const i = e.clamp(Math.min(t.minZoom, r, l), o.minZoom, o.maxZoom), n = y / o.zoomScale(i - r); x = Math.sqrt(n / w * 2); } const T = x * x; function E(e) { const t = (b * b - y * y + (e ? -1 : 1) * T * T * w * w) / (2 * (e ? b : y) * T * w); return Math.log(Math.sqrt(t * t + 1) - t) } function C(e) { return (Math.exp(e) - Math.exp(-e)) / 2 } function M(e) { return (Math.exp(e) + Math.exp(-e)) / 2 } const I = E(0); let S = function(e) { return M(I) / M(I + x * e) }, D = function(e) { return y * ((M(I) * (C(t = I + x * e) / M(t)) - C(I)) / T) / w; var t; }, L = (E(1) - I) / x; if (Math.abs(w) < 1e-6 || !isFinite(L)) { if (Math.abs(y - b) < 1e-6) return this.easeTo(t, i); const e = b < y ? -1 : 1; L = Math.abs(Math.log(b / y)) / x, D = function() { return 0 }, S = function(t) { return Math.exp(e * x * t) }; } t.duration = "duration" in t ? +t.duration : 1e3 * L / ("screenSpeed" in t ? +t.screenSpeed / x : +t.speed), t.maxDuration && t.duration > t.maxDuration && (t.duration = 0); const A = n !== c, z = h !== s, P = !o.isPaddingEqual(u), R = o => _ => { const m = _ * L, x = 1 / S(m); o.zoom = 1 === _ ? l : r + o.scaleZoom(x), A && (o.bearing = e.number(n, c, _)), z && (o.pitch = e.number(s, h, _)), P && (o.interpolatePadding(a, u, _), p = o.centerPoint.add(d)); const y = 1 === _ ? f : o.unproject(g.add(v.mult(D(m))).mult(x)); return o.setLocationAtPoint(o.renderWorldCopies ? y.wrap() : y, p), o._updateCameraOnTerrain(), t.preloadOnly || this._fireMoveEvents(i), o }; if (t.preloadOnly) { const e = this._emulate(R, t.duration, o); return this._preloadTiles(e), this } return this._zooming = !0, this._rotating = A, this._pitching = z, this._padding = P, this._prepareEase(i, !1), this._ease(R(o), (() => this._afterEase(i)), t), this } isEasing() { return !!this._easeFrameId } stop() { return this._stop() } _stop(e, t) { if (this._easeFrameId && (this._cancelRenderFrame(this._easeFrameId), this._easeFrameId = void 0, this._onEaseFrame = void 0), this._onEaseEnd) { const e = this._onEaseEnd; this._onEaseEnd = void 0, e.call(this, t); } if (!e) { const e = this.handlers; e && e.stop(!1); } return this } _ease(t, i, o) { !1 === o.animate || 0 === o.duration ? (t(1), i()) : (this._easeStart = e.exported.now(), this._easeOptions = o, this._onEaseFrame = t, this._onEaseEnd = i, this._easeFrameId = this._requestRenderFrame(this._renderFrameCallback)); } _renderFrameCallback() { const t = Math.min((e.exported.now() - this._easeStart) / this._easeOptions.duration, 1), i = this._onEaseFrame; i && i(this._easeOptions.easing(t)), t < 1 ? this._easeFrameId = this._requestRenderFrame(this._renderFrameCallback) : this.stop(); } _normalizeBearing(t, i) { t = e.wrap(t, -180, 180); const o = Math.abs(t - i); return Math.abs(t - 360 - i) < o && (t -= 360), Math.abs(t + 360 - i) < o && (t += 360), t } _normalizeCenter(e) { const t = this.transform; if (!t.renderWorldCopies || t.maxBounds) return; const i = e.lng - t.center.lng; e.lng += i > 180 ? -360 : i < -180 ? 360 : 0; } _emulate(e, t, i) { const o = Math.ceil(15 * t / 1e3), r = [], n = e(i.clone()); for (let e = 0; e <= o; e++) { const t = n(e / o); r.push(t.clone()); } return r } } class Kr { constructor(t = {}) { this.options = t, e.bindAll(["_toggleAttribution", "_updateEditLink", "_updateData", "_updateCompact"], this); } getDefaultPosition() { return "bottom-right" } onAdd(e) { const t = this.options && this.options.compact; return this._map = e, this._container = n("div", "mapboxgl-ctrl mapboxgl-ctrl-attrib"), this._compactButton = n("button", "mapboxgl-ctrl-attrib-button", this._container), n("span", "mapboxgl-ctrl-icon", this._compactButton).setAttribute("aria-hidden", "true"), this._compactButton.type = "button", this._compactButton.addEventListener("click", this._toggleAttribution), this._setElementTitle(this._compactButton, "ToggleAttribution"), this._innerContainer = n("div", "mapboxgl-ctrl-attrib-inner", this._container), this._innerContainer.setAttribute("role", "list"), t && this._container.classList.add("mapboxgl-compact"), this._updateAttributions(), this._updateEditLink(), this._map.on("styledata", this._updateData), this._map.on("sourcedata", this._updateData), this._map.on("moveend", this._updateEditLink), void 0 === t && (this._map.on("resize", this._updateCompact), this._updateCompact()), this._container } onRemove() { this._container.remove(), this._map.off("styledata", this._updateData), this._map.off("sourcedata", this._updateData), this._map.off("moveend", this._updateEditLink), this._map.off("resize", this._updateCompact), this._map = void 0, this._attribHTML = void 0; } _setElementTitle(e, t) { const i = this._map._getUIString(`AttributionControl.${t}`); e.setAttribute("aria-label", i), e.removeAttribute("title"), e.firstElementChild && e.firstElementChild.setAttribute("title", i); } _toggleAttribution() { this._container.classList.contains("mapboxgl-compact-show") ? (this._container.classList.remove("mapboxgl-compact-show"), this._compactButton.setAttribute("aria-expanded", "false")) : (this._container.classList.add("mapboxgl-compact-show"), this._compactButton.setAttribute("aria-expanded", "true")); } _updateEditLink() { let t = this._editLink; t || (t = this._editLink = this._container.querySelector(".mapbox-improve-map")); const i = [{ key: "owner", value: this.styleOwner }, { key: "id", value: this.styleId }, { key: "access_token", value: this._map._requestManager._customAccessToken || e.config.ACCESS_TOKEN }]; if (t) { const o = i.reduce(((e, t, o) => (t.value && (e += `${t.key}=${t.value}${o<i.length-1?"&":""}`), e)), "?"); t.href = `${e.config.FEEDBACK_URL}/${o}#${er(this._map,!0)}`, t.rel = "noopener nofollow", this._setElementTitle(t, "MapFeedback"); } } _updateData(e) { !e || "metadata" !== e.sourceDataType && "visibility" !== e.sourceDataType && "style" !== e.dataType || (this._updateAttributions(), this._updateEditLink()); } _updateAttributions() { if (!this._map.style) return; let e = []; if (this._map.style.stylesheet) { const e = this._map.style.stylesheet; this.styleOwner = e.owner, this.styleId = e.id; } const t = this._map.style._sourceCaches; for (const i in t) { const o = t[i]; if (o.used) { const t = o.getSource(); t.attribution && e.indexOf(t.attribution) < 0 && e.push(t.attribution); } } e.sort(((e, t) => e.length - t.length)), e = e.filter(((t, i) => { for (let o = i + 1; o < e.length; o++) if (e[o].indexOf(t) >= 0) return !1; return !0 })), this.options.customAttribution && (Array.isArray(this.options.customAttribution) ? e = [...this.options.customAttribution, ...e] : e.unshift(this.options.customAttribution)); const i = e.join(" | "); i !== this._attribHTML && (this._attribHTML = i, e.length ? (this._innerContainer.innerHTML = i, this._container.classList.remove("mapboxgl-attrib-empty")) : this._container.classList.add("mapboxgl-attrib-empty"), this._editLink = null); } _updateCompact() { this._map.getCanvasContainer().offsetWidth <= 640 ? this._container.classList.add("mapboxgl-compact") : this._container.classList.remove("mapboxgl-compact", "mapboxgl-compact-show"); } } class Jr { constructor() { e.bindAll(["_updateLogo", "_updateCompact"], this); } onAdd(e) { this._map = e, this._container = n("div", "mapboxgl-ctrl"); const t = n("a", "mapboxgl-ctrl-logo"); return t.target = "_blank", t.rel = "noopener nofollow", t.href = "https://www.mapbox.com/", t.setAttribute("aria-label", this._map._getUIString("LogoControl.Title")), t.setAttribute("rel", "noopener nofollow"), this._container.appendChild(t), this._container.style.display = "none", this._map.on("sourcedata", this._updateLogo), this._updateLogo(), this._map.on("resize", this._updateCompact), this._updateCompact(), this._container } onRemove() { this._container.remove(), this._map.off("sourcedata", this._updateLogo), this._map.off("resize", this._updateCompact); } getDefaultPosition() { return "bottom-left" } _updateLogo(e) { e && "metadata" !== e.sourceDataType || (this._container.style.display = this._logoRequired() ? "block" : "none"); } _logoRequired() { if (!this._map.style) return !0; const e = this._map.style._sourceCaches; if (0 === Object.entries(e).length) return !0; for (const t in e) { const i = e[t].getSource(); if (i.hasOwnProperty("mapbox_logo") && !i.mapbox_logo) return !1 } return !0 } _updateCompact() { const e = this._container.children; if (e.length) { const t = e[0]; this._map.getCanvasContainer().offsetWidth < 250 ? t.classList.add("mapboxgl-compact") : t.classList.remove("mapboxgl-compact"); } } } class Qr { constructor() { this._queue = [], this._id = 0, this._cleared = !1, this._currentlyRunning = !1; } add(e) { const t = ++this._id; return this._queue.push({ callback: e, id: t, cancelled: !1 }), t } remove(e) { const t = this._currentlyRunning, i = t ? this._queue.concat(t) : this._queue; for (const t of i) if (t.id === e) return void(t.cancelled = !0) } run(e = 0) { const t = this._currentlyRunning = this._queue; this._queue = []; for (const i of t) if (!i.cancelled && (i.callback(e), this._cleared)) break; this._cleared = !1, this._currentlyRunning = !1; } clear() { this._currentlyRunning && (this._cleared = !0), this._queue = []; } } function en(t, i, o) { if (t = new e.LngLat(t.lng, t.lat), i) { const r = new e.LngLat(t.lng - 360, t.lat), n = new e.LngLat(t.lng + 360, t.lat), s = 360 * Math.ceil(Math.abs(t.lng - o.center.lng) / 360), a = o.locationPoint(t).distSqr(i), l = i.x < 0 || i.y < 0 || i.x > o.width || i.y > o.height; o.locationPoint(r).distSqr(i) < a && (l || Math.abs(r.lng - o.center.lng) < s) ? t = r : o.locationPoint(n).distSqr(i) < a && (l || Math.abs(n.lng - o.center.lng) < s) && (t = n); } for (; Math.abs(t.lng - o.center.lng) > 180;) { const e = o.locationPoint(t); if (e.x >= 0 && e.y >= 0 && e.x <= o.width && e.y <= o.height) break; t.lng > o.center.lng ? t.lng -= 360 : t.lng += 360; } return t } const tn = { 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%)" }; class on extends e.Evented { constructor(t, i) { if (super(), (t instanceof e.window.HTMLElement || i) && (t = e.extend({ element: t }, i)), e.bindAll(["_update", "_onMove", "_onUp", "_addDragHandler", "_onMapClick", "_onKeyPress", "_clearFadeTimer"], this), this._anchor = t && t.anchor || "center", this._color = t && t.color || "#3FB1CE", this._scale = t && t.scale || 1, this._draggable = t && t.draggable || !1, this._clickTolerance = t && t.clickTolerance || 0, this._isDragging = !1, this._state = "inactive", this._rotation = t && t.rotation || 0, this._rotationAlignment = t && t.rotationAlignment || "auto", this._pitchAlignment = t && t.pitchAlignment && t.pitchAlignment || "auto", this._updateMoving = () => this._update(!0), this._occludedOpacity = t && t.occludedOpacity || .2, t && t.element) this._element = t.element, this._offset = e.pointGeometry.convert(t && t.offset || [0, 0]); else { this._defaultMarker = !0, this._element = n("div"); const i = 41, o = 27, r = s("svg", { display: "block", height: i * this._scale + "px", width: o * this._scale + "px", viewBox: `0 0 ${o} ${i}` }, this._element), a = s("radialGradient", { id: "shadowGradient" }, s("defs", {}, r)); s("stop", { offset: "10%", "stop-opacity": .4 }, a), s("stop", { offset: "100%", "stop-opacity": .05 }, a), s("ellipse", { cx: 13.5, cy: 34.8, rx: 10.5, ry: 5.25, fill: "url(#shadowGradient)" }, r), s("path", { fill: this._color, d: "M27,13.5C27,19.07 20.25,27 14.75,34.5C14.02,35.5 12.98,35.5 12.25,34.5C6.75,27 0,19.22 0,13.5C0,6.04 6.04,0 13.5,0C20.96,0 27,6.04 27,13.5Z" }, r), s("path", { opacity: .25, d: "M13.5,0C6.04,0 0,6.04 0,13.5C0,19.22 6.75,27 12.25,34.5C13,35.52 14.02,35.5 14.75,34.5C20.25,27 27,19.07 27,13.5C27,6.04 20.96,0 13.5,0ZM13.5,1C20.42,1 26,6.58 26,13.5C26,15.9 24.5,19.18 22.22,22.74C19.95,26.3 16.71,30.14 13.94,33.91C13.74,34.18 13.61,34.32 13.5,34.44C13.39,34.32 13.26,34.18 13.06,33.91C10.28,30.13 7.41,26.31 5.02,22.77C2.62,19.23 1,15.95 1,13.5C1,6.58 6.58,1 13.5,1Z" }, r), s("circle", { fill: "white", cx: 13.5, cy: 13.5, r: 5.5 }, r), this._offset = e.pointGeometry.convert(t && t.offset || [0, -14]); } this._element.hasAttribute("aria-label") || this._element.setAttribute("aria-label", "Map marker"), this._element.classList.add("mapboxgl-marker"), this._element.addEventListener("dragstart", (e => { e.preventDefault(); })), this._element.addEventListener("mousedown", (e => { e.preventDefault(); })); const o = this._element.classList; for (const e in tn) o.remove(`mapboxgl-marker-anchor-${e}`); o.add(`mapboxgl-marker-anchor-${this._anchor}`), this._popup = null; } addTo(e) { return e === this._map || (this.remove(), this._map = e, e.getCanvasContainer().appendChild(this._element), e.on("move", this._updateMoving), e.on("moveend", this._update), e.on("remove", this._clearFadeTimer), e._addMarker(this), this.setDraggable(this._draggable), this._update(), e.on("click", this._onMapClick)), this } remove() { const e = this._map; return e && (e.off("click", this._onMapClick), e.off("move", this._updateMoving), e.off("moveend", this._update), e.off("mousedown", this._addDragHandler), e.off("touchstart", this._addDragHandler), e.off("mouseup", this._onUp), e.off("touchend", this._onUp), e.off("mousemove", this._onMove), e.off("touchmove", this._onMove), e.off("remove", this._clearFadeTimer), e._removeMarker(this), this._map = void 0), this._clearFadeTimer(), this._element.remove(), this._popup && this._popup.remove(), this } getLngLat() { return this._lngLat } setLngLat(t) { return this._lngLat = e.LngLat.convert(t), this._pos = null, this._popup && this._popup.setLngLat(this._lngLat), this._update(!0), this } getElement() { return this._element } setPopup(e) { if (this._popup && (this._popup.remove(), this._popup = null, this._element.removeAttribute("role"), this._element.removeEventListener("keypress", this._onKeyPress), this._originalTabIndex || this._element.removeAttribute("tabindex")), e) { if (!("offset" in e.options)) { const t = 38.1, i = 13.5, o = Math.sqrt(Math.pow(i, 2) / 2); e.options.offset = this._defaultMarker ? { top: [0, 0], "top-left": [0, 0], "top-right": [0, 0], bottom: [0, -t], "bottom-left": [o, -1 * (t - i + o)], "bottom-right": [-o, -1 * (t - i + o)], left: [i, -1 * (t - i)], right: [-i, -1 * (t - i)] } : this._offset; } this._popup = e, e._marker = this, this._lngLat && this._popup.setLngLat(this._lngLat), this._element.setAttribute("role", "button"), this._originalTabIndex = this._element.getAttribute("tabindex"), this._originalTabIndex || this._element.setAttribute("tabindex", "0"), this._element.addEventListener("keypress", this._onKeyPress), this._element.setAttribute("aria-expanded", "false"); } return this } _onKeyPress(e) { const t = e.code, i = e.charCode || e.keyCode; "Space" !== t && "Enter" !== t && 32 !== i && 13 !== i || this.togglePopup(); } _onMapClick(e) { const t = e.originalEvent.target, i = this._element; this._popup && (t === i || i.contains(t)) && this.togglePopup(); } getPopup() { return this._popup } togglePopup() { const e = this._popup; return e ? (e.isOpen() ? (e.remove(), this._element.setAttribute("aria-expanded", "false")) : this._map && (e.addTo(this._map), this._element.setAttribute("aria-expanded", "true")), this) : this } _behindTerrain() { const e = this._map, t = this._pos; if (!e || !t) return !1; const i = e.unproject(t), o = e.getFreeCameraOptions(); if (!o.position) return !1; const r = o.position.toLngLat(); return r.distanceTo(i) < .9 * r.distanceTo(this._lngLat) } _evaluateOpacity() { const t = this._map; if (!t) return; const i = this._pos; if (!i || i.x < 0 || i.x > t.transform.width || i.y < 0 || i.y > t.transform.height) return void this._clearFadeTimer(); const o = t.unproject(i); let r; t._showingGlobe() && e.isLngLatBehindGlobe(t.transform, this._lngLat) ? r = 0 : (r = 1 - t._queryFogOpacity(o), t.transform._terrainEnabled() && t.getTerrain() && this._behindTerrain() && (r *= this._occludedOpacity)), this._element.style.opacity = `${r}`, this._element.style.pointerEvents = r > 0 ? "auto" : "none", this._popup && this._popup._setOpacity(r), this._fadeTimer = null; } _clearFadeTimer() { this._fadeTimer && (clearTimeout(this._fadeTimer), this._fadeTimer = null); } _updateDOM() { const e = this._pos; if (!e || !this._map) return; const t = this._offset.mult(this._scale); this._element.style.transform = `\n translate(${e.x}px,${e.y}px)\n ${tn[this._anchor]}\n ${this._calculateXYTransform()} ${this._calculateZTransform()}\n translate(${t.x}px,${t.y}px)\n `; } _calculateXYTransform() { const t = this._pos, i = this._map, o = this.getPitchAlignment(); if (!i || !t || "map" !== o) return ""; if (!i._showingGlobe()) { const e = i.getPitch(); return e ? `rotateX(${e}deg)` : "" } const r = e.radToDeg(e.globeTiltAtLngLat(i.transform, this._lngLat)), n = t.sub(e.globeCenterToScreenPoint(i.transform)), s = Math.abs(n.x) + Math.abs(n.y); if (0 === s) return ""; const a = r / s; return `rotateX(${-n.y*a}deg) rotateY(${n.x*a}deg)` } _calculateZTransform() { const t = this._pos, i = this._map; if (!i || !t) return ""; let o = 0; const r = this.getRotationAlignment(); if ("map" === r) if (i._showingGlobe()) { const t = i.project(new e.LngLat(this._lngLat.lng, this._lngLat.lat + .001)), r = i.project(new e.LngLat(this._lngLat.lng, this._lngLat.lat - .001)).sub(t); o = e.radToDeg(Math.atan2(r.y, r.x)) - 90; } else o = -i.getBearing(); else if ("horizon" === r) { const r = e.smoothstep(4, 6, i.getZoom()), n = e.globeCenterToScreenPoint(i.transform); n.y += r * i.transform.height; const s = t.sub(n), a = e.radToDeg(Math.atan2(s.y, s.x)); o = (a > 90 ? a - 270 : a + 90) * (1 - r); } return o += this._rotation, o ? `rotateZ(${o}deg)` : "" } _update(t) { e.window.cancelAnimationFrame(this._updateFrameId); const i = this._map; i && (i.transform.renderWorldCopies && (this._lngLat = en(this._lngLat, this._pos, i.transform)), this._pos = i.project(this._lngLat), !0 === t ? this._updateFrameId = e.window.requestAnimationFrame((() => { this._element && this._pos && this._anchor && (this._pos = this._pos.round(), this._updateDOM()); })) : this._pos = this._pos.round(), i._requestDomTask((() => { this._map && (this._element && this._pos && this._anchor && this._updateDOM(), (i._showingGlobe() || i.getTerrain() || i.getFog()) && !this._fadeTimer && (this._fadeTimer = setTimeout(this._evaluateOpacity.bind(this), 60))); }))); } getOffset() { return this._offset } setOffset(t) { return this._offset = e.pointGeometry.convert(t), this._update(), this } _onMove(t) { const i = this._map; if (!i) return; const o = this._pointerdownPos, r = this._positionDelta; if (o && r) { if (!this._isDragging) { const e = this._clickTolerance || i._clickTolerance; if (t.point.dist(o) < e) return; this._isDragging = !0; } this._pos = t.point.sub(r), this._lngLat = i.unproject(this._pos), this.setLngLat(this._lngLat), this._element.style.pointerEvents = "none", "pending" === this._state && (this._state = "active", this.fire(new e.Event("dragstart"))), this.fire(new e.Event("drag")); } } _onUp() { this._element.style.pointerEvents = "auto", this._positionDelta = null, this._pointerdownPos = null, this._isDragging = !1; const t = this._map; t && (t.off("mousemove", this._onMove), t.off("touchmove", this._onMove)), "active" === this._state && this.fire(new e.Event("dragend")), this._state = "inactive"; } _addDragHandler(e) { const t = this._map, i = this._pos; t && i && this._element.contains(e.originalEvent.target) && (e.preventDefault(), this._positionDelta = e.point.sub(i), this._pointerdownPos = e.point, this._state = "pending", t.on("mousemove", this._onMove), t.on("touchmove", this._onMove), t.once("mouseup", this._onUp), t.once("touchend", this._onUp)); } setDraggable(e) { this._draggable = !!e; const t = this._map; return t && (e ? (t.on("mousedown", this._addDragHandler), t.on("touchstart", this._addDragHandler)) : (t.off("mousedown", this._addDragHandler), t.off("touchstart", this._addDragHandler))), this } isDraggable() { return this._draggable } setRotation(e) { return this._rotation = e || 0, this._update(), this } getRotation() { return this._rotation } setRotationAlignment(e) { return this._rotationAlignment = e || "auto", this._update(), this } getRotationAlignment() { return "auto" === this._rotationAlignment || "horizon" === this._rotationAlignment && this._map && !this._map._showingGlobe() ? "viewport" : this._rotationAlignment } setPitchAlignment(e) { return this._pitchAlignment = e || "auto", this._update(), this } getPitchAlignment() { return "auto" === this._pitchAlignment ? this.getRotationAlignment() : this._pitchAlignment } setOccludedOpacity(e) { return this._occludedOpacity = e || .2, this._update(), this } getOccludedOpacity() { return this._occludedOpacity } } const rn = { closeButton: !0, closeOnClick: !0, focusAfterOpen: !0, className: "", maxWidth: "240px" }, nn = ["a[href]", "[tabindex]:not([tabindex='-1'])", "[contenteditable]:not([contenteditable='false'])", "button:not([disabled])", "input:not([disabled])", "select:not([disabled])", "textarea:not([disabled])"].join(", "); function sn(t = new e.pointGeometry(0, 0), i = "bottom") { if ("number" == typeof t) { const o = Math.round(Math.sqrt(.5 * Math.pow(t, 2))); switch (i) { case "top": return new e.pointGeometry(0, t); case "top-left": return new e.pointGeometry(o, o); case "top-right": return new e.pointGeometry(-o, o); case "bottom": return new e.pointGeometry(0, -t); case "bottom-left": return new e.pointGeometry(o, -o); case "bottom-right": return new e.pointGeometry(-o, -o); case "left": return new e.pointGeometry(t, 0); case "right": return new e.pointGeometry(-t, 0) } return new e.pointGeometry(0, 0) } return t instanceof e.pointGeometry || Array.isArray(t) ? e.pointGeometry.convert(t) : e.pointGeometry.convert(t[i] || [0, 0]) } class an { constructor(e) { this.jumpTo(e); } getValue(t) { if (t <= this._startTime) return this._start; if (t >= this._endTime) return this._end; const i = e.easeCubicInOut((t - this._startTime) / (this._endTime - this._startTime)); return this._start * (1 - i) + this._end * i } isEasing(e) { return e >= this._startTime && e <= this._endTime } jumpTo(e) { this._startTime = -1 / 0, this._endTime = -1 / 0, this._start = e, this._end = e; } easeTo(e, t, i) { this._start = this.getValue(t), this._end = e, this._startTime = t, this._endTime = t + i; } } const ln = { "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", "Map.Title": "Map", "NavigationControl.ResetBearing": "Reset bearing to north", "NavigationControl.ZoomIn": "Zoom in", "NavigationControl.ZoomOut": "Zoom out", "ScrollZoomBlocker.CtrlMessage": "Use ctrl + scroll to zoom the map", "ScrollZoomBlocker.CmdMessage": "Use ⌘ + scroll to zoom the map", "TouchPanBlocker.Message": "Use two fingers to move the map" }, cn = { center: [0, 0], zoom: 0, bearing: 0, pitch: 0, minZoom: -2, maxZoom: 22, minPitch: 0, maxPitch: 85, interactive: !0, scrollZoom: !0, boxZoom: !0, dragRotate: !0, dragPan: !0, keyboard: !0, doubleClickZoom: !0, touchZoomRotate: !0, touchPitch: !0, cooperativeGestures: !1, performanceMetricsCollection: !0, bearingSnap: 7, clickTolerance: 3, pitchWithRotate: !0, hash: !1, attributionControl: !0, failIfMajorPerformanceCaveat: !1, preserveDrawingBuffer: !1, trackResize: !0, optimizeForTerrain: !0, renderWorldCopies: !0, refreshExpiredTiles: !0, minTileCacheSize: null, maxTileCacheSize: null, localIdeographFontFamily: "sans-serif", localFontFamily: null, transformRequest: null, accessToken: null, fadeDuration: 300, crossSourceCollisions: !0 }, hn = { showCompass: !0, showZoom: !0, visualizePitch: !1 }; class un { constructor(t, i, o = !1) { this._clickTolerance = 10, this.element = i, this.mouseRotate = new wr({ clickTolerance: t.dragRotate._mouseRotate._clickTolerance }), this.map = t, o && (this.mousePitch = new Tr({ clickTolerance: t.dragRotate._mousePitch._clickTolerance })), e.bindAll(["mousedown", "mousemove", "mouseup", "touchstart", "touchmove", "touchend", "reset"], this), i.addEventListener("mousedown", this.mousedown), i.addEventListener("touchstart", this.touchstart, { passive: !1 }), i.addEventListener("touchmove", this.touchmove), i.addEventListener("touchend", this.touchend), i.addEventListener("touchcancel", this.reset); } down(e, t) { this.mouseRotate.mousedown(e, t), this.mousePitch && this.mousePitch.mousedown(e, t), h(); } move(e, t) { const i = this.map, o = this.mouseRotate.mousemoveWindow(e, t), r = o && o.bearingDelta; if (r && i.setBearing(i.getBearing() + r), this.mousePitch) { const o = this.mousePitch.mousemoveWindow(e, t), r = o && o.pitchDelta; r && i.setPitch(i.getPitch() + r); } } off() { const e = this.element; e.removeEventListener("mousedown", this.mousedown), e.removeEventListener("touchstart", this.touchstart, { passive: !1 }), e.removeEventListener("touchmove", this.touchmove), e.removeEventListener("touchend", this.touchend), e.removeEventListener("touchcancel", this.reset), this.offTemp(); } offTemp() { u(), e.window.removeEventListener("mousemove", this.mousemove), e.window.removeEventListener("mouseup", this.mouseup); } mousedown(t) { this.down(e.extend({}, t, { ctrlKey: !0, preventDefault: () => t.preventDefault() }), p(this.element, t)), e.window.addEventListener("mousemove", this.mousemove), e.window.addEventListener("mouseup", this.mouseup); } mousemove(e) { this.move(e, p(this.element, e)); } mouseup(e) { this.mouseRotate.mouseupWindow(e), this.mousePitch && this.mousePitch.mouseupWindow(e), this.offTemp(); } touchstart(e) { 1 !== e.targetTouches.length ? this.reset() : (this._startPos = this._lastPos = m(this.element, e.targetTouches)[0], this.down({ type: "mousedown", button: 0, ctrlKey: !0, preventDefault: () => e.preventDefault() }, this._startPos)); } touchmove(e) { 1 !== e.targetTouches.length ? this.reset() : (this._lastPos = m(this.element, e.targetTouches)[0], this.move({ preventDefault: () => e.preventDefault() }, this._lastPos)); } touchend(e) { 0 === e.targetTouches.length && this._startPos && this._lastPos && this._startPos.dist(this._lastPos) < this._clickTolerance && this.element.click(), this.reset(); } reset() { this.mouseRotate.reset(), this.mousePitch && this.mousePitch.reset(), delete this._startPos, delete this._lastPos, this.offTemp(); } } const _n = { positionOptions: { enableHighAccuracy: !1, maximumAge: 0, timeout: 6e3 }, fitBoundsOptions: { maxZoom: 15 }, trackUserLocation: !1, showAccuracyCircle: !0, showUserLocation: !0, showUserHeading: !1 }, dn = { maxWidth: 100, unit: "metric" }; function pn(e, t, i) { const o = mn(t), r = o / t, n = { kilometer: "km", meter: "m", mile: "mi", foot: "ft", "nautical-mile": "nm" }[i]; this._map._requestDomTask((() => { this._container.style.width = e * r + "px", this._container.innerHTML = `${o} ${n}`; })); } function mn(e) { const t = Math.pow(10, `${Math.floor(e)}`.length - 1); let i = e / t; return i = i >= 10 ? 10 : i >= 5 ? 5 : i >= 3 ? 3 : i >= 2 ? 2 : i >= 1 ? 1 : function(e) { const t = Math.pow(10, Math.ceil(-Math.log(e) / Math.LN10)); return Math.round(e * t) / t }(i), t * i } const fn = { version: e.version, supported: i, setRTLTextPlugin: e.setRTLTextPlugin, getRTLTextPluginStatus: e.getRTLTextPluginStatus, Map: class extends Yr { constructor(t) { if (e.LivePerformanceUtils.mark(e.PerformanceMarkers.create), null != (t = e.extend({}, cn, t)).minZoom && null != t.maxZoom && t.minZoom > t.maxZoom) throw new Error("maxZoom must be greater than or equal to minZoom"); if (null != t.minPitch && null != t.maxPitch && t.minPitch > t.maxPitch) throw new Error("maxPitch must be greater than or equal to minPitch"); if (null != t.minPitch && t.minPitch < 0) throw new Error("minPitch must be greater than or equal to 0"); if (null != t.maxPitch && t.maxPitch > 85) throw new Error("maxPitch must be less than or equal to 85"); if (t.antialias && e.isSafariWithAntialiasingBug(e.window) && (t.antialias = !1, e.warnOnce("Antialiasing is disabled for this WebGL context to avoid browser bug: https://github.com/mapbox/mapbox-gl-js/issues/11609")), super(new Ko(t.minZoom, t.maxZoom, t.minPitch, t.maxPitch, t.renderWorldCopies), t), this._interactive = t.interactive, this._minTileCacheSize = t.minTileCacheSize, this._maxTileCacheSize = t.maxTileCacheSize, this._failIfMajorPerformanceCaveat = t.failIfMajorPerformanceCaveat, this._preserveDrawingBuffer = t.preserveDrawingBuffer, this._antialias = t.antialias, this._useWebGL2 = t.useWebGL2, this._trackResize = t.trackResize, this._bearingSnap = t.bearingSnap, this._refreshExpiredTiles = t.refreshExpiredTiles, this._fadeDuration = t.fadeDuration, this._isInitialLoad = !0, this._crossSourceCollisions = t.crossSourceCollisions, this._collectResourceTiming = t.collectResourceTiming, this._optimizeForTerrain = t.optimizeForTerrain, this._language = this._parseLanguage(t.language), this._worldview = t.worldview, this._renderTaskQueue = new Qr, this._domRenderTaskQueue = new Qr, this._controls = [], this._markers = [], this._popups = [], this._mapId = e.uniqueId(), this._locale = e.extend({}, ln, t.locale), this._clickTolerance = t.clickTolerance, this._cooperativeGestures = t.cooperativeGestures, this._performanceMetricsCollection = t.performanceMetricsCollection, this._containerWidth = 0, this._containerHeight = 0, this._averageElevationLastSampledAt = -1 / 0, this._averageElevationExaggeration = 0, this._averageElevation = new an(0), this._interactionRange = [1 / 0, -1 / 0], this._visibilityHidden = 0, this._useExplicitProjection = !1, this._requestManager = new e.RequestManager(t.transformRequest, t.accessToken, t.testMode), this._silenceAuthErrors = !!t.testMode, "string" == typeof t.container) { if (this._container = e.window.document.getElementById(t.container), !this._container) throw new Error(`Container '${t.container}' not found.`) } else { if (!(t.container instanceof e.window.HTMLElement)) throw new Error("Invalid type: 'container' must be a String or HTMLElement."); this._container = t.container; } if (this._container.childNodes.length > 0 && e.warnOnce("The map container element should be empty, otherwise the map's interactivity will be negatively impacted. If you want to display a message when WebGL is not supported, use the Mapbox GL Supported plugin instead."), t.maxBounds && this.setMaxBounds(t.maxBounds), e.bindAll(["_onWindowOnline", "_onWindowResize", "_onVisibilityChange", "_onMapScroll", "_contextLost", "_contextRestored"], this), this._setupContainer(), this._setupPainter(), void 0 === this.painter) throw new Error("Failed to initialize WebGL."); this.on("move", (() => this._update(!1))), this.on("moveend", (() => this._update(!1))), this.on("zoom", (() => this._update(!0))), void 0 !== e.window && (e.window.addEventListener("online", this._onWindowOnline, !1), e.window.addEventListener("resize", this._onWindowResize, !1), e.window.addEventListener("orientationchange", this._onWindowResize, !1), e.window.addEventListener("webkitfullscreenchange", this._onWindowResize, !1), e.window.addEventListener("visibilitychange", this._onVisibilityChange, !1)), this.handlers = new $r(this, t), this._localFontFamily = t.localFontFamily, this._localIdeographFontFamily = t.localIdeographFontFamily, t.style && this.setStyle(t.style, { localFontFamily: this._localFontFamily, localIdeographFontFamily: this._localIdeographFontFamily }), t.projection && this.setProjection(t.projection), this._hash = t.hash && new Qo("string" == typeof t.hash && t.hash || void 0).addTo(this), this._hash && this._hash._onHashChange() || (this.jumpTo({ center: t.center, zoom: t.zoom, bearing: t.bearing, pitch: t.pitch }), t.bounds && (this.resize(), this.fitBounds(t.bounds, e.extend({}, t.fitBoundsOptions, { duration: 0 })))), this.resize(), t.attributionControl && this.addControl(new Kr({ customAttribution: t.customAttribution })), this._logoControl = new Jr, this.addControl(this._logoControl, t.logoPosition), this.on("style.load", (() => { this.transform.unmodified && this.jumpTo(this.style.stylesheet); })), this.on("data", (t => { this._update("style" === t.dataType), this.fire(new e.Event(`${t.dataType}data`, t)); })), this.on("dataloading", (t => { this.fire(new e.Event(`${t.dataType}dataloading`, t)); })); } _getMapId() { return this._mapId } addControl(t, i) { if (void 0 === i && (i = t.getDefaultPosition ? t.getDefaultPosition() : "top-right"), !t || !t.onAdd) return this.fire(new e.ErrorEvent(new Error("Invalid argument to map.addControl(). Argument must be a control with onAdd and onRemove methods."))); const o = t.onAdd(this); this._controls.push(t); const r = this._controlPositions[i]; return -1 !== i.indexOf("bottom") ? r.insertBefore(o, r.firstChild) : r.appendChild(o), this } removeControl(t) { if (!t || !t.onRemove) return this.fire(new e.ErrorEvent(new Error("Invalid argument to map.removeControl(). Argument must be a control with onAdd and onRemove methods."))); const i = this._controls.indexOf(t); return i > -1 && this._controls.splice(i, 1), t.onRemove(this), this } hasControl(e) { return this._controls.indexOf(e) > -1 } getContainer() { return this._container } getCanvasContainer() { return this._canvasContainer } getCanvas() { return this._canvas } resize(t) { if (this._updateContainerDimensions(), this._containerWidth === this.transform.width && this._containerHeight === this.transform.height) return this; this._resizeCanvas(this._containerWidth, this._containerHeight), this.transform.resize(this._containerWidth, this._containerHeight), this.painter.resize(Math.ceil(this._containerWidth), Math.ceil(this._containerHeight)); const i = !this._moving; return i && this.fire(new e.Event("movestart", t)).fire(new e.Event("move", t)), this.fire(new e.Event("resize", t)), i && this.fire(new e.Event("moveend", t)), this } getBounds() { return this.transform.getBounds() } getMaxBounds() { return this.transform.getMaxBounds() || null } setMaxBounds(t) { return this.transform.setMaxBounds(e.LngLatBounds.convert(t)), this._update() } setMinZoom(t) { if ((t = null == t ? -2 : t) >= -2 && t <= this.transform.maxZoom) return this.transform.minZoom = t, this._update(), this.getZoom() < t ? this.setZoom(t) : this.fire(new e.Event("zoomstart")).fire(new e.Event("zoom")).fire(new e.Event("zoomend")), this; throw new Error("minZoom must be between -2 and the current maxZoom, inclusive") } getMinZoom() { return this.transform.minZoom } setMaxZoom(t) { if ((t = null == t ? 22 : t) >= this.transform.minZoom) return this.transform.maxZoom = t, this._update(), this.getZoom() > t ? this.setZoom(t) : this.fire(new e.Event("zoomstart")).fire(new e.Event("zoom")).fire(new e.Event("zoomend")), this; throw new Error("maxZoom must be greater than the current minZoom") } getMaxZoom() { return this.transform.maxZoom } setMinPitch(t) { if ((t = null == t ? 0 : t) < 0) throw new Error("minPitch must be greater than or equal to 0"); if (t >= 0 && t <= this.transform.maxPitch) return this.transform.minPitch = t, this._update(), this.getPitch() < t ? this.setPitch(t) : this.fire(new e.Event("pitchstart")).fire(new e.Event("pitch")).fire(new e.Event("pitchend")), this; throw new Error("minPitch must be between 0 and the current maxPitch, inclusive") } getMinPitch() { return this.transform.minPitch } setMaxPitch(t) { if ((t = null == t ? 85 : t) > 85) throw new Error("maxPitch must be less than or equal to 85"); if (t >= this.transform.minPitch) return this.transform.maxPitch = t, this._update(), this.getPitch() > t ? this.setPitch(t) : this.fire(new e.Event("pitchstart")).fire(new e.Event("pitch")).fire(new e.Event("pitchend")), this; throw new Error("maxPitch must be greater than or equal to minPitch") } getMaxPitch() { return this.transform.maxPitch } getRenderWorldCopies() { return this.transform.renderWorldCopies } setRenderWorldCopies(e) { return this.transform.renderWorldCopies = e, this.transform.renderWorldCopies || this._forceMarkerAndPopupUpdate(!0), this._update() } getLanguage() { return this._language } _parseLanguage(t) { return "auto" === t ? e.window.navigator.language : Array.isArray(t) ? 0 === t.length ? void 0 : t.map((t => "auto" === t ? e.window.navigator.language : t)) : t } setLanguage(e) { const t = this._parseLanguage(e); if (!this.style || t === this._language) return this; this._language = t, this.style._reloadSources(); for (const e of this._controls) e._setLanguage && e._setLanguage(this._language); return this } getWorldview() { return this._worldview } setWorldview(e) { return this.style && e !== this._worldview ? (this._worldview = e, this.style._reloadSources(), this) : this } getProjection() { return this.transform.mercatorFromTransition ? { name: "globe", center: [0, 0] } : this.transform.getProjection() } _showingGlobe() { return "globe" === this.transform.projection.name } setProjection(e) { return this._lazyInitEmptyStyle(), e ? "string" == typeof e && (e = { name: e }) : e = null, this._useExplicitProjection = !!e, this._prioritizeAndUpdateProjection(e, this.style.stylesheet ? this.style.stylesheet.projection : null) } _updateProjectionTransition() { if ("globe" !== this.getProjection().name) return; const t = this.transform, i = t.projection.name; let o; "globe" === i && t.zoom >= e.GLOBE_ZOOM_THRESHOLD_MAX ? (t.setMercatorFromTransition(), o = !0) : "mercator" === i && t.zoom < e.GLOBE_ZOOM_THRESHOLD_MAX && (t.setProjection({ name: "globe" }), o = !0), o && (this.style.applyProjectionUpdate(), this.style._forceSymbolLayerUpdate()); } _prioritizeAndUpdateProjection(e, t) { return this._updateProjection(e || t || { name: "mercator" }) } _updateProjection(t) { let i; if (i = "globe" === t.name && this.transform.zoom >= e.GLOBE_ZOOM_THRESHOLD_MAX ? this.transform.setMercatorFromTransition() : this.transform.setProjection(t), this.style.applyProjectionUpdate(), i) { this.painter.clearBackgroundTiles(); for (const e in this.style._sourceCaches) this.style._sourceCaches[e].clearTiles(); this._update(!0), this._forceMarkerAndPopupUpdate(!0); } return this } project(t) { return this.transform.locationPoint3D(e.LngLat.convert(t)) } unproject(t) { return this.transform.pointLocation3D(e.pointGeometry.convert(t)) } isMoving() { return this._moving || this.handlers && this.handlers.isMoving() || !1 } isZooming() { return this._zooming || this.handlers && this.handlers.isZooming() || !1 } isRotating() { return this._rotating || this.handlers && this.handlers.isRotating() || !1 } _isDragging() { return this.handlers && this.handlers._isDragging() || !1 } _createDelegatedListener(e, t, i) { if ("mouseenter" === e || "mouseover" === e) { let o = !1; const r = r => { const n = t.filter((e => this.getLayer(e))), s = n.length ? this.queryRenderedFeatures(r.point, { layers: n }) : []; s.length ? o || (o = !0, i.call(this, new cr(e, this, r.originalEvent, { features: s }))) : o = !1; }, n = () => { o = !1; }; return { layers: new Set(t), listener: i, delegates: { mousemove: r, mouseout: n } } } if ("mouseleave" === e || "mouseout" === e) { let o = !1; const r = r => { const n = t.filter((e => this.getLayer(e))); (n.length ? this.queryRenderedFeatures(r.point, { layers: n }) : []).length ? o = !0 : o && (o = !1, i.call(this, new cr(e, this, r.originalEvent))); }, n = t => { o && (o = !1, i.call(this, new cr(e, this, t.originalEvent))); }; return { layers: new Set(t), listener: i, delegates: { mousemove: r, mouseout: n } } } { const o = e => { const o = t.filter((e => this.getLayer(e))), r = o.length ? this.queryRenderedFeatures(e.point, { layers: o }) : []; r.length && (e.features = r, i.call(this, e), delete e.features); }; return { layers: new Set(t), listener: i, delegates: { [e]: o } } } } on(e, t, i) { if (void 0 === i) return super.on(e, t); Array.isArray(t) || (t = [t]); const o = this._createDelegatedListener(e, t, i); this._delegatedListeners = this._delegatedListeners || {}, this._delegatedListeners[e] = this._delegatedListeners[e] || [], this._delegatedListeners[e].push(o); for (const e in o.delegates) this.on(e, o.delegates[e]); return this } once(e, t, i) { if (void 0 === i) return super.once(e, t); Array.isArray(t) || (t = [t]); const o = this._createDelegatedListener(e, t, i); for (const e in o.delegates) this.once(e, o.delegates[e]); return this } off(e, t, i) { if (void 0 === i) return super.off(e, t); t = new Set(Array.isArray(t) ? t : [t]); const o = (e, t) => { if (e.size !== t.size) return !1; for (const i of e) if (!t.has(i)) return !1; return !0 }, r = this._delegatedListeners ? this._delegatedListeners[e] : void 0; return r && (e => { for (let r = 0; r < e.length; r++) { const n = e[r]; if (n.listener === i && o(n.layers, t)) { for (const e in n.delegates) this.off(e, n.delegates[e]); return e.splice(r, 1), this } } })(r), this } queryRenderedFeatures(t, i) { return this.style ? (void 0 !== i || void 0 === t || t instanceof e.pointGeometry || Array.isArray(t) || (i = t, t = void 0), this.style.queryRenderedFeatures(t = t || [ [0, 0], [this.transform.width, this.transform.height] ], i = i || {}, this.transform)) : [] } querySourceFeatures(e, t) { return this.style.querySourceFeatures(e, t) } setStyle(t, i) { return !1 !== (i = e.extend({}, { localIdeographFontFamily: this._localIdeographFontFamily, localFontFamily: this._localFontFamily }, i)).diff && i.localIdeographFontFamily === this._localIdeographFontFamily && i.localFontFamily === this._localFontFamily && this.style && t ? (this._diffStyle(t, i), this) : (this._localIdeographFontFamily = i.localIdeographFontFamily, this._localFontFamily = i.localFontFamily, this._updateStyle(t, i)) } _getUIString(e) { const t = this._locale[e]; if (null == t) throw new Error(`Missing UI string '${e}'`); return t } _updateStyle(e, t) { return this.style && (this.style.setEventedParent(null), this.style._remove(), this.style = void 0), e && (this.style = new Qt(this, t || {}), this.style.setEventedParent(this, { style: this.style }), "string" == typeof e ? this.style.loadURL(e) : this.style.loadJSON(e)), this._updateTerrain(), this } _lazyInitEmptyStyle() { this.style || (this.style = new Qt(this, {}), this.style.setEventedParent(this, { style: this.style }), this.style.loadEmpty()); } _diffStyle(t, i) { if ("string" == typeof t) { const o = this._requestManager.normalizeStyleURL(t), r = this._requestManager.transformRequest(o, e.ResourceType.Style); e.getJSON(r, ((t, o) => { t ? this.fire(new e.ErrorEvent(t)) : o && this._updateDiff(o, i); })); } else "object" == typeof t && this._updateDiff(t, i); } _updateDiff(t, i) { try { this.style.setState(t) && this._update(!0); } catch (o) { e.warnOnce(`Unable to perform style diff: ${o.message||o.error||o}. Rebuilding the style from scratch.`), this._updateStyle(t, i); } } getStyle() { if (this.style) return this.style.serialize() } isStyleLoaded() { return this.style ? this.style.loaded() : (e.warnOnce("There is no style added to the map."), !1) } addSource(e, t) { return this._lazyInitEmptyStyle(), this.style.addSource(e, t), this._update(!0) } isSourceLoaded(e) { return !!this.style && this.style._isSourceCacheLoaded(e) } areTilesLoaded() { const e = this.style && this.style._sourceCaches; for (const t in e) { const i = e[t]._tiles; for (const e in i) { const t = i[e]; if ("loaded" !== t.state && "errored" !== t.state) return !1 } } return !0 } addSourceType(e, t, i) { this._lazyInitEmptyStyle(), this.style.addSourceType(e, t, i); } removeSource(e) { return this.style.removeSource(e), this._updateTerrain(), this._update(!0) } getSource(e) { return this.style.getSource(e) } addImage(t, i, { pixelRatio: o = 1, sdf: r = !1, stretchX: n, stretchY: s, content: a } = {}) { if (this._lazyInitEmptyStyle(), i instanceof e.window.HTMLImageElement || e.window.ImageBitmap && i instanceof e.window.ImageBitmap) { const { width: l, height: c, data: h } = e.exported.getImageData(i); this.style.addImage(t, { data: new e.RGBAImage({ width: l, height: c }, h), pixelRatio: o, stretchX: n, stretchY: s, content: a, sdf: r, version: 0 }); } else if (void 0 === i.width || void 0 === i.height) this.fire(new e.ErrorEvent(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`"))); else { const { width: l, height: c } = i, h = i; this.style.addImage(t, { data: new e.RGBAImage({ width: l, height: c }, new Uint8Array(h.data)), pixelRatio: o, stretchX: n, stretchY: s, content: a, sdf: r, version: 0, userImage: h }), h.onAdd && h.onAdd(this, t); } } updateImage(t, i) { const o = this.style.getImage(t); if (!o) return void this.fire(new e.ErrorEvent(new Error("The map has no image with that id. If you are adding a new image use `map.addImage(...)` instead."))); const r = i instanceof e.window.HTMLImageElement || e.window.ImageBitmap && i instanceof e.window.ImageBitmap ? e.exported.getImageData(i) : i, { width: n, height: s } = r; void 0 !== n && void 0 !== s ? n === o.data.width && s === o.data.height ? (o.data.replace(r.data, !(i instanceof e.window.HTMLImageElement || e.window.ImageBitmap && i instanceof e.window.ImageBitmap)), this.style.updateImage(t, o)) : this.fire(new e.ErrorEvent(new Error(`The width and height of the updated image (${n}, ${s})\n must be that same as the previous version of the image\n (${o.data.width}, ${o.data.height})`))) : this.fire(new e.ErrorEvent(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`"))); } hasImage(t) { return t ? !!this.style.getImage(t) : (this.fire(new e.ErrorEvent(new Error("Missing required image id"))), !1) } removeImage(e) { this.style.removeImage(e); } loadImage(t, i) { e.getImage(this._requestManager.transformRequest(t, e.ResourceType.Image), ((t, o) => { i(t, o instanceof e.window.HTMLImageElement ? e.exported.getImageData(o) : o); })); } listImages() { return this.style.listImages() } addLayer(e, t) { return this._lazyInitEmptyStyle(), this.style.addLayer(e, t), this._update(!0) } moveLayer(e, t) { return this.style.moveLayer(e, t), this._update(!0) } removeLayer(e) { return this.style.removeLayer(e), this._update(!0) } getLayer(e) { return this.style.getLayer(e) } setLayerZoomRange(e, t, i) { return this.style.setLayerZoomRange(e, t, i), this._update(!0) } setFilter(e, t, i = {}) { return this.style.setFilter(e, t, i), this._update(!0) } getFilter(e) { return this.style.getFilter(e) } setPaintProperty(e, t, i, o = {}) { return this.style.setPaintProperty(e, t, i, o), this._update(!0) } getPaintProperty(e, t) { return this.style.getPaintProperty(e, t) } setLayoutProperty(e, t, i, o = {}) { return this.style.setLayoutProperty(e, t, i, o), this._update(!0) } getLayoutProperty(e, t) { return this.style.getLayoutProperty(e, t) } setLight(e, t = {}) { return this._lazyInitEmptyStyle(), this.style.setLight(e, t), this._update(!0) } getLight() { return this.style.getLight() } setTerrain(e) { return this._lazyInitEmptyStyle(), !e && this.transform.projection.requiresDraping ? this.style.setTerrainForDraping() : this.style.setTerrain(e), this._averageElevationLastSampledAt = -1 / 0, this._update(!0) } getTerrain() { return this.style ? this.style.getTerrain() : null } setFog(e) { return this._lazyInitEmptyStyle(), this.style.setFog(e), this._update(!0) } getFog() { return this.style ? this.style.getFog() : null } _queryFogOpacity(t) { return this.style && this.style.fog ? this.style.fog.getOpacityAtLatLng(e.LngLat.convert(t), this.transform) : 0 } setFeatureState(e, t) { return this.style.setFeatureState(e, t), this._update() } removeFeatureState(e, t) { return this.style.removeFeatureState(e, t), this._update() } getFeatureState(e) { return this.style.getFeatureState(e) } _updateContainerDimensions() { if (!this._container) return; const t = this._container.getBoundingClientRect().width || 400, i = this._container.getBoundingClientRect().height || 300; let o, r, n, s = this._container; for (; s && (!r || !n);) { const t = e.window.getComputedStyle(s).transform; t && "none" !== t && (o = t.match(/matrix.*\((.+)\)/)[1].split(", "), o[0] && "0" !== o[0] && "1" !== o[0] && (r = o[0]), o[3] && "0" !== o[3] && "1" !== o[3] && (n = o[3])), s = s.parentElement; } this._containerWidth = r ? Math.abs(t / r) : t, this._containerHeight = n ? Math.abs(i / n) : i; } _detectMissingCSS() { "rgb(250, 128, 114)" !== e.window.getComputedStyle(this._missingCSSCanary).getPropertyValue("background-color") && e.warnOnce("This page appears to be missing CSS declarations for Mapbox GL JS, which may cause the map to display incorrectly. Please ensure your page includes mapbox-gl.css, as described in https://www.mapbox.com/mapbox-gl-js/api/."); } _setupContainer() { const e = this._container; e.classList.add("mapboxgl-map"), (this._missingCSSCanary = n("div", "mapboxgl-canary", e)).style.visibility = "hidden", this._detectMissingCSS(); const t = this._canvasContainer = n("div", "mapboxgl-canvas-container", e); this._interactive && t.classList.add("mapboxgl-interactive"), this._canvas = n("canvas", "mapboxgl-canvas", t), this._canvas.addEventListener("webglcontextlost", this._contextLost, !1), this._canvas.addEventListener("webglcontextrestored", this._contextRestored, !1), this._canvas.setAttribute("tabindex", "0"), this._canvas.setAttribute("aria-label", this._getUIString("Map.Title")), this._canvas.setAttribute("role", "region"), this._updateContainerDimensions(), this._resizeCanvas(this._containerWidth, this._containerHeight); const i = this._controlContainer = n("div", "mapboxgl-control-container", e), o = this._controlPositions = {}; ["top-left", "top-right", "bottom-left", "bottom-right"].forEach((e => { o[e] = n("div", `mapboxgl-ctrl-${e}`, i); })), this._container.addEventListener("scroll", this._onMapScroll, !1); } _resizeCanvas(t, i) { const o = e.exported.devicePixelRatio || 1; this._canvas.width = o * Math.ceil(t), this._canvas.height = o * Math.ceil(i), this._canvas.style.width = `${t}px`, this._canvas.style.height = `${i}px`; } _addMarker(e) { this._markers.push(e); } _removeMarker(e) { const t = this._markers.indexOf(e); - 1 !== t && this._markers.splice(t, 1); } _addPopup(e) { this._popups.push(e); } _removePopup(e) { const t = this._popups.indexOf(e); - 1 !== t && this._popups.splice(t, 1); } _setupPainter() { const t = e.extend({}, i.webGLContextAttributes, { failIfMajorPerformanceCaveat: this._failIfMajorPerformanceCaveat, preserveDrawingBuffer: this._preserveDrawingBuffer, antialias: this._antialias || !1 }), o = this._useWebGL2 && this._canvas.getContext("webgl2", t), r = o || this._canvas.getContext("webgl", t) || this._canvas.getContext("experimental-webgl", t); r ? (this._useWebGL2 && !o && e.warnOnce("Failed to create WebGL 2 context. Using WebGL 1."), e.storeAuthState(r, !0), this.painter = new Fo(r, this.transform, !!o), this.on("data", (e => { "source" === e.dataType && this.painter.setTileLoadedFlag(!0); })), e.exported$1.testSupport(r)) : this.fire(new e.ErrorEvent(new Error("Failed to initialize WebGL"))); } _contextLost(t) { t.preventDefault(), this._frame && (this._frame.cancel(), this._frame = null), this.fire(new e.Event("webglcontextlost", { originalEvent: t })); } _contextRestored(t) { this._setupPainter(), this.resize(), this._update(), this.fire(new e.Event("webglcontextrestored", { originalEvent: t })); } _onMapScroll(e) { if (e.target === this._container) return this._container.scrollTop = 0, this._container.scrollLeft = 0, !1 } loaded() { return !this._styleDirty && !this._sourcesDirty && !!this.style && this.style.loaded() } _update(e) { return this.style ? (this._styleDirty = this._styleDirty || e, this._sourcesDirty = !0, this.triggerRepaint(), this) : this } _requestRenderFrame(e) { return this._update(), this._renderTaskQueue.add(e) } _cancelRenderFrame(e) { this._renderTaskQueue.remove(e); } _requestDomTask(e) { !this.loaded() || this.loaded() && !this.isMoving() ? e() : this._domRenderTaskQueue.add(e); } _render(t) { let i; const o = this.painter.context.extTimerQuery, r = e.exported.now(); if (this.listens("gpu-timing-frame") && (i = o.createQueryEXT(), o.beginQueryEXT(o.TIME_ELAPSED_EXT, i)), this.painter.context.setDirty(), this.painter.setBaseState(), (this.isMoving() || this.isRotating() || this.isZooming()) && (this._interactionRange[0] = Math.min(this._interactionRange[0], e.window.performance.now()), this._interactionRange[1] = Math.max(this._interactionRange[1], e.window.performance.now())), this._renderTaskQueue.run(t), this._domRenderTaskQueue.run(t), this._removed) return; this._updateProjectionTransition(); const n = this._isInitialLoad ? 0 : this._fadeDuration; if (this.style && this._styleDirty) { this._styleDirty = !1; const t = this.transform.zoom, i = this.transform.pitch, o = e.exported.now(), r = new e.EvaluationParameters(t, { now: o, fadeDuration: n, pitch: i, transition: this.style.getTransition() }); this.style.update(r); } this.style && this.style.fog && this.style.fog.hasTransition() && (this.style._markersNeedUpdate = !0, this._sourcesDirty = !0); let s = !1; if (this.style && this._sourcesDirty ? (this._sourcesDirty = !1, this.painter._updateFog(this.style), this._updateTerrain(), s = this._updateAverageElevation(r), this.style._updateSources(this.transform), this._forceMarkerAndPopupUpdate()) : s = this._updateAverageElevation(r), this._placementDirty = this.style && this.style._updatePlacement(this.painter.transform, this.showCollisionBoxes, n, this._crossSourceCollisions), this.style && this.painter.render(this.style, { showTileBoundaries: this.showTileBoundaries, showTerrainWireframe: this.showTerrainWireframe, showOverdrawInspector: this._showOverdrawInspector, showQueryGeometry: !!this._showQueryGeometry, showTileAABBs: this.showTileAABBs, rotating: this.isRotating(), zooming: this.isZooming(), moving: this.isMoving(), fadeDuration: n, isInitialLoad: this._isInitialLoad, showPadding: this.showPadding, gpuTiming: !!this.listens("gpu-timing-layer"), gpuTimingDeferredRender: !!this.listens("gpu-timing-deferred-render"), speedIndexTiming: this.speedIndexTiming }), this.fire(new e.Event("render")), this.loaded() && !this._loaded && (this._loaded = !0, this.fire(new e.Event("load"))), this.style && this.style.hasTransitions() && (this._styleDirty = !0), this.style && !this._placementDirty && this.style._releaseSymbolFadeTiles(), i) { const t = e.exported.now() - r; o.endQueryEXT(o.TIME_ELAPSED_EXT, i), setTimeout((() => { const n = o.getQueryObjectEXT(i, o.QUERY_RESULT_EXT) / 1e6; o.deleteQueryEXT(i), this.fire(new e.Event("gpu-timing-frame", { cpuTime: t, gpuTime: n })), e.window.performance.mark("frame-gpu", { startTime: r, detail: { gpuTime: n } }); }), 50); } if (this.listens("gpu-timing-layer")) { const t = this.painter.collectGpuTimers(); setTimeout((() => { const i = this.painter.queryGpuTimers(t); this.fire(new e.Event("gpu-timing-layer", { layerTimes: i })); }), 50); } if (this.listens("gpu-timing-deferred-render")) { const t = this.painter.collectDeferredRenderGpuQueries(); setTimeout((() => { const i = this.painter.queryGpuTimeDeferredRender(t); this.fire(new e.Event("gpu-timing-deferred-render", { gpuTime: i })); }), 50); } const a = this._sourcesDirty || this._styleDirty || this._placementDirty || s; if (a || this._repaint) this.triggerRepaint(); else { const t = !this.isMoving() && this.loaded(); if (t && (s = this._updateAverageElevation(r, !0)), s) this.triggerRepaint(); else if (this._triggerFrame(!1), t && (this.fire(new e.Event("idle")), this._isInitialLoad = !1, this.speedIndexTiming)) { const t = this._calculateSpeedIndex(); this.fire(new e.Event("speedindexcompleted", { speedIndex: t })), this.speedIndexTiming = !1; } }!this._loaded || this._fullyLoaded || a || (this._fullyLoaded = !0, e.LivePerformanceUtils.mark(e.PerformanceMarkers.fullLoad), this._performanceMetricsCollection && e.postPerformanceEvent(this._requestManager._customAccessToken, { width: this.painter.width, height: this.painter.height, interactionRange: this._interactionRange, visibilityHidden: this._visibilityHidden, terrainEnabled: !!this.painter.style.getTerrain(), fogEnabled: !!this.painter.style.getFog(), projection: this.getProjection().name, zoom: this.transform.zoom, renderer: this.painter.context.renderer, vendor: this.painter.context.vendor }), this._authenticate()); } _forceMarkerAndPopupUpdate(e) { for (const t of this._markers) e && !this.getRenderWorldCopies() && (t._lngLat = t._lngLat.wrap()), t._update(); for (const t of this._popups) !e || this.getRenderWorldCopies() || t._trackPointer || (t._lngLat = t._lngLat.wrap()), t._update(); } _updateAverageElevation(e, t = !1) { const i = e => (this.transform.averageElevation = e, this._update(!1), !0); if (!this.painter.averageElevationNeedsEasing()) return 0 !== this.transform.averageElevation && i(0); if ((t || e - this._averageElevationLastSampledAt > 500) && !this._averageElevation.isEasing(e)) { const t = this.transform.averageElevation; let o = this.transform.sampleAverageElevation(), r = !1; this.transform.elevation && (r = this.transform.elevation.exaggeration() !== this._averageElevationExaggeration, this._averageElevationExaggeration = this.transform.elevation.exaggeration()), isNaN(o) ? o = 0 : this._averageElevationLastSampledAt = e; const n = Math.abs(t - o); if (n > 1) { if (this._isInitialLoad || r) return this._averageElevation.jumpTo(o), i(o); this._averageElevation.easeTo(o, e, 300); } else if (n > 1e-4) return this._averageElevation.jumpTo(o), i(o) } return !!this._averageElevation.isEasing(e) && i(this._averageElevation.getValue(e)) } _authenticate() { e.getMapSessionAPI(this._getMapId(), this._requestManager._skuToken, this._requestManager._customAccessToken, (t => { if (t && (t.message === e.AUTH_ERR_MSG || 401 === t.status)) { const t = this.painter.context.gl; e.storeAuthState(t, !1), this._logoControl instanceof Jr && this._logoControl._updateLogo(), t && t.clear(t.DEPTH_BUFFER_BIT | t.COLOR_BUFFER_BIT | t.STENCIL_BUFFER_BIT), this._silenceAuthErrors || this.fire(new e.ErrorEvent(new Error("A valid Mapbox access token is required to use Mapbox GL JS. To create an account or a new access token, visit https://account.mapbox.com/"))); } })), e.postMapLoadEvent(this._getMapId(), this._requestManager._skuToken, this._requestManager._customAccessToken, (() => {})); } _updateTerrain() { const e = this._isDragging(); this.painter.updateTerrain(this.style, e); } _calculateSpeedIndex() { const e = this.painter.canvasCopy(), t = this.painter.getCanvasCopiesAndTimestamps(); t.timeStamps.push(performance.now()); const i = this.painter.context.gl, o = i.createFramebuffer(); function r(e) { i.framebufferTexture2D(i.FRAMEBUFFER, i.COLOR_ATTACHMENT0, i.TEXTURE_2D, e, 0); const t = new Uint8Array(i.drawingBufferWidth * i.drawingBufferHeight * 4); return i.readPixels(0, 0, i.drawingBufferWidth, i.drawingBufferHeight, i.RGBA, i.UNSIGNED_BYTE, t), t } return i.bindFramebuffer(i.FRAMEBUFFER, o), this._canvasPixelComparison(r(e), t.canvasCopies.map(r), t.timeStamps) } _canvasPixelComparison(e, t, i) { let o = i[1] - i[0]; const r = e.length / 4; for (let n = 0; n < t.length; n++) { const s = t[n]; let a = 0; for (let t = 0; t < s.length; t += 4) s[t] === e[t] && s[t + 1] === e[t + 1] && s[t + 2] === e[t + 2] && s[t + 3] === e[t + 3] && (a += 1); o += (i[n + 2] - i[n + 1]) * (1 - a / r); } return o } remove() { this._hash && this._hash.remove(); for (const e of this._controls) e.onRemove(this); this._controls = [], this._frame && (this._frame.cancel(), this._frame = null), this._renderTaskQueue.clear(), this._domRenderTaskQueue.clear(), this.style && this.style.destroy(), this.painter.destroy(), this.handlers && this.handlers.destroy(), this.handlers = void 0, this.setStyle(null), void 0 !== e.window && (e.window.removeEventListener("resize", this._onWindowResize, !1), e.window.removeEventListener("orientationchange", this._onWindowResize, !1), e.window.removeEventListener("webkitfullscreenchange", this._onWindowResize, !1), e.window.removeEventListener("online", this._onWindowOnline, !1), e.window.removeEventListener("visibilitychange", this._onVisibilityChange, !1)); const t = this.painter.context.gl.getExtension("WEBGL_lose_context"); t && t.loseContext(), this._canvas.removeEventListener("webglcontextlost", this._contextLost, !1), this._canvas.removeEventListener("webglcontextrestored", this._contextRestored, !1), this._canvasContainer.remove(), this._controlContainer.remove(), this._missingCSSCanary.remove(), this._canvas = void 0, this._canvasContainer = void 0, this._controlContainer = void 0, this._missingCSSCanary = void 0, this._container.classList.remove("mapboxgl-map"), this._container.removeEventListener("scroll", this._onMapScroll, !1), e.removeAuthState(this.painter.context.gl), this._removed = !0, this.fire(new e.Event("remove")); } triggerRepaint() { this._triggerFrame(!0); } _triggerFrame(t) { this._renderNextFrame = this._renderNextFrame || t, this.style && !this._frame && (this._frame = e.exported.frame((e => { const t = !!this._renderNextFrame; this._frame = null, this._renderNextFrame = null, t && this._render(e); }))); } _preloadTiles(t) { const i = this.style ? Object.values(this.style._sourceCaches) : []; return e.asyncAll(i, ((e, i) => e._preloadTiles(t, i)), (() => { this.triggerRepaint(); })), this } _onWindowOnline() { this._update(); } _onWindowResize(e) { this._trackResize && this.resize({ originalEvent: e })._update(); } _onVisibilityChange() { "hidden" === e.window.document.visibilityState && this._visibilityHidden++; } get showTileBoundaries() { return !!this._showTileBoundaries } set showTileBoundaries(e) { this._showTileBoundaries !== e && (this._showTileBoundaries = e, this._update()); } get showTerrainWireframe() { return !!this._showTerrainWireframe } set showTerrainWireframe(e) { this._showTerrainWireframe !== e && (this._showTerrainWireframe = e, this._update()); } get speedIndexTiming() { return !!this._speedIndexTiming } set speedIndexTiming(e) { this._speedIndexTiming !== e && (this._speedIndexTiming = e, this._update()); } get showPadding() { return !!this._showPadding } set showPadding(e) { this._showPadding !== e && (this._showPadding = e, this._update()); } get showCollisionBoxes() { return !!this._showCollisionBoxes } set showCollisionBoxes(e) { this._showCollisionBoxes !== e && (this._showCollisionBoxes = e, e ? this.style._generateCollisionBoxes() : this._update()); } get showOverdrawInspector() { return !!this._showOverdrawInspector } set showOverdrawInspector(e) { this._showOverdrawInspector !== e && (this._showOverdrawInspector = e, this._update()); } get repaint() { return !!this._repaint } set repaint(e) { this._repaint !== e && (this._repaint = e, this.triggerRepaint()); } get vertices() { return !!this._vertices } set vertices(e) { this._vertices = e, this._update(); } get showTileAABBs() { return !!this._showTileAABBs } set showTileAABBs(e) { this._showTileAABBs !== e && (this._showTileAABBs = e, e && this._update()); } _setCacheLimits(t, i) { e.setCacheLimits(t, i); } get version() { return e.version } }, NavigationControl: class { constructor(t) { this.options = e.extend({}, hn, t), this._container = n("div", "mapboxgl-ctrl mapboxgl-ctrl-group"), this._container.addEventListener("contextmenu", (e => e.preventDefault())), this.options.showZoom && (e.bindAll(["_setButtonTitle", "_updateZoomButtons"], this), this._zoomInButton = this._createButton("mapboxgl-ctrl-zoom-in", (e => { this._map && this._map.zoomIn({}, { originalEvent: e }); })), n("span", "mapboxgl-ctrl-icon", this._zoomInButton).setAttribute("aria-hidden", "true"), this._zoomOutButton = this._createButton("mapboxgl-ctrl-zoom-out", (e => { this._map && this._map.zoomOut({}, { originalEvent: e }); })), n("span", "mapboxgl-ctrl-icon", this._zoomOutButton).setAttribute("aria-hidden", "true")), this.options.showCompass && (e.bindAll(["_rotateCompassArrow"], this), this._compass = this._createButton("mapboxgl-ctrl-compass", (e => { const t = this._map; t && (this.options.visualizePitch ? t.resetNorthPitch({}, { originalEvent: e }) : t.resetNorth({}, { originalEvent: e })); })), this._compassIcon = n("span", "mapboxgl-ctrl-icon", this._compass), this._compassIcon.setAttribute("aria-hidden", "true")); } _updateZoomButtons() { const e = this._map; if (!e) return; const t = e.getZoom(), i = t === e.getMaxZoom(), o = t === e.getMinZoom(); this._zoomInButton.disabled = i, this._zoomOutButton.disabled = o, this._zoomInButton.setAttribute("aria-disabled", i.toString()), this._zoomOutButton.setAttribute("aria-disabled", o.toString()); } _rotateCompassArrow() { const e = this._map; if (!e) return; const t = this.options.visualizePitch ? `scale(${1/Math.pow(Math.cos(e.transform.pitch*(Math.PI/180)),.5)}) rotateX(${e.transform.pitch}deg) rotateZ(${e.transform.angle*(180/Math.PI)}deg)` : `rotate(${e.transform.angle*(180/Math.PI)}deg)`; e._requestDomTask((() => { this._compassIcon && (this._compassIcon.style.transform = t); })); } onAdd(e) { return this._map = e, this.options.showZoom && (this._setButtonTitle(this._zoomInButton, "ZoomIn"), this._setButtonTitle(this._zoomOutButton, "ZoomOut"), e.on("zoom", this._updateZoomButtons), this._updateZoomButtons()), this.options.showCompass && (this._setButtonTitle(this._compass, "ResetBearing"), this.options.visualizePitch && e.on("pitch", this._rotateCompassArrow), e.on("rotate", this._rotateCompassArrow), this._rotateCompassArrow(), this._handler = new un(e, this._compass, this.options.visualizePitch)), this._container } onRemove() { const e = this._map; e && (this._container.remove(), this.options.showZoom && e.off("zoom", this._updateZoomButtons), this.options.showCompass && (this.options.visualizePitch && e.off("pitch", this._rotateCompassArrow), e.off("rotate", this._rotateCompassArrow), this._handler && this._handler.off(), this._handler = void 0), this._map = void 0); } _createButton(e, t) { const i = n("button", e, this._container); return i.type = "button", i.addEventListener("click", t), i } _setButtonTitle(e, t) { if (!this._map) return; const i = this._map._getUIString(`NavigationControl.${t}`); e.setAttribute("aria-label", i), e.firstElementChild && e.firstElementChild.setAttribute("title", i); } }, GeolocateControl: class extends e.Evented { constructor(t) { super(), this.options = e.extend({ geolocation: e.window.navigator.geolocation }, _n, t), e.bindAll(["_onSuccess", "_onError", "_onZoom", "_finish", "_setupUI", "_updateCamera", "_updateMarker", "_updateMarkerRotation", "_onDeviceOrientation"], this), this._updateMarkerRotationThrottled = Jo(this._updateMarkerRotation, 20), this._numberOfWatches = 0; } onAdd(e) { return this._map = e, this._container = n("div", "mapboxgl-ctrl mapboxgl-ctrl-group"), this._checkGeolocationSupport(this._setupUI), this._container } onRemove() { void 0 !== this._geolocationWatchID && (this.options.geolocation.clearWatch(this._geolocationWatchID), this._geolocationWatchID = void 0), this.options.showUserLocation && this._userLocationDotMarker && this._userLocationDotMarker.remove(), this.options.showAccuracyCircle && this._accuracyCircleMarker && this._accuracyCircleMarker.remove(), this._container.remove(), this._map.off("zoom", this._onZoom), this._map = void 0, this._numberOfWatches = 0, this._noTimeout = !1; } _checkGeolocationSupport(t) { const i = (e = !!this.options.geolocation) => { this._supportsGeolocation = e, t(e); }; void 0 !== this._supportsGeolocation ? t(this._supportsGeolocation) : void 0 !== e.window.navigator.permissions ? e.window.navigator.permissions.query({ name: "geolocation" }).then((e => i("denied" !== e.state))).catch((() => i())) : i(); } _isOutOfMapMaxBounds(e) { const t = this._map.getMaxBounds(), i = e.coords; return !!t && (i.longitude < t.getWest() || i.longitude > t.getEast() || i.latitude < t.getSouth() || i.latitude > t.getNorth()) } _setErrorState() { switch (this._watchState) { case "WAITING_ACTIVE": this._watchState = "ACTIVE_ERROR", this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"), this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active-error"); break; case "ACTIVE_LOCK": this._watchState = "ACTIVE_ERROR", this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"), this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active-error"), this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting"); break; case "BACKGROUND": this._watchState = "BACKGROUND_ERROR", this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background"), this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background-error"), this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting"); } } _onSuccess(t) { if (this._map) { if (this._isOutOfMapMaxBounds(t)) return this._setErrorState(), this.fire(new e.Event("outofmaxbounds", t)), this._updateMarker(), void this._finish(); if (this.options.trackUserLocation) switch (this._lastKnownPosition = t, this._watchState) { case "WAITING_ACTIVE": case "ACTIVE_LOCK": case "ACTIVE_ERROR": this._watchState = "ACTIVE_LOCK", this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-waiting"), this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active-error"), this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active"); break; case "BACKGROUND": case "BACKGROUND_ERROR": this._watchState = "BACKGROUND", this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-waiting"), this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background-error"), this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background"); } this.options.showUserLocation && "OFF" !== this._watchState && this._updateMarker(t), this.options.trackUserLocation && "ACTIVE_LOCK" !== this._watchState || this._updateCamera(t), this.options.showUserLocation && this._dotElement.classList.remove("mapboxgl-user-location-dot-stale"), this.fire(new e.Event("geolocate", t)), this._finish(); } } _updateCamera(t) { const i = new e.LngLat(t.coords.longitude, t.coords.latitude), o = t.coords.accuracy, r = this._map.getBearing(), n = e.extend({ bearing: r }, this.options.fitBoundsOptions); this._map.fitBounds(i.toBounds(o), n, { geolocateSource: !0 }); } _updateMarker(t) { if (t) { const i = new e.LngLat(t.coords.longitude, t.coords.latitude); this._accuracyCircleMarker.setLngLat(i).addTo(this._map), this._userLocationDotMarker.setLngLat(i).addTo(this._map), this._accuracy = t.coords.accuracy, this.options.showUserLocation && this.options.showAccuracyCircle && this._updateCircleRadius(); } else this._userLocationDotMarker.remove(), this._accuracyCircleMarker.remove(); } _updateCircleRadius() { const t = this._map.transform, i = e.mercatorZfromAltitude(1, t._center.lat) * t.worldSize, o = Math.ceil(2 * this._accuracy * i); this._circleElement.style.width = `${o}px`, this._circleElement.style.height = `${o}px`; } _onZoom() { this.options.showUserLocation && this.options.showAccuracyCircle && this._updateCircleRadius(); } _updateMarkerRotation() { this._userLocationDotMarker && "number" == typeof this._heading ? (this._userLocationDotMarker.setRotation(this._heading), this._dotElement.classList.add("mapboxgl-user-location-show-heading")) : (this._dotElement.classList.remove("mapboxgl-user-location-show-heading"), this._userLocationDotMarker.setRotation(0)); } _onError(t) { if (this._map) { if (this.options.trackUserLocation) if (1 === t.code) { this._watchState = "OFF", this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-waiting"), this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"), this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active-error"), this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background"), this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background-error"), this._geolocateButton.disabled = !0; const e = this._map._getUIString("GeolocateControl.LocationNotAvailable"); this._geolocateButton.setAttribute("aria-label", e), this._geolocateButton.firstElementChild && this._geolocateButton.firstElementChild.setAttribute("title", e), void 0 !== this._geolocationWatchID && this._clearWatch(); } else { if (3 === t.code && this._noTimeout) return; this._setErrorState(); } "OFF" !== this._watchState && this.options.showUserLocation && this._dotElement.classList.add("mapboxgl-user-location-dot-stale"), this.fire(new e.Event("error", t)), this._finish(); } } _finish() { this._timeoutId && clearTimeout(this._timeoutId), this._timeoutId = void 0; } _setupUI(t) { if (void 0 !== this._map) { if (this._container.addEventListener("contextmenu", (e => e.preventDefault())), this._geolocateButton = n("button", "mapboxgl-ctrl-geolocate", this._container), n("span", "mapboxgl-ctrl-icon", this._geolocateButton).setAttribute("aria-hidden", "true"), this._geolocateButton.type = "button", !1 === t) { e.warnOnce("Geolocation support is not available so the GeolocateControl will be disabled."); const t = this._map._getUIString("GeolocateControl.LocationNotAvailable"); this._geolocateButton.disabled = !0, this._geolocateButton.setAttribute("aria-label", t), this._geolocateButton.firstElementChild && this._geolocateButton.firstElementChild.setAttribute("title", t); } else { const e = this._map._getUIString("GeolocateControl.FindMyLocation"); this._geolocateButton.setAttribute("aria-label", e), this._geolocateButton.firstElementChild && this._geolocateButton.firstElementChild.setAttribute("title", e); } this.options.trackUserLocation && (this._geolocateButton.setAttribute("aria-pressed", "false"), this._watchState = "OFF"), this.options.showUserLocation && (this._dotElement = n("div", "mapboxgl-user-location"), this._dotElement.appendChild(n("div", "mapboxgl-user-location-dot")), this._dotElement.appendChild(n("div", "mapboxgl-user-location-heading")), this._userLocationDotMarker = new on({ element: this._dotElement, rotationAlignment: "map", pitchAlignment: "map" }), this._circleElement = n("div", "mapboxgl-user-location-accuracy-circle"), this._accuracyCircleMarker = new on({ 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 = !0, this.options.trackUserLocation && this._map.on("movestart", (t => { t.geolocateSource || "ACTIVE_LOCK" !== this._watchState || t.originalEvent && "resize" === t.originalEvent.type || (this._watchState = "BACKGROUND", this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background"), this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"), this.fire(new e.Event("trackuserlocationend"))); })); } } _onDeviceOrientation(e) { this._userLocationDotMarker && (e.webkitCompassHeading ? this._heading = e.webkitCompassHeading : !0 === e.absolute && (this._heading = -1 * e.alpha), this._updateMarkerRotationThrottled()); } trigger() { if (!this._setup) return e.warnOnce("Geolocate control triggered before added to a map"), !1; if (this.options.trackUserLocation) { switch (this._watchState) { case "OFF": this._watchState = "WAITING_ACTIVE", this.fire(new e.Event("trackuserlocationstart")); break; case "WAITING_ACTIVE": case "ACTIVE_LOCK": case "ACTIVE_ERROR": case "BACKGROUND_ERROR": this._numberOfWatches--, this._noTimeout = !1, this._watchState = "OFF", this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-waiting"), this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"), this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active-error"), this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background"), this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background-error"), this.fire(new e.Event("trackuserlocationend")); break; case "BACKGROUND": this._watchState = "ACTIVE_LOCK", this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background"), this._lastKnownPosition && this._updateCamera(this._lastKnownPosition), this.fire(new e.Event("trackuserlocationstart")); } switch (this._watchState) { case "WAITING_ACTIVE": this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting"), this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active"); break; case "ACTIVE_LOCK": this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active"); break; case "ACTIVE_ERROR": this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting"), this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active-error"); break; case "BACKGROUND": this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background"); break; case "BACKGROUND_ERROR": this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting"), this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background-error"); } if ("OFF" === this._watchState && void 0 !== this._geolocationWatchID) this._clearWatch(); else if (void 0 === this._geolocationWatchID) { let e; this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting"), this._geolocateButton.setAttribute("aria-pressed", "true"), this._numberOfWatches++, this._numberOfWatches > 1 ? (e = { maximumAge: 6e5, timeout: 0 }, this._noTimeout = !0) : (e = this.options.positionOptions, this._noTimeout = !1), this._geolocationWatchID = this.options.geolocation.watchPosition(this._onSuccess, this._onError, e), this.options.showUserHeading && this._addDeviceOrientationListener(); } } else this.options.geolocation.getCurrentPosition(this._onSuccess, this._onError, this.options.positionOptions), this._timeoutId = setTimeout(this._finish, 1e4); return !0 } _addDeviceOrientationListener() { const t = () => { e.window.addEventListener("ondeviceorientationabsolute" in e.window ? "deviceorientationabsolute" : "deviceorientation", this._onDeviceOrientation); }; void 0 !== e.window.DeviceMotionEvent && "function" == typeof e.window.DeviceMotionEvent.requestPermission ? DeviceOrientationEvent.requestPermission().then((e => { "granted" === e && t(); })).catch(console.error) : t(); } _clearWatch() { this.options.geolocation.clearWatch(this._geolocationWatchID), e.window.removeEventListener("deviceorientation", this._onDeviceOrientation), e.window.removeEventListener("deviceorientationabsolute", this._onDeviceOrientation), this._geolocationWatchID = void 0, this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-waiting"), this._geolocateButton.setAttribute("aria-pressed", "false"), this.options.showUserLocation && this._updateMarker(null); } }, AttributionControl: Kr, ScaleControl: class { constructor(t) { this.options = e.extend({}, dn, t), function() { try { return new Intl.NumberFormat("en", { style: "unit", unitDisplay: "narrow", unit: "meter" }), !0 } catch (e) { return !1 } }() || (this._setScale = pn.bind(this)), e.bindAll(["_update", "_setScale", "setUnit"], this); } getDefaultPosition() { return "bottom-left" } _update() { const e = this.options.maxWidth || 100, t = this._map, i = t._containerHeight / 2, o = t._containerWidth / 2 - e / 2, r = t.unproject([o, i]), n = t.unproject([o + e, i]), s = r.distanceTo(n); if ("imperial" === this.options.unit) { const t = 3.2808 * s; t > 5280 ? this._setScale(e, t / 5280, "mile") : this._setScale(e, t, "foot"); } else "nautical" === this.options.unit ? this._setScale(e, s / 1852, "nautical-mile") : s >= 1e3 ? this._setScale(e, s / 1e3, "kilometer") : this._setScale(e, s, "meter"); } _setScale(e, t, i) { const o = mn(t), r = o / t; this._map._requestDomTask((() => { this._container.style.width = e * r + "px", this._container.innerHTML = "nautical-mile" !== i ? new Intl.NumberFormat(this._language, { style: "unit", unitDisplay: "narrow", unit: i }).format(o) : `${o} nm`; })); } onAdd(e) { return this._map = e, this._language = e.getLanguage(), this._container = n("div", "mapboxgl-ctrl mapboxgl-ctrl-scale", e.getContainer()), this._container.dir = "auto", this._map.on("move", this._update), this._update(), this._container } onRemove() { this._container.remove(), this._map.off("move", this._update), this._map = void 0; } _setLanguage(e) { this._language = e, this._update(); } setUnit(e) { this.options.unit = e, this._update(); } }, FullscreenControl: class { constructor(t) { this._fullscreen = !1, t && t.container && (t.container instanceof e.window.HTMLElement ? this._container = t.container : e.warnOnce("Full screen control 'container' must be a DOM element.")), e.bindAll(["_onClickFullscreen", "_changeIcon"], this), "onfullscreenchange" in e.window.document ? this._fullscreenchange = "fullscreenchange" : "onwebkitfullscreenchange" in e.window.document && (this._fullscreenchange = "webkitfullscreenchange"); } onAdd(t) { return this._map = t, this._container || (this._container = this._map.getContainer()), this._controlContainer = n("div", "mapboxgl-ctrl mapboxgl-ctrl-group"), this._checkFullscreenSupport() ? this._setupUI() : (this._controlContainer.style.display = "none", e.warnOnce("This device does not support fullscreen mode.")), this._controlContainer } onRemove() { this._controlContainer.remove(), this._map = null, e.window.document.removeEventListener(this._fullscreenchange, this._changeIcon); } _checkFullscreenSupport() { return !(!e.window.document.fullscreenEnabled && !e.window.document.webkitFullscreenEnabled) } _setupUI() { const t = this._fullscreenButton = n("button", "mapboxgl-ctrl-fullscreen", this._controlContainer); n("span", "mapboxgl-ctrl-icon", t).setAttribute("aria-hidden", "true"), t.type = "button", this._updateTitle(), this._fullscreenButton.addEventListener("click", this._onClickFullscreen), e.window.document.addEventListener(this._fullscreenchange, this._changeIcon); } _updateTitle() { const e = this._getTitle(); this._fullscreenButton.setAttribute("aria-label", e), this._fullscreenButton.firstElementChild && this._fullscreenButton.firstElementChild.setAttribute("title", e); } _getTitle() { return this._map._getUIString(this._isFullscreen() ? "FullscreenControl.Exit" : "FullscreenControl.Enter") } _isFullscreen() { return this._fullscreen } _changeIcon() { (e.window.document.fullscreenElement || e.window.document.webkitFullscreenElement) === this._container !== this._fullscreen && (this._fullscreen = !this._fullscreen, this._fullscreenButton.classList.toggle("mapboxgl-ctrl-shrink"), this._fullscreenButton.classList.toggle("mapboxgl-ctrl-fullscreen"), this._updateTitle()); } _onClickFullscreen() { this._isFullscreen() ? e.window.document.exitFullscreen ? e.window.document.exitFullscreen() : e.window.document.webkitCancelFullScreen && e.window.document.webkitCancelFullScreen() : this._container.requestFullscreen ? this._container.requestFullscreen() : this._container.webkitRequestFullscreen && this._container.webkitRequestFullscreen(); } }, Popup: class extends e.Evented { constructor(t) { super(), this.options = e.extend(Object.create(rn), t), e.bindAll(["_update", "_onClose", "remove", "_onMouseEvent"], this), this._classList = new Set(t && t.className ? t.className.trim().split(/\s+/) : []); } addTo(t) { return this._map && this.remove(), this._map = t, this.options.closeOnClick && t.on("preclick", this._onClose), this.options.closeOnMove && t.on("move", this._onClose), t.on("remove", this.remove), this._update(), t._addPopup(this), this._focusFirstElement(), this._trackPointer ? (t.on("mousemove", this._onMouseEvent), t.on("mouseup", this._onMouseEvent), t._canvasContainer.classList.add("mapboxgl-track-pointer")) : t.on("move", this._update), this.fire(new e.Event("open")), this } isOpen() { return !!this._map } remove() { this._content && this._content.remove(), this._container && (this._container.remove(), this._container = void 0); const t = this._map; return t && (t.off("move", this._update), t.off("move", this._onClose), t.off("preclick", this._onClose), t.off("click", this._onClose), t.off("remove", this.remove), t.off("mousemove", this._onMouseEvent), t.off("mouseup", this._onMouseEvent), t.off("drag", this._onMouseEvent), t._canvasContainer && t._canvasContainer.classList.remove("mapboxgl-track-pointer"), t._removePopup(this), this._map = void 0), this.fire(new e.Event("close")), this } getLngLat() { return this._lngLat } setLngLat(t) { this._lngLat = e.LngLat.convert(t), this._pos = null, this._trackPointer = !1, this._update(); const i = this._map; return i && (i.on("move", this._update), i.off("mousemove", this._onMouseEvent), i._canvasContainer.classList.remove("mapboxgl-track-pointer")), this } trackPointer() { this._trackPointer = !0, this._pos = null, this._update(); const e = this._map; return e && (e.off("move", this._update), e.on("mousemove", this._onMouseEvent), e.on("drag", this._onMouseEvent), e._canvasContainer.classList.add("mapboxgl-track-pointer")), this } getElement() { return this._container } setText(t) { return this.setDOMContent(e.window.document.createTextNode(t)) } setHTML(t) { const i = e.window.document.createDocumentFragment(), o = e.window.document.createElement("body"); let r; for (o.innerHTML = t; r = o.firstChild, r;) i.appendChild(r); return this.setDOMContent(i) } getMaxWidth() { return this._container && this._container.style.maxWidth } setMaxWidth(e) { return this.options.maxWidth = e, this._update(), this } setDOMContent(e) { let t = this._content; if (t) for (; t.hasChildNodes();) t.firstChild && t.removeChild(t.firstChild); else t = this._content = n("div", "mapboxgl-popup-content", this._container || void 0); if (t.appendChild(e), this.options.closeButton) { const e = this._closeButton = n("button", "mapboxgl-popup-close-button", t); e.type = "button", e.setAttribute("aria-label", "Close popup"), e.setAttribute("aria-hidden", "true"), e.innerHTML = "×", e.addEventListener("click", this._onClose); } return this._update(), this._focusFirstElement(), this } addClassName(e) { return this._classList.add(e), this._updateClassList(), this } removeClassName(e) { return this._classList.delete(e), this._updateClassList(), this } setOffset(e) { return this.options.offset = e, this._update(), this } toggleClassName(e) { let t; return this._classList.delete(e) ? t = !1 : (this._classList.add(e), t = !0), this._updateClassList(), t } _onMouseEvent(e) { this._update(e.point); } _getAnchor(e) { if (this.options.anchor) return this.options.anchor; const t = this._map, i = this._container, o = this._pos; if (!t || !i || !o) return "bottom"; const r = i.offsetWidth, n = i.offsetHeight, s = o.x < r / 2, a = o.x > t.transform.width - r / 2; if (o.y + e < n) return s ? "top-left" : a ? "top-right" : "top"; if (o.y > t.transform.height - n) { if (s) return "bottom-left"; if (a) return "bottom-right" } return s ? "left" : a ? "right" : "bottom" } _updateClassList() { const e = this._container; if (!e) return; const t = [...this._classList]; t.push("mapboxgl-popup"), this._anchor && t.push(`mapboxgl-popup-anchor-${this._anchor}`), this._trackPointer && t.push("mapboxgl-popup-track-pointer"), e.className = t.join(" "); } _update(t) { const i = this._map, o = this._content; if (!i || !this._lngLat && !this._trackPointer || !o) return; let r = this._container; if (r || (r = this._container = n("div", "mapboxgl-popup", i.getContainer()), this._tip = n("div", "mapboxgl-popup-tip", r), r.appendChild(o)), this.options.maxWidth && r.style.maxWidth !== this.options.maxWidth && (r.style.maxWidth = this.options.maxWidth), i.transform.renderWorldCopies && !this._trackPointer && (this._lngLat = en(this._lngLat, this._pos, i.transform)), !this._trackPointer || t) { const e = this._pos = this._trackPointer && t ? t : i.project(this._lngLat), o = sn(this.options.offset), r = this._anchor = this._getAnchor(o.y), n = sn(this.options.offset, r), s = e.add(n).round(); i._requestDomTask((() => { this._container && r && (this._container.style.transform = `${tn[r]} translate(${s.x}px,${s.y}px)`); })); } if (!this._marker && i._showingGlobe()) { const t = e.isLngLatBehindGlobe(i.transform, this._lngLat) ? 0 : 1; this._setOpacity(t); } this._updateClassList(); } _focusFirstElement() { if (!this.options.focusAfterOpen || !this._container) return; const e = this._container.querySelector(nn); e && e.focus(); } _onClose() { this.remove(); } _setOpacity(e) { this._container && (this._container.style.opacity = `${e}`), this._content && (this._content.style.pointerEvents = e ? "auto" : "none"); } }, Marker: on, Style: Qt, LngLat: e.LngLat, LngLatBounds: e.LngLatBounds, Point: e.pointGeometry, MercatorCoordinate: e.MercatorCoordinate, FreeCameraOptions: Zo, Evented: e.Evented, config: e.config, prewarm: function() { je().acquire(Ue); }, clearPrewarmedResources: function() { const e = Ge; e && (e.isPreloaded() && 1 === e.numActive() ? (e.release(Ue), Ge = 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()")); }, get accessToken() { return e.config.ACCESS_TOKEN }, set accessToken(t) { e.config.ACCESS_TOKEN = t; }, get baseApiUrl() { return e.config.API_URL }, set baseApiUrl(t) { e.config.API_URL = t; }, get workerCount() { return Ne.workerCount }, set workerCount(e) { Ne.workerCount = e; }, get maxParallelImageRequests() { return e.config.MAX_PARALLEL_IMAGE_REQUESTS }, set maxParallelImageRequests(t) { e.config.MAX_PARALLEL_IMAGE_REQUESTS = t; }, clearStorage(t) { e.clearTileCache(t); }, workerUrl: "", workerClass: null, setNow: e.exported.setNow, restoreNow: e.exported.restoreNow }; return fn })); // var mapboxgl$1 = mapboxgl; return mapboxgl$1; })); //# sourceMappingURL=mapbox-gl.js.map